@weave-design-system/react 0.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 (230) hide show
  1. package/dist/index.cjs +7729 -0
  2. package/dist/index.cjs.map +1 -0
  3. package/dist/index.d.cts +677 -0
  4. package/dist/index.d.ts +677 -0
  5. package/dist/index.js +7654 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/theme.css +2 -0
  8. package/dist/tokens.cjs +78 -0
  9. package/dist/tokens.cjs.map +1 -0
  10. package/dist/tokens.d.cts +67 -0
  11. package/dist/tokens.d.ts +67 -0
  12. package/dist/tokens.js +70 -0
  13. package/dist/tokens.js.map +1 -0
  14. package/package.json +103 -0
  15. package/src/data-display/activity-feed/ActivityFeed.stories.tsx +16 -0
  16. package/src/data-display/activity-feed/ActivityFeed.test.tsx +11 -0
  17. package/src/data-display/activity-feed/ActivityFeed.tsx +34 -0
  18. package/src/data-display/activity-feed/index.ts +2 -0
  19. package/src/data-display/circular-progress/CircularProgress.stories.tsx +10 -0
  20. package/src/data-display/circular-progress/CircularProgress.test.tsx +11 -0
  21. package/src/data-display/circular-progress/CircularProgress.tsx +35 -0
  22. package/src/data-display/circular-progress/index.ts +2 -0
  23. package/src/data-display/empty-state/EmptyState.stories.tsx +15 -0
  24. package/src/data-display/empty-state/EmptyState.test.tsx +18 -0
  25. package/src/data-display/empty-state/EmptyState.tsx +34 -0
  26. package/src/data-display/empty-state/index.ts +2 -0
  27. package/src/data-display/progress-bar/ProgressBar.stories.tsx +10 -0
  28. package/src/data-display/progress-bar/ProgressBar.test.tsx +15 -0
  29. package/src/data-display/progress-bar/ProgressBar.tsx +38 -0
  30. package/src/data-display/progress-bar/index.ts +2 -0
  31. package/src/data-display/stat-card/StatCard.stories.tsx +10 -0
  32. package/src/data-display/stat-card/StatCard.test.tsx +15 -0
  33. package/src/data-display/stat-card/StatCard.tsx +40 -0
  34. package/src/data-display/stat-card/index.ts +2 -0
  35. package/src/data-display/table/Table.stories.tsx +44 -0
  36. package/src/data-display/table/Table.test.tsx +16 -0
  37. package/src/data-display/table/Table.tsx +71 -0
  38. package/src/data-display/table/index.ts +1 -0
  39. package/src/data-display/timeline/Timeline.stories.tsx +16 -0
  40. package/src/data-display/timeline/Timeline.test.tsx +11 -0
  41. package/src/data-display/timeline/Timeline.tsx +44 -0
  42. package/src/data-display/timeline/index.ts +2 -0
  43. package/src/docs/ComponentOverview.mdx +192 -0
  44. package/src/docs/DesignTokens.mdx +235 -0
  45. package/src/docs/GettingStarted.mdx +145 -0
  46. package/src/feedback/alert-banner/AlertBanner.stories.tsx +10 -0
  47. package/src/feedback/alert-banner/AlertBanner.test.tsx +16 -0
  48. package/src/feedback/alert-banner/AlertBanner.tsx +47 -0
  49. package/src/feedback/alert-banner/index.ts +2 -0
  50. package/src/feedback/modal/Modal.stories.tsx +31 -0
  51. package/src/feedback/modal/Modal.test.tsx +33 -0
  52. package/src/feedback/modal/Modal.tsx +88 -0
  53. package/src/feedback/modal/index.ts +2 -0
  54. package/src/feedback/skeleton-loader/SkeletonLoader.stories.tsx +23 -0
  55. package/src/feedback/skeleton-loader/SkeletonLoader.test.tsx +14 -0
  56. package/src/feedback/skeleton-loader/SkeletonLoader.tsx +61 -0
  57. package/src/feedback/skeleton-loader/index.ts +2 -0
  58. package/src/feedback/toast/Toast.stories.tsx +27 -0
  59. package/src/feedback/toast/Toast.test.tsx +32 -0
  60. package/src/feedback/toast/Toast.tsx +106 -0
  61. package/src/feedback/toast/index.ts +2 -0
  62. package/src/hooks/index.ts +3 -0
  63. package/src/hooks/use-controllable-state.ts +34 -0
  64. package/src/hooks/use-focus-trap.ts +56 -0
  65. package/src/hooks/use-reduced-motion.ts +17 -0
  66. package/src/index.ts +148 -0
  67. package/src/layout/card/Card.stories.tsx +45 -0
  68. package/src/layout/card/Card.test.tsx +23 -0
  69. package/src/layout/card/Card.tsx +42 -0
  70. package/src/layout/card/Card.types.ts +6 -0
  71. package/src/layout/card/index.ts +2 -0
  72. package/src/layout/command-palette/CommandPalette.stories.tsx +34 -0
  73. package/src/layout/command-palette/CommandPalette.test.tsx +43 -0
  74. package/src/layout/command-palette/CommandPalette.tsx +188 -0
  75. package/src/layout/command-palette/CommandPalette.types.ts +18 -0
  76. package/src/layout/command-palette/index.ts +2 -0
  77. package/src/layout/sidebar/Sidebar.stories.tsx +60 -0
  78. package/src/layout/sidebar/Sidebar.test.tsx +27 -0
  79. package/src/layout/sidebar/Sidebar.tsx +57 -0
  80. package/src/layout/sidebar/Sidebar.types.ts +14 -0
  81. package/src/layout/sidebar/index.ts +2 -0
  82. package/src/layout/top-bar/TopBar.stories.tsx +51 -0
  83. package/src/layout/top-bar/TopBar.test.tsx +18 -0
  84. package/src/layout/top-bar/TopBar.tsx +19 -0
  85. package/src/layout/top-bar/TopBar.types.ts +10 -0
  86. package/src/layout/top-bar/index.ts +2 -0
  87. package/src/navigation/breadcrumbs/Breadcrumbs.stories.tsx +30 -0
  88. package/src/navigation/breadcrumbs/Breadcrumbs.test.tsx +43 -0
  89. package/src/navigation/breadcrumbs/Breadcrumbs.tsx +45 -0
  90. package/src/navigation/breadcrumbs/Breadcrumbs.types.ts +12 -0
  91. package/src/navigation/breadcrumbs/index.ts +2 -0
  92. package/src/navigation/sidebar-nav-item/SidebarNavItem.stories.tsx +41 -0
  93. package/src/navigation/sidebar-nav-item/SidebarNavItem.test.tsx +46 -0
  94. package/src/navigation/sidebar-nav-item/SidebarNavItem.tsx +38 -0
  95. package/src/navigation/sidebar-nav-item/SidebarNavItem.types.ts +12 -0
  96. package/src/navigation/sidebar-nav-item/index.ts +2 -0
  97. package/src/navigation/tabs/Tabs.stories.tsx +47 -0
  98. package/src/navigation/tabs/Tabs.test.tsx +67 -0
  99. package/src/navigation/tabs/Tabs.tsx +111 -0
  100. package/src/navigation/tabs/Tabs.types.ts +36 -0
  101. package/src/navigation/tabs/index.ts +2 -0
  102. package/src/patterns/accordion/Accordion.stories.tsx +25 -0
  103. package/src/patterns/accordion/Accordion.test.tsx +44 -0
  104. package/src/patterns/accordion/Accordion.tsx +92 -0
  105. package/src/patterns/accordion/index.ts +2 -0
  106. package/src/patterns/action-menu/ActionMenu.stories.tsx +18 -0
  107. package/src/patterns/action-menu/ActionMenu.test.tsx +18 -0
  108. package/src/patterns/action-menu/ActionMenu.tsx +41 -0
  109. package/src/patterns/action-menu/index.ts +2 -0
  110. package/src/patterns/carousel/Carousel.stories.tsx +16 -0
  111. package/src/patterns/carousel/Carousel.test.tsx +16 -0
  112. package/src/patterns/carousel/Carousel.tsx +69 -0
  113. package/src/patterns/carousel/index.ts +2 -0
  114. package/src/patterns/image-placeholder/ImagePlaceholder.stories.tsx +9 -0
  115. package/src/patterns/image-placeholder/ImagePlaceholder.test.tsx +10 -0
  116. package/src/patterns/image-placeholder/ImagePlaceholder.tsx +21 -0
  117. package/src/patterns/image-placeholder/index.ts +2 -0
  118. package/src/patterns/notification-dot/NotificationDot.stories.tsx +17 -0
  119. package/src/patterns/notification-dot/NotificationDot.test.tsx +14 -0
  120. package/src/patterns/notification-dot/NotificationDot.tsx +18 -0
  121. package/src/patterns/notification-dot/index.ts +2 -0
  122. package/src/patterns/pagination/Pagination.stories.tsx +14 -0
  123. package/src/patterns/pagination/Pagination.test.tsx +22 -0
  124. package/src/patterns/pagination/Pagination.tsx +67 -0
  125. package/src/patterns/pagination/index.ts +2 -0
  126. package/src/primitives/avatar/Avatar.stories.tsx +46 -0
  127. package/src/primitives/avatar/Avatar.test.tsx +35 -0
  128. package/src/primitives/avatar/Avatar.tsx +49 -0
  129. package/src/primitives/avatar/Avatar.types.ts +21 -0
  130. package/src/primitives/avatar/AvatarGroup.tsx +27 -0
  131. package/src/primitives/avatar/index.ts +3 -0
  132. package/src/primitives/badge/Badge.stories.tsx +28 -0
  133. package/src/primitives/badge/Badge.test.tsx +23 -0
  134. package/src/primitives/badge/Badge.tsx +44 -0
  135. package/src/primitives/badge/Badge.types.ts +14 -0
  136. package/src/primitives/badge/index.ts +2 -0
  137. package/src/primitives/button/Button.stories.tsx +81 -0
  138. package/src/primitives/button/Button.test.tsx +64 -0
  139. package/src/primitives/button/Button.tsx +85 -0
  140. package/src/primitives/button/Button.types.ts +17 -0
  141. package/src/primitives/button/index.ts +2 -0
  142. package/src/primitives/checkbox/Checkbox.stories.tsx +27 -0
  143. package/src/primitives/checkbox/Checkbox.test.tsx +30 -0
  144. package/src/primitives/checkbox/Checkbox.tsx +79 -0
  145. package/src/primitives/checkbox/Checkbox.types.ts +12 -0
  146. package/src/primitives/checkbox/index.ts +2 -0
  147. package/src/primitives/combobox/Combobox.stories.tsx +44 -0
  148. package/src/primitives/combobox/Combobox.test.tsx +44 -0
  149. package/src/primitives/combobox/Combobox.tsx +201 -0
  150. package/src/primitives/combobox/Combobox.types.ts +25 -0
  151. package/src/primitives/combobox/index.ts +2 -0
  152. package/src/primitives/date-input/DateInput.stories.tsx +23 -0
  153. package/src/primitives/date-input/DateInput.test.tsx +22 -0
  154. package/src/primitives/date-input/DateInput.tsx +66 -0
  155. package/src/primitives/date-input/DateInput.types.ts +10 -0
  156. package/src/primitives/date-input/index.ts +2 -0
  157. package/src/primitives/file-upload/FileUploadDropzone.stories.tsx +27 -0
  158. package/src/primitives/file-upload/FileUploadDropzone.test.tsx +26 -0
  159. package/src/primitives/file-upload/FileUploadDropzone.tsx +99 -0
  160. package/src/primitives/file-upload/FileUploadDropzone.types.ts +14 -0
  161. package/src/primitives/file-upload/index.ts +2 -0
  162. package/src/primitives/input/InputGroup.stories.tsx +31 -0
  163. package/src/primitives/input/InputGroup.test.tsx +40 -0
  164. package/src/primitives/input/InputGroup.tsx +65 -0
  165. package/src/primitives/input/InputGroup.types.ts +12 -0
  166. package/src/primitives/input/index.ts +2 -0
  167. package/src/primitives/link/Link.stories.tsx +28 -0
  168. package/src/primitives/link/Link.test.tsx +23 -0
  169. package/src/primitives/link/Link.tsx +28 -0
  170. package/src/primitives/link/Link.types.ts +8 -0
  171. package/src/primitives/link/index.ts +2 -0
  172. package/src/primitives/radio/Radio.stories.tsx +29 -0
  173. package/src/primitives/radio/Radio.test.tsx +32 -0
  174. package/src/primitives/radio/Radio.tsx +59 -0
  175. package/src/primitives/radio/Radio.types.ts +6 -0
  176. package/src/primitives/radio/index.ts +2 -0
  177. package/src/primitives/select/SelectGroup.stories.tsx +33 -0
  178. package/src/primitives/select/SelectGroup.test.tsx +34 -0
  179. package/src/primitives/select/SelectGroup.tsx +72 -0
  180. package/src/primitives/select/SelectGroup.types.ts +12 -0
  181. package/src/primitives/select/index.ts +2 -0
  182. package/src/primitives/slider/Slider.stories.tsx +23 -0
  183. package/src/primitives/slider/Slider.test.tsx +28 -0
  184. package/src/primitives/slider/Slider.tsx +80 -0
  185. package/src/primitives/slider/Slider.types.ts +22 -0
  186. package/src/primitives/slider/index.ts +2 -0
  187. package/src/primitives/textarea/TextareaGroup.stories.tsx +27 -0
  188. package/src/primitives/textarea/TextareaGroup.test.tsx +24 -0
  189. package/src/primitives/textarea/TextareaGroup.tsx +59 -0
  190. package/src/primitives/textarea/TextareaGroup.types.ts +10 -0
  191. package/src/primitives/textarea/index.ts +2 -0
  192. package/src/primitives/toggle/Toggle.stories.tsx +27 -0
  193. package/src/primitives/toggle/Toggle.test.tsx +31 -0
  194. package/src/primitives/toggle/Toggle.tsx +65 -0
  195. package/src/primitives/toggle/Toggle.types.ts +16 -0
  196. package/src/primitives/toggle/index.ts +2 -0
  197. package/src/primitives/tooltip/Tooltip.stories.tsx +45 -0
  198. package/src/primitives/tooltip/Tooltip.test.tsx +28 -0
  199. package/src/primitives/tooltip/Tooltip.tsx +94 -0
  200. package/src/primitives/tooltip/Tooltip.types.ts +16 -0
  201. package/src/primitives/tooltip/index.ts +2 -0
  202. package/src/productivity/comment-thread/CommentThread.stories.tsx +20 -0
  203. package/src/productivity/comment-thread/CommentThread.test.tsx +21 -0
  204. package/src/productivity/comment-thread/CommentThread.tsx +47 -0
  205. package/src/productivity/comment-thread/index.ts +2 -0
  206. package/src/productivity/kanban-board/KanbanBoard.tsx +41 -0
  207. package/src/productivity/kanban-board/index.ts +2 -0
  208. package/src/productivity/kanban-column/KanbanColumn.stories.tsx +131 -0
  209. package/src/productivity/kanban-column/KanbanColumn.test.tsx +18 -0
  210. package/src/productivity/kanban-column/KanbanColumn.tsx +58 -0
  211. package/src/productivity/kanban-column/SortableTaskCard.tsx +46 -0
  212. package/src/productivity/kanban-column/index.ts +4 -0
  213. package/src/productivity/priority-selector/PrioritySelector.stories.tsx +14 -0
  214. package/src/productivity/priority-selector/PrioritySelector.test.tsx +18 -0
  215. package/src/productivity/priority-selector/PrioritySelector.tsx +40 -0
  216. package/src/productivity/priority-selector/index.ts +2 -0
  217. package/src/productivity/rich-text-toolbar/RichTextToolbar.stories.tsx +19 -0
  218. package/src/productivity/rich-text-toolbar/RichTextToolbar.test.tsx +21 -0
  219. package/src/productivity/rich-text-toolbar/RichTextToolbar.tsx +50 -0
  220. package/src/productivity/rich-text-toolbar/index.ts +2 -0
  221. package/src/productivity/task-card/TaskCard.stories.tsx +20 -0
  222. package/src/productivity/task-card/TaskCard.test.tsx +21 -0
  223. package/src/productivity/task-card/TaskCard.tsx +76 -0
  224. package/src/productivity/task-card/index.ts +2 -0
  225. package/src/test-setup.ts +1 -0
  226. package/src/tokens/index.ts +1 -0
  227. package/src/tokens/tokens.ts +71 -0
  228. package/src/tokens/weave-theme.css +168 -0
  229. package/src/utils/cn.ts +6 -0
  230. package/src/utils/index.ts +1 -0
