@idds/styles 1.0.26

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 (81) hide show
  1. package/README.md +147 -0
  2. package/package.json +55 -0
  3. package/src/colors/brands/bgn.css +29 -0
  4. package/src/colors/brands/bkn.css +32 -0
  5. package/src/colors/brands/inagov.css +39 -0
  6. package/src/colors/brands/inaku.css +28 -0
  7. package/src/colors/brands/inapas.css +28 -0
  8. package/src/colors/brands/lan.css +38 -0
  9. package/src/colors/brands/pan-rb.css +30 -0
  10. package/src/colors/index.css +11 -0
  11. package/src/colors/primitives/index.css +150 -0
  12. package/src/colors/product/index.css +205 -0
  13. package/src/colors/utilities/index.css +77 -0
  14. package/src/components/accordion-card.css +99 -0
  15. package/src/components/accordion.css +120 -0
  16. package/src/components/action-dropdown.css +140 -0
  17. package/src/components/alert.css +180 -0
  18. package/src/components/avatar.css +182 -0
  19. package/src/components/badge.css +244 -0
  20. package/src/components/bottom-sheet.css +61 -0
  21. package/src/components/breadcrumb.css +94 -0
  22. package/src/components/button-group.css +130 -0
  23. package/src/components/button.css +233 -0
  24. package/src/components/card.css +488 -0
  25. package/src/components/carousel.css +100 -0
  26. package/src/components/chart.css +81 -0
  27. package/src/components/checkbox.css +211 -0
  28. package/src/components/chip.css +228 -0
  29. package/src/components/collapse.css +84 -0
  30. package/src/components/confirmation.css +131 -0
  31. package/src/components/date-picker.css +1063 -0
  32. package/src/components/divider.css +174 -0
  33. package/src/components/drawer.css +757 -0
  34. package/src/components/dropdown.css +369 -0
  35. package/src/components/field-input-table.css +347 -0
  36. package/src/components/file-upload.css +357 -0
  37. package/src/components/input-search.css +428 -0
  38. package/src/components/linear-progress-indicator.css +34 -0
  39. package/src/components/modal.css +497 -0
  40. package/src/components/month-picker.css +325 -0
  41. package/src/components/multiple-choice-grid.css +383 -0
  42. package/src/components/pagination.css +415 -0
  43. package/src/components/password-input.css +472 -0
  44. package/src/components/phone-input.css +412 -0
  45. package/src/components/progress-bar.css +447 -0
  46. package/src/components/radio-input.css +263 -0
  47. package/src/components/reset.css +431 -0
  48. package/src/components/select-dropdown.css +663 -0
  49. package/src/components/select-option.css +217 -0
  50. package/src/components/skeleton.css +488 -0
  51. package/src/components/spinner.css +450 -0
  52. package/src/components/stepper.css +209 -0
  53. package/src/components/tab-horizontal.css +278 -0
  54. package/src/components/tab-vertical.css +261 -0
  55. package/src/components/table-progress-bar.css +48 -0
  56. package/src/components/table.css +538 -0
  57. package/src/components/text-area.css +216 -0
  58. package/src/components/text-field.css +275 -0
  59. package/src/components/theme-toggle.css +259 -0
  60. package/src/components/time-picker.css +436 -0
  61. package/src/components/toast.css +245 -0
  62. package/src/components/toggle.css +223 -0
  63. package/src/components/tooltip.css +452 -0
  64. package/src/components/year-picker.css +423 -0
  65. package/src/index.css +3 -0
  66. package/src/tailwind/css/bgn.css +43 -0
  67. package/src/tailwind/css/bkn.css +37 -0
  68. package/src/tailwind/css/idds.css +231 -0
  69. package/src/tailwind/css/inagov.css +33 -0
  70. package/src/tailwind/css/inaku.css +33 -0
  71. package/src/tailwind/css/inapas.css +33 -0
  72. package/src/tailwind/css/lan.css +43 -0
  73. package/src/tailwind/css/pan-rb.css +35 -0
  74. package/src/tailwind/ts/bgn.ts +20 -0
  75. package/src/tailwind/ts/bkn.ts +38 -0
  76. package/src/tailwind/ts/idds.ts +240 -0
  77. package/src/tailwind/ts/inagov.ts +35 -0
  78. package/src/tailwind/ts/inaku.ts +35 -0
  79. package/src/tailwind/ts/inapas.ts +35 -0
  80. package/src/tailwind/ts/lan.ts +45 -0
  81. package/src/tailwind/ts/panrb.ts +37 -0
