pxd 0.0.31 → 0.0.32

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.
@@ -325,7 +325,7 @@ onBeforeUnmount(() => {
325
325
  <Transition name="pxd-transition--fade">
326
326
  <div
327
327
  v-if="showTooltip"
328
- class="pxd-active-graph--tooltip left-0 top-0 px-2 py-1 pointer-events-none absolute z-10 w-max rounded-sm bg-gray-1000 text-[13px] text-gray-100 duration-50 will-change-transform motion-safe:transition-transform"
328
+ class="pxd-active-graph--tooltip left-0 top-0 px-2 py-1 pointer-events-none absolute z-1 w-max rounded-sm bg-gray-1000 text-[13px] text-gray-100 duration-50 will-change-transform motion-safe:transition-transform"
329
329
  :style="`transform: translate(${tooltipInfo.left}px, ${tooltipInfo.top}px);`"
330
330
  >
331
331
  <slot name="tooltip" :data="tooltipInfo">
@@ -64,7 +64,7 @@ defineExpose({
64
64
 
65
65
  <div
66
66
  v-if="$slots.icon"
67
- class="-bottom-1 -left-1 absolute z-10 flex size-1/2 items-center overflow-hidden rounded-full border border-background-100 bg-background-100"
67
+ class="-bottom-1 -left-1 absolute z-1 flex size-1/2 items-center overflow-hidden rounded-full border border-background-100 bg-background-100"
68
68
  >
69
69
  <slot name="icon" />
70
70
  </div>
@@ -27,7 +27,7 @@ provideAvatarGroupContext(props);
27
27
  :src="option.src"
28
28
  :alt="option.alt"
29
29
  :loading="option.loading"
30
- class="[&:nth-child(n+2)]:-ml-3 hover:z-10"
30
+ class="[&:nth-child(n+2)]:-ml-2.5 hover:z-1"
31
31
  />
32
32
 
33
33
  <PAvatar v-if="slicedOptions.length < options.length" class="text-xs -ml-3 bg-gray-1000 text-gray-100">
@@ -1,5 +1,7 @@
1
1
  <script setup>
2
2
  import ArrowLeftIcon from "@gdsicon/vue/arrow-left";
3
+ import CheckIcon from "@gdsicon/vue/check";
4
+ import CopyIcon from "@gdsicon/vue/copy";
3
5
  import LockClosedIcon from "@gdsicon/vue/lock-closed";
4
6
  import RefreshClockwiseIcon from "@gdsicon/vue/refresh-clockwise";
5
7
  import { useCopyClick } from "../../composables/use-copy-click";
@@ -10,7 +12,7 @@ defineOptions({
10
12
  defineProps({
11
13
  address: { type: String, required: false }
12
14
  });
13
- const { renderAs, onCopyClick } = useCopyClick();
15
+ const { isCopied, copyText } = useCopyClick();
14
16
  </script>
15
17
 
16
18
  <template>
@@ -38,9 +40,9 @@ const { renderAs, onCopyClick } = useCopyClick();
38
40
  {{ address }}
39
41
  </div>
40
42
 
41
- <PButton variant="ghost" size="xs" shape="rounded" class="size-6" icon @click="onCopyClick(address)">
43
+ <PButton variant="ghost" size="xs" shape="rounded" class="size-6" icon @click="copyText(address)">
42
44
  <Transition name="pxd-transition--fade-scale" mode="out-in">
43
- <component :is="renderAs" class="text-sm text-foreground-secondary" />
45
+ <component :is="isCopied ? CheckIcon : CopyIcon" class="text-sm text-foreground-secondary" />
44
46
  </Transition>
45
47
  </PButton>
46
48
  </div>
@@ -1,11 +1,15 @@
1
1
  <script setup>
2
- import { computed } from "vue";
2
+ import dayjs from "dayjs";
3
+ import dayjsDuration from "dayjs/plugin/duration";
4
+ import { computed, onBeforeUnmount } from "vue";
3
5
  import { useCountdown } from "../../composables/use-countdown";
6
+ import millisecondTokenPlugin from "../../utils/dayjs-millisecond-token";
4
7
  defineOptions({
5
8
  name: "PCountDown"
6
9
  });
7
10
  const props = defineProps({
8
- format: { type: String, required: false, default: "hh:mm:ss.ms" },
11
+ format: { type: String, required: false, default: "HH:mm:ss" },
12
+ invert: { type: Boolean, required: false },
9
13
  active: { type: Boolean, required: false, default: false },
10
14
  endTime: { type: Number, required: false, default: 0 },
11
15
  autoReset: { type: Boolean, required: false, default: true },
@@ -14,15 +18,29 @@ const props = defineProps({
14
18
  millisecond: { type: Boolean, required: false, default: true }
15
19
  });
16
20
  const emits = defineEmits(["change", "reset", "finish"]);
21
+ dayjs.extend(dayjsDuration);
22
+ dayjs.extend(millisecondTokenPlugin);
17
23
  const {
24
+ clean,
18
25
  reset,
19
- times
26
+ timestamp
20
27
  } = useCountdown(props, emits);
28
+ const times = computed(() => {
29
+ const t = dayjs.duration(timestamp.value);
30
+ return {
31
+ dd: t.format("DD"),
32
+ hh: t.format("HH"),
33
+ mm: t.format("mm"),
34
+ ss: t.format("ss"),
35
+ ms: t.format("SSS")
36
+ };
37
+ });
21
38
  const displayTimes = computed(() => {
22
- const { format, precision } = props;
23
- let result = format;
24
- result = result.replace(/\.ms/, precision ? `.${times.value.ms}` : "");
25
- return result.replace(/dd/, times.value.dd).replace(/hh/, times.value.hh).replace(/mm/, times.value.mm).replace(/ss/, times.value.ss);
39
+ const time = dayjs.duration(timestamp.value).format(props.format);
40
+ return time;
41
+ });
42
+ onBeforeUnmount(() => {
43
+ clean();
26
44
  });
27
45
  defineExpose({
28
46
  reset,
@@ -101,16 +101,16 @@ watch(() => isVisible.value, (visible) => {
101
101
  :style="computedStyle"
102
102
  >
103
103
  <header
104
- class="pxd-drawer--header px-6 py-4 sm:py-6 relative shrink-0 empty:py-3"
104
+ class="pxd-drawer--header p-6 sm:py-4 relative shrink-0 empty:py-3"
105
105
  :class="{ 'border-b bg-background-200 dark:bg-background-100': headerStyle }"
106
106
  >
107
- <h3 v-if="$slots.title || title" class="text-base sm:text-2xl font-semibold tracking-tight">
107
+ <h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight">
108
108
  <slot name="title">
109
109
  {{ title }}
110
110
  </slot>
111
111
  </h3>
112
112
 
113
- <div v-if="$slots.subtitle || subtitle" class="mt-4 text-sm text-muted-foreground">
113
+ <div v-if="$slots.subtitle || subtitle" class="mt-3 text-sm text-muted-foreground">
114
114
  <slot name="subtitle">
115
115
  {{ subtitle }}
116
116
  </slot>
@@ -121,7 +121,7 @@ watch(() => isVisible.value, (visible) => {
121
121
  v-if="$slots.default"
122
122
  :data-header="headerStyle"
123
123
  class="pxd-drawer--content group flex-1"
124
- content-class="group-data-[header=true]:pt-6 px-6 pb-6"
124
+ content-class="group-data-[header=true]:pt-5 px-6 pb-5"
125
125
  >
126
126
  <slot />
127
127
  </PScrollable>
@@ -28,7 +28,7 @@ const computedClass = computed(() => {
28
28
 
29
29
  <template>
30
30
  <div :class="computedClass">
31
- <StopIcon class="size-4 min-w-4 mr-2 mt-(--mt)" />
31
+ <StopIcon class="size-4 mr-2 mt-(--mt) shrink-0" />
32
32
 
33
33
  <div class="flex-1">
34
34
  <b v-if="label || error?.label" class="font-medium whitespace-nowrap">{{ label || error?.label }}:</b>
@@ -80,14 +80,14 @@ function onPointerOut(e) {
80
80
  <template>
81
81
  <PTeleport to="body">
82
82
  <div
83
- class="pxd-message p-4 pointer-events-none fixed z-10 w-full"
83
+ class="pxd-message p-4 fixed z-10 w-full empty:pointer-events-none"
84
84
  :style="{ zIndex }"
85
85
  :data-position="position"
86
86
  >
87
87
  <TransitionGroup
88
88
  name="pxd-transition--fade-scale"
89
89
  tag="div"
90
- class="pxd-message--group gap-3 sm:pointer-events-auto relative flex"
90
+ class="pxd-message--group gap-3 relative flex"
91
91
  appear
92
92
  @pointerover="onPointerOver"
93
93
  @pointerout="onPointerOut"
@@ -99,10 +99,10 @@ function onPointerOut(e) {
99
99
  aria-live="polite"
100
100
  :data-key="item.key"
101
101
  :data-type="item.type"
102
- :class="item.class"
103
- class="pxd-message--item group py-2 pl-3 pr-2 text-sm flex w-max max-w-full items-center rounded-lg bg-background-100 shadow-border-modal"
102
+ :class="[item.class, { 'pr-9': item.closeable }]"
103
+ class="pxd-message--item py-2 px-3 text-sm relative flex w-max max-w-full rounded-lg bg-background-100 break-all shadow-border-modal"
104
104
  >
105
- <component :is="TYPE_ICONS[item.type]" v-if="item.type" class="pxd-message--icon mr-2 shrink-0" :class="item.type" />
105
+ <component :is="TYPE_ICONS[item.type]" v-if="item.type" class="pxd-message--icon size-4 mr-2 mt-0.5 shrink-0" :class="item.type" />
106
106
 
107
107
  <span v-if="typeof item.message === 'string'">
108
108
  {{ item.message }}
@@ -114,7 +114,7 @@ function onPointerOut(e) {
114
114
  icon
115
115
  size="xs"
116
116
  variant="ghost"
117
- class="ml-1 touch-none text-foreground-secondary"
117
+ class="right-1.5 top-1.5 absolute z-1 touch-none text-foreground-secondary"
118
118
  @click="closeMessage(item.key)"
119
119
  >
120
120
  <CloseIcon />
@@ -68,16 +68,16 @@ watch(() => isVisible.value, (visible) => {
68
68
  :style="{ '--w': width }"
69
69
  >
70
70
  <header
71
- class="pxd-modal--header px-6 py-4 sm:py-6 relative shrink-0 empty:py-3"
71
+ class="pxd-modal--header p-6 sm:py-4 relative shrink-0 empty:py-3"
72
72
  :class="{ 'border-b bg-background-200 dark:bg-background-100': headerStyle }"
73
73
  >
74
- <h3 v-if="$slots.title || title" class="text-base sm:text-2xl font-semibold tracking-tight">
74
+ <h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight">
75
75
  <slot name="title">
76
76
  {{ title }}
77
77
  </slot>
78
78
  </h3>
79
79
 
80
- <div v-if="$slots.subtitle || subtitle" class="mt-4 text-sm text-muted-foreground">
80
+ <div v-if="$slots.subtitle || subtitle" class="mt-3 text-sm text-muted-foreground">
81
81
  <slot name="subtitle">
82
82
  {{ subtitle }}
83
83
  </slot>
@@ -88,7 +88,7 @@ watch(() => isVisible.value, (visible) => {
88
88
  v-if="$slots.default"
89
89
  :data-header="headerStyle"
90
90
  class="pxd-modal--content group flex-1"
91
- content-class="group-data-[header=true]:pt-6 px-6 pb-6 empty:hidden"
91
+ content-class="group-data-[header=true]:pt-5 px-6 pb-5"
92
92
  >
93
93
  <slot />
94
94
  </PScrollable>
@@ -37,7 +37,7 @@ function onToggleExpand() {
37
37
 
38
38
  <template>
39
39
  <div class="pxd-more-button px-4 mt-4 flex w-full items-center">
40
- <PButton class="relative z-10" v-bind="buttonProps" @click="onToggleExpand">
40
+ <PButton class="relative z-1" v-bind="buttonProps" @click="onToggleExpand">
41
41
  {{ isExpanded ? lessText : moreText }}
42
42
 
43
43
  <template #suffix>
@@ -1,7 +1,6 @@
1
1
  <script setup>
2
2
  import { computed, nextTick, onBeforeUnmount, onMounted, shallowRef, watch } from "vue";
3
3
  import { useDelayDestroy } from "../../composables/use-delay-destroy";
4
- import { PRESET_MEDIA_QUERIES, useMediaQuery } from "../../composables/use-media-query";
5
4
  import {
6
5
  getElementRectFromContainer,
7
6
  getScrollContainer,
@@ -67,7 +66,6 @@ const {
67
66
  default: props.visible,
68
67
  delay: props.destroyDelay
69
68
  });
70
- const isSmUp = useMediaQuery(PRESET_MEDIA_QUERIES.SM_UP);
71
69
  const triggerMethods = computed(() => toArray(props.trigger));
72
70
  let cachedScrollTop = 0;
73
71
  let cachedBasePosition = null;
@@ -309,46 +307,35 @@ function updateContentPosition() {
309
307
  left = `${scrollLeft + width}px`;
310
308
  translateX = "-100%";
311
309
  }
312
- if (!isSmUp.value) {
313
- left = "";
314
- translateX = "0";
315
- }
316
310
  } else if (isHorizontal) {
317
- if (isSmUp.value) {
318
- if (position === "left") {
319
- top = `${scrollTop + height / 2}px`;
320
- left = `${scrollLeft}px`;
321
- translateX = "-100%";
322
- translateY = "-50%";
323
- } else if (position === "right") {
324
- top = `${scrollTop + height / 2}px`;
325
- left = `${scrollLeft + width}px`;
326
- translateX = "0";
327
- translateY = "-50%";
328
- } else if (position === "left-start") {
329
- top = `${scrollTop}px`;
330
- left = `${scrollLeft}px`;
331
- translateX = "-100%";
332
- translateY = "0";
333
- } else if (position === "left-end") {
334
- top = `${scrollTop + height}px`;
335
- left = `${scrollLeft}px`;
336
- translateX = "-100%";
337
- translateY = "-100%";
338
- } else if (position === "right-start") {
339
- top = `${scrollTop}px`;
340
- left = `${scrollLeft + width}px`;
341
- } else if (position === "right-end") {
342
- top = `${scrollTop + height}px`;
343
- left = `${scrollLeft + width}px`;
344
- translateX = "0";
345
- translateY = "-100%";
346
- }
347
- } else {
311
+ if (position === "left") {
312
+ top = `${scrollTop + height / 2}px`;
313
+ left = `${scrollLeft}px`;
314
+ translateX = "-100%";
315
+ translateY = "-50%";
316
+ } else if (position === "right") {
317
+ top = `${scrollTop + height / 2}px`;
318
+ left = `${scrollLeft + width}px`;
319
+ translateX = "0";
320
+ translateY = "-50%";
321
+ } else if (position === "left-start") {
348
322
  top = `${scrollTop}px`;
349
- left = "";
323
+ left = `${scrollLeft}px`;
324
+ translateX = "-100%";
325
+ translateY = "0";
326
+ } else if (position === "left-end") {
327
+ top = `${scrollTop + height}px`;
328
+ left = `${scrollLeft}px`;
329
+ translateX = "-100%";
330
+ translateY = "-100%";
331
+ } else if (position === "right-start") {
332
+ top = `${scrollTop}px`;
333
+ left = `${scrollLeft + width}px`;
334
+ } else if (position === "right-end") {
335
+ top = `${scrollTop + height}px`;
336
+ left = `${scrollLeft + width}px`;
337
+ translateX = "0";
350
338
  translateY = "-100%";
351
- localPosition.value = "top-start";
352
339
  }
353
340
  }
354
341
  wrapperStyle.value = {
@@ -591,22 +578,22 @@ defineExpose({
591
578
 
592
579
  &[data-position='left-start'] .pxd-popover--arrow,
593
580
  &[data-position='right-start'] .pxd-popover--arrow {
594
- top: 15px;
581
+ top: 16px;
595
582
  }
596
583
 
597
584
  &[data-position='left-end'] .pxd-popover--arrow,
598
585
  &[data-position='right-end'] .pxd-popover--arrow {
599
- bottom: 15px;
586
+ bottom: 16px;
600
587
  }
601
588
 
602
589
  &[data-position='top-start'] .pxd-popover--arrow,
603
590
  &[data-position='bottom-start'] .pxd-popover--arrow {
604
- left: 15px;
591
+ left: 16px;
605
592
  }
606
593
 
607
594
  &[data-position='top-end'] .pxd-popover--arrow,
608
595
  &[data-position='bottom-end'] .pxd-popover--arrow {
609
- right: 15px;
596
+ right: 16px;
610
597
  }
611
598
  }
612
599
 
@@ -214,14 +214,14 @@ onBeforeUnmount(() => {
214
214
 
215
215
  <div
216
216
  v-if="props.range"
217
- class="pxd-slider--thumb rounded-xs absolute -translate-x-1/2 touch-none bg-background-100 hover:scale-130 active:z-10 active:scale-130 motion-safe:transition-transform"
217
+ class="pxd-slider--thumb rounded-xs absolute -translate-x-1/2 touch-none bg-background-100 hover:scale-130 active:z-1 active:scale-130 motion-safe:transition-transform"
218
218
  :class="[{ 'scale-130': activeThumb === 'start', 'pointer-events-none': disabled }, computedSize.thumb]"
219
219
  :style="{ left: `${startPercentage}%` }"
220
220
  @pointerdown.prevent.stop="startDragging($event, 'start')"
221
221
  />
222
222
 
223
223
  <div
224
- class="pxd-slider--thumb rounded-xs absolute -translate-x-1/2 touch-none bg-background-100 hover:scale-130 active:z-10 active:scale-130 motion-safe:transition-transform"
224
+ class="pxd-slider--thumb rounded-xs absolute -translate-x-1/2 touch-none bg-background-100 hover:scale-130 active:z-1 active:scale-130 motion-safe:transition-transform"
225
225
  :class="[{ 'scale-130': activeThumb === 'end', 'pointer-events-none': disabled }, computedSize.thumb]"
226
226
  :style="{ left: `${endPercentage}%` }"
227
227
  @pointerdown.prevent.stop="startDragging($event, 'end')"
@@ -1,5 +1,7 @@
1
1
  <script setup>
2
- import { computed, ref } from "vue";
2
+ import CheckIcon from "@gdsicon/vue/check";
3
+ import CopyIcon from "@gdsicon/vue/copy";
4
+ import { computed } from "vue";
3
5
  import { useConfigProvider } from "../../composables/use-config-provider-context";
4
6
  import { useCopyClick } from "../../composables/use-copy-click";
5
7
  import { getCssUnitValue, toArray } from "../../utils/format";
@@ -15,7 +17,6 @@ const props = defineProps({
15
17
  variant: { type: String, required: false, default: "default" }
16
18
  });
17
19
  const emits = defineEmits(["copy"]);
18
- const isCopied = ref(false);
19
20
  const SIZES = {
20
21
  sm: "min-h-7.5 pl-3.5 pr-1.5 py-2 text-sm",
21
22
  md: "min-h-9 pl-3.5 pr-2.5 py-2.5 text-sm",
@@ -31,7 +32,7 @@ const VARIANTS = {
31
32
  const config = useConfigProvider();
32
33
  const computedClass = computed(() => {
33
34
  const classes = [
34
- "pxd-snippet pr-14 relative flex w-max items-center rounded-lg border motion-safe:transition-all",
35
+ "pxd-snippet pr-12 relative flex items-center rounded-lg border motion-safe:transition-all",
35
36
  getFallbackValue(props.variant, VARIANTS),
36
37
  getFallbackValue(props.size, SIZES, config.size)
37
38
  ];
@@ -41,10 +42,10 @@ const computedClass = computed(() => {
41
42
  return classes.join(" ");
42
43
  });
43
44
  const computedTextArray = computed(() => toArray(props.text));
44
- const { renderAs, onCopyClick } = useCopyClick();
45
+ const { isCopied, copyText } = useCopyClick();
45
46
  async function onCopyButtonClick() {
46
47
  const text = computedTextArray.value.join("\n");
47
- await onCopyClick(text);
48
+ await copyText(text);
48
49
  emits("copy", text);
49
50
  }
50
51
  </script>
@@ -56,12 +57,12 @@ async function onCopyButtonClick() {
56
57
  </div>
57
58
 
58
59
  <div
59
- class="right-1 p-2 absolute top-1/2 -translate-y-1/2 cursor-pointer rounded-md hover:bg-background-hover active:bg-background-active"
60
+ class="right-1 p-2 absolute top-1/2 -translate-y-1/2 cursor-pointer touch-none rounded-md select-none hover:bg-background-hover active:bg-background-active"
60
61
  :class="{ copied: isCopied }"
61
62
  @click="onCopyButtonClick"
62
63
  >
63
64
  <Transition name="pxd-transition--fade-scale" mode="out-in">
64
- <component :is="renderAs" class="text-sm" />
65
+ <component :is="isCopied ? CheckIcon : CopyIcon" class="text-sm" />
65
66
  </Transition>
66
67
  </div>
67
68
  </div>
@@ -90,7 +90,7 @@ const computedClass = computed(() => {
90
90
  </script>
91
91
 
92
92
  <template>
93
- <component :is="props.as" :class="computedClass" v-bind="$attrs" :style="formattedGap">
93
+ <component :is="props.as" :class="computedClass" :data-direction="direction" v-bind="$attrs" :style="formattedGap">
94
94
  <slot />
95
95
  </component>
96
96
  </template>
@@ -21,17 +21,33 @@ const props = defineProps({
21
21
  popoverStyle: { type: [Object, String], required: false, default: "" }
22
22
  });
23
23
  const VARIANTS = {
24
- primary: "var(--color-primary)",
25
- error: "var(--color-red-700)",
26
- warning: "var(--color-amber-700)",
27
- success: "var(--color-green-700)"
24
+ primary: {
25
+ bg: "var(--color-primary)",
26
+ text: "text-gray-100"
27
+ },
28
+ error: {
29
+ bg: "var(--color-red-700)",
30
+ text: "text-gray-100 dark:text-gray-1000"
31
+ },
32
+ warning: {
33
+ bg: "var(--color-amber-700)",
34
+ text: "text-gray-1000 dark:text-gray-100"
35
+ },
36
+ success: {
37
+ bg: "var(--color-green-700)",
38
+ text: "text-gray-100 dark:text-gray-1000"
39
+ }
28
40
  };
29
41
  const computedVariant = computed(() => getFallbackValue(props.variant, VARIANTS, "primary"));
30
42
  const computedDisabled = computed(() => {
31
43
  return props.disabled || props.desktopOnly && isTouchDevice();
32
44
  });
33
45
  const computedPopoverClass = computed(() => {
34
- return ["px-3 py-2 text-gray-100 rounded-md text-[13px] break-words whitespace-pre-line shadow-border-tooltip bg-(--color)", props.popoverClass].join(" ");
46
+ return [
47
+ "px-3 py-2 rounded-md text-[13px] break-words whitespace-pre-line shadow-border-tooltip bg-(--color)",
48
+ computedVariant.value.text,
49
+ props.popoverClass
50
+ ].join(" ");
35
51
  });
36
52
  </script>
37
53
 
@@ -41,7 +57,7 @@ const computedPopoverClass = computed(() => {
41
57
  show-arrow
42
58
  :position="position"
43
59
  :disabled="computedDisabled"
44
- :arrow-color="computedVariant"
60
+ :arrow-color="computedVariant.bg"
45
61
  :trigger-class="triggerClass"
46
62
  :trigger-style="triggerStyle"
47
63
  :popover-class="computedPopoverClass"
@@ -1,5 +1,4 @@
1
1
  export declare function useCopyClick(): {
2
- isCopied: import("vue").Ref<boolean, boolean>;
3
- renderAs: import("vue").ComputedRef<any>;
4
- onCopyClick: (text: string | undefined) => Promise<void>;
2
+ isCopied: import("vue").ShallowRef<boolean, boolean>;
3
+ copyText: (text?: string | undefined) => Promise<void>;
5
4
  };
@@ -1,31 +1,34 @@
1
- import CheckIcon from "@gdsicon/vue/check";
2
- import CopyIcon from "@gdsicon/vue/copy";
3
- import { computed, markRaw, ref } from "vue";
1
+ import { shallowRef } from "vue";
4
2
  export function useCopyClick() {
5
3
  let copiedTimer;
6
- const isCopied = ref(false);
7
- const render = computed(() => {
8
- return markRaw(isCopied.value ? CheckIcon : CopyIcon);
9
- });
10
- async function onCopyClick(text) {
11
- clearTimeout(copiedTimer);
12
- if (typeof navigator.clipboard !== "undefined") {
13
- await navigator.clipboard.writeText(text || "");
14
- } else {
15
- hackCopy(text || "");
4
+ let copyPromise = null;
5
+ const isCopied = shallowRef(false);
6
+ async function copyText(text = "") {
7
+ if (copyPromise) {
8
+ return copyPromise;
16
9
  }
17
- isCopied.value = true;
18
- copiedTimer = setTimeout(() => {
19
- isCopied.value = false;
20
- }, 1500);
10
+ try {
11
+ await navigator.clipboard.writeText(text);
12
+ } catch {
13
+ legacyCopyText(text);
14
+ }
15
+ copyPromise = new Promise((resolve) => {
16
+ isCopied.value = true;
17
+ resolve();
18
+ clearTimeout(copiedTimer);
19
+ copiedTimer = setTimeout(() => {
20
+ isCopied.value = false;
21
+ copyPromise = null;
22
+ }, 1500);
23
+ });
24
+ return copyPromise;
21
25
  }
22
26
  return {
23
27
  isCopied,
24
- renderAs: render,
25
- onCopyClick
28
+ copyText
26
29
  };
27
30
  }
28
- function hackCopy(text) {
31
+ function legacyCopyText(text) {
29
32
  const textarea = document.createElement("textarea");
30
33
  textarea.value = text;
31
34
  document.body.appendChild(textarea);
@@ -1,5 +1,11 @@
1
1
  import type { EmitFn } from 'vue';
2
2
  export interface Options {
3
+ /**
4
+ * 是否启用正计时
5
+ * Whether to enable count up mode.
6
+ * @default false
7
+ */
8
+ invert?: boolean;
3
9
  /**
4
10
  * 是否激活
5
11
  * Whether the countdown is active.
@@ -37,12 +43,7 @@ export interface Options {
37
43
  millisecond?: boolean;
38
44
  }
39
45
  export declare function useCountdown<T extends Record<string, any>>(props: Options, emits: EmitFn<T>): {
46
+ clean: () => void;
40
47
  reset: () => void;
41
- times: import("vue").ComputedRef<{
42
- dd: string;
43
- hh: string;
44
- mm: string;
45
- ss: string;
46
- ms: string;
47
- }>;
48
+ timestamp: import("vue").ShallowRef<number, number>;
48
49
  };
@@ -1,130 +1,133 @@
1
- import { computed, onBeforeUnmount, shallowRef, watch } from "vue";
1
+ import { computed, shallowRef, watch } from "vue";
2
+ const UPDATE_INTERVAL = 34;
3
+ const MILLISECOND_LENGTH = 13;
4
+ function normalizeEndTime(endTime) {
5
+ return String(endTime).length >= MILLISECOND_LENGTH ? endTime : endTime * 1e3;
6
+ }
7
+ function normalizeDuration(duration, millisecond = true) {
8
+ return millisecond ? Math.round(duration) : Math.round(duration * 1e3);
9
+ }
2
10
  export function useCountdown(props, emits) {
3
- let pnow = -1;
4
- let finished = false;
5
- let isPaused = false;
6
- const UPDATE_INTERVAL = 34;
7
- const TIME_CONSTANTS = {
8
- DAY: 864e5,
9
- HOUR: 36e5,
10
- MINUTE: 6e4,
11
- SECOND: 1e3
11
+ const state = {
12
+ startTime: -1,
13
+ isFinished: false,
14
+ isPaused: false
12
15
  };
13
16
  const distanceRef = shallowRef(0);
14
- const durations = computed(() => {
15
- const { endTime, durations: durations2 = 0, millisecond } = props;
17
+ const durationRef = computed(() => {
18
+ const { endTime, durations = 0, millisecond, invert } = props;
16
19
  if (endTime) {
17
- const end = (String(endTime).length >= 13 ? endTime : endTime * 1e3) - Date.now();
18
- return Math.max(0, end);
20
+ const end = normalizeEndTime(endTime) - Date.now();
21
+ return invert ? Math.max(0, -end) : Math.max(0, end);
19
22
  }
20
- const time = millisecond ? Math.round(durations2) : Math.round(durations2 * 1e3);
23
+ const time = normalizeDuration(durations, millisecond);
21
24
  return Math.max(0, time);
22
25
  });
23
- const times = computed(() => {
24
- const { dd, hh, mm, ss, ms } = getTimeInfo(distanceRef.value);
25
- const formatMs = props.precision === 0 ? 0 : Math.floor(
26
- ms / (props.precision === 1 ? 100 : props.precision === 2 ? 10 : 1)
27
- );
28
- return {
29
- dd: String(dd).padStart(2, "0"),
30
- hh: String(hh).padStart(2, "0"),
31
- mm: String(mm).padStart(2, "0"),
32
- ss: String(ss).padStart(2, "0"),
33
- ms: formatMs.toString().padStart(props.precision || 0, "0")
34
- };
35
- });
36
- function getTimeInfo(time) {
37
- const dd = Math.floor(time / TIME_CONSTANTS.DAY);
38
- const hh = Math.floor(time % TIME_CONSTANTS.DAY / TIME_CONSTANTS.HOUR);
39
- const mm = Math.floor(time % TIME_CONSTANTS.HOUR / TIME_CONSTANTS.MINUTE);
40
- const ss = Math.floor(time % TIME_CONSTANTS.MINUTE / TIME_CONSTANTS.SECOND);
41
- const ms = Math.floor(time % TIME_CONSTANTS.SECOND);
42
- return { dd, hh, mm, ss, ms };
43
- }
44
- function getDistance(time) {
45
- return durations.value + pnow - time;
26
+ function getCurrentDistance(currentTime) {
27
+ if (props.invert) {
28
+ return currentTime - state.startTime;
29
+ }
30
+ return durationRef.value + state.startTime - currentTime;
46
31
  }
47
- function setDistance() {
48
- distanceRef.value = durations.value;
32
+ function setInitialDistance() {
33
+ distanceRef.value = props.invert ? 0 : durationRef.value;
49
34
  }
50
- function finish() {
51
- distanceRef.value = 0;
52
- finished = true;
53
- emits("finish");
35
+ function checkFinish(distance) {
36
+ const { durations, invert } = props;
37
+ if (invert) {
38
+ return durations !== void 0 && durations > 0 && distance >= durations;
39
+ }
40
+ return distance <= 0;
54
41
  }
55
42
  function reset() {
56
- pnow = performance.now();
57
- finished = false;
58
- isPaused = false;
59
- setDistance();
43
+ state.startTime = performance.now();
44
+ state.isFinished = false;
45
+ state.isPaused = false;
46
+ setInitialDistance();
60
47
  emits("reset");
61
48
  if (props.active) {
62
- frame();
49
+ startFrameLoop();
63
50
  }
64
51
  }
65
52
  let previousFrameTime = 0;
66
- function frame(timestamp) {
67
- const distance = getDistance(performance.now());
53
+ function startFrameLoop(timestamp) {
54
+ const currentTime = performance.now();
55
+ const distance = getCurrentDistance(currentTime);
68
56
  let isLastFrame = false;
69
- if (isPaused) {
57
+ if (state.isPaused) {
70
58
  if (distance < UPDATE_INTERVAL) {
71
59
  isLastFrame = true;
72
60
  } else {
73
61
  return;
74
62
  }
75
63
  }
76
- if (performance.now() - previousFrameTime < UPDATE_INTERVAL && !isLastFrame) {
77
- requestAnimationFrame(frame);
64
+ if (currentTime - previousFrameTime < UPDATE_INTERVAL && !isLastFrame) {
65
+ requestAnimationFrame(startFrameLoop);
78
66
  return;
79
67
  }
80
- previousFrameTime = timestamp;
81
- if (distance <= 0) {
82
- finish();
68
+ previousFrameTime = timestamp || currentTime;
69
+ if (checkFinish(distance)) {
70
+ onFinish();
83
71
  return;
84
72
  }
85
73
  distanceRef.value = Math.max(0, distance);
86
- requestAnimationFrame(frame);
74
+ requestAnimationFrame(startFrameLoop);
87
75
  }
88
- const unwatchActive = watch(
89
- () => props.active,
90
- (isActive) => {
91
- emits("change", isActive);
92
- if (isActive) {
93
- if (isPaused) {
94
- pnow = performance.now() - durations.value + distanceRef.value;
95
- } else {
96
- pnow = performance.now();
97
- }
98
- isPaused = false;
99
- if (finished && props.autoReset) {
100
- reset();
101
- } else if (finished) {
102
- return;
103
- }
104
- frame();
76
+ function onFinish() {
77
+ const { durations, invert } = props;
78
+ if (invert && durations !== void 0 && durations > 0) {
79
+ distanceRef.value = durations;
80
+ } else if (!invert) {
81
+ distanceRef.value = 0;
82
+ }
83
+ state.isFinished = true;
84
+ emits("finish");
85
+ }
86
+ function onActiveChange(isActive) {
87
+ emits("change", isActive);
88
+ if (isActive) {
89
+ if (state.isPaused) {
90
+ state.startTime = performance.now() - distanceRef.value;
105
91
  } else {
106
- isPaused = true;
92
+ state.startTime = performance.now();
93
+ if (props.invert) {
94
+ distanceRef.value = 0;
95
+ }
107
96
  }
108
- },
109
- { immediate: true }
97
+ state.isPaused = false;
98
+ if (state.isFinished && props.autoReset) {
99
+ reset();
100
+ } else if (state.isFinished) {
101
+ return;
102
+ }
103
+ startFrameLoop();
104
+ } else {
105
+ state.isPaused = true;
106
+ }
107
+ }
108
+ function onTimeChange() {
109
+ setInitialDistance();
110
+ state.isFinished = false;
111
+ if (props.active) {
112
+ reset();
113
+ }
114
+ }
115
+ const unwatchActive = watch(
116
+ () => props.active,
117
+ (isActive) => onActiveChange(isActive || false)
110
118
  );
111
119
  const unwatchTimes = watch(
112
120
  () => [props.durations, props.endTime],
113
- () => {
114
- setDistance();
115
- finished = false;
116
- if (props.active) {
117
- reset();
118
- }
119
- },
120
- { immediate: true }
121
+ () => onTimeChange()
121
122
  );
122
- onBeforeUnmount(() => {
123
+ function clean() {
123
124
  unwatchTimes();
124
125
  unwatchActive();
125
- });
126
+ }
127
+ setInitialDistance();
126
128
  return {
129
+ clean,
127
130
  reset,
128
- times
131
+ timestamp: distanceRef
129
132
  };
130
133
  }
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import type { App } from 'vue';
2
2
  export * from './components/index.js';
3
3
  export * from './composables/index.js';
4
- export declare const version = "0.0.31";
4
+ export declare const version = "0.0.32";
5
5
  export default function install(app: App, prefix?: string): void;
package/dist/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import * as components from "./components/index.js";
2
2
  export * from "./components/index.js";
3
3
  export * from "./composables/index.js";
4
- export const version = "0.0.31";
4
+ export const version = "0.0.32";
5
5
  export default function install(app, prefix = "P") {
6
6
  Object.entries(components).forEach(([key, component]) => {
7
7
  app.component(`${prefix}${key}`, component);
@@ -1,2 +1,2 @@
1
1
  /*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */
2
- @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-content:""}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-700:hsl(var(--color-red-700-value));--color-red-800:hsl(var(--color-red-800-value));--color-red-900:hsl(var(--color-red-900-value));--color-amber-600:hsl(var(--color-amber-600-value));--color-amber-700:hsl(var(--color-amber-700-value));--color-amber-800:hsl(var(--color-amber-800-value));--color-yellow-500:oklch(79.5% .184 86.047);--color-green-300:hsl(var(--color-green-300-value));--color-green-500:hsl(var(--color-green-500-value));--color-green-700:hsl(var(--color-green-700-value));--color-green-900:hsl(var(--color-green-900-value));--color-violet-100:oklch(94.3% .029 294.588);--color-violet-200:oklch(89.4% .057 293.283);--color-violet-400:oklch(70.2% .183 293.541);--color-violet-900:oklch(38% .189 293.745);--color-gray-100:hsl(var(--color-gray-100-value));--color-gray-200:hsl(var(--color-gray-200-value));--color-gray-300:hsl(var(--color-gray-300-value));--color-gray-500:hsl(var(--color-gray-500-value));--color-gray-600:hsl(var(--color-gray-600-value));--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height:calc(1.5/1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--tracking-tight:-.025em;--radius-xs:.125rem;--animate-spin:spin 1s linear infinite;--blur-xs:4px;--default-transition-duration:.2s;--default-transition-timing-function:ease-in-out;--color-primary:hsl(var(--primary));--color-border:hsl(var(--color-gray-300-value));--color-foreground:hsl(var(--color-gray-1000-value));--color-foreground-secondary:hsl(var(--color-gray-900-value));--color-background-100:hsl(var(--background-100-value));--color-gray-alpha-100:var(--color-gray-alpha-100-value);--color-gray-alpha-200:var(--color-gray-alpha-200-value);--color-gray-alpha-300:var(--color-gray-alpha-300-value);--color-gray-alpha-400:var(--color-gray-alpha-400-value);--color-gray-alpha-500:var(--color-gray-alpha-500-value);--color-gray-alpha-600:var(--color-gray-alpha-600-value);--shadow-border-default:var(--shadow-border-default-value);--shadow-border-small:var(--shadow-border-small-value);--shadow-border-medium:var(--shadow-border-medium-value);--shadow-border-large:var(--shadow-border-large-value);--shadow-border-tooltip:var(--shadow-border-tooltip-value);--shadow-border-menu:var(--shadow-border-menu-value);--shadow-border-modal:var(--shadow-border-modal-value);--shadow-border-fullscreen:var(--shadow-border-fullscreen-value)}}@layer base{*{border-color:hsl(var(--color-gray-300-value))}}@layer components{.pxd-input--border{border:1px solid var(--border-color,var(--color-gray-alpha-300))}.pxd-input--border:not(.is-disabled,.is-readonly):hover,.pxd-input--border:not(.is-disabled,.is-readonly):focus-within{--border-color:var(--color-primary)}.pxd-input--border:not(.is-disabled,.is-readonly):focus-within{box-shadow:0 0 0 3px hsla(var(--primary),.2)}.pxd-input--border.is-error:not(:focus)::placeholder{color:var(--color-red-900)!important}.pxd-input--border.is-error,.pxd-input--border.is-error:focus-within{--border-color:hsl(var(--color-red-900-value));box-shadow:0 0 0 3px hsl(var(--color-red-300-value))}.pxd-input--border.is-error:focus-within,.pxd-input--border.is-error:not(.is-disabled,.is-readonly):hover{--border-color:hsl(var(--color-red-900-value));box-shadow:0 0 0 3px hsl(var(--color-red-500-value))}.pxd-form--label{max-width:100%;margin-bottom:calc(var(--spacing)*1.5);font-size:var(--text-sm);color:var(--color-foreground-secondary)}}@layer utilities{.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.smallest{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.-inset-px{inset:-1px}.inset-0{inset:calc(var(--spacing)*0)}.-top-1{top:calc(var(--spacing)*-1)}.top-0{top:calc(var(--spacing)*0)}.top-1\/2{top:50%}.-right-5{right:calc(var(--spacing)*-5)}.right-0{right:calc(var(--spacing)*0)}.right-1{right:calc(var(--spacing)*1)}.-bottom-1{bottom:calc(var(--spacing)*-1)}.bottom-0{bottom:calc(var(--spacing)*0)}.-left-1{left:calc(var(--spacing)*-1)}.-left-5{left:calc(var(--spacing)*-5)}.left-0{left:calc(var(--spacing)*0)}.left-px{left:1px}.isolate{isolation:isolate}.z-\(--z\,10\){z-index:var(--z,10)}.z-0{z-index:0}.z-1{z-index:1}.z-10{z-index:10}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.container\!{width:100%!important}@media (min-width:40rem){.container\!{max-width:40rem!important}}@media (min-width:48rem){.container\!{max-width:48rem!important}}@media (min-width:64rem){.container\!{max-width:64rem!important}}@media (min-width:80rem){.container\!{max-width:80rem!important}}@media (min-width:96rem){.container\!{max-width:96rem!important}}.m-0{margin:calc(var(--spacing)*0)}.mx-auto{margin-inline:auto}.mx-px{margin-inline:1px}.mt-\(--mt\){margin-top:var(--mt)}.mt-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-4{margin-top:calc(var(--spacing)*4)}.mr-1{margin-right:calc(var(--spacing)*1)}.mr-1\.5{margin-right:calc(var(--spacing)*1.5)}.mr-2{margin-right:calc(var(--spacing)*2)}.mr-3{margin-right:calc(var(--spacing)*3)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.-ml-0\.5{margin-left:calc(var(--spacing)*-.5)}.-ml-3{margin-left:calc(var(--spacing)*-3)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-1\.5{margin-left:calc(var(--spacing)*1.5)}.ml-3{margin-left:calc(var(--spacing)*3)}.scrollbar-hidden{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.scrollbar-hidden::-webkit-scrollbar{display:none}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.aspect-square{aspect-ratio:1}.size-\(--size\){width:var(--size);height:var(--size)}.size-1\/2{width:50%;height:50%}.size-3{width:calc(var(--spacing)*3);height:calc(var(--spacing)*3)}.size-4{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.size-6{width:calc(var(--spacing)*6);height:calc(var(--spacing)*6)}.size-15{width:calc(var(--spacing)*15);height:calc(var(--spacing)*15)}.size-\[calc\(1em\/4\)\]{width:.25em;height:.25em}.size-em{width:1em;height:1em}.size-full{width:100%;height:100%}.size-max{width:max-content;height:max-content}.h-\(--h\){height:var(--h)}.h-\(--scrollbar-size\){height:var(--scrollbar-size)}.h-0\.5{height:calc(var(--spacing)*.5)}.h-2{height:calc(var(--spacing)*2)}.h-2\.5{height:calc(var(--spacing)*2.5)}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-4\.5{height:calc(var(--spacing)*4.5)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-7\.5{height:calc(var(--spacing)*7.5)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-full{height:100%}.h-max{height:max-content}.max-h-68{max-height:calc(var(--spacing)*68)}.max-h-full{max-height:100%}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-3\.5{min-height:calc(var(--spacing)*3.5)}.min-h-7\.5{min-height:calc(var(--spacing)*7.5)}.min-h-9{min-height:calc(var(--spacing)*9)}.min-h-10{min-height:calc(var(--spacing)*10)}.min-h-13{min-height:calc(var(--spacing)*13)}.min-h-\[inherit\]{min-height:inherit}.w-\(--scrollbar-size\){width:var(--scrollbar-size)}.w-\(--w\){width:var(--w)}.w-1\.5{width:calc(var(--spacing)*1.5)}.w-2{width:calc(var(--spacing)*2)}.w-2\.5{width:calc(var(--spacing)*2.5)}.w-3{width:calc(var(--spacing)*3)}.w-6{width:calc(var(--spacing)*6)}.w-7{width:calc(var(--spacing)*7)}.w-7\.5{width:calc(var(--spacing)*7.5)}.w-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-11{width:calc(var(--spacing)*11)}.w-fit{width:fit-content}.w-full{width:100%}.w-max{width:max-content}.max-w-full{max-width:100%}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-3{min-width:calc(var(--spacing)*3)}.min-w-4{min-width:calc(var(--spacing)*4)}.min-w-full{min-width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.border-separate{border-collapse:separate}.-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-\(--tx\){--tw-translate-x:var(--tx);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-1\/2{--tw-translate-x:calc(1/2*100%);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/3{--tw-translate-y:calc(calc(1/3*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-z-0{--tw-translate-z:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)var(--tw-translate-z)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-130{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-y-90{--tw-scale-y:90%;scale:var(--tw-scale-x)var(--tw-scale-y)}.-rotate-\[85deg\]{rotate:-85deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.transform-gpu{transform:translateZ(0)var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-manipulation{touch-action:manipulation}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.list-none{list-style-type:none}.appearance-none{appearance:none}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.items-stretch{align-items:stretch}.justify-around{justify-content:space-around}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-evenly{justify-content:space-evenly}.justify-start{justify-content:flex-start}.justify-stretch{justify-content:stretch}.gap-\(--gap-xs\){gap:var(--gap-xs)}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-scroll{overflow:scroll}.overflow-visible{overflow:visible}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-inherit{border-radius:inherit}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-none{border-radius:0}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.rounded-xs{border-radius:var(--radius-xs)}.rounded-t-lg{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.rounded-l-inherit{border-top-left-radius:inherit;border-bottom-left-radius:inherit}.rounded-r-inherit{border-top-right-radius:inherit;border-bottom-right-radius:inherit}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-none{--tw-border-style:none;border-style:none}.border-amber-100{border-color:hsl(var(--color-amber-100-value))}.border-amber-500{border-color:hsl(var(--color-amber-500-value))}.border-background-100{border-color:hsl(var(--background-100-value))}.border-blue-100{border-color:hsl(var(--color-blue-100-value))}.border-blue-500{border-color:hsl(var(--color-blue-500-value))}.border-gray-100{border-color:hsl(var(--color-gray-100-value))}.border-gray-300{border-color:hsl(var(--color-gray-300-value))}.border-gray-400{border-color:hsl(var(--color-gray-400-value))}.border-gray-500{border-color:hsl(var(--color-gray-500-value))}.border-gray-600{border-color:hsl(var(--color-gray-600-value))}.border-gray-alpha-300{border-color:var(--color-gray-alpha-300-value)}.border-gray-alpha-400{border-color:var(--color-gray-alpha-400-value)}.border-input{border-color:var(--color-gray-alpha-300)}.border-primary{border-color:hsl(var(--primary))}.border-red-100{border-color:hsl(var(--color-red-100-value))}.border-red-500{border-color:hsl(var(--color-red-500-value))}.border-teal-100{border-color:hsl(var(--color-teal-100-value))}.border-teal-400{border-color:hsl(var(--color-teal-400-value))}.border-transparent{border-color:#0000}.border-violet-100{border-color:var(--color-violet-100)}.border-violet-400{border-color:var(--color-violet-400)}.\!bg-primary{background-color:hsl(var(--primary))!important}.bg-\(--color\){background-color:var(--color)}.bg-\(--ibc\){background-color:var(--ibc)}.bg-\(--mc\){background-color:var(--mc)}.bg-\(--scrollbar-color\){background-color:var(--scrollbar-color)}.bg-\[\#26C941\]{background-color:#26c941}.bg-\[\#FE5F57\]{background-color:#fe5f57}.bg-\[\#FEBB2E\]{background-color:#febb2e}.bg-amber-200{background-color:hsl(var(--color-amber-200-value))}.bg-amber-700{background-color:hsl(var(--color-amber-700-value))}.bg-amber-800{background-color:hsl(var(--color-amber-800-value))}.bg-background-100{background-color:hsl(var(--background-100-value))}.bg-background-200{background-color:hsl(var(--background-200-value))}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black)40%,transparent)}}.bg-blue-200{background-color:hsl(var(--color-blue-200-value))}.bg-blue-700{background-color:hsl(var(--color-blue-700-value))}.bg-border{background-color:hsl(var(--color-gray-300-value))}.bg-current{background-color:currentColor}.bg-gray-100{background-color:hsl(var(--color-gray-100-value))}.bg-gray-200{background-color:hsl(var(--color-gray-200-value))}.bg-gray-600{background-color:hsl(var(--color-gray-600-value))}.bg-gray-700{background-color:hsl(var(--color-gray-700-value))}.bg-gray-900{background-color:hsl(var(--color-gray-900-value))}.bg-gray-1000{background-color:hsl(var(--color-gray-1000-value))}.bg-gray-alpha-100{background-color:var(--color-gray-alpha-100-value)}.bg-gray-alpha-200{background-color:var(--color-gray-alpha-200-value)}.bg-gray-alpha-400{background-color:var(--color-gray-alpha-400-value)}.bg-green-200{background-color:hsl(var(--color-green-200-value))}.bg-green-600{background-color:hsl(var(--color-green-600-value))}.bg-green-700{background-color:hsl(var(--color-green-700-value))}.bg-green-800{background-color:hsl(var(--color-green-800-value))}.bg-pink-200{background-color:hsl(var(--color-pink-200-value))}.bg-pink-700{background-color:hsl(var(--color-pink-700-value))}.bg-primary{background-color:hsl(var(--primary))}.bg-purple-200{background-color:hsl(var(--color-purple-200-value))}.bg-purple-700{background-color:hsl(var(--color-purple-700-value))}.bg-red-200{background-color:hsl(var(--color-red-200-value))}.bg-red-600{background-color:hsl(var(--color-red-600-value))}.bg-red-700{background-color:hsl(var(--color-red-700-value))}.bg-red-800{background-color:hsl(var(--color-red-800-value))}.bg-teal-200{background-color:hsl(var(--color-teal-200-value))}.bg-teal-700{background-color:hsl(var(--color-teal-700-value))}.bg-transparent{background-color:#0000}.bg-violet-200{background-color:var(--color-violet-200)}.bg-yellow-500{background-color:var(--color-yellow-500)}.bg-cover{background-size:cover}.object-cover{object-fit:cover}.\!p-0{padding:calc(var(--spacing)*0)!important}.p-0{padding:calc(var(--spacing)*0)}.p-1{padding:calc(var(--spacing)*1)}.p-1\.5{padding:calc(var(--spacing)*1.5)}.p-2{padding:calc(var(--spacing)*2)}.p-2\.5{padding:calc(var(--spacing)*2.5)}.p-3{padding:calc(var(--spacing)*3)}.p-3\.5{padding:calc(var(--spacing)*3.5)}.p-4{padding:calc(var(--spacing)*4)}.p-px{padding:1px}.px-1{padding-inline:calc(var(--spacing)*1)}.px-1\.5{padding-inline:calc(var(--spacing)*1.5)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-2\.5{padding-inline:calc(var(--spacing)*2.5)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-3\.5{padding-inline:calc(var(--spacing)*3.5)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-18{padding-inline:calc(var(--spacing)*18)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-2\.5{padding-block:calc(var(--spacing)*2.5)}.py-3{padding-block:calc(var(--spacing)*3)}.py-4{padding-block:calc(var(--spacing)*4)}.py-12{padding-block:calc(var(--spacing)*12)}.py-\[3px\]{padding-block:3px}.pr-0{padding-right:calc(var(--spacing)*0)}.pr-0\.5{padding-right:calc(var(--spacing)*.5)}.pr-1{padding-right:calc(var(--spacing)*1)}.pr-1\.5{padding-right:calc(var(--spacing)*1.5)}.pr-2{padding-right:calc(var(--spacing)*2)}.pr-2\.5{padding-right:calc(var(--spacing)*2.5)}.pr-3\.5{padding-right:calc(var(--spacing)*3.5)}.pr-5{padding-right:calc(var(--spacing)*5)}.pr-6{padding-right:calc(var(--spacing)*6)}.pr-9{padding-right:calc(var(--spacing)*9)}.pr-14{padding-right:calc(var(--spacing)*14)}.pr-\[3px\]{padding-right:3px}.pb-6{padding-bottom:calc(var(--spacing)*6)}.pl-0\.5{padding-left:calc(var(--spacing)*.5)}.pl-1\.5{padding-left:calc(var(--spacing)*1.5)}.pl-2{padding-left:calc(var(--spacing)*2)}.pl-2\.5{padding-left:calc(var(--spacing)*2.5)}.pl-3{padding-left:calc(var(--spacing)*3)}.pl-3\.5{padding-left:calc(var(--spacing)*3.5)}.pl-6{padding-left:calc(var(--spacing)*6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[13px\]{font-size:13px}.leading-4{--tw-leading:calc(var(--spacing)*4);line-height:calc(var(--spacing)*4)}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-balance{text-wrap:balance}.text-nowrap{text-wrap:nowrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.text-amber-900{color:hsl(var(--color-amber-900-value))}.text-background-100{color:hsl(var(--background-100-value))}.text-black{color:var(--color-black)}.text-blue-900{color:hsl(var(--color-blue-900-value))}.text-foreground{color:hsl(var(--color-gray-1000-value))}.text-foreground-secondary{color:hsl(var(--color-gray-900-value))}.text-gray-100{color:hsl(var(--color-gray-100-value))}.text-gray-500{color:hsl(var(--color-gray-500-value))}.text-gray-700{color:hsl(var(--color-gray-700-value))}.text-gray-900{color:hsl(var(--color-gray-900-value))}.text-gray-1000{color:hsl(var(--color-gray-1000-value))}.text-green-900{color:hsl(var(--color-green-900-value))}.text-pink-900{color:hsl(var(--color-pink-900-value))}.text-primary{color:hsl(var(--primary))}.text-purple-900{color:hsl(var(--color-purple-900-value))}.text-red-900{color:hsl(var(--color-red-900-value))}.text-teal-900{color:hsl(var(--color-teal-900-value))}.text-violet-900{color:var(--color-violet-900)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.\!no-underline{text-decoration-line:none!important}.underline{text-decoration-line:underline}.opacity-\(--sv\){opacity:var(--sv)}.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-50{opacity:.5}.opacity-100{opacity:1}.mix-blend-overlay{mix-blend-mode:overlay}.shadow-border-menu{--tw-shadow:var(--shadow-border-menu-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-modal{--tw-shadow:var(--shadow-border-modal-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-small{--tw-shadow:var(--shadow-border-small-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-tooltip{--tw-shadow:var(--shadow-border-tooltip-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.peer:focus-visible~.peer-focus-ring,.self-focus-ring:focus-visible{box-shadow:0 0 0 2px var(--color-background-100),0 0 0 4px hsl(var(--ring))}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-xs{--tw-backdrop-blur:blur(var(--blur-xs));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.duration-50{--tw-duration:50ms;transition-duration:50ms}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.will-change-transform{will-change:transform}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.\[--book-width\:var\(--width-xs\)\]{--book-width:var(--width-xs)}.\[--mt\:2px\]{--mt:2px}.\[--mt\:4px\]{--mt:4px}.\[--tx\:0\]{--tx:0}.transform-3d{transform-style:preserve-3d}@media (hover:hover){.group-hover\:text-foreground:is(:where(.group):hover *){color:hsl(var(--color-gray-1000-value))}.group-hover\/checkbox\:bg-gray-200:is(:where(.group\/checkbox):hover *){background-color:hsl(var(--color-gray-200-value))}.group-hover\/collapse\:will-change-\[height\]:is(:where(.group\/collapse):hover *){will-change:height}.group-hover\/radio\:bg-gray-200:is(:where(.group\/radio):hover *){background-color:hsl(var(--color-gray-200-value))}.group-hover\/toggle\:will-change-transform:is(:where(.group\/toggle):hover *){will-change:transform}}.group-data-\[direction\=horizontal\]\:flex:is(:where(.group)[data-direction=horizontal] *){display:flex}.group-data-\[direction\=vertical\]\:rotate-90:is(:where(.group)[data-direction=vertical] *){rotate:90deg}.group-data-\[header\=true\]\:pt-6:is(:where(.group)[data-header=true] *){padding-top:calc(var(--spacing)*6)}.group-data-\[indicator-position\=left\]\:flex-col:is(:where(.group)[data-indicator-position=left] *),.group-data-\[indicator-position\=right\]\:flex-col:is(:where(.group)[data-indicator-position=right] *){flex-direction:column}.group-data-\[state\=open\]\/collapse\:-rotate-180:is(:where(.group\/collapse)[data-state=open] *){rotate:-180deg}.peer-checked\:bg-\(--abc\):is(:where(.peer):checked~*){background-color:var(--abc)}.peer-checked\:bg-gray-100:is(:where(.peer):checked~*){background-color:hsl(var(--color-gray-100-value))}.peer-checked\:text-foreground:is(:where(.peer):checked~*){color:hsl(var(--color-gray-1000-value))}.peer-checked\:opacity-50:is(:where(.peer):checked~*){opacity:.5}.peer-checked\:opacity-100:is(:where(.peer):checked~*){opacity:1}.peer-checked\:\[--tx\:100\%\]:is(:where(.peer):checked~*){--tx:100%}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:text-gray-800:is(:where(.peer):disabled~*){color:hsl(var(--color-gray-800-value))}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.placeholder\:text-gray-600::placeholder{color:hsl(var(--color-gray-600-value))}.placeholder\:select-none::placeholder{-webkit-user-select:none;user-select:none}.before\:content-\[attr\(data-prompt\)\]:before{content:var(--tw-content);--tw-content:attr(data-prompt);content:var(--tw-content)}.before\:select-none:before{content:var(--tw-content);-webkit-user-select:none;user-select:none}.after\:size-2:after{content:var(--tw-content);width:calc(var(--spacing)*2);height:calc(var(--spacing)*2)}.after\:scale-40:after{content:var(--tw-content);--tw-scale-x:40%;--tw-scale-y:40%;--tw-scale-z:40%;scale:var(--tw-scale-x)var(--tw-scale-y)}.after\:rounded-full:after{content:var(--tw-content);border-radius:3.40282e38px}.after\:bg-gray-500:after{content:var(--tw-content);background-color:hsl(var(--color-gray-500-value))}.after\:bg-primary:after{content:var(--tw-content);background-color:hsl(var(--primary))}.after\:opacity-0:after{content:var(--tw-content);opacity:0}.after\:content-\[attr\(aria-label\)\]:after{content:var(--tw-content);--tw-content:attr(aria-label);content:var(--tw-content)}.peer-checked\:after\:scale-100:is(:where(.peer):checked~*):after{content:var(--tw-content);--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x)var(--tw-scale-y)}.peer-checked\:after\:opacity-100:is(:where(.peer):checked~*):after{content:var(--tw-content);opacity:1}.first\:justify-start:first-child{justify-content:flex-start}.last\:justify-end:last-child{justify-content:flex-end}.empty\:hidden:empty{display:none}.empty\:py-3:empty{padding-block:calc(var(--spacing)*3)}@media (hover:hover){.hover\:z-1:hover{z-index:1}.hover\:z-10:hover{z-index:10}.hover\:scale-130:hover{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:border-gray-500:hover{border-color:hsl(var(--color-gray-500-value))}.hover\:bg-\(--scrollbar-hover-color\):hover{background-color:var(--scrollbar-hover-color)}.hover\:bg-amber-700:hover{background-color:hsl(var(--color-amber-700-value))}.hover\:bg-background-hover:hover{background-color:var(--color-gray-alpha-200-value)}.hover\:bg-gray-100:hover{background-color:hsl(var(--color-gray-100-value))}.hover\:bg-gray-alpha-400:hover{background-color:var(--color-gray-alpha-400-value)}.hover\:bg-green-700:hover{background-color:hsl(var(--color-green-700-value))}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/80:hover{background-color:color-mix(in oklab,hsl(var(--primary))80%,transparent)}}.hover\:bg-red-700:hover{background-color:hsl(var(--color-red-700-value))}.hover\:text-foreground:hover{color:hsl(var(--color-gray-1000-value))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-60:hover{opacity:.6}.hover\:will-change-transform:hover{will-change:transform}.hover\:\[--sv\:1\]:hover{--sv:1}.hover\:after\:bg-primary\/20:hover:after{content:var(--tw-content);background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.hover\:after\:bg-primary\/20:hover:after{background-color:color-mix(in oklab,hsl(var(--primary))20%,transparent)}}}.focus\:placeholder\:opacity-0:focus::placeholder{opacity:0}.active\:z-10:active{z-index:10}.active\:scale-130:active{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\:bg-\(--scrollbar-hover-color\):active{background-color:var(--scrollbar-hover-color)}.active\:bg-amber-900:active{background-color:hsl(var(--color-amber-900-value))}.active\:bg-background-active:active{background-color:var(--color-gray-alpha-300-value)}.active\:bg-gray-100:active{background-color:hsl(var(--color-gray-100-value))}.active\:bg-gray-900:active{background-color:hsl(var(--color-gray-900-value))}.active\:bg-green-900:active{background-color:hsl(var(--color-green-900-value))}.active\:bg-red-900:active{background-color:hsl(var(--color-red-900-value))}.active\:opacity-80:active{opacity:.8}.active\:opacity-100:active{opacity:1}.active\:select-none:active{-webkit-user-select:none;user-select:none}.active\:after\:bg-primary\/30:active:after{content:var(--tw-content);background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.active\:after\:bg-primary\/30:active:after{background-color:color-mix(in oklab,hsl(var(--primary))30%,transparent)}}@media (hover:hover){.enabled\:hover\:bg-background-hover:enabled:hover{background-color:var(--color-gray-alpha-200-value)}.enabled\:hover\:text-gray-1000:enabled:hover{color:hsl(var(--color-gray-1000-value))}}.enabled\:active\:bg-background-active:enabled:active{background-color:var(--color-gray-alpha-300-value)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-100:disabled{background-color:hsl(var(--color-gray-100-value))}.disabled\:text-gray-700:disabled{color:hsl(var(--color-gray-700-value))}.disabled\:placeholder\:text-gray-400:disabled::placeholder{color:hsl(var(--color-gray-400-value))}.data-\[blur\=true\]\:backdrop-blur-xs[data-blur=true]{--tw-backdrop-blur:blur(var(--blur-xs));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.data-\[direction\=vertical\]\:flex-col[data-direction=vertical]{flex-direction:column}.data-\[enterable\=false\]\:pointer-events-none[data-enterable=false]{pointer-events:none}.data-\[selected\=true\]\:bg-gray-alpha-100[data-selected=true]{background-color:var(--color-gray-alpha-100-value)}@media (prefers-reduced-motion:no-preference){.motion-safe\:animate-spin{animation:var(--animate-spin)}.motion-safe\:transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:duration-200{--tw-duration:.2s;transition-duration:.2s}}.after\:motion-safe\:transition-colors:after{content:var(--tw-content)}@media (prefers-reduced-motion:no-preference){.after\:motion-safe\:transition-colors:after{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:after\:transition-all:after{content:var(--tw-content);transition-property:all;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}}@media (prefers-reduced-motion:reduce){.motion-reduce\:opacity-20{opacity:.2}.motion-reduce\:opacity-50{opacity:.5}.motion-reduce\:opacity-80{opacity:.8}}@media not all and (min-width:64rem){.max-lg\:hidden{display:none}}@media not all and (min-width:48rem){.max-md\:hidden{display:none}.max-md\:first\:flex-none:first-child{flex:none}}@media (min-width:40rem){.sm\:pointer-events-auto{pointer-events:auto}.sm\:top-1\/2{top:50%}.sm\:left-1\/2{left:50%}.sm\:w-\[calc\(var\(--w\,540\)\*1px\)\]{width:calc(var(--w,540)*1px)}.sm\:max-w-\(--max-width\){max-width:var(--max-width)}.sm\:-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.sm\:-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.sm\:flex-col{flex-direction:column}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:gap-\(--gap-sm\){gap:var(--gap-sm)}.sm\:rounded-xl{border-radius:calc(var(--radius) + 4px)}.sm\:bg-background-100\/80{background-color:hsl(var(--background-100-value))}@supports (color:color-mix(in lab, red, red)){.sm\:bg-background-100\/80{background-color:color-mix(in oklab,hsl(var(--background-100-value))80%,transparent)}}.sm\:p-0{padding:calc(var(--spacing)*0)}.sm\:py-6{padding-block:calc(var(--spacing)*6)}.sm\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.sm\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.sm\:\[--book-width\:var\(--width-sm\)\]{--book-width:var(--width-sm)}.sm\:\[--o\:0\]{--o:0}.sm\:\[--sv\:0\]{--sv:0}.sm\:\[--t\:scale\(0\.98\)\]{--t:scale(.98)}}@media (min-width:48rem){.md\:flex-col{flex-direction:column}.md\:flex-row{flex-direction:row}.md\:gap-\(--gap-md\){gap:var(--gap-md)}.md\:gap-6{gap:calc(var(--spacing)*6)}.md\:\[--book-width\:var\(--width-md\)\]{--book-width:var(--width-md)}.md\:first\:max-w-\[140px\]:first-child,.md\:last\:max-w-\[140px\]:last-child{max-width:140px}}@media (min-width:64rem){.lg\:max-w-xs{max-width:var(--container-xs)}.lg\:flex-col{flex-direction:column}.lg\:flex-row{flex-direction:row}.lg\:gap-\(--gap-lg\){gap:var(--gap-lg)}.lg\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.lg\:\[--book-width\:var\(--width-lg\)\]{--book-width:var(--width-lg)}}@media (min-width:80rem){.xl\:flex-col{flex-direction:column}.xl\:flex-row{flex-direction:row}.xl\:gap-\(--gap-xl\){gap:var(--gap-xl)}.xl\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.xl\:\[--book-width\:var\(--width-xl\)\]{--book-width:var(--width-xl)}}.dark\:bg-background-100:is(.dark *){background-color:hsl(var(--background-100-value))}.dark\:bg-background-200:is(.dark *){background-color:hsl(var(--background-200-value))}.dark\:text-gray-100:is(.dark *){color:hsl(var(--color-gray-100-value))}.dark\:text-gray-1000:is(.dark *){color:hsl(var(--color-gray-1000-value))}.\[\&\:nth-child\(n\+2\)\]\:-ml-3:nth-child(n+2){margin-left:calc(var(--spacing)*-3)}}:root{--radius:.5rem;--background-100-value:0,0%,100%;--background-200-value:0,0%,97%;--ring:var(--color-blue-900-value);--primary:var(--color-gray-1000-value);--color-gray-alpha-100-value:#0000000d;--color-gray-alpha-200-value:#00000014;--color-gray-alpha-300-value:#0000001f;--color-gray-alpha-400-value:#0000002b;--color-gray-alpha-500-value:#00000036;--color-gray-alpha-600-value:#00000057;--color-gray-alpha-700-value:#00000070;--color-gray-alpha-800-value:#00000082;--color-gray-alpha-900-value:#0000009c;--color-gray-alpha-1000-value:#000000e8;--color-gray-100-value:0,0%,95%;--color-gray-200-value:0,0%,93%;--color-gray-300-value:0,0%,90%;--color-gray-400-value:0,0%,85%;--color-gray-500-value:0,0%,79%;--color-gray-600-value:0,0%,66%;--color-gray-700-value:0,0%,56%;--color-gray-800-value:0,0%,49%;--color-gray-900-value:0,0%,40%;--color-gray-1000-value:0,0%,9%;--color-blue-100-value:212,100%,97%;--color-blue-200-value:210,100%,96%;--color-blue-300-value:210,100%,94%;--color-blue-400-value:209,100%,90%;--color-blue-500-value:209,100%,80%;--color-blue-600-value:208,100%,66%;--color-blue-700-value:212,100%,48%;--color-blue-800-value:212,100%,41%;--color-blue-900-value:211,100%,42%;--color-blue-1000-value:211,100%,15%;--color-red-100-value:0,100%,97%;--color-red-200-value:0,100%,96%;--color-red-300-value:0,100%,95%;--color-red-400-value:0,90%,92%;--color-red-500-value:0,82%,85%;--color-red-600-value:359,90%,71%;--color-red-700-value:358,75%,59%;--color-red-800-value:358,70%,52%;--color-red-900-value:358,66%,48%;--color-red-1000-value:355,49%,15%;--color-amber-100-value:39,100%,95%;--color-amber-200-value:44,100%,92%;--color-amber-300-value:43,96%,90%;--color-amber-400-value:42,100%,78%;--color-amber-500-value:38,100%,71%;--color-amber-600-value:36,90%,62%;--color-amber-700-value:39,100%,57%;--color-amber-800-value:35,100%,52%;--color-amber-900-value:30,100%,32%;--color-amber-1000-value:20,79%,17%;--color-green-100-value:120,60%,96%;--color-green-200-value:120,60%,95%;--color-green-300-value:120,60%,91%;--color-green-400-value:122,60%,86%;--color-green-500-value:124,60%,75%;--color-green-600-value:125,60%,64%;--color-green-700-value:131,41%,46%;--color-green-800-value:132,43%,39%;--color-green-900-value:133,50%,32%;--color-green-1000-value:128,29%,15%;--color-teal-100-value:169,70%,96%;--color-teal-200-value:167,70%,94%;--color-teal-300-value:168,70%,90%;--color-teal-400-value:170,70%,85%;--color-teal-500-value:170,70%,72%;--color-teal-600-value:170,70%,57%;--color-teal-700-value:173,80%,36%;--color-teal-800-value:173,83%,30%;--color-teal-900-value:174,91%,25%;--color-teal-1000-value:171,80%,13%;--color-purple-100-value:276,100%,97%;--color-purple-200-value:277,87%,97%;--color-purple-300-value:274,78%,95%;--color-purple-400-value:276,71%,92%;--color-purple-500-value:274,70%,82%;--color-purple-600-value:273,72%,73%;--color-purple-700-value:272,51%,54%;--color-purple-800-value:272,47%,45%;--color-purple-900-value:274,71%,43%;--color-purple-1000-value:276,100%,15%;--color-pink-100-value:330,100%,96%;--color-pink-200-value:340,90%,96%;--color-pink-300-value:340,82%,94%;--color-pink-400-value:341,76%,91%;--color-pink-500-value:340,75%,84%;--color-pink-600-value:341,75%,73%;--color-pink-700-value:336,80%,58%;--color-pink-800-value:336,74%,51%;--color-pink-900-value:336,65%,45%;--color-pink-1000-value:333,74%,15%;--shadow-border-default-value:0 0 0 1px #00000014;--shadow-border-small-value:0 0 0 1px #00000014,0 1px 2px 0 #0000000a;--shadow-border-medium-value:0 0 0 1px #00000014,0px 2px 2px #0000000a,0px 8px 8px -8px #0000000a;--shadow-border-large-value:0 0 0 1px #00000014,0px 2px 2px #0000000a,0px 8px 16px -4px #0000000a;--shadow-border-tooltip-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 4px 8px #0000000a;--shadow-border-menu-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 4px 8px -4px #0000000a,0px 16px 24px -8px #0000000f;--shadow-border-modal-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;--shadow-border-fullscreen-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;text-autospace:auto;font-synthesis:none;color-scheme:light;background-color:var(--color-background-100);color:var(--color-foreground)}:root.dark{--background-100-value:0,0%,5%;--background-200-value:0,0%,0%;--color-gray-alpha-100-value:#ffffff0f;--color-gray-alpha-200-value:#ffffff17;--color-gray-alpha-300-value:#ffffff21;--color-gray-alpha-400-value:#ffffff24;--color-gray-alpha-500-value:#ffffff3d;--color-gray-alpha-600-value:#ffffff82;--color-gray-alpha-700-value:#ffffff8a;--color-gray-alpha-800-value:#ffffff78;--color-gray-alpha-900-value:#ffffff9c;--color-gray-alpha-1000-value:#ffffffeb;--color-gray-100-value:0,0%,10%;--color-gray-200-value:0,0%,12%;--color-gray-300-value:0,0%,16%;--color-gray-400-value:0,0%,18%;--color-gray-500-value:0,0%,27%;--color-gray-600-value:0,0%,53%;--color-gray-700-value:0,0%,56%;--color-gray-800-value:0,0%,49%;--color-gray-900-value:0,0%,63%;--color-gray-1000-value:0,0%,93%;--color-blue-100-value:216,50%,12%;--color-blue-200-value:214,59%,15%;--color-blue-300-value:213,71%,20%;--color-blue-400-value:212,78%,23%;--color-blue-500-value:211,86%,27%;--color-blue-600-value:206,100%,50%;--color-blue-700-value:212,100%,48%;--color-blue-800-value:212,100%,41%;--color-blue-900-value:210,100%,66%;--color-blue-1000-value:206,100%,96%;--color-red-100-value:357,37%,12%;--color-red-200-value:357,46%,16%;--color-red-300-value:356,54%,22%;--color-red-400-value:357,55%,26%;--color-red-500-value:357,60%,32%;--color-red-600-value:358,75%,59%;--color-red-700-value:358,75%,59%;--color-red-800-value:358,69%,52%;--color-red-900-value:358,100%,69%;--color-red-1000-value:353,90%,96%;--color-amber-100-value:35,100%,8%;--color-amber-200-value:32,100%,10%;--color-amber-300-value:33,100%,15%;--color-amber-400-value:35,100%,17%;--color-amber-500-value:35,91%,22%;--color-amber-600-value:39,85%,49%;--color-amber-700-value:39,100%,57%;--color-amber-800-value:35,100%,52%;--color-amber-900-value:39,90%,50%;--color-amber-1000-value:40,94%,93%;--color-green-100-value:136,50%,9%;--color-green-200-value:137,50%,12%;--color-green-300-value:136,50%,14%;--color-green-400-value:135,70%,16%;--color-green-500-value:135,70%,23%;--color-green-600-value:135,70%,34%;--color-green-700-value:131,41%,46%;--color-green-800-value:132,43%,39%;--color-green-900-value:131,43%,57%;--color-green-1000-value:136,73%,94%;--color-teal-100-value:169,78%,7%;--color-teal-200-value:170,74%,9%;--color-teal-300-value:171,75%,13%;--color-teal-400-value:171,85%,13%;--color-teal-500-value:172,85%,20%;--color-teal-600-value:172,85%,32%;--color-teal-700-value:173,80%,36%;--color-teal-800-value:173,83%,30%;--color-teal-900-value:174,90%,41%;--color-teal-1000-value:166,71%,93%;--color-purple-100-value:283,30%,12%;--color-purple-200-value:281,38%,16%;--color-purple-300-value:279,44%,23%;--color-purple-400-value:277,46%,28%;--color-purple-500-value:274,49%,35%;--color-purple-600-value:272,51%,54%;--color-purple-700-value:272,51%,54%;--color-purple-800-value:272,47%,45%;--color-purple-900-value:275,80%,71%;--color-purple-1000-value:281,73%,96%;--color-pink-100-value:335,32%,12%;--color-pink-200-value:335,43%,16%;--color-pink-300-value:335,47%,21%;--color-pink-400-value:335,51%,22%;--color-pink-500-value:335,57%,27%;--color-pink-600-value:336,75%,40%;--color-pink-700-value:336,80%,58%;--color-pink-800-value:336,74%,51%;--color-pink-900-value:341,90%,67%;--color-pink-1000-value:333,90%,96%;--shadow-border-default-value:0 0 0 1px #ffffff25;--shadow-border-small-value:0 0 0 1px #ffffff25,0 1px 2px 0 #0000000a;--shadow-border-medium-value:0 0 0 1px #ffffff25,0px 2px 2px #00000052,0px 8px 8px -8px #00000029;--shadow-border-large-value:0 0 0 1px #ffffff25,0px 2px 2px #0000000a,0px 8px 16px -4px #0000000a;--shadow-border-tooltip-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 4px 8px #0000000a;--shadow-border-menu-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 4px 8px -4px #0000000a,0px 16px 24px -8px #0000000f;--shadow-border-modal-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;--shadow-border-fullscreen-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;color-scheme:dark}@media (prefers-reduced-motion:reduce){:root{--default-transition-duration:0!important}}.pxd-transition--fade-enter-active,.pxd-transition--fade-leave-active{transition:opacity var(--default-transition-duration)var(--default-transition-timing-function)}.pxd-transition--fade-enter-from,.pxd-transition--fade-leave-to{opacity:0;will-change:opacity}.pxd-transition--fade-scale-move,.pxd-transition--fade-scale-enter-active,.pxd-transition--fade-scale-leave-active{transition:var(--default-transition-duration)var(--default-transition-timing-function);will-change:opacity,transform;transition-property:opacity,transform}.pxd-transition--fade-scale-enter-from,.pxd-transition--fade-scale-leave-to{opacity:0;transform:scale(var(--scale,.8))translateZ(0)}.line-clamp{text-overflow:ellipsis;-webkit-line-clamp:var(--line-clamp,1);-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.scroll-disabled{scrollbar-gutter:stable!important;overflow:clip!important}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}
2
+ @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-content:""}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-700:hsl(var(--color-red-700-value));--color-red-800:hsl(var(--color-red-800-value));--color-red-900:hsl(var(--color-red-900-value));--color-amber-600:hsl(var(--color-amber-600-value));--color-amber-700:hsl(var(--color-amber-700-value));--color-amber-800:hsl(var(--color-amber-800-value));--color-yellow-500:oklch(79.5% .184 86.047);--color-green-300:hsl(var(--color-green-300-value));--color-green-500:hsl(var(--color-green-500-value));--color-green-700:hsl(var(--color-green-700-value));--color-green-900:hsl(var(--color-green-900-value));--color-violet-100:oklch(94.3% .029 294.588);--color-violet-200:oklch(89.4% .057 293.283);--color-violet-400:oklch(70.2% .183 293.541);--color-violet-900:oklch(38% .189 293.745);--color-gray-100:hsl(var(--color-gray-100-value));--color-gray-200:hsl(var(--color-gray-200-value));--color-gray-300:hsl(var(--color-gray-300-value));--color-gray-500:hsl(var(--color-gray-500-value));--color-gray-600:hsl(var(--color-gray-600-value));--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height:calc(1.5/1);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--tracking-tight:-.025em;--radius-xs:.125rem;--animate-spin:spin 1s linear infinite;--blur-xs:4px;--default-transition-duration:.2s;--default-transition-timing-function:ease-in-out;--color-primary:hsl(var(--primary));--color-border:hsl(var(--color-gray-300-value));--color-foreground:hsl(var(--color-gray-1000-value));--color-foreground-secondary:hsl(var(--color-gray-900-value));--color-background-100:hsl(var(--background-100-value));--color-gray-alpha-100:var(--color-gray-alpha-100-value);--color-gray-alpha-200:var(--color-gray-alpha-200-value);--color-gray-alpha-300:var(--color-gray-alpha-300-value);--color-gray-alpha-400:var(--color-gray-alpha-400-value);--color-gray-alpha-500:var(--color-gray-alpha-500-value);--color-gray-alpha-600:var(--color-gray-alpha-600-value);--shadow-border-default:var(--shadow-border-default-value);--shadow-border-small:var(--shadow-border-small-value);--shadow-border-medium:var(--shadow-border-medium-value);--shadow-border-large:var(--shadow-border-large-value);--shadow-border-tooltip:var(--shadow-border-tooltip-value);--shadow-border-menu:var(--shadow-border-menu-value);--shadow-border-modal:var(--shadow-border-modal-value);--shadow-border-fullscreen:var(--shadow-border-fullscreen-value)}}@layer base{*{border-color:hsl(var(--color-gray-300-value))}}@layer components{.pxd-input--border{border:1px solid var(--border-color,var(--color-gray-alpha-300))}.pxd-input--border:not(.is-disabled,.is-readonly):hover,.pxd-input--border:not(.is-disabled,.is-readonly):focus-within{--border-color:var(--color-primary)}.pxd-input--border:not(.is-disabled,.is-readonly):focus-within{box-shadow:0 0 0 3px hsla(var(--primary),.2)}.pxd-input--border.is-error:not(:focus)::placeholder{color:var(--color-red-900)!important}.pxd-input--border.is-error,.pxd-input--border.is-error:focus-within{--border-color:hsl(var(--color-red-900-value));box-shadow:0 0 0 3px hsl(var(--color-red-300-value))}.pxd-input--border.is-error:focus-within,.pxd-input--border.is-error:not(.is-disabled,.is-readonly):hover{--border-color:hsl(var(--color-red-900-value));box-shadow:0 0 0 3px hsl(var(--color-red-500-value))}.pxd-form--label{max-width:100%;margin-bottom:calc(var(--spacing)*1.5);font-size:var(--text-sm);color:var(--color-foreground-secondary)}}@layer utilities{.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.smallest{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.-inset-px{inset:-1px}.inset-0{inset:calc(var(--spacing)*0)}.-top-1{top:calc(var(--spacing)*-1)}.top-0{top:calc(var(--spacing)*0)}.top-1\.5{top:calc(var(--spacing)*1.5)}.top-1\/2{top:50%}.-right-5{right:calc(var(--spacing)*-5)}.right-0{right:calc(var(--spacing)*0)}.right-1{right:calc(var(--spacing)*1)}.right-1\.5{right:calc(var(--spacing)*1.5)}.-bottom-1{bottom:calc(var(--spacing)*-1)}.bottom-0{bottom:calc(var(--spacing)*0)}.-left-1{left:calc(var(--spacing)*-1)}.-left-5{left:calc(var(--spacing)*-5)}.left-0{left:calc(var(--spacing)*0)}.left-px{left:1px}.isolate{isolation:isolate}.z-\(--z\,10\){z-index:var(--z,10)}.z-0{z-index:0}.z-1{z-index:1}.z-10{z-index:10}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.container\!{width:100%!important}@media (min-width:40rem){.container\!{max-width:40rem!important}}@media (min-width:48rem){.container\!{max-width:48rem!important}}@media (min-width:64rem){.container\!{max-width:64rem!important}}@media (min-width:80rem){.container\!{max-width:80rem!important}}@media (min-width:96rem){.container\!{max-width:96rem!important}}.m-0{margin:calc(var(--spacing)*0)}.mx-auto{margin-inline:auto}.mx-px{margin-inline:1px}.mt-\(--mt\){margin-top:var(--mt)}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mr-1{margin-right:calc(var(--spacing)*1)}.mr-1\.5{margin-right:calc(var(--spacing)*1.5)}.mr-2{margin-right:calc(var(--spacing)*2)}.mr-3{margin-right:calc(var(--spacing)*3)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.-ml-0\.5{margin-left:calc(var(--spacing)*-.5)}.-ml-3{margin-left:calc(var(--spacing)*-3)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-1\.5{margin-left:calc(var(--spacing)*1.5)}.ml-3{margin-left:calc(var(--spacing)*3)}.scrollbar-hidden{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.scrollbar-hidden::-webkit-scrollbar{display:none}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.aspect-square{aspect-ratio:1}.size-\(--size\){width:var(--size);height:var(--size)}.size-1\/2{width:50%;height:50%}.size-3{width:calc(var(--spacing)*3);height:calc(var(--spacing)*3)}.size-4{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.size-6{width:calc(var(--spacing)*6);height:calc(var(--spacing)*6)}.size-15{width:calc(var(--spacing)*15);height:calc(var(--spacing)*15)}.size-\[calc\(1em\/4\)\]{width:.25em;height:.25em}.size-em{width:1em;height:1em}.size-full{width:100%;height:100%}.size-max{width:max-content;height:max-content}.h-\(--h\){height:var(--h)}.h-\(--scrollbar-size\){height:var(--scrollbar-size)}.h-0\.5{height:calc(var(--spacing)*.5)}.h-2{height:calc(var(--spacing)*2)}.h-2\.5{height:calc(var(--spacing)*2.5)}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-4\.5{height:calc(var(--spacing)*4.5)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-7\.5{height:calc(var(--spacing)*7.5)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-full{height:100%}.h-max{height:max-content}.max-h-68{max-height:calc(var(--spacing)*68)}.max-h-full{max-height:100%}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-3\.5{min-height:calc(var(--spacing)*3.5)}.min-h-7\.5{min-height:calc(var(--spacing)*7.5)}.min-h-9{min-height:calc(var(--spacing)*9)}.min-h-10{min-height:calc(var(--spacing)*10)}.min-h-13{min-height:calc(var(--spacing)*13)}.min-h-\[inherit\]{min-height:inherit}.w-\(--scrollbar-size\){width:var(--scrollbar-size)}.w-\(--w\){width:var(--w)}.w-1\.5{width:calc(var(--spacing)*1.5)}.w-2{width:calc(var(--spacing)*2)}.w-2\.5{width:calc(var(--spacing)*2.5)}.w-3{width:calc(var(--spacing)*3)}.w-6{width:calc(var(--spacing)*6)}.w-7{width:calc(var(--spacing)*7)}.w-7\.5{width:calc(var(--spacing)*7.5)}.w-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-11{width:calc(var(--spacing)*11)}.w-fit{width:fit-content}.w-full{width:100%}.w-max{width:max-content}.max-w-full{max-width:100%}.max-w-sm{max-width:var(--container-sm)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-3{min-width:calc(var(--spacing)*3)}.min-w-full{min-width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.border-separate{border-collapse:separate}.-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-\(--tx\){--tw-translate-x:var(--tx);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-1\/2{--tw-translate-x:calc(1/2*100%);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/3{--tw-translate-y:calc(calc(1/3*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-z-0{--tw-translate-z:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)var(--tw-translate-z)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-130{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-y-90{--tw-scale-y:90%;scale:var(--tw-scale-x)var(--tw-scale-y)}.-rotate-\[85deg\]{rotate:-85deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.transform-gpu{transform:translateZ(0)var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-manipulation{touch-action:manipulation}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.list-none{list-style-type:none}.appearance-none{appearance:none}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.items-stretch{align-items:stretch}.justify-around{justify-content:space-around}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-evenly{justify-content:space-evenly}.justify-start{justify-content:flex-start}.justify-stretch{justify-content:stretch}.gap-\(--gap-xs\){gap:var(--gap-xs)}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-scroll{overflow:scroll}.overflow-visible{overflow:visible}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-inherit{border-radius:inherit}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-none{border-radius:0}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.rounded-xs{border-radius:var(--radius-xs)}.rounded-t-lg{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.rounded-l-inherit{border-top-left-radius:inherit;border-bottom-left-radius:inherit}.rounded-r-inherit{border-top-right-radius:inherit;border-bottom-right-radius:inherit}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-none{--tw-border-style:none;border-style:none}.border-amber-100{border-color:hsl(var(--color-amber-100-value))}.border-amber-500{border-color:hsl(var(--color-amber-500-value))}.border-background-100{border-color:hsl(var(--background-100-value))}.border-blue-100{border-color:hsl(var(--color-blue-100-value))}.border-blue-500{border-color:hsl(var(--color-blue-500-value))}.border-gray-100{border-color:hsl(var(--color-gray-100-value))}.border-gray-300{border-color:hsl(var(--color-gray-300-value))}.border-gray-400{border-color:hsl(var(--color-gray-400-value))}.border-gray-500{border-color:hsl(var(--color-gray-500-value))}.border-gray-600{border-color:hsl(var(--color-gray-600-value))}.border-gray-alpha-300{border-color:var(--color-gray-alpha-300-value)}.border-gray-alpha-400{border-color:var(--color-gray-alpha-400-value)}.border-input{border-color:var(--color-gray-alpha-300)}.border-primary{border-color:hsl(var(--primary))}.border-red-100{border-color:hsl(var(--color-red-100-value))}.border-red-500{border-color:hsl(var(--color-red-500-value))}.border-teal-100{border-color:hsl(var(--color-teal-100-value))}.border-teal-400{border-color:hsl(var(--color-teal-400-value))}.border-transparent{border-color:#0000}.border-violet-100{border-color:var(--color-violet-100)}.border-violet-400{border-color:var(--color-violet-400)}.\!bg-primary{background-color:hsl(var(--primary))!important}.bg-\(--color\){background-color:var(--color)}.bg-\(--ibc\){background-color:var(--ibc)}.bg-\(--mc\){background-color:var(--mc)}.bg-\(--scrollbar-color\){background-color:var(--scrollbar-color)}.bg-\[\#26C941\]{background-color:#26c941}.bg-\[\#FE5F57\]{background-color:#fe5f57}.bg-\[\#FEBB2E\]{background-color:#febb2e}.bg-amber-200{background-color:hsl(var(--color-amber-200-value))}.bg-amber-700{background-color:hsl(var(--color-amber-700-value))}.bg-amber-800{background-color:hsl(var(--color-amber-800-value))}.bg-background-100{background-color:hsl(var(--background-100-value))}.bg-background-200{background-color:hsl(var(--background-200-value))}.bg-black\/40{background-color:#0006}@supports (color:color-mix(in lab, red, red)){.bg-black\/40{background-color:color-mix(in oklab,var(--color-black)40%,transparent)}}.bg-blue-200{background-color:hsl(var(--color-blue-200-value))}.bg-blue-700{background-color:hsl(var(--color-blue-700-value))}.bg-border{background-color:hsl(var(--color-gray-300-value))}.bg-current{background-color:currentColor}.bg-gray-100{background-color:hsl(var(--color-gray-100-value))}.bg-gray-200{background-color:hsl(var(--color-gray-200-value))}.bg-gray-600{background-color:hsl(var(--color-gray-600-value))}.bg-gray-700{background-color:hsl(var(--color-gray-700-value))}.bg-gray-900{background-color:hsl(var(--color-gray-900-value))}.bg-gray-1000{background-color:hsl(var(--color-gray-1000-value))}.bg-gray-alpha-100{background-color:var(--color-gray-alpha-100-value)}.bg-gray-alpha-200{background-color:var(--color-gray-alpha-200-value)}.bg-gray-alpha-400{background-color:var(--color-gray-alpha-400-value)}.bg-green-200{background-color:hsl(var(--color-green-200-value))}.bg-green-600{background-color:hsl(var(--color-green-600-value))}.bg-green-700{background-color:hsl(var(--color-green-700-value))}.bg-green-800{background-color:hsl(var(--color-green-800-value))}.bg-pink-200{background-color:hsl(var(--color-pink-200-value))}.bg-pink-700{background-color:hsl(var(--color-pink-700-value))}.bg-primary{background-color:hsl(var(--primary))}.bg-purple-200{background-color:hsl(var(--color-purple-200-value))}.bg-purple-700{background-color:hsl(var(--color-purple-700-value))}.bg-red-200{background-color:hsl(var(--color-red-200-value))}.bg-red-600{background-color:hsl(var(--color-red-600-value))}.bg-red-700{background-color:hsl(var(--color-red-700-value))}.bg-red-800{background-color:hsl(var(--color-red-800-value))}.bg-teal-200{background-color:hsl(var(--color-teal-200-value))}.bg-teal-700{background-color:hsl(var(--color-teal-700-value))}.bg-transparent{background-color:#0000}.bg-violet-200{background-color:var(--color-violet-200)}.bg-yellow-500{background-color:var(--color-yellow-500)}.bg-cover{background-size:cover}.object-cover{object-fit:cover}.\!p-0{padding:calc(var(--spacing)*0)!important}.p-0{padding:calc(var(--spacing)*0)}.p-1{padding:calc(var(--spacing)*1)}.p-1\.5{padding:calc(var(--spacing)*1.5)}.p-2{padding:calc(var(--spacing)*2)}.p-2\.5{padding:calc(var(--spacing)*2.5)}.p-3{padding:calc(var(--spacing)*3)}.p-3\.5{padding:calc(var(--spacing)*3.5)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.p-px{padding:1px}.px-1{padding-inline:calc(var(--spacing)*1)}.px-1\.5{padding-inline:calc(var(--spacing)*1.5)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-2\.5{padding-inline:calc(var(--spacing)*2.5)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-3\.5{padding-inline:calc(var(--spacing)*3.5)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-5{padding-inline:calc(var(--spacing)*5)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-18{padding-inline:calc(var(--spacing)*18)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-2\.5{padding-block:calc(var(--spacing)*2.5)}.py-3{padding-block:calc(var(--spacing)*3)}.py-12{padding-block:calc(var(--spacing)*12)}.py-\[3px\]{padding-block:3px}.pr-0{padding-right:calc(var(--spacing)*0)}.pr-0\.5{padding-right:calc(var(--spacing)*.5)}.pr-1{padding-right:calc(var(--spacing)*1)}.pr-1\.5{padding-right:calc(var(--spacing)*1.5)}.pr-2{padding-right:calc(var(--spacing)*2)}.pr-2\.5{padding-right:calc(var(--spacing)*2.5)}.pr-3\.5{padding-right:calc(var(--spacing)*3.5)}.pr-5{padding-right:calc(var(--spacing)*5)}.pr-6{padding-right:calc(var(--spacing)*6)}.pr-9{padding-right:calc(var(--spacing)*9)}.pr-12{padding-right:calc(var(--spacing)*12)}.pr-\[3px\]{padding-right:3px}.pb-5{padding-bottom:calc(var(--spacing)*5)}.pl-0\.5{padding-left:calc(var(--spacing)*.5)}.pl-1\.5{padding-left:calc(var(--spacing)*1.5)}.pl-2{padding-left:calc(var(--spacing)*2)}.pl-2\.5{padding-left:calc(var(--spacing)*2.5)}.pl-3\.5{padding-left:calc(var(--spacing)*3.5)}.pl-6{padding-left:calc(var(--spacing)*6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[13px\]{font-size:13px}.leading-4{--tw-leading:calc(var(--spacing)*4);line-height:calc(var(--spacing)*4)}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-balance{text-wrap:balance}.text-nowrap{text-wrap:nowrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.text-amber-900{color:hsl(var(--color-amber-900-value))}.text-background-100{color:hsl(var(--background-100-value))}.text-black{color:var(--color-black)}.text-blue-900{color:hsl(var(--color-blue-900-value))}.text-foreground{color:hsl(var(--color-gray-1000-value))}.text-foreground-secondary{color:hsl(var(--color-gray-900-value))}.text-gray-100{color:hsl(var(--color-gray-100-value))}.text-gray-500{color:hsl(var(--color-gray-500-value))}.text-gray-700{color:hsl(var(--color-gray-700-value))}.text-gray-900{color:hsl(var(--color-gray-900-value))}.text-gray-1000{color:hsl(var(--color-gray-1000-value))}.text-green-900{color:hsl(var(--color-green-900-value))}.text-pink-900{color:hsl(var(--color-pink-900-value))}.text-primary{color:hsl(var(--primary))}.text-purple-900{color:hsl(var(--color-purple-900-value))}.text-red-900{color:hsl(var(--color-red-900-value))}.text-teal-900{color:hsl(var(--color-teal-900-value))}.text-violet-900{color:var(--color-violet-900)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.\!no-underline{text-decoration-line:none!important}.underline{text-decoration-line:underline}.opacity-\(--sv\){opacity:var(--sv)}.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-50{opacity:.5}.opacity-100{opacity:1}.mix-blend-overlay{mix-blend-mode:overlay}.shadow-border-menu{--tw-shadow:var(--shadow-border-menu-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-modal{--tw-shadow:var(--shadow-border-modal-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-small{--tw-shadow:var(--shadow-border-small-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-border-tooltip{--tw-shadow:var(--shadow-border-tooltip-value);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.peer:focus-visible~.peer-focus-ring,.self-focus-ring:focus-visible{box-shadow:0 0 0 2px var(--color-background-100),0 0 0 4px hsl(var(--ring))}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-xs{--tw-backdrop-blur:blur(var(--blur-xs));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.duration-50{--tw-duration:50ms;transition-duration:50ms}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.will-change-transform{will-change:transform}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.\[--book-width\:var\(--width-xs\)\]{--book-width:var(--width-xs)}.\[--mt\:2px\]{--mt:2px}.\[--mt\:4px\]{--mt:4px}.\[--tx\:0\]{--tx:0}.transform-3d{transform-style:preserve-3d}@media (hover:hover){.group-hover\:text-foreground:is(:where(.group):hover *){color:hsl(var(--color-gray-1000-value))}.group-hover\/checkbox\:bg-gray-200:is(:where(.group\/checkbox):hover *){background-color:hsl(var(--color-gray-200-value))}.group-hover\/collapse\:will-change-\[height\]:is(:where(.group\/collapse):hover *){will-change:height}.group-hover\/radio\:bg-gray-200:is(:where(.group\/radio):hover *){background-color:hsl(var(--color-gray-200-value))}.group-hover\/toggle\:will-change-transform:is(:where(.group\/toggle):hover *){will-change:transform}}.group-data-\[direction\=horizontal\]\:flex:is(:where(.group)[data-direction=horizontal] *){display:flex}.group-data-\[direction\=vertical\]\:rotate-90:is(:where(.group)[data-direction=vertical] *){rotate:90deg}.group-data-\[header\=true\]\:pt-5:is(:where(.group)[data-header=true] *){padding-top:calc(var(--spacing)*5)}.group-data-\[indicator-position\=left\]\:flex-col:is(:where(.group)[data-indicator-position=left] *),.group-data-\[indicator-position\=right\]\:flex-col:is(:where(.group)[data-indicator-position=right] *){flex-direction:column}.group-data-\[state\=open\]\/collapse\:-rotate-180:is(:where(.group\/collapse)[data-state=open] *){rotate:-180deg}.peer-checked\:bg-\(--abc\):is(:where(.peer):checked~*){background-color:var(--abc)}.peer-checked\:bg-gray-100:is(:where(.peer):checked~*){background-color:hsl(var(--color-gray-100-value))}.peer-checked\:text-foreground:is(:where(.peer):checked~*){color:hsl(var(--color-gray-1000-value))}.peer-checked\:opacity-50:is(:where(.peer):checked~*){opacity:.5}.peer-checked\:opacity-100:is(:where(.peer):checked~*){opacity:1}.peer-checked\:\[--tx\:100\%\]:is(:where(.peer):checked~*){--tx:100%}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:text-gray-800:is(:where(.peer):disabled~*){color:hsl(var(--color-gray-800-value))}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.placeholder\:text-gray-600::placeholder{color:hsl(var(--color-gray-600-value))}.placeholder\:select-none::placeholder{-webkit-user-select:none;user-select:none}.before\:content-\[attr\(data-prompt\)\]:before{content:var(--tw-content);--tw-content:attr(data-prompt);content:var(--tw-content)}.before\:select-none:before{content:var(--tw-content);-webkit-user-select:none;user-select:none}.after\:size-2:after{content:var(--tw-content);width:calc(var(--spacing)*2);height:calc(var(--spacing)*2)}.after\:scale-40:after{content:var(--tw-content);--tw-scale-x:40%;--tw-scale-y:40%;--tw-scale-z:40%;scale:var(--tw-scale-x)var(--tw-scale-y)}.after\:rounded-full:after{content:var(--tw-content);border-radius:3.40282e38px}.after\:bg-gray-500:after{content:var(--tw-content);background-color:hsl(var(--color-gray-500-value))}.after\:bg-primary:after{content:var(--tw-content);background-color:hsl(var(--primary))}.after\:opacity-0:after{content:var(--tw-content);opacity:0}.after\:content-\[attr\(aria-label\)\]:after{content:var(--tw-content);--tw-content:attr(aria-label);content:var(--tw-content)}.peer-checked\:after\:scale-100:is(:where(.peer):checked~*):after{content:var(--tw-content);--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x)var(--tw-scale-y)}.peer-checked\:after\:opacity-100:is(:where(.peer):checked~*):after{content:var(--tw-content);opacity:1}.first\:justify-start:first-child{justify-content:flex-start}.last\:justify-end:last-child{justify-content:flex-end}.empty\:pointer-events-none:empty{pointer-events:none}.empty\:hidden:empty{display:none}.empty\:py-3:empty{padding-block:calc(var(--spacing)*3)}@media (hover:hover){.hover\:z-1:hover{z-index:1}.hover\:scale-130:hover{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:border-gray-500:hover{border-color:hsl(var(--color-gray-500-value))}.hover\:bg-\(--scrollbar-hover-color\):hover{background-color:var(--scrollbar-hover-color)}.hover\:bg-amber-700:hover{background-color:hsl(var(--color-amber-700-value))}.hover\:bg-background-hover:hover{background-color:var(--color-gray-alpha-200-value)}.hover\:bg-gray-100:hover{background-color:hsl(var(--color-gray-100-value))}.hover\:bg-gray-alpha-400:hover{background-color:var(--color-gray-alpha-400-value)}.hover\:bg-green-700:hover{background-color:hsl(var(--color-green-700-value))}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/80:hover{background-color:color-mix(in oklab,hsl(var(--primary))80%,transparent)}}.hover\:bg-red-700:hover{background-color:hsl(var(--color-red-700-value))}.hover\:text-foreground:hover{color:hsl(var(--color-gray-1000-value))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-60:hover{opacity:.6}.hover\:will-change-transform:hover{will-change:transform}.hover\:\[--sv\:1\]:hover{--sv:1}.hover\:after\:bg-primary\/20:hover:after{content:var(--tw-content);background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.hover\:after\:bg-primary\/20:hover:after{background-color:color-mix(in oklab,hsl(var(--primary))20%,transparent)}}}.focus\:placeholder\:opacity-0:focus::placeholder{opacity:0}.active\:z-1:active{z-index:1}.active\:scale-130:active{--tw-scale-x:130%;--tw-scale-y:130%;--tw-scale-z:130%;scale:var(--tw-scale-x)var(--tw-scale-y)}.active\:bg-\(--scrollbar-hover-color\):active{background-color:var(--scrollbar-hover-color)}.active\:bg-amber-900:active{background-color:hsl(var(--color-amber-900-value))}.active\:bg-background-active:active{background-color:var(--color-gray-alpha-300-value)}.active\:bg-gray-100:active{background-color:hsl(var(--color-gray-100-value))}.active\:bg-gray-900:active{background-color:hsl(var(--color-gray-900-value))}.active\:bg-green-900:active{background-color:hsl(var(--color-green-900-value))}.active\:bg-red-900:active{background-color:hsl(var(--color-red-900-value))}.active\:opacity-80:active{opacity:.8}.active\:opacity-100:active{opacity:1}.active\:select-none:active{-webkit-user-select:none;user-select:none}.active\:after\:bg-primary\/30:active:after{content:var(--tw-content);background-color:hsl(var(--primary))}@supports (color:color-mix(in lab, red, red)){.active\:after\:bg-primary\/30:active:after{background-color:color-mix(in oklab,hsl(var(--primary))30%,transparent)}}@media (hover:hover){.enabled\:hover\:bg-background-hover:enabled:hover{background-color:var(--color-gray-alpha-200-value)}.enabled\:hover\:text-gray-1000:enabled:hover{color:hsl(var(--color-gray-1000-value))}}.enabled\:active\:bg-background-active:enabled:active{background-color:var(--color-gray-alpha-300-value)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-100:disabled{background-color:hsl(var(--color-gray-100-value))}.disabled\:text-gray-700:disabled{color:hsl(var(--color-gray-700-value))}.disabled\:placeholder\:text-gray-400:disabled::placeholder{color:hsl(var(--color-gray-400-value))}.data-\[blur\=true\]\:backdrop-blur-xs[data-blur=true]{--tw-backdrop-blur:blur(var(--blur-xs));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.data-\[direction\=vertical\]\:flex-col[data-direction=vertical]{flex-direction:column}.data-\[enterable\=false\]\:pointer-events-none[data-enterable=false]{pointer-events:none}.data-\[selected\=true\]\:bg-gray-alpha-100[data-selected=true]{background-color:var(--color-gray-alpha-100-value)}@media (prefers-reduced-motion:no-preference){.motion-safe\:animate-spin{animation:var(--animate-spin)}.motion-safe\:transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:duration-200{--tw-duration:.2s;transition-duration:.2s}}.after\:motion-safe\:transition-colors:after{content:var(--tw-content)}@media (prefers-reduced-motion:no-preference){.after\:motion-safe\:transition-colors:after{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}.motion-safe\:after\:transition-all:after{content:var(--tw-content);transition-property:all;transition-timing-function:var(--tw-ease,ease-in-out);transition-duration:var(--tw-duration,.2s)}}@media (prefers-reduced-motion:reduce){.motion-reduce\:opacity-20{opacity:.2}.motion-reduce\:opacity-50{opacity:.5}.motion-reduce\:opacity-80{opacity:.8}}@media not all and (min-width:64rem){.max-lg\:hidden{display:none}}@media not all and (min-width:48rem){.max-md\:hidden{display:none}.max-md\:first\:flex-none:first-child{flex:none}}@media (min-width:40rem){.sm\:top-1\/2{top:50%}.sm\:left-1\/2{left:50%}.sm\:w-\[calc\(var\(--w\,540\)\*1px\)\]{width:calc(var(--w,540)*1px)}.sm\:max-w-\(--max-width\){max-width:var(--max-width)}.sm\:-translate-x-1\/2{--tw-translate-x:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.sm\:-translate-y-1\/2{--tw-translate-y:calc(calc(1/2*100%)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.sm\:flex-col{flex-direction:column}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:gap-\(--gap-sm\){gap:var(--gap-sm)}.sm\:rounded-xl{border-radius:calc(var(--radius) + 4px)}.sm\:bg-background-100\/80{background-color:hsl(var(--background-100-value))}@supports (color:color-mix(in lab, red, red)){.sm\:bg-background-100\/80{background-color:color-mix(in oklab,hsl(var(--background-100-value))80%,transparent)}}.sm\:p-0{padding:calc(var(--spacing)*0)}.sm\:py-4{padding-block:calc(var(--spacing)*4)}.sm\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.sm\:\[--book-width\:var\(--width-sm\)\]{--book-width:var(--width-sm)}.sm\:\[--o\:0\]{--o:0}.sm\:\[--sv\:0\]{--sv:0}.sm\:\[--t\:scale\(0\.98\)\]{--t:scale(.98)}}@media (min-width:48rem){.md\:flex-col{flex-direction:column}.md\:flex-row{flex-direction:row}.md\:gap-\(--gap-md\){gap:var(--gap-md)}.md\:gap-6{gap:calc(var(--spacing)*6)}.md\:\[--book-width\:var\(--width-md\)\]{--book-width:var(--width-md)}.md\:first\:max-w-\[140px\]:first-child,.md\:last\:max-w-\[140px\]:last-child{max-width:140px}}@media (min-width:64rem){.lg\:max-w-xs{max-width:var(--container-xs)}.lg\:flex-col{flex-direction:column}.lg\:flex-row{flex-direction:row}.lg\:gap-\(--gap-lg\){gap:var(--gap-lg)}.lg\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.lg\:\[--book-width\:var\(--width-lg\)\]{--book-width:var(--width-lg)}}@media (min-width:80rem){.xl\:flex-col{flex-direction:column}.xl\:flex-row{flex-direction:row}.xl\:gap-\(--gap-xl\){gap:var(--gap-xl)}.xl\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.xl\:\[--book-width\:var\(--width-xl\)\]{--book-width:var(--width-xl)}}.dark\:bg-background-100:is(.dark *){background-color:hsl(var(--background-100-value))}.dark\:bg-background-200:is(.dark *){background-color:hsl(var(--background-200-value))}.dark\:text-gray-100:is(.dark *){color:hsl(var(--color-gray-100-value))}.dark\:text-gray-1000:is(.dark *){color:hsl(var(--color-gray-1000-value))}.\[\&\:nth-child\(n\+2\)\]\:-ml-2\.5:nth-child(n+2){margin-left:calc(var(--spacing)*-2.5)}}:root{--radius:.5rem;--background-100-value:0,0%,100%;--background-200-value:0,0%,97%;--ring:var(--color-blue-900-value);--primary:var(--color-gray-1000-value);--color-gray-alpha-100-value:#0000000d;--color-gray-alpha-200-value:#00000014;--color-gray-alpha-300-value:#0000001f;--color-gray-alpha-400-value:#0000002b;--color-gray-alpha-500-value:#00000036;--color-gray-alpha-600-value:#00000057;--color-gray-alpha-700-value:#00000070;--color-gray-alpha-800-value:#00000082;--color-gray-alpha-900-value:#0000009c;--color-gray-alpha-1000-value:#000000e8;--color-gray-100-value:0,0%,95%;--color-gray-200-value:0,0%,93%;--color-gray-300-value:0,0%,90%;--color-gray-400-value:0,0%,85%;--color-gray-500-value:0,0%,79%;--color-gray-600-value:0,0%,66%;--color-gray-700-value:0,0%,56%;--color-gray-800-value:0,0%,49%;--color-gray-900-value:0,0%,40%;--color-gray-1000-value:0,0%,9%;--color-blue-100-value:212,100%,97%;--color-blue-200-value:210,100%,96%;--color-blue-300-value:210,100%,94%;--color-blue-400-value:209,100%,90%;--color-blue-500-value:209,100%,80%;--color-blue-600-value:208,100%,66%;--color-blue-700-value:212,100%,48%;--color-blue-800-value:212,100%,41%;--color-blue-900-value:211,100%,42%;--color-blue-1000-value:211,100%,15%;--color-red-100-value:0,100%,97%;--color-red-200-value:0,100%,96%;--color-red-300-value:0,100%,95%;--color-red-400-value:0,90%,92%;--color-red-500-value:0,82%,85%;--color-red-600-value:359,90%,71%;--color-red-700-value:358,75%,59%;--color-red-800-value:358,70%,52%;--color-red-900-value:358,66%,48%;--color-red-1000-value:355,49%,15%;--color-amber-100-value:39,100%,95%;--color-amber-200-value:44,100%,92%;--color-amber-300-value:43,96%,90%;--color-amber-400-value:42,100%,78%;--color-amber-500-value:38,100%,71%;--color-amber-600-value:36,90%,62%;--color-amber-700-value:39,100%,57%;--color-amber-800-value:35,100%,52%;--color-amber-900-value:30,100%,32%;--color-amber-1000-value:20,79%,17%;--color-green-100-value:120,60%,96%;--color-green-200-value:120,60%,95%;--color-green-300-value:120,60%,91%;--color-green-400-value:122,60%,86%;--color-green-500-value:124,60%,75%;--color-green-600-value:125,60%,64%;--color-green-700-value:131,41%,46%;--color-green-800-value:132,43%,39%;--color-green-900-value:133,50%,32%;--color-green-1000-value:128,29%,15%;--color-teal-100-value:169,70%,96%;--color-teal-200-value:167,70%,94%;--color-teal-300-value:168,70%,90%;--color-teal-400-value:170,70%,85%;--color-teal-500-value:170,70%,72%;--color-teal-600-value:170,70%,57%;--color-teal-700-value:173,80%,36%;--color-teal-800-value:173,83%,30%;--color-teal-900-value:174,91%,25%;--color-teal-1000-value:171,80%,13%;--color-purple-100-value:276,100%,97%;--color-purple-200-value:277,87%,97%;--color-purple-300-value:274,78%,95%;--color-purple-400-value:276,71%,92%;--color-purple-500-value:274,70%,82%;--color-purple-600-value:273,72%,73%;--color-purple-700-value:272,51%,54%;--color-purple-800-value:272,47%,45%;--color-purple-900-value:274,71%,43%;--color-purple-1000-value:276,100%,15%;--color-pink-100-value:330,100%,96%;--color-pink-200-value:340,90%,96%;--color-pink-300-value:340,82%,94%;--color-pink-400-value:341,76%,91%;--color-pink-500-value:340,75%,84%;--color-pink-600-value:341,75%,73%;--color-pink-700-value:336,80%,58%;--color-pink-800-value:336,74%,51%;--color-pink-900-value:336,65%,45%;--color-pink-1000-value:333,74%,15%;--shadow-border-default-value:0 0 0 1px #00000014;--shadow-border-small-value:0 0 0 1px #00000014,0 1px 2px 0 #0000000a;--shadow-border-medium-value:0 0 0 1px #00000014,0px 2px 2px #0000000a,0px 8px 8px -8px #0000000a;--shadow-border-large-value:0 0 0 1px #00000014,0px 2px 2px #0000000a,0px 8px 16px -4px #0000000a;--shadow-border-tooltip-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 4px 8px #0000000a;--shadow-border-menu-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 4px 8px -4px #0000000a,0px 16px 24px -8px #0000000f;--shadow-border-modal-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;--shadow-border-fullscreen-value:0 0 0 1px #00000014,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;text-autospace:auto;font-synthesis:none;color-scheme:light;background-color:var(--color-background-100);color:var(--color-foreground)}:root.dark{--background-100-value:0,0%,5%;--background-200-value:0,0%,0%;--color-gray-alpha-100-value:#ffffff0f;--color-gray-alpha-200-value:#ffffff17;--color-gray-alpha-300-value:#ffffff21;--color-gray-alpha-400-value:#ffffff24;--color-gray-alpha-500-value:#ffffff3d;--color-gray-alpha-600-value:#ffffff82;--color-gray-alpha-700-value:#ffffff8a;--color-gray-alpha-800-value:#ffffff78;--color-gray-alpha-900-value:#ffffff9c;--color-gray-alpha-1000-value:#ffffffeb;--color-gray-100-value:0,0%,10%;--color-gray-200-value:0,0%,12%;--color-gray-300-value:0,0%,16%;--color-gray-400-value:0,0%,18%;--color-gray-500-value:0,0%,27%;--color-gray-600-value:0,0%,53%;--color-gray-700-value:0,0%,56%;--color-gray-800-value:0,0%,49%;--color-gray-900-value:0,0%,63%;--color-gray-1000-value:0,0%,93%;--color-blue-100-value:216,50%,12%;--color-blue-200-value:214,59%,15%;--color-blue-300-value:213,71%,20%;--color-blue-400-value:212,78%,23%;--color-blue-500-value:211,86%,27%;--color-blue-600-value:206,100%,50%;--color-blue-700-value:212,100%,48%;--color-blue-800-value:212,100%,41%;--color-blue-900-value:210,100%,66%;--color-blue-1000-value:206,100%,96%;--color-red-100-value:357,37%,12%;--color-red-200-value:357,46%,16%;--color-red-300-value:356,54%,22%;--color-red-400-value:357,55%,26%;--color-red-500-value:357,60%,32%;--color-red-600-value:358,75%,59%;--color-red-700-value:358,75%,59%;--color-red-800-value:358,69%,52%;--color-red-900-value:358,100%,69%;--color-red-1000-value:353,90%,96%;--color-amber-100-value:35,100%,8%;--color-amber-200-value:32,100%,10%;--color-amber-300-value:33,100%,15%;--color-amber-400-value:35,100%,17%;--color-amber-500-value:35,91%,22%;--color-amber-600-value:39,85%,49%;--color-amber-700-value:39,100%,57%;--color-amber-800-value:35,100%,52%;--color-amber-900-value:39,90%,50%;--color-amber-1000-value:40,94%,93%;--color-green-100-value:136,50%,9%;--color-green-200-value:137,50%,12%;--color-green-300-value:136,50%,14%;--color-green-400-value:135,70%,16%;--color-green-500-value:135,70%,23%;--color-green-600-value:135,70%,34%;--color-green-700-value:131,41%,46%;--color-green-800-value:132,43%,39%;--color-green-900-value:131,43%,57%;--color-green-1000-value:136,73%,94%;--color-teal-100-value:169,78%,7%;--color-teal-200-value:170,74%,9%;--color-teal-300-value:171,75%,13%;--color-teal-400-value:171,85%,13%;--color-teal-500-value:172,85%,20%;--color-teal-600-value:172,85%,32%;--color-teal-700-value:173,80%,36%;--color-teal-800-value:173,83%,30%;--color-teal-900-value:174,90%,41%;--color-teal-1000-value:166,71%,93%;--color-purple-100-value:283,30%,12%;--color-purple-200-value:281,38%,16%;--color-purple-300-value:279,44%,23%;--color-purple-400-value:277,46%,28%;--color-purple-500-value:274,49%,35%;--color-purple-600-value:272,51%,54%;--color-purple-700-value:272,51%,54%;--color-purple-800-value:272,47%,45%;--color-purple-900-value:275,80%,71%;--color-purple-1000-value:281,73%,96%;--color-pink-100-value:335,32%,12%;--color-pink-200-value:335,43%,16%;--color-pink-300-value:335,47%,21%;--color-pink-400-value:335,51%,22%;--color-pink-500-value:335,57%,27%;--color-pink-600-value:336,75%,40%;--color-pink-700-value:336,80%,58%;--color-pink-800-value:336,74%,51%;--color-pink-900-value:341,90%,67%;--color-pink-1000-value:333,90%,96%;--shadow-border-default-value:0 0 0 1px #ffffff25;--shadow-border-small-value:0 0 0 1px #ffffff25,0 1px 2px 0 #0000000a;--shadow-border-medium-value:0 0 0 1px #ffffff25,0px 2px 2px #00000052,0px 8px 8px -8px #00000029;--shadow-border-large-value:0 0 0 1px #ffffff25,0px 2px 2px #0000000a,0px 8px 16px -4px #0000000a;--shadow-border-tooltip-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 4px 8px #0000000a;--shadow-border-menu-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 4px 8px -4px #0000000a,0px 16px 24px -8px #0000000f;--shadow-border-modal-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;--shadow-border-fullscreen-value:0 0 0 1px #ffffff25,0px 1px 1px #00000005,0px 8px 16px -4px #0000000a,0px 24px 32px -8px #0000000f;color-scheme:dark}@media (prefers-reduced-motion:reduce){:root{--default-transition-duration:0!important}}.pxd-transition--fade-enter-active,.pxd-transition--fade-leave-active{transition:opacity var(--default-transition-duration)var(--default-transition-timing-function)}.pxd-transition--fade-enter-from,.pxd-transition--fade-leave-to{opacity:0;will-change:opacity}.pxd-transition--fade-scale-move,.pxd-transition--fade-scale-enter-active,.pxd-transition--fade-scale-leave-active{transition:var(--default-transition-duration)var(--default-transition-timing-function);will-change:opacity,transform;transition-property:opacity,transform}.pxd-transition--fade-scale-enter-from,.pxd-transition--fade-scale-leave-to{opacity:0;transform:scale(var(--scale,.8))translateZ(0)}.line-clamp{text-overflow:ellipsis;-webkit-line-clamp:var(--line-clamp,1);-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.scroll-disabled{scrollbar-gutter:stable!important;overflow:clip!important}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@keyframes spin{to{transform:rotate(360deg)}}
@@ -17,7 +17,7 @@ export declare function getAllDatesBetween(startDate: Date | string, endDate: Da
17
17
  */
18
18
  export declare function getMonthDays(year: number, month: number): {
19
19
  days: number;
20
- firstDay: number;
21
- lastDay: number;
20
+ firstDay: 0 | 2 | 1 | 3 | 4 | 5 | 6;
21
+ lastDay: 0 | 2 | 1 | 3 | 4 | 5 | 6;
22
22
  };
23
23
  export {};
@@ -1,35 +1,27 @@
1
- function getYMDDateString(date) {
2
- const year = date.getFullYear();
3
- const month = String(date.getMonth() + 1).padStart(2, "0");
4
- const day = String(date.getDate()).padStart(2, "0");
5
- return `${year}-${month}-${day}`;
6
- }
1
+ import dayjs from "dayjs";
7
2
  export function getAllDatesBetween(startDate, endDate, format = "string") {
8
- let start = startDate instanceof Date ? startDate : new Date(startDate);
9
- let end = endDate instanceof Date ? endDate : new Date(endDate);
10
- if (Number.isNaN(start.getTime()) || Number.isNaN(end.getTime())) {
3
+ let start = dayjs(startDate);
4
+ let end = dayjs(endDate);
5
+ if (!start.isValid() || !end.isValid()) {
11
6
  throw new TypeError("\u65E0\u6548\u7684\u65E5\u671F\u8F93\u5165");
12
7
  }
13
- if (start > end) {
8
+ if (start.isAfter(end)) {
14
9
  [start, end] = [end, start];
15
10
  }
16
11
  const years = /* @__PURE__ */ new Set();
17
12
  const months = /* @__PURE__ */ new Set();
18
13
  const weeks = /* @__PURE__ */ new Set();
19
14
  const dates = [];
20
- const currentDate = new Date(start);
21
- currentDate.setHours(0, 0, 0, 0);
22
- const endDateTime = new Date(end);
23
- endDateTime.setHours(0, 0, 0, 0);
24
- while (currentDate <= endDateTime) {
25
- years.add(currentDate.getFullYear());
26
- months.add(currentDate.getMonth() + 1);
27
- weeks.add(currentDate.getDay());
15
+ let currentDate = start.startOf("day");
16
+ const endDateTime = end.startOf("day");
17
+ while (!currentDate.isAfter(endDateTime)) {
18
+ years.add(currentDate.year());
19
+ months.add(currentDate.month() + 1);
20
+ weeks.add(currentDate.day());
28
21
  dates.push(
29
- format === "object" ? new Date(currentDate) : getYMDDateString(currentDate)
30
- // YYYY-MM-DD
22
+ format === "object" ? currentDate.toDate() : currentDate.format("YYYY-MM-DD")
31
23
  );
32
- currentDate.setDate(currentDate.getDate() + 1);
24
+ currentDate = currentDate.add(1, "day");
33
25
  }
34
26
  return {
35
27
  years: Array.from(years),
@@ -39,11 +31,11 @@ export function getAllDatesBetween(startDate, endDate, format = "string") {
39
31
  };
40
32
  }
41
33
  export function getMonthDays(year, month) {
42
- const firstDay = new Date(year, month - 1, 1);
43
- const lastDay = new Date(year, month, 0);
34
+ const firstDay = dayjs().year(year).month(month - 1).date(1);
35
+ const lastDay = firstDay.endOf("month");
44
36
  return {
45
- days: lastDay.getDate(),
46
- firstDay: firstDay.getDay(),
47
- lastDay: lastDay.getDay()
37
+ days: lastDay.date(),
38
+ firstDay: firstDay.day(),
39
+ lastDay: lastDay.day()
48
40
  };
49
41
  }
@@ -0,0 +1,3 @@
1
+ import type { PluginFunc } from 'dayjs';
2
+ declare const millisecondTokenPlugin: PluginFunc;
3
+ export default millisecondTokenPlugin;
@@ -0,0 +1,41 @@
1
+ function replaceMillisecondToken(formatStr, matcher, replacer) {
2
+ return formatStr.replace(matcher, replacer);
3
+ }
4
+ function padToThreeDigits(value) {
5
+ const normalized = Math.max(0, Math.min(999, Math.trunc(value)));
6
+ return String(normalized).padStart(3, "0");
7
+ }
8
+ const millisecondTokenPlugin = (_opts, DayjsClass, dayjsFactory) => {
9
+ const processFormat = (ms, formatStr) => {
10
+ const ms3 = padToThreeDigits(ms);
11
+ return replaceMillisecondToken(formatStr, /S+/g, (match) => {
12
+ const len = Math.min(match.length, 3);
13
+ return ms3.slice(0, len);
14
+ });
15
+ };
16
+ const originalFormat = DayjsClass.prototype.format;
17
+ DayjsClass.prototype.format = function(formatStr) {
18
+ if (!formatStr || typeof formatStr !== "string") {
19
+ return originalFormat.call(this, formatStr);
20
+ }
21
+ return originalFormat.call(this, processFormat(this.millisecond(), formatStr));
22
+ };
23
+ try {
24
+ const isDurationInjected = typeof dayjsFactory.duration === "function";
25
+ if (!isDurationInjected) {
26
+ return;
27
+ }
28
+ const durationProto = Object.getPrototypeOf(dayjsFactory.duration(0));
29
+ if (durationProto?.format) {
30
+ const originalDurationFormat = durationProto.format;
31
+ durationProto.format = function(formatStr) {
32
+ if (!formatStr || typeof formatStr !== "string") {
33
+ return originalDurationFormat.call(this, formatStr);
34
+ }
35
+ return originalDurationFormat.call(this, processFormat(this.milliseconds(), formatStr));
36
+ };
37
+ }
38
+ } catch {
39
+ }
40
+ };
41
+ export default millisecondTokenPlugin;
@@ -1,7 +1,12 @@
1
1
  import type { Nullable } from '../types/shared';
2
+ /** string -> String */
2
3
  export declare function capitalize(text: string): string;
4
+ /** kabab-case -> kababCase */
3
5
  export declare function camelize(str: string): string;
6
+ /** kabab-case -> KababCase */
4
7
  export declare function pascalize(text: string): string;
8
+ /** KababCase -> kabab-case */
9
+ export declare function uncapitalize(text: string): string;
5
10
  export declare function isTruthyProp(value: unknown): unknown;
6
11
  export declare function isExternalLink(href: string): boolean;
7
12
  export declare function toArray(value: unknown | unknown[]): any[];
@@ -8,6 +8,9 @@ export function camelize(str) {
8
8
  export function pascalize(text) {
9
9
  return text.charAt(0).toUpperCase() + text.slice(1).replace(camelizeRE, (_, c) => c ? c.toUpperCase() : "");
10
10
  }
11
+ export function uncapitalize(text) {
12
+ return text.charAt(0).toLowerCase() + text.slice(1).replace(/([A-Z])/g, "-$1").toLowerCase();
13
+ }
11
14
  export function isTruthyProp(value) {
12
15
  return value || value === "";
13
16
  }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "pxd",
3
3
  "type": "module",
4
- "version": "0.0.31",
4
+ "version": "0.0.32",
5
5
  "description": "A universal UI component library for Vue2&3.",
6
6
  "author": "libondev <bon.li@outlook.com>",
7
7
  "license": "MIT",
@@ -90,7 +90,8 @@
90
90
  "vue": ">=2.7.0 || >=3.2.0"
91
91
  },
92
92
  "dependencies": {
93
- "@gdsicon/vue": "^1.0.4"
93
+ "@gdsicon/vue": "^1.0.4",
94
+ "dayjs": "^1.11.13"
94
95
  },
95
96
  "devDependencies": {
96
97
  "@antfu/eslint-config": "^4.19.0",
@@ -123,9 +124,10 @@
123
124
  "dev": "run-s dev:lib dev:docs",
124
125
  "dev:lib": "unbuild --stub",
125
126
  "dev:docs": "pnpm --filter docs dev",
126
- "build": "run-s update-exports build:lib build:docs",
127
- "build:lib": "unbuild",
128
- "build:only": "run-s build:lib build:docs",
127
+ "build": "run-s update-exports build:core build:docs",
128
+ "build:lib": "run-s update-exports build:core build:style build:types",
129
+ "build:core": "unbuild",
130
+ "build:only": "run-s build:core build:docs",
129
131
  "build:docs": "pnpm --filter docs build",
130
132
  "build:style": "run-s gen-styles-file gen-tw-css-file",
131
133
  "build:types": "vue-tsc -p tsconfig.type.json",