premium-ds 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (257) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +113 -0
  3. package/dist/alert.d.ts +31 -0
  4. package/dist/alert.js +6 -0
  5. package/dist/alert.js.map +1 -0
  6. package/dist/avatar-group.d.ts +13 -0
  7. package/dist/avatar-group.js +3 -0
  8. package/dist/avatar-group.js.map +1 -0
  9. package/dist/avatar.d.ts +25 -0
  10. package/dist/avatar.js +3 -0
  11. package/dist/avatar.js.map +1 -0
  12. package/dist/badge.d.ts +23 -0
  13. package/dist/badge.js +3 -0
  14. package/dist/badge.js.map +1 -0
  15. package/dist/button.d.ts +20 -0
  16. package/dist/button.js +3 -0
  17. package/dist/button.js.map +1 -0
  18. package/dist/checkbox.d.ts +25 -0
  19. package/dist/checkbox.js +3 -0
  20. package/dist/checkbox.js.map +1 -0
  21. package/dist/chunk-2OWHZ4JT.js +36 -0
  22. package/dist/chunk-2OWHZ4JT.js.map +1 -0
  23. package/dist/chunk-34SIXSYL.js +64 -0
  24. package/dist/chunk-34SIXSYL.js.map +1 -0
  25. package/dist/chunk-37O2ZXD6.js +55 -0
  26. package/dist/chunk-37O2ZXD6.js.map +1 -0
  27. package/dist/chunk-4AZL76UJ.js +89 -0
  28. package/dist/chunk-4AZL76UJ.js.map +1 -0
  29. package/dist/chunk-4HSCN5TZ.js +86 -0
  30. package/dist/chunk-4HSCN5TZ.js.map +1 -0
  31. package/dist/chunk-5DDOOT33.js +258 -0
  32. package/dist/chunk-5DDOOT33.js.map +1 -0
  33. package/dist/chunk-5FVHWIMY.js +117 -0
  34. package/dist/chunk-5FVHWIMY.js.map +1 -0
  35. package/dist/chunk-5K6KRJGX.js +147 -0
  36. package/dist/chunk-5K6KRJGX.js.map +1 -0
  37. package/dist/chunk-5PQMQBQC.js +74 -0
  38. package/dist/chunk-5PQMQBQC.js.map +1 -0
  39. package/dist/chunk-7OCTVQ7C.js +95 -0
  40. package/dist/chunk-7OCTVQ7C.js.map +1 -0
  41. package/dist/chunk-7OPMOET7.js +39 -0
  42. package/dist/chunk-7OPMOET7.js.map +1 -0
  43. package/dist/chunk-BXXS7YRC.js +270 -0
  44. package/dist/chunk-BXXS7YRC.js.map +1 -0
  45. package/dist/chunk-CV2Q4YXX.js +272 -0
  46. package/dist/chunk-CV2Q4YXX.js.map +1 -0
  47. package/dist/chunk-EIMMDWIW.js +282 -0
  48. package/dist/chunk-EIMMDWIW.js.map +1 -0
  49. package/dist/chunk-EZ2CWTBE.js +230 -0
  50. package/dist/chunk-EZ2CWTBE.js.map +1 -0
  51. package/dist/chunk-FGHDG3Y4.js +89 -0
  52. package/dist/chunk-FGHDG3Y4.js.map +1 -0
  53. package/dist/chunk-FPP2XLKX.js +127 -0
  54. package/dist/chunk-FPP2XLKX.js.map +1 -0
  55. package/dist/chunk-G6OY35DI.js +295 -0
  56. package/dist/chunk-G6OY35DI.js.map +1 -0
  57. package/dist/chunk-H6KWJNOE.js +65 -0
  58. package/dist/chunk-H6KWJNOE.js.map +1 -0
  59. package/dist/chunk-HGILYGY3.js +45 -0
  60. package/dist/chunk-HGILYGY3.js.map +1 -0
  61. package/dist/chunk-I3BCB4Z5.js +88 -0
  62. package/dist/chunk-I3BCB4Z5.js.map +1 -0
  63. package/dist/chunk-KBWNUUWM.js +582 -0
  64. package/dist/chunk-KBWNUUWM.js.map +1 -0
  65. package/dist/chunk-KN7JFAZ6.js +113 -0
  66. package/dist/chunk-KN7JFAZ6.js.map +1 -0
  67. package/dist/chunk-MEF7PI6U.js +16 -0
  68. package/dist/chunk-MEF7PI6U.js.map +1 -0
  69. package/dist/chunk-NKGMQL6I.js +310 -0
  70. package/dist/chunk-NKGMQL6I.js.map +1 -0
  71. package/dist/chunk-NMFQRGLL.js +127 -0
  72. package/dist/chunk-NMFQRGLL.js.map +1 -0
  73. package/dist/chunk-OUBWD6CX.js +433 -0
  74. package/dist/chunk-OUBWD6CX.js.map +1 -0
  75. package/dist/chunk-PFNXVBLU.js +96 -0
  76. package/dist/chunk-PFNXVBLU.js.map +1 -0
  77. package/dist/chunk-PUPZ4HME.js +165 -0
  78. package/dist/chunk-PUPZ4HME.js.map +1 -0
  79. package/dist/chunk-QFS52OK5.js +690 -0
  80. package/dist/chunk-QFS52OK5.js.map +1 -0
  81. package/dist/chunk-QNC6O3PG.js +45 -0
  82. package/dist/chunk-QNC6O3PG.js.map +1 -0
  83. package/dist/chunk-QUHOXWBK.js +82 -0
  84. package/dist/chunk-QUHOXWBK.js.map +1 -0
  85. package/dist/chunk-UIQGSTBJ.js +106 -0
  86. package/dist/chunk-UIQGSTBJ.js.map +1 -0
  87. package/dist/chunk-UJQKVP6V.js +193 -0
  88. package/dist/chunk-UJQKVP6V.js.map +1 -0
  89. package/dist/chunk-VVPGEAC6.js +11 -0
  90. package/dist/chunk-VVPGEAC6.js.map +1 -0
  91. package/dist/chunk-XA3T5KWA.js +58 -0
  92. package/dist/chunk-XA3T5KWA.js.map +1 -0
  93. package/dist/chunk-YSHJHSJM.js +19 -0
  94. package/dist/chunk-YSHJHSJM.js.map +1 -0
  95. package/dist/chunk-YVHOAVSM.js +182 -0
  96. package/dist/chunk-YVHOAVSM.js.map +1 -0
  97. package/dist/collapse.d.ts +16 -0
  98. package/dist/collapse.js +3 -0
  99. package/dist/collapse.js.map +1 -0
  100. package/dist/count-badge.d.ts +11 -0
  101. package/dist/count-badge.js +4 -0
  102. package/dist/count-badge.js.map +1 -0
  103. package/dist/date-field.d.ts +39 -0
  104. package/dist/date-field.js +8 -0
  105. package/dist/date-field.js.map +1 -0
  106. package/dist/date-range-field.d.ts +30 -0
  107. package/dist/date-range-field.js +8 -0
  108. package/dist/date-range-field.js.map +1 -0
  109. package/dist/datetime-field.d.ts +28 -0
  110. package/dist/datetime-field.js +10 -0
  111. package/dist/datetime-field.js.map +1 -0
  112. package/dist/dialog.d.ts +26 -0
  113. package/dist/dialog.js +7 -0
  114. package/dist/dialog.js.map +1 -0
  115. package/dist/index.d.ts +35 -0
  116. package/dist/index.js +40 -0
  117. package/dist/index.js.map +1 -0
  118. package/dist/motion-tokens.d.ts +29 -0
  119. package/dist/motion-tokens.js +3 -0
  120. package/dist/motion-tokens.js.map +1 -0
  121. package/dist/multi-select.d.ts +25 -0
  122. package/dist/multi-select.js +7 -0
  123. package/dist/multi-select.js.map +1 -0
  124. package/dist/number-field.d.ts +24 -0
  125. package/dist/number-field.js +4 -0
  126. package/dist/number-field.js.map +1 -0
  127. package/dist/otp-field.d.ts +20 -0
  128. package/dist/otp-field.js +3 -0
  129. package/dist/otp-field.js.map +1 -0
  130. package/dist/overlay.d.ts +31 -0
  131. package/dist/overlay.js +4 -0
  132. package/dist/overlay.js.map +1 -0
  133. package/dist/pagination.d.ts +24 -0
  134. package/dist/pagination.js +5 -0
  135. package/dist/pagination.js.map +1 -0
  136. package/dist/radio-group.d.ts +46 -0
  137. package/dist/radio-group.js +6 -0
  138. package/dist/radio-group.js.map +1 -0
  139. package/dist/select-core-SAyS-8w0.d.ts +16 -0
  140. package/dist/select.d.ts +27 -0
  141. package/dist/select.js +7 -0
  142. package/dist/select.js.map +1 -0
  143. package/dist/status-badge.d.ts +17 -0
  144. package/dist/status-badge.js +5 -0
  145. package/dist/status-badge.js.map +1 -0
  146. package/dist/table.d.ts +65 -0
  147. package/dist/table.js +5 -0
  148. package/dist/table.js.map +1 -0
  149. package/dist/tabs.d.ts +44 -0
  150. package/dist/tabs.js +5 -0
  151. package/dist/tabs.js.map +1 -0
  152. package/dist/tag.d.ts +28 -0
  153. package/dist/tag.js +5 -0
  154. package/dist/tag.js.map +1 -0
  155. package/dist/text-field.d.ts +30 -0
  156. package/dist/text-field.js +6 -0
  157. package/dist/text-field.js.map +1 -0
  158. package/dist/textarea.d.ts +33 -0
  159. package/dist/textarea.js +5 -0
  160. package/dist/textarea.js.map +1 -0
  161. package/dist/time-field.d.ts +27 -0
  162. package/dist/time-field.js +6 -0
  163. package/dist/time-field.js.map +1 -0
  164. package/dist/toast-store.d.ts +75 -0
  165. package/dist/toast-store.js +3 -0
  166. package/dist/toast-store.js.map +1 -0
  167. package/dist/toast.d.ts +3 -0
  168. package/dist/toast.js +6 -0
  169. package/dist/toast.js.map +1 -0
  170. package/dist/toggle-tag.d.ts +24 -0
  171. package/dist/toggle-tag.js +4 -0
  172. package/dist/toggle-tag.js.map +1 -0
  173. package/dist/toggle.d.ts +21 -0
  174. package/dist/toggle.js +3 -0
  175. package/dist/toggle.js.map +1 -0
  176. package/dist/tooltip.d.ts +27 -0
  177. package/dist/tooltip.js +4 -0
  178. package/dist/tooltip.js.map +1 -0
  179. package/llms.txt +165 -0
  180. package/package.json +205 -0
  181. package/src/components/alert/Alert.tsx +118 -0
  182. package/src/components/alert/alert.css +136 -0
  183. package/src/components/avatar/Avatar.tsx +128 -0
  184. package/src/components/avatar/AvatarGroup.tsx +50 -0
  185. package/src/components/avatar/avatar.css +200 -0
  186. package/src/components/badge/Badge.tsx +66 -0
  187. package/src/components/badge/CountBadge.tsx +46 -0
  188. package/src/components/badge/StatusBadge.tsx +132 -0
  189. package/src/components/badge/badge.css +243 -0
  190. package/src/components/button/Button.tsx +68 -0
  191. package/src/components/button/button.css +222 -0
  192. package/src/components/checkbox/Checkbox.tsx +90 -0
  193. package/src/components/checkbox/checkbox.css +179 -0
  194. package/src/components/date-picker/DateField.tsx +362 -0
  195. package/src/components/date-picker/DateRangeField.tsx +533 -0
  196. package/src/components/date-picker/DateTimeField.tsx +177 -0
  197. package/src/components/date-picker/TimeField.tsx +100 -0
  198. package/src/components/date-picker/date-picker.css +591 -0
  199. package/src/components/date-picker/date-utils.ts +55 -0
  200. package/src/components/date-picker/field-shell.tsx +78 -0
  201. package/src/components/date-picker/glide-pill.tsx +81 -0
  202. package/src/components/date-picker/time-core.tsx +305 -0
  203. package/src/components/dialog/Dialog.tsx +181 -0
  204. package/src/components/dialog/dialog.css +170 -0
  205. package/src/components/glass/glass.css +100 -0
  206. package/src/components/icon/Icon.tsx +76 -0
  207. package/src/components/icon/IconSlot.tsx +11 -0
  208. package/src/components/icon/icon.css +33 -0
  209. package/src/components/input/NumberField.tsx +117 -0
  210. package/src/components/input/OtpField.tsx +118 -0
  211. package/src/components/input/TextField.tsx +123 -0
  212. package/src/components/input/input.css +335 -0
  213. package/src/components/motion/Collapse.tsx +33 -0
  214. package/src/components/motion/collapse.css +41 -0
  215. package/src/components/overlay/Overlay.tsx +239 -0
  216. package/src/components/overlay/overlay-core.tsx +565 -0
  217. package/src/components/overlay/overlay.css +119 -0
  218. package/src/components/overlay/sheet-drag.tsx +146 -0
  219. package/src/components/pagination/Pagination.tsx +140 -0
  220. package/src/components/pagination/pagination.css +48 -0
  221. package/src/components/radio-group/RadioGroup.tsx +182 -0
  222. package/src/components/radio-group/radio-group.css +277 -0
  223. package/src/components/select/MultiSelect.tsx +251 -0
  224. package/src/components/select/Select.tsx +235 -0
  225. package/src/components/select/select-core.tsx +417 -0
  226. package/src/components/select/select.css +386 -0
  227. package/src/components/table/Table.tsx +433 -0
  228. package/src/components/table/table.css +348 -0
  229. package/src/components/tabs/Tabs.tsx +371 -0
  230. package/src/components/tabs/tabs.css +228 -0
  231. package/src/components/tag/Tag.tsx +145 -0
  232. package/src/components/tag/ToggleTag.tsx +125 -0
  233. package/src/components/tag/tag.css +248 -0
  234. package/src/components/textarea/Textarea.tsx +197 -0
  235. package/src/components/textarea/textarea.css +219 -0
  236. package/src/components/toast/Toast.tsx +349 -0
  237. package/src/components/toast/toast-store.ts +266 -0
  238. package/src/components/toast/toast.css +233 -0
  239. package/src/components/toggle/Toggle.tsx +94 -0
  240. package/src/components/toggle/toggle.css +152 -0
  241. package/src/components/tooltip/Tooltip.tsx +365 -0
  242. package/src/components/tooltip/tooltip.css +86 -0
  243. package/src/index.ts +42 -0
  244. package/src/styles.css +39 -0
  245. package/src/tokens/avatar.css +20 -0
  246. package/src/tokens/color.css +56 -0
  247. package/src/tokens/elevation.css +20 -0
  248. package/src/tokens/fonts.css +3 -0
  249. package/src/tokens/glass.css +21 -0
  250. package/src/tokens/icons.css +7 -0
  251. package/src/tokens/layers.css +6 -0
  252. package/src/tokens/motion-tokens.ts +72 -0
  253. package/src/tokens/motion.css +49 -0
  254. package/src/tokens/radius.css +11 -0
  255. package/src/tokens/semantic.css +75 -0
  256. package/src/tokens/spacing.css +26 -0
  257. package/src/tokens/typography.css +54 -0
