@arclux/arc-ui-html 1.0.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 (138) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +57 -0
  3. package/css/animated-number.css +12 -0
  4. package/css/app-shell.css +52 -0
  5. package/css/arc-ui.css +3045 -0
  6. package/css/aspect-ratio.css +23 -0
  7. package/css/auth-shell.css +98 -0
  8. package/css/avatar-group.css +49 -0
  9. package/css/avatar.css +53 -0
  10. package/css/badge.css +76 -0
  11. package/css/button.css +94 -0
  12. package/css/callout.css +84 -0
  13. package/css/card.css +50 -0
  14. package/css/code-block.css +86 -0
  15. package/css/color-swatch.css +47 -0
  16. package/css/container.css +15 -0
  17. package/css/dashboard-grid.css +21 -0
  18. package/css/divider.css +128 -0
  19. package/css/empty-state.css +43 -0
  20. package/css/feature-card.css +102 -0
  21. package/css/footer.css +60 -0
  22. package/css/form.css +454 -0
  23. package/css/highlight.css +13 -0
  24. package/css/icon-button.css +118 -0
  25. package/css/icon.css +36 -0
  26. package/css/kbd.css +21 -0
  27. package/css/link.css +74 -0
  28. package/css/markdown.css +133 -0
  29. package/css/meter.css +59 -0
  30. package/css/page-header.css +55 -0
  31. package/css/page-layout.css +65 -0
  32. package/css/progress.css +96 -0
  33. package/css/scroll-area.css +70 -0
  34. package/css/section.css +27 -0
  35. package/css/settings-layout.css +55 -0
  36. package/css/skeleton.css +44 -0
  37. package/css/spinner.css +46 -0
  38. package/css/stack.css +38 -0
  39. package/css/stat.css +42 -0
  40. package/css/status-bar.css +50 -0
  41. package/css/stepper.css +134 -0
  42. package/css/table.css +85 -0
  43. package/css/text.css +77 -0
  44. package/css/timeline.css +117 -0
  45. package/css/toolbar.css +54 -0
  46. package/css/tooltip.css +107 -0
  47. package/css/top-bar.css +158 -0
  48. package/css/value-card.css +60 -0
  49. package/examples/animated-number.html +8 -0
  50. package/examples/animated-number.inline.html +8 -0
  51. package/examples/app-shell.html +20 -0
  52. package/examples/app-shell.inline.html +31 -0
  53. package/examples/aspect-ratio.html +12 -0
  54. package/examples/aspect-ratio.inline.html +12 -0
  55. package/examples/auth-shell.html +20 -0
  56. package/examples/auth-shell.inline.html +28 -0
  57. package/examples/avatar-group.html +8 -0
  58. package/examples/avatar-group.inline.html +8 -0
  59. package/examples/avatar.html +7 -0
  60. package/examples/avatar.inline.html +11 -0
  61. package/examples/badge.html +5 -0
  62. package/examples/badge.inline.html +10 -0
  63. package/examples/button.html +5 -0
  64. package/examples/button.inline.html +21 -0
  65. package/examples/callout.html +12 -0
  66. package/examples/callout.inline.html +12 -0
  67. package/examples/card.html +5 -0
  68. package/examples/card.inline.html +13 -0
  69. package/examples/code-block.html +18 -0
  70. package/examples/code-block.inline.html +22 -0
  71. package/examples/color-swatch.html +12 -0
  72. package/examples/color-swatch.inline.html +16 -0
  73. package/examples/container.html +5 -0
  74. package/examples/container.inline.html +5 -0
  75. package/examples/dashboard-grid.html +7 -0
  76. package/examples/dashboard-grid.inline.html +10 -0
  77. package/examples/divider.html +5 -0
  78. package/examples/divider.inline.html +10 -0
  79. package/examples/empty-state.html +14 -0
  80. package/examples/empty-state.inline.html +14 -0
  81. package/examples/feature-card.html +12 -0
  82. package/examples/feature-card.inline.html +25 -0
  83. package/examples/footer.html +18 -0
  84. package/examples/footer.inline.html +18 -0
  85. package/examples/form.html +86 -0
  86. package/examples/highlight.html +5 -0
  87. package/examples/highlight.inline.html +5 -0
  88. package/examples/icon-button.html +5 -0
  89. package/examples/icon-button.inline.html +22 -0
  90. package/examples/icon.html +12 -0
  91. package/examples/icon.inline.html +12 -0
  92. package/examples/kbd.html +5 -0
  93. package/examples/kbd.inline.html +5 -0
  94. package/examples/link.html +13 -0
  95. package/examples/link.inline.html +23 -0
  96. package/examples/markdown.html +6 -0
  97. package/examples/markdown.inline.html +16 -0
  98. package/examples/meter.html +20 -0
  99. package/examples/meter.inline.html +29 -0
  100. package/examples/page-header.html +22 -0
  101. package/examples/page-header.inline.html +22 -0
  102. package/examples/page-layout.html +15 -0
  103. package/examples/page-layout.inline.html +21 -0
  104. package/examples/progress.html +20 -0
  105. package/examples/progress.inline.html +27 -0
  106. package/examples/scroll-area.html +12 -0
  107. package/examples/scroll-area.inline.html +22 -0
  108. package/examples/section.html +8 -0
  109. package/examples/section.inline.html +13 -0
  110. package/examples/settings-layout.html +12 -0
  111. package/examples/settings-layout.inline.html +22 -0
  112. package/examples/skeleton.html +10 -0
  113. package/examples/skeleton.inline.html +15 -0
  114. package/examples/spinner.html +9 -0
  115. package/examples/spinner.inline.html +9 -0
  116. package/examples/stack.html +5 -0
  117. package/examples/stack.inline.html +5 -0
  118. package/examples/stat.html +9 -0
  119. package/examples/stat.inline.html +10 -0
  120. package/examples/status-bar.html +15 -0
  121. package/examples/status-bar.inline.html +15 -0
  122. package/examples/stepper.html +18 -0
  123. package/examples/stepper.inline.html +18 -0
  124. package/examples/table.html +7 -0
  125. package/examples/table.inline.html +7 -0
  126. package/examples/text.html +5 -0
  127. package/examples/text.inline.html +5 -0
  128. package/examples/timeline.html +10 -0
  129. package/examples/timeline.inline.html +10 -0
  130. package/examples/toolbar.html +15 -0
  131. package/examples/toolbar.inline.html +15 -0
  132. package/examples/tooltip.html +19 -0
  133. package/examples/tooltip.inline.html +19 -0
  134. package/examples/top-bar.html +23 -0
  135. package/examples/top-bar.inline.html +29 -0
  136. package/examples/value-card.html +11 -0
  137. package/examples/value-card.inline.html +15 -0
  138. package/package.json +31 -0