@@ -0,0 +1,447 @@
1
+ /**
2
+ * ProgressBar Component Styles
3
+ * Menggunakan BEM naming convention dengan prefix "ina-"
4
+ */
5
+
6
+ .ina-progress-bar {
7
+ /* Base container styling */
8
+ position: relative;
9
+ width: 100%;
10
+ background-color: var(--ina-neutral-200);
11
+ border-radius: var(--ina-radius-full);
12
+ overflow: hidden;
13
+ transition: opacity var(--ina-transition-base);
14
+ }
15
+
16
+ .ina-progress-bar--hidden {
17
+ opacity: 0;
18
+ visibility: hidden;
19
+ }
20
+
21
+ /* Height variants */
22
+ .ina-progress-bar--height-sm {
23
+ height: 2px;
24
+ }
25
+
26
+ .ina-progress-bar--height-md {
27
+ height: 4px;
28
+ }
29
+
30
+ .ina-progress-bar--height-lg {
31
+ height: 6px;
32
+ }
33
+
34
+ /* Progress fill */
35
+ .ina-progress-bar__fill {
36
+ position: absolute;
37
+ top: 0;
38
+ left: 0;
39
+ height: 100%;
40
+ width: 0%;
41
+ border-radius: inherit;
42
+ transition: width var(--ina-transition-duration-1000) ease-out;
43
+ background-color: var(--ina-primary-500);
44
+ }
45
+
46
+ /* Variant colors */
47
+ .ina-progress-bar__fill--primary {
48
+ background-color: var(--ina-primary-500);
49
+ }
50
+
51
+ .ina-progress-bar__fill--secondary {
52
+ background-color: var(--ina-neutral-500);
53
+ }
54
+
55
+ .ina-progress-bar__fill--success {
56
+ background-color: var(--ina-positive-500);
57
+ }
58
+
59
+ .ina-progress-bar__fill--warning {
60
+ background-color: var(--ina-warning-500);
61
+ }
62
+
63
+ .ina-progress-bar__fill--error {
64
+ background-color: var(--ina-negative-500);
65
+ }
66
+
67
+ /* Shimmer effect */
68
+ .ina-progress-bar__shimmer {
69
+ position: absolute;
70
+ top: 0;
71
+ left: 0;
72
+ height: 100%;
73
+ width: 100%;
74
+ background: linear-gradient(
75
+ 90deg,
76
+ transparent,
77
+ rgba(255, 255, 255, 0.3),
78
+ transparent
79
+ );
80
+ animation: shimmer 2s infinite linear;
81
+ opacity: 0;
82
+ transition: opacity var(--ina-transition-base);
83
+ }
84
+
85
+ .ina-progress-bar--shimmer .ina-progress-bar__shimmer {
86
+ opacity: 1;
87
+ }
88
+
89
+ @keyframes shimmer {
90
+ 0% {
91
+ transform: translateX(-100%);
92
+ }
93
+ 100% {
94
+ transform: translateX(100%);
95
+ }
96
+ }
97
+
98
+ /* Animated indicator */
99
+ .ina-progress-bar__indicator {
100
+ position: absolute;
101
+ top: 0;
102
+ height: 100%;
103
+ width: 32px;
104
+ border-radius: inherit;
105
+ opacity: 0.8;
106
+ transform: translateX(-100%);
107
+ transition: left var(--ina-transition-duration-1000) ease-out;
108
+ animation: pulse 1.5s infinite;
109
+ }
110
+
111
+ .ina-progress-bar__indicator--primary {
112
+ background-color: var(--ina-primary-500);
113
+ }
114
+
115
+ .ina-progress-bar__indicator--secondary {
116
+ background-color: var(--ina-neutral-500);
117
+ }
118
+
119
+ .ina-progress-bar__indicator--success {
120
+ background-color: var(--ina-positive-500);
121
+ }
122
+
123
+ .ina-progress-bar__indicator--warning {
124
+ background-color: var(--ina-warning-500);
125
+ }
126
+
127
+ .ina-progress-bar__indicator--error {
128
+ background-color: var(--ina-negative-500);
129
+ }
130
+
131
+ @keyframes pulse {
132
+ 0%,
133
+ 100% {
134
+ opacity: 0.8;
135
+ }
136
+ 50% {
137
+ opacity: 0.6;
138
+ }
139
+ }
140
+
141
+ /* Striped variant */
142
+ .ina-progress-bar__fill--striped {
143
+ background-image: linear-gradient(
144
+ 45deg,
145
+ rgba(255, 255, 255, 0.15) 25%,
146
+ transparent 25%,
147
+ transparent 50%,
148
+ rgba(255, 255, 255, 0.15) 50%,
149
+ rgba(255, 255, 255, 0.15) 75%,
150
+ transparent 75%,
151
+ transparent
152
+ );
153
+ background-size: 20px 20px;
154
+ animation: moveStripes 1s linear infinite;
155
+ }
156
+
157
+ @keyframes moveStripes {
158
+ 0% {
159
+ background-position: 0 0;
160
+ }
161
+ 100% {
162
+ background-position: 20px 0;
163
+ }
164
+ }
165
+
166
+ /* Size variants with more height options */
167
+ .ina-progress-bar--height-xs {
168
+ height: 1px;
169
+ }
170
+
171
+ .ina-progress-bar--height-xl {
172
+ height: 8px;
173
+ }
174
+
175
+ .ina-progress-bar--height-2xl {
176
+ height: 12px;
177
+ }
178
+
179
+ /* Custom duration variants */
180
+ .ina-progress-bar--duration-fast .ina-progress-bar__fill {
181
+ transition-duration: var(--ina-transition-duration-200);
182
+ }
183
+
184
+ .ina-progress-bar--duration-medium .ina-progress-bar__fill {
185
+ transition-duration: var(--ina-transition-duration-500);
186
+ }
187
+
188
+ .ina-progress-bar--duration-slow .ina-progress-bar__fill {
189
+ transition-duration: var(--ina-transition-duration-2000);
190
+ }
191
+
192
+ /* Loading state animation */
193
+ .ina-progress-bar--loading {
194
+ animation: indeterminate 2s infinite linear;
195
+ }
196
+
197
+ .ina-progress-bar--loading .ina-progress-bar__fill {
198
+ position: relative;
199
+ width: 30%;
200
+ background: linear-gradient(
201
+ 90deg,
202
+ var(--ina-primary-500) 0%,
203
+ var(--ina-primary-400) 50%,
204
+ var(--ina-primary-500) 100%
205
+ );
206
+ background-size: 200% 100%;
207
+ animation: loading-shift 1s infinite linear;
208
+ }
209
+
210
+ @keyframes indeterminate {
211
+ 0% {
212
+ transform: translateX(-100%);
213
+ }
214
+ 100% {
215
+ transform: translateX(400%);
216
+ }
217
+ }
218
+
219
+ @keyframes loading-shift {
220
+ 0% {
221
+ background-position: 200% 0;
222
+ }
223
+ 100% {
224
+ background-position: -200% 0;
225
+ }
226
+ }
227
+
228
+ /* Gradient variants */
229
+ .ina-progress-bar__fill--gradient-primary {
230
+ background: linear-gradient(
231
+ 90deg,
232
+ var(--ina-primary-400),
233
+ var(--ina-primary-500),
234
+ var(--ina-primary-600)
235
+ );
236
+ }
237
+
238
+ .ina-progress-bar__fill--gradient-success {
239
+ background: linear-gradient(
240
+ 90deg,
241
+ var(--ina-positive-400),
242
+ var(--ina-positive-500),
243
+ var(--ina-positive-600)
244
+ );
245
+ }
246
+
247
+ .ina-progress-bar__fill--gradient-warning {
248
+ background: linear-gradient(
249
+ 90deg,
250
+ var(--ina-warning-400),
251
+ var(--ina-warning-500),
252
+ var(--ina-warning-600)
253
+ );
254
+ }
255
+
256
+ .ina-progress-bar__fill--gradient-error {
257
+ background: linear-gradient(
258
+ 90deg,
259
+ var(--ina-negative-400),
260
+ var(--ina-negative-500),
261
+ var(--ina-negative-600)
262
+ );
263
+ }
264
+
265
+ /* Status-based styling */
266
+ .ina-progress-bar__fill--complete {
267
+ background-color: var(--ina-positive-500);
268
+ }
269
+
270
+ .ina-progress-bar__fill--in-progress {
271
+ animation: breathing 2s infinite ease-in-out;
272
+ }
273
+
274
+ @keyframes breathing {
275
+ 0%,
276
+ 100% {
277
+ opacity: 1;
278
+ }
279
+ 50% {
280
+ opacity: 0.8;
281
+ }
282
+ }
283
+
284
+ /* Circular variant */
285
+ .ina-progress-bar--circular {
286
+ width: 120px;
287
+ height: 120px;
288
+ border-radius: 50%;
289
+ background: conic-gradient(
290
+ var(--ina-primary-500) 0deg,
291
+ var(--ina-neutral-200) 0deg
292
+ );
293
+ display: flex;
294
+ align-items: center;
295
+ justify-content: center;
296
+ position: relative;
297
+ }
298
+
299
+ .ina-progress-bar--circular .ina-progress-bar__fill {
300
+ display: none;
301
+ }
302
+
303
+ .ina-progress-bar__circular-content {
304
+ position: absolute;
305
+ inset: 20%;
306
+ background-color: var(--ina-background-primary);
307
+ border-radius: 50%;
308
+ display: flex;
309
+ align-items: center;
310
+ justify-content: center;
311
+ font-size: var(--ina-font-xs);
312
+ font-weight: var(--ina-font-medium);
313
+ color: var(--ina-content-primary);
314
+ }
315
+
316
+ /* Progress label */
317
+ .ina-progress-bar__label {
318
+ position: absolute;
319
+ top: 50%;
320
+ left: 50%;
321
+ transform: translate(-50%, -50%);
322
+ font-size: var(--ina-font-xs);
323
+ font-weight: var(--ina-font-medium);
324
+ color: var(--ina-content-primary);
325
+ text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
326
+ }
327
+
328
+ /* Skeleton variant */
329
+ .ina-progress-bar--skeleton {
330
+ background: linear-gradient(
331
+ 90deg,
332
+ var(--ina-neutral-200) 25%,
333
+ var(--ina-neutral-300) 50%,
334
+ var(--ina-neutral-200) 75%
335
+ );
336
+ background-size: 200% 100%;
337
+ animation: skeleton 1.5s infinite ease-out;
338
+ }
339
+
340
+ .ina-progress-bar--skeleton .ina-progress-bar__fill {
341
+ display: none;
342
+ }
343
+
344
+ @keyframes skeleton {
345
+ 0% {
346
+ background-position: 200% 0;
347
+ }
348
+ 100% {
349
+ background-position: -200% 0;
350
+ }
351
+ }
352
+
353
+ /* Dark mode support */
354
+ /* @media (prefers-color-scheme: dark) {
355
+ .ina-progress-bar {
356
+ background-color: var(--ina-neutral-700);
357
+ }
358
+
359
+ .ina-progress-bar__fill--primary {
360
+ background-color: var(--ina-primary-400);
361
+ }
362
+
363
+ .ina-progress-bar__fill--secondary {
364
+ background-color: var(--ina-neutral-400);
365
+ }
366
+
367
+ .ina-progress-bar__fill--success {
368
+ background-color: var(--ina-positive-400);
369
+ }
370
+
371
+ .ina-progress-bar__fill--warning {
372
+ background-color: var(--ina-warning-400);
373
+ }
374
+
375
+ .ina-progress-bar__fill--error {
376
+ background-color: var(--ina-negative-400);
377
+ }
378
+
379
+ .ina-progress-bar__shimmer {
380
+ background: linear-gradient(
381
+ 90deg,
382
+ transparent,
383
+ rgba(255, 255, 255, 0.1),
384
+ transparent
385
+ );
386
+ }
387
+
388
+ .ina-progress-bar__circular-content {
389
+ background-color: var(--ina-background-dark-primary);
390
+ color: var(--ina-content-dark-primary);
391
+ }
392
+
393
+ .ina-progress-bar__label {
394
+ color: var(--ina-content-dark-primary);
395
+ text-shadow: 0 1px 2px rgba(0, 0, 0, 0.8);
396
+ }
397
+
398
+ .ina-progress-bar--skeleton {
399
+ background: linear-gradient(
400
+ 90deg,
401
+ var(--ina-neutral-700) 25%,
402
+ var(--ina-neutral-600) 50%,
403
+ var(--ina-neutral-700) 75%
404
+ );
405
+ }
406
+ } */
407
+
408
+ /* Responsive adjustments */
409
+ @media (max-width: 640px) {
410
+ .ina-progress-bar--circular {
411
+ width: 80px;
412
+ height: 80px;
413
+ }
414
+
415
+ .ina-progress-bar__circular-content {
416
+ font-size: var(--ina-font-xs);
417
+ }
418
+ }
419
+
420
+ /* Accessibility improvements */
421
+ .ina-progress-bar[aria-hidden='true'] {
422
+ visibility: hidden;
423
+ }
424
+
425
+ /* High contrast mode */
426
+ @media (prefers-contrast: high) {
427
+ .ina-progress-bar {
428
+ border: 1px solid var(--ina-content-primary);
429
+ }
430
+
431
+ .ina-progress-bar__fill {
432
+ border: 1px solid var(--ina-background-primary);
433
+ }
434
+ }
435
+
436
+ /* Reduced motion */
437
+ @media (prefers-reduced-motion: reduce) {
438
+ .ina-progress-bar__fill,
439
+ .ina-progress-bar__indicator,
440
+ .ina-progress-bar__shimmer,
441
+ .ina-progress-bar--skeleton,
442
+ .ina-progress-bar--loading,
443
+ .ina-progress-bar--loading .ina-progress-bar__fill {
444
+ animation: none;
445
+ transition: none;
446
+ }
447
+ }
@@ -0,0 +1,263 @@
1
+ /**
2
+ * RadioInput Component Styles
3
+ * Menggunakan BEM naming convention dengan prefix "ina-"
4
+ */
5
+
6
+ .ina-radio-input {
7
+ /* Base container styling */
8
+ display: flex;
9
+ flex-direction: column;
10
+ gap: var(--ina-spacing-2);
11
+ }
12
+
13
+ /* Label styling */
14
+ .ina-radio-input__main-label {
15
+ display: block;
16
+ font-size: var(--ina-font-sm);
17
+ color: var(--ina-content-color-181717);
18
+ font-weight: var(--ina-font-medium);
19
+ }
20
+
21
+ /* Radio group container */
22
+ .ina-radio-input__group {
23
+ display: flex;
24
+ flex-direction: column;
25
+ gap: var(--ina-spacing-2);
26
+ }
27
+
28
+ /* Individual radio option */
29
+ .ina-radio-input__option {
30
+ display: flex;
31
+ align-items: center;
32
+ gap: var(--ina-spacing-2);
33
+ cursor: pointer;
34
+ transition: background-color var(--ina-transition-base);
35
+ padding: var(--ina-spacing-2);
36
+ border-radius: var(--ina-radius-md);
37
+ }
38
+
39
+ .ina-radio-input__option:hover {
40
+ background-color: var(--ina-neutral-50);
41
+ }
42
+
43
+ .ina-radio-input__option:focus-within {
44
+ background-color: var(--ina-neutral-100);
45
+ outline: 2px solid var(--ina-primary-500);
46
+ outline-offset: 2px;
47
+ }
48
+
49
+ .ina-radio-input__option--disabled {
50
+ cursor: not-allowed;
51
+ opacity: 0.6;
52
+ }
53
+
54
+ .ina-radio-input__option--disabled:hover {
55
+ background-color: transparent;
56
+ }
57
+
58
+ /* Radio input field - Default styling */
59
+ .ina-radio-input__field {
60
+ appearance: none;
61
+ width: 20px;
62
+ height: 20px;
63
+ border: 1px solid var(--ina-content-light-secondary) !important;
64
+ border-radius: 50%;
65
+ background-color: transparent;
66
+ cursor: pointer;
67
+ position: relative;
68
+ transition: all var(--ina-transition-base);
69
+ flex-shrink: 0;
70
+ }
71
+
72
+ /* Hover state */
73
+ .ina-radio-input__field:hover:not(:disabled) {
74
+ border-color: #666666;
75
+ }
76
+
77
+ /* Selected state */
78
+ .ina-radio-input__field:checked {
79
+ border-color: #000000;
80
+ background-color: #000000;
81
+ }
82
+
83
+ .ina-radio-input__field:checked::after {
84
+ content: '';
85
+ position: absolute;
86
+ top: 50%;
87
+ left: 50%;
88
+ transform: translate(-50%, -50%);
89
+ width: 8px;
90
+ height: 8px;
91
+ border-radius: 50%;
92
+ background-color: #ffffff;
93
+ }
94
+
95
+ /* Disabled states */
96
+ .ina-radio-input__field:disabled {
97
+ border-color: #e0e0e0;
98
+ background-color: transparent;
99
+ cursor: not-allowed;
100
+ opacity: 1;
101
+ }
102
+
103
+ /* Disabled + Checked state - Higher specificity */
104
+ .ina-radio-input__field:disabled:checked {
105
+ border-color: #e0e0e0 !important;
106
+ background-color: transparent !important;
107
+ }
108
+
109
+ .ina-radio-input__field:disabled:checked::after {
110
+ content: '' !important;
111
+ position: absolute;
112
+ top: 50%;
113
+ left: 50%;
114
+ transform: translate(-50%, -50%);
115
+ width: 8px;
116
+ height: 8px;
117
+ border-radius: 50%;
118
+ background-color: #e0e0e0;
119
+ }
120
+
121
+ /* Radio option label */
122
+ .ina-radio-input__option-label {
123
+ font-size: var(--ina-font-sm);
124
+ color: #000000;
125
+ cursor: pointer;
126
+ user-select: none;
127
+ flex: 1;
128
+ line-height: 1.5;
129
+ }
130
+
131
+ .ina-radio-input__option-label--disabled {
132
+ cursor: not-allowed;
133
+ color: #e0e0e0;
134
+ }
135
+
136
+ /* Size variants */
137
+ .ina-radio-input--size-sm .ina-radio-input__main-label {
138
+ font-size: var(--ina-font-xs);
139
+ }
140
+
141
+ .ina-radio-input--size-sm .ina-radio-input__option-label {
142
+ font-size: var(--ina-font-xs);
143
+ }
144
+
145
+ .ina-radio-input--size-sm .ina-radio-input__field {
146
+ width: 16px;
147
+ height: 16px;
148
+ }
149
+
150
+ .ina-radio-input--size-lg .ina-radio-input__main-label {
151
+ font-size: var(--ina-font-base);
152
+ }
153
+
154
+ .ina-radio-input--size-lg .ina-radio-input__option-label {
155
+ font-size: var(--ina-font-base);
156
+ }
157
+
158
+ .ina-radio-input--size-lg .ina-radio-input__field {
159
+ width: 24px;
160
+ height: 24px;
161
+ }
162
+
163
+ /* Orientation variants */
164
+ .ina-radio-input--orientation-horizontal .ina-radio-input__group {
165
+ flex-direction: row;
166
+ flex-wrap: wrap;
167
+ gap: var(--ina-spacing-4);
168
+ }
169
+
170
+ /* Status variants */
171
+ .ina-radio-input__main-label--required::after {
172
+ content: '*';
173
+ color: var(--ina-danger-5);
174
+ margin-left: var(--ina-spacing-1);
175
+ }
176
+
177
+ /* Focus indicators */
178
+ .ina-radio-input__field:focus-visible {
179
+ outline: 2px solid #000000;
180
+ outline-offset: 2px;
181
+ }
182
+
183
+ /* Error state */
184
+ .ina-radio-input--error .ina-radio-input__main-label {
185
+ color: #dc2626;
186
+ }
187
+
188
+ .ina-radio-input--error .ina-radio-input__field {
189
+ border-color: #dc2626;
190
+ }
191
+
192
+ .ina-radio-input--error .ina-radio-input__field:focus-visible {
193
+ outline-color: #dc2626;
194
+ }
195
+
196
+ /* Loading state */
197
+ .ina-radio-input--loading .ina-radio-input__option {
198
+ opacity: 0.6;
199
+ cursor: not-allowed;
200
+ }
201
+
202
+ .ina-radio-input--loading .ina-radio-input__field {
203
+ cursor: not-allowed;
204
+ }
205
+
206
+ /* Help text */
207
+ .ina-radio-input__help-text {
208
+ font-size: var(--ina-font-xs);
209
+ color: #666666;
210
+ margin-top: var(--ina-spacing-1);
211
+ }
212
+
213
+ .ina-radio-input__help-text--error {
214
+ color: #dc2626;
215
+ }
216
+
217
+ /* Responsive adjustments */
218
+ @media (max-width: 640px) {
219
+ .ina-radio-input__main-label {
220
+ font-size: var(--ina-font-xs); /* Turun dari sm ke xs */
221
+ }
222
+
223
+ .ina-radio-input__option-label {
224
+ font-size: var(--ina-font-xs); /* Turun dari sm ke xs */
225
+ }
226
+
227
+ .ina-radio-input__help-text {
228
+ font-size: var(--ina-font-xs); /* Tetap xs */
229
+ }
230
+
231
+ .ina-radio-input--orientation-horizontal .ina-radio-input__group {
232
+ flex-direction: column;
233
+ gap: var(--ina-spacing-2);
234
+ }
235
+ }
236
+
237
+ /* Dark mode support - handled by CSS variables in css-variables.css */
238
+
239
+ /* Accessibility improvements */
240
+ .ina-radio-input__field + .ina-radio-input__option-label {
241
+ /* Improve tap target size for touch devices */
242
+ padding: var(--ina-spacing-1) var(--ina-spacing-2);
243
+ margin: calc(var(--ina-spacing-1) * -1) calc(var(--ina-spacing-2) * -1);
244
+ }
245
+
246
+ /* High contrast mode */
247
+ @media (prefers-contrast: high) {
248
+ .ina-radio-input__field {
249
+ border-width: 3px;
250
+ }
251
+
252
+ .ina-radio-input__field:checked {
253
+ border-width: 3px;
254
+ }
255
+ }
256
+
257
+ /* Reduced motion */
258
+ @media (prefers-reduced-motion: reduce) {
259
+ .ina-radio-input__option,
260
+ .ina-radio-input__field {
261
+ transition: none;
262
+ }
263
+ }