@cimplify/sdk 0.45.0 → 0.45.1
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.
- package/dist/advanced.d.mts +1 -1
- package/dist/advanced.d.ts +1 -1
- package/dist/{client-5B9IPDmf.d.ts → client-Bsd4Vi_y.d.ts} +1 -0
- package/dist/{client-CpVMRI8V.d.mts → client-C5LcbNxL.d.mts} +1 -0
- package/dist/{client-DMhRxuzm.d.ts → client-DjzIoewX.d.ts} +1 -1
- package/dist/{client-Cwb1sMr3.d.mts → client-EM8xKCPO.d.mts} +1 -1
- package/dist/index.d.mts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/react.d.mts +120 -45
- package/dist/react.d.ts +120 -45
- package/dist/react.js +453 -97
- package/dist/react.mjs +452 -98
- package/dist/server.d.mts +2 -2
- package/dist/server.d.ts +2 -2
- package/dist/styles.css +1 -1
- package/dist/testing/suite.d.mts +2 -2
- package/dist/testing/suite.d.ts +2 -2
- package/dist/testing.d.mts +2 -2
- package/dist/testing.d.ts +2 -2
- package/package.json +1 -1
- package/registry/booking-page.json +19 -0
- package/registry/bookings-page.json +17 -0
- package/registry/index.json +24 -0
package/dist/react.mjs
CHANGED
|
@@ -9475,6 +9475,457 @@ function BookingList({
|
|
|
9475
9475
|
booking.order_id
|
|
9476
9476
|
)) });
|
|
9477
9477
|
}
|
|
9478
|
+
var ANY_VALUE2 = "__any__";
|
|
9479
|
+
function roomToResource(room) {
|
|
9480
|
+
return {
|
|
9481
|
+
id: room.id,
|
|
9482
|
+
name: room.name,
|
|
9483
|
+
capacity: room.capacity,
|
|
9484
|
+
floor: room.floor,
|
|
9485
|
+
is_available: room.status === "available"
|
|
9486
|
+
};
|
|
9487
|
+
}
|
|
9488
|
+
function ResourcePicker({
|
|
9489
|
+
resources,
|
|
9490
|
+
selectedResourceId,
|
|
9491
|
+
onResourceSelect,
|
|
9492
|
+
showAnyOption = true,
|
|
9493
|
+
anyLabel = "Any available",
|
|
9494
|
+
renderImage,
|
|
9495
|
+
className,
|
|
9496
|
+
classNames
|
|
9497
|
+
}) {
|
|
9498
|
+
const groupValue = selectedResourceId === null ? ANY_VALUE2 : selectedResourceId ?? "";
|
|
9499
|
+
return /* @__PURE__ */ jsxs(
|
|
9500
|
+
RadioGroup,
|
|
9501
|
+
{
|
|
9502
|
+
"data-cimplify-resource-picker": true,
|
|
9503
|
+
className: cn("flex flex-col gap-2", className, classNames?.root),
|
|
9504
|
+
value: groupValue,
|
|
9505
|
+
onValueChange: (value) => {
|
|
9506
|
+
onResourceSelect?.(value === ANY_VALUE2 ? null : value);
|
|
9507
|
+
},
|
|
9508
|
+
children: [
|
|
9509
|
+
showAnyOption && /* @__PURE__ */ jsx(
|
|
9510
|
+
Radio.Root,
|
|
9511
|
+
{
|
|
9512
|
+
value: ANY_VALUE2,
|
|
9513
|
+
"data-cimplify-resource-option": true,
|
|
9514
|
+
"data-selected": selectedResourceId === null || void 0,
|
|
9515
|
+
"data-any": true,
|
|
9516
|
+
className: cn(
|
|
9517
|
+
"flex items-center gap-3 rounded-lg border border-border p-3 transition-colors cursor-pointer",
|
|
9518
|
+
"hover:bg-muted data-[checked]:border-primary data-[checked]:bg-primary/5",
|
|
9519
|
+
classNames?.option
|
|
9520
|
+
),
|
|
9521
|
+
children: /* @__PURE__ */ jsx("span", { "data-cimplify-resource-name": true, className: cn("font-medium text-foreground", classNames?.name), children: anyLabel })
|
|
9522
|
+
}
|
|
9523
|
+
),
|
|
9524
|
+
resources.map((resource) => {
|
|
9525
|
+
const unavailable = resource.is_available === false;
|
|
9526
|
+
return /* @__PURE__ */ jsxs(
|
|
9527
|
+
Radio.Root,
|
|
9528
|
+
{
|
|
9529
|
+
value: resource.id,
|
|
9530
|
+
disabled: unavailable,
|
|
9531
|
+
"data-cimplify-resource-option": true,
|
|
9532
|
+
"data-selected": selectedResourceId === resource.id || void 0,
|
|
9533
|
+
"data-unavailable": unavailable || void 0,
|
|
9534
|
+
className: cn(
|
|
9535
|
+
"flex items-center gap-3 rounded-lg border border-border p-3 transition-colors cursor-pointer",
|
|
9536
|
+
"hover:bg-muted data-[checked]:border-primary data-[checked]:bg-primary/5",
|
|
9537
|
+
unavailable && "opacity-50 cursor-not-allowed",
|
|
9538
|
+
classNames?.option,
|
|
9539
|
+
unavailable ? classNames?.unavailable : void 0
|
|
9540
|
+
),
|
|
9541
|
+
children: [
|
|
9542
|
+
resource.image_url && (renderImage ? renderImage({
|
|
9543
|
+
src: resource.image_url,
|
|
9544
|
+
alt: resource.name,
|
|
9545
|
+
className: classNames?.image
|
|
9546
|
+
}) : /* @__PURE__ */ jsx(
|
|
9547
|
+
"img",
|
|
9548
|
+
{
|
|
9549
|
+
src: resource.image_url,
|
|
9550
|
+
alt: resource.name,
|
|
9551
|
+
"data-cimplify-resource-image": true,
|
|
9552
|
+
className: cn("w-10 h-10 rounded-lg object-cover", classNames?.image)
|
|
9553
|
+
}
|
|
9554
|
+
)),
|
|
9555
|
+
/* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-0.5 flex-1 min-w-0", children: [
|
|
9556
|
+
/* @__PURE__ */ jsx("span", { "data-cimplify-resource-name": true, className: cn("font-medium text-foreground", classNames?.name), children: resource.name }),
|
|
9557
|
+
resource.description && /* @__PURE__ */ jsx("span", { "data-cimplify-resource-description": true, className: cn("text-sm text-muted-foreground truncate", classNames?.description), children: resource.description }),
|
|
9558
|
+
/* @__PURE__ */ jsxs("div", { "data-cimplify-resource-meta": true, className: cn("flex items-center gap-2 text-xs text-muted-foreground", classNames?.meta), children: [
|
|
9559
|
+
resource.capacity !== void 0 && /* @__PURE__ */ jsxs("span", { "data-cimplify-resource-capacity": true, className: classNames?.capacity, children: [
|
|
9560
|
+
"Up to ",
|
|
9561
|
+
resource.capacity
|
|
9562
|
+
] }),
|
|
9563
|
+
resource.floor && /* @__PURE__ */ jsx("span", { "data-cimplify-resource-floor": true, className: classNames?.floor, children: resource.floor })
|
|
9564
|
+
] })
|
|
9565
|
+
] })
|
|
9566
|
+
]
|
|
9567
|
+
},
|
|
9568
|
+
resource.id
|
|
9569
|
+
);
|
|
9570
|
+
})
|
|
9571
|
+
]
|
|
9572
|
+
}
|
|
9573
|
+
);
|
|
9574
|
+
}
|
|
9575
|
+
var STEP = {
|
|
9576
|
+
SELECT_SLOT: "select-slot",
|
|
9577
|
+
SELECT_RESOURCE: "select-resource",
|
|
9578
|
+
SELECT_STAFF: "select-staff",
|
|
9579
|
+
CONFIRM: "confirm"
|
|
9580
|
+
};
|
|
9581
|
+
function BookingPage({
|
|
9582
|
+
service,
|
|
9583
|
+
product,
|
|
9584
|
+
staff,
|
|
9585
|
+
resources,
|
|
9586
|
+
participantCount,
|
|
9587
|
+
title,
|
|
9588
|
+
onBooked,
|
|
9589
|
+
onBack,
|
|
9590
|
+
existingBooking,
|
|
9591
|
+
onRescheduled,
|
|
9592
|
+
showPrice = true,
|
|
9593
|
+
className,
|
|
9594
|
+
classNames
|
|
9595
|
+
}) {
|
|
9596
|
+
const { addItem } = useCart();
|
|
9597
|
+
const { client } = useCimplifyClient();
|
|
9598
|
+
const isReschedule = existingBooking !== void 0;
|
|
9599
|
+
const [step, setStep] = useState(STEP.SELECT_SLOT);
|
|
9600
|
+
const [selectedSlot, setSelectedSlot] = useState(null);
|
|
9601
|
+
const [selectedDate, setSelectedDate] = useState(null);
|
|
9602
|
+
const [selectedStaffId, setSelectedStaffId] = useState(null);
|
|
9603
|
+
const [selectedResourceId, setSelectedResourceId] = useState(null);
|
|
9604
|
+
const [isSubmitting, setIsSubmitting] = useState(false);
|
|
9605
|
+
const [error, setError] = useState(null);
|
|
9606
|
+
const hasResourceStep = resources && resources.length > 0;
|
|
9607
|
+
const hasStaffStep = staff && staff.length > 0;
|
|
9608
|
+
const depositType = product?.deposit_type;
|
|
9609
|
+
const depositAmount = product?.deposit_amount;
|
|
9610
|
+
const hasDeposit = depositType !== void 0 && depositType !== "none" && depositAmount !== void 0 && parsePrice(depositAmount) !== 0;
|
|
9611
|
+
const cancellationMinutes = product?.cancellation_window_minutes;
|
|
9612
|
+
const noShowFee = product?.no_show_fee;
|
|
9613
|
+
const handleSlotSelect = useCallback(
|
|
9614
|
+
(slot, date) => {
|
|
9615
|
+
setSelectedSlot(slot);
|
|
9616
|
+
setSelectedDate(date);
|
|
9617
|
+
setError(null);
|
|
9618
|
+
if (hasResourceStep) {
|
|
9619
|
+
setStep(STEP.SELECT_RESOURCE);
|
|
9620
|
+
} else if (hasStaffStep) {
|
|
9621
|
+
setStep(STEP.SELECT_STAFF);
|
|
9622
|
+
} else {
|
|
9623
|
+
setStep(STEP.CONFIRM);
|
|
9624
|
+
}
|
|
9625
|
+
},
|
|
9626
|
+
[hasResourceStep, hasStaffStep]
|
|
9627
|
+
);
|
|
9628
|
+
const handleResourceSelect = useCallback(
|
|
9629
|
+
(resourceId) => {
|
|
9630
|
+
setSelectedResourceId(resourceId);
|
|
9631
|
+
if (hasStaffStep) {
|
|
9632
|
+
setStep(STEP.SELECT_STAFF);
|
|
9633
|
+
} else {
|
|
9634
|
+
setStep(STEP.CONFIRM);
|
|
9635
|
+
}
|
|
9636
|
+
},
|
|
9637
|
+
[hasStaffStep]
|
|
9638
|
+
);
|
|
9639
|
+
const handleStaffSelect = useCallback((staffId) => {
|
|
9640
|
+
setSelectedStaffId(staffId);
|
|
9641
|
+
setStep(STEP.CONFIRM);
|
|
9642
|
+
}, []);
|
|
9643
|
+
const handleBack = useCallback(() => {
|
|
9644
|
+
setError(null);
|
|
9645
|
+
if (step === STEP.CONFIRM && hasStaffStep) {
|
|
9646
|
+
setStep(STEP.SELECT_STAFF);
|
|
9647
|
+
} else if (step === STEP.CONFIRM && hasResourceStep) {
|
|
9648
|
+
setStep(STEP.SELECT_RESOURCE);
|
|
9649
|
+
} else if (step === STEP.SELECT_STAFF && hasResourceStep) {
|
|
9650
|
+
setStep(STEP.SELECT_RESOURCE);
|
|
9651
|
+
} else if (step === STEP.CONFIRM || step === STEP.SELECT_STAFF || step === STEP.SELECT_RESOURCE) {
|
|
9652
|
+
setStep(STEP.SELECT_SLOT);
|
|
9653
|
+
} else {
|
|
9654
|
+
onBack?.();
|
|
9655
|
+
}
|
|
9656
|
+
}, [step, hasStaffStep, hasResourceStep, onBack]);
|
|
9657
|
+
const handleConfirm = useCallback(async () => {
|
|
9658
|
+
if (!selectedSlot || !selectedDate) return;
|
|
9659
|
+
setIsSubmitting(true);
|
|
9660
|
+
setError(null);
|
|
9661
|
+
try {
|
|
9662
|
+
if (isReschedule && existingBooking) {
|
|
9663
|
+
const serviceItem = existingBooking.service_items[0];
|
|
9664
|
+
const result = await client.scheduling.rescheduleBooking({
|
|
9665
|
+
order_id: existingBooking.order_id,
|
|
9666
|
+
line_item_id: serviceItem?.service_id ?? existingBooking.order_id,
|
|
9667
|
+
new_start_time: selectedSlot.start_time,
|
|
9668
|
+
new_end_time: selectedSlot.end_time,
|
|
9669
|
+
new_staff_id: selectedStaffId || void 0,
|
|
9670
|
+
reschedule_type: "customer"
|
|
9671
|
+
});
|
|
9672
|
+
if (!result.ok) {
|
|
9673
|
+
throw result.error;
|
|
9674
|
+
}
|
|
9675
|
+
onRescheduled?.(existingBooking, selectedSlot);
|
|
9676
|
+
} else {
|
|
9677
|
+
const serviceProduct = {
|
|
9678
|
+
id: service.product_id || service.id,
|
|
9679
|
+
business_id: service.business_id || "",
|
|
9680
|
+
category_id: service.category_id || void 0,
|
|
9681
|
+
name: service.name,
|
|
9682
|
+
slug: service.id,
|
|
9683
|
+
description: service.description || void 0,
|
|
9684
|
+
image_url: service.image_url || void 0,
|
|
9685
|
+
default_price: service.price || "0",
|
|
9686
|
+
type: "service",
|
|
9687
|
+
inventory_type: "none",
|
|
9688
|
+
variant_strategy: "fetch_all",
|
|
9689
|
+
is_active: service.is_available,
|
|
9690
|
+
created_at: (/* @__PURE__ */ new Date()).toISOString(),
|
|
9691
|
+
updated_at: (/* @__PURE__ */ new Date()).toISOString()
|
|
9692
|
+
};
|
|
9693
|
+
await addItem(serviceProduct, 1, {
|
|
9694
|
+
scheduledStart: selectedSlot.start_time,
|
|
9695
|
+
scheduledEnd: selectedSlot.end_time,
|
|
9696
|
+
staffId: selectedStaffId || void 0,
|
|
9697
|
+
resourceId: selectedResourceId || void 0
|
|
9698
|
+
});
|
|
9699
|
+
onBooked?.(selectedSlot, selectedStaffId);
|
|
9700
|
+
}
|
|
9701
|
+
} catch (err) {
|
|
9702
|
+
const fallbackMessage = isReschedule ? "Failed to reschedule booking" : "Failed to add booking to cart";
|
|
9703
|
+
setError(err instanceof Error ? err.message : fallbackMessage);
|
|
9704
|
+
} finally {
|
|
9705
|
+
setIsSubmitting(false);
|
|
9706
|
+
}
|
|
9707
|
+
}, [selectedSlot, selectedDate, selectedStaffId, service, addItem, onBooked, isReschedule, existingBooking, client, onRescheduled]);
|
|
9708
|
+
return /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-page": true, className: cn(className, classNames?.root), children: [
|
|
9709
|
+
/* @__PURE__ */ jsxs("div", { "data-cimplify-booking-page-header": true, className: classNames?.header, children: [
|
|
9710
|
+
onBack && step === STEP.SELECT_SLOT && /* @__PURE__ */ jsx(
|
|
9711
|
+
"button",
|
|
9712
|
+
{
|
|
9713
|
+
type: "button",
|
|
9714
|
+
onClick: onBack,
|
|
9715
|
+
"data-cimplify-booking-page-back": true,
|
|
9716
|
+
className: classNames?.backButton,
|
|
9717
|
+
children: "Back"
|
|
9718
|
+
}
|
|
9719
|
+
),
|
|
9720
|
+
step !== STEP.SELECT_SLOT && /* @__PURE__ */ jsx(
|
|
9721
|
+
"button",
|
|
9722
|
+
{
|
|
9723
|
+
type: "button",
|
|
9724
|
+
onClick: handleBack,
|
|
9725
|
+
"data-cimplify-booking-page-back": true,
|
|
9726
|
+
className: classNames?.backButton,
|
|
9727
|
+
children: "Back"
|
|
9728
|
+
}
|
|
9729
|
+
),
|
|
9730
|
+
/* @__PURE__ */ jsx("h1", { "data-cimplify-booking-page-title": true, className: classNames?.title, children: title || (isReschedule ? "Reschedule Booking" : `Book ${service.name}`) })
|
|
9731
|
+
] }),
|
|
9732
|
+
isReschedule && existingBooking && /* @__PURE__ */ jsx("div", { "data-cimplify-booking-reschedule-info": true, className: classNames?.rescheduleInfo, children: /* @__PURE__ */ jsxs("span", { children: [
|
|
9733
|
+
"Rescheduling booking from ",
|
|
9734
|
+
new Date(existingBooking.service_items[0]?.scheduled_start ?? existingBooking.created_at).toLocaleDateString()
|
|
9735
|
+
] }) }),
|
|
9736
|
+
/* @__PURE__ */ jsxs("div", { "data-cimplify-booking-service-info": true, className: classNames?.serviceInfo, children: [
|
|
9737
|
+
/* @__PURE__ */ jsx("span", { "data-cimplify-booking-service-name": true, children: service.name }),
|
|
9738
|
+
/* @__PURE__ */ jsx("span", { "data-cimplify-booking-service-duration": true, children: formatDuration2(service.duration_minutes, service.duration_unit) }),
|
|
9739
|
+
service.price && /* @__PURE__ */ jsx("span", { "data-cimplify-booking-service-price": true, children: /* @__PURE__ */ jsx(Price, { amount: service.price }) }),
|
|
9740
|
+
hasDeposit && /* @__PURE__ */ jsxs("span", { "data-cimplify-booking-deposit-info": true, className: classNames?.depositInfo, children: [
|
|
9741
|
+
"Deposit: ",
|
|
9742
|
+
depositType === "percentage" ? `${parsePrice(depositAmount)}%` : /* @__PURE__ */ jsx(Price, { amount: depositAmount })
|
|
9743
|
+
] }),
|
|
9744
|
+
cancellationMinutes !== void 0 && cancellationMinutes > 0 && /* @__PURE__ */ jsxs("span", { "data-cimplify-booking-cancellation-policy": true, className: classNames?.cancellationPolicy, children: [
|
|
9745
|
+
"Free cancellation up to ",
|
|
9746
|
+
cancellationMinutes >= 60 ? `${Math.floor(cancellationMinutes / 60)} hour${Math.floor(cancellationMinutes / 60) !== 1 ? "s" : ""}` : `${cancellationMinutes} minute${cancellationMinutes !== 1 ? "s" : ""}`,
|
|
9747
|
+
" before"
|
|
9748
|
+
] }),
|
|
9749
|
+
noShowFee !== void 0 && parsePrice(noShowFee) !== 0 && /* @__PURE__ */ jsxs("span", { "data-cimplify-booking-no-show-fee": true, className: classNames?.cancellationPolicy, children: [
|
|
9750
|
+
"No-show fee: ",
|
|
9751
|
+
/* @__PURE__ */ jsx(Price, { amount: noShowFee })
|
|
9752
|
+
] })
|
|
9753
|
+
] }),
|
|
9754
|
+
error && /* @__PURE__ */ jsx("div", { "data-cimplify-booking-error": true, className: classNames?.error, children: error }),
|
|
9755
|
+
step === STEP.SELECT_SLOT && /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-step": "select-slot", className: classNames?.step, children: [
|
|
9756
|
+
/* @__PURE__ */ jsx("h2", { "data-cimplify-booking-step-title": true, className: classNames?.stepTitle, children: "Select a date & time" }),
|
|
9757
|
+
/* @__PURE__ */ jsx(
|
|
9758
|
+
DateSlotPicker,
|
|
9759
|
+
{
|
|
9760
|
+
serviceId: service.id,
|
|
9761
|
+
participantCount,
|
|
9762
|
+
selectedSlot,
|
|
9763
|
+
onSlotSelect: handleSlotSelect,
|
|
9764
|
+
showPrice
|
|
9765
|
+
}
|
|
9766
|
+
)
|
|
9767
|
+
] }),
|
|
9768
|
+
step === STEP.SELECT_RESOURCE && resources && /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-step": "select-resource", className: cn(classNames?.step, classNames?.resourceStep), children: [
|
|
9769
|
+
/* @__PURE__ */ jsx("h2", { "data-cimplify-booking-step-title": true, className: classNames?.stepTitle, children: "Choose a room" }),
|
|
9770
|
+
/* @__PURE__ */ jsx(
|
|
9771
|
+
ResourcePicker,
|
|
9772
|
+
{
|
|
9773
|
+
resources,
|
|
9774
|
+
selectedResourceId,
|
|
9775
|
+
onResourceSelect: handleResourceSelect
|
|
9776
|
+
}
|
|
9777
|
+
)
|
|
9778
|
+
] }),
|
|
9779
|
+
step === STEP.SELECT_STAFF && staff && /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-step": "select-staff", className: classNames?.step, children: [
|
|
9780
|
+
/* @__PURE__ */ jsx("h2", { "data-cimplify-booking-step-title": true, className: classNames?.stepTitle, children: "Choose a provider" }),
|
|
9781
|
+
/* @__PURE__ */ jsx(
|
|
9782
|
+
StaffPicker,
|
|
9783
|
+
{
|
|
9784
|
+
staff,
|
|
9785
|
+
selectedStaffId,
|
|
9786
|
+
onStaffSelect: handleStaffSelect
|
|
9787
|
+
}
|
|
9788
|
+
)
|
|
9789
|
+
] }),
|
|
9790
|
+
step === STEP.CONFIRM && selectedSlot && /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-step": "confirm", className: classNames?.step, children: [
|
|
9791
|
+
/* @__PURE__ */ jsx("h2", { "data-cimplify-booking-step-title": true, className: classNames?.stepTitle, children: "Confirm your booking" }),
|
|
9792
|
+
/* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary": true, className: classNames?.summary, children: [
|
|
9793
|
+
/* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary-row": true, className: classNames?.summaryRow, children: [
|
|
9794
|
+
/* @__PURE__ */ jsx("span", { children: "Service" }),
|
|
9795
|
+
/* @__PURE__ */ jsx("span", { children: service.name })
|
|
9796
|
+
] }),
|
|
9797
|
+
/* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary-row": true, className: classNames?.summaryRow, children: [
|
|
9798
|
+
/* @__PURE__ */ jsx("span", { children: "Date" }),
|
|
9799
|
+
/* @__PURE__ */ jsx("span", { children: selectedDate })
|
|
9800
|
+
] }),
|
|
9801
|
+
/* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary-row": true, className: classNames?.summaryRow, children: [
|
|
9802
|
+
/* @__PURE__ */ jsx("span", { children: "Time" }),
|
|
9803
|
+
/* @__PURE__ */ jsx("span", { children: new Date(selectedSlot.start_time).toLocaleTimeString(void 0, {
|
|
9804
|
+
hour: "numeric",
|
|
9805
|
+
minute: "2-digit"
|
|
9806
|
+
}) })
|
|
9807
|
+
] }),
|
|
9808
|
+
/* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary-row": true, className: classNames?.summaryRow, children: [
|
|
9809
|
+
/* @__PURE__ */ jsx("span", { children: "Duration" }),
|
|
9810
|
+
/* @__PURE__ */ jsx("span", { children: formatDuration2(service.duration_minutes, service.duration_unit) })
|
|
9811
|
+
] }),
|
|
9812
|
+
selectedResourceId && resources && /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary-row": true, className: classNames?.summaryRow, children: [
|
|
9813
|
+
/* @__PURE__ */ jsx("span", { children: "Room" }),
|
|
9814
|
+
/* @__PURE__ */ jsx("span", { children: resources.find((r) => r.id === selectedResourceId)?.name ?? "Selected" })
|
|
9815
|
+
] }),
|
|
9816
|
+
selectedStaffId && staff && /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary-row": true, className: classNames?.summaryRow, children: [
|
|
9817
|
+
/* @__PURE__ */ jsx("span", { children: "Provider" }),
|
|
9818
|
+
/* @__PURE__ */ jsx("span", { children: staff.find((s) => s.id === selectedStaffId)?.name ?? "Selected" })
|
|
9819
|
+
] }),
|
|
9820
|
+
(selectedSlot.price || service.price) && /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary-row": true, className: classNames?.summaryRow, children: [
|
|
9821
|
+
/* @__PURE__ */ jsx("span", { children: "Price" }),
|
|
9822
|
+
/* @__PURE__ */ jsx("span", { children: /* @__PURE__ */ jsx(Price, { amount: selectedSlot.price || service.price }) })
|
|
9823
|
+
] }),
|
|
9824
|
+
hasDeposit && /* @__PURE__ */ jsxs("div", { "data-cimplify-booking-summary-row": true, className: cn(classNames?.summaryRow, classNames?.depositInfo), children: [
|
|
9825
|
+
/* @__PURE__ */ jsx("span", { children: "Deposit" }),
|
|
9826
|
+
/* @__PURE__ */ jsx("span", { children: depositType === "percentage" ? `${parsePrice(depositAmount)}%` : /* @__PURE__ */ jsx(Price, { amount: depositAmount }) })
|
|
9827
|
+
] })
|
|
9828
|
+
] }),
|
|
9829
|
+
/* @__PURE__ */ jsx(
|
|
9830
|
+
"button",
|
|
9831
|
+
{
|
|
9832
|
+
type: "button",
|
|
9833
|
+
onClick: handleConfirm,
|
|
9834
|
+
disabled: isSubmitting,
|
|
9835
|
+
"data-cimplify-booking-confirm": true,
|
|
9836
|
+
className: classNames?.confirmButton,
|
|
9837
|
+
children: isSubmitting ? isReschedule ? "Rescheduling\u2026" : "Adding to cart\u2026" : isReschedule ? "Reschedule" : "Confirm Booking"
|
|
9838
|
+
}
|
|
9839
|
+
)
|
|
9840
|
+
] })
|
|
9841
|
+
] });
|
|
9842
|
+
}
|
|
9843
|
+
var BOOKING_FILTERS = [
|
|
9844
|
+
{ label: "All", value: "all" },
|
|
9845
|
+
{ label: "Upcoming", value: "upcoming" },
|
|
9846
|
+
{ label: "Past", value: "past" }
|
|
9847
|
+
];
|
|
9848
|
+
function BookingsPage({
|
|
9849
|
+
title = "My Bookings",
|
|
9850
|
+
bookings: bookingsProp,
|
|
9851
|
+
onBookingNavigate,
|
|
9852
|
+
onCancel,
|
|
9853
|
+
onReschedule,
|
|
9854
|
+
showFilters = true,
|
|
9855
|
+
renderBooking,
|
|
9856
|
+
className,
|
|
9857
|
+
classNames
|
|
9858
|
+
}) {
|
|
9859
|
+
const [filter, setFilter] = useState("all");
|
|
9860
|
+
const [selectedBooking, setSelectedBooking] = useState(null);
|
|
9861
|
+
const handleBookingClick = useCallback(
|
|
9862
|
+
(booking) => {
|
|
9863
|
+
if (onBookingNavigate) {
|
|
9864
|
+
onBookingNavigate(booking);
|
|
9865
|
+
} else {
|
|
9866
|
+
setSelectedBooking(booking);
|
|
9867
|
+
}
|
|
9868
|
+
},
|
|
9869
|
+
[onBookingNavigate]
|
|
9870
|
+
);
|
|
9871
|
+
const handleBack = useCallback(() => {
|
|
9872
|
+
setSelectedBooking(null);
|
|
9873
|
+
}, []);
|
|
9874
|
+
if (selectedBooking && !onBookingNavigate) {
|
|
9875
|
+
return /* @__PURE__ */ jsx("div", { "data-cimplify-bookings-page": true, className: cn(className, classNames?.root), children: /* @__PURE__ */ jsxs("div", { "data-cimplify-bookings-detail": true, className: classNames?.detail, children: [
|
|
9876
|
+
/* @__PURE__ */ jsx(
|
|
9877
|
+
"button",
|
|
9878
|
+
{
|
|
9879
|
+
type: "button",
|
|
9880
|
+
onClick: handleBack,
|
|
9881
|
+
"data-cimplify-bookings-back": true,
|
|
9882
|
+
className: classNames?.backButton,
|
|
9883
|
+
children: "Back to bookings"
|
|
9884
|
+
}
|
|
9885
|
+
),
|
|
9886
|
+
/* @__PURE__ */ jsx(
|
|
9887
|
+
BookingCard,
|
|
9888
|
+
{
|
|
9889
|
+
booking: selectedBooking,
|
|
9890
|
+
onCancel,
|
|
9891
|
+
onReschedule
|
|
9892
|
+
}
|
|
9893
|
+
)
|
|
9894
|
+
] }) });
|
|
9895
|
+
}
|
|
9896
|
+
return /* @__PURE__ */ jsxs("div", { "data-cimplify-bookings-page": true, className: cn(className, classNames?.root), children: [
|
|
9897
|
+
/* @__PURE__ */ jsx("div", { "data-cimplify-bookings-header": true, className: classNames?.header, children: /* @__PURE__ */ jsx("h1", { "data-cimplify-bookings-title": true, className: classNames?.title, children: title }) }),
|
|
9898
|
+
showFilters && /* @__PURE__ */ jsx(
|
|
9899
|
+
Tabs.Root,
|
|
9900
|
+
{
|
|
9901
|
+
value: filter,
|
|
9902
|
+
onValueChange: (value) => setFilter(value),
|
|
9903
|
+
children: /* @__PURE__ */ jsx(Tabs.List, { "data-cimplify-bookings-filters": true, className: classNames?.filters, children: BOOKING_FILTERS.map((f) => /* @__PURE__ */ jsx(
|
|
9904
|
+
Tabs.Tab,
|
|
9905
|
+
{
|
|
9906
|
+
value: f.value,
|
|
9907
|
+
"data-cimplify-booking-filter": true,
|
|
9908
|
+
"data-selected": filter === f.value || void 0,
|
|
9909
|
+
className: classNames?.filterButton,
|
|
9910
|
+
children: f.label
|
|
9911
|
+
},
|
|
9912
|
+
f.value
|
|
9913
|
+
)) })
|
|
9914
|
+
}
|
|
9915
|
+
),
|
|
9916
|
+
/* @__PURE__ */ jsx("div", { "data-cimplify-bookings-list": true, className: classNames?.list, children: /* @__PURE__ */ jsx(
|
|
9917
|
+
BookingList,
|
|
9918
|
+
{
|
|
9919
|
+
bookings: bookingsProp,
|
|
9920
|
+
filter,
|
|
9921
|
+
onCancel,
|
|
9922
|
+
onReschedule,
|
|
9923
|
+
onBookingClick: handleBookingClick,
|
|
9924
|
+
renderBooking
|
|
9925
|
+
}
|
|
9926
|
+
) })
|
|
9927
|
+
] });
|
|
9928
|
+
}
|
|
9478
9929
|
function DefaultCatalogueLayout({
|
|
9479
9930
|
products,
|
|
9480
9931
|
categories,
|
|
@@ -12424,103 +12875,6 @@ function CurrencySelector({
|
|
|
12424
12875
|
);
|
|
12425
12876
|
}) });
|
|
12426
12877
|
}
|
|
12427
|
-
var ANY_VALUE2 = "__any__";
|
|
12428
|
-
function roomToResource(room) {
|
|
12429
|
-
return {
|
|
12430
|
-
id: room.id,
|
|
12431
|
-
name: room.name,
|
|
12432
|
-
capacity: room.capacity,
|
|
12433
|
-
floor: room.floor,
|
|
12434
|
-
is_available: room.status === "available"
|
|
12435
|
-
};
|
|
12436
|
-
}
|
|
12437
|
-
function ResourcePicker({
|
|
12438
|
-
resources,
|
|
12439
|
-
selectedResourceId,
|
|
12440
|
-
onResourceSelect,
|
|
12441
|
-
showAnyOption = true,
|
|
12442
|
-
anyLabel = "Any available",
|
|
12443
|
-
renderImage,
|
|
12444
|
-
className,
|
|
12445
|
-
classNames
|
|
12446
|
-
}) {
|
|
12447
|
-
const groupValue = selectedResourceId === null ? ANY_VALUE2 : selectedResourceId ?? "";
|
|
12448
|
-
return /* @__PURE__ */ jsxs(
|
|
12449
|
-
RadioGroup,
|
|
12450
|
-
{
|
|
12451
|
-
"data-cimplify-resource-picker": true,
|
|
12452
|
-
className: cn("flex flex-col gap-2", className, classNames?.root),
|
|
12453
|
-
value: groupValue,
|
|
12454
|
-
onValueChange: (value) => {
|
|
12455
|
-
onResourceSelect?.(value === ANY_VALUE2 ? null : value);
|
|
12456
|
-
},
|
|
12457
|
-
children: [
|
|
12458
|
-
showAnyOption && /* @__PURE__ */ jsx(
|
|
12459
|
-
Radio.Root,
|
|
12460
|
-
{
|
|
12461
|
-
value: ANY_VALUE2,
|
|
12462
|
-
"data-cimplify-resource-option": true,
|
|
12463
|
-
"data-selected": selectedResourceId === null || void 0,
|
|
12464
|
-
"data-any": true,
|
|
12465
|
-
className: cn(
|
|
12466
|
-
"flex items-center gap-3 rounded-lg border border-border p-3 transition-colors cursor-pointer",
|
|
12467
|
-
"hover:bg-muted data-[checked]:border-primary data-[checked]:bg-primary/5",
|
|
12468
|
-
classNames?.option
|
|
12469
|
-
),
|
|
12470
|
-
children: /* @__PURE__ */ jsx("span", { "data-cimplify-resource-name": true, className: cn("font-medium text-foreground", classNames?.name), children: anyLabel })
|
|
12471
|
-
}
|
|
12472
|
-
),
|
|
12473
|
-
resources.map((resource) => {
|
|
12474
|
-
const unavailable = resource.is_available === false;
|
|
12475
|
-
return /* @__PURE__ */ jsxs(
|
|
12476
|
-
Radio.Root,
|
|
12477
|
-
{
|
|
12478
|
-
value: resource.id,
|
|
12479
|
-
disabled: unavailable,
|
|
12480
|
-
"data-cimplify-resource-option": true,
|
|
12481
|
-
"data-selected": selectedResourceId === resource.id || void 0,
|
|
12482
|
-
"data-unavailable": unavailable || void 0,
|
|
12483
|
-
className: cn(
|
|
12484
|
-
"flex items-center gap-3 rounded-lg border border-border p-3 transition-colors cursor-pointer",
|
|
12485
|
-
"hover:bg-muted data-[checked]:border-primary data-[checked]:bg-primary/5",
|
|
12486
|
-
unavailable && "opacity-50 cursor-not-allowed",
|
|
12487
|
-
classNames?.option,
|
|
12488
|
-
unavailable ? classNames?.unavailable : void 0
|
|
12489
|
-
),
|
|
12490
|
-
children: [
|
|
12491
|
-
resource.image_url && (renderImage ? renderImage({
|
|
12492
|
-
src: resource.image_url,
|
|
12493
|
-
alt: resource.name,
|
|
12494
|
-
className: classNames?.image
|
|
12495
|
-
}) : /* @__PURE__ */ jsx(
|
|
12496
|
-
"img",
|
|
12497
|
-
{
|
|
12498
|
-
src: resource.image_url,
|
|
12499
|
-
alt: resource.name,
|
|
12500
|
-
"data-cimplify-resource-image": true,
|
|
12501
|
-
className: cn("w-10 h-10 rounded-lg object-cover", classNames?.image)
|
|
12502
|
-
}
|
|
12503
|
-
)),
|
|
12504
|
-
/* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-0.5 flex-1 min-w-0", children: [
|
|
12505
|
-
/* @__PURE__ */ jsx("span", { "data-cimplify-resource-name": true, className: cn("font-medium text-foreground", classNames?.name), children: resource.name }),
|
|
12506
|
-
resource.description && /* @__PURE__ */ jsx("span", { "data-cimplify-resource-description": true, className: cn("text-sm text-muted-foreground truncate", classNames?.description), children: resource.description }),
|
|
12507
|
-
/* @__PURE__ */ jsxs("div", { "data-cimplify-resource-meta": true, className: cn("flex items-center gap-2 text-xs text-muted-foreground", classNames?.meta), children: [
|
|
12508
|
-
resource.capacity !== void 0 && /* @__PURE__ */ jsxs("span", { "data-cimplify-resource-capacity": true, className: classNames?.capacity, children: [
|
|
12509
|
-
"Up to ",
|
|
12510
|
-
resource.capacity
|
|
12511
|
-
] }),
|
|
12512
|
-
resource.floor && /* @__PURE__ */ jsx("span", { "data-cimplify-resource-floor": true, className: classNames?.floor, children: resource.floor })
|
|
12513
|
-
] })
|
|
12514
|
-
] })
|
|
12515
|
-
]
|
|
12516
|
-
},
|
|
12517
|
-
resource.id
|
|
12518
|
-
);
|
|
12519
|
-
})
|
|
12520
|
-
]
|
|
12521
|
-
}
|
|
12522
|
-
);
|
|
12523
|
-
}
|
|
12524
12878
|
function ChatWidget({
|
|
12525
12879
|
client: clientProp,
|
|
12526
12880
|
businessName = "Support",
|
|
@@ -13008,4 +13362,4 @@ function SparkleIcon({ className }) {
|
|
|
13008
13362
|
);
|
|
13009
13363
|
}
|
|
13010
13364
|
|
|
13011
|
-
export { AccommodationCard, Ad, AdProvider, AddOnSelector, AddressElement, AuthElement, AvailabilityBadge, BillingPlanSelector, BookingCard, BookingList, BundleProductCard, BundleProductLayout, BundleSelector, CardImage, CardShell, CardVariant, CartDrawer, CartDrawerProvider, CartPage, CartSummary, CartTemplate, CatalogueCollectionLayout, CataloguePage, CatalogueTemplate, CategoryFilter, CategoryGrid, ChatWidget, CheckoutPage, CimplifyAccount, CimplifyCheckout, CimplifyProvider, CollectionPage, CollectionTemplate, CompactCartLayout, CompactCatalogueLayout, CompactSearchLayout, CompactServiceCard, CompositeProductCard, CompositeProductLayout, CompositeSelector, CurrencySelector, CustomAttributesTable, CustomerInputFields, DateSlotPicker, DealBanner, DealsPage, DefaultCartLayout, DefaultCatalogueLayout, DefaultCollectionLayout, DefaultProductLayout, DefaultSearchLayout, DeliveryEstimate, DigitalProductCard, DigitalProductLayout, DiscountInput, ElementsProvider, FeaturedCollectionLayout, FoodProductCard, FoodProductLayout, InventoryBadge, LeaseServiceCard, LocationPicker, MetadataStringList, OrderDetailPage, OrderHistory, OrderHistoryPage, OrderSummary, PaymentElement, Price, PriceRange, ProductCard, ProductCustomizer, ProductGrid, ProductImageGallery, ProductPage, ProductSheet, ProductTemplate, PropertiesTable, QuantitySelector, QuickAddButton, RecentlyViewed, RecommendationCarousel, RelatedProductsSection, RentalServiceCard, ResourcePicker, RetailProductCard, SaleBadge, ScheduleServiceCard, SearchInput, SearchPage, SearchTemplate, ServiceProductLayout, SessionMessageBanner, SlotPicker, SoldOutOverlay, StaffPicker, StandardServiceCard, StoreNav, SubscriptionCard, TagPills, TwoColumnGrid, VariantSelector, VolumePricing, WholesaleProductCard, WholesaleProductLayout, WishlistButton, cn, roomToResource, useActivityState, useAds, useAttributeDefinitions, useAvailableSlots, useBillingPlans, useBookings, useBootstrap, useBundles, useCart, useCartDrawer, useCategories, useChat, useCheckout, useCimplify, useCimplifyClient, useCollection, useCollections, useDeals, useDeliveryFee, useElements, useElementsReady, useFxRate, useLocations, useOptionalCimplify, useOrder, useOrders, useProduct, useProductAvailability, useProductDeals, useProductPrice, useProductSchedules, useProducts, useProductsOnSale, usePropertyFacets, useQuote, useRecommendations, useSearch, useServiceAvailability, useServices, useSubscription, useSubscriptions, useTaxonomies, useTaxonomy, useTaxonomyPath, useValidateDiscount, useVariantSelector };
|
|
13365
|
+
export { AccommodationCard, Ad, AdProvider, AddOnSelector, AddressElement, AuthElement, AvailabilityBadge, BillingPlanSelector, BookingCard, BookingList, BookingPage, BookingsPage, BundleProductCard, BundleProductLayout, BundleSelector, CardImage, CardShell, CardVariant, CartDrawer, CartDrawerProvider, CartPage, CartSummary, CartTemplate, CatalogueCollectionLayout, CataloguePage, CatalogueTemplate, CategoryFilter, CategoryGrid, ChatWidget, CheckoutPage, CimplifyAccount, CimplifyCheckout, CimplifyProvider, CollectionPage, CollectionTemplate, CompactCartLayout, CompactCatalogueLayout, CompactSearchLayout, CompactServiceCard, CompositeProductCard, CompositeProductLayout, CompositeSelector, CurrencySelector, CustomAttributesTable, CustomerInputFields, DateSlotPicker, DealBanner, DealsPage, DefaultCartLayout, DefaultCatalogueLayout, DefaultCollectionLayout, DefaultProductLayout, DefaultSearchLayout, DeliveryEstimate, DigitalProductCard, DigitalProductLayout, DiscountInput, ElementsProvider, FeaturedCollectionLayout, FoodProductCard, FoodProductLayout, InventoryBadge, LeaseServiceCard, LocationPicker, MetadataStringList, OrderDetailPage, OrderHistory, OrderHistoryPage, OrderSummary, PaymentElement, Price, PriceRange, ProductCard, ProductCustomizer, ProductGrid, ProductImageGallery, ProductPage, ProductSheet, ProductTemplate, PropertiesTable, QuantitySelector, QuickAddButton, RecentlyViewed, RecommendationCarousel, RelatedProductsSection, RentalServiceCard, ResourcePicker, RetailProductCard, SaleBadge, ScheduleServiceCard, SearchInput, SearchPage, SearchTemplate, ServiceProductLayout, SessionMessageBanner, SlotPicker, SoldOutOverlay, StaffPicker, StandardServiceCard, StoreNav, SubscriptionCard, TagPills, TwoColumnGrid, VariantSelector, VolumePricing, WholesaleProductCard, WholesaleProductLayout, WishlistButton, cn, roomToResource, useActivityState, useAds, useAttributeDefinitions, useAvailableSlots, useBillingPlans, useBookings, useBootstrap, useBundles, useCart, useCartDrawer, useCategories, useChat, useCheckout, useCimplify, useCimplifyClient, useCollection, useCollections, useDeals, useDeliveryFee, useElements, useElementsReady, useFxRate, useLocations, useOptionalCimplify, useOrder, useOrders, useProduct, useProductAvailability, useProductDeals, useProductPrice, useProductSchedules, useProducts, useProductsOnSale, usePropertyFacets, useQuote, useRecommendations, useSearch, useServiceAvailability, useServices, useSubscription, useSubscriptions, useTaxonomies, useTaxonomy, useTaxonomyPath, useValidateDiscount, useVariantSelector };
|
package/dist/server.d.mts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { C as CimplifyClient } from './client-
|
|
2
|
-
export { aN as Result } from './client-
|
|
1
|
+
import { C as CimplifyClient } from './client-C5LcbNxL.mjs';
|
|
2
|
+
export { aN as Result } from './client-C5LcbNxL.mjs';
|
|
3
3
|
export { an as Category, h as CimplifyError, ap as Collection, U as Product, a8 as ProductWithDetails } from './payment-4JSLNTVM.mjs';
|
|
4
4
|
|
|
5
5
|
interface ServerClientOptions {
|
package/dist/server.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { C as CimplifyClient } from './client-
|
|
2
|
-
export { aN as Result } from './client-
|
|
1
|
+
import { C as CimplifyClient } from './client-Bsd4Vi_y.js';
|
|
2
|
+
export { aN as Result } from './client-Bsd4Vi_y.js';
|
|
3
3
|
export { an as Category, h as CimplifyError, ap as Collection, U as Product, a8 as ProductWithDetails } from './payment-4JSLNTVM.js';
|
|
4
4
|
|
|
5
5
|
interface ServerClientOptions {
|
package/dist/styles.css
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
/*! tailwindcss v4.
|
|
1
|
+
/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
|
|
2
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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-divide-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--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-ease:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.sr-only{clip-path:inset(50%);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}.static{position:static}.sticky{position:sticky}.top-1\/2{top:50%}.top-full{top:100%}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-\[200\]{z-index:200}.z-\[9999\]{z-index:9999}.container{width:100%}.m-auto{margin:auto}.mx-auto{margin-inline:auto}.-mt-px{margin-top:-1px}.mr-auto{margin-right:auto}.ml-auto{margin-left:auto}.line-clamp-1{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.aspect-\[3\/4\]{aspect-ratio:3/4}.aspect-\[4\/3\]{aspect-ratio:4/3}.aspect-\[5\/2\]{aspect-ratio:5/2}.aspect-\[16\/9\]{aspect-ratio:16/9}.aspect-square{aspect-ratio:1}.h-\[6px\]{height:6px}.h-\[7px\]{height:7px}.h-\[11px\]{height:11px}.h-\[18px\]{height:18px}.h-\[72px\]{height:72px}.h-\[min\(600px\,calc\(100vh-6rem\)\)\]{height:min(600px,100vh - 6rem)}.h-fit{height:fit-content}.h-full{height:100%}.max-h-\[85vh\]{max-height:85vh}.max-h-\[100px\]{max-height:100px}.min-h-\[20px\]{min-height:20px}.w-1\/2{width:50%}.w-2\/5{width:40%}.w-3\/4{width:75%}.w-3\/5{width:60%}.w-4\/5{width:80%}.w-\[6px\]{width:6px}.w-\[7px\]{width:7px}.w-\[11px\]{width:11px}.w-\[18px\]{width:18px}.w-\[72px\]{width:72px}.w-\[400px\]{width:400px}.w-full{width:100%}.max-w-\[85\%\]{max-width:85%}.max-w-\[260px\]{max-width:260px}.max-w-\[280px\]{max-width:280px}.max-w-\[300px\]{max-width:300px}.max-w-\[calc\(100vw-3rem\)\]{max-width:calc(100vw - 3rem)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.origin-bottom-left{transform-origin:0 100%}.origin-bottom-right{transform-origin:100% 100%}.translate-x-full{--tw-translate-x: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)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-crosshair{cursor:crosshair}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.list-none{list-style-type:none}.\[appearance\:textfield\]{appearance:textfield}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.place-items-center{place-items:center}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}:where(.divide-y>:not(:last-child)){--tw-divide-y-reverse:0;border-bottom-style:var(--tw-border-style);border-top-style:var(--tw-border-style);border-top-width:calc(1px * var(--tw-divide-y-reverse));border-bottom-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))}:where(.divide-border>:not(:last-child)){border-color:var(--color-border,oklch(90% 0 0))}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:var(--radius,.5rem)}.rounded-\[10px\]{border-radius:10px}.rounded-\[14px\]{border-radius:14px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:3.40282e38px}.rounded-tl{border-top-left-radius:var(--radius,.5rem)}.rounded-tr{border-top-right-radius:var(--radius,.5rem)}.rounded-br{border-bottom-right-radius:var(--radius,.5rem)}.rounded-bl{border-bottom-left-radius:var(--radius,.5rem)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[1\.5px\]{border-style:var(--tw-border-style);border-width:1.5px}.border-y{border-block-style:var(--tw-border-style);border-block-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-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-dashed{--tw-border-style:dashed;border-style:dashed}.border-none{--tw-border-style:none;border-style:none}.border-border{border-color:var(--color-border,oklch(90% 0 0))}.border-foreground{border-color:var(--color-foreground,oklch(15% 0 0))}.border-input{border-color:var(--color-input,oklch(90% 0 0))}.border-muted-foreground\/30{border-color:#6363634d}@supports (color:color-mix(in lab, red, red)){.border-muted-foreground\/30{border-color:color-mix(in oklab, var(--color-muted-foreground,oklch(50% 0 0)) 30%, transparent)}}.border-primary{border-color:var(--color-primary,oklch(50% .1 35))}.border-transparent{border-color:#0000}.border-t-foreground{border-top-color:var(--color-foreground,oklch(15% 0 0))}.bg-background{background-color:var(--color-background,oklch(99% 0 0))}.bg-background\/50{background-color:#fcfcfc80}@supports (color:color-mix(in lab, red, red)){.bg-background\/50{background-color:color-mix(in oklab, var(--color-background,oklch(99% 0 0)) 50%, transparent)}}.bg-background\/90{background-color:#fcfcfce6}@supports (color:color-mix(in lab, red, red)){.bg-background\/90{background-color:color-mix(in oklab, var(--color-background,oklch(99% 0 0)) 90%, transparent)}}.bg-background\/92{background-color:#fcfcfceb}@supports (color:color-mix(in lab, red, red)){.bg-background\/92{background-color:color-mix(in oklab, var(--color-background,oklch(99% 0 0)) 92%, transparent)}}.bg-border{background-color:var(--color-border,oklch(90% 0 0))}.bg-destructive{background-color:var(--color-destructive,oklch(50% .2 25))}.bg-destructive\/10{background-color:#bb061e1a}@supports (color:color-mix(in lab, red, red)){.bg-destructive\/10{background-color:color-mix(in oklab, var(--color-destructive,oklch(50% .2 25)) 10%, transparent)}}.bg-foreground{background-color:var(--color-foreground,oklch(15% 0 0))}.bg-foreground\/40{background-color:#0b0b0b66}@supports (color:color-mix(in lab, red, red)){.bg-foreground\/40{background-color:color-mix(in oklab, var(--color-foreground,oklch(15% 0 0)) 40%, transparent)}}.bg-muted{background-color:var(--color-muted,oklch(95% 0 0))}.bg-muted-foreground\/40{background-color:#63636366}@supports (color:color-mix(in lab, red, red)){.bg-muted-foreground\/40{background-color:color-mix(in oklab, var(--color-muted-foreground,oklch(50% 0 0)) 40%, transparent)}}.bg-muted\/40{background-color:#eee6}@supports (color:color-mix(in lab, red, red)){.bg-muted\/40{background-color:color-mix(in oklab, var(--color-muted,oklch(95% 0 0)) 40%, transparent)}}.bg-muted\/50{background-color:#eeeeee80}@supports (color:color-mix(in lab, red, red)){.bg-muted\/50{background-color:color-mix(in oklab, var(--color-muted,oklch(95% 0 0)) 50%, transparent)}}.bg-primary{background-color:var(--color-primary,oklch(50% .1 35))}.bg-primary\/5{background-color:#934c3a0d}@supports (color:color-mix(in lab, red, red)){.bg-primary\/5{background-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 5%, transparent)}}.bg-primary\/10{background-color:#934c3a1a}@supports (color:color-mix(in lab, red, red)){.bg-primary\/10{background-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 10%, transparent)}}.bg-transparent{background-color:#0000}.bg-gradient-to-t{--tw-gradient-position:to top in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.to-transparent{--tw-gradient-to:transparent;--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.object-cover{object-fit:cover}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-\[inherit\]{font-family:inherit}.text-\[9px\]{font-size:9px}.text-\[10\.5px\]{font-size:10.5px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12\.5px\]{font-size:12.5px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14\.5px\]{font-size:14.5px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.tracking-\[0\.16em\]{--tw-tracking:.16em;letter-spacing:.16em}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[inherit\]{color:inherit}.text-background{color:var(--color-background,oklch(99% 0 0))}.text-border{color:var(--color-border,oklch(90% 0 0))}.text-destructive{color:var(--color-destructive,oklch(50% .2 25))}.text-destructive-foreground{color:var(--color-destructive-foreground,oklch(99% 0 0))}.text-foreground{color:var(--color-foreground,oklch(15% 0 0))}.text-foreground\/80{color:#0b0b0bcc}@supports (color:color-mix(in lab, red, red)){.text-foreground\/80{color:color-mix(in oklab, var(--color-foreground,oklch(15% 0 0)) 80%, transparent)}}.text-muted-foreground{color:var(--color-muted-foreground,oklch(50% 0 0))}.text-muted-foreground\/30{color:#6363634d}@supports (color:color-mix(in lab, red, red)){.text-muted-foreground\/30{color:color-mix(in oklab, var(--color-muted-foreground,oklch(50% 0 0)) 30%, transparent)}}.text-muted-foreground\/40{color:#63636366}@supports (color:color-mix(in lab, red, red)){.text-muted-foreground\/40{color:color-mix(in oklab, var(--color-muted-foreground,oklch(50% 0 0)) 40%, transparent)}}.text-muted-foreground\/60{color:#63636399}@supports (color:color-mix(in lab, red, red)){.text-muted-foreground\/60{color:color-mix(in oklab, var(--color-muted-foreground,oklch(50% 0 0)) 60%, transparent)}}.text-muted-foreground\/70{color:#636363b3}@supports (color:color-mix(in lab, red, red)){.text-muted-foreground\/70{color:color-mix(in oklab, var(--color-muted-foreground,oklch(50% 0 0)) 70%, transparent)}}.text-primary{color:var(--color-primary,oklch(50% .1 35))}.text-primary-foreground{color:var(--color-primary-foreground,oklch(99% 0 0))}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.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,)}.line-through{text-decoration-line:line-through}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.accent-foreground{accent-color:var(--color-foreground,oklch(15% 0 0))}.accent-primary{accent-color:var(--color-primary,oklch(50% .1 35))}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-100{opacity:1}.shadow-\[0_1px_3px_rgba\(0\,0\,0\,0\.04\)\,0_6px_24px_rgba\(0\,0\,0\,0\.06\)\]{--tw-shadow:0 1px 3px var(--tw-shadow-color,#0000000a), 0 6px 24px var(--tw-shadow-color,#0000000f);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0_1px_4px_rgba\(0\,0\,0\,0\.10\)\,0_4px_12px_rgba\(0\,0\,0\,0\.08\)\]{--tw-shadow:0 1px 4px var(--tw-shadow-color,#0000001a), 0 4px 12px var(--tw-shadow-color,#00000014);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-background{--tw-ring-color:var(--color-background,oklch(99% 0 0))}.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-\[1px\]{--tw-backdrop-blur:blur(1px);-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,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-\[width\]{transition-property:width;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.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);transition-duration:var(--tw-duration,0s)}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.duration-700{--tw-duration:.7s;transition-duration:.7s}.ease-\[cubic-bezier\(0\.19\,1\,0\.22\,1\)\]{--tw-ease:cubic-bezier(.19,1,.22,1);transition-timing-function:cubic-bezier(.19,1,.22,1)}.\[transition-timing-function\:cubic-bezier\(0\.16\,1\,0\.3\,1\)\]{transition-timing-function:cubic-bezier(.16,1,.3,1)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.\[cimplify\:checkout\]{cimplify:checkout}@media (hover:hover){.group-hover\:scale-105:is(:where(.group):hover *){--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x) var(--tw-scale-y)}.group-hover\:scale-\[1\.04\]:is(:where(.group):hover *){scale:1.04}.group-hover\:text-foreground:is(:where(.group):hover *){color:var(--color-foreground,oklch(15% 0 0))}.group-hover\:text-primary:is(:where(.group):hover *){color:var(--color-primary,oklch(50% .1 35))}.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}}.placeholder\:text-muted-foreground::placeholder{color:var(--color-muted-foreground,oklch(50% 0 0))}.last\:border-b-0:last-child{border-bottom-style:var(--tw-border-style);border-bottom-width:0}.focus-within\:border-foreground:focus-within{border-color:var(--color-foreground,oklch(15% 0 0))}.focus-within\:bg-background:focus-within{background-color:var(--color-background,oklch(99% 0 0))}@media (hover:hover){.hover\:-translate-y-\[1px\]:hover{--tw-translate-y:calc(1px * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:-translate-y-px:hover{--tw-translate-y:-1px;translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:\!scale-110:hover{--tw-scale-x:110%!important;--tw-scale-y:110%!important;--tw-scale-z:110%!important;scale:var(--tw-scale-x) var(--tw-scale-y)!important}.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x) var(--tw-scale-y)}.hover\:scale-110:hover{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}.hover\:scale-\[1\.04\]:hover{scale:1.04}.hover\:scale-\[1\.08\]:hover{scale:1.08}.hover\:border-foreground:hover{border-color:var(--color-foreground,oklch(15% 0 0))}.hover\:border-primary\/20:hover{border-color:#934c3a33}@supports (color:color-mix(in lab, red, red)){.hover\:border-primary\/20:hover{border-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 20%, transparent)}}.hover\:border-primary\/40:hover{border-color:#934c3a66}@supports (color:color-mix(in lab, red, red)){.hover\:border-primary\/40:hover{border-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 40%, transparent)}}.hover\:border-primary\/50:hover{border-color:#934c3a80}@supports (color:color-mix(in lab, red, red)){.hover\:border-primary\/50:hover{border-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 50%, transparent)}}.hover\:\!bg-foreground:hover{background-color:var(--color-foreground,oklch(15% 0 0))!important}.hover\:bg-background:hover{background-color:var(--color-background,oklch(99% 0 0))}.hover\:bg-destructive\/10:hover{background-color:#bb061e1a}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/10:hover{background-color:color-mix(in oklab, var(--color-destructive,oklch(50% .2 25)) 10%, transparent)}}.hover\:bg-foreground\/90:hover{background-color:#0b0b0be6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-foreground\/90:hover{background-color:color-mix(in oklab, var(--color-foreground,oklch(15% 0 0)) 90%, transparent)}}.hover\:bg-muted:hover{background-color:var(--color-muted,oklch(95% 0 0))}.hover\:bg-muted\/70:hover{background-color:#eeeeeeb3}@supports (color:color-mix(in lab, red, red)){.hover\:bg-muted\/70:hover{background-color:color-mix(in oklab, var(--color-muted,oklch(95% 0 0)) 70%, transparent)}}.hover\:bg-muted\/80:hover{background-color:#eeec}@supports (color:color-mix(in lab, red, red)){.hover\:bg-muted\/80:hover{background-color:color-mix(in oklab, var(--color-muted,oklch(95% 0 0)) 80%, transparent)}}.hover\:bg-primary\/90:hover{background-color:#934c3ae6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 90%, transparent)}}.hover\:\!text-background:hover{color:var(--color-background,oklch(99% 0 0))!important}.hover\:text-destructive:hover{color:var(--color-destructive,oklch(50% .2 25))}.hover\:text-foreground:hover{color:var(--color-foreground,oklch(15% 0 0))}.hover\:text-primary:hover{color:var(--color-primary,oklch(50% .1 35))}.hover\:text-primary\/80:hover{color:#934c3acc}@supports (color:color-mix(in lab, red, red)){.hover\:text-primary\/80:hover{color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 80%, transparent)}}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-\[0_2px_6px_rgba\(0\,0\,0\,0\.04\)\,0_12px_40px_rgba\(0\,0\,0\,0\.10\)\]:hover{--tw-shadow:0 2px 6px var(--tw-shadow-color,#0000000a), 0 12px 40px 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)}}.focus\:border-primary:focus{border-color:var(--color-primary,oklch(50% .1 35))}.focus\:border-primary\/30:focus{border-color:#934c3a4d}@supports (color:color-mix(in lab, red, red)){.focus\:border-primary\/30:focus{border-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 30%, transparent)}}.focus\:ring-1:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-primary\/10:focus{--tw-ring-color:#934c3a1a}@supports (color:color-mix(in lab, red, red)){.focus\:ring-primary\/10:focus{--tw-ring-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 10%, transparent)}}.focus\:ring-primary\/20:focus{--tw-ring-color:#934c3a33}@supports (color:color-mix(in lab, red, red)){.focus\:ring-primary\/20:focus{--tw-ring-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 20%, transparent)}}.focus\:ring-ring:focus{--tw-ring-color:var(--color-ring,oklch(50% .1 35))}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.active\:scale-95:active{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x) var(--tw-scale-y)}.active\:scale-\[0\.99\]:active{scale:.99}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.data-\[checked\]\:border-primary[data-checked]{border-color:var(--color-primary,oklch(50% .1 35))}.data-\[checked\]\:bg-primary\/5[data-checked]{background-color:#934c3a0d}@supports (color:color-mix(in lab, red, red)){.data-\[checked\]\:bg-primary\/5[data-checked]{background-color:color-mix(in oklab, var(--color-primary,oklch(50% .1 35)) 5%, transparent)}}.\[\&\:\:-webkit-details-marker\]\:hidden::-webkit-details-marker{display:none}.\[\&\:\:-webkit-inner-spin-button\]\:appearance-none::-webkit-inner-spin-button{appearance:none}.\[\&\:\:-webkit-outer-spin-button\]\:appearance-none::-webkit-outer-spin-button{appearance:none}[open]>.\[\[open\]\>\&\]\:rotate-180{rotate:180deg}@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-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-divide-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@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-ease{syntax:"*";inherits:false}@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}
|