package/css/form.css ADDED
@@ -0,0 +1,454 @@
1
+ /* Auto-generated by @arclux/prism — do not edit manually */
2
+
3
+ /* arc-form — styles native form elements with ARC design tokens */
4
+ /* Requires tokens.css */
5
+
6
+ /* ── Form Layout ── */
7
+ .arc-form {
8
+ display: flex;
9
+ flex-direction: column;
10
+ gap: var(--space-md);
11
+ font-family: var(--font-body);
12
+ }
13
+
14
+ .arc-form fieldset {
15
+ border: none;
16
+ margin: 0;
17
+ padding: 0;
18
+ display: flex;
19
+ flex-direction: column;
20
+ gap: var(--space-md);
21
+ }
22
+
23
+ .arc-form legend {
24
+ font-family: var(--font-accent);
25
+ font-weight: 600;
26
+ font-size: 11px;
27
+ letter-spacing: 1.5px;
28
+ text-transform: uppercase;
29
+ color: var(--text-primary);
30
+ margin-bottom: var(--space-sm);
31
+ }
32
+
33
+ /* ── Field Group ── */
34
+ .arc-field {
35
+ display: flex;
36
+ flex-direction: column;
37
+ gap: var(--space-xs);
38
+ }
39
+
40
+ /* ── Labels ── */
41
+ .arc-form label,
42
+ .arc-field > label {
43
+ font-family: var(--font-accent);
44
+ font-weight: 600;
45
+ font-size: 12px;
46
+ letter-spacing: 1px;
47
+ text-transform: uppercase;
48
+ color: var(--text-muted);
49
+ }
50
+
51
+ /* ── Text Inputs, Email, Password, URL, Search, Tel, Number ── */
52
+ .arc-form input[type="text"],
53
+ .arc-form input[type="email"],
54
+ .arc-form input[type="password"],
55
+ .arc-form input[type="url"],
56
+ .arc-form input[type="search"],
57
+ .arc-form input[type="tel"],
58
+ .arc-form input[type="number"],
59
+ .arc-form input[type="date"],
60
+ .arc-form input[type="time"],
61
+ .arc-form input[type="datetime-local"] {
62
+ font-family: var(--font-body);
63
+ font-size: 14px;
64
+ font-weight: 300;
65
+ color: var(--text-primary);
66
+ background: var(--bg-surface);
67
+ border: 1px solid var(--border-default);
68
+ border-radius: var(--radius-md);
69
+ padding: var(--space-sm) var(--space-md);
70
+ outline: none;
71
+ width: 100%;
72
+ box-sizing: border-box;
73
+ transition:
74
+ border-color var(--transition-fast),
75
+ box-shadow var(--transition-fast),
76
+ background var(--transition-fast);
77
+ }
78
+
79
+ .arc-form input[type="text"]::placeholder,
80
+ .arc-form input[type="email"]::placeholder,
81
+ .arc-form input[type="password"]::placeholder,
82
+ .arc-form input[type="url"]::placeholder,
83
+ .arc-form input[type="search"]::placeholder,
84
+ .arc-form input[type="tel"]::placeholder,
85
+ .arc-form input[type="number"]::placeholder {
86
+ color: var(--text-ghost);
87
+ }
88
+
89
+ .arc-form input:hover:not(:focus):not(:disabled) {
90
+ border-color: var(--border-bright);
91
+ }
92
+
93
+ .arc-form input:focus:not([type="checkbox"]):not([type="radio"]):not([type="range"]) {
94
+ border-color: rgba(var(--accent-primary-rgb), 0.4);
95
+ box-shadow: var(--focus-glow);
96
+ background: var(--bg-card);
97
+ }
98
+
99
+ .arc-form input:disabled {
100
+ opacity: 0.4;
101
+ cursor: not-allowed;
102
+ }
103
+
104
+ /* ── Textarea ── */
105
+ .arc-form textarea {
106
+ font-family: var(--font-body);
107
+ font-size: 14px;
108
+ line-height: 1.5;
109
+ color: var(--text-primary);
110
+ background: var(--bg-card);
111
+ border: 1px solid var(--border-default);
112
+ border-radius: var(--radius-md);
113
+ padding: var(--space-sm) var(--space-md);
114
+ outline: none;
115
+ width: 100%;
116
+ box-sizing: border-box;
117
+ resize: vertical;
118
+ transition:
119
+ border-color var(--transition-fast),
120
+ box-shadow var(--transition-fast);
121
+ }
122
+
123
+ .arc-form textarea::placeholder {
124
+ color: var(--text-muted);
125
+ }
126
+
127
+ .arc-form textarea:hover:not(:focus):not(:disabled):not(:read-only) {
128
+ border-color: var(--border-bright);
129
+ }
130
+
131
+ .arc-form textarea:focus {
132
+ border-color: rgba(var(--accent-primary-rgb), 0.4);
133
+ box-shadow: var(--focus-glow);
134
+ }
135
+
136
+ .arc-form textarea:disabled {
137
+ opacity: 0.4;
138
+ cursor: not-allowed;
139
+ }
140
+
141
+ /* ── Select ── */
142
+ .arc-form select {
143
+ font-family: var(--font-body);
144
+ font-size: 14px;
145
+ color: var(--text-primary);
146
+ background: var(--bg-surface);
147
+ border: 1px solid var(--border-default);
148
+ border-radius: var(--radius-md);
149
+ padding: var(--space-sm) var(--space-md);
150
+ padding-right: 36px;
151
+ outline: none;
152
+ width: 100%;
153
+ box-sizing: border-box;
154
+ cursor: pointer;
155
+ appearance: none;
156
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' stroke='%237c7c89' fill='none' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
157
+ background-repeat: no-repeat;
158
+ background-position: right var(--space-sm) center;
159
+ transition:
160
+ border-color var(--transition-fast),
161
+ box-shadow var(--transition-fast);
162
+ }
163
+
164
+ .arc-form select:hover:not(:focus):not(:disabled) {
165
+ border-color: var(--border-bright);
166
+ }
167
+
168
+ .arc-form select:focus {
169
+ border-color: rgba(var(--accent-primary-rgb), 0.4);
170
+ box-shadow: var(--focus-glow);
171
+ }
172
+
173
+ .arc-form select:disabled {
174
+ opacity: 0.4;
175
+ cursor: not-allowed;
176
+ }
177
+
178
+ /* ── Checkbox ── */
179
+ .arc-form input[type="checkbox"] {
180
+ appearance: none;
181
+ width: 18px;
182
+ height: 18px;
183
+ border-radius: var(--radius-sm);
184
+ border: 1px solid var(--border-bright);
185
+ background: var(--bg-surface);
186
+ cursor: pointer;
187
+ position: relative;
188
+ flex-shrink: 0;
189
+ transition:
190
+ background var(--transition-fast),
191
+ border-color var(--transition-fast),
192
+ box-shadow var(--transition-fast);
193
+ }
194
+
195
+ .arc-form input[type="checkbox"]:checked {
196
+ background: var(--accent-primary);
197
+ border-color: var(--accent-primary);
198
+ box-shadow: 0 0 8px rgba(var(--accent-primary-rgb), 0.3);
199
+ }
200
+
201
+ .arc-form input[type="checkbox"]:checked::after {
202
+ content: '';
203
+ position: absolute;
204
+ top: 2px;
205
+ left: 5px;
206
+ width: 5px;
207
+ height: 9px;
208
+ border: solid var(--bg-deep);
209
+ border-width: 0 2px 2px 0;
210
+ transform: rotate(45deg);
211
+ }
212
+
213
+ .arc-form input[type="checkbox"]:focus-visible {
214
+ outline: none;
215
+ box-shadow: var(--focus-glow);
216
+ }
217
+
218
+ /* ── Radio ── */
219
+ .arc-form input[type="radio"] {
220
+ appearance: none;
221
+ width: 18px;
222
+ height: 18px;
223
+ border-radius: var(--radius-full);
224
+ border: 1px solid var(--border-bright);
225
+ background: var(--bg-surface);
226
+ cursor: pointer;
227
+ position: relative;
228
+ flex-shrink: 0;
229
+ transition:
230
+ border-color var(--transition-fast),
231
+ box-shadow var(--transition-fast);
232
+ }
233
+
234
+ .arc-form input[type="radio"]:checked {
235
+ border-color: var(--accent-primary);
236
+ box-shadow: 0 0 8px rgba(var(--accent-primary-rgb), 0.3);
237
+ }
238
+
239
+ .arc-form input[type="radio"]:checked::after {
240
+ content: '';
241
+ position: absolute;
242
+ top: 4px;
243
+ left: 4px;
244
+ width: 8px;
245
+ height: 8px;
246
+ border-radius: var(--radius-full);
247
+ background: var(--accent-primary);
248
+ }
249
+
250
+ .arc-form input[type="radio"]:focus-visible {
251
+ outline: none;
252
+ box-shadow: var(--focus-glow);
253
+ }
254
+
255
+ /* ── Checkbox & Radio inline layout ── */
256
+ .arc-check {
257
+ display: inline-flex;
258
+ align-items: center;
259
+ gap: var(--space-sm);
260
+ cursor: pointer;
261
+ }
262
+
263
+ .arc-check label {
264
+ font-family: var(--font-body);
265
+ font-size: 14px;
266
+ font-weight: 400;
267
+ color: var(--text-secondary);
268
+ text-transform: none;
269
+ letter-spacing: 0;
270
+ cursor: pointer;
271
+ user-select: none;
272
+ }
273
+
274
+ /* ── Range / Slider ── */
275
+ .arc-form input[type="range"] {
276
+ appearance: none;
277
+ width: 100%;
278
+ height: 4px;
279
+ background: var(--border-default);
280
+ border-radius: var(--radius-full);
281
+ outline: none;
282
+ cursor: pointer;
283
+ }
284
+
285
+ .arc-form input[type="range"]::-webkit-slider-thumb {
286
+ appearance: none;
287
+ width: 18px;
288
+ height: 18px;
289
+ border-radius: var(--radius-full);
290
+ background: var(--accent-primary);
291
+ border: 2px solid var(--bg-deep);
292
+ box-shadow: 0 0 6px rgba(var(--accent-primary-rgb), 0.3);
293
+ cursor: pointer;
294
+ transition: box-shadow var(--transition-fast), transform var(--transition-fast);
295
+ }
296
+
297
+ .arc-form input[type="range"]::-webkit-slider-thumb:hover {
298
+ box-shadow: 0 0 12px rgba(var(--accent-primary-rgb), 0.5);
299
+ transform: scale(1.1);
300
+ }
301
+
302
+ .arc-form input[type="range"]:focus-visible::-webkit-slider-thumb {
303
+ box-shadow: var(--focus-glow);
304
+ }
305
+
306
+ /* ── File Input ── */
307
+ .arc-form input[type="file"] {
308
+ font-family: var(--font-body);
309
+ font-size: 14px;
310
+ color: var(--text-secondary);
311
+ background: var(--bg-surface);
312
+ border: 1px dashed var(--border-default);
313
+ border-radius: var(--radius-md);
314
+ padding: var(--space-md);
315
+ width: 100%;
316
+ box-sizing: border-box;
317
+ cursor: pointer;
318
+ transition: border-color var(--transition-fast);
319
+ }
320
+
321
+ .arc-form input[type="file"]:hover {
322
+ border-color: var(--border-bright);
323
+ }
324
+
325
+ .arc-form input[type="file"]:focus-visible {
326
+ outline: none;
327
+ box-shadow: var(--focus-glow);
328
+ }
329
+
330
+ /* ── Submit / Button ── */
331
+ .arc-form button[type="submit"],
332
+ .arc-form input[type="submit"] {
333
+ display: inline-flex;
334
+ align-items: center;
335
+ justify-content: center;
336
+ gap: var(--space-sm);
337
+ font-family: var(--font-accent);
338
+ font-weight: 600;
339
+ font-size: 12px;
340
+ text-transform: uppercase;
341
+ letter-spacing: 2px;
342
+ background: var(--accent-primary);
343
+ color: var(--bg-deep);
344
+ border: 1px solid var(--accent-primary);
345
+ border-radius: var(--radius-md);
346
+ padding: var(--space-sm) var(--space-lg);
347
+ cursor: pointer;
348
+ transition:
349
+ box-shadow var(--transition-base),
350
+ transform var(--transition-fast);
351
+ }
352
+
353
+ .arc-form button[type="submit"]:hover,
354
+ .arc-form input[type="submit"]:hover {
355
+ box-shadow: 0 0 8px rgba(var(--accent-primary-rgb), 0.9),
356
+ 0 0 20px rgba(var(--accent-primary-rgb), 0.5),
357
+ 0 0 44px rgba(var(--accent-primary-rgb), 0.25);
358
+ }
359
+
360
+ .arc-form button[type="submit"]:active,
361
+ .arc-form input[type="submit"]:active {
362
+ transform: scale(0.97);
363
+ box-shadow: 0 0 8px rgba(var(--accent-primary-rgb), 0.5);
364
+ }
365
+
366
+ .arc-form button[type="submit"]:focus-visible,
367
+ .arc-form input[type="submit"]:focus-visible {
368
+ outline: none;
369
+ box-shadow: var(--focus-glow);
370
+ }
371
+
372
+ .arc-form button[type="submit"]:disabled,
373
+ .arc-form input[type="submit"]:disabled {
374
+ opacity: 0.4;
375
+ cursor: not-allowed;
376
+ pointer-events: none;
377
+ }
378
+
379
+ /* ── Reset Button ── */
380
+ .arc-form button[type="reset"],
381
+ .arc-form input[type="reset"] {
382
+ display: inline-flex;
383
+ align-items: center;
384
+ justify-content: center;
385
+ font-family: var(--font-accent);
386
+ font-weight: 600;
387
+ font-size: 12px;
388
+ text-transform: uppercase;
389
+ letter-spacing: 2px;
390
+ background: transparent;
391
+ color: var(--text-muted);
392
+ border: 1px solid var(--border-default);
393
+ border-radius: var(--radius-md);
394
+ padding: var(--space-sm) var(--space-lg);
395
+ cursor: pointer;
396
+ transition:
397
+ border-color var(--transition-fast),
398
+ color var(--transition-fast),
399
+ box-shadow var(--transition-fast),
400
+ transform var(--transition-fast);
401
+ }
402
+
403
+ .arc-form button[type="reset"]:hover,
404
+ .arc-form input[type="reset"]:hover {
405
+ border-color: var(--accent-primary);
406
+ color: var(--accent-primary);
407
+ box-shadow: 0 0 20px rgba(var(--accent-primary-rgb), 0.15);
408
+ }
409
+
410
+ .arc-form button[type="reset"]:active,
411
+ .arc-form input[type="reset"]:active {
412
+ transform: scale(0.97);
413
+ }
414
+
415
+ .arc-form button[type="reset"]:focus-visible,
416
+ .arc-form input[type="reset"]:focus-visible {
417
+ outline: none;
418
+ box-shadow: var(--focus-glow);
419
+ }
420
+
421
+ /* ── Button Row ── */
422
+ .arc-form-actions {
423
+ display: flex;
424
+ align-items: center;
425
+ gap: var(--space-md);
426
+ padding-top: var(--space-sm);
427
+ }
428
+
429
+ /* ── Error State ── */
430
+ .arc-field.error input,
431
+ .arc-field.error textarea,
432
+ .arc-field.error select {
433
+ border-color: var(--color-error);
434
+ }
435
+
436
+ .arc-field.error input:focus,
437
+ .arc-field.error textarea:focus,
438
+ .arc-field.error select:focus {
439
+ box-shadow: 0 0 6px rgba(var(--color-error-rgb), 0.35),
440
+ 0 0 16px rgba(var(--color-error-rgb), 0.2);
441
+ }
442
+
443
+ .arc-field .arc-error {
444
+ font-size: 12px;
445
+ color: var(--color-error);
446
+ line-height: 1.4;
447
+ }
448
+
449
+ /* ── Help Text ── */
450
+ .arc-field .arc-hint {
451
+ font-size: 12px;
452
+ color: var(--text-ghost);
453
+ line-height: 1.4;
454
+ }
@@ -0,0 +1,13 @@
1
+ /* Auto-generated by @arclux/prism — do not edit manually */
2
+
3
+ /* arc-highlight */
4
+ .arc-highlight { display: inline; }
5
+
6
+ mark {
7
+ background: var(--accent-primary-subtle);
8
+ color: var(--accent-primary);
9
+ border-radius: var(--radius-sm);
10
+ padding: 1px var(--space-xs); /* cosmetic 1px vertical for inline highlight */
11
+ font-style: inherit;
12
+ font-weight: inherit;
13
+ }
@@ -0,0 +1,118 @@
1
+ /* Auto-generated by @arclux/prism — do not edit manually */
2
+
3
+ /* arc-icon-button */
4
+ .arc-icon-button { display: inline-flex; }
5
+ .arc-icon-button[disabled] { pointer-events: none; }
6
+
7
+ .arc-icon-button .btn {
8
+ display: inline-flex;
9
+ align-items: center;
10
+ justify-content: center;
11
+ gap: var(--space-xs);
12
+ border: 1px solid transparent;
13
+ border-radius: var(--radius-md);
14
+ cursor: pointer;
15
+ transition:
16
+ background var(--transition-base),
17
+ border-color var(--transition-base),
18
+ box-shadow var(--transition-base),
19
+ color var(--transition-base),
20
+ transform var(--transition-fast);
21
+ text-decoration: none;
22
+ box-sizing: border-box;
23
+ color: inherit;
24
+ }
25
+
26
+ /* Icon-only (square) */
27
+ .arc-icon-button .btn:not(.btn--has-text) { aspect-ratio: 1; }
28
+
29
+ /* With text */
30
+ .arc-icon-button .btn--has-text {
31
+ font-family: var(--font-accent);
32
+ font-weight: 600;
33
+ text-transform: uppercase;
34
+ letter-spacing: 1.5px;
35
+ white-space: nowrap;
36
+ }
37
+
38
+ .arc-icon-button .btn__text {
39
+ line-height: 1;
40
+ }
41
+
42
+ /* Sizes — icon-only */
43
+ .arc-icon-button[data-size="xs"] .btn:not(.btn--has-text) { width: 28px; height: 28px; border-radius: var(--radius-sm); }
44
+ .arc-icon-button[data-size="sm"] .btn:not(.btn--has-text) { width: 32px; height: 32px; }
45
+ .arc-icon-button:not([data-size]) .btn:not(.btn--has-text),
46
+ .arc-icon-button[data-size="md"] .btn:not(.btn--has-text) { width: 36px; height: 36px; }
47
+ .arc-icon-button[data-size="lg"] .btn:not(.btn--has-text) { width: 44px; height: 44px; }
48
+
49
+ /* Sizes — with text */
50
+ .arc-icon-button[data-size="xs"] .btn--has-text { padding: var(--space-xs) var(--space-sm); font-size: var(--text-xs); }
51
+ .arc-icon-button[data-size="sm"] .btn--has-text { padding: calc(var(--space-xs) + 2px) calc(var(--space-sm) + 2px); font-size: var(--text-xs); }
52
+ .arc-icon-button:not([data-size]) .btn--has-text,
53
+ .arc-icon-button[data-size="md"] .btn--has-text { padding: var(--space-xs) var(--space-sm); font-size: var(--text-xs); }
54
+ .arc-icon-button[data-size="lg"] .btn--has-text { padding: var(--space-sm) var(--space-md); font-size: var(--text-xs); }
55
+
56
+ /* Ghost (default) */
57
+ .arc-icon-button:not([data-variant]) .btn,
58
+ .arc-icon-button[data-variant="ghost"] .btn {
59
+ background: transparent;
60
+ color: var(--text-muted);
61
+ border-color: transparent;
62
+ }
63
+ .arc-icon-button:not([data-variant]) .btn:hover,
64
+ .arc-icon-button[data-variant="ghost"] .btn:hover {
65
+ color: var(--text-primary);
66
+ background: var(--bg-hover);
67
+ }
68
+ .arc-icon-button:not([data-variant]) .btn:active,
69
+ .arc-icon-button[data-variant="ghost"] .btn:active {
70
+ transform: scale(0.93);
71
+ background: var(--bg-elevated);
72
+ }
73
+
74
+ /* Secondary */
75
+ .arc-icon-button[data-variant="secondary"] .btn {
76
+ background: transparent;
77
+ color: var(--text-secondary);
78
+ border-color: var(--border-default);
79
+ }
80
+ .arc-icon-button[data-variant="secondary"] .btn:hover {
81
+ border-color: var(--accent-primary);
82
+ color: var(--accent-primary);
83
+ box-shadow: 0 0 16px var(--accent-primary-ring);
84
+ }
85
+ .arc-icon-button[data-variant="secondary"] .btn:active {
86
+ transform: scale(0.93);
87
+ background: rgba(var(--accent-primary-rgb), 0.05);
88
+ }
89
+
90
+ /* Primary */
91
+ .arc-icon-button[data-variant="primary"] .btn {
92
+ background: var(--accent-primary);
93
+ color: var(--bg-deep);
94
+ border-color: var(--accent-primary);
95
+ }
96
+ .arc-icon-button[data-variant="primary"] .btn:hover {
97
+ box-shadow: var(--glow-primary);
98
+ }
99
+ .arc-icon-button[data-variant="primary"] .btn:active {
100
+ transform: scale(0.93);
101
+ box-shadow: 0 0 8px rgba(var(--accent-primary-rgb), 0.5);
102
+ }
103
+
104
+ /* Focus */
105
+ .arc-icon-button .btn:focus-visible { outline: none; box-shadow: var(--focus-glow); }
106
+
107
+ /* Disabled */
108
+ .arc-icon-button[disabled] .btn { opacity: 0.4; cursor: not-allowed; pointer-events: none; }
109
+
110
+ @media (prefers-reduced-motion: reduce) {
111
+ .arc-icon-button *,
112
+ .arc-icon-button *::before,
113
+ .arc-icon-button *::after {
114
+ animation-duration: 0.01ms !important;
115
+ animation-iteration-count: 1 !important;
116
+ transition-duration: 0.01ms !important;
117
+ }
118
+ }
package/css/icon.css ADDED
@@ -0,0 +1,36 @@
1
+ /* Auto-generated by @arclux/prism — do not edit manually */
2
+
3
+ /* arc-icon */
4
+ .arc-icon {
5
+ display: inline-flex;
6
+ align-items: center;
7
+ justify-content: center;
8
+ color: currentColor;
9
+ vertical-align: middle;
10
+ }
11
+
12
+ .arc-icon[data-size="xs"] { width: 12px; height: 12px; }
13
+ .arc-icon:not([data-size]),
14
+ .arc-icon[data-size="sm"] { width: 16px; height: 16px; }
15
+ .arc-icon[data-size="md"] { width: 20px; height: 20px; }
16
+ .arc-icon[data-size="lg"] { width: 24px; height: 24px; }
17
+ .arc-icon[data-size="xl"] { width: 32px; height: 32px; }
18
+
19
+ .arc-icon .icon {
20
+ display: flex;
21
+ align-items: center;
22
+ justify-content: center;
23
+ width: 100%;
24
+ height: 100%;
25
+ }
26
+
27
+ svg {
28
+ width: 100%;
29
+ height: 100%;
30
+ }
31
+
32
+ ::slotted(svg) {
33
+ width: 100%;
34
+ height: 100%;
35
+ fill: currentColor;
36
+ }
package/css/kbd.css ADDED
@@ -0,0 +1,21 @@
1
+ /* Auto-generated by @arclux/prism — do not edit manually */
2
+
3
+ /* arc-kbd */
4
+ .arc-kbd { display: inline; }
5
+
6
+ .arc-kbd .kbd {
7
+ display: inline-flex;
8
+ align-items: center;
9
+ font-family: var(--font-mono);
10
+ font-size: var(--text-sm);
11
+ line-height: 1;
12
+ color: var(--text-secondary);
13
+ background: var(--bg-elevated);
14
+ border: 1px solid var(--border-default);
15
+ border-bottom-width: 2px;
16
+ border-radius: var(--radius-sm);
17
+ padding: 2px calc(var(--space-xs) + 2px); /* cosmetic 2px vertical for kbd element */
18
+ white-space: nowrap;
19
+ user-select: none;
20
+ vertical-align: baseline;
21
+ }