pxd 0.0.35 → 0.0.37

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.
@@ -3,7 +3,7 @@ import { computed, onBeforeUnmount, shallowRef } from "vue";
3
3
  import { useConfigProvider } from "../../composables/use-config-provider-context";
4
4
  import { useDelayChange } from "../../composables/use-delay-change";
5
5
  import { getColorByThreshold } from "../../utils/colors";
6
- import { getAllDatesBetween } from "../../utils/dates";
6
+ import { getAllDatesBetween } from "../../utils/date";
7
7
  defineOptions({
8
8
  name: "PActiveGraph"
9
9
  });
@@ -206,8 +206,7 @@ let tbodyRect;
206
206
  const tbodyRef = shallowRef();
207
207
  const {
208
208
  value: showTooltip,
209
- setValue: setShowTooltip,
210
- setValueDelay: setShowTooltipDelay
209
+ setValue: setShowTooltip
211
210
  } = useDelayChange(false, 500);
212
211
  const tooltipInfo = shallowRef({});
213
212
  const formatTooltipText = computed(() => {
@@ -218,25 +217,25 @@ const formatTooltipText = computed(() => {
218
217
  return "";
219
218
  });
220
219
  function onMouseLeave() {
221
- setShowTooltip(false);
220
+ setShowTooltip(false, true);
222
221
  tooltipInfo.value = {};
223
222
  tbodyRect = null;
224
223
  }
225
224
  async function onMouseOver(ev) {
226
225
  const targetEl = ev.target;
227
226
  if (targetEl.tagName !== "TD") {
228
- setShowTooltipDelay(false);
227
+ setShowTooltip(false);
229
228
  return;
230
229
  }
231
230
  const date = targetEl.dataset.date;
232
231
  if (!date) {
233
- setShowTooltip(false);
232
+ setShowTooltip(false, true);
234
233
  return;
235
234
  }
236
235
  if (!tbodyRect) {
237
236
  tbodyRect = tbodyRef.value.getBoundingClientRect();
238
237
  }
239
- setShowTooltip(true);
238
+ setShowTooltip(true, true);
240
239
  const rect = targetEl.getBoundingClientRect();
241
240
  let top = rect.top - tbodyRect.top - CELL_SIZE;
242
241
  if (props.graphOnly) {
@@ -326,7 +325,7 @@ onBeforeUnmount(() => {
326
325
  <div
327
326
  v-if="showTooltip"
328
327
  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
- :style="`transform: translate(${tooltipInfo.left}px, ${tooltipInfo.top}px);`"
328
+ :style="`transform: translate3d(${tooltipInfo.left}px, ${tooltipInfo.top}px, 0);`"
330
329
  >
331
330
  <slot name="tooltip" :data="tooltipInfo">
332
331
  {{ formatTooltipText }}
@@ -1,9 +1,11 @@
1
1
  <script setup>
2
- import dayjs from "dayjs/esm/index.js";
3
- import durationPlugin from "dayjs/esm/plugin/duration/index.js";
4
2
  import { computed, onBeforeUnmount } from "vue";
5
3
  import { useCountdown } from "../../composables/use-countdown";
6
- import millisecondTokenPlugin from "../../utils/dayjs-millisecond-token";
4
+ import {
5
+ dayjs,
6
+ dayjsDurationPlugin,
7
+ dayjsMillisecondTokenPlugin
8
+ } from "../../utils/date";
7
9
  defineOptions({
8
10
  name: "PCountDown"
9
11
  });
@@ -11,6 +13,7 @@ const props = defineProps({
11
13
  format: { type: String, required: false, default: "HH:mm:ss" },
12
14
  invert: { type: Boolean, required: false },
13
15
  active: { type: Boolean, required: false, default: false },
16
+ startAt: { type: Number, required: false },
14
17
  endTime: { type: Number, required: false, default: 0 },
15
18
  autoReset: { type: Boolean, required: false, default: true },
16
19
  durations: { type: Number, required: false, default: 0 },
@@ -18,8 +21,8 @@ const props = defineProps({
18
21
  millisecond: { type: Boolean, required: false, default: true }
19
22
  });
20
23
  const emits = defineEmits(["change", "reset", "finish"]);
21
- dayjs.extend(durationPlugin);
22
- dayjs.extend(millisecondTokenPlugin);
24
+ dayjs.extend(dayjsDurationPlugin);
25
+ dayjs.extend(dayjsMillisecondTokenPlugin);
23
26
  const {
24
27
  stop,
25
28
  reset,
@@ -17,7 +17,7 @@ const props = defineProps({
17
17
  title: { type: [String, Number, Array, null], required: false },
18
18
  subtitle: { type: [String, Number, Array, null], required: false },
19
19
  size: { type: [Number, String], required: false },
20
- pending: { type: Boolean, required: false },
20
+ loading: { type: Boolean, required: false },
21
21
  position: { type: String, required: false, default: "right" },
22
22
  modelValue: { type: Boolean, required: false, default: false },
23
23
  appendToBody: { type: Boolean, required: false, default: true },
@@ -48,13 +48,13 @@ const computedStyle = computed(() => {
48
48
  });
49
49
  function onOverlayClick(ev) {
50
50
  emits("click-outside", ev);
51
- if (!props.closeOnClickOverlay || props.pending) {
51
+ if (!props.closeOnClickOverlay || props.loading) {
52
52
  return;
53
53
  }
54
54
  isVisible.value = false;
55
55
  }
56
56
  function onUpdateModelValue(visible) {
57
- if (!visible && props.pending) {
57
+ if (!visible && props.loading) {
58
58
  return;
59
59
  }
60
60
  isVisible.value = visible;
@@ -92,7 +92,7 @@ watch(() => isVisible.value, (visible) => {
92
92
  class="pxd-drawer--header p-6 sm:pb-4 relative shrink-0 empty:py-3"
93
93
  :class="{ 'sm:pt-4 border-b bg-background-200 dark:bg-background-100': headerStylize }"
94
94
  >
95
- <h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight">
95
+ <h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight m-0">
96
96
  <slot name="title">
97
97
  {{ title }}
98
98
  </slot>
@@ -3,7 +3,7 @@ interface Props {
3
3
  title?: ComponentLabel;
4
4
  subtitle?: ComponentLabel;
5
5
  size?: number | string;
6
- pending?: boolean;
6
+ loading?: boolean;
7
7
  position?: BasePosition;
8
8
  modelValue?: boolean;
9
9
  appendToBody?: boolean;
@@ -60,7 +60,7 @@ const isComposing = shallowRef(false);
60
60
  const isPasswordVisible = shallowRef(!props.password);
61
61
  const internalInputType = computed(() => props.inputType || isPasswordVisible.value ? "text" : "password");
62
62
  const computedClass = computed(() => {
63
- const classes = ["pxd-input--border relative flex items-center overflow-hidden rounded-md bg-background-100 motion-safe:transition-all"];
63
+ const classes = ["pxd-input--border group relative flex items-center overflow-hidden rounded-md bg-background-100 data-[disabled=true]:cursor-not-allowed data-[disabled=true]:bg-gray-100 motion-safe:transition-all"];
64
64
  classes.push(getFallbackValue(props.size, SIZES, config.size));
65
65
  if (isTruthyProp(props.disabled)) {
66
66
  classes.push("is-disabled");
@@ -161,11 +161,11 @@ defineExpose({
161
161
  <slot name="label">{{ label }}</slot>
162
162
  </div>
163
163
 
164
- <div :class="computedClass">
164
+ <div :data-disabled="disabled" :class="computedClass">
165
165
  <div
166
166
  v-if="$slots.prefix"
167
167
  class="pxd-input--prefix text-sm flex h-full items-center text-gray-700"
168
- :class="{ 'px-3 rounded-l-inherit border-r bg-background-200': prefixStyle }"
168
+ :class="{ 'px-3 rounded-l-inherit border-r border-gray-300 bg-background-200': prefixStyle }"
169
169
  >
170
170
  <slot name="prefix" />
171
171
  </div>
@@ -173,7 +173,7 @@ defineExpose({
173
173
  <input
174
174
  :id="uniqueId"
175
175
  ref="inputRef"
176
- class="px-3 size-full rounded-inherit bg-transparent outline-none file:font-medium file:border-0 file:bg-transparent placeholder:text-gray-600 placeholder:select-none disabled:cursor-not-allowed disabled:bg-gray-100 disabled:text-gray-700 disabled:placeholder:text-gray-400"
176
+ class="px-3 size-full rounded-inherit bg-transparent outline-none file:font-medium file:border-0 file:bg-transparent placeholder:text-gray-600 placeholder:select-none disabled:cursor-not-allowed disabled:text-gray-700 disabled:placeholder:text-gray-500"
177
177
  :class="{ 'pr-9': password || allowClear, [ALIGN[align]]: true }"
178
178
  :type="internalInputType"
179
179
  :min="min"
@@ -217,7 +217,7 @@ defineExpose({
217
217
  <div
218
218
  v-if="$slots.suffix"
219
219
  class="pxd-input--suffix text-sm flex h-full items-center text-gray-700"
220
- :class="{ 'px-3 rounded-r-inherit border-l bg-background-200': suffixStyle }"
220
+ :class="{ 'px-3 rounded-r-inherit border-l border-gray-300 bg-background-200': suffixStyle }"
221
221
  >
222
222
  <slot name="suffix" />
223
223
  </div>
@@ -1,7 +1,8 @@
1
1
  <script setup>
2
2
  import PStack from "../stack/index.vue";
3
3
  defineOptions({
4
- name: "PMaterial"
4
+ name: "PMaterial",
5
+ inheritAttrs: false
5
6
  });
6
7
  defineProps({
7
8
  variant: { type: String, required: false, default: "default" }
@@ -9,7 +10,7 @@ defineProps({
9
10
  </script>
10
11
 
11
12
  <template>
12
- <PStack class="pxd-material w-full bg-background-100" :class="variant">
13
+ <PStack class="pxd-material w-full bg-background-100" :class="variant" v-bind="$attrs">
13
14
  <slot />
14
15
  </PStack>
15
16
  </template>
@@ -1,4 +1,4 @@
1
- import type { Message } from '../../composables/use-message';
1
+ import type { MessageItem } from '../../composables/use-message';
2
2
  import type { ComponentPosition } from '../../types/shared/props';
3
3
  interface Props {
4
4
  max?: number;
@@ -37,7 +37,7 @@ declare const _default: import("vue").DefineComponent<Props, {
37
37
  durations: number;
38
38
  closeable: boolean;
39
39
  type?: "info" | "success" | "warning" | "error" | "loading" | "" | false | undefined;
40
- }[], Message[] | {
40
+ }[], MessageItem[] | {
41
41
  message: string | import("vue").VNode;
42
42
  _timerId?: ReturnType<typeof setTimeout>;
43
43
  _remainingMs?: number;
@@ -15,7 +15,7 @@ const props = defineProps({
15
15
  title: { type: [String, Number, Array, null], required: false },
16
16
  subtitle: { type: [String, Number, Array, null], required: false },
17
17
  width: { type: [Number, String], required: false },
18
- pending: { type: Boolean, required: false },
18
+ loading: { type: Boolean, required: false },
19
19
  modelValue: { type: Boolean, required: false, default: false },
20
20
  appendToBody: { type: Boolean, required: false, default: true },
21
21
  headerStylize: { type: Boolean, required: false, default: false },
@@ -30,13 +30,13 @@ const isVisible = useModelValue(props, emits);
30
30
  useFocusTrap(modalRef);
31
31
  function onOverlayClick(ev) {
32
32
  emits("click-outside", ev);
33
- if (!props.closeOnClickOverlay || props.pending) {
33
+ if (!props.closeOnClickOverlay || props.loading) {
34
34
  return;
35
35
  }
36
36
  isVisible.value = false;
37
37
  }
38
38
  function onUpdateModelValue(visible) {
39
- if (!visible && props.pending) {
39
+ if (!visible && props.loading) {
40
40
  return;
41
41
  }
42
42
  isVisible.value = visible;
@@ -73,7 +73,7 @@ watch(() => isVisible.value, (visible) => {
73
73
  class="pxd-modal--header p-6 sm:pb-4 relative shrink-0 empty:py-3"
74
74
  :class="{ 'sm:pt-4 border-b bg-background-200 dark:bg-background-100': headerStylize }"
75
75
  >
76
- <h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight">
76
+ <h3 v-if="$slots.title || title" class="text-xl font-semibold tracking-tight m-0">
77
77
  <slot name="title">
78
78
  {{ title }}
79
79
  </slot>
@@ -3,7 +3,7 @@ interface Props {
3
3
  title?: ComponentLabel;
4
4
  subtitle?: ComponentLabel;
5
5
  width?: number | string;
6
- pending?: boolean;
6
+ loading?: boolean;
7
7
  modelValue?: boolean;
8
8
  appendToBody?: boolean;
9
9
  headerStylize?: boolean;
@@ -1,6 +1,6 @@
1
1
  <script setup>
2
2
  import { computed, nextTick, onBeforeUnmount, shallowRef, watch } from "vue";
3
- import { getScrollContainer, getScrollElByContainer } from "../../utils/dom";
3
+ import { getScrollContainer, getScrollElByContainer, hasScrollbar, isScrollable } from "../../utils/dom";
4
4
  import { optimizedOff, optimizedOn } from "../../utils/events";
5
5
  import { isServer } from "../../utils/is";
6
6
  import PTeleport from "../teleport/index.vue";
@@ -34,7 +34,7 @@ function onOverlayClick(ev) {
34
34
  emits("update:modelValue", false);
35
35
  }
36
36
  function onOverlayKeydown(ev) {
37
- if (!props.closeOnPressEscape) {
37
+ if (!props.closeOnPressEscape || !props.modelValue) {
38
38
  return;
39
39
  }
40
40
  if (ev.ctrlKey || ev.metaKey || ev.altKey || ev.shiftKey) {
@@ -49,19 +49,20 @@ function addScrollDisabled() {
49
49
  if (!scrollContainer) {
50
50
  return;
51
51
  }
52
- const { scrollHeight, clientWidth, scrollWidth, clientHeight } = scrollContainer;
53
- if (scrollWidth > clientWidth) {
54
- scrollContainer.classList.add("scroll-disabled-x");
52
+ const { x: xScrollbar, y: yScrollbar } = hasScrollbar(scrollContainer);
53
+ const { x: xScrollable, y: yScrollable } = isScrollable(scrollContainer);
54
+ if (xScrollbar && xScrollable) {
55
+ scrollContainer.classList.add("scrollbar-stable", "scroll-disabled-x");
55
56
  }
56
- if (scrollHeight > clientHeight) {
57
- scrollContainer.classList.add("scroll-disabled-y");
57
+ if (yScrollbar && yScrollable) {
58
+ scrollContainer.classList.add("scrollbar-stable", "scroll-disabled-y");
58
59
  }
59
60
  }
60
61
  function removeScrollDisabled() {
61
62
  if (!scrollContainer) {
62
63
  return;
63
64
  }
64
- scrollContainer.classList.remove("scroll-disabled-x", "scroll-disabled-y");
65
+ scrollContainer.classList.remove("scroll-disabled-x", "scroll-disabled-y", "scrollbar-stable");
65
66
  }
66
67
  watch(() => props.modelValue, (visible) => {
67
68
  if (isServer) {
@@ -74,7 +75,9 @@ watch(() => props.modelValue, (visible) => {
74
75
  }
75
76
  nextTick(() => {
76
77
  if (!scrollContainer) {
77
- scrollContainer = getScrollElByContainer(getScrollContainer(overlayRef.value));
78
+ scrollContainer = getScrollElByContainer(
79
+ getScrollContainer(overlayRef.value, true)
80
+ );
78
81
  }
79
82
  addScrollDisabled();
80
83
  optimizedOn(document, "keydown", onOverlayKeydown);
@@ -66,8 +66,8 @@ const formattedGap = computed(() => {
66
66
  });
67
67
  const formattedDirection = computed(() => {
68
68
  const { direction } = props;
69
- const defaultDirection = typeof direction === "string" ? direction : direction.xs || "horizontal";
70
- const defaultDirs = { xs: defaultDirection === "horizontal" ? "flex-row" : "flex-col" };
69
+ const defaultDirection = typeof direction === "string" ? direction : direction.xs ?? "horizontal";
70
+ const defaultDirs = { xs: presetDirClasses[`xs:${defaultDirection}`] };
71
71
  if (typeof direction === "object") {
72
72
  return Object.entries(direction).reduce((acc, [bp, value]) => {
73
73
  acc[bp] = presetDirClasses[`${bp}:${value}`];
@@ -1,4 +1,5 @@
1
1
  <script setup>
2
+ import LoaderCircleIcon from "@gdsicon/vue/loader-circle";
2
3
  import { computed } from "vue";
3
4
  import { useConfigProvider } from "../../composables/use-config-provider-context";
4
5
  import { useModelValue } from "../../composables/use-model-value";
@@ -14,15 +15,18 @@ defineOptions({
14
15
  const props = defineProps({
15
16
  size: { type: String, required: false },
16
17
  label: { type: [String, Number, Array, null], required: false },
18
+ loading: { type: Boolean, required: false },
19
+ disabled: { type: Boolean, required: false },
17
20
  modelValue: { type: [Boolean, Number, String], required: false },
18
21
  activeValue: { type: [Boolean, Number, String], required: false, default: true },
19
22
  inactiveValue: { type: [Boolean, Number, String], required: false, default: false },
23
+ beforeChange: { type: Function, required: false },
24
+ activeColor: { type: String, required: false, default: "var(--color-primary)" },
25
+ inactiveColor: { type: String, required: false, default: "var(--color-gray-alpha-100)" },
20
26
  activeLabel: { type: String, required: false },
21
- inactiveLabel: { type: String, required: false },
22
- activeBgColor: { type: String, required: false, default: "var(--color-primary)" },
23
- inactiveBgColor: { type: String, required: false, default: "var(--color-gray-alpha-200)" }
27
+ inactiveLabel: { type: String, required: false }
24
28
  });
25
- const emits = defineEmits(["update:modelValue"]);
29
+ const emits = defineEmits(["change", "update:modelValue"]);
26
30
  const SIZES = {
27
31
  sm: "w-7 h-4",
28
32
  md: "w-9 h-5",
@@ -33,9 +37,22 @@ const config = useConfigProvider();
33
37
  const modelValue = useModelValue(props, emits);
34
38
  const isChecked = computed(() => modelValue.value === props.activeValue);
35
39
  const computedSize = computed(() => getFallbackValue(props.size, SIZES, config.size));
36
- function onCheckboxChange(e) {
37
- const target = e.target;
38
- modelValue.value = target.checked ? props.activeValue : props.inactiveValue;
40
+ async function onCheckboxChange(e) {
41
+ if (props.loading) {
42
+ return;
43
+ }
44
+ const input = e.target;
45
+ const rawValue = input.checked;
46
+ if (typeof props.beforeChange === "function") {
47
+ input.checked = !rawValue;
48
+ const isAllowed = await props.beforeChange(modelValue.value);
49
+ if (!isAllowed) {
50
+ return;
51
+ }
52
+ }
53
+ const changedValue = rawValue ? props.activeValue : props.inactiveValue;
54
+ modelValue.value = changedValue;
55
+ emits("change", changedValue);
39
56
  }
40
57
  </script>
41
58
 
@@ -45,8 +62,8 @@ function onCheckboxChange(e) {
45
62
  class="pxd-toggle group/toggle inline-flex cursor-pointer touch-manipulation flex-col select-none"
46
63
  :aria-label="modelValue ? activeLabel : inactiveLabel"
47
64
  :style="{
48
- '--abc': activeBgColor,
49
- '--ibc': inactiveBgColor,
65
+ '--ac': activeColor,
66
+ '--ic': inactiveColor,
50
67
  }"
51
68
  :for="uniqueId"
52
69
  >
@@ -58,9 +75,10 @@ function onCheckboxChange(e) {
58
75
  <input
59
76
  :id="uniqueId"
60
77
  type="checkbox"
78
+ :disabled="disabled || loading"
61
79
  :checked="isChecked"
62
- class="peer smallest"
63
- @change="onCheckboxChange"
80
+ class="pxd-toggle--input peer smallest"
81
+ @change.prevent="onCheckboxChange"
64
82
  >
65
83
 
66
84
  <span
@@ -69,13 +87,18 @@ function onCheckboxChange(e) {
69
87
  >{{ inactiveLabel }}</span>
70
88
 
71
89
  <div
72
- class="pxd-toggle--handle rounded-full border border-input bg-(--ibc) p-px peer-focus-ring [--tx:0] peer-checked:bg-(--abc) peer-checked:[--tx:100%] motion-safe:transition-all"
90
+ class="pxd-toggle--handle rounded-full border border-input bg-(--ic) p-px peer-focus-ring [--tx:0] peer-checked:bg-(--ac) peer-checked:[--tx:100%] peer-disabled:cursor-not-allowed motion-safe:transition-all"
73
91
  :class="computedSize"
74
92
  >
75
- <span class="pxd-toggle--handle-icon flex aspect-square h-full translate-x-(--tx) transform-gpu items-center justify-center rounded-full border border-input bg-background-100 group-hover/toggle:will-change-transform motion-safe:transition-transform">
76
- <slot v-if="modelValue" name="active-icon" />
77
- <slot v-else name="inactive-icon" />
78
- </span>
93
+ <div class="pxd-toggle--handle-icon text-xs shadow-sm relative flex aspect-square h-full translate-x-(--tx) transform-gpu items-center justify-center overflow-hidden rounded-full bg-background-100 text-foreground-secondary motion-safe:transition-transform">
94
+ <div class="inset-0 absolute flex items-center justify-center">
95
+ <Transition name="pxd-transition--fade" mode="out-in">
96
+ <LoaderCircleIcon v-if="loading" class="motion-safe:animate-spin" />
97
+ <slot v-else-if="modelValue" name="checked" />
98
+ <slot v-else name="unchecked" />
99
+ </Transition>
100
+ </div>
101
+ </div>
79
102
  </div>
80
103
 
81
104
  <span
@@ -85,3 +108,9 @@ function onCheckboxChange(e) {
85
108
  </div>
86
109
  </label>
87
110
  </template>
111
+
112
+ <style lang="postcss">
113
+ .pxd-toggle--input:checked:disabled + .pxd-toggle--handle {
114
+ background-color: var(--color-gray-300)
115
+ }
116
+ </style>
@@ -1,33 +1,38 @@
1
- import type { ComponentLabel, ComponentSize } from '../../types/shared';
1
+ import type { ComponentBeforeChange, ComponentLabel, ComponentSize } from '../../types/shared';
2
2
  type ValueType = boolean | number | string;
3
3
  interface Props {
4
4
  size?: ComponentSize;
5
5
  label?: ComponentLabel;
6
+ loading?: boolean;
7
+ disabled?: boolean;
6
8
  modelValue?: ValueType;
7
9
  activeValue?: ValueType;
8
10
  inactiveValue?: ValueType;
11
+ beforeChange?: ComponentBeforeChange<ValueType>;
12
+ activeColor?: string;
13
+ inactiveColor?: string;
9
14
  activeLabel?: string;
10
15
  inactiveLabel?: string;
11
- activeBgColor?: string;
12
- inactiveBgColor?: string;
13
16
  }
14
- declare var __VLS_1: {}, __VLS_3: {}, __VLS_5: {};
17
+ declare var __VLS_1: {}, __VLS_13: {}, __VLS_15: {};
15
18
  type __VLS_Slots = {} & {
16
19
  label?: (props: typeof __VLS_1) => any;
17
20
  } & {
18
- 'active-icon'?: (props: typeof __VLS_3) => any;
21
+ checked?: (props: typeof __VLS_13) => any;
19
22
  } & {
20
- 'inactive-icon'?: (props: typeof __VLS_5) => any;
23
+ unchecked?: (props: typeof __VLS_15) => any;
21
24
  };
22
25
  declare const __VLS_component: import("vue").DefineComponent<Props, void, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
26
+ change: (args_0: NonNullable<ValueType>) => any;
23
27
  "update:modelValue": (args_0: NonNullable<ValueType>) => any;
24
28
  }, string, import("vue").PublicProps, Readonly<Props> & Readonly<{
29
+ onChange?: (args_0: NonNullable<ValueType>) => any;
25
30
  "onUpdate:modelValue"?: (args_0: NonNullable<ValueType>) => any;
26
31
  }>, {
27
32
  activeValue: ValueType;
28
33
  inactiveValue: ValueType;
29
- activeBgColor: string;
30
- inactiveBgColor: string;
34
+ activeColor: string;
35
+ inactiveColor: string;
31
36
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
32
37
  declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
33
38
  export default _default;
@@ -12,6 +12,11 @@ export interface Options {
12
12
  * @default false
13
13
  */
14
14
  active?: boolean;
15
+ /**
16
+ * 开始时间于
17
+ * The start time of the countdown.
18
+ */
19
+ startAt?: number;
15
20
  /**
16
21
  * 结束时间
17
22
  * The end time of the countdown.
@@ -1,25 +1,45 @@
1
1
  import { computed, shallowRef, watch } from "vue";
2
- const UPDATE_INTERVAL = 34;
3
- const MILLISECOND_LENGTH = 13;
2
+ const UPDATE_INTERVAL = Math.ceil(1e3 / 25);
4
3
  export function useCountdown(props, emits) {
5
4
  let startTimestamp = -1;
6
5
  let isFinished = false;
7
6
  let isPaused = false;
7
+ let previousFrameTime = 0;
8
8
  const timeRef = shallowRef(0);
9
9
  const totalDuration = computed(() => {
10
- const { endTime, durations = 0, millisecond } = props;
10
+ const { endTime, durations } = props;
11
11
  if (endTime) {
12
- const end = (String(endTime).length >= MILLISECOND_LENGTH ? endTime : endTime * 1e3) - Date.now();
12
+ const end = formatTime(endTime) - Date.now();
13
13
  return Math.max(0, end);
14
14
  }
15
- const time = millisecond === false ? Math.round(durations * 1e3) : Math.round(durations);
16
- return Math.max(0, time);
15
+ if (props.invert && [void 0, 0].includes(durations)) {
16
+ return Infinity;
17
+ }
18
+ return Math.max(0, formatTime(durations ?? 0));
17
19
  });
20
+ const isInfiniteCountup = computed(
21
+ () => props.invert && totalDuration.value === Infinity
22
+ );
23
+ function formatTime(time = 0) {
24
+ return props.millisecond ? Math.round(time) : Math.round(time * 1e3);
25
+ }
18
26
  function getCurrent(now) {
19
27
  return props.invert ? now - startTimestamp : totalDuration.value + startTimestamp - now;
20
28
  }
21
29
  function setCurrent() {
22
- timeRef.value = props.invert ? 0 : totalDuration.value;
30
+ const startAtValue = formatTime(props.startAt);
31
+ if (props.invert) {
32
+ timeRef.value = isInfiniteCountup.value ? startAtValue : Math.min(startAtValue, totalDuration.value);
33
+ } else {
34
+ timeRef.value = Math.max(0, totalDuration.value - startAtValue);
35
+ }
36
+ }
37
+ function shouldFinish(current) {
38
+ if (!props.invert) {
39
+ return current <= 0;
40
+ } else {
41
+ return !isInfiniteCountup.value && current >= totalDuration.value;
42
+ }
23
43
  }
24
44
  function finish() {
25
45
  timeRef.value = props.invert ? totalDuration.value : 0;
@@ -27,7 +47,7 @@ export function useCountdown(props, emits) {
27
47
  emits("finish");
28
48
  }
29
49
  function reset() {
30
- startTimestamp = performance.now();
50
+ startTimestamp = performance.now() - formatTime(props.startAt);
31
51
  isFinished = false;
32
52
  isPaused = false;
33
53
  setCurrent();
@@ -36,13 +56,12 @@ export function useCountdown(props, emits) {
36
56
  frame();
37
57
  }
38
58
  }
39
- let previousFrameTime = 0;
40
59
  function frame(timestamp) {
41
60
  const now = performance.now();
42
61
  const current = getCurrent(now);
43
62
  let isLastFrame = false;
44
63
  if (isPaused) {
45
- if (!props.invert && current < UPDATE_INTERVAL || props.invert && current >= totalDuration.value) {
64
+ if (shouldFinish(current)) {
46
65
  isLastFrame = true;
47
66
  } else {
48
67
  return;
@@ -53,11 +72,15 @@ export function useCountdown(props, emits) {
53
72
  return;
54
73
  }
55
74
  previousFrameTime = timestamp;
56
- if (!props.invert && current <= 0 || props.invert && current >= totalDuration.value) {
75
+ if (shouldFinish(current)) {
57
76
  finish();
58
77
  return;
59
78
  }
60
- timeRef.value = props.invert ? Math.min(current, totalDuration.value) : Math.max(0, current);
79
+ if (props.invert) {
80
+ timeRef.value = isInfiniteCountup.value ? current : Math.min(current, totalDuration.value);
81
+ } else {
82
+ timeRef.value = Math.max(0, current);
83
+ }
61
84
  requestAnimationFrame(frame);
62
85
  }
63
86
  const unwatchActive = watch(
@@ -66,9 +89,10 @@ export function useCountdown(props, emits) {
66
89
  emits("change", isActive);
67
90
  if (isActive) {
68
91
  if (isPaused) {
69
- startTimestamp = performance.now() - (props.invert ? timeRef.value : totalDuration.value - timeRef.value);
92
+ const elapsed = props.invert ? timeRef.value : totalDuration.value - timeRef.value;
93
+ startTimestamp = performance.now() - elapsed;
70
94
  } else {
71
- startTimestamp = performance.now();
95
+ startTimestamp = performance.now() - formatTime(props.startAt);
72
96
  }
73
97
  isPaused = false;
74
98
  if (isFinished && props.autoReset) {
@@ -84,7 +108,7 @@ export function useCountdown(props, emits) {
84
108
  { immediate: true }
85
109
  );
86
110
  const unwatchTimes = watch(
87
- () => [props.durations, props.endTime],
111
+ () => [props.durations, props.endTime, props.startAt],
88
112
  () => {
89
113
  setCurrent();
90
114
  isFinished = false;
@@ -1,8 +1,7 @@
1
1
  import type { Ref } from 'vue';
2
2
  interface UseDelayChangeReturnType<T> {
3
3
  value: Ref<T>;
4
- setValue: (value: T) => void;
5
- setValueDelay: (value: T) => void;
4
+ setValue: (value: T, immediate?: boolean) => void;
6
5
  }
7
- export declare function useDelayChange<T>(defaultValue: T, delay?: number): UseDelayChangeReturnType<T>;
6
+ export declare function useDelayChange<T>(defaultValue: T, delayMs?: number): UseDelayChangeReturnType<T>;
8
7
  export {};
@@ -1,20 +1,19 @@
1
1
  import { shallowRef } from "vue";
2
- export function useDelayChange(defaultValue, delay = 1e3) {
3
- const delayValue = shallowRef(defaultValue);
2
+ export function useDelayChange(defaultValue, delayMs = 1e3) {
4
3
  let timerId;
5
- function setValueDelay(value) {
4
+ const delayValue = shallowRef(defaultValue);
5
+ function setValue(newValue, immediate = false) {
6
6
  clearTimeout(timerId);
7
+ if (immediate) {
8
+ delayValue.value = newValue;
9
+ return;
10
+ }
7
11
  timerId = setTimeout(() => {
8
- setValue(value);
9
- }, delay);
10
- }
11
- function setValue(value) {
12
- clearTimeout(timerId);
13
- delayValue.value = value;
12
+ delayValue.value = newValue;
13
+ }, delayMs);
14
14
  }
15
15
  return {
16
16
  value: delayValue,
17
- setValueDelay,
18
17
  setValue
19
18
  };
20
19
  }
@@ -10,7 +10,7 @@ interface Options {
10
10
  }
11
11
  type RequireAllExcept<T, K extends keyof T> = Required<Omit<T, K>> & Pick<T, K>;
12
12
  type RequiredOptionsExceptType = RequireAllExcept<Options, 'type'>;
13
- export interface Message extends RequiredOptionsExceptType {
13
+ export interface MessageItem extends RequiredOptionsExceptType {
14
14
  message: string | VNode;
15
15
  _timerId?: ReturnType<typeof setTimeout>;
16
16
  _remainingMs?: number;
package/dist/index.d.ts CHANGED
@@ -1,5 +1,6 @@
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.35";
4
+ export type * from './types/shared';
5
+ export declare const version = "0.0.37";
5
6
  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.35";
4
+ export const version = "0.0.37";
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-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-blue-700:hsl(var(--color-blue-700-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}.z-20{z-index:20}.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-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-600{background-color:hsl(var(--color-amber-600-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-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-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-600{background-color:hsl(var(--color-teal-600-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-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-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\: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\:border-gray-300:disabled{border-color:hsl(var(--color-gray-300-value))}.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-\[disabled\=true\]\:pointer-events-none[data-disabled=true]{pointer-events:none}.data-\[disabled\=true\]\:text-gray-700[data-disabled=true]{color:hsl(var(--color-gray-700-value))}.data-\[enterable\=false\]\:pointer-events-none[data-enterable=false]{pointer-events:none}.data-\[selected\=true\]\:bg-amber-100[data-selected=true]{background-color:hsl(var(--color-amber-100-value))}.data-\[selected\=true\]\:bg-gray-alpha-100[data-selected=true]{background-color:var(--color-gray-alpha-100-value)}.data-\[selected\=true\]\:bg-red-100[data-selected=true]{background-color:hsl(var(--color-red-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\:pt-4{padding-top:calc(var(--spacing)*4)}.sm\:pb-4{padding-bottom: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\:\[--h\:30vw\]{--h:30vw}.sm\:\[--o\:0\]{--o:0}.sm\:\[--sv\:0\]{--sv:0}.sm\:\[--t\:scale\(0\.98\)\]{--t:scale(.98)}.sm\:\[--w\:30vw\]{--w:30vw}.not-empty\:sm\:pointer-events-auto:not(:empty){pointer-events:auto}}@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:#00000015;--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-x{scrollbar-gutter:stable!important;overflow-x:clip!important}.scroll-disabled-y{scrollbar-gutter:stable!important;overflow-y: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-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-blue-700:hsl(var(--color-blue-700-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}.z-20{z-index:20}.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-\(--ic\){background-color:var(--ic)}.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-600{background-color:hsl(var(--color-amber-600-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-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-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-600{background-color:hsl(var(--color-teal-600-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-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-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)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);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-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-\(--ac\):is(:where(.peer):checked~*){background-color:var(--ac)}.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\: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\:border-gray-300:disabled{border-color:hsl(var(--color-gray-300-value))}.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))}.disabled\:placeholder\:text-gray-500:disabled::placeholder{color:hsl(var(--color-gray-500-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-\[disabled\=true\]\:pointer-events-none[data-disabled=true]{pointer-events:none}.data-\[disabled\=true\]\:cursor-not-allowed[data-disabled=true]{cursor:not-allowed}.data-\[disabled\=true\]\:bg-gray-100[data-disabled=true]{background-color:hsl(var(--color-gray-100-value))}.data-\[disabled\=true\]\:text-gray-700[data-disabled=true]{color:hsl(var(--color-gray-700-value))}.data-\[enterable\=false\]\:pointer-events-none[data-enterable=false]{pointer-events:none}.data-\[selected\=true\]\:bg-amber-100[data-selected=true]{background-color:hsl(var(--color-amber-100-value))}.data-\[selected\=true\]\:bg-gray-alpha-100[data-selected=true]{background-color:var(--color-gray-alpha-100-value)}.data-\[selected\=true\]\:bg-red-100[data-selected=true]{background-color:hsl(var(--color-red-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\:pt-4{padding-top:calc(var(--spacing)*4)}.sm\:pb-4{padding-bottom: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\:\[--h\:30vw\]{--h:30vw}.sm\:\[--o\:0\]{--o:0}.sm\:\[--sv\:0\]{--sv:0}.sm\:\[--t\:scale\(0\.98\)\]{--t:scale(.98)}.sm\:\[--w\:30vw\]{--w:30vw}.not-empty\:sm\:pointer-events-auto:not(:empty){pointer-events:auto}}@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:#00000015;--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}.scrollbar-stable{scrollbar-gutter:stable}.scroll-disabled-both,.scroll-disabled-x{overflow-x:clip!important}.scroll-disabled-both,.scroll-disabled-y{overflow-y: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)}}
@@ -503,12 +503,16 @@
503
503
  -webkit-box-orient: vertical;
504
504
  }
505
505
 
506
+ .scrollbar-stable {
507
+ scrollbar-gutter: stable;
508
+ }
509
+
510
+ .scroll-disabled-both,
506
511
  .scroll-disabled-x {
507
512
  overflow-x: clip !important;
508
- scrollbar-gutter: stable !important;
509
513
  }
510
514
 
515
+ .scroll-disabled-both,
511
516
  .scroll-disabled-y {
512
517
  overflow-y: clip !important;
513
- scrollbar-gutter: stable !important;
514
518
  }
@@ -30,3 +30,5 @@ export interface ComponentOption {
30
30
  value: string | number
31
31
  disabled?: boolean
32
32
  }
33
+
34
+ export type ComponentBeforeChange<T> = (value: T) => PromiseLike<T> | T
@@ -1,3 +1,7 @@
1
+ import dayjs from 'dayjs/esm/index.js';
2
+ import dayjsDurationPlugin from 'dayjs/esm/plugin/duration/index.js';
3
+ import dayjsMillisecondTokenPlugin from './dayjs-millisecond-token.js';
4
+ export { dayjs, dayjsDurationPlugin, dayjsMillisecondTokenPlugin, };
1
5
  interface Result<T> {
2
6
  years: number[];
3
7
  months: number[];
@@ -20,4 +24,3 @@ export declare function getMonthDays(year: number, month: number): {
20
24
  firstDay: 0 | 2 | 1 | 3 | 4 | 5 | 6;
21
25
  lastDay: 0 | 2 | 1 | 3 | 4 | 5 | 6;
22
26
  };
23
- export {};
@@ -1,4 +1,11 @@
1
1
  import dayjs from "dayjs/esm/index.js";
2
+ import dayjsDurationPlugin from "dayjs/esm/plugin/duration/index.js";
3
+ import dayjsMillisecondTokenPlugin from "./dayjs-millisecond-token.js";
4
+ export {
5
+ dayjs,
6
+ dayjsDurationPlugin,
7
+ dayjsMillisecondTokenPlugin
8
+ };
2
9
  export function getAllDatesBetween(startDate, endDate, format = "string") {
3
10
  let start = dayjs(startDate);
4
11
  let end = dayjs(endDate);
@@ -11,9 +11,15 @@ export declare function getElementRectFromContainer(elementOrRect: HTMLElement |
11
11
  scrollLeft: number;
12
12
  scrollRight: number;
13
13
  };
14
- export declare function getStyle(element: HTMLElement, styleName: keyof CSSProperties): string;
15
- export declare function hasScrollbar(el: HTMLElement, isVertical?: boolean): boolean;
16
- export declare function isScrollable(el: HTMLElement, isVertical?: boolean): boolean;
14
+ export declare function getStyle(element: HTMLElement, styleNames: keyof CSSProperties | (keyof CSSProperties)[]): string[];
15
+ export declare function isScrollable(el: HTMLElement): {
16
+ x: boolean;
17
+ y: boolean;
18
+ };
19
+ export declare function hasScrollbar(el: HTMLElement): {
20
+ x: boolean;
21
+ y: boolean;
22
+ };
17
23
  export declare function getScrollContainer(el: HTMLElement, isVertical?: boolean): Window | HTMLElement;
18
24
  export declare function getScrollPositions(el: HTMLElement | Window | Document): {
19
25
  scrollTop: number;
package/dist/utils/dom.js CHANGED
@@ -1,4 +1,4 @@
1
- import { camelize } from "./format.js";
1
+ import { camelize, toArray } from "./format.js";
2
2
  import { isServer } from "./is.js";
3
3
  export function getElementRectFromContainer(elementOrRect, containerOrRect) {
4
4
  const selfRect = elementOrRect instanceof HTMLElement ? elementOrRect.getBoundingClientRect() : elementOrRect;
@@ -16,48 +16,43 @@ export function getElementRectFromContainer(elementOrRect, containerOrRect) {
16
16
  scrollRight: selfRect.right - wrapRect.left
17
17
  };
18
18
  }
19
- export function getStyle(element, styleName) {
20
- if (isServer || !element || !styleName) {
21
- return "";
22
- }
23
- let key = camelize(styleName);
24
- if (key === "float") {
25
- key = "cssFloat";
26
- }
27
- try {
28
- const style = element.style[key];
29
- if (style) {
30
- return style;
31
- }
32
- const computed = document.defaultView?.getComputedStyle(element, "");
33
- return computed ? computed[key] : "";
34
- } catch {
35
- return element.style[key];
19
+ export function getStyle(element, styleNames) {
20
+ if (isServer || !element || !styleNames) {
21
+ return [];
36
22
  }
23
+ const keys = toArray(styleNames).map((k) => {
24
+ return k === "float" ? "cssFloat" : camelize(k);
25
+ });
26
+ const computedStyle = document.defaultView?.getComputedStyle(element, "") || element.style;
27
+ return keys.map((k) => computedStyle[k]);
37
28
  }
38
- export function hasScrollbar(el, isVertical) {
39
- if (isVertical) {
40
- return el.scrollHeight > el.clientHeight;
29
+ export function isScrollable(el) {
30
+ const [x, y] = getStyle(el, ["overflow-x", "overflow-y"]);
31
+ const allowValues = ["scroll", "auto", "overlay"];
32
+ if (el.tagName === "HTML") {
33
+ allowValues.push("visible");
41
34
  }
42
- return el.scrollWidth > el.clientWidth;
35
+ return {
36
+ x: allowValues.includes(x),
37
+ y: allowValues.includes(y)
38
+ };
43
39
  }
44
- export function isScrollable(el, isVertical) {
45
- const key = {
46
- undefined: "overflow",
47
- true: "overflow-y",
48
- false: "overflow-x"
49
- }[String(isVertical)];
50
- const overflow = getStyle(el, key);
51
- return ["scroll", "auto", "overlay"].some((s) => overflow.includes(s));
40
+ export function hasScrollbar(el) {
41
+ const { scrollHeight, clientHeight, scrollWidth, clientWidth } = el;
42
+ return {
43
+ x: scrollWidth > clientWidth,
44
+ y: scrollHeight > clientHeight
45
+ };
52
46
  }
53
47
  export function getScrollContainer(el, isVertical) {
54
48
  const windowTop = [window, document, document.documentElement];
55
49
  let parent = el;
50
+ const direction = isVertical ? "y" : "x";
56
51
  while (parent) {
57
52
  if (windowTop.includes(parent)) {
58
53
  return window;
59
54
  }
60
- if (isScrollable(parent, isVertical) && hasScrollbar(parent, isVertical)) {
55
+ if (isScrollable(parent)[direction] && hasScrollbar(parent)[direction]) {
61
56
  return parent;
62
57
  }
63
58
  parent = parent.parentNode;
@@ -100,10 +95,10 @@ export function getScrollbarSize(element) {
100
95
  document.body.removeChild(div);
101
96
  return size;
102
97
  }
103
- const verticalScrollable = isScrollable(element, true);
104
- const horizontalScrollable = isScrollable(element, false);
105
- const hasVerticalScrollbar = verticalScrollable && hasScrollbar(element, true);
106
- const hasHorizontalScrollbar = horizontalScrollable && hasScrollbar(element, false);
98
+ const { x: isXScrollable, y: isYScrollable } = isScrollable(element);
99
+ const { x: hasXScrollbar, y: hasYScrollbar } = hasScrollbar(element);
100
+ const hasVerticalScrollbar = isYScrollable && hasYScrollbar;
101
+ const hasHorizontalScrollbar = isXScrollable && hasXScrollbar;
107
102
  if (hasVerticalScrollbar || hasHorizontalScrollbar) {
108
103
  const clone = element.cloneNode(true);
109
104
  clone.style.visibility = "hidden";
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "pxd",
3
3
  "type": "module",
4
- "version": "0.0.35",
4
+ "version": "0.0.37",
5
5
  "description": "A universal UI component library for Vue2&3.",
6
6
  "author": "libondev <bon.li@outlook.com>",
7
7
  "license": "MIT",