@primer/view-components 0.45.2 → 0.46.0-rc.4214e155

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 (73) hide show
  1. package/app/assets/styles/primer_view_components.css +1 -6963
  2. package/app/assets/styles/primer_view_components.css.map +1 -1
  3. package/app/components/primer/alpha/action_bar.css +1 -49
  4. package/app/components/primer/alpha/action_list.css +1 -525
  5. package/app/components/primer/alpha/action_list.css.json +64 -64
  6. package/app/components/primer/alpha/auto_complete.css +1 -131
  7. package/app/components/primer/alpha/auto_complete.css.json +3 -3
  8. package/app/components/primer/alpha/banner.css +1 -146
  9. package/app/components/primer/alpha/banner.css.json +2 -2
  10. package/app/components/primer/alpha/button_marketing.css +1 -183
  11. package/app/components/primer/alpha/button_marketing.css.json +6 -6
  12. package/app/components/primer/alpha/dialog.css +1 -377
  13. package/app/components/primer/alpha/dialog.css.json +2 -2
  14. package/app/components/primer/alpha/dropdown.css +1 -296
  15. package/app/components/primer/alpha/dropdown.css.json +19 -19
  16. package/app/components/primer/alpha/layout.css +1 -374
  17. package/app/components/primer/alpha/layout.css.json +10 -10
  18. package/app/components/primer/alpha/menu.css +1 -124
  19. package/app/components/primer/alpha/menu.css.json +5 -5
  20. package/app/components/primer/alpha/overlay.css +1 -25
  21. package/app/components/primer/alpha/segmented_control.css +1 -161
  22. package/app/components/primer/alpha/segmented_control.css.json +5 -5
  23. package/app/components/primer/alpha/select_panel.css +1 -10
  24. package/app/components/primer/alpha/skeleton_box.css +1 -36
  25. package/app/components/primer/alpha/stack.css +1 -255
  26. package/app/components/primer/alpha/stack.css.json +84 -84
  27. package/app/components/primer/alpha/stack_item.css +1 -27
  28. package/app/components/primer/alpha/stack_item.css.json +6 -6
  29. package/app/components/primer/alpha/tab_nav.css +1 -112
  30. package/app/components/primer/alpha/tab_nav.css.json +5 -5
  31. package/app/components/primer/alpha/text_field.css +1 -792
  32. package/app/components/primer/alpha/text_field.css.json +39 -39
  33. package/app/components/primer/alpha/toggle_switch.css +1 -230
  34. package/app/components/primer/alpha/toggle_switch.css.json +10 -10
  35. package/app/components/primer/alpha/tree_view.css +1 -396
  36. package/app/components/primer/alpha/tree_view.css.json +25 -25
  37. package/app/components/primer/alpha/underline_nav.css +1 -150
  38. package/app/components/primer/alpha/underline_nav.css.json +6 -6
  39. package/app/components/primer/beta/avatar.css +1 -77
  40. package/app/components/primer/beta/avatar_stack.css +1 -134
  41. package/app/components/primer/beta/avatar_stack.css.json +6 -6
  42. package/app/components/primer/beta/blankslate.css +1 -168
  43. package/app/components/primer/beta/border_box.css +1 -218
  44. package/app/components/primer/beta/border_box.css.json +3 -3
  45. package/app/components/primer/beta/breadcrumbs.css +1 -29
  46. package/app/components/primer/beta/breadcrumbs.css.json +2 -2
  47. package/app/components/primer/beta/button.css +1 -359
  48. package/app/components/primer/beta/button.css.json +17 -17
  49. package/app/components/primer/beta/button_group.css +1 -20
  50. package/app/components/primer/beta/button_group.css.json +3 -3
  51. package/app/components/primer/beta/counter.css +1 -38
  52. package/app/components/primer/beta/flash.css +1 -152
  53. package/app/components/primer/beta/label.css +1 -109
  54. package/app/components/primer/beta/label.css.json +3 -3
  55. package/app/components/primer/beta/link.css +1 -79
  56. package/app/components/primer/beta/link.css.json +1 -1
  57. package/app/components/primer/beta/popover.css +1 -215
  58. package/app/components/primer/beta/popover.css.json +23 -23
  59. package/app/components/primer/beta/progress_bar.css +1 -38
  60. package/app/components/primer/beta/progress_bar.css.json +1 -1
  61. package/app/components/primer/beta/state.css +1 -60
  62. package/app/components/primer/beta/state.css.json +1 -1
  63. package/app/components/primer/beta/subhead.css +1 -64
  64. package/app/components/primer/beta/subhead.css.json +1 -1
  65. package/app/components/primer/beta/timeline_item.css +1 -106
  66. package/app/components/primer/beta/timeline_item.css.json +1 -1
  67. package/app/components/primer/beta/truncate.css +1 -30
  68. package/app/components/primer/beta/truncate.css.json +6 -6
  69. package/app/components/primer/truncate.css +1 -23
  70. package/app/components/primer/truncate.css.json +4 -4
  71. package/package.json +1 -1
  72. package/static/arguments.json +1 -7
  73. package/static/info_arch.json +1 -7
