@rokkit/themes 1.1.16 → 1.1.18

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 (297) hide show
  1. package/build.mjs +29 -1
  2. package/dist/base/alert-list.css +91 -0
  3. package/dist/base/avatar.css +82 -0
  4. package/dist/base/badge.css +41 -0
  5. package/dist/base/breadcrumbs.css +47 -0
  6. package/dist/base/button.css +254 -0
  7. package/dist/base/card.css +39 -0
  8. package/dist/base/carousel.css +128 -0
  9. package/dist/base/chart.css +94 -0
  10. package/dist/base/code-block.css +76 -0
  11. package/dist/base/command-palette.css +35 -0
  12. package/dist/base/connector.css +92 -0
  13. package/dist/base/density.css +60 -0
  14. package/dist/base/display.css +99 -0
  15. package/dist/base/divider.css +49 -0
  16. package/dist/base/dropdown.css +167 -0
  17. package/dist/base/floating-action.css +388 -0
  18. package/dist/base/floating-navigation.css +405 -0
  19. package/dist/base/frame.css +36 -0
  20. package/dist/base/gradient-border.css +32 -0
  21. package/dist/base/graph-paper.css +83 -0
  22. package/dist/base/grid.css +93 -0
  23. package/dist/base/input.css +342 -0
  24. package/dist/base/item.css +91 -0
  25. package/dist/base/layout.css +17 -0
  26. package/dist/base/list.css +188 -0
  27. package/dist/base/menu.css +277 -0
  28. package/dist/base/message.css +62 -0
  29. package/dist/base/nav-content.css +48 -0
  30. package/dist/base/palette-manager.css +244 -0
  31. package/dist/base/pill.css +61 -0
  32. package/dist/base/progress.css +34 -0
  33. package/dist/base/radius.css +41 -0
  34. package/dist/base/range.css +122 -0
  35. package/dist/base/rating.css +42 -0
  36. package/dist/base/responsive-grid.css +8 -0
  37. package/dist/base/reveal.css +37 -0
  38. package/dist/base/search-filter.css +132 -0
  39. package/dist/base/select.css +413 -0
  40. package/dist/base/shine.css +14 -0
  41. package/dist/base/stack.css +76 -0
  42. package/dist/base/status-list.css +19 -0
  43. package/dist/base/step-indicator.css +74 -0
  44. package/dist/base/stepper.css +154 -0
  45. package/dist/base/swatch.css +85 -0
  46. package/dist/base/switch.css +168 -0
  47. package/dist/base/table.css +313 -0
  48. package/dist/base/tabs.css +184 -0
  49. package/dist/base/tilt.css +14 -0
  50. package/dist/base/timeline.css +84 -0
  51. package/dist/base/toc.css +50 -0
  52. package/dist/base/toggle.css +190 -0
  53. package/dist/base/toolbar.css +341 -0
  54. package/dist/base/tooltip.css +64 -0
  55. package/dist/base/tree.css +235 -0
  56. package/dist/base/typography.css +50 -0
  57. package/dist/base/upload-progress.css +155 -0
  58. package/dist/base/upload-target.css +77 -0
  59. package/dist/base.css +20 -6
  60. package/dist/frosted/button.css +228 -0
  61. package/dist/frosted/card.css +128 -0
  62. package/dist/frosted/chart.css +38 -0
  63. package/dist/frosted/code-block.css +33 -0
  64. package/dist/frosted/command-palette.css +43 -0
  65. package/dist/frosted/dropdown.css +64 -0
  66. package/dist/frosted/floating-action.css +66 -0
  67. package/dist/frosted/floating-navigation.css +78 -0
  68. package/dist/frosted/frame.css +17 -0
  69. package/dist/frosted/grid.css +26 -0
  70. package/dist/frosted/input.css +135 -0
  71. package/dist/frosted/list.css +153 -0
  72. package/dist/frosted/menu.css +107 -0
  73. package/dist/frosted/message.css +39 -0
  74. package/dist/frosted/palette-manager.css +97 -0
  75. package/dist/frosted/pill.css +17 -0
  76. package/dist/frosted/progress.css +13 -0
  77. package/dist/frosted/range.css +64 -0
  78. package/dist/frosted/rating.css +13 -0
  79. package/dist/frosted/search-filter.css +53 -0
  80. package/dist/frosted/select.css +192 -0
  81. package/dist/frosted/status-list.css +67 -0
  82. package/dist/frosted/step-indicator.css +43 -0
  83. package/dist/frosted/swatch.css +21 -0
  84. package/dist/frosted/switch.css +43 -0
  85. package/dist/frosted/table.css +122 -0
  86. package/dist/frosted/tabs.css +61 -0
  87. package/dist/frosted/timeline.css +46 -0
  88. package/dist/frosted/toc.css +19 -0
  89. package/dist/frosted/toggle.css +77 -0
  90. package/dist/frosted/toolbar.css +92 -0
  91. package/dist/frosted/tooltip.css +7 -0
  92. package/dist/frosted/tree.css +126 -0
  93. package/dist/frosted.css +72 -53
  94. package/dist/index.css +446 -307
  95. package/dist/material/button.css +182 -0
  96. package/dist/material/card.css +99 -0
  97. package/dist/material/chart.css +38 -0
  98. package/dist/material/code-block.css +33 -0
  99. package/dist/material/command-palette.css +37 -0
  100. package/dist/material/dropdown.css +50 -0
  101. package/dist/material/floating-action.css +64 -0
  102. package/dist/material/floating-navigation.css +74 -0
  103. package/dist/material/frame.css +17 -0
  104. package/dist/material/grid.css +26 -0
  105. package/dist/material/input.css +164 -0
  106. package/dist/material/list.css +140 -0
  107. package/dist/material/menu.css +92 -0
  108. package/dist/material/message.css +35 -0
  109. package/dist/material/palette-manager.css +97 -0
  110. package/dist/material/pill.css +17 -0
  111. package/dist/material/progress.css +13 -0
  112. package/dist/material/range.css +62 -0
  113. package/dist/material/rating.css +13 -0
  114. package/dist/material/search-filter.css +49 -0
  115. package/dist/material/select.css +177 -0
  116. package/dist/material/status-list.css +66 -0
  117. package/dist/material/step-indicator.css +40 -0
  118. package/dist/material/swatch.css +21 -0
  119. package/dist/material/switch.css +28 -0
  120. package/dist/material/table.css +120 -0
  121. package/dist/material/tabs.css +89 -0
  122. package/dist/material/timeline.css +46 -0
  123. package/dist/material/toc.css +18 -0
  124. package/dist/material/toggle.css +75 -0
  125. package/dist/material/toolbar.css +85 -0
  126. package/dist/material/tooltip.css +7 -0
  127. package/dist/material/tree.css +145 -0
  128. package/dist/material.css +68 -50
  129. package/dist/minimal/button.css +180 -0
  130. package/dist/minimal/card.css +99 -0
  131. package/dist/minimal/chart.css +38 -0
  132. package/dist/minimal/code-block.css +33 -0
  133. package/dist/minimal/command-palette.css +37 -0
  134. package/dist/minimal/dropdown.css +50 -0
  135. package/dist/minimal/floating-action.css +63 -0
  136. package/dist/minimal/floating-navigation.css +70 -0
  137. package/dist/minimal/frame.css +17 -0
  138. package/dist/minimal/grid.css +26 -0
  139. package/dist/minimal/input.css +171 -0
  140. package/dist/minimal/list.css +168 -0
  141. package/dist/minimal/menu.css +88 -0
  142. package/dist/minimal/message.css +35 -0
  143. package/dist/minimal/palette-manager.css +97 -0
  144. package/dist/minimal/pill.css +17 -0
  145. package/dist/minimal/progress.css +13 -0
  146. package/dist/minimal/range.css +61 -0
  147. package/dist/minimal/rating.css +13 -0
  148. package/dist/minimal/search-filter.css +49 -0
  149. package/dist/minimal/select.css +158 -0
  150. package/dist/minimal/status-list.css +66 -0
  151. package/dist/minimal/step-indicator.css +40 -0
  152. package/dist/minimal/swatch.css +21 -0
  153. package/dist/minimal/switch.css +32 -0
  154. package/dist/minimal/table.css +118 -0
  155. package/dist/minimal/tabs.css +151 -0
  156. package/dist/minimal/timeline.css +45 -0
  157. package/dist/minimal/toc.css +18 -0
  158. package/dist/minimal/toggle.css +74 -0
  159. package/dist/minimal/toolbar.css +85 -0
  160. package/dist/minimal/tooltip.css +7 -0
  161. package/dist/minimal/tree.css +152 -0
  162. package/dist/minimal.css +73 -58
  163. package/dist/rokkit/avatar.css +29 -0
  164. package/dist/rokkit/badge.css +29 -0
  165. package/dist/rokkit/button.css +308 -0
  166. package/dist/rokkit/card.css +102 -0
  167. package/dist/rokkit/chart.css +38 -0
  168. package/dist/rokkit/code-block.css +33 -0
  169. package/dist/rokkit/command-palette.css +37 -0
  170. package/dist/rokkit/connector.css +11 -0
  171. package/dist/rokkit/divider.css +26 -0
  172. package/dist/rokkit/dropdown.css +70 -0
  173. package/dist/rokkit/floating-action.css +65 -0
  174. package/dist/rokkit/floating-navigation.css +83 -0
  175. package/dist/rokkit/frame.css +17 -0
  176. package/dist/rokkit/grid.css +46 -0
  177. package/dist/rokkit/input.css +134 -0
  178. package/dist/rokkit/list.css +202 -0
  179. package/dist/rokkit/menu.css +93 -0
  180. package/dist/rokkit/message.css +44 -0
  181. package/dist/rokkit/palette-manager.css +97 -0
  182. package/dist/rokkit/pill.css +17 -0
  183. package/dist/rokkit/progress.css +13 -0
  184. package/dist/rokkit/range.css +62 -0
  185. package/dist/rokkit/rating.css +13 -0
  186. package/dist/rokkit/search-filter.css +49 -0
  187. package/dist/rokkit/select.css +201 -0
  188. package/dist/rokkit/status-list.css +68 -0
  189. package/dist/rokkit/step-indicator.css +40 -0
  190. package/dist/rokkit/swatch.css +20 -0
  191. package/dist/rokkit/switch.css +29 -0
  192. package/dist/rokkit/table.css +118 -0
  193. package/dist/rokkit/tabs.css +114 -0
  194. package/dist/rokkit/timeline.css +46 -0
  195. package/dist/rokkit/toc.css +18 -0
  196. package/dist/rokkit/toggle.css +85 -0
  197. package/dist/rokkit/toolbar.css +90 -0
  198. package/dist/rokkit/tooltip.css +7 -0
  199. package/dist/rokkit/tree.css +160 -0
  200. package/dist/rokkit/upload-progress.css +102 -0
  201. package/dist/rokkit/upload-target.css +50 -0
  202. package/dist/rokkit.css +89 -66
  203. package/dist/zen-sumi/button.css +184 -0
  204. package/dist/zen-sumi/card.css +104 -0
  205. package/dist/zen-sumi/chart.css +41 -0
  206. package/dist/zen-sumi/code-block.css +35 -0
  207. package/dist/zen-sumi/command-palette.css +39 -0
  208. package/dist/zen-sumi/divider.css +29 -0
  209. package/dist/zen-sumi/dropdown.css +53 -0
  210. package/dist/zen-sumi/floating-action.css +68 -0
  211. package/dist/zen-sumi/floating-navigation.css +74 -0
  212. package/dist/zen-sumi/frame.css +20 -0
  213. package/dist/zen-sumi/grid.css +26 -0
  214. package/dist/zen-sumi/input.css +171 -0
  215. package/dist/zen-sumi/list.css +128 -0
  216. package/dist/zen-sumi/menu.css +91 -0
  217. package/dist/zen-sumi/message.css +37 -0
  218. package/dist/zen-sumi/palette-manager.css +97 -0
  219. package/dist/zen-sumi/pill.css +17 -0
  220. package/dist/zen-sumi/progress.css +13 -0
  221. package/dist/zen-sumi/range.css +62 -0
  222. package/dist/zen-sumi/rating.css +13 -0
  223. package/dist/zen-sumi/search-filter.css +49 -0
  224. package/dist/zen-sumi/select.css +160 -0
  225. package/dist/zen-sumi/status-list.css +66 -0
  226. package/dist/zen-sumi/step-indicator.css +40 -0
  227. package/dist/zen-sumi/swatch.css +21 -0
  228. package/dist/zen-sumi/switch.css +34 -0
  229. package/dist/zen-sumi/table.css +128 -0
  230. package/dist/zen-sumi/tabs.css +78 -0
  231. package/dist/zen-sumi/timeline.css +46 -0
  232. package/dist/zen-sumi/toc.css +22 -0
  233. package/dist/zen-sumi/toggle.css +86 -0
  234. package/dist/zen-sumi/toolbar.css +86 -0
  235. package/dist/zen-sumi/tooltip.css +7 -0
  236. package/dist/zen-sumi/tree.css +148 -0
  237. package/dist/zen-sumi.css +124 -74
  238. package/package.json +15 -15
  239. package/src/base/stepper.css +11 -5
  240. package/src/base/table.css +4 -1
  241. package/src/base/toggle.css +5 -0
  242. package/src/frosted/button.css +9 -1
  243. package/src/frosted/dropdown.css +2 -2
  244. package/src/frosted/list.css +5 -5
  245. package/src/frosted/menu.css +5 -5
  246. package/src/frosted/message.css +4 -4
  247. package/src/frosted/select.css +8 -8
  248. package/src/frosted/table.css +5 -5
  249. package/src/frosted/tabs.css +2 -2
  250. package/src/frosted/timeline.css +1 -1
  251. package/src/frosted/toggle.css +4 -4
  252. package/src/frosted/tree.css +15 -4
  253. package/src/material/button.css +8 -4
  254. package/src/material/dropdown.css +2 -2
  255. package/src/material/list.css +5 -5
  256. package/src/material/menu.css +5 -5
  257. package/src/material/select.css +8 -8
  258. package/src/material/table.css +5 -5
  259. package/src/material/tabs.css +4 -3
  260. package/src/material/timeline.css +4 -3
  261. package/src/material/toggle.css +6 -5
  262. package/src/material/tree.css +15 -4
  263. package/src/minimal/button.css +8 -4
  264. package/src/minimal/dropdown.css +2 -2
  265. package/src/minimal/list.css +8 -8
  266. package/src/minimal/menu.css +6 -6
  267. package/src/minimal/select.css +8 -8
  268. package/src/minimal/table.css +5 -5
  269. package/src/minimal/tabs.css +2 -2
  270. package/src/minimal/timeline.css +3 -3
  271. package/src/minimal/toggle.css +4 -4
  272. package/src/minimal/tree.css +17 -6
  273. package/src/rokkit/avatar.css +1 -1
  274. package/src/rokkit/badge.css +1 -1
  275. package/src/rokkit/button.css +1 -1
  276. package/src/rokkit/divider.css +1 -1
  277. package/src/rokkit/dropdown.css +2 -2
  278. package/src/rokkit/list.css +5 -5
  279. package/src/rokkit/menu.css +5 -5
  280. package/src/rokkit/select.css +24 -13
  281. package/src/rokkit/table.css +5 -5
  282. package/src/rokkit/tabs.css +1 -1
  283. package/src/rokkit/timeline.css +4 -3
  284. package/src/rokkit/toggle.css +4 -4
  285. package/src/rokkit/tree.css +17 -6
  286. package/src/zen-sumi/button.css +16 -8
  287. package/src/zen-sumi/divider.css +29 -0
  288. package/src/zen-sumi/dropdown.css +4 -4
  289. package/src/zen-sumi/index.css +1 -0
  290. package/src/zen-sumi/list.css +9 -9
  291. package/src/zen-sumi/menu.css +9 -9
  292. package/src/zen-sumi/select.css +11 -11
  293. package/src/zen-sumi/table.css +6 -6
  294. package/src/zen-sumi/tabs.css +3 -3
  295. package/src/zen-sumi/timeline.css +3 -3
  296. package/src/zen-sumi/toggle.css +6 -5
  297. package/src/zen-sumi/tree.css +19 -8
