@moveindustries/movement-design-system 1.0.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 (187) hide show
  1. package/CHANGELOG.md +190 -0
  2. package/LICENSE +21 -0
  3. package/README.md +76 -0
  4. package/dist/components/Branding/Branding.d.ts +31 -0
  5. package/dist/components/Branding/Branding.d.ts.map +1 -0
  6. package/dist/components/Branding/index.d.ts +3 -0
  7. package/dist/components/Branding/index.d.ts.map +1 -0
  8. package/dist/components/DottedBackground/DottedBackground.d.ts +11 -0
  9. package/dist/components/DottedBackground/DottedBackground.d.ts.map +1 -0
  10. package/dist/components/DottedBackground/index.d.ts +2 -0
  11. package/dist/components/DottedBackground/index.d.ts.map +1 -0
  12. package/dist/components/Footer/Footer.d.ts +72 -0
  13. package/dist/components/Footer/Footer.d.ts.map +1 -0
  14. package/dist/components/Footer/index.d.ts +3 -0
  15. package/dist/components/Footer/index.d.ts.map +1 -0
  16. package/dist/components/GlobalNavMenu/GlobalNavMenu.d.ts +87 -0
  17. package/dist/components/GlobalNavMenu/GlobalNavMenu.d.ts.map +1 -0
  18. package/dist/components/GlobalNavMenu/icons/BridgeIcon.d.ts +2 -0
  19. package/dist/components/GlobalNavMenu/icons/BridgeIcon.d.ts.map +1 -0
  20. package/dist/components/GlobalNavMenu/icons/DelegatedStakingIcon.d.ts +2 -0
  21. package/dist/components/GlobalNavMenu/icons/DelegatedStakingIcon.d.ts.map +1 -0
  22. package/dist/components/GlobalNavMenu/icons/ExplorerIcon.d.ts +2 -0
  23. package/dist/components/GlobalNavMenu/icons/ExplorerIcon.d.ts.map +1 -0
  24. package/dist/components/GlobalNavMenu/icons/GridIcon.d.ts +4 -0
  25. package/dist/components/GlobalNavMenu/icons/GridIcon.d.ts.map +1 -0
  26. package/dist/components/GlobalNavMenu/icons/MoveDocsIcon.d.ts +2 -0
  27. package/dist/components/GlobalNavMenu/icons/MoveDocsIcon.d.ts.map +1 -0
  28. package/dist/components/GlobalNavMenu/icons/ParthenonIcon.d.ts +2 -0
  29. package/dist/components/GlobalNavMenu/icons/ParthenonIcon.d.ts.map +1 -0
  30. package/dist/components/GlobalNavMenu/icons/index.d.ts +7 -0
  31. package/dist/components/GlobalNavMenu/icons/index.d.ts.map +1 -0
  32. package/dist/components/GlobalNavMenu/index.d.ts +3 -0
  33. package/dist/components/GlobalNavMenu/index.d.ts.map +1 -0
  34. package/dist/components/Icon/AllAssetIcons.d.ts +45 -0
  35. package/dist/components/Icon/AllAssetIcons.d.ts.map +1 -0
  36. package/dist/components/Icon/AssetIcons.d.ts +5 -0
  37. package/dist/components/Icon/AssetIcons.d.ts.map +1 -0
  38. package/dist/components/Icon/index.d.ts +3 -0
  39. package/dist/components/Icon/index.d.ts.map +1 -0
  40. package/dist/components/IconButton/IconButton.d.ts +8 -0
  41. package/dist/components/IconButton/IconButton.d.ts.map +1 -0
  42. package/dist/components/Logo/Logo.d.ts +3 -0
  43. package/dist/components/Logo/Logo.d.ts.map +1 -0
  44. package/dist/components/MultiOutlineText/MultiOutlineText.d.ts +23 -0
  45. package/dist/components/MultiOutlineText/MultiOutlineText.d.ts.map +1 -0
  46. package/dist/components/MultiOutlineText/index.d.ts +3 -0
  47. package/dist/components/MultiOutlineText/index.d.ts.map +1 -0
  48. package/dist/components/ProgressButton/ProgressButton.d.ts +53 -0
  49. package/dist/components/ProgressButton/ProgressButton.d.ts.map +1 -0
  50. package/dist/components/ProgressButton/index.d.ts +2 -0
  51. package/dist/components/ProgressButton/index.d.ts.map +1 -0
  52. package/dist/components/WalletModal/WalletModal.d.ts +6 -0
  53. package/dist/components/WalletModal/WalletModal.d.ts.map +1 -0
  54. package/dist/components/WalletModal/index.d.ts +3 -0
  55. package/dist/components/WalletModal/index.d.ts.map +1 -0
  56. package/dist/components/shadcn/accordion.d.ts +17 -0
  57. package/dist/components/shadcn/accordion.d.ts.map +1 -0
  58. package/dist/components/shadcn/alert-dialog.d.ts +15 -0
  59. package/dist/components/shadcn/alert-dialog.d.ts.map +1 -0
  60. package/dist/components/shadcn/alert.d.ts +10 -0
  61. package/dist/components/shadcn/alert.d.ts.map +1 -0
  62. package/dist/components/shadcn/aspect-ratio.d.ts +4 -0
  63. package/dist/components/shadcn/aspect-ratio.d.ts.map +1 -0
  64. package/dist/components/shadcn/avatar.d.ts +13 -0
  65. package/dist/components/shadcn/avatar.d.ts.map +1 -0
  66. package/dist/components/shadcn/badge.d.ts +11 -0
  67. package/dist/components/shadcn/badge.d.ts.map +1 -0
  68. package/dist/components/shadcn/breadcrumb.d.ts +12 -0
  69. package/dist/components/shadcn/breadcrumb.d.ts.map +1 -0
  70. package/dist/components/shadcn/button-group.d.ts +12 -0
  71. package/dist/components/shadcn/button-group.d.ts.map +1 -0
  72. package/dist/components/shadcn/button.d.ts +11 -0
  73. package/dist/components/shadcn/button.d.ts.map +1 -0
  74. package/dist/components/shadcn/card.d.ts +17 -0
  75. package/dist/components/shadcn/card.d.ts.map +1 -0
  76. package/dist/components/shadcn/carousel.d.ts +20 -0
  77. package/dist/components/shadcn/carousel.d.ts.map +1 -0
  78. package/dist/components/shadcn/checkbox.d.ts +5 -0
  79. package/dist/components/shadcn/checkbox.d.ts.map +1 -0
  80. package/dist/components/shadcn/crypto-amount-input.d.ts +31 -0
  81. package/dist/components/shadcn/crypto-amount-input.d.ts.map +1 -0
  82. package/dist/components/shadcn/dialog.d.ts +22 -0
  83. package/dist/components/shadcn/dialog.d.ts.map +1 -0
  84. package/dist/components/shadcn/drawer.d.ts +14 -0
  85. package/dist/components/shadcn/drawer.d.ts.map +1 -0
  86. package/dist/components/shadcn/dropdown-menu.d.ts +26 -0
  87. package/dist/components/shadcn/dropdown-menu.d.ts.map +1 -0
  88. package/dist/components/shadcn/empty.d.ts +12 -0
  89. package/dist/components/shadcn/empty.d.ts.map +1 -0
  90. package/dist/components/shadcn/field.d.ts +25 -0
  91. package/dist/components/shadcn/field.d.ts.map +1 -0
  92. package/dist/components/shadcn/form.d.ts +25 -0
  93. package/dist/components/shadcn/form.d.ts.map +1 -0
  94. package/dist/components/shadcn/hover-card.d.ts +7 -0
  95. package/dist/components/shadcn/hover-card.d.ts.map +1 -0
  96. package/dist/components/shadcn/input-group.d.ts +17 -0
  97. package/dist/components/shadcn/input-group.d.ts.map +1 -0
  98. package/dist/components/shadcn/input.d.ts +28 -0
  99. package/dist/components/shadcn/input.d.ts.map +1 -0
  100. package/dist/components/shadcn/item.d.ts +24 -0
  101. package/dist/components/shadcn/item.d.ts.map +1 -0
  102. package/dist/components/shadcn/label.d.ts +5 -0
  103. package/dist/components/shadcn/label.d.ts.map +1 -0
  104. package/dist/components/shadcn/list.d.ts +45 -0
  105. package/dist/components/shadcn/list.d.ts.map +1 -0
  106. package/dist/components/shadcn/menubar.d.ts +27 -0
  107. package/dist/components/shadcn/menubar.d.ts.map +1 -0
  108. package/dist/components/shadcn/navigation-menu.d.ts +15 -0
  109. package/dist/components/shadcn/navigation-menu.d.ts.map +1 -0
  110. package/dist/components/shadcn/pagination.d.ts +31 -0
  111. package/dist/components/shadcn/pagination.d.ts.map +1 -0
  112. package/dist/components/shadcn/popover.d.ts +8 -0
  113. package/dist/components/shadcn/popover.d.ts.map +1 -0
  114. package/dist/components/shadcn/progress.d.ts +5 -0
  115. package/dist/components/shadcn/progress.d.ts.map +1 -0
  116. package/dist/components/shadcn/radio-group.d.ts +6 -0
  117. package/dist/components/shadcn/radio-group.d.ts.map +1 -0
  118. package/dist/components/shadcn/scroll-area.d.ts +6 -0
  119. package/dist/components/shadcn/scroll-area.d.ts.map +1 -0
  120. package/dist/components/shadcn/select.d.ts +16 -0
  121. package/dist/components/shadcn/select.d.ts.map +1 -0
  122. package/dist/components/shadcn/separator.d.ts +5 -0
  123. package/dist/components/shadcn/separator.d.ts.map +1 -0
  124. package/dist/components/shadcn/sheet.d.ts +19 -0
  125. package/dist/components/shadcn/sheet.d.ts.map +1 -0
  126. package/dist/components/shadcn/sidebar.d.ts +70 -0
  127. package/dist/components/shadcn/sidebar.d.ts.map +1 -0
  128. package/dist/components/shadcn/skeleton.d.ts +3 -0
  129. package/dist/components/shadcn/skeleton.d.ts.map +1 -0
  130. package/dist/components/shadcn/slider.d.ts +5 -0
  131. package/dist/components/shadcn/slider.d.ts.map +1 -0
  132. package/dist/components/shadcn/sonner.d.ts +38 -0
  133. package/dist/components/shadcn/sonner.d.ts.map +1 -0
  134. package/dist/components/shadcn/spinner.d.ts +3 -0
  135. package/dist/components/shadcn/spinner.d.ts.map +1 -0
  136. package/dist/components/shadcn/switch.d.ts +5 -0
  137. package/dist/components/shadcn/switch.d.ts.map +1 -0
  138. package/dist/components/shadcn/table-hooks.d.ts +20 -0
  139. package/dist/components/shadcn/table-hooks.d.ts.map +1 -0
  140. package/dist/components/shadcn/table.d.ts +26 -0
  141. package/dist/components/shadcn/table.d.ts.map +1 -0
  142. package/dist/components/shadcn/tabs.d.ts +8 -0
  143. package/dist/components/shadcn/tabs.d.ts.map +1 -0
  144. package/dist/components/shadcn/textarea.d.ts +4 -0
  145. package/dist/components/shadcn/textarea.d.ts.map +1 -0
  146. package/dist/components/shadcn/toast-types.d.ts +13 -0
  147. package/dist/components/shadcn/toast-types.d.ts.map +1 -0
  148. package/dist/components/shadcn/toast.d.ts +14 -0
  149. package/dist/components/shadcn/toast.d.ts.map +1 -0
  150. package/dist/components/shadcn/toggle-group.d.ts +30 -0
  151. package/dist/components/shadcn/toggle-group.d.ts.map +1 -0
  152. package/dist/components/shadcn/toggle.d.ts +10 -0
  153. package/dist/components/shadcn/toggle.d.ts.map +1 -0
  154. package/dist/components/shadcn/tooltip.d.ts +35 -0
  155. package/dist/components/shadcn/tooltip.d.ts.map +1 -0
  156. package/dist/components/shadcn/typography.d.ts +14 -0
  157. package/dist/components/shadcn/typography.d.ts.map +1 -0
  158. package/dist/components/theme/index.d.ts +4 -0
  159. package/dist/components/theme/index.d.ts.map +1 -0
  160. package/dist/components/theme/theme-provider.d.ts +28 -0
  161. package/dist/components/theme/theme-provider.d.ts.map +1 -0
  162. package/dist/components/theme/theme-switcher.d.ts +33 -0
  163. package/dist/components/theme/theme-switcher.d.ts.map +1 -0
  164. package/dist/components/theme/use-theme.d.ts +20 -0
  165. package/dist/components/theme/use-theme.d.ts.map +1 -0
  166. package/dist/fonts.css +331 -0
  167. package/dist/hooks/use-mobile.d.ts +2 -0
  168. package/dist/hooks/use-mobile.d.ts.map +1 -0
  169. package/dist/index.cjs +548 -0
  170. package/dist/index.css +1 -0
  171. package/dist/index.d.ts +80 -0
  172. package/dist/index.d.ts.map +1 -0
  173. package/dist/index.js +77374 -0
  174. package/dist/lib/border-styles.d.ts +33 -0
  175. package/dist/lib/border-styles.d.ts.map +1 -0
  176. package/dist/lib/global-toast.d.ts +35 -0
  177. package/dist/lib/global-toast.d.ts.map +1 -0
  178. package/dist/lib/gradient-styles.d.ts +23 -0
  179. package/dist/lib/gradient-styles.d.ts.map +1 -0
  180. package/dist/lib/scales.d.ts +335 -0
  181. package/dist/lib/scales.d.ts.map +1 -0
  182. package/dist/lib/utils.d.ts +3 -0
  183. package/dist/lib/utils.d.ts.map +1 -0
  184. package/dist/recipes.css +108 -0
  185. package/dist/theme.css +650 -0
  186. package/dist/vite.svg +1 -0
  187. package/package.json +156 -0
