@fpkit/acss 0.5.12 → 0.5.13

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 (264) hide show
  1. package/README.md +89 -0
  2. package/libs/{chunk-DV56L5YX.cjs → chunk-2LTJ7HHX.cjs} +4 -4
  3. package/libs/{chunk-EQ67LF46.js → chunk-2Y7W75TT.js} +3 -3
  4. package/libs/{chunk-KKLTUJFB.cjs → chunk-3MKLDCKQ.cjs} +5 -5
  5. package/libs/chunk-3MKLDCKQ.cjs.map +1 -0
  6. package/libs/{chunk-X3EVB7VS.cjs → chunk-5S4ORA4C.cjs} +3 -3
  7. package/libs/{chunk-O6QZBB6G.js → chunk-772NRB75.js} +5 -5
  8. package/libs/chunk-772NRB75.js.map +1 -0
  9. package/libs/{chunk-6BVXFW7U.cjs → chunk-AHDJGCG5.cjs} +3 -3
  10. package/libs/{chunk-E3XP6BEX.cjs → chunk-B7F5FS6D.cjs} +3 -3
  11. package/libs/chunk-D4YLRWAO.cjs +18 -0
  12. package/libs/chunk-D4YLRWAO.cjs.map +1 -0
  13. package/libs/chunk-ETFLFC2S.js +10 -0
  14. package/libs/chunk-ETFLFC2S.js.map +1 -0
  15. package/libs/chunk-GZ4QFPRY.js +9 -0
  16. package/libs/chunk-GZ4QFPRY.js.map +1 -0
  17. package/libs/{chunk-LHVJKDMA.cjs → chunk-J32EZPYD.cjs} +3 -3
  18. package/libs/chunk-JJ43O4Y5.js +8 -0
  19. package/libs/chunk-JJ43O4Y5.js.map +1 -0
  20. package/libs/chunk-KUKIVRC2.js +7 -0
  21. package/libs/chunk-KUKIVRC2.js.map +1 -0
  22. package/libs/chunk-L75OQKEI.cjs +13 -0
  23. package/libs/chunk-L75OQKEI.cjs.map +1 -0
  24. package/libs/{chunk-LL7HTLMS.cjs → chunk-M5RRNTVX.cjs} +3 -3
  25. package/libs/{chunk-LIQJ7ZZR.js → chunk-NGTJDDFO.js} +2 -2
  26. package/libs/chunk-OK5QEIMD.cjs +17 -0
  27. package/libs/chunk-OK5QEIMD.cjs.map +1 -0
  28. package/libs/chunk-P2DC76ZZ.cjs +18 -0
  29. package/libs/chunk-P2DC76ZZ.cjs.map +1 -0
  30. package/libs/chunk-PQ2K3BM6.cjs +17 -0
  31. package/libs/chunk-PQ2K3BM6.cjs.map +1 -0
  32. package/libs/{chunk-QCMV4VQZ.js → chunk-QLZWHAMK.js} +2 -2
  33. package/libs/{chunk-BIP2NY53.js → chunk-RIVUMPOG.js} +2 -2
  34. package/libs/{chunk-ICCKQ2GC.cjs → chunk-ROZI23GS.cjs} +4 -4
  35. package/libs/{chunk-NHYXGV3L.js → chunk-SMYRLO3E.js} +2 -2
  36. package/libs/{chunk-5ZM4XL44.js → chunk-TYRCEX2L.js} +2 -2
  37. package/libs/chunk-VUH3FXGJ.js +11 -0
  38. package/libs/chunk-VUH3FXGJ.js.map +1 -0
  39. package/libs/{chunk-PPOOBUOS.js → chunk-XBA562WW.js} +2 -2
  40. package/libs/{chunk-QVV34QEH.cjs → chunk-XTQKWY7W.cjs} +3 -3
  41. package/libs/{chunk-YWOYVRFT.js → chunk-ZANSFMTD.js} +3 -3
  42. package/libs/components/alert/alert.css +1 -1
  43. package/libs/components/alert/alert.css.map +1 -1
  44. package/libs/components/alert/alert.min.css +2 -2
  45. package/libs/components/badge/badge.css +1 -1
  46. package/libs/components/badge/badge.css.map +1 -1
  47. package/libs/components/badge/badge.min.css +2 -2
  48. package/libs/components/breadcrumbs/breadcrumb.cjs +9 -5
  49. package/libs/components/breadcrumbs/breadcrumb.d.cts +271 -32
  50. package/libs/components/breadcrumbs/breadcrumb.d.ts +271 -32
  51. package/libs/components/breadcrumbs/breadcrumb.js +3 -3
  52. package/libs/components/button.cjs +4 -4
  53. package/libs/components/button.d.cts +2 -2
  54. package/libs/components/button.d.ts +2 -2
  55. package/libs/components/button.js +2 -2
  56. package/libs/components/buttons/button.css +1 -1
  57. package/libs/components/buttons/button.css.map +1 -1
  58. package/libs/components/buttons/button.min.css +2 -2
  59. package/libs/components/card.cjs +7 -7
  60. package/libs/components/card.d.cts +277 -33
  61. package/libs/components/card.d.ts +277 -33
  62. package/libs/components/card.js +2 -2
  63. package/libs/components/cards/card.css +1 -1
  64. package/libs/components/cards/card.css.map +1 -1
  65. package/libs/components/cards/card.min.css +2 -2
  66. package/libs/components/details/details.css +1 -1
  67. package/libs/components/details/details.css.map +1 -1
  68. package/libs/components/details/details.min.css +2 -2
  69. package/libs/components/dialog/dialog.cjs +7 -7
  70. package/libs/components/dialog/dialog.css +1 -1
  71. package/libs/components/dialog/dialog.css.map +1 -1
  72. package/libs/components/dialog/dialog.d.cts +88 -34
  73. package/libs/components/dialog/dialog.d.ts +88 -34
  74. package/libs/components/dialog/dialog.js +5 -5
  75. package/libs/components/dialog/dialog.min.css +2 -2
  76. package/libs/components/form/fields.cjs +4 -4
  77. package/libs/components/form/fields.d.cts +2 -2
  78. package/libs/components/form/fields.d.ts +2 -2
  79. package/libs/components/form/fields.js +2 -2
  80. package/libs/components/form/textarea.cjs +4 -4
  81. package/libs/components/form/textarea.d.cts +2 -2
  82. package/libs/components/form/textarea.d.ts +2 -2
  83. package/libs/components/form/textarea.js +2 -2
  84. package/libs/components/heading/heading.cjs +3 -3
  85. package/libs/components/heading/heading.d.cts +3 -14
  86. package/libs/components/heading/heading.d.ts +3 -14
  87. package/libs/components/heading/heading.js +2 -2
  88. package/libs/components/icons/icon.cjs +4 -4
  89. package/libs/components/icons/icon.d.cts +148 -4
  90. package/libs/components/icons/icon.d.ts +148 -4
  91. package/libs/components/icons/icon.js +2 -2
  92. package/libs/components/images/img.css +1 -1
  93. package/libs/components/images/img.css.map +1 -1
  94. package/libs/components/images/img.min.css +2 -2
  95. package/libs/components/link/link.cjs +4 -4
  96. package/libs/components/link/link.d.cts +2 -2
  97. package/libs/components/link/link.d.ts +2 -2
  98. package/libs/components/link/link.js +2 -2
  99. package/libs/components/list/list.cjs +5 -5
  100. package/libs/components/list/list.d.cts +3 -3
  101. package/libs/components/list/list.d.ts +3 -3
  102. package/libs/components/list/list.js +2 -2
  103. package/libs/components/modal.cjs +4 -4
  104. package/libs/components/modal.js +3 -3
  105. package/libs/components/nav/nav.cjs +7 -7
  106. package/libs/components/nav/nav.d.cts +2 -2
  107. package/libs/components/nav/nav.d.ts +2 -2
  108. package/libs/components/nav/nav.js +3 -3
  109. package/libs/components/text/text.cjs +5 -5
  110. package/libs/components/text/text.d.cts +2 -2
  111. package/libs/components/text/text.d.ts +2 -2
  112. package/libs/components/text/text.js +2 -2
  113. package/libs/heading-3648c538.d.ts +250 -0
  114. package/libs/hooks.cjs +7 -0
  115. package/libs/hooks.d.cts +5 -0
  116. package/libs/hooks.d.ts +5 -0
  117. package/libs/hooks.js +3 -0
  118. package/libs/icons.cjs +3 -3
  119. package/libs/icons.d.cts +1 -1
  120. package/libs/icons.d.ts +1 -1
  121. package/libs/icons.js +2 -2
  122. package/libs/index.cjs +112 -91
  123. package/libs/index.cjs.map +1 -1
  124. package/libs/index.css +1 -1
  125. package/libs/index.css.map +1 -1
  126. package/libs/index.d.cts +515 -31
  127. package/libs/index.d.ts +515 -31
  128. package/libs/index.js +31 -19
  129. package/libs/index.js.map +1 -1
  130. package/libs/ui-645f95b5.d.ts +285 -0
  131. package/package.json +2 -83
  132. package/src/components/README-UI.mdx +416 -0
  133. package/src/components/alert/ACCESSIBILITY.md +319 -0
  134. package/src/components/alert/README.mdx +475 -19
  135. package/src/components/alert/alert.scss +113 -6
  136. package/src/components/alert/alert.stories.tsx +372 -0
  137. package/src/components/alert/alert.test.tsx +762 -0
  138. package/src/components/alert/alert.tsx +331 -66
  139. package/src/components/alert/views/alert-actions.tsx +13 -0
  140. package/src/components/alert/views/alert-content.tsx +17 -0
  141. package/src/components/alert/views/alert-icon.tsx +53 -0
  142. package/src/components/alert/views/alert-screen-reader-text.tsx +30 -0
  143. package/src/components/alert/views/alert-title.tsx +23 -0
  144. package/src/components/alert/views/alert-view.tsx +158 -0
  145. package/src/components/alert/views/index.ts +12 -0
  146. package/src/components/badge/badge.mdx +186 -49
  147. package/src/components/badge/badge.scss +20 -2
  148. package/src/components/badge/badge.stories.tsx +160 -14
  149. package/src/components/badge/badge.test.tsx +179 -0
  150. package/src/components/badge/badge.tsx +97 -4
  151. package/src/components/breadcrumbs/README.mdx +364 -45
  152. package/src/components/breadcrumbs/__snapshots__/breadcrumb.test.tsx.snap +152 -0
  153. package/src/components/breadcrumbs/breadcrumb.stories.tsx +7 -3
  154. package/src/components/breadcrumbs/breadcrumb.test.tsx +490 -0
  155. package/src/components/breadcrumbs/breadcrumb.tsx +427 -170
  156. package/src/components/buttons/button.scss +34 -31
  157. package/src/components/buttons/button.stories.tsx +35 -0
  158. package/src/components/cards/README.mdx +657 -0
  159. package/src/components/cards/card.scss +22 -0
  160. package/src/components/cards/card.stories.tsx +167 -5
  161. package/src/components/cards/card.test.tsx +360 -20
  162. package/src/components/cards/card.tsx +200 -79
  163. package/src/components/cards/card.types.ts +135 -0
  164. package/src/components/cards/card.utils.ts +79 -0
  165. package/src/components/details/ACCESSIBILITY-REVIEW-LIVE.md +1050 -0
  166. package/src/components/details/ACCESSIBILITY-REVIEW.md +502 -0
  167. package/src/components/details/README.mdx +437 -69
  168. package/src/components/details/details.scss +16 -7
  169. package/src/components/details/details.test.tsx +385 -0
  170. package/src/components/details/details.tsx +101 -69
  171. package/src/components/details/details.types.ts +76 -0
  172. package/src/components/dialog/README.mdx +513 -110
  173. package/src/components/dialog/dialog-modal.tsx +79 -56
  174. package/src/components/dialog/dialog.scss +53 -3
  175. package/src/components/dialog/dialog.stories.tsx +10 -7
  176. package/src/components/dialog/dialog.test.tsx +450 -0
  177. package/src/components/dialog/dialog.tsx +69 -59
  178. package/src/components/dialog/dialog.types.ts +133 -0
  179. package/src/components/dialog/views/dialog-footer.tsx +54 -11
  180. package/src/components/dialog/views/dialog-header.tsx +20 -15
  181. package/src/components/heading/heading.stories.tsx +44 -4
  182. package/src/components/heading/heading.tsx +89 -23
  183. package/src/components/icons/README.mdx +332 -0
  184. package/src/components/icons/icon.stories.tsx +74 -1
  185. package/src/components/icons/icon.tsx +89 -1
  186. package/src/components/icons/types.ts +47 -0
  187. package/src/components/images/README.mdx +340 -24
  188. package/src/components/images/img.scss +19 -3
  189. package/src/components/images/img.stories.tsx +424 -15
  190. package/src/components/images/img.test.tsx +354 -25
  191. package/src/components/images/img.tsx +186 -63
  192. package/src/components/images/img.types.ts +211 -0
  193. package/src/components/title/MIGRATION.md +199 -0
  194. package/src/components/title/README.md +326 -0
  195. package/src/components/title/README.mdx +452 -0
  196. package/src/components/title/title.stories.tsx +393 -0
  197. package/src/components/title/title.test.tsx +251 -0
  198. package/src/components/title/title.tsx +219 -0
  199. package/src/components/ui.stories.tsx +894 -0
  200. package/src/components/ui.test.tsx +559 -0
  201. package/src/components/ui.tsx +266 -15
  202. package/src/components/word-count/README.md +240 -0
  203. package/src/hooks.ts +1 -0
  204. package/src/index.ts +10 -2
  205. package/src/sass/_properties.scss +1 -0
  206. package/src/styles/alert/alert.css +94 -4
  207. package/src/styles/alert/alert.css.map +1 -1
  208. package/src/styles/badge/badge.css +20 -2
  209. package/src/styles/badge/badge.css.map +1 -1
  210. package/src/styles/buttons/button.css +31 -31
  211. package/src/styles/buttons/button.css.map +1 -1
  212. package/src/styles/cards/card.css +16 -0
  213. package/src/styles/cards/card.css.map +1 -1
  214. package/src/styles/details/details.css +19 -8
  215. package/src/styles/details/details.css.map +1 -1
  216. package/src/styles/dialog/dialog.css +43 -2
  217. package/src/styles/dialog/dialog.css.map +1 -1
  218. package/src/styles/images/img.css +15 -3
  219. package/src/styles/images/img.css.map +1 -1
  220. package/src/styles/index.css +240 -51
  221. package/src/styles/index.css.map +1 -1
  222. package/src/test/setup.d.ts +9 -0
  223. package/src/test/setup.ts +53 -1
  224. package/libs/chunk-6TE5QEVE.cjs +0 -13
  225. package/libs/chunk-6TE5QEVE.cjs.map +0 -1
  226. package/libs/chunk-7K76RW2A.cjs +0 -18
  227. package/libs/chunk-7K76RW2A.cjs.map +0 -1
  228. package/libs/chunk-BSPKFLO4.js +0 -8
  229. package/libs/chunk-BSPKFLO4.js.map +0 -1
  230. package/libs/chunk-BV5CLH44.cjs +0 -18
  231. package/libs/chunk-BV5CLH44.cjs.map +0 -1
  232. package/libs/chunk-DKGJHKGW.js +0 -9
  233. package/libs/chunk-DKGJHKGW.js.map +0 -1
  234. package/libs/chunk-ECLD37WN.cjs +0 -16
  235. package/libs/chunk-ECLD37WN.cjs.map +0 -1
  236. package/libs/chunk-HYBZBN4G.js +0 -8
  237. package/libs/chunk-HYBZBN4G.js.map +0 -1
  238. package/libs/chunk-KKLTUJFB.cjs.map +0 -1
  239. package/libs/chunk-M5QL5TAE.cjs +0 -14
  240. package/libs/chunk-M5QL5TAE.cjs.map +0 -1
  241. package/libs/chunk-NE6YXTMC.js +0 -7
  242. package/libs/chunk-NE6YXTMC.js.map +0 -1
  243. package/libs/chunk-O6QZBB6G.js.map +0 -1
  244. package/libs/chunk-SXVZSWX6.js +0 -11
  245. package/libs/chunk-SXVZSWX6.js.map +0 -1
  246. package/libs/ui-9a6f9f8d.d.ts +0 -24
  247. package/src/components/cards/README.md +0 -80
  248. package/src/components/dialog/hooks/useClickOutside.ts +0 -33
  249. /package/libs/{chunk-DV56L5YX.cjs.map → chunk-2LTJ7HHX.cjs.map} +0 -0
  250. /package/libs/{chunk-EQ67LF46.js.map → chunk-2Y7W75TT.js.map} +0 -0
  251. /package/libs/{chunk-X3EVB7VS.cjs.map → chunk-5S4ORA4C.cjs.map} +0 -0
  252. /package/libs/{chunk-6BVXFW7U.cjs.map → chunk-AHDJGCG5.cjs.map} +0 -0
  253. /package/libs/{chunk-E3XP6BEX.cjs.map → chunk-B7F5FS6D.cjs.map} +0 -0
  254. /package/libs/{chunk-LHVJKDMA.cjs.map → chunk-J32EZPYD.cjs.map} +0 -0
  255. /package/libs/{chunk-LL7HTLMS.cjs.map → chunk-M5RRNTVX.cjs.map} +0 -0
  256. /package/libs/{chunk-LIQJ7ZZR.js.map → chunk-NGTJDDFO.js.map} +0 -0
  257. /package/libs/{chunk-QCMV4VQZ.js.map → chunk-QLZWHAMK.js.map} +0 -0
  258. /package/libs/{chunk-BIP2NY53.js.map → chunk-RIVUMPOG.js.map} +0 -0
  259. /package/libs/{chunk-ICCKQ2GC.cjs.map → chunk-ROZI23GS.cjs.map} +0 -0
  260. /package/libs/{chunk-NHYXGV3L.js.map → chunk-SMYRLO3E.js.map} +0 -0
  261. /package/libs/{chunk-5ZM4XL44.js.map → chunk-TYRCEX2L.js.map} +0 -0
  262. /package/libs/{chunk-PPOOBUOS.js.map → chunk-XBA562WW.js.map} +0 -0
  263. /package/libs/{chunk-QVV34QEH.cjs.map → chunk-XTQKWY7W.cjs.map} +0 -0
  264. /package/libs/{chunk-YWOYVRFT.js.map → chunk-ZANSFMTD.js.map} +0 -0
