@solid-design-system/styles 1.3.1 → 1.3.3

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 (52) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/cdn/modules/list.css +1 -1
  3. package/cdn/modules/pagination.css +1 -1
  4. package/cdn/modules/prose.css +1 -1
  5. package/cdn/solid-styles.css +1 -1
  6. package/cdn-versioned/modules/chip.css +1 -1
  7. package/cdn-versioned/modules/container.css +1 -1
  8. package/cdn-versioned/modules/copyright.css +1 -1
  9. package/cdn-versioned/modules/display.css +1 -1
  10. package/cdn-versioned/modules/flag.css +1 -1
  11. package/cdn-versioned/modules/footnotes.css +1 -1
  12. package/cdn-versioned/modules/headline.css +1 -1
  13. package/cdn-versioned/modules/hidden-links.css +1 -1
  14. package/cdn-versioned/modules/interactive.css +1 -1
  15. package/cdn-versioned/modules/leadtext.css +1 -1
  16. package/cdn-versioned/modules/list.css +1 -1
  17. package/cdn-versioned/modules/mark.css +1 -1
  18. package/cdn-versioned/modules/media.css +1 -1
  19. package/cdn-versioned/modules/meta.css +1 -1
  20. package/cdn-versioned/modules/pagination.css +1 -1
  21. package/cdn-versioned/modules/paragraph.css +1 -1
  22. package/cdn-versioned/modules/prose.css +1 -1
  23. package/cdn-versioned/modules/status-badge.css +1 -1
  24. package/cdn-versioned/modules/table-cell.css +1 -1
  25. package/cdn-versioned/modules/table.css +1 -1
  26. package/cdn-versioned/solid-styles.css +1 -1
  27. package/dist/modules/list.css +97 -51
  28. package/dist/modules/pagination.css +46 -45
  29. package/dist/modules/prose.css +97 -51
  30. package/dist/solid-styles.css +140 -93
  31. package/dist-versioned/modules/chip.css +6 -6
  32. package/dist-versioned/modules/container.css +45 -45
  33. package/dist-versioned/modules/copyright.css +11 -11
  34. package/dist-versioned/modules/display.css +9 -9
  35. package/dist-versioned/modules/flag.css +6 -6
  36. package/dist-versioned/modules/footnotes.css +26 -26
  37. package/dist-versioned/modules/headline.css +67 -67
  38. package/dist-versioned/modules/hidden-links.css +7 -7
  39. package/dist-versioned/modules/interactive.css +38 -38
  40. package/dist-versioned/modules/leadtext.css +8 -8
  41. package/dist-versioned/modules/list.css +119 -73
  42. package/dist-versioned/modules/mark.css +2 -2
  43. package/dist-versioned/modules/media.css +7 -7
  44. package/dist-versioned/modules/meta.css +12 -12
  45. package/dist-versioned/modules/pagination.css +77 -76
  46. package/dist-versioned/modules/paragraph.css +8 -8
  47. package/dist-versioned/modules/prose.css +303 -257
  48. package/dist-versioned/modules/status-badge.css +8 -8
  49. package/dist-versioned/modules/table-cell.css +23 -23
  50. package/dist-versioned/modules/table.css +4 -4
  51. package/dist-versioned/solid-styles.css +500 -453
  52. package/package.json +1 -1
@@ -8,82 +8,124 @@
8
8
 
9
9
  .sd-list:not(.sd-list--icon),
10
10
  .sd-prose > :is(ol, ul) {
11
+ list-style-position: revert;
12
+ list-style-type: revert;
13
+ padding: revert;
11
14
  padding-top: var(--sd-spacing-4, 1rem) /* 16px */;
12
15
  padding-bottom: var(--sd-spacing-4, 1rem) /* 16px */;
16
+ padding-left: var(--sd-spacing-4, 1rem) /* 16px */;
13
17
  text-align: left;
18
+
19
+ /*
20
+ * Unordered lists
21
+ */
14
22
  }
15
23
 
16
24
  .sd-list:not(.sd-list--icon) li:not(:first-child), .sd-prose > :is(ol, ul) li:not(:first-child) {
17
25
  margin-top: var(--sd-spacing-3, 0.75rem) /* 12px */;
18
26
  }