@@ -0,0 +1,72 @@
1
+ /* motion-tokens.ts - the JSandCSS motion bridge; Motion code reads these token values, never hardcodes them. */
2
+
3
+ import type { Transition } from 'motion/react';
4
+
5
+ export type Bezier = [number, number, number, number];
6
+
7
+ export interface MotionTokens {
8
+ /** seconds - fast 0.12 - base 0.18 - slow 0.26 */
9
+ dur: { fast: number; base: number; slow: number };
10
+ ease: { standard: Bezier; entrance: Bezier; exit: Bezier; spring: Bezier; glide: Bezier };
11
+ /** ready-made Motion transitions */
12
+ t: { enter: Transition; exit: Transition; layout: Transition; settle: Transition };
13
+ reduced: boolean;
14
+ }
15
+
16
+ const DEFAULT_DUR: MotionTokens['dur'] = { fast: 0.12, base: 0.18, slow: 0.26 };
17
+ const DEFAULT_EASE: MotionTokens['ease'] = {
18
+ standard: [0.2, 0, 0, 1],
19
+ entrance: [0.16, 1, 0.3, 1],
20
+ exit: [0.4, 0, 1, 1],
21
+ spring: [0.34, 1.4, 0.5, 1],
22
+ glide: [0.55, 0, 0.15, 1],
23
+ };
24
+
25
+ function build(dur: MotionTokens['dur'], ease: MotionTokens['ease']): MotionTokens {
26
+ const reduced = dur.base <= 0.005; // reduced motion collapses durations to ~1ms
27
+ return {
28
+ dur,
29
+ ease,
30
+ reduced,
31
+ t: {
32
+ enter: { duration: dur.base, ease: ease.entrance },
33
+ exit: { duration: dur.fast, ease: ease.exit },
34
+ layout: { duration: dur.slow, ease: ease.entrance },
35
+ settle: reduced
36
+ ? { duration: 0 }
37
+ : { type: 'spring', visualDuration: dur.base, bounce: 0.22 },
38
+ },
39
+ };
40
+ }
41
+
42
+ function readFromDom(): MotionTokens {
43
+ const cs = getComputedStyle(document.documentElement);
44
+ const seconds = (name: string, fallback: number): number => {
45
+ const v = cs.getPropertyValue(name).trim();
46
+ const n = v.slice(-2) === 'ms' ? parseFloat(v) / 1000 : parseFloat(v);
47
+ return isNaN(n) ? fallback : n;
48
+ };
49
+ const bezier = (name: string, fallback: Bezier): Bezier => {
50
+ const m = cs.getPropertyValue(name).match(/-?[\d.]+/g);
51
+ return m && m.length === 4 ? (m.map(Number) as Bezier) : fallback;
52
+ };
53
+ return build(
54
+ {
55
+ fast: seconds('--duration-fast', DEFAULT_DUR.fast),
56
+ base: seconds('--duration-base', DEFAULT_DUR.base),
57
+ slow: seconds('--duration-slow', DEFAULT_DUR.slow),
58
+ },
59
+ {
60
+ standard: bezier('--ease-standard', DEFAULT_EASE.standard),
61
+ entrance: bezier('--ease-entrance', DEFAULT_EASE.entrance),
62
+ exit: bezier('--ease-exit', DEFAULT_EASE.exit),
63
+ spring: bezier('--ease-spring', DEFAULT_EASE.spring),
64
+ glide: bezier('--ease-glide', DEFAULT_EASE.glide),
65
+ },
66
+ );
67
+ }
68
+
69
+ export const UIMotion: MotionTokens =
70
+ typeof document !== 'undefined' ? readFromDom() : build(DEFAULT_DUR, DEFAULT_EASE);
71
+
72
+ export default UIMotion;
@@ -0,0 +1,49 @@
1
+ /* Motion system - durations, brand curves, and pre-composed transitions; smooths every layout shift by default. */
2
+
3
+ :root {
4
+ --duration-fast: 120ms;
5
+ --duration-base: 180ms;
6
+ --duration-slow: 260ms;
7
+ --duration-spin: 600ms; /* continuous loaders only; deliberately outside the UI-transition scale */
8
+ --duration-pulse: 1600ms; /* ambient live/processing breathing; not collapsed under reduced motion */
9
+
10
+ --ease-standard: cubic-bezier(0.2, 0, 0, 1);
11
+ --ease-entrance: cubic-bezier(0.16, 1, 0.3, 1);
12
+ --ease-exit: cubic-bezier(0.4, 0, 1, 1);
13
+ --ease-spring: cubic-bezier(0.34, 1.4, 0.5, 1);
14
+ --ease-glide: cubic-bezier(
15
+ 0.55,
16
+ 0,
17
+ 0.15,
18
+ 1
19
+ ); /* in-out travel - persistent element gliding between siblings; not for enter/exit */
20
+
21
+ --transition-control:
22
+ color var(--duration-fast) var(--ease-standard),
23
+ background-color var(--duration-fast) var(--ease-standard),
24
+ border-color var(--duration-fast) var(--ease-standard),
25
+ box-shadow var(--duration-fast) var(--ease-standard);
26
+ --transition-colors:
27
+ color var(--duration-fast) var(--ease-standard),
28
+ background-color var(--duration-fast) var(--ease-standard),
29
+ border-color var(--duration-fast) var(--ease-standard);
30
+ --transition-opacity: opacity var(--duration-base) var(--ease-standard);
31
+ --transition-transform: transform var(--duration-base) var(--ease-standard);
32
+
33
+ /* Layout transition - animatable stand-ins for width/height; apply wherever size may change. */
34
+ --transition-layout:
35
+ grid-template-rows var(--duration-slow) var(--ease-entrance),
36
+ grid-template-columns var(--duration-slow) var(--ease-entrance),
37
+ max-height var(--duration-slow) var(--ease-entrance),
38
+ max-width var(--duration-slow) var(--ease-entrance);
39
+ }
40
+
41
+ /* Accessibility: honor reduced-motion globally - every consumer gets it free. */
42
+ @media (prefers-reduced-motion: reduce) {
43
+ :root {
44
+ --duration-fast: 1ms;
45
+ --duration-base: 1ms;
46
+ --duration-slow: 1ms;
47
+ --duration-spin: 1200ms; /* slow the loader, never freeze it (1ms = blur) */
48
+ }
49
+ }
@@ -0,0 +1,11 @@
1
+ /* Corner radii - a restrained set; --radius-md (6px) is the control default. */
2
+
3
+ :root {
4
+ --radius-0: 0;
5
+ --radius-sm: 0.25rem;
6
+ --radius-md: 0.375rem;
7
+ --radius-lg: 0.5rem;
8
+ --radius-xl: 0.75rem;
9
+ --radius-2xl: 1rem;
10
+ --radius-full: 624.9375rem;
11
+ }
@@ -0,0 +1,75 @@
1
+ /* Semantic layer - the intent-named aliases components consume; repoint these to re-theme. */
2
+
3
+ :root {
4
+ --bg-app: var(--gray-25);
5
+ --bg-surface: var(--gray-0);
6
+ --bg-surface-raised: var(--gray-0);
7
+ --bg-subtle: var(--gray-50);
8
+ --bg-muted: var(--gray-100);
9
+ --bg-inset: var(--gray-50);
10
+ --bg-overlay: oklch(0.225 0.01 264 / 0.44);
11
+
12
+ --text-strong: var(--gray-950);
13
+ --text-body: var(--gray-800);
14
+ --text-muted: var(--gray-600);
15
+ --text-subtle: var(--gray-500);
16
+ --text-disabled: var(--gray-400);
17
+ --text-accent: var(--teal-700);
18
+ --text-on-accent: var(--gray-0);
19
+ --text-inverse: var(--gray-0);
20
+
21
+ --border-subtle: var(--gray-150);
22
+ --border-default: var(--gray-200);
23
+ --border-strong: var(--gray-300);
24
+
25
+ --accent: var(--teal-500);
26
+ --accent-hover: var(--teal-600);
27
+ --accent-active: var(--teal-700);
28
+ --accent-subtle: var(--teal-50);
29
+ --accent-border: var(--teal-200);
30
+ --accent-disabled: var(--teal-300);
31
+
32
+ --success-subtle: var(--green-50);
33
+ --success: var(--green-600);
34
+ --success-text: var(--green-700);
35
+ --warning-subtle: var(--amber-50);
36
+ --warning: var(--amber-600);
37
+ --warning-text: var(--amber-700);
38
+ --danger-subtle: var(--red-50);
39
+ --danger: var(--red-600);
40
+ --danger-text: var(--red-700);
41
+ --info-subtle: var(--teal-50);
42
+ --info: var(--teal-600);
43
+ --info-text: var(--teal-700);
44
+ --danger-disabled: var(--red-300);
45
+
46
+ --neutral-wash: var(--gray-wash);
47
+ --accent-wash: var(--teal-wash);
48
+ --success-wash: var(--green-wash);
49
+ --warning-wash: var(--amber-wash);
50
+ --danger-wash: var(--red-wash);
51
+
52
+ /* Glass tints - per-tone translucent fills derived from the status hues; alpha kept low so the frost reads through. */
53
+ --glass-tint-neutral: color-mix(in oklab, var(--gray-600) 13%, transparent);
54
+ --glass-tint-info: color-mix(in oklab, var(--info) 17%, transparent);
55
+ --glass-tint-success: color-mix(in oklab, var(--success) 17%, transparent);
56
+ --glass-tint-warning: color-mix(in oklab, var(--warning) 21%, transparent);
57
+ --glass-tint-danger: color-mix(in oklab, var(--danger) 17%, transparent);
58
+
59
+ --focus-ring: var(--ring-accent);
60
+ }
61
+
62
+ /* -- Dark theme - scaffold (light-first; build this next pass) --------------
63
+ [data-theme="dark"] {
64
+ --bg-app: var(--gray-950);
65
+ --bg-surface: var(--gray-900);
66
+ --bg-subtle: var(--gray-800);
67
+ --text-strong: var(--gray-25);
68
+ --text-body: var(--gray-200);
69
+ --text-muted: var(--gray-400);
70
+ --border-default: var(--gray-800);
71
+ --accent: var(--teal-400);
72
+ --text-accent: var(--teal-300);
73
+ ...
74
+ }
75
+ */
@@ -0,0 +1,26 @@
1
+ /* Spacing spine - one 4px base and a short scale; every gap snaps to a step. */
2
+
3
+ :root {
4
+ --space-px: 1px;
5
+ --space-0: 0;
6
+ --space-1: 0.25rem;
7
+ --space-2: 0.5rem;
8
+ --space-3: 0.75rem;
9
+ --space-4: 1rem;
10
+ --space-5: 1.5rem;
11
+ --space-6: 2rem;
12
+ --space-7: 3rem;
13
+ --space-8: 4rem;
14
+ --space-9: 6rem;
15
+ --space-10: 8rem;
16
+
17
+ --container-max: 72rem;
18
+ --measure-prose: 38rem;
19
+ --sidebar-width: 16rem;
20
+
21
+ --control-height-sm: 1.75rem;
22
+ --control-height: 2.25rem;
23
+ --control-height-lg: 2.5rem;
24
+ --control-box: 1.125rem;
25
+ --control-switch: 1.25rem; /* switch track (md); the one control size off the scale - width reuses --control-height(-sm), sm height reuses --space-4 */
26
+ }
@@ -0,0 +1,54 @@
1
+ /* Type system - two families, three weights, a 9-step ramp with matched leading + tracking. */
2
+
3
+ :root {
4
+ --font-sans: 'Geist', system-ui, -apple-system, 'Segoe UI', sans-serif;
5
+ --font-mono: 'Geist Mono', ui-monospace, 'SF Mono', 'Menlo', monospace;
6
+
7
+ --weight-regular: 400;
8
+ --weight-medium: 500;
9
+ --weight-semibold: 600;
10
+
11
+ --size-micro: 0.75rem;
12
+ --size-caption: 0.8125rem;
13
+ --size-body: 0.875rem;
14
+ --size-body-lg: 1rem;
15
+ --size-heading: 1.125rem;
16
+ --size-title: 1.3125rem;
17
+ --size-title-lg: 1.625rem;
18
+ --size-display: 2rem;
19
+ --size-display-lg: 2.5rem;
20
+
21
+ --leading-micro: 1rem;
22
+ --leading-caption: 1.125rem;
23
+ --leading-body: 1.375rem;
24
+ --leading-body-lg: 1.625rem;
25
+ --leading-heading: 1.625rem;
26
+ --leading-title: 1.75rem;
27
+ --leading-title-lg: 2rem;
28
+ --leading-display: 2.375rem;
29
+ --leading-display-lg: 2.875rem;
30
+
31
+ /* Measure - line-length cap for floating text (tooltip, toast, popover hints) so it never runs a long ribbon. */
32
+ --measure-floating: 36ch;
33
+
34
+ --tracking-caps: 0.04em;
35
+ --tracking-normal: 0em;
36
+ --tracking-tight: -0.011em;
37
+ --tracking-tighter: -0.016em;
38
+ --tracking-display: -0.021em;
39
+
40
+ /* Role bundles - size + leading + weight + tracking, pre-composed; reach for these first. */
41
+ --type-display-lg: var(--weight-semibold) var(--size-display-lg)/var(--leading-display-lg)
42
+ var(--font-sans);
43
+ --type-display: var(--weight-semibold) var(--size-display)/var(--leading-display) var(--font-sans);
44
+ --type-title-lg: var(--weight-semibold) var(--size-title-lg)/var(--leading-title-lg)
45
+ var(--font-sans);
46
+ --type-title: var(--weight-semibold) var(--size-title)/var(--leading-title) var(--font-sans);
47
+ --type-heading: var(--weight-semibold) var(--size-heading)/var(--leading-heading) var(--font-sans);
48
+ --type-body-lg: var(--weight-regular) var(--size-body-lg)/var(--leading-body-lg) var(--font-sans);
49
+ --type-body: var(--weight-regular) var(--size-body)/var(--leading-body) var(--font-sans);
50
+ --type-label: var(--weight-medium) var(--size-body)/var(--leading-body) var(--font-sans);
51
+ --type-caption: var(--weight-regular) var(--size-caption)/var(--leading-caption) var(--font-sans);
52
+ --type-micro: var(--weight-medium) var(--size-micro)/var(--leading-micro) var(--font-sans);
53
+ --type-mono: var(--weight-regular) var(--size-caption)/var(--leading-caption) var(--font-mono);
54
+ }