@tokis/theme 1.0.1 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,314 @@
1
+ /* ── DatePicker ────────────────────────────────────────────────────────────── */
2
+
3
+ .tokis-datepicker,
4
+ .tokis-timepicker,
5
+ .tokis-datetimepicker {
6
+ display: inline-flex;
7
+ flex-direction: column;
8
+ gap: var(--tokis-spacing-1, 4px);
9
+ min-width: 180px;
10
+ }
11
+
12
+ .tokis-datetimepicker {
13
+ flex-direction: row;
14
+ align-items: flex-end;
15
+ gap: var(--tokis-spacing-3, 12px);
16
+ min-width: 0;
17
+ }
18
+
19
+ /* ── Trigger button ─────────────────────────────────────────────────────────── */
20
+
21
+ .tokis-datepicker-input-wrap {
22
+ position: relative;
23
+ display: flex;
24
+ align-items: center;
25
+ }
26
+
27
+ .tokis-datepicker-trigger {
28
+ display: flex;
29
+ align-items: center;
30
+ justify-content: space-between;
31
+ gap: var(--tokis-spacing-2, 8px);
32
+ width: 100%;
33
+ padding: var(--tokis-spacing-2, 8px) var(--tokis-spacing-3, 12px);
34
+ border: 1px solid var(--tokis-color-border, #e2e8f0);
35
+ border-radius: var(--tokis-radius-md, 8px);
36
+ background: var(--tokis-color-background, #fff);
37
+ color: var(--tokis-color-text-primary, #0f172a);
38
+ font-size: var(--tokis-typography-fontSize-sm, 0.875rem);
39
+ cursor: pointer;
40
+ text-align: start;
41
+ transition: border-color 0.15s ease, box-shadow 0.15s ease;
42
+ outline: none;
43
+ min-width: 180px;
44
+ }
45
+
46
+ .tokis-datepicker-trigger:hover:not(:disabled) {
47
+ border-color: var(--tokis-color-border-strong, #cbd5e1);
48
+ }
49
+
50
+ .tokis-datepicker-trigger:focus-visible,
51
+ .tokis-datepicker-trigger--open {
52
+ border-color: var(--tokis-color-primary, #0066ff);
53
+ box-shadow: 0 0 0 3px var(--tokis-color-focus-ring, rgb(0 102 255 / 0.15));
54
+ }
55
+
56
+ .tokis-datepicker-trigger:disabled {
57
+ opacity: 0.5;
58
+ cursor: not-allowed;
59
+ background: var(--tokis-color-surface, #f8f9fa);
60
+ }
61
+
62
+ .tokis-datepicker--error .tokis-datepicker-trigger {
63
+ border-color: var(--tokis-color-error, #dc2626);
64
+ }
65
+
66
+ .tokis-datepicker-placeholder {
67
+ color: var(--tokis-color-text-tertiary, #94a3b8);
68
+ }
69
+
70
+ .tokis-datepicker-icon {
71
+ font-size: 1rem;
72
+ line-height: 1;
73
+ flex-shrink: 0;
74
+ }
75
+
76
+ .tokis-datepicker-clear {
77
+ position: absolute;
78
+ inset-inline-end: 36px;
79
+ top: 50%;
80
+ transform: translateY(-50%);
81
+ display: flex;
82
+ align-items: center;
83
+ justify-content: center;
84
+ width: 20px;
85
+ height: 20px;
86
+ padding: 0;
87
+ border: none;
88
+ background: none;
89
+ color: var(--tokis-color-text-tertiary, #94a3b8);
90
+ cursor: pointer;
91
+ font-size: 0.75rem;
92
+ border-radius: 50%;
93
+ transition: color 0.15s ease, background 0.15s ease;
94
+ }
95
+
96
+ .tokis-datepicker-clear:hover {
97
+ color: var(--tokis-color-text-primary, #0f172a);
98
+ background: var(--tokis-color-surface-hover, #f1f5f9);
99
+ }
100
+
101
+ /* ── Floating panel ─────────────────────────────────────────────────────────── */
102
+
103
+ .tokis-datepicker-panel {
104
+ position: absolute;
105
+ z-index: var(--tokis-z-index-popover, 1400);
106
+ background: var(--tokis-color-background, #fff);
107
+ border: 1px solid var(--tokis-color-border, #e2e8f0);
108
+ border-radius: var(--tokis-radius-lg, 12px);
109
+ box-shadow: var(--tokis-shadow-lg, 0 10px 40px rgb(0 0 0 / 0.12));
110
+ padding: var(--tokis-spacing-4, 16px);
111
+ min-width: 280px;
112
+ animation: tokis-panel-in 0.15s ease;
113
+ }
114
+
115
+ @keyframes tokis-panel-in {
116
+ from { opacity: 0; transform: translateY(-4px); }
117
+ to { opacity: 1; transform: translateY(0); }
118
+ }
119
+
120
+ /* ── Calendar ───────────────────────────────────────────────────────────────── */
121
+
122
+ .tokis-calendar {
123
+ display: flex;
124
+ flex-direction: column;
125
+ gap: var(--tokis-spacing-3, 12px);
126
+ width: 100%;
127
+ }
128
+
129
+ .tokis-calendar-nav {
130
+ display: flex;
131
+ align-items: center;
132
+ gap: var(--tokis-spacing-1, 4px);
133
+ }
134
+
135
+ .tokis-calendar-title {
136
+ flex: 1;
137
+ text-align: center;
138
+ font-weight: 600;
139
+ font-size: var(--tokis-typography-fontSize-sm, 0.875rem);
140
+ color: var(--tokis-color-text-primary, #0f172a);
141
+ }
142
+
143
+ .tokis-calendar-nav-btn {
144
+ display: inline-flex;
145
+ align-items: center;
146
+ justify-content: center;
147
+ width: 28px;
148
+ height: 28px;
149
+ padding: 0;
150
+ border: 1px solid transparent;
151
+ border-radius: var(--tokis-radius-md, 8px);
152
+ background: none;
153
+ color: var(--tokis-color-text-secondary, #475569);
154
+ cursor: pointer;
155
+ font-size: 0.875rem;
156
+ transition: background 0.1s ease, color 0.1s ease;
157
+ }
158
+
159
+ .tokis-calendar-nav-btn:hover {
160
+ background: var(--tokis-color-surface-hover, #f1f5f9);
161
+ color: var(--tokis-color-primary, #0066ff);
162
+ }
163
+
164
+ .tokis-calendar-nav-btn:focus-visible {
165
+ outline: 2px solid var(--tokis-color-primary, #0066ff);
166
+ outline-offset: 2px;
167
+ }
168
+
169
+ /* ── Day grid ───────────────────────────────────────────────────────────────── */
170
+
171
+ .tokis-calendar-grid {
172
+ width: 100%;
173
+ border-collapse: collapse;
174
+ table-layout: fixed;
175
+ }
176
+
177
+ .tokis-calendar-weekday {
178
+ padding-block-end: var(--tokis-spacing-2, 8px);
179
+ text-align: center;
180
+ font-size: 0.75rem;
181
+ font-weight: 600;
182
+ color: var(--tokis-color-text-secondary, #475569);
183
+ text-transform: uppercase;
184
+ letter-spacing: 0.04em;
185
+ }
186
+
187
+ .tokis-calendar-day {
188
+ text-align: center;
189
+ padding: 2px;
190
+ font-size: var(--tokis-typography-fontSize-sm, 0.875rem);
191
+ color: var(--tokis-color-text-primary, #0f172a);
192
+ cursor: pointer;
193
+ border-radius: var(--tokis-radius-md, 8px);
194
+ width: 36px;
195
+ height: 36px;
196
+ line-height: 32px;
197
+ transition: background 0.1s ease, color 0.1s ease;
198
+ outline: none;
199
+ user-select: none;
200
+ }
201
+
202
+ .tokis-calendar-day:hover:not(.tokis-calendar-day--disabled):not(.tokis-calendar-day--selected) {
203
+ background: var(--tokis-color-surface-hover, #f1f5f9);
204
+ }
205
+
206
+ .tokis-calendar-day--outside {
207
+ color: var(--tokis-color-text-tertiary, #94a3b8);
208
+ }
209
+
210
+ .tokis-calendar-day--today {
211
+ font-weight: 700;
212
+ color: var(--tokis-color-primary, #0066ff);
213
+ }
214
+
215
+ .tokis-calendar-day--selected {
216
+ background: var(--tokis-color-primary, #0066ff) !important;
217
+ color: var(--tokis-color-text-on-primary, #fff) !important;
218
+ font-weight: 600;
219
+ }
220
+
221
+ .tokis-calendar-day--disabled {
222
+ color: var(--tokis-color-text-disabled, #cbd5e1);
223
+ cursor: not-allowed;
224
+ }
225
+
226
+ .tokis-calendar-day--focused:focus-visible,
227
+ .tokis-calendar-day:focus-visible {
228
+ outline: 2px solid var(--tokis-color-primary, #0066ff);
229
+ outline-offset: 2px;
230
+ }
231
+
232
+ /* ── Today button ───────────────────────────────────────────────────────────── */
233
+
234
+ .tokis-calendar-footer {
235
+ display: flex;
236
+ justify-content: center;
237
+ padding-block-start: var(--tokis-spacing-2, 8px);
238
+ border-block-start: 1px solid var(--tokis-color-border, #e2e8f0);
239
+ }
240
+
241
+ .tokis-calendar-today-btn {
242
+ padding: var(--tokis-spacing-1, 4px) var(--tokis-spacing-3, 12px);
243
+ border: none;
244
+ border-radius: var(--tokis-radius-md, 8px);
245
+ background: none;
246
+ color: var(--tokis-color-primary, #0066ff);
247
+ font-size: var(--tokis-typography-fontSize-sm, 0.875rem);
248
+ font-weight: 500;
249
+ cursor: pointer;
250
+ transition: background 0.1s ease;
251
+ }
252
+
253
+ .tokis-calendar-today-btn:hover {
254
+ background: var(--tokis-color-primary-subtle, #e6f0ff);
255
+ }
256
+
257
+ /* ── TimePicker ─────────────────────────────────────────────────────────────── */
258
+
259
+ .tokis-timepicker-inputs {
260
+ display: flex;
261
+ align-items: center;
262
+ gap: var(--tokis-spacing-1, 4px);
263
+ }
264
+
265
+ .tokis-timepicker-select {
266
+ padding: var(--tokis-spacing-2, 8px) var(--tokis-spacing-2, 8px);
267
+ border: 1px solid var(--tokis-color-border, #e2e8f0);
268
+ border-radius: var(--tokis-radius-md, 8px);
269
+ background: var(--tokis-color-background, #fff);
270
+ color: var(--tokis-color-text-primary, #0f172a);
271
+ font-size: var(--tokis-typography-fontSize-sm, 0.875rem);
272
+ cursor: pointer;
273
+ outline: none;
274
+ width: 64px;
275
+ text-align: center;
276
+ transition: border-color 0.15s ease;
277
+ }
278
+
279
+ .tokis-timepicker-select:focus {
280
+ border-color: var(--tokis-color-primary, #0066ff);
281
+ box-shadow: 0 0 0 3px var(--tokis-color-focus-ring, rgb(0 102 255 / 0.15));
282
+ }
283
+
284
+ .tokis-timepicker-select:disabled {
285
+ opacity: 0.5;
286
+ cursor: not-allowed;
287
+ }
288
+
289
+ .tokis-timepicker-ampm {
290
+ width: 60px;
291
+ }
292
+
293
+ .tokis-timepicker-sep {
294
+ font-weight: 700;
295
+ color: var(--tokis-color-text-secondary, #475569);
296
+ font-size: 1rem;
297
+ line-height: 1;
298
+ }
299
+
300
+ .tokis-timepicker--error .tokis-timepicker-select {
301
+ border-color: var(--tokis-color-error, #dc2626);
302
+ }
303
+
304
+ /* ── Dark mode ──────────────────────────────────────────────────────────────── */
305
+
306
+ [data-theme="dark"] .tokis-datepicker-panel {
307
+ background: var(--tokis-color-surface, #1a202c);
308
+ border-color: var(--tokis-color-border, #2d3748);
309
+ }
310
+
311
+ [data-theme="dark"] .tokis-calendar-day--selected {
312
+ background: var(--tokis-color-primary, #0066ff) !important;
313
+ color: #fff !important;
314
+ }
@@ -28,39 +28,37 @@
28
28
  }
29
29
 
30
30
  .tokis-drawer-content--right {
31
- top: 0;
32
- right: 0;
33
- bottom: 0;
31
+ inset-block: 0;
32
+ inset-inline-end: 0;
34
33
  width: 400px;
35
34
  max-width: 90vw;
36
- border-left: 1px solid var(--tokis-color-border);
35
+ border-inline-start: 1px solid var(--tokis-color-border);
37
36
  animation: tokis-drawer-in-right var(--tokis-duration-slow) var(--tokis-ease-out);
38
37
  }
39
38
  .tokis-drawer-content--left {
40
- top: 0;
41
- left: 0;
42
- bottom: 0;
39
+ inset-block: 0;
40
+ inset-inline-start: 0;
43
41
  width: 400px;
44
42
  max-width: 90vw;
45
- border-right: 1px solid var(--tokis-color-border);
43
+ border-inline-end: 1px solid var(--tokis-color-border);
46
44
  animation: tokis-drawer-in-left var(--tokis-duration-slow) var(--tokis-ease-out);
47
45
  }
48
46
  .tokis-drawer-content--bottom {
49
- left: 0;
50
- right: 0;
47
+ inset-inline: 0;
51
48
  bottom: 0;
52
49
  max-height: 90dvh;
53
50
  border-top: 1px solid var(--tokis-color-border);
54
- border-radius: var(--tokis-radius-xl) var(--tokis-radius-xl) 0 0;
51
+ border-start-start-radius: var(--tokis-radius-xl);
52
+ border-start-end-radius: var(--tokis-radius-xl);
55
53
  animation: tokis-drawer-in-bottom var(--tokis-duration-slow) var(--tokis-ease-out);
56
54
  }
57
55
  .tokis-drawer-content--top {
58
- left: 0;
59
- right: 0;
56
+ inset-inline: 0;
60
57
  top: 0;
61
58
  max-height: 90dvh;
62
59
  border-bottom: 1px solid var(--tokis-color-border);
63
- border-radius: 0 0 var(--tokis-radius-xl) var(--tokis-radius-xl);
60
+ border-end-start-radius: var(--tokis-radius-xl);
61
+ border-end-end-radius: var(--tokis-radius-xl);
64
62
  animation: tokis-drawer-in-top var(--tokis-duration-slow) var(--tokis-ease-out);
65
63
  }
66
64
 
@@ -13,13 +13,19 @@
13
13
  border-radius: 0;
14
14
  }
15
15
  .tokis-button-group > .tokis-btn:first-child {
16
- border-radius: var(--tokis-radius-md) 0 0 var(--tokis-radius-md);
16
+ border-start-start-radius: var(--tokis-radius-md);
17
+ border-end-start-radius: var(--tokis-radius-md);
18
+ border-start-end-radius: 0;
19
+ border-end-end-radius: 0;
17
20
  }
18
21
  .tokis-button-group > .tokis-btn:last-child {
19
- border-radius: 0 var(--tokis-radius-md) var(--tokis-radius-md) 0;
22
+ border-start-start-radius: 0;
23
+ border-end-start-radius: 0;
24
+ border-start-end-radius: var(--tokis-radius-md);
25
+ border-end-end-radius: var(--tokis-radius-md);
20
26
  }
21
27
  .tokis-button-group > .tokis-btn--secondary + .tokis-btn--secondary {
22
- border-left-color: transparent;
28
+ border-inline-start-color: transparent;
23
29
  }
24
30
  .tokis-button-group--vertical {
25
31
  flex-direction: column;
@@ -29,10 +35,16 @@
29
35
  width: 100%;
30
36
  }
31
37
  .tokis-button-group--vertical > .tokis-btn:first-child {
32
- border-radius: var(--tokis-radius-md) var(--tokis-radius-md) 0 0;
38
+ border-start-start-radius: var(--tokis-radius-md);
39
+ border-start-end-radius: var(--tokis-radius-md);
40
+ border-end-start-radius: 0;
41
+ border-end-end-radius: 0;
33
42
  }
34
43
  .tokis-button-group--vertical > .tokis-btn:last-child {
35
- border-radius: 0 0 var(--tokis-radius-md) var(--tokis-radius-md);
44
+ border-start-start-radius: 0;
45
+ border-start-end-radius: 0;
46
+ border-end-start-radius: var(--tokis-radius-md);
47
+ border-end-end-radius: var(--tokis-radius-md);
36
48
  }
37
49
 
38
50
  /* ── FAB (Floating Action Button) ───────────────────────────── */
@@ -45,7 +57,7 @@
45
57
  font-size: 20px;
46
58
  position: fixed;
47
59
  bottom: var(--tokis-spacing-6);
48
- right: var(--tokis-spacing-6);
60
+ inset-inline-end: var(--tokis-spacing-6);
49
61
  z-index: var(--tokis-z-raised);
50
62
  }
51
63
  .tokis-fab:hover {
@@ -68,7 +80,7 @@
68
80
  justify-content: center;
69
81
  gap: var(--tokis-spacing-2);
70
82
  border: 0;
71
- border-right: 1px solid var(--tokis-color-border);
83
+ border-inline-end: 1px solid var(--tokis-color-border);
72
84
  background: transparent;
73
85
  color: var(--tokis-text-secondary);
74
86
  padding: var(--tokis-spacing-2) var(--tokis-spacing-3);
@@ -83,7 +95,7 @@
83
95
  white-space: nowrap;
84
96
  -webkit-tap-highlight-color: transparent;
85
97
  }
86
- .tokis-toggle-button:last-child { border-right: 0; }
98
+ .tokis-toggle-button:last-child { border-inline-end: 0; }
87
99
  .tokis-toggle-button:hover { background: var(--tokis-color-surface-hover); color: var(--tokis-text-primary); }
88
100
  .tokis-toggle-button:focus-visible { box-shadow: 0 0 0 2px inset var(--tokis-color-focus-ring); }
89
101
  .tokis-toggle-button--selected {
@@ -182,8 +194,8 @@
182
194
  .tokis-autocomplete-list {
183
195
  position: absolute;
184
196
  top: calc(100% + 4px);
185
- left: 0;
186
- right: 0;
197
+ inset-inline-start: 0;
198
+ inset-inline-end: 0;
187
199
  background: var(--tokis-color-surface-overlay);
188
200
  border: 1px solid var(--tokis-color-border);
189
201
  border-radius: var(--tokis-radius-lg);
@@ -200,7 +212,7 @@
200
212
  width: 100%;
201
213
  border: 0;
202
214
  background: transparent;
203
- text-align: left;
215
+ text-align: start;
204
216
  padding: var(--tokis-spacing-2) var(--tokis-spacing-3);
205
217
  cursor: pointer;
206
218
  color: var(--tokis-text-primary);
@@ -404,7 +416,7 @@
404
416
  box-shadow: var(--tokis-shadow-xs);
405
417
  }
406
418
  .tokis-app-bar--sticky { position: sticky; top: 0; z-index: var(--tokis-z-sticky); }
407
- .tokis-app-bar--fixed { position: fixed; top: 0; left: 0; right: 0; z-index: var(--tokis-z-sticky); }
419
+ .tokis-app-bar--fixed { position: fixed; top: 0; inset-inline-start: 0; inset-inline-end: 0; z-index: var(--tokis-z-sticky); }
408
420
 
409
421
  .tokis-app-bar__title {
410
422
  font-size: var(--tokis-font-size-lg);
@@ -416,7 +428,7 @@
416
428
  display: flex;
417
429
  align-items: center;
418
430
  gap: var(--tokis-spacing-2);
419
- margin-left: auto;
431
+ margin-inline-start: auto;
420
432
  }
421
433
 
422
434
  /* ── Paper / Surface ────────────────────────────────────────── */
@@ -442,8 +454,8 @@
442
454
  background: var(--tokis-color-surface-raised);
443
455
  position: fixed;
444
456
  bottom: 0;
445
- left: 0;
446
- right: 0;
457
+ inset-inline-start: 0;
458
+ inset-inline-end: 0;
447
459
  z-index: var(--tokis-z-sticky);
448
460
  }
449
461
  .tokis-bottom-nav-item {
@@ -553,8 +565,8 @@
553
565
  .tokis-number-field .tokis-input {
554
566
  border-radius: 0;
555
567
  text-align: center;
556
- border-left-color: transparent;
557
- border-right-color: transparent;
568
+ border-inline-start-color: transparent;
569
+ border-inline-end-color: transparent;
558
570
  }
559
571
  .tokis-number-field-btn {
560
572
  display: inline-flex;
@@ -571,8 +583,18 @@
571
583
  flex-shrink: 0;
572
584
  -webkit-tap-highlight-color: transparent;
573
585
  }
574
- .tokis-number-field-btn:first-child { border-radius: var(--tokis-radius-md) 0 0 var(--tokis-radius-md); }
575
- .tokis-number-field-btn:last-child { border-radius: 0 var(--tokis-radius-md) var(--tokis-radius-md) 0; }
586
+ .tokis-number-field-btn:first-child {
587
+ border-start-start-radius: var(--tokis-radius-md);
588
+ border-end-start-radius: var(--tokis-radius-md);
589
+ border-start-end-radius: 0;
590
+ border-end-end-radius: 0;
591
+ }
592
+ .tokis-number-field-btn:last-child {
593
+ border-start-start-radius: 0;
594
+ border-end-start-radius: 0;
595
+ border-start-end-radius: var(--tokis-radius-md);
596
+ border-end-end-radius: var(--tokis-radius-md);
597
+ }
576
598
  .tokis-number-field-btn:hover { background: var(--tokis-color-surface-hover); color: var(--tokis-text-primary); }
577
599
  .tokis-number-field-btn:focus-visible { box-shadow: 0 0 0 2px inset var(--tokis-color-focus-ring); }
578
600
 
@@ -624,7 +646,7 @@
624
646
  padding: 0;
625
647
  }
626
648
  .tokis-tree-list--nested {
627
- padding-left: var(--tokis-spacing-4);
649
+ padding-inline-start: var(--tokis-spacing-4);
628
650
  }
629
651
  .tokis-tree-item {
630
652
  border: 0;
@@ -639,7 +661,7 @@
639
661
  gap: var(--tokis-spacing-2);
640
662
  border-radius: var(--tokis-radius-sm);
641
663
  width: 100%;
642
- text-align: left;
664
+ text-align: start;
643
665
  transition: background var(--tokis-duration-fast) var(--tokis-ease-out);
644
666
  outline: none;
645
667
  }
@@ -38,3 +38,5 @@
38
38
  @import "./charts.css";
39
39
  @import "./virtual-list.css";
40
40
  @import "./infinite-scroll.css";
41
+ @import "./datagrid.css";
42
+ @import "./datepicker.css";
@@ -102,8 +102,8 @@
102
102
 
103
103
  /* ── Adornments ─────────────────────────────────────────────── */
104
104
 
105
- .tokis-input--with-start { padding-left: 38px; }
106
- .tokis-input--with-end { padding-right: 38px; }
105
+ .tokis-input--with-start { padding-inline-start: 38px; }
106
+ .tokis-input--with-end { padding-inline-end: 38px; }
107
107
 
108
108
  .tokis-input-adornment {
109
109
  position: absolute;
@@ -116,14 +116,14 @@
116
116
  pointer-events: none;
117
117
  flex-shrink: 0;
118
118
  }
119
- .tokis-input-adornment--start { left: 0; }
120
- .tokis-input-adornment--end { right: 0; pointer-events: auto; }
119
+ .tokis-input-adornment--start { inset-inline-start: 0; }
120
+ .tokis-input-adornment--end { inset-inline-end: 0; pointer-events: auto; }
121
121
 
122
122
  /* ── Password Toggle ────────────────────────────────────────── */
123
123
 
124
124
  .tokis-input-password-toggle {
125
125
  position: absolute;
126
- right: 0;
126
+ inset-inline-end: 0;
127
127
  display: flex;
128
128
  align-items: center;
129
129
  justify-content: center;
@@ -137,7 +137,10 @@
137
137
  transition: color var(--tokis-duration-fast) var(--tokis-ease-out);
138
138
  flex-shrink: 0;
139
139
  outline: none;
140
- border-radius: 0 var(--tokis-radius-md) var(--tokis-radius-md) 0;
140
+ border-start-start-radius: 0;
141
+ border-end-start-radius: 0;
142
+ border-start-end-radius: var(--tokis-radius-md);
143
+ border-end-end-radius: var(--tokis-radius-md);
141
144
  }
142
145
  .tokis-input-password-toggle:hover { color: var(--tokis-text-secondary); }
143
146
  .tokis-input-password-toggle:focus-visible {
@@ -5,7 +5,7 @@
5
5
  flex-direction: column;
6
6
  width: 72px;
7
7
  background: var(--tokis-color-surface);
8
- border-right: 1px solid var(--tokis-color-border);
8
+ border-inline-end: 1px solid var(--tokis-color-border);
9
9
  height: 100%;
10
10
  align-items: stretch;
11
11
  }
@@ -71,7 +71,7 @@
71
71
  .tokis-nav-rail__badge {
72
72
  position: absolute;
73
73
  top: -4px;
74
- right: -8px;
74
+ inset-inline-end: -8px;
75
75
  min-width: 16px;
76
76
  height: 16px;
77
77
  padding: 0 4px;
@@ -30,7 +30,7 @@
30
30
  background: none;
31
31
  border: none;
32
32
  width: 100%;
33
- text-align: left;
33
+ text-align: start;
34
34
  min-height: 36px;
35
35
  -webkit-tap-highlight-color: transparent;
36
36
  }
@@ -69,8 +69,8 @@
69
69
  .tokis-menu-item__shortcut {
70
70
  font-size: var(--tokis-font-size-xs);
71
71
  color: var(--tokis-text-tertiary);
72
- margin-left: auto;
73
- padding-left: var(--tokis-spacing-4);
72
+ margin-inline-start: auto;
73
+ padding-inline-start: var(--tokis-spacing-4);
74
74
  font-variant-numeric: tabular-nums;
75
75
  }
76
76
  .tokis-menu-item__indicator {
@@ -20,7 +20,7 @@
20
20
 
21
21
  .tokis-search-field__icon {
22
22
  position: absolute;
23
- left: var(--tokis-spacing-3);
23
+ inset-inline-start: var(--tokis-spacing-3);
24
24
  color: var(--tokis-text-tertiary);
25
25
  display: flex;
26
26
  align-items: center;
@@ -29,7 +29,8 @@
29
29
 
30
30
  .tokis-search-field__input {
31
31
  width: 100%;
32
- padding: var(--tokis-spacing-2) var(--tokis-spacing-3) var(--tokis-spacing-2) calc(var(--tokis-spacing-3) + 20px);
32
+ padding: var(--tokis-spacing-2) var(--tokis-spacing-3);
33
+ padding-inline-start: calc(var(--tokis-spacing-3) + 20px);
33
34
  border: 1px solid var(--tokis-color-border);
34
35
  border-radius: var(--tokis-radius-lg);
35
36
  background: var(--tokis-color-surface);
@@ -55,7 +56,7 @@
55
56
 
56
57
  .tokis-search-field__spinner {
57
58
  position: absolute;
58
- right: var(--tokis-spacing-3);
59
+ inset-inline-end: var(--tokis-spacing-3);
59
60
  width: 14px;
60
61
  height: 14px;
61
62
  border: 2px solid var(--tokis-color-border);
@@ -66,7 +67,7 @@
66
67
 
67
68
  .tokis-search-field__clear {
68
69
  position: absolute;
69
- right: var(--tokis-spacing-2);
70
+ inset-inline-end: var(--tokis-spacing-2);
70
71
  display: flex;
71
72
  align-items: center;
72
73
  justify-content: center;
@@ -112,7 +112,7 @@
112
112
  border: none;
113
113
  background: none;
114
114
  width: 100%;
115
- text-align: left;
115
+ text-align: start;
116
116
  min-height: 36px;
117
117
  }
118
118