package/dist/theme.css ADDED
@@ -0,0 +1,650 @@
1
+
2
+
3
+ @custom-variant dark (&:where(.dark, .dark *));
4
+
5
+ @theme inline {
6
+ /*
7
+ * ============================================================================
8
+ * DESIGN TOKEN SYSTEM - LAYERED ARCHITECTURE
9
+ * ============================================================================
10
+ *
11
+ * This theme implements a layered token system based on Movement Design Tokens:
12
+ *
13
+ * Layer 1: Primitives (spacing, sizing, radii, borders, shadows, opacity)
14
+ * Layer 2: Brand Colors (moveus-marigold, guild-green, etc.)
15
+ * Layer 3: Semantic Base (bg, fg, border, feedback)
16
+ * Layer 4: Component Tokens (accordion, badge, input, etc.)
17
+ * Layer 5: Legacy Mappings (--primary, --secondary, etc.)
18
+ *
19
+ * Source: movement-design-tokens-FULL/design-tokens/
20
+ * ============================================================================
21
+ */
22
+
23
+ /* ========================================================================
24
+ * LAYER 1: PRIMITIVE TOKENS
25
+ * ======================================================================== */
26
+
27
+ /* Spacing scale - based on 2px base scale */
28
+ --spacing-0: 0px;
29
+ --spacing-1: 4px;
30
+ --spacing-2: 8px;
31
+ --spacing-3: 12px;
32
+ --spacing-4: 16px;
33
+ --spacing-5: 20px;
34
+ --spacing-6: 24px;
35
+ --spacing-7: 28px;
36
+ --spacing-8: 32px;
37
+ --spacing-9: 36px;
38
+ --spacing-10: 40px;
39
+ --spacing-12: 48px;
40
+ --spacing-14: 56px;
41
+ --spacing-16: 64px;
42
+ --spacing-20: 80px;
43
+ --spacing-24: 96px;
44
+ --spacing-28: 112px;
45
+ --spacing-32: 128px;
46
+ --spacing-36: 144px;
47
+ --spacing-40: 160px;
48
+ --spacing-44: 176px;
49
+ --spacing-48: 192px;
50
+ --spacing-52: 208px;
51
+ --spacing-56: 224px;
52
+ --spacing-60: 240px;
53
+ --spacing-64: 256px;
54
+ --spacing-72: 288px;
55
+ --spacing-80: 320px;
56
+ --spacing-96: 384px;
57
+ --spacing-100: 400px;
58
+ --spacing-px: 1px;
59
+
60
+ /* Sizes - includes spacing scale plus semantic sizes */
61
+ --size-0: 0px;
62
+ --size-1: 4px;
63
+ --size-2: 8px;
64
+ --size-3: 12px;
65
+ --size-4: 16px;
66
+ --size-5: 20px;
67
+ --size-6: 24px;
68
+ --size-7: 28px;
69
+ --size-8: 32px;
70
+ --size-9: 36px;
71
+ --size-10: 40px;
72
+ --size-12: 48px;
73
+ --size-14: 56px;
74
+ --size-16: 64px;
75
+ --size-20: 80px;
76
+ --size-24: 96px;
77
+ --size-28: 112px;
78
+ --size-32: 128px;
79
+ --size-36: 144px;
80
+ --size-40: 160px;
81
+ --size-44: 176px;
82
+ --size-48: 192px;
83
+ --size-52: 208px;
84
+ --size-56: 224px;
85
+ --size-60: 240px;
86
+ --size-64: 256px;
87
+ --size-72: 288px;
88
+ --size-80: 320px;
89
+ --size-96: 384px;
90
+ --size-100: 400px;
91
+ --size-px: 1px;
92
+ --size-prose: 65ch;
93
+ --size-full: 100%;
94
+ --size-min: min-content;
95
+ --size-max: max-content;
96
+ --size-fit: fit-content;
97
+
98
+ /* Border radius tokens */
99
+ --radius-sm: 2px;
100
+ --radius-base: 4px;
101
+ --radius-md: 6px;
102
+ --radius-lg: 8px;
103
+ --radius-xl: 12px;
104
+ --radius-2xl: 16px;
105
+ --radius-3xl: 24px;
106
+ --radius-full: 9999px;
107
+
108
+ /* Border widths */
109
+ --border-width-0: 0px;
110
+ --border-width-1: 1px;
111
+ --border-width-2: 2px;
112
+ --border-width-3: 3px;
113
+ --border-width-4: 4px;
114
+ --border-width-5: 5px;
115
+ --border-width-6: 6px;
116
+ --border-width-7: 7px;
117
+ --border-width-8: 8px;
118
+
119
+ /* Shadows */
120
+ --shadow-xs: 0 0 0 1px #0000000d;
121
+ --shadow-sm: 0 1px 2px 0 #0000000d;
122
+ --shadow-base: 0 1px 2px 0 #0000000d, 0 1px 3px 0 #0000000d;
123
+ --shadow-md: 0 2px 4px -1px #00000005, 0 4px 6px -1px #00000014;
124
+ --shadow-lg: 0 4px 6px -2px #00000005, 0 10px 15px -3px #0000000d;
125
+ --shadow-xl: 0 10px 10px -5px #00000005, 0 20px 25px -5px #0000000d;
126
+ --shadow-2xl: 0 25px 50px -12px #00000040;
127
+ --shadow-inner: inset 0 2px 4px 0 #00000006;
128
+ --shadow-none: none;
129
+
130
+ /* Z-index scale */
131
+ --z-index-hide: -1;
132
+ --z-index-auto: auto;
133
+ --z-index-base: 0;
134
+ --z-index-docked: 10;
135
+ --z-index-dropdown: 1000;
136
+ --z-index-sticky: 1100;
137
+ --z-index-banner: 1200;
138
+ --z-index-overlay: 1300;
139
+ --z-index-modal: 1400;
140
+ --z-index-popover: 1500;
141
+ --z-index-skip-link: 1600;
142
+ --z-index-toast: 1700;
143
+ --z-index-tooltip: 1800;
144
+
145
+ /* Semantic color mappings */
146
+ --color-background: var(--background);
147
+ --color-foreground: var(--foreground);
148
+ --color-card: var(--card);
149
+ --color-card-foreground: var(--card-foreground);
150
+ --color-popover: var(--popover);
151
+ --color-popover-foreground: var(--popover-foreground);
152
+ --color-primary: var(--primary);
153
+ --color-primary-foreground: var(--primary-foreground);
154
+ --color-secondary: var(--secondary);
155
+ --color-secondary-foreground: var(--secondary-foreground);
156
+ --color-muted: var(--muted);
157
+ --color-muted-foreground: var(--muted-foreground);
158
+ --color-accent: var(--accent);
159
+ --color-accent-foreground: var(--accent-foreground);
160
+ --color-destructive: var(--destructive);
161
+ --color-destructive-foreground: var(--destructive-foreground);
162
+ --color-info: var(--info);
163
+ --color-info-foreground: var(--info-foreground);
164
+ --color-success: var(--success);
165
+ --color-success-foreground: var(--success-foreground);
166
+ --color-warning: var(--warning);
167
+ --color-warning-foreground: var(--warning-foreground);
168
+ --color-error: var(--error);
169
+ --color-error-foreground: var(--error-foreground);
170
+ --color-border: var(--border);
171
+ --color-input: var(--input);
172
+ --color-ring: var(--ring);
173
+ --color-chart-1: var(--chart-1);
174
+ --color-chart-2: var(--chart-2);
175
+ --color-chart-3: var(--chart-3);
176
+ --color-chart-4: var(--chart-4);
177
+ --color-chart-5: var(--chart-5);
178
+ --color-sidebar: var(--sidebar);
179
+ --color-sidebar-foreground: var(--sidebar-foreground);
180
+ --color-sidebar-primary: var(--sidebar-primary);
181
+ --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
182
+ --color-sidebar-accent: var(--sidebar-accent);
183
+ --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
184
+ --color-sidebar-border: var(--sidebar-border);
185
+ --color-sidebar-ring: var(--sidebar-ring);
186
+
187
+ /* ========================================================================
188
+ * LAYER 2: BRAND COLOR TOKENS
189
+ * ======================================================================== */
190
+
191
+ /* Brand colors - Moveus Marigold */
192
+ --color-moveus-marigold-50: #fffbeb;
193
+ --color-moveus-marigold-100: #fff2bd;
194
+ --color-moveus-marigold-200: #ffea90;
195
+ --color-moveus-marigold-300: #ffe162;
196
+ --color-moveus-marigold-400: #ffd935;
197
+ --color-moveus-marigold-500: #ddba22;
198
+ --color-moveus-marigold-600: #bb9b13;
199
+ --color-moveus-marigold-700: #997e08;
200
+ --color-moveus-marigold-800: #776100;
201
+ --color-moveus-marigold-900: #554500;
202
+
203
+ /* Brand colors - Guild Green */
204
+ --color-guild-green-50: #f2fff8;
205
+ --color-guild-green-100: #ccffe3;
206
+ --color-guild-green-200: #a7ffce;
207
+ --color-guild-green-300: #81ffba;
208
+ --color-guild-green-400: #6ce2a1;
209
+ --color-guild-green-500: #58c589;
210
+ --color-guild-green-600: #47a872;
211
+ --color-guild-green-700: #368a5c;
212
+ --color-guild-green-800: #286d47;
213
+ --color-guild-green-900: #1b5033;
214
+
215
+ /* Brand colors - Byzantine Blue */
216
+ --color-byzantine-blue-50: #c2ceff;
217
+ --color-byzantine-blue-100: #859dff;
218
+ --color-byzantine-blue-200: #5c7cff;
219
+ --color-byzantine-blue-300: #335cff;
220
+ --color-byzantine-blue-400: #0337ff;
221
+ --color-byzantine-blue-500: #002cd6;
222
+ --color-byzantine-blue-600: #0024ad;
223
+ --color-byzantine-blue-700: #001b85;
224
+ --color-byzantine-blue-800: #00135c;
225
+ --color-byzantine-blue-900: #000c3d;
226
+
227
+ /* Brand colors - Protocol Pink */
228
+ --color-protocol-pink-50: #fff1fc;
229
+ --color-protocol-pink-100: #ffc9f3;
230
+ --color-protocol-pink-200: #ffa0eb;
231
+ --color-protocol-pink-300: #ff77e2;
232
+ --color-protocol-pink-400: #eb66cf;
233
+ --color-protocol-pink-500: #ce52b4;
234
+ --color-protocol-pink-600: #b14199;
235
+ --color-protocol-pink-700: #94317f;
236
+ --color-protocol-pink-800: #762365;
237
+ --color-protocol-pink-900: #59184b;
238
+
239
+ /* Brand colors - Oracle Orange */
240
+ --color-oracle-orange-50: #ffefec;
241
+ --color-oracle-orange-100: #ffcdc2;
242
+ --color-oracle-orange-200: #ffab97;
243
+ --color-oracle-orange-300: #ff886d;
244
+ --color-oracle-orange-400: #FF6642;
245
+ --color-oracle-orange-500: #ea5330;
246
+ --color-oracle-orange-600: #c83e1e;
247
+ --color-oracle-orange-700: #a62c10;
248
+ --color-oracle-orange-800: #841d05;
249
+ --color-oracle-orange-900: #621300;
250
+
251
+ /* Neutrals */
252
+ --color-neutrals-white: #ffffff;
253
+ --color-neutrals-black: #000000;
254
+
255
+ /* Neutrals - White Alpha */
256
+ --color-neutrals-white-alpha-50: #ffffff0a;
257
+ --color-neutrals-white-alpha-100: #ffffff0f;
258
+ --color-neutrals-white-alpha-200: #ffffff14;
259
+ --color-neutrals-white-alpha-300: #ffffff29;
260
+ --color-neutrals-white-alpha-400: #ffffff3d;
261
+ --color-neutrals-white-alpha-500: #ffffff5c;
262
+ --color-neutrals-white-alpha-600: #ffffff7a;
263
+ --color-neutrals-white-alpha-700: #ffffffa3;
264
+ --color-neutrals-white-alpha-800: #ffffffcc;
265
+ --color-neutrals-white-alpha-900: #ffffffeb;
266
+
267
+ /* Neutrals - Black Alpha */
268
+ --color-neutrals-black-alpha-50: #0000000a;
269
+ --color-neutrals-black-alpha-100: #0000000f;
270
+ --color-neutrals-black-alpha-200: #00000014;
271
+ --color-neutrals-black-alpha-300: #00000029;
272
+ --color-neutrals-black-alpha-400: #0000003d;
273
+ --color-neutrals-black-alpha-500: #0000005c;
274
+ --color-neutrals-black-alpha-600: #0000007a;
275
+ --color-neutrals-black-alpha-700: #000000a3;
276
+ --color-neutrals-black-alpha-800: #000000cc;
277
+ --color-neutrals-black-alpha-900: #000000eb;
278
+
279
+ /* Opacity values */
280
+ /* commenting out because it's interfereing with default scale */
281
+ /* --opacity-1: 0.1;
282
+ --opacity-2: 0.2;
283
+ --opacity-3: 0.3;
284
+ --opacity-4: 0.4;
285
+ --opacity-5: 0.5;
286
+ --opacity-8: 0.8;
287
+ --opacity-9: 0.9;
288
+ --opacity-10: 1; */
289
+
290
+ /* Font families */
291
+ --font-heading: "TWK Everett", sans-serif;
292
+ --font-body: "Neue Haas Unica Pro", sans-serif;
293
+ --font-mono: "TWK Everett Mono", monospace;
294
+
295
+ /* Container configuration */
296
+ --container-center: true;
297
+ --container-padding: 2rem;
298
+ --container-2xl: 1400px;
299
+
300
+ /* Animations */
301
+ --animate-accordion-down: accordion-down 0.2s ease-out;
302
+ --animate-accordion-up: accordion-up 0.2s ease-out;
303
+
304
+ @keyframes accordion-down {
305
+ from {
306
+ height: 0;
307
+ }
308
+ to {
309
+ height: var(--radix-accordion-content-height);
310
+ }
311
+ }
312
+
313
+ @keyframes accordion-up {
314
+ from {
315
+ height: var(--radix-accordion-content-height);
316
+ }
317
+ to {
318
+ height: 0;
319
+ }
320
+ }
321
+
322
+ /* ========================================================================
323
+ * LAYER 3: SEMANTIC BASE TOKENS
324
+ * ======================================================================== */
325
+
326
+ /* These tokens provide semantic meaning to primitives and brand colors.
327
+ * They are theme-aware and change between light/dark modes.
328
+ * Source: Inferred from component token references in design-tokens/semantic/
329
+ */
330
+
331
+ /* ========================================================================
332
+ * LAYER 4: COMPONENT TOKENS
333
+ * ======================================================================== */
334
+
335
+ /* Component-specific tokens that reference semantic base tokens.
336
+ * These create a reference chain: Component → Semantic → Brand → Primitive
337
+ * Source: movement-design-tokens-FULL/design-tokens/semantic/
338
+ *
339
+ * Note: Component tokens are defined inline within component declarations below
340
+ * using the semantic base tokens (--semantic-*) as their foundation.
341
+ */
342
+
343
+ /* ========================================================================
344
+ * TAILWIND UTILITY CLASS MAPPINGS
345
+ * ========================================================================
346
+ *
347
+ * Map semantic tokens to Tailwind utility classes for better DX.
348
+ * Instead of: text-[var(--semantic-fg-muted)]
349
+ * Use: text-fg-muted
350
+ */
351
+
352
+ /* Semantic background colors */
353
+ --color-semantic-base: var(--semantic-bg-base);
354
+ --color-semantic-alt-1: var(--semantic-bg-alt-1);
355
+ --color-semantic-alt-2: var(--semantic-bg-alt-2);
356
+
357
+ /* Semantic foreground colors */
358
+ --color-fg-base: var(--semantic-fg-base);
359
+ --color-fg-muted: var(--semantic-fg-muted);
360
+ --color-fg-subtle: var(--semantic-fg-subtle);
361
+
362
+ /* Semantic border colors */
363
+ --color-border-default: var(--semantic-border-default);
364
+ --color-border-strong: var(--semantic-border-strong);
365
+
366
+ /* Semantic feedback colors */
367
+ --color-feedback-success: var(--semantic-feedback-success-default);
368
+ --color-feedback-success-light: var(--semantic-feedback-success-light);
369
+ --color-feedback-error: var(--semantic-feedback-error-default);
370
+ --color-feedback-error-light: var(--semantic-feedback-error-light);
371
+ --color-feedback-warning: var(--semantic-feedback-warning-default);
372
+ --color-feedback-warning-light: var(--semantic-feedback-warning-light);
373
+ --color-feedback-info: var(--semantic-feedback-info-default);
374
+ --color-feedback-info-light: var(--semantic-feedback-info-light);
375
+
376
+ /* Semantic disabled state */
377
+ --color-disabled: var(--semantic-disabled-base);
378
+ }
379
+
380
+ :root {
381
+ --radius: 0.625rem;
382
+
383
+ /* ========================================================================
384
+ * LAYER 3: SEMANTIC BASE TOKENS (Light Theme Default)
385
+ * ======================================================================== */
386
+
387
+ /* Background semantic tokens */
388
+ --semantic-bg-base: #ffffff;
389
+ --semantic-bg-alt-1: #f5f5f5;
390
+ --semantic-bg-alt-2: #ebebeb;
391
+
392
+ /* Foreground semantic tokens */
393
+ --semantic-fg-base: #000000;
394
+ --semantic-fg-muted: rgba(0, 0, 0, 0.64);
395
+ --semantic-fg-subtle: rgba(0, 0, 0, 0.40);
396
+
397
+ /* Border semantic tokens */
398
+ --semantic-border-default: rgba(0, 0, 0, 0.12);
399
+ --semantic-border-strong: rgba(0, 0, 0, 0.24);
400
+
401
+ /* Feedback semantic tokens */
402
+ --semantic-feedback-success-default: var(--color-guild-green-600);
403
+ --semantic-feedback-success-light: var(--color-guild-green-50);
404
+ --semantic-feedback-error-default: #D82C2D;
405
+ --semantic-feedback-error-light: #ffeaea;
406
+ --semantic-feedback-warning-default: var(--color-oracle-orange-600);
407
+ --semantic-feedback-warning-light: var(--color-oracle-orange-50);
408
+ --semantic-feedback-info-default: var(--color-byzantine-blue-500);
409
+ --semantic-feedback-info-light: var(--color-byzantine-blue-50);
410
+
411
+ /* Disabled state */
412
+ --semantic-disabled-base: var(--color-neutrals-black-alpha-300);
413
+
414
+ /* ========================================================================
415
+ * LAYER 4 → LAYER 5: TOKEN MAPPING DOCUMENTATION
416
+ * ========================================================================
417
+ *
418
+ * This documents how existing (legacy) CSS variables map to the new
419
+ * layered token system. The legacy variables are preserved for backward
420
+ * compatibility with existing components.
421
+ *
422
+ * LEGACY VARIABLE → NEW TOKEN PATH
423
+ * -------------------------------------------------------------------------
424
+ * --primary → semantic.brand.primary.default (guild-green.300)
425
+ * --primary-foreground → semantic.brand.primary.on-primary
426
+ * --secondary → semantic.brand.secondary.default (byzantine-blue.400)
427
+ * --secondary-foreground → semantic.brand.secondary.on-secondary
428
+ * --accent → semantic.brand.accent.default (protocol-pink.400)
429
+ * --accent-foreground → semantic.brand.accent.on-accent
430
+ * --destructive → semantic.brand.error.default
431
+ * --destructive-foreground → semantic.brand.error.on-error
432
+ * --success → semantic.brand.success.default (guild-green.400)
433
+ * --success-foreground → semantic.brand.success.on-success
434
+ * --warning → semantic.brand.warning.default (oracle-orange.500)
435
+ * --warning-foreground → semantic.brand.warning.on-warning
436
+ * --error → semantic.brand.error.default (#D82C2D)
437
+ * --error-foreground → semantic.brand.error.on-error
438
+ * --info → semantic.feedback.info.default (byzantine-blue.400)
439
+ * --info-foreground → semantic.feedback.info.on-info
440
+ * --muted → semantic.bg.alt-1
441
+ * --muted-foreground → semantic.fg.muted
442
+ * --border → semantic.border.default
443
+ * --input → semantic.bg.alt-1
444
+ * --ring → semantic.brand.primary.default
445
+ * --background → semantic.bg.base
446
+ * --foreground → semantic.fg.base
447
+ * -------------------------------------------------------------------------
448
+ */
449
+
450
+ /* ========================================================================
451
+ * LAYER 5: LEGACY SEMANTIC MAPPINGS (Light Mode)
452
+ * ======================================================================== */
453
+
454
+ /* Backgrounds & Foregrounds */
455
+ --background: hsl(0 0% 100%); /* white - light theme default */
456
+ --foreground: hsl(0 0% 0%); /* black - default text */
457
+ --card: hsl(0 0% 100%); /* white card */
458
+ --card-foreground: hsl(0 0% 0%); /* black text */
459
+ --popover: hsl(0 0% 100%); /* white - menu/dropdown bg */
460
+ --popover-foreground: hsl(0 0% 0%); /* black - menu text */
461
+
462
+ /* Brand semantic colors (light theme) */
463
+ --primary: hsl(154 66% 66%); /* guild-green.400 */
464
+ --primary-foreground: hsl(0 0% 0%); /* black - for green bg */
465
+ --secondary: hsl(228 100% 50%); /* byzantine-blue.400 */
466
+ --secondary-foreground: hsl(0 0% 100%); /* white - for blue bg */
467
+ --accent: hsl(304 100% 73%); /* protocol-pink.300 */
468
+ --accent-foreground: hsl(0 0% 0%); /* black - for pink bg */
469
+ --destructive: hsl(0 72% 51%); /* red for destructive actions */
470
+ --destructive-foreground: hsl(0 0% 100%); /* white */
471
+
472
+ /* Feedback colors - for alerts/toasts */
473
+ --info: hsl(228 100% 50%); /* byzantine-blue.400 */
474
+ --info-foreground: hsl(0 0% 100%); /* white */
475
+ --success: hsl(154 66% 66%); /* guild-green.400 */
476
+ --success-foreground: hsl(0 0% 0%); /* black */
477
+ --warning: hsl(47 100% 60%); /* moveus-marigold.400 */
478
+ --warning-foreground: hsl(0 0% 0%); /* black */
479
+ --error: hsl(0 72% 51%); /* red */
480
+ --error-foreground: hsl(0 0% 100%); /* white */
481
+
482
+ /* Muted & UI elements */
483
+ --muted: hsl(0 0% 96%); /* light muted bg */
484
+ --muted-foreground: hsl(0 0% 40%); /* muted gray */
485
+ --border: hsl(0 0% 0% / 12%); /* rgba(0,0,0,0.12) */
486
+ --input: hsl(0 0% 0% / 12%); /* rgba(0,0,0,0.12) */
487
+ --ring: hsl(154 66% 66%); /* guild-green.400 - focus ring */
488
+
489
+ /* Charts (using brand colors) */
490
+ --chart-1: hsl(154 66% 66%); /* guild-green.400 */
491
+ --chart-2: hsl(228 100% 50%); /* byzantine-blue.400 */
492
+ --chart-3: hsl(304 100% 73%); /* protocol-pink.300 */
493
+ --chart-4: hsl(13 100% 63%); /* oracle-orange.400 */
494
+ --chart-5: hsl(47 100% 60%); /* moveus-marigold.400 */
495
+
496
+ /* Sidebar */
497
+ --sidebar: hsl(0 0% 98%); /* light */
498
+ --sidebar-foreground: hsl(0 0% 0%); /* black */
499
+ --sidebar-primary: hsl(154 66% 66%); /* guild-green.400 */
500
+ --sidebar-primary-foreground: hsl(0 0% 0%); /* black */
501
+ --sidebar-accent: hsl(0 0% 96%); /* light gray */
502
+ --sidebar-accent-foreground: hsl(0 0% 0%); /* black */
503
+ --sidebar-border: hsl(0 0% 0% / 10%);
504
+ --sidebar-ring: hsl(154 66% 66%);
505
+ }
506
+
507
+ .dark {
508
+ /* ========================================================================
509
+ * LAYER 3: SEMANTIC BASE TOKENS (Dark Mode)
510
+ * ======================================================================== */
511
+
512
+ /* Background semantic tokens */
513
+ --semantic-bg-base: #000000;
514
+ --semantic-bg-alt-1: #0a0a0a; /* ~4% white */
515
+ --semantic-bg-alt-2: #141414; /* ~8% white */
516
+
517
+ /* Foreground semantic tokens */
518
+ --semantic-fg-base: #ffffff;
519
+ --semantic-fg-muted: rgba(255, 255, 255, 0.64);
520
+ --semantic-fg-subtle: rgba(255, 255, 255, 0.40);
521
+
522
+ /* Border semantic tokens */
523
+ --semantic-border-default: rgba(255, 255, 255, 0.12);
524
+ --semantic-border-strong: rgba(255, 255, 255, 0.24);
525
+
526
+ /* Feedback semantic tokens (dark mode - brighter variants for visibility) */
527
+ --semantic-feedback-success-default: var(--color-guild-green-400);
528
+ --semantic-feedback-success-light: var(--color-guild-green-900);
529
+ --semantic-feedback-error-default: #ff4d4d;
530
+ --semantic-feedback-error-light: #3d1414;
531
+ --semantic-feedback-warning-default: var(--color-oracle-orange-400);
532
+ --semantic-feedback-warning-light: var(--color-oracle-orange-900);
533
+ --semantic-feedback-info-default: var(--color-byzantine-blue-300);
534
+ --semantic-feedback-info-light: var(--color-byzantine-blue-900);
535
+
536
+ /* Disabled state */
537
+ --semantic-disabled-base: rgba(255, 255, 255, 0.16);
538
+
539
+ /* ========================================================================
540
+ * LAYER 5: LEGACY SEMANTIC MAPPINGS (Dark Mode)
541
+ * ======================================================================== */
542
+
543
+ /* Dark mode backgrounds & foregrounds */
544
+ --background: hsl(0 0% 0%); /* black */
545
+ --foreground: hsl(0 0% 100%); /* white */
546
+ --card: hsl(0 0% 7%);
547
+ --card-foreground: hsl(0 0% 100%);
548
+ --popover: hsl(0 0% 7%);
549
+ --popover-foreground: hsl(0 0% 100%);
550
+
551
+ /* Brand semantic colors (dark mode) */
552
+ --primary: hsl(150 100% 75%); /* guild-green.300 - brighter for dark mode */
553
+ --primary-foreground: hsl(0 0% 0%);
554
+ --secondary: hsl(228 100% 65%); /* byzantine-blue.200 - lighter for dark mode */
555
+ --secondary-foreground: hsl(0 0% 0%);
556
+ --accent: hsl(304 100% 73%); /* protocol-pink.300 */
557
+ --accent-foreground: hsl(0 0% 0%);
558
+ --destructive: hsl(0 72% 60%); /* brighter red for dark mode */
559
+ --destructive-foreground: hsl(0 0% 100%);
560
+
561
+ /* Feedback colors (dark mode) */
562
+ --info: hsl(228 100% 65%); /* byzantine-blue.200 */
563
+ --info-foreground: hsl(0 0% 0%);
564
+ --success: hsl(150 100% 75%); /* guild-green.300 - brighter */
565
+ --success-foreground: hsl(0 0% 0%);
566
+ --warning: hsl(47 100% 60%); /* moveus-marigold.400 */
567
+ --warning-foreground: hsl(0 0% 0%);
568
+ --error: hsl(0 72% 60%); /* brighter red */
569
+ --error-foreground: hsl(0 0% 100%);
570
+
571
+ /* Muted & UI elements (dark mode) */
572
+ --muted: hsl(0 0% 15%);
573
+ --muted-foreground: hsl(0 0% 64%);
574
+ --border: hsl(0 0% 100% / 12%);
575
+ --input: hsl(0 0% 100% / 12%);
576
+ --ring: hsl(150 100% 75%); /* guild-green.300 */
577
+
578
+ /* Charts (dark mode) */
579
+ --chart-1: hsl(150 100% 75%); /* guild-green.300 */
580
+ --chart-2: hsl(228 100% 65%); /* byzantine-blue.200 */
581
+ --chart-3: hsl(304 100% 73%); /* protocol-pink.300 */
582
+ --chart-4: hsl(13 100% 63%); /* oracle-orange.400 */
583
+ --chart-5: hsl(47 100% 60%); /* moveus-marigold.400 */
584
+
585
+ /* Sidebar (dark mode) */
586
+ --sidebar: hsl(0 0% 5%);
587
+ --sidebar-foreground: hsl(0 0% 100%);
588
+ --sidebar-primary: hsl(150 100% 75%); /* guild-green.300 */
589
+ --sidebar-primary-foreground: hsl(0 0% 0%);
590
+ --sidebar-accent: hsl(0 0% 15%);
591
+ --sidebar-accent-foreground: hsl(0 0% 100%);
592
+ --sidebar-border: hsl(0 0% 100% / 10%);
593
+ --sidebar-ring: hsl(150 100% 75%);
594
+ }
595
+
596
+ /* ============================================================================
597
+ * COMPONENT TOKEN COVERAGE SUMMARY
598
+ * ============================================================================
599
+ *
600
+ * Components WITH matching token files (16 components UPDATED):
601
+ * -------------------------------------------------------------------------
602
+ * ✓ accordion.tsx → semantic-accordion.json
603
+ * ✓ avatar.tsx → semantic-avatar.json
604
+ * ✓ badge.tsx → semantic-badge.json + semantic-tag.json
605
+ * ✓ card.tsx → semantic-surface.json
606
+ * ✓ checkbox.tsx → semantic-checkbox.json
607
+ * ✓ dialog.tsx → semantic-modal.json
608
+ * ✓ input.tsx → semantic-input.json
609
+ * ✓ navigation-menu.tsx → semantic-navigation.json
610
+ * ✓ pagination.tsx → semantic-pagination.json
611
+ * ✓ radio-group.tsx → semantic-radio.json
612
+ * ✓ select.tsx → semantic-select.json
613
+ * ✓ slider.tsx → semantic-slider.json
614
+ * ✓ switch.tsx → semantic-switch.json
615
+ * ✓ table.tsx → semantic-table.json
616
+ * ✓ tooltip.tsx → semantic-tooltip.json
617
+ * ✓ sonner.tsx → semantic-toast.json (Toaster component)
618
+ *
619
+ * Components WITHOUT matching token files (37 components):
620
+ * -------------------------------------------------------------------------
621
+ * These components use legacy semantic tokens (--primary, --border, etc.)
622
+ * or have custom styling that doesn't map to the design token system:
623
+ *
624
+ * alert, alert-dialog, aspect-ratio, breadcrumb, button, button-group,
625
+ * calendar, carousel, chart, collapsible, command, context-menu,
626
+ * crypto-amount-input, drawer, dropdown-menu, empty, field, form,
627
+ * hover-card, input-group, input-otp, item, kbd, label, menubar, popover,
628
+ * progress, resizable, scroll-area, separator, sheet, sidebar, skeleton,
629
+ * spinner, tabs, textarea, toggle, toggle-group, typography
630
+ *
631
+ * Token files WITHOUT matching components (3 files):
632
+ * -------------------------------------------------------------------------
633
+ * These token files don't have corresponding components in the system:
634
+ *
635
+ * - semantic-stepper.json (no stepper component exists)
636
+ * - semantic-list.json (could apply to item.tsx, unclear mapping)
637
+ * - semantic-segmented-control.json (could apply to toggle-group.tsx, unclear)
638
+ *
639
+ * ============================================================================
640
+ */
641
+
642
+ @layer base {
643
+ * {
644
+ @apply border-border outline-ring/50;
645
+ }
646
+ body {
647
+ @apply bg-background text-foreground;
648
+ font-family: var(--font-family-body);
649
+ }
650
+ }
package/dist/vite.svg ADDED
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="31.88" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 257"><defs><linearGradient id="IconifyId1813088fe1fbc01fb466" x1="-.828%" x2="57.636%" y1="7.652%" y2="78.411%"><stop offset="0%" stop-color="#41D1FF"></stop><stop offset="100%" stop-color="#BD34FE"></stop></linearGradient><linearGradient id="IconifyId1813088fe1fbc01fb467" x1="43.376%" x2="50.316%" y1="2.242%" y2="89.03%"><stop offset="0%" stop-color="#FFEA83"></stop><stop offset="8.333%" stop-color="#FFDD35"></stop><stop offset="100%" stop-color="#FFA800"></stop></linearGradient></defs><path fill="url(#IconifyId1813088fe1fbc01fb466)" d="M255.153 37.938L134.897 252.976c-2.483 4.44-8.862 4.466-11.382.048L.875 37.958c-2.746-4.814 1.371-10.646 6.827-9.67l120.385 21.517a6.537 6.537 0 0 0 2.322-.004l117.867-21.483c5.438-.991 9.574 4.796 6.877 9.62Z"></path><path fill="url(#IconifyId1813088fe1fbc01fb467)" d="M185.432.063L96.44 17.501a3.268 3.268 0 0 0-2.634 3.014l-5.474 92.456a3.268 3.268 0 0 0 3.997 3.378l24.777-5.718c2.318-.535 4.413 1.507 3.936 3.838l-7.361 36.047c-.495 2.426 1.782 4.5 4.151 3.78l15.304-4.649c2.372-.72 4.652 1.36 4.15 3.788l-11.698 56.621c-.732 3.542 3.979 5.473 5.943 2.437l1.313-2.028l72.516-144.72c1.215-2.423-.88-5.186-3.54-4.672l-25.505 4.922c-2.396.462-4.435-1.77-3.759-4.114l16.646-57.705c.677-2.35-1.37-4.583-3.769-4.113Z"></path></svg>