@morscherlab/mld-sdk 0.6.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 (714) hide show
  1. package/README.md +326 -0
  2. package/dist/__tests__/components/AppLayout.test.d.ts +1 -0
  3. package/dist/__tests__/components/AppSidebar.test.d.ts +1 -0
  4. package/dist/__tests__/components/AppTopBar.test.d.ts +1 -0
  5. package/dist/__tests__/components/BaseInput.test.d.ts +1 -0
  6. package/dist/__tests__/components/BasePill.test.d.ts +1 -0
  7. package/dist/__tests__/components/Calendar.test.d.ts +1 -0
  8. package/dist/__tests__/components/CollapsibleCard.test.d.ts +1 -0
  9. package/dist/__tests__/components/DataFrame.test.d.ts +1 -0
  10. package/dist/__tests__/components/DropdownButton.test.d.ts +1 -0
  11. package/dist/__tests__/composables/useAuth.test.d.ts +1 -0
  12. package/dist/__tests__/composables/useForm.test.d.ts +1 -0
  13. package/dist/components/AlertBox.vue.d.ts +30 -0
  14. package/dist/components/AlertBox.vue.js +125 -0
  15. package/dist/components/AlertBox.vue.js.map +1 -0
  16. package/dist/components/AlertBox.vue3.js +6 -0
  17. package/dist/components/AlertBox.vue3.js.map +1 -0
  18. package/dist/components/AppContainer.vue.d.ts +28 -0
  19. package/dist/components/AppContainer.vue.js +28 -0
  20. package/dist/components/AppContainer.vue.js.map +1 -0
  21. package/dist/components/AppContainer.vue2.js +5 -0
  22. package/dist/components/AppContainer.vue2.js.map +1 -0
  23. package/dist/components/AppLayout.vue.d.ts +31 -0
  24. package/dist/components/AppLayout.vue.js +51 -0
  25. package/dist/components/AppLayout.vue.js.map +1 -0
  26. package/dist/components/AppLayout.vue3.js +6 -0
  27. package/dist/components/AppLayout.vue3.js.map +1 -0
  28. package/dist/components/AppSidebar.vue.d.ts +44 -0
  29. package/dist/components/AppSidebar.vue.js +79 -0
  30. package/dist/components/AppSidebar.vue.js.map +1 -0
  31. package/dist/components/AppSidebar.vue3.js +6 -0
  32. package/dist/components/AppSidebar.vue3.js.map +1 -0
  33. package/dist/components/AppTopBar.vue.d.ts +77 -0
  34. package/dist/components/AppTopBar.vue.js +564 -0
  35. package/dist/components/AppTopBar.vue.js.map +1 -0
  36. package/dist/components/AppTopBar.vue3.js +6 -0
  37. package/dist/components/AppTopBar.vue3.js.map +1 -0
  38. package/dist/components/AuditTrail.vue.d.ts +47 -0
  39. package/dist/components/AuditTrail.vue.js +189 -0
  40. package/dist/components/AuditTrail.vue.js.map +1 -0
  41. package/dist/components/AuditTrail.vue3.js +6 -0
  42. package/dist/components/AuditTrail.vue3.js.map +1 -0
  43. package/dist/components/Avatar.vue.d.ts +13 -0
  44. package/dist/components/Avatar.vue.js +64 -0
  45. package/dist/components/Avatar.vue.js.map +1 -0
  46. package/dist/components/Avatar.vue3.js +6 -0
  47. package/dist/components/Avatar.vue3.js.map +1 -0
  48. package/dist/components/BaseButton.vue.d.ts +37 -0
  49. package/dist/components/BaseButton.vue.js +64 -0
  50. package/dist/components/BaseButton.vue.js.map +1 -0
  51. package/dist/components/BaseButton.vue3.js +6 -0
  52. package/dist/components/BaseButton.vue3.js.map +1 -0
  53. package/dist/components/BaseCheckbox.vue.d.ts +16 -0
  54. package/dist/components/BaseCheckbox.vue.js +71 -0
  55. package/dist/components/BaseCheckbox.vue.js.map +1 -0
  56. package/dist/components/BaseCheckbox.vue3.js +6 -0
  57. package/dist/components/BaseCheckbox.vue3.js.map +1 -0
  58. package/dist/components/BaseInput.vue.d.ts +33 -0
  59. package/dist/components/BaseInput.vue.js +57 -0
  60. package/dist/components/BaseInput.vue.js.map +1 -0
  61. package/dist/components/BaseInput.vue3.js +6 -0
  62. package/dist/components/BaseInput.vue3.js.map +1 -0
  63. package/dist/components/BaseModal.vue.d.ts +38 -0
  64. package/dist/components/BaseModal.vue.js +118 -0
  65. package/dist/components/BaseModal.vue.js.map +1 -0
  66. package/dist/components/BaseModal.vue3.js +6 -0
  67. package/dist/components/BaseModal.vue3.js.map +1 -0
  68. package/dist/components/BasePill.vue.d.ts +54 -0
  69. package/dist/components/BasePill.vue.js +68 -0
  70. package/dist/components/BasePill.vue.js.map +1 -0
  71. package/dist/components/BasePill.vue3.js +6 -0
  72. package/dist/components/BasePill.vue3.js.map +1 -0
  73. package/dist/components/BaseRadioGroup.vue.d.ts +19 -0
  74. package/dist/components/BaseRadioGroup.vue.js +80 -0
  75. package/dist/components/BaseRadioGroup.vue.js.map +1 -0
  76. package/dist/components/BaseRadioGroup.vue3.js +6 -0
  77. package/dist/components/BaseRadioGroup.vue3.js.map +1 -0
  78. package/dist/components/BaseSelect.vue.d.ts +19 -0
  79. package/dist/components/BaseSelect.vue.js +70 -0
  80. package/dist/components/BaseSelect.vue.js.map +1 -0
  81. package/dist/components/BaseSelect.vue3.js +6 -0
  82. package/dist/components/BaseSelect.vue3.js.map +1 -0
  83. package/dist/components/BaseSlider.vue.d.ts +22 -0
  84. package/dist/components/BaseSlider.vue.js +97 -0
  85. package/dist/components/BaseSlider.vue.js.map +1 -0
  86. package/dist/components/BaseSlider.vue3.js +6 -0
  87. package/dist/components/BaseSlider.vue3.js.map +1 -0
  88. package/dist/components/BaseTabs.vue.d.ts +14 -0
  89. package/dist/components/BaseTabs.vue.js +63 -0
  90. package/dist/components/BaseTabs.vue.js.map +1 -0
  91. package/dist/components/BaseTabs.vue3.js +6 -0
  92. package/dist/components/BaseTabs.vue3.js.map +1 -0
  93. package/dist/components/BaseTextarea.vue.d.ts +28 -0
  94. package/dist/components/BaseTextarea.vue.js +49 -0
  95. package/dist/components/BaseTextarea.vue.js.map +1 -0
  96. package/dist/components/BaseTextarea.vue3.js +6 -0
  97. package/dist/components/BaseTextarea.vue3.js.map +1 -0
  98. package/dist/components/BaseToggle.vue.d.ts +16 -0
  99. package/dist/components/BaseToggle.vue.js +65 -0
  100. package/dist/components/BaseToggle.vue.js.map +1 -0
  101. package/dist/components/BaseToggle.vue3.js +6 -0
  102. package/dist/components/BaseToggle.vue3.js.map +1 -0
  103. package/dist/components/BatchProgressList.vue.d.ts +59 -0
  104. package/dist/components/BatchProgressList.vue.js +250 -0
  105. package/dist/components/BatchProgressList.vue.js.map +1 -0
  106. package/dist/components/BatchProgressList.vue3.js +6 -0
  107. package/dist/components/BatchProgressList.vue3.js.map +1 -0
  108. package/dist/components/Breadcrumb.vue.d.ts +37 -0
  109. package/dist/components/Breadcrumb.vue.js +71 -0
  110. package/dist/components/Breadcrumb.vue.js.map +1 -0
  111. package/dist/components/Breadcrumb.vue3.js +6 -0
  112. package/dist/components/Breadcrumb.vue3.js.map +1 -0
  113. package/dist/components/Calendar.vue.d.ts +107 -0
  114. package/dist/components/Calendar.vue.js +328 -0
  115. package/dist/components/Calendar.vue.js.map +1 -0
  116. package/dist/components/Calendar.vue3.js +6 -0
  117. package/dist/components/Calendar.vue3.js.map +1 -0
  118. package/dist/components/ChartContainer.vue.d.ts +31 -0
  119. package/dist/components/ChartContainer.vue.js +78 -0
  120. package/dist/components/ChartContainer.vue.js.map +1 -0
  121. package/dist/components/ChartContainer.vue3.js +6 -0
  122. package/dist/components/ChartContainer.vue3.js.map +1 -0
  123. package/dist/components/ChemicalFormula.vue.d.ts +8 -0
  124. package/dist/components/ChemicalFormula.vue.js +57 -0
  125. package/dist/components/ChemicalFormula.vue.js.map +1 -0
  126. package/dist/components/ChemicalFormula.vue3.js +6 -0
  127. package/dist/components/ChemicalFormula.vue3.js.map +1 -0
  128. package/dist/components/CollapsibleCard.vue.d.ts +39 -0
  129. package/dist/components/CollapsibleCard.vue.js +175 -0
  130. package/dist/components/CollapsibleCard.vue.js.map +1 -0
  131. package/dist/components/CollapsibleCard.vue3.js +6 -0
  132. package/dist/components/CollapsibleCard.vue3.js.map +1 -0
  133. package/dist/components/ColorSlider.vue.d.ts +34 -0
  134. package/dist/components/ColorSlider.vue.js +131 -0
  135. package/dist/components/ColorSlider.vue.js.map +1 -0
  136. package/dist/components/ColorSlider.vue3.js +6 -0
  137. package/dist/components/ColorSlider.vue3.js.map +1 -0
  138. package/dist/components/ConcentrationInput.vue.d.ts +25 -0
  139. package/dist/components/ConcentrationInput.vue.js +161 -0
  140. package/dist/components/ConcentrationInput.vue.js.map +1 -0
  141. package/dist/components/ConcentrationInput.vue3.js +6 -0
  142. package/dist/components/ConcentrationInput.vue3.js.map +1 -0
  143. package/dist/components/ConfirmDialog.vue.d.ts +41 -0
  144. package/dist/components/ConfirmDialog.vue.js +140 -0
  145. package/dist/components/ConfirmDialog.vue.js.map +1 -0
  146. package/dist/components/ConfirmDialog.vue3.js +6 -0
  147. package/dist/components/ConfirmDialog.vue3.js.map +1 -0
  148. package/dist/components/DataFrame.vue.d.ts +107 -0
  149. package/dist/components/DataFrame.vue.js +430 -0
  150. package/dist/components/DataFrame.vue.js.map +1 -0
  151. package/dist/components/DataFrame.vue3.js +6 -0
  152. package/dist/components/DataFrame.vue3.js.map +1 -0
  153. package/dist/components/DatePicker.vue.d.ts +23 -0
  154. package/dist/components/DatePicker.vue.js +278 -0
  155. package/dist/components/DatePicker.vue.js.map +1 -0
  156. package/dist/components/DatePicker.vue3.js +6 -0
  157. package/dist/components/DatePicker.vue3.js.map +1 -0
  158. package/dist/components/DateTimePicker.vue.d.ts +30 -0
  159. package/dist/components/DateTimePicker.vue.js +413 -0
  160. package/dist/components/DateTimePicker.vue.js.map +1 -0
  161. package/dist/components/DateTimePicker.vue3.js +6 -0
  162. package/dist/components/DateTimePicker.vue3.js.map +1 -0
  163. package/dist/components/Divider.vue.d.ts +11 -0
  164. package/dist/components/Divider.vue.js +42 -0
  165. package/dist/components/Divider.vue.js.map +1 -0
  166. package/dist/components/Divider.vue3.js +6 -0
  167. package/dist/components/Divider.vue3.js.map +1 -0
  168. package/dist/components/DoseCalculator.vue.d.ts +19 -0
  169. package/dist/components/DoseCalculator.vue.js +470 -0
  170. package/dist/components/DoseCalculator.vue.js.map +1 -0
  171. package/dist/components/DoseCalculator.vue3.js +6 -0
  172. package/dist/components/DoseCalculator.vue3.js.map +1 -0
  173. package/dist/components/DropdownButton.vue.d.ts +47 -0
  174. package/dist/components/DropdownButton.vue.js +171 -0
  175. package/dist/components/DropdownButton.vue.js.map +1 -0
  176. package/dist/components/DropdownButton.vue3.js +6 -0
  177. package/dist/components/DropdownButton.vue3.js.map +1 -0
  178. package/dist/components/EmptyState.vue.d.ts +33 -0
  179. package/dist/components/EmptyState.vue.js +80 -0
  180. package/dist/components/EmptyState.vue.js.map +1 -0
  181. package/dist/components/EmptyState.vue3.js +6 -0
  182. package/dist/components/EmptyState.vue3.js.map +1 -0
  183. package/dist/components/ExperimentTimeline.vue.d.ts +44 -0
  184. package/dist/components/ExperimentTimeline.vue.js +395 -0
  185. package/dist/components/ExperimentTimeline.vue.js.map +1 -0
  186. package/dist/components/ExperimentTimeline.vue3.js +6 -0
  187. package/dist/components/ExperimentTimeline.vue3.js.map +1 -0
  188. package/dist/components/FileUploader.vue.d.ts +23 -0
  189. package/dist/components/FileUploader.vue.js +416 -0
  190. package/dist/components/FileUploader.vue.js.map +1 -0
  191. package/dist/components/FileUploader.vue3.js +6 -0
  192. package/dist/components/FileUploader.vue3.js.map +1 -0
  193. package/dist/components/FormField.vue.d.ts +24 -0
  194. package/dist/components/FormField.vue.js +45 -0
  195. package/dist/components/FormField.vue.js.map +1 -0
  196. package/dist/components/FormField.vue3.js +6 -0
  197. package/dist/components/FormField.vue3.js.map +1 -0
  198. package/dist/components/FormulaInput.vue.d.ts +25 -0
  199. package/dist/components/FormulaInput.vue.js +121 -0
  200. package/dist/components/FormulaInput.vue.js.map +1 -0
  201. package/dist/components/FormulaInput.vue3.js +6 -0
  202. package/dist/components/FormulaInput.vue3.js.map +1 -0
  203. package/dist/components/GroupAssigner.vue.d.ts +25 -0
  204. package/dist/components/GroupAssigner.vue.js +311 -0
  205. package/dist/components/GroupAssigner.vue.js.map +1 -0
  206. package/dist/components/GroupAssigner.vue3.js +6 -0
  207. package/dist/components/GroupAssigner.vue3.js.map +1 -0
  208. package/dist/components/GroupingModal.vue.d.ts +12 -0
  209. package/dist/components/GroupingModal.vue.js +446 -0
  210. package/dist/components/GroupingModal.vue.js.map +1 -0
  211. package/dist/components/GroupingModal.vue3.js +6 -0
  212. package/dist/components/GroupingModal.vue3.js.map +1 -0
  213. package/dist/components/IconButton.vue.d.ts +34 -0
  214. package/dist/components/IconButton.vue.js +67 -0
  215. package/dist/components/IconButton.vue.js.map +1 -0
  216. package/dist/components/IconButton.vue3.js +6 -0
  217. package/dist/components/IconButton.vue3.js.map +1 -0
  218. package/dist/components/LoadingSpinner.vue.d.ts +11 -0
  219. package/dist/components/LoadingSpinner.vue.js +47 -0
  220. package/dist/components/LoadingSpinner.vue.js.map +1 -0
  221. package/dist/components/LoadingSpinner.vue3.js +6 -0
  222. package/dist/components/LoadingSpinner.vue3.js.map +1 -0
  223. package/dist/components/MoleculeInput.vue.d.ts +30 -0
  224. package/dist/components/MoleculeInput.vue.js +327 -0
  225. package/dist/components/MoleculeInput.vue.js.map +1 -0
  226. package/dist/components/MoleculeInput.vue3.js +6 -0
  227. package/dist/components/MoleculeInput.vue3.js.map +1 -0
  228. package/dist/components/MultiSelect.vue.d.ts +19 -0
  229. package/dist/components/MultiSelect.vue.js +109 -0
  230. package/dist/components/MultiSelect.vue.js.map +1 -0
  231. package/dist/components/MultiSelect.vue3.js +6 -0
  232. package/dist/components/MultiSelect.vue3.js.map +1 -0
  233. package/dist/components/NumberInput.vue.d.ts +21 -0
  234. package/dist/components/NumberInput.vue.js +133 -0
  235. package/dist/components/NumberInput.vue.js.map +1 -0
  236. package/dist/components/NumberInput.vue3.js +6 -0
  237. package/dist/components/NumberInput.vue3.js.map +1 -0
  238. package/dist/components/PlateMapEditor.vue.d.ts +50 -0
  239. package/dist/components/PlateMapEditor.vue.js +480 -0
  240. package/dist/components/PlateMapEditor.vue.js.map +1 -0
  241. package/dist/components/PlateMapEditor.vue3.js +6 -0
  242. package/dist/components/PlateMapEditor.vue3.js.map +1 -0
  243. package/dist/components/ProgressBar.vue.d.ts +17 -0
  244. package/dist/components/ProgressBar.vue.js +65 -0
  245. package/dist/components/ProgressBar.vue.js.map +1 -0
  246. package/dist/components/ProgressBar.vue3.js +6 -0
  247. package/dist/components/ProgressBar.vue3.js.map +1 -0
  248. package/dist/components/ProtocolStepEditor.vue.d.ts +24 -0
  249. package/dist/components/ProtocolStepEditor.vue.js +491 -0
  250. package/dist/components/ProtocolStepEditor.vue.js.map +1 -0
  251. package/dist/components/ProtocolStepEditor.vue3.js +6 -0
  252. package/dist/components/ProtocolStepEditor.vue3.js.map +1 -0
  253. package/dist/components/RackEditor.vue.d.ts +40 -0
  254. package/dist/components/RackEditor.vue.js +325 -0
  255. package/dist/components/RackEditor.vue.js.map +1 -0
  256. package/dist/components/RackEditor.vue3.js +6 -0
  257. package/dist/components/RackEditor.vue3.js.map +1 -0
  258. package/dist/components/ReagentList.vue.d.ts +46 -0
  259. package/dist/components/ReagentList.vue.js +526 -0
  260. package/dist/components/ReagentList.vue.js.map +1 -0
  261. package/dist/components/ReagentList.vue3.js +6 -0
  262. package/dist/components/ReagentList.vue3.js.map +1 -0
  263. package/dist/components/ResourceCard.vue.d.ts +50 -0
  264. package/dist/components/ResourceCard.vue.js +212 -0
  265. package/dist/components/ResourceCard.vue.js.map +1 -0
  266. package/dist/components/ResourceCard.vue3.js +6 -0
  267. package/dist/components/ResourceCard.vue3.js.map +1 -0
  268. package/dist/components/SampleHierarchyTree.vue.d.ts +37 -0
  269. package/dist/components/SampleHierarchyTree.vue.js +217 -0
  270. package/dist/components/SampleHierarchyTree.vue.js.map +1 -0
  271. package/dist/components/SampleHierarchyTree.vue3.js +6 -0
  272. package/dist/components/SampleHierarchyTree.vue3.js.map +1 -0
  273. package/dist/components/SampleLegend.vue.d.ts +32 -0
  274. package/dist/components/SampleLegend.vue.js +129 -0
  275. package/dist/components/SampleLegend.vue.js.map +1 -0
  276. package/dist/components/SampleLegend.vue3.js +6 -0
  277. package/dist/components/SampleLegend.vue3.js.map +1 -0
  278. package/dist/components/SampleSelector.vue.d.ts +29 -0
  279. package/dist/components/SampleSelector.vue.js +1076 -0
  280. package/dist/components/SampleSelector.vue.js.map +1 -0
  281. package/dist/components/SampleSelector.vue3.js +6 -0
  282. package/dist/components/SampleSelector.vue3.js.map +1 -0
  283. package/dist/components/ScheduleCalendar.vue.d.ts +110 -0
  284. package/dist/components/ScheduleCalendar.vue.js +535 -0
  285. package/dist/components/ScheduleCalendar.vue.js.map +1 -0
  286. package/dist/components/ScheduleCalendar.vue3.js +6 -0
  287. package/dist/components/ScheduleCalendar.vue3.js.map +1 -0
  288. package/dist/components/ScientificNumber.vue.d.ts +14 -0
  289. package/dist/components/ScientificNumber.vue.js +190 -0
  290. package/dist/components/ScientificNumber.vue.js.map +1 -0
  291. package/dist/components/ScientificNumber.vue3.js +6 -0
  292. package/dist/components/ScientificNumber.vue3.js.map +1 -0
  293. package/dist/components/SegmentedControl.vue.d.ts +20 -0
  294. package/dist/components/SegmentedControl.vue.js +71 -0
  295. package/dist/components/SegmentedControl.vue.js.map +1 -0
  296. package/dist/components/SegmentedControl.vue3.js +6 -0
  297. package/dist/components/SegmentedControl.vue3.js.map +1 -0
  298. package/dist/components/SequenceInput.vue.d.ts +54 -0
  299. package/dist/components/SequenceInput.vue.js +204 -0
  300. package/dist/components/SequenceInput.vue.js.map +1 -0
  301. package/dist/components/SequenceInput.vue3.js +6 -0
  302. package/dist/components/SequenceInput.vue3.js.map +1 -0
  303. package/dist/components/SettingsButton.vue.d.ts +30 -0
  304. package/dist/components/SettingsButton.vue.js +72 -0
  305. package/dist/components/SettingsButton.vue.js.map +1 -0
  306. package/dist/components/SettingsButton.vue3.js +6 -0
  307. package/dist/components/SettingsButton.vue3.js.map +1 -0
  308. package/dist/components/SettingsModal.vue.d.ts +40 -0
  309. package/dist/components/SettingsModal.vue.js +141 -0
  310. package/dist/components/SettingsModal.vue.js.map +1 -0
  311. package/dist/components/SettingsModal.vue3.js +6 -0
  312. package/dist/components/SettingsModal.vue3.js.map +1 -0
  313. package/dist/components/Skeleton.vue.d.ts +11 -0
  314. package/dist/components/Skeleton.vue.js +65 -0
  315. package/dist/components/Skeleton.vue.js.map +1 -0
  316. package/dist/components/Skeleton.vue3.js +6 -0
  317. package/dist/components/Skeleton.vue3.js.map +1 -0
  318. package/dist/components/StatusIndicator.vue.d.ts +13 -0
  319. package/dist/components/StatusIndicator.vue.js +38 -0
  320. package/dist/components/StatusIndicator.vue.js.map +1 -0
  321. package/dist/components/StatusIndicator.vue3.js +6 -0
  322. package/dist/components/StatusIndicator.vue3.js.map +1 -0
  323. package/dist/components/StepWizard.vue.d.ts +72 -0
  324. package/dist/components/StepWizard.vue.js +213 -0
  325. package/dist/components/StepWizard.vue.js.map +1 -0
  326. package/dist/components/StepWizard.vue3.js +6 -0
  327. package/dist/components/StepWizard.vue3.js.map +1 -0
  328. package/dist/components/TagsInput.vue.d.ts +23 -0
  329. package/dist/components/TagsInput.vue.js +124 -0
  330. package/dist/components/TagsInput.vue.js.map +1 -0
  331. package/dist/components/TagsInput.vue3.js +6 -0
  332. package/dist/components/TagsInput.vue3.js.map +1 -0
  333. package/dist/components/ThemeToggle.vue.d.ts +7 -0
  334. package/dist/components/ThemeToggle.vue.js +49 -0
  335. package/dist/components/ThemeToggle.vue.js.map +1 -0
  336. package/dist/components/ThemeToggle.vue3.js +6 -0
  337. package/dist/components/ThemeToggle.vue3.js.map +1 -0
  338. package/dist/components/TimePicker.vue.d.ts +29 -0
  339. package/dist/components/TimePicker.vue.js +275 -0
  340. package/dist/components/TimePicker.vue.js.map +1 -0
  341. package/dist/components/TimePicker.vue3.js +6 -0
  342. package/dist/components/TimePicker.vue3.js.map +1 -0
  343. package/dist/components/TimeRangeInput.vue.d.ts +27 -0
  344. package/dist/components/TimeRangeInput.vue.js +115 -0
  345. package/dist/components/TimeRangeInput.vue.js.map +1 -0
  346. package/dist/components/TimeRangeInput.vue3.js +6 -0
  347. package/dist/components/TimeRangeInput.vue3.js.map +1 -0
  348. package/dist/components/ToastNotification.vue.d.ts +2 -0
  349. package/dist/components/ToastNotification.vue.js +113 -0
  350. package/dist/components/ToastNotification.vue.js.map +1 -0
  351. package/dist/components/ToastNotification.vue3.js +6 -0
  352. package/dist/components/ToastNotification.vue3.js.map +1 -0
  353. package/dist/components/Tooltip.vue.d.ts +25 -0
  354. package/dist/components/Tooltip.vue.js +52 -0
  355. package/dist/components/Tooltip.vue.js.map +1 -0
  356. package/dist/components/Tooltip.vue3.js +6 -0
  357. package/dist/components/Tooltip.vue3.js.map +1 -0
  358. package/dist/components/UnitInput.vue.d.ts +44 -0
  359. package/dist/components/UnitInput.vue.js +178 -0
  360. package/dist/components/UnitInput.vue.js.map +1 -0
  361. package/dist/components/UnitInput.vue3.js +6 -0
  362. package/dist/components/UnitInput.vue3.js.map +1 -0
  363. package/dist/components/WellEditPopup.vue.d.ts +25 -0
  364. package/dist/components/WellEditPopup.vue.js +250 -0
  365. package/dist/components/WellEditPopup.vue.js.map +1 -0
  366. package/dist/components/WellEditPopup.vue3.js +6 -0
  367. package/dist/components/WellEditPopup.vue3.js.map +1 -0
  368. package/dist/components/WellPlate.vue.d.ts +69 -0
  369. package/dist/components/WellPlate.vue.js +531 -0
  370. package/dist/components/WellPlate.vue.js.map +1 -0
  371. package/dist/components/WellPlate.vue3.js +6 -0
  372. package/dist/components/WellPlate.vue3.js.map +1 -0
  373. package/dist/components/index.d.ts +71 -0
  374. package/dist/components/index.js +215 -0
  375. package/dist/components/index.js.map +1 -0
  376. package/dist/composables/index.d.ts +17 -0
  377. package/dist/composables/index.js +49 -0
  378. package/dist/composables/index.js.map +1 -0
  379. package/dist/composables/useApi.d.ts +19 -0
  380. package/dist/composables/useApi.js +101 -0
  381. package/dist/composables/useApi.js.map +1 -0
  382. package/dist/composables/useAsync.d.ts +127 -0
  383. package/dist/composables/useAsync.js +141 -0
  384. package/dist/composables/useAsync.js.map +1 -0
  385. package/dist/composables/useAuth.d.ts +44 -0
  386. package/dist/composables/useAuth.js +286 -0
  387. package/dist/composables/useAuth.js.map +1 -0
  388. package/dist/composables/useChemicalFormula.d.ts +20 -0
  389. package/dist/composables/useChemicalFormula.js +228 -0
  390. package/dist/composables/useChemicalFormula.js.map +1 -0
  391. package/dist/composables/useConcentrationUnits.d.ts +28 -0
  392. package/dist/composables/useConcentrationUnits.js +154 -0
  393. package/dist/composables/useConcentrationUnits.js.map +1 -0
  394. package/dist/composables/useDoseCalculator.d.ts +57 -0
  395. package/dist/composables/useDoseCalculator.js +228 -0
  396. package/dist/composables/useDoseCalculator.js.map +1 -0
  397. package/dist/composables/useForm.d.ts +91 -0
  398. package/dist/composables/useForm.js +253 -0
  399. package/dist/composables/useForm.js.map +1 -0
  400. package/dist/composables/usePasskey.d.ts +9 -0
  401. package/dist/composables/usePasskey.js +171 -0
  402. package/dist/composables/usePasskey.js.map +1 -0
  403. package/dist/composables/usePlatformContext.d.ts +125 -0
  404. package/dist/composables/usePlatformContext.js +149 -0
  405. package/dist/composables/usePlatformContext.js.map +1 -0
  406. package/dist/composables/useProtocolTemplates.d.ts +43 -0
  407. package/dist/composables/useProtocolTemplates.js +437 -0
  408. package/dist/composables/useProtocolTemplates.js.map +1 -0
  409. package/dist/composables/useRackEditor.d.ts +30 -0
  410. package/dist/composables/useRackEditor.js +168 -0
  411. package/dist/composables/useRackEditor.js.map +1 -0
  412. package/dist/composables/useScheduleDrag.d.ts +77 -0
  413. package/dist/composables/useScheduleDrag.js +183 -0
  414. package/dist/composables/useScheduleDrag.js.map +1 -0
  415. package/dist/composables/useSequenceUtils.d.ts +13 -0
  416. package/dist/composables/useSequenceUtils.js +93 -0
  417. package/dist/composables/useSequenceUtils.js.map +1 -0
  418. package/dist/composables/useTheme.d.ts +7 -0
  419. package/dist/composables/useTheme.js +40 -0
  420. package/dist/composables/useTheme.js.map +1 -0
  421. package/dist/composables/useTimeUtils.d.ts +15 -0
  422. package/dist/composables/useTimeUtils.js +105 -0
  423. package/dist/composables/useTimeUtils.js.map +1 -0
  424. package/dist/composables/useToast.d.ts +19 -0
  425. package/dist/composables/useToast.js +33 -0
  426. package/dist/composables/useToast.js.map +1 -0
  427. package/dist/composables/useWellPlateEditor.d.ts +31 -0
  428. package/dist/composables/useWellPlateEditor.js +315 -0
  429. package/dist/composables/useWellPlateEditor.js.map +1 -0
  430. package/dist/histoire.setup.d.ts +1 -0
  431. package/dist/index.d.ts +5 -0
  432. package/dist/index.js +265 -0
  433. package/dist/index.js.map +1 -0
  434. package/dist/install.d.ts +16 -0
  435. package/dist/install.js +15 -0
  436. package/dist/install.js.map +1 -0
  437. package/dist/stores/auth.d.ts +146 -0
  438. package/dist/stores/auth.js +122 -0
  439. package/dist/stores/auth.js.map +1 -0
  440. package/dist/stores/index.d.ts +2 -0
  441. package/dist/stores/index.js +8 -0
  442. package/dist/stores/index.js.map +1 -0
  443. package/dist/stores/settings.d.ts +75 -0
  444. package/dist/stores/settings.js +180 -0
  445. package/dist/stores/settings.js.map +1 -0
  446. package/dist/styles.css +23264 -0
  447. package/dist/tailwind.preset.d.ts +56 -0
  448. package/dist/tailwind.preset.js +59 -0
  449. package/dist/tailwind.preset.js.map +1 -0
  450. package/dist/types/auth.d.ts +42 -0
  451. package/dist/types/components.d.ts +405 -0
  452. package/dist/types/index.d.ts +3 -0
  453. package/dist/types/index.js +2 -0
  454. package/dist/types/index.js.map +1 -0
  455. package/dist/types/platform.d.ts +66 -0
  456. package/package.json +111 -0
  457. package/src/__tests__/components/AppLayout.test.ts +163 -0
  458. package/src/__tests__/components/AppSidebar.test.ts +292 -0
  459. package/src/__tests__/components/AppTopBar.test.ts +590 -0
  460. package/src/__tests__/components/BaseInput.test.ts +99 -0
  461. package/src/__tests__/components/BasePill.test.ts +291 -0
  462. package/src/__tests__/components/Calendar.test.ts +566 -0
  463. package/src/__tests__/components/CollapsibleCard.test.ts +524 -0
  464. package/src/__tests__/components/DataFrame.test.ts +767 -0
  465. package/src/__tests__/components/DropdownButton.test.ts +471 -0
  466. package/src/__tests__/composables/useAuth.test.ts +141 -0
  467. package/src/__tests__/composables/useForm.test.ts +205 -0
  468. package/src/components/AlertBox.story.vue +100 -0
  469. package/src/components/AlertBox.vue +68 -0
  470. package/src/components/AppContainer.story.vue +104 -0
  471. package/src/components/AppContainer.vue +33 -0
  472. package/src/components/AppLayout.story.vue +218 -0
  473. package/src/components/AppLayout.vue +75 -0
  474. package/src/components/AppSidebar.story.vue +300 -0
  475. package/src/components/AppSidebar.vue +114 -0
  476. package/src/components/AppTopBar.story.vue +112 -0
  477. package/src/components/AppTopBar.vue +471 -0
  478. package/src/components/AuditTrail.story.vue +163 -0
  479. package/src/components/AuditTrail.vue +161 -0
  480. package/src/components/Avatar.story.vue +92 -0
  481. package/src/components/Avatar.vue +65 -0
  482. package/src/components/BaseButton.story.vue +96 -0
  483. package/src/components/BaseButton.vue +72 -0
  484. package/src/components/BaseCheckbox.story.vue +73 -0
  485. package/src/components/BaseCheckbox.vue +68 -0
  486. package/src/components/BaseInput.story.vue +98 -0
  487. package/src/components/BaseInput.vue +70 -0
  488. package/src/components/BaseModal.story.vue +126 -0
  489. package/src/components/BaseModal.vue +118 -0
  490. package/src/components/BasePill.story.vue +131 -0
  491. package/src/components/BasePill.vue +84 -0
  492. package/src/components/BaseRadioGroup.story.vue +116 -0
  493. package/src/components/BaseRadioGroup.vue +83 -0
  494. package/src/components/BaseSelect.story.vue +110 -0
  495. package/src/components/BaseSelect.vue +67 -0
  496. package/src/components/BaseSlider.story.vue +82 -0
  497. package/src/components/BaseSlider.vue +112 -0
  498. package/src/components/BaseTabs.story.vue +106 -0
  499. package/src/components/BaseTabs.vue +58 -0
  500. package/src/components/BaseTextarea.story.vue +91 -0
  501. package/src/components/BaseTextarea.vue +58 -0
  502. package/src/components/BaseToggle.story.vue +81 -0
  503. package/src/components/BaseToggle.vue +72 -0
  504. package/src/components/BatchProgressList.story.vue +92 -0
  505. package/src/components/BatchProgressList.vue +202 -0
  506. package/src/components/Breadcrumb.story.vue +93 -0
  507. package/src/components/Breadcrumb.vue +73 -0
  508. package/src/components/Calendar.story.vue +106 -0
  509. package/src/components/Calendar.vue +362 -0
  510. package/src/components/ChartContainer.story.vue +113 -0
  511. package/src/components/ChartContainer.vue +63 -0
  512. package/src/components/ChemicalFormula.story.vue +102 -0
  513. package/src/components/ChemicalFormula.vue +38 -0
  514. package/src/components/CollapsibleCard.story.vue +124 -0
  515. package/src/components/CollapsibleCard.vue +164 -0
  516. package/src/components/ColorSlider.story.vue +120 -0
  517. package/src/components/ColorSlider.vue +163 -0
  518. package/src/components/ConcentrationInput.story.vue +77 -0
  519. package/src/components/ConcentrationInput.vue +184 -0
  520. package/src/components/ConfirmDialog.story.vue +145 -0
  521. package/src/components/ConfirmDialog.vue +96 -0
  522. package/src/components/DataFrame.story.vue +148 -0
  523. package/src/components/DataFrame.vue +418 -0
  524. package/src/components/DatePicker.story.vue +104 -0
  525. package/src/components/DatePicker.vue +298 -0
  526. package/src/components/DateTimePicker.story.vue +112 -0
  527. package/src/components/DateTimePicker.vue +391 -0
  528. package/src/components/Divider.story.vue +72 -0
  529. package/src/components/Divider.vue +45 -0
  530. package/src/components/DoseCalculator.story.vue +68 -0
  531. package/src/components/DoseCalculator.vue +475 -0
  532. package/src/components/DropdownButton.story.vue +102 -0
  533. package/src/components/DropdownButton.vue +180 -0
  534. package/src/components/EmptyState.story.vue +124 -0
  535. package/src/components/EmptyState.vue +64 -0
  536. package/src/components/ExperimentTimeline.story.vue +161 -0
  537. package/src/components/ExperimentTimeline.vue +381 -0
  538. package/src/components/FileUploader.story.vue +106 -0
  539. package/src/components/FileUploader.vue +397 -0
  540. package/src/components/FormField.story.vue +119 -0
  541. package/src/components/FormField.vue +37 -0
  542. package/src/components/FormulaInput.story.vue +96 -0
  543. package/src/components/FormulaInput.vue +123 -0
  544. package/src/components/GroupAssigner.story.vue +83 -0
  545. package/src/components/GroupAssigner.vue +283 -0
  546. package/src/components/GroupingModal.story.vue +52 -0
  547. package/src/components/GroupingModal.vue +420 -0
  548. package/src/components/IconButton.story.vue +135 -0
  549. package/src/components/IconButton.vue +72 -0
  550. package/src/components/LoadingSpinner.story.vue +70 -0
  551. package/src/components/LoadingSpinner.vue +49 -0
  552. package/src/components/MoleculeInput.story.vue +66 -0
  553. package/src/components/MoleculeInput.vue +414 -0
  554. package/src/components/MultiSelect.story.vue +121 -0
  555. package/src/components/MultiSelect.vue +117 -0
  556. package/src/components/NumberInput.story.vue +90 -0
  557. package/src/components/NumberInput.vue +128 -0
  558. package/src/components/PlateMapEditor.story.vue +92 -0
  559. package/src/components/PlateMapEditor.vue +512 -0
  560. package/src/components/ProgressBar.story.vue +117 -0
  561. package/src/components/ProgressBar.vue +63 -0
  562. package/src/components/ProtocolStepEditor.story.vue +69 -0
  563. package/src/components/ProtocolStepEditor.vue +521 -0
  564. package/src/components/RackEditor.story.vue +100 -0
  565. package/src/components/RackEditor.vue +370 -0
  566. package/src/components/ReagentList.story.vue +137 -0
  567. package/src/components/ReagentList.vue +487 -0
  568. package/src/components/ResourceCard.story.vue +150 -0
  569. package/src/components/ResourceCard.vue +160 -0
  570. package/src/components/SampleHierarchyTree.story.vue +161 -0
  571. package/src/components/SampleHierarchyTree.vue +279 -0
  572. package/src/components/SampleLegend.story.vue +91 -0
  573. package/src/components/SampleLegend.vue +118 -0
  574. package/src/components/SampleSelector.story.vue +100 -0
  575. package/src/components/SampleSelector.vue +955 -0
  576. package/src/components/ScheduleCalendar.story.vue +195 -0
  577. package/src/components/ScheduleCalendar.vue +568 -0
  578. package/src/components/ScientificNumber.story.vue +128 -0
  579. package/src/components/ScientificNumber.vue +197 -0
  580. package/src/components/SegmentedControl.story.vue +112 -0
  581. package/src/components/SegmentedControl.vue +78 -0
  582. package/src/components/SequenceInput.story.vue +119 -0
  583. package/src/components/SequenceInput.vue +208 -0
  584. package/src/components/SettingsButton.story.vue +58 -0
  585. package/src/components/SettingsButton.vue +75 -0
  586. package/src/components/SettingsModal.story.vue +145 -0
  587. package/src/components/SettingsModal.vue +151 -0
  588. package/src/components/Skeleton.story.vue +120 -0
  589. package/src/components/Skeleton.vue +73 -0
  590. package/src/components/StatusIndicator.story.vue +99 -0
  591. package/src/components/StatusIndicator.vue +39 -0
  592. package/src/components/StepWizard.story.vue +155 -0
  593. package/src/components/StepWizard.vue +231 -0
  594. package/src/components/TagsInput.story.vue +104 -0
  595. package/src/components/TagsInput.vue +127 -0
  596. package/src/components/ThemeToggle.story.vue +36 -0
  597. package/src/components/ThemeToggle.vue +53 -0
  598. package/src/components/TimePicker.story.vue +96 -0
  599. package/src/components/TimePicker.vue +272 -0
  600. package/src/components/TimeRangeInput.story.vue +104 -0
  601. package/src/components/TimeRangeInput.vue +121 -0
  602. package/src/components/ToastNotification.story.vue +130 -0
  603. package/src/components/ToastNotification.vue +54 -0
  604. package/src/components/Tooltip.story.vue +102 -0
  605. package/src/components/Tooltip.vue +61 -0
  606. package/src/components/UnitInput.story.vue +170 -0
  607. package/src/components/UnitInput.vue +218 -0
  608. package/src/components/WellEditPopup.vue +234 -0
  609. package/src/components/WellPlate.story.vue +198 -0
  610. package/src/components/WellPlate.vue +637 -0
  611. package/src/components/index.ts +96 -0
  612. package/src/composables/index.ts +87 -0
  613. package/src/composables/useApi.ts +145 -0
  614. package/src/composables/useAsync.ts +322 -0
  615. package/src/composables/useAuth.ts +427 -0
  616. package/src/composables/useChemicalFormula.ts +274 -0
  617. package/src/composables/useConcentrationUnits.ts +245 -0
  618. package/src/composables/useDoseCalculator.ts +369 -0
  619. package/src/composables/useForm.ts +415 -0
  620. package/src/composables/usePasskey.ts +209 -0
  621. package/src/composables/usePlatformContext.ts +232 -0
  622. package/src/composables/useProtocolTemplates.ts +517 -0
  623. package/src/composables/useRackEditor.ts +221 -0
  624. package/src/composables/useScheduleDrag.ts +244 -0
  625. package/src/composables/useSequenceUtils.ts +104 -0
  626. package/src/composables/useTheme.ts +49 -0
  627. package/src/composables/useTimeUtils.ts +114 -0
  628. package/src/composables/useToast.ts +39 -0
  629. package/src/composables/useWellPlateEditor.ts +408 -0
  630. package/src/histoire.setup.ts +17 -0
  631. package/src/index.ts +283 -0
  632. package/src/install.ts +32 -0
  633. package/src/stores/auth.ts +144 -0
  634. package/src/stores/index.ts +2 -0
  635. package/src/stores/settings.ts +229 -0
  636. package/src/styles/components/alert-box.css +94 -0
  637. package/src/styles/components/app-container.css +32 -0
  638. package/src/styles/components/app-layout.css +99 -0
  639. package/src/styles/components/app-sidebar.css +133 -0
  640. package/src/styles/components/app-top-bar.css +396 -0
  641. package/src/styles/components/audit-trail.css +143 -0
  642. package/src/styles/components/avatar.css +64 -0
  643. package/src/styles/components/batch-progress-list.css +196 -0
  644. package/src/styles/components/breadcrumb.css +45 -0
  645. package/src/styles/components/button.css +119 -0
  646. package/src/styles/components/calendar.css +192 -0
  647. package/src/styles/components/chart-container.css +69 -0
  648. package/src/styles/components/checkbox.css +112 -0
  649. package/src/styles/components/chemical-formula.css +46 -0
  650. package/src/styles/components/collapsible-card.css +184 -0
  651. package/src/styles/components/color-slider.css +110 -0
  652. package/src/styles/components/concentration-input.css +142 -0
  653. package/src/styles/components/confirm-dialog.css +137 -0
  654. package/src/styles/components/dataframe.css +382 -0
  655. package/src/styles/components/date-picker.css +239 -0
  656. package/src/styles/components/datetime-picker.css +225 -0
  657. package/src/styles/components/divider.css +62 -0
  658. package/src/styles/components/dose-calculator.css +301 -0
  659. package/src/styles/components/dropdown-button.css +236 -0
  660. package/src/styles/components/empty-state.css +148 -0
  661. package/src/styles/components/experiment-timeline.css +529 -0
  662. package/src/styles/components/file-uploader.css +517 -0
  663. package/src/styles/components/form-field.css +35 -0
  664. package/src/styles/components/formula-input.css +96 -0
  665. package/src/styles/components/group-assigner.css +200 -0
  666. package/src/styles/components/grouping-modal.css +323 -0
  667. package/src/styles/components/icon-button.css +128 -0
  668. package/src/styles/components/input.css +53 -0
  669. package/src/styles/components/loading-spinner.css +67 -0
  670. package/src/styles/components/modal.css +122 -0
  671. package/src/styles/components/molecule-input.css +186 -0
  672. package/src/styles/components/multi-select.css +131 -0
  673. package/src/styles/components/number-input.css +110 -0
  674. package/src/styles/components/pill.css +172 -0
  675. package/src/styles/components/plate-map-editor.css +464 -0
  676. package/src/styles/components/progress-bar.css +88 -0
  677. package/src/styles/components/protocol-step-editor.css +449 -0
  678. package/src/styles/components/rack-editor.css +259 -0
  679. package/src/styles/components/radio-group.css +158 -0
  680. package/src/styles/components/reagent-list.css +407 -0
  681. package/src/styles/components/resource-card.css +360 -0
  682. package/src/styles/components/sample-hierarchy-tree.css +314 -0
  683. package/src/styles/components/sample-legend.css +201 -0
  684. package/src/styles/components/sample-selector.css +701 -0
  685. package/src/styles/components/schedule-calendar.css +478 -0
  686. package/src/styles/components/scientific-number.css +63 -0
  687. package/src/styles/components/segmented-control.css +190 -0
  688. package/src/styles/components/select.css +72 -0
  689. package/src/styles/components/sequence-input.css +184 -0
  690. package/src/styles/components/settings-button.css +75 -0
  691. package/src/styles/components/settings-modal.css +95 -0
  692. package/src/styles/components/skeleton.css +36 -0
  693. package/src/styles/components/slider.css +78 -0
  694. package/src/styles/components/status-indicator.css +59 -0
  695. package/src/styles/components/step-wizard.css +187 -0
  696. package/src/styles/components/tabs.css +108 -0
  697. package/src/styles/components/tags-input.css +118 -0
  698. package/src/styles/components/textarea.css +65 -0
  699. package/src/styles/components/theme-toggle.css +50 -0
  700. package/src/styles/components/time-picker.css +171 -0
  701. package/src/styles/components/time-range-input.css +42 -0
  702. package/src/styles/components/toast.css +72 -0
  703. package/src/styles/components/toggle.css +115 -0
  704. package/src/styles/components/tooltip.css +98 -0
  705. package/src/styles/components/unit-input.css +138 -0
  706. package/src/styles/components/well-edit-popup.css +252 -0
  707. package/src/styles/components/well-plate.css +310 -0
  708. package/src/styles/index.css +80 -0
  709. package/src/styles/variables.css +1078 -0
  710. package/src/tailwind.preset.ts +59 -0
  711. package/src/types/auth.ts +55 -0
  712. package/src/types/components.ts +560 -0
  713. package/src/types/index.ts +146 -0
  714. package/src/types/platform.ts +101 -0