19
27
 
20
- .sd-list:not(.sd-list--icon) ol,
21
- .sd-list:not(.sd-list--icon) ul,
22
- .sd-prose > :is(ol, ul) ol,
23
- .sd-prose > :is(ol, ul) ul {
24
- padding-top: var(--sd-spacing-3, 0.75rem) /* 12px */;
25
- }
26
-
27
- /* Counter handling for ordered lists. */
28
+ .sd-list:not(.sd-list--icon) ul,
29
+ .sd-list:not(.sd-list--icon) ol,
30
+ .sd-prose > :is(ol, ul) ul,
31
+ .sd-prose > :is(ol, ul) ol {
32
+ all: revert;
33
+ padding-left: 1.4em;
34
+ padding-top: 0.75em;
35
+ }
28
36
 
29
- .sd-list:not(.sd-list--icon):is(ol) > li, .sd-list:not(.sd-list--icon) ol > li, .sd-prose > :is(ol, ul):is(ol) > li, .sd-prose > :is(ol, ul) ol > li {
30
- counter-increment: item;
31
- }
37
+ @supports not (-webkit-hyphens: none) {
32
38
 
33
- .sd-list:not(.sd-list--icon):is(ol) > li:before, .sd-list:not(.sd-list--icon) ol > li:before, .sd-prose > :is(ol, ul):is(ol) > li:before, .sd-prose > :is(ol, ul) ol > li:before {
34
- content: counters(item, '.') '. ';
35
- }
39
+ .sd-list:not(.sd-list--icon),
40
+ .sd-prose > :is(ol, ul) {
41
+ /* Safari automatically adds some spacing. This adds it for other browsers. */
36
42
 
37
- /* Add second level */
43
+ /*
44
+ * Ordered lists
45
+ */
38
46
 
39
- .sd-list:not(.sd-list--icon):is(ol),
40
- .sd-list:not(.sd-list--icon):is(ol) > li > ol,
41
- .sd-list:not(.sd-list--icon) ol > li > ol,
42
- .sd-prose > :is(ol, ul):is(ol),
43
- .sd-prose > :is(ol, ul):is(ol) > li > ol,
44
- .sd-prose > :is(ol, ul) ol > li > ol {
45
- counter-reset: item;
47
+ /*
48
+ * Safari currently only partially supports the ::marker pseudo class.
49
+ * Support is limited to color and font-size. Therefore we optimize the numbering only for non-Safari browsers.
50
+ * https://developer.mozilla.org/en-US/docs/Web/CSS/::marker#browser_compatibility
51
+ */
52
+ /* Level 1 */
53
+ }
54
+ .sd-list:not(.sd-list--icon) li, .sd-prose > :is(ol, ul) li {
55
+ padding-left: 0.3em;
46
56
  }
47
-
48
- /* Ordered lists inside unordered lists. */
49
-
50
- .sd-list:not(.sd-list--icon):is(ul) > li > ol,
51
- .sd-list:not(.sd-list--icon) ul > li > ol,
52
- .sd-prose > :is(ol, ul):is(ul) > li > ol,
53
- .sd-prose > :is(ol, ul) ul > li > ol {
54
- counter-set: item 0;
57
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon), .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) {
58
+ counter-reset: item;
59
+ }
60
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon) > li, .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) > li {
61
+ counter-increment: item;
62
+ }
63
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon) > li::marker, .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) > li::marker {
64
+ content: counters(item, '.', decimal) '. ';
65
+ }
66
+ /* Level 2 */
67
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon) > li > ol, .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) > li > ol {
68
+ padding-left: 1.9em;
69
+ counter-reset: subitem;
70
+ }
71
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon) > li > ol > li, .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) > li > ol > li {
72
+ counter-increment: subitem;
73
+ }
74
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon) > li > ol > li::marker, .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) > li > ol > li::marker {
75
+ content: counters(item, '.', decimal) '.' counters(subitem, '.', decimal) '. ';
76
+ }
77
+ /* Level 3 */
78
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon) > li > ol > li > ol, .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) > li > ol > li > ol {
79
+ padding-left: 2.7em;
80
+ counter-reset: subsubitem;
81
+ }
82
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon) > li > ol > li > ol > li, .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) > li > ol > li > ol > li {
83
+ counter-increment: subsubitem;
84
+ }
85
+ .sd-list:not(.sd-list--icon):is(ol):not(.sd-list--icon) > li > ol > li > ol > li::marker, .sd-prose > :is(ol, ul):is(ol):not(.sd-list--icon) > li > ol > li > ol > li::marker {
86
+ content: counters(item, '.', decimal) '.' counters(subitem, '.', decimal) '.'
87
+ counters(subsubitem, '.', decimal) '. ';
88
+ }
55
89
  }