@@ -0,0 +1,155 @@
1
+ /**
2
+ * UploadProgress - Base Structural Styles
3
+ *
4
+ * Layout: header flex, file row layout, progress bar track, action positioning.
5
+ * No colors or visual theming - those belong in theme styles.
6
+ */
7
+
8
+ /* =============================================================================
9
+ Container
10
+ ============================================================================= */
11
+
12
+ [data-upload-progress] {
13
+ display: flex;
14
+ flex-direction: column;
15
+ gap: 0.25rem;
16
+ }
17
+
18
+ /* =============================================================================
19
+ Header
20
+ ============================================================================= */
21
+
22
+ [data-upload-header] {
23
+ display: flex;
24
+ align-items: center;
25
+ justify-content: space-between;
26
+ gap: 0.75rem;
27
+ padding: 0.5rem 0.75rem;
28
+ font-size: 0.875rem;
29
+ font-weight: 500;
30
+ }
31
+
32
+ [data-upload-clear] {
33
+ padding: 0.25rem 0.5rem;
34
+ border-radius: 0.25rem;
35
+ font-size: 0.75rem;
36
+ cursor: pointer;
37
+ border: 1px solid currentColor;
38
+ background: transparent;
39
+ transition:
40
+ background-color 150ms ease,
41
+ color 150ms ease;
42
+ }
43
+
44
+ /* =============================================================================
45
+ File Status
46
+ ============================================================================= */
47
+
48
+ [data-upload-file-status] {
49
+ display: flex;
50
+ align-items: center;
51
+ gap: 0.75rem;
52
+ padding: 0.375rem 0.75rem;
53
+ font-size: 0.875rem;
54
+ transition: background-color 150ms ease;
55
+ }
56
+
57
+ /* =============================================================================
58
+ File Elements
59
+ ============================================================================= */
60
+
61
+ [data-upload-file-icon] {
62
+ flex-shrink: 0;
63
+ font-size: 1.25rem;
64
+ }
65
+
66
+ [data-upload-file-name] {
67
+ flex: 1;
68
+ min-width: 0;
69
+ overflow: hidden;
70
+ text-overflow: ellipsis;
71
+ white-space: nowrap;
72
+ }
73
+
74
+ [data-upload-file-size] {
75
+ flex-shrink: 0;
76
+ font-size: 0.75rem;
77
+ white-space: nowrap;
78
+ }
79
+
80
+ /* =============================================================================
81
+ Progress Bar
82
+ ============================================================================= */
83
+
84
+ [data-upload-bar] {
85
+ position: relative;
86
+ width: 6rem;
87
+ height: 0.375rem;
88
+ border-radius: 9999px;
89
+ overflow: hidden;
90
+ flex-shrink: 0;
91
+ }
92
+
93
+ [data-upload-fill] {
94
+ height: 100%;
95
+ border-radius: 9999px;
96
+ transition: width 0.3s ease;
97
+ }
98
+
99
+ /* =============================================================================
100
+ Status Badge
101
+ ============================================================================= */
102
+
103
+ [data-upload-status] {
104
+ flex-shrink: 0;
105
+ font-size: 0.75rem;
106
+ font-weight: 500;
107
+ text-transform: capitalize;
108
+ }
109
+
110
+ /* =============================================================================
111
+ Action Buttons
112
+ ============================================================================= */
113
+
114
+ [data-upload-actions] {
115
+ display: flex;
116
+ gap: 0.25rem;
117
+ flex-shrink: 0;
118
+ }
119
+
120
+ [data-upload-actions] button {
121
+ display: inline-flex;
122
+ align-items: center;
123
+ justify-content: center;
124
+ width: 1.5rem;
125
+ height: 1.5rem;
126
+ padding: 0;
127
+ border: none;
128
+ border-radius: 0.25rem;
129
+ cursor: pointer;
130
+ background: transparent;
131
+ font-size: 0.875rem;
132
+ transition:
133
+ background-color 150ms ease,
134
+ color 150ms ease;
135
+ }
136
+
137
+ /* =============================================================================
138
+ Grid View Tiles
139
+ ============================================================================= */
140
+
141
+ [data-grid] [data-upload-file-status] {
142
+ flex-direction: column;
143
+ align-items: center;
144
+ text-align: center;
145
+ padding: 1rem;
146
+ gap: 0.5rem;
147
+ }
148
+
149
+ [data-grid] [data-upload-file-status] [data-upload-file-icon] {
150
+ font-size: 2rem;
151
+ }
152
+
153
+ [data-grid] [data-upload-file-status] [data-upload-bar] {
154
+ width: 100%;
155
+ }
@@ -0,0 +1,77 @@
1
+ /**
2
+ * UploadTarget - Base Structural Styles
3
+ *
4
+ * Layout: flex centering, dashed border, sizing, transitions.
5
+ * No colors or visual theming - those belong in theme styles.
6
+ */
7
+
8
+ /* =============================================================================
9
+ Drop Zone Container
10
+ ============================================================================= */
11
+
12
+ [data-upload-target] {
13
+ display: flex;
14
+ flex-direction: column;
15
+ align-items: center;
16
+ justify-content: center;
17
+ gap: 0.75rem;
18
+ min-height: 10rem;
19
+ padding: 2rem;
20
+ border: 2px dashed currentColor;
21
+ border-radius: 0.5rem;
22
+ cursor: pointer;
23
+ transition:
24
+ border-color 150ms ease,
25
+ background-color 150ms ease;
26
+ user-select: none;
27
+ }
28
+
29
+ [data-upload-target][data-size='small'] {
30
+ min-height: 4rem;
31
+ padding: 0.75rem;
32
+ gap: 0;
33
+ }
34
+
35
+ [data-upload-target][data-size='small'] [data-upload-icon] {
36
+ font-size: 1.25rem;
37
+ }
38
+
39
+ [data-upload-target]:focus {
40
+ outline: none;
41
+ }
42
+
43
+ [data-upload-target][data-disabled] {
44
+ pointer-events: none;
45
+ opacity: 0.5;
46
+ cursor: not-allowed;
47
+ }
48
+
49
+ /* =============================================================================
50
+ Upload Icon
51
+ ============================================================================= */
52
+
53
+ [data-upload-target] [data-upload-icon] {
54
+ font-size: 2rem;
55
+ }
56
+
57
+ /* =============================================================================
58
+ Browse Button
59
+ ============================================================================= */
60
+
61
+ [data-upload-target] [data-upload-button] {
62
+ padding: 0.375rem 0.75rem;
63
+ border-radius: 0.375rem;
64
+ font-size: 0.875rem;
65
+ font-weight: 500;
66
+ cursor: pointer;
67
+ border: 1px solid currentColor;
68
+ background: transparent;
69
+ transition:
70
+ background-color 150ms ease,
71
+ color 150ms ease;
72
+ }
73
+
74
+ [data-upload-target] [data-upload-button]:disabled {
75
+ pointer-events: none;
76
+ opacity: 0.5;
77
+ }
package/dist/base.css CHANGED
@@ -2279,8 +2279,11 @@
2279
2279
  padding-inline: 0.375rem;
