@scattered-light/base-ui-theme 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 (105) hide show
  1. package/README.md +19 -0
  2. package/dist/index.d.ts +103 -0
  3. package/dist/index.js +313 -0
  4. package/dist/index.js.map +1 -0
  5. package/dist/styles/base/borders.css +26 -0
  6. package/dist/styles/base/breakpoints.css +26 -0
  7. package/dist/styles/base/colors.css +150 -0
  8. package/dist/styles/base/global.css +108 -0
  9. package/dist/styles/base/reset-accessibility.css +119 -0
  10. package/dist/styles/base/reset.css +451 -0
  11. package/dist/styles/base/shadows.css +42 -0
  12. package/dist/styles/base/spacing.css +62 -0
  13. package/dist/styles/base/transitions.css +29 -0
  14. package/dist/styles/base/typography.css +63 -0
  15. package/dist/styles/base/z-index.css +22 -0
  16. package/dist/styles/components/AGGrid.css +6 -0
  17. package/dist/styles/components/Accordion.css +184 -0
  18. package/dist/styles/components/AlertDialog.css +172 -0
  19. package/dist/styles/components/Autocomplete.css +261 -0
  20. package/dist/styles/components/Avatar.css +154 -0
  21. package/dist/styles/components/Button.css +164 -0
  22. package/dist/styles/components/Checkbox.css +199 -0
  23. package/dist/styles/components/CheckboxGroup.css +21 -0
  24. package/dist/styles/components/Collapsible.css +115 -0
  25. package/dist/styles/components/Combobox.css +514 -0
  26. package/dist/styles/components/ContextMenu.css +209 -0
  27. package/dist/styles/components/Dialog.css +159 -0
  28. package/dist/styles/components/Field.css +138 -0
  29. package/dist/styles/components/Fieldset.css +48 -0
  30. package/dist/styles/components/Form.css +22 -0
  31. package/dist/styles/components/Input.css +106 -0
  32. package/dist/styles/components/Menu.css +158 -0
  33. package/dist/styles/components/Menubar.css +201 -0
  34. package/dist/styles/components/Meter.css +104 -0
  35. package/dist/styles/components/NavigationMenu.css +469 -0
  36. package/dist/styles/components/NumberField.css +182 -0
  37. package/dist/styles/components/Popover.css +167 -0
  38. package/dist/styles/components/PreviewCard.css +148 -0
  39. package/dist/styles/components/Progress.css +130 -0
  40. package/dist/styles/components/Radio.css +178 -0
  41. package/dist/styles/components/ScrollArea.css +103 -0
  42. package/dist/styles/components/Select.css +297 -0
  43. package/dist/styles/components/Separator.css +34 -0
  44. package/dist/styles/components/Slider.css +163 -0
  45. package/dist/styles/components/Switch.css +197 -0
  46. package/dist/styles/components/Tabs.css +163 -0
  47. package/dist/styles/components/Toast.css +261 -0
  48. package/dist/styles/components/Toggle.css +103 -0
  49. package/dist/styles/components/ToggleGroup.css +19 -0
  50. package/dist/styles/components/Toolbar.css +78 -0
  51. package/dist/styles/components/Tooltip.css +87 -0
  52. package/dist/styles/index.css +103 -0
  53. package/dist/styles/semantic/accessibility.css +77 -0
  54. package/dist/styles/semantic/accordion.css +102 -0
  55. package/dist/styles/semantic/ag-grid.css +114 -0
  56. package/dist/styles/semantic/alert-dialog.css +78 -0
  57. package/dist/styles/semantic/autocomplete.css +162 -0
  58. package/dist/styles/semantic/avatar.css +96 -0
  59. package/dist/styles/semantic/badge.css +16 -0
  60. package/dist/styles/semantic/button.css +145 -0
  61. package/dist/styles/semantic/card.css +14 -0
  62. package/dist/styles/semantic/checkbox-group.css +18 -0
  63. package/dist/styles/semantic/checkbox.css +117 -0
  64. package/dist/styles/semantic/collapsible.css +123 -0
  65. package/dist/styles/semantic/combobox.css +325 -0
  66. package/dist/styles/semantic/context-menu.css +131 -0
  67. package/dist/styles/semantic/dialog.css +91 -0
  68. package/dist/styles/semantic/dropdown.css +16 -0
  69. package/dist/styles/semantic/field.css +73 -0
  70. package/dist/styles/semantic/fieldset.css +45 -0
  71. package/dist/styles/semantic/form.css +20 -0
  72. package/dist/styles/semantic/input.css +83 -0
  73. package/dist/styles/semantic/menu.css +104 -0
  74. package/dist/styles/semantic/menubar.css +70 -0
  75. package/dist/styles/semantic/meter.css +88 -0
  76. package/dist/styles/semantic/modal.css +14 -0
  77. package/dist/styles/semantic/navigation-menu.css +171 -0
  78. package/dist/styles/semantic/number-field.css +142 -0
  79. package/dist/styles/semantic/popover.css +113 -0
  80. package/dist/styles/semantic/preview-card.css +108 -0
  81. package/dist/styles/semantic/progress.css +85 -0
  82. package/dist/styles/semantic/radio.css +103 -0
  83. package/dist/styles/semantic/scroll-area.css +64 -0
  84. package/dist/styles/semantic/select.css +197 -0
  85. package/dist/styles/semantic/separator.css +37 -0
  86. package/dist/styles/semantic/slider.css +120 -0
  87. package/dist/styles/semantic/switch.css +158 -0
  88. package/dist/styles/semantic/tabs.css +150 -0
  89. package/dist/styles/semantic/toast.css +171 -0
  90. package/dist/styles/semantic/toggle-group.css +29 -0
  91. package/dist/styles/semantic/toggle.css +94 -0
  92. package/dist/styles/semantic/toolbar.css +47 -0
  93. package/dist/styles/semantic/tooltip.css +56 -0
  94. package/dist/styles/theme/README.md +179 -0
  95. package/dist/styles/theme/theme-accessibility.css +13 -0
  96. package/dist/styles/theme/theme-primitives.css +7 -0
  97. package/dist/styles/theme/theme-radius.css +12 -0
  98. package/dist/styles/theme/theme-roles.css +66 -0
  99. package/dist/styles/theme/theme-spacing.css +28 -0
  100. package/dist/styles/theme/theme-stroke.css +7 -0
  101. package/dist/styles/theme/theme-typography.css +218 -0
  102. package/dist/styles/utilities/color-styles.css +34 -0
  103. package/dist/styles/utilities/layout-styles.css +19 -0
  104. package/dist/styles/utilities/text-styles.css +102 -0
  105. package/package.json +75 -0
