@headspace_designsystem/hsds-web-library 0.1.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 (46) hide show
  1. package/README.md +184 -0
  2. package/dist/components/Button/Button.d.ts +3 -0
  3. package/dist/components/Button/Button.d.ts.map +1 -0
  4. package/dist/components/Button/Button.types.d.ts +18 -0
  5. package/dist/components/Button/Button.types.d.ts.map +1 -0
  6. package/dist/components/Button/index.d.ts +3 -0
  7. package/dist/components/Button/index.d.ts.map +1 -0
  8. package/dist/components/index.d.ts +2 -0
  9. package/dist/components/index.d.ts.map +1 -0
  10. package/dist/demo.d.ts +2 -0
  11. package/dist/demo.d.ts.map +1 -0
  12. package/dist/hsds-web-library.es.js +1927 -0
  13. package/dist/hsds-web-library.es.js.map +1 -0
  14. package/dist/hsds-web-library.umd.js +19 -0
  15. package/dist/hsds-web-library.umd.js.map +1 -0
  16. package/dist/index.d.ts +17 -0
  17. package/dist/index.d.ts.map +1 -0
  18. package/dist/theme/ThemeProvider.d.ts +14 -0
  19. package/dist/theme/ThemeProvider.d.ts.map +1 -0
  20. package/dist/theme/index.d.ts +4 -0
  21. package/dist/theme/index.d.ts.map +1 -0
  22. package/dist/theme/theme.d.ts +3 -0
  23. package/dist/theme/theme.d.ts.map +1 -0
  24. package/dist/theme/types.d.ts +88 -0
  25. package/dist/theme/types.d.ts.map +1 -0
  26. package/dist/tokens/index.d.ts +3 -0
  27. package/dist/tokens/index.d.ts.map +1 -0
  28. package/dist/tokens/primitives/borders.d.ts +41 -0
  29. package/dist/tokens/primitives/borders.d.ts.map +1 -0
  30. package/dist/tokens/primitives/colors.d.ts +67 -0
  31. package/dist/tokens/primitives/colors.d.ts.map +1 -0
  32. package/dist/tokens/primitives/index.d.ts +6 -0
  33. package/dist/tokens/primitives/index.d.ts.map +1 -0
  34. package/dist/tokens/primitives/shadows.d.ts +38 -0
  35. package/dist/tokens/primitives/shadows.d.ts.map +1 -0
  36. package/dist/tokens/primitives/spacing.d.ts +29 -0
  37. package/dist/tokens/primitives/spacing.d.ts.map +1 -0
  38. package/dist/tokens/primitives/typography.d.ts +46 -0
  39. package/dist/tokens/primitives/typography.d.ts.map +1 -0
  40. package/dist/tokens/semantic/colors.d.ts +154 -0
  41. package/dist/tokens/semantic/colors.d.ts.map +1 -0
  42. package/dist/tokens/semantic/index.d.ts +3 -0
  43. package/dist/tokens/semantic/index.d.ts.map +1 -0
  44. package/dist/tokens/semantic/typography.d.ts +253 -0
  45. package/dist/tokens/semantic/typography.d.ts.map +1 -0
  46. package/package.json +45 -0
