@chrryai/chrry 1.1.78

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 (116) hide show
  1. package/About.module.scss +112 -0
  2. package/Account.module.scss +159 -0
  3. package/AddToHomeScreen.module.scss +126 -0
  4. package/Affiliate.module.scss +245 -0
  5. package/AffiliateDashboard.module.scss +269 -0
  6. package/Agent.module.scss +197 -0
  7. package/AnimatedWrapper.module.scss +0 -0
  8. package/App.module.scss +283 -0
  9. package/Bookmark.module.scss +15 -0
  10. package/Calendar.module.scss +824 -0
  11. package/CharacterProfiles.module.scss +29 -0
  12. package/Chat.module.scss +932 -0
  13. package/Checkbox.module.scss +67 -0
  14. package/Chrry.module.scss +69 -0
  15. package/Collaborate.module.scss +22 -0
  16. package/CollaborationStatus.module.scss +17 -0
  17. package/CollaborationTooltip.module.scss +257 -0
  18. package/ColorScheme.module.scss +24 -0
  19. package/EditThread.module.scss +51 -0
  20. package/EmptyStateTips.module.scss +52 -0
  21. package/EnableNotifications.module.scss +20 -0
  22. package/EventModal.module.scss +277 -0
  23. package/Img.module.scss +48 -0
  24. package/Instructions.module.scss +333 -0
  25. package/LICENSE +664 -0
  26. package/LanguageSwitcher.module.scss +21 -0
  27. package/Loading.module.scss +32 -0
  28. package/MarkdownContent.module.scss +161 -0
  29. package/MemoryConsent.module.scss +41 -0
  30. package/Menu.module.scss +272 -0
  31. package/Message.module.scss +470 -0
  32. package/Messages.module.scss +86 -0
  33. package/Modal.module.scss +118 -0
  34. package/README.md +112 -0
  35. package/Search.module.scss +26 -0
  36. package/Select.module.scss +32 -0
  37. package/Share.module.scss +84 -0
  38. package/Sidebar.module.scss +69 -0
  39. package/SignIn.module.scss +129 -0
  40. package/Skeleton.module.scss +232 -0
  41. package/SplashScreen.module.scss +189 -0
  42. package/Star.module.scss +15 -0
  43. package/Store.module.scss +240 -0
  44. package/Subscribe.module.scss +219 -0
  45. package/Testimonials.module.scss +33 -0
  46. package/Thread.module.scss +111 -0
  47. package/Threads.module.scss +105 -0
  48. package/TypingIndicator.module.scss +93 -0
  49. package/Users.module.scss +98 -0
  50. package/Version.module.scss +22 -0
  51. package/Weather.module.scss +31 -0
  52. package/Why.module.scss +79 -0
  53. package/__tests__/README.md +126 -0
  54. package/__tests__/TestComponent.module.scss +236 -0
  55. package/animations.scss +163 -0
  56. package/breakpoints.scss +8 -0
  57. package/context/AppContext.module.scss +22 -0
  58. package/context/providers/README.md +329 -0
  59. package/dist/About.module-RPTFOKG6.scss +112 -0
  60. package/dist/Account.module-AA2NOD5S.scss +159 -0
  61. package/dist/AddToHomeScreen.module-P6HAQ4QD.scss +126 -0
  62. package/dist/Affiliate.module-YM7MG54E.scss +245 -0
  63. package/dist/AffiliateDashboard.module-SZQJJBME.scss +269 -0
  64. package/dist/Agent.module-66YIBDMM.scss +197 -0
  65. package/dist/App.module-TOWYJFPB.scss +283 -0
  66. package/dist/Bookmark.module-UVMQ4TED.scss +15 -0
  67. package/dist/Calendar.module-HHEIXJEA.scss +824 -0
  68. package/dist/CharacterProfiles.module-KABR34TV.scss +29 -0
  69. package/dist/Chat.module-Y4TGJLBQ.scss +932 -0
  70. package/dist/Checkbox.module-RNW2YOC5.scss +67 -0
  71. package/dist/Chrry.module-SLPTRY52.scss +69 -0
  72. package/dist/Collaborate.module-MLRE23FZ.scss +22 -0
  73. package/dist/CollaborationStatus.module-CRGOOW56.scss +17 -0
  74. package/dist/ColorScheme.module-N7SJ5N52.scss +24 -0
  75. package/dist/EditThread.module-L3HOEGS3.scss +51 -0
  76. package/dist/EmptyStateTips.module-JLNPQ4OO.scss +52 -0
  77. package/dist/EnableNotifications.module-C4MYQTUA.scss +20 -0
  78. package/dist/EventModal.module-K7VNKTCE.scss +277 -0
  79. package/dist/Instructions.module-JMFWEXAP.scss +333 -0
  80. package/dist/LanguageSwitcher.module-MT2SIZ4L.scss +21 -0
  81. package/dist/Loading.module-OU42QILE.scss +32 -0
  82. package/dist/MarkdownContent.module-64GHE3YP.scss +161 -0
  83. package/dist/MemoryConsent.module-FZL3REH4.scss +41 -0
  84. package/dist/Menu.module-RVXPXILR.scss +272 -0
  85. package/dist/Message.module-5UUYCVY2.scss +470 -0
  86. package/dist/Messages.module-GBPUAPAI.scss +86 -0
  87. package/dist/Modal.module-TOU4YLFQ.scss +118 -0
  88. package/dist/Search.module-GU3BRADG.scss +26 -0
  89. package/dist/Select.module-R7QM256C.scss +32 -0
  90. package/dist/Share.module-VQBCBSA5.scss +84 -0
  91. package/dist/Sidebar.module-AUSDVTCY.scss +69 -0
  92. package/dist/SignIn.module-53SOSG63.scss +129 -0
  93. package/dist/Skeleton.module-REMEBLDY.scss +232 -0
  94. package/dist/Store.module-NP6776GY.scss +240 -0
  95. package/dist/Subscribe.module-NVGQ57RA.scss +219 -0
  96. package/dist/Thread.module-QAJI6KOQ.scss +111 -0
  97. package/dist/Threads.module-J54DFQQZ.scss +105 -0
  98. package/dist/Users.module-ZRHCY63D.scss +98 -0
  99. package/dist/Version.module-MLMD7GW5.scss +22 -0
  100. package/dist/Weather.module-NT6XFKA7.scss +31 -0
  101. package/dist/Why.module-UVZJCJF7.scss +79 -0
  102. package/dist/index.d.mts +1408 -0
  103. package/dist/index.d.ts +1408 -0
  104. package/dist/index.js +44600 -0
  105. package/dist/index.js.map +1 -0
  106. package/dist/index.mjs +44575 -0
  107. package/dist/index.mjs.map +1 -0
  108. package/dist/react-tooltip.min-LLVNRY3Z.css +1 -0
  109. package/globals.css +91 -0
  110. package/globals.scss +585 -0
  111. package/icons/README.md +150 -0
  112. package/package.json +118 -0
  113. package/styles/view-transitions.css +207 -0
  114. package/toRem.scss +6 -0
  115. package/utils.module.scss +116 -0
  116. package/utils.scss +88 -0