@@ -0,0 +1,1078 @@
1
+ /* MLD SDK CSS Variables & Utility Classes
2
+ * Import this file in your plugin's main CSS/entry point:
3
+ * @import '@estrellaxd/mld-sdk/styles';
4
+ */
5
+
6
+ @import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500;600;700&family=Fira+Sans:wght@300;400;500;600;700&display=swap');
7
+
8
+ /* ==========================================================================
9
+ CSS Variables - Light Mode
10
+ ========================================================================== */
11
+ :root {
12
+ /* Background colors */
13
+ --bg-primary: #F8FAFC;
14
+ --bg-secondary: #FFFFFF;
15
+ --bg-tertiary: #F1F5F9;
16
+ --bg-card: #FFFFFF;
17
+ --bg-hover: #F1F5F9;
18
+ --border-color: #E5E7EB;
19
+ --border-light: #F3F4F6;
20
+
21
+ /* Text colors */
22
+ --text-primary: #1E293B;
23
+ --text-secondary: #64748B;
24
+ --text-muted: #94A3B8;
25
+
26
+ /* Brand colors */
27
+ --color-primary: #3B82F6;
28
+ --color-primary-hover: #2563EB;
29
+ --color-cta: #F97316;
30
+ --color-cta-hover: #EA580C;
31
+ --color-purple: #8B5CF6;
32
+
33
+ /* Scrollbar */
34
+ --scrollbar-track: #F3F4F6;
35
+ --scrollbar-thumb: #D1D5DB;
36
+ --scrollbar-hover: #9CA3AF;
37
+
38
+ /* Shadows */
39
+ --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
40
+ --shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
41
+ --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
42
+ --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
43
+
44
+ /* Border radius */
45
+ --radius-sm: 0.25rem;
46
+ --radius: 0.375rem;
47
+ --radius-md: 0.5rem;
48
+ --radius-lg: 0.75rem;
49
+
50
+ /* Semantic colors */
51
+ --mld-success: #10B981;
52
+ --mld-success-bg: rgba(16, 185, 129, 0.1);
53
+ --mld-error: #EF4444;
54
+ --mld-error-bg: rgba(239, 68, 68, 0.1);
55
+ --mld-warning: #F59E0B;
56
+ --mld-warning-bg: rgba(245, 158, 11, 0.1);
57
+ --mld-info: #3B82F6;
58
+ --mld-info-bg: rgba(59, 130, 246, 0.1);
59
+
60
+ /* Legacy aliases (for backwards compatibility) */
61
+ --mld-bg-primary: var(--bg-primary);
62
+ --mld-bg-secondary: var(--bg-secondary);
63
+ --mld-bg-card: var(--bg-card);
64
+ --mld-bg-hover: var(--bg-tertiary);
65
+ --mld-bg-input: var(--bg-secondary);
66
+ --mld-text-primary: var(--text-primary);
67
+ --mld-text-secondary: var(--text-secondary);
68
+ --mld-text-muted: var(--text-muted);
69
+ --mld-text-inverse: #FFFFFF;
70
+ --mld-border: var(--border-color);
71
+ --mld-border-focus: var(--color-primary);
72
+ --mld-shadow-sm: var(--shadow-sm);
73
+ --mld-shadow: var(--shadow);
74
+ --mld-shadow-md: var(--shadow-md);
75
+ --mld-shadow-lg: var(--shadow-lg);
76
+ --mld-radius-sm: var(--radius-sm);
77
+ --mld-radius: var(--radius);
78
+ --mld-radius-md: var(--radius-md);
79
+ --mld-radius-lg: var(--radius-lg);
80
+ --mld-transition: 150ms ease;
81
+ }
82
+
83
+ /* ==========================================================================
84
+ CSS Variables - Dark Mode
85
+ ========================================================================== */
86
+ html.dark {
87
+ /* Background colors */
88
+ --bg-primary: #0F172A;
89
+ --bg-secondary: #1E293B;
90
+ --bg-tertiary: #334155;
91
+ --bg-card: #1E293B;
92
+ --bg-hover: #334155;
93
+ --border-color: #334155;
94
+ --border-light: #1E293B;
95
+
96
+ /* Text colors */
97
+ --text-primary: #F8FAFC;
98
+ --text-secondary: #94A3B8;
99
+ --text-muted: #64748B;
100
+
101
+ /* Scrollbar */
102
+ --scrollbar-track: #1E293B;
103
+ --scrollbar-thumb: #475569;
104
+ --scrollbar-hover: #64748B;
105
+
106
+ /* Shadows - Dark mode */
107
+ --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.2);
108
+ --shadow: 0 1px 3px 0 rgb(0 0 0 / 0.3), 0 1px 2px -1px rgb(0 0 0 / 0.2);
109
+ --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.3), 0 2px 4px -2px rgb(0 0 0 / 0.2);
110
+ --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.3), 0 4px 6px -4px rgb(0 0 0 / 0.2);
111
+
112
+ /* Semantic colors - Dark mode */
113
+ --mld-success-bg: rgba(16, 185, 129, 0.15);
114
+ --mld-error-bg: rgba(239, 68, 68, 0.15);
115
+ --mld-warning-bg: rgba(245, 158, 11, 0.15);
116
+ --mld-info-bg: rgba(59, 130, 246, 0.15);
117
+
118
+ /* Legacy aliases */
119
+ --mld-text-inverse: #1E293B;
120
+ --mld-border-focus: #60A5FA;
121
+
122
+ color-scheme: dark;
123
+ }
124
+
125
+ /* ==========================================================================
126
+ Base Styles
127
+ ========================================================================== */
128
+ html {
129
+ font-family: 'Fira Sans', system-ui, sans-serif;
130
+ }
131
+
132
+ body {
133
+ background-color: var(--bg-primary);
134
+ color: var(--text-primary);
135
+ min-height: 100vh;
136
+ transition: background-color 0.2s, color 0.2s;
137
+ }
138
+
139
+ code, pre {
140
+ font-family: 'Fira Code', monospace;
141
+ }
142
+
143
+ /* ==========================================================================
144
+ Button Styles
145
+ ========================================================================== */
146
+ .btn-primary {
147
+ display: inline-flex;
148
+ align-items: center;
149
+ justify-content: center;
150
+ gap: 0.5rem;
151
+ padding: 0.5rem 1rem;
152
+ background-color: var(--color-primary);
153
+ color: white;
154
+ border-radius: 0.5rem;
155
+ font-size: 0.875rem;
156
+ font-weight: 500;
157
+ transition: background-color 0.2s;
158
+ cursor: pointer;
159
+ border: none;
160
+ }
161
+
162
+ .btn-primary:hover {
163
+ background-color: var(--color-primary-hover);
164
+ }
165
+
166
+ .btn-primary:disabled {
167
+ opacity: 0.5;
168
+ cursor: not-allowed;
169
+ }
170
+
171
+ .btn-cta {
172
+ display: inline-flex;
173
+ align-items: center;
174
+ justify-content: center;
175
+ gap: 0.5rem;
176
+ padding: 0.5rem 1rem;
177
+ background-color: var(--color-cta);
178
+ color: white;
179
+ border-radius: 0.5rem;
180
+ font-size: 0.875rem;
181
+ font-weight: 500;
182
+ transition: background-color 0.2s;
183
+ cursor: pointer;
184
+ border: none;
185
+ }
186
+
187
+ .btn-cta:hover {
188
+ background-color: var(--color-cta-hover);
189
+ }
190
+
191
+ .btn-cta:disabled {
192
+ opacity: 0.5;
193
+ cursor: not-allowed;
194
+ }
195
+
196
+ .btn-secondary {
197
+ display: inline-flex;
198
+ align-items: center;
199
+ justify-content: center;
200
+ gap: 0.5rem;
201
+ padding: 0.5rem 1rem;
202
+ background-color: var(--bg-secondary);
203
+ border: 1px solid var(--border-color);
204
+ color: var(--text-primary);
205
+ border-radius: 0.5rem;
206
+ font-size: 0.875rem;
207
+ font-weight: 500;
208
+ transition: background-color 0.2s, border-color 0.2s;
209
+ cursor: pointer;
210
+ }
211
+
212
+ .btn-secondary:hover {
213
+ background-color: var(--bg-tertiary);
214
+ }
215
+
216
+ .btn-secondary:disabled {
217
+ opacity: 0.5;
218
+ cursor: not-allowed;
219
+ }
220
+
221
+ .btn-success {
222
+ display: inline-flex;
223
+ align-items: center;
224
+ justify-content: center;
225
+ gap: 0.5rem;
226
+ padding: 0.5rem 1rem;
227
+ background-color: #10B981;
228
+ color: white;
229
+ border-radius: 0.5rem;
230
+ font-size: 0.875rem;
231
+ font-weight: 500;
232
+ transition: background-color 0.2s;
233
+ cursor: pointer;
234
+ border: none;
235
+ }
236
+
237
+ .btn-success:hover {
238
+ background-color: #059669;
239
+ }
240
+
241
+ .btn-danger {
242
+ display: inline-flex;
243
+ align-items: center;
244
+ justify-content: center;
245
+ gap: 0.5rem;
246
+ padding: 0.5rem 1rem;
247
+ background-color: #EF4444;
248
+ color: white;
249
+ border-radius: 0.5rem;
250
+ font-size: 0.875rem;
251
+ font-weight: 500;
252
+ transition: background-color 0.2s;
253
+ cursor: pointer;
254
+ border: none;
255
+ }
256
+
257
+ .btn-danger:hover {
258
+ background-color: #DC2626;
259
+ }
260
+
261
+ /* ==========================================================================
262
+ Card Styles
263
+ ========================================================================== */
264
+ .card {
265
+ background-color: var(--bg-card);
266
+ border-radius: 0.75rem;
267
+ border: 1px solid var(--border-color);
268
+ box-shadow: var(--shadow-sm);
269
+ transition: background-color 0.2s, border-color 0.2s;
270
+ }
271
+
272
+ .card-hover:hover {
273
+ box-shadow: var(--shadow);
274
+ }
275
+
276
+ /* Floating card layout pattern */
277
+ .floating-card {
278
+ background-color: var(--bg-secondary);
279
+ border: 1px solid var(--border-color);
280
+ border-radius: 0.75rem;
281
+ box-shadow: var(--shadow);
282
+ }
283
+
284
+ /* ==========================================================================
285
+ Input Styles
286
+ ========================================================================== */
287
+ .input-modern {
288
+ width: 100%;
289
+ padding: 0.5rem 0.75rem;
290
+ font-size: 0.875rem;
291
+ line-height: 1.25rem;
292
+ color: var(--text-primary);
293
+ background-color: var(--bg-tertiary);
294
+ border: 1px solid var(--border-color);
295
+ border-radius: 0.5rem;
296
+ transition: all 0.15s ease;
297
+ outline: none;
298
+ }
299
+
300
+ .input-modern:hover {
301
+ border-color: var(--color-primary);
302
+ }
303
+
304
+ .input-modern:focus {
305
+ border-color: var(--color-primary);
306
+ box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
307
+ }
308
+
309
+ .input-modern::placeholder {
310
+ color: var(--text-muted);
311
+ }
312
+
313
+ /* Select styles */
314
+ .select-modern {
315
+ width: 100%;
316
+ padding: 0.5rem 2rem 0.5rem 0.75rem;
317
+ font-size: 0.875rem;
318
+ line-height: 1.25rem;
319
+ color: var(--text-primary);
320
+ background-color: var(--bg-tertiary);
321
+ background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
322
+ background-position: right 0.5rem center;
323
+ background-repeat: no-repeat;
324
+ background-size: 1.5em 1.5em;
325
+ border: 1px solid var(--border-color);
326
+ border-radius: 0.5rem;
327
+ appearance: none;
328
+ cursor: pointer;
329
+ transition: all 0.15s ease;
330
+ outline: none;
331
+ }
332
+
333
+ .select-modern:hover {
334
+ border-color: var(--color-primary);
335
+ }
336
+
337
+ .select-modern:focus {
338
+ border-color: var(--color-primary);
339
+ box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
340
+ }
341
+
342
+ /* Label styles */
343
+ .label-modern {
344
+ display: block;
345
+ font-size: 0.6875rem;
346
+ font-weight: 500;
347
+ text-transform: uppercase;
348
+ letter-spacing: 0.05em;
349
+ color: var(--text-secondary);
350
+ margin-bottom: 0.375rem;
351
+ }
352
+
353
+ /* ==========================================================================
354
+ Toggle Switch
355
+ ========================================================================== */
356
+ .toggle-switch {
357
+ position: relative;
358
+ width: 2rem;
359
+ height: 1rem;
360
+ border-radius: 9999px;
361
+ background-color: var(--bg-tertiary);
362
+ cursor: pointer;
363
+ transition: background-color 0.2s ease;
364
+ }
365
+
366
+ .toggle-switch.active {
367
+ background-color: var(--color-primary);
368
+ }
369
+
370
+ .toggle-switch::after {
371
+ content: '';
372
+ position: absolute;
373
+ top: 2px;
374
+ left: 2px;
375
+ width: 0.75rem;
376
+ height: 0.75rem;
377
+ border-radius: 9999px;
378
+ background-color: white;
379
+ box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
380
+ transition: transform 0.2s ease;
381
+ }
382
+
383
+ .toggle-switch.active::after {
384
+ transform: translateX(1rem);
385
+ }
386
+
387
+ /* ==========================================================================
388
+ Checkbox Styles
389
+ ========================================================================== */
390
+ .checkbox-modern {
391
+ width: 1.125rem;
392
+ height: 1.125rem;
393
+ border: 2px solid var(--border-color);
394
+ border-radius: 0.25rem;
395
+ background-color: var(--bg-primary);
396
+ cursor: pointer;
397
+ transition: all 0.15s ease;
398
+ appearance: none;
399
+ position: relative;
400
+ }
401
+
402
+ .checkbox-modern:hover {
403
+ border-color: var(--color-primary);
404
+ }
405
+
406
+ .checkbox-modern:checked {
407
+ background-color: #10B981;
408
+ border-color: #10B981;
409
+ }
410
+
411
+ .checkbox-modern:checked::after {
412
+ content: '';
413
+ position: absolute;
414
+ top: 1px;
415
+ left: 5px;
416
+ width: 5px;
417
+ height: 9px;
418
+ border: solid white;
419
+ border-width: 0 2px 2px 0;
420
+ transform: rotate(45deg);
421
+ }
422
+
423
+ /* ==========================================================================
424
+ Scrollbar Styling
425
+ ========================================================================== */
426
+ ::-webkit-scrollbar {
427
+ width: 8px;
428
+ height: 8px;
429
+ }
430
+
431
+ ::-webkit-scrollbar-track {
432
+ background: var(--scrollbar-track);
433
+ border-radius: 4px;
434
+ }
435
+
436
+ ::-webkit-scrollbar-thumb {
437
+ background: var(--scrollbar-thumb);
438
+ border-radius: 4px;
439
+ }
440
+
441
+ ::-webkit-scrollbar-thumb:hover {
442
+ background: var(--scrollbar-hover);
443
+ }
444
+
445
+ /* ==========================================================================
446
+ Score/Status Colors
447
+ ========================================================================== */
448
+ .score-good { color: #22c55e; }
449
+ .score-warning { color: #eab308; }
450
+ .score-bad { color: #ef4444; }
451
+
452
+ .score-bg-good { background-color: rgba(34, 197, 94, 0.15); }
453
+ .score-bg-warning { background-color: rgba(234, 179, 8, 0.15); }
454
+ .score-bg-bad { background-color: rgba(239, 68, 68, 0.15); }
455
+
456
+ /* ==========================================================================
457
+ Alert/Badge Colors
458
+ ========================================================================== */
459
+ .alert-success {
460
+ background-color: rgba(16, 185, 129, 0.1);
461
+ color: #10B981;
462
+ border: 1px solid rgba(16, 185, 129, 0.2);
463
+ }
464
+
465
+ .alert-error {
466
+ background-color: rgba(239, 68, 68, 0.1);
467
+ color: #EF4444;
468
+ border: 1px solid rgba(239, 68, 68, 0.2);
469
+ }
470
+
471
+ .alert-warning {
472
+ background-color: rgba(245, 158, 11, 0.1);
473
+ color: #F59E0B;
474
+ border: 1px solid rgba(245, 158, 11, 0.2);
475
+ }
476
+
477
+ .alert-info {
478
+ background-color: rgba(59, 130, 246, 0.1);
479
+ color: #3B82F6;
480
+ border: 1px solid rgba(59, 130, 246, 0.2);
481
+ }
482
+
483
+ /* ==========================================================================
484
+ Page Transitions
485
+ ========================================================================== */
486
+ .fade-enter-active,
487
+ .fade-leave-active {
488
+ transition: opacity 0.15s ease;
489
+ }
490
+
491
+ .fade-enter-from,
492
+ .fade-leave-to {
493
+ opacity: 0;
494
+ }
495
+
496
+ /* ==========================================================================
497
+ Hover States
498
+ ========================================================================== */
499
+ .hover-bg:hover {
500
+ background-color: var(--bg-tertiary);
501
+ }
502
+
503
+ /* ==========================================================================
504
+ MLD Utility Classes (for Tailwind v4 compatibility)
505
+ ========================================================================== */
506
+ .rounded-mld {
507
+ border-radius: 0.5rem;
508
+ }
509
+
510
+ .rounded-mld-sm {
511
+ border-radius: 0.375rem;
512
+ }
513
+
514
+ .rounded-mld-lg {
515
+ border-radius: 0.75rem;
516
+ }
517
+
518
+ .bg-bg-hover {
519
+ background-color: var(--bg-tertiary);
520
+ }
521
+
522
+ .bg-bg-secondary {
523
+ background-color: var(--bg-secondary);
524
+ }
525
+
526
+ .bg-bg-input {
527
+ background-color: var(--bg-secondary);
528
+ }
529
+
530
+ .text-text-primary {
531
+ color: var(--text-primary);
532
+ }
533
+
534
+ .text-text-secondary {
535
+ color: var(--text-secondary);
536
+ }
537
+
538
+ .text-text-muted {
539
+ color: var(--text-muted);
540
+ }
541
+
542
+ .border-border {
543
+ border-color: var(--border-color);
544
+ }
545
+
546
+ .bg-mld-primary {
547
+ background-color: #3B82F6;
548
+ }
549
+
550
+ .text-mld-primary {
551
+ color: var(--color-primary);
552
+ }
553
+
554
+ .border-mld-primary {
555
+ border-color: var(--color-primary);
556
+ }
557
+
558
+ .bg-mld-primary\/5 {
559
+ background-color: rgba(59, 130, 246, 0.05);
560
+ }
561
+
562
+ .hover\:border-mld-primary\/50:hover {
563
+ border-color: rgba(59, 130, 246, 0.5);
564
+ }
565
+
566
+ /* Danger/error color utilities */
567
+ .text-mld-danger {
568
+ color: var(--mld-error);
569
+ }
570
+
571
+ .bg-mld-danger {
572
+ background-color: var(--mld-error);
573
+ }
574
+
575
+ .hover\:text-mld-danger:hover {
576
+ color: var(--mld-error);
577
+ }
578
+
579
+ .hover\:bg-mld-danger\/10:hover {
580
+ background-color: rgba(239, 68, 68, 0.1);
581
+ }
582
+
583
+ .hover\:bg-bg-hover:hover {
584
+ background-color: var(--bg-tertiary);
585
+ }
586
+
587
+ .hover\:text-text-primary:hover {
588
+ color: var(--text-primary);
589
+ }
590
+
591
+ .duration-mld {
592
+ transition-duration: 150ms;
593
+ }
594
+
595
+ .transition-colors {
596
+ transition-property: color, background-color, border-color;
597
+ transition-timing-function: ease;
598
+ }
599
+
600
+ /* ==========================================================================
601
+ Background Color Utilities (Tailwind v4 compatibility)
602
+ ========================================================================== */
603
+ .bg-mld-primary-hover {
604
+ background-color: var(--color-primary-hover);
605
+ }
606
+
607
+ .hover\:bg-mld-primary-hover:hover {
608
+ background-color: var(--color-primary-hover);
609
+ }
610
+
611
+ .hover\:bg-mld-primary:hover {
612
+ background-color: var(--color-primary);
613
+ }
614
+
615
+ .bg-mld-cta {
616
+ background-color: var(--color-cta);
617
+ }
618
+
619
+ .hover\:bg-mld-cta-hover:hover {
620
+ background-color: var(--color-cta-hover);
621
+ }
622
+
623
+ .bg-mld-success {
624
+ background-color: var(--mld-success);
625
+ }
626
+
627
+ .hover\:bg-mld-success-hover:hover {
628
+ background-color: #059669;
629
+ }
630
+
631
+ .hover\:bg-mld-danger-hover:hover {
632
+ background-color: #DC2626;
633
+ }
634
+
635
+ .bg-mld-primary\/10 {
636
+ background-color: rgba(59, 130, 246, 0.1);
637
+ }
638
+
639
+ .hover\:bg-mld-primary\/20:hover {
640
+ background-color: rgba(59, 130, 246, 0.2);
641
+ }
642
+
643
+ .bg-mld-info {
644
+ background-color: var(--mld-info);
645
+ }
646
+
647
+ .bg-mld-warning {
648
+ background-color: var(--mld-warning);
649
+ }
650
+
651
+ .bg-mld-error {
652
+ background-color: var(--mld-error);
653
+ }
654
+
655
+ /* ==========================================================================
656
+ Text Color Utilities (Tailwind v4 compatibility)
657
+ ========================================================================== */
658
+ .text-mld-success {
659
+ color: var(--mld-success);
660
+ }
661
+
662
+ .text-mld-warning {
663
+ color: var(--mld-warning);
664
+ }
665
+
666
+ .text-mld-info {
667
+ color: var(--mld-info);
668
+ }
669
+
670
+ .text-mld-error {
671
+ color: var(--mld-error);
672
+ }
673
+
674
+ .hover\:text-mld-primary:hover {
675
+ color: var(--color-primary);
676
+ }
677
+
678
+ .text-mld-primary\/80 {
679
+ color: rgba(59, 130, 246, 0.8);
680
+ }
681
+
682
+ .hover\:text-mld-primary\/70:hover {
683
+ color: rgba(59, 130, 246, 0.7);
684
+ }
685
+
686
+ /* ==========================================================================
687
+ Border Color Utilities (Tailwind v4 compatibility)
688
+ ========================================================================== */
689
+ .border-mld-danger {
690
+ border-color: var(--mld-error);
691
+ }
692
+
693
+ .border-mld-success {
694
+ border-color: var(--mld-success);
695
+ }
696
+
697
+ .border-mld-warning {
698
+ border-color: var(--mld-warning);
699
+ }
700
+
701
+ .border-mld-info {
702
+ border-color: var(--mld-info);
703
+ }
704
+
705
+ .hover\:border-mld-primary:hover {
706
+ border-color: var(--color-primary);
707
+ }
708
+
709
+ /* ==========================================================================
710
+ Focus & Ring Utilities (Tailwind v4 compatibility)
711
+ ========================================================================== */
712
+ .focus\:ring-2:focus {
713
+ box-shadow: 0 0 0 2px var(--color-primary);
714
+ }
715
+
716
+ .focus\:ring-mld-primary:focus {
717
+ --tw-ring-color: var(--color-primary);
718
+ box-shadow: 0 0 0 2px var(--color-primary);
719
+ }
720
+
721
+ .focus\:ring-mld-danger:focus {
722
+ box-shadow: 0 0 0 2px var(--mld-error);
723
+ }
724
+
725
+ .focus\:ring-offset-2:focus {
726
+ box-shadow: 0 0 0 2px white, 0 0 0 4px var(--color-primary);
727
+ }
728
+
729
+ html.dark .focus\:ring-offset-2:focus {
730
+ box-shadow: 0 0 0 2px var(--bg-primary), 0 0 0 4px var(--color-primary);
731
+ }
732
+
733
+ .focus\:border-transparent:focus {
734
+ border-color: transparent;
735
+ }
736
+
737
+ .focus\:outline-none:focus {
738
+ outline: none;
739
+ }
740
+
741
+ .ring-1 {
742
+ box-shadow: 0 0 0 1px var(--color-primary);
743
+ }
744
+
745
+ .ring-2 {
746
+ box-shadow: 0 0 0 2px var(--color-primary);
747
+ }
748
+
749
+ .ring-mld-primary {
750
+ --tw-ring-color: var(--color-primary);
751
+ }
752
+
753
+ /* ==========================================================================
754
+ Focus-within Utilities (Tailwind v4 compatibility)
755
+ ========================================================================== */
756
+ .focus-within\:ring-2:focus-within {
757
+ box-shadow: 0 0 0 2px var(--color-primary);
758
+ }
759
+
760
+ .focus-within\:ring-mld-primary:focus-within {
761
+ box-shadow: 0 0 0 2px var(--color-primary);
762
+ }
763
+
764
+ .focus-within\:ring-mld-danger:focus-within {
765
+ box-shadow: 0 0 0 2px var(--mld-error);
766
+ }
767
+
768
+ .focus-within\:border-transparent:focus-within {
769
+ border-color: transparent;
770
+ }
771
+
772
+ /* ==========================================================================
773
+ Placeholder Utilities (Tailwind v4 compatibility)
774
+ ========================================================================== */
775
+ .placeholder\:text-text-muted::placeholder {
776
+ color: var(--text-muted);
777
+ }
778
+
779
+ /* ==========================================================================
780
+ Core Layout Utilities (Tailwind v4 compatibility)
781
+ ========================================================================== */
782
+
783
+ /* Flexbox */
784
+ .flex {
785
+ display: flex;
786
+ }
787
+
788
+ .inline-flex {
789
+ display: inline-flex;
790
+ }
791
+
792
+ .flex-1 {
793
+ flex: 1 1 0%;
794
+ }
795
+
796
+ .flex-shrink-0 {
797
+ flex-shrink: 0;
798
+ }
799
+
800
+ .flex-col {
801
+ flex-direction: column;
802
+ }
803
+
804
+ .flex-wrap {
805
+ flex-wrap: wrap;
806
+ }
807
+
808
+ .items-center {
809
+ align-items: center;
810
+ }
811
+
812
+ .items-start {
813
+ align-items: flex-start;
814
+ }
815
+
816
+ .justify-center {
817
+ justify-content: center;
818
+ }
819
+
820
+ .justify-between {
821
+ justify-content: space-between;
822
+ }
823
+
824
+ /* Gap */
825
+ .gap-1 {
826
+ gap: 0.25rem;
827
+ }
828
+
829
+ .gap-2 {
830
+ gap: 0.5rem;
831
+ }
832
+
833
+ .gap-3 {
834
+ gap: 0.75rem;
835
+ }
836
+
837
+ .gap-4 {
838
+ gap: 1rem;
839
+ }
840
+
841
+ /* Width/Height */
842
+ .w-3 {
843
+ width: 0.75rem;
844
+ }
845
+
846
+ .w-4 {
847
+ width: 1rem;
848
+ }
849
+
850
+ .w-5 {
851
+ width: 1.25rem;
852
+ }
853
+
854
+ .w-8 {
855
+ width: 2rem;
856
+ }
857
+
858
+ .w-full {
859
+ width: 100%;
860
+ }
861
+
862
+ .h-3 {
863
+ height: 0.75rem;
864
+ }
865
+
866
+ .h-4 {
867
+ height: 1rem;
868
+ }
869
+
870
+ .h-5 {
871
+ height: 1.25rem;
872
+ }
873
+
874
+ .h-8 {
875
+ height: 2rem;
876
+ }
877
+
878
+ .min-w-0 {
879
+ min-width: 0;
880
+ }
881
+
882
+ /* Spacing */
883
+ .p-3 {
884
+ padding: 0.75rem;
885
+ }
886
+
887
+ .p-4 {
888
+ padding: 1rem;
889
+ }
890
+
891
+ .p-8 {
892
+ padding: 2rem;
893
+ }
894
+
895
+ .px-4 {
896
+ padding-left: 1rem;
897
+ padding-right: 1rem;
898
+ }
899
+
900
+ .py-3 {
901
+ padding-top: 0.75rem;
902
+ padding-bottom: 0.75rem;
903
+ }
904
+
905
+ .mt-3 {
906
+ margin-top: 0.75rem;
907
+ }
908
+
909
+ .mx-auto {
910
+ margin-left: auto;
911
+ margin-right: auto;
912
+ }
913
+
914
+ .space-y-1 > * + * {
915
+ margin-top: 0.25rem;
916
+ }
917
+
918
+ /* Positioning */
919
+ .relative {
920
+ position: relative;
921
+ }
922
+
923
+ .absolute {
924
+ position: absolute;
925
+ }
926
+
927
+ .fixed {
928
+ position: fixed;
929
+ }
930
+
931
+ .top-4 {
932
+ top: 1rem;
933
+ }
934
+
935
+ .right-4 {
936
+ right: 1rem;
937
+ }
938
+
939
+ .left-4 {
940
+ left: 1rem;
941
+ }
942
+
943
+ .-bottom-2 {
944
+ bottom: -0.5rem;
945
+ }
946
+
947
+ .-translate-x-1\/2 {
948
+ transform: translateX(-50%);
949
+ }
950
+
951
+ .z-10 {
952
+ z-index: 10;
953
+ }
954
+
955
+ /* Overflow */
956
+ .overflow-hidden {
957
+ overflow: hidden;
958
+ }
959
+
960
+ .overflow-y-auto {
961
+ overflow-y: auto;
962
+ }
963
+
964
+ /* Text */
965
+ .truncate {
966
+ overflow: hidden;
967
+ text-overflow: ellipsis;
968
+ white-space: nowrap;
969
+ }
970
+
971
+ .text-xs {
972
+ font-size: 0.75rem;
973
+ line-height: 1rem;
974
+ }
975
+
976
+ .text-sm {
977
+ font-size: 0.875rem;
978
+ line-height: 1.25rem;
979
+ }
980
+
981
+ .font-bold {
982
+ font-weight: 700;
983
+ }
984
+
985
+ .font-semibold {
986
+ font-weight: 600;
987
+ }
988
+
989
+ .font-medium {
990
+ font-weight: 500;
991
+ }
992
+
993
+ .text-white {
994
+ color: white;
995
+ }
996
+
997
+ /* Border */
998
+ .rounded-sm {
999
+ border-radius: 0.125rem;
1000
+ }
1001
+
1002
+ .rounded {
1003
+ border-radius: 0.25rem;
1004
+ }
1005
+
1006
+ .rounded-lg {
1007
+ border-radius: 0.5rem;
1008
+ }
1009
+
1010
+ .rounded-full {
1011
+ border-radius: 9999px;
1012
+ }
1013
+
1014
+ .border {
1015
+ border-width: 1px;
1016
+ }
1017
+
1018
+ .border-2 {
1019
+ border-width: 2px;
1020
+ }
1021
+
1022
+ .border-dashed {
1023
+ border-style: dashed;
1024
+ }
1025
+
1026
+ /* Cursor */
1027
+ .cursor-pointer {
1028
+ cursor: pointer;
1029
+ }
1030
+
1031
+ /* Opacity */
1032
+ .opacity-0 {
1033
+ opacity: 0;
1034
+ }
1035
+
1036
+ /* Pointer Events */
1037
+ .pointer-events-none {
1038
+ pointer-events: none;
1039
+ }
1040
+
1041
+ .pointer-events-auto {
1042
+ pointer-events: auto;
1043
+ }
1044
+
1045
+ /* Transforms */
1046
+ .rotate-180 {
1047
+ transform: rotate(180deg);
1048
+ }
1049
+
1050
+ /* Animations */
1051
+ .animate-spin {
1052
+ animation: spin 1s linear infinite;
1053
+ }
1054
+
1055
+ @keyframes spin {
1056
+ from {
1057
+ transform: rotate(0deg);
1058
+ }
1059
+ to {
1060
+ transform: rotate(360deg);
1061
+ }
1062
+ }
1063
+
1064
+ /* Max Width */
1065
+ .max-w-sm {
1066
+ max-width: 24rem;
1067
+ }
1068
+
1069
+ /* ==========================================================================
1070
+ Reduced Motion
1071
+ ========================================================================== */
1072
+ @media (prefers-reduced-motion: reduce) {
1073
+ *, *::before, *::after {
1074
+ animation-duration: 0.01ms !important;
1075
+ animation-iteration-count: 1 !important;
1076
+ transition-duration: 0.01ms !important;
1077
+ }
1078
+ }