@@ -0,0 +1,1927 @@
1
+ import * as P from "react/jsx-runtime";
2
+ import * as B from "react";
3
+ import { forwardRef as Gr, useContext as fr } from "react";
4
+ import { ThemeProvider as Sr, withEmotionCache as xr, ThemeContext as Zr, keyframes as vr } from "@emotion/react";
5
+ function hr(e) {
6
+ if (e.sheet)
7
+ return e.sheet;
8
+ for (var r = 0; r < document.styleSheets.length; r++)
9
+ if (document.styleSheets[r].ownerNode === e)
10
+ return document.styleSheets[r];
11
+ }
12
+ function Wr(e) {
13
+ var r = document.createElement("style");
14
+ return r.setAttribute("data-emotion", e.key), e.nonce !== void 0 && r.setAttribute("nonce", e.nonce), r.appendChild(document.createTextNode("")), r.setAttribute("data-s", ""), r;
15
+ }
16
+ var Xr = /* @__PURE__ */ function() {
17
+ function e(n) {
18
+ var i = this;
19
+ this._insertTag = function(t) {
20
+ var c;
21
+ i.tags.length === 0 ? i.insertionPoint ? c = i.insertionPoint.nextSibling : i.prepend ? c = i.container.firstChild : c = i.before : c = i.tags[i.tags.length - 1].nextSibling, i.container.insertBefore(t, c), i.tags.push(t);
22
+ }, this.isSpeedy = n.speedy === void 0 ? !0 : n.speedy, this.tags = [], this.ctr = 0, this.nonce = n.nonce, this.key = n.key, this.container = n.container, this.prepend = n.prepend, this.insertionPoint = n.insertionPoint, this.before = null;
23
+ }
24
+ var r = e.prototype;
25
+ return r.hydrate = function(i) {
26
+ i.forEach(this._insertTag);
27
+ }, r.insert = function(i) {
28
+ this.ctr % (this.isSpeedy ? 65e3 : 1) === 0 && this._insertTag(Wr(this));
29
+ var t = this.tags[this.tags.length - 1];
30
+ if (this.isSpeedy) {
31
+ var c = hr(t);
32
+ try {
33
+ c.insertRule(i, c.cssRules.length);
34
+ } catch {
35
+ }
36
+ } else
37
+ t.appendChild(document.createTextNode(i));
38
+ this.ctr++;
39
+ }, r.flush = function() {
40
+ this.tags.forEach(function(i) {
41
+ var t;
42
+ return (t = i.parentNode) == null ? void 0 : t.removeChild(i);
43
+ }), this.tags = [], this.ctr = 0;
44
+ }, e;
45
+ }(), H = "-ms-", ae = "-moz-", p = "-webkit-", Be = "comm", Ge = "rule", fe = "decl", Jr = "@import", De = "@keyframes", Vr = "@layer", Rr = Math.abs, oe = String.fromCharCode, Fr = Object.assign;
46
+ function Yr(e, r) {
47
+ return N(e, 0) ^ 45 ? (((r << 2 ^ N(e, 0)) << 2 ^ N(e, 1)) << 2 ^ N(e, 2)) << 2 ^ N(e, 3) : 0;
48
+ }
49
+ function we(e) {
50
+ return e.trim();
51
+ }
52
+ function Nr(e, r) {
53
+ return (e = r.exec(e)) ? e[0] : e;
54
+ }
55
+ function y(e, r, n) {
56
+ return e.replace(r, n);
57
+ }
58
+ function ue(e, r) {
59
+ return e.indexOf(r);
60
+ }
61
+ function N(e, r) {
62
+ return e.charCodeAt(r) | 0;
63
+ }
64
+ function _(e, r, n) {
65
+ return e.slice(r, n);
66
+ }
67
+ function L(e) {
68
+ return e.length;
69
+ }
70
+ function Se(e) {
71
+ return e.length;
72
+ }
73
+ function ie(e, r) {
74
+ return r.push(e), e;
75
+ }
76
+ function kr(e, r) {
77
+ return e.map(r).join("");
78
+ }
79
+ var Ie = 1, U = 1, Le = 0, D = 0, Y = 0, M = "";
80
+ function le(e, r, n, i, t, c, a) {
81
+ return { value: e, root: r, parent: n, type: i, props: t, children: c, line: Ie, column: U, length: a, return: "" };
82
+ }
83
+ function Q(e, r) {
84
+ return Fr(le("", null, null, "", null, null, 0), e, { length: -e.length }, r);
85
+ }
86
+ function Hr() {
87
+ return Y;
88
+ }
89
+ function Br() {
90
+ return Y = D > 0 ? N(M, --D) : 0, U--, Y === 10 && (U = 1, Ie--), Y;
91
+ }
92
+ function w() {
93
+ return Y = D < Le ? N(M, D++) : 0, U++, Y === 10 && (U = 1, Ie++), Y;
94
+ }
95
+ function z() {
96
+ return N(M, D);
97
+ }
98
+ function te() {
99
+ return D;
100
+ }
101
+ function ee(e, r) {
102
+ return _(M, e, r);
103
+ }
104
+ function $(e) {
105
+ switch (e) {
106
+ case 0:
107
+ case 9:
108
+ case 10:
109
+ case 13:
110
+ case 32:
111
+ return 5;
112
+ case 33:
113
+ case 43:
114
+ case 44:
115
+ case 47:
116
+ case 62:
117
+ case 64:
118
+ case 126:
119
+ case 59:
120
+ case 123:
121
+ case 125:
122
+ return 4;
123
+ case 58:
124
+ return 3;
125
+ case 34:
126
+ case 39:
127
+ case 40:
128
+ case 91:
129
+ return 2;
130
+ case 41:
131
+ case 93:
132
+ return 1;
133
+ }
134
+ return 0;
135
+ }
136
+ function Te(e) {
137
+ return Ie = U = 1, Le = L(M = e), D = 0, [];
138
+ }
139
+ function ze(e) {
140
+ return M = "", e;
141
+ }
142
+ function ce(e) {
143
+ return we(ee(D - 1, de(e === 91 ? e + 2 : e === 40 ? e + 1 : e)));
144
+ }
145
+ function Dr(e) {
146
+ for (; (Y = z()) && Y < 33; )
147
+ w();
148
+ return $(e) > 2 || $(Y) > 3 ? "" : " ";
149
+ }
150
+ function wr(e, r) {
151
+ for (; --r && w() && !(Y < 48 || Y > 102 || Y > 57 && Y < 65 || Y > 70 && Y < 97); )
152
+ ;
153
+ return ee(e, te() + (r < 6 && z() == 32 && w() == 32));
154
+ }
155
+ function de(e) {
156
+ for (; w(); )
157
+ switch (Y) {
158
+ case e:
159
+ return D;
160
+ case 34:
161
+ case 39:
162
+ e !== 34 && e !== 39 && de(Y);
163
+ break;
164
+ case 40:
165
+ e === 41 && de(e);
166
+ break;
167
+ case 92:
168
+ w();
169
+ break;
170
+ }
171
+ return D;
172
+ }
173
+ function Lr(e, r) {
174
+ for (; w() && e + Y !== 57; )
175
+ if (e + Y === 84 && z() === 47)
176
+ break;
177
+ return "/*" + ee(r, D - 1) + "*" + oe(e === 47 ? e : w());
178
+ }
179
+ function Tr(e) {
180
+ for (; !$(z()); )
181
+ w();
182
+ return ee(e, D);
183
+ }
184
+ function zr(e) {
185
+ return ze(ge("", null, null, null, [""], e = Te(e), 0, [0], e));
186
+ }
187
+ function ge(e, r, n, i, t, c, a, l, s) {
188
+ for (var A = 0, b = 0, C = a, k = 0, F = 0, X = 0, u = 1, d = 1, m = 1, V = 0, G = "", J = t, g = c, R = i, f = G; d; )
189
+ switch (X = V, V = w()) {
190
+ case 40:
191
+ if (X != 108 && N(f, C - 1) == 58) {
192
+ ue(f += y(ce(V), "&", "&\f"), "&\f") != -1 && (m = -1);
193
+ break;
194
+ }
195
+ case 34:
196
+ case 39:
197
+ case 91:
198
+ f += ce(V);
199
+ break;
200
+ case 9:
201
+ case 10:
202
+ case 13:
203
+ case 32:
204
+ f += Dr(X);
205
+ break;
206
+ case 92:
207
+ f += wr(te() - 1, 7);
208
+ continue;
209
+ case 47:
210
+ switch (z()) {
211
+ case 42:
212
+ case 47:
213
+ ie(Or(Lr(w(), te()), r, n), s);
214
+ break;
215
+ default:
216
+ f += "/";
217
+ }
218
+ break;
219
+ case 123 * u:
220
+ l[A++] = L(f) * m;
221
+ case 125 * u:
222
+ case 59:
223
+ case 0:
224
+ switch (V) {
225
+ case 0:
226
+ case 125:
227
+ d = 0;
228
+ case 59 + b:
229
+ m == -1 && (f = y(f, /\f/g, "")), F > 0 && L(f) - C && ie(F > 32 ? Xe(f + ";", i, n, C - 1) : Xe(y(f, " ", "") + ";", i, n, C - 2), s);
230
+ break;
231
+ case 59:
232
+ f += ";";
233
+ default:
234
+ if (ie(R = We(f, r, n, A, b, t, l, G, J = [], g = [], C), c), V === 123)
235
+ if (b === 0)
236
+ ge(f, r, R, R, J, c, C, l, g);
237
+ else
238
+ switch (k === 99 && N(f, 3) === 110 ? 100 : k) {
239
+ case 100:
240
+ case 108:
241
+ case 109:
242
+ case 115:
243
+ ge(e, R, R, i && ie(We(e, R, R, 0, 0, t, l, G, t, J = [], C), g), t, g, C, l, i ? J : g);
244
+ break;
245
+ default:
246
+ ge(f, R, R, R, [""], g, 0, l, g);
247
+ }
248
+ }
249
+ A = b = F = 0, u = m = 1, G = f = "", C = a;
250
+ break;
251
+ case 58:
252
+ C = 1 + L(f), F = X;
253
+ default:
254
+ if (u < 1) {
255
+ if (V == 123)
256
+ --u;
257
+ else if (V == 125 && u++ == 0 && Br() == 125)
258
+ continue;
259
+ }
260
+ switch (f += oe(V), V * u) {
261
+ case 38:
262
+ m = b > 0 ? 1 : (f += "\f", -1);
263
+ break;
264
+ case 44:
265
+ l[A++] = (L(f) - 1) * m, m = 1;
266
+ break;
267
+ case 64:
268
+ z() === 45 && (f += ce(w())), k = z(), b = C = L(G = f += Tr(te())), V++;
269
+ break;
270
+ case 45:
271
+ X === 45 && L(f) == 2 && (u = 0);
272
+ }
273
+ }
274
+ return c;
275
+ }
276
+ function We(e, r, n, i, t, c, a, l, s, A, b) {
277
+ for (var C = t - 1, k = t === 0 ? c : [""], F = Se(k), X = 0, u = 0, d = 0; X < i; ++X)
278
+ for (var m = 0, V = _(e, C + 1, C = Rr(u = a[X])), G = e; m < F; ++m)
279
+ (G = we(u > 0 ? k[m] + " " + V : y(V, /&\f/g, k[m]))) && (s[d++] = G);
280
+ return le(e, r, n, t === 0 ? Ge : l, s, A, b);
281
+ }
282
+ function Or(e, r, n) {
283
+ return le(e, r, n, Be, oe(Hr()), _(e, 2, -2), 0);
284
+ }
285
+ function Xe(e, r, n, i) {
286
+ return le(e, r, n, fe, _(e, 0, i), _(e, i + 1, -1), i);
287
+ }
288
+ function E(e, r) {
289
+ for (var n = "", i = Se(e), t = 0; t < i; t++)
290
+ n += r(e[t], t, e, r) || "";
291
+ return n;
292
+ }
293
+ function jr(e, r, n, i) {
294
+ switch (e.type) {
295
+ case Vr:
296
+ if (e.children.length) break;
297
+ case Jr:
298
+ case fe:
299
+ return e.return = e.return || e.value;
300
+ case Be:
301
+ return "";
302
+ case De:
303
+ return e.return = e.value + "{" + E(e.children, i) + "}";
304
+ case Ge:
305
+ e.value = e.props.join(",");
306
+ }
307
+ return L(n = E(e.children, i)) ? e.return = e.value + "{" + n + "}" : "";
308
+ }
309
+ function Er(e) {
310
+ var r = Se(e);
311
+ return function(n, i, t, c) {
312
+ for (var a = "", l = 0; l < r; l++)
313
+ a += e[l](n, i, t, c) || "";
314
+ return a;
315
+ };
316
+ }
317
+ function Ur(e) {
318
+ return function(r) {
319
+ r.root || (r = r.return) && e(r);
320
+ };
321
+ }
322
+ function Oe(e) {
323
+ var r = /* @__PURE__ */ Object.create(null);
324
+ return function(n) {
325
+ return r[n] === void 0 && (r[n] = e(n)), r[n];
326
+ };
327
+ }
328
+ var Mr = function(r, n, i) {
329
+ for (var t = 0, c = 0; t = c, c = z(), t === 38 && c === 12 && (n[i] = 1), !$(c); )
330
+ w();
331
+ return ee(r, D);
332
+ }, Qr = function(r, n) {
333
+ var i = -1, t = 44;
334
+ do
335
+ switch ($(t)) {
336
+ case 0:
337
+ t === 38 && z() === 12 && (n[i] = 1), r[i] += Mr(D - 1, n, i);
338
+ break;
339
+ case 2:
340
+ r[i] += ce(t);
341
+ break;
342
+ case 4:
343
+ if (t === 44) {
344
+ r[++i] = z() === 58 ? "&\f" : "", n[i] = r[i].length;
345
+ break;
346
+ }
347
+ default:
348
+ r[i] += oe(t);
349
+ }
350
+ while (t = w());
351
+ return r;
352
+ }, Pr = function(r, n) {
353
+ return ze(Qr(Te(r), n));
354
+ }, Je = /* @__PURE__ */ new WeakMap(), _r = function(r) {
355
+ if (!(r.type !== "rule" || !r.parent || // positive .length indicates that this rule contains pseudo
356
+ // negative .length indicates that this rule has been already prefixed
357
+ r.length < 1)) {
358
+ for (var n = r.value, i = r.parent, t = r.column === i.column && r.line === i.line; i.type !== "rule"; )
359
+ if (i = i.parent, !i) return;
360
+ if (!(r.props.length === 1 && n.charCodeAt(0) !== 58 && !Je.get(i)) && !t) {
361
+ Je.set(r, !0);
362
+ for (var c = [], a = Pr(n, c), l = i.props, s = 0, A = 0; s < a.length; s++)
363
+ for (var b = 0; b < l.length; b++, A++)
364
+ r.props[A] = c[s] ? a[s].replace(/&\f/g, l[b]) : l[b] + " " + a[s];
365
+ }
366
+ }
367
+ }, $r = function(r) {
368
+ if (r.type === "decl") {
369
+ var n = r.value;
370
+ // charcode for l
371
+ n.charCodeAt(0) === 108 && // charcode for b
372
+ n.charCodeAt(2) === 98 && (r.return = "", r.value = "");
373
+ }
374
+ };
375
+ function je(e, r) {
376
+ switch (Yr(e, r)) {
377
+ case 5103:
378
+ return p + "print-" + e + e;
379
+ case 5737:
380
+ case 4201:
381
+ case 3177:
382
+ case 3433:
383
+ case 1641:
384
+ case 4457:
385
+ case 2921:
386
+ case 5572:
387
+ case 6356:
388
+ case 5844:
389
+ case 3191:
390
+ case 6645:
391
+ case 3005:
392
+ case 6391:
393
+ case 5879:
394
+ case 5623:
395
+ case 6135:
396
+ case 4599:
397
+ case 4855:
398
+ case 4215:
399
+ case 6389:
400
+ case 5109:
401
+ case 5365:
402
+ case 5621:
403
+ case 3829:
404
+ return p + e + e;
405
+ case 5349:
406
+ case 4246:
407
+ case 4810:
408
+ case 6968:
409
+ case 2756:
410
+ return p + e + ae + e + H + e + e;
411
+ case 6828:
412
+ case 4268:
413
+ return p + e + H + e + e;
414
+ case 6165:
415
+ return p + e + H + "flex-" + e + e;
416
+ case 5187:
417
+ return p + e + y(e, /(\w+).+(:[^]+)/, p + "box-$1$2" + H + "flex-$1$2") + e;
418
+ case 5443:
419
+ return p + e + H + "flex-item-" + y(e, /flex-|-self/, "") + e;
420
+ case 4675:
421
+ return p + e + H + "flex-line-pack" + y(e, /align-content|flex-|-self/, "") + e;
422
+ case 5548:
423
+ return p + e + H + y(e, "shrink", "negative") + e;
424
+ case 5292:
425
+ return p + e + H + y(e, "basis", "preferred-size") + e;
426
+ case 6060:
427
+ return p + "box-" + y(e, "-grow", "") + p + e + H + y(e, "grow", "positive") + e;
428
+ case 4554:
429
+ return p + y(e, /([^-])(transform)/g, "$1" + p + "$2") + e;
430
+ case 6187:
431
+ return y(y(y(e, /(zoom-|grab)/, p + "$1"), /(image-set)/, p + "$1"), e, "") + e;
432
+ case 5495:
433
+ case 3959:
434
+ return y(e, /(image-set\([^]*)/, p + "$1$`$1");
435
+ case 4968:
436
+ return y(y(e, /(.+:)(flex-)?(.*)/, p + "box-pack:$3" + H + "flex-pack:$3"), /s.+-b[^;]+/, "justify") + p + e + e;
437
+ case 4095:
438
+ case 3583:
439
+ case 4068:
440
+ case 2532:
441
+ return y(e, /(.+)-inline(.+)/, p + "$1$2") + e;
442
+ case 8116:
443
+ case 7059:
444
+ case 5753:
445
+ case 5535:
446
+ case 5445:
447
+ case 5701:
448
+ case 4933:
449
+ case 4677:
450
+ case 5533:
451
+ case 5789:
452
+ case 5021:
453
+ case 4765:
454
+ if (L(e) - 1 - r > 6) switch (N(e, r + 1)) {
455
+ case 109:
456
+ if (N(e, r + 4) !== 45) break;
457
+ case 102:
458
+ return y(e, /(.+:)(.+)-([^]+)/, "$1" + p + "$2-$3$1" + ae + (N(e, r + 3) == 108 ? "$3" : "$2-$3")) + e;
459
+ case 115:
460
+ return ~ue(e, "stretch") ? je(y(e, "stretch", "fill-available"), r) + e : e;
461
+ }
462
+ break;
463
+ case 4949:
464
+ if (N(e, r + 1) !== 115) break;
465
+ case 6444:
466
+ switch (N(e, L(e) - 3 - (~ue(e, "!important") && 10))) {
467
+ case 107:
468
+ return y(e, ":", ":" + p) + e;
469
+ case 101:
470
+ return y(e, /(.+:)([^;!]+)(;|!.+)?/, "$1" + p + (N(e, 14) === 45 ? "inline-" : "") + "box$3$1" + p + "$2$3$1" + H + "$2box$3") + e;
471
+ }
472
+ break;
473
+ case 5936:
474
+ switch (N(e, r + 11)) {
475
+ case 114:
476
+ return p + e + H + y(e, /[svh]\w+-[tblr]{2}/, "tb") + e;
477
+ case 108:
478
+ return p + e + H + y(e, /[svh]\w+-[tblr]{2}/, "tb-rl") + e;
479
+ case 45:
480
+ return p + e + H + y(e, /[svh]\w+-[tblr]{2}/, "lr") + e;
481
+ }
482
+ return p + e + H + e + e;
483
+ }
484
+ return e;
485
+ }
486
+ var Kr = function(r, n, i, t) {
487
+ if (r.length > -1 && !r.return) switch (r.type) {
488
+ case fe:
489
+ r.return = je(r.value, r.length);
490
+ break;
491
+ case De:
492
+ return E([Q(r, {
493
+ value: y(r.value, "@", "@" + p)
494
+ })], t);
495
+ case Ge:
496
+ if (r.length) return kr(r.props, function(c) {
497
+ switch (Nr(c, /(::plac\w+|:read-\w+)/)) {
498
+ case ":read-only":
499
+ case ":read-write":
500
+ return E([Q(r, {
501
+ props: [y(c, /:(read-\w+)/, ":" + ae + "$1")]
502
+ })], t);
503
+ case "::placeholder":
504
+ return E([Q(r, {
505
+ props: [y(c, /:(plac\w+)/, ":" + p + "input-$1")]
506
+ }), Q(r, {
507
+ props: [y(c, /:(plac\w+)/, ":" + ae + "$1")]
508
+ }), Q(r, {
509
+ props: [y(c, /:(plac\w+)/, H + "input-$1")]
510
+ })], t);
511
+ }
512
+ return "";
513
+ });
514
+ }
515
+ }, qr = [Kr], en = function(r) {
516
+ var n = r.key;
517
+ if (n === "css") {
518
+ var i = document.querySelectorAll("style[data-emotion]:not([data-s])");
519
+ Array.prototype.forEach.call(i, function(u) {
520
+ var d = u.getAttribute("data-emotion");
521
+ d.indexOf(" ") !== -1 && (document.head.appendChild(u), u.setAttribute("data-s", ""));
522
+ });
523
+ }
524
+ var t = r.stylisPlugins || qr, c = {}, a, l = [];
525
+ a = r.container || document.head, Array.prototype.forEach.call(
526
+ // this means we will ignore elements which don't have a space in them which
527
+ // means that the style elements we're looking at are only Emotion 11 server-rendered style elements
528
+ document.querySelectorAll('style[data-emotion^="' + n + ' "]'),
529
+ function(u) {
530
+ for (var d = u.getAttribute("data-emotion").split(" "), m = 1; m < d.length; m++)
531
+ c[d[m]] = !0;
532
+ l.push(u);
533
+ }
534
+ );
535
+ var s, A = [_r, $r];
536
+ {
537
+ var b, C = [jr, Ur(function(u) {
538
+ b.insert(u);
539
+ })], k = Er(A.concat(t, C)), F = function(d) {
540
+ return E(zr(d), k);
541
+ };
542
+ s = function(d, m, V, G) {
543
+ b = V, F(d ? d + "{" + m.styles + "}" : m.styles), G && (X.inserted[m.name] = !0);
544
+ };
545
+ }
546
+ var X = {
547
+ key: n,
548
+ sheet: new Xr({
549
+ key: n,
550
+ container: a,
551
+ nonce: r.nonce,
552
+ speedy: r.speedy,
553
+ prepend: r.prepend,
554
+ insertionPoint: r.insertionPoint
555
+ }),
556
+ nonce: r.nonce,
557
+ inserted: c,
558
+ registered: {},
559
+ insert: s
560
+ };
561
+ return X.sheet.hydrate(l), X;
562
+ };
563
+ function me() {
564
+ return me = Object.assign ? Object.assign.bind() : function(e) {
565
+ for (var r = 1; r < arguments.length; r++) {
566
+ var n = arguments[r];
567
+ for (var i in n) ({}).hasOwnProperty.call(n, i) && (e[i] = n[i]);
568
+ }
569
+ return e;
570
+ }, me.apply(null, arguments);
571
+ }
572
+ var pe = { exports: {} }, S = {};
573
+ /** @license React v16.13.1
574
+ * react-is.production.min.js
575
+ *
576
+ * Copyright (c) Facebook, Inc. and its affiliates.
577
+ *
578
+ * This source code is licensed under the MIT license found in the
579
+ * LICENSE file in the root directory of this source tree.
580
+ */
581
+ var Ve;
582
+ function rn() {
583
+ if (Ve) return S;
584
+ Ve = 1;
585
+ var e = typeof Symbol == "function" && Symbol.for, r = e ? Symbol.for("react.element") : 60103, n = e ? Symbol.for("react.portal") : 60106, i = e ? Symbol.for("react.fragment") : 60107, t = e ? Symbol.for("react.strict_mode") : 60108, c = e ? Symbol.for("react.profiler") : 60114, a = e ? Symbol.for("react.provider") : 60109, l = e ? Symbol.for("react.context") : 60110, s = e ? Symbol.for("react.async_mode") : 60111, A = e ? Symbol.for("react.concurrent_mode") : 60111, b = e ? Symbol.for("react.forward_ref") : 60112, C = e ? Symbol.for("react.suspense") : 60113, k = e ? Symbol.for("react.suspense_list") : 60120, F = e ? Symbol.for("react.memo") : 60115, X = e ? Symbol.for("react.lazy") : 60116, u = e ? Symbol.for("react.block") : 60121, d = e ? Symbol.for("react.fundamental") : 60117, m = e ? Symbol.for("react.responder") : 60118, V = e ? Symbol.for("react.scope") : 60119;
586
+ function G(g) {
587
+ if (typeof g == "object" && g !== null) {
588
+ var R = g.$$typeof;
589
+ switch (R) {
590
+ case r:
591
+ switch (g = g.type, g) {
592
+ case s:
593
+ case A:
594
+ case i:
595
+ case c:
596
+ case t:
597
+ case C:
598
+ return g;
599
+ default:
600
+ switch (g = g && g.$$typeof, g) {
601
+ case l:
602
+ case b:
603
+ case X:
604
+ case F:
605
+ case a:
606
+ return g;
607
+ default:
608
+ return R;
609
+ }
610
+ }
611
+ case n:
612
+ return R;
613
+ }
614
+ }
615
+ }
616
+ function J(g) {
617
+ return G(g) === A;
618
+ }
619
+ return S.AsyncMode = s, S.ConcurrentMode = A, S.ContextConsumer = l, S.ContextProvider = a, S.Element = r, S.ForwardRef = b, S.Fragment = i, S.Lazy = X, S.Memo = F, S.Portal = n, S.Profiler = c, S.StrictMode = t, S.Suspense = C, S.isAsyncMode = function(g) {
620
+ return J(g) || G(g) === s;
621
+ }, S.isConcurrentMode = J, S.isContextConsumer = function(g) {
622
+ return G(g) === l;
623
+ }, S.isContextProvider = function(g) {
624
+ return G(g) === a;
625
+ }, S.isElement = function(g) {
626
+ return typeof g == "object" && g !== null && g.$$typeof === r;
627
+ }, S.isForwardRef = function(g) {
628
+ return G(g) === b;
629
+ }, S.isFragment = function(g) {
630
+ return G(g) === i;
631
+ }, S.isLazy = function(g) {
632
+ return G(g) === X;
633
+ }, S.isMemo = function(g) {
634
+ return G(g) === F;
635
+ }, S.isPortal = function(g) {
636
+ return G(g) === n;
637
+ }, S.isProfiler = function(g) {
638
+ return G(g) === c;
639
+ }, S.isStrictMode = function(g) {
640
+ return G(g) === t;
641
+ }, S.isSuspense = function(g) {
642
+ return G(g) === C;
643
+ }, S.isValidElementType = function(g) {
644
+ return typeof g == "string" || typeof g == "function" || g === i || g === A || g === c || g === t || g === C || g === k || typeof g == "object" && g !== null && (g.$$typeof === X || g.$$typeof === F || g.$$typeof === a || g.$$typeof === l || g.$$typeof === b || g.$$typeof === d || g.$$typeof === m || g.$$typeof === V || g.$$typeof === u);
645
+ }, S.typeOf = G, S;
646
+ }
647
+ var x = {};
648
+ /** @license React v16.13.1
649
+ * react-is.development.js
650
+ *
651
+ * Copyright (c) Facebook, Inc. and its affiliates.
652
+ *
653
+ * This source code is licensed under the MIT license found in the
654
+ * LICENSE file in the root directory of this source tree.
655
+ */
656
+ var Re;
657
+ function nn() {
658
+ return Re || (Re = 1, process.env.NODE_ENV !== "production" && function() {
659
+ var e = typeof Symbol == "function" && Symbol.for, r = e ? Symbol.for("react.element") : 60103, n = e ? Symbol.for("react.portal") : 60106, i = e ? Symbol.for("react.fragment") : 60107, t = e ? Symbol.for("react.strict_mode") : 60108, c = e ? Symbol.for("react.profiler") : 60114, a = e ? Symbol.for("react.provider") : 60109, l = e ? Symbol.for("react.context") : 60110, s = e ? Symbol.for("react.async_mode") : 60111, A = e ? Symbol.for("react.concurrent_mode") : 60111, b = e ? Symbol.for("react.forward_ref") : 60112, C = e ? Symbol.for("react.suspense") : 60113, k = e ? Symbol.for("react.suspense_list") : 60120, F = e ? Symbol.for("react.memo") : 60115, X = e ? Symbol.for("react.lazy") : 60116, u = e ? Symbol.for("react.block") : 60121, d = e ? Symbol.for("react.fundamental") : 60117, m = e ? Symbol.for("react.responder") : 60118, V = e ? Symbol.for("react.scope") : 60119;
660
+ function G(I) {
661
+ return typeof I == "string" || typeof I == "function" || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill.
662
+ I === i || I === A || I === c || I === t || I === C || I === k || typeof I == "object" && I !== null && (I.$$typeof === X || I.$$typeof === F || I.$$typeof === a || I.$$typeof === l || I.$$typeof === b || I.$$typeof === d || I.$$typeof === m || I.$$typeof === V || I.$$typeof === u);
663
+ }
664
+ function J(I) {
665
+ if (typeof I == "object" && I !== null) {
666
+ var be = I.$$typeof;
667
+ switch (be) {
668
+ case r:
669
+ var ne = I.type;
670
+ switch (ne) {
671
+ case s:
672
+ case A:
673
+ case i:
674
+ case c:
675
+ case t:
676
+ case C:
677
+ return ne;
678
+ default:
679
+ var he = ne && ne.$$typeof;
680
+ switch (he) {
681
+ case l:
682
+ case b:
683
+ case X:
684
+ case F:
685
+ case a:
686
+ return he;
687
+ default:
688
+ return be;
689
+ }
690
+ }
691
+ case n:
692
+ return be;
693
+ }
694
+ }
695
+ }
696
+ var g = s, R = A, f = l, re = a, Ae = r, O = b, j = i, nr = X, ir = F, tr = n, cr = c, gr = t, ar = C, Ze = !1;
697
+ function or(I) {
698
+ return Ze || (Ze = !0, console.warn("The ReactIs.isAsyncMode() alias has been deprecated, and will be removed in React 17+. Update your code to use ReactIs.isConcurrentMode() instead. It has the exact same API.")), ve(I) || J(I) === s;
699
+ }
700
+ function ve(I) {
701
+ return J(I) === A;
702
+ }
703
+ function Ir(I) {
704
+ return J(I) === l;
705
+ }
706
+ function lr(I) {
707
+ return J(I) === a;
708
+ }
709
+ function sr(I) {
710
+ return typeof I == "object" && I !== null && I.$$typeof === r;
711
+ }
712
+ function Ar(I) {
713
+ return J(I) === b;
714
+ }
715
+ function br(I) {
716
+ return J(I) === i;
717
+ }
718
+ function Cr(I) {
719
+ return J(I) === X;
720
+ }
721
+ function ur(I) {
722
+ return J(I) === F;
723
+ }
724
+ function dr(I) {
725
+ return J(I) === n;
726
+ }
727
+ function mr(I) {
728
+ return J(I) === c;
729
+ }
730
+ function pr(I) {
731
+ return J(I) === t;
732
+ }
733
+ function yr(I) {
734
+ return J(I) === C;
735
+ }
736
+ x.AsyncMode = g, x.ConcurrentMode = R, x.ContextConsumer = f, x.ContextProvider = re, x.Element = Ae, x.ForwardRef = O, x.Fragment = j, x.Lazy = nr, x.Memo = ir, x.Portal = tr, x.Profiler = cr, x.StrictMode = gr, x.Suspense = ar, x.isAsyncMode = or, x.isConcurrentMode = ve, x.isContextConsumer = Ir, x.isContextProvider = lr, x.isElement = sr, x.isForwardRef = Ar, x.isFragment = br, x.isLazy = Cr, x.isMemo = ur, x.isPortal = dr, x.isProfiler = mr, x.isStrictMode = pr, x.isSuspense = yr, x.isValidElementType = G, x.typeOf = J;
737
+ }()), x;
738
+ }
739
+ process.env.NODE_ENV === "production" ? pe.exports = rn() : pe.exports = nn();
740
+ var tn = pe.exports, Ee = tn, cn = {
741
+ $$typeof: !0,
742
+ render: !0,
743
+ defaultProps: !0,
744
+ displayName: !0,
745
+ propTypes: !0
746
+ }, gn = {
747
+ $$typeof: !0,
748
+ compare: !0,
749
+ defaultProps: !0,
750
+ displayName: !0,
751
+ propTypes: !0,
752
+ type: !0
753
+ }, Ue = {};
754
+ Ue[Ee.ForwardRef] = cn;
755
+ Ue[Ee.Memo] = gn;
756
+ var an = !0;
757
+ function Me(e, r, n) {
758
+ var i = "";
759
+ return n.split(" ").forEach(function(t) {
760
+ e[t] !== void 0 ? r.push(e[t] + ";") : t && (i += t + " ");
761
+ }), i;
762
+ }
763
+ var xe = function(r, n, i) {
764
+ var t = r.key + "-" + n.name;
765
+ // we only need to add the styles to the registered cache if the
766
+ // class name could be used further down
767
+ // the tree but if it's a string tag, we know it won't
768
+ // so we don't have to add it to registered cache.
769
+ // this improves memory usage since we can avoid storing the whole style string
770
+ (i === !1 || // we need to always store it if we're in compat mode and
771
+ // in node since emotion-server relies on whether a style is in
772
+ // the registered cache to know whether a style is global or not
773
+ // also, note that this check will be dead code eliminated in the browser
774
+ an === !1) && r.registered[t] === void 0 && (r.registered[t] = n.styles);
775
+ }, Qe = function(r, n, i) {
776
+ xe(r, n, i);
777
+ var t = r.key + "-" + n.name;
778
+ if (r.inserted[n.name] === void 0) {
779
+ var c = n;
780
+ do
781
+ r.insert(n === c ? "." + t : "", c, r.sheet, !0), c = c.next;
782
+ while (c !== void 0);
783
+ }
784
+ };
785
+ function on(e) {
786
+ for (var r = 0, n, i = 0, t = e.length; t >= 4; ++i, t -= 4)
787
+ n = e.charCodeAt(i) & 255 | (e.charCodeAt(++i) & 255) << 8 | (e.charCodeAt(++i) & 255) << 16 | (e.charCodeAt(++i) & 255) << 24, n = /* Math.imul(k, m): */
788
+ (n & 65535) * 1540483477 + ((n >>> 16) * 59797 << 16), n ^= /* k >>> r: */
789
+ n >>> 24, r = /* Math.imul(k, m): */
790
+ (n & 65535) * 1540483477 + ((n >>> 16) * 59797 << 16) ^ /* Math.imul(h, m): */
791
+ (r & 65535) * 1540483477 + ((r >>> 16) * 59797 << 16);
792
+ switch (t) {
793
+ case 3:
794
+ r ^= (e.charCodeAt(i + 2) & 255) << 16;
795
+ case 2:
796
+ r ^= (e.charCodeAt(i + 1) & 255) << 8;
797
+ case 1:
798
+ r ^= e.charCodeAt(i) & 255, r = /* Math.imul(h, m): */
799
+ (r & 65535) * 1540483477 + ((r >>> 16) * 59797 << 16);
800
+ }
801
+ return r ^= r >>> 13, r = /* Math.imul(h, m): */
802
+ (r & 65535) * 1540483477 + ((r >>> 16) * 59797 << 16), ((r ^ r >>> 15) >>> 0).toString(36);
803
+ }
804
+ var In = {
805
+ animationIterationCount: 1,
806
+ aspectRatio: 1,
807
+ borderImageOutset: 1,
808
+ borderImageSlice: 1,
809
+ borderImageWidth: 1,
810
+ boxFlex: 1,
811
+ boxFlexGroup: 1,
812
+ boxOrdinalGroup: 1,
813
+ columnCount: 1,
814
+ columns: 1,
815
+ flex: 1,
816
+ flexGrow: 1,
817
+ flexPositive: 1,
818
+ flexShrink: 1,
819
+ flexNegative: 1,
820
+ flexOrder: 1,
821
+ gridRow: 1,
822
+ gridRowEnd: 1,
823
+ gridRowSpan: 1,
824
+ gridRowStart: 1,
825
+ gridColumn: 1,
826
+ gridColumnEnd: 1,
827
+ gridColumnSpan: 1,
828
+ gridColumnStart: 1,
829
+ msGridRow: 1,
830
+ msGridRowSpan: 1,
831
+ msGridColumn: 1,
832
+ msGridColumnSpan: 1,
833
+ fontWeight: 1,
834
+ lineHeight: 1,
835
+ opacity: 1,
836
+ order: 1,
837
+ orphans: 1,
838
+ scale: 1,
839
+ tabSize: 1,
840
+ widows: 1,
841
+ zIndex: 1,
842
+ zoom: 1,
843
+ WebkitLineClamp: 1,
844
+ // SVG-related properties
845
+ fillOpacity: 1,
846
+ floodOpacity: 1,
847
+ stopOpacity: 1,
848
+ strokeDasharray: 1,
849
+ strokeDashoffset: 1,
850
+ strokeMiterlimit: 1,
851
+ strokeOpacity: 1,
852
+ strokeWidth: 1
853
+ }, ln = /[A-Z]|^ms/g, sn = /_EMO_([^_]+?)_([^]*?)_EMO_/g, Pe = function(r) {
854
+ return r.charCodeAt(1) === 45;
855
+ }, Fe = function(r) {
856
+ return r != null && typeof r != "boolean";
857
+ }, Ce = /* @__PURE__ */ Oe(function(e) {
858
+ return Pe(e) ? e : e.replace(ln, "-$&").toLowerCase();
859
+ }), Ye = function(r, n) {
860
+ switch (r) {
861
+ case "animation":
862
+ case "animationName":
863
+ if (typeof n == "string")
864
+ return n.replace(sn, function(i, t, c) {
865
+ return T = {
866
+ name: t,
867
+ styles: c,
868
+ next: T
869
+ }, t;
870
+ });
871
+ }
872
+ return In[r] !== 1 && !Pe(r) && typeof n == "number" && n !== 0 ? n + "px" : n;
873
+ };
874
+ function K(e, r, n) {
875
+ if (n == null)
876
+ return "";
877
+ var i = n;
878
+ if (i.__emotion_styles !== void 0)
879
+ return i;
880
+ switch (typeof n) {
881
+ case "boolean":
882
+ return "";
883
+ case "object": {
884
+ var t = n;
885
+ if (t.anim === 1)
886
+ return T = {
887
+ name: t.name,
888
+ styles: t.styles,
889
+ next: T
890
+ }, t.name;
891
+ var c = n;
892
+ if (c.styles !== void 0) {
893
+ var a = c.next;
894
+ if (a !== void 0)
895
+ for (; a !== void 0; )
896
+ T = {
897
+ name: a.name,
898
+ styles: a.styles,
899
+ next: T
900
+ }, a = a.next;
901
+ var l = c.styles + ";";
902
+ return l;
903
+ }
904
+ return An(e, r, n);
905
+ }
906
+ case "function": {
907
+ if (e !== void 0) {
908
+ var s = T, A = n(e);
909
+ return T = s, K(e, r, A);
910
+ }
911
+ break;
912
+ }
913
+ }
914
+ var b = n;
915
+ if (r == null)
916
+ return b;
917
+ var C = r[b];
918
+ return C !== void 0 ? C : b;
919
+ }
920
+ function An(e, r, n) {
921
+ var i = "";
922
+ if (Array.isArray(n))
923
+ for (var t = 0; t < n.length; t++)
924
+ i += K(e, r, n[t]) + ";";
925
+ else
926
+ for (var c in n) {
927
+ var a = n[c];
928
+ if (typeof a != "object") {
929
+ var l = a;
930
+ r != null && r[l] !== void 0 ? i += c + "{" + r[l] + "}" : Fe(l) && (i += Ce(c) + ":" + Ye(c, l) + ";");
931
+ } else if (Array.isArray(a) && typeof a[0] == "string" && (r == null || r[a[0]] === void 0))
932
+ for (var s = 0; s < a.length; s++)
933
+ Fe(a[s]) && (i += Ce(c) + ":" + Ye(c, a[s]) + ";");
934
+ else {
935
+ var A = K(e, r, a);
936
+ switch (c) {
937
+ case "animation":
938
+ case "animationName": {
939
+ i += Ce(c) + ":" + A + ";";
940
+ break;
941
+ }
942
+ default:
943
+ i += c + "{" + A + "}";
944
+ }
945
+ }
946
+ }
947
+ return i;
948
+ }
949
+ var Ne = /label:\s*([^\s;{]+)\s*(;|$)/g, T;
950
+ function _e(e, r, n) {
951
+ if (e.length === 1 && typeof e[0] == "object" && e[0] !== null && e[0].styles !== void 0)
952
+ return e[0];
953
+ var i = !0, t = "";
954
+ T = void 0;
955
+ var c = e[0];
956
+ if (c == null || c.raw === void 0)
957
+ i = !1, t += K(n, r, c);
958
+ else {
959
+ var a = c;
960
+ t += a[0];
961
+ }
962
+ for (var l = 1; l < e.length; l++)
963
+ if (t += K(n, r, e[l]), i) {
964
+ var s = c;
965
+ t += s[l];
966
+ }
967
+ Ne.lastIndex = 0;
968
+ for (var A = "", b; (b = Ne.exec(t)) !== null; )
969
+ A += "-" + b[1];
970
+ var C = on(t) + A;
971
+ return {
972
+ name: C,
973
+ styles: t,
974
+ next: T
975
+ };
976
+ }
977
+ var bn = function(r) {
978
+ return r();
979
+ }, Cn = B.useInsertionEffect ? B.useInsertionEffect : !1, $e = Cn || bn, Ke = /* @__PURE__ */ B.createContext(
980
+ // we're doing this to avoid preconstruct's dead code elimination in this one case
981
+ // because this module is primarily intended for the browser and node
982
+ // but it's also required in react native and similar environments sometimes
983
+ // and we could have a special build just for that
984
+ // but this is much easier and the native packages
985
+ // might use a different theme context in the future anyway
986
+ typeof HTMLElement < "u" ? /* @__PURE__ */ en({
987
+ key: "css"
988
+ }) : null
989
+ );
990
+ Ke.Provider;
991
+ var un = function(r) {
992
+ return /* @__PURE__ */ Gr(function(n, i) {
993
+ var t = fr(Ke);
994
+ return r(n, t, i);
995
+ });
996
+ }, dn = /* @__PURE__ */ B.createContext({}), se = {}.hasOwnProperty, ye = "__EMOTION_TYPE_PLEASE_DO_NOT_USE__", qe = function(r, n) {
997
+ var i = {};
998
+ for (var t in n)
999
+ se.call(n, t) && (i[t] = n[t]);
1000
+ return i[ye] = r, i;
1001
+ }, mn = function(r) {
1002
+ var n = r.cache, i = r.serialized, t = r.isStringTag;
1003
+ return xe(n, i, t), $e(function() {
1004
+ return Qe(n, i, t);
1005
+ }), null;
1006
+ }, pn = /* @__PURE__ */ un(function(e, r, n) {
1007
+ var i = e.css;
1008
+ typeof i == "string" && r.registered[i] !== void 0 && (i = r.registered[i]);
1009
+ var t = e[ye], c = [i], a = "";
1010
+ typeof e.className == "string" ? a = Me(r.registered, c, e.className) : e.className != null && (a = e.className + " ");
1011
+ var l = _e(c, void 0, B.useContext(dn));
1012
+ a += r.key + "-" + l.name;
1013
+ var s = {};
1014
+ for (var A in e)
1015
+ se.call(e, A) && A !== "css" && A !== ye && (s[A] = e[A]);
1016
+ return s.className = a, n && (s.ref = n), /* @__PURE__ */ B.createElement(B.Fragment, null, /* @__PURE__ */ B.createElement(mn, {
1017
+ cache: r,
1018
+ serialized: l,
1019
+ isStringTag: typeof t == "string"
1020
+ }), /* @__PURE__ */ B.createElement(t, s));
1021
+ }), er = pn, yn = P.Fragment, q = function(r, n, i) {
1022
+ return se.call(n, "css") ? P.jsx(er, qe(r, n), i) : P.jsx(r, n, i);
1023
+ }, Gn = function(r, n, i) {
1024
+ return se.call(n, "css") ? P.jsxs(er, qe(r, n), i) : P.jsxs(r, n, i);
1025
+ };
1026
+ const Z = {
1027
+ /** Primary brand font for all headings, body, and label text */
1028
+ sans: '"Headspace Apercu", "Apercu", system-ui, sans-serif',
1029
+ /** Monospace font for utility/code contexts */
1030
+ mono: '"Apercu Mono", "Apercu", ui-monospace, monospace'
1031
+ }, v = {
1032
+ regular: 400,
1033
+ medium: 500,
1034
+ bold: 700
1035
+ }, h = {
1036
+ /** 1.0 — used for the largest display headings */
1037
+ display: "1",
1038
+ /** 1.1 — large headings */
1039
+ heading: "1.1",
1040
+ /** 1.2 — standard heading and label line height */
1041
+ tight: "1.2",
1042
+ /** 1.5 — body text, links, and utility */
1043
+ body: "1.5"
1044
+ }, W = {
1045
+ heading: "-3px",
1046
+ label: "-3px",
1047
+ caption: "-3px",
1048
+ body: "0px",
1049
+ link: "0px",
1050
+ utility: "4px"
1051
+ }, fn = {
1052
+ 2: "2px",
1053
+ 4: "4px",
1054
+ 8: "8px",
1055
+ 12: "12px",
1056
+ 16: "16px",
1057
+ 24: "24px",
1058
+ 32: "32px",
1059
+ 40: "40px",
1060
+ 48: "48px",
1061
+ 56: "56px",
1062
+ 64: "64px",
1063
+ 72: "72px",
1064
+ 80: "80px",
1065
+ 96: "96px",
1066
+ 120: "120px",
1067
+ 128: "128px"
1068
+ }, Sn = {
1069
+ /** 0px — hs-border-radius-sharp */
1070
+ sharp: "0px",
1071
+ /** 4px — hs-border-radius-small2X */
1072
+ small2X: "4px",
1073
+ /** 8px — hs-border-radius-smallX */
1074
+ smallX: "8px",
1075
+ /** 12px — hs-border-radius-small */
1076
+ small: "12px",
1077
+ /** 16px — hs-border-radius-medium */
1078
+ medium: "16px",
1079
+ /** 24px — hs-border-radius-large */
1080
+ large: "24px",
1081
+ /** 32px — hs-border-radius-largeX */
1082
+ largeX: "32px",
1083
+ /** 999px — hs-border-radius-pill */
1084
+ pill: "999px",
1085
+ /** 50% — hs-border-radius-circle */
1086
+ circle: "50%"
1087
+ }, xn = {
1088
+ /** 0px — hs-border-width-none */
1089
+ none: "0px",
1090
+ /** 1px — hs-border-width-smallX */
1091
+ smallX: "1px",
1092
+ /** 2px — hs-border-width-small */
1093
+ small: "2px",
1094
+ /** 4px — hs-border-width-medium */
1095
+ medium: "4px"
1096
+ }, Zn = {
1097
+ /** No shadow — flat surface */
1098
+ none: "none",
1099
+ /**
1100
+ * default — subtle bottom shadow
1101
+ * DROP_SHADOW: offset (0, 2), blur 0, color rgba(20,19,19,0.2)
1102
+ */
1103
+ default: "0px 2px 0px 0px rgba(20, 19, 19, 0.20)",
1104
+ /**
1105
+ * navigationTop — top navigation bar shadow (casts downward)
1106
+ * DROP_SHADOW: offset (0, 2), blur 4, color rgba(20,19,19,0.08)
1107
+ */
1108
+ navigationTop: "0px 2px 4px 0px rgba(20, 19, 19, 0.08)",
1109
+ /**
1110
+ * navigationBottom — bottom navigation bar shadow (casts upward)
1111
+ * DROP_SHADOW: offset (0, -2), blur 4, color rgba(20,19,19,0.08)
1112
+ */
1113
+ navigationBottom: "0px -2px 4px 0px rgba(20, 19, 19, 0.08)",
1114
+ /**
1115
+ * raised — cards, popovers, and floating elements
1116
+ * DROP_SHADOW: offset (0, 2), blur 4, color rgba(20,19,19,0.2)
1117
+ */
1118
+ raised: "0px 2px 4px 0px rgba(20, 19, 19, 0.20)",
1119
+ /**
1120
+ * overlay — modals, drawers, and full-screen overlays
1121
+ * DROP_SHADOW: offset (0, 0), blur 12, color rgba(20,19,19,0.2)
1122
+ */
1123
+ overlay: "0px 0px 12px 0px rgba(20, 19, 19, 0.20)"
1124
+ }, o = {
1125
+ // ─── White ────────────────────────────────────────────────────────────────
1126
+ white: "#ffffff",
1127
+ // ─── Warm Grey (primary neutral — warm-tinted) ───────────────────────────
1128
+ warmGrey100: "#f9f4f2",
1129
+ warmGrey200: "#e2ded9",
1130
+ warmGrey300: "#c6c1b9",
1131
+ warmGrey400: "#a8a5a0",
1132
+ warmGrey500: "#63605d",
1133
+ warmGrey600: "#44423f",
1134
+ warmGrey700: "#2d2c2b",
1135
+ warmGrey800: "#141313",
1136
+ // ─── Cool Grey (used for dark/contrast surfaces) ──────────────────────────
1137
+ coolGrey100: "#e5e7ec",
1138
+ coolGrey300: "#9da5b8",
1139
+ coolGrey400: "#7580a3",
1140
+ coolGrey500: "#545f82",
1141
+ coolGrey600: "#2a2d55",
1142
+ coolGrey800: "#050726",
1143
+ blue200: "#0061ef",
1144
+ blue300: "#0040ea",
1145
+ blue400: "#0000db",
1146
+ orange200: "#ff7300",
1147
+ orange300: "#fc5500",
1148
+ yellow300: "#ffb700",
1149
+ yellow400: "#ff9900",
1150
+ green300: "#02873e",
1151
+ green400: "#0b662a",
1152
+ red300: "#e01919",
1153
+ red400: "#bf0000"
1154
+ }, vn = {
1155
+ // ─── Primary ──────────────────────────────────────────────────────────────
1156
+ // Figma: Primary/primary, Primary/primaryStrong
1157
+ primary: {
1158
+ /** Blue/200 — the main brand action color */
1159
+ primary: o.blue200,
1160
+ /** Blue/300 — darker variant for hover/pressed states */
1161
+ primaryStrong: o.blue300
1162
+ },
1163
+ // ─── Background ───────────────────────────────────────────────────────────
1164
+ // Figma: Background/background, Background/backgroundStrong
1165
+ background: {
1166
+ /** White — main page background */
1167
+ background: o.white,
1168
+ /** Warm Grey 100 — slightly off-white for grouped content areas */
1169
+ backgroundStrong: o.warmGrey100
1170
+ },
1171
+ // ─── Surface ──────────────────────────────────────────────────────────────
1172
+ // Figma: Surface/surface*
1173
+ surface: {
1174
+ /** White — default card/panel surface */
1175
+ surface: o.white,
1176
+ /** Warm Grey 100 — slightly elevated surface */
1177
+ surfaceStrong: o.warmGrey100,
1178
+ /** Warm Grey 200 — more prominent surface (dividers, table rows) */
1179
+ surfaceStronger: o.warmGrey200,
1180
+ /** Warm Grey 300 — highest emphasis surface */
1181
+ surfaceStrongest: o.warmGrey300,
1182
+ /** White — surface that never changes between modes */
1183
+ surfaceStatic: o.white,
1184
+ /** White — modal dialog background (light mode) */
1185
+ surfaceModal: o.white,
1186
+ /** Cool Grey 600 — content that sits on top of a modal overlay */
1187
+ surfaceOnModal: o.coolGrey600
1188
+ },
1189
+ // ─── Overlay ──────────────────────────────────────────────────────────────
1190
+ // Figma: Overlay/*
1191
+ // Expressed as rgba() strings; alpha values are approximate from hex codes.
1192
+ overlay: {
1193
+ /** rgba(20,19,19,0.60) — modal scrim */
1194
+ overlay60: "rgba(20, 19, 19, 0.60)",
1195
+ /** rgba(20,19,19,0.40) — lighter scrim */
1196
+ overlay40: "rgba(20, 19, 19, 0.40)",
1197
+ /** rgba(20,19,19,0.20) — subtle tint */
1198
+ overlay20: "rgba(20, 19, 19, 0.20)",
1199
+ /** rgba(255,255,255,0.60) — inverse (dark bg) scrim */
1200
+ overlayInverse60: "rgba(255, 255, 255, 0.60)",
1201
+ /** rgba(255,255,255,0.80) — light static overlay */
1202
+ overlayLightStatic80: "rgba(255, 255, 255, 0.80)",
1203
+ overlayLightStatic60: "rgba(255, 255, 255, 0.60)",
1204
+ overlayLightStatic40: "rgba(255, 255, 255, 0.40)",
1205
+ overlayLightStatic20: "rgba(255, 255, 255, 0.20)",
1206
+ /** rgba(20,19,19,0.80) — dark static overlay */
1207
+ overlayDarkStatic80: "rgba(20, 19, 19, 0.80)",
1208
+ overlayDarkStatic60: "rgba(20, 19, 19, 0.60)",
1209
+ overlayDarkStatic40: "rgba(20, 19, 19, 0.40)",
1210
+ overlayDarkStatic20: "rgba(20, 19, 19, 0.20)"
1211
+ },
1212
+ // ─── Foreground (text & icons) ────────────────────────────────────────────
1213
+ // Figma: Foreground/*
1214
+ foreground: {
1215
+ /** Warm Grey 700 — primary text color */
1216
+ foreground: o.warmGrey700,
1217
+ /** Warm Grey 600 — secondary/supporting text */
1218
+ foregroundWeak: o.warmGrey600,
1219
+ /** Warm Grey 500 — tertiary/placeholder text */
1220
+ foregroundWeaker: o.warmGrey500,
1221
+ /** Warm Grey 400 — disabled text */
1222
+ foregroundWeakest: o.warmGrey400,
1223
+ /** White — text on dark/colored surfaces */
1224
+ foregroundInverse: o.white,
1225
+ /** White — inverse text that never changes between modes */
1226
+ foregroundInverseStatic: o.white,
1227
+ /** Warm Grey 700 — text that never changes between modes */
1228
+ foregroundStatic: o.warmGrey700,
1229
+ /** Warm Grey 600 — weak static text */
1230
+ foregroundStaticWeak: o.warmGrey600,
1231
+ /** Blue/200 — hyperlink text */
1232
+ foregroundLink: o.blue200,
1233
+ /** Blue/300 — pressed/active hyperlink */
1234
+ foregroundLinkStrong: o.blue300,
1235
+ /** Orange/200 — highlight/accent text (e.g. marketing callouts) */
1236
+ foregroundHighlight: o.orange200,
1237
+ /** Red/300 — destructive actions and error messages */
1238
+ foregroundCritical: o.red300,
1239
+ /** Green/300 — success messages */
1240
+ foregroundSuccess: o.green300
1241
+ },
1242
+ // ─── Border ───────────────────────────────────────────────────────────────
1243
+ // Figma: Border/*
1244
+ border: {
1245
+ /** Warm Grey 200 — default subtle border */
1246
+ border: o.warmGrey200,
1247
+ /** Warm Grey 300 — more visible border */
1248
+ borderStrong: o.warmGrey300,
1249
+ /** Warm Grey 500 — prominent border (focus-adjacent, selected states) */
1250
+ borderStronger: o.warmGrey500,
1251
+ /** Warm Grey 700 — maximum contrast border */
1252
+ borderStrongest: o.warmGrey700,
1253
+ /** White — border on dark surfaces */
1254
+ borderInverse: o.white,
1255
+ /** White — border on dark surfaces, mode-invariant */
1256
+ borderInverseStatic: o.white
1257
+ },
1258
+ // ─── Interactive ──────────────────────────────────────────────────────────
1259
+ // Figma: Interactive/*
1260
+ // These tokens represent the interactive surface colors (button bg, etc.)
1261
+ interactive: {
1262
+ /** White — default interactive surface (e.g. secondary button bg) */
1263
+ interactive: o.white,
1264
+ /** Warm Grey 100 — hovered interactive surface */
1265
+ interactiveStrong: o.warmGrey100,
1266
+ /** Warm Grey 200 — pressed interactive surface */
1267
+ interactiveStronger: o.warmGrey200,
1268
+ /** Warm Grey 300 — strongly active/selected surface */
1269
+ interactiveStrongest: o.warmGrey300,
1270
+ /** White — static interactive surface (mode-invariant) */
1271
+ interactiveStatic: o.white,
1272
+ /** Warm Grey 200 — static hovered interactive surface */
1273
+ interactiveStaticStrong: o.warmGrey200,
1274
+ /** Warm Grey 700 — interactive surface on dark bg */
1275
+ interactiveInverse: o.warmGrey700,
1276
+ /** Warm Grey 800 — hovered interactive on dark bg */
1277
+ interactiveInverseStrong: o.warmGrey800,
1278
+ /** Warm Grey 700 — static inverse interactive */
1279
+ interactiveInverseStatic: o.warmGrey700,
1280
+ /** Warm Grey 800 — static inverse interactive strong */
1281
+ interactiveInverseStaticStrong: o.warmGrey800
1282
+ },
1283
+ // ─── Contrast ─────────────────────────────────────────────────────────────
1284
+ // Figma: Contrast/*
1285
+ // High-contrast foreground/background pairs (used for "midnight" surfaces)
1286
+ contrast: {
1287
+ /** Cool Grey 100 — foreground on dark midnight surface */
1288
+ contrastForeground: o.coolGrey100,
1289
+ /** Cool Grey 800 — dark midnight background */
1290
+ contrastBackground: o.coolGrey800,
1291
+ /** Cool Grey 300 — weaker foreground on midnight surface */
1292
+ contrastForegroundWeak: o.coolGrey300,
1293
+ /** Cool Grey 400 */
1294
+ contrastForegroundWeaker: o.coolGrey400,
1295
+ /** Cool Grey 500 */
1296
+ contrastForegroundWeakest: o.coolGrey500,
1297
+ /** Cool Grey 600 — weak midnight background */
1298
+ contrastBackgroundWeak: o.coolGrey600,
1299
+ /** Cool Grey 500 */
1300
+ contrastBackgroundWeaker: o.coolGrey500
1301
+ },
1302
+ // ─── Status ───────────────────────────────────────────────────────────────
1303
+ // Figma: Status/*
1304
+ status: {
1305
+ /** Red/300 — critical/error state */
1306
+ statusCritical: o.red300,
1307
+ /** Red/400 — stronger critical */
1308
+ statusCriticalStrong: o.red400,
1309
+ /** Green/300 — success state */
1310
+ statusSuccess: o.green300,
1311
+ /** Green/400 — stronger success */
1312
+ statusSuccessStrong: o.green400,
1313
+ /** Yellow/300 — warning state */
1314
+ statusWarning: o.yellow300,
1315
+ /** Yellow/400 — stronger warning */
1316
+ statusWarningStrong: o.yellow400,
1317
+ /** Blue/300 — informational state */
1318
+ statusInfo: o.blue300,
1319
+ /** Blue/400 — stronger info */
1320
+ statusInfoStrong: o.blue400,
1321
+ /** Orange/200 — highlight/promotional state */
1322
+ statusHighlight: o.orange200,
1323
+ /** Orange/300 — stronger highlight */
1324
+ statusHighlightStrong: o.orange300
1325
+ }
1326
+ }, hn = {
1327
+ heading: {
1328
+ /** Heading 3XL — 64px Bold, lh 1.0, ls -3px */
1329
+ "3xl": {
1330
+ fontFamily: Z.sans,
1331
+ fontSize: "64px",
1332
+ fontWeight: v.bold,
1333
+ lineHeight: h.display,
1334
+ letterSpacing: W.heading
1335
+ },
1336
+ /** Heading 2XL — 56px Bold, lh 1.1, ls -3px */
1337
+ "2xl": {
1338
+ fontFamily: Z.sans,
1339
+ fontSize: "56px",
1340
+ fontWeight: v.bold,
1341
+ lineHeight: h.heading,
1342
+ letterSpacing: W.heading
1343
+ },
1344
+ /** Heading XL — 48px Bold, lh 1.1, ls -3px */
1345
+ xl: {
1346
+ fontFamily: Z.sans,
1347
+ fontSize: "48px",
1348
+ fontWeight: v.bold,
1349
+ lineHeight: h.heading,
1350
+ letterSpacing: W.heading
1351
+ },
1352
+ /** Heading L — 40px Bold, lh 1.2, ls -3px */
1353
+ l: {
1354
+ fontFamily: Z.sans,
1355
+ fontSize: "40px",
1356
+ fontWeight: v.bold,
1357
+ lineHeight: h.tight,
1358
+ letterSpacing: W.heading
1359
+ },
1360
+ /** Heading M — 32px Bold, lh 1.2, ls -3px */
1361
+ m: {
1362
+ fontFamily: Z.sans,
1363
+ fontSize: "32px",
1364
+ fontWeight: v.bold,
1365
+ lineHeight: h.tight,
1366
+ letterSpacing: W.heading
1367
+ },
1368
+ /** Heading S — 24px Bold, lh 1.2, ls -3px */
1369
+ s: {
1370
+ fontFamily: Z.sans,
1371
+ fontSize: "24px",
1372
+ fontWeight: v.bold,
1373
+ lineHeight: h.tight,
1374
+ letterSpacing: W.heading
1375
+ }
1376
+ },
1377
+ body: {
1378
+ /** Body L — 20px Regular, lh 1.5, ls 0 */
1379
+ l: {
1380
+ fontFamily: Z.sans,
1381
+ fontSize: "20px",
1382
+ fontWeight: v.regular,
1383
+ lineHeight: h.body,
1384
+ letterSpacing: W.body
1385
+ },
1386
+ /** Body M — 18px Regular, lh 1.5, ls 0 */
1387
+ m: {
1388
+ fontFamily: Z.sans,
1389
+ fontSize: "18px",
1390
+ fontWeight: v.regular,
1391
+ lineHeight: h.body,
1392
+ letterSpacing: W.body
1393
+ },
1394
+ /** Body S — 16px Regular, lh 1.5, ls 0 */
1395
+ s: {
1396
+ fontFamily: Z.sans,
1397
+ fontSize: "16px",
1398
+ fontWeight: v.regular,
1399
+ lineHeight: h.body,
1400
+ letterSpacing: W.body
1401
+ },
1402
+ /** Body XS — 14px Regular, lh 1.5, ls 0 */
1403
+ xs: {
1404
+ fontFamily: Z.sans,
1405
+ fontSize: "14px",
1406
+ fontWeight: v.regular,
1407
+ lineHeight: h.body,
1408
+ letterSpacing: W.body
1409
+ },
1410
+ /** Body 2XS — 12px Regular, lh 1.5, ls 0 */
1411
+ "2xs": {
1412
+ fontFamily: Z.sans,
1413
+ fontSize: "12px",
1414
+ fontWeight: v.regular,
1415
+ lineHeight: h.body,
1416
+ letterSpacing: W.body
1417
+ },
1418
+ /** Body 3XS — 10px Regular, lh 1.5, ls 0 */
1419
+ "3xs": {
1420
+ fontFamily: Z.sans,
1421
+ fontSize: "10px",
1422
+ fontWeight: v.regular,
1423
+ lineHeight: h.body,
1424
+ letterSpacing: W.body
1425
+ }
1426
+ },
1427
+ label: {
1428
+ /** Label L — 20px Bold, lh 1.2, ls -3px */
1429
+ l: {
1430
+ fontFamily: Z.sans,
1431
+ fontSize: "20px",
1432
+ fontWeight: v.bold,
1433
+ lineHeight: h.tight,
1434
+ letterSpacing: W.label
1435
+ },
1436
+ /** Label M — 18px Bold, lh 1.2, ls -3px */
1437
+ m: {
1438
+ fontFamily: Z.sans,
1439
+ fontSize: "18px",
1440
+ fontWeight: v.bold,
1441
+ lineHeight: h.tight,
1442
+ letterSpacing: W.label
1443
+ },
1444
+ /** Label S — 16px Bold, lh 1.2, ls -3px */
1445
+ s: {
1446
+ fontFamily: Z.sans,
1447
+ fontSize: "16px",
1448
+ fontWeight: v.bold,
1449
+ lineHeight: h.tight,
1450
+ letterSpacing: W.label
1451
+ },
1452
+ /** Label XS — 14px Bold, lh 1.2, ls -3px */
1453
+ xs: {
1454
+ fontFamily: Z.sans,
1455
+ fontSize: "14px",
1456
+ fontWeight: v.bold,
1457
+ lineHeight: h.tight,
1458
+ letterSpacing: W.label
1459
+ },
1460
+ /** Label 2XS — 12px Bold, lh 1.2, ls -3px */
1461
+ "2xs": {
1462
+ fontFamily: Z.sans,
1463
+ fontSize: "12px",
1464
+ fontWeight: v.bold,
1465
+ lineHeight: h.tight,
1466
+ letterSpacing: W.label
1467
+ },
1468
+ /** Label 3XS — 10px Bold, lh 1.2, ls -3px */
1469
+ "3xs": {
1470
+ fontFamily: Z.sans,
1471
+ fontSize: "10px",
1472
+ fontWeight: v.bold,
1473
+ lineHeight: h.tight,
1474
+ letterSpacing: W.label
1475
+ }
1476
+ },
1477
+ link: {
1478
+ /** Link L — 20px Regular, lh 1.5, ls 0 */
1479
+ l: {
1480
+ fontFamily: Z.sans,
1481
+ fontSize: "20px",
1482
+ fontWeight: v.regular,
1483
+ lineHeight: h.body,
1484
+ letterSpacing: W.link
1485
+ },
1486
+ /** Link M — 18px Regular, lh 1.5, ls 0 */
1487
+ m: {
1488
+ fontFamily: Z.sans,
1489
+ fontSize: "18px",
1490
+ fontWeight: v.regular,
1491
+ lineHeight: h.body,
1492
+ letterSpacing: W.link
1493
+ },
1494
+ /** Link S — 16px Regular, lh 1.5, ls 0 */
1495
+ s: {
1496
+ fontFamily: Z.sans,
1497
+ fontSize: "16px",
1498
+ fontWeight: v.regular,
1499
+ lineHeight: h.body,
1500
+ letterSpacing: W.link
1501
+ },
1502
+ /** Link XS — 14px Regular, lh 1.5, ls 0 */
1503
+ xs: {
1504
+ fontFamily: Z.sans,
1505
+ fontSize: "14px",
1506
+ fontWeight: v.regular,
1507
+ lineHeight: h.body,
1508
+ letterSpacing: W.link
1509
+ },
1510
+ /** Link 2XS — 12px Regular, lh 1.5, ls 0 */
1511
+ "2xs": {
1512
+ fontFamily: Z.sans,
1513
+ fontSize: "12px",
1514
+ fontWeight: v.regular,
1515
+ lineHeight: h.body,
1516
+ letterSpacing: W.link
1517
+ },
1518
+ /** Link 3XS — 10px Regular, lh 1.5, ls 0 */
1519
+ "3xs": {
1520
+ fontFamily: Z.sans,
1521
+ fontSize: "10px",
1522
+ fontWeight: v.regular,
1523
+ lineHeight: h.body,
1524
+ letterSpacing: W.link
1525
+ }
1526
+ },
1527
+ utility: {
1528
+ /** Utility L — 14px Mono, lh 1.5, ls 4px */
1529
+ l: {
1530
+ fontFamily: Z.mono,
1531
+ fontSize: "14px",
1532
+ fontWeight: v.regular,
1533
+ lineHeight: h.body,
1534
+ letterSpacing: W.utility
1535
+ },
1536
+ /** Utility M — 12px Mono, lh 1.5, ls 4px */
1537
+ m: {
1538
+ fontFamily: Z.mono,
1539
+ fontSize: "12px",
1540
+ fontWeight: v.regular,
1541
+ lineHeight: h.body,
1542
+ letterSpacing: W.utility
1543
+ },
1544
+ /** Utility S — 10px Mono, lh 1.5, ls 4px */
1545
+ s: {
1546
+ fontFamily: Z.mono,
1547
+ fontSize: "10px",
1548
+ fontWeight: v.regular,
1549
+ lineHeight: h.body,
1550
+ letterSpacing: W.utility
1551
+ },
1552
+ /** Utility XS — 8px Mono, lh 1.5, ls 4px */
1553
+ xs: {
1554
+ fontFamily: Z.mono,
1555
+ fontSize: "8px",
1556
+ fontWeight: v.regular,
1557
+ lineHeight: h.body,
1558
+ letterSpacing: W.utility
1559
+ }
1560
+ },
1561
+ /** Caption — 20px Medium, lh 1.2, ls -3px */
1562
+ caption: {
1563
+ fontFamily: Z.sans,
1564
+ fontSize: "20px",
1565
+ fontWeight: v.medium,
1566
+ lineHeight: h.tight,
1567
+ letterSpacing: W.caption
1568
+ }
1569
+ }, Wn = {
1570
+ colors: vn,
1571
+ typography: {
1572
+ fontFamily: Z,
1573
+ desktop: hn
1574
+ },
1575
+ spacing: fn,
1576
+ borders: {
1577
+ radius: Sn,
1578
+ width: xn
1579
+ },
1580
+ shadows: Zn
1581
+ };
1582
+ function On({
1583
+ theme: e = Wn,
1584
+ children: r
1585
+ }) {
1586
+ return /* @__PURE__ */ q(Sr, { theme: e, children: r });
1587
+ }
1588
+ var Xn = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|abbr|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|disableRemotePlayback|download|draggable|encType|enterKeyHint|fetchpriority|fetchPriority|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|popover|popoverTarget|popoverTargetAction|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|translate|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|incremental|fallback|inert|itemProp|itemScope|itemType|itemID|itemRef|on|option|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/, Jn = /* @__PURE__ */ Oe(
1589
+ function(e) {
1590
+ return Xn.test(e) || e.charCodeAt(0) === 111 && e.charCodeAt(1) === 110 && e.charCodeAt(2) < 91;
1591
+ }
1592
+ /* Z+1 */
1593
+ ), Vn = Jn, Rn = function(r) {
1594
+ return r !== "theme";
1595
+ }, ke = function(r) {
1596
+ return typeof r == "string" && // 96 is one less than the char code
1597
+ // for "a" so this is checking that
1598
+ // it's a lowercase character
1599
+ r.charCodeAt(0) > 96 ? Vn : Rn;
1600
+ }, He = function(r, n, i) {
1601
+ var t;
1602
+ if (n) {
1603
+ var c = n.shouldForwardProp;
1604
+ t = r.__emotion_forwardProp && c ? function(a) {
1605
+ return r.__emotion_forwardProp(a) && c(a);
1606
+ } : c;
1607
+ }
1608
+ return typeof t != "function" && i && (t = r.__emotion_forwardProp), t;
1609
+ }, Fn = function(r) {
1610
+ var n = r.cache, i = r.serialized, t = r.isStringTag;
1611
+ return xe(n, i, t), $e(function() {
1612
+ return Qe(n, i, t);
1613
+ }), null;
1614
+ }, rr = function e(r, n) {
1615
+ var i = r.__emotion_real === r, t = i && r.__emotion_base || r, c, a;
1616
+ n !== void 0 && (c = n.label, a = n.target);
1617
+ var l = He(r, n, i), s = l || ke(t), A = !s("as");
1618
+ return function() {
1619
+ var b = arguments, C = i && r.__emotion_styles !== void 0 ? r.__emotion_styles.slice(0) : [];
1620
+ if (c !== void 0 && C.push("label:" + c + ";"), b[0] == null || b[0].raw === void 0)
1621
+ C.push.apply(C, b);
1622
+ else {
1623
+ var k = b[0];
1624
+ C.push(k[0]);
1625
+ for (var F = b.length, X = 1; X < F; X++)
1626
+ C.push(b[X], k[X]);
1627
+ }
1628
+ var u = xr(function(d, m, V) {
1629
+ var G = A && d.as || t, J = "", g = [], R = d;
1630
+ if (d.theme == null) {
1631
+ R = {};
1632
+ for (var f in d)
1633
+ R[f] = d[f];
1634
+ R.theme = B.useContext(Zr);
1635
+ }
1636
+ typeof d.className == "string" ? J = Me(m.registered, g, d.className) : d.className != null && (J = d.className + " ");
1637
+ var re = _e(C.concat(g), m.registered, R);
1638
+ J += m.key + "-" + re.name, a !== void 0 && (J += " " + a);
1639
+ var Ae = A && l === void 0 ? ke(G) : s, O = {};
1640
+ for (var j in d)
1641
+ A && j === "as" || Ae(j) && (O[j] = d[j]);
1642
+ return O.className = J, V && (O.ref = V), /* @__PURE__ */ B.createElement(B.Fragment, null, /* @__PURE__ */ B.createElement(Fn, {
1643
+ cache: m,
1644
+ serialized: re,
1645
+ isStringTag: typeof G == "string"
1646
+ }), /* @__PURE__ */ B.createElement(G, O));
1647
+ });
1648
+ return u.displayName = c !== void 0 ? c : "Styled(" + (typeof t == "string" ? t : t.displayName || t.name || "Component") + ")", u.defaultProps = r.defaultProps, u.__emotion_real = u, u.__emotion_base = t, u.__emotion_styles = C, u.__emotion_forwardProp = l, Object.defineProperty(u, "toString", {
1649
+ value: function() {
1650
+ return "." + a;
1651
+ }
1652
+ }), u.withComponent = function(d, m) {
1653
+ var V = e(d, me({}, n, m, {
1654
+ shouldForwardProp: He(u, m, !0)
1655
+ }));
1656
+ return V.apply(void 0, C);
1657
+ }, u;
1658
+ };
1659
+ };
1660
+ const Yn = {
1661
+ large: "56px",
1662
+ mediumLarge: "48px",
1663
+ medium: "40px",
1664
+ small: "32px",
1665
+ xSmall: "24px"
1666
+ }, Nn = {
1667
+ large: "24px",
1668
+ mediumLarge: "20px",
1669
+ medium: "16px",
1670
+ small: "16px",
1671
+ xSmall: "12px"
1672
+ }, kn = {
1673
+ large: "18px",
1674
+ mediumLarge: "16px",
1675
+ medium: "16px",
1676
+ small: "14px",
1677
+ xSmall: "12px"
1678
+ }, Hn = {
1679
+ large: "20px",
1680
+ mediumLarge: "18px",
1681
+ medium: "16px",
1682
+ small: "14px",
1683
+ xSmall: "12px"
1684
+ }, Bn = vr`
1685
+ from { transform: rotate(0deg); }
1686
+ to { transform: rotate(360deg); }
1687
+ `, Dn = /* @__PURE__ */ rr("svg", process.env.NODE_ENV === "production" ? {
1688
+ target: "eodfskk1"
1689
+ } : {
1690
+ target: "eodfskk1",
1691
+ label: "SpinnerSvg"
1692
+ })({
1693
+ display: "block",
1694
+ flexShrink: 0,
1695
+ animation: `${Bn} 0.75s linear infinite`
1696
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/yash.raut/hsds_web_library/src/components/Button/Button.tsx"],"names":[],"mappings":"AA8CmB","file":"/Users/yash.raut/hsds_web_library/src/components/Button/Button.tsx","sourcesContent":["import styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport type { CSSObject } from '@emotion/react';\nimport type { ButtonProps, ButtonSize, ButtonVariant } from './Button.types';\n\n// ─── Size maps ────────────────────────────────────────────────────────────────\n\nconst HEIGHT: Record<ButtonSize, string> = {\n  large: '56px',\n  mediumLarge: '48px',\n  medium: '40px',\n  small: '32px',\n  xSmall: '24px',\n};\n\nconst PADDING_X: Record<ButtonSize, string> = {\n  large: '24px',\n  mediumLarge: '20px',\n  medium: '16px',\n  small: '16px',\n  xSmall: '12px',\n};\n\nconst FONT_SIZE: Record<ButtonSize, string> = {\n  large: '18px',\n  mediumLarge: '16px',\n  medium: '16px',\n  small: '14px',\n  xSmall: '12px',\n};\n\nconst SPINNER_SIZE: Record<ButtonSize, string> = {\n  large: '20px',\n  mediumLarge: '18px',\n  medium: '16px',\n  small: '14px',\n  xSmall: '12px',\n};\n\n// ─── Spinner ──────────────────────────────────────────────────────────────────\n\nconst spinKeyframes = keyframes`\n  from { transform: rotate(0deg); }\n  to   { transform: rotate(360deg); }\n`;\n\nconst SpinnerSvg = styled.svg({\n  display: 'block',\n  flexShrink: 0,\n  animation: `${spinKeyframes} 0.75s linear infinite`,\n});\n\nfunction Spinner({ size }: { size: string }) {\n  return (\n    <SpinnerSvg\n      aria-hidden=\"true\"\n      width={size}\n      height={size}\n      viewBox=\"0 0 24 24\"\n      fill=\"none\"\n    >\n      <circle\n        cx=\"12\"\n        cy=\"12\"\n        r=\"9\"\n        stroke=\"currentColor\"\n        strokeWidth=\"3\"\n        strokeLinecap=\"round\"\n        strokeDasharray=\"28 57\"\n      />\n    </SpinnerSvg>\n  );\n}\n\n// ─── Styled button ────────────────────────────────────────────────────────────\n\ninterface StyledProps {\n  $variant: ButtonVariant;\n  $size: ButtonSize;\n  $isFullWidth: boolean;\n  $iconOnly: boolean;\n}\n\nconst StyledButton = styled.button<StyledProps>(\n  ({ theme, $variant, $size, $isFullWidth, $iconOnly }) => {\n    const height = HEIGHT[$size];\n\n    const variantStyles: Record<ButtonVariant, CSSObject> = {\n      primary: {\n        backgroundColor: theme.colors.primary.primary,\n        color: theme.colors.foreground.foregroundInverse,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.primary.primaryStrong,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.primary.primaryStrong,\n          boxShadow: 'none',\n        },\n      },\n      secondary: {\n        backgroundColor: theme.colors.interactive.interactiveStrong,\n        color: theme.colors.foreground.foreground,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n          boxShadow: 'none',\n        },\n      },\n      tertiary: {\n        backgroundColor: theme.colors.interactive.interactive,\n        color: theme.colors.foreground.foreground,\n        border: `${theme.borders.width.small} solid ${theme.colors.border.border}`,\n        boxShadow: 'none',\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n          borderColor: 'transparent',\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n          borderColor: 'transparent',\n        },\n      },\n      ghost: {\n        backgroundColor: 'transparent',\n        color: theme.colors.foreground.foreground,\n        border: 'none',\n        boxShadow: 'none',\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n        },\n      },\n      black: {\n        backgroundColor: theme.colors.interactive.interactiveInverseStaticStrong,\n        color: theme.colors.foreground.foregroundInverseStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveInverseStatic,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveInverseStatic,\n          boxShadow: 'none',\n        },\n      },\n      white: {\n        backgroundColor: theme.colors.interactive.interactiveStatic,\n        color: theme.colors.foreground.foregroundStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStaticStrong,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStaticStrong,\n          boxShadow: 'none',\n        },\n      },\n      critical: {\n        backgroundColor: theme.colors.status.statusCritical,\n        color: theme.colors.foreground.foregroundInverseStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusCriticalStrong,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusCriticalStrong,\n          boxShadow: 'none',\n        },\n      },\n      success: {\n        backgroundColor: theme.colors.status.statusSuccess,\n        color: theme.colors.foreground.foregroundInverseStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusSuccessStrong,\n        },\n        '&:active:not(:disabled)': {\n          // Active reverts to base token per Figma — not statusSuccessStrong\n          backgroundColor: theme.colors.status.statusSuccess,\n          boxShadow: 'none',\n        },\n      },\n      warning: {\n        backgroundColor: theme.colors.status.statusWarning,\n        // Yellow background requires dark text for contrast\n        color: theme.colors.foreground.foregroundStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusWarningStrong,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusWarningStrong,\n          boxShadow: 'none',\n        },\n      },\n      textPrimary: {\n        backgroundColor: 'transparent',\n        color: theme.colors.foreground.foreground,\n        border: 'none',\n        boxShadow: 'none',\n        borderRadius: 0,\n        paddingInline: '0px',\n        '&:hover:not(:disabled)': {\n          color: theme.colors.foreground.foregroundWeak,\n          borderBottom: `2px solid ${theme.colors.foreground.foreground}`,\n        },\n        '&:active:not(:disabled)': {\n          color: theme.colors.foreground.foregroundWeak,\n          borderBottom: `2px solid ${theme.colors.foreground.foreground}`,\n        },\n      },\n      textSecondary: {\n        backgroundColor: 'transparent',\n        color: theme.colors.foreground.foregroundLink,\n        border: 'none',\n        boxShadow: 'none',\n        borderRadius: 0,\n        paddingInline: '0px',\n        '&:hover:not(:disabled)': {\n          borderBottom: `2px solid ${theme.colors.foreground.foregroundLink}`,\n        },\n        '&:active:not(:disabled)': {\n          borderBottom: `2px solid ${theme.colors.foreground.foregroundLink}`,\n        },\n      },\n    };\n\n    return {\n      // Layout\n      display: 'inline-flex',\n      alignItems: 'center',\n      justifyContent: 'center',\n      gap: '4px',\n      height,\n      width: $isFullWidth ? '100%' : $iconOnly ? height : 'auto',\n      paddingInline: $iconOnly ? '0px' : PADDING_X[$size],\n\n      // Shape\n      borderRadius: theme.borders.radius.pill,\n\n      // Typography\n      fontFamily: theme.typography.fontFamily.sans,\n      fontSize: FONT_SIZE[$size],\n      fontWeight: 700,\n      lineHeight: '1.2',\n      letterSpacing: '-0.03em',\n      whiteSpace: 'nowrap',\n\n      // Interaction\n      cursor: 'pointer',\n      userSelect: 'none',\n      textDecoration: 'none',\n      transition:\n        'background-color 120ms ease, box-shadow 120ms ease, opacity 120ms ease',\n\n      // Reset\n      appearance: 'none',\n      outline: 'none',\n\n      '&:focus-visible': {\n        outline: `3px solid ${theme.colors.primary.primary}`,\n        outlineOffset: '2px',\n      },\n\n      '&:disabled': {\n        opacity: 0.4,\n        cursor: 'not-allowed',\n        pointerEvents: 'none',\n      },\n\n      ...variantStyles[$variant],\n    };\n  }\n);\n\n// ─── Public component ─────────────────────────────────────────────────────────\n\nexport function Button({\n  variant = 'primary',\n  size = 'large',\n  isLoading = false,\n  isFullWidth = false,\n  leftIcon,\n  rightIcon,\n  disabled,\n  children,\n  ...rest\n}: ButtonProps) {\n  const iconOnly = !children && Boolean(leftIcon ?? rightIcon);\n\n  return (\n    <StyledButton\n      $variant={variant}\n      $size={size}\n      $isFullWidth={isFullWidth}\n      $iconOnly={iconOnly}\n      disabled={disabled ?? isLoading}\n      {...rest}\n    >\n      {isLoading ? (\n        <Spinner size={SPINNER_SIZE[size]} />\n      ) : (\n        <>\n          {leftIcon}\n          {children}\n          {rightIcon}\n        </>\n      )}\n    </StyledButton>\n  );\n}\n"]} */");
1697
+ function wn({
1698
+ size: e
1699
+ }) {
1700
+ return /* @__PURE__ */ q(Dn, { "aria-hidden": "true", width: e, height: e, viewBox: "0 0 24 24", fill: "none", children: /* @__PURE__ */ q("circle", { cx: "12", cy: "12", r: "9", stroke: "currentColor", strokeWidth: "3", strokeLinecap: "round", strokeDasharray: "28 57" }) });
1701
+ }
1702
+ const Ln = /* @__PURE__ */ rr("button", process.env.NODE_ENV === "production" ? {
1703
+ target: "eodfskk0"
1704
+ } : {
1705
+ target: "eodfskk0",
1706
+ label: "StyledButton"
1707
+ })(({
1708
+ theme: e,
1709
+ $variant: r,
1710
+ $size: n,
1711
+ $isFullWidth: i,
1712
+ $iconOnly: t
1713
+ }) => {
1714
+ const c = Yn[n], a = {
1715
+ primary: {
1716
+ backgroundColor: e.colors.primary.primary,
1717
+ color: e.colors.foreground.foregroundInverse,
1718
+ border: "none",
1719
+ boxShadow: e.shadows.default,
1720
+ "&:hover:not(:disabled)": {
1721
+ backgroundColor: e.colors.primary.primaryStrong
1722
+ },
1723
+ "&:active:not(:disabled)": {
1724
+ backgroundColor: e.colors.primary.primaryStrong,
1725
+ boxShadow: "none"
1726
+ }
1727
+ },
1728
+ secondary: {
1729
+ backgroundColor: e.colors.interactive.interactiveStrong,
1730
+ color: e.colors.foreground.foreground,
1731
+ border: "none",
1732
+ boxShadow: e.shadows.default,
1733
+ "&:hover:not(:disabled)": {
1734
+ backgroundColor: e.colors.interactive.interactiveStronger
1735
+ },
1736
+ "&:active:not(:disabled)": {
1737
+ backgroundColor: e.colors.interactive.interactiveStronger,
1738
+ boxShadow: "none"
1739
+ }
1740
+ },
1741
+ tertiary: {
1742
+ backgroundColor: e.colors.interactive.interactive,
1743
+ color: e.colors.foreground.foreground,
1744
+ border: `${e.borders.width.small} solid ${e.colors.border.border}`,
1745
+ boxShadow: "none",
1746
+ "&:hover:not(:disabled)": {
1747
+ backgroundColor: e.colors.interactive.interactiveStronger,
1748
+ borderColor: "transparent"
1749
+ },
1750
+ "&:active:not(:disabled)": {
1751
+ backgroundColor: e.colors.interactive.interactiveStronger,
1752
+ borderColor: "transparent"
1753
+ }
1754
+ },
1755
+ ghost: {
1756
+ backgroundColor: "transparent",
1757
+ color: e.colors.foreground.foreground,
1758
+ border: "none",
1759
+ boxShadow: "none",
1760
+ "&:hover:not(:disabled)": {
1761
+ backgroundColor: e.colors.interactive.interactiveStronger
1762
+ },
1763
+ "&:active:not(:disabled)": {
1764
+ backgroundColor: e.colors.interactive.interactiveStronger
1765
+ }
1766
+ },
1767
+ black: {
1768
+ backgroundColor: e.colors.interactive.interactiveInverseStaticStrong,
1769
+ color: e.colors.foreground.foregroundInverseStatic,
1770
+ border: "none",
1771
+ boxShadow: e.shadows.default,
1772
+ "&:hover:not(:disabled)": {
1773
+ backgroundColor: e.colors.interactive.interactiveInverseStatic
1774
+ },
1775
+ "&:active:not(:disabled)": {
1776
+ backgroundColor: e.colors.interactive.interactiveInverseStatic,
1777
+ boxShadow: "none"
1778
+ }
1779
+ },
1780
+ white: {
1781
+ backgroundColor: e.colors.interactive.interactiveStatic,
1782
+ color: e.colors.foreground.foregroundStatic,
1783
+ border: "none",
1784
+ boxShadow: e.shadows.default,
1785
+ "&:hover:not(:disabled)": {
1786
+ backgroundColor: e.colors.interactive.interactiveStaticStrong
1787
+ },
1788
+ "&:active:not(:disabled)": {
1789
+ backgroundColor: e.colors.interactive.interactiveStaticStrong,
1790
+ boxShadow: "none"
1791
+ }
1792
+ },
1793
+ critical: {
1794
+ backgroundColor: e.colors.status.statusCritical,
1795
+ color: e.colors.foreground.foregroundInverseStatic,
1796
+ border: "none",
1797
+ boxShadow: e.shadows.default,
1798
+ "&:hover:not(:disabled)": {
1799
+ backgroundColor: e.colors.status.statusCriticalStrong
1800
+ },
1801
+ "&:active:not(:disabled)": {
1802
+ backgroundColor: e.colors.status.statusCriticalStrong,
1803
+ boxShadow: "none"
1804
+ }
1805
+ },
1806
+ success: {
1807
+ backgroundColor: e.colors.status.statusSuccess,
1808
+ color: e.colors.foreground.foregroundInverseStatic,
1809
+ border: "none",
1810
+ boxShadow: e.shadows.default,
1811
+ "&:hover:not(:disabled)": {
1812
+ backgroundColor: e.colors.status.statusSuccessStrong
1813
+ },
1814
+ "&:active:not(:disabled)": {
1815
+ // Active reverts to base token per Figma — not statusSuccessStrong
1816
+ backgroundColor: e.colors.status.statusSuccess,
1817
+ boxShadow: "none"
1818
+ }
1819
+ },
1820
+ warning: {
1821
+ backgroundColor: e.colors.status.statusWarning,
1822
+ // Yellow background requires dark text for contrast
1823
+ color: e.colors.foreground.foregroundStatic,
1824
+ border: "none",
1825
+ boxShadow: e.shadows.default,
1826
+ "&:hover:not(:disabled)": {
1827
+ backgroundColor: e.colors.status.statusWarningStrong
1828
+ },
1829
+ "&:active:not(:disabled)": {
1830
+ backgroundColor: e.colors.status.statusWarningStrong,
1831
+ boxShadow: "none"
1832
+ }
1833
+ },
1834
+ textPrimary: {
1835
+ backgroundColor: "transparent",
1836
+ color: e.colors.foreground.foreground,
1837
+ border: "none",
1838
+ boxShadow: "none",
1839
+ borderRadius: 0,
1840
+ paddingInline: "0px",
1841
+ "&:hover:not(:disabled)": {
1842
+ color: e.colors.foreground.foregroundWeak,
1843
+ borderBottom: `2px solid ${e.colors.foreground.foreground}`
1844
+ },
1845
+ "&:active:not(:disabled)": {
1846
+ color: e.colors.foreground.foregroundWeak,
1847
+ borderBottom: `2px solid ${e.colors.foreground.foreground}`
1848
+ }
1849
+ },
1850
+ textSecondary: {
1851
+ backgroundColor: "transparent",
1852
+ color: e.colors.foreground.foregroundLink,
1853
+ border: "none",
1854
+ boxShadow: "none",
1855
+ borderRadius: 0,
1856
+ paddingInline: "0px",
1857
+ "&:hover:not(:disabled)": {
1858
+ borderBottom: `2px solid ${e.colors.foreground.foregroundLink}`
1859
+ },
1860
+ "&:active:not(:disabled)": {
1861
+ borderBottom: `2px solid ${e.colors.foreground.foregroundLink}`
1862
+ }
1863
+ }
1864
+ };
1865
+ return {
1866
+ // Layout
1867
+ display: "inline-flex",
1868
+ alignItems: "center",
1869
+ justifyContent: "center",
1870
+ gap: "4px",
1871
+ height: c,
1872
+ width: i ? "100%" : t ? c : "auto",
1873
+ paddingInline: t ? "0px" : Nn[n],
1874
+ // Shape
1875
+ borderRadius: e.borders.radius.pill,
1876
+ // Typography
1877
+ fontFamily: e.typography.fontFamily.sans,
1878
+ fontSize: kn[n],
1879
+ fontWeight: 700,
1880
+ lineHeight: "1.2",
1881
+ letterSpacing: "-0.03em",
1882
+ whiteSpace: "nowrap",
1883
+ // Interaction
1884
+ cursor: "pointer",
1885
+ userSelect: "none",
1886
+ textDecoration: "none",
1887
+ transition: "background-color 120ms ease, box-shadow 120ms ease, opacity 120ms ease",
1888
+ // Reset
1889
+ appearance: "none",
1890
+ outline: "none",
1891
+ "&:focus-visible": {
1892
+ outline: `3px solid ${e.colors.primary.primary}`,
1893
+ outlineOffset: "2px"
1894
+ },
1895
+ "&:disabled": {
1896
+ opacity: 0.4,
1897
+ cursor: "not-allowed",
1898
+ pointerEvents: "none"
1899
+ },
1900
+ ...a[r]
1901
+ };
1902
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/yash.raut/hsds_web_library/src/components/Button/Button.tsx"],"names":[],"mappings":"AAmFqB","file":"/Users/yash.raut/hsds_web_library/src/components/Button/Button.tsx","sourcesContent":["import styled from '@emotion/styled';\nimport { keyframes } from '@emotion/react';\nimport type { CSSObject } from '@emotion/react';\nimport type { ButtonProps, ButtonSize, ButtonVariant } from './Button.types';\n\n// ─── Size maps ────────────────────────────────────────────────────────────────\n\nconst HEIGHT: Record<ButtonSize, string> = {\n  large: '56px',\n  mediumLarge: '48px',\n  medium: '40px',\n  small: '32px',\n  xSmall: '24px',\n};\n\nconst PADDING_X: Record<ButtonSize, string> = {\n  large: '24px',\n  mediumLarge: '20px',\n  medium: '16px',\n  small: '16px',\n  xSmall: '12px',\n};\n\nconst FONT_SIZE: Record<ButtonSize, string> = {\n  large: '18px',\n  mediumLarge: '16px',\n  medium: '16px',\n  small: '14px',\n  xSmall: '12px',\n};\n\nconst SPINNER_SIZE: Record<ButtonSize, string> = {\n  large: '20px',\n  mediumLarge: '18px',\n  medium: '16px',\n  small: '14px',\n  xSmall: '12px',\n};\n\n// ─── Spinner ──────────────────────────────────────────────────────────────────\n\nconst spinKeyframes = keyframes`\n  from { transform: rotate(0deg); }\n  to   { transform: rotate(360deg); }\n`;\n\nconst SpinnerSvg = styled.svg({\n  display: 'block',\n  flexShrink: 0,\n  animation: `${spinKeyframes} 0.75s linear infinite`,\n});\n\nfunction Spinner({ size }: { size: string }) {\n  return (\n    <SpinnerSvg\n      aria-hidden=\"true\"\n      width={size}\n      height={size}\n      viewBox=\"0 0 24 24\"\n      fill=\"none\"\n    >\n      <circle\n        cx=\"12\"\n        cy=\"12\"\n        r=\"9\"\n        stroke=\"currentColor\"\n        strokeWidth=\"3\"\n        strokeLinecap=\"round\"\n        strokeDasharray=\"28 57\"\n      />\n    </SpinnerSvg>\n  );\n}\n\n// ─── Styled button ────────────────────────────────────────────────────────────\n\ninterface StyledProps {\n  $variant: ButtonVariant;\n  $size: ButtonSize;\n  $isFullWidth: boolean;\n  $iconOnly: boolean;\n}\n\nconst StyledButton = styled.button<StyledProps>(\n  ({ theme, $variant, $size, $isFullWidth, $iconOnly }) => {\n    const height = HEIGHT[$size];\n\n    const variantStyles: Record<ButtonVariant, CSSObject> = {\n      primary: {\n        backgroundColor: theme.colors.primary.primary,\n        color: theme.colors.foreground.foregroundInverse,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.primary.primaryStrong,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.primary.primaryStrong,\n          boxShadow: 'none',\n        },\n      },\n      secondary: {\n        backgroundColor: theme.colors.interactive.interactiveStrong,\n        color: theme.colors.foreground.foreground,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n          boxShadow: 'none',\n        },\n      },\n      tertiary: {\n        backgroundColor: theme.colors.interactive.interactive,\n        color: theme.colors.foreground.foreground,\n        border: `${theme.borders.width.small} solid ${theme.colors.border.border}`,\n        boxShadow: 'none',\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n          borderColor: 'transparent',\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n          borderColor: 'transparent',\n        },\n      },\n      ghost: {\n        backgroundColor: 'transparent',\n        color: theme.colors.foreground.foreground,\n        border: 'none',\n        boxShadow: 'none',\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStronger,\n        },\n      },\n      black: {\n        backgroundColor: theme.colors.interactive.interactiveInverseStaticStrong,\n        color: theme.colors.foreground.foregroundInverseStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveInverseStatic,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveInverseStatic,\n          boxShadow: 'none',\n        },\n      },\n      white: {\n        backgroundColor: theme.colors.interactive.interactiveStatic,\n        color: theme.colors.foreground.foregroundStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStaticStrong,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.interactive.interactiveStaticStrong,\n          boxShadow: 'none',\n        },\n      },\n      critical: {\n        backgroundColor: theme.colors.status.statusCritical,\n        color: theme.colors.foreground.foregroundInverseStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusCriticalStrong,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusCriticalStrong,\n          boxShadow: 'none',\n        },\n      },\n      success: {\n        backgroundColor: theme.colors.status.statusSuccess,\n        color: theme.colors.foreground.foregroundInverseStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusSuccessStrong,\n        },\n        '&:active:not(:disabled)': {\n          // Active reverts to base token per Figma — not statusSuccessStrong\n          backgroundColor: theme.colors.status.statusSuccess,\n          boxShadow: 'none',\n        },\n      },\n      warning: {\n        backgroundColor: theme.colors.status.statusWarning,\n        // Yellow background requires dark text for contrast\n        color: theme.colors.foreground.foregroundStatic,\n        border: 'none',\n        boxShadow: theme.shadows.default,\n        '&:hover:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusWarningStrong,\n        },\n        '&:active:not(:disabled)': {\n          backgroundColor: theme.colors.status.statusWarningStrong,\n          boxShadow: 'none',\n        },\n      },\n      textPrimary: {\n        backgroundColor: 'transparent',\n        color: theme.colors.foreground.foreground,\n        border: 'none',\n        boxShadow: 'none',\n        borderRadius: 0,\n        paddingInline: '0px',\n        '&:hover:not(:disabled)': {\n          color: theme.colors.foreground.foregroundWeak,\n          borderBottom: `2px solid ${theme.colors.foreground.foreground}`,\n        },\n        '&:active:not(:disabled)': {\n          color: theme.colors.foreground.foregroundWeak,\n          borderBottom: `2px solid ${theme.colors.foreground.foreground}`,\n        },\n      },\n      textSecondary: {\n        backgroundColor: 'transparent',\n        color: theme.colors.foreground.foregroundLink,\n        border: 'none',\n        boxShadow: 'none',\n        borderRadius: 0,\n        paddingInline: '0px',\n        '&:hover:not(:disabled)': {\n          borderBottom: `2px solid ${theme.colors.foreground.foregroundLink}`,\n        },\n        '&:active:not(:disabled)': {\n          borderBottom: `2px solid ${theme.colors.foreground.foregroundLink}`,\n        },\n      },\n    };\n\n    return {\n      // Layout\n      display: 'inline-flex',\n      alignItems: 'center',\n      justifyContent: 'center',\n      gap: '4px',\n      height,\n      width: $isFullWidth ? '100%' : $iconOnly ? height : 'auto',\n      paddingInline: $iconOnly ? '0px' : PADDING_X[$size],\n\n      // Shape\n      borderRadius: theme.borders.radius.pill,\n\n      // Typography\n      fontFamily: theme.typography.fontFamily.sans,\n      fontSize: FONT_SIZE[$size],\n      fontWeight: 700,\n      lineHeight: '1.2',\n      letterSpacing: '-0.03em',\n      whiteSpace: 'nowrap',\n\n      // Interaction\n      cursor: 'pointer',\n      userSelect: 'none',\n      textDecoration: 'none',\n      transition:\n        'background-color 120ms ease, box-shadow 120ms ease, opacity 120ms ease',\n\n      // Reset\n      appearance: 'none',\n      outline: 'none',\n\n      '&:focus-visible': {\n        outline: `3px solid ${theme.colors.primary.primary}`,\n        outlineOffset: '2px',\n      },\n\n      '&:disabled': {\n        opacity: 0.4,\n        cursor: 'not-allowed',\n        pointerEvents: 'none',\n      },\n\n      ...variantStyles[$variant],\n    };\n  }\n);\n\n// ─── Public component ─────────────────────────────────────────────────────────\n\nexport function Button({\n  variant = 'primary',\n  size = 'large',\n  isLoading = false,\n  isFullWidth = false,\n  leftIcon,\n  rightIcon,\n  disabled,\n  children,\n  ...rest\n}: ButtonProps) {\n  const iconOnly = !children && Boolean(leftIcon ?? rightIcon);\n\n  return (\n    <StyledButton\n      $variant={variant}\n      $size={size}\n      $isFullWidth={isFullWidth}\n      $iconOnly={iconOnly}\n      disabled={disabled ?? isLoading}\n      {...rest}\n    >\n      {isLoading ? (\n        <Spinner size={SPINNER_SIZE[size]} />\n      ) : (\n        <>\n          {leftIcon}\n          {children}\n          {rightIcon}\n        </>\n      )}\n    </StyledButton>\n  );\n}\n"]} */");
1903
+ function jn({
1904
+ variant: e = "primary",
1905
+ size: r = "large",
1906
+ isLoading: n = !1,
1907
+ isFullWidth: i = !1,
1908
+ leftIcon: t,
1909
+ rightIcon: c,
1910
+ disabled: a,
1911
+ children: l,
1912
+ ...s
1913
+ }) {
1914
+ return /* @__PURE__ */ q(Ln, { $variant: e, $size: r, $isFullWidth: i, $iconOnly: !l && !!(t ?? c), disabled: a ?? n, ...s, children: n ? /* @__PURE__ */ q(wn, { size: Hn[r] }) : /* @__PURE__ */ Gn(yn, { children: [
1915
+ t,
1916
+ l,
1917
+ c
1918
+ ] }) });
1919
+ }
1920
+ export {
1921
+ jn as Button,
1922
+ On as HsdsThemeProvider,
1923
+ hn as desktopTypeScale,
1924
+ Wn as hsdsTheme,
1925
+ vn as semanticColors
1926
+ };
1927
+ //# sourceMappingURL=hsds-web-library.es.js.map