@rokkit/themes 1.0.0-next.124 → 1.0.0-next.127

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 (130) hide show
  1. package/README.md +118 -9
  2. package/package.json +31 -27
  3. package/src/base/breadcrumbs.css +46 -0
  4. package/src/base/button.css +243 -0
  5. package/src/base/card.css +36 -0
  6. package/src/base/carousel.css +122 -12
  7. package/src/base/connector.css +106 -0
  8. package/src/base/display.css +91 -0
  9. package/src/base/floating-action.css +388 -0
  10. package/src/base/floating-navigation.css +381 -0
  11. package/src/base/index.css +36 -0
  12. package/src/base/input.css +194 -39
  13. package/src/base/item.css +52 -0
  14. package/src/base/list.css +258 -0
  15. package/src/base/menu.css +322 -0
  16. package/src/base/pill.css +57 -0
  17. package/src/base/progress.css +28 -15
  18. package/src/base/range.css +121 -0
  19. package/src/base/rating.css +40 -0
  20. package/src/base/reveal.css +37 -0
  21. package/src/base/search-filter.css +132 -0
  22. package/src/base/select.css +411 -0
  23. package/src/base/shine.css +14 -0
  24. package/src/base/stepper.css +140 -0
  25. package/src/base/switch.css +152 -0
  26. package/src/base/table.css +143 -33
  27. package/src/base/tabs.css +171 -0
  28. package/src/base/tilt.css +14 -0
  29. package/src/base/timeline.css +84 -0
  30. package/src/base/toggle.css +134 -0
  31. package/src/base/toolbar.css +337 -0
  32. package/src/base/tree.css +156 -11
  33. package/src/glass/button.css +152 -0
  34. package/src/glass/floating-action.css +61 -0
  35. package/src/glass/floating-navigation.css +74 -0
  36. package/src/glass/index.css +23 -0
  37. package/src/glass/input.css +124 -0
  38. package/src/glass/list.css +122 -0
  39. package/src/glass/menu.css +92 -0
  40. package/src/glass/range.css +61 -0
  41. package/src/glass/search-filter.css +49 -0
  42. package/src/glass/select.css +178 -0
  43. package/src/glass/switch.css +28 -0
  44. package/src/glass/table.css +87 -0
  45. package/src/glass/tabs.css +58 -0
  46. package/src/glass/timeline.css +46 -0
  47. package/src/glass/toggle.css +48 -0
  48. package/src/glass/toolbar.css +84 -0
  49. package/src/glass/tree.css +104 -0
  50. package/src/index.css +18 -0
  51. package/src/index.js +25 -2
  52. package/src/material/button.css +153 -0
  53. package/src/material/floating-action.css +60 -0
  54. package/src/material/floating-navigation.css +74 -0
  55. package/src/material/index.css +23 -0
  56. package/src/material/input.css +118 -40
  57. package/src/material/list.css +90 -64
  58. package/src/material/menu.css +92 -0
  59. package/src/material/range.css +62 -0
  60. package/src/material/search-filter.css +49 -0
  61. package/src/material/select.css +170 -0
  62. package/src/material/switch.css +28 -0
  63. package/src/material/table.css +87 -0
  64. package/src/material/tabs.css +62 -0
  65. package/src/material/timeline.css +46 -0
  66. package/src/material/toggle.css +48 -0
  67. package/src/material/toolbar.css +84 -0
  68. package/src/material/tree.css +100 -0
  69. package/src/minimal/button.css +152 -0
  70. package/src/minimal/floating-action.css +59 -0
  71. package/src/minimal/floating-navigation.css +70 -0
  72. package/src/minimal/index.css +23 -0
  73. package/src/minimal/input.css +81 -120
  74. package/src/minimal/list.css +90 -104
  75. package/src/minimal/menu.css +88 -0
  76. package/src/minimal/range.css +61 -0
  77. package/src/minimal/search-filter.css +49 -0
  78. package/src/minimal/select.css +168 -0
  79. package/src/minimal/switch.css +28 -0
  80. package/src/minimal/table.css +87 -0
  81. package/src/minimal/tabs.css +53 -31
  82. package/src/minimal/timeline.css +45 -0
  83. package/src/minimal/toggle.css +48 -0
  84. package/src/minimal/toolbar.css +84 -0
  85. package/src/minimal/tree.css +100 -0
  86. package/src/rokkit/button.css +225 -0
  87. package/src/rokkit/connector.css +11 -0
  88. package/src/rokkit/floating-action.css +65 -0
  89. package/src/rokkit/floating-navigation.css +83 -0
  90. package/src/rokkit/index.css +24 -0
  91. package/src/rokkit/input.css +130 -0
  92. package/src/rokkit/list.css +141 -0
  93. package/src/rokkit/menu.css +123 -0
  94. package/src/rokkit/range.css +62 -0
  95. package/src/rokkit/search-filter.css +49 -0
  96. package/src/rokkit/select.css +185 -0
  97. package/src/rokkit/switch.css +28 -0
  98. package/src/rokkit/table.css +68 -38
  99. package/src/rokkit/tabs.css +82 -0
  100. package/src/rokkit/timeline.css +46 -0
  101. package/src/rokkit/toggle.css +36 -52
  102. package/src/rokkit/toolbar.css +84 -0
  103. package/src/rokkit/tree.css +123 -0
  104. package/src/base/alert.css +0 -30
  105. package/src/base/animation.css +0 -37
  106. package/src/base/atoms.css +0 -58
  107. package/src/base/core.css +0 -107
  108. package/src/base/layout.css +0 -65
  109. package/src/base/molecules.css +0 -109
  110. package/src/base/organisms.css +0 -66
  111. package/src/base/scrollbar.css +0 -16
  112. package/src/base/toggles.css +0 -17
  113. package/src/base.css +0 -13
  114. package/src/markdown.css +0 -955
  115. package/src/material/base.css +0 -12
  116. package/src/material/form.css +0 -30
  117. package/src/material.css +0 -9
  118. package/src/minimal/base.css +0 -8
  119. package/src/minimal/form.css +0 -87
  120. package/src/minimal.css +0 -11
  121. package/src/mixins/mixins.scss +0 -66
  122. package/src/mixins/palette.scss +0 -48
  123. package/src/prism.css +0 -102
  124. package/src/rokkit/alert.css +0 -4
  125. package/src/rokkit/atoms.css +0 -52
  126. package/src/rokkit/carousel.css +0 -19
  127. package/src/rokkit/layout.css +0 -17
  128. package/src/rokkit/molecules.css +0 -124
  129. package/src/rokkit/organisms.css +0 -307
  130. package/src/rokkit.css +0 -11