@@ -1,3 +1,16 @@
1
+ /* Screen reader only utility class */
2
+ .sr-only {
3
+ position: absolute;
4
+ width: 1px;
5
+ height: 1px;
6
+ padding: 0;
7
+ margin: -1px;
8
+ overflow: hidden;
9
+ clip: rect(0, 0, 0, 0);
10
+ white-space: nowrap;
11
+ border-width: 0;
12
+ }
13
+
1
14
  [role=alert] {
2
15
  /* Success colors */
3
16
  --alert-success-bg: #e6f4ea;
@@ -15,6 +28,8 @@
15
28
  --alert-info-bg: #e5f6fd;
16
29
  --alert-info-border: #0288d1;
17
30
  --alert-info-text: #084154;
31
+ /* Animation */
32
+ --alert-transition-duration: 0.3s;
18
33
  --alert-border: thin solid currentColor;
19
34
  background-color: var(--alert-bg, whitesmoke);
20
35
  border: var(--alert-border, currentColor);
@@ -26,19 +41,59 @@
26
41
  display: flex;
27
42
  flex-direction: row;
28
43
  border-radius: var(--alert-border-radius, var(--border-radius));
29
- border: var(--alert-border);
30
44
  gap: var(--alert-gap, var(--spc-4));
45
+ /* Exit animations */
46
+ transition: opacity var(--alert-transition-duration) ease, transform var(--alert-transition-duration) ease;
47
+ opacity: 1;
48
+ transform: translateY(0);
49
+ /* Focus indicators for keyboard navigation (WCAG 2.4.7) */
50
+ /* Hide focus outline for mouse clicks, keep for keyboard */
51
+ /* Variant: Filled - Solid colored background */
52
+ /* Variant: Soft - No border, subtle background */
53
+ /* Variant: Outlined - Default with border (no additional styles needed) */
54
+ }
55
+ [role=alert]:not([data-visible=true]) {
56
+ opacity: 0;
57
+ transform: translateY(-0.5rem);
58
+ }
59
+ @media (prefers-reduced-motion: reduce) {
60
+ [role=alert] {
61
+ transition-duration: 0.01ms;
62
+ }
63
+ }
64
+ [role=alert]:focus {
65
+ outline: 2px solid currentColor;
66
+ outline-offset: 2px;
31
67
  }