@@ -0,0 +1,277 @@
1
+ @use "./toRem.scss";
2
+
3
+ .overlay {
4
+ position: fixed;
5
+ top: 0;
6
+ left: 0;
7
+ right: 0;
8
+ bottom: 0;
9
+ background: rgba(0, 0, 0, 0.5);
10
+ backdrop-filter: blur(4px);
11
+ display: flex;
12
+ align-items: center;
13
+ justify-content: center;
14
+ z-index: 1000;
15
+ padding: 20px;
16
+ }
17
+
18
+ .modal {
19
+ background: var(--background);
20
+ border: 1px solid var(--shade-2);
21
+ border-radius: var(--radius-lg);
22
+ box-shadow: var(--shadow-lg);
23
+ width: 100%;
24
+ max-width: 500px;
25
+ max-height: 90vh;
26
+ overflow-y: auto;
27
+ animation: modalSlideIn 0.2s ease-out;
28
+ }
29
+
30
+ @keyframes modalSlideIn {
31
+ from {
32
+ opacity: 0;
33
+ transform: scale(0.95) translateY(-10px);
34
+ }
35
+ to {
36
+ opacity: 1;
37
+ transform: scale(1) translateY(0);
38
+ }
39
+ }
40
+
41
+ .header {
42
+ display: flex;
43
+ align-items: center;
44
+ justify-content: space-between;
45
+ padding: 20px 24px 16px;
46
+ border-bottom: 1px solid var(--shade-2);
47
+
48
+ h2 {
49
+ font-size: toRem.toRem(18);
50
+ font-weight: 600;
51
+ margin: 0;
52
+ color: var(--text-primary);
53
+ }
54
+ }
55
+
56
+ .closeButton {
57
+ background: none;
58
+ border: none;
59
+ color: var(--text-secondary);
60
+ cursor: pointer;
61
+ padding: 4px;
62
+ border-radius: var(--radius);
63
+ transition: all 0.2s ease;
64
+
65
+ &:hover {
66
+ background: var(--shade-1);
67
+ color: var(--text-primary);
68
+ }
69
+ }
70
+
71
+ .form {
72
+ display: flex;
73
+ flex-direction: column;
74
+ gap: 20px;
75
+ }
76
+
77
+ .field {
78
+ display: flex;
79
+ align-items: center;
80
+ gap: 12px;
81
+ }
82
+
83
+ .fieldIcon {
84
+ color: var(--text-secondary);
85
+ flex-shrink: 0;
86
+ }
87
+
88
+ .titleInput {
89
+ flex: 1;
90
+ width: 100%;
91
+ background: none;
92
+ border: none;
93
+ font-size: toRem.toRem(24);
94
+ font-weight: 500;
95
+ color: var(--text-primary);
96
+ padding: 8px 0;
97
+ border-bottom: 2px solid transparent;
98
+ transition: border-color 0.2s ease;
99
+
100
+ &:focus {
101
+ outline: none;
102
+ border-bottom-color: var(--primary);
103
+ }
104
+
105
+ &::placeholder {
106
+ color: var(--text-disabled);
107
+ }
108
+ }
109
+
110
+ .input {
111
+ flex: 1;
112
+ background: var(--shade-1);
113
+ border: 1px solid var(--shade-2);
114
+ border-radius: var(--radius);
115
+ padding: 12px 16px;
116
+ font-size: toRem.toRem(14);
117
+ color: var(--text-primary);
118
+ transition: all 0.2s ease;
119
+
120
+ &:focus {
121
+ outline: none;
122
+ border-color: var(--primary);
123
+ box-shadow: 0 0 0 3px var(--primary-light);
124
+ }
125
+
126
+ &::placeholder {
127
+ color: var(--text-secondary);
128
+ }
129
+ }
130
+
131
+ .descriptionEdit {
132
+ display: flex;
133
+ flex-direction: column;
134
+ gap: toRem.toRem(10);
135
+ flex: 1;
136
+ width: 100%;
137
+
138
+ button {
139
+ align-self: flex-start;
140
+ }
141
+ }
142
+ .textarea {
143
+ min-height: 120px;
144
+ width: 100%;
145
+ }
146
+
147
+ .descriptionView {
148
+ width: 100%;
149
+ min-height: 80px;
150
+ color: var(--text);
151
+ line-height: 1.5;
152
+ white-space: pre-wrap;
153
+ word-break: break-word;
154
+
155
+ :global(a) {
156
+ color: var(--primary);
157
+ text-decoration: underline;
158
+
159
+ &:hover {
160
+ color: var(--primary-dark);
161
+ }
162
+ }
163
+ }
164
+
165
+ .allDayToggle {
166
+ display: flex;
167
+ align-items: center;
168
+ gap: 8px;
169
+ cursor: pointer;
170
+ padding: 8px 0;
171
+
172
+ input[type="checkbox"] {
173
+ width: 16px;
174
+ height: 16px;
175
+ accent-color: var(--primary);
176
+ }
177
+
178
+ span {
179
+ font-size: toRem.toRem(14);
180
+ color: var(--text-primary);
181
+ }
182
+ }
183
+
184
+ .dateTimeSection {
185
+ .field {
186
+ align-items: center;
187
+ }
188
+ }
189
+
190
+ .dateTimeGroup {
191
+ display: flex;
192
+ flex-direction: column;
193
+ gap: 6px;
194
+
195
+ label {
196
+ font-size: toRem.toRem(12);
197
+ font-weight: 500;
198
+ color: var(--text-secondary);
199
+ text-transform: uppercase;
200
+ letter-spacing: 0.5px;
201
+ }
202
+ }
203
+
204
+ .dateTimeInput {
205
+ font-size: toRem.toRem(13);
206
+ transition: all 0.2s ease;
207
+ margin-left: auto;
208
+ font-family: var(--font-mono) !important;
209
+ font-size: toRem.toRem(13.5) !important;
210
+
211
+ &:invalid {
212
+ border-color: var(--accent-0);
213
+ }
214
+
215
+ // Style the calendar picker icon
216
+ &::-webkit-calendar-picker-indicator {
217
+ filter: invert(0.5);
218
+ cursor: pointer;
219
+
220
+ &:hover {
221
+ filter: invert(0.3);
222
+ }
223
+ }
224
+ }
225
+
226
+ .error {
227
+ color: var(--accent-0);
228
+ font-size: toRem.toRem(12);
229
+ }
230
+
231
+ .fieldWrapper {
232
+ .error {
233
+ text-align: right;
234
+ margin-top: toRem.toRem(5);
235
+ }
236
+ }
237
+
238
+ .colorSection {
239
+ flex: 1;
240
+ display: flex;
241
+ align-items: center;
242
+ gap: 12px;
243
+ }
244
+
245
+ .colorLabel {
246
+ font-size: toRem.toRem(14);
247
+ color: var(--text-primary);
248
+ min-width: 40px;
249
+ }
250
+
251
+ .colorOptions {
252
+ display: flex;
253
+ gap: toRem.toRem(6);
254
+ }
255
+
256
+ .colorOption {
257
+ transition: all 0.2s ease;
258
+ &:hover {
259
+ transform: scale(1.15);
260
+ }
261
+
262
+ &.selected {
263
+ border-color: var(--foreground);
264
+
265
+ transform: scale(1.3);
266
+ }
267
+ }
268
+
269
+ .actions {
270
+ display: flex;
271
+ align-items: center;
272
+ justify-content: flex-end;
273
+ gap: toRem.toRem(10);
274
+ padding-top: toRem.toRem(10);
275
+ border-top: 1px solid var(--shade-2);
276
+ flex-wrap: wrap;
277
+ }
@@ -0,0 +1,48 @@
1
+ @use "breakpoints";
2
+ @use "utils";
3
+ @use "toRem";
4
+
5
+ .errorMessage {
6
+ padding: 0;
7
+ font-size: toRem.toRem(12);
8
+ flex-grow: 0;
9
+ flex-shrink: 0;
10
+ @media (max-width: (breakpoints.$breakpoint-mobile-max)) {
11
+ width: 100% !important;
12
+ }
13
+ }
14
+
15
+ .container {
16
+ display: flex;
17
+ align-items: center;
18
+ justify-content: center;
19
+ }
20
+
21
+ .loadingPlaceholder {
22
+ display: flex;
23
+ min-height: toRem.toRem(200);
24
+ align-items: center;
25
+ text-align: center;
26
+ justify-content: center;
27
+ flex-grow: 0;
28
+ flex-shrink: 0;
29
+ }
30
+
31
+ .img {
32
+ flex-grow: 0;
33
+ flex-shrink: 0;
34
+ display: flex;
35
+ animation: slideUp 0.1s ease forwards;
36
+ @include utils.respect-reduced-motion;
37
+ }
38
+
39
+ @keyframes slideUp {
40
+ from {
41
+ opacity: 0;
42
+ transform: translateY(toRem.toRem(15)); /* Start slightly below */
43
+ }
44
+ to {
45
+ opacity: 1;
46
+ transform: translateY(0); /* End at original position */
47
+ }
48
+ }
@@ -0,0 +1,333 @@
1
+ @use "./breakpoints.scss";
2
+ @use "./utils.scss";
3
+ @use "./toRem.scss";
4
+
5
+ .instructionsTextarea {
6
+ min-height: toRem.toRem(200);
7
+ border-style: dashed;
8
+ font-size: toRem.toRem(15);
9
+ }
10
+
11
+ .actions {
12
+ display: flex;
13
+ justify-content: flex-end;
14
+ gap: toRem.toRem(7.5);
15
+ margin-left: auto;
16
+ }
17
+
18
+ .modal {
19
+ width: 100% !important;
20
+ margin: 0 auto !important;
21
+ max-width: breakpoints.$breakpoint-mobile !important;
22
+ }
23
+
24
+ .instructionText {
25
+ display: flex;
26
+ align-items: center;
27
+ gap: toRem.toRem(10);
28
+ }
29
+
30
+ .updateModalDescription {
31
+ textarea {
32
+ width: 100% !important;
33
+ }
34
+ }
35
+
36
+ .video {
37
+ width: toRem.toRem(30);
38
+ height: toRem.toRem(30);
39
+ object-fit: cover;
40
+ border-radius: 50%;
41
+ pointer-events: none; // So clicks pass through to foreground content
42
+ }
43
+
44
+ .updateModalButtons {
45
+ display: flex;
46
+ justify-content: flex-end;
47
+ margin-top: toRem.toRem(5);
48
+ }
49
+
50
+ .titleField {
51
+ display: flex;
52
+ align-items: center;
53
+ gap: toRem.toRem(10);
54
+ margin-bottom: toRem.toRem(10);
55
+ input {
56
+ flex: 1;
57
+ }
58
+ }
59
+
60
+ .footer {
61
+ margin-top: toRem.toRem(10);
62
+
63
+ display: flex;
64
+ gap: toRem.toRem(10);
65
+ align-items: center;
66
+ }
67
+
68
+ .bottom {
69
+ display: flex;
70
+ font-size: toRem.toRem(14);
71
+ justify-content: center;
72
+ align-items: center;
73
+ gap: toRem.toRem(10);
74
+ margin-top: toRem.toRem(10);
75
+ }
76
+
77
+ .tip {
78
+ color: var(--shade-8);
79
+ font-size: toRem.toRem(14);
80
+ display: flex;
81
+ align-items: center;
82
+ gap: toRem.toRem(5);
83
+ margin-top: toRem.toRem(10);
84
+ }
85
+
86
+ .charLeft,
87
+ .maxCharCount {
88
+ color: var(--shade-6);
89
+ font-size: toRem.toRem(12);
90
+ color: var(--accent-4);
91
+ font-size: toRem.toRem(11);
92
+ font-weight: normal;
93
+
94
+ &.orange {
95
+ color: var(--accent-1);
96
+ }
97
+
98
+ &.red {
99
+ color: var(--accent-0);
100
+ }
101
+ }
102
+
103
+ .right {
104
+ margin-left: auto;
105
+ display: flex;
106
+ gap: toRem.toRem(7.5);
107
+ align-items: center;
108
+ }
109
+
110
+ .instructionsContainer {
111
+ display: flex;
112
+ flex-direction: column;
113
+ position: relative;
114
+ align-items: center;
115
+ gap: toRem.toRem(2.5);
116
+ }
117
+
118
+ .instructionsButtonContainer {
119
+ display: flex;
120
+ align-items: center;
121
+ gap: toRem.toRem(5);
122
+ }
123
+
124
+ .instructionsButton {
125
+ display: flex;
126
+ align-items: center;
127
+ gap: toRem.toRem(5);
128
+
129
+ &.icon {
130
+ gap: toRem.toRem(0);
131
+ }
132
+ }
133
+
134
+ .instructions {
135
+ display: flex;
136
+ flex-direction: column;
137
+ gap: toRem.toRem(8.5);
138
+ position: relative;
139
+ justify-content: center;
140
+ align-items: center;
141
+ }
142
+
143
+ .installAppButton {
144
+ @media all and (display-mode: standalone) {
145
+ display: none;
146
+ }
147
+
148
+ animation: pulse 1s ease-in-out;
149
+ @include utils.respect-reduced-motion;
150
+
151
+ &.standalone {
152
+ display: none;
153
+ }
154
+ }
155
+
156
+ .installButton {
157
+ animation: pulse 1s ease-in-out;
158
+ @include utils.respect-reduced-motion;
159
+ }
160
+
161
+ .instruction {
162
+ display: none;
163
+ align-items: center;
164
+ gap: toRem.toRem(5);
165
+ color: var(--shade-7) !important;
166
+ font-size: toRem.toRem(14);
167
+ text-align: center !important;
168
+ max-width: 100%;
169
+
170
+ &:nth-child(1),
171
+ &:nth-child(2),
172
+ &:nth-child(3) {
173
+ @media (min-height: toRem.toRem(550)) {
174
+ display: flex;
175
+ }
176
+ }
177
+
178
+ &:nth-child(4) {
179
+ @media (min-height: toRem.toRem(650)) {
180
+ display: flex;
181
+ }
182
+ }
183
+
184
+ &.selected {
185
+ color: var(--accent-6);
186
+ }
187
+
188
+ // &.standalone {
189
+ // @media (min-height: breakpoints.$breakpoint-mobile) {
190
+ // &:nth-child(5) {
191
+ // display: flex;
192
+ // }
193
+ // }
194
+ // }
195
+
196
+ @media (min-height: toRem.toRem(750)) {
197
+ @media all and (display-mode: standalone) {
198
+ display: flex;
199
+ }
200
+
201
+ &.standalone {
202
+ display: flex;
203
+ }
204
+ }
205
+
206
+ @media (min-height: breakpoints.$breakpoint-tablet) {
207
+ display: flex;
208
+ }
209
+
210
+ @media (min-width: breakpoints.$breakpoint-mobile-small) {
211
+ font-size: toRem.toRem(15);
212
+ }
213
+ }
214
+
215
+ .instructionEmoji {
216
+ flex-shrink: 0;
217
+ }
218
+
219
+ .instructionTitle {
220
+ overflow: hidden;
221
+ text-overflow: ellipsis;
222
+ white-space: nowrap;
223
+ flex: 1;
224
+ min-width: 0;
225
+ }
226
+
227
+ // .instructionsList {
228
+ // opacity: 0;
229
+
230
+ // @media (prefers-reduced-motion: reduce) {
231
+ // opacity: 1 !important;
232
+ // }
233
+ // }
234
+
235
+ // .instructionItem {
236
+ // opacity: 0;
237
+
238
+ // @media (prefers-reduced-motion: reduce) {
239
+ // opacity: 1 !important;
240
+ // }
241
+ // }
242
+
243
+ .filePreview {
244
+ position: relative;
245
+ display: flex;
246
+ align-items: center;
247
+ gap: toRem.toRem(8);
248
+ padding: toRem.toRem(8) toRem.toRem(12);
249
+ background: var(--shade-0);
250
+ border: toRem.toRem(1) solid var(--shade-2);
251
+ border-radius: 12.5px;
252
+ font-size: toRem.toRem(14);
253
+ color: var(--accent-6);
254
+ }
255
+
256
+ .filePreviewArea {
257
+ display: flex;
258
+ flex-wrap: wrap;
259
+ gap: toRem.toRem(8);
260
+ padding: toRem.toRem(12);
261
+ margin-bottom: toRem.toRem(8);
262
+ background: var(--shade-1);
263
+ border: toRem.toRem(1) solid var(--shade-2);
264
+ margin: toRem.toRem(-2.75) toRem.toRem(-10) 0 toRem.toRem(-10);
265
+ border-radius: toRem.toRem(16);
266
+ margin: toRem.toRem(12) 0 0 0;
267
+ }
268
+
269
+ .filePreviewImage {
270
+ width: toRem.toRem(32);
271
+ height: toRem.toRem(32);
272
+ border-radius: 4px;
273
+ object-fit: cover;
274
+ background: var(--shade-2);
275
+ }
276
+
277
+ .fileUploader {
278
+ display: flex;
279
+ gap: toRem.toRem(5);
280
+ margin-top: toRem.toRem(10);
281
+ }
282
+
283
+ .maxFiles {
284
+ color: var(--accent-1);
285
+ font-size: toRem.toRem(12);
286
+ }
287
+
288
+ .filePreviewIcon {
289
+ width: toRem.toRem(32);
290
+ height: toRem.toRem(32);
291
+ display: flex;
292
+ align-items: center;
293
+ justify-content: center;
294
+ background: var(--shade-2);
295
+ border-radius: 4px;
296
+ color: var(--accent-5);
297
+ }
298
+
299
+ .filePreviewInfo {
300
+ display: flex;
301
+ flex-direction: column;
302
+ gap: toRem.toRem(2);
303
+ }
304
+
305
+ .filePreviewName {
306
+ font-weight: 500;
307
+ font-size: toRem.toRem(13);
308
+ max-width: toRem.toRem(80);
309
+ overflow: hidden;
310
+ text-overflow: ellipsis;
311
+ white-space: nowrap;
312
+ }
313
+
314
+ .filePreviewSize {
315
+ font-size: toRem.toRem(11);
316
+ color: var(--accent-4);
317
+ }
318
+
319
+ .filePreviewClear {
320
+ position: absolute;
321
+ top: toRem.toRem(-4);
322
+ right: toRem.toRem(-4);
323
+ width: toRem.toRem(16);
324
+ height: toRem.toRem(16);
325
+ border-radius: 50%;
326
+ color: var(--accent-0);
327
+ border: toRem.toRem(2) solid var(--shade-0);
328
+ display: inline-flex;
329
+ align-items: center;
330
+ justify-content: center;
331
+ cursor: pointer;
332
+ transition: background-color 0.2s;
333
+ }