56
90
 
57
- /* Styling */
91
+ /* Level 1 */
58
92
 
59
- .sd-list:not(.sd-list--icon) li, .sd-prose > :is(ol, ul) li {
60
- display: table;
93
+ .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon),
94
+ .sd-list:not(.sd-list--icon) ul,
95
+ .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon),
96
+ .sd-prose > :is(ol, ul) ul {
97
+ padding-left: 0.5em;
61
98
  }
62
99
 
63
- .sd-list:not(.sd-list--icon) li:before, .sd-prose > :is(ol, ul) li:before {
64
- display: table-cell;
65
- padding-right: var(--sd-spacing-2, 0.5rem) /* 8px */;
100
+ .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon) > li, .sd-list:not(.sd-list--icon) ul > li, .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon) > li, .sd-prose > :is(ol, ul) ul > li {
101
+ padding-left: 0.75em;
102
+ list-style-type: '\2022'; /* */
66
103
  }
67
104
 
68
- .sd-list:not(.sd-list--icon):is(ul),
69
- .sd-list:not(.sd-list--icon) ul,
70
- .sd-prose > :is(ol, ul):is(ul),
71
- .sd-prose > :is(ol, ul) ul {
72
- list-style-type: '';
73
- }
74
-
75
- .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon) > li:before, .sd-list:not(.sd-list--icon) ul > li:before, .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon) > li:before, .sd-prose > :is(ol, ul) ul > li:before {
76
- content: '\2022';
77
- }
105
+ /* Level 2 */
78
106
 
79
- .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon) > li > ul > li:before, .sd-list:not(.sd-list--icon) ul > li > ul > li:before, .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon) > li > ul > li:before, .sd-prose > :is(ol, ul) ul > li > ul > li:before {
80
- content: '\002B1D';
81
- }
107
+ .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon) > li > ul, .sd-list:not(.sd-list--icon) ul > li > ul, .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon) > li > ul, .sd-prose > :is(ol, ul) ul > li > ul {
108
+ padding-left: 0.3em;
109
+ }
82
110
 
83
- .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon) > li > ul > li > ul > li:before, .sd-list:not(.sd-list--icon) ul > li > ul > li > ul > li:before, .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon) > li > ul > li > ul > li:before, .sd-prose > :is(ol, ul) ul > li > ul > li > ul > li:before {
84
- content: '\2010';
111
+ .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon) > li > ul > li, .sd-list:not(.sd-list--icon) ul > li > ul > li, .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon) > li > ul > li, .sd-prose > :is(ol, ul) ul > li > ul > li {
112
+ list-style-type: '\002B1D'; /* · */
85
113
  }
86
114
 
115
+ /* Level 3 */
116
+
117
+ .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon) > li > ul > li > ul, .sd-list:not(.sd-list--icon) ul > li > ul > li > ul, .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon) > li > ul > li > ul, .sd-prose > :is(ol, ul) ul > li > ul > li > ul {
118
+ padding-left: 0.4em;
119
+ }
120
+
121
+ .sd-list:not(.sd-list--icon):is(ul):not(.sd-list--icon) > li > ul > li > ul > li, .sd-list:not(.sd-list--icon) ul > li > ul > li > ul > li, .sd-prose > :is(ol, ul):is(ul):not(.sd-list--icon) > li > ul > li > ul > li, .sd-prose > :is(ol, ul) ul > li > ul > li > ul > li {
122
+ list-style-type: '\2010'; /* - */
123
+ }
124
+
125
+ /*
126
+ * Icon lists
127
+ */
128
+
87
129
  .sd-list--icon {
88
130
  padding-top: var(--sd-spacing-4, 1rem) /* 16px */;
89
131
  padding-bottom: var(--sd-spacing-4, 1rem) /* 16px */;
@@ -137,6 +179,10 @@
137
179
  margin-right: var(--sd-spacing-8, 2rem) /* 32px */;
138
180
  }
