@dsrc-cm/core 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/dist/dsrc.css +10743 -0
  2. package/dist/dsrc.min.css +1 -0
  3. package/package.json +44 -0
  4. package/src/base/print.css +404 -0
  5. package/src/base/reset.css +106 -0
  6. package/src/components/accordion/accordion.css +216 -0
  7. package/src/components/alert/alert.css +187 -0
  8. package/src/components/badge/badge.css +178 -0
  9. package/src/components/breadcrumb/breadcrumb.css +235 -0
  10. package/src/components/button/button.css +805 -0
  11. package/src/components/callout/callout.css +95 -0
  12. package/src/components/card/card.css +551 -0
  13. package/src/components/checkbox/checkbox.css +257 -0
  14. package/src/components/consent/consent.css +297 -0
  15. package/src/components/download/download.css +66 -0
  16. package/src/components/dropdown/dropdown.css +295 -0
  17. package/src/components/highlight/highlight.css +74 -0
  18. package/src/components/input/input.css +337 -0
  19. package/src/components/label/label.css +29 -0
  20. package/src/components/link/link.css +208 -0
  21. package/src/components/logo/logo.css +86 -0
  22. package/src/components/modal/modal.css +271 -0
  23. package/src/components/notice/notice.css +211 -0
  24. package/src/components/pagination/pagination.css +132 -0
  25. package/src/components/password/password.css +195 -0
  26. package/src/components/quote/quote.css +156 -0
  27. package/src/components/radio/radio.css +270 -0
  28. package/src/components/range/range.css +362 -0
  29. package/src/components/search/search.css +129 -0
  30. package/src/components/select/select.css +130 -0
  31. package/src/components/sidemenu/sidemenu.css +268 -0
  32. package/src/components/spinner/spinner.css +73 -0
  33. package/src/components/stepper/stepper.css +140 -0
  34. package/src/components/summary/summary.css +142 -0
  35. package/src/components/tab/tab.css +184 -0
  36. package/src/components/table/table.css +556 -0
  37. package/src/components/tag/tag.css +201 -0
  38. package/src/components/tile/tile.css +389 -0
  39. package/src/components/toggle/toggle.css +229 -0
  40. package/src/components/tooltip/tooltip.css +158 -0
  41. package/src/components/translate/translate.css +356 -0
  42. package/src/components/upload/upload.css +185 -0
  43. package/src/index.css +77 -0
  44. package/src/layout/bandeau/bandeau.css +44 -0
  45. package/src/layout/entete/entete.css +130 -0
  46. package/src/layout/footer/footer.css +107 -0
  47. package/src/layout/grid/grid.css +197 -0
  48. package/src/layout/hero/hero.css +86 -0
  49. package/src/layout/main/main.css +123 -0
  50. package/src/layout/navigation/navigation.css +206 -0
  51. package/src/utilities/utilities.css +430 -0
