sonner-vanilla 0.1.1

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.
@@ -0,0 +1,725 @@
1
+ html[dir='ltr'],
2
+ [data-sonner-toaster][dir='ltr'] {
3
+ --toast-icon-margin-start: -3px;
4
+ --toast-icon-margin-end: 4px;
5
+ --toast-svg-margin-start: -1px;
6
+ --toast-svg-margin-end: 0px;
7
+ --toast-button-margin-start: auto;
8
+ --toast-button-margin-end: 0;
9
+ --toast-close-button-start: 0;
10
+ --toast-close-button-end: unset;
11
+ --toast-close-button-transform: translate(-35%, -35%);
12
+ }
13
+
14
+ html[dir='rtl'],
15
+ [data-sonner-toaster][dir='rtl'] {
16
+ --toast-icon-margin-start: 4px;
17
+ --toast-icon-margin-end: -3px;
18
+ --toast-svg-margin-start: 0px;
19
+ --toast-svg-margin-end: -1px;
20
+ --toast-button-margin-start: 0;
21
+ --toast-button-margin-end: auto;
22
+ --toast-close-button-start: unset;
23
+ --toast-close-button-end: 0;
24
+ --toast-close-button-transform: translate(35%, -35%);
25
+ }
26
+
27
+ [data-sonner-toaster] {
28
+ position: fixed;
29
+ width: var(--width);
30
+ font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial,
31
+ Noto Sans, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
32
+ --gray1: hsl(0, 0%, 99%);
33
+ --gray2: hsl(0, 0%, 97.3%);
34
+ --gray3: hsl(0, 0%, 95.1%);
35
+ --gray4: hsl(0, 0%, 93%);
36
+ --gray5: hsl(0, 0%, 90.9%);
37
+ --gray6: hsl(0, 0%, 88.7%);
38
+ --gray7: hsl(0, 0%, 85.8%);
39
+ --gray8: hsl(0, 0%, 78%);
40
+ --gray9: hsl(0, 0%, 56.1%);
41
+ --gray10: hsl(0, 0%, 52.3%);
42
+ --gray11: hsl(0, 0%, 43.5%);
43
+ --gray12: hsl(0, 0%, 9%);
44
+ --border-radius: 8px;
45
+ box-sizing: border-box;
46
+ padding: 0;
47
+ margin: 0;
48
+ list-style: none;
49
+ outline: none;
50
+ z-index: 999999999;
51
+ transition: transform 400ms ease;
52
+ }
53
+
54
+ @media (hover: none) and (pointer: coarse) {
55
+ [data-sonner-toaster][data-lifted='true'] {
56
+ transform: none;
57
+ }
58
+ }
59
+
60
+ [data-sonner-toaster][data-x-position='right'] {
61
+ right: var(--offset-right);
62
+ }
63
+
64
+ [data-sonner-toaster][data-x-position='left'] {
65
+ left: var(--offset-left);
66
+ }
67
+
68
+ [data-sonner-toaster][data-x-position='center'] {
69
+ left: 50%;
70
+ transform: translateX(-50%);
71
+ }
72
+
73
+ [data-sonner-toaster][data-y-position='top'] {
74
+ top: var(--offset-top);
75
+ }
76
+
77
+ [data-sonner-toaster][data-y-position='bottom'] {
78
+ bottom: var(--offset-bottom);
79
+ }
80
+
81
+ [data-sonner-toast] {
82
+ --y: translateY(100%);
83
+ --lift-amount: calc(var(--lift) * var(--gap));
84
+ z-index: var(--z-index);
85
+ position: absolute;
86
+ opacity: 0;
87
+ transform: var(--y);
88
+ touch-action: none;
89
+ transition: transform 400ms, opacity 400ms, height 400ms, box-shadow 200ms;
90
+ box-sizing: border-box;
91
+ outline: none;
92
+ overflow-wrap: anywhere;
93
+ }
94
+
95
+ [data-sonner-toast][data-styled='true'] {
96
+ padding: 16px;
97
+ background: var(--normal-bg);
98
+ border: 1px solid var(--normal-border);
99
+ color: var(--normal-text);
100
+ border-radius: var(--border-radius);
101
+ box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.1);
102
+ width: var(--width);
103
+ font-size: 13px;
104
+ display: flex;
105
+ align-items: center;
106
+ gap: 6px;
107
+ }
108
+
109
+ [data-sonner-toast]:focus-visible {
110
+ box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.1), 0 0 0 2px rgba(0, 0, 0, 0.2);
111
+ }
112
+
113
+ [data-sonner-toast][data-y-position='top'] {
114
+ top: 0;
115
+ --y: translateY(-100%);
116
+ --lift: 1;
117
+ --lift-amount: calc(1 * var(--gap));
118
+ }
119
+
120
+ [data-sonner-toast][data-y-position='bottom'] {
121
+ bottom: 0;
122
+ --y: translateY(100%);
123
+ --lift: -1;
124
+ --lift-amount: calc(var(--lift) * var(--gap));
125
+ }
126
+
127
+ [data-sonner-toast][data-styled='true'] [data-description] {
128
+ font-weight: 400;
129
+ line-height: 1.4;
130
+ color: #3f3f3f;
131
+ }
132
+
133
+ [data-rich-colors='true'][data-sonner-toast][data-styled='true'] [data-description] {
134
+ color: inherit;
135
+ }
136
+
137
+ [data-sonner-toaster][data-sonner-theme='dark'] [data-description] {
138
+ color: hsl(0, 0%, 91%);
139
+ }
140
+
141
+ [data-sonner-toast][data-styled='true'] [data-title] {
142
+ font-weight: 500;
143
+ line-height: 1.5;
144
+ color: inherit;
145
+ }
146
+
147
+ [data-sonner-toast][data-styled='true'] [data-icon] {
148
+ display: flex;
149
+ height: 16px;
150
+ width: 16px;
151
+ position: relative;
152
+ justify-content: flex-start;
153
+ align-items: center;
154
+ flex-shrink: 0;
155
+ margin-left: var(--toast-icon-margin-start);
156
+ margin-right: var(--toast-icon-margin-end);
157
+ }
158
+
159
+ [data-sonner-toast][data-promise='true'] [data-icon] > svg {
160
+ opacity: 0;
161
+ transform: scale(0.8);
162
+ transform-origin: center;
163
+ animation: sonner-fade-in 300ms ease forwards;
164
+ }
165
+
166
+ [data-sonner-toast][data-styled='true'] [data-icon] > * {
167
+ flex-shrink: 0;
168
+ }
169
+
170
+ [data-sonner-toast][data-styled='true'] [data-icon] svg {
171
+ margin-left: var(--toast-svg-margin-start);
172
+ margin-right: var(--toast-svg-margin-end);
173
+ }
174
+
175
+ [data-sonner-toast][data-styled='true'] [data-content] {
176
+ display: flex;
177
+ flex-direction: column;
178
+ gap: 2px;
179
+ }
180
+
181
+ [data-sonner-toast][data-styled='true'] [data-button] {
182
+ border-radius: 4px;
183
+ padding-left: 8px;
184
+ padding-right: 8px;
185
+ height: 24px;
186
+ font-size: 12px;
187
+ color: var(--normal-bg);
188
+ background: var(--normal-text);
189
+ margin-left: var(--toast-button-margin-start);
190
+ margin-right: var(--toast-button-margin-end);
191
+ border: none;
192
+ font-weight: 500;
193
+ cursor: pointer;
194
+ outline: none;
195
+ display: flex;
196
+ align-items: center;
197
+ flex-shrink: 0;
198
+ transition: opacity 400ms, box-shadow 200ms;
199
+ }
200
+
201
+ [data-sonner-toast][data-styled='true'] [data-button]:focus-visible {
202
+ box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.4);
203
+ }
204
+
205
+ [data-sonner-toast][data-styled='true'] [data-button]:first-of-type {
206
+ margin-left: var(--toast-button-margin-start);
207
+ margin-right: var(--toast-button-margin-end);
208
+ }
209
+
210
+ [data-sonner-toast][data-styled='true'] [data-cancel] {
211
+ color: var(--normal-text);
212
+ background: rgba(0, 0, 0, 0.08);
213
+ }
214
+
215
+ [data-sonner-toaster][data-sonner-theme='dark'] [data-sonner-toast][data-styled='true'] [data-cancel] {
216
+ background: rgba(255, 255, 255, 0.3);
217
+ }
218
+
219
+ [data-sonner-toast][data-styled='true'] [data-close-button] {
220
+ position: absolute;
221
+ left: var(--toast-close-button-start);
222
+ right: var(--toast-close-button-end);
223
+ top: 0;
224
+ height: 20px;
225
+ width: 20px;
226
+ display: flex;
227
+ justify-content: center;
228
+ align-items: center;
229
+ padding: 0;
230
+ color: var(--normal-text);
231
+ background: var(--normal-bg);
232
+ border: 1px solid var(--normal-border);
233
+ transform: var(--toast-close-button-transform);
234
+ border-radius: 50%;
235
+ cursor: pointer;
236
+ z-index: 1;
237
+ transition: opacity 100ms, background 200ms, border-color 200ms;
238
+ }
239
+
240
+ [data-sonner-toast][data-styled='true'] [data-close-button]:focus-visible {
241
+ box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.1), 0 0 0 2px rgba(0, 0, 0, 0.2);
242
+ }
243
+
244
+ [data-sonner-toast][data-styled='true'] [data-disabled='true'] {
245
+ cursor: not-allowed;
246
+ }
247
+
248
+ [data-sonner-toast][data-styled='true']:hover [data-close-button]:hover {
249
+ background: var(--gray2);
250
+ border-color: var(--gray5);
251
+ }
252
+
253
+ [data-sonner-toast][data-swiping='true']::before {
254
+ content: '';
255
+ position: absolute;
256
+ left: -100%;
257
+ right: -100%;
258
+ height: 100%;
259
+ z-index: -1;
260
+ }
261
+
262
+ [data-sonner-toast][data-y-position='top'][data-swiping='true']::before {
263
+ bottom: 50%;
264
+ transform: scaleY(3) translateY(50%);
265
+ }
266
+
267
+ [data-sonner-toast][data-y-position='bottom'][data-swiping='true']::before {
268
+ top: 50%;
269
+ transform: scaleY(3) translateY(-50%);
270
+ }
271
+
272
+ [data-sonner-toast][data-swiping='false'][data-removed='true']::before {
273
+ content: '';
274
+ position: absolute;
275
+ inset: 0;
276
+ transform: scaleY(2);
277
+ }
278
+
279
+ [data-sonner-toast][data-expanded='true']::after {
280
+ content: '';
281
+ position: absolute;
282
+ left: 0;
283
+ height: calc(var(--gap) + 1px);
284
+ bottom: 100%;
285
+ width: 100%;
286
+ }
287
+
288
+ [data-sonner-toast][data-mounted='true'] {
289
+ --y: translateY(0);
290
+ opacity: 1;
291
+ }
292
+
293
+ [data-sonner-toast][data-expanded='false'][data-front='false'] {
294
+ --scale: var(--toasts-before) * 0.05 + 1;
295
+ --y: translateY(calc(var(--lift-amount) * var(--toasts-before))) scale(calc(-1 * var(--scale)));
296
+ height: var(--front-toast-height);
297
+ }
298
+
299
+ [data-sonner-toast] > * {
300
+ transition: opacity 400ms;
301
+ }
302
+
303
+ [data-sonner-toast][data-x-position='right'] {
304
+ right: 0;
305
+ }
306
+
307
+ [data-sonner-toast][data-x-position='left'] {
308
+ left: 0;
309
+ }
310
+
311
+ [data-sonner-toast][data-expanded='false'][data-front='false'][data-styled='true'] > * {
312
+ opacity: 0;
313
+ }
314
+
315
+ [data-sonner-toast][data-visible='false'] {
316
+ opacity: 0;
317
+ pointer-events: none;
318
+ }
319
+
320
+ [data-sonner-toast][data-mounted='true'][data-expanded='true'] {
321
+ --y: translateY(calc(var(--lift) * var(--offset)));
322
+ height: var(--initial-height);
323
+ }
324
+
325
+ [data-sonner-toast][data-removed='true'][data-front='true'][data-swipe-out='false'] {
326
+ --y: translateY(calc(var(--lift) * -100%));
327
+ opacity: 0;
328
+ }
329
+
330
+ [data-sonner-toast][data-removed='true'][data-front='false'][data-swipe-out='false'][data-expanded='true'] {
331
+ --y: translateY(calc(var(--lift) * var(--offset) + var(--lift) * -100%));
332
+ opacity: 0;
333
+ }
334
+
335
+ [data-sonner-toast][data-removed='true'][data-front='false'][data-swipe-out='false'][data-expanded='false'] {
336
+ --y: translateY(40%);
337
+ opacity: 0;
338
+ transition: transform 500ms, opacity 200ms;
339
+ }
340
+
341
+ [data-sonner-toast][data-removed='true'][data-front='false']::before {
342
+ height: calc(var(--initial-height) + 20%);
343
+ }
344
+
345
+ [data-sonner-toast][data-swiping='true'] {
346
+ transform: var(--y) translateY(var(--swipe-amount-y, 0px)) translateX(var(--swipe-amount-x, 0px));
347
+ transition: none;
348
+ }
349
+
350
+ [data-sonner-toast][data-swiped='true'] {
351
+ -webkit-user-select: none; /* Safari 3+ */
352
+ user-select: none;
353
+ }
354
+
355
+ [data-sonner-toast][data-swipe-out='true'][data-y-position='bottom'],
356
+ [data-sonner-toast][data-swipe-out='true'][data-y-position='top'] {
357
+ animation-duration: 200ms;
358
+ animation-timing-function: ease-out;
359
+ animation-fill-mode: forwards;
360
+ }
361
+
362
+ [data-sonner-toast][data-swipe-out='true'][data-swipe-direction='left'] {
363
+ animation-name: swipe-out-left;
364
+ }
365
+
366
+ [data-sonner-toast][data-swipe-out='true'][data-swipe-direction='right'] {
367
+ animation-name: swipe-out-right;
368
+ }
369
+
370
+ [data-sonner-toast][data-swipe-out='true'][data-swipe-direction='up'] {
371
+ animation-name: swipe-out-up;
372
+ }
373
+
374
+ [data-sonner-toast][data-swipe-out='true'][data-swipe-direction='down'] {
375
+ animation-name: swipe-out-down;
376
+ }
377
+
378
+ @keyframes swipe-out-left {
379
+ from {
380
+ transform: var(--y) translateX(var(--swipe-amount-x));
381
+ opacity: 1;
382
+ }
383
+
384
+ to {
385
+ transform: var(--y) translateX(calc(var(--swipe-amount-x) - 100%));
386
+ opacity: 0;
387
+ }
388
+ }
389
+
390
+ @keyframes swipe-out-right {
391
+ from {
392
+ transform: var(--y) translateX(var(--swipe-amount-x));
393
+ opacity: 1;
394
+ }
395
+
396
+ to {
397
+ transform: var(--y) translateX(calc(var(--swipe-amount-x) + 100%));
398
+ opacity: 0;
399
+ }
400
+ }
401
+
402
+ @keyframes swipe-out-up {
403
+ from {
404
+ transform: var(--y) translateY(var(--swipe-amount-y));
405
+ opacity: 1;
406
+ }
407
+
408
+ to {
409
+ transform: var(--y) translateY(calc(var(--swipe-amount-y) - 100%));
410
+ opacity: 0;
411
+ }
412
+ }
413
+
414
+ @keyframes swipe-out-down {
415
+ from {
416
+ transform: var(--y) translateY(var(--swipe-amount-y));
417
+ opacity: 1;
418
+ }
419
+
420
+ to {
421
+ transform: var(--y) translateY(calc(var(--swipe-amount-y) + 100%));
422
+ opacity: 0;
423
+ }
424
+ }
425
+
426
+ @media (max-width: 600px) {
427
+ [data-sonner-toaster] {
428
+ position: fixed;
429
+ right: var(--mobile-offset-right);
430
+ left: var(--mobile-offset-left);
431
+ width: 100%;
432
+ }
433
+
434
+ [data-sonner-toaster][dir='rtl'] {
435
+ left: calc(var(--mobile-offset-left) * -1);
436
+ }
437
+
438
+ [data-sonner-toaster] [data-sonner-toast] {
439
+ left: 0;
440
+ right: 0;
441
+ width: calc(100% - var(--mobile-offset-left) * 2);
442
+ }
443
+
444
+ [data-sonner-toaster][data-x-position='left'] {
445
+ left: var(--mobile-offset-left);
446
+ }
447
+
448
+ [data-sonner-toaster][data-y-position='bottom'] {
449
+ bottom: var(--mobile-offset-bottom);
450
+ }
451
+
452
+ [data-sonner-toaster][data-y-position='top'] {
453
+ top: var(--mobile-offset-top);
454
+ }
455
+
456
+ [data-sonner-toaster][data-x-position='center'] {
457
+ left: var(--mobile-offset-left);
458
+ right: var(--mobile-offset-right);
459
+ transform: none;
460
+ }
461
+ }
462
+
463
+ [data-sonner-toaster][data-sonner-theme='light'] {
464
+ --normal-bg: #fff;
465
+ --normal-border: var(--gray4);
466
+ --normal-text: var(--gray12);
467
+
468
+ --success-bg: hsl(143, 85%, 96%);
469
+ --success-border: hsl(145, 92%, 87%);
470
+ --success-text: hsl(140, 100%, 27%);
471
+
472
+ --info-bg: hsl(208, 100%, 97%);
473
+ --info-border: hsl(221, 91%, 93%);
474
+ --info-text: hsl(210, 92%, 45%);
475
+
476
+ --warning-bg: hsl(49, 100%, 97%);
477
+ --warning-border: hsl(49, 91%, 84%);
478
+ --warning-text: hsl(31, 92%, 45%);
479
+
480
+ --error-bg: hsl(359, 100%, 97%);
481
+ --error-border: hsl(359, 100%, 94%);
482
+ --error-text: hsl(360, 100%, 45%);
483
+ }
484
+
485
+ [data-sonner-toaster][data-sonner-theme='light'] [data-sonner-toast][data-invert='true'] {
486
+ --normal-bg: #000;
487
+ --normal-border: hsl(0, 0%, 20%);
488
+ --normal-text: var(--gray1);
489
+ }
490
+
491
+ [data-sonner-toaster][data-sonner-theme='dark'] [data-sonner-toast][data-invert='true'] {
492
+ --normal-bg: #fff;
493
+ --normal-border: var(--gray3);
494
+ --normal-text: var(--gray12);
495
+ }
496
+
497
+ [data-sonner-toaster][data-sonner-theme='dark'] {
498
+ --normal-bg: #000;
499
+ --normal-bg-hover: hsl(0, 0%, 12%);
500
+ --normal-border: hsl(0, 0%, 20%);
501
+ --normal-border-hover: hsl(0, 0%, 25%);
502
+ --normal-text: var(--gray1);
503
+
504
+ --success-bg: hsl(150, 100%, 6%);
505
+ --success-border: hsl(147, 100%, 12%);
506
+ --success-text: hsl(150, 86%, 65%);
507
+
508
+ --info-bg: hsl(215, 100%, 6%);
509
+ --info-border: hsl(223, 43%, 17%);
510
+ --info-text: hsl(216, 87%, 65%);
511
+
512
+ --warning-bg: hsl(64, 100%, 6%);
513
+ --warning-border: hsl(60, 100%, 9%);
514
+ --warning-text: hsl(46, 87%, 65%);
515
+
516
+ --error-bg: hsl(358, 76%, 10%);
517
+ --error-border: hsl(357, 89%, 16%);
518
+ --error-text: hsl(358, 100%, 81%);
519
+ }
520
+
521
+ [data-sonner-toaster][data-sonner-theme='dark'] [data-sonner-toast] [data-close-button] {
522
+ background: var(--normal-bg);
523
+ border-color: var(--normal-border);
524
+ color: var(--normal-text);
525
+ }
526
+
527
+ [data-sonner-toaster][data-sonner-theme='dark'] [data-sonner-toast] [data-close-button]:hover {
528
+ background: var(--normal-bg-hover);
529
+ border-color: var(--normal-border-hover);
530
+ }
531
+
532
+ [data-rich-colors='true'][data-sonner-toast][data-type='success'] {
533
+ background: var(--success-bg);
534
+ border-color: var(--success-border);
535
+ color: var(--success-text);
536
+ }
537
+
538
+ [data-rich-colors='true'][data-sonner-toast][data-type='success'] [data-close-button] {
539
+ background: var(--success-bg);
540
+ border-color: var(--success-border);
541
+ color: var(--success-text);
542
+ }
543
+
544
+ [data-rich-colors='true'][data-sonner-toast][data-type='info'] {
545
+ background: var(--info-bg);
546
+ border-color: var(--info-border);
547
+ color: var(--info-text);
548
+ }
549
+
550
+ [data-rich-colors='true'][data-sonner-toast][data-type='info'] [data-close-button] {
551
+ background: var(--info-bg);
552
+ border-color: var(--info-border);
553
+ color: var(--info-text);
554
+ }
555
+
556
+ [data-rich-colors='true'][data-sonner-toast][data-type='warning'] {
557
+ background: var(--warning-bg);
558
+ border-color: var(--warning-border);
559
+ color: var(--warning-text);
560
+ }
561
+
562
+ [data-rich-colors='true'][data-sonner-toast][data-type='warning'] [data-close-button] {
563
+ background: var(--warning-bg);
564
+ border-color: var(--warning-border);
565
+ color: var(--warning-text);
566
+ }
567
+
568
+ [data-rich-colors='true'][data-sonner-toast][data-type='error'] {
569
+ background: var(--error-bg);
570
+ border-color: var(--error-border);
571
+ color: var(--error-text);
572
+ }
573
+
574
+ [data-rich-colors='true'][data-sonner-toast][data-type='error'] [data-close-button] {
575
+ background: var(--error-bg);
576
+ border-color: var(--error-border);
577
+ color: var(--error-text);
578
+ }
579
+
580
+ .sonner-loading-wrapper {
581
+ --size: 16px;
582
+ height: var(--size);
583
+ width: var(--size);
584
+ position: absolute;
585
+ inset: 0;
586
+ z-index: 10;
587
+ }
588
+
589
+ .sonner-loading-wrapper[data-visible='false'] {
590
+ transform-origin: center;
591
+ animation: sonner-fade-out 0.2s ease forwards;
592
+ }
593
+
594
+ .sonner-spinner {
595
+ position: relative;
596
+ top: 50%;
597
+ left: 50%;
598
+ height: var(--size);
599
+ width: var(--size);
600
+ }
601
+
602
+ .sonner-loading-bar {
603
+ animation: sonner-spin 1.2s linear infinite;
604
+ background: var(--gray11);
605
+ border-radius: 6px;
606
+ height: 8%;
607
+ left: -10%;
608
+ position: absolute;
609
+ top: -3.9%;
610
+ width: 24%;
611
+ }
612
+
613
+ .sonner-loading-bar:nth-child(1) {
614
+ animation-delay: -1.2s;
615
+ transform: rotate(0.0001deg) translate(146%);
616
+ }
617
+
618
+ .sonner-loading-bar:nth-child(2) {
619
+ animation-delay: -1.1s;
620
+ transform: rotate(30deg) translate(146%);
621
+ }
622
+
623
+ .sonner-loading-bar:nth-child(3) {
624
+ animation-delay: -1s;
625
+ transform: rotate(60deg) translate(146%);
626
+ }
627
+
628
+ .sonner-loading-bar:nth-child(4) {
629
+ animation-delay: -0.9s;
630
+ transform: rotate(90deg) translate(146%);
631
+ }
632
+
633
+ .sonner-loading-bar:nth-child(5) {
634
+ animation-delay: -0.8s;
635
+ transform: rotate(120deg) translate(146%);
636
+ }
637
+
638
+ .sonner-loading-bar:nth-child(6) {
639
+ animation-delay: -0.7s;
640
+ transform: rotate(150deg) translate(146%);
641
+ }
642
+
643
+ .sonner-loading-bar:nth-child(7) {
644
+ animation-delay: -0.6s;
645
+ transform: rotate(180deg) translate(146%);
646
+ }
647
+
648
+ .sonner-loading-bar:nth-child(8) {
649
+ animation-delay: -0.5s;
650
+ transform: rotate(210deg) translate(146%);
651
+ }
652
+
653
+ .sonner-loading-bar:nth-child(9) {
654
+ animation-delay: -0.4s;
655
+ transform: rotate(240deg) translate(146%);
656
+ }
657
+
658
+ .sonner-loading-bar:nth-child(10) {
659
+ animation-delay: -0.3s;
660
+ transform: rotate(270deg) translate(146%);
661
+ }
662
+
663
+ .sonner-loading-bar:nth-child(11) {
664
+ animation-delay: -0.2s;
665
+ transform: rotate(300deg) translate(146%);
666
+ }
667
+
668
+ .sonner-loading-bar:nth-child(12) {
669
+ animation-delay: -0.1s;
670
+ transform: rotate(330deg) translate(146%);
671
+ }
672
+
673
+ @keyframes sonner-fade-in {
674
+ 0% {
675
+ opacity: 0;
676
+ transform: scale(0.8);
677
+ }
678
+ 100% {
679
+ opacity: 1;
680
+ transform: scale(1);
681
+ }
682
+ }
683
+
684
+ @keyframes sonner-fade-out {
685
+ 0% {
686
+ opacity: 1;
687
+ transform: scale(1);
688
+ }
689
+ 100% {
690
+ opacity: 0;
691
+ transform: scale(0.8);
692
+ }
693
+ }
694
+
695
+ @keyframes sonner-spin {
696
+ 0% {
697
+ opacity: 1;
698
+ }
699
+ 100% {
700
+ opacity: 0.15;
701
+ }
702
+ }
703
+
704
+ @media (prefers-reduced-motion) {
705
+ [data-sonner-toast],
706
+ [data-sonner-toast] > *,
707
+ .sonner-loading-bar {
708
+ transition: none !important;
709
+ animation: none !important;
710
+ }
711
+ }
712
+
713
+ .sonner-loader {
714
+ position: absolute;
715
+ top: 50%;
716
+ left: 50%;
717
+ transform: translate(-50%, -50%);
718
+ transform-origin: center;
719
+ transition: opacity 200ms, transform 200ms;
720
+ }
721
+
722
+ .sonner-loader[data-visible='false'] {
723
+ opacity: 0;
724
+ transform: scale(0.8) translate(-50%, -50%);
725
+ }