139
181
 
182
+ /*
183
+ * Inverted
184
+ */
185
+
140
186
  .sd-list--inverted,
141
187
  .sd-prose--inverted > :is(ol, ul) {
142
188
 
@@ -39,6 +39,8 @@
39
39
 
40
40
  color: rgb(var(--sd-color-primary, 0 53 142) / var(--tw-text-opacity, 1)) /* Primary brand color for text */;
41
41
 
42
+ text-decoration-line: none;
43
+
42
44
  transition-property: color;
43
45
 
44
46
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
@@ -78,7 +80,9 @@
78
80
 
79
81
  height: var(--sd-spacing-12, 3rem) /* 48px */;
80
82
 
81
- width: var(--sd-spacing-12, 3rem) /* 48px */
83
+ width: var(--sd-spacing-12, 3rem) /* 48px */;
84
+
85
+ font-size: var(--sd-font-size-xl, 1.5rem) /* 24px */
82
86
  }
83
87
 
84
88
  .sd-pagination ul li:first-child a, .sd-pagination ul li:last-child a {
@@ -88,13 +92,6 @@
88
92
  width: 100%
89
93
  }
90
94
 
91
- .sd-pagination ul li:first-child sd-icon, .sd-pagination ul li:last-child sd-icon {
92
-
93
- height: var(--sd-spacing-6, 1.5rem) /* 24px */;
94
-
95
- width: var(--sd-spacing-6, 1.5rem) /* 24px */
96
- }
97
-
98
95
  /* Numbers */
99
96
 
100
97
  .sd-pagination ul li {
@@ -112,7 +109,7 @@
112
109
  text-align: center
113
110
  }
114
111
 