2280
2280
  }
2281
2281
 
2282
+ /* Icon-only options are square — min-width matches the height (same treatment
2283
+ the `button` variant gets), so a lone icon sits in a square, not a portrait box. */
2282
2284
  [data-toggle][data-toggle-size='sm']:not([data-toggle-labels='true']) [data-toggle-option] {
2283
2285
  padding-inline: 0.25rem;
2286
+ min-width: var(--control-h-sm);
2284
2287
  }
2285
2288
 
2286
2289
  [data-toggle][data-toggle-size='sm'] [data-toggle-icon] {
@@ -2303,6 +2306,7 @@
2303
2306
  [data-toggle][data-toggle-size='md']:not([data-toggle-labels='true']) [data-toggle-option],
2304
2307
  [data-toggle]:not([data-toggle-size]):not([data-toggle-labels='true']) [data-toggle-option] {
2305
2308
  padding-inline: 0.375rem;
2309
+ min-width: var(--control-h-md);
2306
2310
  }
2307
2311
 
2308
2312
  [data-toggle][data-toggle-size='md'] [data-toggle-icon],
@@ -2323,6 +2327,7 @@
2323
2327
 
2324
2328
  [data-toggle][data-toggle-size='lg']:not([data-toggle-labels='true']) [data-toggle-option] {
2325
2329
  padding-inline: 0.5rem;
2330
+ min-width: var(--control-h-lg);
2326
2331
  }
2327
2332
 
2328
2333
  [data-toggle][data-toggle-size='lg'] [data-toggle-icon] {
@@ -4289,9 +4294,10 @@ a[data-card] {
4289
4294
  }
4290
4295
 
4291
4296
  [data-stepper-step][data-completed] [data-stepper-circle] {
4297
+ /* solid brand fill + on-primary text (dark, reads on the bright 500). */
4292
4298
  background-color: var(--primary);
4293
4299
  border-color: var(--primary);
4294
- color: var(--paper);
4300
+ color: var(--on-primary);
4295
4301
  }
4296
4302
 
4297
4303
  /* Check glyph inside a completed circle follows the circle's color
@@ -4302,7 +4308,9 @@ a[data-card] {
4302
4308
 
4303
4309
  [data-stepper-step][data-active] [data-stepper-circle] {
4304
4310
  border-color: var(--primary);
4305
- color: var(--primary);
4311
+ /* ink number (not saffron) so it reads on the page; the saffron border + ring
4312
+ keep the active accent */
4313
+ color: var(--ink);
4306
4314
  --un-ring-width:3px;--un-ring-offset-shadow:var(--un-ring-inset) 0 0 0 var(--un-ring-offset-width) var(--un-ring-offset-color);--un-ring-shadow:var(--un-ring-inset) 0 0 0 calc(var(--un-ring-width) + var(--un-ring-offset-width)) var(--un-ring-color);box-shadow:var(--un-ring-offset-shadow), var(--un-ring-shadow), var(--un-shadow);--un-ring-color:color-mix(in srgb, var(--color-primary) calc(0.2 * 100%), transparent);
4307
4315
  }
4308
4316
 
@@ -4313,9 +4321,12 @@ a[data-card] {
4313
4321
  flex: 1;
4314
4322
  height: 2px;
4315
4323
  min-width: 2rem;
4316
- align-self: center;
4317
- /* Vertically center with the circle (half of 2.5rem) */
4318
- margin-top: 1.25rem;
4324
+ /* Align to the circle's vertical center, NOT the full step height. The step
4325
+ is `circle + label below`, so `align-self: center` drops the line into the
4326
+ label gap (reads as bottom-aligned). Pin to the top and offset by the
4327
+ circle's radius (1.25rem) minus half the line height. */
4328
+ align-self: flex-start;
4329
+ margin-top: calc(1.25rem - 1px);
4319
4330
  transition: background-color 0.2s ease;
4320
4331
  }
4321
4332
 
@@ -4626,7 +4637,10 @@ a[data-card] {
4626
4637
  display: inline-block;
4627
4638
  vertical-align: middle;
4628
4639
  margin-left: 0.25rem;
4629
- opacity: 0.4;
4640
+ /* Unsorted hint — visible enough to read as "sortable" against a tinted
4641
+ header, but still clearly secondary to the active (sorted) state below.
4642
+ 0.4 was too faint (the glyph all but vanished on dark headers). */
4643
+ opacity: 0.65;
4630
4644
  transition: opacity 150ms ease;
4631
4645
  }
4632
4646
 
@@ -0,0 +1,228 @@
1
+ /**
2
+ * Button - Frosted Glass Theme Styles
3
+ *
4
+ * Liquid frosted glass: translucent surfaces, specular border highlights,
5
+ * inset top-edge shine. Similar to Apple liquid glass but more opaque.
6
+ */
7
+
8
+ /* =============================================================================
9
+ Default Style (filled)
10
+ ============================================================================= */
11
+
12
+ [data-style='frosted'] [data-button][data-style='default'][data-variant='default'],
13
+ [data-style='frosted'] [data-button]:not([data-style])[data-variant='default'],
14
+ [data-style='frosted'] [data-button][data-style='default']:not([data-variant]),
15
+ [data-style='frosted'] [data-button]:not([data-style]):not([data-variant]) {
16
+ border-width:1px;--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--ink);
17
+ background-color: color-mix(in oklch, var(--paper-edge) 28%, transparent);
18
+ border-color: rgba(255, 255, 255, 0.22);
19
+ box-shadow:
20
+ inset 0 1px 0 rgba(255, 255, 255, 0.2),
21
+ 0 2px 8px rgba(0, 0, 0, 0.08);
22
+ }
23
+
24
+ [data-style='frosted'] [data-button][data-style='default'][data-variant='primary'],
25
+ [data-style='frosted'] [data-button]:not([data-style])[data-variant='primary'] {
26
+ border-width:1px;background-color:color-mix(in srgb, var(--color-primary) calc(0.6 * 100%), transparent);--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--on-primary);
27
+ border-color: rgba(255, 255, 255, 0.25);
28
+ box-shadow:
29
+ inset 0 1px 0 rgba(255, 255, 255, 0.25),
30
+ 0 2px 8px rgba(0, 0, 0, 0.12);
31
+ }
32
+
33
+ [data-style='frosted'] [data-button][data-style='default'][data-variant='secondary'],
34
+ [data-style='frosted'] [data-button]:not([data-style])[data-variant='secondary'] {
35
+ border-width:1px;background-color:color-mix(in srgb, var(--color-accent) calc(0.6 * 100%), transparent);--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--on-primary);
36
+ border-color: rgba(255, 255, 255, 0.25);
37
+ box-shadow:
38
+ inset 0 1px 0 rgba(255, 255, 255, 0.25),
39
+ 0 2px 8px rgba(0, 0, 0, 0.12);
40
+ }
41
+
42
+ [data-style='frosted'] [data-button][data-style='default'][data-variant='accent'],
43
+ [data-style='frosted'] [data-button]:not([data-style])[data-variant='accent'] {
44
+ border-width:1px;background-color:color-mix(in srgb, var(--color-accent) calc(0.6 * 100%), transparent);--un-text-opacity:1;color:rgb(22 22 22 / var(--un-text-opacity));--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);
45
+ border-color: rgba(255, 255, 255, 0.25);
46
+ box-shadow:
47
+ inset 0 1px 0 rgba(255, 255, 255, 0.25),
48
+ 0 2px 8px rgba(0, 0, 0, 0.12);
49
+ }
50
+
51
+ [data-style='frosted'] [data-button][data-style='default'][data-variant='danger'],
52
+ [data-style='frosted'] [data-button]:not([data-style])[data-variant='danger'] {
53
+ border-width:1px;background-color:color-mix(in srgb, var(--color-danger) calc(0.6 * 100%), transparent);--un-text-opacity:1;color:rgb(22 22 22 / var(--un-text-opacity));--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);
54
+ border-color: rgba(255, 255, 255, 0.25);
55
+ box-shadow:
56
+ inset 0 1px 0 rgba(255, 255, 255, 0.25),
57
+ 0 2px 8px rgba(0, 0, 0, 0.12);
58
+ }
59
+
60
+ /* =============================================================================
61
+ Outline Style
62
+ ============================================================================= */
63
+
64
+ [data-style='frosted'] [data-button][data-style='outline'][data-variant='default'],
65
+ [data-style='frosted'] [data-button][data-style='outline']:not([data-variant]) {
66
+ border-width:1px;background-color:transparent;color:var(--ink-mute);
67
+ border-color: rgba(255, 255, 255, 0.28);
68
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
69
+ }
70
+
71
+ [data-style='frosted'] [data-button][data-style='outline'][data-variant='primary'] {
72
+ border-width:1px;background-color:transparent;color:var(--primary);
73
+ border-color: rgba(255, 255, 255, 0.28);
74
+ }
75
+
76
+ [data-style='frosted'] [data-button][data-style='outline'][data-variant='secondary'] {
77
+ border-width:1px;background-color:transparent;color:var(--accent);
78
+ border-color: rgba(255, 255, 255, 0.28);
79
+ }
80
+
81
+ [data-style='frosted'] [data-button][data-style='outline'][data-variant='accent'] {
82
+ border-width:1px;background-color:transparent;color:var(--accent);
83
+ border-color: rgba(255, 255, 255, 0.28);
84
+ }
85
+
86
+ [data-style='frosted'] [data-button][data-style='outline'][data-variant='danger'] {
87
+ border-width:1px;background-color:transparent;color:var(--danger);
88
+ border-color: rgba(255, 255, 255, 0.28);
89
+ }
90
+
91
+ /* =============================================================================
92
+ Ghost Style
93
+ ============================================================================= */
94
+
95
+ [data-style='frosted'] [data-button][data-style='ghost'] {
96
+ border-color:transparent;background-color:transparent;
97
+ }
98
+
99
+ [data-style='frosted'] [data-button][data-style='ghost'][data-variant='default'],
100
+ [data-style='frosted'] [data-button][data-style='ghost']:not([data-variant]) {
101
+ color:var(--ink-mute);
102
+ }
103
+
104
+ [data-style='frosted'] [data-button][data-style='ghost'][data-variant='primary'] {
105
+ color:var(--primary);
106
+ }
107
+
108
+ [data-style='frosted'] [data-button][data-style='ghost'][data-variant='secondary'] {
109
+ color:var(--accent);
110
+ }
111
+
112
+ [data-style='frosted'] [data-button][data-style='ghost'][data-variant='accent'] {
113
+ color:var(--accent);
114
+ }
115
+
116
+ [data-style='frosted'] [data-button][data-style='ghost'][data-variant='danger'] {
117
+ color:var(--danger);
118
+ }
119
+
120
+ /* =============================================================================
121
+ Gradient Style
122
+ ============================================================================= */
123
+
124
+ [data-style='frosted'] [data-button][data-style='gradient'][data-variant='default'],
125
+ [data-style='frosted'] [data-button][data-style='gradient']:not([data-variant]) {
126
+ /* paper-* are named-token shortcuts, not wind3 colors, so they silently drop as
127
+ gradient stops under @apply (unlike primary/accent/danger below). Write the
128
+ translucent gradient directly. See rokkit/button.css for the same workaround. */
129
+ background: linear-gradient(
130
+ to bottom right,
131
+ color-mix(in oklch, var(--paper-mute) 70%, transparent),
132
+ color-mix(in oklch, var(--paper-soft) 50%, transparent)
133
+ );
134
+ --un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--ink);
135
+ border-color: rgba(255, 255, 255, 0.2);
136
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2);
137
+ }
138
+
139
+ [data-style='frosted'] [data-button][data-style='gradient'][data-variant='primary'] {
140
+ --un-gradient-from-position:0%;--un-gradient-from:color-mix(in srgb, var(--color-primary) calc(0.8 * 100%), transparent) var(--un-gradient-from-position);--un-gradient-to-position:100%;--un-gradient-to:rgb(255 255 255 / 0) var(--un-gradient-to-position);--un-gradient-stops:var(--un-gradient-from), var(--un-gradient-to);--un-gradient-to-position:100%;--un-gradient-to:color-mix(in srgb, var(--color-primary) calc(0.6 * 100%), transparent) var(--un-gradient-to-position);--un-gradient-shape:to bottom right in oklch;--un-gradient:var(--un-gradient-shape), var(--un-gradient-stops);background-image:linear-gradient(var(--un-gradient));--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--on-primary);
141
+ border-color: rgba(255, 255, 255, 0.25);
142
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25);
143
+ }
144
+
145
+ [data-style='frosted'] [data-button][data-style='gradient'][data-variant='secondary'] {
146
+ --un-gradient-from-position:0%;--un-gradient-from:color-mix(in srgb, var(--color-accent) calc(0.8 * 100%), transparent) var(--un-gradient-from-position);--un-gradient-to-position:100%;--un-gradient-to:rgb(255 255 255 / 0) var(--un-gradient-to-position);--un-gradient-stops:var(--un-gradient-from), var(--un-gradient-to);--un-gradient-to-position:100%;--un-gradient-to:color-mix(in srgb, var(--color-accent) calc(0.6 * 100%), transparent) var(--un-gradient-to-position);--un-gradient-shape:to bottom right in oklch;--un-gradient:var(--un-gradient-shape), var(--un-gradient-stops);background-image:linear-gradient(var(--un-gradient));--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--on-primary);
147
+ border-color: rgba(255, 255, 255, 0.25);
148
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25);
149
+ }
150
+
151
+ [data-style='frosted'] [data-button][data-style='gradient'][data-variant='accent'] {
152
+ --un-gradient-from-position:0%;--un-gradient-from:color-mix(in srgb, var(--color-accent) calc(0.8 * 100%), transparent) var(--un-gradient-from-position);--un-gradient-to-position:100%;--un-gradient-to:rgb(255 255 255 / 0) var(--un-gradient-to-position);--un-gradient-stops:var(--un-gradient-from), var(--un-gradient-to);--un-gradient-to-position:100%;--un-gradient-to:color-mix(in srgb, var(--color-accent) calc(0.6 * 100%), transparent) var(--un-gradient-to-position);--un-gradient-shape:to bottom right in oklch;--un-gradient:var(--un-gradient-shape), var(--un-gradient-stops);background-image:linear-gradient(var(--un-gradient));--un-text-opacity:1;color:rgb(22 22 22 / var(--un-text-opacity));--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);
153
+ border-color: rgba(255, 255, 255, 0.25);
154
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25);
155
+ }
156
+
157
+ [data-style='frosted'] [data-button][data-style='gradient'][data-variant='danger'] {
158
+ --un-gradient-from-position:0%;--un-gradient-from:color-mix(in srgb, var(--color-danger) calc(0.8 * 100%), transparent) var(--un-gradient-from-position);--un-gradient-to-position:100%;--un-gradient-to:rgb(255 255 255 / 0) var(--un-gradient-to-position);--un-gradient-stops:var(--un-gradient-from), var(--un-gradient-to);--un-gradient-to-position:100%;--un-gradient-to:color-mix(in srgb, var(--color-danger) calc(0.6 * 100%), transparent) var(--un-gradient-to-position);--un-gradient-shape:to bottom right in oklch;--un-gradient:var(--un-gradient-shape), var(--un-gradient-stops);background-image:linear-gradient(var(--un-gradient));--un-text-opacity:1;color:rgb(22 22 22 / var(--un-text-opacity));--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);
159
+ border-color: rgba(255, 255, 255, 0.25);
160
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25);
161
+ }
162
+
163
+ [data-style='frosted']
164
+ [data-button][data-style='gradient']:hover:not(:disabled):not([data-disabled]) {
165
+ filter: brightness(1.1);
166
+ }
167
+
168
+ /* =============================================================================
169
+ Link Style
170
+ ============================================================================= */
171
+
172
+ [data-style='frosted'] [data-button][data-style='link'][data-variant='default'],
173
+ [data-style='frosted'] [data-button][data-style='link']:not([data-variant]) {
174
+ color:var(--ink-mute);
175
+ }
176
+
177
+ [data-style='frosted'] [data-button][data-style='link'][data-variant='primary'] {
178
+ color:var(--primary);
179
+ }
180
+
181
+ [data-style='frosted'] [data-button][data-style='link'][data-variant='secondary'] {
182
+ color:var(--accent);
183
+ }
184
+
185
+ [data-style='frosted'] [data-button][data-style='link'][data-variant='accent'] {
186
+ color:var(--accent);
187
+ }
188
+
189
+ [data-style='frosted'] [data-button][data-style='link'][data-variant='danger'] {
190
+ color:var(--danger);
191
+ }
192
+
193
+ [data-style='frosted'] [data-button][data-style='link']:hover:not(:disabled):not([data-disabled]) {
194
+ color:var(--primary);
195
+ }
196
+
197
+ /* =============================================================================
198
+ Hover States
199
+ ============================================================================= */
200
+
201
+ [data-style='frosted'] [data-button][data-style='default']:hover:not(:disabled):not([data-disabled]),
202
+ [data-style='frosted'] [data-button]:not([data-style]):hover:not(:disabled):not([data-disabled]) {
203
+ background-color: color-mix(in oklch, var(--paper-edge) 38%, transparent);
204
+ border-color: rgba(255, 255, 255, 0.3);
205
+ box-shadow:
206
+ inset 0 1px 0 rgba(255, 255, 255, 0.28),
207
+ 0 4px 16px rgba(0, 0, 0, 0.12);
208
+ }
209
+
210
+ [data-style='frosted'] [data-button][data-style='outline']:hover:not(:disabled):not([data-disabled]) {
211
+ background: rgba(255, 255, 255, 0.06);
212
+ border-color: rgba(255, 255, 255, 0.4);
213
+ }
214
+
215
+ [data-style='frosted'] [data-button][data-style='ghost']:hover:not(:disabled):not([data-disabled]) {
216
+ background: rgba(255, 255, 255, 0.06);
217
+ }
218
+
219
+ /* =============================================================================
220
+ Focus
221
+ ============================================================================= */
222
+
223
+ [data-style='frosted'] [data-button]:focus-visible {
224
+ box-shadow:
225
+ inset 0 1px 0 rgba(255, 255, 255, 0.2),
226
+ 0 0 0 2px rgba(255, 255, 255, 0.25);
227
+ outline: none;
228
+ }
@@ -0,0 +1,128 @@
1
+ /**
2
+ * Card - Frosted Glass Theme Styles
3
+ *
4
+ * Liquid frosted glass: milky translucent surface, specular top-edge shine,
5
+ * deep backdrop blur. More opaque than Apple liquid glass but still glassy.
6
+ */
7
+
8
+ /* =============================================================================
9
+ Base Card Styles
10
+ ============================================================================= */
11
+
12
+ [data-style='frosted'] [data-card] {
13
+ border-width:1px;--un-shadow:var(--un-shadow-inset) 0 10px 15px -3px var(--un-shadow-color, rgb(0 0 0 / 0.1)),var(--un-shadow-inset) 0 4px 6px -4px var(--un-shadow-color, rgb(0 0 0 / 0.1));box-shadow:var(--un-ring-offset-shadow), var(--un-ring-shadow), var(--un-shadow);--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--ink);
14
+ background-color: color-mix(in oklch, var(--paper-mute) 30%, transparent);
15
+ border-color: rgba(255, 255, 255, 0.18);
16
+ box-shadow:
17
+ inset 0 1px 0 rgba(255, 255, 255, 0.22),
18
+ 0 8px 32px rgba(0, 0, 0, 0.1);
19
+ }
20
+
21
+ /* Interactive cards (buttons) */
22
+ [data-style='frosted'] [data-card][data-card-interactive] {
23
+ cursor: pointer;
24
+ transition:
25
+ transform 0.2s ease,
26
+ box-shadow 0.2s ease,
27
+ background 0.2s ease;
28
+ }
29
+
30
+ [data-style='frosted'] [data-card][data-card-interactive]:hover {
31
+ background-color: color-mix(in oklch, var(--paper-mute) 42%, transparent);
32
+ box-shadow:
33
+ inset 0 1px 0 rgba(255, 255, 255, 0.28),
34
+ 0 16px 40px rgba(0, 0, 0, 0.14);
35
+ transform: translateY(-2px);
36
+ }
37
+
38
+ [data-style='frosted'] [data-card][data-card-interactive]:active {
39
+ box-shadow:
40
+ inset 0 1px 0 rgba(255, 255, 255, 0.18),
41
+ 0 4px 16px rgba(0, 0, 0, 0.1);
42
+ transform: translateY(0);
43
+ }
44
+
45
+ /* =============================================================================
46
+ Card Sections
47
+ ============================================================================= */
48
+
49
+ [data-style='frosted'] [data-card-header] {
50
+ border-bottom: 1px solid rgba(255, 255, 255, 0.12);
51
+ }
52
+
53
+ [data-style='frosted'] [data-card-body] {
54
+ color:var(--ink-mute);
55
+ }
56
+
57
+ [data-style='frosted'] [data-card-footer] {
58
+ color:var(--ink-mute);
59
+ border-top: 1px solid rgba(255, 255, 255, 0.12);
60
+ }
61
+
62
+ /* =============================================================================
63
+ Focus States
64
+ ============================================================================= */
65
+
66
+ [data-style='frosted'] [data-card][data-card-interactive]:focus-visible {
67
+ outline: none;
68
+ box-shadow:
69
+ inset 0 1px 0 rgba(255, 255, 255, 0.22),
70
+ 0 0 0 2px rgba(255, 255, 255, 0.25);
71
+ }
72
+
73
+ /* =============================================================================
74
+ Disabled State
75
+ ============================================================================= */
76
+
77
+ [data-style='frosted'] [data-card][data-card-interactive][data-disabled],
78
+ [data-style='frosted'] [data-card][data-card-interactive]:disabled {
79
+ cursor:not-allowed;opacity:0.5;
80
+ transform: none;
81
+ }
82
+
83
+ /* =============================================================================
84
+ Variants
85
+ ============================================================================= */
86
+
87
+ /* Primary — tinted primary glass */
88
+ [data-style='frosted'] [data-card][data-variant='primary'] {
89
+ border-width:1px;background-color:color-mix(in srgb, var(--color-primary) calc(0.45 * 100%), transparent);--un-shadow:var(--un-shadow-inset) 0 10px 15px -3px var(--un-shadow-color, rgb(0 0 0 / 0.1)),var(--un-shadow-inset) 0 4px 6px -4px var(--un-shadow-color, rgb(0 0 0 / 0.1));box-shadow:var(--un-ring-offset-shadow), var(--un-ring-shadow), var(--un-shadow);--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--on-primary);
90
+ border-color: rgba(255, 255, 255, 0.22);
91
+ box-shadow:
92
+ inset 0 1px 0 rgba(255, 255, 255, 0.28),
93
+ 0 8px 32px rgba(0, 0, 0, 0.12);
94
+ }
95
+
96
+ [data-style='frosted'] [data-card][data-variant='primary'] [data-card-header],
97
+ [data-style='frosted'] [data-card][data-variant='primary'] [data-card-footer] {
98
+ border-color: rgba(255, 255, 255, 0.15);
99
+ }
100
+
101
+ [data-style='frosted'] [data-card][data-variant='primary'] [data-card-body] {
102
+ color:rgb(22 22 22 / 0.8);
103
+ }
104
+
105
+ /* Secondary — tinted secondary glass */
106
+ [data-style='frosted'] [data-card][data-variant='secondary'] {
107
+ border-width:1px;background-color:color-mix(in srgb, var(--color-accent) calc(0.45 * 100%), transparent);--un-shadow:var(--un-shadow-inset) 0 10px 15px -3px var(--un-shadow-color, rgb(0 0 0 / 0.1)),var(--un-shadow-inset) 0 4px 6px -4px var(--un-shadow-color, rgb(0 0 0 / 0.1));box-shadow:var(--un-ring-offset-shadow), var(--un-ring-shadow), var(--un-shadow);--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--on-primary);
108
+ border-color: rgba(255, 255, 255, 0.22);
109
+ box-shadow:
110
+ inset 0 1px 0 rgba(255, 255, 255, 0.28),
111
+ 0 8px 32px rgba(0, 0, 0, 0.12);
112
+ }
113
+
114
+ [data-style='frosted'] [data-card][data-variant='secondary'] [data-card-header],
115
+ [data-style='frosted'] [data-card][data-variant='secondary'] [data-card-footer] {
116
+ border-color: rgba(255, 255, 255, 0.15);
117
+ }
118
+
119
+ [data-style='frosted'] [data-card][data-variant='secondary'] [data-card-body] {
120
+ color:rgb(22 22 22 / 0.8);
121
+ }
122
+
123
+ /* Tertiary — barely-there frosted glass */
124
+ [data-style='frosted'] [data-card][data-variant='tertiary'] {
125
+ border-width:1px;--un-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);backdrop-filter:var(--un-backdrop-blur) var(--un-backdrop-brightness) var(--un-backdrop-contrast) var(--un-backdrop-grayscale) var(--un-backdrop-hue-rotate) var(--un-backdrop-invert) var(--un-backdrop-opacity) var(--un-backdrop-saturate) var(--un-backdrop-sepia);color:var(--ink-mute);
126
+ background-color: color-mix(in oklch, var(--paper-mute) 16%, transparent);
127
+ border-color: rgba(255, 255, 255, 0.12);
128
+ }