@@ -0,0 +1,337 @@
1
+ /**
2
+ * Toolbar - Base Structural Styles
3
+ *
4
+ * These styles provide layout, positioning, and basic structure.
5
+ * No colors, shadows, or visual theming - those belong in theme styles.
6
+ */
7
+
8
+ /* =============================================================================
9
+ Toolbar Container
10
+ ============================================================================= */
11
+
12
+ [data-toolbar] {
13
+ display: flex;
14
+ align-items: center;
15
+ gap: 0.25rem;
16
+ }
17
+
18
+ [data-toolbar][data-toolbar-disabled='true'] {
19
+ pointer-events: none;
20
+ opacity: 0.5;
21
+ }
22
+
23
+ /* Position variants - horizontal */
24
+ [data-toolbar][data-toolbar-position='top'],
25
+ [data-toolbar][data-toolbar-position='bottom'],
26
+ [data-toolbar]:not([data-toolbar-position]) {
27
+ flex-direction: row;
28
+ }
29
+
30
+ /* Position variants - vertical */
31
+ [data-toolbar][data-toolbar-position='left'],
32
+ [data-toolbar][data-toolbar-position='right'] {
33
+ flex-direction: column;
34
+ height: 100%;
35
+ width: auto;
36
+ }
37
+
38
+ /* Sticky positioning */
39
+ [data-toolbar][data-toolbar-sticky='true'] {
40
+ position: sticky;
41
+ z-index: 10;
42
+ }
43
+
44
+ [data-toolbar][data-toolbar-sticky='true'][data-toolbar-position='top'],
45
+ [data-toolbar][data-toolbar-sticky='true']:not([data-toolbar-position]) {
46
+ top: 0;
47
+ }
48
+
49
+ [data-toolbar][data-toolbar-sticky='true'][data-toolbar-position='bottom'] {
50
+ bottom: 0;
51
+ }
52
+
53
+ [data-toolbar][data-toolbar-sticky='true'][data-toolbar-position='left'] {
54
+ left: 0;
55
+ }
56
+
57
+ [data-toolbar][data-toolbar-sticky='true'][data-toolbar-position='right'] {
58
+ right: 0;
59
+ }
60
+
61
+ /* Size variants - horizontal */
62
+ [data-toolbar][data-toolbar-size='sm'],
63
+ [data-toolbar][data-size='sm'] {
64
+ height: 2rem;
65
+ padding-inline: 0.5rem;
66
+ gap: 0.25rem;
67
+ }
68
+
69
+ [data-toolbar][data-toolbar-size='md'],
70
+ [data-toolbar][data-size='md'],
71
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) {
72
+ height: 2.5rem;
73
+ padding-inline: 0.75rem;
74
+ gap: 0.5rem;
75
+ }
76
+
77
+ [data-toolbar][data-toolbar-size='lg'],
78
+ [data-toolbar][data-size='lg'] {
79
+ height: 3rem;
80
+ padding-inline: 1rem;
81
+ gap: 0.75rem;
82
+ }
83
+
84
+ /* Compact mode */
85
+ [data-toolbar][data-toolbar-compact='true'] {
86
+ padding-block: 0;
87
+ }
88
+
89
+ [data-toolbar]:not([data-toolbar-compact='true']) {
90
+ padding-block: 0.25rem;
91
+ }
92
+
93
+ /* Vertical toolbar size adjustments */
94
+ [data-toolbar][data-toolbar-position='left'],
95
+ [data-toolbar][data-toolbar-position='right'] {
96
+ height: auto;
97
+ padding-block: 0.5rem;
98
+ padding-inline: 0.25rem;
99
+ }
100
+
101
+ /* =============================================================================
102
+ Toolbar Items (buttons, toggles)
103
+ ============================================================================= */
104
+
105
+ [data-toolbar-item] {
106
+ display: inline-flex;
107
+ align-items: center;
108
+ justify-content: center;
109
+ border: none;
110
+ background: transparent;
111
+ cursor: pointer;
112
+ border-radius: 0.25rem;
113
+ transition: all 150ms ease;
114
+ }
115
+
116
+ [data-toolbar-item]:focus {
117
+ outline: none;
118
+ }
119
+
120
+ [data-toolbar-item][data-disabled='true'],
121
+ [data-toolbar-item]:disabled {
122
+ pointer-events: none;
123
+ opacity: 0.5;
124
+ cursor: not-allowed;
125
+ }
126
+
127
+ /* Size variants for items */
128
+ [data-toolbar][data-toolbar-size='sm'] [data-toolbar-item],
129
+ [data-toolbar][data-size='sm'] [data-toolbar-item] {
130
+ min-width: 1.5rem;
131
+ height: 1.5rem;
132
+ padding: 0.25rem;
133
+ }
134
+
135
+ [data-toolbar][data-toolbar-size='md'] [data-toolbar-item],
136
+ [data-toolbar][data-size='md'] [data-toolbar-item],
137
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) [data-toolbar-item] {
138
+ min-width: 2rem;
139
+ height: 2rem;
140
+ padding: 0.375rem;
141
+ }
142
+
143
+ [data-toolbar][data-toolbar-size='lg'] [data-toolbar-item],
144
+ [data-toolbar][data-size='lg'] [data-toolbar-item] {
145
+ min-width: 2.5rem;
146
+ height: 2.5rem;
147
+ padding: 0.5rem;
148
+ }
149
+
150
+ /* =============================================================================
151
+ Toolbar Item Elements (icon, label)
152
+ ============================================================================= */
153
+
154
+ [data-toolbar-icon] {
155
+ flex-shrink: 0;
156
+ }
157
+
158
+ [data-toolbar-label] {
159
+ white-space: nowrap;
160
+ font-weight: 500;
161
+ }
162
+
163
+ /* Icon sizes */
164
+ [data-toolbar][data-toolbar-size='sm'] [data-toolbar-icon],
165
+ [data-toolbar][data-size='sm'] [data-toolbar-icon] {
166
+ font-size: 0.875rem;
167
+ }
168
+
169
+ [data-toolbar][data-toolbar-size='md'] [data-toolbar-icon],
170
+ [data-toolbar][data-size='md'] [data-toolbar-icon],
171
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) [data-toolbar-icon] {
172
+ font-size: 1rem;
173
+ }
174
+
175
+ [data-toolbar][data-toolbar-size='lg'] [data-toolbar-icon],
176
+ [data-toolbar][data-size='lg'] [data-toolbar-icon] {
177
+ font-size: 1.25rem;
178
+ }
179
+
180
+ /* Label sizes */
181
+ [data-toolbar][data-toolbar-size='sm'] [data-toolbar-label],
182
+ [data-toolbar][data-size='sm'] [data-toolbar-label] {
183
+ font-size: 0.75rem;
184
+ padding-inline: 0.25rem;
185
+ }
186
+
187
+ [data-toolbar][data-toolbar-size='md'] [data-toolbar-label],
188
+ [data-toolbar][data-size='md'] [data-toolbar-label],
189
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) [data-toolbar-label] {
190
+ font-size: 0.875rem;
191
+ padding-inline: 0.375rem;
192
+ }
193
+
194
+ [data-toolbar][data-toolbar-size='lg'] [data-toolbar-label],
195
+ [data-toolbar][data-size='lg'] [data-toolbar-label] {
196
+ font-size: 1rem;
197
+ padding-inline: 0.5rem;
198
+ }
199
+
200
+ /* =============================================================================
201
+ Separator
202
+ ============================================================================= */
203
+
204
+ [data-toolbar-separator] {
205
+ flex-shrink: 0;
206
+ }
207
+
208
+ /* Horizontal toolbar separator (vertical line) */
209
+ [data-toolbar][data-toolbar-position='top'] [data-toolbar-separator],
210
+ [data-toolbar][data-toolbar-position='bottom'] [data-toolbar-separator],
211
+ [data-toolbar]:not([data-toolbar-position]) [data-toolbar-separator] {
212
+ width: 1px;
213
+ margin-inline: 0.5rem;
214
+ }
215
+
216
+ [data-toolbar][data-toolbar-size='sm'] [data-toolbar-separator],
217
+ [data-toolbar][data-size='sm'] [data-toolbar-separator] {
218
+ height: 1rem;
219
+ }
220
+
221
+ [data-toolbar][data-toolbar-size='md'] [data-toolbar-separator],
222
+ [data-toolbar][data-size='md'] [data-toolbar-separator],
223
+ [data-toolbar]:not([data-toolbar-size]):not([data-size]) [data-toolbar-separator] {
224
+ height: 1.25rem;
225
+ }
226
+
227
+ [data-toolbar][data-toolbar-size='lg'] [data-toolbar-separator],
228
+ [data-toolbar][data-size='lg'] [data-toolbar-separator] {
229
+ height: 1.5rem;
230
+ }
231
+
232
+ /* Vertical toolbar separator (horizontal line) */
233
+ [data-toolbar][data-toolbar-position='left'] [data-toolbar-separator],
234
+ [data-toolbar][data-toolbar-position='right'] [data-toolbar-separator] {
235
+ height: 1px;
236
+ width: 1.5rem;
237
+ margin-block: 0.5rem;
238
+ }
239
+
240
+ /* =============================================================================
241
+ Divider (between sections)
242
+ ============================================================================= */
243
+
244
+ [data-toolbar-divider] {
245
+ flex-shrink: 0;
246
+ }
247
+
248
+ /* Horizontal toolbar divider (vertical line) */
249
+ [data-toolbar][data-toolbar-position='top'] [data-toolbar-divider],
250
+ [data-toolbar][data-toolbar-position='bottom'] [data-toolbar-divider],
251
+ [data-toolbar]:not([data-toolbar-position]) [data-toolbar-divider] {
252
+ width: 1px;
253
+ height: 1.5rem;
254
+ margin-inline: 0.5rem;
255
+ }
256
+
257
+ /* Vertical toolbar divider (horizontal line) */
258
+ [data-toolbar][data-toolbar-position='left'] [data-toolbar-divider],
259
+ [data-toolbar][data-toolbar-position='right'] [data-toolbar-divider] {
260
+ height: 1px;
261
+ width: 1.5rem;
262
+ margin-block: 0.5rem;
263
+ }
264
+
265
+ /* =============================================================================
266
+ Spacer
267
+ ============================================================================= */
268
+
269
+ [data-toolbar-spacer] {
270
+ flex: 1;
271
+ }
272
+
273
+ /* =============================================================================
274
+ Sections
275
+ ============================================================================= */
276
+
277
+ [data-toolbar-section] {
278
+ display: flex;
279
+ align-items: center;
280
+ gap: 0.5rem;
281
+ }
282
+
283
+ [data-toolbar-section='center'] {
284
+ flex: 1;
285
+ justify-content: center;
286
+ }
287
+
288
+ [data-toolbar-section='content'] {
289
+ flex: 1;
290
+ }
291
+
292
+ /* Vertical toolbar sections */
293
+ [data-toolbar][data-toolbar-position='left'] [data-toolbar-section],
294
+ [data-toolbar][data-toolbar-position='right'] [data-toolbar-section] {
295
+ flex-direction: column;
296
+ }
297
+
298
+ /* =============================================================================
299
+ Toolbar Group
300
+ ============================================================================= */
301
+
302
+ [data-toolbar-group] {
303
+ display: flex;
304
+ align-items: center;
305
+ min-width: 0;
306
+ }
307
+
308
+ [data-toolbar-group][data-toolbar-group-gap='none'] {
309
+ gap: 0;
310
+ }
311
+
312
+ [data-toolbar-group][data-toolbar-group-gap='sm'],
313
+ [data-toolbar-group]:not([data-toolbar-group-gap]) {
314
+ gap: 0.25rem;
315
+ }
316
+
317
+ [data-toolbar-group][data-toolbar-group-gap='md'] {
318
+ gap: 0.5rem;
319
+ }
320
+
321
+ [data-toolbar-group][data-toolbar-group-gap='lg'] {
322
+ gap: 0.75rem;
323
+ }
324
+
325
+ /* Vertical toolbar groups */
326
+ [data-toolbar][data-toolbar-position='left'] [data-toolbar-group],
327
+ [data-toolbar][data-toolbar-position='right'] [data-toolbar-group] {
328
+ flex-direction: column;
329
+ }
330
+
331
+ /* =============================================================================
332
+ Custom Item Wrapper
333
+ ============================================================================= */
334
+
335
+ [data-toolbar-item-custom] {
336
+ display: contents;
337
+ }
package/src/base/tree.css CHANGED
@@ -1,18 +1,163 @@
1
- rk-tree,
2
- rk-nested-list {
3
- @apply flex w-full flex-col text-sm;
1
+ /**
2
+ * Tree - Base Structural Styles
3
+ *
4
+ * These styles provide layout, positioning, and basic structure.
5
+ * No colors, shadows, or visual theming - those belong in theme styles.
6
+ *
7
+ * Note: Connector styles are in connector.css
8
+ */
9
+
10
+ /* =============================================================================
11
+ Tree Container
12
+ ============================================================================= */
13
+
14
+ [data-tree] {
15
+ display: flex;
16
+ flex-direction: column;
17
+ }
18
+
19
+ /* =============================================================================
20
+ Tree Node
21
+ ============================================================================= */
22
+
23
+ [data-tree-node] {
24
+ display: flex;
25
+ flex-direction: column;
4
26
  }
5
- rk-nested-list rk-node > div {
6
- @apply h-8 px-2;
27
+
28
+ [data-tree-node]:focus {
29
+ outline: none;
7
30
  }
8
31
 
9
- rk-nested-list rk-node {
10
- @apply flex flex-col;
32
+ [data-tree-node-row] {
33
+ display: flex;
34
+ align-items: stretch;
11
35
  }
12
36
 
13
- rk-node > div > rk-item {
14
- @apply px-1;
37
+ /* =============================================================================
38
+ Tree Toggle Button (Expand/Collapse)
39
+ ============================================================================= */
40
+
41
+ [data-tree-toggle-btn] {
42
+ display: flex;
43
+ align-items: center;
44
+ justify-content: center;
45
+ flex-shrink: 0;
46
+ align-self: center;
47
+ padding: 0;
48
+ border: none;
49
+ background: transparent;
50
+ cursor: pointer;
51
+ border-radius: 0.25rem;
52
+ transition: background-color 150ms ease;
15
53
  }
16
- rk-node > div > span {
17
- @apply flex-shrink-0;
54
+
55
+ /* Size variants for toggle */
56
+ [data-tree][data-size='sm'] [data-tree-toggle-btn] {
57
+ width: 1rem;
58
+ height: 1rem;
59
+ }
60
+
61
+ [data-tree][data-size='md'] [data-tree-toggle-btn],
62
+ [data-tree]:not([data-size]) [data-tree-toggle-btn] {
63
+ width: 1.25rem;
64
+ height: 1.25rem;
65
+ }
66
+
67
+ [data-tree][data-size='lg'] [data-tree-toggle-btn] {
68
+ width: 1.5rem;
69
+ height: 1.5rem;
70
+ }
71
+
72
+ /* Toggle icon container */
73
+ [data-tree-toggle] {
74
+ display: flex;
75
+ align-items: center;
76
+ justify-content: center;
77
+ width: 100%;
78
+ height: 100%;
79
+ }
80
+
81
+ [data-tree-toggle]:not([data-tree-has-children]) {
82
+ /* Leaf node - no toggle needed */
83
+ visibility: hidden;
84
+ }
85
+
86
+ /* =============================================================================
87
+ Tree Indent (when showLines=false)
88
+ ============================================================================= */
89
+
90
+ [data-tree-indent] {
91
+ flex-shrink: 0;
92
+ align-self: stretch;
93
+ }
94
+
95
+ /* =============================================================================
96
+ Tree Item Content
97
+ ============================================================================= */
98
+
99
+ [data-tree-item-content] {
100
+ display: flex;
101
+ align-items: center;
102
+ align-self: center;
103
+ flex: 1;
104
+ min-width: 0;
105
+ padding: 0.25rem 0.375rem;
106
+ border: none;
107
+ background: transparent;
108
+ text-align: left;
109
+ cursor: pointer;
110
+ border-radius: 0.25rem;
111
+ font: inherit;
112
+ color: inherit;
113
+ transition:
114
+ background-color 150ms ease,
115
+ color 150ms ease;
116
+ }
117
+
118
+ /* Size variants for item content */
119
+ [data-tree][data-size='sm'] [data-tree-item-content] {
120
+ gap: 0.375rem;
121
+ font-size: 0.75rem;
122
+ }
123
+
124
+ [data-tree][data-size='md'] [data-tree-item-content],
125
+ [data-tree]:not([data-size]) [data-tree-item-content] {
126
+ gap: 0.5rem;
127
+ font-size: 0.875rem;
128
+ }
129
+
130
+ [data-tree][data-size='lg'] [data-tree-item-content] {
131
+ gap: 0.625rem;
132
+ font-size: 1rem;
133
+ }
134
+
135
+ /* Item elements use shared [data-item-*] from item.css */
136
+
137
+ /* =============================================================================
138
+ Loading Spinner
139
+ ============================================================================= */
140
+
141
+ [data-tree-spinner] {
142
+ width: 1em;
143
+ height: 1em;
144
+ border: 2px solid currentColor;
145
+ border-right-color: transparent;
146
+ border-radius: 50%;
147
+ animation: tree-spin 0.6s linear infinite;
148
+ flex-shrink: 0;
149
+ }
150
+
151
+ @keyframes tree-spin {
152
+ to {
153
+ transform: rotate(360deg);
154
+ }
155
+ }
156
+
157
+ /* =============================================================================
158
+ Multi-selection
159
+ ============================================================================= */
160
+
161
+ [data-tree][data-multiselect='true'] [data-tree-item-content] {
162
+ user-select: none;
18
163
  }
@@ -0,0 +1,152 @@
1
+ /**
2
+ * Button - Glass Theme Styles
3
+ *
4
+ * Glassmorphism styling with blur and transparency.
5
+ */
6
+
7
+ /* =============================================================================
8
+ Default Style (filled)
9
+ ============================================================================= */
10
+
11
+ [data-style='glass'] [data-button][data-style='default'][data-variant='default'],
12
+ [data-style='glass'] [data-button]:not([data-style])[data-variant='default'],
13
+ [data-style='glass'] [data-button][data-style='default']:not([data-variant]),
14
+ [data-style='glass'] [data-button]:not([data-style]):not([data-variant]) {
15
+ @apply backdrop-blur-md border shadow-sm bg-surface-z2/70 border-surface-z5/20 text-surface-z9;
16
+ }
17
+
18
+ [data-style='glass'] [data-button][data-style='default'][data-variant='primary'],
19
+ [data-style='glass'] [data-button]:not([data-style])[data-variant='primary'] {
20
+ @apply backdrop-blur-md shadow-sm bg-primary-z5/80 text-on-primary;
21
+ }
22
+
23
+ [data-style='glass'] [data-button][data-style='default'][data-variant='secondary'],
24
+ [data-style='glass'] [data-button]:not([data-style])[data-variant='secondary'] {
25
+ @apply backdrop-blur-md shadow-sm bg-secondary-z4/80 text-on-secondary;
26
+ }
27
+
28
+ [data-style='glass'] [data-button][data-style='default'][data-variant='danger'],
29
+ [data-style='glass'] [data-button]:not([data-style])[data-variant='danger'] {
30
+ @apply backdrop-blur-md shadow-sm bg-danger-z4/80 text-on-danger;
31
+ }
32
+
33
+ /* =============================================================================
34
+ Outline Style
35
+ ============================================================================= */
36
+
37
+ [data-style='glass'] [data-button][data-style='outline'][data-variant='default'],
38
+ [data-style='glass'] [data-button][data-style='outline']:not([data-variant]) {
39
+ @apply border-surface-z5/30 text-surface-z8 border bg-transparent;
40
+ }
41
+
42
+ [data-style='glass'] [data-button][data-style='outline'][data-variant='primary'] {
43
+ @apply border-primary-z4/40 text-primary-z6 border bg-transparent;
44
+ }
45
+
46
+ [data-style='glass'] [data-button][data-style='outline'][data-variant='secondary'] {
47
+ @apply border-secondary-z4/40 text-secondary-z6 border bg-transparent;
48
+ }
49
+
50
+ [data-style='glass'] [data-button][data-style='outline'][data-variant='danger'] {
51
+ @apply border-danger-z4/40 text-danger-z4 border bg-transparent;
52
+ }
53
+
54
+ /* =============================================================================
55
+ Ghost Style
56
+ ============================================================================= */
57
+
58
+ [data-style='glass'] [data-button][data-style='ghost'] {
59
+ @apply border-transparent bg-transparent;
60
+ }
61
+
62
+ [data-style='glass'] [data-button][data-style='ghost'][data-variant='default'],
63
+ [data-style='glass'] [data-button][data-style='ghost']:not([data-variant]) {
64
+ @apply text-surface-z8;
65
+ }
66
+
67
+ [data-style='glass'] [data-button][data-style='ghost'][data-variant='primary'] {
68
+ @apply text-primary-z6;
69
+ }
70
+
71
+ [data-style='glass'] [data-button][data-style='ghost'][data-variant='secondary'] {
72
+ @apply text-secondary-z6;
73
+ }
74
+
75
+ [data-style='glass'] [data-button][data-style='ghost'][data-variant='danger'] {
76
+ @apply text-danger-z4;
77
+ }
78
+
79
+ /* =============================================================================
80
+ Gradient Style
81
+ ============================================================================= */
82
+
83
+ [data-style='glass'] [data-button][data-style='gradient'][data-variant='default'],
84
+ [data-style='glass'] [data-button][data-style='gradient']:not([data-variant]) {
85
+ @apply from-surface-z3/80 to-surface-z1/60 text-surface-z10 backdrop-blur-md bg-gradient-to-br;
86
+ }
87
+
88
+ [data-style='glass'] [data-button][data-style='gradient'][data-variant='primary'] {
89
+ @apply from-primary-z5/80 to-primary-z3/60 text-on-primary backdrop-blur-md bg-gradient-to-br;
90
+ }
91
+
92
+ [data-style='glass'] [data-button][data-style='gradient'][data-variant='secondary'] {
93
+ @apply from-secondary-z5/80 to-secondary-z3/60 text-on-secondary backdrop-blur-md bg-gradient-to-br;
94
+ }
95
+
96
+ [data-style='glass'] [data-button][data-style='gradient'][data-variant='danger'] {
97
+ @apply from-danger-z5/80 to-danger-z3/60 text-on-danger backdrop-blur-md bg-gradient-to-br;
98
+ }
99
+
100
+ [data-style='glass'] [data-button][data-style='gradient']:hover:not(:disabled):not([data-disabled]) {
101
+ filter: brightness(1.1);
102
+ }
103
+
104
+ /* =============================================================================
105
+ Link Style
106
+ ============================================================================= */
107
+
108
+ [data-style='glass'] [data-button][data-style='link'][data-variant='default'],
109
+ [data-style='glass'] [data-button][data-style='link']:not([data-variant]) {
110
+ @apply text-surface-z8;
111
+ }
112
+
113
+ [data-style='glass'] [data-button][data-style='link'][data-variant='primary'] {
114
+ @apply text-primary-z6;
115
+ }
116
+
117
+ [data-style='glass'] [data-button][data-style='link'][data-variant='secondary'] {
118
+ @apply text-secondary-z6;
119
+ }
120
+
121
+ [data-style='glass'] [data-button][data-style='link'][data-variant='danger'] {
122
+ @apply text-danger-z4;
123
+ }
124
+
125
+ [data-style='glass'] [data-button][data-style='link']:hover:not(:disabled):not([data-disabled]) {
126
+ @apply text-primary-z7;
127
+ }
128
+
129
+ /* =============================================================================
130
+ Hover States
131
+ ============================================================================= */
132
+
133
+ [data-style='glass'] [data-button][data-style='default']:hover:not(:disabled):not([data-disabled]),
134
+ [data-style='glass'] [data-button]:not([data-style]):hover:not(:disabled):not([data-disabled]) {
135
+ @apply shadow-md;
136
+ }
137
+
138
+ [data-style='glass'] [data-button][data-style='outline']:hover:not(:disabled):not([data-disabled]) {
139
+ @apply bg-surface-z2/40;
140
+ }
141
+
142
+ [data-style='glass'] [data-button][data-style='ghost']:hover:not(:disabled):not([data-disabled]) {
143
+ @apply bg-surface-z2/30;
144
+ }
145
+
146
+ /* =============================================================================
147
+ Focus
148
+ ============================================================================= */
149
+
150
+ [data-style='glass'] [data-button]:focus-visible {
151
+ @apply outline-none ring-2 ring-surface-z5/40;
152
+ }