115
- .sd-pagination ul li:not(:has(a sd-icon)) a {
112
+ .sd-pagination ul li:not(:first-child):not(:last-child) a {
116
113
 
117
114
  height: 100%;
118
115
 
@@ -123,7 +120,7 @@
123
120
  border-bottom-color: transparent
124
121
  }
125
122
 
126
- .sd-pagination ul li:not(:has(a sd-icon)) a[aria-current] {
123
+ .sd-pagination ul li:not(:first-child):not(:last-child) a[aria-current] {
127
124
 
128
125
  --tw-border-opacity: 1;
129
126
 
@@ -147,7 +144,8 @@
147
144
 
148
145
  /* Previous and next arrow when it has no href */
149
146
 
150
- .sd-pagination ul li:has(a:not([href]) sd-icon) a {
147
+ .sd-pagination ul li:first-child:has(a:not([href])) a,
148
+ .sd-pagination ul li:last-child:has(a:not([href])) a {
151
149
 
152
150
  cursor: not-allowed;
153
151
 
@@ -156,7 +154,8 @@
156
154
  color: rgb(var(--sd-color-neutral-500, 174 174 174) / var(--tw-text-opacity, 1)) /* Used for disabled state */
157
155
  }
158
156
 
159
- .sd-pagination ul li:has(a:not([href]) sd-icon) a:hover:not([disabled]) {
157
+ .sd-pagination ul li:first-child:has(a:not([href])) a:hover:not([disabled]),
158
+ .sd-pagination ul li:last-child:has(a:not([href])) a:hover:not([disabled]) {
160
159
 
161
160
 
162
161
 
@@ -167,57 +166,57 @@
167
166
 
168
167
  /* Number which is not current */
169
168
 
170
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):not(:has(a[aria-current])) {
169
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):not(:has(a[aria-current])) {
171
170
 
172
171
  pointer-events: none;
173
172
 
174
173
  position: absolute
175
174
  }
176
175
 
177
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):not(:has(a[aria-current])) a {
176
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):not(:has(a[aria-current])) a {
178
177
 
179
178
  display: none
180
179
  }
181
180
 
182
181
  /* Apply ellipsis to (n + 2 && n - 1) */
183
182
 
184
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(+ li + li a[aria-current]),
185
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(a[aria-current]) + li + li:not(:last-child) {
183
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(+ li + li a[aria-current]),
184
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(a[aria-current]) + li + li:not(:last-child) {
186
185
 
187
186
  pointer-events: auto !important;
188
187
 
189
188
  position: relative !important
190
189
  }
191
190
 
192
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(+ li + li a[aria-current])::after,
193
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(a[aria-current]) + li + li:not(:last-child)::after {
191
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(+ li + li a[aria-current])::after,
192
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(a[aria-current]) + li + li:not(:last-child)::after {
194
193
 
195
194
  --tw-content: '...';
196
195
 
197
196
  content: var(--tw-content)
198
197
  }
199
198
 
200
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(2),
201
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(2),
202
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(+ li a[aria-current]),
203
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(a[aria-current]) + li {
199
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(2),
200
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(2),
201
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(+ li a[aria-current]),
202
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(a[aria-current]) + li {
204
203
 
205
204
  pointer-events: auto !important;
206
205
 
207
206
  position: relative !important
208
207
  }
209
208
 
210
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(2)::after,
211
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(2)::after,
212
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(+ li a[aria-current])::after,
213
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(a[aria-current]) + li::after {
209
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(2)::after,
210
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(2)::after,
211
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(+ li a[aria-current])::after,
212
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(a[aria-current]) + li::after {
214
213
 
215
214
  content: var(--tw-content) !important;
216
215
 
217
216
  display: none !important
218
217
  }
219
218
 
220
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(2) a, .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(2) a, .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(+ li a[aria-current]) a, .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):has(a[aria-current]) + li a {
219
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(2) a, .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(2) a, .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(+ li a[aria-current]) a, .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):has(a[aria-current]) + li a {
221
220
 
222
221
  display: flex !important
223
222
  }
@@ -226,35 +225,35 @@
226
225
 
227
226
  /* Show until the 5th page (forward) */
228
227
 
229
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(-n + 6) {
228
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(-n + 6) {
230
229
 
231
230
  pointer-events: auto;
232
231
 
233
232
  position: relative
234
233
  }
235
234
 
236
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(-n + 6)::after {
235
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(-n + 6)::after {
237
236
 
238
237
  content: var(--tw-content);
239
238
 
240
239
  display: none
241
240
  }
242
241
 
243
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(-n + 6) a {
242
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(-n + 6) a {
244
243
 
245
244
  display: flex
246
245
  }
247
246
 
248
247
  /* Show ellipsis on the 6th */
249
248
 
250
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(6):not(:last-child) + li {
249
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(6):not(:last-child) + li {
251
250
 
252
251
  pointer-events: none;
253
252
 
254
253
  position: relative
255
254
  }
256
255
 
257
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(6):not(:last-child) + li::after {
256
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(-n + 6):has(a[aria-current]) ~ :nth-child(6):not(:last-child) + li::after {
258
257
 
259
258
  --tw-content: '...';
260
259
 
@@ -263,77 +262,77 @@
263
262
 
264
263
  /* When one of the first 4 pages is selected, show until the 5th page (backward) */
265
264
 
266
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(-n + 6):has(~ :nth-child(-n + 5) a[aria-current]) {
265
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(-n + 6):has(~ :nth-child(-n + 5) a[aria-current]) {
267
266
 
268
267
  pointer-events: auto;
269
268
 
270
269
  position: relative
271
270
  }
272
271
 
273
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(-n + 6):has(~ :nth-child(-n + 5) a[aria-current])::after {
272
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(-n + 6):has(~ :nth-child(-n + 5) a[aria-current])::after {
274
273
 
275
274
  content: var(--tw-content);
276
275
 
277
276
  display: none
278
277
  }
279
278
 
280
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-child(-n + 6):has(~ :nth-child(-n + 5) a[aria-current]) a {
279
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-child(-n + 6):has(~ :nth-child(-n + 5) a[aria-current]) a {
281
280
 
282
281
  display: flex
283
282
  }
284
283
 
285
284
  /* When one of the last 4 pages is selected, show the last 4 pages (forward) */
286
285
 
287
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(-n + 5):has(a[aria-current]) ~ :nth-last-child(-n + 5):not(:has(a sd-icon)) {
286
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(-n + 5):has(a[aria-current]) ~ :nth-last-child(-n + 5):not(:first-child):not(:last-child) {
288
287
 
289
288
  pointer-events: auto;
290
289
 
291
290
  position: relative
292
291
  }
293
292
 
294
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(-n + 5):has(a[aria-current]) ~ :nth-last-child(-n + 5):not(:has(a sd-icon))::after {
293
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(-n + 5):has(a[aria-current]) ~ :nth-last-child(-n + 5):not(:first-child):not(:last-child)::after {
295
294
 
296
295
  content: var(--tw-content);
297
296
 
298
297
  display: none
299
298
  }
300
299
 
301
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(-n + 5):has(a[aria-current]) ~ :nth-last-child(-n + 5):not(:has(a sd-icon)) a {
300
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(-n + 5):has(a[aria-current]) ~ :nth-last-child(-n + 5):not(:first-child):not(:last-child) a {
302
301
 
303
302
  display: flex
304
303
  }
305
304
 
306
305
  /* When one of the last 4 pages is selected, show the last 4 pages (backward) */
307
306
 
308
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(-n + 6):has(~ :nth-last-child(-n + 5) a[aria-current]) {
307
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(-n + 6):has(~ :nth-last-child(-n + 5) a[aria-current]) {
309
308
 
310
309
  pointer-events: auto;
311
310
 
312
311
  position: relative
313
312
  }
314
313
 
315
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(-n + 6):has(~ :nth-last-child(-n + 5) a[aria-current])::after {
314
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(-n + 6):has(~ :nth-last-child(-n + 5) a[aria-current])::after {
316
315
 
317
316
  content: var(--tw-content);
318
317
 
319
318
  display: none
320
319
  }
321
320
 
322
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(-n + 6):has(~ :nth-last-child(-n + 5) a[aria-current]) a {
321
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(-n + 6):has(~ :nth-last-child(-n + 5) a[aria-current]) a {
323
322
 
324
323
  display: flex
325
324
  }
326
325
 
327
326
  /* Show ellipsis on the 6th to last */
328
327
 
329
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(7):has(~ :nth-last-child(-n + 5) a[aria-current]) {
328
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(7):has(~ :nth-last-child(-n + 5) a[aria-current]) {
330
329
 
331
330
  pointer-events: none;
332
331
 
333
332
  position: relative
334
333
  }
335
334
 
336
- .sd-pagination:not(.sd-pagination--simple) ul li:not(:has(a sd-icon)):nth-last-child(7):has(~ :nth-last-child(-n + 5) a[aria-current])::after {
335
+ .sd-pagination:not(.sd-pagination--simple) ul li:not(:first-child):not(:last-child):nth-last-child(7):has(~ :nth-last-child(-n + 5) a[aria-current])::after {
337
336
 
338
337
  --tw-content: '...';
339
338
 
@@ -408,14 +407,16 @@
408
407
  color: rgb(var(--sd-color-white, 255 255 255) / var(--tw-text-opacity, 1)) /* Inverted text color */
409
408
  }
410
409
 
411
- .sd-pagination--inverted ul li:has(a:not([href]) sd-icon) a {
410
+ .sd-pagination--inverted ul li:first-child:has(a:not([href])) a,
411
+ .sd-pagination--inverted ul li:last-child:has(a:not([href])) a {
412
412
 
413
413
 
414
414
 
415
415
  color: rgb(var(--sd-color-neutral-600, 136 136 136) / var(--tw-text-opacity, 1)) /* Used for inverted disabled state */
416
416
  }
417
417
 
418
- .sd-pagination--inverted ul li:has(a:not([href]) sd-icon) a:hover:not([disabled]) {
418
+ .sd-pagination--inverted ul li:first-child:has(a:not([href])) a:hover:not([disabled]),
419
+ .sd-pagination--inverted ul li:last-child:has(a:not([href])) a:hover:not([disabled]) {
419
420
 
420
421
 
421
422