32
- [role=alert] div {
68
+ [role=alert]:focus:not(:focus-visible) {
69
+ outline: none;
70
+ }
71
+ [role=alert] .alert-icon {
33
72
  margin-block-start: 0;
34
73
  align-items: center;
35
74
  }
36
75
  [role=alert] .alert-message {
37
76
  flex: 2;
38
77
  margin-block-start: 0;
78
+ /* Title styles for both heading and strong elements */
79
+ /* Reset heading-specific styles */
80
+ }
81
+ [role=alert] .alert-message .alert-title {
82
+ margin-block-end: var(--spc-1, 0.25rem);
83
+ margin-block-start: 0;
84
+ font-weight: var(--alert-title-weight, 600);
85
+ font-size: var(--alert-title-size, inherit);
86
+ line-height: 1.4;
39
87
  }
40
- [role=alert] .alert-message h3 {
41
- margin-block-end: 0;
88
+ [role=alert] .alert-message h2.alert-title,
89
+ [role=alert] .alert-message h3.alert-title,
90
+ [role=alert] .alert-message h4.alert-title,
91
+ [role=alert] .alert-message h5.alert-title,
92
+ [role=alert] .alert-message h6.alert-title {
93
+ margin: 0;
94
+ margin-block-end: var(--spc-1, 0.25rem);
95
+ font-size: inherit;
96
+ font-weight: var(--alert-title-weight, 600);
42
97
  }
43
98
  [role=alert][data-alert~=info] {
44
99
  --alert-bg: var(--alert-info-bg);
@@ -63,5 +118,40 @@
63
118
  [role=alert] button[data-btn~=icon] {
64
119
  --btn-bg: transparent;
65
120
  }
121
+ [role=alert] * + div {
122
+ margin-block-start: var(--spc-1);
123
+ }
124
+ [role=alert][data-variant=filled] {
125
+ border: none;
126
+ }
127
+ [role=alert][data-variant=filled][data-alert~=info] {
128
+ --alert-bg: var(--alert-info-border);
129
+ --alert-color: white;
130
+ }
131
+ [role=alert][data-variant=filled][data-alert~=warning] {
132
+ --alert-bg: var(--alert-warning-border);
133
+ --alert-color: white;
134
+ }
135
+ [role=alert][data-variant=filled][data-alert~=error] {
136
+ --alert-bg: var(--alert-error-border);
137
+ --alert-color: white;
138
+ }
139
+ [role=alert][data-variant=filled][data-alert~=success] {
140
+ --alert-bg: var(--alert-success-border);
141
+ --alert-color: white;
142
+ }
143
+ [role=alert][data-variant=filled][data-alert~=default] {
144
+ --alert-bg: #757575;
145
+ --alert-color: white;
146
+ }
147
+ [role=alert][data-variant=soft] {
148
+ border: none;
149
+ }
150
+ [role=alert][data-variant=outlined] {
151
+ /* This is the default variant, styles already applied above */
152
+ }
153
+ [role=alert] p {
154
+ font-size: 0.875rem;
155
+ }
66
156
 
67
157
  /*# sourceMappingURL=alert.css.map */
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../components/alert/alert.scss"],"names":[],"mappings":"AAAA;AACE;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;EAEA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;;AACA;EACE;EACA;;AAGF;EACE;EACA;;AACA;EACE;;AAIJ;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAIA;EACE","file":"alert.css"}
1
+ {"version":3,"sourceRoot":"","sources":["../../components/alert/alert.scss"],"names":[],"mappings":"AAAA;AACA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;AACE;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;AAEA;EACA;EAEA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;EACA,YACE;EAEF;EACA;AAWA;AAMA;AAsEA;AA8BA;AAKA;;AAxHA;EACE;EACA;;AAGF;EAlDF;IAmDI;;;AAIF;EACE;EACA;;AAIF;EACE;;AAGF;EACE;EACA;;AAGF;EACE;EACA;AAEA;AASA;;AARA;EACE;EACA;EACA;EACA;EACA;;AAIF;AAAA;AAAA;AAAA;AAAA;EAKE;EACA;EACA;EACA;;AAIJ;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAIA;EACE;;AAIJ;EACE;;AAIF;EACE;;AAEA;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;AAKJ;EACE;;AAIF;AACE;;AAGF;EACE","file":"alert.css"}
@@ -16,8 +16,26 @@ sup:has(> span) span {
16
16
  color: inherit;
17
17
  }
18
18
  sup:has(> span)[data-badge~=rounded] {
19
- --badge-radius: 100%;
20
- --badge-padding: 0.2rem;
19
+ --badge-radius: 50%;
20
+ --badge-padding: 0;
21
+ --badge-size: 1.5625rem;
22
+ width: var(--badge-size);
23
+ height: var(--badge-size);
24
+ display: inline-flex;
25
+ align-items: center;
26
+ justify-content: center;
27
+ line-height: 1;
28
+ font-size: 0.6875rem;
29
+ font-weight: 700;
30
+ overflow: hidden;
31
+ box-sizing: border-box;
32
+ }
33
+ sup:has(> span)[data-badge~=rounded] span {
34
+ max-width: 100%;
35
+ overflow: hidden;
36
+ text-overflow: clip;
37
+ white-space: nowrap;
38
+ padding: 0 0.125rem;
21
39
  }
22
40
 
23
41
  /*# sourceMappingURL=badge.css.map */
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../components/badge/badge.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA","file":"badge.css"}
1
+ {"version":3,"sourceRoot":"","sources":["../../components/badge/badge.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA","file":"badge.css"}
@@ -1,23 +1,19 @@
1
1
  button {
2
- --btn-xs: 0.6rem;
3
- --btn-sm: 0.7rem;
4
- --btn-md: 0.85rem;
5
- --btn-lg: 1.3125rem;
2
+ --btn-xs: 0.6875rem;
3
+ --btn-sm: 0.8125rem;
4
+ --btn-md: 0.9375rem;
5
+ --btn-lg: 1.125rem;
6
6
  --btn-pill: 100rem;
7
- --btn-height: 2.5rem;
8
- --fs: 0.95rem;
9
- --btn-fs: 0.9375rem;
7
+ --btn-fs: var(--btn-md);
8
+ --btn-height: calc(var(--btn-fs) * 2.25);
10
9
  --btn-bg: lightgray;
11
10
  --btn-width: max-content;
12
- --btn-calc-height: var(--btn-height, calc(40rem / 16));
13
11
  font-size: var(--btn-fs);
14
12
  font-weight: var(--btn-fw, 500);
15
- height: var(--btn-height, 2.5rem);
16
- max-height: var(--btn-calc-height);
17
- min-height: 1.5rem;
13
+ height: var(--btn-height);
18
14
  place-items: var(--btn-place, center);
19
- padding-inline: var(--btn-px, calc(var(--btn-fs) + 1.1%));
20
- padding-block: var(--btn-py, calc(var(--btn-fs) + 0.75%));
15
+ padding-inline: var(--btn-px, calc(var(--btn-fs) * 1.5));
16
+ padding-block: var(--btn-py, calc(var(--btn-fs) * 0.5));
21
17
  border: var(--btn-bdr, none);
22
18
  border-radius: var(--btn-rds, 0.375rem);
23
19
  text-decoration: var(--btn-deco, none);
@@ -26,7 +22,7 @@ button {
26
22
  gap: var(--btn-gap, 0.2rem);
27
23
  white-space: var(--btn-wspc, inherit);
28
24
  margin: var(--btn-spc, 0);
29
- transition: var(--tran-all);
25
+ transition: var(--btn-transition, var(--tran-all, all 0.3s cubic-bezier(0.4, 0, 0.2, 1)));
30
26
  background-color: var(--btn-bg, var(--btn));
31
27
  outline: none;
32
28
  width: var(--btn-width);
@@ -49,14 +45,15 @@ button[disabled]:is(:hover, :focus), button[aria-disabled=true]:is(:hover, :focu
49
45
  transform: none;
50
46
  }
51
47
  button:is(:hover, :focus) {
52
- background-color: var(--btn-bg, var(--btn, lightgray));
53
- filter: invert(1) hue-rotate 180deg;
54
- transform: scale(0.95) var(--line-style, solid);
48
+ filter: var(--btn-hover-filter, brightness(0.85));
49
+ transform: var(--btn-hover-transform, scale(1.03));
50
+ outline: var(--btn-hover-outline, thin);
55
51
  outline-offset: var(--line-offset, 1px);
56
52
  }
57
53
  button:is(:hover, :focus)[aria-disabled=true] {
58
54
  transform: none;
59
55
  opacity: var(--btn-opacity, 0.5);
56
+ filter: none;
60
57
  }
61
58
  button[type=reset] {
62
59
  --btn-bg: transparent;
@@ -72,25 +69,25 @@ button[type=submit] {
72
69
  button[data-fp-btn~=pill], button[data-btn~=pill], button[data-style~=pill] {
73
70
  border-radius: var(--btn-pill, 100rem);
74
71
  }
75
- button[data-btn~=xs] {
76
- padding-inline: var(--btn-xs);
72
+ button[data-btn~=xs],
73
+ button .btn-xs {
77
74
  --btn-fs: var(--btn-xs);
78
- --btn-height: 1.5rem;
79
75
  text-transform: uppercase;
80
76
  }
81
- button[data-btn~=sm] {
77
+ button[data-btn~=sm],
78
+ button .btn-sm {
82
79
  --btn-fs: var(--btn-sm);
83
- --btn-height: 1.75rem;
84
80
  }
85
- button[data-btn~=md] {
81
+ button[data-btn~=md],
82
+ button .btn-md {
86
83
  --btn-fs: var(--btn-md);
87
- --btn-height: 2rem;
88
84
  }
89
- button[data-btn~=lg] {
85
+ button[data-btn~=lg],
86
+ button .btn-lg {
90
87
  --btn-fs: var(--btn-lg);
91
- --btn-height: 2.5rem;
92
88
  }
93
- button[data-btn~=icon] {
89
+ button[data-btn~=icon],
90
+ button .btn-icon {
94
91
  padding: unset;
95
92
  height: unset;
96
93
  --btn-bg: transparent;
@@ -101,7 +98,8 @@ button[data-btn~=icon] {
101
98
  align-items: center;
102
99
  justify-content: center;
103
100
  }
104
- button[data-btn~=text] {
101
+ button[data-btn~=text],
102
+ button .btn-text {
105
103
  --btn-bg: transparent;
106
104
  --btn-cl: currentColor;
107
105
  --btn-bdr: none;
@@ -110,10 +108,12 @@ button[data-btn~=text] {
110
108
  --btn-py: 0.75rem;
111
109
  --btn-px: 0.75rem;
112
110
  }
113
- button[data-btn~=text]:is(:hover, :focus) {
114
- background-color: transparent;
115
- outline: 0.07rem solid var(--btn-cl);
111
+ button[data-btn~=text]:is(:hover, :focus),
112
+ button .btn-text:is(:hover, :focus) {
113
+ background-color: color-mix(in srgb, var(--btn-cl) 10%, transparent);
114
+ outline: 0.025rem solid var(--btn-cl);
116
115
  outline-offset: 0;
116
+ filter: none;
117
117
  }
118
118
 
119
119
  /*# sourceMappingURL=button.css.map */
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../components/buttons/button.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EAEE;EACA;;AAGF;EAEE;;AAGA;EACE;;AAOJ;EAEE;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAIJ;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAGF;EAGE;;AAGF;EACE;EACA;EACA;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA","file":"button.css"}
1
+ {"version":3,"sourceRoot":"","sources":["../../components/buttons/button.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAIA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EAEE;EACA;;AAGF;EAEE;;AAGA;EACE;;AAOJ;EAEE;EACA;EACA;EACA;;AAGA;EACE;EACA;EACA;;AAIJ;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;;AAGF;EAGE;;AAGF;AAAA;EAEE;EACA;;AAGF;AAAA;EAEE;;AAGF;AAAA;EAEE;;AAGF;AAAA;EAEE;;AAGF;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;AAAA;EACE;EACA;EACA;EACA","file":"button.css"}
@@ -47,4 +47,20 @@
47
47
  padding-block-start: calc(var(--card-p) - 0.5rem);
48
48
  }
49
49
 
50
+ [data-card=interactive] {
51
+ cursor: pointer;
52
+ transition: box-shadow 0.2s ease, transform 0.2s ease;
53
+ }
54
+ [data-card=interactive]:hover {
55
+ transform: translateY(-2px);
56
+ box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.15);
57
+ }
58
+ [data-card=interactive]:focus-visible {
59
+ outline: 0.125rem solid var(--focus-color, #0066CC);
60
+ outline-offset: 0.125rem;
61
+ }
62
+ [data-card=interactive]:focus:not(:focus-visible) {
63
+ outline: none;
64
+ }
65
+
50
66
  /*# sourceMappingURL=card.css.map */
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../components/cards/card.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA;;AAEA;AAAA;AAAA;AAAA;EAEE;EACA;;AAEF;AAAA;EACE;;AAEF;AAAA;EACE;EACA;EACA;;AAGF;AAAA;EACE;;AAEF;AAAA;EAEE;;AAEF;AAAA;EACE","file":"card.css"}
1
+ {"version":3,"sourceRoot":"","sources":["../../components/cards/card.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA;;AAEA;AAAA;AAAA;AAAA;EAEE;EACA;;AAEF;AAAA;EACE;;AAEF;AAAA;EACE;EACA;EACA;;AAGF;AAAA;EACE;;AAEF;AAAA;EAEE;;AAEF;AAAA;EACE;;;AAKJ;EACE;EACA;;AAEA;EACE;EACA;;AAIF;EACE;EACA;;AAIF;EACE","file":"card.css"}
@@ -30,6 +30,12 @@ details {
30
30
  max-height: var(--max-h-closed);
31
31
  overflow: clip;
32
32
  }
33
+ @starting-style {
34
+ details {
35
+ transition: var(--summary-transitions);
36
+ color: red;
37
+ }
38
+ }
33
39
  details + details {
34
40
  border-radius: 0;
35
41
  border-top: none;
@@ -59,14 +65,6 @@ details summary {
59
65
  transition: var(--summary-transitions);
60
66
  /* This ensures no bullet points are shown */
61
67
  }
62
- @supports (transition-behavior: allow-discrete) {
63
- @starting-style {
64
- details summary {
65
- border-bottom: none;
66
- transition: var(--summary-transitions);
67
- }
68
- }
69
- }
70
68
  details summary::-webkit-details-marker {
71
69
  display: none;
72
70
  }
@@ -101,5 +99,18 @@ details[open] > summary {
101
99
  details[open] > section {
102
100
  max-height: var(--max-h-open);
103
101
  }
102
+ @starting-style {
103
+ details[open] > section {
104
+ max-height: 0;
105
+ }
106
+ }
107
+ @supports (transition-behavior: allow-discrete) {
108
+ @starting-style {
109
+ details {
110
+ max-height: 0;
111
+ transition: var(--summary-transitions);
112
+ }
113
+ }
114
+ }
104
115
 
105
116
  /*# sourceMappingURL=details.css.map */
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../components/details/details.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAGF;EACE;;AAGF;EACE;;AAIF;EACE;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAmBA;;AAjBA;EACE;IAbJ;MAcM;MACA;;;;AAIJ;EACE;;AAGF;EACE;EACA;EACA;;AAIF;EACE;;AAEF;EACE;;AAKF;EACE;EACA;;AAIJ;EACE;EACA;EACA;EACA;;AAGF;EACE;EACA;;AACA;EACE;;AAEF;EACE","file":"details.css"}
1
+ {"version":3,"sourceRoot":"","sources":["../../components/details/details.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EAjCF;IAkCI;IACA;;;AAGF;EACE;EACA;;AAGF;EACE;;AAGF;EACE;;AAIF;EACE;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAYA;;AAVA;EACE;;AAGF;EACE;EACA;EACA;;AAIF;EACE;;AAEF;EACE;;AAKF;EACE;EACA;;AAIJ;EACE;EACA;EACA;EACA;;AAGF;EACE;EACA;;AACA;EACE;;AAEF;EACE;;AACA;EAFF;IAGI;;;AAKN;EACE;IAxHJ;MAyHM;MACA","file":"details.css"}
@@ -13,8 +13,23 @@
13
13
  --dialog-button-hover-bg: whitesmoke;
14
14
  --dialog-display: flex;
15
15
  --dialog-flex-direction: column;
16
+ /* Focus and accessibility */
17
+ --dialog-focus-color: #0066cc;
18
+ --dialog-focus-width: 0.125rem;
19
+ --dialog-focus-offset: 0.125rem;
20
+ --dialog-focus-outline: var(--dialog-focus-width) solid var(--dialog-focus-color);
16
21
  }
17
22
 
23
+ /* High contrast mode support */
24
+ @media (prefers-contrast: high) {
25
+ :root {
26
+ --dialog-border-color: currentColor;
27
+ --dialog-border-width: 0.125rem;
28
+ --dialog-close-color: currentColor;
29
+ --dialog-button-border: currentColor 0.125rem solid;
30
+ --dialog-focus-width: 0.1875rem;
31
+ }
32
+ }
18
33
  dialog {
19
34
  width: var(--dialog-min-w);
20
35
  min-width: var(--min-w);
@@ -22,7 +37,12 @@ dialog {
22
37
  border: var(--dialog-border-color) var(--dialog-border-width) solid;
23
38
  border-radius: var(--dialog-border-radius);
24
39
  padding: var(--dialog-padding);
25
- padding-block-start: calc(var(--dialog-padding) - 0rem);
40
+ padding-block-start: var(--dialog-padding);
41
+ /* Focus visible for keyboard navigation */
42
+ }
43
+ dialog:focus-visible {
44
+ outline: var(--dialog-focus-outline);
45
+ outline-offset: var(--dialog-focus-offset);
26
46
  }
27
47
  dialog[open] {
28
48
  display: var(--dialog-display);
@@ -57,11 +77,22 @@ dialog section {
57
77
  background-color: var(--dialog-button-bg);
58
78
  border: var(--dialog-button-border);
59
79
  cursor: pointer;
80
+ /* Keyboard focus indicator */
81
+ /* Remove default focus for mouse users */
60
82
  }
61
- .dialog-header button[type=button]:hover, .dialog-header button[type=button]:focus {
83
+ .dialog-header button[type=button]:hover {
62
84
  border-color: var(--dialog-close-color);
63
85
  background-color: var(--dialog-button-hover-bg);
64
86
  }
87
+ .dialog-header button[type=button]:focus-visible {
88
+ outline: var(--dialog-focus-outline);
89
+ outline-offset: var(--dialog-focus-offset);
90
+ border-color: var(--dialog-focus-color);
91
+ background-color: var(--dialog-button-hover-bg);
92
+ }
93
+ .dialog-header button[type=button]:focus:not(:focus-visible) {
94
+ outline: none;
95
+ }
65
96
 
66
97
  .alert-dialog-actions,
67
98
  .dialog-footer {
@@ -71,6 +102,16 @@ dialog section {
71
102
  justify-content: var(--dialog-footer-justify, flex-end);
72
103
  gap: var(--dialog-gap);
73
104
  width: 100%;
105
+ /* Focus styles for footer buttons */
106
+ }
107
+ .alert-dialog-actions button:focus-visible,
108
+ .dialog-footer button:focus-visible {
109
+ outline: var(--dialog-focus-outline);
110
+ outline-offset: var(--dialog-focus-offset);
111
+ }
112
+ .alert-dialog-actions button:focus:not(:focus-visible),
113
+ .dialog-footer button:focus:not(:focus-visible) {
114
+ outline: none;
74
115
  }
75
116
 
76
117
  /*# sourceMappingURL=dialog.css.map */
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../components/dialog/dialog.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;AAEF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;;AAEF;EACE;;AAEF;EACE;EACA;EACA;;AACA;EAEE;EACA;;;AAKN;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA","file":"dialog.css"}
1
+ {"version":3,"sourceRoot":"","sources":["../../components/dialog/dialog.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;EACA;;;AAGF;AACA;EACE;IACE;IACA;IACA;IACA;IACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;;AACA;EACE;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;AAOA;AAQA;;AAbA;EACE;EACA;;AAIF;EACE;EACA;EACA;EACA;;AAIF;EACE;;;AAKN;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA;AAEA;;AACA;AAAA;EACE;EACA;;AAGF;AAAA;EACE","file":"dialog.css"}
@@ -1,21 +1,33 @@
1
+ /**
2
+ * Image component styles
3
+ *
4
+ * Applies to all images with alt attribute (both decorative alt="" and semantic).
5
+ * Uses CSS custom properties for flexible theming and responsive behavior.
6
+ */
1
7
  img[alt] {
8
+ /* CSS Custom Properties - Override these for customization */
2
9
  --img-max-width: 100%;
3
10
  --img-height: auto;
4
11
  --img-object-fit: cover;
5
12
  --img-object-position: center;
6
13
  --img-aspect-ratio: auto 2/3;
7
14
  --img-display: inline-block;
15
+ /* Layout - Responsive by default */
8
16
  max-width: var(--img-max-width);
9
- max-inline-size: var(--img-max-width);
17
+ max-inline-size: var(--img-max-width); /* Logical property for i18n */
10
18
  block-size: var(--img-height);
19
+ display: var(--img-display);
20
+ vertical-align: middle;
21
+ /* Object fitting for responsive images */
11
22
  object-fit: var(--img-object-fit);
12
23
  object-position: var(--img-object-position);
13
24
  aspect-ratio: var(--img-aspect-ratio);
14
- display: var(--img-display);
15
- vertical-align: middle;
25
+ /* Accessibility - Italic font for broken image alt text */
16
26
  font-style: italic;
27
+ /* Background for loading state */
17
28
  background-size: cover;
18
29
  background-repeat: no-repeat;
30
+ /* Shape margin for text wrapping */
19
31
  shape-margin: var(--spc-3);
20
32
  }
21
33
 
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../../components/images/img.scss"],"names":[],"mappings":"AAAA;EACE;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAIA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA","file":"img.css"}
1
+ {"version":3,"sourceRoot":"","sources":["../../components/images/img.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA;AACE;EACA;EACA;EACA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;EACA;EACA;AAEA;EACA;EACA;EACA;AAEA;EACA;AAEA;EACA;EACA;AAEA;EACA;;;AAIA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA","file":"img.css"}