zenkit-css 1.2.2 → 1.3.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.
Files changed (82) hide show
  1. package/dist/zenkit.css +9481 -0
  2. package/dist/zenkit.css.map +1 -1
  3. package/dist/zenkit.min.css +1 -1
  4. package/dist/zenkit.min.css.map +1 -1
  5. package/package.json +1 -1
  6. package/scss/components/_actionicon.scss +141 -0
  7. package/scss/components/_angleslider.scss +75 -0
  8. package/scss/components/_appbar.scss +96 -0
  9. package/scss/components/_appshell.scss +137 -0
  10. package/scss/components/_backdrop.scss +66 -0
  11. package/scss/components/_backgroundimage.scss +81 -0
  12. package/scss/components/_blockquote.scss +70 -0
  13. package/scss/components/_cards.scss +367 -0
  14. package/scss/components/_center.scss +33 -0
  15. package/scss/components/_chart.scss +100 -0
  16. package/scss/components/_checkboxcard.scss +105 -0
  17. package/scss/components/_checkboxgroup.scss +45 -0
  18. package/scss/components/_collapse.scss +76 -0
  19. package/scss/components/_colorinput.scss +103 -0
  20. package/scss/components/_colorswatch.scss +94 -0
  21. package/scss/components/_combobox.scss +157 -0
  22. package/scss/components/_contextmenu.scss +150 -0
  23. package/scss/components/_copybutton.scss +117 -0
  24. package/scss/components/_datagrid.scss +200 -0
  25. package/scss/components/_datalist.scss +104 -0
  26. package/scss/components/_daterange.scss +614 -0
  27. package/scss/components/_datetimepicker.scss +123 -0
  28. package/scss/components/_dialog.scss +176 -0
  29. package/scss/components/_dropzone.scss +159 -0
  30. package/scss/components/_filebutton.scss +64 -0
  31. package/scss/components/_fileinput.scss +157 -0
  32. package/scss/components/_floatcomponent.scss +128 -0
  33. package/scss/components/_floatingindicator.scss +49 -0
  34. package/scss/components/_forms.scss +327 -0
  35. package/scss/components/_gauge.scss +143 -0
  36. package/scss/components/_group.scss +100 -0
  37. package/scss/components/_heading.scss +143 -0
  38. package/scss/components/_highlight.scss +60 -0
  39. package/scss/components/_imagelist.scss +657 -0
  40. package/scss/components/_indicator.scss +171 -0
  41. package/scss/components/_infinitescroll.scss +53 -0
  42. package/scss/components/_jsoninput.scss +124 -0
  43. package/scss/components/_label.scss +77 -0
  44. package/scss/components/_loadingoverlay.scss +80 -0
  45. package/scss/components/_mark.scss +72 -0
  46. package/scss/components/_monthpicker.scss +141 -0
  47. package/scss/components/_multiselect.scss +192 -0
  48. package/scss/components/_navlink.scss +127 -0
  49. package/scss/components/_overlay.scss +97 -0
  50. package/scss/components/_paper.scss +98 -0
  51. package/scss/components/_pill.scss +141 -0
  52. package/scss/components/_radiocard.scss +122 -0
  53. package/scss/components/_rangeslider.scss +146 -0
  54. package/scss/components/_richtexteditor.scss +222 -0
  55. package/scss/components/_ringprogress.scss +101 -0
  56. package/scss/components/_scrollshadow.scss +152 -0
  57. package/scss/components/_semicircleprogress.scss +116 -0
  58. package/scss/components/_separator.scss +126 -0
  59. package/scss/components/_sheet.scss +612 -0
  60. package/scss/components/_simplegrid.scss +129 -0
  61. package/scss/components/_skipnavlink.scss +51 -0
  62. package/scss/components/_slider.scss +199 -0
  63. package/scss/components/_snippet.scss +576 -0
  64. package/scss/components/_sortable.scss +115 -0
  65. package/scss/components/_sparkline.scss +124 -0
  66. package/scss/components/_splitbutton.scss +153 -0
  67. package/scss/components/_spoiler.scss +73 -0
  68. package/scss/components/_stepper.scss +153 -0
  69. package/scss/components/_tableofcontents.scss +107 -0
  70. package/scss/components/_tabs.scss +379 -0
  71. package/scss/components/_tagsinput.scss +158 -0
  72. package/scss/components/_textcomponent.scss +183 -0
  73. package/scss/components/_themeicon.scss +121 -0
  74. package/scss/components/_toast.scss +335 -0
  75. package/scss/components/_togglegroup.scss +137 -0
  76. package/scss/components/_toolbar.scss +140 -0
  77. package/scss/components/_unstyledbutton.scss +43 -0
  78. package/scss/components/_user.scss +118 -0
  79. package/scss/components/_virtuallist.scss +118 -0
  80. package/scss/components/_yearpicker.scss +145 -0
  81. package/scss/utilities/_accessibility.scss +470 -0
  82. package/scss/zenkit.scss +80 -0