package/dist/theme.css ADDED
@@ -0,0 +1,2 @@
1
+ /*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */
2
+ @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-x-reverse:0;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:"Satoshi", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--color-black:#000;--color-white:#fff;--spacing:4px;--container-xs:20rem;--container-sm:24rem;--container-md:28rem;--container-lg:32rem;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wider:.05em;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--ease-in:cubic-bezier(.55, 0, 1, .45);--ease-out:cubic-bezier(.22, 1, .36, 1);--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-bg:#faf7f2;--color-surface:#f0ebe3;--color-border:#d9d2c7;--color-text-primary:#2c2825;--color-text-secondary:#6b635a;--color-rust:#b85c38;--color-rust-light:#f0d5c5;--color-rust-dark:#8e4429;--color-forest:#3d6b5e;--color-forest-light:#d4e5df;--color-success:#5e8a6b;--color-success-light:#dde9e0;--color-warning:#c49a3c;--color-warning-light:#f5edd4;--color-error:#b84a3c;--color-error-light:#f3d9d5;--color-info:#7a8a9a;--color-info-light:#e0e5ea;--color-saffron:#d4923a;--color-saffron-light:#f5e3c8;--text-display:2.5rem;--text-h1:2rem;--text-h2:1.625rem;--text-h3:1.375rem;--text-body-lg:1.125rem;--text-body:1rem;--text-body-sm:.875rem;--text-caption:.75rem;--text-code:.875rem;--leading-h1:40px;--leading-h2:34px;--leading-h3:30px;--leading-body-lg:28px;--leading-body:24px;--leading-body-sm:20px;--leading-caption:16px;--radius-full:9999px;--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--animate-skeleton-pulse:skeleton-pulse 2s ease-in-out infinite;--animate-fade-in:fade-in var(--duration-slow) var(--ease-out);--animate-scale-in:scale-in var(--duration-slow) var(--ease-out);--animate-slide-in-right:slide-in-right var(--duration-normal) var(--ease-out)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.-top-0\.5{top:calc(var(--spacing) * -.5)}.top-1\/2{top:50%}.-right-0\.5{right:calc(var(--spacing) * -.5)}.right-2{right:calc(var(--spacing) * 2)}.right-3{right:calc(var(--spacing) * 3)}.right-4{right:calc(var(--spacing) * 4)}.bottom-3{bottom:calc(var(--spacing) * 3)}.bottom-4{bottom:calc(var(--spacing) * 4)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing) * 2)}.z-50{z-index:50}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.mx-1{margin-inline:calc(var(--spacing) * 1)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-6{margin-top:calc(var(--spacing) * 6)}.-mr-0\.5{margin-right:calc(var(--spacing) * -.5)}.-mb-px{margin-bottom:-1px}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.-ml-1{margin-left:calc(var(--spacing) * -1)}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.ml-4{margin-left:calc(var(--spacing) * 4)}.ml-10{margin-left:calc(var(--spacing) * 10)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-14{height:calc(var(--spacing) * 14)}.h-16{height:calc(var(--spacing) * 16)}.h-48{height:calc(var(--spacing) * 48)}.h-\[500px\]{height:500px}.h-full{height:100%}.h-px{height:1px}.max-h-60{max-height:calc(var(--spacing) * 60)}.max-h-72{max-height:calc(var(--spacing) * 72)}.min-h-25{min-height:calc(var(--spacing) * 25)}.min-h-\[80px\]{min-height:80px}.w-2{width:calc(var(--spacing) * 2)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-3{width:calc(var(--spacing) * 3)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-8{width:calc(var(--spacing) * 8)}.w-11{width:calc(var(--spacing) * 11)}.w-14{width:calc(var(--spacing) * 14)}.w-16{width:calc(var(--spacing) * 16)}.w-56{width:calc(var(--spacing) * 56)}.w-60{width:calc(var(--spacing) * 60)}.w-72{width:calc(var(--spacing) * 72)}.w-full{width:100%}.w-px{width:1px}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.max-w-xs{max-width:var(--container-xs)}.min-w-0{min-width:calc(var(--spacing) * 0)}.min-w-\[36px\]{min-width:36px}.flex-1{flex:1}.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[2px\]{--tw-translate-x:2px;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-\[22px\]{--tw-translate-x:22px;translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.scale-0{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-\[1\.02\]{scale:1.02}.-rotate-90{rotate:-90deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-fade-in{animation:var(--animate-fade-in)}.animate-scale-in{animation:var(--animate-scale-in)}.animate-skeleton-pulse{animation:var(--animate-skeleton-pulse)}.animate-slide-in-right{animation:var(--animate-slide-in-right)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-grab{cursor:grab}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-y{resize:vertical}.appearance-none{appearance:none}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0\.5{gap:calc(var(--spacing) * .5)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.-space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * -2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * -2) * calc(1 - var(--tw-space-x-reverse)))}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-border>:not(:last-child)){border-color:var(--color-border)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:var(--radius-full)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-border{border-color:var(--color-border)}.border-error{border-color:var(--color-error)}.border-info{border-color:var(--color-info)}.border-rust{border-color:var(--color-rust)}.border-success{border-color:var(--color-success)}.border-transparent{border-color:#0000}.border-warning{border-color:var(--color-warning)}.bg-bg{background-color:var(--color-bg)}.bg-border{background-color:var(--color-border)}.bg-error{background-color:var(--color-error)}.bg-error-light{background-color:var(--color-error-light)}.bg-forest{background-color:var(--color-forest)}.bg-forest-light{background-color:var(--color-forest-light)}.bg-info-light{background-color:var(--color-info-light)}.bg-rust{background-color:var(--color-rust)}.bg-rust-light{background-color:var(--color-rust-light)}.bg-rust-light\/30{background-color:#f0d5c54d}@supports (color:color-mix(in lab, red, red)){.bg-rust-light\/30{background-color:color-mix(in oklab, var(--color-rust-light) 30%, transparent)}}.bg-saffron-light{background-color:var(--color-saffron-light)}.bg-success-light{background-color:var(--color-success-light)}.bg-surface{background-color:var(--color-surface)}.bg-surface\/50{background-color:#f0ebe380}@supports (color:color-mix(in lab, red, red)){.bg-surface\/50{background-color:color-mix(in oklab, var(--color-surface) 50%, transparent)}}.bg-text-primary{background-color:var(--color-text-primary)}.bg-text-primary\/30{background-color:#2c28254d}@supports (color:color-mix(in lab, red, red)){.bg-text-primary\/30{background-color:color-mix(in oklab, var(--color-text-primary) 30%, transparent)}}.bg-transparent{background-color:#0000}.bg-warning{background-color:var(--color-warning)}.bg-warning-light{background-color:var(--color-warning-light)}.bg-white{background-color:var(--color-white)}.bg-white\/60{background-color:#fff9}@supports (color:color-mix(in lab, red, red)){.bg-white\/60{background-color:color-mix(in oklab, var(--color-white) 60%, transparent)}}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab, red, red)){.bg-white\/80{background-color:color-mix(in oklab, var(--color-white) 80%, transparent)}}.object-cover{object-fit:cover}.p-0\.5{padding:calc(var(--spacing) * .5)}.p-1{padding:calc(var(--spacing) * 1)}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.p-20{padding:calc(var(--spacing) * 20)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-1\.5{padding-inline:calc(var(--spacing) * 1.5)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-16{padding-block:calc(var(--spacing) * 16)}.pt-\[20vh\]{padding-top:20vh}.pr-10{padding-right:calc(var(--spacing) * 10)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-6{padding-bottom:calc(var(--spacing) * 6)}.text-center{text-align:center}.text-left{text-align:left}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.text-error{color:var(--color-error)}.text-forest{color:var(--color-forest)}.text-info{color:var(--color-info)}.text-rust{color:var(--color-rust)}.text-rust-dark{color:var(--color-rust-dark)}.text-saffron{color:var(--color-saffron)}.text-success{color:var(--color-success)}.text-text-primary{color:var(--color-text-primary)}.text-text-secondary{color:var(--color-text-secondary)}.text-warning{color:var(--color-warning)}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-1{--tw-shadow:0 1px 3px var(--tw-shadow-color,#2c28250f);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-2{--tw-shadow:0 4px 12px var(--tw-shadow-color,#2c282514);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-3{--tw-shadow:0 8px 24px var(--tw-shadow-color,#2c28251f);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-4{--tw-shadow:0 16px 48px var(--tw-shadow-color,#2c282529);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-bg{--tw-ring-color:var(--color-bg)}.ring-white{--tw-ring-color:var(--color-white)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.ease-spring{--tw-ease:var(--ease-spring);transition-timing-function:var(--ease-spring)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.peer-checked\:scale-100:is(:where(.peer):checked~*){--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.peer-checked\:border-rust:is(:where(.peer):checked~*){border-color:var(--color-rust)}.peer-focus-visible\:outline-2:is(:where(.peer):focus-visible~*){outline-style:var(--tw-outline-style);outline-width:2px}.peer-focus-visible\:outline-offset-2:is(:where(.peer):focus-visible~*){outline-offset:2px}.peer-focus-visible\:outline-rust:is(:where(.peer):focus-visible~*){outline-color:var(--color-rust)}.placeholder\:text-text-secondary::placeholder{color:var(--color-text-secondary)}.last\:border-0:last-child{border-style:var(--tw-border-style);border-width:0}.last\:pb-0:last-child{padding-bottom:calc(var(--spacing) * 0)}@media (hover:hover){.hover\:-translate-y-0\.5:hover{--tw-translate-y:calc(var(--spacing) * -.5);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:bg-black\/10:hover{background-color:#0000001a}@supports (color:color-mix(in lab, red, red)){.hover\:bg-black\/10:hover{background-color:color-mix(in oklab, var(--color-black) 10%, transparent)}}.hover\:bg-border\/30:hover{background-color:#d9d2c74d}@supports (color:color-mix(in lab, red, red)){.hover\:bg-border\/30:hover{background-color:color-mix(in oklab, var(--color-border) 30%, transparent)}}.hover\:bg-border\/50:hover{background-color:#d9d2c780}@supports (color:color-mix(in lab, red, red)){.hover\:bg-border\/50:hover{background-color:color-mix(in oklab, var(--color-border) 50%, transparent)}}.hover\:bg-error-light:hover{background-color:var(--color-error-light)}.hover\:bg-error\/90:hover{background-color:#b84a3ce6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-error\/90:hover{background-color:color-mix(in oklab, var(--color-error) 90%, transparent)}}.hover\:bg-forest\/90:hover{background-color:#3d6b5ee6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-forest\/90:hover{background-color:color-mix(in oklab, var(--color-forest) 90%, transparent)}}.hover\:bg-rust-dark:hover{background-color:var(--color-rust-dark)}.hover\:bg-surface:hover{background-color:var(--color-surface)}.hover\:bg-surface\/50:hover{background-color:#f0ebe380}@supports (color:color-mix(in lab, red, red)){.hover\:bg-surface\/50:hover{background-color:color-mix(in oklab, var(--color-surface) 50%, transparent)}}.hover\:bg-white:hover{background-color:var(--color-white)}.hover\:text-rust:hover{color:var(--color-rust)}.hover\:text-rust-dark:hover{color:var(--color-rust-dark)}.hover\:text-text-primary:hover{color:var(--color-text-primary)}.hover\:shadow-2:hover{--tw-shadow:0 4px 12px var(--tw-shadow-color,#2c282514);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}}.focus\:border-rust:focus{border-color:var(--color-rust)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-rust-light:focus{--tw-ring-color:var(--color-rust-light)}.focus-visible\:outline-2:focus-visible{outline-style:var(--tw-outline-style);outline-width:2px}.focus-visible\:outline-offset-2:focus-visible{outline-offset:2px}.focus-visible\:outline-rust:focus-visible{outline-color:var(--color-rust)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:scale-\[0\.97\]:active{scale:.97}.active\:cursor-grabbing:active{cursor:grabbing}.active\:bg-border:active{background-color:var(--color-border)}.active\:bg-error\/80:active{background-color:#b84a3ccc}@supports (color:color-mix(in lab, red, red)){.active\:bg-error\/80:active{background-color:color-mix(in oklab, var(--color-error) 80%, transparent)}}.active\:bg-forest\/80:active{background-color:#3d6b5ecc}@supports (color:color-mix(in lab, red, red)){.active\:bg-forest\/80:active{background-color:color-mix(in oklab, var(--color-forest) 80%, transparent)}}.active\:bg-rust-dark\/90:active{background-color:#8e4429e6}@supports (color:color-mix(in lab, red, red)){.active\:bg-rust-dark\/90:active{background-color:color-mix(in oklab, var(--color-rust-dark) 90%, transparent)}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-border:disabled{background-color:var(--color-border)}.disabled\:text-text-secondary:disabled{color:var(--color-text-secondary)}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:active\:scale-100:disabled:active{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y)}.\[\&\:\:-moz-range-thumb\]\:h-5::-moz-range-thumb{height:calc(var(--spacing) * 5)}.\[\&\:\:-moz-range-thumb\]\:w-5::-moz-range-thumb{width:calc(var(--spacing) * 5)}.\[\&\:\:-moz-range-thumb\]\:appearance-none::-moz-range-thumb{appearance:none}.\[\&\:\:-moz-range-thumb\]\:rounded-full::-moz-range-thumb{border-radius:var(--radius-full)}.\[\&\:\:-moz-range-thumb\]\:border-2::-moz-range-thumb{border-style:var(--tw-border-style);border-width:2px}.\[\&\:\:-moz-range-thumb\]\:border-white::-moz-range-thumb{border-color:var(--color-white)}.\[\&\:\:-moz-range-thumb\]\:bg-rust::-moz-range-thumb{background-color:var(--color-rust)}.\[\&\:\:-moz-range-thumb\]\:shadow-2::-moz-range-thumb{--tw-shadow:0 4px 12px var(--tw-shadow-color,#2c282514);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.\[\&\:\:-webkit-slider-thumb\]\:h-5::-webkit-slider-thumb{height:calc(var(--spacing) * 5)}.\[\&\:\:-webkit-slider-thumb\]\:w-5::-webkit-slider-thumb{width:calc(var(--spacing) * 5)}.\[\&\:\:-webkit-slider-thumb\]\:appearance-none::-webkit-slider-thumb{appearance:none}.\[\&\:\:-webkit-slider-thumb\]\:rounded-full::-webkit-slider-thumb{border-radius:var(--radius-full)}.\[\&\:\:-webkit-slider-thumb\]\:border-2::-webkit-slider-thumb{border-style:var(--tw-border-style);border-width:2px}.\[\&\:\:-webkit-slider-thumb\]\:border-white::-webkit-slider-thumb{border-color:var(--color-white)}.\[\&\:\:-webkit-slider-thumb\]\:bg-rust::-webkit-slider-thumb{background-color:var(--color-rust)}.\[\&\:\:-webkit-slider-thumb\]\:shadow-2::-webkit-slider-thumb{--tw-shadow:0 4px 12px var(--tw-shadow-color,#2c282514);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.\[\&\:\:-webkit-slider-thumb\]\:transition-transform::-webkit-slider-thumb{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.\[\&\:\:-webkit-slider-thumb\]\:hover\:scale-110::-webkit-slider-thumb:hover{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}}.\[\&\>tr\:last-child\]\:border-0>tr:last-child{border-style:var(--tw-border-style);border-width:0}}:root{--duration-micro:.1s;--duration-fast:.2s;--duration-normal:.35s;--duration-slow:.5s}@media (prefers-reduced-motion:reduce){:root{--duration-micro:0s;--duration-fast:0s;--duration-normal:0s;--duration-slow:0s}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}
@@ -0,0 +1,78 @@
1
+ 'use strict';
2
+
3
+ // src/tokens/tokens.ts
4
+ var colors = {
5
+ bg: "#FAF7F2",
6
+ surface: "#F0EBE3",
7
+ border: "#D9D2C7",
8
+ textPrimary: "#2C2825",
9
+ textSecondary: "#6B635A",
10
+ white: "#FFFFFF",
11
+ rust: "#B85C38",
12
+ rustLight: "#F0D5C5",
13
+ rustDark: "#8E4429",
14
+ forest: "#3D6B5E",
15
+ forestLight: "#D4E5DF",
16
+ success: "#5E8A6B",
17
+ successLight: "#DDE9E0",
18
+ warning: "#C49A3C",
19
+ warningLight: "#F5EDD4",
20
+ error: "#B84A3C",
21
+ errorLight: "#F3D9D5",
22
+ info: "#7A8A9A",
23
+ infoLight: "#E0E5EA",
24
+ saffron: "#D4923A",
25
+ saffronLight: "#F5E3C8"
26
+ };
27
+ var spacing = {
28
+ 1: "4px",
29
+ 2: "8px",
30
+ 3: "12px",
31
+ 4: "16px",
32
+ 5: "20px",
33
+ 6: "24px",
34
+ 8: "32px",
35
+ 10: "40px",
36
+ 12: "48px",
37
+ 16: "64px",
38
+ 20: "80px",
39
+ 24: "96px"
40
+ };
41
+ var radii = {
42
+ sm: "6px",
43
+ md: "10px",
44
+ lg: "16px",
45
+ xl: "24px",
46
+ full: "9999px"
47
+ };
48
+ var shadows = {
49
+ 1: "0 1px 3px rgba(44, 40, 37, 0.06)",
50
+ 2: "0 4px 12px rgba(44, 40, 37, 0.08)",
51
+ 3: "0 8px 24px rgba(44, 40, 37, 0.12)",
52
+ 4: "0 16px 48px rgba(44, 40, 37, 0.16)"
53
+ };
54
+ var durations = {
55
+ micro: "100ms",
56
+ fast: "200ms",
57
+ normal: "350ms",
58
+ slow: "500ms"
59
+ };
60
+ var easings = {
61
+ out: "cubic-bezier(0.22, 1, 0.36, 1)",
62
+ in: "cubic-bezier(0.55, 0, 1, 0.45)",
63
+ spring: "cubic-bezier(0.34, 1.56, 0.64, 1)"
64
+ };
65
+ var typography = {
66
+ fontSans: "'Satoshi', system-ui, -apple-system, sans-serif",
67
+ fontMono: "'JetBrains Mono', 'Fira Code', monospace"
68
+ };
69
+
70
+ exports.colors = colors;
71
+ exports.durations = durations;
72
+ exports.easings = easings;
73
+ exports.radii = radii;
74
+ exports.shadows = shadows;
75
+ exports.spacing = spacing;
76
+ exports.typography = typography;
77
+ //# sourceMappingURL=tokens.cjs.map
78
+ //# sourceMappingURL=tokens.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tokens/tokens.ts"],"names":[],"mappings":";;;AAAO,IAAM,MAAA,GAAS;AAAA,EACpB,EAAA,EAAI,SAAA;AAAA,EACJ,OAAA,EAAS,SAAA;AAAA,EACT,MAAA,EAAQ,SAAA;AAAA,EACR,WAAA,EAAa,SAAA;AAAA,EACb,aAAA,EAAe,SAAA;AAAA,EACf,KAAA,EAAO,SAAA;AAAA,EACP,IAAA,EAAM,SAAA;AAAA,EACN,SAAA,EAAW,SAAA;AAAA,EACX,QAAA,EAAU,SAAA;AAAA,EACV,MAAA,EAAQ,SAAA;AAAA,EACR,WAAA,EAAa,SAAA;AAAA,EACb,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc,SAAA;AAAA,EACd,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc,SAAA;AAAA,EACd,KAAA,EAAO,SAAA;AAAA,EACP,UAAA,EAAY,SAAA;AAAA,EACZ,IAAA,EAAM,SAAA;AAAA,EACN,SAAA,EAAW,SAAA;AAAA,EACX,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc;AAChB;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,CAAA,EAAG,KAAA;AAAA,EACH,CAAA,EAAG,KAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI;AACN;AAEO,IAAM,KAAA,GAAQ;AAAA,EACnB,EAAA,EAAI,KAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,IAAA,EAAM;AACR;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,CAAA,EAAG,kCAAA;AAAA,EACH,CAAA,EAAG,mCAAA;AAAA,EACH,CAAA,EAAG,mCAAA;AAAA,EACH,CAAA,EAAG;AACL;AAEO,IAAM,SAAA,GAAY;AAAA,EACvB,KAAA,EAAO,OAAA;AAAA,EACP,IAAA,EAAM,OAAA;AAAA,EACN,MAAA,EAAQ,OAAA;AAAA,EACR,IAAA,EAAM;AACR;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,GAAA,EAAK,gCAAA;AAAA,EACL,EAAA,EAAI,gCAAA;AAAA,EACJ,MAAA,EAAQ;AACV;AAEO,IAAM,UAAA,GAAa;AAAA,EACxB,QAAA,EAAU,iDAAA;AAAA,EACV,QAAA,EAAU;AACZ","file":"tokens.cjs","sourcesContent":["export const colors = {\n bg: '#FAF7F2',\n surface: '#F0EBE3',\n border: '#D9D2C7',\n textPrimary: '#2C2825',\n textSecondary: '#6B635A',\n white: '#FFFFFF',\n rust: '#B85C38',\n rustLight: '#F0D5C5',\n rustDark: '#8E4429',\n forest: '#3D6B5E',\n forestLight: '#D4E5DF',\n success: '#5E8A6B',\n successLight: '#DDE9E0',\n warning: '#C49A3C',\n warningLight: '#F5EDD4',\n error: '#B84A3C',\n errorLight: '#F3D9D5',\n info: '#7A8A9A',\n infoLight: '#E0E5EA',\n saffron: '#D4923A',\n saffronLight: '#F5E3C8',\n} as const;\n\nexport const spacing = {\n 1: '4px',\n 2: '8px',\n 3: '12px',\n 4: '16px',\n 5: '20px',\n 6: '24px',\n 8: '32px',\n 10: '40px',\n 12: '48px',\n 16: '64px',\n 20: '80px',\n 24: '96px',\n} as const;\n\nexport const radii = {\n sm: '6px',\n md: '10px',\n lg: '16px',\n xl: '24px',\n full: '9999px',\n} as const;\n\nexport const shadows = {\n 1: '0 1px 3px rgba(44, 40, 37, 0.06)',\n 2: '0 4px 12px rgba(44, 40, 37, 0.08)',\n 3: '0 8px 24px rgba(44, 40, 37, 0.12)',\n 4: '0 16px 48px rgba(44, 40, 37, 0.16)',\n} as const;\n\nexport const durations = {\n micro: '100ms',\n fast: '200ms',\n normal: '350ms',\n slow: '500ms',\n} as const;\n\nexport const easings = {\n out: 'cubic-bezier(0.22, 1, 0.36, 1)',\n in: 'cubic-bezier(0.55, 0, 1, 0.45)',\n spring: 'cubic-bezier(0.34, 1.56, 0.64, 1)',\n} as const;\n\nexport const typography = {\n fontSans: \"'Satoshi', system-ui, -apple-system, sans-serif\",\n fontMono: \"'JetBrains Mono', 'Fira Code', monospace\",\n} as const;\n"]}
@@ -0,0 +1,67 @@
1
+ declare const colors: {
2
+ readonly bg: "#FAF7F2";
3
+ readonly surface: "#F0EBE3";
4
+ readonly border: "#D9D2C7";
5
+ readonly textPrimary: "#2C2825";
6
+ readonly textSecondary: "#6B635A";
7
+ readonly white: "#FFFFFF";
8
+ readonly rust: "#B85C38";
9
+ readonly rustLight: "#F0D5C5";
10
+ readonly rustDark: "#8E4429";
11
+ readonly forest: "#3D6B5E";
12
+ readonly forestLight: "#D4E5DF";
13
+ readonly success: "#5E8A6B";
14
+ readonly successLight: "#DDE9E0";
15
+ readonly warning: "#C49A3C";
16
+ readonly warningLight: "#F5EDD4";
17
+ readonly error: "#B84A3C";
18
+ readonly errorLight: "#F3D9D5";
19
+ readonly info: "#7A8A9A";
20
+ readonly infoLight: "#E0E5EA";
21
+ readonly saffron: "#D4923A";
22
+ readonly saffronLight: "#F5E3C8";
23
+ };
24
+ declare const spacing: {
25
+ readonly 1: "4px";
26
+ readonly 2: "8px";
27
+ readonly 3: "12px";
28
+ readonly 4: "16px";
29
+ readonly 5: "20px";
30
+ readonly 6: "24px";
31
+ readonly 8: "32px";
32
+ readonly 10: "40px";
33
+ readonly 12: "48px";
34
+ readonly 16: "64px";
35
+ readonly 20: "80px";
36
+ readonly 24: "96px";
37
+ };
38
+ declare const radii: {
39
+ readonly sm: "6px";
40
+ readonly md: "10px";
41
+ readonly lg: "16px";
42
+ readonly xl: "24px";
43
+ readonly full: "9999px";
44
+ };
45
+ declare const shadows: {
46
+ readonly 1: "0 1px 3px rgba(44, 40, 37, 0.06)";
47
+ readonly 2: "0 4px 12px rgba(44, 40, 37, 0.08)";
48
+ readonly 3: "0 8px 24px rgba(44, 40, 37, 0.12)";
49
+ readonly 4: "0 16px 48px rgba(44, 40, 37, 0.16)";
50
+ };
51
+ declare const durations: {
52
+ readonly micro: "100ms";
53
+ readonly fast: "200ms";
54
+ readonly normal: "350ms";
55
+ readonly slow: "500ms";
56
+ };
57
+ declare const easings: {
58
+ readonly out: "cubic-bezier(0.22, 1, 0.36, 1)";
59
+ readonly in: "cubic-bezier(0.55, 0, 1, 0.45)";
60
+ readonly spring: "cubic-bezier(0.34, 1.56, 0.64, 1)";
61
+ };
62
+ declare const typography: {
63
+ readonly fontSans: "'Satoshi', system-ui, -apple-system, sans-serif";
64
+ readonly fontMono: "'JetBrains Mono', 'Fira Code', monospace";
65
+ };
66
+
67
+ export { colors, durations, easings, radii, shadows, spacing, typography };
@@ -0,0 +1,67 @@
1
+ declare const colors: {
2
+ readonly bg: "#FAF7F2";
3
+ readonly surface: "#F0EBE3";
4
+ readonly border: "#D9D2C7";
5
+ readonly textPrimary: "#2C2825";
6
+ readonly textSecondary: "#6B635A";
7
+ readonly white: "#FFFFFF";
8
+ readonly rust: "#B85C38";
9
+ readonly rustLight: "#F0D5C5";
10
+ readonly rustDark: "#8E4429";
11
+ readonly forest: "#3D6B5E";
12
+ readonly forestLight: "#D4E5DF";
13
+ readonly success: "#5E8A6B";
14
+ readonly successLight: "#DDE9E0";
15
+ readonly warning: "#C49A3C";
16
+ readonly warningLight: "#F5EDD4";
17
+ readonly error: "#B84A3C";
18
+ readonly errorLight: "#F3D9D5";
19
+ readonly info: "#7A8A9A";
20
+ readonly infoLight: "#E0E5EA";
21
+ readonly saffron: "#D4923A";
22
+ readonly saffronLight: "#F5E3C8";
23
+ };
24
+ declare const spacing: {
25
+ readonly 1: "4px";
26
+ readonly 2: "8px";
27
+ readonly 3: "12px";
28
+ readonly 4: "16px";
29
+ readonly 5: "20px";
30
+ readonly 6: "24px";
31
+ readonly 8: "32px";
32
+ readonly 10: "40px";
33
+ readonly 12: "48px";
34
+ readonly 16: "64px";
35
+ readonly 20: "80px";
36
+ readonly 24: "96px";
37
+ };
38
+ declare const radii: {
39
+ readonly sm: "6px";
40
+ readonly md: "10px";
41
+ readonly lg: "16px";
42
+ readonly xl: "24px";
43
+ readonly full: "9999px";
44
+ };
45
+ declare const shadows: {
46
+ readonly 1: "0 1px 3px rgba(44, 40, 37, 0.06)";
47
+ readonly 2: "0 4px 12px rgba(44, 40, 37, 0.08)";
48
+ readonly 3: "0 8px 24px rgba(44, 40, 37, 0.12)";
49
+ readonly 4: "0 16px 48px rgba(44, 40, 37, 0.16)";
50
+ };
51
+ declare const durations: {
52
+ readonly micro: "100ms";
53
+ readonly fast: "200ms";
54
+ readonly normal: "350ms";
55
+ readonly slow: "500ms";
56
+ };
57
+ declare const easings: {
58
+ readonly out: "cubic-bezier(0.22, 1, 0.36, 1)";
59
+ readonly in: "cubic-bezier(0.55, 0, 1, 0.45)";
60
+ readonly spring: "cubic-bezier(0.34, 1.56, 0.64, 1)";
61
+ };
62
+ declare const typography: {
63
+ readonly fontSans: "'Satoshi', system-ui, -apple-system, sans-serif";
64
+ readonly fontMono: "'JetBrains Mono', 'Fira Code', monospace";
65
+ };
66
+
67
+ export { colors, durations, easings, radii, shadows, spacing, typography };
package/dist/tokens.js ADDED
@@ -0,0 +1,70 @@
1
+ // src/tokens/tokens.ts
2
+ var colors = {
3
+ bg: "#FAF7F2",
4
+ surface: "#F0EBE3",
5
+ border: "#D9D2C7",
6
+ textPrimary: "#2C2825",
7
+ textSecondary: "#6B635A",
8
+ white: "#FFFFFF",
9
+ rust: "#B85C38",
10
+ rustLight: "#F0D5C5",
11
+ rustDark: "#8E4429",
12
+ forest: "#3D6B5E",
13
+ forestLight: "#D4E5DF",
14
+ success: "#5E8A6B",
15
+ successLight: "#DDE9E0",
16
+ warning: "#C49A3C",
17
+ warningLight: "#F5EDD4",
18
+ error: "#B84A3C",
19
+ errorLight: "#F3D9D5",
20
+ info: "#7A8A9A",
21
+ infoLight: "#E0E5EA",
22
+ saffron: "#D4923A",
23
+ saffronLight: "#F5E3C8"
24
+ };
25
+ var spacing = {
26
+ 1: "4px",
27
+ 2: "8px",
28
+ 3: "12px",
29
+ 4: "16px",
30
+ 5: "20px",
31
+ 6: "24px",
32
+ 8: "32px",
33
+ 10: "40px",
34
+ 12: "48px",
35
+ 16: "64px",
36
+ 20: "80px",
37
+ 24: "96px"
38
+ };
39
+ var radii = {
40
+ sm: "6px",
41
+ md: "10px",
42
+ lg: "16px",
43
+ xl: "24px",
44
+ full: "9999px"
45
+ };
46
+ var shadows = {
47
+ 1: "0 1px 3px rgba(44, 40, 37, 0.06)",
48
+ 2: "0 4px 12px rgba(44, 40, 37, 0.08)",
49
+ 3: "0 8px 24px rgba(44, 40, 37, 0.12)",
50
+ 4: "0 16px 48px rgba(44, 40, 37, 0.16)"
51
+ };
52
+ var durations = {
53
+ micro: "100ms",
54
+ fast: "200ms",
55
+ normal: "350ms",
56
+ slow: "500ms"
57
+ };
58
+ var easings = {
59
+ out: "cubic-bezier(0.22, 1, 0.36, 1)",
60
+ in: "cubic-bezier(0.55, 0, 1, 0.45)",
61
+ spring: "cubic-bezier(0.34, 1.56, 0.64, 1)"
62
+ };
63
+ var typography = {
64
+ fontSans: "'Satoshi', system-ui, -apple-system, sans-serif",
65
+ fontMono: "'JetBrains Mono', 'Fira Code', monospace"
66
+ };
67
+
68
+ export { colors, durations, easings, radii, shadows, spacing, typography };
69
+ //# sourceMappingURL=tokens.js.map
70
+ //# sourceMappingURL=tokens.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/tokens/tokens.ts"],"names":[],"mappings":";AAAO,IAAM,MAAA,GAAS;AAAA,EACpB,EAAA,EAAI,SAAA;AAAA,EACJ,OAAA,EAAS,SAAA;AAAA,EACT,MAAA,EAAQ,SAAA;AAAA,EACR,WAAA,EAAa,SAAA;AAAA,EACb,aAAA,EAAe,SAAA;AAAA,EACf,KAAA,EAAO,SAAA;AAAA,EACP,IAAA,EAAM,SAAA;AAAA,EACN,SAAA,EAAW,SAAA;AAAA,EACX,QAAA,EAAU,SAAA;AAAA,EACV,MAAA,EAAQ,SAAA;AAAA,EACR,WAAA,EAAa,SAAA;AAAA,EACb,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc,SAAA;AAAA,EACd,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc,SAAA;AAAA,EACd,KAAA,EAAO,SAAA;AAAA,EACP,UAAA,EAAY,SAAA;AAAA,EACZ,IAAA,EAAM,SAAA;AAAA,EACN,SAAA,EAAW,SAAA;AAAA,EACX,OAAA,EAAS,SAAA;AAAA,EACT,YAAA,EAAc;AAChB;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,CAAA,EAAG,KAAA;AAAA,EACH,CAAA,EAAG,KAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,CAAA,EAAG,MAAA;AAAA,EACH,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI;AACN;AAEO,IAAM,KAAA,GAAQ;AAAA,EACnB,EAAA,EAAI,KAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,EAAA,EAAI,MAAA;AAAA,EACJ,IAAA,EAAM;AACR;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,CAAA,EAAG,kCAAA;AAAA,EACH,CAAA,EAAG,mCAAA;AAAA,EACH,CAAA,EAAG,mCAAA;AAAA,EACH,CAAA,EAAG;AACL;AAEO,IAAM,SAAA,GAAY;AAAA,EACvB,KAAA,EAAO,OAAA;AAAA,EACP,IAAA,EAAM,OAAA;AAAA,EACN,MAAA,EAAQ,OAAA;AAAA,EACR,IAAA,EAAM;AACR;AAEO,IAAM,OAAA,GAAU;AAAA,EACrB,GAAA,EAAK,gCAAA;AAAA,EACL,EAAA,EAAI,gCAAA;AAAA,EACJ,MAAA,EAAQ;AACV;AAEO,IAAM,UAAA,GAAa;AAAA,EACxB,QAAA,EAAU,iDAAA;AAAA,EACV,QAAA,EAAU;AACZ","file":"tokens.js","sourcesContent":["export const colors = {\n bg: '#FAF7F2',\n surface: '#F0EBE3',\n border: '#D9D2C7',\n textPrimary: '#2C2825',\n textSecondary: '#6B635A',\n white: '#FFFFFF',\n rust: '#B85C38',\n rustLight: '#F0D5C5',\n rustDark: '#8E4429',\n forest: '#3D6B5E',\n forestLight: '#D4E5DF',\n success: '#5E8A6B',\n successLight: '#DDE9E0',\n warning: '#C49A3C',\n warningLight: '#F5EDD4',\n error: '#B84A3C',\n errorLight: '#F3D9D5',\n info: '#7A8A9A',\n infoLight: '#E0E5EA',\n saffron: '#D4923A',\n saffronLight: '#F5E3C8',\n} as const;\n\nexport const spacing = {\n 1: '4px',\n 2: '8px',\n 3: '12px',\n 4: '16px',\n 5: '20px',\n 6: '24px',\n 8: '32px',\n 10: '40px',\n 12: '48px',\n 16: '64px',\n 20: '80px',\n 24: '96px',\n} as const;\n\nexport const radii = {\n sm: '6px',\n md: '10px',\n lg: '16px',\n xl: '24px',\n full: '9999px',\n} as const;\n\nexport const shadows = {\n 1: '0 1px 3px rgba(44, 40, 37, 0.06)',\n 2: '0 4px 12px rgba(44, 40, 37, 0.08)',\n 3: '0 8px 24px rgba(44, 40, 37, 0.12)',\n 4: '0 16px 48px rgba(44, 40, 37, 0.16)',\n} as const;\n\nexport const durations = {\n micro: '100ms',\n fast: '200ms',\n normal: '350ms',\n slow: '500ms',\n} as const;\n\nexport const easings = {\n out: 'cubic-bezier(0.22, 1, 0.36, 1)',\n in: 'cubic-bezier(0.55, 0, 1, 0.45)',\n spring: 'cubic-bezier(0.34, 1.56, 0.64, 1)',\n} as const;\n\nexport const typography = {\n fontSans: \"'Satoshi', system-ui, -apple-system, sans-serif\",\n fontMono: \"'JetBrains Mono', 'Fira Code', monospace\",\n} as const;\n"]}
package/package.json ADDED
@@ -0,0 +1,103 @@
1
+ {
2
+ "name": "@weave-design-system/react",
3
+ "version": "0.1.0",
4
+ "description": "A human-centered design system for productivity software",
5
+ "type": "module",
6
+ "sideEffects": [
7
+ "**/*.css"
8
+ ],
9
+ "main": "./dist/index.cjs",
10
+ "module": "./dist/index.js",
11
+ "types": "./dist/index.d.ts",
12
+ "exports": {
13
+ ".": {
14
+ "import": {
15
+ "types": "./dist/index.d.ts",
16
+ "default": "./dist/index.js"
17
+ },
18
+ "require": {
19
+ "types": "./dist/index.d.cts",
20
+ "default": "./dist/index.cjs"
21
+ }
22
+ },
23
+ "./theme.css": "./dist/theme.css",
24
+ "./tokens": {
25
+ "import": {
26
+ "types": "./dist/tokens.d.ts",
27
+ "default": "./dist/tokens.js"
28
+ },
29
+ "require": {
30
+ "types": "./dist/tokens.d.cts",
31
+ "default": "./dist/tokens.cjs"
32
+ }
33
+ }
34
+ },
35
+ "files": [
36
+ "dist",
37
+ "src"
38
+ ],
39
+ "scripts": {
40
+ "dev": "storybook dev -p 6006",
41
+ "build": "pnpm build:js && pnpm build:css",
42
+ "build:js": "tsup",
43
+ "build:css": "npx @tailwindcss/cli -i src/tokens/weave-theme.css -o dist/theme.css --minify",
44
+ "build-storybook": "storybook build",
45
+ "test": "vitest run",
46
+ "test:watch": "vitest",
47
+ "lint": "eslint src/",
48
+ "typecheck": "tsc --noEmit",
49
+ "prepublishOnly": "pnpm build && pnpm test && pnpm typecheck"
50
+ },
51
+ "peerDependencies": {
52
+ "react": "^18.0.0 || ^19.0.0",
53
+ "react-dom": "^18.0.0 || ^19.0.0"
54
+ },
55
+ "dependencies": {
56
+ "@dnd-kit/core": "^6.3.1",
57
+ "@dnd-kit/sortable": "^10.0.0",
58
+ "@dnd-kit/utilities": "^3.2.2",
59
+ "clsx": "^2.1.0",
60
+ "lucide-react": "^0.470.0",
61
+ "tailwind-merge": "^3.0.0"
62
+ },
63
+ "devDependencies": {
64
+ "@floating-ui/react": "^0.27.0",
65
+ "@storybook/addon-a11y": "^8.6.0",
66
+ "@storybook/addon-docs": "^8.6.0",
67
+ "@storybook/addon-viewport": "^8.6.0",
68
+ "@storybook/react": "^8.6.0",
69
+ "@storybook/react-vite": "^8.6.0",
70
+ "@tailwindcss/cli": "^4.0.0",
71
+ "@tailwindcss/oxide-darwin-arm64": "^4.2.1",
72
+ "@tailwindcss/vite": "^4.0.0",
73
+ "@testing-library/jest-dom": "^6.0.0",
74
+ "@testing-library/react": "^16.0.0",
75
+ "@testing-library/user-event": "^14.0.0",
76
+ "@types/react": "^18.0.0",
77
+ "@types/react-dom": "^18.0.0",
78
+ "jsdom": "^25.0.0",
79
+ "react": "^18.3.0",
80
+ "react-dom": "^18.3.0",
81
+ "storybook": "^8.6.0",
82
+ "tailwindcss": "^4.0.0",
83
+ "tsup": "^8.0.0",
84
+ "typescript": "^5.7.0",
85
+ "vite": "^6.0.0",
86
+ "vitest": "^3.0.0"
87
+ },
88
+ "keywords": [
89
+ "design-system",
90
+ "react",
91
+ "components",
92
+ "tailwindcss",
93
+ "weave"
94
+ ],
95
+ "license": "MIT",
96
+ "packageManager": "pnpm@10.32.1",
97
+ "pnpm": {
98
+ "onlyBuiltDependencies": [
99
+ "esbuild",
100
+ "@parcel/watcher"
101
+ ]
102
+ }
103
+ }
@@ -0,0 +1,16 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { ActivityFeed } from './ActivityFeed';
3
+
4
+ const meta: Meta<typeof ActivityFeed> = { title: 'Data Display/ActivityFeed', component: ActivityFeed, tags: ['autodocs'] };
5
+ export default meta;
6
+ type Story = StoryObj<typeof ActivityFeed>;
7
+
8
+ export const Default: Story = {
9
+ args: {
10
+ items: [
11
+ { id: '1', name: 'Alice', action: 'completed the design review', timestamp: '2 min ago' },
12
+ { id: '2', name: 'Bob', action: 'commented on the homepage task', timestamp: '15 min ago' },
13
+ { id: '3', name: 'Charlie', action: 'moved "API integration" to Done', timestamp: '1 hour ago' },
14
+ ],
15
+ },
16
+ };
@@ -0,0 +1,11 @@
1
+ import { render, screen } from '@testing-library/react';
2
+ import { describe, it, expect } from 'vitest';
3
+ import { ActivityFeed } from './ActivityFeed';
4
+
5
+ describe('ActivityFeed', () => {
6
+ it('renders items with name and action', () => {
7
+ render(<ActivityFeed items={[{ id: '1', name: 'Alice', action: 'completed task', timestamp: '1h ago' }]} />);
8
+ expect(screen.getByText('Alice')).toBeInTheDocument();
9
+ expect(screen.getByText('completed task')).toBeInTheDocument();
10
+ });
11
+ });
@@ -0,0 +1,34 @@
1
+ import { cn } from '../../utils/cn';
2
+ import { Avatar } from '../../primitives/avatar';
3
+
4
+ export interface ActivityItem {
5
+ id: string;
6
+ name: string;
7
+ avatarSrc?: string;
8
+ action: string;
9
+ timestamp: string;
10
+ }
11
+
12
+ export interface ActivityFeedProps {
13
+ items: ActivityItem[];
14
+ className?: string;
15
+ }
16
+
17
+ export function ActivityFeed({ items, className }: ActivityFeedProps) {
18
+ return (
19
+ <div className={cn('flex flex-col', className)}>
20
+ {items.map((item) => (
21
+ <div key={item.id} className="flex items-start gap-3 py-3 border-b border-border last:border-0">
22
+ <Avatar name={item.name} src={item.avatarSrc} size="sm" />
23
+ <div className="flex-1 min-w-0">
24
+ <p style={{ fontSize: 'var(--text-body-sm)', lineHeight: 'var(--leading-body-sm)' }}>
25
+ <span className="text-text-primary font-medium">{item.name}</span>{' '}
26
+ <span className="text-text-secondary">{item.action}</span>
27
+ </p>
28
+ <p className="text-text-secondary mt-0.5" style={{ fontSize: 'var(--text-caption)' }}>{item.timestamp}</p>
29
+ </div>
30
+ </div>
31
+ ))}
32
+ </div>
33
+ );
34
+ }
@@ -0,0 +1,2 @@
1
+ export { ActivityFeed } from './ActivityFeed';
2
+ export type { ActivityFeedProps, ActivityItem } from './ActivityFeed';
@@ -0,0 +1,10 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { CircularProgress } from './CircularProgress';
3
+
4
+ const meta: Meta<typeof CircularProgress> = { title: 'Data Display/CircularProgress', component: CircularProgress, tags: ['autodocs'] };
5
+ export default meta;
6
+ type Story = StoryObj<typeof CircularProgress>;
7
+
8
+ export const Default: Story = { args: { value: 72 } };
9
+ export const Full: Story = { args: { value: 100 } };
10
+ export const Small: Story = { args: { value: 45, size: 48, strokeWidth: 4 } };
@@ -0,0 +1,11 @@
1
+ import { render, screen } from '@testing-library/react';
2
+ import { describe, it, expect } from 'vitest';
3
+ import { CircularProgress } from './CircularProgress';
4
+
5
+ describe('CircularProgress', () => {
6
+ it('renders with percentage', () => {
7
+ render(<CircularProgress value={75} />);
8
+ expect(screen.getByRole('progressbar')).toBeInTheDocument();
9
+ expect(screen.getByText('75%')).toBeInTheDocument();
10
+ });
11
+ });
@@ -0,0 +1,35 @@
1
+ import { cn } from '../../utils/cn';
2
+
3
+ export interface CircularProgressProps {
4
+ value: number;
5
+ max?: number;
6
+ size?: number;
7
+ strokeWidth?: number;
8
+ className?: string;
9
+ }
10
+
11
+ export function CircularProgress({ value, max = 100, size = 80, strokeWidth = 6, className }: CircularProgressProps) {
12
+ const percent = Math.min(100, Math.max(0, (value / max) * 100));
13
+ const radius = (size - strokeWidth) / 2;
14
+ const circumference = 2 * Math.PI * radius;
15
+ const offset = circumference - (percent / 100) * circumference;
16
+
17
+ return (
18
+ <div className={cn('relative inline-flex items-center justify-center', className)} style={{ width: size, height: size }} role="progressbar" aria-valuenow={value} aria-valuemin={0} aria-valuemax={max}>
19
+ <svg width={size} height={size} className="-rotate-90">
20
+ <circle cx={size / 2} cy={size / 2} r={radius} fill="none" stroke="var(--color-border)" strokeWidth={strokeWidth} />
21
+ <circle
22
+ cx={size / 2} cy={size / 2} r={radius} fill="none" stroke="var(--color-rust)" strokeWidth={strokeWidth}
23
+ strokeDasharray={circumference} strokeDashoffset={offset} strokeLinecap="round"
24
+ className="transition-all" style={{ transitionDuration: 'var(--duration-normal)' }}
25
+ />
26
+ </svg>
27
+ <span
28
+ className="absolute font-bold text-text-primary tabular-nums"
29
+ style={{ fontSize: 'var(--text-body-sm)' }}
30
+ >
31
+ {Math.round(percent)}%
32
+ </span>
33
+ </div>
34
+ );
35
+ }
@@ -0,0 +1,2 @@
1
+ export { CircularProgress } from './CircularProgress';
2
+ export type { CircularProgressProps } from './CircularProgress';
@@ -0,0 +1,15 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { FileText, Inbox } from 'lucide-react';
3
+ import { EmptyState } from './EmptyState';
4
+
5
+ const meta: Meta<typeof EmptyState> = { title: 'Data Display/EmptyState', component: EmptyState, tags: ['autodocs'] };
6
+ export default meta;
7
+ type Story = StoryObj<typeof EmptyState>;
8
+
9
+ export const WithAction: Story = {
10
+ args: { icon: <FileText size={28} />, title: 'No tasks yet', description: 'Ready to start something? Create your first task.', actionLabel: 'Create Task', onAction: () => {} },
11
+ };
12
+
13
+ export const NoAction: Story = {
14
+ args: { icon: <Inbox size={28} />, title: 'Inbox zero', description: "You're all caught up. Nice work!" },
15
+ };
@@ -0,0 +1,18 @@
1
+ import { render, screen } from '@testing-library/react';
2
+ import userEvent from '@testing-library/user-event';
3
+ import { describe, it, expect, vi } from 'vitest';
4
+ import { EmptyState } from './EmptyState';
5
+
6
+ describe('EmptyState', () => {
7
+ it('renders title and description', () => {
8
+ render(<EmptyState icon={<span>IC</span>} title="No items" description="Create one" />);
9
+ expect(screen.getByText('No items')).toBeInTheDocument();
10
+ expect(screen.getByText('Create one')).toBeInTheDocument();
11
+ });
12
+ it('calls action on click', async () => {
13
+ const onAction = vi.fn();
14
+ render(<EmptyState icon={<span>IC</span>} title="Empty" actionLabel="Add" onAction={onAction} />);
15
+ await userEvent.click(screen.getByRole('button', { name: 'Add' }));
16
+ expect(onAction).toHaveBeenCalledOnce();
17
+ });
18
+ });