@@ -0,0 +1,167 @@
1
+ /* Popover - Mojave Theme */
2
+
3
+ /* ============================================
4
+ TRIGGER
5
+ ============================================ */
6
+
7
+ .PopoverTrigger {
8
+ display: var(--popover-trigger-display);
9
+ align-items: var(--popover-trigger-align-items);
10
+ justify-content: var(--popover-trigger-justify-content);
11
+ }
12
+
13
+ /* ============================================
14
+ BACKDROP
15
+ ============================================ */
16
+
17
+ .PopoverBackdrop {
18
+ position: fixed;
19
+ inset: 0;
20
+ background: var(--popover-backdrop-background);
21
+ z-index: var(--popover-backdrop-z-index);
22
+ }
23
+
24
+ /* ============================================
25
+ POSITIONER
26
+ ============================================ */
27
+
28
+ .PopoverPositioner {
29
+ z-index: var(--popover-positioner-z-index);
30
+ outline: 0;
31
+ }
32
+
33
+ /* ============================================
34
+ POPUP
35
+ ============================================ */
36
+
37
+ .PopoverPopup {
38
+ position: relative;
39
+ min-width: var(--popover-popup-min-width);
40
+ max-width: var(--popover-popup-max-width);
41
+ padding: var(--popover-popup-padding);
42
+ background: var(--popover-popup-background);
43
+ border: var(--popover-popup-border-width) solid var(--popover-popup-border-color);
44
+ border-radius: var(--popover-popup-border-radius);
45
+ box-shadow: var(--popover-popup-shadow);
46
+ outline: none;
47
+ transform-origin: var(--transform-origin);
48
+ transition: opacity var(--popover-popup-animation-duration) var(--popover-popup-animation-easing),
49
+ transform var(--popover-popup-animation-duration) var(--popover-popup-animation-easing);
50
+ }
51
+
52
+ .PopoverPopup[data-starting-style],
53
+ .PopoverPopup[data-ending-style] {
54
+ opacity: 0;
55
+ transform: scale(0.95);
56
+ }
57
+
58
+ /* ============================================
59
+ TITLE
60
+ ============================================ */
61
+
62
+ .PopoverTitle {
63
+ font-family: var(--popover-title-font-family);
64
+ font-size: var(--popover-title-font-size);
65
+ font-weight: var(--popover-title-font-weight);
66
+ color: var(--popover-title-color);
67
+ line-height: var(--popover-title-line-height);
68
+ letter-spacing: var(--popover-title-letter-spacing);
69
+ margin: 0 0 var(--popover-title-margin-bottom) 0;
70
+ }
71
+
72
+ /* ============================================
73
+ DESCRIPTION
74
+ ============================================ */
75
+
76
+ .PopoverDescription {
77
+ font-family: var(--popover-description-font-family);
78
+ font-size: var(--popover-description-font-size);
79
+ font-weight: var(--popover-description-font-weight);
80
+ color: var(--popover-description-color);
81
+ line-height: var(--popover-description-line-height);
82
+ letter-spacing: var(--popover-description-letter-spacing);
83
+ margin: 0;
84
+ }
85
+
86
+ /* ============================================
87
+ CLOSE BUTTON
88
+ ============================================ */
89
+
90
+ .PopoverClose {
91
+ position: var(--popover-close-position);
92
+ top: var(--popover-close-top);
93
+ right: var(--popover-close-right);
94
+ width: var(--popover-close-width);
95
+ height: var(--popover-close-height);
96
+ padding: var(--popover-close-padding);
97
+ border: var(--popover-close-border);
98
+ border-radius: var(--popover-close-border-radius);
99
+ background: var(--popover-close-background);
100
+ color: var(--popover-close-color);
101
+ cursor: var(--popover-close-cursor);
102
+ transition: var(--popover-close-transition);
103
+ display: flex;
104
+ align-items: center;
105
+ justify-content: center;
106
+ outline: none;
107
+ }
108
+
109
+ .PopoverClose:hover {
110
+ background: var(--popover-close-background-hover);
111
+ color: var(--popover-close-color-hover);
112
+ }
113
+
114
+ .PopoverClose:focus-visible {
115
+ outline: 2px solid var(--focus-ring);
116
+ outline-offset: -1px;
117
+ }
118
+
119
+ /* ============================================
120
+ ARROW
121
+ ============================================ */
122
+
123
+ .PopoverArrow {
124
+ display: flex;
125
+ }
126
+
127
+ .PopoverArrow[data-side='top'] {
128
+ bottom: -8px;
129
+ rotate: 180deg;
130
+ }
131
+
132
+ .PopoverArrow[data-side='bottom'] {
133
+ top: -8px;
134
+ rotate: 0deg;
135
+ }
136
+
137
+ .PopoverArrow[data-side='left'] {
138
+ right: -13px;
139
+ rotate: 90deg;
140
+ }
141
+
142
+ .PopoverArrow[data-side='right'] {
143
+ left: -13px;
144
+ rotate: -90deg;
145
+ }
146
+
147
+ .PopoverArrowFill {
148
+ fill: var(--popover-arrow-fill);
149
+ }
150
+
151
+ .PopoverArrowOuterStroke {
152
+ fill: var(--popover-arrow-stroke);
153
+ }
154
+
155
+ .PopoverArrowInnerStroke {
156
+ fill: var(--popover-arrow-stroke);
157
+ }
158
+
159
+ /* ============================================
160
+ REDUCED MOTION
161
+ ============================================ */
162
+
163
+ @media (prefers-reduced-motion: reduce) {
164
+ .PopoverPopup {
165
+ transition: none;
166
+ }
167
+ }
@@ -0,0 +1,148 @@
1
+ /* Preview Card - Mojave Theme */
2
+
3
+ /* ============================================
4
+ TRIGGER (link)
5
+ ============================================ */
6
+
7
+ .PreviewCardTrigger {
8
+ color: var(--preview-card-trigger-color);
9
+ text-decoration: var(--preview-card-trigger-text-decoration);
10
+ text-decoration-style: var(--preview-card-trigger-text-decoration-style);
11
+ text-underline-offset: var(--preview-card-trigger-text-underline-offset);
12
+ cursor: var(--preview-card-trigger-cursor);
13
+ }
14
+
15
+ .PreviewCardTrigger:hover {
16
+ color: var(--preview-card-trigger-color-hover);
17
+ }
18
+
19
+ /* ============================================
20
+ POSITIONER
21
+ ============================================ */
22
+
23
+ .PreviewCardPositioner {
24
+ z-index: var(--preview-card-positioner-z-index);
25
+ outline: 0;
26
+ }
27
+
28
+ /* ============================================
29
+ POPUP
30
+ ============================================ */
31
+
32
+ .PreviewCardPopup {
33
+ position: relative;
34
+ min-width: var(--preview-card-popup-min-width);
35
+ max-width: var(--preview-card-popup-max-width);
36
+ padding: var(--preview-card-popup-padding);
37
+ background: var(--preview-card-popup-background);
38
+ border: var(--preview-card-popup-border-width) solid var(--preview-card-popup-border-color);
39
+ border-radius: var(--preview-card-popup-border-radius);
40
+ box-shadow: var(--preview-card-popup-shadow);
41
+ overflow: var(--preview-card-popup-overflow);
42
+ outline: none;
43
+ transform-origin: var(--transform-origin);
44
+ transition: opacity var(--preview-card-popup-animation-duration) var(--preview-card-popup-animation-easing),
45
+ transform var(--preview-card-popup-animation-duration) var(--preview-card-popup-animation-easing);
46
+ }
47
+
48
+ .PreviewCardPopup[data-starting-style],
49
+ .PreviewCardPopup[data-ending-style] {
50
+ opacity: 0;
51
+ transform: scale(0.95) translateY(-4px);
52
+ }
53
+
54
+ /* ============================================
55
+ IMAGE
56
+ ============================================ */
57
+
58
+ .PreviewCardImage {
59
+ width: var(--preview-card-image-width);
60
+ height: var(--preview-card-image-height);
61
+ display: var(--preview-card-image-display);
62
+ }
63
+
64
+ /* ============================================
65
+ CONTENT
66
+ ============================================ */
67
+
68
+ .PreviewCardContent {
69
+ padding: var(--preview-card-content-padding);
70
+ }
71
+
72
+ /* ============================================
73
+ TITLE
74
+ ============================================ */
75
+
76
+ .PreviewCardTitle {
77
+ font-family: var(--preview-card-title-font-family);
78
+ font-size: var(--preview-card-title-font-size);
79
+ font-weight: var(--preview-card-title-font-weight);
80
+ color: var(--preview-card-title-color);
81
+ line-height: var(--preview-card-title-line-height);
82
+ letter-spacing: var(--preview-card-title-letter-spacing);
83
+ margin: 0 0 var(--preview-card-title-margin-bottom) 0;
84
+ }
85
+
86
+ /* ============================================
87
+ DESCRIPTION
88
+ ============================================ */
89
+
90
+ .PreviewCardDescription {
91
+ font-family: var(--preview-card-description-font-family);
92
+ font-size: var(--preview-card-description-font-size);
93
+ font-weight: var(--preview-card-description-font-weight);
94
+ color: var(--preview-card-description-color);
95
+ line-height: var(--preview-card-description-line-height);
96
+ letter-spacing: var(--preview-card-description-letter-spacing);
97
+ margin: 0;
98
+ }
99
+
100
+ /* ============================================
101
+ ARROW
102
+ ============================================ */
103
+
104
+ .PreviewCardArrow {
105
+ display: flex;
106
+ }
107
+
108
+ .PreviewCardArrow[data-side='top'] {
109
+ bottom: -8px;
110
+ rotate: 180deg;
111
+ }
112
+
113
+ .PreviewCardArrow[data-side='bottom'] {
114
+ top: -8px;
115
+ rotate: 0deg;
116
+ }
117
+
118
+ .PreviewCardArrow[data-side='left'] {
119
+ right: -13px;
120
+ rotate: 90deg;
121
+ }
122
+
123
+ .PreviewCardArrow[data-side='right'] {
124
+ left: -13px;
125
+ rotate: -90deg;
126
+ }
127
+
128
+ .PreviewCardArrowFill {
129
+ fill: var(--preview-card-arrow-fill);
130
+ }
131
+
132
+ .PreviewCardArrowOuterStroke {
133
+ fill: var(--preview-card-arrow-stroke);
134
+ }
135
+
136
+ .PreviewCardArrowInnerStroke {
137
+ fill: var(--preview-card-arrow-stroke);
138
+ }
139
+
140
+ /* ============================================
141
+ REDUCED MOTION
142
+ ============================================ */
143
+
144
+ @media (prefers-reduced-motion: reduce) {
145
+ .PreviewCardPopup {
146
+ transition: none;
147
+ }
148
+ }
@@ -0,0 +1,130 @@
1
+ /* Progress - Mojave Theme */
2
+
3
+ /* ============================================
4
+ ROOT CONTAINER
5
+ ============================================ */
6
+
7
+ .ProgressRoot {
8
+ display: var(--progress-root-display);
9
+ flex-direction: var(--progress-root-flex-direction);
10
+ gap: var(--progress-root-gap);
11
+ width: var(--progress-root-width);
12
+ }
13
+
14
+ /* ============================================
15
+ HEADER (label + value container)
16
+ ============================================ */
17
+
18
+ .ProgressHeader {
19
+ display: flex;
20
+ justify-content: space-between;
21
+ align-items: center;
22
+ }
23
+
24
+ /* ============================================
25
+ LABEL
26
+ ============================================ */
27
+
28
+ .ProgressLabel {
29
+ font-family: var(--progress-label-font-family);
30
+ font-size: var(--progress-label-font-size);
31
+ font-weight: var(--progress-label-font-weight);
32
+ line-height: var(--progress-label-line-height);
33
+ letter-spacing: var(--progress-label-letter-spacing);
34
+ color: var(--progress-label-color);
35
+ }
36
+
37
+ /* ============================================
38
+ VALUE (percentage display)
39
+ ============================================ */
40
+
41
+ .ProgressValue {
42
+ font-family: var(--progress-value-font-family);
43
+ font-size: var(--progress-value-font-size);
44
+ font-weight: var(--progress-value-font-weight);
45
+ line-height: var(--progress-value-line-height);
46
+ letter-spacing: var(--progress-value-letter-spacing);
47
+ color: var(--progress-value-color);
48
+ }
49
+
50
+ /* ============================================
51
+ TRACK
52
+ ============================================ */
53
+
54
+ .ProgressTrack {
55
+ position: relative;
56
+ height: var(--progress-track-height);
57
+ background: var(--progress-track-background);
58
+ border-radius: var(--progress-track-border-radius);
59
+ overflow: var(--progress-track-overflow);
60
+ }
61
+
62
+ /* ============================================
63
+ INDICATOR
64
+ ============================================ */
65
+
66
+ .ProgressIndicator {
67
+ height: 100%;
68
+ background: var(--progress-indicator-background);
69
+ border-radius: var(--progress-indicator-border-radius);
70
+ transition: var(--progress-indicator-transition);
71
+ }
72
+
73
+ /* Indeterminate state */
74
+ .ProgressRoot[data-state='indeterminate'] .ProgressIndicator {
75
+ animation: progressIndeterminate var(--progress-indicator-indeterminate-animation-duration) ease-in-out infinite;
76
+ }
77
+
78
+ @keyframes progressIndeterminate {
79
+ 0% {
80
+ transform: translateX(-100%);
81
+ }
82
+ 50% {
83
+ transform: translateX(0%);
84
+ }
85
+ 100% {
86
+ transform: translateX(100%);
87
+ }
88
+ }
89
+
90
+ /* ============================================
91
+ SIZE VARIANTS
92
+ ============================================ */
93
+
94
+ .ProgressRoot[data-size='sm'] .ProgressTrack {
95
+ height: var(--progress-track-height-sm);
96
+ }
97
+
98
+ .ProgressRoot[data-size='lg'] .ProgressTrack {
99
+ height: var(--progress-track-height-lg);
100
+ }
101
+
102
+ /* ============================================
103
+ COLOR VARIANTS
104
+ ============================================ */
105
+
106
+ .ProgressRoot[data-variant='success'] .ProgressIndicator {
107
+ background: var(--progress-indicator-success);
108
+ }
109
+
110
+ .ProgressRoot[data-variant='warning'] .ProgressIndicator {
111
+ background: var(--progress-indicator-warning);
112
+ }
113
+
114
+ .ProgressRoot[data-variant='error'] .ProgressIndicator {
115
+ background: var(--progress-indicator-error);
116
+ }
117
+
118
+ /* ============================================
119
+ REDUCED MOTION
120
+ ============================================ */
121
+
122
+ @media (prefers-reduced-motion: reduce) {
123
+ .ProgressIndicator {
124
+ transition: none;
125
+ }
126
+
127
+ .ProgressRoot[data-state='indeterminate'] .ProgressIndicator {
128
+ animation: none;
129
+ }
130
+ }
@@ -0,0 +1,178 @@
1
+ /* Radio - Mojave Theme */
2
+
3
+ /* ============================================
4
+ ROOT CONTAINER (label wrapper)
5
+ ============================================ */
6
+
7
+ .RadioRoot {
8
+ display: var(--radio-root-display);
9
+ align-items: var(--radio-root-align-items);
10
+ gap: var(--radio-root-gap);
11
+ cursor: var(--radio-label-cursor);
12
+ }
13
+
14
+ .RadioRoot[data-disabled] {
15
+ cursor: var(--radio-button-cursor-disabled);
16
+ }
17
+
18
+ /* ============================================
19
+ RADIO BUTTON (Radio.Root element)
20
+ ============================================ */
21
+
22
+ .RadioButton {
23
+ box-sizing: border-box;
24
+ display: flex;
25
+ width: var(--radio-button-size);
26
+ height: var(--radio-button-size);
27
+ align-items: center;
28
+ justify-content: center;
29
+ border-radius: var(--radio-button-border-radius);
30
+ outline: 0;
31
+ padding: 0;
32
+ margin: 0;
33
+ border: none;
34
+ flex-shrink: 0;
35
+ cursor: pointer;
36
+ transition: var(--radio-button-transition);
37
+ }
38
+
39
+ .RadioButton[data-unchecked] {
40
+ border: var(--radio-button-border-width) solid var(--radio-button-border-color);
41
+ background-color: var(--radio-button-bg);
42
+ }
43
+
44
+ .RadioRoot:hover .RadioButton[data-unchecked]:not([disabled]) {
45
+ border-color: var(--radio-button-border-color-hover);
46
+ }
47
+
48
+ .RadioButton[data-checked] {
49
+ background-color: var(--radio-button-bg-checked);
50
+ border: var(--radio-button-border-width) solid var(--radio-button-border-color-checked);
51
+ }
52
+
53
+ .RadioButton:focus-visible {
54
+ outline: 2px solid var(--radio-button-border-color-checked);
55
+ outline-offset: 2px;
56
+ box-shadow: var(--radio-button-shadow-focus);
57
+ }
58
+
59
+ .RadioButton[disabled] {
60
+ opacity: var(--radio-button-opacity-disabled);
61
+ cursor: var(--radio-button-cursor-disabled);
62
+ }
63
+
64
+ /* ============================================
65
+ RADIO INDICATOR (inner dot)
66
+ ============================================ */
67
+
68
+ .RadioIndicator {
69
+ display: flex;
70
+ align-items: center;
71
+ justify-content: center;
72
+ }
73
+
74
+ .RadioIndicator[data-unchecked] {
75
+ display: none;
76
+ }
77
+
78
+ .RadioIndicator::before {
79
+ content: '';
80
+ border-radius: var(--radio-indicator-border-radius);
81
+ width: var(--radio-indicator-size);
82
+ height: var(--radio-indicator-size);
83
+ background-color: var(--radio-indicator-color);
84
+ animation: radioScale 0.15s ease-out;
85
+ }
86
+
87
+ @keyframes radioScale {
88
+ from {
89
+ opacity: 0;
90
+ transform: scale(0);
91
+ }
92
+ to {
93
+ opacity: 1;
94
+ transform: scale(1);
95
+ }
96
+ }
97
+
98
+ /* ============================================
99
+ LABEL
100
+ ============================================ */
101
+
102
+ .RadioLabel {
103
+ font-family: var(--radio-label-font-family);
104
+ font-size: var(--radio-label-font-size);
105
+ font-weight: var(--radio-label-font-weight);
106
+ line-height: var(--radio-label-line-height);
107
+ letter-spacing: var(--radio-label-letter-spacing);
108
+ color: var(--radio-label-color);
109
+ user-select: none;
110
+ }
111
+
112
+ .RadioRoot[data-disabled] .RadioLabel {
113
+ color: var(--radio-label-color-disabled);
114
+ }
115
+
116
+ /* ============================================
117
+ GROUP
118
+ ============================================ */
119
+
120
+ .RadioGroup {
121
+ display: var(--radio-group-display);
122
+ flex-direction: var(--radio-group-flex-direction);
123
+ gap: var(--radio-group-gap);
124
+ }
125
+
126
+ /* ============================================
127
+ SIZE VARIANTS
128
+ ============================================ */
129
+
130
+ .RadioRoot[data-size='sm'] .RadioButton {
131
+ width: var(--radio-button-size-sm);
132
+ height: var(--radio-button-size-sm);
133
+ }
134
+
135
+ .RadioRoot[data-size='sm'] .RadioIndicator::before {
136
+ width: var(--radio-indicator-size-sm);
137
+ height: var(--radio-indicator-size-sm);
138
+ }
139
+
140
+ .RadioRoot[data-size='sm'] .RadioLabel {
141
+ font-family: var(--radio-label-font-family-sm);
142
+ font-size: var(--radio-label-font-size-sm);
143
+ font-weight: var(--radio-label-font-weight-sm);
144
+ line-height: var(--radio-label-line-height-sm);
145
+ letter-spacing: var(--radio-label-letter-spacing-sm);
146
+ }
147
+
148
+ .RadioRoot[data-size='lg'] .RadioButton {
149
+ width: var(--radio-button-size-lg);
150
+ height: var(--radio-button-size-lg);
151
+ }
152
+
153
+ .RadioRoot[data-size='lg'] .RadioIndicator::before {
154
+ width: var(--radio-indicator-size-lg);
155
+ height: var(--radio-indicator-size-lg);
156
+ }
157
+
158
+ .RadioRoot[data-size='lg'] .RadioLabel {
159
+ font-family: var(--radio-label-font-family-lg);
160
+ font-size: var(--radio-label-font-size-lg);
161
+ font-weight: var(--radio-label-font-weight-lg);
162
+ line-height: var(--radio-label-line-height-lg);
163
+ letter-spacing: var(--radio-label-letter-spacing-lg);
164
+ }
165
+
166
+ /* ============================================
167
+ REDUCED MOTION
168
+ ============================================ */
169
+
170
+ @media (prefers-reduced-motion: reduce) {
171
+ .RadioButton {
172
+ transition: none;
173
+ }
174
+
175
+ .RadioIndicator::before {
176
+ animation: none;
177
+ }
178
+ }