@@ -0,0 +1,176 @@
1
+ // ========================================
2
+ // Dialog Component (Radix-style)
3
+ // ========================================
4
+
5
+ .dialog {
6
+ --zk-dialog-bg: var(--zk-bg-primary);
7
+ --zk-dialog-border-color: var(--zk-border-color);
8
+ --zk-dialog-shadow: var(--zk-shadow-xl);
9
+ --zk-dialog-max-width: 500px;
10
+
11
+ &-overlay {
12
+ position: fixed;
13
+ inset: 0;
14
+ background: rgba(0, 0, 0, 0.5);
15
+ z-index: 1040;
16
+ display: flex;
17
+ align-items: center;
18
+ justify-content: center;
19
+ padding: 1rem;
20
+
21
+ // Animation
22
+ opacity: 0;
23
+ animation: dialog-overlay-in 0.2s ease forwards;
24
+
25
+ &[data-state="closed"] {
26
+ animation: dialog-overlay-out 0.2s ease forwards;
27
+ }
28
+ }
29
+
30
+ &-content {
31
+ position: relative;
32
+ width: 100%;
33
+ max-width: var(--zk-dialog-max-width);
34
+ max-height: calc(100vh - 2rem);
35
+ background: var(--zk-dialog-bg);
36
+ border: 1px solid var(--zk-dialog-border-color);
37
+ border-radius: var(--zk-radius-lg);
38
+ box-shadow: var(--zk-dialog-shadow);
39
+ overflow: hidden;
40
+ display: flex;
41
+ flex-direction: column;
42
+
43
+ // Animation
44
+ opacity: 0;
45
+ transform: scale(0.95);
46
+ animation: dialog-content-in 0.2s ease forwards;
47
+
48
+ &[data-state="closed"] {
49
+ animation: dialog-content-out 0.2s ease forwards;
50
+ }
51
+ }
52
+
53
+ &-header {
54
+ display: flex;
55
+ align-items: center;
56
+ justify-content: space-between;
57
+ padding: 1rem 1.5rem;
58
+ border-bottom: 1px solid var(--zk-dialog-border-color);
59
+ }
60
+
61
+ &-title {
62
+ font-size: 1.125rem;
63
+ font-weight: 600;
64
+ color: var(--zk-text-primary);
65
+ margin: 0;
66
+ }
67
+
68
+ &-description {
69
+ font-size: 0.875rem;
70
+ color: var(--zk-text-muted);
71
+ margin-top: 0.25rem;
72
+ }
73
+
74
+ &-close {
75
+ position: absolute;
76
+ top: 1rem;
77
+ right: 1rem;
78
+ display: flex;
79
+ align-items: center;
80
+ justify-content: center;
81
+ width: 32px;
82
+ height: 32px;
83
+ background: transparent;
84
+ border: none;
85
+ border-radius: var(--zk-radius-sm);
86
+ cursor: pointer;
87
+ color: var(--zk-text-muted);
88
+ transition: background-color 0.2s ease, color 0.2s ease;
89
+
90
+ &:hover {
91
+ background: var(--zk-bg-secondary);
92
+ color: var(--zk-text-primary);
93
+ }
94
+ }
95
+
96
+ &-body {
97
+ flex: 1;
98
+ padding: 1.5rem;
99
+ overflow-y: auto;
100
+ }
101
+
102
+ &-footer {
103
+ display: flex;
104
+ align-items: center;
105
+ justify-content: flex-end;
106
+ gap: 0.5rem;
107
+ padding: 1rem 1.5rem;
108
+ border-top: 1px solid var(--zk-dialog-border-color);
109
+ background: var(--zk-bg-secondary);
110
+ }
111
+
112
+ // Sizes
113
+ &-sm {
114
+ --zk-dialog-max-width: 360px;
115
+ }
116
+
117
+ &-lg {
118
+ --zk-dialog-max-width: 700px;
119
+ }
120
+
121
+ &-xl {
122
+ --zk-dialog-max-width: 900px;
123
+ }
124
+
125
+ &-fullscreen {
126
+ --zk-dialog-max-width: none;
127
+
128
+ .dialog-content {
129
+ width: 100vw;
130
+ height: 100vh;
131
+ max-height: 100vh;
132
+ border-radius: 0;
133
+ }
134
+ }
135
+ }
136
+
137
+ // Animations
138
+ @keyframes dialog-overlay-in {
139
+ from {
140
+ opacity: 0;
141
+ }
142
+ to {
143
+ opacity: 1;
144
+ }
145
+ }
146
+
147
+ @keyframes dialog-overlay-out {
148
+ from {
149
+ opacity: 1;
150
+ }
151
+ to {
152
+ opacity: 0;
153
+ }
154
+ }
155
+
156
+ @keyframes dialog-content-in {
157
+ from {
158
+ opacity: 0;
159
+ transform: scale(0.95);
160
+ }
161
+ to {
162
+ opacity: 1;
163
+ transform: scale(1);
164
+ }
165
+ }
166
+
167
+ @keyframes dialog-content-out {
168
+ from {
169
+ opacity: 1;
170
+ transform: scale(1);
171
+ }
172
+ to {
173
+ opacity: 0;
174
+ transform: scale(0.95);
175
+ }
176
+ }
@@ -0,0 +1,159 @@
1
+ // ========================================
2
+ // Dropzone Component
3
+ // ========================================
4
+
5
+ .dropzone {
6
+ --zk-dropzone-bg: var(--zk-bg-secondary);
7
+ --zk-dropzone-border-color: var(--zk-border-color);
8
+ --zk-dropzone-active-border-color: var(--zk-primary);
9
+ --zk-dropzone-active-bg: rgba(var(--zk-primary-rgb), 0.05);
10
+
11
+ display: flex;
12
+ flex-direction: column;
13
+ align-items: center;
14
+ justify-content: center;
15
+ min-height: 200px;
16
+ padding: 2rem;
17
+ background: var(--zk-dropzone-bg);
18
+ border: 2px dashed var(--zk-dropzone-border-color);
19
+ border-radius: var(--zk-radius-lg);
20
+ cursor: pointer;
21
+ transition: all 0.2s ease;
22
+ text-align: center;
23
+
24
+ &:hover {
25
+ border-color: var(--zk-dropzone-active-border-color);
26
+ background: var(--zk-dropzone-active-bg);
27
+ }
28
+
29
+ &-active {
30
+ border-color: var(--zk-dropzone-active-border-color);
31
+ background: var(--zk-dropzone-active-bg);
32
+ border-style: solid;
33
+ }
34
+
35
+ &-accept {
36
+ border-color: var(--zk-success);
37
+ background: rgba(var(--zk-success-rgb), 0.1);
38
+ }
39
+
40
+ &-reject {
41
+ border-color: var(--zk-danger);
42
+ background: rgba(var(--zk-danger-rgb), 0.1);
43
+ }
44
+
45
+ &-icon {
46
+ width: 48px;
47
+ height: 48px;
48
+ margin-bottom: 1rem;
49
+ color: var(--zk-text-muted);
50
+ }
51
+
52
+ &-title {
53
+ font-size: 1rem;
54
+ font-weight: 500;
55
+ color: var(--zk-text-primary);
56
+ margin-bottom: 0.25rem;
57
+ }
58
+
59
+ &-description {
60
+ font-size: 0.875rem;
61
+ color: var(--zk-text-muted);
62
+ margin-bottom: 1rem;
63
+ }
64
+
65
+ &-button {
66
+ margin-top: 0.5rem;
67
+ }
68
+
69
+ &-files {
70
+ width: 100%;
71
+ margin-top: 1rem;
72
+ display: flex;
73
+ flex-direction: column;
74
+ gap: 0.5rem;
75
+ }
76
+
77
+ &-file {
78
+ display: flex;
79
+ align-items: center;
80
+ gap: 0.75rem;
81
+ padding: 0.75rem;
82
+ background: var(--zk-bg-primary);
83
+ border: 1px solid var(--zk-border-color);
84
+ border-radius: var(--zk-radius-md);
85
+
86
+ &-icon {
87
+ width: 32px;
88
+ height: 32px;
89
+ color: var(--zk-text-muted);
90
+ }
91
+
92
+ &-info {
93
+ flex: 1;
94
+ text-align: left;
95
+ }
96
+
97
+ &-name {
98
+ font-size: 0.875rem;
99
+ font-weight: 500;
100
+ color: var(--zk-text-primary);
101
+ }
102
+
103
+ &-size {
104
+ font-size: 0.75rem;
105
+ color: var(--zk-text-muted);
106
+ }
107
+
108
+ &-remove {
109
+ width: 24px;
110
+ height: 24px;
111
+ display: flex;
112
+ align-items: center;
113
+ justify-content: center;
114
+ background: transparent;
115
+ border: none;
116
+ cursor: pointer;
117
+ color: var(--zk-text-muted);
118
+ border-radius: var(--zk-radius-sm);
119
+
120
+ &:hover {
121
+ background: var(--zk-bg-secondary);
122
+ color: var(--zk-danger);
123
+ }
124
+ }
125
+
126
+ &-progress {
127
+ height: 4px;
128
+ background: var(--zk-bg-secondary);
129
+ border-radius: 2px;
130
+ margin-top: 0.5rem;
131
+ overflow: hidden;
132
+
133
+ &-bar {
134
+ height: 100%;
135
+ background: var(--zk-primary);
136
+ transition: width 0.3s ease;
137
+ }
138
+ }
139
+ }
140
+
141
+ // Disabled
142
+ &-disabled {
143
+ opacity: 0.5;
144
+ cursor: not-allowed;
145
+ pointer-events: none;
146
+ }
147
+
148
+ // Compact
149
+ &-compact {
150
+ min-height: 100px;
151
+ padding: 1rem;
152
+
153
+ .dropzone-icon {
154
+ width: 32px;
155
+ height: 32px;
156
+ margin-bottom: 0.5rem;
157
+ }
158
+ }
159
+ }
@@ -0,0 +1,64 @@
1
+ // ========================================
2
+ // FileButton Component (Mantine-style)
3
+ // ========================================
4
+
5
+ .file-button {
6
+ position: relative;
7
+ display: inline-flex;
8
+
9
+ &-input {
10
+ position: absolute;
11
+ inset: 0;
12
+ width: 100%;
13
+ height: 100%;
14
+ opacity: 0;
15
+ cursor: pointer;
16
+ z-index: 1;
17
+
18
+ &:disabled {
19
+ cursor: not-allowed;
20
+ }
21
+ }
22
+
23
+ // The actual button content (child element)
24
+ &-content {
25
+ pointer-events: none;
26
+ }
27
+
28
+ // Focus state
29
+ &:focus-within {
30
+ outline: 2px solid var(--zk-primary);
31
+ outline-offset: 2px;
32
+ }
33
+
34
+ // Disabled state
35
+ &-disabled {
36
+ pointer-events: none;
37
+ opacity: 0.5;
38
+ }
39
+
40
+ // Reset button (for clearing selection)
41
+ &-reset {
42
+ display: inline-flex;
43
+ align-items: center;
44
+ gap: 0.5rem;
45
+ }
46
+
47
+ &-reset-btn {
48
+ display: flex;
49
+ align-items: center;
50
+ justify-content: center;
51
+ width: 20px;
52
+ height: 20px;
53
+ background: var(--zk-bg-secondary);
54
+ border: none;
55
+ border-radius: 50%;
56
+ cursor: pointer;
57
+ color: var(--zk-text-muted);
58
+
59
+ &:hover {
60
+ background: var(--zk-bg-tertiary);
61
+ color: var(--zk-danger);
62
+ }
63
+ }
64
+ }
@@ -0,0 +1,157 @@
1
+ // ========================================
2
+ // FileInput Component
3
+ // ========================================
4
+
5
+ .file-input {
6
+ --zk-file-input-bg: var(--zk-bg-primary);
7
+ --zk-file-input-border-color: var(--zk-border-color);
8
+
9
+ display: flex;
10
+ flex-direction: column;
11
+ gap: 0.25rem;
12
+
13
+ &-wrapper {
14
+ position: relative;
15
+ display: flex;
16
+ align-items: stretch;
17
+ }
18
+
19
+ &-field {
20
+ flex: 1;
21
+ display: flex;
22
+ align-items: center;
23
+ padding: 0.5rem 0.75rem;
24
+ background: var(--zk-file-input-bg);
25
+ border: 1px solid var(--zk-file-input-border-color);
26
+ border-radius: var(--zk-radius-md);
27
+ cursor: pointer;
28
+ transition: border-color 0.2s ease;
29
+
30
+ &:hover {
31
+ border-color: var(--zk-primary);
32
+ }
33
+ }
34
+
35
+ &-placeholder {
36
+ color: var(--zk-text-muted);
37
+ font-size: 0.875rem;
38
+ }
39
+
40
+ &-filename {
41
+ color: var(--zk-text-primary);
42
+ font-size: 0.875rem;
43
+ white-space: nowrap;
44
+ overflow: hidden;
45
+ text-overflow: ellipsis;
46
+ }
47
+
48
+ &-button {
49
+ display: flex;
50
+ align-items: center;
51
+ gap: 0.5rem;
52
+ padding: 0.5rem 1rem;
53
+ background: var(--zk-bg-secondary);
54
+ border: 1px solid var(--zk-file-input-border-color);
55
+ border-left: none;
56
+ border-radius: 0 var(--zk-radius-md) var(--zk-radius-md) 0;
57
+ font-size: 0.875rem;
58
+ color: var(--zk-text-primary);
59
+ cursor: pointer;
60
+ transition: background-color 0.2s ease;
61
+
62
+ &:hover {
63
+ background: var(--zk-bg-tertiary);
64
+ }
65
+ }
66
+
67
+ &-input {
68
+ position: absolute;
69
+ inset: 0;
70
+ opacity: 0;
71
+ cursor: pointer;
72
+ }
73
+
74
+ &-label {
75
+ font-size: 0.875rem;
76
+ font-weight: 500;
77
+ color: var(--zk-text-primary);
78
+ }
79
+
80
+ &-description {
81
+ font-size: 0.75rem;
82
+ color: var(--zk-text-muted);
83
+ }
84
+
85
+ &-error {
86
+ font-size: 0.75rem;
87
+ color: var(--zk-danger);
88
+ }
89
+
90
+ // Clear button
91
+ &-clear {
92
+ position: absolute;
93
+ right: 0.5rem;
94
+ top: 50%;
95
+ transform: translateY(-50%);
96
+ width: 20px;
97
+ height: 20px;
98
+ display: flex;
99
+ align-items: center;
100
+ justify-content: center;
101
+ background: var(--zk-bg-secondary);
102
+ border: none;
103
+ border-radius: 50%;
104
+ cursor: pointer;
105
+ color: var(--zk-text-muted);
106
+
107
+ &:hover {
108
+ background: var(--zk-bg-tertiary);
109
+ color: var(--zk-text-primary);
110
+ }
111
+ }
112
+
113
+ // Disabled
114
+ &-disabled {
115
+ opacity: 0.5;
116
+ pointer-events: none;
117
+ }
118
+
119
+ // Error state
120
+ &.has-error {
121
+ .file-input-field {
122
+ border-color: var(--zk-danger);
123
+ }
124
+ }
125
+
126
+ // Multiple files
127
+ &-multiple {
128
+ .file-input-field {
129
+ flex-wrap: wrap;
130
+ gap: 0.25rem;
131
+ }
132
+ }
133
+
134
+ &-tag {
135
+ display: inline-flex;
136
+ align-items: center;
137
+ gap: 0.25rem;
138
+ padding: 0.125rem 0.5rem;
139
+ background: var(--zk-bg-secondary);
140
+ border-radius: var(--zk-radius-sm);
141
+ font-size: 0.75rem;
142
+
143
+ &-remove {
144
+ width: 14px;
145
+ height: 14px;
146
+ display: flex;
147
+ align-items: center;
148
+ justify-content: center;
149
+ cursor: pointer;
150
+ color: var(--zk-text-muted);
151
+
152
+ &:hover {
153
+ color: var(--zk-danger);
154
+ }
155
+ }
156
+ }
157
+ }
@@ -0,0 +1,128 @@
1
+ // ========================================
2
+ // Float Component (Chakra-style)
3
+ // ========================================
4
+
5
+ .float {
6
+ position: absolute;
7
+
8
+ // Placement - horizontal
9
+ &-left {
10
+ left: 0;
11
+ }
12
+
13
+ &-right {
14
+ right: 0;
15
+ }
16
+
17
+ &-center-x {
18
+ left: 50%;
19
+ transform: translateX(-50%);
20
+ }
21
+
22
+ // Placement - vertical
23
+ &-top {
24
+ top: 0;
25
+ }
26
+
27
+ &-bottom {
28
+ bottom: 0;
29
+ }
30
+
31
+ &-center-y {
32
+ top: 50%;
33
+ transform: translateY(-50%);
34
+ }
35
+
36
+ // Combined center
37
+ &-center {
38
+ top: 50%;
39
+ left: 50%;
40
+ transform: translate(-50%, -50%);
41
+ }
42
+
43
+ // Corner positions
44
+ &-top-left {
45
+ top: 0;
46
+ left: 0;
47
+ }
48
+
49
+ &-top-right {
50
+ top: 0;
51
+ right: 0;
52
+ }
53
+
54
+ &-bottom-left {
55
+ bottom: 0;
56
+ left: 0;
57
+ }
58
+
59
+ &-bottom-right {
60
+ bottom: 0;
61
+ right: 0;
62
+ }
63
+
64
+ // Edge positions (middle of edge)
65
+ &-top-center {
66
+ top: 0;
67
+ left: 50%;
68
+ transform: translateX(-50%);
69
+ }
70
+
71
+ &-bottom-center {
72
+ bottom: 0;
73
+ left: 50%;
74
+ transform: translateX(-50%);
75
+ }
76
+
77
+ &-left-center {
78
+ left: 0;
79
+ top: 50%;
80
+ transform: translateY(-50%);
81
+ }
82
+
83
+ &-right-center {
84
+ right: 0;
85
+ top: 50%;
86
+ transform: translateY(-50%);
87
+ }
88
+
89
+ // Offset variants
90
+ &-offset-1 {
91
+ margin: 0.25rem;
92
+ }
93
+
94
+ &-offset-2 {
95
+ margin: 0.5rem;
96
+ }
97
+
98
+ &-offset-3 {
99
+ margin: 0.75rem;
100
+ }
101
+
102
+ &-offset-4 {
103
+ margin: 1rem;
104
+ }
105
+
106
+ // Placement outside container
107
+ &-outside {
108
+ &.float-top {
109
+ top: auto;
110
+ bottom: 100%;
111
+ }
112
+
113
+ &.float-bottom {
114
+ bottom: auto;
115
+ top: 100%;
116
+ }
117
+
118
+ &.float-left {
119
+ left: auto;
120
+ right: 100%;
121
+ }
122
+
123
+ &.float-right {
124
+ right: auto;
125
+ left: 100%;
126
+ }
127
+ }
128
+ }
@@ -0,0 +1,49 @@
1
+ // ========================================
2
+ // FloatingIndicator Component (Mantine-style)
3
+ // ========================================
4
+
5
+ .floating-indicator {
6
+ --zk-indicator-bg: var(--zk-bg-primary);
7
+ --zk-indicator-shadow: var(--zk-shadow-sm);
8
+ --zk-indicator-radius: var(--zk-radius-md);
9
+
10
+ position: absolute;
11
+ background: var(--zk-indicator-bg);
12
+ box-shadow: var(--zk-indicator-shadow);
13
+ border-radius: var(--zk-indicator-radius);
14
+ transition: all 0.2s ease;
15
+ pointer-events: none;
16
+ z-index: 0;
17
+
18
+ // Parent container needs relative positioning
19
+ &-container {
20
+ position: relative;
21
+ }
22
+
23
+ // Variants
24
+ &-filled {
25
+ --zk-indicator-bg: var(--zk-primary);
26
+ }
27
+
28
+ &-light {
29
+ --zk-indicator-bg: rgba(var(--zk-primary-rgb), 0.1);
30
+ --zk-indicator-shadow: none;
31
+ }
32
+
33
+ &-outline {
34
+ --zk-indicator-bg: transparent;
35
+ --zk-indicator-shadow: none;
36
+ border: 2px solid var(--zk-primary);
37
+ }
38
+
39
+ // No transition (for immediate position updates)
40
+ &-no-transition {
41
+ transition: none;
42
+ }
43
+
44
+ // Hidden state
45
+ &-hidden {
46
+ opacity: 0;
47
+ transform: scale(0.95);
48
+ }
49
+ }