@@ -1,792 +1 @@
1
- /* stylelint-disable selector-max-type */
2
- /* stylelint-disable max-nesting-depth */
3
- /* stylelint-disable selector-max-specificity */
4
- /* stylelint-disable primer/spacing */
5
- /* FormControl */
6
- /* groups label, field, caption and inline error message */
7
- .FormControl {
8
- display: inline-flex;
9
- flex-direction: column;
10
- gap: var(--base-size-4);
11
- }
12
- /* fill container */
13
- .FormControl--fullWidth {
14
- display: flex;
15
- }
16
- /* <label> */
17
- .FormControl-label {
18
- font-size: var(--text-body-size-medium);
19
- font-weight: var(--base-text-weight-semibold);
20
- line-height: var(--text-body-lineHeight-medium);
21
- color: var(--fgColor-default);
22
- }
23
- /* optional caption */
24
- .FormControl-caption {
25
- margin-bottom: 0;
26
- font-size: var(--text-caption-size);
27
- font-weight: var(--text-caption-weight);
28
- line-height: var(--text-caption-lineHeight);
29
- color: var(--fgColor-muted);
30
- }
31
- /* inline validation message */
32
- .FormControl-inlineValidation {
33
- display: flex;
34
- font-size: var(--text-caption-size);
35
- font-weight: var(--base-text-weight-semibold);
36
- line-height: var(--text-caption-lineHeight);
37
- color: var(--control-danger-fgColor-rest);
38
- fill: var(--control-danger-fgColor-rest);
39
- flex-direction: row;
40
- align-items: flex-start;
41
- gap: var(--base-size-4);
42
- }
43
- .FormControl-inlineValidation p {
44
- margin-bottom: 0;
45
- }
46
- .FormControl-inlineValidation--success {
47
- color: var(--fgColor-success);
48
- fill: var(--fgColor-success);
49
- }
50
- .FormControl-inlineValidation--visual {
51
- align-items: center;
52
- display: flex;
53
- min-height: var(--base-size-16);
54
- }
55
- .FormControl-spacingWrapper {
56
- display: flex;
57
- flex-direction: column;
58
- row-gap: var(--stack-gap-normal);
59
- }
60
- .FormControl-horizontalGroup {
61
- display: flex;
62
- column-gap: 0.5rem;
63
- }
64
- /* shared among all form control components (input, select, textarea, checkbox, radio) */
65
- /* TextInput structure
66
- ** ===================
67
- **
68
- ** .FormControl
69
- ** ├─ .FormControl-label
70
- ** │ ├─ .FormControl-input-wrap
71
- ** │ │ ├─ .FormControl-input-trailingVisualWrap
72
- ** │ │ │ ├─ .FormControl-input-trailingVisual
73
- ** │ │ ├─ .FormControl-input-leadingVisualWrap
74
- ** │ │ │ ├─ .FormControl-input-leadingVisual
75
- ** │ │ ├─ .FormControl-input
76
- ** │ │ ├─ .FormControl-input-trailingAction
77
- ** ├─ .FormControl-inlineValidation
78
- ** ├─ .FormControl-caption */
79
- /* // Select structure
80
- ** ===================
81
- **
82
- ** .FormControl
83
- ** ├─ .FormControl-label
84
- ** │ ├─ .FormControl-select-wrap
85
- ** │ │ ├─ .FormControl-select
86
- ** ├─ .FormControl-inlineValidation
87
- ** ├─ .FormControl-caption */
88
- /* // Textarea structure
89
- ** ===================
90
- **
91
- ** .FormControl
92
- ** ├─ .FormControl-label
93
- ** ├─ .FormControl-textarea
94
- ** ├─ .FormControl-inlineValidation
95
- ** ├─ .FormControl-caption */
96
- .FormControl-input,
97
- .FormControl-select,
98
- .FormControl-textarea {
99
- color: var(--fgColor-default);
100
- background-color: var(--bgColor-default);
101
- border: var(--borderWidth-thin) solid var(--control-borderColor-rest, var(--color-border-default));
102
- box-shadow: var(--shadow-inset);
103
- }
104
- [disabled]:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
105
- color: var(--control-fgColor-disabled);
106
- cursor: not-allowed;
107
- background-color: var(--control-bgColor-disabled);
108
- border-color: var(--control-borderColor-disabled);
109
- box-shadow: none;
110
- opacity: 1;
111
- -webkit-text-fill-color: var(--control-fgColor-disabled);
112
- }
113
- [invalid='true']:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not(:focus) {
114
- border-color: var(--control-borderColor-danger);
115
- }
116
- [invalid='false']:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not(:focus) {
117
- border-color: var(--control-borderColor-success);
118
- }
119
- :is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type='checkbox'],[type='radio']):focus {
120
- border-color: var(--focus-outlineColor);
121
- outline: none;
122
- box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
123
-
124
- /* remove fallback :focus if :focus-visible is supported */
125
- }
126
- :is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type='checkbox'],[type='radio']):focus:not(:focus-visible) {
127
- border-color: transparent;
128
-
129
- border-color: var(--focus-outlineColor);
130
-
131
- outline: none;
132
-
133
- box-shadow: inset 0 0 0 1px transparent var(--focus-outlineColor);
134
- }
135
- /* default focus state */
136
- :is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type='checkbox'],[type='radio']):focus-visible {
137
- border-color: var(--focus-outlineColor);
138
- outline: none;
139
- box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
140
- }
141
- .FormControl-input,
142
- .FormControl-select,
143
- .FormControl-textarea {
144
-
145
- width: 100%;
146
- font-size: var(--text-body-size-medium);
147
- line-height: var(--text-body-lineHeight-medium);
148
- border-radius: var(--borderRadius-medium);
149
- transition: 80ms cubic-bezier(0.33, 1, 0.68, 1);
150
- transition-property: color, background-color, box-shadow, border-color;
151
- padding-inline: var(--control-medium-paddingInline-condensed);
152
- padding-block: calc(var(--control-medium-paddingBlock) - var(--borderWidth-thin));
153
- }
154
- [disabled]:is(.FormControl-input,.FormControl-select,.FormControl-textarea)::placeholder {
155
- color: var(--control-fgColor-disabled);
156
- }
157
- [readonly]:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
158
- background-color: var(--control-bgColor-disabled);
159
- }
160
- :is(.FormControl-input,.FormControl-select,.FormControl-textarea)::placeholder {
161
- color: var(--control-fgColor-placeholder);
162
- opacity: 1;
163
- }
164
- /* sizes */
165
- .FormControl-small:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
166
- height: var(--control-small-size);
167
- padding-inline: var(--control-small-paddingInline-normal);
168
- padding-block: var(--control-small-paddingBlock);
169
- font-size: var(--text-body-size-small);
170
- }
171
- .FormControl-medium:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
172
- height: var(--control-medium-size);
173
- }
174
- .FormControl-large:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
175
- height: var(--control-large-size);
176
- padding-inline: var(--control-large-paddingInline-normal);
177
- padding-block: var(--control-large-paddingBlock);
178
- }
179
- /* variants */
180
- .FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
181
- background-color: var(--bgColor-muted);
182
- }
183
- .FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea):focus-visible,.FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea):focus {
184
- background-color: var(--bgColor-default);
185
- }
186
- .FormControl-monospace:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
187
- font-family: var(--fontStack-monospace);
188
- }
189
- /* validation states */
190
- .FormControl-error:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
191
- border-color: var(--control-borderColor-danger);
192
- }
193
- .FormControl-success:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
194
- border-color: var(--control-borderColor-success);
195
- }
196
- .FormControl-warning:is(.FormControl-input,.FormControl-select,.FormControl-textarea) {
197
- border-color: var(--control-borderColor-warning);
198
- }
199
- .FormControl-toggleSwitchInput {
200
- display: flex;
201
- align-items: flex-start;
202
- gap: var(--base-size-16);
203
- }
204
- /* positioning for leading/trailing items for TextInput */
205
- .FormControl-input-wrap {
206
- position: relative;
207
- display: grid;
208
- }
209
- .FormControl-input-wrap .FormControl-input-leadingVisualWrap {
210
- position: absolute;
211
- top: var(--base-size-8);
212
- left: var(--base-size-8);
213
- display: block;
214
- width: var(--base-size-16);
215
- height: var(--base-size-16);
216
- color: var(--fgColor-muted);
217
- pointer-events: none;
218
-
219
- /* octicon */
220
- }
221
- :is(.FormControl-input-wrap .FormControl-input-leadingVisualWrap) .FormControl-input-leadingVisual {
222
- display: block;
223
- -webkit-user-select: none;
224
- user-select: none;
225
- }
226
- .FormControl-input-wrap .FormControl-input-trailingVisualWrap {
227
- position: absolute;
228
- top: var(--base-size-8);
229
- right: var(--base-size-8);
230
- display: flex;
231
- height: var(--base-size-16);
232
- align-items: center;
233
- gap: var(--base-size-4);
234
- color: var(--fgColor-muted);
235
- pointer-events: none;
236
- }
237
- :is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap):has(.FormControl-input-trailingVisualText) {
238
- max-width: 25%;
239
- padding-left: var(--base-size-8);
240
- }
241
- :is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap):has(.FormControl-input-trailingVisualLabel) {
242
- max-width: 25%;
243
- padding-left: var(--base-size-8);
244
- }
245
- :is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap) .FormControl-input-trailingVisualLabel {
246
- overflow: hidden;
247
- text-overflow: ellipsis;
248
- }
249
- /* TODO: replace with new Button component */
250
- .FormControl-input-wrap .FormControl-input-trailingAction {
251
- position: absolute;
252
- top: var(--base-size-4);
253
- right: var(--base-size-4);
254
- z-index: 4;
255
- display: grid;
256
- width: var(--control-xsmall-size);
257
- height: var(--control-xsmall-size);
258
- padding: 0;
259
- color: var(--fgColor-muted);
260
- cursor: pointer;
261
- background: transparent;
262
- border: 0;
263
- border-radius: var(--borderRadius-small);
264
- transition: 0.2s cubic-bezier(0.3, 0, 0.5, 1);
265
- transition-property: color, background-color, border-color;
266
- align-items: center;
267
- justify-content: center;
268
- }
269
- :is(.FormControl-input-wrap .FormControl-input-trailingAction) svg {
270
- -webkit-user-select: none;
271
- user-select: none;
272
- }
273
- [disabled]:is(.FormControl-input-wrap .FormControl-input-trailingAction) {
274
- color: var(--control-fgColor-disabled);
275
- pointer-events: none;
276
- }
277
- :is(.FormControl-input-wrap .FormControl-input-trailingAction):hover {
278
- background: var(--control-transparent-bgColor-hover);
279
- }
280
- :is(.FormControl-input-wrap .FormControl-input-trailingAction):active {
281
- background: var(--control-transparent-bgColor-active);
282
- }
283
- /* show vertical divider line between field and button */
284
- .FormControl-input-trailingAction--divider:is(.FormControl-input-wrap .FormControl-input-trailingAction)::before {
285
- position: absolute;
286
- top: calc((var(--control-xsmall-size) - var(--base-size-16)) / 2);
287
- left: calc(var(--base-size-4) * -1);
288
- display: block;
289
- width: var(--borderWidth-thin);
290
- height: var(--base-size-16);
291
- content: '';
292
- /* stylelint-disable-next-line primer/colors */
293
- background: var(--borderColor-default);
294
- }
295
- :is(:is(.FormControl-input-wrap .FormControl-input-trailingAction)::after) {
296
- position: absolute;
297
- top: 50%;
298
- left: 50%;
299
- width: 100%;
300
- height: 100%;
301
- min-height: var(--control-medium-size) var(--control-medium-size);
302
- content: "";
303
- transform: translateX(-50%) translateY(-50%);
304
- }
305
- @media (pointer: coarse) {
306
- :is(.FormControl-input-wrap .FormControl-input-trailingAction)::after {
307
- min-width: var(--control-minTarget-coarse);
308
- min-height: var(--control-minTarget-coarse);
309
- }
310
- }
311
- /* if leadingVisual is present */
312
- /*
313
- ┌──32px──┬────────────────────┐
314
- ╎ ┌───┐ ┌────────────────┐ ╎
315
- ╎ 16px 16px ╎
316
- ╎ └───┘ └────────────────┘ ╎
317
- └───────8px───────────────────┘
318
- */
319
- .FormControl-input-wrap.FormControl-input-wrap--leadingVisual .FormControl-input {
320
- padding-inline-start: calc(
321
- var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap)
322
- ); /* 32px */
323
- }
324
- /* if trailingVisual is present */
325
- /*
326
- ┌──────────────────┬──32px──┐
327
- ╎ ┌──────────────┐ ┌────┐ ╎
328
- ╎ 24px 24px ╎
329
- ╎ └──────────────┘ └────┘ ╎
330
- └──────────────────┴────────┘
331
- */
332
- .FormControl-input-wrap.FormControl-input-wrap--trailingVisual .FormControl-input {
333
- padding-inline-end: calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap));
334
- }
335
- .FormControl-input-wrap.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualText) .FormControl-input {
336
- padding-inline-end: 25%
337
- }
338
- .FormControl-input-wrap.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualLabel) .FormControl-input {
339
- padding-inline-end: 25%
340
- }
341
- /*
342
- ┌──────────────────┬──32px──┐
343
- ╎ ┌──────────────┐ ┌────┐ ╎
344
- ╎ 24px 24px ╎
345
- ╎ └──────────────┘ └────┘ ╎
346
- └──────────────────┴────────┘
347
- */
348
- /* if trailingAction is present */
349
- .FormControl-input-wrap.FormControl-input-wrap--trailingAction .FormControl-input {
350
- padding-inline-end: calc(
351
- var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap)
352
- ); /* 32px */
353
- }
354
- /*
355
- 32px + 1px border
356
- ┌──────────────────┬──33px──┐
357
- ╎ ┌──────────────┐ ┌────┐ ╎
358
- ╎ 24px 24px ╎
359
- ╎ └──────────────┘ └────┘ ╎
360
- └──────────────────┴────────┘
361
- */
362
- /* if trailingAction divider is present, add 1px padding to accomodate input field text
363
- ** can be refactored to has(.FormControl-input-trailingAction--divider) */
364
- .FormControl-input-wrap.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input {
365
- padding-inline-end: calc(
366
- var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap) +
367
- var(--borderWidth-thin)
368
- ); /* 33px */
369
- }
370
- /* size modifications can be refactored with :has() - FormControl-input-wrap:has(.FormControl-large)
371
- // sizes */
372
- .FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-leadingVisualWrap {
373
- top: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
374
- left: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
375
- }
376
- .FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingVisualWrap {
377
- top: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
378
- right: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
379
- }
380
- /*
381
- ┌──────────────────┬──28px──┐
382
- ╎ ┌──────────────┐ ┌────┐ ╎
383
- ╎ 20px 20px ╎
384
- ╎ └──────────────┘ └────┘ ╎
385
- └──────────────────┴────────┘
386
- */
387
- .FormControl-input-wrap.FormControl-input-wrap--small.FormControl-input-wrap--trailingAction .FormControl-input.FormControl-small {
388
- padding-inline-end: calc(
389
- var(--control-small-paddingInline-condensed) + var(--base-size-16) + var(--control-small-gap)
390
- ); /* 28px */
391
- }
392
- /*
393
- 28px + 1px border
394
- ┌──────────────────┬──29px──┐
395
- ╎ ┌──────────────┐ ┌────┐ ╎
396
- ╎ 20px 20px ╎
397
- ╎ └──────────────┘ └────┘ ╎
398
- └──────────────────┴────────┘
399
- */
400
- .FormControl-input-wrap.FormControl-input-wrap--small.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input.FormControl-small {
401
- padding-inline-end: calc(
402
- var(--control-small-paddingInline-condensed) + var(--base-size-16) + var(--control-small-gap) +
403
- var(--borderWidth-thin)
404
- ); /* 29px */
405
- }
406
- .FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingAction {
407
- width: calc(var(--control-small-size) - var(--base-size-8));
408
- height: calc(var(--control-small-size) - var(--base-size-8));
409
- }
410
- :is(.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingAction)::before {
411
- top: calc((var(--control-xsmall-size) - var(--base-size-16)) / 4); /* 2px */
412
- }
413
- .FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-leadingVisualWrap {
414
- top: var(--control-medium-paddingInline-normal);
415
- left: var(--control-medium-paddingInline-normal);
416
- }
417
- .FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingVisualWrap {
418
- top: var(--control-medium-paddingInline-normal);
419
- right: var(--control-medium-paddingInline-normal);
420
- }
421
- /*
422
- ┌──36px──┬───12px padding──────┐
423
- ╎ ┌───┐ ┌────────────────┐ ╎
424
- ╎ 16px 16px ╎
425
- ╎ └───┘ └────────────────┘ ╎
426
- └12px───8px───────────────────┘
427
- */
428
- .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--leadingVisual .FormControl-input.FormControl-large {
429
- padding-inline-start: calc(
430
- var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap)
431
- ); /* 36px */
432
- }
433
- .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual .FormControl-input {
434
- padding-inline-end: calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap));
435
- }
436
- .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualText) .FormControl-input {
437
- padding-inline-end: 25%
438
- }
439
- .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualLabel) .FormControl-input {
440
- padding-inline-end: 25%
441
- }
442
- .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingText .FormControl-input.FormControl-large {
443
- padding-inline-end: 25%;
444
- }
445
- .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingLabel .FormControl-input.FormControl-large {
446
- padding-inline-end: 25%;
447
- }
448
- /*
449
- ┌──────────────────┬──36px──┐
450
- ╎ ┌──────────────┐ ┌────┐ ╎
451
- ╎ 28px 28px ╎
452
- ╎ └──────────────┘ └────┘ ╎
453
- └──────────────────┴────────┘
454
- */
455
- .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingAction .FormControl-input.FormControl-large {
456
- padding-inline-end: calc(
457
- var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap)
458
- ); /* 36px */
459
- }
460
- /*
461
- ┌──────────────────┬──37px──┐
462
- ╎ ┌──────────────┐ ┌────┐ ╎
463
- ╎ 28px 28px ╎
464
- ╎ └──────────────┘ └────┘ ╎
465
- └──────────────────┴────────┘
466
- */
467
- .FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input.FormControl-large {
468
- padding-inline-end: calc(
469
- var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap) +
470
- var(--borderWidth-thin)
471
- ); /* 37px */
472
- }
473
- .FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingAction {
474
- top: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
475
- right: calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2)); /* 6px */
476
- width: var(--control-small-size);
477
- height: var(--control-small-size);
478
- }
479
- :is(.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingAction)::before {
480
- top: unset;
481
- height: var(--base-size-20);
482
- }
483
- .FormControl-select-wrap {
484
- display: grid;
485
- grid-template-columns: minmax(0, auto) var(--base-size-16);
486
-
487
- /* mask allows for background-color to respect themes */
488
- }
489
- .FormControl-select-wrap::after {
490
- width: var(--base-size-16);
491
- height: var(--base-size-16);
492
- padding-right: var(--base-size-4);
493
- pointer-events: none;
494
- content: '';
495
- background-color: var(--bgColor-neutral-emphasis);
496
- mask: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHZpZXdCb3g9IjAgMCAxNiAxNiIgZmlsbD0iIzU4NjA2OSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNNC40MjcgOS40MjdsMy4zOTYgMy4zOTZhLjI1MS4yNTEgMCAwMC4zNTQgMGwzLjM5Ni0zLjM5NkEuMjUuMjUgMCAwMDExLjM5NiA5SDQuNjA0YS4yNS4yNSAwIDAwLS4xNzcuNDI3ek00LjQyMyA2LjQ3TDcuODIgMy4wNzJhLjI1LjI1IDAgMDEuMzU0IDBMMTEuNTcgNi40N2EuMjUuMjUgMCAwMS0uMTc3LjQyN0g0LjZhLjI1LjI1IDAgMDEtLjE3Ny0uNDI3eiIgLz48L3N2Zz4=');
497
- mask-size: contain;
498
- mask-repeat: no-repeat;
499
- grid-column: 2;
500
- grid-row: 1;
501
- place-self: center end;
502
- }
503
- /* spans entire grid below mask */
504
- .FormControl-select-wrap .FormControl-select {
505
- grid-column: 1/-1;
506
- grid-row: 1;
507
- appearance: none;
508
- padding-right: var(--base-size-20);
509
- }
510
- .FormControl-select-wrap[data-multiple]::after {
511
- content: none;
512
- }
513
- .FormControl-select-wrap[data-multiple] .FormControl-select {
514
- padding-right: var(--base-size-8);
515
- }
516
- /* checkbox + radio specific styles */
517
- /* // Checkbox + Radio structure
518
- ** ===================
519
- **
520
- ** .FormControl-radio-wrap
521
- ** ├─ .FormControl-radio
522
- ** ├─ .FormControl-radio-labelWrap
523
- ** │ ├─ .FormControl-label
524
- ** │ ├─ .FormControl-caption */
525
- .FormControl-checkbox-wrap,
526
- .FormControl-radio-wrap {
527
- display: inline-grid;
528
- grid-template-columns: min-content auto;
529
- gap: var(--base-size-8);
530
- }
531
- :is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-checkbox-labelWrap,:is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-radio-labelWrap {
532
- display: flex;
533
- flex-direction: column;
534
- gap: var(--base-size-4);
535
- }
536
- :is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-label {
537
- cursor: pointer;
538
- }
539
- .FormControl-radio-group-wrap fieldset {
540
- padding: 0;
541
- margin: 0;
542
- border: 0;
543
- }
544
- .FormControl-check-group-wrap fieldset {
545
- padding: 0;
546
- margin: 0;
547
- border: 0;
548
- }
549
- /* these selectors are temporary to override base.scss
550
- ** once Field styles are widely adopted, we can adjust this and the global base styles */
551
- .FormControl-checkbox {
552
- color: var(--fgColor-default);
553
- background-color: var(--bgColor-default);
554
- border: var(--borderWidth-thin) solid var(--control-borderColor-rest, var(--color-border-default));
555
- box-shadow: var(--shadow-inset);
556
- }
557
- .FormControl-checkbox[disabled] {
558
- color: var(--control-fgColor-disabled);
559
- cursor: not-allowed;
560
- background-color: var(--control-bgColor-disabled);
561
- border-color: var(--control-borderColor-disabled);
562
- box-shadow: none;
563
- opacity: 1;
564
- -webkit-text-fill-color: var(--control-fgColor-disabled);
565
- }
566
- .FormControl-checkbox[invalid='true']:not(:focus) {
567
- border-color: var(--control-borderColor-danger);
568
- }
569
- .FormControl-checkbox[invalid='false']:not(:focus) {
570
- border-color: var(--control-borderColor-success);
571
- }
572
- .FormControl-checkbox:not([type='checkbox'],[type='radio']):focus {
573
- border-color: var(--focus-outlineColor);
574
- outline: none;
575
- box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
576
-
577
- /* remove fallback :focus if :focus-visible is supported */
578
- }
579
- .FormControl-checkbox:not([type='checkbox'],[type='radio']):focus:not(:focus-visible) {
580
- border-color: transparent;
581
-
582
- border-color: var(--focus-outlineColor);
583
-
584
- outline: none;
585
-
586
- box-shadow: inset 0 0 0 1px transparent var(--focus-outlineColor);
587
- }
588
- /* default focus state */
589
- .FormControl-checkbox:not([type='checkbox'],[type='radio']):focus-visible {
590
- border-color: var(--focus-outlineColor);
591
- outline: none;
592
- box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
593
- }
594
- .FormControl-checkbox {
595
-
596
- position: relative;
597
- display: grid;
598
- width: var(--base-size-16);
599
- height: var(--base-size-16);
600
- margin: 0;
601
- margin-top: var(--base-size-2); /* 2px to center align with label (20px line-height) */
602
- cursor: pointer;
603
- border-color: var(--control-borderColor-emphasis);
604
- border-radius: var(--borderRadius-small);
605
- transition: background-color, border-color 80ms cubic-bezier(0.33, 1, 0.68, 1); /* checked -> unchecked - add 120ms delay to fully see animation-out */
606
- appearance: none;
607
- place-content: center;
608
- }
609
- .FormControl-checkbox::before {
610
- width: var(--base-size-16);
611
- height: var(--base-size-16);
612
- visibility: hidden;
613
- content: '';
614
- /* stylelint-disable-next-line primer/colors */
615
- background-color: var(--control-checked-fgColor-rest);
616
- transition: visibility 0s linear 230ms;
617
- clip-path: inset(var(--base-size-16) 0 0 0);
618
-
619
- /* octicon checkmark image */
620
- mask-image: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iOSIgdmlld0JveD0iMCAwIDEyIDkiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNMTEuNzgwMyAwLjIxOTYyNUMxMS45MjEgMC4zNjA0MjcgMTIgMC41NTEzMDUgMTIgMC43NTAzMTNDMTIgMC45NDkzMjEgMTEuOTIxIDEuMTQwMTkgMTEuNzgwMyAxLjI4MUw0LjUxODYgOC41NDA0MkM0LjM3Nzc1IDguNjgxIDQuMTg2ODIgOC43NiAzLjk4Nzc0IDguNzZDMy43ODg2NyA4Ljc2IDMuNTk3NzMgOC42ODEgMy40NTY4OSA4LjU0MDQyTDAuMjAxNjIyIDUuMjg2MkMwLjA2ODkyNzcgNS4xNDM4MyAtMC4wMDMzMDkwNSA0Ljk1NTU1IDAuMDAwMTE2NDkzIDQuNzYwOThDMC4wMDM1NTIwNSA0LjU2NjQzIDAuMDgyMzg5NCA0LjM4MDgxIDAuMjIwMDMyIDQuMjQzMjFDMC4zNTc2NjUgNC4xMDU2MiAwLjU0MzM1NSA0LjAyNjgxIDAuNzM3OTcgNC4wMjMzOEMwLjkzMjU4NCA0LjAxOTk0IDEuMTIwOTMgNC4wOTIxNyAxLjI2MzM0IDQuMjI0ODJMMy45ODc3NCA2Ljk0ODM1TDEwLjcxODYgMC4yMTk2MjVDMTAuODU5NSAwLjA3ODk5MjMgMTEuMDUwNCAwIDExLjI0OTUgMEMxMS40NDg1IDAgMTEuNjM5NSAwLjA3ODk5MjMgMTEuNzgwMyAwLjIxOTYyNVoiIGZpbGw9IndoaXRlIi8+Cjwvc3ZnPgo=');
621
- mask-size: 75%;
622
- mask-repeat: no-repeat;
623
- mask-position: center;
624
- animation: checkmarkOut 80ms cubic-bezier(0.65, 0, 0.35, 1) forwards; /* slightly snappier animation out */
625
- }
626
- /* extend touch target */
627
- :is(.FormControl-checkbox::after) {
628
- position: absolute;
629
- top: 50%;
630
- left: 50%;
631
- width: 100%;
632
- height: 100%;
633
- min-height: var(--control-medium-size) var(--control-medium-size);
634
- content: "";
635
- transform: translateX(-50%) translateY(-50%);
636
- }
637
- :is(.FormControl-checkbox[disabled] ~ .FormControl-checkbox-labelWrap) .FormControl-label {
638
- color: var(--control-fgColor-disabled);
639
- cursor: not-allowed;
640
- }
641
- .FormControl-checkbox:checked {
642
- background: var(--control-checked-bgColor-rest, var(--color-accent-fg));
643
- border-color: var(--control-checked-borderColor-rest, var(--color-accent-fg));
644
- transition: background-color, border-color 80ms cubic-bezier(0.32, 0, 0.67, 0) 0ms; /* unchecked -> checked */
645
- }
646
- .FormControl-checkbox:checked::before {
647
- visibility: visible;
648
- transition: visibility 0s linear 0s;
649
- animation: checkmarkIn 80ms cubic-bezier(0.65, 0, 0.35, 1) forwards 80ms;
650
- }
651
- .FormControl-checkbox:checked:disabled {
652
- cursor: not-allowed;
653
- /* stylelint-disable-next-line primer/colors */
654
- background-color: var(--control-fgColor-disabled);
655
- /* stylelint-disable-next-line primer/colors */
656
- border-color: var(--control-fgColor-disabled);
657
- opacity: 1;
658
- }
659
- .FormControl-checkbox:checked:disabled::before {
660
- /* stylelint-disable-next-line primer/colors */
661
- background-color: var(--control-checked-fgColor-rest);
662
- }
663
- /* Windows High Contrast mode */
664
- @media (forced-colors: active) {
665
- .FormControl-checkbox:checked {
666
- background-color: canvastext;
667
- border-color: canvastext;
668
- }
669
- }
670
- .FormControl-checkbox:focus-visible {
671
- outline: 2px solid var(--focus-outlineColor);
672
- outline-offset: 2px;
673
- box-shadow: none;
674
- }
675
- .FormControl-checkbox:indeterminate::before {
676
- mask-image: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAiIGhlaWdodD0iMiIgdmlld0JveD0iMCAwIDEwIDIiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNMCAxQzAgMC40NDc3MTUgMC40NDc3MTUgMCAxIDBIOUM5LjU1MjI5IDAgMTAgMC40NDc3MTUgMTAgMUMxMCAxLjU1MjI4IDkuNTUyMjkgMiA5IDJIMUMwLjQ0NzcxNSAyIDAgMS41NTIyOCAwIDFaIiBmaWxsPSJ3aGl0ZSIvPgo8L3N2Zz4K');
677
- visibility: visible;
678
- }
679
- .FormControl-radio {
680
- color: var(--fgColor-default);
681
- background-color: var(--bgColor-default);
682
- border: var(--borderWidth-thin) solid var(--control-borderColor-rest, var(--color-border-default));
683
- box-shadow: var(--shadow-inset);
684
- }
685
- .FormControl-radio[disabled] {
686
- color: var(--control-fgColor-disabled);
687
- cursor: not-allowed;
688
- background-color: var(--control-bgColor-disabled);
689
- border-color: var(--control-borderColor-disabled);
690
- box-shadow: none;
691
- opacity: 1;
692
- -webkit-text-fill-color: var(--control-fgColor-disabled);
693
- }
694
- .FormControl-radio[invalid='true']:not(:focus) {
695
- border-color: var(--control-borderColor-danger);
696
- }
697
- .FormControl-radio[invalid='false']:not(:focus) {
698
- border-color: var(--control-borderColor-success);
699
- }
700
- .FormControl-radio:not([type='checkbox'],[type='radio']):focus {
701
- border-color: var(--focus-outlineColor);
702
- outline: none;
703
- box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
704
-
705
- /* remove fallback :focus if :focus-visible is supported */
706
- }
707
- .FormControl-radio:not([type='checkbox'],[type='radio']):focus:not(:focus-visible) {
708
- border-color: transparent;
709
-
710
- border-color: var(--focus-outlineColor);
711
-
712
- outline: none;
713
-
714
- box-shadow: inset 0 0 0 1px transparent var(--focus-outlineColor);
715
- }
716
- /* default focus state */
717
- .FormControl-radio:not([type='checkbox'],[type='radio']):focus-visible {
718
- border-color: var(--focus-outlineColor);
719
- outline: none;
720
- box-shadow: inset 0 0 0 1px var(--focus-outlineColor);
721
- }
722
- .FormControl-radio {
723
-
724
- position: relative;
725
- width: var(--base-size-16);
726
- height: var(--base-size-16);
727
- margin: 0;
728
- margin-top: var(--base-size-2); /* 2px to center align with label (20px line-height) */
729
- cursor: pointer;
730
- border-color: var(--control-borderColor-emphasis);
731
- border-radius: var(--borderRadius-full);
732
- transition: background-color, border-color 80ms cubic-bezier(0.33, 1, 0.68, 1); /* checked -> unchecked - add 120ms delay to fully see animation-out */
733
- appearance: none;
734
- }
735
- :is(.FormControl-radio::after) {
736
- position: absolute;
737
- top: 50%;
738
- left: 50%;
739
- width: 100%;
740
- height: 100%;
741
- min-height: var(--control-medium-size) var(--control-medium-size);
742
- content: "";
743
- transform: translateX(-50%) translateY(-50%);
744
- }
745
- :is(.FormControl-radio[disabled] ~ .FormControl-radio-labelWrap) .FormControl-label {
746
- color: var(--control-fgColor-disabled);
747
- cursor: not-allowed;
748
- }
749
- .FormControl-radio:checked {
750
- border-color: var(--control-checked-borderColor-rest, var(--color-accent-fg));
751
- /* stylelint-disable-next-line primer/borders */
752
- border-width: var(--base-size-4);
753
- }
754
- .FormControl-radio[disabled]:checked,.FormControl-radio:checked:disabled {
755
- cursor: not-allowed;
756
- /* stylelint-disable-next-line primer/colors */
757
- border-color: var(--control-fgColor-disabled);
758
- }
759
- :is(:is(.FormControl-radio[disabled]:checked,.FormControl-radio:checked:disabled) ~ .FormControl-radio-labelWrap) .FormControl-label {
760
- color: var(--control-fgColor-disabled);
761
- cursor: not-allowed;
762
- }
763
- .FormControl-radio:focus-visible {
764
- outline: 2px solid var(--focus-outlineColor);
765
- outline-offset: 2px;
766
- box-shadow: none;
767
- }
768
- /* Windows High Contrast mode */
769
- @media (forced-colors: active) {
770
- .FormControl-radio {
771
- background-color: canvastext;
772
- border-color: canvastext;
773
- }
774
- }
775
- @keyframes checkmarkIn {
776
- from {
777
- clip-path: inset(var(--base-size-16) 0 0 0);
778
- }
779
-
780
- to {
781
- clip-path: inset(0 0 0 0);
782
- }
783
- }
784
- @keyframes checkmarkOut {
785
- from {
786
- clip-path: inset(0 0 0 0);
787
- }
788
-
789
- to {
790
- clip-path: inset(var(--base-size-16) 0 0 0);
791
- }
792
- }
1
+ .FormControl{display:inline-flex;flex-direction:column;gap:var(--base-size-4)}.FormControl--fullWidth{display:flex}.FormControl-label{color:var(--fgColor-default);font-size:var(--text-body-size-medium);font-weight:var(--base-text-weight-semibold);line-height:var(--text-body-lineHeight-medium)}.FormControl-caption{color:var(--fgColor-muted);font-weight:var(--text-caption-weight);margin-bottom:0}.FormControl-caption,.FormControl-inlineValidation{font-size:var(--text-caption-size);line-height:var(--text-caption-lineHeight)}.FormControl-inlineValidation{color:var(--control-danger-fgColor-rest);display:flex;font-weight:var(--base-text-weight-semibold);fill:var(--control-danger-fgColor-rest);align-items:flex-start;flex-direction:row;gap:var(--base-size-4)}.FormControl-inlineValidation p{margin-bottom:0}.FormControl-inlineValidation--success{color:var(--fgColor-success);fill:var(--fgColor-success)}.FormControl-inlineValidation--visual{align-items:center;display:flex;min-height:var(--base-size-16)}.FormControl-spacingWrapper{display:flex;flex-direction:column;row-gap:var(--stack-gap-normal)}.FormControl-horizontalGroup{column-gap:.5rem;display:flex}.FormControl-input,.FormControl-select,.FormControl-textarea{background-color:var(--bgColor-default);border:var(--borderWidth-thin) solid var(--control-borderColor-rest,var(--color-border-default));box-shadow:var(--shadow-inset);color:var(--fgColor-default)}[disabled]:is(.FormControl-input,.FormControl-select,.FormControl-textarea){background-color:var(--control-bgColor-disabled);border-color:var(--control-borderColor-disabled);box-shadow:none;color:var(--control-fgColor-disabled);cursor:not-allowed;opacity:1;-webkit-text-fill-color:var(--control-fgColor-disabled)}[invalid=true]:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not(:focus){border-color:var(--control-borderColor-danger)}[invalid=false]:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not(:focus){border-color:var(--control-borderColor-success)}:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type=checkbox],[type=radio]):focus{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type=checkbox],[type=radio]):focus:not(:focus-visible){border-color:#0000;border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px #0000 var(--focus-outlineColor);outline:none}:is(.FormControl-input,.FormControl-select,.FormControl-textarea):not([type=checkbox],[type=radio]):focus-visible{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-input,.FormControl-select,.FormControl-textarea{border-radius:var(--borderRadius-medium);font-size:var(--text-body-size-medium);line-height:var(--text-body-lineHeight-medium);padding-block:calc(var(--control-medium-paddingBlock) - var(--borderWidth-thin));padding-inline:var(--control-medium-paddingInline-condensed);transition:80ms cubic-bezier(.33,1,.68,1);transition-property:color,background-color,box-shadow,border-color;width:100%}[disabled]:is(.FormControl-input,.FormControl-select,.FormControl-textarea)::placeholder{color:var(--control-fgColor-disabled)}[readonly]:is(.FormControl-input,.FormControl-select,.FormControl-textarea){background-color:var(--control-bgColor-disabled)}:is(.FormControl-input,.FormControl-select,.FormControl-textarea)::placeholder{color:var(--control-fgColor-placeholder);opacity:1}.FormControl-small:is(.FormControl-input,.FormControl-select,.FormControl-textarea){font-size:var(--text-body-size-small);height:var(--control-small-size);padding-block:var(--control-small-paddingBlock);padding-inline:var(--control-small-paddingInline-normal)}.FormControl-medium:is(.FormControl-input,.FormControl-select,.FormControl-textarea){height:var(--control-medium-size)}.FormControl-large:is(.FormControl-input,.FormControl-select,.FormControl-textarea){height:var(--control-large-size);padding-block:var(--control-large-paddingBlock);padding-inline:var(--control-large-paddingInline-normal)}.FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea){background-color:var(--bgColor-muted)}.FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea):focus,.FormControl-inset:is(.FormControl-input,.FormControl-select,.FormControl-textarea):focus-visible{background-color:var(--bgColor-default)}.FormControl-monospace:is(.FormControl-input,.FormControl-select,.FormControl-textarea){font-family:var(--fontStack-monospace)}.FormControl-error:is(.FormControl-input,.FormControl-select,.FormControl-textarea){border-color:var(--control-borderColor-danger)}.FormControl-success:is(.FormControl-input,.FormControl-select,.FormControl-textarea){border-color:var(--control-borderColor-success)}.FormControl-warning:is(.FormControl-input,.FormControl-select,.FormControl-textarea){border-color:var(--control-borderColor-warning)}.FormControl-toggleSwitchInput{align-items:flex-start;display:flex;gap:var(--base-size-16)}.FormControl-input-wrap{display:grid;position:relative}.FormControl-input-wrap .FormControl-input-leadingVisualWrap{color:var(--fgColor-muted);display:block;height:var(--base-size-16);left:var(--base-size-8);pointer-events:none;position:absolute;top:var(--base-size-8);width:var(--base-size-16)}:is(.FormControl-input-wrap .FormControl-input-leadingVisualWrap) .FormControl-input-leadingVisual{display:block;-webkit-user-select:none;user-select:none}.FormControl-input-wrap .FormControl-input-trailingVisualWrap{align-items:center;color:var(--fgColor-muted);display:flex;gap:var(--base-size-4);height:var(--base-size-16);pointer-events:none;position:absolute;right:var(--base-size-8);top:var(--base-size-8)}:is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap):has(.FormControl-input-trailingVisualLabel),:is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap):has(.FormControl-input-trailingVisualText){max-width:25%;padding-left:var(--base-size-8)}:is(.FormControl-input-wrap .FormControl-input-trailingVisualWrap) .FormControl-input-trailingVisualLabel{overflow:hidden;text-overflow:ellipsis}.FormControl-input-wrap .FormControl-input-trailingAction{align-items:center;background:#0000;border:0;border-radius:var(--borderRadius-small);color:var(--fgColor-muted);cursor:pointer;display:grid;height:var(--control-xsmall-size);justify-content:center;padding:0;position:absolute;right:var(--base-size-4);top:var(--base-size-4);transition:.2s cubic-bezier(.3,0,.5,1);transition-property:color,background-color,border-color;width:var(--control-xsmall-size);z-index:4}:is(.FormControl-input-wrap .FormControl-input-trailingAction) svg{-webkit-user-select:none;user-select:none}[disabled]:is(.FormControl-input-wrap .FormControl-input-trailingAction){color:var(--control-fgColor-disabled);pointer-events:none}:is(.FormControl-input-wrap .FormControl-input-trailingAction):hover{background:var(--control-transparent-bgColor-hover)}:is(.FormControl-input-wrap .FormControl-input-trailingAction):active{background:var(--control-transparent-bgColor-active)}.FormControl-input-trailingAction--divider:is(.FormControl-input-wrap .FormControl-input-trailingAction):before{background:var(--borderColor-default);content:"";display:block;height:var(--base-size-16);left:calc(var(--base-size-4)*-1);position:absolute;top:calc((var(--control-xsmall-size) - var(--base-size-16))/2);width:var(--borderWidth-thin)}:is(:is(.FormControl-input-wrap .FormControl-input-trailingAction):after){content:"";height:100%;left:50%;min-height:var(--control-medium-size) var(--control-medium-size);position:absolute;top:50%;transform:translateX(-50%) translateY(-50%);width:100%}@media (pointer:coarse){:is(.FormControl-input-wrap .FormControl-input-trailingAction):after{min-height:var(--control-minTarget-coarse);min-width:var(--control-minTarget-coarse)}}.FormControl-input-wrap.FormControl-input-wrap--leadingVisual .FormControl-input{padding-inline-start:calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap))}.FormControl-input-wrap.FormControl-input-wrap--trailingVisual .FormControl-input{padding-inline-end:calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap))}.FormControl-input-wrap.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualLabel) .FormControl-input,.FormControl-input-wrap.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualText) .FormControl-input{padding-inline-end:25%}.FormControl-input-wrap.FormControl-input-wrap--trailingAction .FormControl-input{padding-inline-end:calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap))}.FormControl-input-wrap.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input{padding-inline-end:calc(var(--control-medium-paddingInline-condensed) + var(--base-size-16) + var(--control-medium-gap) + var(--borderWidth-thin))}.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-leadingVisualWrap{left:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2));top:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2))}.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingVisualWrap{right:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2));top:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2))}.FormControl-input-wrap.FormControl-input-wrap--small.FormControl-input-wrap--trailingAction .FormControl-input.FormControl-small{padding-inline-end:calc(var(--control-small-paddingInline-condensed) + var(--base-size-16) + var(--control-small-gap))}.FormControl-input-wrap.FormControl-input-wrap--small.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input.FormControl-small{padding-inline-end:calc(var(--control-small-paddingInline-condensed) + var(--base-size-16) + var(--control-small-gap) + var(--borderWidth-thin))}.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingAction{height:calc(var(--control-small-size) - var(--base-size-8));width:calc(var(--control-small-size) - var(--base-size-8))}:is(.FormControl-input-wrap.FormControl-input-wrap--small .FormControl-input-trailingAction):before{top:calc((var(--control-xsmall-size) - var(--base-size-16))/4)}.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-leadingVisualWrap{left:var(--control-medium-paddingInline-normal);top:var(--control-medium-paddingInline-normal)}.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingVisualWrap{right:var(--control-medium-paddingInline-normal);top:var(--control-medium-paddingInline-normal)}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--leadingVisual .FormControl-input.FormControl-large{padding-inline-start:calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap))}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual .FormControl-input{padding-inline-end:calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap))}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingLabel .FormControl-input.FormControl-large,.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingText .FormControl-input.FormControl-large,.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualLabel) .FormControl-input,.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingVisual:has(.FormControl-input-trailingVisualText) .FormControl-input{padding-inline-end:25%}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingAction .FormControl-input.FormControl-large{padding-inline-end:calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap))}.FormControl-input-wrap.FormControl-input-wrap--large.FormControl-input-wrap--trailingAction.FormControl-input-wrap-trailingAction--divider .FormControl-input.FormControl-large{padding-inline-end:calc(var(--control-large-paddingInline-normal) + var(--base-size-16) + var(--control-large-gap) + var(--borderWidth-thin))}.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingAction{height:var(--control-small-size);right:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2));top:calc(var(--control-medium-paddingInline-condensed) - var(--base-size-2));width:var(--control-small-size)}:is(.FormControl-input-wrap.FormControl-input-wrap--large .FormControl-input-trailingAction):before{height:var(--base-size-20);top:unset}.FormControl-select-wrap{display:grid;grid-template-columns:minmax(0,auto) var(--base-size-16)}.FormControl-select-wrap:after{background-color:var(--bgColor-neutral-emphasis);content:"";grid-column:2;grid-row:1;height:var(--base-size-16);mask:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxNiIgZmlsbD0iIzU4NjA2OSIgdmlld0JveD0iMCAwIDE2IDE2Ij48cGF0aCBkPSJtNC40MjcgOS40MjcgMy4zOTYgMy4zOTZhLjI1LjI1IDAgMCAwIC4zNTQgMGwzLjM5Ni0zLjM5NkEuMjUuMjUgMCAwIDAgMTEuMzk2IDlINC42MDRhLjI1LjI1IDAgMCAwLS4xNzcuNDI3TTQuNDIzIDYuNDcgNy44MiAzLjA3MmEuMjUuMjUgMCAwIDEgLjM1NCAwTDExLjU3IDYuNDdhLjI1LjI1IDAgMCAxLS4xNzcuNDI3SDQuNmEuMjUuMjUgMCAwIDEtLjE3Ny0uNDI3Ii8+PC9zdmc+");mask-repeat:no-repeat;mask-size:contain;padding-right:var(--base-size-4);place-self:center end;pointer-events:none;width:var(--base-size-16)}.FormControl-select-wrap .FormControl-select{appearance:none;grid-column:1/-1;grid-row:1;padding-right:var(--base-size-20)}.FormControl-select-wrap[data-multiple]:after{content:none}.FormControl-select-wrap[data-multiple] .FormControl-select{padding-right:var(--base-size-8)}.FormControl-checkbox-wrap,.FormControl-radio-wrap{display:inline-grid;gap:var(--base-size-8);grid-template-columns:min-content auto}:is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-checkbox-labelWrap,:is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-radio-labelWrap{display:flex;flex-direction:column;gap:var(--base-size-4)}:is(.FormControl-checkbox-wrap,.FormControl-radio-wrap) .FormControl-label{cursor:pointer}.FormControl-check-group-wrap fieldset,.FormControl-radio-group-wrap fieldset{border:0;margin:0;padding:0}.FormControl-checkbox{background-color:var(--bgColor-default);border:var(--borderWidth-thin) solid var(--control-borderColor-rest,var(--color-border-default));box-shadow:var(--shadow-inset);color:var(--fgColor-default)}.FormControl-checkbox[disabled]{background-color:var(--control-bgColor-disabled);border-color:var(--control-borderColor-disabled);box-shadow:none;color:var(--control-fgColor-disabled);cursor:not-allowed;opacity:1;-webkit-text-fill-color:var(--control-fgColor-disabled)}.FormControl-checkbox[invalid=true]:not(:focus){border-color:var(--control-borderColor-danger)}.FormControl-checkbox[invalid=false]:not(:focus){border-color:var(--control-borderColor-success)}.FormControl-checkbox:not([type=checkbox],[type=radio]):focus{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-checkbox:not([type=checkbox],[type=radio]):focus:not(:focus-visible){border-color:#0000;border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px #0000 var(--focus-outlineColor);outline:none}.FormControl-checkbox:not([type=checkbox],[type=radio]):focus-visible{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-checkbox{appearance:none;border-color:var(--control-borderColor-emphasis);border-radius:var(--borderRadius-small);cursor:pointer;display:grid;height:var(--base-size-16);margin:0;margin-top:var(--base-size-2);place-content:center;position:relative;transition:background-color,border-color 80ms cubic-bezier(.33,1,.68,1);width:var(--base-size-16)}.FormControl-checkbox:before{animation:checkmarkOut 80ms cubic-bezier(.65,0,.35,1) forwards;background-color:var(--control-checked-fgColor-rest);clip-path:inset(var(--base-size-16) 0 0 0);content:"";height:var(--base-size-16);mask-image:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMiIgaGVpZ2h0PSI5IiBmaWxsPSJub25lIiB2aWV3Qm94PSIwIDAgMTIgOSI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNMTEuNzguMjJhLjc1Ljc1IDAgMCAxIDAgMS4wNjFMNC41MiA4LjU0MWEuNzUuNzUgMCAwIDEtMS4wNjIgMEwuMjAyIDUuMjg1YS43NS43NSAwIDAgMSAxLjA2MS0xLjA2MWwyLjcyNSAyLjcyM0wxMC43MTguMjJhLjc1Ljc1IDAgMCAxIDEuMDYyIDAiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjwvc3ZnPg==");mask-position:center;mask-repeat:no-repeat;mask-size:75%;transition:visibility 0s linear .23s;visibility:hidden;width:var(--base-size-16)}:is(.FormControl-checkbox:after){content:"";height:100%;left:50%;min-height:var(--control-medium-size) var(--control-medium-size);position:absolute;top:50%;transform:translateX(-50%) translateY(-50%);width:100%}:is(.FormControl-checkbox[disabled]~.FormControl-checkbox-labelWrap) .FormControl-label{color:var(--control-fgColor-disabled);cursor:not-allowed}.FormControl-checkbox:checked{background:var(--control-checked-bgColor-rest,var(--color-accent-fg));border-color:var(--control-checked-borderColor-rest,var(--color-accent-fg));transition:background-color,border-color 80ms cubic-bezier(.32,0,.67,0) 0s}.FormControl-checkbox:checked:before{animation:checkmarkIn 80ms cubic-bezier(.65,0,.35,1) 80ms forwards;transition:visibility 0s linear 0s;visibility:visible}.FormControl-checkbox:checked:disabled{background-color:var(--control-fgColor-disabled);border-color:var(--control-fgColor-disabled);cursor:not-allowed;opacity:1}.FormControl-checkbox:checked:disabled:before{background-color:var(--control-checked-fgColor-rest)}@media (forced-colors:active){.FormControl-checkbox:checked{background-color:canvastext;border-color:canvastext}}.FormControl-checkbox:focus-visible{box-shadow:none;outline:2px solid var(--focus-outlineColor);outline-offset:2px}.FormControl-checkbox:indeterminate:before{mask-image:url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMCIgaGVpZ2h0PSIyIiBmaWxsPSJub25lIiB2aWV3Qm94PSIwIDAgMTAgMiI+PHBhdGggZmlsbD0iI2ZmZiIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNMCAxYTEgMSAwIDAgMSAxLTFoOGExIDEgMCAxIDEgMCAySDFhMSAxIDAgMCAxLTEtMSIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9zdmc+");visibility:visible}.FormControl-radio{background-color:var(--bgColor-default);border:var(--borderWidth-thin) solid var(--control-borderColor-rest,var(--color-border-default));box-shadow:var(--shadow-inset);color:var(--fgColor-default)}.FormControl-radio[disabled]{background-color:var(--control-bgColor-disabled);border-color:var(--control-borderColor-disabled);box-shadow:none;color:var(--control-fgColor-disabled);cursor:not-allowed;opacity:1;-webkit-text-fill-color:var(--control-fgColor-disabled)}.FormControl-radio[invalid=true]:not(:focus){border-color:var(--control-borderColor-danger)}.FormControl-radio[invalid=false]:not(:focus){border-color:var(--control-borderColor-success)}.FormControl-radio:not([type=checkbox],[type=radio]):focus{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-radio:not([type=checkbox],[type=radio]):focus:not(:focus-visible){border-color:#0000;border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px #0000 var(--focus-outlineColor);outline:none}.FormControl-radio:not([type=checkbox],[type=radio]):focus-visible{border-color:var(--focus-outlineColor);box-shadow:inset 0 0 0 1px var(--focus-outlineColor);outline:none}.FormControl-radio{appearance:none;border-color:var(--control-borderColor-emphasis);border-radius:var(--borderRadius-full);cursor:pointer;height:var(--base-size-16);margin:0;margin-top:var(--base-size-2);position:relative;transition:background-color,border-color 80ms cubic-bezier(.33,1,.68,1);width:var(--base-size-16)}:is(.FormControl-radio:after){content:"";height:100%;left:50%;min-height:var(--control-medium-size) var(--control-medium-size);position:absolute;top:50%;transform:translateX(-50%) translateY(-50%);width:100%}:is(.FormControl-radio[disabled]~.FormControl-radio-labelWrap) .FormControl-label{color:var(--control-fgColor-disabled);cursor:not-allowed}.FormControl-radio:checked{border-color:var(--control-checked-borderColor-rest,var(--color-accent-fg));border-width:var(--base-size-4)}.FormControl-radio:checked:disabled,.FormControl-radio[disabled]:checked{border-color:var(--control-fgColor-disabled);cursor:not-allowed}:is(:is(.FormControl-radio[disabled]:checked,.FormControl-radio:checked:disabled)~.FormControl-radio-labelWrap) .FormControl-label{color:var(--control-fgColor-disabled);cursor:not-allowed}.FormControl-radio:focus-visible{box-shadow:none;outline:2px solid var(--focus-outlineColor);outline-offset:2px}@media (forced-colors:active){.FormControl-radio{background-color:canvastext;border-color:canvastext}}@keyframes checkmarkIn{0%{clip-path:inset(var(--base-size-16) 0 0 0)}to{clip-path:inset(0 0 0 0)}}@keyframes checkmarkOut{0%{clip-path:inset(0 0 0 0)}to{clip-path:inset(var(--base-size-16) 0 0 0)}}