@@ -0,0 +1,129 @@
1
+ /**
2
+ * DSRC Search Component
3
+ *
4
+ * Usage:
5
+ * <div class="dsrc-search">
6
+ * <input type="search" class="dsrc-search__input" placeholder="Rechercher...">
7
+ * <button class="dsrc-search__btn" aria-label="Rechercher"></button>
8
+ * </div>
9
+ */
10
+
11
+ .dsrc-search {
12
+ display: flex;
13
+ width: 100%;
14
+ max-width: 480px;
15
+ }
16
+
17
+ .dsrc-search[hidden] {
18
+ display: none;
19
+ }
20
+
21
+ .dsrc-search__input {
22
+ flex: 1;
23
+ font-family: var(--dsrc-font-family-sans);
24
+ font-size: var(--dsrc-font-size-small);
25
+ padding: var(--dsrc-spacing-2) var(--dsrc-spacing-3);
26
+ border: var(--dsrc-border-width-default) solid var(--dsrc-color-gris-200);
27
+ border-right: none;
28
+ border-radius: var(--dsrc-radius-default) 0 0 var(--dsrc-radius-default);
29
+ background-color: var(--dsrc-color-blanc);
30
+ color: var(--dsrc-color-noir);
31
+ outline: none;
32
+ transition: border-color var(--dsrc-transition-duration-fast) ease, box-shadow var(--dsrc-transition-duration-fast) ease;
33
+ }
34
+
35
+ .dsrc-search__input::placeholder {
36
+ color: var(--dsrc-color-gris-400);
37
+ }
38
+
39
+ .dsrc-search__input:hover {
40
+ border-color: var(--dsrc-color-gris-400);
41
+ }
42
+
43
+ .dsrc-search__input:focus-visible {
44
+ border-color: var(--dsrc-color-primaire);
45
+ box-shadow: 0 0 0 var(--dsrc-outline-width) var(--dsrc-color-primaire-focus);
46
+ z-index: 1;
47
+ }
48
+
49
+ .dsrc-search__btn {
50
+ display: inline-flex;
51
+ align-items: center;
52
+ justify-content: center;
53
+ padding: var(--dsrc-spacing-2) var(--dsrc-spacing-4);
54
+ background-color: var(--dsrc-color-primaire);
55
+ color: var(--dsrc-color-blanc);
56
+ border: var(--dsrc-border-width-default) solid var(--dsrc-color-primaire);
57
+ border-radius: 0 var(--dsrc-radius-default) var(--dsrc-radius-default) 0;
58
+ cursor: pointer;
59
+ font-size: var(--dsrc-font-size-small);
60
+ transition: background-color var(--dsrc-transition-duration-fast) ease;
61
+ }
62
+
63
+ .dsrc-search__btn::before {
64
+ content: "";
65
+ display: block;
66
+ width: 16px;
67
+ height: 16px;
68
+ background-color: currentColor;
69
+ mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='10.5' cy='10.5' r='7'/%3E%3Cline x1='15.5' y1='15.5' x2='22' y2='22'/%3E%3C/svg%3E");
70
+ mask-size: contain;
71
+ mask-repeat: no-repeat;
72
+ mask-position: center;
73
+ -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='10.5' cy='10.5' r='7'/%3E%3Cline x1='15.5' y1='15.5' x2='22' y2='22'/%3E%3C/svg%3E");
74
+ -webkit-mask-size: contain;
75
+ -webkit-mask-repeat: no-repeat;
76
+ -webkit-mask-position: center;
77
+ }
78
+
79
+ .dsrc-search__btn:hover {
80
+ background-color: var(--dsrc-color-primaire-fonce);
81
+ border-color: var(--dsrc-color-primaire-fonce);
82
+ }
83
+
84
+ .dsrc-search__btn:focus-visible {
85
+ outline: var(--dsrc-outline-width) solid var(--dsrc-color-primaire-focus);
86
+ outline-offset: var(--dsrc-outline-offset);
87
+ }
88
+
89
+ .dsrc-search__btn:active {
90
+ background-color: var(--dsrc-color-primaire);
91
+ }
92
+
93
+ .dsrc-search--lg .dsrc-search__input {
94
+ font-size: var(--dsrc-font-size-body);
95
+ padding: var(--dsrc-spacing-3) var(--dsrc-spacing-4);
96
+ }
97
+
98
+ .dsrc-search--lg .dsrc-search__btn {
99
+ padding: var(--dsrc-spacing-3) var(--dsrc-spacing-5);
100
+ font-size: var(--dsrc-font-size-body);
101
+ }
102
+
103
+ .dsrc-search--lg .dsrc-search__btn::before {
104
+ width: 18px;
105
+ height: 18px;
106
+ }
107
+
108
+
109
+ /* ============================================
110
+ * High contrast (forced-colors)
111
+ * ============================================ */
112
+
113
+ @media (forced-colors: active) {
114
+ .dsrc-search__input {
115
+ border: 1px solid ButtonText;
116
+ }
117
+
118
+ .dsrc-search__btn {
119
+ border: 1px solid ButtonText;
120
+ }
121
+
122
+ .dsrc-search__btn::before {
123
+ background-color: ButtonText;
124
+ }
125
+
126
+ .dsrc-search__btn:focus-visible {
127
+ outline: 2px solid Highlight;
128
+ }
129
+ }
@@ -0,0 +1,130 @@
1
+ /**
2
+ * DSRC Select Component
3
+ *
4
+ * Usage:
5
+ * <div class="dsrc-select-group">
6
+ * <label class="dsrc-label" for="region">Region</label>
7
+ * <select class="dsrc-select-group__select" id="region">
8
+ * <option value="">Selectionnez...</option>
9
+ * <option value="ce">Centre</option>
10
+ * </select>
11
+ * <p class="dsrc-select-group__help">Selectionnez votre region</p>
12
+ * </div>
13
+ */
14
+
15
+ .dsrc-select-group {
16
+ display: flex;
17
+ flex-direction: column;
18
+ gap: var(--dsrc-spacing-1);
19
+ margin-bottom: var(--dsrc-spacing-4);
20
+ }
21
+
22
+ .dsrc-select-group__select {
23
+ display: block;
24
+ width: 100%;
25
+ font-family: var(--dsrc-font-family-sans);
26
+ font-size: var(--dsrc-font-size-small);
27
+ padding: var(--dsrc-spacing-2) 34px var(--dsrc-spacing-2) var(--dsrc-spacing-3);
28
+ border: var(--dsrc-border-width-default) solid var(--dsrc-color-gris-200);
29
+ border-radius: var(--dsrc-radius-default);
30
+ background-color: var(--dsrc-color-blanc);
31
+ color: var(--dsrc-color-noir);
32
+ outline: none;
33
+ appearance: none;
34
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23555' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
35
+ background-repeat: no-repeat;
36
+ background-position: right var(--dsrc-spacing-3) center;
37
+ cursor: pointer;
38
+ transition: border-color var(--dsrc-transition-duration-fast) ease, box-shadow var(--dsrc-transition-duration-fast) ease;
39
+ }
40
+
41
+ .dsrc-select-group__select:hover {
42
+ border-color: var(--dsrc-color-gris-400);
43
+ }
44
+
45
+ .dsrc-select-group__select:focus-visible {
46
+ border-color: var(--dsrc-color-primaire);
47
+ box-shadow: 0 0 0 var(--dsrc-outline-width) var(--dsrc-color-primaire-focus);
48
+ }
49
+
50
+ .dsrc-select-group__select:disabled {
51
+ background-color: var(--dsrc-color-gris-100);
52
+ color: var(--dsrc-color-gris-600);
53
+ cursor: not-allowed;
54
+ }
55
+
56
+ /* Error state (DSFR left-bar pattern, aligned with input) */
57
+ .dsrc-select-group--error {
58
+ border-left: var(--dsrc-border-width-thick) solid var(--dsrc-color-erreur-bordure);
59
+ padding-left: var(--dsrc-spacing-4);
60
+ }
61
+
62
+ .dsrc-select-group--error .dsrc-select-group__select {
63
+ border-color: var(--dsrc-color-erreur-bordure);
64
+ border-width: 2px;
65
+ }
66
+
67
+ .dsrc-select-group--error .dsrc-select-group__select:focus-visible {
68
+ box-shadow: 0 0 0 var(--dsrc-outline-width) rgba(197, 48, 48, 0.12);
69
+ }
70
+
71
+ .dsrc-select-group--error .dsrc-label {
72
+ color: var(--dsrc-color-erreur-texte);
73
+ }
74
+
75
+ /* Valid state (aligned with input) */
76
+ .dsrc-select-group--valid {
77
+ border-left: var(--dsrc-border-width-thick) solid var(--dsrc-color-succes-bordure);
78
+ padding-left: var(--dsrc-spacing-4);
79
+ }
80
+
81
+ .dsrc-select-group--valid .dsrc-select-group__select {
82
+ border-color: var(--dsrc-color-succes-bordure);
83
+ border-width: 2px;
84
+ }
85
+
86
+ .dsrc-select-group--valid .dsrc-select-group__select:focus-visible {
87
+ box-shadow: 0 0 0 var(--dsrc-outline-width) rgba(24, 128, 56, 0.12);
88
+ }
89
+
90
+ .dsrc-select-group--valid .dsrc-label {
91
+ color: var(--dsrc-color-succes-texte);
92
+ }
93
+
94
+ .dsrc-select-group__valid {
95
+ font-size: var(--dsrc-font-size-caption);
96
+ font-weight: var(--dsrc-font-weight-medium);
97
+ color: var(--dsrc-color-succes-texte);
98
+ }
99
+
100
+ .dsrc-select-group__help {
101
+ font-size: var(--dsrc-font-size-caption);
102
+ color: var(--dsrc-color-gris-600);
103
+ }
104
+
105
+ .dsrc-select-group__error {
106
+ font-size: var(--dsrc-font-size-caption);
107
+ font-weight: var(--dsrc-font-weight-medium);
108
+ color: var(--dsrc-color-erreur-texte);
109
+ }
110
+
111
+
112
+ /* ============================================
113
+ * High contrast (forced-colors)
114
+ * ============================================ */
115
+
116
+ @media (forced-colors: active) {
117
+ .dsrc-select-group__select {
118
+ border: 1px solid ButtonText;
119
+ }
120
+
121
+ .dsrc-select-group__select:disabled {
122
+ border-color: GrayText;
123
+ color: GrayText;
124
+ }
125
+
126
+ .dsrc-select-group--error .dsrc-select-group__select {
127
+ border-color: LinkText;
128
+ border-width: 2px;
129
+ }
130
+ }
@@ -0,0 +1,268 @@
1
+ /**
2
+ * DSRC Sidemenu Component
3
+ *
4
+ * Lateral navigation menu with collapsible nested levels.
5
+ *
6
+ * Variants:
7
+ * --sticky ... Sticks to viewport on scroll (desktop)
8
+ *
9
+ * Usage:
10
+ * <nav class="dsrc-sidemenu" role="navigation" aria-label="Menu latéral">
11
+ * <div class="dsrc-sidemenu__inner">
12
+ * <button class="dsrc-sidemenu__btn" aria-expanded="false"
13
+ * aria-controls="sm-list">Menu</button>
14
+ * <div class="dsrc-sidemenu__wrapper" id="sm-list">
15
+ * <ul class="dsrc-sidemenu__list">
16
+ * <li class="dsrc-sidemenu__item">
17
+ * <a class="dsrc-sidemenu__link" href="#"
18
+ * aria-current="page">Accueil</a>
19
+ * </li>
20
+ * <li class="dsrc-sidemenu__item">
21
+ * <button class="dsrc-sidemenu__link"
22
+ * aria-expanded="false"
23
+ * aria-controls="sub1">Services</button>
24
+ * <ul class="dsrc-sidemenu__list" id="sub1">
25
+ * <li class="dsrc-sidemenu__item">
26
+ * <a class="dsrc-sidemenu__link" href="#">Sous-page</a>
27
+ * </li>
28
+ * </ul>
29
+ * </li>
30
+ * </ul>
31
+ * </div>
32
+ * </div>
33
+ * </nav>
34
+ */
35
+
36
+
37
+ /* ============================================
38
+ * 1. Base sidemenu
39
+ * ============================================ */
40
+
41
+ .dsrc-sidemenu {
42
+ position: relative;
43
+ }
44
+
45
+ .dsrc-sidemenu__inner {
46
+ padding-right: var(--dsrc-spacing-8);
47
+ }
48
+
49
+
50
+ /* ============================================
51
+ * 2. Mobile toggle button
52
+ * ============================================ */
53
+
54
+ .dsrc-sidemenu__btn {
55
+ display: flex;
56
+ align-items: center;
57
+ width: 100%;
58
+ padding: var(--dsrc-spacing-3) var(--dsrc-spacing-4);
59
+ font-family: var(--dsrc-font-family-sans);
60
+ font-size: var(--dsrc-font-size-body);
61
+ font-weight: 700;
62
+ color: var(--dsrc-color-noir);
63
+ background: none;
64
+ border: none;
65
+ border-bottom: 1px solid var(--dsrc-color-gris-200);
66
+ cursor: pointer;
67
+ text-align: left;
68
+ }
69
+
70
+ .dsrc-sidemenu__btn::after {
71
+ content: '';
72
+ display: inline-block;
73
+ width: 16px;
74
+ height: 16px;
75
+ margin-left: auto;
76
+ background-color: currentColor;
77
+ -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6z'/%3E%3C/svg%3E");
78
+ mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6z'/%3E%3C/svg%3E");
79
+ -webkit-mask-size: contain;
80
+ mask-size: contain;
81
+ -webkit-mask-repeat: no-repeat;
82
+ mask-repeat: no-repeat;
83
+ transition: transform 0.2s;
84
+ }
85
+
86
+ .dsrc-sidemenu__btn[aria-expanded="true"]::after {
87
+ transform: rotate(180deg);
88
+ }
89
+
90
+ .dsrc-sidemenu__btn:focus-visible {
91
+ outline: 2px solid var(--dsrc-color-primaire);
92
+ outline-offset: 2px;
93
+ }
94
+
95
+ @media (min-width: 768px) {
96
+ .dsrc-sidemenu__btn {
97
+ display: none;
98
+ }
99
+ }
100
+
101
+
102
+ /* ============================================
103
+ * 3. Wrapper (collapsible on mobile)
104
+ * ============================================ */
105
+
106
+ .dsrc-sidemenu__wrapper {
107
+ overflow: hidden;
108
+ max-height: 0;
109
+ transition: max-height 0.3s ease-out;
110
+ }
111
+
112
+ .dsrc-sidemenu__btn[aria-expanded="true"] + .dsrc-sidemenu__wrapper {
113
+ max-height: 2000px;
114
+ }
115
+
116
+ @media (min-width: 768px) {
117
+ .dsrc-sidemenu__wrapper {
118
+ max-height: none;
119
+ overflow: visible;
120
+ }
121
+ }
122
+
123
+
124
+ /* ============================================
125
+ * 4. List & items
126
+ * ============================================ */
127
+
128
+ .dsrc-sidemenu__list {
129
+ list-style: none;
130
+ padding: 0;
131
+ margin: 0;
132
+ }
133
+
134
+ .dsrc-sidemenu__item {
135
+ position: relative;
136
+ }
137
+
138
+ /* Nested lists */
139
+ .dsrc-sidemenu__item .dsrc-sidemenu__list {
140
+ overflow: hidden;
141
+ max-height: 0;
142
+ transition: max-height 0.3s ease-out;
143
+ padding-left: var(--dsrc-spacing-4);
144
+ }
145
+
146
+ .dsrc-sidemenu__link[aria-expanded="true"] + .dsrc-sidemenu__list {
147
+ max-height: 2000px;
148
+ }
149
+
150
+
151
+ /* ============================================
152
+ * 5. Links
153
+ * ============================================ */
154
+
155
+ .dsrc-sidemenu__link {
156
+ display: flex;
157
+ align-items: center;
158
+ width: 100%;
159
+ padding: var(--dsrc-spacing-2) var(--dsrc-spacing-3);
160
+ font-family: var(--dsrc-font-family-sans);
161
+ font-size: var(--dsrc-font-size-body);
162
+ line-height: 1.5;
163
+ color: var(--dsrc-color-noir);
164
+ text-decoration: none;
165
+ background: none;
166
+ border: none;
167
+ border-left: 2px solid transparent;
168
+ cursor: pointer;
169
+ text-align: left;
170
+ }
171
+
172
+ .dsrc-sidemenu__link:hover {
173
+ background-color: var(--dsrc-color-gris-50);
174
+ }
175
+
176
+ .dsrc-sidemenu__link:focus-visible {
177
+ outline: 2px solid var(--dsrc-color-primaire);
178
+ outline-offset: 2px;
179
+ }
180
+
181
+ .dsrc-sidemenu__link[aria-current="page"] {
182
+ color: var(--dsrc-color-primaire);
183
+ border-left-color: var(--dsrc-color-primaire);
184
+ font-weight: 700;
185
+ }
186
+
187
+ /* Expand icon for parent items */
188
+ button.dsrc-sidemenu__link::after {
189
+ content: '';
190
+ display: inline-block;
191
+ width: 16px;
192
+ height: 16px;
193
+ margin-left: auto;
194
+ background-color: currentColor;
195
+ -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6z'/%3E%3C/svg%3E");
196
+ mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6z'/%3E%3C/svg%3E");
197
+ -webkit-mask-size: contain;
198
+ mask-size: contain;
199
+ -webkit-mask-repeat: no-repeat;
200
+ mask-repeat: no-repeat;
201
+ transition: transform 0.2s;
202
+ }
203
+
204
+ button.dsrc-sidemenu__link[aria-expanded="true"]::after {
205
+ transform: rotate(180deg);
206
+ }
207
+
208
+
209
+ /* ============================================
210
+ * 6. Sticky variant
211
+ * ============================================ */
212
+
213
+ @media (min-width: 768px) {
214
+ .dsrc-sidemenu--sticky .dsrc-sidemenu__inner {
215
+ position: sticky;
216
+ top: var(--dsrc-spacing-4);
217
+ }
218
+ }
219
+
220
+
221
+ /* ============================================
222
+ * 7. High contrast (forced-colors)
223
+ * ============================================ */
224
+
225
+ @media (forced-colors: active) {
226
+ .dsrc-sidemenu__link[aria-current="page"] {
227
+ border-left-color: Highlight;
228
+ }
229
+
230
+ .dsrc-sidemenu__btn {
231
+ border: 1px solid ButtonText;
232
+ }
233
+ }
234
+
235
+
236
+ /* ============================================
237
+ * 8. Reduced motion
238
+ * ============================================ */
239
+
240
+ @media (prefers-reduced-motion: reduce) {
241
+ .dsrc-sidemenu__wrapper,
242
+ .dsrc-sidemenu__item .dsrc-sidemenu__list,
243
+ .dsrc-sidemenu__btn::after,
244
+ button.dsrc-sidemenu__link::after {
245
+ transition: none;
246
+ }
247
+ }
248
+
249
+
250
+ /* ============================================
251
+ * 9. Print
252
+ * ============================================ */
253
+
254
+ @media print {
255
+ .dsrc-sidemenu__btn {
256
+ display: none;
257
+ }
258
+
259
+ .dsrc-sidemenu__wrapper {
260
+ max-height: none;
261
+ overflow: visible;
262
+ }
263
+
264
+ .dsrc-sidemenu__item .dsrc-sidemenu__list {
265
+ max-height: none;
266
+ overflow: visible;
267
+ }
268
+ }
@@ -0,0 +1,73 @@
1
+ /**
2
+ * DSRC Spinner Component
3
+ *
4
+ * Usage:
5
+ * <div class="dsrc-spinner" role="status" aria-label="Chargement..."></div>
6
+ *
7
+ * Sizes:
8
+ * .dsrc-spinner--sm (16px)
9
+ * .dsrc-spinner--lg (40px)
10
+ *
11
+ * Overlay:
12
+ * <div class="dsrc-spinner-overlay">
13
+ * <div class="dsrc-spinner dsrc-spinner--lg" role="status" aria-label="Chargement..."></div>
14
+ * </div>
15
+ */
16
+
17
+ @keyframes dsrc-spin {
18
+ from {
19
+ transform: rotate(0deg);
20
+ }
21
+ to {
22
+ transform: rotate(360deg);
23
+ }
24
+ }
25
+
26
+ /* Base spinner */
27
+ .dsrc-spinner {
28
+ display: inline-block;
29
+ width: 24px;
30
+ height: 24px;
31
+ border: var(--dsrc-border-width-thick) solid var(--dsrc-color-gris-200);
32
+ border-top-color: var(--dsrc-color-primaire);
33
+ border-radius: var(--dsrc-radius-round);
34
+ animation: dsrc-spin 0.7s linear infinite;
35
+ }
36
+
37
+ /* Small */
38
+ .dsrc-spinner--sm {
39
+ width: 16px;
40
+ height: 16px;
41
+ border-width: 2px;
42
+ }
43
+
44
+ /* Large */
45
+ .dsrc-spinner--lg {
46
+ width: 40px;
47
+ height: 40px;
48
+ border-width: 4px;
49
+ }
50
+
51
+ /* Overlay */
52
+ .dsrc-spinner-overlay {
53
+ position: fixed;
54
+ inset: 0;
55
+ display: flex;
56
+ align-items: center;
57
+ justify-content: center;
58
+ background-color: rgba(255, 255, 255, 0.8);
59
+ z-index: var(--dsrc-z-index-overlay);
60
+ }
61
+
62
+
63
+ /* ============================================
64
+ * Reduced motion
65
+ * ============================================ */
66
+
67
+ @media (prefers-reduced-motion: reduce) {
68
+ .dsrc-spinner {
69
+ animation: none;
70
+ border-top-color: var(--dsrc-color-primaire);
71
+ opacity: 0.7;
72
+ }
73
+ }