keystone-design-bootstrap 1.0.86 → 1.0.87
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/company-information-C1pP-SvU.d.ts +50 -0
- package/dist/config-C_XBZixg.d.ts +21 -0
- package/dist/consumer-BWjQawiO.d.ts +48 -0
- package/dist/design_system/portal/index.d.ts +52 -0
- package/dist/design_system/portal/index.js +3113 -0
- package/dist/design_system/portal/index.js.map +1 -0
- package/dist/design_system/sections/index.d.ts +2 -1
- package/dist/index.d.ts +5 -24
- package/dist/lib/consumer-session.d.ts +16 -0
- package/dist/lib/consumer-session.js +85 -0
- package/dist/lib/consumer-session.js.map +1 -0
- package/dist/lib/cta-urls.d.ts +34 -0
- package/dist/lib/cta-urls.js +33 -0
- package/dist/lib/cta-urls.js.map +1 -0
- package/dist/lib/server-api.d.ts +2 -1
- package/dist/lib/server-api.js +1 -1
- package/dist/lib/server-api.js.map +1 -1
- package/dist/next/contexts/form-definitions.d.ts +17 -0
- package/dist/next/contexts/form-definitions.js +21 -0
- package/dist/next/contexts/form-definitions.js.map +1 -0
- package/dist/next/gallery/design-gallery.d.ts +103 -0
- package/dist/next/gallery/design-gallery.js +19301 -0
- package/dist/next/gallery/design-gallery.js.map +1 -0
- package/dist/next/layouts/root-layout.d.ts +55 -0
- package/dist/next/layouts/root-layout.js +19713 -0
- package/dist/next/layouts/root-layout.js.map +1 -0
- package/dist/next/legal/privacy-policy.d.ts +7 -0
- package/dist/next/legal/privacy-policy.js +18949 -0
- package/dist/next/legal/privacy-policy.js.map +1 -0
- package/dist/next/legal/terms-of-service.d.ts +7 -0
- package/dist/next/legal/terms-of-service.js +18949 -0
- package/dist/next/legal/terms-of-service.js.map +1 -0
- package/dist/next/providers/ssr-provider.d.ts +12 -0
- package/dist/next/providers/ssr-provider.js +12 -0
- package/dist/next/providers/ssr-provider.js.map +1 -0
- package/dist/next/routes/chat.d.ts +26 -0
- package/dist/next/routes/chat.js +160 -0
- package/dist/next/routes/chat.js.map +1 -0
- package/dist/next/routes/consumer-auth.d.ts +33 -0
- package/dist/next/routes/consumer-auth.js +254 -0
- package/dist/next/routes/consumer-auth.js.map +1 -0
- package/dist/next/routes/form.d.ts +37 -0
- package/dist/next/routes/form.js +97 -0
- package/dist/next/routes/form.js.map +1 -0
- package/dist/package-IU_GpDA0.d.ts +74 -0
- package/dist/types/index.d.ts +6 -68
- package/package.json +28 -28
- package/src/design_system/portal/PortalPage.tsx +3 -2
- package/src/lib/server-api.ts +2 -1
- package/src/types/rails-actioncable.d.ts +16 -0
- package/dist/package-DeHKpQp7.d.ts +0 -121
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/next/legal/privacy-policy.tsx","../../../src/design_system/sections/index.tsx","../../../src/lib/component-registry.ts","../../../src/contexts/ThemeContext.tsx","../../../src/design_system/sections/hero-home.tsx","../../../src/design_system/elements/index.tsx","../../../src/design_system/elements/buttons/button.tsx","../../../src/utils/cx.ts","../../../src/utils/is-react-component.ts","../../../src/design_system/elements/buttons/round-button.tsx","../../../src/design_system/elements/button-group/button-group.tsx","../../../src/design_system/elements/input/input.tsx","../../../src/design_system/elements/input/hint-text.tsx","../../../src/design_system/elements/input/label.tsx","../../../src/design_system/elements/tooltip/tooltip.tsx","../../../src/design_system/elements/input/input-group.tsx","../../../src/design_system/elements/textarea/textarea.tsx","../../../src/design_system/elements/checkbox/privacy-checkbox.tsx","../../../src/design_system/elements/form/form.tsx","../../../src/design_system/elements/form-container/form-container.tsx","../../../src/design_system/elements/select/select.tsx","../../../src/design_system/elements/avatar/avatar.tsx","../../../src/design_system/elements/avatar/base-components/avatar-online-indicator.tsx","../../../src/design_system/elements/avatar/base-components/verified-tick.tsx","../../../src/design_system/elements/select/combobox.tsx","../../../src/design_system/elements/select/popover.tsx","../../../src/lib/hooks/use-resize-observer.ts","../../../src/design_system/elements/select/select-item.tsx","../../../src/design_system/elements/select/select-native.tsx","../../../src/design_system/elements/photo-fallback/photo-fallback.tsx","../../../src/utils/gradient-placeholder.ts","../../../src/design_system/elements/badges/badges.tsx","../../../src/design_system/elements/badges/badge-types.ts","../../../src/design_system/elements/badges/badge-groups.tsx","../../../src/design_system/elements/rating/rating-stars.tsx","../../../src/design_system/elements/rating/rating-badge.tsx","../../../src/design_system/elements/avatar/avatar-label-group.tsx","../../../src/design_system/elements/breadcrumb/Breadcrumb.tsx","../../../src/design_system/elements/featured-icon/featured-icon.tsx","../../../src/design_system/elements/pagination/pagination.tsx","../../../src/lib/hooks/use-breakpoint.ts","../../../src/design_system/elements/pagination/pagination-base.tsx","../../../src/design_system/elements/map/GoogleMap.tsx","../../../src/design_system/elements/markdown-renderer/MarkdownRenderer.tsx","../../../src/design_system/elements/buttons/button.aman.tsx","../../../src/design_system/elements/buttons/button.barelux.tsx","../../../src/design_system/elements/buttons/button.balance.tsx","../../../src/design_system/elements/input/input.aman.tsx","../../../src/design_system/elements/textarea/textarea.aman.tsx","../../../src/design_system/elements/select/select.aman.tsx","../../../src/design_system/elements/social-icons/social-icons.tsx","../../../src/design_system/elements/carousel/carousel.tsx","../../../src/design_system/elements/carousel/carousel-section-wrapper.tsx","../../../src/design_system/elements/video-modal.tsx","../../../src/design_system/elements/video-play-button.tsx","../../../src/design_system/elements/modal/modal.tsx","../../../src/design_system/utils/icon-mapping.tsx","../../../src/design_system/sections/services-home.tsx","../../../src/design_system/sections/about-home.tsx","../../../src/design_system/sections/feature-text.tsx","../../../src/utils/photo-helpers.ts","../../../src/design_system/sections/testimonials-home.tsx","../../../src/design_system/sections/testimonials-grid.tsx","../../../src/design_system/sections/faq-home.tsx","../../../src/design_system/sections/blog-section.tsx","../../../src/design_system/elements/carousel/carousel-base.tsx","../../../src/design_system/sections/contact-section.tsx","../../../src/design_system/sections/contact-section-form.tsx","../../../src/design_system/components/DynamicFormFields.tsx","../../../src/utils/countries.tsx","../../../src/utils/phone-helpers.ts","../../../src/tracking/firePixelEvent.ts","../../../src/tracking/captureEvent.ts","../../../src/next/contexts/form-definitions.tsx","../../../src/design_system/sections/footer-home.tsx","../../../src/design_system/sections/header-navigation.tsx","../../../src/design_system/sections/generic-header-component.tsx","../../../src/lib/cta-urls.ts","../../../src/design_system/sections/statistics-section.tsx","../../../src/design_system/sections/values-section.tsx","../../../src/design_system/sections/team-grid.tsx","../../../src/design_system/sections/location-grid.tsx","../../../src/design_system/sections/location-details-section.tsx","../../../src/design_system/sections/services-grid.tsx","../../../src/design_system/sections/social-media-grid.tsx","../../../src/design_system/sections/job-gallery.tsx","../../../src/design_system/sections/blog-home.tsx","../../../src/design_system/sections/blog-gallery.tsx","../../../src/design_system/sections/blog-cards.tsx","../../../src/design_system/sections/blog-post.tsx","../../../src/utils/markdown-toc.ts","../../../src/design_system/sections/contact-home.tsx","../../../src/design_system/sections/faq-grid.tsx","../../../src/design_system/sections/hero-faq.tsx","../../../src/design_system/sections/hero-generic-text.tsx","../../../src/design_system/sections/hero-location-detail.tsx","../../../src/design_system/sections/hero-service-detail.tsx","../../../src/design_system/sections/hero-social-media.tsx","../../../src/design_system/sections/hero-testimonials.tsx","../../../src/design_system/sections/home-hero-component.tsx","../../../src/design_system/elements/IconComponent.tsx","../../../src/design_system/sections/hero-job-detail.tsx","../../../src/design_system/sections/job-application-form.tsx","../../../src/design_system/sections/job-detail-section.tsx","../../../src/design_system/sections/policy-document-section.tsx","../../../src/design_system/sections/hero-home.aman.tsx","../../../src/design_system/sections/header-navigation.aman.tsx","../../../src/design_system/sections/about-home.aman.tsx","../../../src/design_system/sections/services-home.aman.tsx","../../../src/design_system/sections/services-grid.aman.tsx","../../../src/design_system/sections/testimonials-home.aman.tsx","../../../src/design_system/sections/testimonials-grid.aman.tsx","../../../src/design_system/sections/contact-section.aman.tsx","../../../src/design_system/sections/contact-section-form.aman.tsx","../../../src/design_system/sections/team-grid.aman.tsx","../../../src/design_system/sections/footer-home.aman.tsx","../../../src/design_system/sections/hero-service-detail.aman.tsx","../../../src/design_system/sections/values-section.aman.tsx","../../../src/design_system/sections/statistics-section.aman.tsx","../../../src/design_system/sections/location-grid.aman.tsx","../../../src/design_system/sections/location-details-section.aman.tsx","../../../src/design_system/sections/social-media-grid.aman.tsx","../../../src/design_system/sections/blog-home.aman.tsx","../../../src/design_system/sections/blog-gallery.aman.tsx","../../../src/design_system/sections/blog-post.aman.tsx","../../../src/design_system/sections/blog-section.aman.tsx","../../../src/design_system/sections/faq-home.aman.tsx","../../../node_modules/framer-motion/dist/es/context/LayoutGroupContext.mjs","../../../node_modules/framer-motion/dist/es/utils/use-constant.mjs","../../../node_modules/framer-motion/dist/es/utils/use-isomorphic-effect.mjs","../../../node_modules/framer-motion/dist/es/utils/is-browser.mjs","../../../node_modules/framer-motion/dist/es/context/PresenceContext.mjs","../../../node_modules/motion-utils/dist/es/array.mjs","../../../node_modules/motion-utils/dist/es/clamp.mjs","../../../node_modules/motion-utils/dist/es/format-error-message.mjs","../../../node_modules/motion-utils/dist/es/errors.mjs","../../../node_modules/motion-utils/dist/es/global-config.mjs","../../../node_modules/motion-utils/dist/es/is-numerical-string.mjs","../../../node_modules/motion-utils/dist/es/is-object.mjs","../../../node_modules/motion-utils/dist/es/is-zero-value-string.mjs","../../../node_modules/motion-utils/dist/es/memo.mjs","../../../node_modules/motion-utils/dist/es/noop.mjs","../../../node_modules/motion-utils/dist/es/pipe.mjs","../../../node_modules/motion-utils/dist/es/progress.mjs","../../../node_modules/motion-utils/dist/es/subscription-manager.mjs","../../../node_modules/motion-utils/dist/es/time-conversion.mjs","../../../node_modules/motion-utils/dist/es/velocity-per-second.mjs","../../../node_modules/motion-utils/dist/es/warn-once.mjs","../../../node_modules/motion-utils/dist/es/easing/cubic-bezier.mjs","../../../node_modules/motion-utils/dist/es/easing/modifiers/mirror.mjs","../../../node_modules/motion-utils/dist/es/easing/modifiers/reverse.mjs","../../../node_modules/motion-utils/dist/es/easing/back.mjs","../../../node_modules/motion-utils/dist/es/easing/anticipate.mjs","../../../node_modules/motion-utils/dist/es/easing/circ.mjs","../../../node_modules/motion-utils/dist/es/easing/ease.mjs","../../../node_modules/motion-utils/dist/es/easing/utils/is-easing-array.mjs","../../../node_modules/motion-utils/dist/es/easing/utils/is-bezier-definition.mjs","../../../node_modules/motion-utils/dist/es/easing/utils/map.mjs","../../../node_modules/motion-dom/dist/es/frameloop/order.mjs","../../../node_modules/motion-dom/dist/es/stats/buffer.mjs","../../../node_modules/motion-dom/dist/es/frameloop/render-step.mjs","../../../node_modules/motion-dom/dist/es/frameloop/batcher.mjs","../../../node_modules/motion-dom/dist/es/frameloop/frame.mjs","../../../node_modules/motion-dom/dist/es/frameloop/sync-time.mjs","../../../node_modules/motion-dom/dist/es/stats/animation-count.mjs","../../../node_modules/motion-dom/dist/es/animation/utils/is-css-variable.mjs","../../../node_modules/motion-dom/dist/es/value/types/numbers/index.mjs","../../../node_modules/motion-dom/dist/es/value/types/utils/sanitize.mjs","../../../node_modules/motion-dom/dist/es/value/types/utils/float-regex.mjs","../../../node_modules/motion-dom/dist/es/value/types/utils/is-nullish.mjs","../../../node_modules/motion-dom/dist/es/value/types/utils/single-color-regex.mjs","../../../node_modules/motion-dom/dist/es/value/types/color/utils.mjs","../../../node_modules/motion-dom/dist/es/value/types/color/rgba.mjs","../../../node_modules/motion-dom/dist/es/value/types/color/hex.mjs","../../../node_modules/motion-dom/dist/es/value/types/numbers/units.mjs","../../../node_modules/motion-dom/dist/es/value/types/color/hsla.mjs","../../../node_modules/motion-dom/dist/es/value/types/color/index.mjs","../../../node_modules/motion-dom/dist/es/value/types/utils/color-regex.mjs","../../../node_modules/motion-dom/dist/es/value/types/complex/index.mjs","../../../node_modules/motion-dom/dist/es/value/types/color/hsla-to-rgba.mjs","../../../node_modules/motion-dom/dist/es/utils/mix/immediate.mjs","../../../node_modules/motion-dom/dist/es/utils/mix/number.mjs","../../../node_modules/motion-dom/dist/es/utils/mix/color.mjs","../../../node_modules/motion-dom/dist/es/utils/mix/visibility.mjs","../../../node_modules/motion-dom/dist/es/utils/mix/complex.mjs","../../../node_modules/motion-dom/dist/es/utils/mix/index.mjs","../../../node_modules/motion-dom/dist/es/animation/drivers/frame.mjs","../../../node_modules/motion-dom/dist/es/animation/waapi/utils/linear.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/utils/calc-duration.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/utils/create-generator-easing.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/utils/velocity.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/spring/defaults.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/spring/find.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/spring/index.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/inertia.mjs","../../../node_modules/motion-dom/dist/es/utils/interpolate.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/offsets/fill.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/offsets/default.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/offsets/time.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/keyframes.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/get-final.mjs","../../../node_modules/motion-dom/dist/es/animation/utils/replace-transition-type.mjs","../../../node_modules/motion-dom/dist/es/animation/utils/WithPromise.mjs","../../../node_modules/motion-dom/dist/es/animation/JSAnimation.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/utils/fill-wildcards.mjs","../../../node_modules/motion-dom/dist/es/render/dom/parse-transform.mjs","../../../node_modules/motion-dom/dist/es/render/utils/keys-transform.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/utils/unit-conversion.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/KeyframesResolver.mjs","../../../node_modules/motion-dom/dist/es/render/dom/is-css-var.mjs","../../../node_modules/motion-dom/dist/es/render/dom/style-set.mjs","../../../node_modules/motion-dom/dist/es/utils/supports/scroll-timeline.mjs","../../../node_modules/motion-dom/dist/es/utils/supports/flags.mjs","../../../node_modules/motion-dom/dist/es/utils/supports/memo.mjs","../../../node_modules/motion-dom/dist/es/utils/supports/linear-easing.mjs","../../../node_modules/motion-dom/dist/es/animation/waapi/easing/cubic-bezier.mjs","../../../node_modules/motion-dom/dist/es/animation/waapi/easing/supported.mjs","../../../node_modules/motion-dom/dist/es/animation/waapi/easing/map-easing.mjs","../../../node_modules/motion-dom/dist/es/animation/waapi/start-waapi-animation.mjs","../../../node_modules/motion-dom/dist/es/animation/generators/utils/is-generator.mjs","../../../node_modules/motion-dom/dist/es/animation/waapi/utils/apply-generator.mjs","../../../node_modules/motion-dom/dist/es/animation/NativeAnimation.mjs","../../../node_modules/motion-dom/dist/es/animation/waapi/utils/unsupported-easing.mjs","../../../node_modules/motion-dom/dist/es/animation/NativeAnimationExtended.mjs","../../../node_modules/motion-dom/dist/es/animation/utils/is-animatable.mjs","../../../node_modules/motion-dom/dist/es/animation/utils/can-animate.mjs","../../../node_modules/motion-dom/dist/es/animation/utils/make-animation-instant.mjs","../../../node_modules/motion-dom/dist/es/animation/waapi/supports/waapi.mjs","../../../node_modules/motion-dom/dist/es/animation/AsyncMotionValueAnimation.mjs","../../../node_modules/motion-dom/dist/es/animation/utils/css-variables-conversion.mjs","../../../node_modules/motion-dom/dist/es/animation/utils/get-value-transition.mjs","../../../node_modules/motion-dom/dist/es/render/utils/keys-position.mjs","../../../node_modules/motion-dom/dist/es/value/types/auto.mjs","../../../node_modules/motion-dom/dist/es/value/types/test.mjs","../../../node_modules/motion-dom/dist/es/value/types/dimensions.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/utils/is-none.mjs","../../../node_modules/motion-dom/dist/es/value/types/complex/filter.mjs","../../../node_modules/motion-dom/dist/es/value/types/int.mjs","../../../node_modules/motion-dom/dist/es/value/types/maps/transform.mjs","../../../node_modules/motion-dom/dist/es/value/types/maps/number.mjs","../../../node_modules/motion-dom/dist/es/value/types/maps/defaults.mjs","../../../node_modules/motion-dom/dist/es/value/types/utils/animatable-none.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/utils/make-none-animatable.mjs","../../../node_modules/motion-dom/dist/es/animation/keyframes/DOMKeyframesResolver.mjs","../../../node_modules/motion-dom/dist/es/utils/resolve-elements.mjs","../../../node_modules/motion-dom/dist/es/value/types/utils/get-as-type.mjs","../../../node_modules/motion-dom/dist/es/utils/is-html-element.mjs","../../../node_modules/motion-dom/dist/es/value/index.mjs","../../../node_modules/motion-dom/dist/es/frameloop/microtask.mjs","../../../node_modules/motion-dom/dist/es/gestures/drag/state/is-active.mjs","../../../node_modules/motion-dom/dist/es/gestures/drag/state/set-active.mjs","../../../node_modules/motion-dom/dist/es/gestures/utils/setup.mjs","../../../node_modules/motion-dom/dist/es/gestures/hover.mjs","../../../node_modules/motion-dom/dist/es/gestures/utils/is-node-or-child.mjs","../../../node_modules/motion-dom/dist/es/gestures/utils/is-primary-pointer.mjs","../../../node_modules/motion-dom/dist/es/gestures/press/utils/is-keyboard-accessible.mjs","../../../node_modules/motion-dom/dist/es/gestures/press/utils/state.mjs","../../../node_modules/motion-dom/dist/es/gestures/press/utils/keyboard.mjs","../../../node_modules/motion-dom/dist/es/gestures/press/index.mjs","../../../node_modules/motion-dom/dist/es/utils/is-svg-element.mjs","../../../node_modules/motion-dom/dist/es/utils/is-svg-svg-element.mjs","../../../node_modules/motion-dom/dist/es/value/utils/is-motion-value.mjs","../../../node_modules/motion-dom/dist/es/value/types/utils/find.mjs","../../../node_modules/framer-motion/dist/es/context/MotionConfigContext.mjs","../../../node_modules/framer-motion/dist/es/components/AnimatePresence/use-presence.mjs","../../../node_modules/framer-motion/dist/es/context/LazyContext.mjs","../../../node_modules/framer-motion/dist/es/motion/features/definitions.mjs","../../../node_modules/framer-motion/dist/es/motion/features/load-features.mjs","../../../node_modules/framer-motion/dist/es/motion/utils/valid-prop.mjs","../../../node_modules/framer-motion/dist/es/render/dom/utils/filter-props.mjs","../../../node_modules/framer-motion/dist/es/motion/index.mjs","../../../node_modules/framer-motion/dist/es/context/MotionContext/index.mjs","../../../node_modules/framer-motion/dist/es/context/MotionContext/create.mjs","../../../node_modules/framer-motion/dist/es/animation/utils/is-animation-controls.mjs","../../../node_modules/framer-motion/dist/es/render/utils/is-variant-label.mjs","../../../node_modules/framer-motion/dist/es/render/utils/variant-props.mjs","../../../node_modules/framer-motion/dist/es/render/utils/is-controlling-variants.mjs","../../../node_modules/framer-motion/dist/es/context/MotionContext/utils.mjs","../../../node_modules/framer-motion/dist/es/render/dom/use-render.mjs","../../../node_modules/framer-motion/dist/es/render/html/use-props.mjs","../../../node_modules/framer-motion/dist/es/projection/styles/scale-border-radius.mjs","../../../node_modules/framer-motion/dist/es/projection/styles/scale-box-shadow.mjs","../../../node_modules/framer-motion/dist/es/projection/styles/scale-correction.mjs","../../../node_modules/framer-motion/dist/es/motion/utils/is-forced-motion-value.mjs","../../../node_modules/framer-motion/dist/es/render/html/utils/build-transform.mjs","../../../node_modules/framer-motion/dist/es/render/html/utils/build-styles.mjs","../../../node_modules/framer-motion/dist/es/render/html/utils/create-render-state.mjs","../../../node_modules/framer-motion/dist/es/render/svg/use-props.mjs","../../../node_modules/framer-motion/dist/es/render/svg/utils/path.mjs","../../../node_modules/framer-motion/dist/es/render/svg/utils/build-attrs.mjs","../../../node_modules/framer-motion/dist/es/render/svg/utils/create-render-state.mjs","../../../node_modules/framer-motion/dist/es/render/svg/utils/is-svg-tag.mjs","../../../node_modules/framer-motion/dist/es/render/svg/lowercase-elements.mjs","../../../node_modules/framer-motion/dist/es/render/dom/utils/is-svg-component.mjs","../../../node_modules/framer-motion/dist/es/motion/utils/use-visual-state.mjs","../../../node_modules/framer-motion/dist/es/render/utils/resolve-variants.mjs","../../../node_modules/framer-motion/dist/es/value/utils/resolve-motion-value.mjs","../../../node_modules/framer-motion/dist/es/render/html/utils/scrape-motion-values.mjs","../../../node_modules/framer-motion/dist/es/render/html/use-html-visual-state.mjs","../../../node_modules/framer-motion/dist/es/render/svg/utils/scrape-motion-values.mjs","../../../node_modules/framer-motion/dist/es/render/svg/use-svg-visual-state.mjs","../../../node_modules/framer-motion/dist/es/motion/utils/symbol.mjs","../../../node_modules/framer-motion/dist/es/motion/utils/use-motion-ref.mjs","../../../node_modules/framer-motion/dist/es/utils/is-ref-object.mjs","../../../node_modules/framer-motion/dist/es/motion/utils/use-visual-element.mjs","../../../node_modules/framer-motion/dist/es/render/dom/utils/camel-to-dash.mjs","../../../node_modules/framer-motion/dist/es/animation/optimized-appear/data-id.mjs","../../../node_modules/framer-motion/dist/es/context/SwitchLayoutGroupContext.mjs","../../../node_modules/framer-motion/dist/es/render/components/create-proxy.mjs","../../../node_modules/framer-motion/dist/es/render/dom/create-visual-element.mjs","../../../node_modules/framer-motion/dist/es/projection/geometry/conversion.mjs","../../../node_modules/framer-motion/dist/es/projection/utils/has-transform.mjs","../../../node_modules/framer-motion/dist/es/projection/geometry/delta-apply.mjs","../../../node_modules/framer-motion/dist/es/projection/utils/measure.mjs","../../../node_modules/framer-motion/dist/es/projection/geometry/models.mjs","../../../node_modules/framer-motion/dist/es/utils/reduced-motion/state.mjs","../../../node_modules/framer-motion/dist/es/utils/reduced-motion/index.mjs","../../../node_modules/framer-motion/dist/es/render/store.mjs","../../../node_modules/framer-motion/dist/es/render/utils/motion-values.mjs","../../../node_modules/framer-motion/dist/es/render/VisualElement.mjs","../../../node_modules/framer-motion/dist/es/render/dom/DOMVisualElement.mjs","../../../node_modules/framer-motion/dist/es/render/html/utils/render.mjs","../../../node_modules/framer-motion/dist/es/render/html/HTMLVisualElement.mjs","../../../node_modules/framer-motion/dist/es/render/svg/utils/camel-case-attrs.mjs","../../../node_modules/framer-motion/dist/es/render/svg/utils/render.mjs","../../../node_modules/framer-motion/dist/es/render/svg/SVGVisualElement.mjs","../../../node_modules/framer-motion/dist/es/render/utils/resolve-dynamic-variants.mjs","../../../node_modules/framer-motion/dist/es/animation/utils/is-keyframes-target.mjs","../../../node_modules/framer-motion/dist/es/render/utils/setters.mjs","../../../node_modules/framer-motion/dist/es/value/use-will-change/is.mjs","../../../node_modules/framer-motion/dist/es/value/use-will-change/add-will-change.mjs","../../../node_modules/framer-motion/dist/es/animation/optimized-appear/get-appear-id.mjs","../../../node_modules/framer-motion/dist/es/animation/animators/waapi/utils/get-final-keyframe.mjs","../../../node_modules/framer-motion/dist/es/animation/utils/default-transitions.mjs","../../../node_modules/framer-motion/dist/es/animation/utils/is-transition-defined.mjs","../../../node_modules/framer-motion/dist/es/animation/interfaces/motion-value.mjs","../../../node_modules/framer-motion/dist/es/animation/interfaces/visual-element-target.mjs","../../../node_modules/framer-motion/dist/es/animation/utils/calc-child-stagger.mjs","../../../node_modules/framer-motion/dist/es/animation/interfaces/visual-element-variant.mjs","../../../node_modules/framer-motion/dist/es/animation/interfaces/visual-element.mjs","../../../node_modules/framer-motion/dist/es/utils/shallow-compare.mjs","../../../node_modules/framer-motion/dist/es/render/utils/get-variant-context.mjs","../../../node_modules/framer-motion/dist/es/render/utils/animation-state.mjs","../../../node_modules/framer-motion/dist/es/motion/features/Feature.mjs","../../../node_modules/framer-motion/dist/es/motion/features/animation/index.mjs","../../../node_modules/framer-motion/dist/es/motion/features/animation/exit.mjs","../../../node_modules/framer-motion/dist/es/motion/features/animations.mjs","../../../node_modules/framer-motion/dist/es/events/add-dom-event.mjs","../../../node_modules/framer-motion/dist/es/events/event-info.mjs","../../../node_modules/framer-motion/dist/es/events/add-pointer-event.mjs","../../../node_modules/framer-motion/dist/es/projection/geometry/delta-calc.mjs","../../../node_modules/framer-motion/dist/es/projection/utils/each-axis.mjs","../../../node_modules/framer-motion/dist/es/utils/get-context-window.mjs","../../../node_modules/framer-motion/dist/es/utils/distance.mjs","../../../node_modules/framer-motion/dist/es/gestures/pan/PanSession.mjs","../../../node_modules/framer-motion/dist/es/gestures/drag/utils/constraints.mjs","../../../node_modules/framer-motion/dist/es/gestures/drag/VisualElementDragControls.mjs","../../../node_modules/framer-motion/dist/es/gestures/drag/index.mjs","../../../node_modules/framer-motion/dist/es/gestures/pan/index.mjs","../../../node_modules/framer-motion/dist/es/motion/features/layout/MeasureLayout.mjs","../../../node_modules/framer-motion/dist/es/projection/node/state.mjs","../../../node_modules/framer-motion/dist/es/animation/animate/single-value.mjs","../../../node_modules/framer-motion/dist/es/render/utils/compare-by-depth.mjs","../../../node_modules/framer-motion/dist/es/render/utils/flat-tree.mjs","../../../node_modules/framer-motion/dist/es/utils/delay.mjs","../../../node_modules/framer-motion/dist/es/projection/animation/mix-values.mjs","../../../node_modules/framer-motion/dist/es/projection/geometry/copy.mjs","../../../node_modules/framer-motion/dist/es/projection/geometry/delta-remove.mjs","../../../node_modules/framer-motion/dist/es/projection/geometry/utils.mjs","../../../node_modules/framer-motion/dist/es/projection/shared/stack.mjs","../../../node_modules/framer-motion/dist/es/projection/styles/transform.mjs","../../../node_modules/framer-motion/dist/es/projection/node/create-projection-node.mjs","../../../node_modules/framer-motion/dist/es/projection/node/DocumentProjectionNode.mjs","../../../node_modules/framer-motion/dist/es/projection/node/HTMLProjectionNode.mjs","../../../node_modules/framer-motion/dist/es/motion/features/drag.mjs","../../../node_modules/framer-motion/dist/es/gestures/hover.mjs","../../../node_modules/framer-motion/dist/es/gestures/focus.mjs","../../../node_modules/framer-motion/dist/es/gestures/press.mjs","../../../node_modules/framer-motion/dist/es/motion/features/viewport/observers.mjs","../../../node_modules/framer-motion/dist/es/motion/features/viewport/index.mjs","../../../node_modules/framer-motion/dist/es/motion/features/gestures.mjs","../../../node_modules/framer-motion/dist/es/motion/features/layout.mjs","../../../node_modules/framer-motion/dist/es/render/components/motion/feature-bundle.mjs","../../../node_modules/framer-motion/dist/es/render/components/motion/proxy.mjs","../../../src/design_system/sections/faq-grid.aman.tsx","../../../src/design_system/sections/hero-faq.aman.tsx","../../../src/design_system/sections/hero-generic-text.aman.tsx","../../../src/design_system/sections/hero-location-detail.aman.tsx","../../../src/design_system/sections/hero-social-media.aman.tsx","../../../src/design_system/sections/hero-testimonials.aman.tsx","../../../src/design_system/sections/job-gallery.aman.tsx","../../../src/design_system/sections/hero-job-detail.aman.tsx","../../../src/design_system/sections/job-application-form.aman.tsx","../../../src/design_system/sections/hero-home.barelux.tsx","../../../src/design_system/sections/header-navigation.barelux.tsx","../../../src/design_system/sections/services-home.barelux.tsx","../../../src/design_system/sections/about-home.barelux.tsx","../../../src/design_system/sections/testimonials-home.barelux.tsx","../../../src/design_system/sections/blog-section.barelux.tsx","../../../src/design_system/sections/blog-gallery.barelux.tsx","../../../src/design_system/sections/social-media-grid.barelux.tsx","../../../src/design_system/sections/contact-section.barelux.tsx","../../../src/design_system/sections/contact-section-form.barelux.tsx","../../../src/design_system/sections/footer-home.barelux.tsx","../../../src/design_system/sections/hero-home.balance.tsx","../../../src/design_system/sections/header-navigation.balance.tsx","../../../src/design_system/sections/footer-home.balance.tsx","../../../src/design_system/sections/contact-section.balance.tsx","../../../src/design_system/sections/contact-section-form.balance.tsx","../../../src/design_system/sections/services-home.balance.tsx","../../../src/design_system/sections/about-home.balance.tsx","../../../src/design_system/sections/testimonials-home.balance.tsx","../../../src/design_system/sections/blog-section.balance.tsx","../../../src/design_system/sections/team-grid.balance.tsx","../../../src/design_system/sections/services-grid.balance.tsx","../../../src/design_system/sections/faq-home.balance.tsx","../../../src/design_system/sections/email-signup-section.tsx","../../../src/design_system/sections/service-menu-section.tsx","../../../src/lib/hooks/use-image-cycle.ts","../../../src/lib/server-api.ts","../../../src/next/legal/placeholders.ts"],"sourcesContent":["import React from 'react';\nimport { GenericTextHero, PolicyDocumentSection } from '../../design_system/sections';\nimport { getCompanyInformation, getLocations } from '../../lib/server-api';\nimport { buildLegalPlaceholders, replaceLegalPlaceholders } from './placeholders';\nimport type { Location } from '../../types/api/location';\n\nexport async function PrivacyPolicyPage(props?: { markdownOverride?: string }) {\n const [companyInformation, locationsData] = await Promise.all([getCompanyInformation(), getLocations()]);\n const locations = Array.isArray(locationsData) ? (locationsData as Location[]) : [];\n const primaryLocation = locations.find((l) => l.is_primary) ?? locations[0];\n\n const placeholders = buildLegalPlaceholders(\n companyInformation?.company_name,\n null,\n companyInformation?.primary_email,\n companyInformation?.primary_phone,\n primaryLocation?.email\n );\n\n // Priority: explicit prop override → API-stored markdown\n const resolvedMarkdown = props?.markdownOverride ?? companyInformation?.privacy_policy_markdown ?? '';\n\n const markdown = replaceLegalPlaceholders(resolvedMarkdown.trim(), placeholders);\n const effectiveDate = `January 1, ${placeholders.effectiveYear}`;\n\n return (\n <main>\n <GenericTextHero title=\"Privacy Policy\" subtitle={companyInformation?.company_name ?? undefined} />\n <PolicyDocumentSection title=\"Privacy Policy\" effectiveDate={effectiveDate} content={markdown} />\n </main>\n );\n}\n","/**\n * Centralized Section Exports\n * All sections export from here with theme variant support\n * Includes all 34 section components (excluding index.tsx and .modern variants)\n */\n\n'use client';\n\nimport React from 'react';\nimport { getThemedComponent } from '../../lib/component-registry';\nimport { useTheme } from '../../contexts/ThemeContext';\n\n// Import base components (these are the defaults/classic theme)\nimport { HeroHome as BaseHeroHome } from './hero-home';\nimport { ServicesHome as BaseServicesHome } from './services-home';\nimport { AboutHome as BaseAboutHome } from './about-home';\nimport { TestimonialsHome as BaseTestimonialsHome } from './testimonials-home';\nimport { TestimonialsGrid as BaseTestimonialsGrid } from './testimonials-grid';\nimport { FAQHome as BaseFAQHome } from './faq-home';\nimport { BlogSection as BaseBlogSection } from './blog-section';\nimport ContactSectionBase from './contact-section';\nimport { FooterHome as BaseFooterHome } from './footer-home';\nimport { HeaderNavigation as BaseHeaderNavigation } from './header-navigation';\nimport { GenericHeaderComponent as BaseGenericHeaderComponent } from './generic-header-component';\nimport { StatisticsSection as BaseStatisticsSection } from './statistics-section';\nimport { ValuesSection as BaseValuesSection } from './values-section';\nimport { TeamGrid as BaseTeamGrid } from './team-grid';\nimport { LocationGrid as BaseLocationGrid } from './location-grid';\nimport { LocationDetailsSection as BaseLocationDetailsSection } from './location-details-section';\nimport { ServicesGrid as BaseServicesGrid } from './services-grid';\nimport { SocialMediaGrid as BaseSocialMediaGrid } from './social-media-grid';\nimport { JobGallery as BaseJobGallery } from './job-gallery';\nimport { BlogHome as BaseBlogHome } from './blog-home';\nimport { BlogGallery as BaseBlogGallery } from './blog-gallery';\nimport { BlogPostSection as BaseBlogPostSection } from './blog-post';\nimport { ContactHome as BaseContactHome } from './contact-home';\nimport { FAQGrid as BaseFAQGrid } from './faq-grid';\nimport { FAQHero as BaseFAQHero } from './hero-faq';\nimport { GenericTextHero as BaseGenericTextHero } from './hero-generic-text';\nimport { LocationDetailHero as BaseLocationDetailHero } from './hero-location-detail';\nimport { ServiceDetailHero as BaseServiceDetailHero } from './hero-service-detail';\nimport { ServiceDetailContent as BaseServiceDetailContent } from './service-detail-content';\nimport { SocialMediaHero as BaseSocialMediaHero } from './hero-social-media';\nimport { TestimonialsHero as BaseTestimonialsHero } from './hero-testimonials';\nimport { HomeHeroComponent as BaseHomeHeroComponent } from './home-hero-component';\nimport { JobDetailHero as BaseJobDetailHero } from './hero-job-detail';\nimport { JobDetailSection as BaseJobDetailSection } from './job-detail-section';\nimport { PolicyDocumentSection as BasePolicyDocumentSection } from './policy-document-section';\n// Import variant files to trigger their registration\n// Aman theme variants\nimport './hero-home.aman';\nimport './header-navigation.aman';\nimport './about-home.aman';\nimport './services-home.aman';\nimport './services-grid.aman';\nimport './testimonials-home.aman';\nimport './testimonials-grid.aman';\nimport './contact-section.aman';\nimport './team-grid.aman';\nimport './footer-home.aman';\nimport './hero-service-detail.aman';\nimport './values-section.aman';\nimport './statistics-section.aman';\nimport './location-grid.aman';\nimport './location-details-section.aman';\nimport './social-media-grid.aman';\nimport './blog-home.aman';\nimport './blog-gallery.aman';\nimport './blog-post.aman';\nimport './blog-section.aman';\nimport './faq-home.aman';\nimport './faq-grid.aman';\nimport './hero-faq.aman';\nimport './hero-generic-text.aman';\nimport './hero-location-detail.aman';\nimport './hero-social-media.aman';\nimport './hero-testimonials.aman';\nimport './job-gallery.aman';\nimport './hero-job-detail.aman';\nimport './job-detail-section.aman';\n\n// Barelux theme variants\nimport './hero-home.barelux';\nimport './header-navigation.barelux';\nimport './services-home.barelux';\nimport './about-home.barelux';\nimport './testimonials-home.barelux';\nimport './blog-section.barelux';\nimport './blog-gallery.barelux';\nimport './social-media-grid.barelux';\nimport './contact-section.barelux';\nimport './footer-home.barelux';\n\n// Balance theme variants\nimport './hero-home.balance';\nimport './header-navigation.balance';\nimport './footer-home.balance';\nimport './contact-section.balance';\nimport './contact-section-form.balance';\nimport './services-home.balance';\nimport './about-home.balance';\nimport './testimonials-home.balance';\nimport './blog-section.balance';\nimport './statistics-section.balance';\nimport './team-grid.balance';\nimport './services-grid.balance';\nimport './faq-home.balance';\n\n/**\n * Create a themed component wrapper that checks for variants\n * Falls back to base component if no variant exists\n * Uses type erasure to store components with different prop requirements\n * Type casts are used internally to allow components with required props\n */\nfunction createThemedExport<P extends Record<string, unknown>>(\n componentName: string,\n // The base component is cast internally - the actual component type is preserved at usage sites\n BaseComponent: React.ComponentType<P>\n) {\n return function ThemedComponent(props: P) {\n const { theme } = useTheme();\n \n try {\n // Try to get themed variant from registry\n const Component = getThemedComponent(componentName, theme);\n // Type erasure: components are stored without prop type information\n // but are type-checked where they're actually used\n return React.createElement(Component as React.ComponentType<P>, props);\n } catch {\n // No variant registered, use base component\n return React.createElement(BaseComponent, props);\n }\n };\n}\n\n// All components wrapped with themed export (falls back to base if no variant)\nexport const HeroHome = createThemedExport('hero-home', BaseHeroHome);\nexport const ServicesHome = createThemedExport('services-home', BaseServicesHome as unknown as React.ComponentType<Record<string, unknown>>);\nexport const AboutHome = createThemedExport('about-home', BaseAboutHome);\nexport const TestimonialsHome = createThemedExport('testimonials-home', BaseTestimonialsHome as unknown as React.ComponentType<Record<string, unknown>>);\nexport const TestimonialsGrid = createThemedExport('testimonials-grid', BaseTestimonialsGrid);\nexport const FAQHome = createThemedExport('faq-home', BaseFAQHome as unknown as React.ComponentType<Record<string, unknown>>);\nexport const BlogSection = createThemedExport('blog-section', BaseBlogSection as unknown as React.ComponentType<Record<string, unknown>>);\nexport const ContactSection = createThemedExport('contact-section', ContactSectionBase);\nexport const FooterHome = createThemedExport('footer-home', BaseFooterHome as unknown as React.ComponentType<Record<string, unknown>>);\nexport const HeaderNavigation = createThemedExport('header-navigation', BaseHeaderNavigation);\nexport const GenericHeaderComponent = createThemedExport('generic-header-component', BaseGenericHeaderComponent as unknown as React.ComponentType<Record<string, unknown>>);\nexport const StatisticsSection = createThemedExport('statistics-section', BaseStatisticsSection);\nexport const ValuesSection = createThemedExport('values-section', BaseValuesSection);\nexport const TeamGrid = createThemedExport('team-grid', BaseTeamGrid);\nexport const LocationGrid = createThemedExport('location-grid', BaseLocationGrid);\nexport const LocationDetailsSection = createThemedExport('location-details-section', BaseLocationDetailsSection);\nexport const ServicesGrid = createThemedExport('services-grid', BaseServicesGrid);\nexport const SocialMediaGrid = createThemedExport('social-media-grid', BaseSocialMediaGrid);\nexport const JobGallery = createThemedExport('job-gallery', BaseJobGallery);\nexport const BlogHome = createThemedExport('blog-home', BaseBlogHome);\nexport const BlogGallery = createThemedExport('blog-gallery', BaseBlogGallery);\nexport const BlogPostSection = createThemedExport('blog-post', BaseBlogPostSection);\nexport const ContactHome = createThemedExport('contact-home', BaseContactHome);\nexport const FAQGrid = createThemedExport('faq-grid', BaseFAQGrid);\nexport const FAQHero = createThemedExport('hero-faq', BaseFAQHero);\n\n// Re-export component variants (these files contain multiple variants, not a single component)\nexport * from './blog-cards';\nexport * from './feature-tab';\nexport * from './feature-text';\nexport const GenericTextHero = createThemedExport('hero-generic-text', BaseGenericTextHero);\nexport const LocationDetailHero = createThemedExport('hero-location-detail', BaseLocationDetailHero);\nexport const ServiceDetailHero = createThemedExport('hero-service-detail', BaseServiceDetailHero);\nexport const ServiceDetailContent = BaseServiceDetailContent;\nexport const JobDetailHero = createThemedExport('hero-job-detail', BaseJobDetailHero);\nexport const JobDetailSection = createThemedExport('job-detail-section', BaseJobDetailSection);\nexport const PolicyDocumentSection = BasePolicyDocumentSection;\nexport const SocialMediaHero = createThemedExport('hero-social-media', BaseSocialMediaHero);\nexport const TestimonialsHero = createThemedExport('hero-testimonials', BaseTestimonialsHero);\nexport const HomeHeroComponent = createThemedExport('home-hero-component', BaseHomeHeroComponent as unknown as React.ComponentType<Record<string, unknown>>);\n\n// Re-export application form (client component, no theme variants)\nexport { JobApplicationForm } from './job-application-form';\n\n// Email / newsletter signup section (client component, no theme variants needed)\nexport { EmailSignupSection } from './email-signup-section';\nexport type { EmailSignupSectionProps } from './email-signup-section';\n\n// Service Menu: packages + treatments; nested specials as badges / modal callouts\nexport { ServiceMenuSection } from './service-menu-section';\nexport type { ServiceMenuSectionProps, PackageForMenu } from './service-menu-section';\n\n// Re-export types\nexport type { Theme } from '../../themes';\n","/**\n * Component Registry\n * Runtime registry for component theme variants\n */\n\n'use client';\n\nimport React from 'react';\nimport { Theme } from '../themes';\n\n// The registry stores components with different prop types\n// We use React.ComponentType (without generics) to store components dynamically\n// This is type-safe because the generic registerThemeVariant function ensures correct types at registration\n// and components are retrieved and used dynamically at runtime\nconst registry = new Map<string, Map<string, React.ComponentType<unknown>>>();\n\n// Generic function accepts any component type without requiring type assertions at call sites\n// The component is stored with type erasure internally, but callers have full type safety\nexport function registerThemeVariant<P = unknown>(\n componentName: string,\n theme: string,\n component: React.ComponentType<P>\n) {\n if (!registry.has(componentName)) {\n registry.set(componentName, new Map());\n }\n registry.get(componentName)!.set(theme, component as React.ComponentType<unknown>);\n}\n\nexport function getThemedComponent(\n componentName: string,\n theme: Theme = 'classic'\n): React.ComponentType<unknown> {\n const variants = registry.get(componentName);\n \n if (!variants || variants.size === 0) {\n throw new Error(`No theme variants registered for \"${componentName}\"`);\n }\n \n if (variants.has(theme)) {\n return variants.get(theme)!;\n }\n \n if (theme === 'classic') {\n throw new Error(`No classic variant for \"${componentName}\" - use base component`);\n }\n \n throw new Error(`No variant available for \"${componentName}.${theme}\"`);\n}\n\nexport function getRegistry() {\n const result: Record<string, string[]> = {};\n registry.forEach((variants, name) => {\n result[name] = Array.from(variants.keys());\n });\n return result;\n}\n","'use client';\n\nimport { createContext, useContext } from 'react';\nimport { Theme, isValidTheme } from '../themes';\n\ninterface ThemeContextValue {\n theme: Theme;\n}\n\nconst ThemeContext = createContext<ThemeContextValue>({ theme: 'classic' });\n\nexport function ThemeProvider({ \n theme, \n children \n}: { \n theme: Theme; \n children: React.ReactNode;\n}) {\n // Validate theme at runtime\n if (!isValidTheme(theme)) {\n console.warn(`Invalid theme \"${theme}\", falling back to \"classic\"`);\n theme = 'classic';\n }\n \n return (\n <ThemeContext.Provider value={{ theme }}>\n {children}\n </ThemeContext.Provider>\n );\n}\n\nexport function useTheme() {\n return useContext(ThemeContext);\n}\n","\"use client\";\n\nimport { Fragment, useMemo, useState } from \"react\";\nimport React from \"react\";\nimport { Button, Form, Input, PhotoWithFallback, VideoModal, VideoPlayButton } from '../elements';\nimport { cx } from '../../utils/cx';\nimport { mapIcon } from '../utils/icon-mapping';\nimport type { FC } from \"react\";\nimport type { WebsitePhotos } from '../../types/api/website-photos';\n\n\ninterface Statistic {\n number: string;\n label: string;\n icon?: string;\n color?: string;\n}\n\ninterface EmailSignup {\n placeholder?: string;\n button_text?: string;\n privacy_policy_link?: string;\n}\n\ninterface HeroHomeProps {\n websitePhotos?: WebsitePhotos | null;\n reviews?: {\n rating?: number;\n count?: number;\n };\n headline?: string;\n subhead?: string;\n statistics?: Statistic[];\n email_signup?: EmailSignup;\n onEmailSubmit?: (email: string) => void;\n videoUrl?: string;\n}\n\nconst AvatarsWithReview = ({ \n count = 200, \n stockPhotos = [],\n className \n}: { \n count?: number;\n stockPhotos?: Array<{ id?: number; url?: string; thumbnail_url?: string; alt?: string }>;\n className?: string;\n}) => {\n // Get up to 5 stock photos for avatars, cycling if needed\n const avatarPhotos = useMemo(() => {\n if (stockPhotos.length === 0) {\n return Array(5).fill(null).map((_, i) => ({\n url: undefined,\n alt: `Avatar ${i + 1}`,\n fallbackId: `avatar-${i + 1}`\n }));\n }\n \n return Array(5).fill(null).map((_, i) => {\n const photo = stockPhotos[i % stockPhotos.length];\n return {\n url: photo?.url || photo?.thumbnail_url,\n alt: photo?.alt || `Avatar ${i + 1}`,\n fallbackId: photo?.id || `avatar-${i + 1}`\n };\n });\n }, [stockPhotos]);\n \n return (\n <div className={cx(\"flex items-center gap-4\", className)}>\n <div className=\"inline-flex -space-x-3 overflow-hidden\">\n {avatarPhotos.map((avatar, index) => (\n <div\n key={index}\n className=\"inline-block size-10 rounded-full ring-[1.5px] ring-bg-primary outline-1 -outline-offset-1 outline-avatar-contrast-border overflow-hidden\"\n >\n <PhotoWithFallback\n photoUrl={avatar.url}\n photoAlt={avatar.alt}\n fallbackId={avatar.fallbackId}\n className=\"size-full object-cover\"\n />\n </div>\n ))}\n </div>\n <div className=\"flex flex-col gap-0.5\">\n <div className=\"flex items-center gap-2\">\n <div className=\"flex items-center gap-1\">\n {Array(5)\n .fill(null)\n .map((_, index) => {\n const clipId0 = `clip0_star_${index}`;\n const clipId1 = `clip1_star_${index}`;\n return (\n <svg\n key={index}\n width={20}\n height={20}\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n className=\"relative size-5 shrink-0 grow-0\"\n preserveAspectRatio=\"none\"\n >\n <g clipPath={`url(#${clipId0})`}>\n <path\n d=\"M9.53834 1.60996C9.70914 1.19932 10.2909 1.19932 10.4617 1.60996L12.5278 6.57744C12.5998 6.75056 12.7626 6.86885 12.9495 6.88383L18.3123 7.31376C18.7556 7.3493 18.9354 7.90256 18.5976 8.19189L14.5117 11.6919C14.3693 11.8139 14.3071 12.0053 14.3506 12.1876L15.5989 17.4208C15.7021 17.8534 15.2315 18.1954 14.8519 17.9635L10.2606 15.1592C10.1006 15.0615 9.89938 15.0615 9.73937 15.1592L5.14806 17.9635C4.76851 18.1954 4.29788 17.8534 4.40108 17.4208L5.64939 12.1876C5.69289 12.0053 5.6307 11.8139 5.48831 11.6919L1.40241 8.19189C1.06464 7.90256 1.24441 7.3493 1.68773 7.31376L7.05054 6.88383C7.23744 6.86885 7.40024 6.75056 7.47225 6.57744L9.53834 1.60996Z\"\n className=\"fill-bg-tertiary\"\n />\n <g clipPath={`url(#${clipId1})`}>\n <path\n d=\"M9.53834 1.60996C9.70914 1.19932 10.2909 1.19932 10.4617 1.60996L12.5278 6.57744C12.5998 6.75056 12.7626 6.86885 12.9495 6.88383L18.3123 7.31376C18.7556 7.3493 18.9354 7.90256 18.5976 8.19189L14.5117 11.6919C14.3693 11.8139 14.3071 12.0053 14.3506 12.1876L15.5989 17.4208C15.7021 17.8534 15.2315 18.1954 14.8519 17.9635L10.2606 15.1592C10.1006 15.0615 9.89938 15.0615 9.73937 15.1592L5.14806 17.9635C4.76851 18.1954 4.29788 17.8534 4.40108 17.4208L5.64939 12.1876C5.69289 12.0053 5.6307 11.8139 5.48831 11.6919L1.40241 8.19189C1.06464 7.90256 1.24441 7.3493 1.68773 7.31376L7.05054 6.88383C7.23744 6.86885 7.40024 6.75056 7.47225 6.57744L9.53834 1.60996Z\"\n className=\"fill-warning-300\"\n />\n </g>\n </g>\n <defs>\n <clipPath id={clipId0}>\n <rect width={20} height={20} fill=\"white\" />\n </clipPath>\n <clipPath id={clipId1}>\n <rect width={20} height={20} fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n );\n })}\n </div>\n </div>\n <p className=\"text-md font-medium text-tertiary\">from {count}+ reviews</p>\n </div>\n </div>\n );\n};\n\nexport const HeroHome = ({\n websitePhotos,\n reviews,\n headline = \"\",\n subhead = \"\",\n statistics = [],\n email_signup,\n onEmailSubmit,\n videoUrl,\n}: HeroHomeProps) => {\n const [showVideo, setShowVideo] = useState(false);\n \n // Get hero image from props\n const heroImage = {\n url: websitePhotos?.hero?.url || '',\n alt: websitePhotos?.hero?.alt || 'Hero image',\n };\n \n const stockPhotos = websitePhotos?.stock_photos || [];\n \n return (\n <Fragment>\n <section className=\"bg-primary py-16 md:pb-24\">\n <div className=\"mx-auto grid max-w-container grid-cols-1 items-center gap-16 px-4 md:px-8 lg:grid-cols-2 lg:gap-8\">\n <div className=\"flex max-w-3xl flex-col items-start lg:pr-8\">\n <h1 className=\"text-display-md font-semibold text-primary md:text-display-lg lg:text-display-xl\">\n {headline || 'Welcome'}\n </h1>\n <p className=\"mt-4 max-w-lg text-lg text-balance text-tertiary md:mt-6 md:text-xl\">\n {subhead || ''}\n </p>\n\n {email_signup && (\n <Form\n onSubmit={(e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n const formData = new FormData(e.currentTarget);\n const email = formData.get(\"email\") as string;\n if (onEmailSubmit) {\n onEmailSubmit(email);\n }\n }}\n className=\"mt-8 flex w-full flex-col items-stretch gap-4 md:mt-12 md:max-w-120 md:flex-row md:items-start\"\n >\n <Input\n isRequired\n size=\"md\"\n name=\"email\"\n type=\"email\"\n placeholder={email_signup.placeholder}\n wrapperClassName=\"py-0.5\"\n hint={\n <span>\n We care about your data in our{\" \"}\n <a\n href={email_signup.privacy_policy_link}\n className=\"rounded-xs underline underline-offset-3 outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n privacy policy\n </a>\n .\n </span>\n }\n />\n <Button type=\"submit\" color=\"primary\" size=\"xl\">\n {email_signup.button_text}\n </Button>\n </Form>\n )}\n\n <AvatarsWithReview \n count={reviews?.count}\n stockPhotos={stockPhotos}\n className=\"mt-8 md:mt-12\"\n />\n\n {(() => {\n const statsToShow = statistics && statistics.length > 0 ? statistics.slice(0, 4) : [];\n \n return statsToShow.length > 0 && (\n <dl className=\"mt-8 grid grid-cols-2 gap-x-6 gap-y-4 md:mt-12\">\n {statsToShow.map((stat: { number: string; label: string; icon?: string | FC<{ className?: string }> | React.ReactNode; color?: string }, index: number) => {\n const IconComponent = mapIcon(stat.icon);\n \n return (\n <div key={index} className=\"flex flex-col gap-2\">\n <div className=\"flex items-center gap-2\">\n {IconComponent && (\n <div className=\"size-5 shrink-0\">\n <IconComponent className=\"w-full h-full\" />\n </div>\n )}\n <dd className=\"text-lg font-semibold text-primary md:text-xl\">{stat.number}</dd>\n </div>\n <dt className=\"text-sm font-medium text-tertiary md:text-md\">{stat.label}</dt>\n </div>\n );\n })}\n </dl>\n );\n })()}\n </div>\n\n <div className=\"relative lg:h-full lg:min-h-160\">\n <PhotoWithFallback\n photoUrl={heroImage.url}\n photoAlt={heroImage.alt}\n fallbackId=\"hero-home-image\"\n className=\"inset-0 h-70 w-full object-cover md:h-110 lg:absolute lg:h-full\"\n />\n \n {/* Video play button overlay */}\n {videoUrl && (\n <div className=\"absolute inset-0 flex items-center justify-center\">\n <VideoPlayButton onClick={() => setShowVideo(true)} />\n </div>\n )}\n </div>\n </div>\n </section>\n \n {/* Video modal */}\n {videoUrl && (\n <VideoModal \n isOpen={showVideo}\n onClose={() => setShowVideo(false)}\n videoUrl={videoUrl}\n />\n )}\n </Fragment>\n );\n};\n","/**\n * Centralized Elements Exports\n * All commonly used elements export from here with theme variant support\n * Includes: Buttons, Form inputs, Date pickers, UI components\n * Excludes: .demo.tsx, .story.tsx, and specialized sub-components\n */\n\n'use client';\n\nimport React from 'react';\nimport { getThemedComponent } from '../../lib/component-registry';\nimport { useTheme } from '../../contexts/ThemeContext';\n\n// Import all base components - Buttons\nimport { Button as BaseButton } from './buttons/button';\nimport { RoundButton as BaseRoundButton } from './buttons/round-button';\nimport { ButtonGroup as BaseButtonGroup } from './button-group/button-group';\n\n// Form inputs\nimport { Input as BaseInput, InputBase as BaseInputBase } from './input/input';\nimport { InputGroup as BaseInputGroup } from './input/input-group';\nimport { TextArea as BaseTextarea } from './textarea/textarea';\nimport { PrivacyCheckbox as BasePrivacyCheckbox } from './checkbox/privacy-checkbox';\nimport { Form as BaseForm } from './form/form';\nimport { FormContainer as BaseFormContainer } from './form-container/form-container';\nimport { Label as BaseLabel } from './input/label';\nimport { HintText as BaseHintText } from './input/hint-text';\nimport { Select as BaseSelect } from './select/select';\nimport { SelectItem as BaseSelectItem } from './select/select-item';\nimport { NativeSelect as BaseNativeSelect } from './select/select-native';\n\n// UI components\nimport PhotoWithFallbackBase from './photo-fallback/photo-fallback';\nimport { Badge as BaseBadge, BadgeWithDot as BaseBadgeWithDot } from './badges/badges';\nimport { BadgeGroup as BaseBadgeGroup } from './badges/badge-groups';\nimport { RatingStars as BaseRatingStars } from './rating/rating-stars';\nimport { RatingBadge as BaseRatingBadge } from './rating/rating-badge';\nimport { Tooltip as BaseTooltip } from './tooltip/tooltip';\nimport { Avatar as BaseAvatar } from './avatar/avatar';\nimport { AvatarLabelGroup as BaseAvatarLabelGroup } from './avatar/avatar-label-group';\nimport { VerifiedTick as BaseVerifiedTick } from './avatar/base-components';\nimport { Breadcrumb as BaseBreadcrumb } from './breadcrumb/Breadcrumb';\nimport { FeaturedIcon as BaseFeaturedIcon } from './featured-icon/featured-icon';\nimport { PaginationPageDefault as BasePaginationPageDefault, PaginationPageMinimalCenter as BasePaginationPageMinimalCenter } from './pagination/pagination';\nimport BaseGoogleMap from './map/GoogleMap';\nimport BaseMarkdownRenderer from './markdown-renderer/MarkdownRenderer';\n\n// Import variant files to trigger registration (only ones that exist)\nimport './buttons/button.aman';\nimport './buttons/button.barelux';\nimport './buttons/button.balance';\nimport './input/input.aman';\nimport './textarea/textarea.aman';\nimport './select/select.aman';\n\n/**\n * Create themed component wrapper\n * Uses type erasure to store components with different prop requirements\n * Type casts are used internally to allow components with required props\n */\nfunction createThemedExport<P extends Record<string, unknown>>(\n componentName: string,\n // The base component is cast internally - the actual component type is preserved at usage sites\n BaseComponent: React.ComponentType<P>\n) {\n return function ThemedComponent(props: P) {\n const { theme } = useTheme();\n \n try {\n const Component = getThemedComponent(componentName, theme);\n // Type erasure: components are stored without prop type information\n // but are type-checked where they're actually used\n return React.createElement(Component as React.ComponentType<P>, props);\n } catch {\n // No variant registered, use base component\n return React.createElement(BaseComponent, props);\n }\n };\n}\n\n// All elements wrapped (falls back to base if no variant)\n// Buttons\nexport const Button = createThemedExport('button', BaseButton);\nexport const RoundButton = createThemedExport('round-button', BaseRoundButton);\nexport const ButtonGroup = createThemedExport('button-group', BaseButtonGroup);\n\n// Form inputs\nexport const Input = createThemedExport('input', BaseInput);\nexport const InputBase = BaseInputBase;\nexport const Textarea = createThemedExport('textarea', BaseTextarea);\nexport const PrivacyCheckbox = BasePrivacyCheckbox;\nexport const Form = createThemedExport('form', BaseForm);\nexport const FormContainer = createThemedExport('form-container', BaseFormContainer as unknown as React.ComponentType<Record<string, unknown>>);\nexport const InputGroup = createThemedExport('input-group', BaseInputGroup as unknown as React.ComponentType<Record<string, unknown>>);\nexport const Label = createThemedExport('label', BaseLabel as unknown as React.ComponentType<Record<string, unknown>>);\nexport const HintText = createThemedExport('hint-text', BaseHintText as unknown as React.ComponentType<Record<string, unknown>>);\nexport const Select = createThemedExport('select', BaseSelect as unknown as React.ComponentType<Record<string, unknown>>);\nexport const SelectItem = createThemedExport('select-item', BaseSelectItem as unknown as React.ComponentType<Record<string, unknown>>);\nexport const NativeSelect = createThemedExport('native-select', BaseNativeSelect as unknown as React.ComponentType<Record<string, unknown>>);\n\n// UI components\nexport const PhotoWithFallback = createThemedExport('photo-fallback', PhotoWithFallbackBase);\nexport const Badge = createThemedExport('badge', BaseBadge as unknown as React.ComponentType<Record<string, unknown>>);\nexport const BadgeWithDot = createThemedExport('badge-with-dot', BaseBadgeWithDot as unknown as React.ComponentType<Record<string, unknown>>);\nexport const BadgeGroup = createThemedExport('badge-group', BaseBadgeGroup as unknown as React.ComponentType<Record<string, unknown>>);\nexport const RatingStars = createThemedExport('rating-stars', BaseRatingStars);\nexport const RatingBadge = createThemedExport('rating-badge', BaseRatingBadge);\nexport const Tooltip = createThemedExport('tooltip', BaseTooltip as unknown as React.ComponentType<Record<string, unknown>>);\nexport const Avatar = createThemedExport('avatar', BaseAvatar);\nexport const AvatarLabelGroup = createThemedExport('avatar-label-group', BaseAvatarLabelGroup as unknown as React.ComponentType<Record<string, unknown>>);\nexport const VerifiedTick = createThemedExport('verified-tick', BaseVerifiedTick as unknown as React.ComponentType<Record<string, unknown>>);\nexport const Breadcrumb = createThemedExport('breadcrumb', BaseBreadcrumb as unknown as React.ComponentType<Record<string, unknown>>);\nexport const FeaturedIcon = createThemedExport('featured-icon', BaseFeaturedIcon as unknown as React.ComponentType<Record<string, unknown>>);\nexport const PaginationPageDefault = createThemedExport('pagination-page-default', BasePaginationPageDefault as unknown as React.ComponentType<Record<string, unknown>>);\nexport const PaginationPageMinimalCenter = createThemedExport('pagination-page-minimal-center', BasePaginationPageMinimalCenter as unknown as React.ComponentType<Record<string, unknown>>);\nexport const GoogleMap = createThemedExport('google-map', BaseGoogleMap as unknown as React.ComponentType<Record<string, unknown>>);\nexport const MarkdownRenderer = createThemedExport('markdown-renderer', BaseMarkdownRenderer as unknown as React.ComponentType<Record<string, unknown>>);\n\n// Re-export compound components directly\nexport { Pagination } from './pagination/pagination-base';\n\n// Re-export everything from subdirectories that doesn't need theming\nexport * from './rating/rating-stars';\nexport * from './rating/rating-badge';\nexport { SocialIcon, getSocialIcon } from './social-icons';\nexport * from './carousel/carousel';\nexport { CarouselSectionWrapper } from './carousel/carousel-section-wrapper';\n\n// Re-export combobox (still exists in select directory but not wrapped with theming)\nexport { ComboBox } from './select/combobox';\n\n// Video components (no theming needed)\nexport { VideoModal } from './video-modal';\nexport { VideoPlayButton } from './video-play-button';\n\n// Shared modal for detail views, confirmations, etc.\nexport { Modal } from './modal/modal';\nexport type { ModalProps } from './modal/modal';\n","\"use client\";\n\nimport type { AnchorHTMLAttributes, ButtonHTMLAttributes, DetailedHTMLProps, FC, ReactNode } from \"react\";\nimport React, { isValidElement } from \"react\";\nimport type { ButtonProps as AriaButtonProps } from \"react-aria-components\";\nimport { Button as AriaButton, Link as AriaLink } from \"react-aria-components\";\nimport { cx, sortCx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\n\nexport const styles = sortCx({\n common: {\n root: [\n \"group relative inline-flex h-max cursor-pointer items-center justify-center whitespace-nowrap outline-brand transition duration-100 ease-linear before:absolute focus-visible:outline-2 focus-visible:outline-offset-2\",\n // When button is used within `InputGroup`\n \"in-data-input-wrapper:shadow-xs in-data-input-wrapper:focus:!z-50 in-data-input-wrapper:in-data-leading:-mr-px in-data-input-wrapper:in-data-leading:rounded-r-none in-data-input-wrapper:in-data-leading:before:rounded-r-none in-data-input-wrapper:in-data-trailing:-ml-px in-data-input-wrapper:in-data-trailing:rounded-l-none in-data-input-wrapper:in-data-trailing:before:rounded-l-none\",\n // Disabled styles\n \"disabled:cursor-not-allowed disabled:text-fg-disabled\",\n // Icon styles\n \"disabled:*:data-icon:text-fg-disabled_subtle\",\n // Same as `icon` but for SSR icons that cannot be passed to the client as functions.\n \"*:data-icon:pointer-events-none *:data-icon:size-5 *:data-icon:shrink-0 *:data-icon:transition-inherit-all\",\n ].join(\" \"),\n icon: \"pointer-events-none size-5 shrink-0 transition-inherit-all\",\n },\n sizes: {\n sm: {\n root: [\n \"gap-1 rounded-lg px-3 py-2 text-sm font-semibold before:rounded-[7px] data-icon-only:p-2\",\n \"in-data-input-wrapper:px-3.5 in-data-input-wrapper:py-2.5 in-data-input-wrapper:data-icon-only:p-2.5\",\n ].join(\" \"),\n linkRoot: \"gap-1\",\n },\n md: {\n root: [\n \"gap-1 rounded-lg px-3.5 py-2.5 text-sm font-semibold before:rounded-[7px] data-icon-only:p-2.5\",\n \"in-data-input-wrapper:gap-1.5 in-data-input-wrapper:px-4 in-data-input-wrapper:text-md in-data-input-wrapper:data-icon-only:p-3\",\n ].join(\" \"),\n linkRoot: \"gap-1\",\n },\n lg: {\n root: \"gap-1.5 rounded-lg px-4 py-2.5 text-md font-semibold before:rounded-[7px] data-icon-only:p-3\",\n linkRoot: \"gap-1.5\",\n },\n xl: {\n root: \"gap-1.5 rounded-lg px-4.5 py-3 text-md font-semibold before:rounded-[7px] data-icon-only:p-3.5\",\n linkRoot: \"gap-1.5\",\n },\n },\n\n colors: {\n primary: {\n root: [\n \"bg-brand-solid text-white shadow-xs-skeumorphic ring-1 ring-transparent ring-inset hover:bg-brand-solid_hover data-loading:bg-brand-solid_hover\",\n // Inner border gradient\n \"before:absolute before:inset-px before:border before:border-white/12 before:mask-b-from-0%\",\n // Disabled styles\n \"disabled:bg-disabled disabled:shadow-xs disabled:ring-disabled_subtle\",\n // Icon styles\n \"*:data-icon:text-button-primary-icon hover:*:data-icon:text-button-primary-icon_hover\",\n ].join(\" \"),\n },\n secondary: {\n root: [\n \"bg-primary text-secondary shadow-xs-skeumorphic ring-1 ring-primary ring-inset hover:bg-primary_hover hover:text-secondary_hover data-loading:bg-primary_hover\",\n // Disabled styles\n \"disabled:shadow-xs disabled:ring-disabled_subtle\",\n // Icon styles\n \"*:data-icon:text-fg-quaternary hover:*:data-icon:text-fg-quaternary_hover\",\n ].join(\" \"),\n },\n tertiary: {\n root: [\n \"text-tertiary hover:bg-primary_hover hover:text-tertiary_hover data-loading:bg-primary_hover\",\n // Icon styles\n \"*:data-icon:text-fg-quaternary hover:*:data-icon:text-fg-quaternary_hover\",\n ].join(\" \"),\n },\n \"link-gray\": {\n root: [\n \"justify-normal rounded p-0! text-tertiary hover:text-tertiary_hover\",\n // Inner text underline\n \"*:data-text:underline *:data-text:decoration-transparent *:data-text:underline-offset-2 hover:*:data-text:decoration-current\",\n // Icon styles\n \"*:data-icon:text-fg-quaternary hover:*:data-icon:text-fg-quaternary_hover\",\n ].join(\" \"),\n },\n \"link-color\": {\n root: [\n \"justify-normal rounded p-0! text-brand-secondary hover:text-brand-secondary_hover\",\n // Inner text underline\n \"*:data-text:underline *:data-text:decoration-transparent *:data-text:underline-offset-2 hover:*:data-text:decoration-current\",\n // Icon styles\n \"*:data-icon:text-fg-brand-secondary_alt hover:*:data-icon:text-fg-brand-secondary_hover\",\n ].join(\" \"),\n },\n \"primary-destructive\": {\n root: [\n \"bg-error-solid text-white shadow-xs-skeumorphic ring-1 ring-transparent outline-error ring-inset\",\n // Inner border gradient\n \"before:absolute before:inset-px before:border before:border-white/12 before:mask-b-from-0%\",\n // Disabled styles\n \"disabled:bg-disabled disabled:shadow-xs disabled:ring-disabled_subtle\",\n // Icon styles\n \"*:data-icon:text-button-destructive-primary-icon hover:*:data-icon:text-button-destructive-primary-icon_hover\",\n ].join(\" \"),\n },\n \"secondary-destructive\": {\n root: [\n \"bg-primary text-error-primary shadow-xs-skeumorphic ring-1 ring-error_subtle outline-error ring-inset hover:bg-error-primary hover:text-error-primary_hover data-loading:bg-error-primary\",\n // Disabled styles\n \"disabled:bg-primary disabled:shadow-xs disabled:ring-disabled_subtle\",\n // Icon styles\n \"*:data-icon:text-fg-error-secondary hover:*:data-icon:text-fg-error-primary\",\n ].join(\" \"),\n },\n \"tertiary-destructive\": {\n root: [\n \"text-error-primary outline-error hover:bg-error-primary hover:text-error-primary_hover data-loading:bg-error-primary\",\n // Icon styles\n \"*:data-icon:text-fg-error-secondary hover:*:data-icon:text-fg-error-primary\",\n ].join(\" \"),\n },\n \"link-destructive\": {\n root: [\n \"justify-normal rounded p-0! text-error-primary outline-error hover:text-error-primary_hover\",\n // Inner text underline\n \"*:data-text:underline *:data-text:decoration-transparent *:data-text:underline-offset-2 hover:*:data-text:decoration-current\",\n // Icon styles\n \"*:data-icon:text-fg-error-secondary hover:*:data-icon:text-fg-error-primary\",\n ].join(\" \"),\n },\n },\n});\n\n/**\n * Common props shared between button and anchor variants\n */\nexport interface CommonProps {\n /** Disables the button and shows a disabled state */\n isDisabled?: boolean;\n /** Shows a loading spinner and disables the button */\n isLoading?: boolean;\n /** The size variant of the button */\n size?: keyof typeof styles.sizes;\n /** The color variant of the button */\n color?: keyof typeof styles.colors;\n /** Icon component or element to show before the text */\n iconLeading?: FC<{ className?: string }> | ReactNode;\n /** Icon component or element to show after the text */\n iconTrailing?: FC<{ className?: string }> | ReactNode;\n /** Removes horizontal padding from the text content */\n noTextPadding?: boolean;\n /** When true, keeps the text visible during loading state */\n showTextWhileLoading?: boolean;\n}\n\n/**\n * Props for the button variant (non-link)\n */\nexport interface ButtonProps extends CommonProps, DetailedHTMLProps<Omit<ButtonHTMLAttributes<HTMLButtonElement>, \"color\" | \"slot\">, HTMLButtonElement> {\n /** Slot name for react-aria component */\n slot?: AriaButtonProps[\"slot\"];\n}\n\n/**\n * Props for the link variant (anchor tag)\n */\ninterface LinkProps extends CommonProps, DetailedHTMLProps<Omit<AnchorHTMLAttributes<HTMLAnchorElement>, \"color\">, HTMLAnchorElement> {}\n\n/** Union type of button and link props */\nexport type Props = ButtonProps | LinkProps;\n\nexport const Button = ({\n size = \"sm\",\n color = \"primary\",\n children,\n className,\n noTextPadding,\n iconLeading: IconLeading,\n iconTrailing: IconTrailing,\n isDisabled: disabled,\n isLoading: loading,\n showTextWhileLoading,\n ...otherProps\n}: Props) => {\n const href = \"href\" in otherProps ? otherProps.href : undefined;\n const Component = href ? AriaLink : AriaButton;\n\n const isIcon = (IconLeading || IconTrailing) && !children;\n const isLinkType = [\"link-gray\", \"link-color\", \"link-destructive\"].includes(color);\n\n noTextPadding = isLinkType || noTextPadding;\n\n let props = {};\n\n if (href) {\n props = {\n ...otherProps,\n\n href: disabled ? undefined : href,\n\n // Since anchor elements do not support the `disabled` attribute and state,\n // we need to specify `data-rac` and `data-disabled` in order to be able\n // to use the `disabled:` selector in classes.\n ...(disabled ? { \"data-rac\": true, \"data-disabled\": true } : {}),\n };\n } else {\n props = {\n ...otherProps,\n\n type: otherProps.type || \"button\",\n isPending: loading,\n isDisabled: disabled,\n };\n }\n\n return (\n <Component\n data-loading={loading ? true : undefined}\n data-icon-only={isIcon ? true : undefined}\n {...props}\n className={cx(\n styles.common.root,\n styles.sizes[size].root,\n styles.colors[color].root,\n isLinkType && styles.sizes[size].linkRoot,\n (loading || (href && (disabled || loading))) && \"pointer-events-none\",\n // If in `loading` state, hide everything except the loading icon (and text if `showTextWhileLoading` is true).\n loading && (showTextWhileLoading ? \"[&>*:not([data-icon=loading]):not([data-text])]:hidden\" : \"[&>*:not([data-icon=loading])]:invisible\"),\n className,\n )}\n >\n {/* Leading icon */}\n {isValidElement(IconLeading) && IconLeading}\n {isReactComponent(IconLeading) && React.createElement(IconLeading, { 'data-icon': 'leading', className: styles.common.icon } as Record<string, unknown>)}\n\n {loading && (\n <svg\n fill=\"none\"\n data-icon=\"loading\"\n viewBox=\"0 0 20 20\"\n className={cx(styles.common.icon, !showTextWhileLoading && \"absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2\")}\n >\n {/* Background circle */}\n <circle className=\"stroke-current opacity-30\" cx=\"10\" cy=\"10\" r=\"8\" fill=\"none\" strokeWidth=\"2\" />\n {/* Spinning circle */}\n <circle\n className=\"origin-center animate-spin stroke-current\"\n cx=\"10\"\n cy=\"10\"\n r=\"8\"\n fill=\"none\"\n strokeWidth=\"2\"\n strokeDasharray=\"12.5 50\"\n strokeLinecap=\"round\"\n />\n </svg>\n )}\n\n {children && (\n <span data-text className={cx(\"transition-inherit-all\", !noTextPadding && \"px-0.5\")}>\n {children}\n </span>\n )}\n\n {/* Trailing icon */}\n {isValidElement(IconTrailing) && IconTrailing}\n {isReactComponent(IconTrailing) && React.createElement(IconTrailing, { 'data-icon': 'trailing', className: styles.common.icon } as Record<string, unknown>)}\n </Component>\n );\n};\n","import { extendTailwindMerge } from \"tailwind-merge\";\n\nconst twMerge = extendTailwindMerge({\n extend: {\n theme: {\n text: [\"display-xs\", \"display-sm\", \"display-md\", \"display-lg\", \"display-xl\", \"display-2xl\"],\n },\n },\n});\n\n/**\n * This function is a wrapper around the twMerge function.\n * It is used to merge the classes inside style objects.\n */\nexport const cx = twMerge;\n\n/**\n * This function does nothing besides helping us to be able to\n * sort the classes inside style objects which is not supported\n * by the Tailwind IntelliSense by default.\n */\nexport function sortCx<T extends Record<string, string | number | Record<string, string | number | Record<string, string | number>>>>(classes: T): T {\n return classes;\n}\n\n","import type React from \"react\";\n\n// Use unknown for inputs since we're checking if an unknown value is a React component\n// The return types use proper type guards to narrow the type after validation\ntype ReactComponent = React.FC<unknown> | React.ComponentClass<unknown, unknown>;\n\n/**\n * Checks if a given value is a function component.\n */\nexport const isFunctionComponent = (component: unknown): component is React.FC<unknown> => {\n return typeof component === \"function\";\n};\n\n/**\n * Checks if a given value is a class component.\n */\nexport const isClassComponent = (component: unknown): component is React.ComponentClass<unknown, unknown> => {\n return typeof component === \"function\" && \n typeof component === \"function\" && \n component.prototype !== undefined && \n component.prototype !== null &&\n (!!component.prototype.isReactComponent || !!component.prototype.render);\n};\n\n/**\n * Checks if a given value is a forward ref component.\n */\nexport const isForwardRefComponent = (component: unknown): component is React.ForwardRefExoticComponent<unknown> => {\n return typeof component === \"object\" && \n component !== null && \n '$$typeof' in component &&\n component.$$typeof !== undefined &&\n component.$$typeof !== null &&\n component.$$typeof.toString() === \"Symbol(react.forward_ref)\";\n};\n\n/**\n * Checks if a given value is a valid React component.\n */\nexport const isReactComponent = (component: unknown): component is ReactComponent => {\n return isFunctionComponent(component) || isForwardRefComponent(component) || isClassComponent(component);\n};\n","\"use client\";\n\nimport type { ComponentPropsWithRef, FC } from \"react\";\nimport { createElement } from \"react\";\nimport { Button } from '..';\nimport { cx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\n\ninterface RoundButtonProps extends ComponentPropsWithRef<\"button\"> {\n icon?: FC<{ className?: string }>;\n}\n\nexport const RoundButton = ({ icon: Icon, ...props }: RoundButtonProps) => {\n return (\n <Button\n {...props}\n color=\"link-gray\"\n className={cx(\n \"group flex size-12 items-center justify-center rounded-full bg-primary ring-1 ring-secondary backdrop-blur transition duration-100 ease-linear ring-inset hover:bg-secondary md:size-14\",\n props.className,\n )}\n >\n {props.children ??\n (isReactComponent(Icon) ? createElement(Icon, { className: \"size-5 text-fg-quaternary transition-inherit-all group-hover:text-fg-quaternary_hover md:size-6\" } as Record<string, unknown>) : null)}\n </Button>\n );\n};\n\n","\"use client\";\n\nimport { type FC, type PropsWithChildren, type ReactNode, type RefAttributes, createContext, createElement, isValidElement, useContext } from \"react\";\nimport {\n ToggleButton as AriaToggleButton,\n ToggleButtonGroup as AriaToggleButtonGroup,\n type ToggleButtonGroupProps,\n type ToggleButtonProps,\n} from \"react-aria-components\";\nimport { cx, sortCx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\n\nexport const styles = sortCx({\n common: {\n root: [\n \"group/button-group inline-flex h-max cursor-pointer items-center bg-primary font-semibold whitespace-nowrap text-secondary shadow-skeumorphic ring-1 ring-primary outline-brand transition duration-100 ease-linear ring-inset\",\n // Hover and focus styles\n \"hover:bg-primary_hover hover:text-secondary_hover focus-visible:z-10 focus-visible:outline-2 focus-visible:outline-offset-2\",\n // Disabled styles\n \"disabled:cursor-not-allowed disabled:bg-primary disabled:text-disabled\",\n // Selected styles\n \"selected:bg-active selected:text-secondary_hover selected:disabled:bg-disabled_subtle\",\n ].join(\" \"),\n icon: \"pointer-events-none text-fg-quaternary transition-[inherit] group-hover/button-group:text-fg-quaternary_hover group-disabled/button-group:text-fg-disabled_subtle\",\n },\n\n sizes: {\n sm: {\n root: \"gap-1.5 px-3.5 py-2 text-sm not-last:pr-[calc(calc(var(--spacing)*3.5)+1px)] first:rounded-l-lg last:rounded-r-lg data-icon-leading:pl-3 data-icon-only:p-2\",\n icon: \"size-5\",\n },\n md: {\n root: \"gap-1.5 px-4 py-2.5 text-sm not-last:pr-[calc(calc(var(--spacing)*4)+1px)] first:rounded-l-lg last:rounded-r-lg data-icon-leading:pl-3.5 data-icon-only:px-3\",\n icon: \"size-5\",\n },\n lg: {\n root: \"gap-2 px-4.5 py-2.5 text-md not-last:pr-[calc(calc(var(--spacing)*4.5)+1px)] first:rounded-l-lg last:rounded-r-lg data-icon-leading:pl-4 data-icon-only:p-3\",\n icon: \"size-5\",\n },\n },\n});\n\ntype ButtonSize = keyof typeof styles.sizes;\n\nconst ButtonGroupContext = createContext<{ size: ButtonSize }>({ size: \"md\" });\n\ninterface ButtonGroupItemProps extends ToggleButtonProps, RefAttributes<HTMLButtonElement> {\n iconLeading?: FC<{ className?: string }> | ReactNode;\n iconTrailing?: FC<{ className?: string }> | ReactNode;\n onClick?: () => void;\n className?: string;\n}\n\nexport const ButtonGroupItem = ({\n iconLeading: IconLeading,\n iconTrailing: IconTrailing,\n children,\n className,\n ...otherProps\n}: PropsWithChildren<ButtonGroupItemProps>) => {\n const context = useContext(ButtonGroupContext);\n\n if (!context) {\n throw new Error(\"ButtonGroupItem must be used within a ButtonGroup component\");\n }\n\n const { size } = context;\n\n const isIcon = (IconLeading || IconTrailing) && !children;\n\n return (\n <AriaToggleButton\n {...otherProps}\n data-icon-only={isIcon ? true : undefined}\n data-icon-leading={IconLeading ? true : undefined}\n className={cx(styles.common.root, styles.sizes[size].root, className)}\n >\n {isReactComponent(IconLeading) && createElement(IconLeading, { className: cx(styles.common.icon, styles.sizes[size].icon) } as Record<string, unknown>)}\n {isValidElement(IconLeading) && IconLeading}\n\n {children}\n\n {isReactComponent(IconTrailing) && createElement(IconTrailing, { className: cx(styles.common.icon, styles.sizes[size].icon) } as Record<string, unknown>)}\n {isValidElement(IconTrailing) && IconTrailing}\n </AriaToggleButton>\n );\n};\n\ninterface ButtonGroupProps extends Omit<ToggleButtonGroupProps, \"orientation\">, RefAttributes<HTMLDivElement> {\n size?: ButtonSize;\n className?: string;\n}\n\nexport const ButtonGroup = ({ children, size = \"md\", className, ...otherProps }: ButtonGroupProps) => {\n return (\n <ButtonGroupContext.Provider value={{ size }}>\n <AriaToggleButtonGroup\n selectionMode=\"single\"\n className={cx(\"relative z-0 inline-flex w-max -space-x-px rounded-lg shadow-xs\", className)}\n {...otherProps}\n >\n {children}\n </AriaToggleButtonGroup>\n </ButtonGroupContext.Provider>\n );\n};\n","\"use client\";\n\nimport { type ComponentType, type HTMLAttributes, type ReactNode, type Ref, createContext, useContext } from \"react\";\nimport { HelpCircle, InfoCircle } from \"@untitledui/icons\";\nimport type { InputProps as AriaInputProps, TextFieldProps as AriaTextFieldProps } from \"react-aria-components\";\nimport { Group as AriaGroup, Input as AriaInput, TextField as AriaTextField } from \"react-aria-components\";\nimport { HintText } from './hint-text';\nimport { Label } from './label';\nimport { Tooltip, TooltipTrigger } from '../tooltip/tooltip';\nimport { cx, sortCx } from '../../../utils/cx';\n\nexport interface InputBaseProps extends TextFieldProps {\n /** Tooltip message on hover. */\n tooltip?: string;\n /**\n * Input size.\n * @default \"sm\"\n */\n size?: \"sm\" | \"md\";\n /** Placeholder text. */\n placeholder?: string;\n /** Class name for the icon. */\n iconClassName?: string;\n /** Class name for the input. */\n inputClassName?: string;\n /** Class name for the input wrapper. */\n wrapperClassName?: string;\n /** Class name for the tooltip. */\n tooltipClassName?: string;\n /** Keyboard shortcut to display. */\n shortcut?: string | boolean;\n ref?: Ref<HTMLInputElement>;\n groupRef?: Ref<HTMLDivElement>;\n /** Icon component to display on the left side of the input. */\n icon?: ComponentType<HTMLAttributes<HTMLOrSVGElement>>;\n}\n\nexport const InputBase = ({\n ref,\n tooltip,\n shortcut,\n groupRef,\n size = \"sm\",\n isInvalid,\n isDisabled,\n icon: Icon,\n placeholder,\n wrapperClassName,\n tooltipClassName,\n inputClassName,\n iconClassName,\n ...inputProps\n}: Omit<InputBaseProps, \"label\" | \"hint\" | \"isRequired\">) => {\n // Check if the input has a leading icon or tooltip\n const hasTrailingIcon = tooltip || isInvalid;\n const hasLeadingIcon = Icon;\n\n // If the input is inside a `TextFieldContext`, use its context to simplify applying styles\n const context = useContext(TextFieldContext);\n\n const inputSize = context?.size || size;\n\n const sizes = sortCx({\n sm: {\n root: cx(\"px-3 py-2\", hasTrailingIcon && \"pr-9\", hasLeadingIcon && \"pl-10\"),\n iconLeading: \"left-3\",\n iconTrailing: \"right-3\",\n shortcut: \"pr-2.5\",\n },\n md: {\n root: cx(\"px-3.5 py-2.5\", hasTrailingIcon && \"pr-9.5\", hasLeadingIcon && \"pl-10.5\"),\n iconLeading: \"left-3.5\",\n iconTrailing: \"right-3.5\",\n shortcut: \"pr-3\",\n },\n });\n\n return (\n <AriaGroup\n {...{ isDisabled, isInvalid }}\n ref={groupRef}\n className={({ isFocusWithin, isDisabled, isInvalid }) =>\n cx(\n \"relative flex w-full flex-row place-content-center place-items-center rounded-lg bg-primary shadow-xs ring-1 ring-primary transition-shadow duration-100 ease-linear ring-inset\",\n\n isFocusWithin && !isDisabled && \"ring-2 ring-brand\",\n\n // Disabled state styles\n isDisabled && \"cursor-not-allowed bg-disabled_subtle ring-disabled\",\n \"group-disabled:cursor-not-allowed group-disabled:bg-disabled_subtle group-disabled:ring-disabled\",\n\n // Invalid state styles\n isInvalid && \"ring-error_subtle\",\n \"group-invalid:ring-error_subtle\",\n\n // Invalid state with focus-within styles\n isInvalid && isFocusWithin && \"ring-2 ring-error\",\n isFocusWithin && \"group-invalid:ring-2 group-invalid:ring-error\",\n\n context?.wrapperClassName,\n wrapperClassName,\n )\n }\n >\n {/* Leading icon and Payment icon */}\n {Icon && (\n <Icon\n className={cx(\n \"pointer-events-none absolute size-5 text-fg-quaternary\",\n isDisabled && \"text-fg-disabled\",\n sizes[inputSize].iconLeading,\n context?.iconClassName,\n iconClassName,\n )}\n />\n )}\n\n {/* Input field */}\n <AriaInput\n {...(inputProps as AriaInputProps)}\n ref={ref}\n placeholder={placeholder}\n className={cx(\n \"m-0 w-full bg-transparent text-md text-primary ring-0 outline-hidden placeholder:text-placeholder autofill:rounded-lg autofill:text-primary\",\n isDisabled && \"cursor-not-allowed text-disabled\",\n sizes[inputSize].root,\n context?.inputClassName,\n inputClassName,\n )}\n />\n\n {/* Tooltip and help icon */}\n {tooltip && !isInvalid && (\n <Tooltip title={tooltip} placement=\"top\">\n <TooltipTrigger\n className={cx(\n \"absolute cursor-pointer text-fg-quaternary transition duration-200 hover:text-fg-quaternary_hover focus:text-fg-quaternary_hover\",\n sizes[inputSize].iconTrailing,\n context?.tooltipClassName,\n tooltipClassName,\n )}\n >\n <HelpCircle className=\"size-4\" />\n </TooltipTrigger>\n </Tooltip>\n )}\n\n {/* Invalid icon */}\n {isInvalid && (\n <InfoCircle\n className={cx(\n \"pointer-events-none absolute size-4 text-fg-error-secondary\",\n sizes[inputSize].iconTrailing,\n context?.tooltipClassName,\n tooltipClassName,\n )}\n />\n )}\n\n {/* Shortcut */}\n {shortcut && (\n <div\n className={cx(\n \"pointer-events-none absolute inset-y-0.5 right-0.5 z-10 flex items-center rounded-r-[inherit] bg-linear-to-r from-transparent to-bg-primary to-40% pl-8\",\n sizes[inputSize].shortcut,\n )}\n >\n <span\n className={cx(\n \"pointer-events-none rounded px-1 py-px text-xs font-medium text-quaternary ring-1 ring-secondary select-none ring-inset\",\n isDisabled && \"bg-transparent text-disabled\",\n )}\n aria-hidden=\"true\"\n >\n {typeof shortcut === \"string\" ? shortcut : \"⌘K\"}\n </span>\n </div>\n )}\n </AriaGroup>\n );\n};\n\nInputBase.displayName = \"InputBase\";\n\ninterface BaseProps {\n /** Label text for the input */\n label?: string;\n /** Helper text displayed below the input */\n hint?: ReactNode;\n}\n\ninterface TextFieldProps\n extends BaseProps,\n AriaTextFieldProps,\n Pick<InputBaseProps, \"size\" | \"wrapperClassName\" | \"inputClassName\" | \"iconClassName\" | \"tooltipClassName\"> {\n ref?: Ref<HTMLDivElement>;\n}\n\nconst TextFieldContext = createContext<TextFieldProps>({});\n\nexport const TextField = ({ className, ...props }: TextFieldProps) => {\n return (\n <TextFieldContext.Provider value={props}>\n <AriaTextField\n {...props}\n data-input-wrapper\n className={(state) =>\n cx(\"group flex h-max w-full flex-col items-start justify-start gap-1.5\", typeof className === \"function\" ? className(state) : className)\n }\n />\n </TextFieldContext.Provider>\n );\n};\n\nTextField.displayName = \"TextField\";\n\ninterface InputProps extends InputBaseProps, BaseProps {\n /** Whether to hide required indicator from label */\n hideRequiredIndicator?: boolean;\n}\n\nexport const Input = ({\n size = \"sm\",\n placeholder,\n icon: Icon,\n label,\n hint,\n shortcut,\n hideRequiredIndicator,\n className,\n ref,\n groupRef,\n tooltip,\n iconClassName,\n inputClassName,\n wrapperClassName,\n tooltipClassName,\n ...props\n}: InputProps) => {\n return (\n <TextField aria-label={!label ? placeholder : undefined} {...props} className={className}>\n {({ isRequired, isInvalid }) => (\n <>\n {label && <Label isRequired={hideRequiredIndicator ? !hideRequiredIndicator : isRequired}>{label}</Label>}\n\n <InputBase\n {...{\n ref,\n groupRef,\n size,\n placeholder,\n icon: Icon,\n shortcut,\n iconClassName,\n inputClassName,\n wrapperClassName,\n tooltipClassName,\n tooltip,\n }}\n />\n\n {hint && <HintText isInvalid={isInvalid}>{hint}</HintText>}\n </>\n )}\n </TextField>\n );\n};\n\nInput.displayName = \"Input\";\n","\"use client\";\n\nimport type { ReactNode, Ref } from \"react\";\nimport type { TextProps as AriaTextProps } from \"react-aria-components\";\nimport { Text as AriaText } from \"react-aria-components\";\nimport { cx } from '../../../utils/cx';\n\ninterface HintTextProps extends AriaTextProps {\n /** Indicates that the hint text is an error message. */\n isInvalid?: boolean;\n ref?: Ref<HTMLElement>;\n children: ReactNode;\n}\n\nexport const HintText = ({ isInvalid, className, ...props }: HintTextProps) => {\n return (\n <AriaText\n {...props}\n slot={isInvalid ? \"errorMessage\" : \"description\"}\n className={cx(\n \"text-sm text-tertiary\",\n\n // Invalid state\n isInvalid && \"text-error-primary\",\n \"group-invalid:text-error-primary\",\n\n className,\n )}\n />\n );\n};\n\nHintText.displayName = \"HintText\";\n","\"use client\";\n\nimport type { ReactNode, Ref } from \"react\";\nimport { HelpCircle } from \"@untitledui/icons\";\nimport type { LabelProps as AriaLabelProps } from \"react-aria-components\";\nimport { Label as AriaLabel } from \"react-aria-components\";\nimport { Tooltip, TooltipTrigger } from '../tooltip/tooltip';\nimport { cx } from '../../../utils/cx';\n\ninterface LabelProps extends AriaLabelProps {\n children: ReactNode;\n isRequired?: boolean;\n tooltip?: string;\n tooltipDescription?: string;\n ref?: Ref<HTMLLabelElement>;\n}\n\nexport const Label = ({ isRequired, tooltip, tooltipDescription, className, ...props }: LabelProps) => {\n return (\n <AriaLabel\n // Used for conditionally hiding/showing the label element via CSS:\n // <Input label=\"Visible only on mobile\" className=\"lg:**:data-label:hidden\" />\n // or\n // <Input label=\"Visible only on mobile\" className=\"lg:label:hidden\" />\n data-label=\"true\"\n {...props}\n className={cx(\"flex cursor-default items-center gap-0.5 text-sm font-medium text-secondary\", className)}\n >\n {props.children}\n\n <span className={cx(\"hidden text-brand-tertiary\", isRequired && \"block\", typeof isRequired === \"undefined\" && \"group-required:block\")}>*</span>\n\n {tooltip && (\n <Tooltip title={tooltip} description={tooltipDescription} placement=\"top\">\n <TooltipTrigger\n // `TooltipTrigger` inherits the disabled state from the parent form field\n // but we don't that. We want the tooltip be enabled even if the parent\n // field is disabled.\n isDisabled={false}\n className=\"cursor-pointer text-fg-quaternary transition duration-200 hover:text-fg-quaternary_hover focus:text-fg-quaternary_hover\"\n >\n <HelpCircle className=\"size-4\" />\n </TooltipTrigger>\n </Tooltip>\n )}\n </AriaLabel>\n );\n};\n\nLabel.displayName = \"Label\";\n","\"use client\";\n\nimport type { ReactNode } from \"react\";\nimport type {\n ButtonProps as AriaButtonProps,\n TooltipProps as AriaTooltipProps,\n TooltipTriggerComponentProps as AriaTooltipTriggerComponentProps,\n} from \"react-aria-components\";\nimport { Button as AriaButton, OverlayArrow as AriaOverlayArrow, Tooltip as AriaTooltip, TooltipTrigger as AriaTooltipTrigger } from \"react-aria-components\";\nimport { cx } from '../../../utils/cx';\n\ninterface TooltipProps extends AriaTooltipTriggerComponentProps, Omit<AriaTooltipProps, \"children\"> {\n /**\n * The title of the tooltip.\n */\n title: ReactNode;\n /**\n * The description of the tooltip.\n */\n description?: ReactNode;\n /**\n * Whether to show the arrow on the tooltip.\n *\n * @default false\n */\n arrow?: boolean;\n /**\n * Delay in milliseconds before the tooltip is shown.\n *\n * @default 300\n */\n delay?: number;\n}\n\nexport const Tooltip = ({\n title,\n description,\n children,\n arrow = false,\n delay = 300,\n closeDelay = 0,\n trigger,\n isDisabled,\n isOpen,\n defaultOpen,\n offset = 6,\n crossOffset,\n placement = \"top\",\n onOpenChange,\n ...tooltipProps\n}: TooltipProps) => {\n const isTopOrBottomLeft = [\"top left\", \"top end\", \"bottom left\", \"bottom end\"].includes(placement);\n const isTopOrBottomRight = [\"top right\", \"top start\", \"bottom right\", \"bottom start\"].includes(placement);\n // Set negative cross offset for left and right placement to visually balance the tooltip.\n const calculatedCrossOffset = isTopOrBottomLeft ? -12 : isTopOrBottomRight ? 12 : 0;\n\n return (\n <AriaTooltipTrigger {...{ trigger, delay, closeDelay, isDisabled, isOpen, defaultOpen, onOpenChange }}>\n {children}\n\n <AriaTooltip\n {...tooltipProps}\n offset={offset}\n placement={placement}\n crossOffset={crossOffset ?? calculatedCrossOffset}\n className={({ isEntering, isExiting }) => cx(isEntering && \"ease-out animate-in\", isExiting && \"ease-in animate-out\")}\n >\n {({ isEntering, isExiting }) => (\n <div\n className={cx(\n \"z-50 flex max-w-xs origin-(--trigger-anchor-point) flex-col items-start gap-1 rounded-lg bg-primary-solid px-3 shadow-lg will-change-transform\",\n description ? \"py-3\" : \"py-2\",\n\n isEntering &&\n \"ease-out animate-in fade-in zoom-in-95 in-placement-left:slide-in-from-right-0.5 in-placement-right:slide-in-from-left-0.5 in-placement-top:slide-in-from-bottom-0.5 in-placement-bottom:slide-in-from-top-0.5\",\n isExiting &&\n \"ease-in animate-out fade-out zoom-out-95 in-placement-left:slide-out-to-right-0.5 in-placement-right:slide-out-to-left-0.5 in-placement-top:slide-out-to-bottom-0.5 in-placement-bottom:slide-out-to-top-0.5\",\n )}\n >\n <span className=\"text-xs font-semibold text-white\">{title}</span>\n\n {description && <span className=\"text-xs font-medium text-tooltip-supporting-text\">{description}</span>}\n\n {arrow && (\n <AriaOverlayArrow>\n <svg\n viewBox=\"0 0 100 100\"\n className=\"size-2.5 fill-bg-primary-solid in-placement-left:-rotate-90 in-placement-right:rotate-90 in-placement-top:rotate-0 in-placement-bottom:rotate-180\"\n >\n <path d=\"M0,0 L35.858,35.858 Q50,50 64.142,35.858 L100,0 Z\" />\n </svg>\n </AriaOverlayArrow>\n )}\n </div>\n )}\n </AriaTooltip>\n </AriaTooltipTrigger>\n );\n};\n\ntype TooltipTriggerProps = AriaButtonProps;\n\nexport const TooltipTrigger = ({ children, className, ...buttonProps }: TooltipTriggerProps) => {\n return (\n <AriaButton {...buttonProps} className={(values) => cx(\"h-max w-max outline-hidden\", typeof className === \"function\" ? className(values) : className)}>\n {children}\n </AriaButton>\n );\n};\n","\"use client\";\n\nimport { type HTMLAttributes, type ReactNode } from \"react\";\nimport { HintText } from './hint-text';\nimport type { InputBaseProps } from './input';\nimport { TextField } from './input';\nimport { Label } from './label';\nimport { cx, sortCx } from '../../../utils/cx';\n\ninterface InputPrefixProps extends HTMLAttributes<HTMLDivElement> {\n /** The position of the prefix. */\n position?: \"leading\" | \"trailing\";\n /** The size of the prefix. */\n size?: \"sm\" | \"md\";\n /** Indicates that the prefix is disabled. */\n isDisabled?: boolean;\n}\n\nexport const InputPrefix = ({ isDisabled, children, ...props }: InputPrefixProps) => (\n <span\n {...props}\n className={cx(\n \"flex text-md text-tertiary shadow-xs ring-1 ring-border-primary ring-inset\",\n // Styles when the prefix is within an `InputGroup`\n \"in-data-input-wrapper:in-data-leading:-mr-px in-data-input-wrapper:in-data-leading:rounded-l-lg\",\n \"in-data-input-wrapper:in-data-trailing:-ml-px in-data-input-wrapper:in-data-trailing:rounded-r-lg\",\n // Size styles based on size when within an `InputGroup`\n \"in-data-input-wrapper:in-data-[input-size=md]:py-2.5 in-data-input-wrapper:in-data-[input-size=md]:pr-3 in-data-input-wrapper:in-data-[input-size=md]:pl-3.5 in-data-input-wrapper:in-data-[input-size=sm]:px-3 in-data-input-wrapper:in-data-[input-size=sm]:py-2\",\n // Disabled styles\n isDisabled && \"border-disabled bg-disabled_subtle text-tertiary\",\n \"in-data-input-wrapper:group-disabled:bg-disabled_subtle in-data-input-wrapper:group-disabled:text-disabled in-data-input-wrapper:group-disabled:ring-border-disabled\",\n\n props.className,\n )}\n >\n {children}\n </span>\n);\n\n// `${string}ClassName` is used to omit any className prop that ends with a `ClassName` suffix\ninterface InputGroupProps extends Omit<InputBaseProps, \"type\" | \"icon\" | \"placeholder\" | \"tooltip\" | \"shortcut\" | `${string}ClassName`> {\n /** A prefix text that is displayed in the same box as the input.*/\n prefix?: string;\n /** A leading addon that is displayed with visual separation from the input. */\n leadingAddon?: ReactNode;\n /** A trailing addon that is displayed with visual separation from the input. */\n trailingAddon?: ReactNode;\n /** The class name to apply to the input group. */\n className?: string;\n /** The children of the input group (i.e `<InputBase />`) */\n children: ReactNode;\n}\n\nexport const InputGroup = ({ size = \"sm\", prefix, leadingAddon, trailingAddon, label, hint, children, ...props }: InputGroupProps) => {\n const hasLeading = !!leadingAddon;\n const hasTrailing = !!trailingAddon;\n\n const paddings = sortCx({\n sm: {\n input: cx(\n hasLeading && \"group-has-[&>select]:px-2.5 group-has-[&>select]:pl-2.5\",\n hasTrailing && (prefix ? \"group-has-[&>select]:pr-6 group-has-[&>select]:pl-0\" : \"group-has-[&>select]:pr-6 group-has-[&>select]:pl-3\"),\n ),\n leadingText: \"pl-3\",\n },\n md: {\n input: cx(\n hasLeading && \"group-has-[&>select]:px-3 group-has-[&>select]:pl-3\",\n hasTrailing && (prefix ? \"group-has-[&>select]:pr-6 group-has-[&>select]:pl-0\" : \"group-has-[&>select]:pr-6 group-has-[&>select]:pl-3\"),\n ),\n leadingText: \"pl-3.5\",\n },\n });\n\n return (\n <TextField\n size={size}\n aria-label={label || undefined}\n inputClassName={cx(paddings[size].input)}\n tooltipClassName={cx(hasTrailing && !hasLeading && \"group-has-[&>select]:right-0\")}\n wrapperClassName={cx(\n \"z-10 min-w-0 flex-1 !w-auto\",\n hasLeading && \"rounded-sm rounded-l-none bg-white ring-1 ring-secondary ring-inset focus-within:ring-2 focus-within:ring-brand group-disabled:bg-disabled_subtle group-disabled:ring-disabled\",\n hasTrailing && \"rounded-r-none\",\n )}\n {...props}\n >\n {({ isDisabled, isInvalid, isRequired }) => (\n <>\n {label && <Label isRequired={isRequired}>{label}</Label>}\n\n <div\n data-input-size={size}\n data-input-wrapper\n className={cx(\n \"group relative flex h-max w-full flex-row items-center rounded-sm bg-white transition-all duration-100 ease-linear\",\n \"has-[&>select]:shadow-xs has-[&>select]:ring-1 has-[&>select]:ring-secondary has-[&>select]:ring-inset has-[&>select]:has-[input:focus]:ring-2 has-[&>select]:has-[input:focus]:ring-brand\",\n isDisabled && \"cursor-not-allowed has-[&>select]:bg-disabled_subtle has-[&>select]:ring-border-disabled\",\n isInvalid && \"has-[&>select]:ring-border-error_subtle has-[&>select]:has-[input:focus]:ring-border-error\",\n )}\n >\n {leadingAddon && (\n <div data-leading={hasLeading || undefined} className=\"flex shrink-0\">\n {leadingAddon}\n </div>\n )}\n\n {prefix && (\n <span className={cx(\"my-auto grow pr-2\", paddings[size].leadingText)}>\n <p className={cx(\"text-md text-tertiary\", isDisabled && \"text-disabled\")}>{prefix}</p>\n </span>\n )}\n\n {children}\n\n {trailingAddon && <div data-trailing={hasTrailing || undefined}>{trailingAddon}</div>}\n </div>\n\n {hint && <HintText isInvalid={isInvalid}>{hint}</HintText>}\n </>\n )}\n </TextField>\n );\n};\n\nInputGroup.Prefix = InputPrefix;\n\nInputGroup.displayName = \"InputGroup\";\n","\"use client\";\n\nimport type { ReactNode, Ref } from \"react\";\nimport React from \"react\";\nimport type { TextAreaProps as AriaTextAreaProps, TextFieldProps as AriaTextFieldProps } from \"react-aria-components\";\nimport { TextArea as AriaTextArea, TextField as AriaTextField } from \"react-aria-components\";\nimport { HintText } from '../input/hint-text';\nimport { Label } from '../input/label';\nimport { cx } from '../../../utils/cx';\n\n// Creates a data URL for an SVG resize handle with a given color.\nconst getResizeHandleBg = (color: string) => {\n return `url(data:image/svg+xml;base64,${btoa(`<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M10 2L2 10\" stroke=\"${color}\" stroke-linecap=\"round\"/><path d=\"M11 7L7 11\" stroke=\"${color}\" stroke-linecap=\"round\"/></svg>`)})`;\n};\n\ninterface TextAreaBaseProps extends AriaTextAreaProps {\n ref?: Ref<HTMLTextAreaElement>;\n}\n\nexport const TextAreaBase = ({ className, ...props }: TextAreaBaseProps) => {\n return (\n <AriaTextArea\n {...props}\n style={\n {\n \"--resize-handle-bg\": getResizeHandleBg(\"#D5D7DA\"),\n \"--resize-handle-bg-dark\": getResizeHandleBg(\"#373A41\"),\n } as React.CSSProperties\n }\n className={(state) =>\n cx(\n \"w-full scroll-py-3 rounded-lg bg-primary px-3.5 py-3 text-md text-primary shadow-xs ring-1 ring-primary transition duration-100 ease-linear ring-inset placeholder:text-placeholder autofill:rounded-lg autofill:text-primary focus:outline-hidden\",\n\n // Resize handle\n \"[&::-webkit-resizer]:bg-(image:--resize-handle-bg) [&::-webkit-resizer]:bg-contain dark:[&::-webkit-resizer]:bg-(image:--resize-handle-bg-dark)\",\n\n state.isFocused && !state.isDisabled && \"ring-2 ring-brand\",\n state.isDisabled && \"cursor-not-allowed bg-disabled_subtle text-disabled ring-disabled\",\n state.isInvalid && \"ring-error_subtle\",\n state.isInvalid && state.isFocused && \"ring-2 ring-error\",\n\n typeof className === \"function\" ? className(state) : className,\n )\n }\n />\n );\n};\n\nTextAreaBase.displayName = \"TextAreaBase\";\n\ninterface TextFieldProps extends AriaTextFieldProps {\n /** Label text for the textarea */\n label?: string;\n /** Helper text displayed below the textarea */\n hint?: ReactNode;\n /** Tooltip message displayed after the label. */\n tooltip?: string;\n /** Class name for the textarea wrapper */\n textAreaClassName?: TextAreaBaseProps[\"className\"];\n /** Ref for the textarea wrapper */\n ref?: Ref<HTMLDivElement>;\n /** Ref for the textarea */\n textAreaRef?: TextAreaBaseProps[\"ref\"];\n /** Whether to hide required indicator from label. */\n hideRequiredIndicator?: boolean;\n /** Placeholder text. */\n placeholder?: string;\n /** Visible height of textarea in rows . */\n rows?: number;\n /** Visible width of textarea in columns. */\n cols?: number;\n}\n\nexport const TextArea = ({\n label,\n hint,\n tooltip,\n textAreaRef,\n hideRequiredIndicator,\n textAreaClassName,\n placeholder,\n className,\n rows,\n cols,\n ...props\n}: TextFieldProps) => {\n return (\n <AriaTextField\n {...props}\n className={(state) =>\n cx(\"group flex h-max w-full flex-col items-start justify-start gap-1.5\", typeof className === \"function\" ? className(state) : className)\n }\n >\n {({ isInvalid, isRequired }) => (\n <>\n {label && (\n <Label isRequired={hideRequiredIndicator ? !hideRequiredIndicator : isRequired} tooltip={tooltip}>\n {label}\n </Label>\n )}\n\n <TextAreaBase placeholder={placeholder} className={textAreaClassName} ref={textAreaRef} rows={rows} cols={cols} />\n\n {hint && <HintText isInvalid={isInvalid}>{hint}</HintText>}\n </>\n )}\n </AriaTextField>\n );\n};\n\nTextArea.displayName = \"TextArea\";\n","'use client';\n\nimport { useId } from 'react';\n\n/**\n * A2P 10DLC-compliant privacy + SMS consent checkbox. Use on any form that collects phone numbers.\n * Same copy and markup used across contact and job application forms.\n */\nexport function PrivacyCheckbox() {\n const id = useId();\n return (\n <div className=\"flex items-start gap-3\">\n <input\n type=\"checkbox\"\n id={id}\n name=\"privacy\"\n required\n aria-label=\"Agree to Privacy Policy, Terms of Service, and SMS consent\"\n className=\"mt-1 w-4 h-4 shrink-0 border-secondary rounded focus:ring-focus-ring\"\n />\n <label htmlFor={id} className=\"font-body text-sm text-tertiary\">\n By checking this box, you agree to our{' '}\n <a\n href=\"/privacy-policy\"\n className=\"underline outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n Privacy Policy\n </a>\n {' '}\n and{' '}\n <a\n href=\"/terms-of-service\"\n className=\"underline outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n Terms of Service\n </a>\n . You consent to receive text messages from our team and our automated systems (e.g., question follow-ups, updates, responses to ads) at the number provided. Message frequency varies. Message and data rates may apply. Reply HELP for help, STOP to opt out. *\n </label>\n </div>\n );\n}\n","\"use client\";\n\nimport type { ComponentPropsWithRef } from \"react\";\nimport { Form as AriaForm } from \"react-aria-components\";\n\nexport const Form = (props: ComponentPropsWithRef<typeof AriaForm>) => {\n return <AriaForm {...props} />;\n};\n\nForm.displayName = \"Form\";\n","import React from 'react';\nimport { cx } from '../../../utils/cx';\n\ninterface FormContainerProps {\n children: React.ReactNode;\n title?: string;\n description?: string;\n variant?: 'default' | 'aman' | 'barelux';\n bordered?: boolean;\n className?: string;\n}\n\nexport const FormContainer = ({ \n children,\n title,\n description,\n variant = 'default',\n bordered = false,\n className\n}: FormContainerProps) => {\n const isAman = variant === 'aman';\n const isBarelux = variant === 'barelux';\n\n // Container styles based on variant and bordered prop\n const containerClassName = cx(\n 'bg-white p-6 md:p-8',\n bordered && 'border border-secondary',\n isAman && bordered && '', // No rounded corners for Aman\n !isAman && bordered && 'rounded-lg', // Default and Barelux have rounded corners\n className\n );\n\n // Title styles based on variant\n const titleClassName = cx(\n isAman && 'font-heading text-2xl font-light uppercase tracking-wide text-primary',\n isBarelux && 'font-heading text-2xl font-semibold text-primary',\n !isAman && !isBarelux && 'font-display text-2xl font-semibold text-primary'\n );\n\n // Description styles based on variant\n const descriptionClassName = cx(\n 'mt-2 text-base text-tertiary',\n isAman && 'font-body',\n isBarelux && 'font-body',\n !isAman && !isBarelux && 'font-body'\n );\n\n return (\n <div className={containerClassName}>\n {(title || description) && (\n <div className=\"mb-6\">\n {title && (\n <h2 className={titleClassName}>\n {title}\n </h2>\n )}\n {description && (\n <p className={descriptionClassName}>\n {description}\n </p>\n )}\n </div>\n )}\n {children}\n </div>\n );\n};\n","\"use client\";\n\nimport type { FC, ReactNode, Ref, RefAttributes } from \"react\";\nimport { createContext, isValidElement } from \"react\";\nimport { ChevronDown } from \"@untitledui/icons\";\nimport type { SelectProps as AriaSelectProps } from \"react-aria-components\";\nimport { Button as AriaButton, ListBox as AriaListBox, Select as AriaSelect, SelectValue as AriaSelectValue } from \"react-aria-components\";\nimport { Avatar } from '../avatar/avatar';\nimport { HintText } from '../input/hint-text';\nimport { Label } from '../input/label';\nimport { cx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\nimport { ComboBox } from './combobox';\nimport { Popover } from \"./popover\";\nimport { SelectItem } from \"./select-item\";\n\nexport type SelectItemType = {\n id: string;\n label?: string;\n avatarUrl?: string;\n isDisabled?: boolean;\n supportingText?: string;\n icon?: FC | ReactNode;\n};\n\nexport interface CommonProps {\n hint?: string;\n label?: string;\n tooltip?: string;\n size?: \"sm\" | \"md\";\n placeholder?: string;\n}\n\ninterface SelectProps extends Omit<AriaSelectProps<SelectItemType>, \"children\" | \"items\">, RefAttributes<HTMLDivElement>, CommonProps {\n items?: SelectItemType[];\n popoverClassName?: string;\n placeholderIcon?: FC | ReactNode;\n children: ReactNode | ((item: SelectItemType) => ReactNode);\n}\n\ninterface SelectValueProps {\n isOpen: boolean;\n size: \"sm\" | \"md\";\n isFocused: boolean;\n isDisabled: boolean;\n placeholder?: string;\n ref?: Ref<HTMLButtonElement>;\n placeholderIcon?: FC | ReactNode;\n}\n\nexport const sizes = {\n sm: { root: \"py-2 px-3\", shortcut: \"pr-2.5\" },\n md: { root: \"py-2.5 px-3.5\", shortcut: \"pr-3\" },\n};\n\nconst SelectValue = ({ isOpen, isFocused, isDisabled, size, placeholder, placeholderIcon, ref }: SelectValueProps) => {\n return (\n <AriaButton\n ref={ref}\n className={cx(\n \"relative flex w-full cursor-pointer items-center rounded-lg bg-primary shadow-xs ring-1 ring-primary outline-hidden transition duration-100 ease-linear ring-inset\",\n (isFocused || isOpen) && \"ring-2 ring-brand\",\n isDisabled && \"cursor-not-allowed bg-disabled_subtle text-disabled\",\n )}\n >\n <AriaSelectValue<SelectItemType>\n className={cx(\n \"flex h-max w-full items-center justify-start gap-2 truncate text-left align-middle\",\n\n // Icon styles\n \"*:data-icon:size-5 *:data-icon:shrink-0 *:data-icon:text-fg-quaternary in-disabled:*:data-icon:text-fg-disabled\",\n\n sizes[size].root,\n )}\n >\n {(state) => {\n const Icon = state.selectedItem?.icon || placeholderIcon;\n return (\n <>\n {state.selectedItem?.avatarUrl ? (\n <Avatar size=\"xs\" src={state.selectedItem.avatarUrl} alt={state.selectedItem.label} />\n ) : isReactComponent(Icon) ? (\n <Icon data-icon aria-hidden=\"true\" />\n ) : isValidElement(Icon) ? (\n Icon\n ) : null}\n\n {state.selectedItem ? (\n <section className=\"flex w-full gap-2 truncate\">\n <p className=\"truncate text-md font-medium text-primary\">{state.selectedItem?.label}</p>\n {state.selectedItem?.supportingText && <p className=\"text-md text-tertiary\">{state.selectedItem?.supportingText}</p>}\n </section>\n ) : (\n <p className={cx(\"text-md text-placeholder\", isDisabled && \"text-disabled\")}>{placeholder}</p>\n )}\n\n <ChevronDown\n aria-hidden=\"true\"\n className={cx(\"ml-auto shrink-0 text-fg-quaternary\", size === \"sm\" ? \"size-4 stroke-[2.5px]\" : \"size-5\")}\n />\n </>\n );\n }}\n </AriaSelectValue>\n </AriaButton>\n );\n};\n\nexport const SelectContext = createContext<{ size: \"sm\" | \"md\" }>({ size: \"sm\" });\n\nconst Select = ({ placeholder = \"Select\", placeholderIcon, size = \"sm\", children, items, label, hint, tooltip, className, ...rest }: SelectProps) => {\n return (\n <SelectContext.Provider value={{ size }}>\n <AriaSelect {...rest} className={(state) => cx(\"flex flex-col gap-1.5\", typeof className === \"function\" ? className(state) : className)}>\n {(state) => (\n <>\n {label && (\n <Label isRequired={state.isRequired} tooltip={tooltip}>\n {label}\n </Label>\n )}\n\n <SelectValue {...state} {...{ size, placeholder }} placeholderIcon={placeholderIcon} />\n\n <Popover size={size} className={rest.popoverClassName}>\n <AriaListBox items={items} className=\"size-full outline-hidden\">\n {children}\n </AriaListBox>\n </Popover>\n\n {hint && <HintText isInvalid={state.isInvalid}>{hint}</HintText>}\n </>\n )}\n </AriaSelect>\n </SelectContext.Provider>\n );\n};\n\nconst _Select = Select as typeof Select & {\n ComboBox: typeof ComboBox;\n Item: typeof SelectItem;\n};\n_Select.ComboBox = ComboBox;\n_Select.Item = SelectItem;\n\nexport { _Select as Select };\n","\"use client\";\n\nimport { type FC, type ReactNode, useState } from \"react\";\nimport Image from \"next/image\";\nimport { User01 } from \"@untitledui/icons\";\nimport { cx } from '../../../utils/cx';\nimport { AvatarOnlineIndicator, VerifiedTick } from \"./base-components\";\n\ntype AvatarSize = \"xxs\" | \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\n\nexport interface AvatarProps {\n size?: AvatarSize;\n className?: string;\n src?: string | null;\n alt?: string;\n /**\n * Display a contrast border around the avatar.\n */\n contrastBorder?: boolean;\n /**\n * Display a badge (i.e. company logo).\n */\n badge?: ReactNode;\n /**\n * Display a status indicator.\n */\n status?: \"online\" | \"offline\";\n /**\n * Display a verified tick icon.\n *\n * @default false\n */\n verified?: boolean;\n\n /**\n * The initials of the user to display if no image is available.\n */\n initials?: string;\n /**\n * An icon to display if no image is available.\n */\n placeholderIcon?: FC<{ className?: string }>;\n /**\n * A placeholder to display if no image is available.\n */\n placeholder?: ReactNode;\n\n /**\n * Whether the avatar should show a focus ring when the parent group is in focus.\n * For example, when the avatar is wrapped inside a link.\n *\n * @default false\n */\n focusable?: boolean;\n}\n\nconst styles = {\n xxs: { root: \"size-4 outline-[0.5px] -outline-offset-[0.5px]\", initials: \"text-xs font-semibold\", icon: \"size-3\" },\n xs: { root: \"size-6 outline-[0.5px] -outline-offset-[0.5px]\", initials: \"text-xs font-semibold\", icon: \"size-4\" },\n sm: { root: \"size-8 outline-[0.75px] -outline-offset-[0.75px]\", initials: \"text-sm font-semibold\", icon: \"size-5\" },\n md: { root: \"size-10 outline-1 -outline-offset-1\", initials: \"text-md font-semibold\", icon: \"size-6\" },\n lg: { root: \"size-12 outline-1 -outline-offset-1\", initials: \"text-lg font-semibold\", icon: \"size-7\" },\n xl: { root: \"size-14 outline-1 -outline-offset-1\", initials: \"text-xl font-semibold\", icon: \"size-8\" },\n \"2xl\": { root: \"size-16 outline-1 -outline-offset-1\", initials: \"text-display-xs font-semibold\", icon: \"size-8\" },\n};\n\nexport const Avatar = ({\n contrastBorder = true,\n size = \"md\",\n src,\n alt,\n initials,\n placeholder,\n placeholderIcon: PlaceholderIcon,\n badge,\n status,\n verified,\n focusable = false,\n className,\n}: AvatarProps) => {\n const [isFailed, setIsFailed] = useState(false);\n\n const renderMainContent = () => {\n if (src && !isFailed) {\n return <Image data-avatar-img className=\"size-full rounded-full object-cover\" src={src} alt={alt || ''} onError={() => setIsFailed(true)} width={100} height={100} />;\n }\n\n if (initials) {\n return <span className={cx(\"text-quaternary\", styles[size].initials)}>{initials}</span>;\n }\n\n if (PlaceholderIcon) {\n return <PlaceholderIcon className={cx(\"text-fg-quaternary\", styles[size].icon)} />;\n }\n\n return placeholder || <User01 className={cx(\"text-fg-quaternary\", styles[size].icon)} />;\n };\n\n const renderBadgeContent = () => {\n if (status) {\n return <AvatarOnlineIndicator status={status} size={size === \"xxs\" ? \"xs\" : size} />;\n }\n\n if (verified) {\n return (\n <VerifiedTick\n size={size === \"xxs\" ? \"xs\" : size}\n className={cx(\"absolute right-0 bottom-0\", (size === \"xxs\" || size === \"xs\") && \"-right-px -bottom-px\")}\n />\n );\n }\n\n return badge;\n };\n\n return (\n <div\n data-avatar\n className={cx(\n \"relative inline-flex shrink-0 items-center justify-center rounded-full bg-avatar-bg outline-transparent\",\n // Focus styles\n focusable && \"group-outline-focus-ring group-focus-visible:outline-2 group-focus-visible:outline-offset-2\",\n contrastBorder && \"outline outline-avatar-contrast-border\",\n styles[size].root,\n className,\n )}\n >\n {renderMainContent()}\n {renderBadgeContent()}\n </div>\n );\n};\n","\"use client\";\n\nimport { cx } from '../../../../utils/cx';\n\nconst sizes = {\n xs: \"size-1.5\",\n sm: \"size-2\",\n md: \"size-2.5\",\n lg: \"size-3\",\n xl: \"size-3.5\",\n \"2xl\": \"size-4\",\n \"3xl\": \"size-4.5\",\n \"4xl\": \"size-5\",\n};\n\ninterface AvatarOnlineIndicatorProps {\n size: \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\" | \"3xl\" | \"4xl\";\n status: \"online\" | \"offline\";\n className?: string;\n}\n\nexport const AvatarOnlineIndicator = ({ size, status, className }: AvatarOnlineIndicatorProps) => (\n <span\n className={cx(\n \"absolute right-0 bottom-0 rounded-full ring-[1.5px] ring-bg-primary\",\n status === \"online\" ? \"bg-fg-success-secondary\" : \"bg-fg-disabled_subtle\",\n sizes[size],\n className,\n )}\n />\n);\n","\"use client\";\n\nimport { cx } from '../../../../utils/cx';\n\nconst sizes = {\n xs: { root: \"size-2.5\", tick: \"size-[4.38px\" },\n sm: { root: \"size-3\", tick: \"size-[5.25px]\" },\n md: { root: \"size-3.5\", tick: \"size-[6.13px]\" },\n lg: { root: \"size-4\", tick: \"size-[7px]\" },\n xl: { root: \"size-4.5\", tick: \"size-[7.88px]\" },\n \"2xl\": { root: \"size-5\", tick: \"size-[8.75px]\" },\n \"3xl\": { root: \"size-6\", tick: \"size-[10.5px]\" },\n \"4xl\": { root: \"size-8\", tick: \"size-[14px]\" },\n};\n\ninterface VerifiedTickProps {\n size: \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\" | \"3xl\" | \"4xl\";\n className?: string;\n}\n\nexport const VerifiedTick = ({ size, className }: VerifiedTickProps) => (\n <svg data-verified className={cx(\"z-10 text-utility-blue-500\", sizes[size].root, className)} viewBox=\"0 0 10 10\" fill=\"none\">\n <path\n d=\"M7.72237 1.77098C7.81734 2.00068 7.99965 2.18326 8.2292 2.27858L9.03413 2.61199C9.26384 2.70714 9.44635 2.88965 9.5415 3.11936C9.63665 3.34908 9.63665 3.60718 9.5415 3.83689L9.20833 4.64125C9.11313 4.87106 9.113 5.12943 9.20863 5.35913L9.54122 6.16325C9.58839 6.27702 9.61268 6.39897 9.6127 6.52214C9.61272 6.6453 9.58847 6.76726 9.54134 6.88105C9.4942 6.99484 9.42511 7.09823 9.33801 7.18531C9.2509 7.27238 9.14749 7.34144 9.03369 7.38854L8.22934 7.72171C7.99964 7.81669 7.81706 7.99899 7.72174 8.22855L7.38833 9.03348C7.29318 9.26319 7.11067 9.4457 6.88096 9.54085C6.65124 9.636 6.39314 9.636 6.16343 9.54085L5.35907 9.20767C5.12935 9.11276 4.87134 9.11295 4.64177 9.20821L3.83684 9.54115C3.60725 9.63608 3.34937 9.636 3.11984 9.54092C2.89032 9.44585 2.70791 9.26356 2.6127 9.03409L2.27918 8.22892C2.18421 7.99923 2.0019 7.81665 1.77235 7.72133L0.967421 7.38792C0.737807 7.29281 0.555355 7.11041 0.460169 6.88083C0.364983 6.65125 0.364854 6.39327 0.45981 6.16359L0.792984 5.35924C0.8879 5.12952 0.887707 4.87151 0.792445 4.64193L0.459749 3.83642C0.41258 3.72265 0.388291 3.60069 0.388272 3.47753C0.388252 3.35436 0.412501 3.2324 0.459634 3.11861C0.506767 3.00482 0.57586 2.90144 0.662965 2.81436C0.75007 2.72728 0.853479 2.65822 0.967283 2.61113L1.77164 2.27795C2.00113 2.18306 2.1836 2.00099 2.27899 1.7717L2.6124 0.966768C2.70755 0.737054 2.89006 0.554547 3.11978 0.459397C3.34949 0.364246 3.60759 0.364246 3.83731 0.459397L4.64166 0.792571C4.87138 0.887487 5.12939 0.887293 5.35897 0.792031L6.16424 0.459913C6.39392 0.364816 6.65197 0.364836 6.88164 0.459968C7.11131 0.555099 7.29379 0.737554 7.38895 0.967208L7.72247 1.77238L7.72237 1.77098Z\"\n className=\"fill-current\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M6.95829 3.68932C7.02509 3.58439 7.04747 3.45723 7.02051 3.3358C6.99356 3.21437 6.91946 3.10862 6.81454 3.04182C6.70961 2.97502 6.58245 2.95264 6.46102 2.97959C6.33959 3.00655 6.23384 3.08064 6.16704 3.18557L4.33141 6.06995L3.49141 5.01995C3.41375 4.92281 3.30069 4.8605 3.17709 4.84673C3.05349 4.83296 2.92949 4.86885 2.83235 4.94651C2.73522 5.02417 2.67291 5.13723 2.65914 5.26083C2.64536 5.38443 2.68125 5.50843 2.75891 5.60557L4.00891 7.16807C4.0555 7.22638 4.11533 7.27271 4.18344 7.30323C4.25154 7.33375 4.32595 7.34757 4.40047 7.34353C4.47499 7.3395 4.54747 7.31773 4.61188 7.28004C4.67629 7.24234 4.73077 7.18981 4.77079 7.12682L6.95829 3.68932Z\"\n fill=\"white\"\n />\n </svg>\n);\n","\"use client\";\n\nimport type { FocusEventHandler, PointerEventHandler, RefAttributes, RefObject } from \"react\";\nimport { useCallback, useContext, useRef, useState } from \"react\";\nimport { SearchLg as SearchIcon } from \"@untitledui/icons\";\nimport type { ComboBoxProps as AriaComboBoxProps, GroupProps as AriaGroupProps, ListBoxProps as AriaListBoxProps } from \"react-aria-components\";\nimport { ComboBox as AriaComboBox, Group as AriaGroup, Input as AriaInput, ListBox as AriaListBox, ComboBoxStateContext } from \"react-aria-components\";\nimport { HintText } from '../input/hint-text';\nimport { Label } from '../input/label';\nimport { Popover } from './popover';\nimport { type CommonProps, SelectContext, type SelectItemType, sizes } from './select';\nimport { useResizeObserver } from '../../../lib/hooks/use-resize-observer';\nimport { cx } from '../../../utils/cx';\n\ninterface ComboBoxProps extends Omit<AriaComboBoxProps<SelectItemType>, \"children\" | \"items\">, RefAttributes<HTMLDivElement>, CommonProps {\n shortcut?: boolean;\n items?: SelectItemType[];\n popoverClassName?: string;\n shortcutClassName?: string;\n children: AriaListBoxProps<SelectItemType>[\"children\"];\n}\n\ninterface ComboBoxValueProps extends AriaGroupProps {\n size: \"sm\" | \"md\";\n shortcut: boolean;\n placeholder?: string;\n shortcutClassName?: string;\n onFocus?: FocusEventHandler;\n onPointerEnter?: PointerEventHandler;\n ref?: RefObject<HTMLDivElement | null>;\n}\n\nconst ComboBoxValue = ({ size, shortcut, placeholder, shortcutClassName, ...otherProps }: ComboBoxValueProps) => {\n const state = useContext(ComboBoxStateContext);\n\n const value = state?.selectedItem?.value || null;\n const inputValue = state?.inputValue || null;\n\n const first = inputValue?.split(value?.supportingText)?.[0] || \"\";\n const last = inputValue?.split(first)[1];\n\n return (\n <AriaGroup\n {...otherProps}\n className={({ isFocusWithin, isDisabled }) =>\n cx(\n \"relative flex w-full items-center gap-2 rounded-lg bg-primary shadow-xs ring-1 ring-primary outline-hidden transition-shadow duration-100 ease-linear ring-inset\",\n isDisabled && \"cursor-not-allowed bg-disabled_subtle\",\n isFocusWithin && \"ring-2 ring-brand\",\n sizes[size].root,\n )\n }\n >\n {({ isDisabled }) => (\n <>\n <SearchIcon className=\"pointer-events-none size-5 shrink-0 text-fg-quaternary\" />\n\n <div className=\"relative flex w-full items-center gap-2\">\n {inputValue && (\n <span className=\"absolute top-1/2 z-0 inline-flex w-full -translate-y-1/2 gap-2 truncate\" aria-hidden=\"true\">\n <p className={cx(\"text-md font-medium text-primary\", isDisabled && \"text-disabled\")}>{first}</p>\n {last && <p className={cx(\"-ml-0.75 text-md text-tertiary\", isDisabled && \"text-disabled\")}>{last}</p>}\n </span>\n )}\n\n <AriaInput\n placeholder={placeholder}\n className=\"z-10 w-full appearance-none bg-transparent text-md text-transparent caret-alpha-black/90 placeholder:text-placeholder focus:outline-hidden disabled:cursor-not-allowed disabled:text-disabled disabled:placeholder:text-disabled\"\n />\n </div>\n\n {shortcut && (\n <div\n className={cx(\n \"absolute inset-y-0.5 right-0.5 z-10 flex items-center rounded-r-[inherit] bg-linear-to-r from-transparent to-bg-primary to-40% pl-8\",\n isDisabled && \"to-bg-disabled_subtle\",\n sizes[size].shortcut,\n shortcutClassName,\n )}\n >\n <span\n className={cx(\n \"pointer-events-none rounded px-1 py-px text-xs font-medium text-quaternary ring-1 ring-secondary select-none ring-inset\",\n isDisabled && \"bg-transparent text-disabled\",\n )}\n aria-hidden=\"true\"\n >\n ⌘K\n </span>\n </div>\n )}\n </>\n )}\n </AriaGroup>\n );\n};\n\nexport const ComboBox = ({ placeholder = \"Search\", shortcut = true, size = \"sm\", children, items, shortcutClassName, ...otherProps }: ComboBoxProps) => {\n const placeholderRef = useRef<HTMLDivElement>(null);\n const [popoverWidth, setPopoverWidth] = useState(\"\");\n\n // Resize observer for popover width\n const onResize = useCallback(() => {\n if (!placeholderRef.current) return;\n\n const divRect = placeholderRef.current?.getBoundingClientRect();\n\n setPopoverWidth(divRect.width + \"px\");\n }, [placeholderRef, setPopoverWidth]);\n\n useResizeObserver({\n ref: placeholderRef,\n box: \"border-box\",\n onResize,\n });\n\n return (\n <SelectContext.Provider value={{ size }}>\n <AriaComboBox menuTrigger=\"focus\" {...otherProps}>\n {(state) => (\n <div className=\"flex flex-col gap-1.5\">\n {otherProps.label && (\n <Label isRequired={state.isRequired} tooltip={otherProps.tooltip}>\n {otherProps.label}\n </Label>\n )}\n\n <ComboBoxValue\n ref={placeholderRef}\n placeholder={placeholder}\n shortcut={shortcut}\n shortcutClassName={shortcutClassName}\n size={size}\n // This is a workaround to correctly calculating the trigger width\n // while using ResizeObserver wasn't 100% reliable.\n onFocus={onResize}\n onPointerEnter={onResize}\n />\n\n <Popover size={size} triggerRef={placeholderRef} style={{ width: popoverWidth }} className={otherProps.popoverClassName}>\n <AriaListBox items={items} className=\"size-full outline-hidden\">\n {children}\n </AriaListBox>\n </Popover>\n\n {otherProps.hint && <HintText isInvalid={state.isInvalid}>{otherProps.hint}</HintText>}\n </div>\n )}\n </AriaComboBox>\n </SelectContext.Provider>\n );\n};\n","\"use client\";\n\nimport type { RefAttributes } from \"react\";\nimport type { PopoverProps as AriaPopoverProps } from \"react-aria-components\";\nimport { Popover as AriaPopover } from \"react-aria-components\";\nimport { cx } from '../../../utils/cx';\n\ninterface PopoverProps extends AriaPopoverProps, RefAttributes<HTMLElement> {\n size: \"sm\" | \"md\";\n}\n\nexport const Popover = (props: PopoverProps) => {\n return (\n <AriaPopover\n placement=\"bottom\"\n containerPadding={0}\n offset={4}\n {...props}\n className={(state) =>\n cx(\n \"max-h-64! w-(--trigger-width) origin-(--trigger-anchor-point) overflow-x-hidden overflow-y-auto rounded-lg bg-primary py-1 shadow-lg ring-1 ring-secondary_alt outline-hidden will-change-transform\",\n\n state.isEntering &&\n \"duration-150 ease-out animate-in fade-in placement-right:slide-in-from-left-0.5 placement-top:slide-in-from-bottom-0.5 placement-bottom:slide-in-from-top-0.5\",\n state.isExiting &&\n \"duration-100 ease-in animate-out fade-out placement-right:slide-out-to-left-0.5 placement-top:slide-out-to-bottom-0.5 placement-bottom:slide-out-to-top-0.5\",\n props.size === \"md\" && \"max-h-80!\",\n\n typeof props.className === \"function\" ? props.className(state) : props.className,\n )\n }\n />\n );\n};\n","import { useEffect } from \"react\";\nimport type { RefObject } from \"@react-types/shared\";\n\n/**\n * Checks if the ResizeObserver API is supported.\n * @returns True if the ResizeObserver API is supported, false otherwise.\n */\nfunction hasResizeObserver() {\n return typeof window.ResizeObserver !== \"undefined\";\n}\n\n/**\n * The options for the useResizeObserver hook.\n */\ntype useResizeObserverOptionsType<T> = {\n /**\n * The ref to the element to observe.\n */\n ref: RefObject<T | undefined | null> | undefined;\n /**\n * The box to observe.\n */\n box?: ResizeObserverBoxOptions;\n /**\n * The callback function to call when the size changes.\n */\n onResize: () => void;\n};\n\n/**\n * A hook that observes the size of an element and calls a callback function when the size changes.\n * @param options - The options for the hook.\n */\nexport function useResizeObserver<T extends Element>(options: useResizeObserverOptionsType<T>) {\n const { ref, box, onResize } = options;\n\n useEffect(() => {\n const element = ref?.current;\n if (!element) {\n return;\n }\n\n if (!hasResizeObserver()) {\n window.addEventListener(\"resize\", onResize, false);\n\n return () => {\n window.removeEventListener(\"resize\", onResize, false);\n };\n } else {\n const resizeObserverInstance = new window.ResizeObserver((entries) => {\n if (!entries.length) {\n return;\n }\n\n onResize();\n });\n\n resizeObserverInstance.observe(element, { box });\n\n return () => {\n if (element) {\n resizeObserverInstance.unobserve(element);\n }\n };\n }\n }, [onResize, ref, box]);\n}\n\n","\"use client\";\n\nimport { isValidElement, useContext } from \"react\";\nimport { Check } from \"@untitledui/icons\";\nimport type { ListBoxItemProps as AriaListBoxItemProps } from \"react-aria-components\";\nimport { ListBoxItem as AriaListBoxItem, Text as AriaText } from \"react-aria-components\";\nimport { Avatar } from '../avatar/avatar';\nimport { cx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\nimport type { SelectItemType } from \"./select\";\nimport { SelectContext } from \"./select\";\n\nconst sizes = {\n sm: \"p-2 pr-2.5\",\n md: \"p-2.5 pl-2\",\n};\n\ninterface SelectItemProps extends Omit<AriaListBoxItemProps<SelectItemType>, \"id\">, SelectItemType {}\n\nexport const SelectItem = ({ label, id, value, avatarUrl, supportingText, isDisabled, icon: Icon, className, children, ...props }: SelectItemProps) => {\n const { size } = useContext(SelectContext);\n\n const labelOrChildren = label || (typeof children === \"string\" ? children : \"\");\n const textValue = supportingText ? labelOrChildren + \" \" + supportingText : labelOrChildren;\n\n return (\n <AriaListBoxItem\n id={id}\n value={\n value ?? {\n id,\n label: labelOrChildren,\n avatarUrl,\n supportingText,\n isDisabled,\n icon: Icon,\n }\n }\n textValue={textValue}\n isDisabled={isDisabled}\n {...props}\n className={(state) => cx(\"w-full px-1.5 py-px outline-hidden\", typeof className === \"function\" ? className(state) : className)}\n >\n {(state) => (\n <div\n className={cx(\n \"flex cursor-pointer items-center gap-2 rounded-md outline-hidden select-none\",\n state.isSelected && \"bg-active\",\n state.isDisabled && \"cursor-not-allowed\",\n state.isFocused && \"bg-primary_hover\",\n state.isFocusVisible && \"ring-2 ring-focus-ring ring-inset\",\n\n // Icon styles\n \"*:data-icon:size-5 *:data-icon:shrink-0 *:data-icon:text-fg-quaternary\",\n state.isDisabled && \"*:data-icon:text-fg-disabled\",\n\n sizes[size],\n )}\n >\n {avatarUrl ? (\n <Avatar aria-hidden=\"true\" size=\"xs\" src={avatarUrl} alt={label} />\n ) : isReactComponent(Icon) ? (\n <Icon data-icon aria-hidden=\"true\" />\n ) : isValidElement(Icon) ? (\n Icon\n ) : null}\n\n <div className=\"flex w-full min-w-0 flex-1 flex-wrap gap-x-2\">\n <AriaText\n slot=\"label\"\n className={cx(\"truncate text-md font-medium whitespace-nowrap text-primary\", state.isDisabled && \"text-disabled\")}\n >\n {label || (typeof children === \"function\" ? children(state) : children)}\n </AriaText>\n\n {supportingText && (\n <AriaText slot=\"description\" className={cx(\"text-md whitespace-nowrap text-tertiary\", state.isDisabled && \"text-disabled\")}>\n {supportingText}\n </AriaText>\n )}\n </div>\n\n {state.isSelected && (\n <Check\n aria-hidden=\"true\"\n className={cx(\n \"ml-auto text-fg-brand-primary\",\n size === \"sm\" ? \"size-4 stroke-[2.5px]\" : \"size-5\",\n state.isDisabled && \"text-fg-disabled\",\n )}\n />\n )}\n </div>\n )}\n </AriaListBoxItem>\n );\n};\n","\"use client\";\n\nimport { type SelectHTMLAttributes, useId } from \"react\";\nimport { ChevronDown } from \"@untitledui/icons\";\nimport { HintText } from '../input/hint-text';\nimport { Label } from '../input/label';\nimport { cx } from '../../../utils/cx';\n\ninterface NativeSelectProps extends SelectHTMLAttributes<HTMLSelectElement> {\n label?: string;\n hint?: string;\n selectClassName?: string;\n options: { label: string; value: string; disabled?: boolean }[];\n}\n\nexport const NativeSelect = ({ label, hint, options, className, selectClassName, ...props }: NativeSelectProps) => {\n const id = useId();\n const selectId = `select-native-${id}`;\n const hintId = `select-native-hint-${id}`;\n\n return (\n <div className={cx(\"w-full in-data-input-wrapper:w-max\", className)}>\n {label && (\n <Label htmlFor={selectId} id={selectId} className=\"mb-1.5\">\n {label}\n </Label>\n )}\n\n <div className=\"relative grid w-full items-center\">\n <select\n {...props}\n id={selectId}\n aria-describedby={hintId}\n aria-labelledby={selectId}\n className={cx(\n \"appearance-none rounded-lg bg-primary px-3.5 py-2.5 text-md font-medium text-primary shadow-xs ring-1 ring-primary outline-hidden transition duration-100 ease-linear ring-inset placeholder:text-fg-quaternary focus-visible:ring-2 focus-visible:ring-brand disabled:cursor-not-allowed disabled:bg-disabled_subtle disabled:text-disabled\",\n /* InputGroup: match other inputs (bg-white, rounded-sm, ring-secondary) */\n \"in-data-input-wrapper:flex in-data-input-wrapper:h-full in-data-input-wrapper:gap-1 in-data-input-wrapper:!bg-white in-data-input-wrapper:px-3 in-data-input-wrapper:py-2 in-data-input-wrapper:font-normal in-data-input-wrapper:text-tertiary in-data-input-wrapper:shadow-none in-data-input-wrapper:ring-1 in-data-input-wrapper:ring-secondary in-data-input-wrapper:ring-inset in-data-input-wrapper:rounded-sm in-data-input-wrapper:focus-visible:ring-2 in-data-input-wrapper:focus-visible:ring-brand\",\n \"in-data-input-wrapper:group-disabled:pointer-events-none in-data-input-wrapper:group-disabled:cursor-not-allowed in-data-input-wrapper:group-disabled:bg-transparent in-data-input-wrapper:group-disabled:ring-disabled in-data-input-wrapper:group-disabled:text-disabled\",\n \"in-data-input-wrapper:in-data-leading:rounded-l-sm in-data-input-wrapper:in-data-leading:rounded-r-none in-data-input-wrapper:in-data-trailing:rounded-r-sm in-data-input-wrapper:in-data-trailing:rounded-l-none\",\n \"in-data-input-wrapper:in-data-[input-size=md]:py-2.5 in-data-input-wrapper:in-data-leading:in-data-[input-size=md]:pl-3.5 in-data-input-wrapper:in-data-[input-size=sm]:py-2 in-data-input-wrapper:in-data-[input-size=sm]:pl-3\",\n \"in-data-input-wrapper:in-data-leading:in-data-[input-size=md]:pr-4.5 in-data-input-wrapper:in-data-leading:in-data-[input-size=sm]:pr-4.5\",\n \"in-data-input-wrapper:in-data-trailing:in-data-[input-size=md]:pr-8 in-data-input-wrapper:in-data-trailing:in-data-[input-size=sm]:pr-7.5\",\n selectClassName,\n )}\n >\n {options.map((opt) => (\n <option key={opt.value} value={opt.value}>\n {opt.label}\n </option>\n ))}\n </select>\n <ChevronDown\n aria-hidden=\"true\"\n className=\"pointer-events-none absolute right-3.5 size-5 text-fg-quaternary in-data-input-wrapper:right-1.5 in-data-input-wrapper:size-4 in-data-input-wrapper:stroke-[2.625px] in-data-input-wrapper:in-data-trailing:in-data-[input-size=sm]:right-3\"\n />\n </div>\n\n {hint && (\n <HintText className=\"mt-2\" id={hintId}>\n {hint}\n </HintText>\n )}\n </div>\n );\n};\n","'use client';\n\nimport React, { useState, useEffect, useMemo } from 'react';\nimport Image from 'next/image';\nimport { getGradientUrl } from '../../../utils/gradient-placeholder';\nimport type { WebsitePhotos } from '../../../types/api/website-photos';\nimport type { CompanyInformation } from '../../../types/api/company-information';\n\ninterface PhotoWithFallbackProps {\n // Generic object with photo_attachments (service, location, team member, blog post, etc.)\n item?: {\n id?: number;\n name?: string;\n title?: string;\n photo_attachments?: Array<{\n id: number;\n featured: boolean;\n photo?: {\n id: number;\n title: string;\n thumbnail_url?: string;\n medium_url?: string;\n large_url?: string;\n original_url?: string;\n };\n }>;\n };\n // Generic photo props (for direct photo URLs; null/undefined = use gradient fallback)\n photoUrl?: string | null;\n photoAlt?: string;\n // Fallback props\n fallbackId?: number | string;\n // Image props\n className?: string;\n alt?: string;\n // SSR data props (optional)\n websitePhotos?: WebsitePhotos | null;\n companyInformation?: CompanyInformation | null;\n}\n\n/**\n * Reusable component that displays a photo with automatic fallback to gradient.\n * Supports photo_attachments from any object (services, locations, team members, blog posts, etc.),\n * direct photo URLs, or gradient fallback.\n */\nexport default function PhotoWithFallback({\n item,\n photoUrl,\n photoAlt,\n fallbackId,\n className = '',\n alt,\n websitePhotos,\n companyInformation,\n}: PhotoWithFallbackProps) {\n // Determine the image URL synchronously to avoid gradient flash\n const { imageUrl, imageAlt } = useMemo(() => {\n // Use data from props (SSR) - moved inside useMemo to fix dependency issues\n const isStubMode = companyInformation?.account_status === 'stub';\n const stockPhotos = websitePhotos?.stock_photos || [];\n\n // Priority 1: Direct photoUrl prop\n if (photoUrl) {\n return { imageUrl: photoUrl, imageAlt: photoAlt || alt || \"\" };\n }\n\n // Priority 2: Photo from photo_attachments\n if (item?.photo_attachments && item.photo_attachments.length > 0) {\n const photoAttachments = item.photo_attachments;\n const featuredPhoto = photoAttachments.find((pa) => pa.featured) || photoAttachments[0];\n const photo = featuredPhoto?.photo;\n \n if (photo) {\n const url = photo.large_url || photo.medium_url || photo.thumbnail_url || photo.original_url;\n if (url) {\n return {\n imageUrl: url,\n imageAlt: photo.title || item.name || item.title || alt || \"Image\"\n };\n }\n }\n }\n\n // Priority 3: In stub mode, use deterministic stock photo selection based on item id\n if (isStubMode && stockPhotos.length > 0) {\n // Use item id to deterministically select a stock photo (avoid Math.random in render)\n const itemId = item?.id || fallbackId || 1;\n const numericId = typeof itemId === 'number' ? itemId : typeof itemId === 'string' ? parseInt(itemId, 10) || 1 : 1;\n const stockPhotoIndex = numericId % stockPhotos.length;\n const stockPhoto = stockPhotos[stockPhotoIndex];\n if (stockPhoto?.url) {\n return {\n imageUrl: stockPhoto.url,\n imageAlt: stockPhoto.alt || item?.name || item?.title || alt || \"Image\"\n };\n }\n }\n\n // Priority 4: Fallback to gradient\n const id = fallbackId || item?.id || 1;\n return {\n imageUrl: getGradientUrl(id),\n imageAlt: item?.name || item?.title || alt || \"Image\"\n };\n }, [item, photoUrl, photoAlt, fallbackId, alt, websitePhotos, companyInformation]);\n\n const [isLoaded, setIsLoaded] = useState(false);\n const imgRef = React.useRef<HTMLImageElement>(null);\n\n // Reset loaded state when image URL changes\n useEffect(() => {\n // Reset loaded state asynchronously to avoid cascading renders\n const resetTimer = setTimeout(() => {\n setIsLoaded(false);\n }, 0);\n \n // Check if image is already loaded (cached)\n const checkTimer = setTimeout(() => {\n if (imgRef.current?.complete && imgRef.current.naturalWidth > 0) {\n setIsLoaded(true);\n }\n }, 0);\n \n return () => {\n clearTimeout(resetTimer);\n clearTimeout(checkTimer);\n };\n }, [imageUrl]);\n\n // Callback ref to check if image is already loaded (cached images)\n const setImgRef = React.useCallback((img: HTMLImageElement | null) => {\n imgRef.current = img;\n if (img && img.complete && img.naturalWidth > 0) {\n setIsLoaded(true);\n }\n }, []);\n\n if (!imageUrl) {\n return null;\n }\n\n return (\n <Image\n ref={setImgRef}\n src={imageUrl}\n alt={imageAlt}\n width={800}\n height={600}\n className={`${className} transition-opacity duration-500 ease-in-out ${\n isLoaded ? 'opacity-100' : 'opacity-0'\n }`}\n onLoad={() => setIsLoaded(true)}\n onError={() => setIsLoaded(true)}\n />\n );\n}\n","/**\n * Generates a beautiful gradient SVG data URL using the full color palette\n * Each seed (post ID or index) will consistently return the same gradient\n */\nexport const getGradientUrl = (seed: string | number): string => {\n // Colors match Tailwind's default palette (purple, pink, blue, green, orange, indigo)\n const gradients = [\n // Purple gradients (like from-purple-200 to-purple-300)\n ['rgb(233, 213, 255)', 'rgb(221, 214, 254)', 'rgb(196, 181, 253)'], // purple-200 to purple-300\n ['rgb(250, 232, 255)', 'rgb(251, 207, 232)', 'rgb(244, 114, 182)'], // pink-200 to pink-300 via pink-400\n // Blue gradients (like from-blue-200 to-blue-300)\n ['rgb(191, 219, 254)', 'rgb(147, 197, 253)', 'rgb(96, 165, 250)'], // blue-200 to blue-300 to blue-400\n // Green gradients (like from-green-200 to-green-300)\n ['rgb(187, 247, 208)', 'rgb(134, 239, 172)', 'rgb(74, 222, 128)'], // green-200 to green-300 to green-400\n // Pink to Purple (like from-pink-400 to-purple-500)\n ['rgb(244, 114, 182)', 'rgb(217, 70, 239)', 'rgb(168, 85, 247)'], // pink-400 to purple-500\n // Blue to Purple (like from-blue-500 to-purple-600)\n ['rgb(59, 130, 246)', 'rgb(147, 51, 234)', 'rgb(147, 51, 234)'], // blue-500 to purple-600\n // Indigo to Purple (like from-indigo-500 to-purple-600)\n ['rgb(99, 102, 241)', 'rgb(139, 92, 246)', 'rgb(147, 51, 234)'], // indigo-500 to purple-600\n // Orange gradients (like from-orange-200 to-orange-300)\n ['rgb(254, 215, 170)', 'rgb(253, 186, 116)', 'rgb(251, 146, 60)'], // orange-200 to orange-300 to orange-400\n // Purple to Pink (like from-purple-400 to-pink-400)\n ['rgb(192, 132, 252)', 'rgb(232, 121, 249)', 'rgb(244, 114, 182)'], // purple-400 to pink-400\n // Softer blue-green blend\n ['rgb(165, 243, 252)', 'rgb(103, 232, 249)', 'rgb(134, 239, 172)'], // cyan-300 to green-400\n // Warm pink-orange\n ['rgb(251, 207, 232)', 'rgb(254, 202, 202)', 'rgb(253, 186, 116)'], // pink-200 to orange-300\n // Cool indigo-blue\n ['rgb(199, 210, 254)', 'rgb(165, 180, 252)', 'rgb(129, 140, 248)'], // indigo-200 to indigo-400\n ];\n \n // Calculate consistent index from seed\n const index = typeof seed === 'string' \n ? seed.split('').reduce((acc, char) => acc + char.charCodeAt(0), 0) % gradients.length\n : Number(seed) % gradients.length;\n \n const [color1, color2, color3] = gradients[index];\n \n // Generate SVG with gradient (diagonal like bg-gradient-to-br)\n const svg = `\n <svg width=\"600\" height=\"400\" xmlns=\"http://www.w3.org/2000/svg\">\n <defs>\n <linearGradient id=\"grad${index}\" x1=\"0%\" y1=\"0%\" x2=\"100%\" y2=\"100%\">\n <stop offset=\"0%\" style=\"stop-color:${color1};stop-opacity:1\" />\n <stop offset=\"50%\" style=\"stop-color:${color2};stop-opacity:1\" />\n <stop offset=\"100%\" style=\"stop-color:${color3};stop-opacity:1\" />\n </linearGradient>\n </defs>\n <rect width=\"600\" height=\"400\" fill=\"url(#grad${index})\" />\n </svg>\n `.trim();\n \n // Convert to base64 data URL\n return `data:image/svg+xml;base64,${btoa(svg)}`;\n};\n\n","\"use client\";\n\nimport type { MouseEventHandler, ReactNode, HTMLAttributes } from \"react\";\nimport Image from \"next/image\";\nimport { X as CloseX } from \"@untitledui/icons\";\nimport { cx } from '../../../utils/cx';\nimport type { BadgeColors, BadgeTypeToColorMap, BadgeTypes, FlagTypes, IconComponentType, Sizes } from \"./badge-types\";\nimport { badgeTypes } from \"./badge-types\";\n\n// Inline Dot component (previously from foundations)\nconst dotSizes = {\n sm: { wh: 8, c: 4, r: 2.5 },\n md: { wh: 10, c: 5, r: 4 },\n};\n\nexport const Dot = ({ size = \"md\", ...props }: HTMLAttributes<HTMLOrSVGElement> & { size?: \"sm\" | \"md\" }) => {\n return (\n <svg width={dotSizes[size].wh} height={dotSizes[size].wh} viewBox={`0 0 ${dotSizes[size].wh} ${dotSizes[size].wh}`} fill=\"none\" {...props}>\n <circle cx={dotSizes[size].c} cy={dotSizes[size].c} r={dotSizes[size].r} fill=\"currentColor\" stroke=\"currentColor\" />\n </svg>\n );\n};\n\nexport const filledColors: Record<BadgeColors, { root: string; addon: string; addonButton: string }> = {\n gray: {\n root: \"bg-utility-gray-50 text-utility-gray-700 ring-utility-gray-200\",\n addon: \"text-utility-gray-500\",\n addonButton: \"hover:bg-utility-gray-100 text-utility-gray-400 hover:text-utility-gray-500\",\n },\n brand: {\n root: \"bg-utility-brand-50 text-utility-brand-700 ring-utility-brand-200\",\n addon: \"text-utility-brand-500\",\n addonButton: \"hover:bg-utility-brand-100 text-utility-brand-400 hover:text-utility-brand-500\",\n },\n error: {\n root: \"bg-utility-error-50 text-utility-error-700 ring-utility-error-200\",\n addon: \"text-utility-error-500\",\n addonButton: \"hover:bg-utility-error-100 text-utility-error-400 hover:text-utility-error-500\",\n },\n warning: {\n root: \"bg-utility-warning-50 text-utility-warning-700 ring-utility-warning-200\",\n addon: \"text-utility-warning-500\",\n addonButton: \"hover:bg-utility-warning-100 text-utility-warning-400 hover:text-utility-warning-500\",\n },\n success: {\n root: \"bg-utility-success-50 text-utility-success-700 ring-utility-success-200\",\n addon: \"text-utility-success-500\",\n addonButton: \"hover:bg-utility-success-100 text-utility-success-400 hover:text-utility-success-500\",\n },\n \"gray-blue\": {\n root: \"bg-utility-gray-blue-50 text-utility-gray-blue-700 ring-utility-gray-blue-200\",\n addon: \"text-utility-gray-blue-500\",\n addonButton: \"hover:bg-utility-gray-blue-100 text-utility-gray-blue-400 hover:text-utility-gray-blue-500\",\n },\n \"blue-light\": {\n root: \"bg-utility-blue-light-50 text-utility-blue-light-700 ring-utility-blue-light-200\",\n addon: \"text-utility-blue-light-500\",\n addonButton: \"hover:bg-utility-blue-light-100 text-utility-blue-light-400 hover:text-utility-blue-light-500\",\n },\n blue: {\n root: \"bg-utility-blue-50 text-utility-blue-700 ring-utility-blue-200\",\n addon: \"text-utility-blue-500\",\n addonButton: \"hover:bg-utility-blue-100 text-utility-blue-400 hover:text-utility-blue-500\",\n },\n indigo: {\n root: \"bg-utility-indigo-50 text-utility-indigo-700 ring-utility-indigo-200\",\n addon: \"text-utility-indigo-500\",\n addonButton: \"hover:bg-utility-indigo-100 text-utility-indigo-400 hover:text-utility-indigo-500\",\n },\n purple: {\n root: \"bg-utility-purple-50 text-utility-purple-700 ring-utility-purple-200\",\n addon: \"text-utility-purple-500\",\n addonButton: \"hover:bg-utility-purple-100 text-utility-purple-400 hover:text-utility-purple-500\",\n },\n pink: {\n root: \"bg-utility-pink-50 text-utility-pink-700 ring-utility-pink-200\",\n addon: \"text-utility-pink-500\",\n addonButton: \"hover:bg-utility-pink-100 text-utility-pink-400 hover:text-utility-pink-500\",\n },\n orange: {\n root: \"bg-utility-orange-50 text-utility-orange-700 ring-utility-orange-200\",\n addon: \"text-utility-orange-500\",\n addonButton: \"hover:bg-utility-orange-100 text-utility-orange-400 hover:text-utility-orange-500\",\n },\n};\n\nconst addonOnlyColors = Object.fromEntries(Object.entries(filledColors).map(([key, value]) => [key, { root: \"\", addon: value.addon }])) as Record<\n BadgeColors,\n { root: string; addon: string }\n>;\n\nconst withPillTypes = {\n [badgeTypes.pillColor]: {\n common: \"size-max flex items-center whitespace-nowrap rounded-full ring-1 ring-inset\",\n styles: filledColors,\n },\n [badgeTypes.badgeColor]: {\n common: \"size-max flex items-center whitespace-nowrap rounded-md ring-1 ring-inset\",\n styles: filledColors,\n },\n [badgeTypes.badgeModern]: {\n common: \"size-max flex items-center whitespace-nowrap rounded-md ring-1 ring-inset shadow-xs\",\n styles: {\n gray: {\n root: \"bg-primary text-secondary ring-primary\",\n addon: \"text-gray-500\",\n addonButton: \"hover:bg-utility-gray-100 text-utility-gray-400 hover:text-utility-gray-500\",\n },\n },\n },\n};\n\nconst withBadgeTypes = {\n [badgeTypes.pillColor]: {\n common: \"size-max flex items-center whitespace-nowrap rounded-full ring-1 ring-inset\",\n styles: filledColors,\n },\n [badgeTypes.badgeColor]: {\n common: \"size-max flex items-center whitespace-nowrap rounded-md ring-1 ring-inset\",\n styles: filledColors,\n },\n [badgeTypes.badgeModern]: {\n common: \"size-max flex items-center whitespace-nowrap rounded-md ring-1 ring-inset bg-primary text-secondary ring-primary shadow-xs\",\n styles: addonOnlyColors,\n },\n};\n\nexport type BadgeColor<T extends BadgeTypes> = BadgeTypeToColorMap<typeof withPillTypes>[T];\n\ninterface BadgeProps<T extends BadgeTypes> {\n type?: T;\n size?: Sizes;\n color?: BadgeColor<T>;\n children: ReactNode;\n className?: string;\n}\n\nexport const Badge = <T extends BadgeTypes>(props: BadgeProps<T>) => {\n const { type = \"pill-color\", size = \"md\", color = \"gray\", children } = props;\n const colors = withPillTypes[type];\n\n const pillSizes = {\n sm: \"py-0.5 px-2 text-xs font-medium\",\n md: \"py-0.5 px-2.5 text-sm font-medium\",\n lg: \"py-1 px-3 text-sm font-medium\",\n };\n const badgeSizes = {\n sm: \"py-0.5 px-1.5 text-xs font-medium\",\n md: \"py-0.5 px-2 text-sm font-medium\",\n lg: \"py-1 px-2.5 text-sm font-medium rounded-lg\",\n };\n\n const sizes = {\n [badgeTypes.pillColor]: pillSizes,\n [badgeTypes.badgeColor]: badgeSizes,\n [badgeTypes.badgeModern]: badgeSizes,\n };\n\n return <span className={cx(colors.common, sizes[type][size], colors.styles[color].root, props.className)}>{children}</span>;\n};\n\ninterface BadgeWithDotProps<T extends BadgeTypes> {\n type?: T;\n size?: Sizes;\n color?: BadgeTypeToColorMap<typeof withBadgeTypes>[T];\n className?: string;\n children: ReactNode;\n}\n\nexport const BadgeWithDot = <T extends BadgeTypes>(props: BadgeWithDotProps<T>) => {\n const { size = \"md\", color = \"gray\", type = \"pill-color\", className, children } = props;\n\n const colors = withBadgeTypes[type];\n\n const pillSizes = {\n sm: \"gap-1 py-0.5 pl-1.5 pr-2 text-xs font-medium\",\n md: \"gap-1.5 py-0.5 pl-2 pr-2.5 text-sm font-medium\",\n lg: \"gap-1.5 py-1 pl-2.5 pr-3 text-sm font-medium\",\n };\n\n const badgeSizes = {\n sm: \"gap-1 py-0.5 px-1.5 text-xs font-medium\",\n md: \"gap-1.5 py-0.5 px-2 text-sm font-medium\",\n lg: \"gap-1.5 py-1 px-2.5 text-sm font-medium rounded-lg\",\n };\n\n const sizes = {\n [badgeTypes.pillColor]: pillSizes,\n [badgeTypes.badgeColor]: badgeSizes,\n [badgeTypes.badgeModern]: badgeSizes,\n };\n\n return (\n <span className={cx(colors.common, sizes[type][size], colors.styles[color].root, className)}>\n <Dot className={colors.styles[color].addon} size=\"sm\" />\n {children}\n </span>\n );\n};\n\ninterface BadgeWithIconProps<T extends BadgeTypes> {\n type?: T;\n size?: Sizes;\n color?: BadgeTypeToColorMap<typeof withBadgeTypes>[T];\n iconLeading?: IconComponentType;\n iconTrailing?: IconComponentType;\n children: ReactNode;\n className?: string;\n}\n\nexport const BadgeWithIcon = <T extends BadgeTypes>(props: BadgeWithIconProps<T>) => {\n const { size = \"md\", color = \"gray\", type = \"pill-color\", iconLeading: IconLeading, iconTrailing: IconTrailing, children, className } = props;\n\n const colors = withBadgeTypes[type];\n\n const icon = IconLeading ? \"leading\" : \"trailing\";\n\n const pillSizes = {\n sm: {\n trailing: \"gap-0.5 py-0.5 pl-2 pr-1.5 text-xs font-medium\",\n leading: \"gap-0.5 py-0.5 pr-2 pl-1.5 text-xs font-medium\",\n },\n md: {\n trailing: \"gap-1 py-0.5 pl-2.5 pr-2 text-sm font-medium\",\n leading: \"gap-1 py-0.5 pr-2.5 pl-2 text-sm font-medium\",\n },\n lg: {\n trailing: \"gap-1 py-1 pl-3 pr-2.5 text-sm font-medium\",\n leading: \"gap-1 py-1 pr-3 pl-2.5 text-sm font-medium\",\n },\n };\n const badgeSizes = {\n sm: {\n trailing: \"gap-0.5 py-0.5 pl-2 pr-1.5 text-xs font-medium\",\n leading: \"gap-0.5 py-0.5 pr-2 pl-1.5 text-xs font-medium\",\n },\n md: {\n trailing: \"gap-1 py-0.5 pl-2 pr-1.5 text-sm font-medium\",\n leading: \"gap-1 py-0.5 pr-2 pl-1.5 text-sm font-medium\",\n },\n lg: {\n trailing: \"gap-1 py-1 pl-2.5 pr-2 text-sm font-medium rounded-lg\",\n leading: \"gap-1 py-1 pr-2.5 pl-2 text-sm font-medium rounded-lg\",\n },\n };\n\n const sizes = {\n [badgeTypes.pillColor]: pillSizes,\n [badgeTypes.badgeColor]: badgeSizes,\n [badgeTypes.badgeModern]: badgeSizes,\n };\n\n return (\n <span className={cx(colors.common, sizes[type][size][icon], colors.styles[color].root, className)}>\n {IconLeading && <IconLeading className={cx(colors.styles[color].addon, \"size-3 stroke-3\")} />}\n {children}\n {IconTrailing && <IconTrailing className={cx(colors.styles[color].addon, \"size-3 stroke-3\")} />}\n </span>\n );\n};\n\ninterface BadgeWithFlagProps<T extends BadgeTypes> {\n type?: T;\n size?: Sizes;\n flag?: FlagTypes;\n color?: BadgeTypeToColorMap<typeof withPillTypes>[T];\n children: ReactNode;\n}\n\nexport const BadgeWithFlag = <T extends BadgeTypes>(props: BadgeWithFlagProps<T>) => {\n const { size = \"md\", color = \"gray\", flag = \"AU\", type = \"pill-color\", children } = props;\n\n const colors = withPillTypes[type];\n\n const pillSizes = {\n sm: \"gap-1 py-0.5 pl-0.75 pr-2 text-xs font-medium\",\n md: \"gap-1.5 py-0.5 pl-1 pr-2.5 text-sm font-medium\",\n lg: \"gap-1.5 py-1 pl-1.5 pr-3 text-sm font-medium\",\n };\n const badgeSizes = {\n sm: \"gap-1 py-0.5 pl-1 pr-1.5 text-xs font-medium\",\n md: \"gap-1.5 py-0.5 pl-1.5 pr-2 text-sm font-medium\",\n lg: \"gap-1.5 py-1 pl-2 pr-2.5 text-sm font-medium rounded-lg\",\n };\n\n const sizes = {\n [badgeTypes.pillColor]: pillSizes,\n [badgeTypes.badgeColor]: badgeSizes,\n [badgeTypes.badgeModern]: badgeSizes,\n };\n\n return (\n <span className={cx(colors.common, sizes[type][size], colors.styles[color].root)}>\n <Image src={`https://www.untitledui.com/images/flags/${flag}.svg`} className=\"size-4 max-w-none rounded-full\" alt={`${flag} flag`} width={16} height={16} />\n {children}\n </span>\n );\n};\n\ninterface BadgeWithImageProps<T extends BadgeTypes> {\n type?: T;\n size?: Sizes;\n imgSrc: string;\n color?: BadgeTypeToColorMap<typeof withPillTypes>[T];\n children: ReactNode;\n}\n\nexport const BadgeWithImage = <T extends BadgeTypes>(props: BadgeWithImageProps<T>) => {\n const { size = \"md\", color = \"gray\", type = \"pill-color\", imgSrc, children } = props;\n\n const colors = withPillTypes[type];\n\n const pillSizes = {\n sm: \"gap-1 py-0.5 pl-0.75 pr-2 text-xs font-medium\",\n md: \"gap-1.5 py-0.5 pl-1 pr-2.5 text-sm font-medium\",\n lg: \"gap-1.5 py-1 pl-1.5 pr-3 text-sm font-medium\",\n };\n const badgeSizes = {\n sm: \"gap-1 py-0.5 pl-1 pr-1.5 text-xs font-medium\",\n md: \"gap-1.5 py-0.5 pl-1.5 pr-2 text-sm font-medium\",\n lg: \"gap-1.5 py-1 pl-2 pr-2.5 text-sm font-medium rounded-lg\",\n };\n\n const sizes = {\n [badgeTypes.pillColor]: pillSizes,\n [badgeTypes.badgeColor]: badgeSizes,\n [badgeTypes.badgeModern]: badgeSizes,\n };\n\n return (\n <span className={cx(colors.common, sizes[type][size], colors.styles[color].root)}>\n <Image src={imgSrc} className=\"size-4 max-w-none rounded-full\" alt=\"Badge image\" width={16} height={16} />\n {children}\n </span>\n );\n};\n\ninterface BadgeWithButtonProps<T extends BadgeTypes> {\n type?: T;\n size?: Sizes;\n icon?: IconComponentType;\n color?: BadgeTypeToColorMap<typeof withPillTypes>[T];\n children: ReactNode;\n /**\n * The label for the button.\n */\n buttonLabel?: string;\n /**\n * The click event handler for the button.\n */\n onButtonClick?: MouseEventHandler<HTMLButtonElement>;\n}\n\nexport const BadgeWithButton = <T extends BadgeTypes>(props: BadgeWithButtonProps<T>) => {\n const { size = \"md\", color = \"gray\", type = \"pill-color\", icon: Icon = CloseX, buttonLabel, children } = props;\n\n const colors = withPillTypes[type];\n\n const pillSizes = {\n sm: \"gap-0.5 py-0.5 pl-2 pr-0.75 text-xs font-medium\",\n md: \"gap-0.5 py-0.5 pl-2.5 pr-1 text-sm font-medium\",\n lg: \"gap-0.5 py-1 pl-3 pr-1.5 text-sm font-medium\",\n };\n const badgeSizes = {\n sm: \"gap-0.5 py-0.5 pl-1.5 pr-0.75 text-xs font-medium\",\n md: \"gap-0.5 py-0.5 pl-2 pr-1 text-sm font-medium\",\n lg: \"gap-0.5 py-1 pl-2.5 pr-1.5 text-sm font-medium rounded-lg\",\n };\n\n const sizes = {\n [badgeTypes.pillColor]: pillSizes,\n [badgeTypes.badgeColor]: badgeSizes,\n [badgeTypes.badgeModern]: badgeSizes,\n };\n\n return (\n <span className={cx(colors.common, sizes[type][size], colors.styles[color].root)}>\n {children}\n <button\n type=\"button\"\n aria-label={buttonLabel}\n onClick={props.onButtonClick}\n className={cx(\n \"flex cursor-pointer items-center justify-center p-0.5 outline-focus-ring transition duration-100 ease-linear focus-visible:outline-2\",\n colors.styles[color].addonButton,\n type === \"pill-color\" ? \"rounded-full\" : \"rounded-[3px]\",\n )}\n >\n <Icon className=\"size-3 stroke-[3px] transition-inherit-all\" />\n </button>\n </span>\n );\n};\n\ninterface BadgeIconProps<T extends BadgeTypes> {\n type?: T;\n size?: Sizes;\n icon: IconComponentType;\n color?: BadgeTypeToColorMap<typeof withPillTypes>[T];\n children?: ReactNode;\n}\n\nexport const BadgeIcon = <T extends BadgeTypes>(props: BadgeIconProps<T>) => {\n const { size = \"md\", color = \"gray\", type = \"pill-color\", icon: Icon } = props;\n\n const colors = withPillTypes[type];\n\n const pillSizes = {\n sm: \"p-1.25\",\n md: \"p-1.5\",\n lg: \"p-2\",\n };\n\n const badgeSizes = {\n sm: \"p-1.25\",\n md: \"p-1.5\",\n lg: \"p-2 rounded-lg\",\n };\n\n const sizes = {\n [badgeTypes.pillColor]: pillSizes,\n [badgeTypes.badgeColor]: badgeSizes,\n [badgeTypes.badgeModern]: badgeSizes,\n };\n\n return (\n <span className={cx(colors.common, sizes[type][size], colors.styles[color].root)}>\n <Icon className={cx(\"size-3 stroke-[3px]\", colors.styles[color].addon)} />\n </span>\n );\n};\n","import type React from \"react\";\n\nexport type IconComponentType = React.FunctionComponent<{ className?: string; strokeWidth?: string | number }>;\n\nexport type Sizes = \"sm\" | \"md\" | \"lg\";\n\nexport type BadgeColors = \"gray\" | \"brand\" | \"error\" | \"warning\" | \"success\" | \"gray-blue\" | \"blue-light\" | \"blue\" | \"indigo\" | \"purple\" | \"pink\" | \"orange\";\n\nexport type FlagTypes =\n | \"AD\"\n | \"AE\"\n | \"AF\"\n | \"AG\"\n | \"AI\"\n | \"AL\"\n | \"AM\"\n | \"AO\"\n | \"AR\"\n | \"AS\"\n | \"AT\"\n | \"AU\"\n | \"AW\"\n | \"AX\"\n | \"AZ\"\n | \"BA\"\n | \"BB\"\n | \"BD\"\n | \"BE\"\n | \"BF\"\n | \"BG\"\n | \"BH\"\n | \"BI\"\n | \"BJ\"\n | \"BL\"\n | \"BM\"\n | \"BN\"\n | \"BO\"\n | \"BQ-1\"\n | \"BQ-2\"\n | \"BQ\"\n | \"BR\"\n | \"BS\"\n | \"BT\"\n | \"BW\"\n | \"BY\"\n | \"BZ\"\n | \"CA\"\n | \"CC\"\n | \"CD-1\"\n | \"CD\"\n | \"CF\"\n | \"CH\"\n | \"CK\"\n | \"CL\"\n | \"CM\"\n | \"CN\"\n | \"CO\"\n | \"CR\"\n | \"CU\"\n | \"CW\"\n | \"CX\"\n | \"CY\"\n | \"CZ\"\n | \"DE\"\n | \"DJ\"\n | \"DK\"\n | \"DM\"\n | \"DO\"\n | \"DS\"\n | \"DZ\"\n | \"earth\"\n | \"EC\"\n | \"EE\"\n | \"EG\"\n | \"EH\"\n | \"ER\"\n | \"ES\"\n | \"ET\"\n | \"FI\"\n | \"FJ\"\n | \"FK\"\n | \"FM\"\n | \"FO\"\n | \"FR\"\n | \"GA\"\n | \"GB-2\"\n | \"GB\"\n | \"GD\"\n | \"GE\"\n | \"GG\"\n | \"GH\"\n | \"GI\"\n | \"GL\"\n | \"GM\"\n | \"GN\"\n | \"GQ\"\n | \"GR\"\n | \"GT\"\n | \"GU\"\n | \"GW\"\n | \"GY\"\n | \"HK\"\n | \"HN\"\n | \"HR\"\n | \"HT\"\n | \"HU\"\n | \"ID\"\n | \"IE\"\n | \"IL\"\n | \"IM\"\n | \"IN\"\n | \"IO\"\n | \"IQ\"\n | \"IR\"\n | \"IS\"\n | \"IT\"\n | \"JE\"\n | \"JM\"\n | \"JO\"\n | \"JP\"\n | \"KE\"\n | \"KG\"\n | \"KH\"\n | \"KI\"\n | \"KM\"\n | \"KN\"\n | \"KP\"\n | \"KR\"\n | \"KW\"\n | \"KY\"\n | \"KZ\"\n | \"LA\"\n | \"LB\"\n | \"LC\"\n | \"LI\"\n | \"LK\"\n | \"LR\"\n | \"LS\"\n | \"LT\"\n | \"LU\"\n | \"LV\"\n | \"LY\"\n | \"MA\"\n | \"MC\"\n | \"MD\"\n | \"ME\"\n | \"MG\"\n | \"MH\"\n | \"MK\"\n | \"ML\"\n | \"MM\"\n | \"MN\"\n | \"MO\"\n | \"MP\"\n | \"MQ\"\n | \"MR\"\n | \"MS\"\n | \"MT\"\n | \"MU\"\n | \"MV\"\n | \"MW\"\n | \"MX\"\n | \"MY\"\n | \"MZ\"\n | \"NA\"\n | \"NE\"\n | \"NF\"\n | \"NG\"\n | \"NI\"\n | \"NL\"\n | \"NO\"\n | \"NP\"\n | \"NR\"\n | \"NU\"\n | \"NZ\"\n | \"OM\"\n | \"PA\"\n | \"PE\"\n | \"PF\"\n | \"PG\"\n | \"PH\"\n | \"PK\"\n | \"PL\"\n | \"PM\"\n | \"PN\"\n | \"PR\"\n | \"PT\"\n | \"PW\"\n | \"PY\"\n | \"QA\"\n | \"RE\"\n | \"RO\"\n | \"RS\"\n | \"RU\"\n | \"RW\"\n | \"SA\"\n | \"SB\"\n | \"SC\"\n | \"SD\"\n | \"SE\"\n | \"SG\"\n | \"SH\"\n | \"SI\"\n | \"SJ\"\n | \"SK\"\n | \"SL\"\n | \"SM\"\n | \"SN\"\n | \"SO\"\n | \"SR\"\n | \"SS\"\n | \"ST\"\n | \"SV\"\n | \"SX\"\n | \"SY\"\n | \"SZ\"\n | \"TC\"\n | \"TD\"\n | \"TF\"\n | \"TG\"\n | \"TH\"\n | \"TJ\"\n | \"TK\"\n | \"TL\"\n | \"TM\"\n | \"TN\"\n | \"TO\"\n | \"TR\"\n | \"TT\"\n | \"TV\"\n | \"TZ\"\n | \"UA\"\n | \"UG\"\n | \"UM\"\n | \"US\"\n | \"UY\"\n | \"UZ\"\n | \"VA\"\n | \"VC\"\n | \"VE\"\n | \"VG\"\n | \"VI\"\n | \"VN\"\n | \"VU\"\n | \"WF\"\n | \"WS\"\n | \"YE\"\n | \"YT\"\n | \"ZA\"\n | \"ZM\"\n | \"ZW\";\n\nexport type ExtractColorKeys<T> = T extends { styles: infer C } ? keyof C : never;\nexport type ExtractBadgeKeys<T> = keyof T;\nexport type BadgeTypeToColorMap<T> = {\n [K in ExtractBadgeKeys<T>]: ExtractColorKeys<T[K]>;\n};\nexport type BadgeTypeColors<T> = ExtractColorKeys<T[keyof T]>;\n\nexport const badgeTypes = {\n pillColor: \"pill-color\",\n badgeColor: \"color\",\n badgeModern: \"modern\",\n} as const;\n\nexport type BadgeTypes = (typeof badgeTypes)[keyof typeof badgeTypes];\n","\"use client\";\n\nimport type { FC, ReactNode } from \"react\";\nimport { createElement, isValidElement } from \"react\";\nimport { ArrowRight } from \"@untitledui/icons\";\nimport { cx, sortCx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\n\ntype Size = \"md\" | \"lg\";\ntype Color = \"brand\" | \"warning\" | \"error\" | \"gray\" | \"success\";\ntype Theme = \"light\" | \"modern\";\ntype Align = \"leading\" | \"trailing\";\n\nconst baseClasses: Record<Theme, { root?: string; addon?: string; icon?: string }> = {\n light: {\n root: \"rounded-full ring-1 ring-inset\",\n addon: \"rounded-full ring-1 ring-inset\",\n },\n modern: {\n root: \"rounded-[10px] bg-primary text-secondary shadow-xs ring-1 ring-inset ring-primary hover:bg-secondary\",\n addon: \"flex items-center rounded-md bg-primary shadow-xs ring-1 ring-inset ring-primary\",\n icon: \"text-utility-gray-500\",\n },\n};\n\nconst getSizeClasses = (\n theme?: Theme,\n text?: boolean,\n icon?: boolean,\n): Record<Align, Record<Size, { root?: string; addon?: string; icon?: string; dot?: string }>> => ({\n leading: {\n md: {\n root: cx(\"py-1 pr-2 pl-1 text-xs font-medium\", !text && !icon && \"pr-1\"),\n addon: cx(\"px-2 py-0.5\", theme === \"modern\" && \"gap-1 px-1.5\", text && \"mr-2\"),\n icon: \"ml-1 size-4\",\n },\n lg: {\n root: cx(\"py-1 pr-2 pl-1 text-sm font-medium\", !text && !icon && \"pr-1\"),\n addon: cx(\"px-2.5 py-0.5\", theme === \"modern\" && \"gap-1.5 px-2\", text && \"mr-2\"),\n icon: \"ml-1 size-4\",\n },\n },\n trailing: {\n md: {\n root: cx(\"py-1 pr-1 pl-3 text-xs font-medium\", theme === \"modern\" && \"pl-2.5\"),\n addon: cx(\"py-0.5 pr-1.5 pl-2\", theme === \"modern\" && \"pr-1.5 pl-2\", text && \"ml-2\"),\n icon: \"ml-0.5 size-3 stroke-[3px]\",\n dot: \"mr-1.5\",\n },\n lg: {\n root: \"py-1 pr-1 pl-3 text-sm font-medium\",\n addon: cx(\"py-0.5 pr-2 pl-2.5\", theme === \"modern\" && \"pr-1.5 pl-2\", text && \"ml-2\"),\n icon: \"ml-1 size-3 stroke-[3px]\",\n dot: \"mr-2\",\n },\n },\n});\n\nconst colorClasses: Record<Theme, Record<Color, { root?: string; addon?: string; icon?: string; dot?: string }>> = sortCx({\n light: {\n brand: {\n root: \"bg-utility-brand-50 text-utility-brand-700 ring-utility-brand-200 hover:bg-utility-brand-100\",\n addon: \"bg-primary text-current ring-utility-brand-200\",\n icon: \"text-utility-brand-500\",\n },\n gray: {\n root: \"bg-utility-gray-50 text-utility-gray-700 ring-utility-gray-200 hover:bg-utility-gray-100\",\n addon: \"bg-primary text-current ring-utility-gray-200\",\n icon: \"text-utility-gray-500\",\n },\n error: {\n root: \"bg-utility-error-50 text-utility-error-700 ring-utility-error-200 hover:bg-utility-error-100\",\n addon: \"bg-primary text-current ring-utility-error-200\",\n icon: \"text-utility-error-500\",\n },\n warning: {\n root: \"bg-utility-warning-50 text-utility-warning-700 ring-utility-warning-200 hover:bg-utility-warning-100\",\n addon: \"bg-primary text-current ring-utility-warning-200\",\n icon: \"text-utility-warning-500\",\n },\n success: {\n root: \"bg-utility-success-50 text-utility-success-700 ring-utility-success-200 hover:bg-utility-success-100\",\n addon: \"bg-primary text-current ring-utility-success-200\",\n icon: \"text-utility-success-500\",\n },\n },\n modern: {\n brand: {\n dot: \"bg-utility-brand-500 outline-3 -outline-offset-1 outline-utility-brand-100\",\n },\n gray: {\n dot: \"bg-utility-gray-500 outline-3 -outline-offset-1 outline-utility-gray-100\",\n },\n error: {\n dot: \"bg-utility-error-500 outline-3 -outline-offset-1 outline-utility-error-100\",\n },\n warning: {\n dot: \"bg-utility-warning-500 outline-3 -outline-offset-1 outline-utility-warning-100\",\n },\n success: {\n dot: \"bg-utility-success-500 outline-3 -outline-offset-1 outline-utility-success-100\",\n },\n },\n});\n\ninterface BadgeGroupProps {\n children?: string | ReactNode;\n addonText: string;\n size?: Size;\n color: Color;\n theme?: Theme;\n /**\n * Alignment of the badge addon element.\n */\n align?: Align;\n iconTrailing?: FC<{ className?: string }> | ReactNode;\n className?: string;\n}\n\nexport const BadgeGroup = ({\n children,\n addonText,\n size = \"md\",\n color = \"brand\",\n theme = \"light\",\n align = \"leading\",\n className,\n iconTrailing: IconTrailing = ArrowRight,\n}: BadgeGroupProps) => {\n const colors = colorClasses[theme][color];\n const sizes = getSizeClasses(theme, !!children, !!IconTrailing)[align][size];\n\n const rootClasses = cx(\n \"inline-flex w-max cursor-pointer items-center transition duration-100 ease-linear\",\n baseClasses[theme].root,\n sizes.root,\n colors.root,\n className,\n );\n const addonClasses = cx(\"inline-flex items-center\", baseClasses[theme].addon, sizes.addon, colors.addon);\n const dotClasses = cx(\"inline-block size-2 shrink-0 rounded-full\", sizes.dot, colors.dot);\n const iconClasses = cx(baseClasses[theme].icon, sizes.icon, colors.icon);\n\n if (align === \"trailing\") {\n return (\n <div className={rootClasses}>\n {theme === \"modern\" && <span className={dotClasses} />}\n\n {children}\n\n <span className={addonClasses}>\n {addonText}\n\n {/* Trailing icon */}\n {isReactComponent(IconTrailing) && createElement(IconTrailing, { className: iconClasses } as Record<string, unknown>)}\n {isValidElement(IconTrailing) && IconTrailing}\n </span>\n </div>\n );\n }\n\n return (\n <div className={rootClasses}>\n <span className={addonClasses}>\n {theme === \"modern\" && <span className={dotClasses} />}\n {addonText}\n </span>\n\n {children}\n\n {/* Trailing icon */}\n {isReactComponent(IconTrailing) && createElement(IconTrailing, { className: iconClasses } as Record<string, unknown>)}\n {isValidElement(IconTrailing) && IconTrailing}\n </div>\n );\n};\n","\"use client\";\n\nimport type { HTMLAttributes, SVGProps } from \"react\";\nimport { useId } from \"react\";\nimport { cx } from '../../../utils/cx';\n\nexport const getStarProgress = (starPosition: number, rating: number, maxRating: number = 5) => {\n // Ensure rating is between 0 and 5\n const clampedRating = Math.min(Math.max(rating, 0), maxRating);\n\n const diff = clampedRating - starPosition;\n\n if (diff >= 1) return 100;\n if (diff <= 0) return 0;\n\n return Math.round(diff * 100);\n};\n\ninterface StarIconProps extends SVGProps<SVGSVGElement> {\n /**\n * The progress of the star icon. It should be a number between 0 and 100.\n *\n * @default 100\n */\n progress?: number;\n}\n\nexport const StarIcon = ({ progress = 100, ...props }: StarIconProps) => {\n const id = useId();\n\n return (\n <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" {...props} className={cx(\"size-5 text-warning-400\", props.className)}>\n <path\n d=\"M9.53834 1.60996C9.70914 1.19932 10.2909 1.19932 10.4617 1.60996L12.5278 6.57744C12.5998 6.75056 12.7626 6.86885 12.9495 6.88383L18.3123 7.31376C18.7556 7.3493 18.9354 7.90256 18.5976 8.19189L14.5117 11.6919C14.3693 11.8139 14.3071 12.0053 14.3506 12.1876L15.5989 17.4208C15.7021 17.8534 15.2315 18.1954 14.8519 17.9635L10.2606 15.1592C10.1006 15.0615 9.89938 15.0615 9.73937 15.1592L5.14806 17.9635C4.76851 18.1954 4.29788 17.8534 4.40108 17.4208L5.64939 12.1876C5.69289 12.0053 5.6307 11.8139 5.48831 11.6919L1.40241 8.19189C1.06464 7.90256 1.24441 7.3493 1.68773 7.31376L7.05054 6.88383C7.23744 6.86885 7.40024 6.75056 7.47225 6.57744L9.53834 1.60996Z\"\n className=\"fill-bg-tertiary\"\n />\n <g clipPath={`url(#clip-${id})`}>\n <path\n d=\"M9.53834 1.60996C9.70914 1.19932 10.2909 1.19932 10.4617 1.60996L12.5278 6.57744C12.5998 6.75056 12.7626 6.86885 12.9495 6.88383L18.3123 7.31376C18.7556 7.3493 18.9354 7.90256 18.5976 8.19189L14.5117 11.6919C14.3693 11.8139 14.3071 12.0053 14.3506 12.1876L15.5989 17.4208C15.7021 17.8534 15.2315 18.1954 14.8519 17.9635L10.2606 15.1592C10.1006 15.0615 9.89938 15.0615 9.73937 15.1592L5.14806 17.9635C4.76851 18.1954 4.29788 17.8534 4.40108 17.4208L5.64939 12.1876C5.69289 12.0053 5.6307 11.8139 5.48831 11.6919L1.40241 8.19189C1.06464 7.90256 1.24441 7.3493 1.68773 7.31376L7.05054 6.88383C7.23744 6.86885 7.40024 6.75056 7.47225 6.57744L9.53834 1.60996Z\"\n fill=\"currentColor\"\n />\n </g>\n <defs>\n <clipPath id={`clip-${id}`}>\n <rect width={`${progress}%`} height=\"20\" fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n );\n};\n\ninterface RatingStarsProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * The rating to display.\n *\n * @default 5\n */\n rating?: number;\n /**\n * The number of stars to display.\n */\n stars?: number;\n /**\n * The class name of the star icon.\n */\n starClassName?: string;\n}\n\nexport const RatingStars = ({ rating = 5, stars = 5, starClassName, ...props }: RatingStarsProps) => {\n return (\n <div {...props} className={cx(\"flex\", props.className)}>\n {Array.from({ length: stars }).map((_, index) => (\n <StarIcon key={index} progress={getStarProgress(index, rating, stars)} className={starClassName} />\n ))}\n </div>\n );\n};\n","\"use client\";\n\nimport { type HTMLAttributes } from \"react\";\nimport { RatingStars } from './rating-stars';\nimport { cx } from '../../../utils/cx';\n\nexport const Wreath = (props: HTMLAttributes<HTMLOrSVGElement>) => (\n <svg width=\"36\" height=\"81\" viewBox=\"0 0 36 81\" fill=\"none\" {...props} className={cx(\"text-fg-primary\", props.className)}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M34.188 79.123C21.8844 77.4193 12.9273 67.7396 8.84084 54.5087C7.16207 49.0327 6.91909 42.9593 7.50445 36.6094C8.58681 25.2702 13.7888 15.4245 21.3764 8.24482C21.4095 8.21163 21.4206 8.20057 21.4316 8.23376C21.4537 8.26695 21.52 8.30013 21.5531 8.32226C21.5973 8.34439 21.6083 8.32226 21.5752 8.37757C13.5237 15.7563 8.35488 27.4938 7.79161 39.3529C6.91909 56.2898 15.1362 71.2907 27.4509 76.4569C29.5162 77.3308 31.6809 77.9946 33.934 78.3375C34.0886 78.5367 34.177 78.8132 34.188 79.123Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M3.51737 50.8359C4.52243 52.0306 6.12388 53.2033 7.84683 52.7497C7.93518 52.8825 8.38801 53.5462 8.45428 53.6458C8.53159 53.7675 8.67517 53.8892 8.78561 53.7896C8.85188 53.7453 8.9071 53.6458 8.84084 53.4909C8.58681 53.1812 8.34383 52.8603 8.05667 52.5285C7.54863 49.8402 6.80864 48.0481 5.26241 46.2338C3.4732 44.1541 1.6398 43.2248 0.502216 42.8376C0.336548 42.7934 0.181926 42.7491 0.0162576 42.6938C-0.0941877 43.7337 0.380727 45.2493 0.756241 46.1121C1.48518 47.8822 2.28039 49.4309 3.51737 50.8359Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M18.317 12.9686C18.1735 13.0239 17.3341 13.2451 17.2347 13.0792C17.2015 13.0349 17.2457 12.869 17.323 12.8579C17.6323 12.8247 17.9747 12.8026 18.2729 12.7362C18.814 11.0326 20.3161 10.2914 21.6967 10.0038C23.3533 9.6719 25.1757 10.1808 27.1306 10.4573C27.23 10.4795 27.3404 10.4905 27.4288 10.4905C27.3956 10.5569 27.3515 10.6012 27.3073 10.6675C26.49 11.7849 25.2088 12.8137 23.9608 13.3226C23.1214 13.6766 22.1164 13.8757 21.1334 13.8425C20.0952 13.7983 19.2227 13.5659 18.317 12.9686Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M21.5531 8.3112C21.6194 8.33332 21.6194 8.3112 21.7408 8.24482C21.9728 8.02357 22.1716 7.89082 22.4035 7.68063C23.7289 7.69169 24.9879 7.29344 26.1807 6.49693C26.7109 6.14293 27.241 5.71148 27.6828 5.19154C28.7431 4.05209 29.5935 2.38164 29.9801 0.854996C30.0022 0.766495 30.0132 0.711182 30.0242 0.622681C29.9248 0.666931 29.8365 0.711183 29.7371 0.755433C27.5945 1.61832 25.5181 2.01657 23.7951 3.68703C22.6244 4.80435 22.017 6.15399 22.2599 7.45938C21.9949 7.66957 21.7188 7.86869 21.4647 8.11207C21.3543 8.21163 21.4868 8.3112 21.5531 8.3112Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.7557 20.1039C13.6121 20.1814 12.8058 20.6018 12.6843 20.4579C12.6291 20.4026 12.6512 20.2256 12.7285 20.1924C13.0267 20.0818 13.3801 20.0044 13.6783 19.8716C13.7888 18.6658 14.4625 17.5374 15.7989 16.763C17.8421 15.6789 20.1615 15.8559 22.3483 15.6678C22.4587 15.6568 22.5581 15.6568 22.6575 15.6457C22.6244 15.7121 22.5913 15.7674 22.5692 15.8338C21.8402 17.0949 20.6585 18.4556 19.4546 19.23C18.6484 19.7721 17.6544 20.1814 16.6604 20.3805C15.6111 20.5907 14.7165 20.469 13.7557 20.1039Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M3.0535 38.7113C3.71618 40.2047 4.90898 41.842 6.65402 41.9526C6.70924 42.1075 7.02953 42.8266 7.07371 42.9372C7.10685 43.0921 7.21729 43.258 7.36087 43.1916C7.42714 43.1695 7.4934 43.081 7.48236 42.9261C7.31669 42.5279 7.10685 42.2181 6.90804 41.8088C7.06267 39.0653 6.90804 37.0629 5.85881 34.8062C4.666 32.2064 3.03141 30.713 2.02636 29.9829C1.90487 29.8722 1.76129 29.7837 1.61771 29.6952C1.38578 30.7572 1.46309 32.4056 1.60667 33.357C1.86069 35.2818 2.26934 36.9744 3.0535 38.7113Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M5.00838 27.6929C5.29554 29.2859 6.01344 30.89 7.60385 31.5869C7.62594 31.7529 7.80265 32.5273 7.82474 32.6489C7.82474 32.8149 7.87996 33.0029 8.03458 32.9808C8.07876 32.9698 8.18921 32.9255 8.20025 32.7596C8.13399 32.3392 8.0125 31.8635 7.93519 31.4099C8.46532 29.474 8.75248 27.704 8.66412 25.8123C8.52054 23.1462 7.52654 20.8341 5.95821 18.9756C5.83672 18.8428 5.74837 18.699 5.63792 18.5773C5.19614 19.4955 4.90898 21.0664 4.83167 22.0067C4.666 23.9095 4.67705 25.8233 5.00838 27.6929Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M9.01755 17.637C8.97337 19.2742 9.37097 21.1106 10.7405 22.1727C10.7295 22.3386 10.6963 23.1351 10.6963 23.2457C10.6742 23.4006 10.6853 23.5887 10.8399 23.6219C10.8951 23.6219 10.9945 23.6108 11.0277 23.4559C11.0608 23.0466 11.0718 22.416 11.0939 21.9625C12.2646 19.9712 12.8942 17.8029 12.9163 15.3249C12.9604 12.4597 12.2536 10.6343 11.6903 9.48383C11.613 9.32896 11.5357 9.17408 11.4584 9.01921C10.8399 9.77146 10.2545 11.2096 9.98947 12.0946C9.45933 13.8868 9.07277 15.7563 9.01755 17.637Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M15.092 8.45501C14.7386 9.99271 14.838 12.2495 15.9867 13.1787C15.9425 13.3779 15.8431 14.0638 15.832 14.2186C15.7878 14.3846 15.7547 14.5394 15.8872 14.6058C15.9425 14.6279 15.9866 14.628 16.0529 14.4841C16.1302 14.0527 16.1523 13.6987 16.2186 13.2562C17.8532 11.5083 18.7809 9.78252 19.3 7.42619C19.8191 4.95923 19.7418 3.00114 19.5209 1.61832C19.4988 1.45238 19.4546 1.28644 19.4105 1.10944C17.9747 2.25995 16.9586 3.77553 16.0971 5.50129C15.6332 6.44162 15.2688 7.40406 15.092 8.45501Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M10.0889 29.5182C9.95633 29.6399 9.22739 30.3369 9.05068 30.2484C9.0065 30.2041 8.97337 29.9718 9.05068 29.9275C9.32679 29.7063 9.68022 29.5404 9.95633 29.3302C9.86798 28.0026 10.1662 26.653 11.37 25.3919C13.2255 23.5887 15.6884 22.9802 17.9305 22.051C18.0299 22.0067 18.1293 21.9514 18.2508 21.9071C18.2287 21.9846 18.2176 22.0731 18.1845 22.1505C17.7427 23.6993 16.8592 25.5025 15.7878 26.7194C15.092 27.538 14.1533 28.3235 13.1703 28.8434C12.1432 29.3965 11.1712 29.5735 10.0889 29.5182Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M8.54263 40.3264C8.44323 40.5034 7.85787 41.4548 7.67012 41.4105C7.5928 41.4105 7.51549 41.1782 7.57072 41.0897C7.81369 40.7689 8.12294 40.5145 8.33279 40.1826C7.95727 38.9657 8.13399 37.2067 9.03964 35.5252C10.4754 33.0693 12.5739 31.8746 14.6061 30.1599C14.6944 30.0714 14.7828 29.9939 14.8822 29.8944C14.8932 29.9718 14.9043 30.0603 14.8932 30.1599C14.8491 31.8414 14.4073 33.9543 13.6231 35.5474C13.1151 36.6204 12.364 37.6935 11.5026 38.5896C10.608 39.4856 9.65813 40.0056 8.54263 40.3264Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M9.55873 50.9244C9.48142 51.1346 9.08382 52.263 8.88501 52.3072C8.81875 52.2961 8.68621 52.1302 8.74144 52.0085C8.90711 51.6324 9.09486 51.2009 9.24948 50.8138C8.56472 50.1611 8.33279 48.3468 8.88501 46.444C9.80171 43.6562 11.8449 41.5654 13.4906 39.2533C13.5679 39.1427 13.6452 39.0321 13.7225 38.9214C13.7446 38.9989 13.7557 39.0874 13.7777 39.1759C14.0649 40.8021 14.0428 42.9593 13.601 44.7183C13.3028 45.8909 12.7837 47.1852 12.11 48.2915C11.4142 49.4641 10.5859 50.2717 9.55873 50.9244Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M7.0958 63.3256C8.34383 64.1442 10.5748 64.7637 12.11 63.757C12.2315 63.8455 12.8721 64.2327 12.9494 64.2991C13.0598 64.4097 13.2145 64.4871 13.3139 64.3323C13.3691 64.2659 13.4022 64.1553 13.2918 64.0336C12.9715 63.8123 12.6181 63.6685 12.2757 63.4473C11.105 61.0135 9.84589 59.3652 7.9131 58.1483C5.70419 56.7323 3.85975 56.7101 2.67799 56.7101C2.51232 56.7101 2.34665 56.7212 2.18098 56.7212C2.46814 59.1218 5.43912 62.2968 7.0958 63.3256Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.2255 61.4449C13.2145 61.5998 13.1372 62.2857 13.0267 62.7061C12.9936 62.8277 12.9825 63.0048 12.8169 62.9384C12.7506 62.9273 12.6843 62.7835 12.6843 62.7171C12.7616 62.3078 12.8279 61.8432 12.861 61.4339C12.099 60.9471 11.5026 59.3541 11.3811 57.396C11.5136 54.4423 12.839 51.7651 13.8992 48.9774C13.9324 48.8557 13.9765 48.7229 14.0207 48.5902C14.0649 48.6565 14.087 48.7229 14.1312 48.7893C14.838 50.2496 15.3792 52.2962 15.4234 54.1436C15.4676 55.3494 15.2908 56.7544 14.9374 58.0598C14.5619 59.3983 14.0097 60.4493 13.2255 61.4449Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.8551 73.4257C15.2908 73.7134 17.2347 73.647 18.4496 72.0982C18.7588 72.1425 19.2558 72.2199 19.5761 72.242C19.6645 72.2531 19.7307 72.1867 19.7639 72.0761C19.786 71.9987 19.7639 71.8991 19.6203 71.8217C19.2558 71.7442 18.8914 71.7442 18.5048 71.6778C16.8923 69.7861 15.3682 68.7241 13.1703 68.3259C10.6301 67.8612 8.47637 68.5139 7.32774 68.9896C7.17311 69.0449 7.00744 69.1113 6.86387 69.1888C7.27251 70.1069 8.46532 71.0473 9.21635 71.5008C10.6521 72.4522 12.1211 73.1381 13.8551 73.4257Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M18.9908 69.4321C19.0128 69.5981 19.0349 70.2618 19.0349 70.7043C19.0239 70.826 19.057 70.992 18.8914 71.003C18.814 71.003 18.7257 70.9035 18.7257 70.826C18.6926 70.4167 18.7146 69.9742 18.6484 69.5538C17.798 69.2883 16.6714 67.994 16.1523 66.2129C15.5559 63.3588 16.2075 60.4161 16.5168 57.396C16.5389 57.2633 16.5278 57.1305 16.5389 56.9867C16.5941 57.042 16.6604 57.0973 16.7156 57.1526C17.7538 58.2921 18.792 60.051 19.289 61.7768C19.6313 62.9052 19.8081 64.2991 19.8081 65.6376C19.786 67.0426 19.4988 68.2263 18.9908 69.4321Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M27.0312 75.24C27.1085 75.3617 27.2079 75.9148 27.3183 76.3352C27.3515 76.4348 27.4177 76.5896 27.2631 76.645C27.1858 76.6781 27.0864 76.6118 27.0643 76.5454C26.9207 76.1914 26.9207 75.8153 26.744 75.4613C25.9157 75.6604 24.4799 74.6094 23.5411 73.2377C22.2379 70.8703 22.0943 68.0936 21.5862 65.2726C21.5752 65.1398 21.531 65.0182 21.5089 64.8854C21.5752 64.8965 21.6414 64.9407 21.7077 64.9628C22.9557 65.5934 24.3805 66.7107 25.2972 68.0825C25.9267 68.9675 26.5121 70.1955 26.8434 71.4234C27.1858 72.7177 27.1968 73.9457 27.0312 75.24Z\"\n fill=\"currentColor\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M22.514 80.5058C23.9829 80.3067 25.8825 79.6319 26.7219 77.7512C27.0201 77.6627 27.5392 77.6074 27.8485 77.5189C27.9368 77.5078 27.981 77.4083 27.9921 77.2866C27.9921 77.2202 27.9479 77.1207 27.7933 77.0985C27.4288 77.1538 27.0643 77.2645 26.6557 77.3087C24.5241 76.0476 22.8011 75.4723 20.5591 75.7931C17.9857 76.1582 16.1081 77.4525 15.1031 78.2822C14.9595 78.4039 14.8159 78.5145 14.6834 78.6362C15.3019 79.3996 16.6935 79.9084 17.5218 80.1297C19.1454 80.5833 20.7358 80.7603 22.514 80.5058Z\"\n fill=\"currentColor\"\n />\n </svg>\n);\n\ninterface RatingBadgeProps extends HTMLAttributes<HTMLDivElement> {\n title?: string;\n subtitle?: string;\n rating?: number;\n theme?: \"light\" | \"dark\";\n}\n\nexport const RatingBadge = ({ title = \"Best Design Tool\", subtitle = \"2,000+ reviews\", rating, theme = \"dark\", className, ...props }: RatingBadgeProps) => {\n return (\n <div {...props} className={cx(\"flex items-center -space-x-0.5\", className)}>\n <Wreath className={cx(\"shrink-0\", theme === \"light\" && \"text-fg-white\")} />\n\n <div className=\"flex flex-col items-center gap-1\">\n <RatingStars rating={rating} className=\"gap-0.5\" starClassName=\"size-4\" />\n\n <div className=\"text-center\">\n <p className={cx(\"text-sm font-semibold\", theme === \"light\" ? \"text-primary_on-brand\" : \"text-primary\")}>{title}</p>\n <p className={cx(\"text-xs font-medium\", theme === \"light\" ? \"text-secondary_on-brand\" : \"text-secondary\")}>{subtitle}</p>\n </div>\n </div>\n\n <Wreath className={cx(\"shrink-0 -scale-x-100\", theme === \"light\" && \"text-fg-white\")} />\n </div>\n );\n};\n","\"use client\";\n\nimport { type ReactNode } from \"react\";\nimport { cx } from '../../../utils/cx';\nimport { Avatar, type AvatarProps } from \"./avatar\";\n\nconst styles = {\n sm: { root: \"gap-2\", title: \"text-sm font-semibold\", subtitle: \"text-xs\" },\n md: { root: \"gap-2\", title: \"text-sm font-semibold\", subtitle: \"text-sm\" },\n lg: { root: \"gap-3\", title: \"text-md font-semibold\", subtitle: \"text-md\" },\n xl: { root: \"gap-4\", title: \"text-lg font-semibold\", subtitle: \"text-md\" },\n};\n\ninterface AvatarLabelGroupProps extends AvatarProps {\n size: \"sm\" | \"md\" | \"lg\" | \"xl\";\n title: string | ReactNode;\n subtitle: string | ReactNode;\n}\n\nexport const AvatarLabelGroup = ({ title, subtitle, className, ...props }: AvatarLabelGroupProps) => {\n return (\n <figure className={cx(\"group flex min-w-0 flex-1 items-center\", styles[props.size].root, className)}>\n <Avatar {...props} />\n <figcaption className=\"min-w-0 flex-1\">\n <p className={cx(\"text-primary\", styles[props.size].title)}>{title}</p>\n <p className={cx(\"truncate text-tertiary\", styles[props.size].subtitle)}>{subtitle}</p>\n </figcaption>\n </figure>\n );\n};\n","\"use client\";\n\nimport { ChevronLeft } from \"@untitledui/icons\";\nimport { Button } from '../buttons/button';\n\ninterface BreadcrumbProps {\n backHref: string;\n backLabel: string;\n currentLabel: string;\n}\n\nexport const Breadcrumb = ({ backHref, backLabel, currentLabel }: BreadcrumbProps) => {\n return (\n <nav className=\"mb-8\" aria-label=\"Breadcrumb\">\n <div className=\"flex items-center gap-2\">\n <Button \n color=\"link-gray\" \n size=\"md\" \n href={backHref}\n iconLeading={ChevronLeft}\n className=\"text-tertiary hover:text-primary\"\n >\n {backLabel}\n </Button>\n <span className=\"text-tertiary\">/</span>\n <span className=\"text-primary font-medium\">{currentLabel}</span>\n </div>\n </nav>\n );\n};\n\nexport default Breadcrumb;\n\n","import type { FC, ReactNode, Ref } from \"react\";\nimport { createElement, isValidElement } from \"react\";\nimport { cx, sortCx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\n\nconst iconsSizes = {\n sm: \"*:data-icon:size-4\",\n md: \"*:data-icon:size-5\",\n lg: \"*:data-icon:size-6\",\n xl: \"*:data-icon:size-7\",\n};\n\nconst styles = sortCx({\n light: {\n base: \"rounded-full\",\n sizes: {\n sm: \"size-8\",\n md: \"size-10\",\n lg: \"size-12\",\n xl: \"size-14\",\n },\n colors: {\n brand: \"bg-brand-secondary text-featured-icon-light-fg-brand\",\n gray: \"bg-tertiary text-featured-icon-light-fg-gray\",\n error: \"bg-error-secondary text-featured-icon-light-fg-error\",\n warning: \"bg-warning-secondary text-featured-icon-light-fg-warning\",\n success: \"bg-success-secondary text-featured-icon-light-fg-success\",\n },\n },\n\n gradient: {\n base: \"rounded-full text-fg-white before:absolute before:inset-0 before:size-full before:rounded-full before:border before:mask-b-from-0% after:absolute after:block after:rounded-full\",\n sizes: {\n sm: \"size-8 after:size-6 *:data-icon:size-4\",\n md: \"size-10 after:size-7 *:data-icon:size-4\",\n lg: \"size-12 after:size-8 *:data-icon:size-5\",\n xl: \"size-14 after:size-10 *:data-icon:size-5\",\n },\n colors: {\n brand: \"before:border-utility-brand-200 before:bg-utility-brand-50 after:bg-brand-solid\",\n gray: \"before:border-utility-gray-200 before:bg-utility-gray-50 after:bg-secondary-solid\",\n error: \"before:border-utility-error-200 before:bg-utility-error-50 after:bg-error-solid\",\n warning: \"before:border-utility-warning-200 before:bg-utility-warning-50 after:bg-warning-solid\",\n success: \"before:border-utility-success-200 before:bg-utility-success-50 after:bg-success-solid\",\n },\n },\n\n dark: {\n base: \"text-fg-white shadow-xs-skeumorphic before:absolute before:inset-px before:border before:border-white/12 before:mask-b-from-0%\",\n sizes: {\n sm: \"size-8 rounded-md before:rounded-[5px]\",\n md: \"size-10 rounded-lg before:rounded-[7px]\",\n lg: \"size-12 rounded-[10px] before:rounded-[9px]\",\n xl: \"size-14 rounded-xl before:rounded-[11px]\",\n },\n colors: {\n brand: \"bg-brand-solid before:border-utility-brand-200/12\",\n gray: \"bg-secondary-solid before:border-utility-gray-200/12\",\n error: \"bg-error-solid before:border-utility-error-200/12\",\n warning: \"bg-warning-solid before:border-utility-warning-200/12\",\n success: \"bg-success-solid before:border-utility-success-200/12\",\n },\n },\n\n modern: {\n base: \"bg-primary shadow-xs-skeumorphic ring-1 ring-inset\",\n sizes: {\n sm: \"size-8 rounded-md\",\n md: \"size-10 rounded-lg\",\n lg: \"size-12 rounded-[10px]\",\n xl: \"size-14 rounded-xl\",\n },\n colors: {\n brand: \"\",\n gray: \"text-fg-secondary ring-primary\",\n error: \"\",\n warning: \"\",\n success: \"\",\n },\n },\n \"modern-neue\": {\n base: [\n \"bg-primary_alt ring-1 ring-inset before:absolute before:inset-1\",\n // Shadow\n \"before:shadow-[0px_1px_2px_0px_rgba(0,0,0,0.1),0px_3px_3px_0px_rgba(0,0,0,0.09),1px_8px_5px_0px_rgba(0,0,0,0.05),2px_21px_6px_0px_rgba(0,0,0,0),0px_0px_0px_1px_rgba(0,0,0,0.08),1px_13px_5px_0px_rgba(0,0,0,0.01),0px_-2px_2px_0px_rgba(0,0,0,0.13)_inset] before:ring-1 before:ring-secondary_alt\",\n ].join(\" \"),\n sizes: {\n sm: \"size-8 rounded-[8px] before:rounded-[4px]\",\n md: \"size-10 rounded-[10px] before:rounded-[6px]\",\n lg: \"size-12 rounded-[12px] before:rounded-[8px]\",\n xl: \"size-14 rounded-[14px] before:rounded-[10px]\",\n },\n colors: {\n brand: \"\",\n gray: \"text-fg-secondary ring-primary\",\n error: \"\",\n warning: \"\",\n success: \"\",\n },\n },\n\n outline: {\n base: \"before:absolute before:rounded-full before:border-2 after:absolute after:rounded-full after:border-2\",\n sizes: {\n sm: \"size-4 before:size-6 after:size-8.5\",\n md: \"size-5 before:size-7 after:size-9.5\",\n lg: \"size-6 before:size-8 after:size-10.5\",\n xl: \"size-7 before:size-9 after:size-11.5\",\n },\n colors: {\n brand: \"text-fg-brand-primary before:border-fg-brand-primary/30 after:border-fg-brand-primary/10\",\n gray: \"text-fg-tertiary before:border-fg-tertiary/30 after:border-fg-tertiary/10\",\n error: \"text-fg-error-primary before:border-fg-error-primary/30 after:border-fg-error-primary/10\",\n warning: \"text-fg-warning-primary before:border-fg-warning-primary/30 after:border-fg-warning-primary/10\",\n success: \"text-fg-success-primary before:border-fg-success-primary/30 after:border-fg-success-primary/10\",\n },\n },\n});\n\ninterface FeaturedIconProps {\n ref?: Ref<HTMLDivElement>;\n children?: ReactNode;\n className?: string;\n icon?: FC<{ className?: string }> | ReactNode;\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\";\n color: \"brand\" | \"gray\" | \"success\" | \"warning\" | \"error\";\n theme?: \"light\" | \"gradient\" | \"dark\" | \"outline\" | \"modern\" | \"modern-neue\";\n}\n\nexport const FeaturedIcon = (props: FeaturedIconProps) => {\n const { size = \"sm\", theme: variant = \"light\", color = \"brand\", icon: Icon, ...otherProps } = props;\n\n return (\n <div\n {...otherProps}\n data-featured-icon\n className={cx(\n \"relative flex shrink-0 items-center justify-center\",\n\n iconsSizes[size],\n styles[variant].base,\n styles[variant].sizes[size],\n styles[variant].colors[color],\n\n props.className,\n )}\n >\n {isReactComponent(Icon) && createElement(Icon, { 'data-icon': true, className: \"z-1\" } as Record<string, unknown>)}\n {isValidElement(Icon) && <div className=\"z-1\">{Icon}</div>}\n\n {props.children}\n </div>\n );\n};\n","\"use client\";\n\nimport { ArrowLeft, ArrowRight } from \"@untitledui/icons\";\nimport { Button } from '../buttons/button';\nimport { ButtonGroup, ButtonGroupItem } from '../button-group/button-group';\nimport { useBreakpoint } from '../../../lib/hooks/use-breakpoint';\nimport { cx } from '../../../utils/cx';\nimport type { PaginationRootProps } from \"./pagination-base\";\nimport { Pagination } from \"./pagination-base\";\n\ninterface PaginationProps extends Partial<Omit<PaginationRootProps, \"children\">> {\n /** Whether the pagination buttons are rounded. */\n rounded?: boolean;\n}\n\nconst PaginationItem = ({ value, rounded, isCurrent }: { value: number; rounded?: boolean; isCurrent: boolean }) => {\n return (\n <Pagination.Item\n value={value}\n isCurrent={isCurrent}\n className={({ isSelected }) =>\n cx(\n \"flex size-10 cursor-pointer items-center justify-center p-3 text-sm font-medium text-quaternary outline-focus-ring transition duration-100 ease-linear hover:bg-primary_hover hover:text-secondary focus-visible:z-10 focus-visible:bg-primary_hover focus-visible:outline-2 focus-visible:outline-offset-2\",\n rounded ? \"rounded-full\" : \"rounded-lg\",\n isSelected && \"bg-primary_hover text-secondary\",\n )\n }\n >\n {value}\n </Pagination.Item>\n );\n};\n\ninterface MobilePaginationProps {\n /** The current page. */\n page?: number;\n /** The total number of pages. */\n total?: number;\n /** The class name of the pagination component. */\n className?: string;\n /** The function to call when the page changes. */\n onPageChange?: (page: number) => void;\n}\n\nconst MobilePagination = ({ page = 1, total = 10, className, onPageChange }: MobilePaginationProps) => {\n return (\n <nav aria-label=\"Pagination\" className={cx(\"flex items-center justify-between md:hidden\", className)}>\n <Button\n aria-label=\"Go to previous page\"\n iconLeading={ArrowLeft}\n color=\"secondary\"\n size=\"sm\"\n onClick={() => onPageChange?.(Math.max(0, page - 1))}\n />\n\n <span className=\"text-sm text-fg-secondary\">\n Page <span className=\"font-medium\">{page}</span> of <span className=\"font-medium\">{total}</span>\n </span>\n\n <Button\n aria-label=\"Go to next page\"\n iconLeading={ArrowRight}\n color=\"secondary\"\n size=\"sm\"\n onClick={() => onPageChange?.(Math.min(total, page + 1))}\n />\n </nav>\n );\n};\n\nexport const PaginationPageDefault = ({ rounded, page = 1, total = 10, className, ...props }: PaginationProps) => {\n const isDesktop = useBreakpoint(\"md\");\n\n return (\n <Pagination.Root\n {...props}\n page={page}\n total={total}\n className={cx(\"flex w-full items-center justify-between gap-3 border-t border-secondary pt-4 md:pt-5\", className)}\n >\n <div className=\"hidden flex-1 justify-start md:flex\">\n <Pagination.PrevTrigger asChild>\n <Button iconLeading={ArrowLeft} color=\"link-gray\" size=\"sm\">\n {isDesktop ? \"Previous\" : undefined}{\" \"}\n </Button>\n </Pagination.PrevTrigger>\n </div>\n\n <Pagination.PrevTrigger asChild className=\"md:hidden\">\n <Button iconLeading={ArrowLeft} color=\"secondary\" size=\"sm\">\n {isDesktop ? \"Previous\" : undefined}\n </Button>\n </Pagination.PrevTrigger>\n\n <Pagination.Context>\n {({ pages, currentPage, total }) => (\n <>\n <div className=\"hidden justify-center gap-0.5 md:flex\">\n {pages.map((page, index) =>\n page.type === \"page\" ? (\n <PaginationItem key={index} rounded={rounded} {...page} />\n ) : (\n <Pagination.Ellipsis key={index} className=\"flex size-10 shrink-0 items-center justify-center text-tertiary\">\n …\n </Pagination.Ellipsis>\n ),\n )}\n </div>\n\n <div className=\"flex justify-center text-sm whitespace-pre text-fg-secondary md:hidden\">\n Page <span className=\"font-medium\">{currentPage}</span> of <span className=\"font-medium\">{total}</span>\n </div>\n </>\n )}\n </Pagination.Context>\n\n <div className=\"hidden flex-1 justify-end md:flex\">\n <Pagination.NextTrigger asChild>\n <Button iconTrailing={ArrowRight} color=\"link-gray\" size=\"sm\">\n {isDesktop ? \"Next\" : undefined}\n </Button>\n </Pagination.NextTrigger>\n </div>\n <Pagination.NextTrigger asChild className=\"md:hidden\">\n <Button iconTrailing={ArrowRight} color=\"secondary\" size=\"sm\">\n {isDesktop ? \"Next\" : undefined}\n </Button>\n </Pagination.NextTrigger>\n </Pagination.Root>\n );\n};\n\nexport const PaginationPageMinimalCenter = ({ rounded, page = 1, total = 10, className, ...props }: PaginationProps) => {\n const isDesktop = useBreakpoint(\"md\");\n\n return (\n <Pagination.Root\n {...props}\n page={page}\n total={total}\n className={cx(\"flex w-full items-center justify-between gap-3 border-t border-secondary pt-4 md:pt-5\", className)}\n >\n <div className=\"flex flex-1 justify-start\">\n <Pagination.PrevTrigger asChild>\n <Button iconLeading={ArrowLeft} color=\"secondary\" size=\"sm\">\n {isDesktop ? \"Previous\" : undefined}\n </Button>\n </Pagination.PrevTrigger>\n </div>\n\n <Pagination.Context>\n {({ pages, currentPage, total }) => (\n <>\n <div className=\"hidden justify-center gap-0.5 md:flex\">\n {pages.map((page, index) =>\n page.type === \"page\" ? (\n <PaginationItem key={index} rounded={rounded} {...page} />\n ) : (\n <Pagination.Ellipsis key={index} className=\"flex size-10 shrink-0 items-center justify-center text-tertiary\">\n …\n </Pagination.Ellipsis>\n ),\n )}\n </div>\n\n <div className=\"flex justify-center text-sm whitespace-pre text-fg-secondary md:hidden\">\n Page <span className=\"font-medium\">{currentPage}</span> of <span className=\"font-medium\">{total}</span>\n </div>\n </>\n )}\n </Pagination.Context>\n\n <div className=\"flex flex-1 justify-end\">\n <Pagination.NextTrigger asChild>\n <Button iconTrailing={ArrowRight} color=\"secondary\" size=\"sm\">\n {isDesktop ? \"Next\" : undefined}\n </Button>\n </Pagination.NextTrigger>\n </div>\n </Pagination.Root>\n );\n};\n\nexport const PaginationCardDefault = ({ rounded, page = 1, total = 10, ...props }: PaginationProps) => {\n const isDesktop = useBreakpoint(\"md\");\n\n return (\n <Pagination.Root\n {...props}\n page={page}\n total={total}\n className=\"flex w-full items-center justify-between gap-3 border-t border-secondary px-4 py-3 md:px-6 md:pt-3 md:pb-4\"\n >\n <div className=\"flex flex-1 justify-start\">\n <Pagination.PrevTrigger asChild>\n <Button iconLeading={ArrowLeft} color=\"secondary\" size=\"sm\">\n {isDesktop ? \"Previous\" : undefined}\n </Button>\n </Pagination.PrevTrigger>\n </div>\n\n <Pagination.Context>\n {({ pages, currentPage, total }) => (\n <>\n <div className=\"hidden justify-center gap-0.5 md:flex\">\n {pages.map((page, index) =>\n page.type === \"page\" ? (\n <PaginationItem key={index} rounded={rounded} {...page} />\n ) : (\n <Pagination.Ellipsis key={index} className=\"flex size-10 shrink-0 items-center justify-center text-tertiary\">\n …\n </Pagination.Ellipsis>\n ),\n )}\n </div>\n\n <div className=\"flex justify-center text-sm whitespace-pre text-fg-secondary md:hidden\">\n Page <span className=\"font-medium\">{currentPage}</span> of <span className=\"font-medium\">{total}</span>\n </div>\n </>\n )}\n </Pagination.Context>\n\n <div className=\"flex flex-1 justify-end\">\n <Pagination.NextTrigger asChild>\n <Button iconTrailing={ArrowRight} color=\"secondary\" size=\"sm\">\n {isDesktop ? \"Next\" : undefined}\n </Button>\n </Pagination.NextTrigger>\n </div>\n </Pagination.Root>\n );\n};\n\ninterface PaginationCardMinimalProps {\n /** The current page. */\n page?: number;\n /** The total number of pages. */\n total?: number;\n /** The alignment of the pagination. */\n align?: \"left\" | \"center\" | \"right\";\n /** The class name of the pagination component. */\n className?: string;\n /** The function to call when the page changes. */\n onPageChange?: (page: number) => void;\n}\n\nexport const PaginationCardMinimal = ({ page = 1, total = 10, align = \"left\", onPageChange, className }: PaginationCardMinimalProps) => {\n return (\n <div className={cx(\"border-t border-secondary px-4 py-3 md:px-6 md:pt-3 md:pb-4\", className)}>\n <MobilePagination page={page} total={total} onPageChange={onPageChange} />\n\n <nav aria-label=\"Pagination\" className={cx(\"hidden items-center gap-3 md:flex\", align === \"center\" && \"justify-between\")}>\n <div className={cx(align === \"center\" && \"flex flex-1 justify-start\")}>\n <Button isDisabled={page === 1} color=\"secondary\" size=\"sm\" onClick={() => onPageChange?.(Math.max(0, page - 1))}>\n Previous\n </Button>\n </div>\n\n <span\n className={cx(\n \"text-sm font-medium text-fg-secondary\",\n align === \"right\" && \"order-first mr-auto\",\n align === \"left\" && \"order-last ml-auto\",\n )}\n >\n Page {page} of {total}\n </span>\n\n <div className={cx(align === \"center\" && \"flex flex-1 justify-end\")}>\n <Button isDisabled={page === total} color=\"secondary\" size=\"sm\" onClick={() => onPageChange?.(Math.min(total, page + 1))}>\n Next\n </Button>\n </div>\n </nav>\n </div>\n );\n};\n\ninterface PaginationButtonGroupProps extends Partial<Omit<PaginationRootProps, \"children\">> {\n /** The alignment of the pagination. */\n align?: \"left\" | \"center\" | \"right\";\n}\n\nexport const PaginationButtonGroup = ({ align = \"left\", page = 1, total = 10, ...props }: PaginationButtonGroupProps) => {\n const isDesktop = useBreakpoint(\"md\");\n\n return (\n <div\n className={cx(\n \"flex border-t border-secondary px-4 py-3 md:px-6 md:pt-3 md:pb-4\",\n align === \"left\" && \"justify-start\",\n align === \"center\" && \"justify-center\",\n align === \"right\" && \"justify-end\",\n )}\n >\n <Pagination.Root {...props} page={page} total={total}>\n <Pagination.Context>\n {({ pages }) => (\n <ButtonGroup size=\"md\">\n <Pagination.PrevTrigger asChild>\n <ButtonGroupItem iconLeading={ArrowLeft}>{isDesktop ? \"Previous\" : undefined}</ButtonGroupItem>\n </Pagination.PrevTrigger>\n\n {pages.map((page, index) =>\n page.type === \"page\" ? (\n <Pagination.Item key={index} {...page} asChild>\n <ButtonGroupItem isSelected={page.isCurrent} className=\"size-10 items-center justify-center\">\n {page.value}\n </ButtonGroupItem>\n </Pagination.Item>\n ) : (\n <Pagination.Ellipsis key={index}>\n <ButtonGroupItem className=\"pointer-events-none size-10 items-center justify-center rounded-none!\">\n …\n </ButtonGroupItem>\n </Pagination.Ellipsis>\n ),\n )}\n\n <Pagination.NextTrigger asChild>\n <ButtonGroupItem iconTrailing={ArrowRight}>{isDesktop ? \"Next\" : undefined}</ButtonGroupItem>\n </Pagination.NextTrigger>\n </ButtonGroup>\n )}\n </Pagination.Context>\n </Pagination.Root>\n </div>\n );\n};\n","\"use client\";\n\nimport { useSyncExternalStore } from \"react\";\n\nconst screens = {\n sm: \"640px\",\n md: \"768px\",\n lg: \"1024px\",\n xl: \"1280px\",\n \"2xl\": \"1536px\",\n};\n\n/**\n * Checks whether a particular Tailwind CSS viewport size applies.\n *\n * @param size The size to check, which must either be included in Tailwind CSS's\n * list of default screen sizes, or added to the Tailwind CSS config file.\n *\n * @returns A boolean indicating whether the viewport size applies.\n */\nexport const useBreakpoint = (size: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\") => {\n return useSyncExternalStore(\n (onStoreChange) => {\n if (typeof window === \"undefined\") {\n return () => {};\n }\n const breakpoint = window.matchMedia(`(min-width: ${screens[size]})`);\n breakpoint.addEventListener(\"change\", onStoreChange);\n return () => breakpoint.removeEventListener(\"change\", onStoreChange);\n },\n () => {\n if (typeof window === \"undefined\") {\n return true;\n }\n return window.matchMedia(`(min-width: ${screens[size]})`).matches;\n },\n () => true\n );\n};\n\n","\"use client\";\n\nimport type { CSSProperties, FC, HTMLAttributes, ReactNode } from \"react\";\nimport React, { cloneElement, createContext, isValidElement, useContext, useMemo } from \"react\";\n\ntype PaginationPage = {\n /** The type of the pagination item. */\n type: \"page\";\n /** The value of the pagination item. */\n value: number;\n /** Whether the pagination item is the current page. */\n isCurrent: boolean;\n};\n\ntype PaginationEllipsisType = {\n type: \"ellipsis\";\n key: number;\n};\n\ntype PaginationItemType = PaginationPage | PaginationEllipsisType;\n\ninterface PaginationContextType {\n /** The pages of the pagination. */\n pages: PaginationItemType[];\n /** The current page of the pagination. */\n currentPage: number;\n /** The total number of pages. */\n total: number;\n /** The function to call when the page changes. */\n onPageChange: (page: number) => void;\n}\n\nconst PaginationContext = createContext<PaginationContextType | undefined>(undefined);\n\nexport interface PaginationRootProps {\n /** Number of sibling pages to show on each side of the current page */\n siblingCount?: number;\n /** Current active page number */\n page: number;\n /** Total number of pages */\n total: number;\n children: ReactNode;\n /** The style of the pagination root. */\n style?: CSSProperties;\n /** The class name of the pagination root. */\n className?: string;\n /** Callback function that's called when the page changes with the new page number. */\n onPageChange?: (page: number) => void;\n}\n\nconst PaginationRoot = ({ total, siblingCount = 1, page, onPageChange, children, style, className }: PaginationRootProps) => {\n const pages = useMemo((): PaginationItemType[] => {\n const items: PaginationItemType[] = [];\n // Calculate the maximum number of pagination elements (pages, potential ellipsis, first and last) to show\n const totalPageNumbers = siblingCount * 2 + 5;\n\n // If the total number of items to show is greater than or equal to the total pages,\n // we can simply list all pages without needing to collapse with ellipsis\n if (totalPageNumbers >= total) {\n for (let i = 1; i <= total; i++) {\n items.push({\n type: \"page\",\n value: i,\n isCurrent: i === page,\n });\n }\n } else {\n // Calculate left and right sibling boundaries around the current page\n const leftSiblingIndex = Math.max(page - siblingCount, 1);\n const rightSiblingIndex = Math.min(page + siblingCount, total);\n\n // Determine if we need to show ellipsis on either side\n const showLeftEllipsis = leftSiblingIndex > 2;\n const showRightEllipsis = rightSiblingIndex < total - 1;\n\n // Case 1: No left ellipsis, but right ellipsis is needed\n if (!showLeftEllipsis && showRightEllipsis) {\n // Calculate how many page numbers to show starting from the beginning\n const leftItemCount = siblingCount * 2 + 3;\n const leftRange = range(1, leftItemCount);\n\n leftRange.forEach((pageNum) =>\n items.push({\n type: \"page\",\n value: pageNum,\n isCurrent: pageNum === page,\n }),\n );\n\n // Insert ellipsis after the left range and add the last page\n items.push({ type: \"ellipsis\", key: leftItemCount + 1 });\n items.push({\n type: \"page\",\n value: total,\n isCurrent: total === page,\n });\n }\n // Case 2: Left ellipsis needed, but right ellipsis is not needed\n else if (showLeftEllipsis && !showRightEllipsis) {\n // Determine how many items from the end should be shown\n const rightItemCount = siblingCount * 2 + 3;\n const rightRange = range(total - rightItemCount + 1, total);\n\n // Always show the first page, then add an ellipsis to indicate skipped pages\n items.push({\n type: \"page\",\n value: 1,\n isCurrent: page === 1,\n });\n items.push({ type: \"ellipsis\", key: total - rightItemCount });\n rightRange.forEach((pageNum) =>\n items.push({\n type: \"page\",\n value: pageNum,\n isCurrent: pageNum === page,\n }),\n );\n }\n // Case 3: Both left and right ellipsis are needed\n else if (showLeftEllipsis && showRightEllipsis) {\n // Always show the first page\n items.push({\n type: \"page\",\n value: 1,\n isCurrent: page === 1,\n });\n // Insert left ellipsis after the first page\n items.push({ type: \"ellipsis\", key: leftSiblingIndex - 1 });\n\n // Show a range of pages around the current page\n const middleRange = range(leftSiblingIndex, rightSiblingIndex);\n middleRange.forEach((pageNum) =>\n items.push({\n type: \"page\",\n value: pageNum,\n isCurrent: pageNum === page,\n }),\n );\n\n // Insert right ellipsis and finally the last page\n items.push({ type: \"ellipsis\", key: rightSiblingIndex + 1 });\n items.push({\n type: \"page\",\n value: total,\n isCurrent: total === page,\n });\n }\n }\n\n return items;\n }, [total, siblingCount, page]);\n\n const onPageChangeHandler = (newPage: number) => {\n onPageChange?.(newPage);\n };\n\n const paginationContextValue: PaginationContextType = {\n pages,\n currentPage: page,\n total,\n onPageChange: onPageChangeHandler,\n };\n\n return (\n <PaginationContext.Provider value={paginationContextValue}>\n <nav aria-label=\"Pagination Navigation\" style={style} className={className}>\n {children}\n </nav>\n </PaginationContext.Provider>\n );\n};\n\n/**\n * Creates an array of numbers from start to end.\n * @param start - The start number.\n * @param end - The end number.\n * @returns An array of numbers from start to end.\n */\nconst range = (start: number, end: number): number[] => {\n const length = end - start + 1;\n\n return Array.from({ length }, (_, index) => index + start);\n};\n\ninterface TriggerRenderProps {\n isDisabled: boolean;\n onClick: () => void;\n}\n\ninterface TriggerProps {\n /** The children of the trigger. Can be a render prop or a valid element. */\n children: ReactNode | ((props: TriggerRenderProps) => ReactNode);\n /** The style of the trigger. */\n style?: CSSProperties;\n /** The class name of the trigger. */\n className?: string | ((args: { isDisabled: boolean }) => string);\n /** If true, the child element will be cloned and passed down the prop of the trigger. */\n asChild?: boolean;\n /** The direction of the trigger. */\n direction: \"prev\" | \"next\";\n /** The aria label of the trigger. */\n ariaLabel?: string;\n}\n\nconst Trigger: FC<TriggerProps> = ({ children, style, className, asChild = false, direction, ariaLabel }) => {\n const context = useContext(PaginationContext);\n if (!context) {\n throw new Error(\"Pagination components must be used within a Pagination.Root\");\n }\n\n const { currentPage, total, onPageChange } = context;\n\n const isDisabled = direction === \"prev\" ? currentPage <= 1 : currentPage >= total;\n\n const handleClick = () => {\n if (isDisabled) return;\n\n const newPage = direction === \"prev\" ? currentPage - 1 : currentPage + 1;\n onPageChange?.(newPage);\n };\n\n const computedClassName = typeof className === \"function\" ? className({ isDisabled }) : className;\n\n const defaultAriaLabel = direction === \"prev\" ? \"Previous Page\" : \"Next Page\";\n\n // If the children is a render prop, we need to pass the isDisabled and onClick to the render prop.\n if (typeof children === \"function\") {\n return <>{children({ isDisabled, onClick: handleClick })}</>;\n }\n\n // If the children is a valid element, we need to clone it and pass the isDisabled and onClick to the cloned element.\n if (asChild && isValidElement(children)) {\n return cloneElement(children, {\n onClick: handleClick,\n disabled: isDisabled,\n isDisabled,\n \"aria-label\": ariaLabel || defaultAriaLabel,\n style: { ...(children.props as HTMLAttributes<HTMLElement>).style, ...style },\n className: [computedClassName, (children.props as HTMLAttributes<HTMLElement>).className].filter(Boolean).join(\" \") || undefined,\n } as HTMLAttributes<HTMLElement>);\n }\n\n return (\n <button aria-label={ariaLabel || defaultAriaLabel} onClick={handleClick} disabled={isDisabled} style={style} className={computedClassName}>\n {children}\n </button>\n );\n};\n\nconst PaginationPrevTrigger: FC<Omit<TriggerProps, \"direction\">> = (props) => <Trigger {...props} direction=\"prev\" />;\n\nconst PaginationNextTrigger: FC<Omit<TriggerProps, \"direction\">> = (props) => <Trigger {...props} direction=\"next\" />;\n\ninterface PaginationItemRenderProps {\n isSelected: boolean;\n onClick: () => void;\n value: number;\n \"aria-current\"?: \"page\";\n \"aria-label\"?: string;\n}\n\nexport interface PaginationItemProps {\n /** The value of the pagination item. */\n value: number;\n /** Whether the pagination item is the current page. */\n isCurrent: boolean;\n /** The children of the pagination item. Can be a render prop or a valid element. */\n children?: ReactNode | ((props: PaginationItemRenderProps) => ReactNode);\n /** The style object of the pagination item. */\n style?: CSSProperties;\n /** The class name of the pagination item. */\n className?: string | ((args: { isSelected: boolean }) => string);\n /** The aria label of the pagination item. */\n ariaLabel?: string;\n /** If true, the child element will be cloned and passed down the prop of the item. */\n asChild?: boolean;\n}\n\nconst PaginationItem = ({ value, isCurrent, children, style, className, ariaLabel, asChild = false }: PaginationItemProps) => {\n const context = useContext(PaginationContext);\n if (!context) {\n throw new Error(\"Pagination components must be used within a <Pagination.Root />\");\n }\n\n const { onPageChange } = context;\n\n const isSelected = isCurrent;\n\n const handleClick = () => {\n onPageChange?.(value);\n };\n\n const computedClassName = typeof className === \"function\" ? className({ isSelected }) : className;\n\n // If the children is a render prop, we need to pass the necessary props to the render prop.\n if (typeof children === \"function\") {\n return (\n <>\n {children({\n isSelected,\n onClick: handleClick,\n value,\n \"aria-current\": isCurrent ? \"page\" : undefined,\n \"aria-label\": ariaLabel || `Page ${value}`,\n })}\n </>\n );\n }\n\n // If the children is a valid element, we need to clone it and pass the necessary props to the cloned element.\n if (asChild && isValidElement(children)) {\n return cloneElement(children, {\n onClick: handleClick,\n \"aria-current\": isCurrent ? \"page\" : undefined,\n \"aria-label\": ariaLabel || `Page ${value}`,\n style: { ...(children.props as HTMLAttributes<HTMLElement>).style, ...style },\n className: [computedClassName, (children.props as HTMLAttributes<HTMLElement>).className].filter(Boolean).join(\" \") || undefined,\n } as HTMLAttributes<HTMLElement>);\n }\n\n return (\n <button\n onClick={handleClick}\n style={style}\n className={computedClassName}\n aria-current={isCurrent ? \"page\" : undefined}\n aria-label={ariaLabel || `Page ${value}`}\n role=\"listitem\"\n >\n {children}\n </button>\n );\n};\ninterface PaginationEllipsisProps {\n key: number;\n children?: ReactNode;\n style?: CSSProperties;\n className?: string | (() => string);\n}\n\nconst PaginationEllipsis: FC<PaginationEllipsisProps> = ({ children, style, className }) => {\n const computedClassName = typeof className === \"function\" ? className() : className;\n\n return (\n <span style={style} className={computedClassName} aria-hidden=\"true\">\n {children}\n </span>\n );\n};\n\ninterface PaginationContextComponentProps {\n children: (pagination: PaginationContextType) => ReactNode;\n}\n\nconst PaginationContextComponent: FC<PaginationContextComponentProps> = ({ children }) => {\n const context = useContext(PaginationContext);\n if (!context) {\n throw new Error(\"Pagination components must be used within a Pagination.Root\");\n }\n\n return <>{children(context)}</>;\n};\n\nexport const Pagination = {\n Root: PaginationRoot,\n PrevTrigger: PaginationPrevTrigger,\n NextTrigger: PaginationNextTrigger,\n Item: PaginationItem,\n Ellipsis: PaginationEllipsis,\n Context: PaginationContextComponent,\n};\n","'use client';\n\nimport { useEffect, useRef, useState, useCallback } from 'react';\n\ninterface GoogleMapProps {\n address: string;\n locationName?: string;\n className?: string;\n}\n\n// Google Maps API types\ninterface GoogleMaps {\n maps: {\n Geocoder: new () => GoogleGeocoder;\n Map: new (element: HTMLElement, options: GoogleMapOptions) => GoogleMapInstance;\n GeocoderStatus: {\n OK: string;\n [key: string]: string;\n };\n importLibrary: (library: string) => Promise<{ AdvancedMarkerElement: new (options: GoogleMarkerOptions) => GoogleMarker }>;\n };\n}\n\ninterface GoogleGeocoder {\n geocode: (request: { address: string }, callback: (results: GoogleGeocodeResult[] | null, status: string) => void) => void;\n}\n\ninterface GoogleGeocodeResult {\n geometry: {\n location: GoogleLatLng;\n };\n}\n\ninterface GoogleLatLng {\n lat: () => number;\n lng: () => number;\n}\n\ninterface GoogleMapOptions {\n zoom: number;\n center: GoogleLatLng;\n mapId: string;\n mapTypeControl: boolean;\n streetViewControl: boolean;\n fullscreenControl: boolean;\n zoomControl: boolean;\n}\n\ninterface GoogleMapInstance {\n markers?: GoogleMarker[];\n}\n\ninterface GoogleMarkerOptions {\n map: GoogleMapInstance;\n position: GoogleLatLng;\n title: string;\n}\n\ninterface GoogleMarker {\n map: GoogleMapInstance | null;\n}\n\ndeclare global {\n interface Window {\n google?: GoogleMaps;\n [key: string]: unknown; // Allow dynamic callback properties\n }\n}\n\nconst GOOGLE_MAPS_API_KEY = 'AIzaSyAb4-zSsPFx-QGi4cAiCGaRrzsAJC6e348';\n\nexport default function GoogleMap({ address, locationName, className = '' }: GoogleMapProps) {\n const mapRef = useRef<HTMLDivElement>(null);\n const [mapError, setMapError] = useState<string | null>(null);\n const [isLoaded, setIsLoaded] = useState(false);\n const geocoderRef = useRef<GoogleGeocoder | null>(null);\n const mapInstanceRef = useRef<GoogleMapInstance | null>(null);\n const isInitializingRef = useRef(false);\n const callbackNameRef = useRef<string | null>(null);\n\n // Initialize map once Google Maps API is loaded\n // Use ref to store callback to avoid \"accessed before declaration\" error\n const initMapRef = useRef<(() => Promise<void>) | null>(null);\n \n const initMap = useCallback(async () => {\n // Prevent multiple simultaneous initializations\n if (isInitializingRef.current) return;\n \n // Ensure DOM element exists and Google Maps is fully loaded\n if (!mapRef.current || !window.google || !window.google.maps) {\n return;\n }\n\n // Check if Geocoder is available (required for async loading)\n if (!window.google.maps.Geocoder) {\n console.warn('Google Maps Geocoder not yet available, retrying...');\n setTimeout(() => {\n if (mapRef.current && window.google?.maps?.Geocoder && initMapRef.current) {\n void initMapRef.current();\n }\n }, 100);\n return;\n }\n\n // Double-check the element is still in the DOM\n if (!document.body.contains(mapRef.current)) {\n return;\n }\n\n isInitializingRef.current = true;\n\n try {\n // Clear any existing map instance\n if (mapInstanceRef.current) {\n // Clear markers and listeners\n const markers = mapInstanceRef.current.markers || [];\n markers.forEach((marker) => {\n if (marker.map) marker.map = null;\n });\n mapInstanceRef.current = null;\n }\n\n // Import marker library for AdvancedMarkerElement\n const markerLibrary = await window.google.maps.importLibrary(\"marker\");\n const AdvancedMarkerElement = markerLibrary.AdvancedMarkerElement;\n\n // Create geocoder - now we know it's available\n geocoderRef.current = new window.google.maps.Geocoder();\n \n // Geocode the address\n geocoderRef.current.geocode({ address }, (results: GoogleGeocodeResult[] | null, status: string) => {\n // Check if component is still mounted and ref is still valid\n if (!mapRef.current || !document.body.contains(mapRef.current)) {\n isInitializingRef.current = false;\n return;\n }\n\n if (status === 'OK' && results && results[0]) {\n const location = results[0].geometry.location;\n \n // Create map centered on the geocoded location\n // Advanced markers require a mapId\n // Note: When using mapId, styles are controlled via Google Cloud Console, not in code\n if (!window.google) return;\n const map = new window.google.maps.Map(mapRef.current, {\n zoom: 15,\n center: location,\n mapId: 'DEMO_MAP_ID', // Can be replaced with a custom Map ID from Google Cloud Console\n mapTypeControl: false,\n streetViewControl: false,\n fullscreenControl: true,\n zoomControl: true,\n // Styles cannot be set when mapId is present - configure in Google Cloud Console instead\n });\n\n // Create AdvancedMarkerElement (modern, non-deprecated approach)\n const marker = new AdvancedMarkerElement({\n map: map,\n position: location,\n title: locationName || address,\n });\n\n // Store markers for cleanup\n map.markers = [marker];\n mapInstanceRef.current = map;\n setIsLoaded(true);\n setMapError(null);\n } else {\n // If geocoding fails, show error\n setMapError('Unable to find the address. Please check the address and try again.');\n setIsLoaded(false);\n }\n \n isInitializingRef.current = false;\n });\n } catch (error) {\n console.error('Error initializing map:', error);\n setMapError('Error loading map. Please try again later.');\n isInitializingRef.current = false;\n }\n }, [address, locationName]);\n\n // Store callback in ref (use effect to avoid accessing refs during render)\n useEffect(() => {\n initMapRef.current = initMap;\n }, [initMap]);\n\n // Load Google Maps script with proper callback\n useEffect(() => {\n let mounted = true;\n let checkInterval: NodeJS.Timeout | null = null;\n\n // Generate unique callback name for this component instance\n const callbackName = `initGoogleMap_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;\n callbackNameRef.current = callbackName;\n\n // Create callback function that will be called when API loads\n (window as Window & { [key: string]: () => void })[callbackName] = () => {\n if (mounted && mapRef.current && initMapRef.current) {\n // Small delay to ensure everything is ready\n setTimeout(() => {\n if (mounted && mapRef.current && initMapRef.current) {\n void initMapRef.current();\n }\n }, 100);\n }\n };\n\n // Check if script is already loaded\n if (window.google && window.google.maps && window.google.maps.Geocoder) {\n setTimeout(() => {\n if (mounted && mapRef.current && initMapRef.current) {\n void initMapRef.current();\n }\n }, 100);\n return () => {\n mounted = false;\n delete (window as Window & { [key: string]: unknown })[callbackName];\n };\n }\n\n // Check if script tag already exists (shared script)\n const existingScript = document.querySelector(`script[src*=\"maps.googleapis.com\"]`) as HTMLScriptElement;\n if (existingScript) {\n // Script is loading or loaded, wait for it\n checkInterval = setInterval(() => {\n if (window.google && window.google.maps && window.google.maps.Geocoder && mounted) {\n clearInterval(checkInterval!);\n setTimeout(() => {\n if (mounted && mapRef.current && initMapRef.current) {\n void initMapRef.current();\n }\n }, 100);\n }\n }, 100);\n \n return () => {\n mounted = false;\n if (checkInterval) {\n clearInterval(checkInterval);\n }\n delete (window as Window & { [key: string]: unknown })[callbackName];\n };\n }\n\n // Create and load script with callback\n // Include 'marker' library for AdvancedMarkerElement\n const script = document.createElement('script');\n script.src = `https://maps.googleapis.com/maps/api/js?key=${GOOGLE_MAPS_API_KEY}&libraries=places,marker&loading=async&callback=${callbackName}`;\n script.async = true;\n script.defer = true;\n \n script.onerror = () => {\n if (mounted) {\n setMapError('Failed to load Google Maps. Please check your internet connection.');\n delete (window as Window & { [key: string]: unknown })[callbackName];\n }\n };\n \n document.head.appendChild(script);\n \n return () => {\n mounted = false;\n if (checkInterval) {\n clearInterval(checkInterval);\n }\n // Clean up callback\n if (callbackNameRef.current) {\n delete (window as Window & { [key: string]: unknown })[callbackNameRef.current];\n callbackNameRef.current = null;\n }\n // Never remove the script - it's shared and removing it causes React errors\n };\n }, []); // Only run once on mount\n\n // Re-initialize map if address changes (but only after API is loaded)\n useEffect(() => {\n if (window.google && window.google.maps && window.google.maps.Geocoder && mapRef.current && !isInitializingRef.current && initMapRef.current) {\n // Small delay to ensure DOM is stable\n const timeoutId = setTimeout(() => {\n if (mapRef.current && initMapRef.current) {\n void initMapRef.current();\n }\n }, 100);\n \n return () => clearTimeout(timeoutId);\n }\n }, [address, locationName]);\n\n // Cleanup map instance on unmount\n useEffect(() => {\n return () => {\n if (mapInstanceRef.current) {\n // Clear markers\n const markers = mapInstanceRef.current.markers || [];\n markers.forEach((marker) => {\n if (marker.map) marker.map = null;\n });\n mapInstanceRef.current = null;\n }\n isInitializingRef.current = false;\n };\n }, []);\n\n return (\n <div className={`h-full w-full rounded-lg ${className}`} style={{ minHeight: '240px', position: 'relative' }}>\n {/* Map container - always present, Google Maps will render into it */}\n <div \n ref={mapRef} \n className=\"h-full w-full rounded-lg\"\n style={{ minHeight: '240px' }}\n />\n \n {/* Loading overlay - positioned absolutely to not interfere with map DOM */}\n {!isLoaded && !mapError && (\n <div \n className=\"absolute inset-0 bg-secondary_alt rounded-lg flex items-center justify-center z-10\"\n style={{ pointerEvents: 'none' }}\n >\n <p className=\"text-tertiary\">Loading map...</p>\n </div>\n )}\n \n {/* Error overlay - positioned absolutely to not interfere with map DOM */}\n {mapError && (\n <div \n className=\"absolute inset-0 bg-secondary_alt rounded-lg flex items-center justify-center z-10\"\n style={{ pointerEvents: 'auto' }}\n >\n <div className=\"text-center p-4\">\n <p className=\"text-tertiary mb-2\">{mapError}</p>\n <a \n href={`https://maps.google.com/?q=${encodeURIComponent(address)}`}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"text-sm text-brand-secondary hover:underline\"\n >\n Open in Google Maps\n </a>\n </div>\n </div>\n )}\n </div>\n );\n}\n","'use client';\n\nimport Image from 'next/image';\nimport ReactMarkdown from 'react-markdown';\nimport remarkGfm from 'remark-gfm';\n\ninterface MarkdownRendererProps {\n content: string;\n className?: string;\n}\n\n/**\n * Generate a URL-friendly ID from a heading text\n */\nfunction slugify(text: string): string {\n return text\n .toLowerCase()\n .trim()\n .replace(/[^\\w\\s-]/g, '') // Remove special characters\n .replace(/[\\s_-]+/g, '-') // Replace spaces and underscores with hyphens\n .replace(/^-+|-+$/g, ''); // Remove leading/trailing hyphens\n}\n\n/**\n * Extract text content from React children (handles nested structures)\n */\nfunction extractTextFromChildren(children: React.ReactNode): string {\n if (typeof children === 'string') {\n return children;\n }\n if (Array.isArray(children)) {\n return children.map((child) => extractTextFromChildren(child)).join('');\n }\n if (children && typeof children === 'object' && 'props' in children && children.props && typeof children.props === 'object' && 'children' in children.props) {\n return extractTextFromChildren(children.props.children as React.ReactNode);\n }\n return '';\n}\n\nexport default function MarkdownRenderer({ content, className = '' }: MarkdownRendererProps) {\n return (\n <div className={className}>\n <ReactMarkdown\n remarkPlugins={[remarkGfm]}\n components={{\n // Headings with IDs for table of contents\n h1: ({ children, ...props }: React.HTMLAttributes<HTMLHeadingElement>) => {\n const text = extractTextFromChildren(children);\n const id = slugify(text);\n return <h1 id={id} className=\"text-3xl md:text-4xl font-bold text-gray-900 mb-6\" {...props}>{children}</h1>;\n },\n h2: ({ children, ...props }: React.HTMLAttributes<HTMLHeadingElement>) => {\n const text = extractTextFromChildren(children);\n const id = slugify(text);\n return <h2 id={id} className=\"text-2xl font-semibold text-gray-900 mb-4\" {...props}>{children}</h2>;\n },\n h3: ({ children, ...props }: React.HTMLAttributes<HTMLHeadingElement>) => {\n const text = extractTextFromChildren(children);\n const id = slugify(text);\n return <h3 id={id} className=\"text-xl font-semibold text-gray-900 mb-3\" {...props}>{children}</h3>;\n },\n h4: ({ children, ...props }: React.HTMLAttributes<HTMLHeadingElement>) => {\n const text = extractTextFromChildren(children);\n const id = slugify(text);\n return <h4 id={id} className=\"text-lg font-semibold text-gray-900 mb-2\" {...props}>{children}</h4>;\n },\n h5: ({ children, ...props }: React.HTMLAttributes<HTMLHeadingElement>) => {\n const text = extractTextFromChildren(children);\n const id = slugify(text);\n return <h5 id={id} className=\"text-base font-semibold text-gray-900 mb-2\" {...props}>{children}</h5>;\n },\n h6: ({ children, ...props }: React.HTMLAttributes<HTMLHeadingElement>) => {\n const text = extractTextFromChildren(children);\n const id = slugify(text);\n return <h6 id={id} className=\"text-sm font-semibold text-gray-900 mb-2\" {...props}>{children}</h6>;\n },\n \n // Paragraphs and text\n p: (props: React.HTMLAttributes<HTMLParagraphElement>) => (\n <p className=\"text-gray-700 leading-relaxed mb-4 last:mb-0\" {...props} />\n ),\n strong: (props: React.HTMLAttributes<HTMLElement>) => (\n <strong className=\"font-semibold text-gray-900\" {...props} />\n ),\n em: (props: React.HTMLAttributes<HTMLElement>) => (\n <em className=\"italic text-gray-700\" {...props} />\n ),\n\n \n // Lists\n ul: (props: React.HTMLAttributes<HTMLUListElement>) => (\n <ul className=\"list-disc list-inside space-y-1 mb-4 last:mb-0\" {...props} />\n ),\n ol: (props: React.HTMLAttributes<HTMLOListElement>) => (\n <ol className=\"list-decimal list-inside space-y-1 mb-4 last:mb-0\" {...props} />\n ),\n li: (props: React.HTMLAttributes<HTMLLIElement>) => (\n <li className=\"text-gray-700 leading-relaxed\" {...props} />\n ),\n \n // Blockquotes\n blockquote: (props: React.HTMLAttributes<HTMLQuoteElement>) => (\n <blockquote className=\"border-l-4 border-blue-500 pl-4 italic text-gray-600 bg-blue-50 py-2 mb-4\" {...props} />\n ),\n \n // Links\n a: (props: React.AnchorHTMLAttributes<HTMLAnchorElement>) => (\n <a className=\"text-blue-600 hover:text-blue-800 hover:underline\" {...props} />\n ),\n \n // Images\n img: (props: React.ImgHTMLAttributes<HTMLImageElement>) => {\n const { src, alt, width, height, ...restProps } = props;\n if (!src || typeof src !== 'string') return null;\n return (\n <Image \n src={src} \n alt={alt || \"\"} \n width={typeof width === 'number' ? width : 800} \n height={typeof height === 'number' ? height : 600} \n className=\"max-w-full h-auto rounded-lg shadow-md my-4\" \n {...restProps} \n />\n );\n },\n \n // Horizontal rules\n hr: () => <hr className=\"my-6 border-gray-200\" />,\n \n // Tables\n table: (props: React.HTMLAttributes<HTMLTableElement>) => (\n <div className=\"overflow-x-auto my-4\">\n <table className=\"min-w-full bg-white border border-gray-200 rounded-lg\" {...props} />\n </div>\n ),\n thead: (props: React.HTMLAttributes<HTMLTableSectionElement>) => (\n <thead className=\"bg-gray-50\" {...props} />\n ),\n tbody: (props: React.HTMLAttributes<HTMLTableSectionElement>) => (\n <tbody {...props} />\n ),\n tr: (props: React.HTMLAttributes<HTMLTableRowElement>) => (\n <tr className=\"border-b border-gray-200\" {...props} />\n ),\n th: (props: React.HTMLAttributes<HTMLTableCellElement>) => (\n <th className=\"px-4 py-3 text-left text-sm font-semibold text-gray-900\" {...props} />\n ),\n td: (props: React.HTMLAttributes<HTMLTableCellElement>) => (\n <td className=\"px-4 py-3 text-sm text-gray-700\" {...props} />\n ),\n \n // Code blocks\n pre: (props: React.HTMLAttributes<HTMLPreElement>) => (\n <pre className=\"bg-gray-100 p-4 rounded-lg overflow-x-auto my-4\" {...props} />\n ),\n \n // Code\n code: (props: React.HTMLAttributes<HTMLElement>) => (\n <code className=\"bg-gray-100 px-1.5 py-0.5 rounded text-sm font-mono text-gray-800\" {...props} />\n ),\n }}\n >\n {content}\n </ReactMarkdown>\n </div>\n );\n}\n","\"use client\";\n\nimport type { AnchorHTMLAttributes, ButtonHTMLAttributes, DetailedHTMLProps, FC, ReactNode } from \"react\";\nimport React, { isValidElement } from \"react\";\nimport type { ButtonProps as AriaButtonProps } from \"react-aria-components\";\nimport { Button as AriaButton, Link as AriaLink } from \"react-aria-components\";\nimport { cx, sortCx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\n\n// Aman theme: Minimal dark charcoal buttons with white text\nexport const styles = sortCx({\n common: {\n root: [\n \"group relative inline-flex h-max cursor-pointer items-center justify-center whitespace-nowrap outline-none transition duration-100 ease-linear focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-focus-ring\",\n \"disabled:cursor-not-allowed disabled:opacity-50\",\n \"*:data-icon:pointer-events-none *:data-icon:size-5 *:data-icon:shrink-0 *:data-icon:transition-inherit-all\",\n ].join(\" \"),\n icon: \"pointer-events-none size-5 shrink-0 transition-inherit-all\",\n },\n sizes: {\n sm: {\n root: \"gap-2 rounded-sm px-5 py-2.5 text-sm font-medium uppercase tracking-wide\",\n },\n md: {\n root: \"gap-2 rounded-sm px-6 py-3 text-base font-medium uppercase tracking-wide\",\n },\n lg: {\n root: \"gap-2 rounded-sm px-8 py-3.5 text-lg font-medium uppercase tracking-wide\",\n },\n xl: {\n root: \"gap-2.5 rounded-sm px-10 py-4 text-xl font-medium uppercase tracking-wide\",\n },\n },\n\n colors: {\n primary: {\n root: \"bg-brand-solid text-white hover:bg-brand-solid_hover transition-colors\",\n },\n secondary: {\n root: \"bg-white text-fg-primary border-2 hover:opacity-90 transition-all\",\n },\n tertiary: {\n root: \"text-fg-primary hover:underline\",\n },\n \"link-gray\": {\n root: [\n \"p-0! text-fg-primary\",\n \"*:data-text:underline *:data-text:underline-offset-4 hover:*:data-text:no-underline\",\n ].join(\" \"),\n },\n \"link-color\": {\n root: [\n \"p-0! text-fg-primary\",\n \"*:data-text:underline *:data-text:underline-offset-4 hover:*:data-text:no-underline\",\n ].join(\" \"),\n },\n },\n});\n\nexport interface CommonProps {\n isDisabled?: boolean;\n isLoading?: boolean;\n size?: keyof typeof styles.sizes;\n color?: keyof typeof styles.colors;\n iconLeading?: FC<{ className?: string }> | ReactNode;\n iconTrailing?: FC<{ className?: string }> | ReactNode;\n noTextPadding?: boolean;\n showTextWhileLoading?: boolean;\n}\n\nexport interface ButtonProps extends CommonProps, DetailedHTMLProps<Omit<ButtonHTMLAttributes<HTMLButtonElement>, \"color\" | \"slot\">, HTMLButtonElement> {\n slot?: AriaButtonProps[\"slot\"];\n}\n\ninterface LinkProps extends CommonProps, DetailedHTMLProps<Omit<AnchorHTMLAttributes<HTMLAnchorElement>, \"color\">, HTMLAnchorElement> {}\n\nexport type Props = ButtonProps | LinkProps;\n\nexport const Button = ({\n size = \"sm\",\n color = \"primary\",\n children,\n className,\n noTextPadding,\n iconLeading: IconLeading,\n iconTrailing: IconTrailing,\n isDisabled: disabled,\n isLoading: loading,\n showTextWhileLoading,\n ...otherProps\n}: Props) => {\n const href = \"href\" in otherProps ? otherProps.href : undefined;\n const Component = href ? AriaLink : AriaButton;\n\n const isIcon = (IconLeading || IconTrailing) && !children;\n const isLinkType = [\"link-gray\", \"link-color\"].includes(color);\n\n noTextPadding = isLinkType || noTextPadding;\n\n let props = {};\n\n if (href) {\n props = {\n ...otherProps,\n href: disabled ? undefined : href,\n ...(disabled ? { \"data-rac\": true, \"data-disabled\": true } : {}),\n };\n } else {\n props = {\n ...otherProps,\n type: otherProps.type || \"button\",\n isPending: loading,\n isDisabled: disabled,\n };\n }\n\n // Dynamic border color for secondary buttons using brand secondary color\n const secondaryStyle = color === 'secondary' ? {\n borderColor: 'var(--color-text-brand-secondary)'\n } : undefined;\n\n return (\n <Component\n data-loading={loading ? true : undefined}\n data-icon-only={isIcon ? true : undefined}\n {...props}\n style={secondaryStyle}\n className={cx(\n styles.common.root,\n styles.sizes[size].root,\n styles.colors[color].root,\n (loading || (href && (disabled || loading))) && \"pointer-events-none\",\n loading && (showTextWhileLoading ? \"[&>*:not([data-icon=loading]):not([data-text])]:hidden\" : \"[&>*:not([data-icon=loading])]:invisible\"),\n className,\n )}\n >\n {isValidElement(IconLeading) && IconLeading}\n {isReactComponent(IconLeading) && React.createElement(IconLeading, { 'data-icon': 'leading', className: styles.common.icon } as Record<string, unknown>)}\n\n {loading && (\n <svg\n fill=\"none\"\n data-icon=\"loading\"\n viewBox=\"0 0 20 20\"\n className={cx(styles.common.icon, !showTextWhileLoading && \"absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2\")}\n >\n <circle className=\"stroke-current opacity-30\" cx=\"10\" cy=\"10\" r=\"8\" fill=\"none\" strokeWidth=\"2\" />\n <circle\n className=\"origin-center animate-spin stroke-current\"\n cx=\"10\"\n cy=\"10\"\n r=\"8\"\n fill=\"none\"\n strokeWidth=\"2\"\n strokeDasharray=\"12.5 50\"\n strokeLinecap=\"round\"\n />\n </svg>\n )}\n\n {children && (\n <span data-text className={cx(\"transition-inherit-all\", !noTextPadding && \"px-0.5\")}>\n {children}\n </span>\n )}\n\n {isValidElement(IconTrailing) && IconTrailing}\n {isReactComponent(IconTrailing) && React.createElement(IconTrailing, { 'data-icon': 'trailing', className: styles.common.icon } as Record<string, unknown>)}\n </Component>\n );\n};\n\nimport { registerThemeVariant } from '../../../lib/component-registry';\nregisterThemeVariant('button', 'aman', Button);\n","\"use client\";\n\nimport type { AnchorHTMLAttributes, ButtonHTMLAttributes, DetailedHTMLProps, FC, ReactNode } from \"react\";\nimport React, { isValidElement } from \"react\";\nimport type { ButtonProps as AriaButtonProps } from \"react-aria-components\";\nimport { Button as AriaButton, Link as AriaLink } from \"react-aria-components\";\nimport { cx, sortCx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\n\n// Barelux theme: Rounded full buttons with elegant styling\nexport const styles = sortCx({\n common: {\n root: [\n \"group relative inline-flex h-max cursor-pointer items-center justify-center whitespace-nowrap outline-none transition duration-100 ease-linear focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-focus-ring\",\n \"disabled:cursor-not-allowed disabled:opacity-50\",\n \"*:data-icon:pointer-events-none *:data-icon:size-5 *:data-icon:shrink-0 *:data-icon:transition-inherit-all\",\n ].join(\" \"),\n icon: \"pointer-events-none size-5 shrink-0 transition-inherit-all\",\n },\n sizes: {\n sm: {\n root: \"gap-2 rounded-full px-6 py-2.5 text-sm font-medium uppercase tracking-wide\",\n },\n md: {\n root: \"gap-2 rounded-full px-8 py-3 text-base font-medium uppercase tracking-wide\",\n },\n lg: {\n root: \"gap-2 rounded-full px-10 py-3.5 text-lg font-medium uppercase tracking-wide\",\n },\n xl: {\n root: \"gap-2.5 rounded-full px-12 py-4 text-xl font-medium uppercase tracking-wide\",\n },\n },\n\n colors: {\n primary: {\n root: \"bg-brand-solid text-white hover:bg-brand-solid_hover transition-colors\",\n },\n secondary: {\n root: \"bg-secondary text-fg-primary hover:opacity-90 transition-all\",\n },\n tertiary: {\n root: \"text-fg-primary hover:underline\",\n },\n \"link-gray\": {\n root: [\n \"p-0! text-fg-primary\",\n \"*:data-text:underline *:data-text:underline-offset-4 hover:*:data-text:no-underline\",\n ].join(\" \"),\n },\n \"link-color\": {\n root: [\n \"p-0! text-fg-primary\",\n \"*:data-text:underline *:data-text:underline-offset-4 hover:*:data-text:no-underline\",\n ].join(\" \"),\n },\n },\n});\n\nexport interface CommonProps {\n isDisabled?: boolean;\n isLoading?: boolean;\n size?: keyof typeof styles.sizes;\n color?: keyof typeof styles.colors;\n iconLeading?: FC<{ className?: string }> | ReactNode;\n iconTrailing?: FC<{ className?: string }> | ReactNode;\n noTextPadding?: boolean;\n showTextWhileLoading?: boolean;\n}\n\nexport interface ButtonProps extends CommonProps, DetailedHTMLProps<Omit<ButtonHTMLAttributes<HTMLButtonElement>, \"color\" | \"slot\">, HTMLButtonElement> {\n slot?: AriaButtonProps[\"slot\"];\n}\n\ninterface LinkProps extends CommonProps, DetailedHTMLProps<Omit<AnchorHTMLAttributes<HTMLAnchorElement>, \"color\">, HTMLAnchorElement> {}\n\nexport type Props = ButtonProps | LinkProps;\n\nexport const Button = ({\n size = \"sm\",\n color = \"primary\",\n children,\n className,\n noTextPadding,\n iconLeading: IconLeading,\n iconTrailing: IconTrailing,\n isDisabled: disabled,\n isLoading: loading,\n showTextWhileLoading,\n ...otherProps\n}: Props) => {\n const href = \"href\" in otherProps ? otherProps.href : undefined;\n const Component = href ? AriaLink : AriaButton;\n\n const isIcon = (IconLeading || IconTrailing) && !children;\n const isLinkType = [\"link-gray\", \"link-color\"].includes(color);\n\n noTextPadding = isLinkType || noTextPadding;\n\n let props = {};\n\n if (href) {\n props = {\n ...otherProps,\n href: disabled ? undefined : href,\n ...(disabled ? { \"data-rac\": true, \"data-disabled\": true } : {}),\n };\n } else {\n props = {\n ...otherProps,\n type: otherProps.type || \"button\",\n isPending: loading,\n isDisabled: disabled,\n };\n }\n\n return (\n <Component\n data-loading={loading ? true : undefined}\n data-icon-only={isIcon ? true : undefined}\n {...props}\n className={cx(\n styles.common.root,\n styles.sizes[size].root,\n styles.colors[color].root,\n (loading || (href && (disabled || loading))) && \"pointer-events-none\",\n loading && (showTextWhileLoading ? \"[&>*:not([data-icon=loading]):not([data-text])]:hidden\" : \"[&>*:not([data-icon=loading])]:invisible\"),\n className,\n )}\n >\n {/* Leading icon */}\n {isValidElement(IconLeading) && IconLeading}\n {isReactComponent(IconLeading) && React.createElement(IconLeading, { 'data-icon': 'leading', className: styles.common.icon } as Record<string, unknown>)}\n\n {loading && (\n <svg\n fill=\"none\"\n data-icon=\"loading\"\n viewBox=\"0 0 20 20\"\n className={cx(styles.common.icon, !showTextWhileLoading && \"absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2\")}\n >\n {/* Background circle */}\n <circle className=\"stroke-current opacity-30\" cx=\"10\" cy=\"10\" r=\"8\" fill=\"none\" strokeWidth=\"2\" />\n {/* Spinning circle */}\n <circle\n className=\"origin-center animate-spin stroke-current\"\n cx=\"10\"\n cy=\"10\"\n r=\"8\"\n fill=\"none\"\n strokeWidth=\"2\"\n strokeDasharray=\"12.5 50\"\n strokeLinecap=\"round\"\n />\n </svg>\n )}\n\n {children && (\n <span data-text className={cx(\"transition-inherit-all\", !noTextPadding && \"px-0.5\")}>\n {children}\n </span>\n )}\n\n {/* Trailing icon */}\n {isValidElement(IconTrailing) && IconTrailing}\n {isReactComponent(IconTrailing) && React.createElement(IconTrailing, { 'data-icon': 'trailing', className: styles.common.icon } as Record<string, unknown>)}\n </Component>\n );\n};\n\nimport { registerThemeVariant } from '../../../lib/component-registry';\nregisterThemeVariant('button', 'barelux', Button);\n","\"use client\";\n\nimport type { AnchorHTMLAttributes, ButtonHTMLAttributes, DetailedHTMLProps, FC, ReactNode } from \"react\";\nimport React, { isValidElement } from \"react\";\nimport type { ButtonProps as AriaButtonProps } from \"react-aria-components\";\nimport { Button as AriaButton, Link as AriaLink } from \"react-aria-components\";\nimport { cx, sortCx } from '../../../utils/cx';\nimport { isReactComponent } from '../../../utils/is-react-component';\n\n// Balance theme: Rounded full buttons with elegant styling\nexport const styles = sortCx({\n common: {\n root: [\n \"group relative inline-flex h-max cursor-pointer items-center justify-center whitespace-nowrap outline-none transition duration-100 ease-linear focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-focus-ring\",\n \"disabled:cursor-not-allowed disabled:opacity-50\",\n \"*:data-icon:pointer-events-none *:data-icon:size-5 *:data-icon:shrink-0 *:data-icon:transition-inherit-all\",\n ].join(\" \"),\n icon: \"pointer-events-none size-5 shrink-0 transition-inherit-all\",\n },\n sizes: {\n sm: {\n root: \"gap-2 rounded-full px-6 py-2.5 text-sm font-medium\",\n },\n md: {\n root: \"gap-2 rounded-full px-8 py-3 text-base font-medium\",\n },\n lg: {\n root: \"gap-2 rounded-full px-10 py-3.5 text-lg font-medium\",\n },\n xl: {\n root: \"gap-2.5 rounded-full px-12 py-4 text-xl font-medium\",\n },\n },\n\n colors: {\n primary: {\n root: \"bg-brand-solid text-white hover:bg-brand-solid_hover transition-colors\",\n },\n secondary: {\n root: \"bg-secondary text-fg-primary hover:opacity-90 transition-all\",\n },\n tertiary: {\n root: \"text-fg-primary hover:underline\",\n },\n \"link-gray\": {\n root: [\n \"p-0! text-fg-primary\",\n \"*:data-text:underline *:data-text:underline-offset-4 hover:*:data-text:no-underline\",\n ].join(\" \"),\n },\n \"link-color\": {\n root: [\n \"p-0! text-fg-primary\",\n \"*:data-text:underline *:data-text:underline-offset-4 hover:*:data-text:no-underline\",\n ].join(\" \"),\n },\n },\n});\n\nexport interface CommonProps {\n isDisabled?: boolean;\n isLoading?: boolean;\n size?: keyof typeof styles.sizes;\n color?: keyof typeof styles.colors;\n iconLeading?: FC<{ className?: string }> | ReactNode;\n iconTrailing?: FC<{ className?: string }> | ReactNode;\n noTextPadding?: boolean;\n showTextWhileLoading?: boolean;\n}\n\nexport interface ButtonProps extends CommonProps, DetailedHTMLProps<Omit<ButtonHTMLAttributes<HTMLButtonElement>, \"color\" | \"slot\">, HTMLButtonElement> {\n slot?: AriaButtonProps[\"slot\"];\n}\n\ninterface LinkProps extends CommonProps, DetailedHTMLProps<Omit<AnchorHTMLAttributes<HTMLAnchorElement>, \"color\">, HTMLAnchorElement> {}\n\nexport type Props = ButtonProps | LinkProps;\n\nexport const Button = ({\n size = \"sm\",\n color = \"primary\",\n children,\n className,\n noTextPadding,\n iconLeading: IconLeading,\n iconTrailing: IconTrailing,\n isDisabled: disabled,\n isLoading: loading,\n showTextWhileLoading,\n ...otherProps\n}: Props) => {\n const href = \"href\" in otherProps ? otherProps.href : undefined;\n const Component = href ? AriaLink : AriaButton;\n\n const isIcon = (IconLeading || IconTrailing) && !children;\n const isLinkType = [\"link-gray\", \"link-color\"].includes(color);\n\n noTextPadding = isLinkType || noTextPadding;\n\n let props = {};\n\n if (href) {\n props = {\n ...otherProps,\n href: disabled ? undefined : href,\n ...(disabled ? { \"data-rac\": true, \"data-disabled\": true } : {}),\n };\n } else {\n props = {\n ...otherProps,\n type: otherProps.type || \"button\",\n isPending: loading,\n isDisabled: disabled,\n };\n }\n\n return (\n <Component\n data-loading={loading ? true : undefined}\n data-icon-only={isIcon ? true : undefined}\n {...props}\n className={cx(\n styles.common.root,\n styles.sizes[size].root,\n styles.colors[color].root,\n (loading || (href && (disabled || loading))) && \"pointer-events-none\",\n loading && (showTextWhileLoading ? \"[&>*:not([data-icon=loading]):not([data-text])]:hidden\" : \"[&>*:not([data-icon=loading])]:invisible\"),\n className,\n )}\n >\n {/* Leading icon */}\n {isValidElement(IconLeading) && IconLeading}\n {isReactComponent(IconLeading) && React.createElement(IconLeading, { 'data-icon': 'leading', className: styles.common.icon } as Record<string, unknown>)}\n\n {loading && (\n <svg\n fill=\"none\"\n data-icon=\"loading\"\n viewBox=\"0 0 20 20\"\n className={cx(styles.common.icon, !showTextWhileLoading && \"absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2\")}\n >\n {/* Background circle */}\n <circle className=\"stroke-current opacity-30\" cx=\"10\" cy=\"10\" r=\"8\" fill=\"none\" strokeWidth=\"2\" />\n {/* Spinning circle */}\n <circle\n className=\"origin-center animate-spin stroke-current\"\n cx=\"10\"\n cy=\"10\"\n r=\"8\"\n fill=\"none\"\n strokeWidth=\"2\"\n strokeDasharray=\"12.5 50\"\n strokeLinecap=\"round\"\n />\n </svg>\n )}\n\n {children && (\n <span data-text className={cx(\"transition-inherit-all\", !noTextPadding && \"px-0.5\")}>\n {children}\n </span>\n )}\n\n {/* Trailing icon */}\n {isValidElement(IconTrailing) && IconTrailing}\n {isReactComponent(IconTrailing) && React.createElement(IconTrailing, { 'data-icon': 'trailing', className: styles.common.icon } as Record<string, unknown>)}\n </Component>\n );\n};\n\nimport { registerThemeVariant } from '../../../lib/component-registry';\nregisterThemeVariant('button', 'balance', Button);\n","\"use client\";\n\nimport { type ComponentType, type HTMLAttributes, type Ref, createContext, useContext } from \"react\";\nimport { HelpCircle, InfoCircle } from \"@untitledui/icons\";\nimport type { InputProps as AriaInputProps, TextFieldProps as AriaTextFieldProps } from \"react-aria-components\";\nimport { Group as AriaGroup, Input as AriaInput, TextField as AriaTextField } from \"react-aria-components\";\nimport { HintText } from './hint-text';\nimport { Label } from './label';\nimport { Tooltip, TooltipTrigger } from '../tooltip/tooltip';\nimport { cx, sortCx } from '../../../utils/cx';\n\nexport interface InputBaseProps extends AriaTextFieldProps {\n tooltip?: string;\n size?: \"sm\" | \"md\";\n placeholder?: string;\n iconClassName?: string;\n inputClassName?: string;\n wrapperClassName?: string;\n tooltipClassName?: string;\n shortcut?: string | boolean;\n ref?: Ref<HTMLInputElement>;\n groupRef?: Ref<HTMLDivElement>;\n icon?: ComponentType<HTMLAttributes<HTMLOrSVGElement>>;\n label?: string;\n hint?: string;\n}\n\nconst TextFieldContext = createContext<Partial<InputBaseProps>>({});\n\nexport const InputBase = ({\n ref,\n tooltip,\n shortcut,\n groupRef,\n size = \"sm\",\n isInvalid,\n isDisabled,\n icon: Icon,\n placeholder,\n wrapperClassName,\n tooltipClassName,\n inputClassName,\n iconClassName,\n ...inputProps\n}: Omit<InputBaseProps, \"label\" | \"hint\" | \"isRequired\">) => {\n const hasTrailingIcon = tooltip || isInvalid;\n const hasLeadingIcon = Icon;\n const context = useContext(TextFieldContext);\n const inputSize = context?.size || size;\n\n const sizes = sortCx({\n sm: {\n root: cx(\"px-3 py-2.5\", hasTrailingIcon && \"pr-9\", hasLeadingIcon && \"pl-10\"),\n iconLeading: \"left-3\",\n iconTrailing: \"right-3\",\n shortcut: \"pr-2.5\",\n },\n md: {\n root: cx(\"px-3.5 py-3\", hasTrailingIcon && \"pr-9.5\", hasLeadingIcon && \"pl-10.5\"),\n iconLeading: \"left-3.5\",\n iconTrailing: \"right-3.5\",\n shortcut: \"pr-3\",\n },\n });\n\n return (\n <AriaGroup\n {...{ isDisabled, isInvalid }}\n ref={groupRef}\n className={({ isFocusWithin, isDisabled, isInvalid }) =>\n cx(\n \"relative flex w-full flex-row place-content-center place-items-center rounded-sm bg-white ring-1 ring-secondary transition-shadow duration-100 ease-linear ring-inset\",\n isFocusWithin && !isDisabled && \"ring-2 ring-focus-ring\",\n isDisabled && \"cursor-not-allowed bg-primary ring-secondary\",\n isInvalid && \"ring-error_subtle\",\n isInvalid && isFocusWithin && \"ring-2 ring-error\",\n context?.wrapperClassName,\n wrapperClassName,\n )\n }\n >\n {Icon && (\n <Icon\n className={cx(\n \"pointer-events-none absolute size-5 text-secondary\",\n isDisabled && \"text-border-secondary\",\n sizes[inputSize].iconLeading,\n context?.iconClassName,\n iconClassName,\n )}\n />\n )}\n\n <AriaInput\n {...(inputProps as AriaInputProps)}\n ref={ref}\n placeholder={placeholder}\n className={cx(\n \"m-0 w-full bg-transparent text-base font-body text-fg-primary ring-0 outline-hidden placeholder:text-secondary autofill:rounded-sm autofill:text-fg-primary\",\n isDisabled && \"cursor-not-allowed text-secondary\",\n sizes[inputSize].root,\n context?.inputClassName,\n inputClassName,\n )}\n />\n\n {tooltip && !isInvalid && (\n <Tooltip title={tooltip} placement=\"top\">\n <TooltipTrigger\n className={cx(\n \"absolute cursor-pointer text-secondary transition duration-200 hover:text-fg-primary focus:text-fg-primary\",\n sizes[inputSize].iconTrailing,\n context?.tooltipClassName,\n tooltipClassName,\n )}\n >\n <HelpCircle className=\"size-4\" />\n </TooltipTrigger>\n </Tooltip>\n )}\n\n {isInvalid && (\n <InfoCircle\n className={cx(\n \"pointer-events-none absolute size-4 text-error\",\n sizes[inputSize].iconTrailing,\n )}\n />\n )}\n\n {shortcut && (\n <kbd\n className={cx(\n \"pointer-events-none absolute flex h-5 items-center justify-center rounded bg-utility-gray-50 px-1.5 text-xs font-medium text-tertiary shadow-xs ring-1 ring-inset ring-utility-gray-200\",\n sizes[inputSize].shortcut,\n )}\n >\n {shortcut === true ? \"⌘K\" : shortcut}\n </kbd>\n )}\n </AriaGroup>\n );\n};\n\nexport const Input = ({\n label,\n hint,\n size,\n isInvalid,\n isDisabled,\n isRequired,\n ...props\n}: InputBaseProps) => {\n const textFieldContext = { size, wrapperClassName: props.wrapperClassName, inputClassName: props.inputClassName, iconClassName: props.iconClassName, tooltipClassName: props.tooltipClassName };\n\n return (\n <TextFieldContext.Provider value={textFieldContext}>\n <AriaTextField\n {...({ isInvalid, isDisabled, isRequired } as AriaTextFieldProps)}\n className=\"flex flex-col gap-1.5\"\n >\n {label && <Label>{label}</Label>}\n <InputBase {...props} size={size} isInvalid={isInvalid} isDisabled={isDisabled} />\n {hint && <HintText>{hint}</HintText>}\n </AriaTextField>\n </TextFieldContext.Provider>\n );\n};\n\nimport { registerThemeVariant } from '../../../lib/component-registry';\nregisterThemeVariant('input', 'aman', Input);\n","\"use client\";\n\nimport type { TextAreaProps as AriaTextAreaProps, TextFieldProps as AriaTextFieldProps } from \"react-aria-components\";\nimport { TextArea as AriaTextArea, TextField as AriaTextField } from \"react-aria-components\";\nimport { HintText } from '../input/hint-text';\nimport { Label } from '../input/label';\nimport { cx } from '../../../utils/cx';\n\nexport interface TextareaProps extends AriaTextFieldProps {\n label?: string;\n hint?: string;\n placeholder?: string;\n rows?: number;\n className?: string;\n}\n\nexport const TextArea = ({\n label,\n hint,\n placeholder,\n rows = 4,\n isInvalid,\n isDisabled,\n isRequired,\n className,\n ...props\n}: TextareaProps) => {\n return (\n <AriaTextField\n {...({ isInvalid, isDisabled, isRequired } as AriaTextFieldProps)}\n className=\"flex flex-col gap-1.5\"\n >\n {label && <Label>{label}</Label>}\n <AriaTextArea\n {...(props as AriaTextAreaProps)}\n rows={rows}\n placeholder={placeholder}\n className={cx(\n \"w-full rounded-sm bg-white px-3 py-2.5 text-base font-body text-fg-primary ring-1 ring-secondary ring-inset placeholder:text-secondary outline-none transition-shadow duration-100 ease-linear\",\n \"focus:ring-2 focus:ring-focus-ring\",\n isDisabled && \"cursor-not-allowed bg-primary text-secondary ring-secondary\",\n isInvalid && \"ring-error_subtle focus:ring-2 focus:ring-error\",\n className,\n )}\n />\n {hint && <HintText>{hint}</HintText>}\n </AriaTextField>\n );\n};\n\nimport { registerThemeVariant } from '../../../lib/component-registry';\nregisterThemeVariant('textarea', 'aman', TextArea);\n","\"use client\";\n\nimport React from \"react\";\nimport { ChevronDown } from \"@untitledui/icons\";\nimport {\n Button as AriaButton,\n ListBox as AriaListBox,\n Popover as AriaPopover,\n Select as AriaSelect,\n SelectValue as AriaSelectValue,\n type SelectProps as AriaSelectProps,\n} from \"react-aria-components\";\nimport { HintText } from '../input/hint-text';\nimport { Label } from '../input/label';\nimport { cx } from '../../../utils/cx';\n\nexport interface SelectProps<T extends object> extends Omit<AriaSelectProps<T>, 'children'> {\n label?: string;\n hint?: string;\n placeholder?: string;\n children: React.ReactNode;\n className?: string;\n}\n\nexport function Select<T extends object>({\n label,\n hint,\n placeholder = \"Select an option\",\n isInvalid,\n isDisabled,\n isRequired,\n children,\n className,\n ...props\n}: SelectProps<T>) {\n return (\n <AriaSelect\n {...props}\n isInvalid={isInvalid}\n isDisabled={isDisabled}\n isRequired={isRequired}\n className={cx(\"flex flex-col gap-1.5\", className)}\n >\n {label && <Label>{label}</Label>}\n <AriaButton\n className={({ isFocusVisible, isDisabled }) =>\n cx(\n \"flex items-center justify-between w-full rounded-sm bg-white px-3 py-2.5 text-base font-body text-fg-primary shadow-sm ring-1 ring-secondary ring-inset transition-shadow duration-100 ease-linear\",\n isFocusVisible && !isDisabled && \"ring-2 ring-focus-ring\",\n isDisabled && \"cursor-not-allowed bg-primary text-secondary ring-secondary\",\n isInvalid && \"ring-error_subtle\",\n )\n }\n >\n <AriaSelectValue className=\"flex-1 text-left placeholder-shown:text-secondary\">\n {({ selectedText }) => selectedText || placeholder}\n </AriaSelectValue>\n <ChevronDown className=\"size-5 text-secondary\" />\n </AriaButton>\n {hint && <HintText>{hint}</HintText>}\n <AriaPopover\n className=\"w-[--trigger-width] rounded-sm bg-white shadow-lg ring-1 ring-secondary overflow-auto max-h-60\"\n >\n <AriaListBox className=\"outline-none p-1\">\n {children}\n </AriaListBox>\n </AriaPopover>\n </AriaSelect>\n );\n}\n\nimport { registerThemeVariant } from '../../../lib/component-registry';\nregisterThemeVariant('select', 'aman', Select);\n","import React from 'react';\n\nconst defaultClassName = 'w-5 h-5 flex-shrink-0';\n\ninterface SocialIconProps {\n platform: string;\n className?: string;\n}\n\nconst FacebookIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M24 12.073c0-6.627-5.373-12-12-12s-12 5.373-12 12c0 5.99 4.388 10.954 10.125 11.854v-8.385H7.078v-3.47h3.047V9.43c0-3.007 1.792-4.669 4.533-4.669 1.312 0 2.686.235 2.686.235v2.953H15.83c-1.491 0-1.956.925-1.956 1.874v2.25h3.328l-.532 3.47h-2.796v8.385C19.612 23.027 24 18.062 24 12.073z\" />\n </svg>\n);\n\nconst InstagramIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M12 2.163c3.204 0 3.584.012 4.85.07 3.252.148 4.771 1.691 4.919 4.919.058 1.265.069 1.645.069 4.849 0 3.205-.012 3.584-.069 4.849-.149 3.225-1.664 4.771-4.919 4.919-1.266.058-1.644.07-4.85.07-3.204 0-3.584-.012-4.849-.07-3.26-.149-4.771-1.699-4.919-4.92-.058-1.265-.07-1.644-.07-4.849 0-3.204.013-3.583.07-4.849.149-3.227 1.664-4.771 4.919-4.919 1.266-.057 1.645-.069 4.849-.069zm0-2.163c-3.259 0-3.667.014-4.947.072-4.358.2-6.78 2.618-6.98 6.98-.059 1.281-.073 1.689-.073 4.948 0 3.259.014 3.668.072 4.948.2 4.358 2.618 6.78 6.98 6.98 1.281.058 1.689.072 4.948.072 3.259 0 3.668-.014 4.948-.072 4.354-.2 6.782-2.618 6.979-6.98.059-1.28.073-1.689.073-4.948 0-3.259-.014-3.667-.072-4.947-.196-4.354-2.617-6.78-6.979-6.98-1.281-.059-1.69-.073-4.949-.073zm0 5.838c-3.403 0-6.162 2.759-6.162 6.162s2.759 6.163 6.162 6.163 6.162-2.759 6.162-6.163c0-3.403-2.759-6.162-6.162-6.162zm0 10.162c-2.209 0-4-1.79-4-4 0-2.209 1.791-4 4-4s4 1.791 4 4c0 2.21-1.791 4-4 4zm6.406-11.845c-.796 0-1.441.645-1.441 1.44s.645 1.44 1.441 1.44c.795 0 1.439-.645 1.439-1.44s-.644-1.44-1.439-1.44z\" />\n </svg>\n);\n\nconst YouTubeIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M23.498 6.186a3.016 3.016 0 0 0-2.122-2.136C19.505 3.545 12 3.545 12 3.545s-7.505 0-9.377.505A3.017 3.017 0 0 0 .502 6.186C0 8.07 0 12 0 12s0 3.93.502 5.814a3.016 3.016 0 0 0 2.122 2.136c1.871.505 9.376.505 9.376.505s7.505 0 9.377-.505a3.015 3.015 0 0 0 2.122-2.136C24 15.93 24 12 24 12s0-3.93-.502-5.814zM9.545 15.568V8.432L15.818 12l-6.273 3.568z\" />\n </svg>\n);\n\nconst GoogleIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z\" />\n <path d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\" />\n <path d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z\" />\n <path d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\" />\n </svg>\n);\n\nconst TikTokIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M19.59 6.69a4.83 4.83 0 0 1-3.77-4.25V2h-3.45v13.67a2.89 2.89 0 0 1-5.2 1.74 2.89 2.89 0 0 1 2.31-4.64 2.93 2.93 0 0 1 .88.13V9.4a6.84 6.84 0 0 0-1-.05A6.33 6.33 0 0 0 5 20.1a6.34 6.34 0 0 0 10.86-4.43v-7a8.16 8.16 0 0 0 4.77 1.52v-3.4a4.85 4.85 0 0 1-1-.1z\" />\n </svg>\n);\n\nconst LinkedInIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433c-1.144 0-2.063-.926-2.063-2.065 0-1.138.92-2.063 2.063-2.063 1.14 0 2.064.925 2.064 2.063 0 1.139-.925 2.065-2.064 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.222 0h.003z\" />\n </svg>\n);\n\nconst TwitterIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z\" />\n </svg>\n);\n\nconst PinterestIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M12.017 0C5.396 0 .029 5.367.029 11.987c0 5.079 3.158 9.417 7.618 11.162-.105-.949-.199-2.403.041-3.439.219-.937 1.406-5.957 1.406-5.957s-.359-.72-.359-1.781c0-1.663.967-2.911 2.168-2.911 1.024 0 1.518.769 1.518 1.688 0 1.029-.653 2.567-.992 3.992-.285 1.193.6 2.165 1.775 2.165 2.128 0 3.768-2.245 3.768-5.487 0-2.861-2.063-4.869-5.008-4.869-3.41 0-5.409 2.562-5.409 5.199 0 1.033.394 2.143.889 2.741.099.12.112.225.085.345-.09.375-.293 1.199-.334 1.363-.053.225-.172.271-.401.165-1.495-.69-2.433-2.878-2.433-4.646 0-3.776 2.748-7.252 7.92-7.252 4.158 0 7.392 2.967 7.392 6.923 0 4.135-2.607 7.462-6.233 7.462-1.214 0-2.354-.629-2.758-1.379l-.749 2.848c-.269 1.045-1.004 2.352-1.498 3.146 1.123.345 2.306.535 3.55.535 6.607 0 11.985-5.365 11.985-11.987C23.97 5.39 18.592.026 11.985.026L12.017 0z\" />\n </svg>\n);\n\nconst YelpIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M20.16 12.594l-4.995 1.33c-.96.26-1.96-.19-2.23-1.11l-.894-3.39c-.27-.99.31-2.04 1.31-2.42l4.995-1.33c.96-.26 1.96.19 2.23 1.11l.894 3.39c.27.99-.31 2.04-1.31 2.42zM12 1C5.925 1 1 5.925 1 12s4.925 11 11 11 11-4.925 11-11S18.075 1 12 1z\" />\n </svg>\n);\n\nconst TripAdvisorIcon = ({ className = defaultClassName }: { className?: string }) => (\n <svg className={className} fill=\"currentColor\" viewBox=\"0 0 24 24\">\n <path d=\"M12.006 4.295c-2.67 0-5.338.784-7.645 2.353H0l2.337 4.598a11.994 11.994 0 0 0 9.669 5.107 11.994 11.994 0 0 0 9.669-5.107L24 6.648h-4.35a12.037 12.037 0 0 0-7.644-2.353zM12 6.255c1.531 0 2.764 1.233 2.764 2.764S13.531 11.783 12 11.783 9.236 10.55 9.236 9.019s1.233-2.764 2.764-2.764zM12 15.021c-2.667 0-5.338-.784-7.645-2.352H0l2.337 4.598a11.994 11.994 0 0 0 9.669 5.107 11.994 11.994 0 0 0 9.669-5.107L24 15.021h-4.35A12.037 12.037 0 0 1 12 15.021z\" />\n </svg>\n);\n\n/** Renders the icon for a given platform (facebook, instagram, tiktok, etc.). */\nexport function SocialIcon({ platform, className = defaultClassName }: SocialIconProps): React.ReactNode {\n const p = platform.toLowerCase();\n switch (p) {\n case 'facebook':\n return <FacebookIcon className={className} />;\n case 'instagram':\n return <InstagramIcon className={className} />;\n case 'youtube':\n return <YouTubeIcon className={className} />;\n case 'google':\n case 'google_my_business':\n case 'google_reviews':\n return <GoogleIcon className={className} />;\n case 'tiktok':\n return <TikTokIcon className={className} />;\n case 'linkedin':\n return <LinkedInIcon className={className} />;\n case 'twitter':\n return <TwitterIcon className={className} />;\n case 'pinterest':\n return <PinterestIcon className={className} />;\n case 'yelp':\n return <YelpIcon className={className} />;\n case 'tripadvisor':\n return <TripAdvisorIcon className={className} />;\n default:\n return null;\n }\n}\n\n/** Returns the icon element for a platform (for use in map/render). */\nexport function getSocialIcon(platform: string, className?: string): React.ReactNode {\n return <SocialIcon platform={platform} className={className ?? defaultClassName} />;\n}\n\nexport {\n FacebookIcon,\n InstagramIcon,\n YouTubeIcon,\n GoogleIcon,\n TikTokIcon,\n LinkedInIcon,\n TwitterIcon,\n PinterestIcon,\n YelpIcon,\n TripAdvisorIcon,\n};\n","\"use client\";\n\nimport type { CSSProperties, ComponentPropsWithRef, HTMLAttributes, KeyboardEvent, ReactNode, Ref } from \"react\";\nimport { cloneElement, createContext, isValidElement, useCallback, useContext, useEffect, useRef, useSyncExternalStore } from \"react\";\nimport useEmblaCarousel, { type UseEmblaCarouselType } from \"embla-carousel-react\";\nimport { cx } from '../../../utils/cx';\n\ntype CarouselApi = UseEmblaCarouselType[1];\ntype UseCarouselParameters = Parameters<typeof useEmblaCarousel>;\ntype CarouselOptions = UseCarouselParameters[0];\ntype CarouselPlugin = UseCarouselParameters[1];\n\ntype CarouselProps = {\n /** The options for the Embla carousel. */\n opts?: CarouselOptions;\n /** The plugins for the Embla carousel. */\n plugins?: CarouselPlugin;\n /** The orientation of the carousel. */\n orientation?: \"horizontal\" | \"vertical\";\n /** The function to set the API for the carousel. */\n setApi?: (api: CarouselApi) => void;\n};\n\ntype CarouselContextProps = CarouselProps & {\n /** The ref of the carousel. */\n carouselRef: ReturnType<typeof useEmblaCarousel>[0];\n /** The API of the carousel. */\n api: ReturnType<typeof useEmblaCarousel>[1];\n /** The function to scroll the carousel to the previous slide. */\n scrollPrev: () => void;\n /** The function to scroll the carousel to the next slide. */\n scrollNext: () => void;\n /** Whether the carousel can scroll to the previous slide. */\n canScrollPrev: boolean;\n /** Whether the carousel can scroll to the next slide. */\n canScrollNext: boolean;\n /** The index of the selected slide. */\n selectedIndex: number;\n /** The scroll snaps of the carousel. */\n scrollSnaps: number[];\n};\n\nexport const CarouselContext = createContext<CarouselContextProps | null>(null);\n\nexport const useCarousel = () => {\n const context = useContext(CarouselContext);\n\n if (!context) {\n throw new Error(\"The `useCarousel` hook must be used within a <Carousel />\");\n }\n\n return context;\n};\n\n// Stable default snapshot for SSR - must be a constant to avoid infinite loops\nconst DEFAULT_SNAPSHOT = {\n canScrollPrev: false,\n canScrollNext: false,\n selectedIndex: 0,\n scrollSnaps: [] as number[],\n};\n\nconst CarouselRoot = ({ orientation = \"horizontal\", opts, setApi, plugins, className, children, ...props }: ComponentPropsWithRef<\"div\"> & CarouselProps) => {\n const [carouselRef, api] = useEmblaCarousel(\n {\n ...opts,\n axis: orientation === \"horizontal\" ? \"x\" : \"y\",\n },\n plugins,\n );\n \n // Cache the snapshot object to avoid creating new objects on every call\n const snapshotRef = useRef(DEFAULT_SNAPSHOT);\n \n const getSnapshot = useCallback(() => {\n if (!api) {\n return DEFAULT_SNAPSHOT;\n }\n\n const canScrollPrev = api.canScrollPrev();\n const canScrollNext = api.canScrollNext();\n const selectedIndex = api.selectedScrollSnap();\n const scrollSnaps = api.scrollSnapList();\n \n // Only create a new object if values have changed\n if (\n snapshotRef.current.canScrollPrev !== canScrollPrev ||\n snapshotRef.current.canScrollNext !== canScrollNext ||\n snapshotRef.current.selectedIndex !== selectedIndex ||\n snapshotRef.current.scrollSnaps.length !== scrollSnaps.length ||\n snapshotRef.current.scrollSnaps.some((val, idx) => val !== scrollSnaps[idx])\n ) {\n snapshotRef.current = {\n canScrollPrev,\n canScrollNext,\n selectedIndex,\n scrollSnaps,\n };\n }\n \n return snapshotRef.current;\n }, [api]);\n\n // Stable server snapshot - returns the same cached object reference for SSR\n const getServerSnapshot = useCallback(() => DEFAULT_SNAPSHOT, []);\n\n const subscribe = useCallback(\n (onStoreChange: () => void) => {\n if (!api) return () => {};\n\n api.on(\"select\", onStoreChange);\n api.on(\"reInit\", onStoreChange);\n\n return () => {\n api.off(\"select\", onStoreChange);\n api.off(\"reInit\", onStoreChange);\n };\n },\n [api],\n );\n\n const { canScrollPrev, canScrollNext, selectedIndex, scrollSnaps } = useSyncExternalStore(subscribe, getSnapshot, getServerSnapshot);\n\n const scrollPrev = useCallback(() => {\n api?.scrollPrev();\n }, [api]);\n\n const scrollNext = useCallback(() => {\n api?.scrollNext();\n }, [api]);\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent<HTMLDivElement>) => {\n if (event.key === \"ArrowLeft\") {\n event.preventDefault();\n scrollPrev();\n } else if (event.key === \"ArrowRight\") {\n event.preventDefault();\n scrollNext();\n }\n },\n [scrollPrev, scrollNext],\n );\n\n useEffect(() => {\n if (!api || !setApi) return;\n\n setApi(api);\n }, [api, setApi]);\n\n return (\n <CarouselContext.Provider\n value={{\n carouselRef,\n api: api,\n opts,\n orientation: orientation || (opts?.axis === \"y\" ? \"vertical\" : \"horizontal\"),\n scrollPrev,\n scrollNext,\n canScrollPrev,\n canScrollNext,\n selectedIndex,\n scrollSnaps,\n }}\n >\n <div onKeyDownCapture={handleKeyDown} className={cx(\"relative\", className)} role=\"region\" aria-roledescription=\"carousel\" {...props}>\n {children}\n </div>\n </CarouselContext.Provider>\n );\n};\n\ninterface CarouselContentProps extends ComponentPropsWithRef<\"div\"> {\n /** The class name of the content. */\n className?: string;\n /** Whether to hide the overflow. */\n overflowHidden?: boolean;\n}\n\nconst CarouselContent = ({ className, overflowHidden = true, ...props }: CarouselContentProps) => {\n const { carouselRef, orientation } = useCarousel();\n\n return (\n <div ref={carouselRef} className={cx(\"h-full w-full\", overflowHidden && \"overflow-hidden\")}>\n <div className={cx(\"flex max-h-full\", orientation === \"horizontal\" ? \"\" : \"flex-col\", className)} {...props} />\n </div>\n );\n};\n\nconst CarouselItem = ({ className, ...props }: ComponentPropsWithRef<\"div\">) => {\n return <div role=\"group\" aria-roledescription=\"slide\" className={cx(\"min-w-0 shrink-0 grow-0 basis-full\", className)} {...props} />;\n};\n\ninterface TriggerRenderProps {\n isDisabled: boolean;\n onClick: () => void;\n}\n\ninterface TriggerProps {\n /** The ref of the trigger. */\n ref?: Ref<HTMLButtonElement>;\n /** If true, the child element will be cloned and passed down the prop of the trigger. */\n asChild?: boolean;\n /** The direction of the trigger. */\n direction: \"prev\" | \"next\";\n /** The children of the trigger. Can be a render prop or a valid element. */\n children: ReactNode | ((props: TriggerRenderProps) => ReactNode);\n /** The style of the trigger. */\n style?: CSSProperties;\n /** The class name of the trigger. */\n className?: string | ((args: { isDisabled: boolean }) => string);\n}\n\nconst Trigger = ({ className, children, asChild, direction, style, ...props }: TriggerProps) => {\n const { scrollPrev, canScrollNext, scrollNext, canScrollPrev } = useCarousel();\n\n const isDisabled = direction === \"prev\" ? !canScrollPrev : !canScrollNext;\n\n const handleClick = () => {\n if (isDisabled) return;\n\n if (direction === \"prev\") {\n scrollPrev();\n } else {\n scrollNext();\n }\n };\n\n const computedClassName = typeof className === \"function\" ? className({ isDisabled }) : className;\n\n const defaultAriaLabel = direction === \"prev\" ? \"Previous slide\" : \"Next slide\";\n\n // If the children is a render prop, we need to pass the necessary props to the render prop.\n if (typeof children === \"function\") {\n return <>{children({ isDisabled, onClick: handleClick })}</>;\n }\n\n // If the children is a valid element, we need to clone it and pass the necessary props to the cloned element.\n if (asChild && isValidElement(children)) {\n return cloneElement(children, {\n onClick: handleClick,\n disabled: isDisabled,\n \"aria-label\": defaultAriaLabel,\n style: { ...(children.props as HTMLAttributes<HTMLElement>).style, ...style },\n className: [computedClassName, (children.props as HTMLAttributes<HTMLElement>).className].filter(Boolean).join(\" \") || undefined,\n } as HTMLAttributes<HTMLElement>);\n }\n\n return (\n <button aria-label={defaultAriaLabel} disabled={isDisabled} className={computedClassName} onClick={handleClick} {...props}>\n {children}\n </button>\n );\n};\n\nconst CarouselPrevTrigger = (props: Omit<TriggerProps, \"direction\">) => <Trigger {...props} direction=\"prev\" />;\n\nconst CarouselNextTrigger = (props: Omit<TriggerProps, \"direction\">) => <Trigger {...props} direction=\"next\" />;\n\ninterface CarouselIndicatorRenderProps {\n isSelected: boolean;\n onClick: () => void;\n}\n\ninterface CarouselIndicatorProps {\n /** The index of the indicator. */\n index: number;\n /** If true, the child element will be cloned and passed down the prop of the indicator. */\n asChild?: boolean;\n /** If true, the indicator will be selected. */\n isSelected?: boolean;\n /** The children of the indicator. Can be a render prop or a valid element. */\n children?: ReactNode | ((props: CarouselIndicatorRenderProps) => ReactNode);\n /** The style of the indicator. */\n style?: CSSProperties;\n /** The class name of the indicator. */\n className?: string | ((args: { isSelected: boolean }) => string);\n}\n\nconst CarouselIndicator = ({ index, isSelected = false, children, asChild, className, style }: CarouselIndicatorProps) => {\n const { api, selectedIndex } = useCarousel();\n\n isSelected = isSelected || selectedIndex === index;\n\n const handleClick = () => {\n api?.scrollTo(index);\n };\n const computedClassName = typeof className === \"function\" ? className({ isSelected }) : className;\n\n const defaultAriaLabel = \"Go to slide\" + (index + 1);\n\n // If the children is a render prop, we need to pass the necessary props to the render prop.\n if (typeof children === \"function\") {\n return <>{children({ isSelected, onClick: handleClick })}</>;\n }\n\n // If the children is a valid element, we need to clone it and pass the necessary props to the cloned element.\n if (asChild && isValidElement(children)) {\n return cloneElement(children, {\n onClick: handleClick,\n \"aria-label\": defaultAriaLabel,\n \"aria-current\": isSelected ? \"true\" : undefined,\n style: { ...(children.props as HTMLAttributes<HTMLElement>).style, ...style },\n className: [computedClassName, (children.props as HTMLAttributes<HTMLElement>).className].filter(Boolean).join(\" \") || undefined,\n } as HTMLAttributes<HTMLElement>);\n }\n\n return (\n <button aria-label={defaultAriaLabel} aria-current={isSelected ? \"true\" : undefined} className={computedClassName} onClick={handleClick}>\n {children}\n </button>\n );\n};\n\ninterface CarouselIndicatorGroupProps extends Omit<HTMLAttributes<HTMLDivElement>, \"children\"> {\n children: ReactNode | ((props: { index: number }) => ReactNode);\n className?: string;\n}\n\nconst CarouselIndicatorGroup = ({ children, ...props }: CarouselIndicatorGroupProps) => {\n const { scrollSnaps } = useCarousel();\n\n // If the children is a render prop, we need to pass the index to the render prop.\n if (typeof children === \"function\") {\n return <nav {...props}>{scrollSnaps.map((index) => children({ index }))}</nav>;\n }\n\n return <nav {...props}>{children}</nav>;\n};\n\nexport const Carousel = {\n Root: CarouselRoot,\n Content: CarouselContent,\n Item: CarouselItem,\n PrevTrigger: CarouselPrevTrigger,\n NextTrigger: CarouselNextTrigger,\n IndicatorGroup: CarouselIndicatorGroup,\n Indicator: CarouselIndicator,\n};\n","\"use client\";\n\nimport React from 'react';\nimport { Carousel } from './carousel';\nimport { ChevronLeft, ChevronRight } from '@untitledui/icons';\n\ninterface CarouselSectionWrapperProps {\n title: string;\n subtitle?: string;\n hasItems: boolean;\n children: React.ReactNode;\n emptyMessage?: string;\n}\n\nexport const CarouselSectionWrapper = ({\n title,\n subtitle,\n hasItems,\n children,\n emptyMessage = \"No items available\",\n}: CarouselSectionWrapperProps) => {\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {hasItems ? (\n <Carousel.Root opts={{ align: \"start\", loop: true }}>\n <div className=\"flex items-center justify-between mb-12\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n <div className=\"flex gap-2\">\n <Carousel.PrevTrigger className=\"rounded-full p-2 border border-secondary hover:bg-primary_hover transition-colors disabled:opacity-30 disabled:cursor-not-allowed\">\n <ChevronLeft className=\"w-6 h-6 text-fg-primary\" />\n </Carousel.PrevTrigger>\n <Carousel.NextTrigger className=\"rounded-full p-2 border border-secondary hover:bg-primary_hover transition-colors disabled:opacity-30 disabled:cursor-not-allowed\">\n <ChevronRight className=\"w-6 h-6 text-fg-primary\" />\n </Carousel.NextTrigger>\n </div>\n </div>\n \n <Carousel.Content className=\"-ml-4\">\n {children}\n </Carousel.Content>\n </Carousel.Root>\n ) : (\n <>\n <div className=\"mb-12\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-6 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">{emptyMessage}</p>\n </div>\n </>\n )}\n </div>\n </section>\n );\n};\n","'use client';\n\nimport { useEffect } from 'react';\n\ninterface VideoModalProps {\n isOpen: boolean;\n onClose: () => void;\n videoUrl: string;\n}\n\nexport function VideoModal({ isOpen, onClose, videoUrl }: VideoModalProps) {\n // Prevent body scroll when modal is open\n useEffect(() => {\n if (isOpen) {\n document.body.style.overflow = 'hidden';\n } else {\n document.body.style.overflow = '';\n }\n return () => {\n document.body.style.overflow = '';\n };\n }, [isOpen]);\n\n if (!isOpen) return null;\n\n return (\n <div \n className=\"fixed inset-0 z-[60] flex items-center justify-center p-4 backdrop-blur-md bg-black/50\"\n onClick={onClose}\n >\n {/* Close button */}\n <button\n onClick={onClose}\n className=\"absolute top-4 right-4 md:top-8 md:right-8 text-white text-4xl md:text-5xl hover:text-gray-300 z-10 transition-colors\"\n aria-label=\"Close video\"\n >\n ×\n </button>\n \n {/* Video container */}\n <div \n className=\"relative w-full max-w-5xl aspect-video\"\n onClick={(e) => e.stopPropagation()}\n >\n <iframe\n src={videoUrl}\n title=\"Video player\"\n className=\"w-full h-full rounded-lg shadow-2xl\"\n allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n allowFullScreen\n />\n </div>\n </div>\n );\n}\n\n","'use client';\n\ninterface VideoPlayButtonProps {\n onClick: () => void;\n className?: string;\n}\n\nexport function VideoPlayButton({ onClick, className = '' }: VideoPlayButtonProps) {\n return (\n <button\n onClick={onClick}\n className={`group flex items-center justify-center w-24 h-24 md:w-32 md:h-32 rounded-full bg-black/40 backdrop-blur-sm hover:bg-black/50 transition-all hover:scale-105 ${className}`}\n aria-label=\"Play video\"\n >\n <svg\n className=\"w-10 h-10 md:w-14 md:h-14 text-white group-hover:scale-110 transition-transform ml-1\"\n fill=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path d=\"M8 5v14l11-7z\" />\n </svg>\n </button>\n );\n}\n\n","'use client';\n\nimport React, { useEffect, useRef } from 'react';\n\nexport interface ModalProps {\n /** Whether the modal is open */\n isOpen: boolean;\n /** Called when the user requests close (button, Escape, or overlay click) */\n onClose: () => void;\n /** Optional title for the dialog (used for aria-labelledby) */\n title?: string;\n /** Optional id for the title element (must be set if title is set for a11y) */\n titleId?: string;\n /** Dialog content */\n children: React.ReactNode;\n /** Optional footer rendered below scrollable content (e.g. branding or action bars). */\n footer?: React.ReactNode;\n /**\n * Hide the built-in header bar and close button. Use when the content provides its own\n * title and close affordance (e.g. a form with its own header). Escape and overlay click\n * still close the dialog.\n */\n hideHeader?: boolean;\n /** Accessible name for the dialog when no visible title is rendered (i.e. when hideHeader is true). */\n ariaLabel?: string;\n /** Optional className for the overlay (backdrop) */\n overlayClassName?: string;\n /** Optional className for the dialog panel */\n panelClassName?: string;\n /** Optional max width class for the panel (default: max-w-md). Use max-w-lg, max-w-2xl, etc. */\n maxWidth?: 'sm' | 'md' | 'lg' | 'xl' | '2xl' | '3xl' | '4xl' | '5xl';\n}\n\nconst MAX_WIDTH_CLASSES: Record<NonNullable<ModalProps['maxWidth']>, string> = {\n sm: 'max-w-sm',\n md: 'max-w-md',\n lg: 'max-w-lg',\n xl: 'max-w-xl',\n '2xl': 'max-w-2xl',\n '3xl': 'max-w-3xl',\n '4xl': 'max-w-4xl',\n '5xl': 'max-w-5xl',\n};\n\n/**\n * Shared modal (dialog) component. Escape to close, aria-modal, overlay click to close, scroll lock, focus return on close.\n * Use for detail views, confirmations, and other overlay content. Renders in place (use a portal from the consumer if needed).\n * When `hideHeader` is true, provide an `aria-label` via `panelClassName` or ensure children supply a visible heading.\n */\nexport function Modal({\n isOpen,\n onClose,\n title,\n titleId = 'modal-title',\n children,\n footer,\n hideHeader = false,\n ariaLabel,\n overlayClassName,\n panelClassName,\n maxWidth = 'md',\n}: ModalProps) {\n const overlayRef = useRef<HTMLDivElement>(null);\n const closeButtonRef = useRef<HTMLButtonElement>(null);\n\n useEffect(() => {\n if (!isOpen) return;\n const previouslyFocused = document.activeElement as HTMLElement | null;\n // When hideHeader is true there is no close button ref; autoFocus on content handles focus.\n closeButtonRef.current?.focus();\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === 'Escape') onClose();\n };\n document.addEventListener('keydown', handleEscape);\n document.body.style.overflow = 'hidden';\n return () => {\n document.removeEventListener('keydown', handleEscape);\n document.body.style.overflow = '';\n previouslyFocused?.focus();\n };\n }, [isOpen, onClose]);\n\n if (!isOpen) return null;\n\n const maxWidthClass = MAX_WIDTH_CLASSES[maxWidth];\n\n return (\n <div\n ref={overlayRef}\n className={\n overlayClassName ??\n 'fixed inset-0 z-[200] flex items-center justify-center p-4 bg-black/50'\n }\n role=\"dialog\"\n aria-modal=\"true\"\n aria-label={ariaLabel}\n aria-labelledby={!ariaLabel && title && !hideHeader ? titleId : undefined}\n onClick={(e) => e.target === overlayRef.current && onClose()}\n >\n <div\n className={\n panelClassName ??\n `bg-primary border border-secondary rounded-lg shadow-xl w-full overflow-hidden ${maxWidthClass} max-h-[90vh] flex flex-col`\n }\n onClick={(e) => e.stopPropagation()}\n >\n {!hideHeader && (\n <div className=\"flex items-start justify-between gap-4 p-4 md:p-6 border-b border-secondary flex-shrink-0\">\n {title ? (\n <h2\n id={titleId}\n className=\"font-display text-lg font-normal text-fg-primary md:text-xl flex-1 min-w-0\"\n >\n {title}\n </h2>\n ) : (\n <span className=\"flex-1\" aria-hidden />\n )}\n <button\n ref={closeButtonRef}\n type=\"button\"\n onClick={onClose}\n className=\"shrink-0 p-1 text-fg-primary hover:text-brand-accent rounded focus:outline-none focus:ring-2 focus:ring-brand-accent\"\n aria-label=\"Close\"\n >\n <svg\n className=\"w-5 h-5\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n aria-hidden\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n </button>\n </div>\n )}\n <div className=\"overflow-y-auto flex-1 p-4 md:p-6\">{children}</div>\n {footer && <div className=\"flex-shrink-0 border-t border-secondary\">{footer}</div>}\n </div>\n </div>\n );\n}\n","import React from 'react';\nimport { Heart, Star01, Users01, Clock, CheckCircle } from '@untitledui/icons';\n\n/**\n * Icon mapping utility for converting icon string names to icon components.\n * Used across design system components to ensure consistent icon rendering.\n */\nexport const iconMap: Record<string, React.FC<{ className?: string }>> = {\n heart: Heart,\n star: Star01,\n users: Users01,\n clock: Clock,\n check: CheckCircle,\n};\n\n/**\n * Maps an icon (string, component, or ReactNode) to an icon component.\n * If it's already a component, returns it as-is.\n * If it's a string, looks it up in the iconMap.\n * If it's null or other ReactNode, returns undefined.\n */\nexport function mapIcon(icon: string | React.FC<{ className?: string }> | React.ReactNode | undefined | null): React.FC<{ className?: string }> | undefined {\n if (!icon) return undefined;\n if (typeof icon === 'function') return icon;\n if (typeof icon === 'string') return iconMap[icon.toLowerCase()];\n return undefined; // For other ReactNode types\n}\n\n","\"use client\";\n\nimport { useState } from \"react\";\nimport { ArrowRight } from \"@untitledui/icons\";\nimport { Button, PhotoWithFallback } from '../elements';\nimport { cx } from '../../utils/cx';\nimport type { Service } from '../../types/api/service';\n\n\ninterface ServicesHomeProps {\n services: Service[];\n label?: string;\n title?: string;\n subtitle?: string;\n viewAllText?: string;\n}\n\nexport const ServicesHome = ({\n services: servicesData,\n label = \"\",\n title = \"\",\n subtitle = \"\",\n viewAllText = \"View all services\",\n}: ServicesHomeProps) => {\n const services = Array.isArray(servicesData) ? servicesData.slice(0, 6) : [];\n const viewAllHref = \"/services\";\n \n const [internalSelectedId, setInternalSelectedId] = useState<string | undefined>(\n services.length > 0 ? services[0].id.toString() : undefined\n );\n\n const handleServiceClick = (serviceId: string) => {\n setInternalSelectedId(serviceId);\n };\n\n const currentSelectedId = internalSelectedId || (services.length > 0 ? services[0].id.toString() : undefined);\n const selectedService = services.find(s => s.id.toString() === currentSelectedId) || services[0];\n \n const getServiceDescription = (service: Service | undefined): string => {\n if (!service) return '';\n return service.summary || service.description_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n };\n\n return (\n <section className=\"overflow-hidden bg-primary py-16 md:py-24\">\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n <div className=\"flex w-full flex-col lg:max-w-3xl\">\n <span className=\"text-sm font-semibold text-brand-secondary md:text-md\">{label}</span>\n <h2 className=\"mt-3 text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n\n <div className=\"mt-12 grid grid-cols-1 gap-12 md:mt-16 md:gap-16 lg:grid-cols-5 lg:items-start\">\n {/* Left side - Service list */}\n <div className=\"lg:col-span-2\">\n <ul className=\"flex flex-col\">\n {services.map((service) => {\n const serviceId = service.id.toString();\n const isSelected = serviceId === currentSelectedId;\n return (\n <li key={service.id}>\n <div className=\"relative\">\n {isSelected && (\n <div className=\"absolute left-0 top-0 bottom-0 w-1 bg-brand-secondary rounded-r\" />\n )}\n <div \n className={cx(\n \"flex items-center py-4 pl-6 pr-4\",\n isSelected && \"pl-5\",\n \"hover:bg-primary_hover transition-colors cursor-pointer\"\n )}\n onClick={() => handleServiceClick(serviceId)}\n >\n <h3 className={cx(\n \"text-lg font-semibold\",\n isSelected ? \"text-brand-secondary\" : \"text-primary\"\n )}>\n {service.name}\n </h3>\n </div>\n </div>\n </li>\n );\n })}\n </ul>\n\n <div className=\"mt-4\">\n <Button\n color=\"link-color\"\n size=\"lg\"\n href={viewAllHref}\n iconTrailing={ArrowRight}\n >\n {viewAllText}\n </Button>\n </div>\n </div>\n\n {/* Right side - Featured service image */}\n {selectedService && (\n <div className=\"lg:col-span-3\">\n <div className=\"relative flex w-full items-center justify-center h-108 md:h-128\">\n <PhotoWithFallback\n item={selectedService}\n fallbackId={selectedService.id}\n alt={selectedService.name || \"Service image\"}\n className=\"absolute top-0 left-0 z-0 size-full object-cover\"\n />\n\n <div className=\"z-10 flex w-full items-center justify-center p-3 md:p-4\">\n <div className=\"w-[70%] rounded-xl bg-primary/30 px-4 pt-5 pb-6 ring-1 ring-alpha-white/30 backdrop-blur-[10px] ring-inset\">\n <h3 className=\"text-xl font-semibold text-white\">{selectedService.name}</h3>\n {getServiceDescription(selectedService) && (\n <p className=\"mt-2 text-md text-white/90\">{getServiceDescription(selectedService)}</p>\n )}\n </div>\n </div>\n </div>\n </div>\n )}\n </div>\n </div>\n </section>\n );\n};\n","import type { FC } from \"react\";\nimport { ArrowRight } from \"@untitledui/icons\";\nimport { Button } from '../elements';\nimport { FeatureTextFeaturedIconCard } from './feature-text';\nimport { mapIcon } from '../utils/icon-mapping';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\n\ninterface Value {\n id?: string;\n title: string;\n description: string;\n icon: string | FC<{ className?: string }>;\n href?: string;\n}\n\ninterface AboutHomeProps {\n companyInformation?: CompanyInformation | null;\n websitePhotos?: WebsitePhotos | null;\n title?: string;\n subtitle?: string;\n values?: Value[];\n ctaText?: string;\n}\n\n\nexport const AboutHome = ({\n companyInformation,\n title = \"\",\n subtitle = \"\",\n values = [],\n ctaText = \"\",\n}: AboutHomeProps) => {\n const description = companyInformation?.about_text_markdown || '';\n \n const firstValue = values && values.length > 0 ? values[0] : null;\n\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n <div className=\"grid grid-cols-1 gap-12 md:gap-16 lg:grid-cols-3\">\n {/* Left column */}\n <div className=\"max-w-3xl lg:col-span-1\">\n {firstValue?.icon && (() => {\n const IconComponent = mapIcon(firstValue.icon);\n return IconComponent ? (\n <>\n <div className=\"hidden md:flex\">\n <IconComponent className=\"size-14 text-brand-secondary\" />\n </div>\n <div className=\"flex md:hidden\">\n <IconComponent className=\"size-12 text-brand-secondary\" />\n </div>\n </>\n ) : null;\n })()}\n <h2 className=\"mt-5 text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n <p className=\"mt-4 text-lg text-tertiary md:mt-5\">\n {description || subtitle}\n </p>\n {ctaText && (\n <Button\n href=\"/about\"\n color=\"link-color\"\n size=\"lg\"\n className=\"mt-8\"\n iconTrailing={ArrowRight}\n >\n {ctaText}\n </Button>\n )}\n </div>\n\n {/* Right column - Feature cards */}\n {values && values.length > 0 && (\n <div className=\"lg:col-span-2\">\n <ul className=\"grid w-full grid-cols-1 gap-x-8 gap-y-6 sm:grid-flow-col sm:grid-cols-2 sm:grid-rows-2 md:gap-y-8 lg:grid-cols-2\">\n {values.map((value: Value, index: number) => {\n if (!value.icon) return null;\n const IconComponent = mapIcon(value.icon);\n if (!IconComponent) return null;\n \n return (\n <li key={value.id || index}>\n <FeatureTextFeaturedIconCard\n icon={IconComponent}\n title={value.title}\n subtitle={value.description}\n footer={\n value.href ? (\n <Button \n color=\"link-color\" \n size=\"lg\" \n href={value.href}\n iconTrailing={ArrowRight}\n >\n Learn more\n </Button>\n ) : undefined\n }\n />\n </li>\n );\n })}\n </ul>\n </div>\n )}\n </div>\n </div>\n </section>\n );\n};\n","import type { FC } from \"react\";\nimport { type ReactNode } from \"react\";\nimport Image from \"next/image\";\nimport { FeaturedIcon } from '../elements';\n\ninterface TextCentered {\n title: string;\n subtitle: string;\n footer?: ReactNode;\n}\n\nexport const FeatureTextCentered = ({ title, subtitle, footer }: TextCentered) => (\n <div className=\"flex max-w-sm flex-col items-center gap-4 text-center\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\nexport const FeatureTextLeft = ({ title, subtitle, footer }: TextCentered) => (\n <div className=\"flex max-w-sm flex-col gap-4\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\ninterface FeatureTextIcon extends TextCentered {\n icon: FC<{ className?: string }>;\n}\n\nexport const FeatureTextIconTopCentered = ({ icon: Icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex max-w-sm flex-col items-center gap-3 text-center md:gap-4\">\n <Icon className=\"size-6 text-icon-fg-brand\" />\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\nexport const FeatureTextIconTopLeft = ({ icon: Icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex max-w-sm flex-col gap-4\">\n <Icon className=\"size-6 text-icon-fg-brand\" />\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\nexport const FeatureTextIconLeft = ({ icon: Icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex max-w-140 gap-4\">\n <Icon className=\"size-6 shrink-0 text-icon-fg-brand\" />\n\n <div className=\"flex flex-col gap-4\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n </div>\n);\n\nexport const FeatureTextFeaturedIconTopCentered = ({\n color = \"gray\",\n theme = \"modern\",\n icon,\n title,\n subtitle,\n footer,\n}: FeatureTextIcon & {\n color?: \"brand\" | \"gray\" | \"success\" | \"warning\" | \"error\";\n theme?: \"light\" | \"gradient\" | \"dark\" | \"outline\" | \"modern\";\n}) => (\n <div className=\"flex max-w-sm flex-col items-center gap-4 text-center\">\n <FeaturedIcon icon={icon} size=\"lg\" color={color} theme={theme} className=\"hidden md:inline-flex\" />\n <FeaturedIcon icon={icon} size=\"md\" color={color} theme={theme} className=\"inline-flex md:hidden\" />\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\nexport const FeatureTextFeaturedIconTopLeft = ({ icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex max-w-sm flex-col gap-4\">\n <FeaturedIcon icon={icon} size=\"lg\" color=\"gray\" theme=\"modern\" className=\"hidden md:inline-flex\" />\n <FeaturedIcon icon={icon} size=\"md\" color=\"gray\" theme=\"modern\" className=\"inline-flex md:hidden\" />\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\nexport const FeatureTextFeaturedIconLeft = ({ icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex max-w-140 gap-4\">\n <FeaturedIcon icon={icon} size=\"lg\" color=\"gray\" theme=\"modern\" className=\"hidden md:inline-flex\" />\n <FeaturedIcon icon={icon} size=\"md\" color=\"gray\" theme=\"modern\" className=\"inline-flex md:hidden\" />\n\n <div className=\"flex flex-col items-start gap-4\">\n <div>\n <h3 className=\"mt-1.5 text-lg font-semibold text-primary md:mt-2.5\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n </div>\n);\n\nexport const FeatureTextFeaturedIconBox = ({ icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"mt-6 flex max-w-sm flex-col items-center gap-4 rounded-2xl bg-secondary px-6 pb-8 text-center\">\n <FeaturedIcon icon={icon} size=\"lg\" color=\"gray\" theme=\"modern\" className=\"-mt-6\" />\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\ninterface FeatureTextIntegrationIcon extends TextCentered {\n imgUrl: string;\n}\n\nexport const FeatureTextIntegrationIconTopCentered = ({ imgUrl, title, subtitle, footer }: FeatureTextIntegrationIcon) => (\n <div className=\"flex max-w-sm flex-col items-center gap-4 text-center\">\n <span className=\"flex size-13 shrink-0 items-center justify-center rounded-lg bg-primary shadow-xs ring-1 ring-secondary ring-inset md:size-16 md:rounded-xl\">\n <Image alt={title} src={imgUrl} className=\"size-12 md:size-14\" width={56} height={56} />\n </span>\n\n <div className=\"5 flex flex-col items-center gap-4\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n </div>\n);\n\nexport const FeatureTextIntegrationIconTopLeft = ({ imgUrl, title, subtitle, footer }: FeatureTextIntegrationIcon) => (\n <div className=\"flex max-w-sm flex-col gap-4\">\n <span className=\"flex size-13 shrink-0 items-center justify-center rounded-lg bg-primary shadow-xs ring-1 ring-secondary ring-inset md:size-16 md:rounded-xl\">\n <Image alt={title} src={imgUrl} className=\"size-12 md:size-14\" width={56} height={56} />\n </span>\n\n <div className=\"flex flex-col gap-4\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n </div>\n);\n\nexport const FeatureTextIntegrationIconLeft = ({ imgUrl, title, subtitle, footer }: FeatureTextIntegrationIcon) => (\n <div className=\"flex max-w-140 gap-4\">\n <span className=\"flex size-13 shrink-0 items-center justify-center rounded-lg bg-primary shadow-xs ring-1 ring-secondary ring-inset md:size-16 md:rounded-xl\">\n <Image alt={title} src={imgUrl} className=\"size-12 md:size-14\" width={56} height={56} />\n </span>\n\n <div className=\"flex flex-col gap-4\">\n <div>\n <h3 className=\"mt-2.5 text-lg font-semibold text-primary md:mt-4\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n </div>\n);\n\nexport const FeatureTextIntegrationIconBox = ({ imgUrl, title, subtitle, footer }: FeatureTextIntegrationIcon) => (\n <div className=\"mt-6 flex max-w-sm flex-col items-center gap-4 rounded-2xl bg-secondary px-6 pb-8 text-center\">\n <span className=\"-mt-[26px] flex size-13 shrink-0 items-center justify-center rounded-lg bg-primary shadow-xs ring-1 ring-secondary ring-inset md:-mt-8 md:size-16 md:rounded-xl\">\n <Image alt={title} src={imgUrl} className=\"size-12 md:size-14\" width={56} height={56} />\n </span>\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\nexport const FeatureTextIconCard = ({ icon: Icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex flex-col gap-8 bg-secondary p-5 md:max-w-71.5 md:gap-12 md:p-6\">\n <Icon className=\"size-6 text-icon-fg-brand\" />\n\n <div className=\"flex flex-col gap-4\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n </div>\n);\n\nexport const FeatureTextFeaturedIconCard = ({ icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex flex-col gap-12 bg-secondary p-5 md:inline-flex md:gap-16 md:p-6\">\n <FeaturedIcon icon={icon} size=\"lg\" color=\"gray\" theme=\"light\" />\n\n <div className=\"flex flex-col gap-4\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n </div>\n);\n\nexport const FeatureTextLeftBrand = ({ title, subtitle, footer }: TextCentered) => (\n <div className=\"flex max-w-sm flex-col gap-4\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary_on-brand\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary_on-brand\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\nexport const FeatureTextFeaturedIconTopCenteredBrand = ({ icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex max-w-sm flex-col items-center gap-4 text-center\">\n <FeaturedIcon icon={icon} size=\"lg\" color=\"brand\" theme=\"dark\" className=\"hidden md:inline-flex\" />\n <FeaturedIcon icon={icon} size=\"md\" color=\"brand\" theme=\"dark\" className=\"inline-flex md:hidden\" />\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary_on-brand\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary_on-brand\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n\nexport const FeatureTextFeaturedIconTopLeftBrand = ({ icon, title, subtitle, footer }: FeatureTextIcon) => (\n <div className=\"flex max-w-sm flex-col gap-4\">\n <FeaturedIcon icon={icon} size=\"lg\" color=\"brand\" theme=\"dark\" className=\"hidden md:inline-flex\" />\n <FeaturedIcon icon={icon} size=\"md\" color=\"brand\" theme=\"dark\" className=\"inline-flex md:hidden\" />\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary_on-brand\">{title}</h3>\n <p className=\"mt-1 text-md text-tertiary_on-brand\">{subtitle}</p>\n </div>\n\n {footer}\n </div>\n);\n","/**\n * Helper functions for extracting photo URLs from photo associations\n */\n\nimport type { PhotoAttachment } from '../types/api/photos';\nimport type { WebsitePhotos } from '../types/api/website-photos';\n\nexport type { PhotoAttachment } from '../types/api/photos';\n\n/** Video file extensions treated as video (match backend ExternalPhotoService.video_url?) */\nconst VIDEO_EXTENSIONS = ['.mp4', '.mov', '.webm', '.m4v', '.avi', '.mkv', '.flv', '.wmv'];\n\n/**\n * True if the URL looks like a video by path extension. Used to avoid using video URLs in img src.\n */\nexport function isVideoUrl(url: string | null | undefined): boolean {\n if (!url || typeof url !== 'string') return false;\n const path = url.split('?')[0] ?? '';\n const ext = path.slice(path.lastIndexOf('.')).toLowerCase();\n return VIDEO_EXTENSIONS.includes(ext);\n}\n\n/**\n * Get the best available photo URL from a photos array\n * Priority: featured photo > first photo > fallback\n */\nexport function getPhotoUrl(\n photos?: PhotoAttachment[]\n): string | null {\n // Priority 1: Featured photo from photos array\n if (photos && photos.length > 0) {\n const featuredPhoto = photos.find(pa => pa.featured);\n const photoToUse = featuredPhoto || photos[0];\n const photo = photoToUse.photo;\n \n if (photo) {\n return photo.large_url || photo.medium_url || photo.thumbnail_url || photo.original_url || null;\n }\n }\n \n // Fallback (gradient or null)\n return null;\n}\n\n/**\n * Get avatar URL for team members or authors.\n * Returns a URL only when there is a real photo in attachments; otherwise null.\n * Callers should use PhotoWithFallback (gradient fallback) or Avatar with initials when null.\n */\n/** Optional fallbackId/name reserved for future use (e.g. deterministic fallback). */\n/* eslint-disable @typescript-eslint/no-unused-vars -- _fallbackId, _name reserved for API */\nexport function getAvatarUrl(\n photos?: PhotoAttachment[],\n _fallbackId?: number | string,\n _name?: string\n): string | null {\n return getPhotoUrl(photos);\n}\n/* eslint-enable @typescript-eslint/no-unused-vars */\n\n/**\n * Get featured image URL for blog posts\n */\nexport function getFeaturedImageUrl(\n photos?: PhotoAttachment[]\n): string | null {\n return getPhotoUrl(photos);\n}\n\n/**\n * Get logo URL from website_photos API (which aggregates from account_photos)\n * \n * The website_photos API endpoint returns logos from account_photos with photo_type: 'logo',\n * with industry fallback. This is the primary and only source for logos.\n * \n * Returns undefined if no logo is available (for PhotoWithFallback gradient fallback)\n */\nexport function getLogoUrl(\n websitePhotos?: WebsitePhotos | null\n): string | undefined {\n if (websitePhotos?.logo?.url) {\n return websitePhotos.logo.url;\n }\n \n return undefined;\n}\n\n","import { StarIcon, AvatarLabelGroup, VerifiedTick } from '../elements';\nimport { getAvatarUrl } from '../../utils/photo-helpers';\nimport type { Testimonial } from '../../types/api/testimonial';\n\n\ninterface TestimonialsHomeProps {\n testimonials: Testimonial[];\n title?: string;\n subtitle?: string;\n perPage?: number;\n}\n\nexport const TestimonialsHome = ({\n testimonials: testimonialsData,\n title = \"\",\n subtitle = \"\",\n perPage,\n}: TestimonialsHomeProps) => {\n const testimonials = Array.isArray(testimonialsData) ? testimonialsData : [];\n const displayTestimonials = perPage ? testimonials.slice(0, perPage) : testimonials;\n\n return (\n <section className=\"flex flex-col items-center gap-16 bg-primary py-16 lg:py-24\">\n <div className=\"flex max-w-container flex-col items-center gap-4 px-4 text-center lg:gap-5 lg:px-8\">\n <h1 className=\"text-display-sm font-semibold text-primary lg:text-display-md\">\n {title}\n </h1>\n <p className=\"text-lg text-tertiary lg:text-xl\">\n {subtitle}\n </p>\n </div>\n \n {displayTestimonials && displayTestimonials.length > 0 ? (\n <div className=\"grid max-w-container grid-cols-1 gap-5 px-4 lg:grid-cols-3 lg:gap-6 lg:px-8\">\n {displayTestimonials.map((testimonial, index) => {\n const reviewerName = testimonial.reviewer_name || 'Customer';\n const quote = testimonial.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const username = `@${reviewerName.toLowerCase().replace(/\\s+/g, '')}`;\n const avatarUrl = getAvatarUrl(testimonial.photo_attachments, testimonial.id, reviewerName);\n \n return (\n <div \n key={testimonial.id || index} \n className=\"flex flex-col items-start gap-8 rounded-xl bg-secondary p-6 lg:justify-between lg:p-8\"\n >\n <div className=\"flex flex-col items-start gap-4\">\n <div aria-hidden=\"true\" className=\"flex gap-1\">\n <StarIcon />\n <StarIcon />\n <StarIcon />\n <StarIcon />\n <StarIcon />\n </div>\n <blockquote className=\"text-md font-medium text-primary\">{quote}</blockquote>\n </div>\n <a href=\"#\" className=\"group flex outline-hidden\">\n <AvatarLabelGroup\n size=\"lg\"\n src={avatarUrl}\n alt={reviewerName}\n title={\n <span className=\"relative flex items-center gap-1\">\n {reviewerName}\n <VerifiedTick size=\"lg\" />\n </span>\n }\n subtitle={<span className=\"underline decoration-1 underline-offset-4\">{username}</span>}\n />\n </a>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center\">\n <p className=\"text-gray-500\">No testimonials available</p>\n </div>\n )}\n </section>\n );\n};\n","import React from 'react';\nimport { PhotoWithFallback } from '../elements';\nimport type { Testimonial } from '../../types/api/testimonial';\nimport { getAvatarUrl } from '../../utils/photo-helpers';\n\ninterface TestimonialsGridProps {\n testimonials?: Testimonial[] | null;\n title?: string;\n subtitle?: string;\n}\n\nexport const TestimonialsGrid = ({\n testimonials: testimonialsData,\n title = \"\",\n subtitle = \"\"\n}: TestimonialsGridProps) => {\n const testimonials = Array.isArray(testimonialsData) ? testimonialsData : [];\n \n return (\n <section className=\"py-16 md:py-24\">\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mx-auto mb-12 flex w-full max-w-3xl flex-col items-center text-center\">\n {title && (\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {testimonials.length > 0 ? (\n <div className=\"grid max-w-container grid-cols-1 gap-5 lg:grid-cols-3 lg:gap-6\">\n {testimonials.map((testimonial, index) => {\n const reviewerName = testimonial.reviewer_name || 'Customer';\n const quote = testimonial.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const username = `@${reviewerName.toLowerCase().replace(/\\s+/g, '')}`;\n const avatarUrl = getAvatarUrl(testimonial.photo_attachments, testimonial.id, reviewerName);\n const rating = testimonial.rating || 5;\n \n return (\n <div key={testimonial.id || index} className=\"flex flex-col gap-6 rounded-2xl bg-secondary p-6 md:p-8\">\n <div className=\"flex gap-0.5\">\n {Array.from({ length: 5 }).map((_, i) => (\n <svg\n key={i}\n className=\"size-5\"\n fill={i < rating ? \"currentColor\" : \"none\"}\n stroke={i < rating ? \"none\" : \"currentColor\"}\n strokeWidth={2}\n viewBox=\"0 0 24 24\"\n >\n <path d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\" />\n </svg>\n ))}\n </div>\n\n <p className=\"text-md text-primary\">\n {quote}\n </p>\n\n <div className=\"flex items-center gap-3 mt-auto\">\n <div className=\"size-12 shrink-0 overflow-hidden rounded-full\">\n <PhotoWithFallback\n photoUrl={avatarUrl}\n photoAlt={reviewerName}\n fallbackId={`testimonial-${testimonial.id || index}`}\n className=\"size-full object-cover\"\n />\n </div>\n <div>\n <p className=\"text-sm font-semibold text-primary\">\n {reviewerName}\n </p>\n <p className=\"text-sm text-tertiary\">\n {username}\n </p>\n </div>\n </div>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"text-gray-500\">No testimonials available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\n","\"use client\";\n\nimport { useState } from \"react\";\nimport { motion } from \"motion/react\";\nimport { cx } from '../../utils/cx';\nimport type { FaqQuestion } from '../../types/api/faq';\n\n\ninterface FAQHomeProps {\n faqs: FaqQuestion[];\n title?: string;\n subtitle?: string;\n maxItems?: number;\n}\n\nexport const FAQHome = ({\n faqs: faqsData,\n title = \"\",\n subtitle = \"\",\n maxItems,\n}: FAQHomeProps) => {\n const items = Array.isArray(faqsData) ? faqsData : [];\n const [openQuestions, setOpenQuestions] = useState<Set<number>>(new Set([0]));\n\n const handleToggle = (index: number) => {\n const newSet = new Set(openQuestions);\n if (newSet.has(index)) {\n newSet.delete(index);\n } else {\n newSet.add(index);\n }\n setOpenQuestions(newSet);\n };\n\n const displayItems = maxItems ? items.slice(0, maxItems) : items;\n\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n </div>\n\n {displayItems && displayItems.length > 0 ? (\n <div className=\"mx-auto mt-12 max-w-3xl md:mt-16\">\n <div className=\"flex flex-col gap-4\">\n {displayItems.map((faq, index) => (\n <div\n key={faq.id || index}\n className={cx(\n \"rounded-2xl bg-transparent p-5 transition duration-300 ease-in-out md:p-6\",\n openQuestions.has(index) && \"bg-secondary\",\n )}\n >\n <h3>\n <button\n onClick={() => handleToggle(index)}\n className=\"flex w-full cursor-pointer gap-2 rounded-md text-left outline-focus-ring select-none focus-visible:outline-2 focus-visible:outline-offset-2 md:flex-row-reverse md:gap-4\"\n >\n <span className=\"flex-1 text-md font-semibold text-primary\">{faq.question}</span>\n <span aria-hidden=\"true\" className=\"flex size-6 items-center text-fg-quaternary\">\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <circle cx=\"12\" cy=\"12\" r=\"10\"></circle>\n <line\n className={cx(\n \"origin-center rotate-0 transition duration-150 ease-out\",\n openQuestions.has(index) && \"-rotate-90\",\n )}\n x1=\"12\"\n y1=\"8\"\n x2=\"12\"\n y2=\"16\"\n ></line>\n <line x1=\"8\" y1=\"12\" x2=\"16\" y2=\"12\"></line>\n </svg>\n </span>\n </button>\n </h3>\n\n <motion.div\n className=\"overflow-hidden\"\n initial={false}\n animate={{\n height: openQuestions.has(index) ? \"auto\" : 0,\n opacity: openQuestions.has(index) ? 1 : 0,\n }}\n transition={{\n type: \"spring\",\n damping: 24,\n stiffness: 240,\n bounce: 0.4,\n }}\n >\n <div className=\"pt-1 pr-8 md:pr-0 md:pl-10\">\n <div className=\"text-md text-tertiary whitespace-pre-line\">\n {faq.answer_markdown || ''}\n </div>\n </div>\n </motion.div>\n </div>\n ))}\n </div>\n </div>\n ) : (\n <div className=\"text-center mt-12\">\n <p className=\"text-gray-500\">No FAQ items available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n","import React from 'react';\nimport Link from 'next/link';\nimport { ArrowLeft, ArrowRight, ArrowUpRight } from \"@untitledui/icons\";\nimport { Carousel } from '../elements/carousel/carousel-base';\nimport { Button, PhotoWithFallback, RoundButton } from '../elements';\nimport { cx } from '../../utils/cx';\nimport type { BlogPost } from '../../types/api/blog-post';\n\n\ninterface BlogSectionProps {\n blogPosts: BlogPost[];\n title?: string;\n subtitle?: string;\n maxPosts?: number;\n backgroundColor?: string;\n showViewAll?: boolean;\n}\n\nexport const BlogSection = ({\n blogPosts: postsData,\n title = \"\",\n subtitle = \"\",\n maxPosts = 8,\n backgroundColor = \"bg-primary\",\n showViewAll = true,\n}: BlogSectionProps) => {\n \n let postsArray = Array.isArray(postsData) ? postsData : [];\n postsArray = postsArray.slice(0, maxPosts);\n\n const formatDate = (dateString: string) => {\n if (!dateString) return 'Recent';\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n day: 'numeric',\n month: 'short',\n year: 'numeric'\n });\n } catch {\n return 'Recent';\n }\n };\n\n return (\n <section className={`overflow-hidden ${backgroundColor} py-16 md:py-24`}>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"flex flex-col items-start justify-between lg:flex-row\">\n <div className=\"max-w-3xl\">\n <p className=\"text-sm font-semibold text-brand-secondary md:text-md\">Latest posts</p>\n <h2 className=\"mt-3 text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n </div>\n\n {showViewAll && (\n <div className=\"hidden gap-3 lg:flex\">\n <Button size=\"xl\" href=\"/blog\">View all posts</Button>\n </div>\n )}\n </div>\n\n {postsArray.length > 0 ? (\n <>\n <Carousel.Root\n className=\"mt-12 md:mt-16\"\n opts={{\n align: \"start\",\n }}\n >\n <Carousel.Content overflowHidden={false} className=\"gap-6 pr-4 md:gap-8 md:pr-8\">\n {postsArray.map((post: BlogPost, index: number) => {\n const author = Array.isArray(post.blog_post_authors) && post.blog_post_authors.length > 0 \n ? post.blog_post_authors[0] \n : null;\n \n const excerpt = post.excerpt_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <Carousel.Item key={post.id || index} className=\"max-w-xs md:max-w-96\">\n <article className={cx(\"flex flex-col gap-4\")}>\n <div className=\"relative\">\n <a href={`/blog/${post.slug || post.id}`} className=\"w-full\" tabIndex={-1}>\n <PhotoWithFallback\n item={post}\n fallbackId={post.id || index}\n alt={post.title || 'Blog post'}\n className={cx(\"aspect-[1.5] w-full object-cover\")}\n />\n </a>\n <div className=\"absolute inset-x-0 bottom-0 overflow-hidden bg-linear-to-b from-transparent to-black/40\">\n <div className=\"relative flex items-start justify-between bg-alpha-white/30 p-4 backdrop-blur-md before:absolute before:inset-x-0 before:top-0 before:h-px before:bg-alpha-white/30 md:p-5\">\n <div>\n <a\n href={author?.slug ? `/blog/author/${author.slug}` : '/blog'}\n className=\"block rounded-xs text-sm font-semibold text-white outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {author?.name || 'Author'}\n </a>\n <time className=\"block text-sm text-white\">\n {formatDate(post.published_at || '')}\n </time>\n </div>\n <Link\n href=\"/blog\"\n className=\"rounded-xs text-sm font-semibold text-white outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n Blog\n </Link>\n </div>\n </div>\n </div>\n <div className=\"flex flex-col gap-2\">\n <a\n href={`/blog/${post.slug || post.id}`}\n className=\"group/title flex justify-between gap-x-4 rounded-md text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {post.title || 'Untitled Post'}\n <ArrowUpRight\n className=\"mt-0.5 size-6 shrink-0 text-fg-quaternary transition duration-100 ease-linear group-hover/title:text-fg-quaternary_hover\"\n aria-hidden=\"true\"\n />\n </a>\n {excerpt && (\n <p className=\"line-clamp-2 text-md text-tertiary\">{excerpt}</p>\n )}\n </div>\n </article>\n </Carousel.Item>\n );\n })}\n </Carousel.Content>\n <div className=\"mt-8 flex gap-4 md:gap-8\">\n <Carousel.PrevTrigger asChild>\n <RoundButton icon={ArrowLeft} />\n </Carousel.PrevTrigger>\n <Carousel.NextTrigger asChild>\n <RoundButton icon={ArrowRight} />\n </Carousel.NextTrigger>\n </div>\n </Carousel.Root>\n {showViewAll && (\n <div className=\"mt-12 flex flex-col gap-3 lg:hidden\">\n <Button size=\"xl\" href=\"/blog\">View all posts</Button>\n </div>\n )}\n </>\n ) : (\n <div className=\"mt-12 text-center md:mt-16\">\n <p className=\"text-gray-500\">No blog posts available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n","\"use client\";\n\nimport type { CSSProperties, ComponentPropsWithRef, HTMLAttributes, KeyboardEvent, ReactNode, Ref } from \"react\";\nimport { cloneElement, createContext, isValidElement, useCallback, useContext, useEffect, useRef, useSyncExternalStore } from \"react\";\nimport useEmblaCarousel, { type UseEmblaCarouselType } from \"embla-carousel-react\";\nimport { cx } from '../../../utils/cx';\n\ntype CarouselApi = UseEmblaCarouselType[1];\ntype UseCarouselParameters = Parameters<typeof useEmblaCarousel>;\ntype CarouselOptions = UseCarouselParameters[0];\ntype CarouselPlugin = UseCarouselParameters[1];\n\ntype CarouselProps = {\n /** The options for the Embla carousel. */\n opts?: CarouselOptions;\n /** The plugins for the Embla carousel. */\n plugins?: CarouselPlugin;\n /** The orientation of the carousel. */\n orientation?: \"horizontal\" | \"vertical\";\n /** The function to set the API for the carousel. */\n setApi?: (api: CarouselApi) => void;\n};\n\ntype CarouselContextProps = CarouselProps & {\n /** The ref of the carousel. */\n carouselRef: ReturnType<typeof useEmblaCarousel>[0];\n /** The API of the carousel. */\n api: ReturnType<typeof useEmblaCarousel>[1];\n /** The function to scroll the carousel to the previous slide. */\n scrollPrev: () => void;\n /** The function to scroll the carousel to the next slide. */\n scrollNext: () => void;\n /** Whether the carousel can scroll to the previous slide. */\n canScrollPrev: boolean;\n /** Whether the carousel can scroll to the next slide. */\n canScrollNext: boolean;\n /** The index of the selected slide. */\n selectedIndex: number;\n /** The scroll snaps of the carousel. */\n scrollSnaps: number[];\n};\n\nexport const CarouselContext = createContext<CarouselContextProps | null>(null);\n\nexport const useCarousel = () => {\n const context = useContext(CarouselContext);\n\n if (!context) {\n throw new Error(\"The `useCarousel` hook must be used within a <Carousel />\");\n }\n\n return context;\n};\n\n// Stable default snapshot for SSR - must be a constant to avoid infinite loops\nconst DEFAULT_SNAPSHOT = {\n canScrollPrev: false,\n canScrollNext: false,\n selectedIndex: 0,\n scrollSnaps: [] as number[],\n};\n\nconst CarouselRoot = ({ orientation = \"horizontal\", opts, setApi, plugins, className, children, ...props }: ComponentPropsWithRef<\"div\"> & CarouselProps) => {\n const [carouselRef, api] = useEmblaCarousel(\n {\n ...opts,\n axis: orientation === \"horizontal\" ? \"x\" : \"y\",\n },\n plugins,\n );\n \n // Cache the snapshot object to avoid creating new objects on every call\n const snapshotRef = useRef(DEFAULT_SNAPSHOT);\n \n const getSnapshot = useCallback(() => {\n if (!api) {\n return DEFAULT_SNAPSHOT;\n }\n\n const canScrollPrev = api.canScrollPrev();\n const canScrollNext = api.canScrollNext();\n const selectedIndex = api.selectedScrollSnap();\n const scrollSnaps = api.scrollSnapList();\n \n // Only create a new object if values have changed\n if (\n snapshotRef.current.canScrollPrev !== canScrollPrev ||\n snapshotRef.current.canScrollNext !== canScrollNext ||\n snapshotRef.current.selectedIndex !== selectedIndex ||\n snapshotRef.current.scrollSnaps.length !== scrollSnaps.length ||\n snapshotRef.current.scrollSnaps.some((val, idx) => val !== scrollSnaps[idx])\n ) {\n snapshotRef.current = {\n canScrollPrev,\n canScrollNext,\n selectedIndex,\n scrollSnaps,\n };\n }\n \n return snapshotRef.current;\n }, [api]);\n\n // Stable server snapshot - returns the same cached object reference for SSR\n const getServerSnapshot = useCallback(() => DEFAULT_SNAPSHOT, []);\n\n const subscribe = useCallback(\n (onStoreChange: () => void) => {\n if (!api) return () => {};\n\n api.on(\"select\", onStoreChange);\n api.on(\"reInit\", onStoreChange);\n\n return () => {\n api.off(\"select\", onStoreChange);\n api.off(\"reInit\", onStoreChange);\n };\n },\n [api],\n );\n\n const { canScrollPrev, canScrollNext, selectedIndex, scrollSnaps } = useSyncExternalStore(subscribe, getSnapshot, getServerSnapshot);\n\n const scrollPrev = useCallback(() => {\n api?.scrollPrev();\n }, [api]);\n\n const scrollNext = useCallback(() => {\n api?.scrollNext();\n }, [api]);\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent<HTMLDivElement>) => {\n if (event.key === \"ArrowLeft\") {\n event.preventDefault();\n scrollPrev();\n } else if (event.key === \"ArrowRight\") {\n event.preventDefault();\n scrollNext();\n }\n },\n [scrollPrev, scrollNext],\n );\n\n useEffect(() => {\n if (!api || !setApi) return;\n\n setApi(api);\n }, [api, setApi]);\n\n return (\n <CarouselContext.Provider\n value={{\n carouselRef,\n api: api,\n opts,\n orientation: orientation || (opts?.axis === \"y\" ? \"vertical\" : \"horizontal\"),\n scrollPrev,\n scrollNext,\n canScrollPrev,\n canScrollNext,\n selectedIndex,\n scrollSnaps,\n }}\n >\n <div onKeyDownCapture={handleKeyDown} className={cx(\"relative\", className)} role=\"region\" aria-roledescription=\"carousel\" {...props}>\n {children}\n </div>\n </CarouselContext.Provider>\n );\n};\n\ninterface CarouselContentProps extends ComponentPropsWithRef<\"div\"> {\n /** The class name of the content. */\n className?: string;\n /** Whether to hide the overflow. */\n overflowHidden?: boolean;\n}\n\nconst CarouselContent = ({ className, overflowHidden = true, ...props }: CarouselContentProps) => {\n const { carouselRef, orientation } = useCarousel();\n\n return (\n <div ref={carouselRef} className={cx(\"h-full w-full\", overflowHidden && \"overflow-hidden\")}>\n <div className={cx(\"flex max-h-full\", orientation === \"horizontal\" ? \"\" : \"flex-col\", className)} {...props} />\n </div>\n );\n};\n\nconst CarouselItem = ({ className, ...props }: ComponentPropsWithRef<\"div\">) => {\n return <div role=\"group\" aria-roledescription=\"slide\" className={cx(\"min-w-0 shrink-0 grow-0 basis-full\", className)} {...props} />;\n};\n\ninterface TriggerRenderProps {\n isDisabled: boolean;\n onClick: () => void;\n}\n\ninterface TriggerProps {\n /** The ref of the trigger. */\n ref?: Ref<HTMLButtonElement>;\n /** If true, the child element will be cloned and passed down the prop of the trigger. */\n asChild?: boolean;\n /** The direction of the trigger. */\n direction: \"prev\" | \"next\";\n /** The children of the trigger. Can be a render prop or a valid element. */\n children: ReactNode | ((props: TriggerRenderProps) => ReactNode);\n /** The style of the trigger. */\n style?: CSSProperties;\n /** The class name of the trigger. */\n className?: string | ((args: { isDisabled: boolean }) => string);\n}\n\nconst Trigger = ({ className, children, asChild, direction, style, ...props }: TriggerProps) => {\n const { scrollPrev, canScrollNext, scrollNext, canScrollPrev } = useCarousel();\n\n const isDisabled = direction === \"prev\" ? !canScrollPrev : !canScrollNext;\n\n const handleClick = () => {\n if (isDisabled) return;\n\n if (direction === \"prev\") {\n scrollPrev();\n } else {\n scrollNext();\n }\n };\n\n const computedClassName = typeof className === \"function\" ? className({ isDisabled }) : className;\n\n const defaultAriaLabel = direction === \"prev\" ? \"Previous slide\" : \"Next slide\";\n\n // If the children is a render prop, we need to pass the necessary props to the render prop.\n if (typeof children === \"function\") {\n return <>{children({ isDisabled, onClick: handleClick })}</>;\n }\n\n // If the children is a valid element, we need to clone it and pass the necessary props to the cloned element.\n if (asChild && isValidElement(children)) {\n return cloneElement(children, {\n onClick: handleClick,\n disabled: isDisabled,\n \"aria-label\": defaultAriaLabel,\n style: { ...(children.props as HTMLAttributes<HTMLElement>).style, ...style },\n className: [computedClassName, (children.props as HTMLAttributes<HTMLElement>).className].filter(Boolean).join(\" \") || undefined,\n } as HTMLAttributes<HTMLElement>);\n }\n\n return (\n <button aria-label={defaultAriaLabel} disabled={isDisabled} className={computedClassName} onClick={handleClick} {...props}>\n {children}\n </button>\n );\n};\n\nconst CarouselPrevTrigger = (props: Omit<TriggerProps, \"direction\">) => <Trigger {...props} direction=\"prev\" />;\n\nconst CarouselNextTrigger = (props: Omit<TriggerProps, \"direction\">) => <Trigger {...props} direction=\"next\" />;\n\ninterface CarouselIndicatorRenderProps {\n isSelected: boolean;\n onClick: () => void;\n}\n\ninterface CarouselIndicatorProps {\n /** The index of the indicator. */\n index: number;\n /** If true, the child element will be cloned and passed down the prop of the indicator. */\n asChild?: boolean;\n /** If true, the indicator will be selected. */\n isSelected?: boolean;\n /** The children of the indicator. Can be a render prop or a valid element. */\n children?: ReactNode | ((props: CarouselIndicatorRenderProps) => ReactNode);\n /** The style of the indicator. */\n style?: CSSProperties;\n /** The class name of the indicator. */\n className?: string | ((args: { isSelected: boolean }) => string);\n}\n\nconst CarouselIndicator = ({ index, isSelected = false, children, asChild, className, style }: CarouselIndicatorProps) => {\n const { api, selectedIndex } = useCarousel();\n\n isSelected = isSelected || selectedIndex === index;\n\n const handleClick = () => {\n api?.scrollTo(index);\n };\n const computedClassName = typeof className === \"function\" ? className({ isSelected }) : className;\n\n const defaultAriaLabel = \"Go to slide\" + (index + 1);\n\n // If the children is a render prop, we need to pass the necessary props to the render prop.\n if (typeof children === \"function\") {\n return <>{children({ isSelected, onClick: handleClick })}</>;\n }\n\n // If the children is a valid element, we need to clone it and pass the necessary props to the cloned element.\n if (asChild && isValidElement(children)) {\n return cloneElement(children, {\n onClick: handleClick,\n \"aria-label\": defaultAriaLabel,\n \"aria-current\": isSelected ? \"true\" : undefined,\n style: { ...(children.props as HTMLAttributes<HTMLElement>).style, ...style },\n className: [computedClassName, (children.props as HTMLAttributes<HTMLElement>).className].filter(Boolean).join(\" \") || undefined,\n } as HTMLAttributes<HTMLElement>);\n }\n\n return (\n <button aria-label={defaultAriaLabel} aria-current={isSelected ? \"true\" : undefined} className={computedClassName} onClick={handleClick}>\n {children}\n </button>\n );\n};\n\ninterface CarouselIndicatorGroupProps extends Omit<HTMLAttributes<HTMLDivElement>, \"children\"> {\n children: ReactNode | ((props: { index: number }) => ReactNode);\n className?: string;\n}\n\nconst CarouselIndicatorGroup = ({ children, ...props }: CarouselIndicatorGroupProps) => {\n const { scrollSnaps } = useCarousel();\n\n // If the children is a render prop, we need to pass the index to the render prop.\n if (typeof children === \"function\") {\n return <nav {...props}>{scrollSnaps.map((index) => children({ index }))}</nav>;\n }\n\n return <nav {...props}>{children}</nav>;\n};\n\nexport const Carousel = {\n Root: CarouselRoot,\n Content: CarouselContent,\n Item: CarouselItem,\n PrevTrigger: CarouselPrevTrigger,\n NextTrigger: CarouselNextTrigger,\n IndicatorGroup: CarouselIndicatorGroup,\n Indicator: CarouselIndicator,\n};\n","import React from 'react';\nimport { PhotoWithFallback } from '../elements';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { FormDefinition } from '../../types/api/form';\nimport type { SiteConfig } from '../../types/config';\nimport { ContactSectionForm } from './contact-section-form';\n\nfunction getLegalUrlsFromConfig(config: SiteConfig | null | undefined): { privacyPolicyUrl?: string; termsOfServiceUrl?: string } {\n if (!config?.navigation?.footer) return {};\n const flat = config.navigation.footer.flat();\n const privacy = flat.find((l) => l.label === 'Privacy Policy')?.href;\n const terms = flat.find((l) => l.label === 'Terms of Service')?.href;\n return { privacyPolicyUrl: privacy, termsOfServiceUrl: terms };\n}\n\ninterface ContactSectionProps {\n websitePhotos?: WebsitePhotos | null;\n title?: string;\n subtitle?: string;\n /** When provided, contact form fields are rendered from this definition. */\n formDefinition?: FormDefinition | null;\n /** Optional site config; used to derive Privacy Policy / Terms of Service URLs for the consent checkbox links. */\n config?: SiteConfig | null;\n}\n\nconst ContactSection = ({\n websitePhotos,\n title = \"\",\n subtitle = \"\",\n formDefinition,\n config,\n}: ContactSectionProps) => {\n const { privacyPolicyUrl, termsOfServiceUrl } = getLegalUrlsFromConfig(config);\n const contactPhoto = websitePhotos?.contact;\n const contactImageUrl = contactPhoto?.url;\n const finalContactImage = contactImageUrl && contactImageUrl.trim() !== \"\" ? contactImageUrl : undefined;\n const finalContactImageAlt = contactPhoto?.alt || \"Contact image\";\n\n return (\n <section className=\"bg-primary py-16 md:pt-16 md:pb-24\">\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n <div className=\"grid grid-cols-1 gap-12 md:gap-16 lg:grid-cols-2\">\n <div className=\"flex w-full flex-col gap-12\">\n <div className=\"flex flex-col\">\n <h2 className=\"text-display-md font-semibold text-primary\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n <ContactSectionForm\n formDefinition={formDefinition}\n privacyPolicyUrl={privacyPolicyUrl}\n termsOfServiceUrl={termsOfServiceUrl}\n />\n </div>\n\n <div className=\"max-lg:hidden h-full min-h-0\">\n <PhotoWithFallback\n photoUrl={finalContactImage}\n photoAlt={finalContactImageAlt}\n fallbackId=\"contact-section-image\"\n className=\"h-full w-full object-cover\"\n />\n </div>\n </div>\n </div>\n </section>\n );\n};\n\nexport default ContactSection;\n","\"use client\";\n\nimport React, { useRef, useState } from 'react';\nimport { Form, Button } from '../elements';\nimport { DynamicFormFields } from '../components/DynamicFormFields';\nimport { firePixelEvent, setPixelUserData } from '../../tracking/firePixelEvent';\nimport { captureEvent } from '../../tracking/captureEvent';\nimport type { FormDefinition } from '../../types/api/form';\nimport { useFormDefinitions } from '../../next/contexts/form-definitions';\n\ninterface ContactSectionFormProps {\n /** Form fields are rendered from this definition (required). */\n formDefinition: FormDefinition | null | undefined;\n submitButtonText?: string;\n successMessage?: string;\n thankYouMessage?: string;\n onSuccess?: () => void;\n /** Optional URLs for ToS/Privacy links in consent checkbox (passed to DynamicFormFields). */\n privacyPolicyUrl?: string;\n termsOfServiceUrl?: string;\n}\n\nexport const ContactSectionForm = ({\n formDefinition,\n submitButtonText = \"Send message\",\n successMessage = \"Thank you for contacting us! We'll get back to you soon.\",\n thankYouMessage,\n onSuccess,\n privacyPolicyUrl,\n termsOfServiceUrl,\n}: ContactSectionFormProps) => {\n const { leadFormDefinition } = useFormDefinitions();\n const resolvedFormDefinition = formDefinition ?? leadFormDefinition;\n const [isSubmitting, setIsSubmitting] = useState(false);\n const [submitStatus, setSubmitStatus] = useState<'idle' | 'success' | 'error'>('idle');\n const [statusMessage, setStatusMessage] = useState<string>('');\n const formRef = useRef<HTMLFormElement>(null);\n\n if (\n !resolvedFormDefinition ||\n !Array.isArray(resolvedFormDefinition.fields) ||\n resolvedFormDefinition.fields.length === 0\n ) {\n return null;\n }\n\n const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n setIsSubmitting(true);\n setSubmitStatus('idle');\n setStatusMessage('');\n\n const formData = new FormData(e.currentTarget);\n const data: Record<string, string> = { formType: 'lead' };\n formData.forEach((value, key) => {\n if (key.endsWith('_prefix')) return;\n if (typeof value === 'string') data[key] = value;\n });\n\n try {\n const response = await fetch('/api/form/', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(data),\n });\n const result = await response.json();\n\n if (result.success) {\n setSubmitStatus('success');\n setStatusMessage(result.message || successMessage);\n formRef.current?.reset();\n onSuccess?.();\n await setPixelUserData({ email: data.email, phone: data.phone });\n firePixelEvent('Lead', undefined, result.eventId);\n captureEvent('form_submitted', { form_type: 'lead', ...(result.eventId && { event_id: result.eventId }) });\n setTimeout(() => setSubmitStatus('idle'), 5000);\n } else {\n const errorMsg = result.error || 'Something went wrong. Please try again.';\n setSubmitStatus('error');\n setStatusMessage(errorMsg);\n captureEvent('form_failed', { form_type: 'lead', error: errorMsg });\n }\n } catch {\n setSubmitStatus('error');\n setStatusMessage('Network error. Please try again later.');\n captureEvent('form_failed', { form_type: 'lead', error: 'network_error' });\n }\n setIsSubmitting(false);\n };\n\n return (\n <Form ref={formRef} onSubmit={handleSubmit} className=\"flex flex-col gap-8\">\n <div className=\"flex flex-col gap-6\">\n <DynamicFormFields\n form={resolvedFormDefinition}\n privacyPolicyUrl={privacyPolicyUrl}\n termsOfServiceUrl={termsOfServiceUrl}\n />\n </div>\n {submitStatus === 'success' && (\n <div className=\"rounded-lg bg-success-50 p-4 text-success-700\">\n {thankYouMessage ?? statusMessage}\n </div>\n )}\n {submitStatus === 'error' && (\n <div className=\"rounded-lg bg-error-50 p-4 text-error-700\">{statusMessage}</div>\n )}\n <Button\n type=\"submit\"\n size=\"xl\"\n isDisabled={isSubmitting}\n isLoading={isSubmitting}\n >\n {isSubmitting ? 'Sending...' : submitButtonText}\n </Button>\n </Form>\n );\n};\n","'use client';\n\nimport React, { useState } from 'react';\nimport ReactMarkdown from 'react-markdown';\nimport remarkGfm from 'remark-gfm';\nimport { Input, InputBase, InputGroup, NativeSelect, Textarea, PrivacyCheckbox } from '../elements';\nimport type { FormDefinition, FormFieldDefinition } from '../../types/api/form';\nimport countries from '../../utils/countries';\nimport { getNationalMask, formatDigitsToMask } from '../../utils/phone-helpers';\n\nexport interface DynamicFormFieldsProps {\n /** Form definition from API (fields array + optional settings). */\n form: FormDefinition;\n /** For job_application forms: add hidden jobSlug input. */\n jobSlug?: string;\n /** Optional URLs for ToS/Privacy links in consent checkbox label. */\n privacyPolicyUrl?: string;\n termsOfServiceUrl?: string;\n}\n\nconst INPUT_TYPES = ['text', 'email', 'tel'] as const;\n\nfunction allFieldsFlat(fields: FormDefinition['fields']): FormFieldDefinition[] {\n const out: FormFieldDefinition[] = [];\n for (const item of fields) {\n if (Array.isArray(item)) out.push(...item);\n else if (item && typeof item === 'object' && 'name' in item) out.push(item);\n }\n return out;\n}\n\n// ─── CheckboxGroup ────────────────────────────────────────────────────────────\n\ninterface CheckboxGroupProps {\n field: FormFieldDefinition;\n}\n\nfunction CheckboxGroup({ field }: CheckboxGroupProps) {\n const [selected, setSelected] = useState<string[]>([]);\n const options = field.options ?? [];\n\n const toggle = (value: string) => {\n setSelected((prev) =>\n prev.includes(value) ? prev.filter((v) => v !== value) : [...prev, value]\n );\n };\n\n return (\n <fieldset>\n <legend className=\"mb-2 font-body text-sm font-medium text-fg-primary\">\n {field.label}\n {field.required && <span className=\"ml-1 text-error-500\">*</span>}\n </legend>\n\n {/* Hidden input carries the comma-separated value on submit */}\n <input\n type=\"hidden\"\n name={field.name}\n value={selected.join(',')}\n />\n\n <div className=\"grid grid-cols-2 gap-x-8 gap-y-3\">\n {options.map((opt) => {\n const id = `cbg-${field.name}-${opt.value}`;\n const checked = selected.includes(opt.value);\n return (\n <div key={opt.value} className=\"flex items-center gap-3\">\n <input\n type=\"checkbox\"\n id={id}\n checked={checked}\n onChange={() => toggle(opt.value)}\n className=\"h-4 w-4 shrink-0 rounded border-secondary focus:ring-focus-ring\"\n />\n <label htmlFor={id} className=\"font-body text-sm text-tertiary cursor-pointer\">\n {opt.label}\n </label>\n </div>\n );\n })}\n </div>\n </fieldset>\n );\n}\n\n// ─── renderField ─────────────────────────────────────────────────────────────\n\nfunction renderField(\n field: FormFieldDefinition,\n index: number,\n showCountryCode: boolean,\n selectedCountryPhone: string,\n onCountryChange: (code: string) => void,\n phoneValues: Record<string, string>,\n setPhoneValues: React.Dispatch<React.SetStateAction<Record<string, string>>>,\n companyName: string,\n privacyPolicyUrl: string | undefined,\n termsOfServiceUrl: string | undefined\n): React.ReactNode {\n const name = field.name ?? `field-${index}`;\n const type = (field.type ?? 'text').toString().toLowerCase();\n\n if (type === 'checkbox_group') {\n return <CheckboxGroup key={name} field={field} />;\n }\n\n if (field.type === 'hidden') {\n const val = field.value ?? '';\n return <input key={name} type=\"hidden\" name={name} value={val} />;\n }\n\n if (type === 'checkbox') {\n const labelRaw = field.label ?? '';\n const companyNameClean = companyName.replace(/\\*\\*/g, '').trim();\n let labelWithCompany = companyNameClean\n ? labelRaw.replace(/\\{\\{company_name\\}\\}/gi, companyNameClean)\n : labelRaw;\n // Inject ToS/Privacy links as markdown so they render as links\n if (name === 'tos_privacy_consent' && privacyPolicyUrl && termsOfServiceUrl) {\n labelWithCompany = labelWithCompany\n .replace(/\\*\\*Terms of Service\\*\\*/gi, `**[Terms of Service](${termsOfServiceUrl})**`)\n .replace(/\\*\\*Privacy Policy\\*\\*/gi, `**[Privacy Policy](${privacyPolicyUrl})**`);\n }\n const id = `checkbox-${name}-${index}`;\n return (\n <div key={name} className=\"flex items-start gap-3\">\n <input\n type=\"checkbox\"\n id={id}\n name={name}\n value=\"on\"\n required={Boolean(field.required)}\n aria-describedby={id ? `${id}-desc` : undefined}\n className=\"mt-1 h-4 w-4 shrink-0 rounded border-secondary focus:ring-focus-ring\"\n />\n <label\n id={id ? `${id}-desc` : undefined}\n htmlFor={id}\n className=\"font-body text-sm text-tertiary [&_a]:underline [&_a]:outline-focus-ring [&_strong]:font-semibold\"\n >\n <ReactMarkdown\n remarkPlugins={[remarkGfm]}\n components={{\n p: ({ children }) => <span>{children}</span>,\n strong: (props) => <strong className=\"font-semibold\" {...props} />,\n a: (props) => <a {...props} className=\"underline outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\" />,\n }}\n >\n {labelWithCompany}\n </ReactMarkdown>\n </label>\n </div>\n );\n }\n\n if (field.type === 'tel') {\n const country = countries.find((c) => c.code === selectedCountryPhone);\n const nationalMask = getNationalMask(country);\n const value = phoneValues[name] ?? '';\n const placeholder = nationalMask ? nationalMask.replace(/#/g, '0') : (field.placeholder ?? '');\n\n const handlePhoneChange = (valueOrEvent: unknown) => {\n const raw =\n typeof valueOrEvent === 'string'\n ? valueOrEvent\n : (valueOrEvent &&\n typeof valueOrEvent === 'object' &&\n 'target' in valueOrEvent &&\n (valueOrEvent as { target?: { value?: unknown } }).target &&\n typeof (valueOrEvent as { target: { value?: unknown } }).target.value === 'string'\n ? (valueOrEvent as { target: { value: string } }).target.value\n : '');\n\n const digits = raw.replace(/\\D/g, '');\n const formatted = nationalMask ? formatDigitsToMask(digits, nationalMask) : digits;\n setPhoneValues((prev) => ({ ...prev, [name]: formatted }));\n };\n\n if (showCountryCode) {\n const countryOptions = countries.map((c) => ({\n label: c.phoneCode.startsWith('+') ? c.phoneCode : `+${c.phoneCode}`,\n value: c.code,\n }));\n return (\n <InputGroup\n key={name}\n label={field.label}\n isRequired={Boolean(field.required)}\n size=\"md\"\n leadingAddon={\n <NativeSelect\n aria-label=\"Country code\"\n value={selectedCountryPhone}\n onChange={(e: React.ChangeEvent<HTMLSelectElement>) =>\n onCountryChange(e.currentTarget.value)\n }\n options={countryOptions}\n />\n }\n >\n <InputBase\n type=\"tel\"\n name={name}\n value={value}\n onChange={handlePhoneChange}\n placeholder={placeholder}\n size=\"md\"\n />\n </InputGroup>\n );\n }\n\n // No country code selector — render a formatted phone input directly\n return (\n <InputGroup key={name} label={field.label} isRequired={Boolean(field.required)} size=\"md\">\n <InputBase\n type=\"tel\"\n name={name}\n value={value}\n onChange={handlePhoneChange}\n placeholder={placeholder}\n size=\"md\"\n />\n </InputGroup>\n );\n }\n\n if (field.type === 'textarea') {\n return (\n <Textarea\n key={name}\n name={name}\n label={field.label}\n placeholder={field.placeholder}\n rows={6}\n isRequired={Boolean(field.required)}\n />\n );\n }\n\n const inputType = INPUT_TYPES.includes(field.type as (typeof INPUT_TYPES)[number])\n ? (field.type as 'text' | 'email' | 'tel')\n : 'text';\n return (\n <Input\n key={name}\n isRequired={Boolean(field.required)}\n size=\"md\"\n name={name}\n label={field.label}\n type={inputType}\n placeholder={field.placeholder}\n />\n );\n}\n\n// ─── DynamicFormFields ────────────────────────────────────────────────────────\n\nexport function DynamicFormFields({ form, jobSlug, privacyPolicyUrl, termsOfServiceUrl }: DynamicFormFieldsProps) {\n const [selectedCountryPhone, setSelectedCountryPhone] = useState('US');\n const [phoneValues, setPhoneValues] = useState<Record<string, string>>({});\n const { settings } = form;\n const fields: FormDefinition['fields'] = Array.isArray(form.fields) ? form.fields : [];\n const companyName = form.company_name ?? '';\n\n const handleCountryChange = (newCode: string) => {\n setSelectedCountryPhone(newCode);\n const country = countries.find((c) => c.code === newCode);\n const nationalMask = getNationalMask(country);\n if (!nationalMask) return;\n setPhoneValues((prev) => {\n const next = { ...prev };\n let changed = false;\n for (const name of Object.keys(next)) {\n const digits = next[name].replace(/\\D/g, '');\n const formatted = formatDigitsToMask(digits, nationalMask);\n if (formatted !== next[name]) {\n next[name] = formatted;\n changed = true;\n }\n }\n return changed ? next : prev;\n });\n };\n\n /** Show country code selector for tel fields; default true (US +1) unless backend sets to false. */\n const showCountryCode = settings?.show_country_code !== false;\n const flat = allFieldsFlat(fields);\n const hasPhoneField = flat.some((f) => f.type === 'tel');\n const hasCheckboxFields = flat.some((f) => (f.type ?? '').toString().toLowerCase() === 'checkbox');\n const showPrivacyCheckbox =\n settings?.show_privacy_checkbox !== false && hasPhoneField && !hasCheckboxFields;\n\n const renderFieldWithProps = (item: FormFieldDefinition, i: number) =>\n renderField(\n item,\n i,\n showCountryCode,\n selectedCountryPhone,\n handleCountryChange,\n phoneValues,\n setPhoneValues,\n companyName,\n privacyPolicyUrl,\n termsOfServiceUrl\n );\n\n return (\n <div className=\"flex flex-col gap-6\">\n {fields.map((item, index) => {\n if (Array.isArray(item)) {\n if (item.length === 0) return null;\n return (\n <div\n key={`row-${index}`}\n className=\"flex flex-col gap-x-8 gap-y-6 md:flex-row\"\n >\n {item.map((f, i) => (\n <div key={f.name} className=\"flex-1\">\n {renderFieldWithProps(f, i)}\n </div>\n ))}\n </div>\n );\n }\n return (\n <div key={item.name ?? `field-${index}`}>\n {renderFieldWithProps(item, index)}\n </div>\n );\n })}\n\n {jobSlug ? <input type=\"hidden\" name=\"jobSlug\" value={jobSlug} /> : null}\n\n {showPrivacyCheckbox && <PrivacyCheckbox />}\n </div>\n );\n}\n","\"use client\";\n\nimport type { HTMLAttributes } from \"react\";\nimport Image from \"next/image\";\nimport type { SelectItemType } from '../design_system/elements/select/select';\n\n/**\n * List of countries with their respective country code, flag, phone code, and phone mask.\n */\nexport const countries = [\n {\n name: \"Afghanistan\",\n code: \"AF\",\n flag: \"https://www.untitledui.com/images/flags/AF.svg\",\n phoneCode: \"93\",\n phoneMask: \"+93-##-###-####\",\n },\n {\n name: \"Albania\",\n code: \"AL\",\n flag: \"https://www.untitledui.com/images/flags/AL.svg\",\n phoneCode: \"355\",\n phoneMask: \"+355 (###) ###-###\",\n },\n {\n name: \"Algeria\",\n code: \"DZ\",\n flag: \"https://www.untitledui.com/images/flags/DZ.svg\",\n phoneCode: \"213\",\n phoneMask: \"+213-##-###-####\",\n },\n {\n name: \"Andorra\",\n code: \"AD\",\n flag: \"https://www.untitledui.com/images/flags/AD.svg\",\n phoneCode: \"376\",\n phoneMask: \"+376-###-###\",\n },\n {\n name: \"Angola\",\n code: \"AO\",\n flag: \"https://www.untitledui.com/images/flags/AO.svg\",\n phoneCode: \"244\",\n phoneMask: \"+244 (###) ###-###\",\n },\n {\n name: \"Antigua and Barbuda\",\n code: \"AG\",\n flag: \"https://www.untitledui.com/images/flags/AG.svg\",\n phoneCode: \"+1-268\",\n phoneMask: \"+1 (268) ###-####\",\n },\n {\n name: \"Argentina\",\n code: \"AR\",\n flag: \"https://www.untitledui.com/images/flags/AR.svg\",\n phoneCode: \"54\",\n phoneMask: \"+54 (###) ###-####\",\n },\n {\n name: \"Armenia\",\n code: \"AM\",\n flag: \"https://www.untitledui.com/images/flags/AM.svg\",\n phoneCode: \"374\",\n phoneMask: \"+374-##-###-###\",\n },\n {\n name: \"Australia\",\n code: \"AU\",\n flag: \"https://www.untitledui.com/images/flags/AU.svg\",\n phoneCode: \"61\",\n phoneMask: \"+61-#-####-####\",\n },\n {\n name: \"Austria\",\n code: \"AT\",\n flag: \"https://www.untitledui.com/images/flags/AT.svg\",\n phoneCode: \"43\",\n phoneMask: \"+43 (###) ###-####\",\n },\n {\n name: \"Azerbaijan\",\n code: \"AZ\",\n flag: \"https://www.untitledui.com/images/flags/AZ.svg\",\n phoneCode: \"994\",\n phoneMask: \"+994-##-###-##-##\",\n },\n {\n name: \"Bahamas\",\n code: \"BS\",\n flag: \"https://www.untitledui.com/images/flags/BS.svg\",\n phoneCode: \"+1-242\",\n phoneMask: \"+1 (242) ###-####\",\n },\n {\n name: \"Bahrain\",\n code: \"BH\",\n flag: \"https://www.untitledui.com/images/flags/BH.svg\",\n phoneCode: \"973\",\n phoneMask: \"+973-####-####\",\n },\n {\n name: \"Bangladesh\",\n code: \"BD\",\n flag: \"https://www.untitledui.com/images/flags/BD.svg\",\n phoneCode: \"880\",\n phoneMask: \"+880-##-###-###\",\n },\n {\n name: \"Barbados\",\n code: \"BB\",\n flag: \"https://www.untitledui.com/images/flags/BB.svg\",\n phoneCode: \"+1-246\",\n phoneMask: \"+1 (246) ###-####\",\n },\n {\n name: \"Belarus\",\n code: \"BY\",\n flag: \"https://www.untitledui.com/images/flags/BY.svg\",\n phoneCode: \"375\",\n phoneMask: \"+375 (##) ###-##-##\",\n },\n {\n name: \"Belgium\",\n code: \"BE\",\n flag: \"https://www.untitledui.com/images/flags/BE.svg\",\n phoneCode: \"32\",\n phoneMask: \"+32 (###) ###-###\",\n },\n {\n name: \"Belize\",\n code: \"BZ\",\n flag: \"https://www.untitledui.com/images/flags/BZ.svg\",\n phoneCode: \"501\",\n phoneMask: \"+501-###-####\",\n },\n {\n name: \"Benin\",\n code: \"BJ\",\n flag: \"https://www.untitledui.com/images/flags/BJ.svg\",\n phoneCode: \"229\",\n phoneMask: \"+229-##-##-####\",\n },\n {\n name: \"Bhutan\",\n code: \"BT\",\n flag: \"https://www.untitledui.com/images/flags/BT.svg\",\n phoneCode: \"975\",\n phoneMask: \"+975-#-###-###\",\n },\n {\n name: \"Bolivia\",\n code: \"BO\",\n flag: \"https://www.untitledui.com/images/flags/BO.svg\",\n phoneCode: \"591\",\n phoneMask: \"+591-#-###-####\",\n },\n {\n name: \"Bosnia and Herzegovina\",\n code: \"BA\",\n flag: \"https://www.untitledui.com/images/flags/BA.svg\",\n phoneCode: \"387\",\n phoneMask: \"+387-##-####\",\n },\n {\n name: \"Botswana\",\n code: \"BW\",\n flag: \"https://www.untitledui.com/images/flags/BW.svg\",\n phoneCode: \"267\",\n phoneMask: \"+267-##-###-###\",\n },\n {\n name: \"Brazil\",\n code: \"BR\",\n flag: \"https://www.untitledui.com/images/flags/BR.svg\",\n phoneCode: \"55\",\n phoneMask: \"+55 (##) 9####-####\",\n },\n {\n name: \"Brunei\",\n code: \"BN\",\n flag: \"https://www.untitledui.com/images/flags/BN.svg\",\n phoneCode: \"673\",\n phoneMask: \"+673-###-####\",\n },\n {\n name: \"Bulgaria\",\n code: \"BG\",\n flag: \"https://www.untitledui.com/images/flags/BG.svg\",\n phoneCode: \"359\",\n phoneMask: \"+359 (###) ###-###\",\n },\n {\n name: \"Burkina Faso\",\n code: \"BF\",\n flag: \"https://www.untitledui.com/images/flags/BF.svg\",\n phoneCode: \"226\",\n phoneMask: \"+226-##-##-####\",\n },\n {\n name: \"Burundi\",\n code: \"BI\",\n flag: \"https://www.untitledui.com/images/flags/BI.svg\",\n phoneCode: \"257\",\n phoneMask: \"+257-##-##-####\",\n },\n {\n name: \"Cambodia\",\n code: \"KH\",\n flag: \"https://www.untitledui.com/images/flags/KH.svg\",\n phoneCode: \"855\",\n phoneMask: \"+855-##-###-###\",\n },\n {\n name: \"Cameroon\",\n code: \"CM\",\n flag: \"https://www.untitledui.com/images/flags/CM.svg\",\n phoneCode: \"237\",\n phoneMask: \"+237-####-####\",\n },\n {\n name: \"Canada\",\n code: \"CA\",\n flag: \"https://www.untitledui.com/images/flags/CA.svg\",\n phoneCode: \"1\",\n phoneMask: \"+1 (###) ###-####\",\n },\n {\n name: \"Central African Republic\",\n code: \"CF\",\n flag: \"https://www.untitledui.com/images/flags/CF.svg\",\n phoneCode: \"236\",\n phoneMask: \"+236-##-##-####\",\n },\n {\n name: \"Chad\",\n code: \"TD\",\n flag: \"https://www.untitledui.com/images/flags/TD.svg\",\n phoneCode: \"235\",\n phoneMask: \"+235-##-##-##-##\",\n },\n {\n name: \"Chile\",\n code: \"CL\",\n flag: \"https://www.untitledui.com/images/flags/CL.svg\",\n phoneCode: \"56\",\n phoneMask: \"+56-#-####-####\",\n },\n {\n name: \"China\",\n code: \"CN\",\n flag: \"https://www.untitledui.com/images/flags/CN.svg\",\n phoneCode: \"86\",\n phoneMask: \"+86-##-#####-#####\",\n },\n {\n name: \"Colombia\",\n code: \"CO\",\n flag: \"https://www.untitledui.com/images/flags/CO.svg\",\n phoneCode: \"57\",\n phoneMask: \"+57 (###) ###-####\",\n },\n {\n name: \"Comoros\",\n code: \"KM\",\n flag: \"https://www.untitledui.com/images/flags/KM.svg\",\n phoneCode: \"269\",\n phoneMask: \"+269-##-#####\",\n },\n {\n name: \"Costa Rica\",\n code: \"CR\",\n flag: \"https://www.untitledui.com/images/flags/CR.svg\",\n phoneCode: \"506\",\n phoneMask: \"+506-####-####\",\n },\n {\n name: \"Croatia\",\n code: \"HR\",\n flag: \"https://www.untitledui.com/images/flags/HR.svg\",\n phoneCode: \"385\",\n phoneMask: \"+385-##-###-###\",\n },\n {\n name: \"Cuba\",\n code: \"CU\",\n flag: \"https://www.untitledui.com/images/flags/CU.svg\",\n phoneCode: \"53\",\n phoneMask: \"+53-#-###-####\",\n },\n {\n name: \"Cyprus\",\n code: \"CY\",\n flag: \"https://www.untitledui.com/images/flags/CY.svg\",\n phoneCode: \"357\",\n phoneMask: \"+357-##-###-###\",\n },\n {\n name: \"Czech Republic\",\n code: \"CZ\",\n flag: \"https://www.untitledui.com/images/flags/CZ.svg\",\n phoneCode: \"420\",\n phoneMask: \"+420 (###) ###-###\",\n },\n {\n name: \"Democratic Republic of the Congo\",\n code: \"CD\",\n flag: \"https://www.untitledui.com/images/flags/CD.svg\",\n phoneCode: \"243\",\n phoneMask: \"+243 (###) ###-###\",\n },\n {\n name: \"Denmark\",\n code: \"DK\",\n flag: \"https://www.untitledui.com/images/flags/DK.svg\",\n phoneCode: \"45\",\n phoneMask: \"+45-##-##-##-##\",\n },\n {\n name: \"Djibouti\",\n code: \"DJ\",\n flag: \"https://www.untitledui.com/images/flags/DJ.svg\",\n phoneCode: \"253\",\n phoneMask: \"+253-##-##-##-##\",\n },\n {\n name: \"Dominica\",\n code: \"DM\",\n flag: \"https://www.untitledui.com/images/flags/DM.svg\",\n phoneCode: \"+1-767\",\n phoneMask: \"+1 (767) ###-####\",\n },\n {\n name: \"Dominican Republic\",\n code: \"DO\",\n flag: \"https://www.untitledui.com/images/flags/DO.svg\",\n phoneCode: \"+1-809\",\n phoneMask: \"+1 (809) ###-####\",\n },\n {\n name: \"East Timor\",\n code: \"TL\",\n flag: \"https://www.untitledui.com/images/flags/TL.svg\",\n phoneCode: \"670\",\n phoneMask: \"+670-78#-#####\",\n },\n {\n name: \"Ecuador\",\n code: \"EC\",\n flag: \"https://www.untitledui.com/images/flags/EC.svg\",\n phoneCode: \"593\",\n phoneMask: \"+593-#-###-####\",\n },\n {\n name: \"Egypt\",\n code: \"EG\",\n flag: \"https://www.untitledui.com/images/flags/EG.svg\",\n phoneCode: \"20\",\n phoneMask: \"+20 (###) ###-####\",\n },\n {\n name: \"El Salvador\",\n code: \"SV\",\n flag: \"https://www.untitledui.com/images/flags/SV.svg\",\n phoneCode: \"503\",\n phoneMask: \"+503-##-##-####\",\n },\n {\n name: \"Equatorial Guinea\",\n code: \"GQ\",\n flag: \"https://www.untitledui.com/images/flags/GQ.svg\",\n phoneCode: \"240\",\n phoneMask: \"+240-##-###-####\",\n },\n {\n name: \"Eritrea\",\n code: \"ER\",\n flag: \"https://www.untitledui.com/images/flags/ER.svg\",\n phoneCode: \"291\",\n phoneMask: \"+291-#-###-###\",\n },\n {\n name: \"Estonia\",\n code: \"EE\",\n flag: \"https://www.untitledui.com/images/flags/EE.svg\",\n phoneCode: \"372\",\n phoneMask: \"+372-###-####\",\n },\n {\n name: \"Eswatini\",\n code: \"SZ\",\n flag: \"https://www.untitledui.com/images/flags/SZ.svg\",\n phoneCode: \"268\",\n phoneMask: \"+268-##-##-####\",\n },\n {\n name: \"Ethiopia\",\n code: \"ET\",\n flag: \"https://www.untitledui.com/images/flags/ET.svg\",\n phoneCode: \"251\",\n phoneMask: \"+251-##-###-####\",\n },\n {\n name: \"Fiji\",\n code: \"FJ\",\n flag: \"https://www.untitledui.com/images/flags/FJ.svg\",\n phoneCode: \"679\",\n phoneMask: \"+679-##-#####\",\n },\n {\n name: \"Finland\",\n code: \"FI\",\n flag: \"https://www.untitledui.com/images/flags/FI.svg\",\n phoneCode: \"358\",\n phoneMask: \"+358 (###) ###-##-##\",\n },\n {\n name: \"France\",\n code: \"FR\",\n flag: \"https://www.untitledui.com/images/flags/FR.svg\",\n phoneCode: \"33\",\n phoneMask: \"+590 (###) ###-###\",\n },\n {\n name: \"Gabon\",\n code: \"GA\",\n flag: \"https://www.untitledui.com/images/flags/GA.svg\",\n phoneCode: \"241\",\n phoneMask: \"+241-#-##-##-##\",\n },\n {\n name: \"Gambia\",\n code: \"GM\",\n flag: \"https://www.untitledui.com/images/flags/GM.svg\",\n phoneCode: \"220\",\n phoneMask: \"+220 (###) ##-##\",\n },\n {\n name: \"Georgia\",\n code: \"GE\",\n flag: \"https://www.untitledui.com/images/flags/GE.svg\",\n phoneCode: \"995\",\n phoneMask: \"+995 (###) ###-###\",\n },\n {\n name: \"Germany\",\n code: \"DE\",\n flag: \"https://www.untitledui.com/images/flags/DE.svg\",\n phoneCode: \"49\",\n phoneMask: \"+49-###-###\",\n },\n {\n name: \"Ghana\",\n code: \"GH\",\n flag: \"https://www.untitledui.com/images/flags/GH.svg\",\n phoneCode: \"233\",\n phoneMask: \"+233 (###) ###-###\",\n },\n {\n name: \"Greece\",\n code: \"GR\",\n flag: \"https://www.untitledui.com/images/flags/GR.svg\",\n phoneCode: \"30\",\n phoneMask: \"+30 (###) ###-####\",\n },\n {\n name: \"Grenada\",\n code: \"GD\",\n flag: \"https://www.untitledui.com/images/flags/GD.svg\",\n phoneCode: \"+1-473\",\n phoneMask: \"+1 (473) ###-####\",\n },\n {\n name: \"Guatemala\",\n code: \"GT\",\n flag: \"https://www.untitledui.com/images/flags/GT.svg\",\n phoneCode: \"502\",\n phoneMask: \"+502-#-###-####\",\n },\n {\n name: \"Guinea\",\n code: \"GN\",\n flag: \"https://www.untitledui.com/images/flags/GN.svg\",\n phoneCode: \"224\",\n phoneMask: \"+224-##-###-###\",\n },\n {\n name: \"Guinea-Bissau\",\n code: \"GW\",\n flag: \"https://www.untitledui.com/images/flags/GW.svg\",\n phoneCode: \"245\",\n phoneMask: \"+245-#-######\",\n },\n {\n name: \"Guyana\",\n code: \"GY\",\n flag: \"https://www.untitledui.com/images/flags/GY.svg\",\n phoneCode: \"592\",\n phoneMask: \"+592-###-####\",\n },\n {\n name: \"Haiti\",\n code: \"HT\",\n flag: \"https://www.untitledui.com/images/flags/HT.svg\",\n phoneCode: \"509\",\n phoneMask: \"+509-##-##-####\",\n },\n {\n name: \"Honduras\",\n code: \"HN\",\n flag: \"https://www.untitledui.com/images/flags/HN.svg\",\n phoneCode: \"504\",\n phoneMask: \"+504-####-####\",\n },\n {\n name: \"Hungary\",\n code: \"HU\",\n flag: \"https://www.untitledui.com/images/flags/HU.svg\",\n phoneCode: \"36\",\n phoneMask: \"+36 (###) ###-###\",\n },\n {\n name: \"Iceland\",\n code: \"IS\",\n flag: \"https://www.untitledui.com/images/flags/IS.svg\",\n phoneCode: \"354\",\n phoneMask: \"+354-###-####\",\n },\n {\n name: \"India\",\n code: \"IN\",\n flag: \"https://www.untitledui.com/images/flags/IN.svg\",\n phoneCode: \"91\",\n phoneMask: \"+91 (####) ###-###\",\n },\n {\n name: \"Indonesia\",\n code: \"ID\",\n flag: \"https://www.untitledui.com/images/flags/ID.svg\",\n phoneCode: \"62\",\n phoneMask: \"+62 (8##) ###-##-###\",\n },\n {\n name: \"Iran\",\n code: \"IR\",\n flag: \"https://www.untitledui.com/images/flags/IR.svg\",\n phoneCode: \"98\",\n phoneMask: \"+98 (###) ###-####\",\n },\n {\n name: \"Iraq\",\n code: \"IQ\",\n flag: \"https://www.untitledui.com/images/flags/IQ.svg\",\n phoneCode: \"964\",\n phoneMask: \"+964 (###) ###-####\",\n },\n {\n name: \"Ireland\",\n code: \"IE\",\n flag: \"https://www.untitledui.com/images/flags/IE.svg\",\n phoneCode: \"353\",\n phoneMask: \"+353 (###) ###-###\",\n },\n {\n name: \"Israel\",\n code: \"IL\",\n flag: \"https://www.untitledui.com/images/flags/IL.svg\",\n phoneCode: \"972\",\n phoneMask: \"+972-#-###-####\",\n },\n {\n name: \"Italy\",\n code: \"IT\",\n flag: \"https://www.untitledui.com/images/flags/IT.svg\",\n phoneCode: \"39\",\n phoneMask: \"+39 (###) ####-###\",\n },\n {\n name: \"Jamaica\",\n code: \"JM\",\n flag: \"https://www.untitledui.com/images/flags/JM.svg\",\n phoneCode: \"+1-876\",\n phoneMask: \"+1 (876) ###-####\",\n },\n {\n name: \"Japan\",\n code: \"JP\",\n flag: \"https://www.untitledui.com/images/flags/JP.svg\",\n phoneCode: \"81\",\n phoneMask: \"+81 (###) ###-###\",\n },\n {\n name: \"Jordan\",\n code: \"JO\",\n flag: \"https://www.untitledui.com/images/flags/JO.svg\",\n phoneCode: \"962\",\n phoneMask: \"+962-#-####-####\",\n },\n {\n name: \"Kazakhstan\",\n code: \"KZ\",\n flag: \"https://www.untitledui.com/images/flags/KZ.svg\",\n phoneCode: \"7\",\n phoneMask: \"+7 (7##) ###-##-##\",\n },\n {\n name: \"Kenya\",\n code: \"KE\",\n flag: \"https://www.untitledui.com/images/flags/KE.svg\",\n phoneCode: \"254\",\n phoneMask: \"+254-###-######\",\n },\n {\n name: \"Kiribati\",\n code: \"KI\",\n flag: \"https://www.untitledui.com/images/flags/KI.svg\",\n phoneCode: \"686\",\n phoneMask: \"+686-##-###\",\n },\n {\n name: \"Kuwait\",\n code: \"KW\",\n flag: \"https://www.untitledui.com/images/flags/KW.svg\",\n phoneCode: \"965\",\n phoneMask: \"+965-####-####\",\n },\n {\n name: \"Kyrgyzstan\",\n code: \"KG\",\n flag: \"https://www.untitledui.com/images/flags/KG.svg\",\n phoneCode: \"996\",\n phoneMask: \"+996 (###) ###-###\",\n },\n {\n name: \"Laos\",\n code: \"LA\",\n flag: \"https://www.untitledui.com/images/flags/LA.svg\",\n phoneCode: \"856\",\n phoneMask: \"+856-##-###-###\",\n },\n {\n name: \"Latvia\",\n code: \"LV\",\n flag: \"https://www.untitledui.com/images/flags/LV.svg\",\n phoneCode: \"371\",\n phoneMask: \"+371-##-###-###\",\n },\n {\n name: \"Lebanon\",\n code: \"LB\",\n flag: \"https://www.untitledui.com/images/flags/LB.svg\",\n phoneCode: \"961\",\n phoneMask: \"+961-#-###-###\",\n },\n {\n name: \"Lesotho\",\n code: \"LS\",\n flag: \"https://www.untitledui.com/images/flags/LS.svg\",\n phoneCode: \"266\",\n phoneMask: \"+266-#-###-####\",\n },\n {\n name: \"Liberia\",\n code: \"LR\",\n flag: \"https://www.untitledui.com/images/flags/LR.svg\",\n phoneCode: \"231\",\n phoneMask: \"+231-##-###-###\",\n },\n {\n name: \"Libya\",\n code: \"LY\",\n flag: \"https://www.untitledui.com/images/flags/LY.svg\",\n phoneCode: \"218\",\n phoneMask: \"+218-21-###-####\",\n },\n {\n name: \"Liechtenstein\",\n code: \"LI\",\n flag: \"https://www.untitledui.com/images/flags/LI.svg\",\n phoneCode: \"423\",\n phoneMask: \"+423 (###) ###-####\",\n },\n {\n name: \"Lithuania\",\n code: \"LT\",\n flag: \"https://www.untitledui.com/images/flags/LT.svg\",\n phoneCode: \"370\",\n phoneMask: \"+370 (###) ##-###\",\n },\n {\n name: \"Luxembourg\",\n code: \"LU\",\n flag: \"https://www.untitledui.com/images/flags/LU.svg\",\n phoneCode: \"352\",\n phoneMask: \"+352 (###) ###-###\",\n },\n {\n name: \"Madagascar\",\n code: \"MG\",\n flag: \"https://www.untitledui.com/images/flags/MG.svg\",\n phoneCode: \"261\",\n phoneMask: \"+261-##-##-#####\",\n },\n {\n name: \"Malawi\",\n code: \"MW\",\n flag: \"https://www.untitledui.com/images/flags/MW.svg\",\n phoneCode: \"265\",\n phoneMask: \"+265-#-####-####\",\n },\n {\n name: \"Malaysia\",\n code: \"MY\",\n flag: \"https://www.untitledui.com/images/flags/MY.svg\",\n phoneCode: \"60\",\n phoneMask: \"+60-#-###-###\",\n },\n {\n name: \"Maldives\",\n code: \"MV\",\n flag: \"https://www.untitledui.com/images/flags/MV.svg\",\n phoneCode: \"960\",\n phoneMask: \"+960-###-####\",\n },\n {\n name: \"Mali\",\n code: \"ML\",\n flag: \"https://www.untitledui.com/images/flags/ML.svg\",\n phoneCode: \"223\",\n phoneMask: \"+223-##-##-####\",\n },\n {\n name: \"Malta\",\n code: \"MT\",\n flag: \"https://www.untitledui.com/images/flags/MT.svg\",\n phoneCode: \"356\",\n phoneMask: \"+356-####-####\",\n },\n {\n name: \"Marshall Islands\",\n code: \"MH\",\n flag: \"https://www.untitledui.com/images/flags/MH.svg\",\n phoneCode: \"692\",\n phoneMask: \"+692-###-####\",\n },\n {\n name: \"Mauritania\",\n code: \"MR\",\n flag: \"https://www.untitledui.com/images/flags/MR.svg\",\n phoneCode: \"222\",\n phoneMask: \"+222-##-##-####\",\n },\n {\n name: \"Mauritius\",\n code: \"MU\",\n flag: \"https://www.untitledui.com/images/flags/MU.svg\",\n phoneCode: \"230\",\n phoneMask: \"+230-###-####\",\n },\n {\n name: \"Mexico\",\n code: \"MX\",\n flag: \"https://www.untitledui.com/images/flags/MX.svg\",\n phoneCode: \"52\",\n phoneMask: \"+52-##-##-####\",\n },\n {\n name: \"Micronesia\",\n code: \"FM\",\n flag: \"https://www.untitledui.com/images/flags/FM.svg\",\n phoneCode: \"691\",\n phoneMask: \"+691-###-####\",\n },\n {\n name: \"Moldova\",\n code: \"MD\",\n flag: \"https://www.untitledui.com/images/flags/MD.svg\",\n phoneCode: \"373\",\n phoneMask: \"+373-####-####\",\n },\n {\n name: \"Monaco\",\n code: \"MC\",\n flag: \"https://www.untitledui.com/images/flags/MC.svg\",\n phoneCode: \"377\",\n phoneMask: \"+377-##-###-###\",\n },\n {\n name: \"Mongolia\",\n code: \"MN\",\n flag: \"https://www.untitledui.com/images/flags/MN.svg\",\n phoneCode: \"976\",\n phoneMask: \"+976-##-##-####\",\n },\n {\n name: \"Montenegro\",\n code: \"ME\",\n flag: \"https://www.untitledui.com/images/flags/ME.svg\",\n phoneCode: \"382\",\n phoneMask: \"+382-##-###-###\",\n },\n {\n name: \"Morocco\",\n code: \"MA\",\n flag: \"https://www.untitledui.com/images/flags/MA.svg\",\n phoneCode: \"212\",\n phoneMask: \"+212-##-####-###\",\n },\n {\n name: \"Mozambique\",\n code: \"MZ\",\n flag: \"https://www.untitledui.com/images/flags/MZ.svg\",\n phoneCode: \"258\",\n phoneMask: \"+258-##-###-###\",\n },\n {\n name: \"Myanmar\",\n code: \"MM\",\n flag: \"https://www.untitledui.com/images/flags/MM.svg\",\n phoneCode: \"95\",\n phoneMask: \"+95-###-###\",\n },\n {\n name: \"Namibia\",\n code: \"NA\",\n flag: \"https://www.untitledui.com/images/flags/NA.svg\",\n phoneCode: \"264\",\n phoneMask: \"+264-##-###-####\",\n },\n {\n name: \"Nauru\",\n code: \"NR\",\n flag: \"https://www.untitledui.com/images/flags/NR.svg\",\n phoneCode: \"674\",\n phoneMask: \"+674-###-####\",\n },\n {\n name: \"Nepal\",\n code: \"NP\",\n flag: \"https://www.untitledui.com/images/flags/NP.svg\",\n phoneCode: \"977\",\n phoneMask: \"+977-##-###-###\",\n },\n {\n name: \"Netherlands\",\n code: \"NL\",\n flag: \"https://www.untitledui.com/images/flags/NL.svg\",\n phoneCode: \"31\",\n phoneMask: \"+31-##-###-####\",\n },\n {\n name: \"New Zealand\",\n code: \"NZ\",\n flag: \"https://www.untitledui.com/images/flags/NZ.svg\",\n phoneCode: \"64\",\n phoneMask: \"+64 (###) ###-####\",\n },\n {\n name: \"Nicaragua\",\n code: \"NI\",\n flag: \"https://www.untitledui.com/images/flags/NI.svg\",\n phoneCode: \"505\",\n phoneMask: \"+505-####-####\",\n },\n {\n name: \"Niger\",\n code: \"NE\",\n flag: \"https://www.untitledui.com/images/flags/NE.svg\",\n phoneCode: \"227\",\n phoneMask: \"+227-##-##-####\",\n },\n {\n name: \"Nigeria\",\n code: \"NG\",\n flag: \"https://www.untitledui.com/images/flags/NG.svg\",\n phoneCode: \"234\",\n phoneMask: \"+234 (###) ###-####\",\n },\n {\n name: \"North Korea\",\n code: \"KP\",\n flag: \"https://www.untitledui.com/images/flags/KP.svg\",\n phoneCode: \"850\",\n phoneMask: \"+850-####-#############\",\n },\n {\n name: \"North Macedonia\",\n code: \"MK\",\n flag: \"https://www.untitledui.com/images/flags/MK.svg\",\n phoneCode: \"389\",\n phoneMask: \"+389-##-###-###\",\n },\n {\n name: \"Norway\",\n code: \"NO\",\n flag: \"https://www.untitledui.com/images/flags/NO.svg\",\n phoneCode: \"47\",\n phoneMask: \"+47 (###) ##-###\",\n },\n {\n name: \"Oman\",\n code: \"OM\",\n flag: \"https://www.untitledui.com/images/flags/OM.svg\",\n phoneCode: \"968\",\n phoneMask: \"+968-##-###-###\",\n },\n {\n name: \"Pakistan\",\n code: \"PK\",\n flag: \"https://www.untitledui.com/images/flags/PK.svg\",\n phoneCode: \"92\",\n phoneMask: \"+92 (###) ###-####\",\n },\n {\n name: \"Palau\",\n code: \"PW\",\n flag: \"https://www.untitledui.com/images/flags/PW.svg\",\n phoneCode: \"680\",\n phoneMask: \"+680-###-####\",\n },\n {\n name: \"Panama\",\n code: \"PA\",\n flag: \"https://www.untitledui.com/images/flags/PA.svg\",\n phoneCode: \"507\",\n phoneMask: \"+507-###-####\",\n },\n {\n name: \"Papua New Guinea\",\n code: \"PG\",\n flag: \"https://www.untitledui.com/images/flags/PG.svg\",\n phoneCode: \"675\",\n phoneMask: \"+675 (###) ##-###\",\n },\n {\n name: \"Paraguay\",\n code: \"PY\",\n flag: \"https://www.untitledui.com/images/flags/PY.svg\",\n phoneCode: \"595\",\n phoneMask: \"+595 (###) ###-###\",\n },\n {\n name: \"Peru\",\n code: \"PE\",\n flag: \"https://www.untitledui.com/images/flags/PE.svg\",\n phoneCode: \"51\",\n phoneMask: \"+51 (###) ###-###\",\n },\n {\n name: \"Philippines\",\n code: \"PH\",\n flag: \"https://www.untitledui.com/images/flags/PH.svg\",\n phoneCode: \"63\",\n phoneMask: \"+63 (###) ###-####\",\n },\n {\n name: \"Poland\",\n code: \"PL\",\n flag: \"https://www.untitledui.com/images/flags/PL.svg\",\n phoneCode: \"48\",\n phoneMask: \"+48 (###) ###-###\",\n },\n {\n name: \"Portugal\",\n code: \"PT\",\n flag: \"https://www.untitledui.com/images/flags/PT.svg\",\n phoneCode: \"351\",\n phoneMask: \"+351-##-###-####\",\n },\n {\n name: \"Qatar\",\n code: \"QA\",\n flag: \"https://www.untitledui.com/images/flags/QA.svg\",\n phoneCode: \"974\",\n phoneMask: \"+974-####-####\",\n },\n {\n name: \"Romania\",\n code: \"RO\",\n flag: \"https://www.untitledui.com/images/flags/RO.svg\",\n phoneCode: \"40\",\n phoneMask: \"+40-##-###-####\",\n },\n {\n name: \"Russia\",\n code: \"RU\",\n flag: \"https://www.untitledui.com/images/flags/RU.svg\",\n phoneCode: \"7\",\n phoneMask: \"+7 (###) ###-##-##\",\n },\n {\n name: \"Rwanda\",\n code: \"RW\",\n flag: \"https://www.untitledui.com/images/flags/RW.svg\",\n phoneCode: \"250\",\n phoneMask: \"+250 (###) ###-###\",\n },\n {\n name: \"Saint Kitts and Nevis\",\n code: \"KN\",\n flag: \"https://www.untitledui.com/images/flags/KN.svg\",\n phoneCode: \"+1-869\",\n phoneMask: \"+1 (869) ###-####\",\n },\n {\n name: \"Saint Lucia\",\n code: \"LC\",\n flag: \"https://www.untitledui.com/images/flags/LC.svg\",\n phoneCode: \"+1-758\",\n phoneMask: \"+1 (758) ###-####\",\n },\n {\n name: \"Saint Vincent and the Grenadines\",\n code: \"VC\",\n flag: \"https://www.untitledui.com/images/flags/VC.svg\",\n phoneCode: \"+1-784\",\n phoneMask: \"+1 (784) ###-####\",\n },\n {\n name: \"Samoa\",\n code: \"WS\",\n flag: \"https://www.untitledui.com/images/flags/WS.svg\",\n phoneCode: \"685\",\n phoneMask: \"+685-##-####\",\n },\n {\n name: \"San Marino\",\n code: \"SM\",\n flag: \"https://www.untitledui.com/images/flags/SM.svg\",\n phoneCode: \"378\",\n phoneMask: \"+378-####-######\",\n },\n {\n name: \"Sao Tome and Principe\",\n code: \"ST\",\n flag: \"https://www.untitledui.com/images/flags/ST.svg\",\n phoneCode: \"239\",\n phoneMask: \"+239-##-#####\",\n },\n {\n name: \"Saudi Arabia\",\n code: \"SA\",\n flag: \"https://www.untitledui.com/images/flags/SA.svg\",\n phoneCode: \"966\",\n phoneMask: \"+966-#-###-####\",\n },\n {\n name: \"Senegal\",\n code: \"SN\",\n flag: \"https://www.untitledui.com/images/flags/SN.svg\",\n phoneCode: \"221\",\n phoneMask: \"+221-##-###-####\",\n },\n {\n name: \"Serbia\",\n code: \"RS\",\n flag: \"https://www.untitledui.com/images/flags/RS.svg\",\n phoneCode: \"381\",\n phoneMask: \"+381-##-###-####\",\n },\n {\n name: \"Seychelles\",\n code: \"SC\",\n flag: \"https://www.untitledui.com/images/flags/SC.svg\",\n phoneCode: \"248\",\n phoneMask: \"+248-#-###-###\",\n },\n {\n name: \"Sierra Leone\",\n code: \"SL\",\n flag: \"https://www.untitledui.com/images/flags/SL.svg\",\n phoneCode: \"232\",\n phoneMask: \"+232-##-######\",\n },\n {\n name: \"Singapore\",\n code: \"SG\",\n flag: \"https://www.untitledui.com/images/flags/SG.svg\",\n phoneCode: \"65\",\n phoneMask: \"+65-####-####\",\n },\n {\n name: \"Slovakia\",\n code: \"SK\",\n flag: \"https://www.untitledui.com/images/flags/SK.svg\",\n phoneCode: \"421\",\n phoneMask: \"+421 (###) ###-###\",\n },\n {\n name: \"Slovenia\",\n code: \"SI\",\n flag: \"https://www.untitledui.com/images/flags/SI.svg\",\n phoneCode: \"386\",\n phoneMask: \"+386-##-###-###\",\n },\n {\n name: \"Solomon Islands\",\n code: \"SB\",\n flag: \"https://www.untitledui.com/images/flags/SB.svg\",\n phoneCode: \"677\",\n phoneMask: \"+677-#####\",\n },\n {\n name: \"Somalia\",\n code: \"SO\",\n flag: \"https://www.untitledui.com/images/flags/SO.svg\",\n phoneCode: \"252\",\n phoneMask: \"+252-#-###-###\",\n },\n {\n name: \"South Africa\",\n code: \"ZA\",\n flag: \"https://www.untitledui.com/images/flags/ZA.svg\",\n phoneCode: \"27\",\n phoneMask: \"+27-##-###-####\",\n },\n {\n name: \"South Korea\",\n code: \"KR\",\n flag: \"https://www.untitledui.com/images/flags/KR.svg\",\n phoneCode: \"82\",\n phoneMask: \"+82-##-###-####\",\n },\n {\n name: \"South Sudan\",\n code: \"SS\",\n flag: \"https://www.untitledui.com/images/flags/SS.svg\",\n phoneCode: \"211\",\n phoneMask: \"+211-##-###-####\",\n },\n {\n name: \"Spain\",\n code: \"ES\",\n flag: \"https://www.untitledui.com/images/flags/ES.svg\",\n phoneCode: \"34\",\n phoneMask: \"+34 (###) ###-###\",\n },\n {\n name: \"Sri Lanka\",\n code: \"LK\",\n flag: \"https://www.untitledui.com/images/flags/LK.svg\",\n phoneCode: \"94\",\n phoneMask: \"+94-##-###-####\",\n },\n {\n name: \"Suriname\",\n code: \"SR\",\n flag: \"https://www.untitledui.com/images/flags/SR.svg\",\n phoneCode: \"597\",\n phoneMask: \"+597-###-###\",\n },\n {\n name: \"Sweden\",\n code: \"SE\",\n flag: \"https://www.untitledui.com/images/flags/SE.svg\",\n phoneCode: \"46\",\n phoneMask: \"+46-##-###-####\",\n },\n {\n name: \"Switzerland\",\n code: \"CH\",\n flag: \"https://www.untitledui.com/images/flags/CH.svg\",\n phoneCode: \"41\",\n phoneMask: \"+41-##-###-####\",\n },\n {\n name: \"Syria\",\n code: \"SY\",\n flag: \"https://www.untitledui.com/images/flags/SY.svg\",\n phoneCode: \"963\",\n phoneMask: \"+963-##-####-###\",\n },\n {\n name: \"Tajikistan\",\n code: \"TJ\",\n flag: \"https://www.untitledui.com/images/flags/TJ.svg\",\n phoneCode: \"992\",\n phoneMask: \"+992-##-###-####\",\n },\n {\n name: \"Tanzania\",\n code: \"TZ\",\n flag: \"https://www.untitledui.com/images/flags/TZ.svg\",\n phoneCode: \"255\",\n phoneMask: \"+255-##-###-####\",\n },\n {\n name: \"Thailand\",\n code: \"TH\",\n flag: \"https://www.untitledui.com/images/flags/TH.svg\",\n phoneCode: \"66\",\n phoneMask: \"+66-##-###-###\",\n },\n {\n name: \"Togo\",\n code: \"TG\",\n flag: \"https://www.untitledui.com/images/flags/TG.svg\",\n phoneCode: \"228\",\n phoneMask: \"+228-##-###-###\",\n },\n {\n name: \"Tonga\",\n code: \"TO\",\n flag: \"https://www.untitledui.com/images/flags/TO.svg\",\n phoneCode: \"676\",\n phoneMask: \"+676-#####\",\n },\n {\n name: \"Trinidad and Tobago\",\n code: \"TT\",\n flag: \"https://www.untitledui.com/images/flags/TT.svg\",\n phoneCode: \"+1-868\",\n phoneMask: \"+1 (868) ###-####\",\n },\n {\n name: \"Tunisia\",\n code: \"TN\",\n flag: \"https://www.untitledui.com/images/flags/TN.svg\",\n phoneCode: \"216\",\n phoneMask: \"+216-##-###-###\",\n },\n {\n name: \"Turkey\",\n code: \"TR\",\n flag: \"https://www.untitledui.com/images/flags/TR.svg\",\n phoneCode: \"90\",\n phoneMask: \"+90 (###) ###-####\",\n },\n {\n name: \"Turkmenistan\",\n code: \"TM\",\n flag: \"https://www.untitledui.com/images/flags/TM.svg\",\n phoneCode: \"993\",\n phoneMask: \"+993-#-###-####\",\n },\n {\n name: \"Tuvalu\",\n code: \"TV\",\n flag: \"https://www.untitledui.com/images/flags/TV.svg\",\n phoneCode: \"688\",\n phoneMask: \"+688-2####\",\n },\n {\n name: \"Uganda\",\n code: \"UG\",\n flag: \"https://www.untitledui.com/images/flags/UG.svg\",\n phoneCode: \"256\",\n phoneMask: \"+256 (###) ###-###\",\n },\n {\n name: \"Ukraine\",\n code: \"UA\",\n flag: \"https://www.untitledui.com/images/flags/UA.svg\",\n phoneCode: \"380\",\n phoneMask: \"+380 (##) ###-##-##\",\n },\n {\n name: \"United Arab Emirates\",\n code: \"AE\",\n flag: \"https://www.untitledui.com/images/flags/AE.svg\",\n phoneCode: \"971\",\n phoneMask: \"+971-#-###-####\",\n },\n {\n name: \"United Kingdom\",\n code: \"GB\",\n flag: \"https://www.untitledui.com/images/flags/GB.svg\",\n phoneCode: \"44\",\n },\n {\n name: \"United States\",\n code: \"US\",\n flag: \"https://www.untitledui.com/images/flags/US.svg\",\n phoneCode: \"1\",\n phoneMask: \"+1 (###) ###-####\",\n },\n {\n name: \"Uruguay\",\n code: \"UY\",\n flag: \"https://www.untitledui.com/images/flags/UY.svg\",\n phoneCode: \"598\",\n phoneMask: \"+598-#-###-##-##\",\n },\n {\n name: \"Uzbekistan\",\n code: \"UZ\",\n flag: \"https://www.untitledui.com/images/flags/UZ.svg\",\n phoneCode: \"998\",\n phoneMask: \"+998-##-###-####\",\n },\n {\n name: \"Vanuatu\",\n code: \"VU\",\n flag: \"https://www.untitledui.com/images/flags/VU.svg\",\n phoneCode: \"678\",\n phoneMask: \"+678-#####\",\n },\n {\n name: \"Venezuela\",\n code: \"VE\",\n flag: \"https://www.untitledui.com/images/flags/VE.svg\",\n phoneCode: \"58\",\n phoneMask: \"+58 (###) ###-####\",\n },\n {\n name: \"Vietnam\",\n code: \"VN\",\n flag: \"https://www.untitledui.com/images/flags/VN.svg\",\n phoneCode: \"84\",\n phoneMask: \"+84 (###) ####-###\",\n },\n {\n name: \"Yemen\",\n code: \"YE\",\n flag: \"https://www.untitledui.com/images/flags/YE.svg\",\n phoneCode: \"967\",\n phoneMask: \"+967-##-###-###\",\n },\n {\n name: \"Zambia\",\n code: \"ZM\",\n flag: \"https://www.untitledui.com/images/flags/ZM.svg\",\n phoneCode: \"260\",\n phoneMask: \"+260-##-###-####\",\n },\n {\n name: \"Zimbabwe\",\n code: \"ZW\",\n flag: \"https://www.untitledui.com/images/flags/ZW.svg\",\n phoneCode: \"263\",\n phoneMask: \"+263-#-######\",\n },\n];\n\n/**\n * Phone code options for the select component.\n */\nexport const phoneCodeOptions: SelectItemType[] = countries.map((country) => ({\n id: country.code,\n label: country.code,\n}));\n\n/**\n * Country options for the select component.\n */\nexport const countriesOptions: SelectItemType[] = countries.map((country) => ({\n id: country.code,\n label: country.name,\n icon: (props: HTMLAttributes<HTMLImageElement>) => {\n const { ...restProps } = props;\n return <Image {...restProps} src={country.flag} alt={`${country.name} flag`} width={20} height={15} />;\n },\n}));\n\nexport default countries;\n","import type countries from './countries';\n\ntype Country = (typeof countries)[0];\n\n/** Get national-format mask from country by stripping the country code prefix (e.g. \"+1 (###) ###-####\" → \"(###) ###-####\"). */\nexport function getNationalMask(country: Country | undefined): string {\n if (!country?.phoneMask) return '';\n const code = country.phoneCode.startsWith('+') ? country.phoneCode : `+${country.phoneCode}`;\n const escaped = code.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n return country.phoneMask.replace(new RegExp(`^\\\\s*${escaped}[\\\\s-]*`), '').trim();\n}\n\n/** Format a raw digit string into a mask pattern where '#' represents one digit. No trailing literals so backspace works naturally. */\nexport function formatDigitsToMask(digits: string, mask: string): string {\n if (digits.length === 0) return '';\n let i = 0;\n let out = '';\n for (const c of mask) {\n if (c === '#') {\n if (i < digits.length) out += digits[i++];\n else break;\n } else if (i < digits.length) {\n out += c;\n }\n }\n return out;\n}\n","type FbqFn = (method: string, ...args: unknown[]) => void;\n\nexport type PixelEvent = 'PageView' | 'ViewContent' | 'InitiateCheckout' | 'Lead';\n\nexport interface PixelEventParams {\n contentName?: string;\n contentCategory?: string;\n}\n\n/** Raw (unhashed) user identifiers for advanced matching. */\nexport interface PixelUserData {\n email?: string | null;\n phone?: string | null;\n}\n\n// Hashed user data stored in sessionStorage for the duration of the browsing session.\n// Keyed by a short namespace to avoid collisions.\nconst STORAGE_KEY = 'ks_pud';\n\nasync function sha256Hex(str: string): Promise<string> {\n const buffer = await crypto.subtle.digest('SHA-256', new TextEncoder().encode(str));\n return Array.from(new Uint8Array(buffer))\n .map((b) => b.toString(16).padStart(2, '0'))\n .join('');\n}\n\nfunction getFbq(): FbqFn | undefined {\n if (typeof window === 'undefined') return undefined;\n return (window as Window & { fbq?: FbqFn }).fbq;\n}\n\n/** Read the pixel IDs registered by MetaPixel via the inline init script. */\nfunction getRegisteredPixelIds(): string[] {\n return (window as Window & { __ks_pixel_ids?: string[] }).__ks_pixel_ids ?? [];\n}\n\n/** Apply stored hashed user data to every configured Meta Pixel. */\nfunction applyStoredUserData(fbq: FbqFn): void {\n try {\n const raw = sessionStorage.getItem(STORAGE_KEY);\n if (!raw) return;\n const hashed = JSON.parse(raw) as Record<string, string>;\n if (Object.keys(hashed).length === 0) return;\n getRegisteredPixelIds().forEach((id) => fbq('init', id, hashed));\n } catch {\n // sessionStorage unavailable or JSON malformed — safe to ignore\n }\n}\n\n/**\n * Hash and store user identifiers so they are automatically included in all\n * subsequent pixel events for this browser session. Call this as soon as\n * identity is known (e.g. contact form submission, portal login step 1).\n */\nexport async function setPixelUserData(userData: PixelUserData): Promise<void> {\n const hashed: Record<string, string> = {};\n\n if (userData.email) {\n hashed.em = await sha256Hex(userData.email.trim().toLowerCase());\n }\n if (userData.phone) {\n const digits = userData.phone.replace(/\\D/g, '');\n if (digits) hashed.ph = await sha256Hex(digits);\n }\n\n if (Object.keys(hashed).length === 0) return;\n\n try {\n sessionStorage.setItem(STORAGE_KEY, JSON.stringify(hashed));\n } catch {\n // sessionStorage unavailable — still apply to fbq for this page load\n }\n\n const fbq = getFbq();\n if (fbq) {\n getRegisteredPixelIds().forEach((id) => fbq('init', id, hashed));\n }\n}\n\n/**\n * Single entry point for all client-side Meta Pixel event fires.\n * Automatically applies any stored user identity before firing so that Meta\n * can match events to known users across the entire session.\n * Silently no-ops if fbq is not loaded (pixel not configured for this site).\n *\n * @param eventId - Optional server-side event ID for browser/server deduplication.\n * Pass the `eventId` returned by the form submission API so Meta can match and\n * deduplicate the browser Lead event against the server-side CAPI Lead event.\n * Format: fbq('track', event, params, { eventID: eventId })\n */\nexport function firePixelEvent(event: PixelEvent, params?: PixelEventParams, eventId?: string): void {\n const fbq = getFbq();\n if (!fbq) {\n console.debug('[MetaPixel] skipped — fbq not loaded', { event });\n return;\n }\n\n // Re-apply stored identity before every event so user data is included\n // even on events that fire after a client-side navigation (PageView, ViewContent, etc.)\n applyStoredUserData(fbq);\n\n const normalized: Record<string, string> = {};\n if (params?.contentName) normalized.content_name = params.contentName;\n if (params?.contentCategory) normalized.content_category = params.contentCategory;\n\n const customData = Object.keys(normalized).length > 0 ? normalized : undefined;\n const eventData = eventId ? { eventID: eventId } : undefined;\n\n console.debug('[MetaPixel]', event, normalized, eventId ? { eventID: eventId } : '');\n fbq('track', event, customData, eventData);\n}\n","/**\n * PostHog event capture — Keystone customer sites.\n *\n * ## Naming convention\n * All events use snake_case `object_action` format.\n * Properties use snake_case as well.\n *\n * ## Event taxonomy\n * Add new events here: define the name in `KsEventName` and its required\n * properties in `KsEventProperties`. Every callsite is then type-checked.\n *\n * ## Usage\n *\n * import { captureEvent } from 'keystone-design-bootstrap/tracking';\n *\n * captureEvent('form_submitted', { form_type: 'lead' });\n * captureEvent('booking_cta_clicked', { source_path: '/services/massage', booking_url: url });\n *\n * All calls are safe no-ops when PostHog has not been initialised (e.g. no\n * POSTHOG_API_KEY configured on the server).\n *\n * ## Super properties\n * account_id, account_name, and site_domain are registered as super properties\n * by PostHogProvider and are automatically attached to every event — you do not\n * need to include them in individual captureEvent calls.\n */\n\nimport posthog from 'posthog-js';\n\n// ---------------------------------------------------------------------------\n// Event taxonomy\n// ---------------------------------------------------------------------------\n\nexport type KsEventName =\n // Booking / conversion\n | 'booking_cta_clicked'\n // Forms\n | 'form_submitted'\n | 'form_failed'\n // Chat widget\n | 'chat_opened'\n | 'chat_message_sent'\n | 'chat_message_failed'\n // Member portal — tab navigation\n | 'portal_tab_viewed'\n // Member portal — authentication flow\n | 'portal_login_started'\n | 'portal_login_step_viewed'\n | 'portal_login_step_submitted'\n | 'portal_login_step_advanced'\n | 'portal_login_back_clicked'\n | 'portal_login_identified'\n | 'portal_login_completed'\n | 'portal_login_failed';\n\nexport type KsEventProperties = {\n /** Fired when a visitor clicks any CTA that links to the external booking URL. */\n booking_cta_clicked: {\n source_path: string;\n booking_url: string;\n };\n\n /** Fired when a Keystone form is successfully submitted. */\n form_submitted: {\n /** One of: lead | job_application | marketing_list_signup */\n form_type: string;\n /** Server-generated event ID for CAPI deduplication (when present). */\n event_id?: string;\n };\n\n /** Fired when a form submission fails (validation error or network error). */\n form_failed: {\n form_type: string;\n error: string;\n };\n\n /** Fired when the chat widget is first opened by the visitor. */\n chat_opened: Record<string, never>;\n\n /** Fired when a chat message is successfully sent. */\n chat_message_sent: {\n /** Whether the visitor is authenticated (contactId present). */\n is_authenticated: boolean;\n };\n\n /** Fired when a chat message fails to send. */\n chat_message_failed: {\n error: string;\n };\n\n /** Fired when a member portal tab is opened. */\n portal_tab_viewed: {\n tab: string;\n };\n\n /** Fired when the portal login modal is opened / login flow starts. */\n portal_login_started: Record<string, never>;\n\n /** Fired whenever a login step becomes visible to the user. */\n portal_login_step_viewed: {\n step: 'identifier' | 'signin' | 'signup';\n };\n\n /** Fired when the user submits a specific login step. */\n portal_login_step_submitted: {\n step: 'identifier' | 'signin' | 'signup';\n };\n\n /** Fired when the flow transitions from one step to another state. */\n portal_login_step_advanced: {\n from_step: 'identifier' | 'signin' | 'signup';\n to_step: 'signin' | 'signup' | 'authenticated';\n reason: string;\n };\n\n /** Fired when the user explicitly navigates back to the identifier step. */\n portal_login_back_clicked: {\n from_step: 'signin' | 'signup';\n to_step: 'identifier';\n };\n\n /**\n * Fired after the identifier step resolves — we know whether the user\n * already has an account.\n */\n portal_login_identified: {\n method: 'email' | 'phone' | 'email_and_phone';\n user_exists: boolean;\n };\n\n /** Fired after the user successfully signs in or creates an account. */\n portal_login_completed: {\n flow: 'signin' | 'signup';\n };\n\n /** Fired when any step of the login flow returns an error. */\n portal_login_failed: {\n step: 'identifier' | 'signin' | 'signup';\n reason: string;\n };\n};\n\n// ---------------------------------------------------------------------------\n// Capture helper\n// ---------------------------------------------------------------------------\n\n/**\n * Captures a typed Keystone analytics event via PostHog.\n * Safe no-op when PostHog has not been initialised.\n */\nexport function captureEvent<E extends KsEventName>(\n event: E,\n ...args: KsEventProperties[E] extends Record<string, never>\n ? []\n : [properties: KsEventProperties[E]]\n): void {\n posthog.capture(event, args[0] as Record<string, unknown>);\n}\n","'use client';\n\nimport React, { createContext, useContext } from 'react';\nimport type { FormDefinition } from '../../types/api/form';\n\nexport type FormDefinitionsContextValue = {\n leadFormDefinition: FormDefinition | null;\n jobApplicationFormDefinition: FormDefinition | null;\n marketingListSignupFormDefinition: FormDefinition | null;\n};\n\nconst FormDefinitionsContext = createContext<FormDefinitionsContextValue>({\n leadFormDefinition: null,\n jobApplicationFormDefinition: null,\n marketingListSignupFormDefinition: null,\n});\n\nexport function FormDefinitionsProvider(props: {\n leadFormDefinition: FormDefinition | null;\n jobApplicationFormDefinition: FormDefinition | null;\n marketingListSignupFormDefinition: FormDefinition | null;\n children: React.ReactNode;\n}) {\n const { leadFormDefinition, jobApplicationFormDefinition, marketingListSignupFormDefinition, children } = props;\n return (\n <FormDefinitionsContext.Provider value={{ leadFormDefinition, jobApplicationFormDefinition, marketingListSignupFormDefinition }}>\n {children}\n </FormDefinitionsContext.Provider>\n );\n}\n\nexport function useFormDefinitions(): FormDefinitionsContextValue {\n return useContext(FormDefinitionsContext);\n}\n\n","import Link from \"next/link\";\nimport Image from \"next/image\";\nimport { getLogoUrl } from '../../utils/photo-helpers';\nimport { getSocialIcon } from '../elements';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { SiteConfig } from '../../types/config';\n\ninterface FooterHomeProps {\n config: SiteConfig;\n companyInformation?: CompanyInformation | null;\n websitePhotos?: WebsitePhotos | null;\n}\n\nconst COLUMN_TITLES = ['Home', 'Services', 'Locations', 'About Us'];\n\nexport const FooterHome = ({\n config,\n companyInformation,\n websitePhotos,\n}: FooterHomeProps) => {\n const currentYear = new Date().getFullYear();\n \n // Get footer navigation from config\n const footerColumns = config?.navigation?.footer || [];\n \n // Build logo from props data\n const logoImage = getLogoUrl(websitePhotos);\n const companyName = companyInformation?.company_name || '';\n const logoText = companyName?.charAt(0)?.toUpperCase() || '';\n const logo = (logoText || logoImage) ? {\n text: logoText,\n href: '/',\n image: logoImage,\n } : undefined;\n \n // Build about text\n const aboutText = companyInformation?.about_text_markdown || companyInformation?.description_markdown;\n \n // Build contact info\n const address = [\n companyInformation?.primary_address_line_1,\n companyInformation?.primary_address_line_2,\n companyInformation?.primary_city,\n companyInformation?.primary_state,\n companyInformation?.primary_zip_code\n ].filter(Boolean).join(', ') || undefined;\n \n const contactInfo = (address || companyInformation?.primary_phone || companyInformation?.primary_email) ? {\n address,\n phone: companyInformation?.primary_phone,\n email: companyInformation?.primary_email,\n } : undefined;\n \n // Build social links\n const socialLinksArray = [];\n if (companyInformation?.facebook_url) socialLinksArray.push({ platform: 'facebook', url: companyInformation.facebook_url });\n if (companyInformation?.twitter_url) socialLinksArray.push({ platform: 'twitter', url: companyInformation.twitter_url });\n if (companyInformation?.linkedin_url) socialLinksArray.push({ platform: 'linkedin', url: companyInformation.linkedin_url });\n if (companyInformation?.instagram_url) socialLinksArray.push({ platform: 'instagram', url: companyInformation.instagram_url });\n if (companyInformation?.youtube_url) socialLinksArray.push({ platform: 'youtube', url: companyInformation.youtube_url });\n if (companyInformation?.pinterest_url) socialLinksArray.push({ platform: 'pinterest', url: companyInformation.pinterest_url });\n if (companyInformation?.tiktok_url) socialLinksArray.push({ platform: 'tiktok', url: companyInformation.tiktok_url });\n if (companyInformation?.google_my_business_url) socialLinksArray.push({ platform: 'google_my_business', url: companyInformation.google_my_business_url });\n if (companyInformation?.yelp_url) socialLinksArray.push({ platform: 'yelp', url: companyInformation.yelp_url });\n if (companyInformation?.tripadvisor_url) socialLinksArray.push({ platform: 'tripadvisor', url: companyInformation.tripadvisor_url });\n if (companyInformation?.google_reviews_url) socialLinksArray.push({ platform: 'google_reviews', url: companyInformation.google_reviews_url });\n const socialLinks = socialLinksArray.length > 0 ? socialLinksArray : undefined;\n \n // Build legal links\n const legalLinks = [\n { label: 'Privacy Policy', href: '/privacy-policy/' },\n { label: 'Terms of Service', href: '/terms-of-service/' },\n { label: 'Cookie Policy', href: '/cookie-policy/' },\n { label: 'Accessibility', href: '/accessibility/' },\n { label: 'Sitemap', href: '/sitemap.xml' },\n ];\n \n // Build copyright text\n const copyrightText = `© ${currentYear} ${companyInformation?.company_name || 'Company Name'}. All rights reserved.`;\n\n return (\n <footer className=\"bg-gray-900 text-white py-12\">\n <div className=\"container mx-auto px-4 md:px-8\">\n <div className=\"grid lg:grid-cols-6 gap-8\">\n {/* Company Info */}\n <div className=\"lg:col-span-2\">\n <div className=\"flex items-center space-x-2 mb-6\">\n <Link href={logo?.href || '/'} className=\"flex items-center space-x-2\">\n {logo?.image ? (\n <Image \n src={logo.image} \n alt={companyName || 'Logo'}\n className=\"h-10 w-10 object-contain\"\n width={40}\n height={40}\n />\n ) : (\n <div className=\"h-10 w-10 bg-blue-600 rounded-lg flex items-center justify-center\">\n <span className=\"text-white font-bold text-lg\">\n {logoText}\n </span>\n </div>\n )}\n <span className=\"text-2xl font-bold text-white\">{companyName}</span>\n </Link>\n </div>\n \n {aboutText && (\n <p className=\"text-gray-300 mb-6 max-w-md\">\n {aboutText}\n </p>\n )}\n \n {/* Contact Info */}\n {contactInfo && (\n <div className=\"space-y-3 mb-6\">\n {contactInfo.address && (\n <div className=\"flex items-center space-x-3\">\n <svg className=\"w-5 h-5 text-blue-400\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path fillRule=\"evenodd\" d=\"M5.05 4.05a7 7 0 119.9 9.9L10 18.9l-4.95-4.95a7 7 0 010-9.9zM10 11a2 2 0 100-4 2 2 0 000 4z\" clipRule=\"evenodd\" />\n </svg>\n <span className=\"text-gray-300\">{contactInfo.address}</span>\n </div>\n )}\n \n {contactInfo.phone && (\n <div className=\"flex items-center space-x-3\">\n <svg className=\"w-5 h-5 text-blue-400\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M2 3a1 1 0 011-1h2.153a1 1 0 01.986.836l.74 4.435a1 1 0 01-.54 1.06l-1.548.773a11.037 11.037 0 006.105 6.105l.774-1.548a1 1 0 011.059-.54l4.435.74a1 1 0 01.836.986V17a1 1 0 01-1 1h-2C7.82 18 2 12.18 2 5V3z\" />\n </svg>\n <a href={`tel:${contactInfo.phone}`} className=\"text-gray-300 hover:text-white transition-colors\">\n {contactInfo.phone}\n </a>\n </div>\n )}\n \n {contactInfo.email && (\n <div className=\"flex items-center space-x-3\">\n <svg className=\"w-5 h-5 text-blue-400\" fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M2.003 5.884L10 9.882l7.997-3.998A2 2 0 0016 4H4a2 2 0 00-1.997 1.884z\" />\n <path d=\"M18 8.118l-8 4-8-4V14a2 2 0 002 2h12a2 2 0 002-2V8.118z\" />\n </svg>\n <a href={`mailto:${contactInfo.email}`} className=\"text-gray-300 hover:text-white transition-colors\">\n {contactInfo.email}\n </a>\n </div>\n )}\n </div>\n )}\n \n {/* Social Links */}\n {socialLinks && socialLinks.length > 0 && (\n <div className=\"flex space-x-4\">\n {socialLinks.map((social, index) => (\n <a\n key={index}\n href={social.url}\n className=\"w-10 h-10 bg-gray-800 rounded-lg flex items-center justify-center text-gray-300 hover:bg-blue-600 hover:text-white transition-colors shrink-0\"\n aria-label={social.platform}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n <span className=\"flex items-center justify-center\">\n {getSocialIcon(social.platform)}\n </span>\n </a>\n ))}\n </div>\n )}\n </div>\n \n {/* Navigation Columns */}\n {footerColumns.map((column, colIndex) => (\n <div key={colIndex}>\n <h3 className=\"text-white font-semibold mb-4\">\n {COLUMN_TITLES[colIndex] || `Column ${colIndex + 1}`}\n </h3>\n <ul className=\"space-y-2\">\n {column.map((link, linkIndex) => (\n <li key={linkIndex}>\n <Link\n href={link.href}\n className=\"text-gray-300 hover:text-white transition-colors\"\n >\n {link.label}\n </Link>\n </li>\n ))}\n </ul>\n </div>\n ))}\n </div>\n \n {/* Bottom Bar */}\n <div className=\"border-t border-gray-800 py-8 mt-8\">\n <div className=\"flex flex-col md:flex-row justify-between items-center space-y-4 md:space-y-0\">\n <div className=\"text-gray-400 text-sm\">\n {copyrightText}\n </div>\n {legalLinks && legalLinks.length > 0 && (\n <div className=\"flex space-x-6 text-sm\">\n {legalLinks.map((link, index) => (\n <Link \n key={index}\n href={link.href} \n className=\"text-gray-400 hover:text-white transition-colors\"\n >\n {link.label}\n </Link>\n ))}\n </div>\n )}\n </div>\n </div>\n </div>\n </footer>\n );\n};\n","'use client';\nimport React, { useRef, useState } from 'react';\nimport Link from 'next/link';\nimport { usePathname } from 'next/navigation';\nimport Image from 'next/image';\nimport { ChevronDown } from \"@untitledui/icons\";\nimport { Button as AriaButton, Dialog as AriaDialog, DialogTrigger as AriaDialogTrigger, Popover as AriaPopover } from \"react-aria-components\";\nimport { Button } from '../elements';\nimport { GenericHeaderComponent } from './generic-header-component';\nimport { cx } from '../../utils/cx';\nimport { getLogoUrl } from '../../utils/photo-helpers';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { NavItem, SiteConfig } from '../../types/config';\nimport { resolveCtaUrls, isExternalCtaUrl, resolvePortalPath } from '../../lib/cta-urls';\n\nexport interface HeaderProps {\n logo: {\n text: string;\n href: string;\n image?: string;\n };\n cta_button?: {\n label: string;\n href: string;\n target?: '_blank' | '_self';\n secondary_label?: string;\n secondary_href?: string;\n secondary_target?: '_blank' | '_self';\n };\n}\n\nexport interface HeaderComponentProps {\n variant?: 'minimal' | 'centered' | 'standard';\n props?: HeaderProps;\n navigation?: NavItem[];\n logoImage?: string;\n logoText?: string;\n config?: SiteConfig;\n companyInformation?: CompanyInformation | null;\n websitePhotos?: WebsitePhotos | null;\n}\n\nconst MobileNavItem = ({ label, href, children, onClose }: { \n label: string; \n href?: string; \n children?: React.ReactNode;\n onClose?: () => void;\n}) => {\n const [isOpen, setIsOpen] = useState(false);\n\n if (href) {\n return (\n <li>\n <Link \n href={href} \n className=\"flex items-center justify-between px-4 py-3 text-sm font-medium text-primary hover:bg-primary_hover\"\n onClick={onClose}\n >\n {label}\n </Link>\n </li>\n );\n }\n\n return (\n <li className=\"flex flex-col gap-0.5\">\n <button\n aria-expanded={isOpen}\n onClick={() => setIsOpen(!isOpen)}\n className=\"flex w-full items-center justify-between px-4 py-3 text-sm font-medium text-primary hover:bg-primary_hover\"\n >\n {label}\n <ChevronDown\n className={cx(\"size-4 stroke-[2.625px] text-fg-quaternary transition duration-100 ease-linear\", isOpen ? \"-rotate-180\" : \"rotate-0\")}\n />\n </button>\n {isOpen && <div>{children}</div>}\n </li>\n );\n};\n\nexport function HeaderNavigation({ \n variant = 'standard', \n props, \n navigation: navigationOverride, \n logoImage: logoImageOverride, \n logoText: logoTextOverride, \n config,\n companyInformation,\n websitePhotos,\n}: HeaderComponentProps) {\n const headerRef = useRef<HTMLElement>(null);\n \n // Use navigation from config or override\n const navigation = navigationOverride || config?.navigation?.header || [];\n \n // Build logo\n const logoImage = logoImageOverride || getLogoUrl(websitePhotos) || props?.logo?.image;\n const logoText = logoTextOverride || companyInformation?.company_name || props?.logo?.text || '';\n const cta_button = props?.cta_button;\n const resolvedCtaUrls = resolveCtaUrls(companyInformation);\n const ctaUrls = {\n primaryHref: cta_button?.secondary_href ?? resolvedCtaUrls.primaryHref,\n secondaryHref: cta_button?.href ?? resolvedCtaUrls.secondaryHref,\n hasSecondary: cta_button?.secondary_href != null || resolvedCtaUrls.hasSecondary,\n };\n \n const logo = {\n text: logoText || '',\n href: props?.logo?.href || '/',\n image: logoImage,\n };\n \n const dynamicNavigation = navigation;\n\n // Hide the sticky bottom bar when the user is already on the portal page —\n // the portal has its own Book Now tab so the bar is redundant and confusing.\n const pathname = usePathname();\n const portalPath = resolvePortalPath(companyInformation);\n const isPortalPage = portalPath ? pathname?.startsWith(portalPath) : false;\n\n const getVariantClasses = () => {\n switch (variant) {\n case 'minimal':\n return 'py-4';\n case 'centered':\n return 'py-6';\n case 'standard':\n default:\n return 'py-4';\n }\n };\n\n const HoverDropdown = ({ label, href, children }: { label: string; href?: string; children: React.ReactNode }) => {\n const [isOpen, setIsOpen] = useState(false);\n const timeoutRef = React.useRef<NodeJS.Timeout | null>(null);\n\n const handleMouseEnter = () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n timeoutRef.current = null;\n }\n setIsOpen(true);\n };\n\n const handleMouseLeave = () => {\n const id = setTimeout(() => {\n setIsOpen(false);\n }, 100);\n timeoutRef.current = id;\n };\n\n React.useEffect(() => {\n return () => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n };\n }, []);\n\n return (\n <div \n className=\"relative\"\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n >\n <Link\n href={href || '#'}\n className=\"flex cursor-pointer items-center gap-0.5 rounded-lg px-1.5 py-1 text-sm font-medium text-secondary outline-focus-ring transition duration-100 ease-linear hover:text-secondary_hover focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n <span className=\"px-0.5\">{label}</span>\n <ChevronDown className={cx(\"size-4 stroke-[2.625px] text-fg-quaternary transition duration-100 ease-linear\", isOpen ? \"-rotate-180\" : \"rotate-0\")} />\n </Link>\n \n {isOpen && (\n <div \n className=\"absolute top-full left-0 z-50 mt-1 origin-top animate-in fade-in slide-in-from-top-1 duration-75 ease-out\"\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n >\n <div className=\"w-max max-w-sm\">\n {children}\n </div>\n </div>\n )}\n </div>\n );\n };\n\n const headerNavItems = dynamicNavigation.map((navItem) => {\n if (navItem.children && navItem.children.length > 0) {\n return {\n label: navItem.label,\n href: navItem.href,\n menu: (\n <GenericHeaderComponent \n items={navItem.children.map(child => ({\n label: child.label,\n href: child.href,\n subtitle: child.subtitle,\n }))}\n />\n ),\n };\n }\n return {\n label: navItem.label,\n href: navItem.href,\n };\n });\n\n return (\n <>\n <header \n ref={headerRef}\n className={cx(\n \"sticky top-0 z-50 flex h-18 w-full items-center justify-center backdrop-blur-md bg-primary/80 md:h-20\",\n getVariantClasses()\n )}\n >\n <div className=\"flex size-full max-w-container flex-1 items-center pr-3 pl-4 md:px-8\">\n <div className=\"flex w-full justify-between gap-4\">\n <div className=\"flex flex-1 items-center gap-5\">\n <Link href={logo?.href || '/'} className=\"flex items-center space-x-2\">\n {logoImage ? (\n <Image \n src={logoImage} \n alt={logoText}\n className=\"h-8 w-8 object-contain\"\n width={32}\n height={32}\n />\n ) : (\n <div className=\"h-8 w-8 bg-blue-600 rounded-lg flex items-center justify-center\">\n <span className=\"text-white font-bold text-lg\">\n {logoText?.charAt(0)?.toUpperCase() || ''}\n </span>\n </div>\n )}\n <span className=\"text-xl font-bold text-primary hidden md:block\">{logoText}</span>\n </Link>\n\n <nav className=\"max-md:hidden\">\n <ul className=\"flex items-center gap-0.5\">\n {headerNavItems.map((navItem) => (\n <li key={navItem.label}>\n {navItem.menu ? (\n <HoverDropdown label={navItem.label} href={navItem.href}>\n {navItem.menu}\n </HoverDropdown>\n ) : (\n <Link\n href={navItem.href || '#'}\n className=\"flex cursor-pointer items-center gap-0.5 rounded-lg px-1.5 py-1 text-sm font-medium text-secondary outline-focus-ring transition duration-100 ease-linear hover:text-secondary_hover focus:outline-offset-2 focus-visible:outline-2\"\n >\n <span className=\"px-0.5\">{navItem.label}</span>\n </Link>\n )}\n </li>\n ))}\n </ul>\n </nav>\n </div>\n\n <div className=\"hidden items-center gap-3 md:flex\">\n {/* Left: Contact Us -> /contact */}\n {cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button \n href={ctaUrls.secondaryHref}\n target={cta_button.secondary_target}\n rel={cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"secondary\" \n size=\"lg\"\n >\n {cta_button.label}\n </Button>\n )}\n {/* Right: Book Now -> booking link (external opens in new tab) */}\n <Button \n href={ctaUrls.primaryHref}\n target={cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\" \n size=\"lg\"\n >\n {(cta_button?.secondary_label && ctaUrls.hasSecondary) ? cta_button.secondary_label : (cta_button?.label || \"Get Started\")}\n </Button>\n </div>\n <AriaDialogTrigger>\n <AriaButton\n aria-label=\"Toggle navigation menu\"\n className={({ isFocusVisible, isHovered }) =>\n cx(\n \"group ml-auto cursor-pointer rounded-lg p-2 md:hidden\",\n isHovered && \"bg-primary_hover\",\n isFocusVisible && \"outline-2 outline-offset-2 outline-focus-ring\",\n )\n }\n >\n <svg aria-hidden=\"true\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n className=\"hidden text-secondary group-aria-expanded:block\"\n d=\"M18 6L6 18M6 6L18 18\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n className=\"text-secondary group-aria-expanded:hidden\"\n d=\"M3 12H21M3 6H21M3 18H21\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </AriaButton>\n <AriaPopover\n triggerRef={headerRef}\n className=\"h-calc(100%-72px) scrollbar-hide w-full overflow-y-auto shadow-lg md:hidden\"\n offset={0}\n crossOffset={20}\n containerPadding={0}\n placement=\"bottom left\"\n >\n <AriaDialog className=\"outline-hidden\">\n <nav className=\"w-full bg-primary shadow-lg\">\n <ul className=\"flex flex-col gap-0.5 py-5\">\n {headerNavItems.map((navItem) =>\n navItem.menu ? (\n <MobileNavItem \n key={navItem.label} \n label={navItem.label}\n >\n {navItem.menu}\n </MobileNavItem>\n ) : (\n <MobileNavItem \n key={navItem.label} \n label={navItem.label} \n href={navItem.href}\n />\n ),\n )}\n </ul>\n\n <div className=\"flex flex-col gap-3 border-t border-secondary px-4 py-6\">\n {/* Contact Us -> /contact */}\n {cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button \n href={ctaUrls.secondaryHref}\n target={cta_button.secondary_target}\n rel={cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"secondary\" \n size=\"lg\"\n >\n {cta_button.label}\n </Button>\n )}\n {/* Book Now -> booking link (external opens in new tab) */}\n <Button \n href={ctaUrls.primaryHref}\n target={cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\" \n size=\"lg\"\n >\n {(cta_button?.secondary_label && ctaUrls.hasSecondary) ? cta_button.secondary_label : (cta_button?.label || \"Get Started\")}\n </Button>\n </div>\n </nav>\n </AriaDialog>\n </AriaPopover>\n </AriaDialogTrigger>\n </div>\n </div>\n </header>\n\n {/* Sticky Book/Contact bar (mobile only) — hidden on portal page where it would be redundant */}\n {!isPortalPage && <div className=\"fixed bottom-0 left-0 right-0 z-40 md:hidden bg-fg-primary\">\n <div className=\"flex gap-0\">\n {/* Left: Contact Us -> /contact */}\n {cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n target={cta_button.secondary_target}\n rel={cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className=\"flex-1 font-body text-sm uppercase tracking-wide py-4 rounded-none border-r border-white/20\"\n >\n {cta_button.label}\n </Button>\n )}\n {/* Right: Book Now -> booking link (external opens in new tab) */}\n <Button\n href={ctaUrls.primaryHref}\n target={cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className={`${cta_button?.secondary_label && ctaUrls.hasSecondary ? 'flex-1' : 'w-full'} font-body text-sm uppercase tracking-wide py-4 rounded-none`}\n >\n {(cta_button?.secondary_label && ctaUrls.hasSecondary) ? cta_button.secondary_label : (cta_button?.label || 'Contact')}\n </Button>\n </div>\n </div>}\n </>\n );\n}\n","import { type FC, type ReactNode, createElement, isValidElement } from \"react\";\nimport Link from \"next/link\";\nimport { cx } from '../../utils/cx';\nimport { isReactComponent } from '../../utils/is-react-component';\n\ninterface GenericHeaderComponentProps {\n items: Array<{\n label: string;\n href: string;\n icon?: FC<{ className?: string }>;\n subtitle?: string;\n }>;\n}\n\n// Nav Menu Item Link component (consolidated)\ninterface NavMenuItemLinkProps {\n href: string;\n icon?: FC<{ className?: string }> | ReactNode;\n iconClassName?: string;\n className?: string;\n title: string;\n subtitle?: string;\n badge?: ReactNode;\n actionsContent?: ReactNode;\n onClick?: (e: React.MouseEvent) => void;\n}\n\nconst NavMenuItemLink = ({ href, icon: Icon, iconClassName, title, subtitle, badge, actionsContent, className, onClick }: NavMenuItemLinkProps) => {\n const content = (\n <>\n {isValidElement(Icon) && Icon}\n {isReactComponent(Icon) && createElement(Icon, { className: cx(\"mt-0.5 size-4 shrink-0 stroke-[2.3px] text-fg-brand-primary\", iconClassName) } as Record<string, unknown>)}\n\n <div className=\"flex min-w-0 flex-1 flex-col gap-3\">\n <div className=\"flex min-w-0 flex-1 flex-col gap-0.5\">\n <div className=\"flex items-center gap-2\">\n <span className=\"text-md font-semibold text-primary\">{title}</span>\n {badge}\n </div>\n\n {subtitle && <span className=\"line-clamp-2 min-w-0 text-sm text-tertiary\">{subtitle}</span>}\n </div>\n\n {actionsContent}\n </div>\n </>\n );\n\n if (onClick) {\n return (\n <button\n onClick={onClick}\n className={cx(\n \"inline-flex w-full gap-3 px-4 py-3 outline-focus-ring transition duration-100 ease-linear hover:bg-primary_hover focus-visible:outline-2 sm:p-3 md:rounded-lg text-left\",\n className,\n )}\n >\n {content}\n </button>\n );\n }\n\n return (\n <Link\n href={href}\n className={cx(\n \"inline-flex w-full gap-3 px-4 py-3 outline-focus-ring transition duration-100 ease-linear hover:bg-primary_hover focus-visible:outline-2 sm:p-3 md:rounded-lg\",\n className,\n )}\n >\n {content}\n </Link>\n );\n};\n\n/**\n * Generic header dropdown menu component for navigation\n * Based on the UntitledUI dropdown-menu-simple pattern from the design system\n * Used in the site template header for dropdown navigation menus\n */\nexport const GenericHeaderComponent = ({ items }: GenericHeaderComponentProps) => {\n return (\n <div className=\"px-3 pb-2 md:max-w-84 md:p-0\" style={{ fontFamily: 'var(--font-body, var(--font-inter, \"Inter\"), -apple-system, \"Segoe UI\", Roboto, Arial, sans-serif)' }}>\n <nav className=\"overflow-hidden rounded-2xl bg-primary py-2 shadow-xs ring-1 ring-secondary_alt md:p-2 md:shadow-lg\">\n <ul className=\"flex flex-col gap-0.5\">\n {items.map((item) => (\n <li key={item.label || item.href}>\n <NavMenuItemLink\n icon={item.icon}\n title={item.label}\n subtitle={item.subtitle}\n href={item.href}\n />\n </li>\n ))}\n </ul>\n </nav>\n </div>\n );\n};\n\n","/**\n * Resolves the primary and secondary CTA hrefs used across the site.\n *\n * Resolution order for primaryHref:\n * 1. portal_url — set by backend when account has consumer portal enabled\n * 2. external_management_url — booking platform URL from the API\n * 3. /contact — final fallback\n *\n * No per-site configuration needed. Enable the portal in the admin console and\n * every CTA across the site automatically routes to the portal.\n */\n\nimport type { CompanyInformation } from '../types/api/company-information';\n\nconst CONTACT_PATH = '/contact';\n\n/** True when the href is absolute (external); use for target=\"_blank\" and rel=\"noopener noreferrer\". */\nexport function isExternalCtaUrl(href: string): boolean {\n return href.startsWith('http://') || href.startsWith('https://');\n}\n\nexport interface ResolvedCtaUrls {\n primaryHref: string;\n secondaryHref: string;\n hasSecondary: boolean;\n}\n\n/**\n * Extracts the pathname from portal_url for use in client-side route comparisons.\n * Handles both absolute URLs (https://domain.com/portal → /portal) and relative paths (/portal).\n *\n * Returns null when:\n * - portal_url is not set\n * - the URL cannot be resolved to a non-root pathname (would otherwise match every page)\n */\nexport function resolvePortalPath(\n companyInformation?: CompanyInformation | null\n): string | null {\n const url = companyInformation?.portal_url?.trim();\n if (!url) return null;\n\n let pathname: string | null = null;\n try {\n pathname = new URL(url).pathname;\n } catch {\n pathname = url.startsWith('/') ? url : null;\n }\n\n if (!pathname || pathname === '/') return null;\n\n // Normalize trailing slash so startsWith comparisons are consistent.\n return pathname.endsWith('/') ? pathname.slice(0, -1) : pathname;\n}\n\nexport function resolveCtaUrls(\n companyInformation?: CompanyInformation | null\n): ResolvedCtaUrls {\n const portalUrl = companyInformation?.portal_url?.trim() || null;\n const externalUrl = companyInformation?.external_management_url?.trim() || null;\n const primaryHref = portalUrl ?? externalUrl ?? CONTACT_PATH;\n const secondaryHref = CONTACT_PATH;\n const hasSecondary = primaryHref !== CONTACT_PATH;\n\n return { primaryHref, secondaryHref, hasSecondary };\n}\n","import type { FC } from \"react\";\nimport { mapIcon } from '../utils/icon-mapping';\n\ninterface StatisticsSectionProps {\n title?: string;\n subtitle?: string;\n statistics?: Array<{\n number?: string;\n value?: string;\n label: string;\n icon?: string;\n description?: string;\n }>;\n}\n\nexport const StatisticsSection = ({\n title = \"\",\n subtitle = \"\",\n statistics = [],\n}: StatisticsSectionProps) => {\n const stats = statistics.map((stat) => ({\n number: stat.number || stat.value || '',\n label: stat.label || '',\n icon: stat.icon,\n description: stat.description,\n }));\n\n const backgroundColor = \"bg-secondary\";\n \n return (\n <section className={`${backgroundColor} py-16 md:py-24`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mx-auto mb-12 flex w-full max-w-3xl flex-col items-center text-center\">\n {title && (\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n \n <div className=\"grid grid-cols-1 gap-8 md:grid-cols-3\">\n {stats.map((stat: { number: string | number; label: string; icon?: string | FC<{ className?: string }> }, index: number) => {\n const IconComponent = mapIcon(stat.icon);\n \n return (\n <div key={index} className=\"text-center\">\n <div className=\"flex items-center justify-center gap-2\">\n {IconComponent && (\n <div className=\"size-6 shrink-0\">\n <IconComponent className=\"w-full h-full text-brand-secondary\" />\n </div>\n )}\n <div className=\"text-display-lg font-semibold text-primary md:text-display-xl\">\n {stat.number}\n </div>\n </div>\n <div className=\"mt-2 text-lg text-tertiary\">{stat.label}</div>\n </div>\n );\n })}\n </div>\n </div>\n </section>\n );\n};\n","import React from 'react';\nimport type { FC } from 'react';\nimport { FeaturedIcon } from '../elements';\nimport { mapIcon } from '../utils/icon-mapping';\n\ntype FeaturedIconColor = \"success\" | \"gray\" | \"brand\" | \"error\" | \"warning\";\n\n\ninterface Value {\n title: string;\n description: string;\n icon?: string | FC<{ className?: string }>;\n color?: FeaturedIconColor;\n}\n\ninterface ValuesSectionProps {\n values?: Value[];\n label?: string;\n title?: string;\n subtitle?: string;\n description?: string;\n backgroundColor?: string;\n className?: string;\n}\n\nexport const ValuesSection = ({\n values = [],\n label = \"\",\n title = \"\",\n subtitle = \"\",\n description = \"\",\n backgroundColor = \"bg-secondary\",\n className = \"\",\n}: ValuesSectionProps) => {\n const hasValues = values.length > 0;\n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n {label && (\n <span className=\"text-sm font-semibold text-brand-secondary md:text-md\">{label}</span>\n )}\n {title && (\n <h2 className={`${label ? 'mt-3' : ''} text-display-sm font-semibold text-primary md:text-display-md`}>\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n {description && !hasValues && (\n <p className=\"mt-4 text-md text-tertiary md:mt-6 md:text-lg\">\n {description}\n </p>\n )}\n </div>\n\n {values.length > 0 ? (\n <div className=\"mt-12 md:mt-16\">\n {(() => {\n // Check if any icons are missing - if so, use stars for all\n const anyIconMissing = values.some((value: { icon?: string | FC<{ className?: string }> }) => \n typeof value.icon === 'string' && value.icon && !mapIcon(value.icon)\n );\n const useStarForAll = anyIconMissing;\n\n return (\n <ul className=\"grid w-full grid-cols-1 justify-items-center gap-x-8 gap-y-10 sm:grid-cols-2 md:gap-y-16 lg:grid-cols-3\">\n {values.map((value: { title: string; description: string; icon?: string | FC<{ className?: string }>; color?: FeaturedIconColor }, index: number) => {\n // Use star for all if any icon is missing, otherwise use the specified icon\n const IconComponent = useStarForAll ? mapIcon('star') : (mapIcon(value.icon) || mapIcon('star'));\n if (!IconComponent) return null;\n \n const IconWrapper = ({ className }: { className?: string }) => (\n <div className={className}>\n <IconComponent className=\"w-full h-full\" />\n </div>\n );\n\n return (\n <li key={index}>\n <div className=\"flex max-w-sm flex-col items-center gap-4 text-center\">\n <FeaturedIcon \n icon={IconWrapper} \n size=\"lg\" \n color={(value.color as FeaturedIconColor) || 'gray'} \n theme=\"modern\" \n className=\"hidden md:inline-flex\"\n />\n <FeaturedIcon \n icon={IconWrapper} \n size=\"md\" \n color={(value.color as FeaturedIconColor) || 'gray'} \n theme=\"modern\" \n className=\"inline-flex md:hidden\"\n />\n\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{value.title}</h3>\n <p className=\"mt-1 text-md text-tertiary\">{value.description}</p>\n </div>\n </div>\n </li>\n );\n })}\n </ul>\n );\n })()}\n </div>\n ) : null}\n </div>\n </section>\n );\n};\n\n\n","import React from 'react';\nimport { PhotoWithFallback } from '../elements';\nimport type { TeamMember } from '../../types/api/team-member';\n\ninterface TeamGridProps {\n teamMembers?: TeamMember[] | null;\n title?: string;\n subtitle?: string;\n maxMembers?: number;\n backgroundColor?: string;\n className?: string;\n}\n\nexport const TeamGrid = ({\n teamMembers: membersData,\n title = \"\",\n subtitle = \"\",\n maxMembers = 8,\n backgroundColor = \"bg-primary\",\n className = \"\",\n}: TeamGridProps) => {\n const members = Array.isArray(membersData) ? membersData : [];\n \n const displayMembers = members.slice(0, maxMembers);\n\n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mx-auto mb-12 flex w-full max-w-3xl flex-col items-center text-center\">\n {title && (\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {displayMembers.length > 0 ? (\n <div className=\"mt-12 md:mt-16\">\n <ul className=\"grid w-full grid-cols-1 gap-x-8 gap-y-10 sm:grid-cols-2 md:gap-y-12 lg:grid-cols-3 xl:grid-cols-4\">\n {displayMembers.map((member, index) => {\n const bio = member.bio_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <li key={member.id || index} className=\"flex flex-col gap-5 md:gap-6\">\n <PhotoWithFallback\n item={member}\n fallbackId={member.id || index}\n alt={member.name || 'Team member'}\n className=\"h-78 w-full object-cover md:h-74 rounded-2xl\"\n />\n <div>\n <h3 className=\"text-lg font-semibold text-primary md:text-xl\">{member.name}</h3>\n <p className=\"text-md text-brand-secondary md:mt-0.5 md:text-lg\">\n {member.position}\n </p>\n {bio && (\n <p className=\"mt-4 text-md text-tertiary leading-relaxed\">\n {bio}\n </p>\n )}\n </div>\n </li>\n );\n })}\n </ul>\n </div>\n ) : (\n <div className=\"text-center mt-12\">\n <p className=\"text-gray-500\">No team members available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n","import React from 'react';\nimport { ArrowRight } from '@untitledui/icons';\nimport { Button } from '../elements';\nimport type { Location } from '../../types/api/location';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport { resolveCtaUrls, isExternalCtaUrl } from '../../lib/cta-urls';\n\ninterface LocationGridProps {\n locations?: Location[] | null;\n companyInformation?: CompanyInformation | null;\n title?: string;\n subtitle?: string;\n /** Optional route override for the \"Contact Us\" CTA. When not set, uses primary CTA URL (booking or /contact) from company info. */\n primaryCtaHrefOverride?: string;\n backgroundColor?: string;\n className?: string;\n}\n\n// Simple icon components\nconst LocationIcon = ({ className }: { className?: string }) => (\n <svg className={className} fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M17.657 16.657L13.414 20.9a1.998 1.998 0 01-2.827 0l-4.244-4.243a8 8 0 1111.314 0z\" />\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M15 11a3 3 0 11-6 0 3 3 0 016 0z\" />\n </svg>\n);\n\nconst PhoneIcon = ({ className }: { className?: string }) => (\n <svg className={className} fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M3 5a2 2 0 012-2h3.28a1 1 0 01.948.684l1.498 4.493a1 1 0 01-.502 1.21l-2.257 1.13a11.042 11.042 0 005.516 5.516l1.13-2.257a1 1 0 011.21-.502l4.493 1.498a1 1 0 01.684.949V19a2 2 0 01-2 2h-1C9.716 21 3 14.284 3 6V5z\" />\n </svg>\n);\n\nexport const LocationGrid = ({\n locations: locationsData,\n companyInformation,\n title = \"\",\n subtitle = \"\",\n primaryCtaHrefOverride,\n backgroundColor = \"bg-primary\",\n className = \"\",\n}: LocationGridProps) => {\n const locations = Array.isArray(locationsData) ? locationsData : [];\n const resolved = companyInformation ? resolveCtaUrls(companyInformation) : null;\n const primaryCtaHref = primaryCtaHrefOverride ?? resolved?.primaryHref ?? '/contact';\n \n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mx-auto mb-12 flex w-full max-w-3xl flex-col items-center text-center\">\n {title && (\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {locations.length > 0 ? (\n <ul className=\"grid grid-cols-1 gap-x-8 gap-y-10 sm:grid-cols-2 md:gap-y-12 lg:grid-cols-3\">\n {locations.map((location, index) => {\n const fullAddress = `${location.address_line_1}${location.address_line_2 ? `, ${location.address_line_2}` : ''}, ${location.city}, ${location.state} ${location.zip_code}`.trim();\n \n return (\n <li key={location.id || index} className=\"flex flex-col gap-6 rounded-2xl bg-secondary p-6 ring-1 ring-secondary_alt md:p-8\">\n <div className=\"flex flex-col gap-4\">\n <h3 className=\"text-lg font-semibold text-primary md:text-xl\">{location.name}</h3>\n \n {fullAddress && (\n <div className=\"flex items-start gap-3\">\n <div className=\"size-5 shrink-0 mt-0.5 text-fg-quaternary\">\n <LocationIcon className=\"w-full h-full\" />\n </div>\n <span className=\"text-md text-tertiary\">{fullAddress}</span>\n </div>\n )}\n \n {location.phone && (\n <div className=\"flex items-center gap-3\">\n <div className=\"size-5 shrink-0 text-fg-quaternary\">\n <PhoneIcon className=\"w-full h-full\" />\n </div>\n <a \n href={`tel:${location.phone}`}\n className=\"text-md text-tertiary hover:text-primary transition-colors\"\n >\n {location.phone}\n </a>\n </div>\n )}\n </div>\n\n <div className=\"flex flex-col gap-3 mt-auto\">\n <Button\n size=\"lg\"\n href={`/locations/${location.slug}`}\n iconTrailing={ArrowRight}\n >\n View details\n </Button>\n </div>\n </li>\n );\n })}\n </ul>\n ) : (\n <div className=\"text-center py-12\">\n <div className=\"text-gray-400 text-6xl mb-4\">📍</div>\n <h3 className=\"text-xl font-semibold text-primary mb-2\">No Locations Available</h3>\n <p className=\"text-gray-600 mb-4\">We're working on adding our service locations.</p>\n <Button href={primaryCtaHref} target={isExternalCtaUrl(primaryCtaHref) ? '_blank' : undefined} rel={isExternalCtaUrl(primaryCtaHref) ? 'noopener noreferrer' : undefined}>Contact Us</Button>\n </div>\n )}\n </div>\n </section>\n );\n};\n","import React from 'react';\nimport { Mail01, MarkerPin02, Phone, Clock } from '@untitledui/icons';\nimport { Button } from '../elements';\nimport { FeaturedIcon, GoogleMap } from '../elements';\nimport type { Location } from '../../types/api/location';\n\ninterface LocationDetailsSectionProps {\n location?: Location | null;\n}\n\n// Parse business hours - handle both string and object formats\nconst parseBusinessHours = (hours: string | Record<string, { open: string; close: string }> | undefined): Array<{ day: string; hours: string }> => {\n if (!hours) return [];\n \n if (typeof hours === 'object' && !Array.isArray(hours)) {\n const dayNames: Record<string, string> = {\n monday: 'Monday',\n tuesday: 'Tuesday',\n wednesday: 'Wednesday',\n thursday: 'Thursday',\n friday: 'Friday',\n saturday: 'Saturday',\n sunday: 'Sunday',\n };\n \n return Object.entries(hours)\n .filter(([, value]) => value && typeof value === 'object' && value.open && value.close)\n .map(([day, value]) => ({\n day: dayNames[day.toLowerCase()] || day.charAt(0).toUpperCase() + day.slice(1),\n hours: `${value.open}-${value.close}`,\n }));\n }\n \n if (typeof hours === 'string') {\n const entries = hours.split(',').map(entry => {\n const parts = entry.trim().split(':');\n if (parts.length === 2) {\n return { day: parts[0].trim(), hours: parts[1].trim() };\n }\n return null;\n }).filter(Boolean) as Array<{ day: string; hours: string }>;\n \n return entries.length > 0 ? entries : [{ day: 'Hours', hours }];\n }\n \n return [];\n};\n\nexport const LocationDetailsSection = ({\n location,\n}: LocationDetailsSectionProps) => {\n if (!location) return null;\n\n const label = \"Contact us\";\n const title = \"Get in touch\";\n const subtitle = location.description_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const emailLabel = \"Email\";\n const emailDescription = \"Our friendly team is here to help.\";\n const officeLabel = \"Address\";\n const officeDescription = \"Visit or get directions.\";\n const phoneLabel = \"Phone\";\n const phoneDescription = \"Reach us on the phone.\";\n const backgroundColor = \"bg-primary\";\n const className = \"\";\n const showMap = true;\n const fullAddress = `${location.address_line_1}${location.address_line_2 ? `, ${location.address_line_2}` : ''}, ${location.city}, ${location.state} ${location.zip_code}`.trim();\n \n const businessHours = location.business_hours ? parseBusinessHours(location.business_hours) : [];\n\n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n <div className=\"flex w-full max-w-3xl flex-col\">\n {label && (\n <span className=\"text-sm font-semibold text-brand-secondary md:text-md\">\n {label}\n </span>\n )}\n {title && (\n <h2 className=\"mt-3 text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n\n <div className=\"mt-12 grid grid-cols-1 items-start gap-12 md:mt-16 md:gap-16 lg:grid-cols-3\">\n <ul className=\"col-span-1 grid w-full grid-cols-1 gap-x-8 gap-y-10 md:grid-cols-2 lg:grid-cols-1 lg:gap-y-12\">\n {location.address_line_1 && (\n <li className=\"flex max-w-sm flex-col items-start gap-4 lg:flex-row\">\n <FeaturedIcon className=\"hidden md:flex\" size=\"lg\" icon={MarkerPin02} color=\"brand\" theme=\"light\" />\n <FeaturedIcon className=\"md:hidden\" size=\"md\" icon={MarkerPin02} color=\"brand\" theme=\"light\" />\n <div className=\"lg:pt-2.5\">\n <h3 className=\"text-lg font-semibold text-primary\">\n {officeLabel}\n </h3>\n <p className=\"mt-1 text-md text-tertiary\">\n {officeDescription}\n </p>\n <Button \n href={`https://maps.google.com/?q=${encodeURIComponent(fullAddress)}`}\n color=\"link-color\" \n size=\"lg\" \n className=\"mt-4 whitespace-pre lg:mt-5\"\n >\n {location.address_line_1}{location.address_line_2 ? `\\n${location.address_line_2}` : ''}\n {`\\n${location.city}, ${location.state} ${location.zip_code}`}\n </Button>\n </div>\n </li>\n )}\n \n {location.phone && (\n <li className=\"flex max-w-sm flex-col items-start gap-4 lg:flex-row\">\n <FeaturedIcon className=\"hidden md:flex\" size=\"lg\" icon={Phone} color=\"brand\" theme=\"light\" />\n <FeaturedIcon className=\"md:hidden\" size=\"md\" icon={Phone} color=\"brand\" theme=\"light\" />\n <div className=\"lg:pt-2.5\">\n <h3 className=\"text-lg font-semibold text-primary\">\n {phoneLabel}\n </h3>\n <p className=\"mt-1 text-md text-tertiary\">\n {phoneDescription}\n </p>\n <Button href={`tel:${location.phone}`} color=\"link-color\" size=\"lg\" className=\"mt-4 lg:mt-5\">\n {location.phone}\n </Button>\n </div>\n </li>\n )}\n \n {location.email && (\n <li className=\"flex max-w-sm flex-col items-start gap-4 lg:flex-row\">\n <FeaturedIcon className=\"hidden md:flex\" size=\"lg\" icon={Mail01} color=\"brand\" theme=\"light\" />\n <FeaturedIcon className=\"md:hidden\" size=\"md\" icon={Mail01} color=\"brand\" theme=\"light\" />\n <div className=\"lg:pt-2.5\">\n <h3 className=\"text-lg font-semibold text-primary\">\n {emailLabel}\n </h3>\n <p className=\"mt-1 text-md text-tertiary\">\n {emailDescription}\n </p>\n <Button href={`mailto:${location.email}`} color=\"link-color\" size=\"lg\" className=\"mt-4 lg:mt-5\">\n {location.email}\n </Button>\n </div>\n </li>\n )}\n\n {businessHours.length > 0 && (\n <li className=\"flex max-w-sm flex-col items-start gap-4 lg:flex-row\">\n <FeaturedIcon className=\"hidden md:flex\" size=\"lg\" icon={Clock} color=\"brand\" theme=\"light\" />\n <FeaturedIcon className=\"md:hidden\" size=\"md\" icon={Clock} color=\"brand\" theme=\"light\" />\n <div className=\"lg:pt-2.5\">\n <h3 className=\"text-lg font-semibold text-primary\">\n Business Hours\n </h3>\n <div className=\"mt-1 flex flex-col gap-2 text-md text-tertiary\">\n {businessHours.map(({ day, hours }) => (\n <div key={day} className=\"flex justify-between gap-4\">\n <span className=\"font-medium capitalize\">{day}:</span>\n <span>{hours}</span>\n </div>\n ))}\n </div>\n </div>\n </li>\n )}\n </ul>\n\n {showMap && fullAddress && (\n <div className=\"col-span-2 h-60 w-full border-none lg:h-full\">\n <GoogleMap\n address={fullAddress}\n locationName={location.name}\n className=\"h-full\"\n />\n </div>\n )}\n </div>\n </div>\n </section>\n );\n};\n","import React from 'react';\nimport { ArrowRight } from '@untitledui/icons';\nimport { Button } from '../elements';\nimport { PhotoWithFallback } from '../elements';\nimport type { Service } from '../../types/api/service';\n\ninterface ServicesGridProps {\n services?: Service[] | null;\n title?: string;\n subtitle?: string;\n backgroundColor?: string;\n className?: string;\n}\n\nexport const ServicesGrid = ({\n services: servicesData,\n title = \"\",\n subtitle = \"\",\n backgroundColor = \"bg-secondary\",\n className = \"\",\n}: ServicesGridProps) => {\n const services = Array.isArray(servicesData) ? servicesData : [];\n \n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mx-auto mb-12 flex w-full max-w-3xl flex-col items-center text-center\">\n {title && (\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {services.length > 0 ? (\n <ul className=\"grid grid-cols-1 gap-x-8 gap-y-10 sm:grid-cols-2 md:gap-y-12 lg:grid-cols-3\">\n {services.map((service, index) => {\n const description = service.summary || \n (service.description_markdown ? service.description_markdown.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 120) + '...' : '');\n \n // Get service image from photo_attachments\n const photo = service.photo_attachments?.find((pa) => pa.featured)?.photo ||\n service.photo_attachments?.[0]?.photo;\n const imageAlt = photo?.title || service.name;\n \n return (\n <li key={service.id || index}>\n <div className=\"flex flex-col gap-12 bg-secondary p-5 md:inline-flex md:gap-16 md:p-6\">\n {/* Service Image using PhotoWithFallback */}\n <div className=\"h-48 w-full overflow-hidden rounded-lg md:h-64\">\n <PhotoWithFallback\n item={service}\n fallbackId={service.id || index}\n alt={imageAlt || \"Service image\"}\n className=\"size-full object-cover\"\n />\n </div>\n\n <div className=\"flex flex-col gap-4\">\n <div>\n <h3 className=\"text-lg font-semibold text-primary\">{service.name}</h3>\n {description && (\n <p className=\"mt-1 text-md text-tertiary\">\n {description}\n </p>\n )}\n </div>\n\n <Button\n color=\"link-color\"\n size=\"lg\"\n href={`/services/${service.slug}`}\n iconTrailing={ArrowRight}\n >\n Learn more\n </Button>\n </div>\n </div>\n </li>\n );\n })}\n </ul>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"text-gray-500\">No services available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n","\"use client\";\n\nimport React, { useState } from 'react';\nimport Image from 'next/image';\nimport { ArrowLeft, ArrowRight } from '@untitledui/icons';\nimport { Carousel } from '../elements/carousel/carousel-base';\nimport { Button, PaginationPageMinimalCenter, PhotoWithFallback, RoundButton } from '../elements';\nimport { cx } from '../../utils/cx';\nimport { isVideoUrl } from '../../utils/photo-helpers';\nimport type { SocialPost } from '../../types/api/social-post';\n\n/** Get display image URLs from post (excludes video URLs so img/PhotoWithFallback don't break) */\nfunction getPostImageUrls(post: SocialPost): string[] {\n const videoSet = post.video_urls?.length ? new Set(post.video_urls) : null;\n const isVideo = (url: string) => isVideoUrl(url) || (videoSet !== null && videoSet.has(url));\n if (post.image_urls?.length) {\n return post.image_urls.filter((url) => !isVideo(url));\n }\n const attachments = post.photo_attachments || [];\n const sorted = [...attachments].sort((a, b) => (a.sort_order ?? 0) - (b.sort_order ?? 0));\n return sorted\n .map((pa) => pa.photo?.large_url || pa.photo?.original_url || pa.photo?.medium_url || pa.photo?.thumbnail_url)\n .filter((url): url is string => Boolean(url))\n .filter((url) => !isVideo(url));\n}\n\ninterface SocialMediaGridProps {\n socialPosts?: SocialPost[] | null;\n title?: string;\n subtitle?: string;\n}\n\nconst getPlatformBadge = (platform?: string) => {\n const platformLower = platform?.toLowerCase() || 'social';\n const colors: Record<string, string> = {\n facebook: 'bg-blue-600',\n instagram: 'bg-pink-600',\n twitter: 'bg-blue-400',\n linkedin: 'bg-blue-700',\n youtube: 'bg-red-600',\n };\n return colors[platformLower] || 'bg-gray-600';\n};\n\nconst formatDate = (dateString?: string) => {\n if (!dateString) return 'Recent';\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n year: 'numeric',\n month: 'short',\n day: 'numeric'\n });\n } catch {\n return 'Recent';\n }\n};\n\n\nexport const SocialMediaGrid = ({\n socialPosts: postsData,\n title = \"\",\n subtitle = \"\",\n}: SocialMediaGridProps) => {\n const posts = Array.isArray(postsData) ? postsData : [];\n const postsPerPage = 8;\n const backgroundColor = \"bg-primary\";\n const className = \"\";\n \n const [currentPage, setCurrentPage] = useState(1);\n \n const totalPages = Math.ceil(posts.length / postsPerPage);\n const startIndex = (currentPage - 1) * postsPerPage;\n const endIndex = startIndex + postsPerPage;\n const paginatedPosts = posts.slice(startIndex, endIndex);\n\n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mx-auto mb-12 flex w-full max-w-3xl flex-col items-center text-center\">\n {title && (\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {paginatedPosts.length > 0 ? (\n <>\n <ul className=\"grid grid-cols-1 gap-x-8 gap-y-10 sm:grid-cols-2 md:gap-y-12 lg:grid-cols-3 xl:grid-cols-4\">\n {paginatedPosts.map((post, index) => {\n const images = getPostImageUrls(post);\n const hasMultipleImages = images.length > 1;\n const firstImage = images[0];\n const content = post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <li key={post.id || index} className=\"flex flex-col gap-5 md:gap-6\">\n <div className=\"relative h-78 w-full overflow-hidden md:h-74\">\n {firstImage ? (\n hasMultipleImages ? (\n <Carousel.Root\n opts={{ align: \"start\" }}\n className=\"h-full w-full\"\n >\n <Carousel.Content className=\"h-full\">\n {images.map((imgUrl: string, imgIndex: number) => (\n <Carousel.Item key={imgIndex} className=\"h-full\">\n <Image \n src={imgUrl} \n alt={`${post.platform} post image ${imgIndex + 1}`}\n className=\"size-full object-cover\"\n width={600}\n height={600}\n />\n </Carousel.Item>\n ))}\n </Carousel.Content>\n <div className=\"absolute bottom-4 left-1/2 flex -translate-x-1/2 gap-2\">\n <Carousel.PrevTrigger asChild>\n <RoundButton icon={ArrowLeft} />\n </Carousel.PrevTrigger>\n <Carousel.NextTrigger asChild>\n <RoundButton icon={ArrowRight} />\n </Carousel.NextTrigger>\n </div>\n </Carousel.Root>\n ) : (\n <PhotoWithFallback\n item={post}\n photoUrl={firstImage}\n photoAlt={`${post.platform} post`}\n fallbackId={`social-post-${post.id || index}`}\n className=\"size-full object-cover\"\n />\n )\n ) : (\n <PhotoWithFallback\n item={post}\n photoUrl={undefined}\n photoAlt={`${post.platform} post`}\n fallbackId={`social-post-${post.id || index}`}\n className=\"size-full object-cover\"\n />\n )}\n \n {post.platform && (\n <div className={cx(\n \"absolute top-4 right-4 rounded-full px-3 py-1.5 text-sm font-semibold text-white\",\n getPlatformBadge(post.platform)\n )}>\n {post.platform.charAt(0).toUpperCase() + post.platform.slice(1)}\n </div>\n )}\n </div>\n\n <div className=\"flex flex-col gap-4\">\n <div className=\"flex items-center justify-between\">\n <span className=\"text-sm text-tertiary\">{formatDate(post.posted_at)}</span>\n </div>\n \n {content && (\n <p className=\"text-md text-tertiary line-clamp-4\">\n {content}\n </p>\n )}\n \n <Button \n href={post.external_post_url || `https://${post.platform.toLowerCase()}.com`}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n color=\"link-color\"\n size=\"md\"\n >\n View on {post.platform}\n </Button>\n </div>\n </li>\n );\n })}\n </ul>\n \n {totalPages > 1 && (\n <div className=\"mt-12\">\n <PaginationPageMinimalCenter\n page={currentPage}\n total={totalPages}\n onPageChange={setCurrentPage}\n />\n </div>\n )}\n </>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"text-gray-500\">No social media posts available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n","import React from 'react';\nimport { Clock, CurrencyDollarCircle } from '@untitledui/icons';\nimport { Badge, BadgeWithDot, Button, PhotoWithFallback } from '../elements';\n\nimport type { JobPosting } from '../../types/api/job-posting';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport { resolveCtaUrls, isExternalCtaUrl } from '../../lib/cta-urls';\n\ninterface JobGalleryProps {\n jobs?: JobPosting[] | null;\n websitePhotos?: WebsitePhotos | null;\n companyInformation?: CompanyInformation | null;\n label?: string;\n title?: string;\n subtitle?: string;\n /** Optional route override for the \"Send Us Your Resume\" CTA. When not set, uses primary CTA URL (booking or /contact) from company info. */\n primaryCtaHrefOverride?: string;\n backgroundColor?: string;\n className?: string;\n}\n\nexport const JobGallery = ({\n jobs: jobsData,\n websitePhotos,\n companyInformation,\n label = \"\",\n title = \"\",\n subtitle = \"\",\n primaryCtaHrefOverride,\n backgroundColor = \"bg-primary\",\n className = \"\",\n}: JobGalleryProps) => {\n const resolved = companyInformation ? resolveCtaUrls(companyInformation) : null;\n const primaryCtaHref = primaryCtaHrefOverride ?? resolved?.primaryHref ?? '/contact';\n const careersPhoto = websitePhotos?.careers;\n \n // Use careers photo from API, undefined if not available (triggers gradient fallback)\n const finalHeaderImage = careersPhoto?.url;\n const finalHeaderImageAlt = careersPhoto?.alt || \"Team collaboration\";\n \n // Group jobs by employment_type\n const groupedJobs = React.useMemo(() => {\n const jobs = Array.isArray(jobsData) ? jobsData : [];\n if (!jobs.length) return [];\n \n const groups: Record<string, JobPosting[]> = {};\n jobs.forEach((job) => {\n const category = job.employment_type || 'General';\n if (!groups[category]) {\n groups[category] = [];\n }\n groups[category].push(job);\n });\n \n return Object.entries(groups);\n }, [jobsData]);\n\n return (\n <div className={`${backgroundColor} ${className}`}>\n {/* Hero Section */}\n <section className={`${backgroundColor} py-16 md:py-24`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n {label && (\n <span className=\"text-sm font-semibold text-brand-secondary md:text-md\">{label}</span>\n )}\n <h1 className=\"mt-3 text-display-md font-semibold text-primary md:text-display-lg\">\n {title}\n </h1>\n <p className=\"mt-4 text-lg text-tertiary md:mt-6 md:text-xl\">\n {subtitle}\n </p>\n </div>\n </div>\n </section>\n\n {/* Jobs Section */}\n <section className={`${backgroundColor} py-16 md:py-24`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n <Badge className=\"hidden md:flex\" size=\"lg\" color=\"brand\" type=\"pill-color\">\n Careers\n </Badge>\n <Badge className=\"md:hidden\" size=\"md\" color=\"brand\" type=\"pill-color\">\n Careers\n </Badge>\n\n <h2 className=\"mt-4 text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n </div>\n\n {/* Header Image using PhotoWithFallback */}\n <div className=\"mt-12 h-60 w-full md:mt-16 md:h-140 rounded-xl overflow-hidden\">\n <PhotoWithFallback\n photoUrl={finalHeaderImage}\n photoAlt={finalHeaderImageAlt}\n fallbackId=\"careers-header\"\n className=\"size-full object-cover\"\n />\n </div>\n\n {groupedJobs.length > 0 ? (\n <div className=\"mx-auto mt-12 max-w-3xl md:mt-16\">\n <ul className=\"flex flex-col gap-8 md:gap-16\">\n {groupedJobs.map(([category, categoryJobs]) => (\n <li key={category}>\n <h2 className=\"text-lg font-semibold text-primary md:text-xl\">{category}</h2>\n <ul className=\"mt-5 flex flex-col gap-4 md:mt-8 md:gap-6\">\n {categoryJobs.map((job, index) => {\n const description = job.description_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <li key={job.id || index}>\n <a\n href={`/careers/${job.slug}`}\n className=\"flex flex-col rounded-2xl bg-primary p-6 ring-1 ring-secondary ring-inset hover:ring-2 hover:ring-brand-secondary transition-all\"\n >\n <div className=\"flex flex-col items-start gap-2 md:flex-row\">\n <h3 className=\"text-md font-semibold text-primary\">{job.title}</h3>\n\n <div className=\"flex flex-1 gap-2 md:flex-row-reverse md:justify-between\">\n {job.location && (\n <Badge color=\"gray\" size=\"md\" type=\"modern\">\n {job.location}\n </Badge>\n )}\n\n {job.employment_type && (\n <BadgeWithDot color=\"brand\" size=\"md\" type=\"modern\">\n {job.employment_type}\n </BadgeWithDot>\n )}\n </div>\n </div>\n\n <p className=\"mt-2 text-md text-tertiary line-clamp-2\">\n {description}\n </p>\n\n <div className=\"mt-5 flex gap-4\">\n {job.employment_type && (\n <div className=\"flex items-center gap-1.5\">\n <Clock size={20} className=\"text-fg-quaternary\" />\n <span className=\"text-sm font-medium text-tertiary\">{job.employment_type}</span>\n </div>\n )}\n {job.salary_range && (\n <div className=\"flex items-center gap-1.5\">\n <CurrencyDollarCircle size={20} className=\"text-fg-quaternary\" />\n <span className=\"text-sm font-medium text-tertiary\">{job.salary_range}</span>\n </div>\n )}\n </div>\n </a>\n </li>\n );\n })}\n </ul>\n </li>\n ))}\n </ul>\n </div>\n ) : (\n <div className=\"text-center mt-12\">\n <p className=\"text-gray-500 mb-4\">No open positions at the moment.</p>\n <p className=\"text-gray-600 mb-6\">We're always looking for talented individuals to join our team.</p>\n <Button href={primaryCtaHref} target={isExternalCtaUrl(primaryCtaHref) ? '_blank' : undefined} rel={isExternalCtaUrl(primaryCtaHref) ? 'noopener noreferrer' : undefined}>Send Us Your Resume</Button>\n </div>\n )}\n </div>\n </section>\n </div>\n );\n};\n","import Link from 'next/link';\nimport { ArrowUpRight, ArrowLeft, ArrowRight } from \"@untitledui/icons\";\nimport { Button, PhotoWithFallback, RoundButton } from '../elements';\nimport { Carousel } from '../elements/carousel/carousel-base';\nimport { cx } from '../../utils/cx';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface BlogHomeProps {\n blogPosts?: BlogPost[] | null;\n label?: string;\n title?: string;\n subtitle?: string;\n maxPosts?: number;\n viewAllHref?: string;\n viewAllText?: string;\n}\n\nexport const BlogHome = ({\n blogPosts: postsData,\n label = \"\",\n title = \"\",\n subtitle = \"\",\n maxPosts = 6,\n viewAllHref = \"/blog\",\n viewAllText = \"View all posts\",\n}: BlogHomeProps) => {\n \n const posts = Array.isArray(postsData) ? postsData.slice(0, maxPosts) : [];\n \n const formatDate = (dateString?: string) => {\n if (!dateString) return 'Recent';\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n day: 'numeric',\n month: 'short',\n year: 'numeric'\n });\n } catch {\n return 'Recent';\n }\n };\n\n return (\n <section className=\"overflow-hidden bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"flex flex-col items-start justify-between lg:flex-row\">\n <div className=\"max-w-3xl\">\n <p className=\"text-sm font-semibold text-brand-secondary md:text-md\">{label}</p>\n <h2 className=\"mt-3 text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n </div>\n\n {viewAllHref && (\n <div className=\"hidden gap-3 lg:flex\">\n <Button size=\"xl\" href={viewAllHref}>{viewAllText}</Button>\n </div>\n )}\n </div>\n\n {posts && posts.length > 0 ? (\n <>\n <Carousel.Root\n className=\"mt-12 md:mt-16\"\n opts={{\n align: \"start\",\n }}\n >\n <Carousel.Content overflowHidden={false} className=\"gap-6 pr-4 md:gap-8 md:pr-8\">\n {posts.map((post, index) => {\n const author = post.blog_post_authors?.[0];\n const excerpt = post.excerpt_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <Carousel.Item key={post.id || index} className=\"max-w-xs md:max-w-96\">\n <article className={cx(\"flex flex-col gap-4\")}>\n <div className=\"relative\">\n <a href={`/blog/${post.slug || post.id}`} className=\"w-full\" tabIndex={-1}>\n <PhotoWithFallback\n item={post}\n fallbackId={post.id || index}\n alt={post.title || 'Blog post'}\n className={cx(\"aspect-[1.5] w-full object-cover\")}\n />\n </a>\n <div className=\"absolute inset-x-0 bottom-0 overflow-hidden bg-linear-to-b from-transparent to-black/40\">\n <div className=\"relative flex items-start justify-between bg-alpha-white/30 p-4 backdrop-blur-md before:absolute before:inset-x-0 before:top-0 before:h-px before:bg-alpha-white/30 md:p-5\">\n <div>\n <a\n href={author?.slug ? `/blog/author/${author.slug}` : '/blog'}\n className=\"block rounded-xs text-sm font-semibold text-white outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {author?.name || 'Author'}\n </a>\n <time className=\"block text-sm text-white\">\n {formatDate(post.published_at)}\n </time>\n </div>\n <Link\n href=\"/blog\"\n className=\"rounded-xs text-sm font-semibold text-white outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n Blog\n </Link>\n </div>\n </div>\n </div>\n <div className=\"flex flex-col gap-2\">\n <a\n href={`/blog/${post.slug || post.id}`}\n className=\"group/title flex justify-between gap-x-4 rounded-md text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {post.title || 'Untitled Post'}\n <ArrowUpRight\n className=\"mt-0.5 size-6 shrink-0 text-fg-quaternary transition duration-100 ease-linear group-hover/title:text-fg-quaternary_hover\"\n aria-hidden=\"true\"\n />\n </a>\n {excerpt && (\n <p className=\"line-clamp-2 text-md text-tertiary\">{excerpt}</p>\n )}\n </div>\n </article>\n </Carousel.Item>\n );\n })}\n </Carousel.Content>\n <div className=\"mt-8 flex gap-4 md:gap-8\">\n <Carousel.PrevTrigger asChild>\n <RoundButton icon={ArrowLeft} />\n </Carousel.PrevTrigger>\n <Carousel.NextTrigger asChild>\n <RoundButton icon={ArrowRight} />\n </Carousel.NextTrigger>\n </div>\n </Carousel.Root>\n {viewAllHref && (\n <div className=\"mt-12 flex flex-col gap-3 lg:hidden\">\n <Button size=\"xl\" href={viewAllHref}>{viewAllText}</Button>\n </div>\n )}\n </>\n ) : (\n <div className=\"mt-12 text-center md:mt-16\">\n <p className=\"text-gray-500\">No blog posts available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n","\"use client\";\n\nimport React, { useState } from 'react';\nimport { ArrowUpRight } from '@untitledui/icons';\nimport { Avatar, Select, SelectItem, PaginationPageDefault, PhotoWithFallback } from '../elements';\nimport { BlogCardVertical, getBlogPostData } from './blog-cards';\nimport { useBreakpoint } from '../../lib/hooks/use-breakpoint';\nimport { cx } from '../../utils/cx';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface BlogGalleryProps {\n blogPosts?: BlogPost[] | null;\n postsPerPage?: number;\n className?: string;\n}\n\nconst defaultSortByOptions = [\n { id: \"recent\", label: \"Most recent\" },\n { id: \"popular\", label: \"Most popular\" },\n { id: \"viewed\", label: \"Most viewed\" },\n];\n\nexport const BlogGallery = ({\n blogPosts: postsData,\n postsPerPage = 12,\n className = \"\",\n}: BlogGalleryProps) => {\n const posts = Array.isArray(postsData) ? postsData : [];\n const isDesktop = useBreakpoint(\"lg\");\n const [currentPage, setCurrentPage] = useState(1);\n const [sortBy, setSortBy] = useState(defaultSortByOptions[0].id);\n\n // Sort posts based on sortBy\n const sortedPosts = [...posts];\n if (sortBy === 'recent') {\n sortedPosts.sort((a, b) => {\n const dateA = a.published_at ? new Date(a.published_at).getTime() : 0;\n const dateB = b.published_at ? new Date(b.published_at).getTime() : 0;\n return dateB - dateA;\n });\n }\n // TODO: Add popular and viewed sorting when those fields are available\n\n // Get featured post (first post with featured: true or first post)\n const featuredPost = sortedPosts.find((post) => post.featured) || sortedPosts[0];\n const nonFeaturedPosts = sortedPosts.filter((post) => post.id !== featuredPost?.id);\n \n // Calculate pagination for non-featured posts\n const totalPages = Math.ceil(nonFeaturedPosts.length / postsPerPage);\n const startIndex = (currentPage - 1) * postsPerPage;\n const endIndex = startIndex + postsPerPage;\n const paginatedNonFeaturedPosts = nonFeaturedPosts.slice(startIndex, endIndex);\n\n // Reset to page 1 when sort changes\n React.useEffect(() => {\n setCurrentPage(1);\n }, [sortBy]);\n\n return (\n <section className={className}>\n <div className=\"mx-auto flex w-full max-w-container flex-col gap-12 px-4 md:gap-16 md:px-8\">\n {posts.length > 0 ? (\n <>\n {/* Featured Post - Desktop: image on top, text below */}\n {featuredPost && (\n <a\n href={`/blog/${featuredPost.slug}`}\n className=\"group hidden w-full overflow-hidden rounded-2xl outline-focus-ring select-none focus:outline-2 focus:outline-offset-4 md:flex md:flex-col\"\n >\n <div className=\"relative w-full overflow-hidden rounded-t-2xl md:h-145 lg:h-180\">\n <PhotoWithFallback\n item={featuredPost}\n fallbackId={featuredPost.id}\n alt={featuredPost.title || 'Featured post'}\n className=\"size-full object-cover transition duration-100 ease-linear group-hover:scale-105\"\n />\n </div>\n {(() => {\n const { title, summary, publishedAt, authorName, authorAvatarUrl } = getBlogPostData(featuredPost);\n return (\n <div className=\"flex flex-col gap-4 rounded-b-2xl border border-t-0 border-secondary bg-primary p-6\">\n <div className=\"flex flex-col gap-2\">\n <div className=\"flex items-start gap-2\">\n <p className=\"flex-1 text-display-xs font-semibold text-primary\">{title}</p>\n <ArrowUpRight className=\"size-5 shrink-0 text-tertiary group-hover:text-brand-secondary\" />\n </div>\n {summary && <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>}\n </div>\n <div className=\"flex flex-wrap items-center gap-4 text-sm text-tertiary\">\n <div className=\"flex items-center gap-2\">\n <Avatar focusable size=\"sm\" src={authorAvatarUrl} alt={authorName} />\n <span className=\"font-medium\">{authorName}</span>\n </div>\n <span>{publishedAt}</span>\n </div>\n </div>\n );\n })()}\n </a>\n )}\n\n {/* Featured Post - Mobile */}\n {featuredPost && (\n <div className=\"md:hidden\">\n <BlogCardVertical article={featuredPost} />\n </div>\n )}\n\n {/* Sort Controls */}\n <div className=\"flex flex-col items-end gap-8 md:flex-row\">\n <div className=\"relative w-full md:w-auto md:min-w-36 md:max-w-40\">\n <Select\n aria-label=\"Sort by\"\n size=\"sm\"\n selectedKey={sortBy}\n onSelectionChange={(value: string | number | null) => setSortBy(value as string)}\n items={defaultSortByOptions}\n >\n {(item: { id: string; label: string }) => <SelectItem id={item.id}>{item.label}</SelectItem>}\n </Select>\n </div>\n </div>\n\n {/* Posts Grid */}\n {paginatedNonFeaturedPosts.length > 0 && (\n <ul className=\"grid grid-cols-1 gap-x-8 gap-y-12 md:grid-cols-2 md:gap-y-12 lg:grid-cols-3\">\n {paginatedNonFeaturedPosts.map((post) => (\n <li key={post.id} className={cx(!isDesktop && \"nth-[n+7]:hidden\")}>\n <BlogCardVertical article={post} />\n </li>\n ))}\n </ul>\n )}\n\n {/* Pagination */}\n {totalPages > 1 && (\n <PaginationPageDefault \n rounded \n page={currentPage}\n total={totalPages}\n onPageChange={setCurrentPage}\n />\n )}\n </>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"text-gray-500\">No blog posts available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n","import type { ComponentProps } from \"react\";\nimport { ArrowUpRight } from \"@untitledui/icons\";\nimport { Avatar, BadgeGroup, Button, PhotoWithFallback } from '../elements';\nimport { cx } from '../../utils/cx';\nimport { getAvatarUrl } from '../../utils/photo-helpers';\nimport type { BlogPost } from '../../types/api/blog-post';\n\n// Helper to get first author from blog post\nconst getFirstAuthor = (post: BlogPost) => {\n return Array.isArray(post.blog_post_authors) && post.blog_post_authors.length > 0 \n ? post.blog_post_authors[0] \n : null;\n};\n\n// Helper to format published date\nconst formatPublishedDate = (publishedAt?: string) => {\n return publishedAt \n ? new Date(publishedAt).toLocaleDateString('en-US', { day: 'numeric', month: 'short', year: 'numeric' })\n : 'Recent';\n};\n\n// Helper to clean excerpt markdown\nconst cleanExcerpt = (excerpt?: string) => {\n return excerpt?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n};\n\n// Helper to get first tag from blog post\nconst getFirstTag = (post: BlogPost) => {\n return Array.isArray(post.blog_post_tags) && post.blog_post_tags.length > 0 \n ? post.blog_post_tags[0] \n : null;\n};\n\n// Helper to extract all blog post data for rendering (exported for use in blog-gallery featured card)\nexport const getBlogPostData = (article: BlogPost) => {\n const author = getFirstAuthor(article);\n const authorName = author?.name || 'Author';\n const authorHref = author?.slug ? `/blog/author/${author.slug}` : '/blog';\n const authorAvatarUrl = getAvatarUrl(author?.photo_attachments, author?.id, authorName);\n const tag = getFirstTag(article);\n const tagName = tag?.name || 'Blog';\n const tagHref = tag?.slug ? `/blog/tag/${tag.slug}` : '/blog';\n const href = `/blog/${article.slug}`;\n const title = article.title || 'Untitled Post';\n const publishedAt = formatPublishedDate(article.published_at);\n const summary = cleanExcerpt(article.excerpt_markdown);\n \n return {\n author,\n authorName,\n authorHref,\n authorAvatarUrl,\n tag,\n tagName,\n tagHref,\n href,\n title,\n publishedAt,\n summary,\n };\n};\n\nexport const BlogCardVertical = ({ article, imageClassName }: { article: BlogPost; imageClassName?: string }) => {\n const { authorName, authorHref, authorAvatarUrl, href, title, summary, publishedAt } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col gap-4\">\n <a href={href} className=\"overflow-hidden rounded-2xl\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className={cx(\"aspect-[1.5] w-full object-cover transition duration-100 ease-linear hover:scale-105\", imageClassName)}\n />\n </a>\n\n <div className=\"flex flex-col gap-5\">\n <div className=\"flex flex-col gap-2\">\n <span className=\"text-sm font-semibold text-brand-secondary\">Blog</span>\n <div className=\"flex flex-col gap-1\">\n <a\n href={href}\n className=\"group/title flex justify-between gap-x-4 rounded-md text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {title}\n <ArrowUpRight\n className=\"mt-0.5 size-6 shrink-0 text-fg-quaternary transition duration-100 ease-linear group-hover/title:text-fg-quaternary_hover\"\n aria-hidden=\"true\"\n />\n </a>\n\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n </div>\n\n <div className=\"flex gap-2\">\n <a href={authorHref} tabIndex={-1} className=\"flex\">\n <Avatar focusable alt={authorName} src={authorAvatarUrl} size=\"md\" />\n </a>\n\n <div>\n <a\n href={authorHref}\n className=\"block rounded-xs text-sm font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {authorName}\n </a>\n <time className=\"block text-sm text-tertiary\">{publishedAt}</time>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardVerticalBadge = ({\n article,\n badgeTheme = \"light\",\n imageClassName,\n}: {\n article: BlogPost;\n badgeTheme?: ComponentProps<typeof BadgeGroup>[\"theme\"];\n imageClassName?: string;\n}) => {\n const { authorName, authorHref, authorAvatarUrl, href, title, summary, publishedAt } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col gap-4\">\n <a href={href} className=\"overflow-hidden rounded-xl\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className={cx(\"aspect-[1.5] w-full object-cover\", imageClassName)}\n />\n </a>\n\n <div className=\"flex flex-col gap-5\">\n <div className=\"flex flex-col items-start gap-3\">\n <BadgeGroup addonText=\"Blog\" size=\"md\" theme={badgeTheme} color=\"brand\" className=\"pr-3\" iconTrailing={null}>\n 5 min read\n </BadgeGroup>\n <div className=\"flex flex-col gap-1\">\n <a\n href={href}\n className=\"flex justify-between gap-x-4 rounded-md text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {title}\n <ArrowUpRight className=\"mt-0.5 size-6 shrink-0 text-fg-quaternary\" aria-hidden=\"true\" />\n </a>\n <p className=\"line-clamp-2 text-md text-tertiary md:line-clamp-none\">{summary}</p>\n </div>\n </div>\n\n <div className=\"flex gap-2\">\n <a href={authorHref} tabIndex={-1} className=\"flex\">\n <Avatar focusable alt={authorName} src={authorAvatarUrl} size=\"md\" />\n </a>\n\n <div>\n <a\n href={authorHref}\n className=\"block rounded-xs text-sm font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {authorName}\n </a>\n <time className=\"block text-sm text-tertiary\">{publishedAt}</time>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardVerticalCompact = ({\n article,\n imageClassName,\n titleClassName,\n className,\n}: {\n article: BlogPost;\n imageClassName?: string;\n titleClassName?: string;\n className?: string;\n}) => {\n const { authorName, href, title, summary, publishedAt } = getBlogPostData(article);\n \n return (\n <article className={cx(\"flex flex-col gap-4\", className)}>\n <a href={href} className=\"overflow-hidden rounded-2xl\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className={cx(\"aspect-[1.5] w-full object-cover\", imageClassName)}\n />\n </a>\n\n <div className=\"flex flex-col gap-6\">\n <div className=\"flex flex-col items-start gap-2\">\n <p className=\"text-sm font-semibold text-brand-secondary\">\n {authorName} • <time>{publishedAt}</time>\n </p>\n <div className=\"flex w-full flex-col gap-1\">\n <a\n href={href}\n className={cx(\n \"flex justify-between gap-x-4 rounded-md text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\",\n titleClassName,\n )}\n >\n {title}\n <ArrowUpRight className=\"mt-0.5 size-6 shrink-0 text-fg-quaternary\" aria-hidden=\"true\" />\n </a>\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardVerticalMinimal = ({ article, imageClassName, className }: { article: BlogPost; imageClassName?: string; className?: string }) => {\n const { authorName, authorHref, href, title, summary, publishedAt } = getBlogPostData(article);\n \n return (\n <article className={cx(\"flex flex-col gap-4\", className)}>\n <div className=\"relative\">\n <a href={href} className=\"w-full\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className={cx(\"aspect-[1.5] w-full object-cover\", imageClassName)}\n />\n </a>\n <div className=\"absolute inset-x-0 bottom-0 overflow-hidden bg-linear-to-b from-transparent to-black/40\">\n <div className=\"relative flex items-start justify-between bg-alpha-white/30 p-4 backdrop-blur-md before:absolute before:inset-x-0 before:top-0 before:h-px before:bg-alpha-white/30 md:p-5\">\n <div>\n <a\n href={authorHref}\n className=\"block rounded-xs text-sm font-semibold text-white outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {authorName}\n </a>\n <time className=\"block text-sm text-white\">{publishedAt}</time>\n </div>\n <a\n href={href}\n className=\"rounded-xs text-sm font-semibold text-white outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n Blog\n </a>\n </div>\n </div>\n </div>\n\n <div className=\"flex flex-col items-start gap-5\">\n <div className=\"flex flex-col gap-1\">\n <a\n href={href}\n className=\"flex justify-between gap-x-4 rounded-md text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {title}\n </a>\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n\n <Button href={href} color=\"link-color\" size=\"lg\" iconTrailing={ArrowUpRight}>\n Read post\n </Button>\n </div>\n </article>\n );\n};\n\nexport const BlogCardHorizontal = ({ article, imageClassName }: { article: BlogPost; imageClassName?: string }) => {\n const { authorName, authorHref, authorAvatarUrl, tagName, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col gap-4 xl:flex-row xl:items-start\">\n <a href={href} className=\"shrink-0 overflow-hidden rounded-2xl\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className={cx(\"aspect-[1.5] w-full object-cover xl:w-80\", imageClassName)}\n />\n </a>\n\n <div className=\"flex flex-col gap-5\">\n <div className=\"flex flex-col gap-2\">\n <span className=\"text-sm font-semibold text-brand-secondary\">{tagName}</span>\n\n <div className=\"flex flex-col gap-1\">\n <a\n href={href}\n className=\"flex justify-between gap-x-4 rounded-md text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {title}\n </a>\n\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n </div>\n\n <div className=\"flex gap-2\">\n <a href={authorHref} tabIndex={-1} className=\"flex\">\n <Avatar focusable alt={authorName} src={authorAvatarUrl} size=\"md\" />\n </a>\n\n <div>\n <a\n href={authorHref}\n className=\"block rounded-xs text-sm font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {authorName}\n </a>\n <time className=\"block text-sm text-tertiary\">{publishedAt}</time>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardHorizontalBadge = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, authorAvatarUrl, tagName, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col gap-5 lg:flex-row lg:items-start\">\n <a href={href} className=\"shrink-0 overflow-hidden\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover lg:h-50 lg:w-91.5\"\n />\n </a>\n\n <div className=\"flex flex-col gap-6\">\n <div className=\"flex flex-col gap-2\">\n <BadgeGroup addonText={tagName} size=\"md\" theme=\"light\" color=\"brand\" className=\"pr-3\" iconTrailing={null}>\n Blog\n </BadgeGroup>\n <div className=\"flex flex-col gap-2\">\n <a\n href={href}\n className=\"rounded-xs text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {title}\n </a>\n\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n </div>\n\n <div className=\"flex gap-2\">\n <a href={authorHref} tabIndex={-1} className=\"flex\">\n <Avatar focusable alt={authorName} src={authorAvatarUrl} size=\"md\" />\n </a>\n\n <div>\n <a\n href={authorHref}\n className=\"block rounded-xs text-sm font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {authorName}\n </a>\n <time className=\"block text-sm text-tertiary\">{publishedAt}</time>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardHorizontalCompact = ({ article, imageClassName }: { article: BlogPost; imageClassName?: string }) => {\n const { authorName, authorHref, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col gap-4 xl:flex-row xl:items-start\">\n <a href={href} className=\"shrink-0 overflow-hidden rounded-2xl\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className={cx(\"aspect-[1.5] w-full object-cover xl:w-91.5\", imageClassName)}\n />\n </a>\n\n <div className=\"flex flex-col gap-6\">\n <div className=\"flex flex-col gap-2\">\n <p className=\"text-sm font-semibold text-brand-secondary\">\n <a href={authorHref} className=\"rounded-xs outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\">\n {authorName}\n </a>{\" \"}\n • <time>{publishedAt}</time>\n </p>\n <div className=\"flex flex-col gap-1\">\n <a\n href={href}\n className=\"rounded-xs text-lg font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {title}\n </a>\n\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardHorizontalMinimal = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, tagName, tagHref, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col gap-5 lg:flex-row lg:items-start\">\n <div className=\"relative shrink-0\">\n <a href={href} className=\"w-full\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover lg:h-50 lg:w-80\"\n />\n </a>\n <div className=\"absolute inset-x-0 bottom-0 overflow-hidden bg-linear-to-b from-transparent to-black/40\">\n <div className=\"relative flex items-start justify-between bg-alpha-white/30 p-4 backdrop-blur-md before:absolute before:inset-x-0 before:top-0 before:h-px before:bg-alpha-white/30\">\n <div>\n <a\n href={authorHref}\n className=\"block rounded-xs text-sm font-semibold text-white outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {authorName}\n </a>\n <time className=\"block text-sm text-white\">{publishedAt}</time>\n </div>\n <a\n href={tagHref}\n className=\"rounded-xs text-sm font-semibold text-white outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n {tagName}\n </a>\n </div>\n </div>\n </div>\n\n <div className=\"flex flex-col items-start gap-6\">\n <div className=\"flex flex-col gap-2\">\n <a\n href={href}\n className=\"block rounded-xs text-xl font-semibold text-primary outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2 md:text-lg\"\n >\n {title}\n </a>\n <p className=\"line-clamp-2 text-md text-tertiary lg:line-clamp-3\">{summary}</p>\n </div>\n\n <Button href={href} color=\"link-color\" size=\"lg\" iconTrailing={ArrowUpRight}>\n Read post\n </Button>\n </div>\n </article>\n );\n};\n\nexport const BlogCardFullWidthVertical = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, authorAvatarUrl, tagName, tagHref, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col overflow-hidden rounded-2xl ring-1 ring-secondary ring-inset\">\n <a href={href} tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-50 w-full object-cover md:h-60\"\n />\n </a>\n\n <div className=\"flex flex-col gap-6 p-5 pb-6 md:p-6\">\n <div className=\"flex flex-col gap-2\">\n <Button color=\"link-color\" href={tagHref}>\n {tagName}\n </Button>\n <div className=\"flex flex-col gap-2\">\n <Button\n color=\"link-gray\"\n href={href}\n className=\"flex justify-between gap-4 text-xl font-semibold text-primary hover:text-brand-secondary md:text-display-xs\"\n iconTrailing={<ArrowUpRight className=\"size-6 shrink-0\" aria-hidden=\"true\" />}\n >\n {title}\n </Button>\n <p className=\"line-clamp-2 text-md text-tertiary md:line-clamp-3\">{summary}</p>\n </div>\n </div>\n\n <div className=\"flex gap-2\">\n <a href={authorHref} tabIndex={-1} className=\"flex\">\n <Avatar focusable alt={authorName} src={authorAvatarUrl} size=\"md\" />\n </a>\n\n <div>\n <p className=\"text-sm font-semibold\">\n <Button color=\"link-color\" href={authorHref} className=\"text-primary\">\n {authorName}\n </Button>\n </p>\n <time className=\"block text-sm text-tertiary\">{publishedAt}</time>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardFullWidthVerticalAlt = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, authorAvatarUrl, tagName, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col overflow-hidden rounded-2xl ring-1 ring-secondary ring-inset\">\n <a href={href} tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover\"\n />\n </a>\n\n <div className=\"flex flex-col gap-6 p-5 pb-6 md:p-6\">\n <div className=\"flex flex-col gap-4\">\n <BadgeGroup addonText={tagName} size=\"md\" theme=\"light\" color=\"brand\" className=\"pr-3\" iconTrailing={null}>\n Blog\n </BadgeGroup>\n <div className=\"flex flex-col gap-2\">\n <Button\n color=\"link-gray\"\n href={href}\n className=\"flex justify-between gap-4 text-xl font-semibold text-primary hover:text-brand-secondary md:text-display-xs\"\n iconTrailing={<ArrowUpRight className=\"size-6 shrink-0\" aria-hidden=\"true\" />}\n >\n {title}\n </Button>\n <p className=\"line-clamp-2 text-md text-tertiary md:line-clamp-3\">{summary}</p>\n </div>\n </div>\n\n <div className=\"flex gap-2\">\n <a href={authorHref} tabIndex={-1} className=\"flex\">\n <Avatar focusable alt={authorName} src={authorAvatarUrl} size=\"md\" />\n </a>\n\n <div>\n <p className=\"text-sm font-semibold\">\n <Button color=\"link-color\" href={authorHref} className=\"text-primary\">\n {authorName}\n </Button>\n </p>\n <time className=\"block text-sm text-tertiary\">{publishedAt}</time>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardFullWidthVerticalCompact = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col overflow-hidden rounded-2xl ring-1 ring-secondary ring-inset\">\n <a href={href} tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover\"\n />\n </a>\n\n <div className=\"flex flex-col gap-6 p-5 pb-6 md:p-6\">\n <div className=\"flex flex-col gap-2\">\n <p className=\"text-sm font-semibold text-brand-secondary\">\n <Button href={authorHref} color=\"link-color\">\n {authorName}\n </Button>{\" \"}\n • <time>{publishedAt}</time>\n </p>\n <div className=\"flex flex-col gap-2\">\n <Button\n color=\"link-gray\"\n href={href}\n className=\"flex justify-between gap-4 text-xl font-semibold text-primary hover:text-brand-secondary md:text-display-xs\"\n iconTrailing={<ArrowUpRight className=\"size-6 shrink-0\" aria-hidden=\"true\" />}\n >\n {title}\n </Button>\n <p className=\"line-clamp-2 text-md text-tertiary md:line-clamp-3\">{summary}</p>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardFullWidthVerticalMinimal = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, tagName, tagHref, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col overflow-hidden rounded-2xl ring-1 ring-secondary ring-inset\">\n <div className=\"relative shrink-0\">\n <a href={href} className=\"w-full\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover md:h-70\"\n />\n </a>\n <div className=\"absolute inset-x-0 bottom-0 overflow-hidden bg-linear-to-b from-transparent to-black/40\">\n <div className=\"relative flex items-start justify-between bg-alpha-white/30 p-4 backdrop-blur-md before:absolute before:inset-x-0 before:top-0 before:h-px before:bg-alpha-white/30 md:p-6\">\n <div>\n <p className=\"text-sm font-semibold\">\n <Button href={authorHref} color=\"link-gray\" className=\"text-white\">\n {authorName}\n </Button>\n </p>\n <time className=\"block text-sm text-white\">{publishedAt}</time>\n </div>\n <p className=\"text-sm font-semibold\">\n <Button href={tagHref} color=\"link-gray\" className=\"text-white\">\n {tagName}\n </Button>\n </p>\n </div>\n </div>\n </div>\n\n <div className=\"flex flex-col gap-6 p-5 pb-6 md:p-6\">\n <div className=\"flex flex-col gap-2\">\n <div className=\"flex flex-col gap-2\">\n <Button\n color=\"link-gray\"\n href={href}\n className=\"flex justify-between gap-4 text-xl font-semibold text-primary hover:text-brand-secondary md:text-display-xs\"\n iconTrailing={<ArrowUpRight className=\"size-6 shrink-0\" aria-hidden=\"true\" />}\n >\n {title}\n </Button>\n <p className=\"line-clamp-2 text-md text-tertiary md:line-clamp-3\">{summary}</p>\n </div>\n </div>\n\n <Button href={href} color=\"link-color\" size=\"lg\" iconTrailing={ArrowUpRight}>\n Read post\n </Button>\n </div>\n </article>\n );\n};\n\nexport const BlogCardFullWidthHorizontal = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, authorAvatarUrl, tagName, tagHref, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col overflow-hidden rounded-2xl ring-1 ring-secondary ring-inset md:flex-row md:items-start\">\n <a href={href} className=\"shrink-0\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover md:h-60 md:w-80\"\n />\n </a>\n\n <div className=\"flex flex-col gap-6 p-5 pb-6 md:p-6\">\n <div className=\"flex flex-col gap-2\">\n <Button href={tagHref} color=\"link-color\">\n {tagName}\n </Button>\n <div className=\"flex flex-col gap-2\">\n <Button href={href} color=\"link-gray\" size=\"xl\" className=\"text-xl font-semibold text-primary md:text-lg\">\n {title}\n </Button>\n\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n </div>\n\n <div className=\"flex gap-2\">\n <a href={authorHref} tabIndex={-1} className=\"flex\">\n <Avatar focusable alt={authorName} src={authorAvatarUrl} size=\"md\" />\n </a>\n\n <div>\n <p className=\"text-sm font-semibold\">\n <Button href={authorHref} color=\"link-gray\" className=\"text-primary\">\n {authorName}\n </Button>\n </p>\n <time className=\"block text-sm text-tertiary\">{publishedAt}</time>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardFullWidthHorizontalAlt = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, authorAvatarUrl, tagName, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col overflow-hidden rounded-2xl ring-1 ring-secondary ring-inset md:flex-row md:items-start\">\n <a href={href} className=\"shrink-0\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover md:h-60.5 md:w-80\"\n />\n </a>\n\n <div className=\"flex flex-col gap-6 p-5 pb-6 md:p-6\">\n <div className=\"flex flex-col gap-4\">\n <BadgeGroup addonText={tagName} size=\"md\" theme=\"light\" color=\"brand\" className=\"pr-3\" iconTrailing={null}>\n Blog\n </BadgeGroup>\n <div className=\"flex flex-col gap-2\">\n <Button href={href} color=\"link-gray\" size=\"xl\" className=\"text-xl font-semibold text-primary md:text-lg\">\n {title}\n </Button>\n\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n </div>\n\n <div className=\"flex gap-2\">\n <a href={authorHref} tabIndex={-1} className=\"flex\">\n <Avatar focusable alt={authorName} src={authorAvatarUrl} size=\"md\" />\n </a>\n\n <div>\n <p className=\"text-sm font-semibold\">\n <Button href={authorHref} color=\"link-gray\" className=\"text-primary\">\n {authorName}\n </Button>\n </p>\n <time className=\"block text-sm text-tertiary\">{publishedAt}</time>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardFullWidthHorizontalCompact = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col overflow-hidden rounded-2xl ring-1 ring-secondary ring-inset md:flex-row md:items-start\">\n <a href={href} className=\"shrink-0\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover md:h-60 md:w-80\"\n />\n </a>\n\n <div className=\"flex flex-col gap-6 p-5 pb-6 md:p-6\">\n <div className=\"flex flex-col gap-2\">\n <p className=\"text-sm font-semibold text-brand-secondary\">\n <Button href={authorHref} color=\"link-color\">\n {authorName}\n </Button>{\" \"}\n • <time>{publishedAt}</time>\n </p>\n <div className=\"flex flex-col gap-2\">\n <Button href={href} color=\"link-gray\" size=\"xl\" className=\"text-xl font-semibold text-primary md:text-lg\">\n {title}\n </Button>\n\n <p className=\"line-clamp-2 text-md text-tertiary\">{summary}</p>\n </div>\n </div>\n </div>\n </article>\n );\n};\n\nexport const BlogCardFullWidthHorizontalMinimal = ({ article }: { article: BlogPost }) => {\n const { authorName, authorHref, tagName, tagHref, href, title, publishedAt, summary } = getBlogPostData(article);\n \n return (\n <article className=\"flex flex-col overflow-hidden rounded-2xl ring-1 ring-secondary ring-inset md:flex-row md:items-start\">\n <div className=\"relative shrink-0\">\n <a href={href} className=\"w-full\" tabIndex={-1}>\n <PhotoWithFallback\n item={article}\n fallbackId={article.id}\n alt={title}\n className=\"h-60 w-full object-cover md:h-60 md:w-80\"\n />\n </a>\n <div className=\"absolute inset-x-0 bottom-0 overflow-hidden bg-linear-to-b from-transparent to-black/40\">\n <div className=\"relative flex items-start justify-between bg-alpha-white/30 p-4 backdrop-blur-md before:absolute before:inset-x-0 before:top-0 before:h-px before:bg-alpha-white/30 md:p-6\">\n <div>\n <p className=\"text-sm font-semibold\">\n <Button href={authorHref} color=\"link-gray\" className=\"text-white\">\n {authorName}\n </Button>\n </p>\n <time className=\"block text-sm text-white\">{publishedAt}</time>\n </div>\n <p className=\"text-sm font-semibold\">\n <Button href={tagHref} color=\"link-gray\" className=\"text-white\">\n {tagName}\n </Button>\n </p>\n </div>\n </div>\n </div>\n\n <div className=\"flex flex-col gap-6 p-5 pb-6 md:p-6\">\n <div className=\"flex flex-col gap-2\">\n <div className=\"flex flex-col gap-2\">\n <Button href={href} color=\"link-gray\" size=\"xl\" className=\"text-xl font-semibold text-primary md:text-lg\">\n {title}\n </Button>\n\n <p className=\"line-clamp-2 text-md text-tertiary md:line-clamp-3\">{summary}</p>\n </div>\n </div>\n\n <Button href={href} color=\"link-color\" size=\"lg\" iconTrailing={ArrowUpRight}>\n Read post\n </Button>\n </div>\n </article>\n );\n};\n","\"use client\";\n\nimport React, { useState } from 'react';\nimport { Link01, Copy01 } from '@untitledui/icons';\nimport { Badge, BadgeGroup, Button, Form, Input, Avatar, Breadcrumb, MarkdownRenderer, PhotoWithFallback } from '../elements';\nimport { extractTableOfContents } from '../../utils/markdown-toc';\nimport { getAvatarUrl } from '../../utils/photo-helpers';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface ExtendedBlogPost extends BlogPost {\n category?: { name: string };\n reading_time_minutes?: number;\n excerpt?: string;\n tags?: Array<{ name: string } | string>;\n}\n\ninterface TableOfContentsItem {\n id: string;\n title: string;\n level: number;\n}\n\ninterface BlogPostSectionProps {\n blogPost?: ExtendedBlogPost | null;\n}\n\nexport const BlogPostSection = ({\n blogPost,\n}: BlogPostSectionProps) => {\n\n const formatDate = (dateString?: string) => {\n if (!dateString) return 'Recent';\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n day: 'numeric',\n month: 'short',\n year: 'numeric'\n });\n } catch {\n return 'Recent';\n }\n };\n\n // Extract table of contents from markdown\n const tableOfContents = blogPost?.content_markdown \n ? extractTableOfContents(blogPost.content_markdown)\n : [];\n\n const [copied, setCopied] = useState(false);\n\n const handleCopyLink = async () => {\n try {\n await navigator.clipboard.writeText(window.location.href);\n setCopied(true);\n setTimeout(() => setCopied(false), 2000);\n } catch (err) {\n console.error('Failed to copy:', err);\n }\n };\n\n const handleShareLink = () => {\n if (navigator.share) {\n navigator.share({\n title: blogPost?.title,\n url: window.location.href,\n }).catch((err) => {\n console.error('Error sharing:', err);\n });\n } else {\n // Fallback to copy if share is not available\n handleCopyLink();\n }\n };\n\n if (!blogPost) {\n return (\n <div className=\"text-center py-12\">\n <div className=\"text-gray-600 text-6xl mb-4\">📝</div>\n <h3 className=\"text-xl font-semibold text-gray-900 mb-2\">Blog Post Not Found</h3>\n <p className=\"text-gray-600 mb-4\">The blog post you're looking for doesn't exist.</p>\n <Button href=\"/blog\">View All Blog Posts</Button>\n </div>\n );\n }\n\n return (\n <>\n {/* Breadcrumb - top left aligned */}\n <section className=\"bg-primary py-2 md:py-2\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <Breadcrumb \n backHref=\"/blog\" \n backLabel=\"Blog\" \n currentLabel={blogPost.title} \n />\n </div>\n </section>\n\n {/* Blog Post Header with Image */}\n <section className=\"bg-primary py-4 md:py-6\">\n <div className=\"relative mx-auto max-w-container gap-16 px-4 pb-16 md:gap-8 md:px-8 md:pt-16 md:pb-24 grid grid-cols-1 items-center md:grid-cols-2\">\n <div className=\"flex max-w-180 flex-col items-start\">\n <BadgeGroup \n size=\"md\" \n addonText={blogPost.category?.name || \"Blog\"} \n color=\"brand\" \n theme=\"modern\" \n className=\"pr-3 mt-4\" \n iconTrailing={null}\n >\n {blogPost.reading_time_minutes \n ? `${blogPost.reading_time_minutes} min read` \n : (blogPost.published_at ? formatDate(blogPost.published_at) : 'Recent')}\n </BadgeGroup>\n \n <h1 className=\"mt-4 text-display-md font-semibold text-primary md:text-display-lg\">\n {blogPost.title}\n </h1>\n {blogPost.excerpt && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-6 md:max-w-120 md:text-xl\">\n {(blogPost.excerpt || blogPost.excerpt_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '').replace(/[#*\\[\\]()]/g, '').trim()}\n </p>\n )}\n </div>\n\n {/* Hero Image - Always show with fallback support */}\n <PhotoWithFallback\n item={blogPost}\n fallbackId={blogPost.id}\n alt={blogPost.title}\n className=\"order-first -ml-4 h-36 w-screen max-w-none object-cover md:order-1 md:ml-0 md:h-96 md:w-full md:max-w-full rounded-2xl\"\n />\n </div>\n\n {/* Content Section with Sidebar */}\n {blogPost.content_markdown && (\n <div className=\"mx-auto max-w-container px-4 pb-16 md:px-8 md:pb-24\">\n <div className=\"mx-auto flex justify-center gap-16\">\n {/* Left sidebar - hidden on mobile */}\n <div className=\"hidden w-70 flex-col gap-8 lg:flex\">\n {tableOfContents.length > 0 && (\n <>\n <div className=\"w-full border-t border-secondary\" />\n <div className=\"flex flex-col gap-4\">\n <p className=\"text-md font-semibold text-brand-secondary\">Table of contents</p>\n <ul className=\"flex flex-col gap-3\">\n {tableOfContents.map((item: TableOfContentsItem) => (\n <li key={item.id}>\n <Button \n size=\"lg\" \n color=\"link-gray\" \n href={`#${item.id}`}\n className={`${item.level === 3 ? 'pl-4' : ''} w-full text-left whitespace-normal justify-start`}\n >\n <span className=\"break-words block w-full\">{item.title}</span>\n </Button>\n </li>\n ))}\n </ul>\n </div>\n <div className=\"w-full border-t border-secondary\" />\n </>\n )}\n {blogPost.blog_post_authors && Array.isArray(blogPost.blog_post_authors) && blogPost.blog_post_authors.length > 0 && (\n <div className=\"flex flex-col gap-6\">\n <p className=\"text-md font-semibold text-brand-secondary\">Author</p>\n <div className=\"flex items-center gap-3\">\n {(() => {\n const author = blogPost.blog_post_authors[0];\n const authorName = author?.name || 'Author';\n const authorAvatarUrl = getAvatarUrl(author?.photo_attachments, author?.id, authorName);\n return (\n <>\n <Avatar\n src={authorAvatarUrl ?? undefined}\n alt={authorName}\n initials={authorName.trim().charAt(0).toUpperCase() || '?'}\n size=\"md\"\n />\n <div>\n <p className=\"text-md font-semibold text-primary\">{authorName}</p>\n {author?.bio_markdown && (\n <p className=\"text-md text-tertiary\">{author.bio_markdown.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 100)}</p>\n )}\n </div>\n </>\n );\n })()}\n </div>\n </div>\n )}\n <div className=\"w-full border-t border-secondary\" />\n <Form\n onSubmit={(e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n const formData = new FormData(e.currentTarget);\n console.log(\"Form data:\", formData);\n }}\n className=\"flex flex-col gap-4\"\n >\n <label htmlFor=\"blog-email-input\" className=\"text-md font-semibold text-brand-secondary\">\n Subscribe to our newsletter\n </label>\n <Input isRequired id=\"blog-email-input\" name=\"email\" type=\"email\" placeholder=\"Enter your email\" size=\"md\" />\n <Button type=\"submit\" size=\"xl\">\n Subscribe\n </Button>\n </Form>\n <div className=\"w-full border-t border-secondary\" />\n <div className=\"flex gap-3\">\n <button\n onClick={handleShareLink}\n title=\"Share link\"\n className=\"inline-flex h-max cursor-pointer items-center justify-center gap-1.5 rounded-lg px-3.5 py-2.5 text-sm font-semibold outline-brand transition duration-100 ease-linear focus-visible:outline-2 focus-visible:outline-offset-2 bg-secondary text-primary hover:bg-secondary_hover\"\n >\n <Link01 className=\"size-5 shrink-0\" />\n </button>\n <button\n onClick={handleCopyLink}\n title={copied ? \"Copied!\" : \"Copy link\"}\n className=\"inline-flex h-max cursor-pointer items-center justify-center gap-1.5 rounded-lg px-3.5 py-2.5 text-sm font-semibold outline-brand transition duration-100 ease-linear focus-visible:outline-2 focus-visible:outline-offset-2 bg-secondary text-fg-quaternary hover:bg-secondary_hover\"\n >\n <Copy01 className=\"size-5 shrink-0\" />\n </button>\n </div>\n </div>\n\n {/* Main content */}\n <div className=\"max-w-prose lg:max-w-180\">\n <div className=\"prose-centered-quote mx-auto prose md:prose-lg\" id=\"content\">\n <MarkdownRenderer content={blogPost.content_markdown || ''} />\n </div>\n\n {/* Mobile-only contributors and social */}\n <div className=\"flex flex-col items-start justify-between gap-y-8 lg:hidden lg:flex-row mt-8\">\n {blogPost.blog_post_authors && Array.isArray(blogPost.blog_post_authors) && blogPost.blog_post_authors.length > 0 && (\n <div className=\"flex flex-col gap-6\">\n <p className=\"text-md font-semibold text-brand-secondary\">Author</p>\n <div className=\"flex items-center gap-3\">\n {(() => {\n const author = blogPost.blog_post_authors[0];\n const authorName = author?.name || 'Author';\n const authorAvatarUrl = getAvatarUrl(author?.photo_attachments, author?.id, authorName);\n return (\n <>\n <Avatar\n src={authorAvatarUrl ?? undefined}\n alt={authorName}\n initials={authorName.trim().charAt(0).toUpperCase() || '?'}\n size=\"md\"\n />\n <div>\n <p className=\"text-md font-semibold text-primary\">{authorName}</p>\n {author?.bio_markdown && (\n <p className=\"text-md text-tertiary\">{author.bio_markdown.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 100)}</p>\n )}\n </div>\n </>\n );\n })()}\n </div>\n </div>\n )}\n <div className=\"flex gap-3\">\n <button\n onClick={handleShareLink}\n title=\"Share link\"\n className=\"inline-flex h-max cursor-pointer items-center justify-center gap-1.5 rounded-lg px-3.5 py-2.5 text-sm font-semibold outline-brand transition duration-100 ease-linear focus-visible:outline-2 focus-visible:outline-offset-2 bg-secondary text-primary hover:bg-secondary_hover\"\n >\n <Link01 className=\"size-5 shrink-0\" />\n </button>\n <button\n onClick={handleCopyLink}\n title={copied ? \"Copied!\" : \"Copy link\"}\n className=\"inline-flex h-max cursor-pointer items-center justify-center gap-1.5 rounded-lg px-3.5 py-2.5 text-sm font-semibold outline-brand transition duration-100 ease-linear focus-visible:outline-2 focus-visible:outline-offset-2 bg-secondary text-fg-quaternary hover:bg-secondary_hover\"\n >\n <Copy01 className=\"size-5 shrink-0\" />\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n )}\n </section>\n\n {/* Navigation */}\n <section className=\"bg-primary pb-16 md:pb-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto max-w-prose md:max-w-180\">\n <div className=\"flex flex-col gap-4 sm:flex-row sm:items-center sm:justify-end border-t border-secondary pt-8\">\n {blogPost.tags && Array.isArray(blogPost.tags) && blogPost.tags.length > 0 && (\n <div className=\"flex flex-wrap gap-2\">\n {blogPost.tags.map((tag, index: number) => (\n <Badge key={index} color=\"gray\" size=\"md\" type=\"modern\">\n {typeof tag === 'string' ? tag : tag.name}\n </Badge>\n ))}\n </div>\n )}\n </div>\n </div>\n </div>\n </section>\n </>\n );\n};\n","/**\n * Utility functions for extracting table of contents from markdown\n */\n\nexport interface TableOfContentsItem {\n id: string;\n title: string;\n level: number;\n}\n\n/**\n * Generate a URL-friendly ID from a heading text\n */\nfunction slugify(text: string): string {\n return text\n .toLowerCase()\n .trim()\n .replace(/[^\\w\\s-]/g, '') // Remove special characters\n .replace(/[\\s_-]+/g, '-') // Replace spaces and underscores with hyphens\n .replace(/^-+|-+$/g, ''); // Remove leading/trailing hyphens\n}\n\n/**\n * Extract headings from markdown content and generate table of contents\n */\nexport function extractTableOfContents(markdown: string): TableOfContentsItem[] {\n if (!markdown) return [];\n\n const toc: TableOfContentsItem[] = [];\n const lines = markdown.split('\\n');\n\n for (const line of lines) {\n // Match markdown headings (##, ###, etc.)\n const headingMatch = line.match(/^(#{1,6})\\s+(.+)$/);\n if (headingMatch) {\n const level = headingMatch[1].length;\n const title = headingMatch[2].trim();\n \n // Only include h2 and h3 headings in TOC\n if (level >= 2 && level <= 3) {\n const id = slugify(title);\n toc.push({\n id,\n title,\n level,\n });\n }\n }\n }\n\n return toc;\n}\n\n\n","import ContactSection from \"./contact-section\";\nimport type { WebsitePhotos } from '../../types/api/website-photos';\n\ninterface ContactHomeProps {\n websitePhotos?: WebsitePhotos | null;\n title?: string;\n subtitle?: string;\n}\n\nexport const ContactHome = ({\n websitePhotos,\n title = \"\",\n subtitle = \"\",\n}: ContactHomeProps) => {\n return (\n <ContactSection\n websitePhotos={websitePhotos}\n title={title}\n subtitle={subtitle}\n />\n );\n};\n\n\n","import React from 'react';\nimport { Button } from '../elements';\nimport type { FaqQuestion } from '../../types/api/faq';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport { resolveCtaUrls, isExternalCtaUrl } from '../../lib/cta-urls';\n\ninterface FAQGridProps {\n faqs?: FaqQuestion[] | null;\n companyInformation?: CompanyInformation | null;\n title?: string;\n subtitle?: string;\n ctaTitle?: string;\n ctaSubtitle?: string;\n ctaButtonText?: string;\n /** Optional route override for the CTA button. When not set, uses primary CTA URL (booking or /contact) from company info. */\n ctaButtonHref?: string;\n backgroundColor?: string;\n className?: string;\n}\n\n// Simple markdown renderer - converts basic markdown to HTML\nconst renderMarkdown = (content: string) => {\n let html = content.replace(/\\[([^\\]]+)\\]\\(([^)]+)\\)/g, '<a href=\"$2\" class=\"text-brand-secondary underline\">$1</a>');\n html = html.replace(/\\*\\*([^*]+)\\*\\*/g, '<strong>$1</strong>');\n html = html.replace(/__([^_]+)__/g, '<strong>$1</strong>');\n html = html.replace(/\\*([^*]+)\\*/g, '<em>$1</em>');\n html = html.replace(/_([^_]+)_/g, '<em>$1</em>');\n html = html.replace(/\\n/g, '<br />');\n return html;\n};\n\nexport const FAQGrid = ({\n faqs: faqsData,\n companyInformation,\n title = \"\",\n subtitle = \"\",\n ctaTitle = \"\",\n ctaSubtitle = \"\",\n ctaButtonText = \"\",\n ctaButtonHref,\n backgroundColor = \"bg-primary\",\n className = \"\",\n}: FAQGridProps) => {\n const faqs = Array.isArray(faqsData) ? faqsData : [];\n const resolved = companyInformation ? resolveCtaUrls(companyInformation) : null;\n const effectiveCtaButtonHref = ctaButtonHref ?? resolved?.primaryHref ?? '/contact';\n \n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`} id=\"faq\">\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n <div className=\"flex w-full max-w-3xl flex-col\">\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n\n {faqs.length > 0 && (\n <div className=\"mt-12 md:mt-16\">\n <dl className=\"grid w-full grid-cols-1 gap-x-8 gap-y-10 sm:grid-cols-2 md:gap-y-16 lg:grid-cols-3\">\n {faqs.map((faq: FaqQuestion, index: number) => {\n const answerContent = faq.answer_markdown || '';\n const answerHtml = renderMarkdown(answerContent);\n \n return (\n <div key={faq.id || index}>\n <div className=\"flex max-w-sm flex-col\">\n <dt className=\"text-md font-semibold text-primary\">{faq.question}</dt>\n <dd \n className=\"mt-1 text-md text-tertiary\"\n dangerouslySetInnerHTML={{ __html: answerHtml }}\n />\n </div>\n </div>\n );\n })}\n </dl>\n </div>\n )}\n\n {(ctaTitle || ctaSubtitle || ctaButtonText) && (\n <div className=\"mt-12 flex flex-col items-start justify-between gap-6 rounded-2xl bg-secondary px-5 py-8 md:mt-16 md:flex-row md:gap-8 md:p-8\">\n <div className=\"w-full max-w-3xl\">\n {ctaTitle && (\n <h4 className=\"text-xl font-semibold text-primary\">{ctaTitle}</h4>\n )}\n {ctaSubtitle && (\n <p className=\"mt-2 text-md text-tertiary md:text-lg\">\n {ctaSubtitle}\n </p>\n )}\n </div>\n {ctaButtonText && (\n <Button \n size=\"xl\" \n href={effectiveCtaButtonHref}\n target={isExternalCtaUrl(effectiveCtaButtonHref) ? '_blank' : undefined}\n rel={isExternalCtaUrl(effectiveCtaButtonHref) ? 'noopener noreferrer' : undefined}\n >\n {ctaButtonText}\n </Button>\n )}\n </div>\n )}\n </div>\n </section>\n );\n};\n","import { SearchLg } from '@untitledui/icons';\nimport { Input } from '../elements';\n\ninterface FAQHeroProps {\n title?: string;\n subtitle?: string;\n label?: string;\n // Optional search props\n searchTerm?: string;\n onSearchChange?: (value: string) => void;\n}\n\nexport const FAQHero = ({\n title = \"\",\n subtitle = \"\",\n label = \"\",\n searchTerm,\n onSearchChange,\n}: FAQHeroProps) => {\n const headline = title;\n const subhead = subtitle;\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n <span className=\"text-sm font-semibold text-brand-secondary md:text-md\">{label}</span>\n <h1 className=\"mt-3 text-display-md font-semibold text-primary md:text-display-lg\">\n {headline}\n </h1>\n <p className=\"mt-4 text-lg text-tertiary md:mt-6 md:text-xl\">\n {subhead}\n </p>\n {onSearchChange && (\n <div className=\"mt-8 w-full sm:mt-12 sm:w-80\">\n <Input \n size=\"md\" \n type=\"search\" \n placeholder=\"Search\" \n icon={SearchLg} \n wrapperClassName=\"sm:py-0.5\"\n value={searchTerm || ''}\n onChange={onSearchChange}\n />\n </div>\n )}\n </div>\n </div>\n </section>\n );\n};\n\n\n","\ninterface GenericTextHeroProps {\n title?: string;\n subtitle?: string;\n label?: string;\n}\n\nexport const GenericTextHero = ({\n title = \"\",\n subtitle = \"\",\n label,\n}: GenericTextHeroProps) => {\n // Don't render if there's no content\n if (!title && !subtitle && !label) {\n return null;\n }\n \n const headline = title;\n const subhead = subtitle;\n \n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n {label && (\n <span className=\"text-sm font-semibold text-brand-secondary md:text-md\">{label}</span>\n )}\n {headline && (\n <h1 className={`${label ? 'mt-3' : ''} text-display-md font-semibold text-primary md:text-display-lg`}>\n {headline}\n </h1>\n )}\n {subhead && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-6 md:text-xl\">\n {subhead}\n </p>\n )}\n </div>\n </div>\n </section>\n );\n};\n\n\n","import { ChevronLeft } from \"@untitledui/icons\";\nimport { Button } from '../elements';\nimport type { Location } from '../../types/api/location';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport { resolveCtaUrls, isExternalCtaUrl } from '../../lib/cta-urls';\n\ninterface LocationDetailHeroProps {\n location?: Location | null;\n companyInformation?: CompanyInformation | null;\n /** Optional route override for the CTA. When not set, uses primary CTA URL (booking or /contact) from company info. */\n ctaHrefOverride?: string;\n}\n\nexport const LocationDetailHero = ({\n location,\n companyInformation,\n ctaHrefOverride,\n}: LocationDetailHeroProps) => {\n if (!location) return null;\n\n const resolved = companyInformation ? resolveCtaUrls(companyInformation) : null;\n const ctaHref = ctaHrefOverride ?? resolved?.primaryHref ?? '/contact';\n\n const breadcrumb = {\n backHref: \"/locations\",\n backLabel: \"Locations\",\n currentLabel: location.name || \"Location\",\n };\n \n const headline = location.name || \"Location\";\n const subhead = location.description_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || \"\";\n const ctaText = \"Book Now\";\n \n return (\n <section className=\"bg-primary py-4 md:py-6\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {breadcrumb && (\n <div className=\"mb-8\">\n <nav aria-label=\"Breadcrumb\">\n <div className=\"flex items-center gap-2\">\n <Button \n color=\"link-gray\" \n size=\"md\" \n href={breadcrumb.backHref}\n iconLeading={ChevronLeft}\n className=\"text-tertiary hover:text-primary\"\n >\n {breadcrumb.backLabel}\n </Button>\n <span className=\"text-tertiary\">/</span>\n <span className=\"text-primary font-medium\">{breadcrumb.currentLabel}</span>\n </div>\n </nav>\n </div>\n )}\n \n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n <h1 className=\"text-display-md font-semibold text-primary md:text-display-lg\">\n {headline}\n </h1>\n\n <p className=\"mt-4 text-lg text-tertiary md:mt-6 md:text-xl\">\n {subhead}\n </p>\n\n <div className=\"mt-8\">\n <Button\n size=\"xl\"\n href={ctaHref}\n target={isExternalCtaUrl(ctaHref) ? '_blank' : undefined}\n rel={isExternalCtaUrl(ctaHref) ? 'noopener noreferrer' : undefined}\n >\n {ctaText}\n </Button>\n </div>\n </div>\n </div>\n </section>\n );\n};\n","import { ChevronLeft } from \"@untitledui/icons\";\nimport { Button } from '../elements';\nimport type { Service } from '../../types/api/service';\n\ninterface ServiceDetailHeroProps {\n service?: Service | null;\n}\n\nexport const ServiceDetailHero = ({\n service,\n}: ServiceDetailHeroProps) => {\n if (!service) return null;\n\n // Build breadcrumb from service data\n const breadcrumb = {\n backHref: \"/services\",\n backLabel: \"Services\",\n currentLabel: service.name || \"Service\",\n };\n\n return (\n <section className=\"bg-primary py-4 md:py-6\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Breadcrumb - top left aligned */}\n <div className=\"mb-8\">\n <nav aria-label=\"Breadcrumb\">\n <div className=\"flex items-center gap-2\">\n <Button \n color=\"link-gray\" \n size=\"md\" \n href={breadcrumb.backHref}\n iconLeading={ChevronLeft}\n className=\"text-tertiary hover:text-primary\"\n >\n {breadcrumb.backLabel}\n </Button>\n <span className=\"text-tertiary\">/</span>\n <span className=\"text-primary font-medium\">{breadcrumb.currentLabel}</span>\n </div>\n </nav>\n </div>\n </div>\n </section>\n );\n};\n","\ninterface SocialMediaHeroProps {\n label?: string;\n title?: string;\n subtitle?: string;\n}\n\nexport const SocialMediaHero = ({\n label = \"\",\n title = \"\",\n subtitle = \"\",\n}: SocialMediaHeroProps) => {\n const headline = title;\n const subhead = subtitle;\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n <span className=\"text-sm font-semibold text-brand-secondary md:text-md\">{label}</span>\n <h1 className=\"mt-3 text-display-md font-semibold text-primary md:text-display-lg\">\n {headline}\n </h1>\n <p className=\"mt-4 text-lg text-tertiary md:mt-6 md:text-xl\">\n {subhead}\n </p>\n </div>\n </div>\n </section>\n );\n};\n\n\n","import { SearchLg } from '@untitledui/icons';\nimport { Input } from '../elements';\n\ninterface TestimonialsHeroProps {\n title?: string;\n subtitle?: string;\n label?: string;\n // Optional search props\n searchTerm?: string;\n onSearchChange?: (value: string) => void;\n}\n\nexport const TestimonialsHero = ({\n title = \"\",\n subtitle = \"\",\n label = \"\",\n searchTerm,\n onSearchChange,\n}: TestimonialsHeroProps) => {\n const headline = title;\n const subhead = subtitle;\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n <span className=\"text-sm font-semibold text-brand-secondary md:text-md\">{label}</span>\n <h1 className=\"mt-3 text-display-md font-semibold text-primary md:text-display-lg\">\n {headline}\n </h1>\n <p className=\"mt-4 text-lg text-tertiary md:mt-6 md:text-xl\">\n {subhead}\n </p>\n {onSearchChange && (\n <div className=\"mt-8 w-full sm:mt-12 sm:w-80\">\n <Input \n size=\"md\" \n type=\"search\" \n placeholder=\"Search testimonials\" \n icon={SearchLg} \n wrapperClassName=\"sm:py-0.5\"\n value={searchTerm || ''}\n onChange={onSearchChange}\n />\n </div>\n )}\n </div>\n </div>\n </section>\n );\n};\n\n\n","import { Fragment } from \"react\";\nimport Image from \"next/image\";\nimport { Button, Form, Input } from '../elements';\nimport { cx } from '../../utils/cx';\nimport IconComponent from '../elements/IconComponent';\nimport { getGradientUrl } from '../../utils/gradient-placeholder';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\n\ninterface HomeHeroComponentProps {\n headline: string;\n subhead: string;\n email_signup?: {\n placeholder?: string;\n button_text?: string;\n privacy_policy_link?: string;\n };\n reviews?: {\n rating?: number;\n count?: number;\n avatars?: Array<{\n url: string;\n alt: string;\n }>;\n };\n statistics?: Array<{\n number: string;\n label: string;\n icon: string;\n color: string;\n }>;\n onEmailSubmit?: (email: string) => void;\n websitePhotos?: WebsitePhotos | null;\n}\n\n// Default avatars use inline gradient (no external request); real sites pass avatars from API/mock data.\nconst DEFAULT_AVATARS = [1, 2, 3, 4, 5].map((i) => ({\n url: getGradientUrl(`hero-avatar-${i}`),\n alt: `Avatar ${i}`,\n}));\n\nconst AvatarsWithReview = ({ \n count = 200, \n avatars = DEFAULT_AVATARS,\n className \n}: { \n count?: number; \n avatars?: Array<{ url: string; alt: string }>;\n className?: string;\n}) => {\n return (\n <div className={cx(\"flex items-center gap-4\", className)}>\n <div className=\"inline-flex -space-x-3 overflow-hidden\">\n {avatars.map((avatar, index) => (\n <Image\n key={index}\n className=\"inline-block size-10 rounded-full ring-[1.5px] ring-bg-primary outline-1 -outline-offset-1 outline-avatar-contrast-border\"\n src={avatar.url}\n alt={avatar.alt}\n width={40}\n height={40}\n />\n ))}\n </div>\n <div className=\"flex flex-col gap-0.5\">\n <div className=\"flex items-center gap-2\">\n <div className=\"flex items-center gap-1\">\n {Array(5)\n .fill(null)\n .map((_, index) => {\n const clipId0 = `clip0_star_${index}`;\n const clipId1 = `clip1_star_${index}`;\n return (\n <svg\n key={index}\n width={20}\n height={20}\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n className=\"relative size-5 shrink-0 grow-0\"\n preserveAspectRatio=\"none\"\n >\n <g clipPath={`url(#${clipId0})`}>\n <path\n d=\"M9.53834 1.60996C9.70914 1.19932 10.2909 1.19932 10.4617 1.60996L12.5278 6.57744C12.5998 6.75056 12.7626 6.86885 12.9495 6.88383L18.3123 7.31376C18.7556 7.3493 18.9354 7.90256 18.5976 8.19189L14.5117 11.6919C14.3693 11.8139 14.3071 12.0053 14.3506 12.1876L15.5989 17.4208C15.7021 17.8534 15.2315 18.1954 14.8519 17.9635L10.2606 15.1592C10.1006 15.0615 9.89938 15.0615 9.73937 15.1592L5.14806 17.9635C4.76851 18.1954 4.29788 17.8534 4.40108 17.4208L5.64939 12.1876C5.69289 12.0053 5.6307 11.8139 5.48831 11.6919L1.40241 8.19189C1.06464 7.90256 1.24441 7.3493 1.68773 7.31376L7.05054 6.88383C7.23744 6.86885 7.40024 6.75056 7.47225 6.57744L9.53834 1.60996Z\"\n className=\"fill-bg-tertiary\"\n />\n <g clipPath={`url(#${clipId1})`}>\n <path\n d=\"M9.53834 1.60996C9.70914 1.19932 10.2909 1.19932 10.4617 1.60996L12.5278 6.57744C12.5998 6.75056 12.7626 6.86885 12.9495 6.88383L18.3123 7.31376C18.7556 7.3493 18.9354 7.90256 18.5976 8.19189L14.5117 11.6919C14.3693 11.8139 14.3071 12.0053 14.3506 12.1876L15.5989 17.4208C15.7021 17.8534 15.2315 18.1954 14.8519 17.9635L10.2606 15.1592C10.1006 15.0615 9.89938 15.0615 9.73937 15.1592L5.14806 17.9635C4.76851 18.1954 4.29788 17.8534 4.40108 17.4208L5.64939 12.1876C5.69289 12.0053 5.6307 11.8139 5.48831 11.6919L1.40241 8.19189C1.06464 7.90256 1.24441 7.3493 1.68773 7.31376L7.05054 6.88383C7.23744 6.86885 7.40024 6.75056 7.47225 6.57744L9.53834 1.60996Z\"\n className=\"fill-warning-300\"\n />\n </g>\n </g>\n <defs>\n <clipPath id={clipId0}>\n <rect width={20} height={20} fill=\"white\" />\n </clipPath>\n <clipPath id={clipId1}>\n <rect width={20} height={20} fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n );\n })}\n </div>\n </div>\n <p className=\"text-md font-medium text-tertiary\">from {count}+ reviews</p>\n </div>\n </div>\n );\n};\n\nexport const HomeHeroComponent = ({\n headline,\n subhead,\n email_signup,\n reviews,\n statistics,\n onEmailSubmit,\n websitePhotos,\n}: HomeHeroComponentProps) => {\n // Get hero image from website photos prop\n const heroImage = websitePhotos?.hero ? {\n url: websitePhotos.hero.url,\n alt: websitePhotos.hero.alt\n } : null;\n \n return (\n <Fragment>\n <section className=\"bg-primary py-16 md:pb-24\">\n <div className=\"mx-auto grid max-w-container grid-cols-1 items-center gap-16 px-4 md:px-8 lg:grid-cols-2 lg:gap-8\">\n <div className=\"flex max-w-3xl flex-col items-start lg:pr-8\">\n <h1 className=\"text-display-md font-semibold text-primary md:text-display-lg lg:text-display-xl\">\n {headline}\n </h1>\n <p className=\"mt-4 max-w-lg text-lg text-balance text-tertiary md:mt-6 md:text-xl\">\n {subhead}\n </p>\n\n {email_signup && (\n <Form\n onSubmit={(e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n const formData = new FormData(e.currentTarget);\n const email = formData.get(\"email\") as string;\n if (onEmailSubmit) {\n onEmailSubmit(email);\n } else {\n console.log(\"Email signup:\", email);\n }\n }}\n className=\"mt-8 flex w-full flex-col items-stretch gap-4 md:mt-12 md:max-w-120 md:flex-row md:items-start\"\n >\n <Input\n isRequired\n size=\"md\"\n name=\"email\"\n type=\"email\"\n placeholder={email_signup.placeholder || \"Enter your email\"}\n wrapperClassName=\"py-0.5\"\n hint={\n <span>\n We care about your data in our{\" \"}\n <a\n href={email_signup.privacy_policy_link || \"#\"}\n className=\"rounded-xs underline underline-offset-3 outline-focus-ring focus-visible:outline-2 focus-visible:outline-offset-2\"\n >\n privacy policy\n </a>\n .\n </span>\n }\n />\n <Button type=\"submit\" color=\"primary\" size=\"xl\">\n {email_signup.button_text || \"Get started\"}\n </Button>\n </Form>\n )}\n\n <AvatarsWithReview \n count={reviews?.count}\n avatars={reviews?.avatars}\n className=\"mt-8 md:mt-12\"\n />\n\n {/* Statistics in 2x2 grid */}\n {statistics && statistics.length > 0 && (\n <dl className=\"mt-8 grid grid-cols-2 gap-x-6 gap-y-4 md:mt-12\">\n {statistics.slice(0, 4).map((stat, index) => {\n const IconWrapper = ({ className }: { className?: string }) => (\n <div className={className}>\n <IconComponent \n icon={stat.icon} \n color={stat.color || 'blue'}\n className=\"w-full h-full\"\n />\n </div>\n );\n \n return (\n <div key={index} className=\"flex flex-col gap-2\">\n <div className=\"flex items-center gap-2\">\n <IconWrapper className=\"size-5 shrink-0\" />\n <dd className=\"text-lg font-semibold text-primary md:text-xl\">{stat.number}</dd>\n </div>\n <dt className=\"text-sm font-medium text-tertiary md:text-md\">{stat.label}</dt>\n </div>\n );\n })}\n </dl>\n )}\n </div>\n\n {heroImage && heroImage.url && (\n <div className=\"relative lg:h-full lg:min-h-160\">\n <Image\n className=\"inset-0 h-70 w-full object-cover md:h-110 lg:absolute lg:h-full\"\n src={heroImage.url}\n alt={heroImage.alt}\n width={1200}\n height={800}\n />\n </div>\n )}\n </div>\n </section>\n </Fragment>\n );\n};\n","import React from 'react';\n\ninterface IconComponentProps {\n icon: string;\n color?: string;\n className?: string;\n}\n\nconst IconComponent = ({ icon, color = 'blue', className = '' }: IconComponentProps) => {\n const getIconColor = (colorName: string) => {\n switch (colorName) {\n case 'blue':\n return 'text-blue-600';\n case 'green':\n return 'text-green-600';\n case 'red':\n return 'text-red-600';\n case 'yellow':\n return 'text-yellow-600';\n case 'purple':\n return 'text-purple-600';\n case 'gray':\n return 'text-gray-600';\n case 'white':\n return 'text-white';\n default:\n return 'text-blue-600';\n }\n };\n\n const renderIcon = () => {\n switch (icon) {\n case 'star':\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371 1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54 1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1 1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z\"/>\n </svg>\n );\n case 'heart':\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path fillRule=\"evenodd\" d=\"M3.172 5.172a4 4 0 015.656 0L10 6.343l1.172-1.171a4 4 0 115.656 5.656L10 17.657l-6.828-6.829a4 4 0 010-5.656z\" clipRule=\"evenodd\"/>\n </svg>\n );\n case 'home':\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M10.707 2.293a1 1 0 00-1.414 0l-7 7a1 1 0 001.414 1.414L4 10.414V17a1 1 0 001 1h2a1 1 0 001-1v-2a1 1 0 011-1h2a1 1 0 011 1v2a1 1 0 001 1h2a1 1 0 001-1v-6.586l.293.293a1 1 0 001.414-1.414l-7-7z\"/>\n </svg>\n );\n case 'person':\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path fillRule=\"evenodd\" d=\"M10 9a3 3 0 100-6 3 3 0 000 6zm-7 9a7 7 0 1114 0H3z\" clipRule=\"evenodd\"/>\n </svg>\n );\n case 'phone':\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M2 3a1 1 0 011-1h2.153a1 1 0 01.986.836l.74 4.435a1 1 0 01-.01 1.01l-.804 1.646a1 1 0 00.01 1.01l.74 4.435a1 1 0 01-.986.836H3a1 1 0 01-1-1V3z\"/>\n </svg>\n );\n case 'email':\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path d=\"M2.003 5.884L10 9.882l7.997-3.998A2 2 0 0016 4H4a2 2 0 00-1.997 1.884z\"/>\n <path d=\"M18 8.118l-8 4-8-4V14a2 2 0 002 2h12a2 2 0 002-2V8.118z\"/>\n </svg>\n );\n case 'location':\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path fillRule=\"evenodd\" d=\"M5.05 4.05a7 7 0 119.9 9.9L10 18.9l-4.95-4.95a7 7 0 010-9.9zM10 11a2 2 0 100-4 2 2 0 000 4z\" clipRule=\"evenodd\"/>\n </svg>\n );\n case 'clock':\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path fillRule=\"evenodd\" d=\"M10 18a8 8 0 100-16 8 8 0 000 16zm1-12a1 1 0 10-2 0v4a1 1 0 00.293.707l2.828 2.829a1 1 0 101.415-1.415L11 9.586V6z\" clipRule=\"evenodd\"/>\n </svg>\n );\n default:\n return (\n <svg className={`w-full h-full ${getIconColor(color)}`} fill=\"currentColor\" viewBox=\"0 0 20 20\">\n <path fillRule=\"evenodd\" d=\"M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7-4a1 1 0 11-2 0 1 1 0 012 0zM9 9a1 1 0 000 2v3a1 1 0 001 1h1a1 1 0 100-2v-3a1 1 0 00-1-1H9z\" clipRule=\"evenodd\"/>\n </svg>\n );\n }\n };\n\n return (\n <div className={className}>\n {renderIcon()}\n </div>\n );\n};\n\nexport default IconComponent;\n","import { ChevronLeft, MarkerPin02, Briefcase01, CurrencyDollarCircle } from \"@untitledui/icons\";\nimport { Button } from '../elements';\nimport type { JobPosting } from '../../types/api/job-posting';\n\ninterface JobDetailHeroProps {\n job?: JobPosting | null;\n}\n\nexport const JobDetailHero = ({\n job,\n}: JobDetailHeroProps) => {\n if (!job) return null;\n\n const breadcrumb = {\n backHref: \"/about/careers\",\n backLabel: \"Careers\",\n currentLabel: job.title || \"Job\",\n };\n\n return (\n <section className=\"bg-primary py-4 md:py-6\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Breadcrumb */}\n <div className=\"mb-8\">\n <nav aria-label=\"Breadcrumb\">\n <div className=\"flex items-center gap-2\">\n <Button \n color=\"link-gray\" \n size=\"md\" \n href={breadcrumb.backHref}\n iconLeading={ChevronLeft}\n className=\"text-tertiary hover:text-primary\"\n >\n {breadcrumb.backLabel}\n </Button>\n <span className=\"text-tertiary\">/</span>\n <span className=\"text-primary font-medium\">{breadcrumb.currentLabel}</span>\n </div>\n </nav>\n </div>\n\n {/* Job Header */}\n <div className=\"flex flex-col gap-6\">\n <div className=\"flex flex-col gap-4\">\n <h1 className=\"text-display-md font-semibold text-primary md:text-display-lg\">\n {job.title}\n </h1>\n \n <div className=\"flex flex-wrap items-center gap-4 text-sm text-secondary\">\n {job.location && (\n <div className=\"flex items-center gap-1.5\">\n <MarkerPin02 className=\"h-4 w-4\" />\n <span>{job.location}</span>\n </div>\n )}\n {job.employment_type && (\n <div className=\"flex items-center gap-1.5\">\n <Briefcase01 className=\"h-4 w-4\" />\n <span>{job.employment_type}</span>\n </div>\n )}\n {job.salary_range && (\n <div className=\"flex items-center gap-1.5\">\n <CurrencyDollarCircle className=\"h-4 w-4\" />\n <span>{job.salary_range}</span>\n </div>\n )}\n </div>\n </div>\n\n <div>\n <Button \n size=\"xl\" \n color=\"primary\"\n onClick={() => {\n const appForm = document.getElementById('application-form');\n appForm?.scrollIntoView({ behavior: 'smooth', block: 'start' });\n }}\n >\n Apply Now\n </Button>\n </div>\n </div>\n </div>\n </section>\n );\n};\n","\"use client\";\n\nimport React, { useRef, useState } from 'react';\nimport { Form, Button } from '../elements';\nimport { DynamicFormFields } from '../components/DynamicFormFields';\nimport type { FormDefinition } from '../../types/api/form';\nimport { useFormDefinitions } from '../../next/contexts/form-definitions';\nimport { captureEvent } from '../../tracking/captureEvent';\n\ninterface JobApplicationFormProps {\n jobSlug: string;\n /** Form fields are rendered from this definition (required). */\n formDefinition: FormDefinition | null | undefined;\n inline?: boolean;\n}\n\nexport const JobApplicationForm = ({ jobSlug, formDefinition, inline = false }: JobApplicationFormProps) => {\n const { jobApplicationFormDefinition } = useFormDefinitions();\n const resolvedFormDefinition = formDefinition ?? jobApplicationFormDefinition;\n const [isSubmitting, setIsSubmitting] = useState(false);\n const [submitStatus, setSubmitStatus] = useState<'idle' | 'success' | 'error'>('idle');\n const [statusMessage, setStatusMessage] = useState<string>('');\n const formRef = useRef<HTMLFormElement>(null);\n\n const hasFields =\n resolvedFormDefinition != null &&\n Array.isArray(resolvedFormDefinition.fields) &&\n resolvedFormDefinition.fields.length > 0;\n\n const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n setIsSubmitting(true);\n setSubmitStatus('idle');\n setStatusMessage('');\n\n const formData = new FormData(e.currentTarget);\n const data: Record<string, string> = { formType: 'job_application', jobSlug };\n formData.forEach((value, key) => {\n if (key !== 'privacy' && typeof value === 'string') data[key] = value;\n });\n\n try {\n const response = await fetch('/api/form/', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(data),\n });\n const result = await response.json();\n\n if (result.success) {\n setSubmitStatus('success');\n setStatusMessage(result.message || \"Thank you for applying! We'll be in touch soon.\");\n formRef.current?.reset();\n captureEvent('form_submitted', { form_type: 'job_application' });\n setTimeout(() => setSubmitStatus('idle'), 5000);\n } else {\n const errorMsg = result.error || 'Something went wrong. Please try again.';\n setSubmitStatus('error');\n setStatusMessage(errorMsg);\n captureEvent('form_failed', { form_type: 'job_application', error: errorMsg });\n }\n } catch {\n setSubmitStatus('error');\n setStatusMessage('Network error. Please try again.');\n captureEvent('form_failed', { form_type: 'job_application', error: 'network_error' });\n }\n setIsSubmitting(false);\n };\n\n if (!hasFields) return null;\n\n const formContent = (\n <Form ref={formRef} onSubmit={handleSubmit} className=\"flex flex-col gap-6\">\n <DynamicFormFields form={resolvedFormDefinition} jobSlug={jobSlug} />\n {submitStatus === 'success' && (\n <div className=\"rounded-lg bg-success-50 p-4 text-success-700\">{statusMessage}</div>\n )}\n {submitStatus === 'error' && (\n <div className=\"rounded-lg bg-error-50 p-4 text-error-700\">{statusMessage}</div>\n )}\n <Button\n type=\"submit\"\n color=\"primary\"\n size=\"xl\"\n className=\"w-full\"\n isDisabled={isSubmitting}\n isLoading={isSubmitting}\n >\n {isSubmitting ? 'Submitting...' : 'Submit Application'}\n </Button>\n </Form>\n );\n\n if (inline) return formContent;\n\n return (\n <section id=\"application-form\" className=\"bg-primary py-16 md:py-20\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto max-w-2xl\">\n <div className=\"mb-8 text-center\">\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n Apply for this Position\n </h2>\n <p className=\"mt-4 text-lg text-tertiary\">\n Fill out the form below to submit your application\n </p>\n </div>\n {formContent}\n </div>\n </div>\n </section>\n );\n};\n","import { MarkdownRenderer, FormContainer } from '../elements';\nimport type { JobPosting } from '../../types/api/job-posting';\nimport type { FormDefinition } from '../../types/api/form';\nimport { JobApplicationForm } from './job-application-form';\n\ninterface JobDetailSectionProps {\n job?: JobPosting | null;\n /** When provided, application form fields are rendered from this definition. */\n formDefinition?: FormDefinition | null;\n}\n\nexport const JobDetailSection = ({\n job,\n formDefinition,\n}: JobDetailSectionProps) => {\n if (!job) return null;\n\n const sections = [\n { title: 'About the Role', content: job.description_markdown },\n { title: 'Requirements', content: job.requirements_markdown },\n { title: 'Benefits', content: job.benefits_markdown },\n ].filter(section => section.content);\n\n return (\n <section className=\"bg-primary py-16 md:py-20\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"grid grid-cols-1 gap-12 lg:grid-cols-2 lg:gap-16\">\n {/* Left Column: About the Role and Requirements */}\n <div className=\"space-y-12\">\n {sections.map((section, index) => (\n <div key={index} className=\"space-y-4\">\n <h2 className=\"text-display-xs font-semibold text-primary md:text-display-sm\">\n {section.title}\n </h2>\n <div className=\"prose prose-lg max-w-none\">\n <MarkdownRenderer content={section.content} />\n </div>\n </div>\n ))}\n </div>\n\n {/* Right Column: Application Form */}\n <div className=\"lg:sticky lg:top-8 lg:self-start\">\n <FormContainer \n variant=\"default\"\n bordered={true}\n title=\"Apply for this Position\"\n description=\"Fill out the form below to submit your application\"\n >\n <JobApplicationForm jobSlug={job.slug} formDefinition={formDefinition} inline />\n </FormContainer>\n </div>\n </div>\n </div>\n </section>\n );\n};\n","'use client';\n\nimport MarkdownRenderer from '../elements/markdown-renderer/MarkdownRenderer';\n\nexport interface PolicyDocumentSectionProps {\n /** Page title (e.g. \"Terms of Service\" or \"Privacy Policy\") */\n title: string;\n /** Optional effective date string (e.g. \"January 1, 2025\") */\n effectiveDate?: string;\n /** Full markdown content for the policy (supports placeholders replaced before passing in) */\n content: string;\n /** Optional additional class name for the container */\n className?: string;\n}\n\n/**\n * Renders a legal/policy page: title, optional effective date, and markdown body.\n * Content is passed in with all dynamic placeholders already replaced.\n * Businesses can override by providing custom content (e.g. from CMS or overwritten file).\n */\nexport const PolicyDocumentSection = ({\n title,\n effectiveDate,\n content,\n className = '',\n}: PolicyDocumentSectionProps) => {\n return (\n <section className={`py-12 md:py-16 ${className}`}>\n <div className=\"mx-auto max-w-3xl px-4 md:px-8\">\n <header className=\"mb-10 border-b border-gray-200 pb-8\">\n <h1 className=\"font-display text-4xl font-semibold text-gray-900 md:text-5xl\">\n {title}\n </h1>\n {effectiveDate && (\n <p className=\"mt-3 text-sm text-gray-500\">\n Effective Date: {effectiveDate}\n </p>\n )}\n </header>\n <div className=\"prose prose-gray max-w-none text-gray-700\">\n <MarkdownRenderer content={content} />\n </div>\n </div>\n </section>\n );\n};\n","\"use client\";\n\nimport { Fragment, useState } from \"react\";\nimport React from \"react\";\nimport { PhotoWithFallback, VideoModal, VideoPlayButton } from '../elements';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport { resolveCtaUrls, isExternalCtaUrl } from '../../lib/cta-urls';\n\ninterface HeroHomeProps {\n websitePhotos?: WebsitePhotos | null;\n companyInformation?: CompanyInformation | null;\n headline?: string;\n subhead?: string;\n ctaText?: string;\n /** Optional route override for the main CTA. When not set, uses primary CTA URL (booking or /contact) from company info. */\n ctaHref?: string;\n reviews?: { rating: number; count: number };\n onEmailSubmit?: (email: string) => void;\n videoUrl?: string;\n}\n\nexport const HeroHome = ({\n websitePhotos,\n companyInformation,\n headline = \"\",\n subhead = \"\",\n ctaText = \"\",\n ctaHref,\n videoUrl,\n}: HeroHomeProps) => {\n const [showVideo, setShowVideo] = useState(false);\n const resolved = companyInformation ? resolveCtaUrls(companyInformation) : null;\n const effectiveCtaHref = ctaHref ?? resolved?.primaryHref ?? '/contact';\n \n const heroImage = {\n url: websitePhotos?.hero?.url || '',\n alt: websitePhotos?.hero?.alt || 'Hero image',\n };\n\n return (\n <Fragment>\n <section className=\"py-24 md:py-32\">\n <div className=\"mx-auto max-w-4xl px-4 text-center md:px-8\">\n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl lg:text-7xl\">\n {headline}\n </h1>\n \n <p className=\"mt-6 font-body text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subhead}\n </p>\n\n {ctaText && (\n <a\n href={effectiveCtaHref}\n target={isExternalCtaUrl(effectiveCtaHref) ? '_blank' : undefined}\n rel={isExternalCtaUrl(effectiveCtaHref) ? 'noopener noreferrer' : undefined}\n className=\"mt-8 inline-block font-body text-base underline underline-offset-4 hover:no-underline transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n {ctaText}\n </a>\n )}\n </div>\n </section>\n\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"relative w-full h-[400px] md:h-[500px] lg:h-[600px]\">\n <PhotoWithFallback\n photoUrl={heroImage.url}\n photoAlt={heroImage.alt}\n fallbackId=\"hero-home-brand\"\n className=\"w-full h-full object-cover\"\n />\n \n {/* Video play button overlay */}\n {videoUrl && (\n <div className=\"absolute inset-0 flex items-center justify-center\">\n <VideoPlayButton onClick={() => setShowVideo(true)} />\n </div>\n )}\n </div>\n </div>\n </section>\n \n {/* Video modal */}\n {videoUrl && (\n <VideoModal \n isOpen={showVideo}\n onClose={() => setShowVideo(false)}\n videoUrl={videoUrl}\n />\n )}\n </Fragment>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-home', 'aman', HeroHome);\n","\"use client\";\n\nimport React, { useState, useRef, useCallback } from 'react';\nimport Link from 'next/link';\nimport Image from 'next/image';\nimport { usePathname } from 'next/navigation';\nimport { Button } from '../elements';\nimport { cx } from '../../utils/cx';\nimport { getLogoUrl } from '../../utils/photo-helpers';\nimport type { HeaderComponentProps } from './header-navigation';\nimport type { NavItem } from '../../types/config';\nimport { resolveCtaUrls, isExternalCtaUrl, resolvePortalPath } from '../../lib/cta-urls';\n\n// Maximum items to show before \"View All\" link\nconst MAX_DROPDOWN_ITEMS = 3;\n\nexport function HeaderNavigation({ \n props, \n navigation: navigationOverride, \n logoImage: logoImageOverride, \n logoText: logoTextOverride, \n config,\n companyInformation,\n websitePhotos,\n}: HeaderComponentProps) {\n const [activeDropdown, setActiveDropdown] = useState<string | null>(null);\n const [isMobileMenuOpen, setIsMobileMenuOpen] = useState(false);\n const [dropdownTop, setDropdownTop] = useState(0);\n const [isScrolled, setIsScrolled] = useState(false);\n \n // Timeout ref for delayed dropdown closing\n const closeTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n \n // Track scroll position for header animation; close dropdown on scroll to\n // avoid a stale fixed `top` value creating a gap between the nav and dropdown.\n React.useEffect(() => {\n const handleScroll = () => {\n setIsScrolled(window.scrollY > 10);\n setActiveDropdown(null);\n };\n \n window.addEventListener('scroll', handleScroll, { passive: true });\n return () => window.removeEventListener('scroll', handleScroll);\n }, []);\n \n // Cleanup timeout on unmount\n React.useEffect(() => {\n return () => {\n if (closeTimeoutRef.current) {\n clearTimeout(closeTimeoutRef.current);\n }\n };\n }, []);\n \n const logoUrl = logoImageOverride || getLogoUrl(websitePhotos) || props?.logo?.image;\n const companyName = logoTextOverride || companyInformation?.company_name || props?.logo?.text || '';\n \n // Use navigation from config or override\n const navigation = navigationOverride || config?.navigation?.header || [];\n const resolvedCtaUrls = resolveCtaUrls(companyInformation);\n const ctaUrls = {\n primaryHref: props?.cta_button?.secondary_href ?? resolvedCtaUrls.primaryHref,\n secondaryHref: props?.cta_button?.href ?? resolvedCtaUrls.secondaryHref,\n hasSecondary: props?.cta_button?.secondary_href != null || resolvedCtaUrls.hasSecondary,\n };\n\n // Hide the sticky bottom bar when the user is already on the portal page —\n // the portal has its own Book Now tab so the bar is redundant and confusing.\n const pathname = usePathname();\n const portalPath = resolvePortalPath(companyInformation);\n const isPortalPage = portalPath ? pathname?.startsWith(portalPath) : false;\n\n // Cancel any pending close timeout\n const cancelCloseTimeout = useCallback(() => {\n if (closeTimeoutRef.current) {\n clearTimeout(closeTimeoutRef.current);\n closeTimeoutRef.current = null;\n }\n }, []);\n\n // Open dropdown immediately; clear it when hovering a childless item so the\n // previous dropdown doesn't linger while a different top-level item is active.\n const handleMouseEnter = useCallback((item: NavItem, e: React.MouseEvent<HTMLDivElement>) => {\n cancelCloseTimeout();\n if (item.children && item.children.length > 0) {\n const target = e.currentTarget.closest('nav');\n if (target) {\n const rect = target.getBoundingClientRect();\n setDropdownTop(rect.bottom);\n }\n setActiveDropdown(item.label);\n } else {\n setActiveDropdown(null);\n }\n }, [cancelCloseTimeout]);\n\n // Close dropdown with delay (allows moving to dropdown)\n const handleMouseLeave = useCallback(() => {\n cancelCloseTimeout();\n closeTimeoutRef.current = setTimeout(() => {\n setActiveDropdown(null);\n }, 150); // 150ms delay before closing\n }, [cancelCloseTimeout]);\n\n // Keep dropdown open when hovering over it\n const handleDropdownMouseEnter = useCallback(() => {\n cancelCloseTimeout();\n }, [cancelCloseTimeout]);\n\n // Close dropdown when leaving the dropdown area\n const handleDropdownMouseLeave = useCallback(() => {\n handleMouseLeave();\n }, [handleMouseLeave]);\n\n // Get display items for dropdown (limit + \"View All\" if needed)\n const getDropdownItems = (item: NavItem) => {\n const children = item.children || [];\n const isDynamicMenu = item.label === 'Services' || item.label === 'Locations';\n \n if (isDynamicMenu && children.length > MAX_DROPDOWN_ITEMS + 1) {\n // Show first MAX_DROPDOWN_ITEMS items + \"View All\" link\n const displayItems = children.slice(0, MAX_DROPDOWN_ITEMS);\n const viewAllHref = item.label === 'Services' ? '/services' : '/locations';\n return {\n items: displayItems,\n showViewAll: true,\n viewAllHref,\n viewAllLabel: `View All ${item.label}`,\n };\n }\n \n return {\n items: children,\n showViewAll: false,\n viewAllHref: '',\n viewAllLabel: '',\n };\n };\n\n return (\n <>\n {/* Desktop Header */}\n <header className=\"hidden md:block sticky top-0 z-50 bg-primary border-b border-secondary transition-all duration-300\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Top Row: Logo (left), Company Name (center), Contact Button (right) */}\n <div className={cx(\n \"relative flex items-center justify-between transition-all duration-300\",\n isScrolled ? \"py-2\" : \"py-8\"\n )}>\n {/* Left: Logo Image */}\n <Link href={props?.logo?.href || '/'} className=\"flex items-center\">\n {logoUrl && (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-8 md:h-10 w-auto object-contain\"\n width={120}\n height={40}\n />\n )}\n </Link>\n\n {/* Center: Company Name Text */}\n <Link href={props?.logo?.href || '/'} className=\"absolute left-1/2 transform -translate-x-1/2 font-display text-2xl md:text-3xl font-normal uppercase tracking-widest text-fg-primary\" suppressHydrationWarning>\n {companyName}\n </Link>\n\n {/* Right: CTA Buttons - Left=Contact Us (/contact), Right=Book Now (booking) */}\n <div className=\"flex items-center gap-3\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n target={props.cta_button.secondary_target}\n rel={props.cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n size=\"sm\"\n color=\"primary\"\n className=\"font-body text-sm uppercase tracking-wide px-6 py-2 rounded-sm\"\n >\n {props.cta_button.label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n target={props?.cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(props?.cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n size=\"sm\"\n color=\"primary\"\n className=\"font-body text-sm uppercase tracking-wide px-6 py-2 rounded-sm\"\n >\n {(props?.cta_button?.secondary_label && ctaUrls.hasSecondary) ? props.cta_button.secondary_label : (props?.cta_button?.label || \"Contact\")}\n </Button>\n </div>\n </div>\n\n {/* Navigation Row with Dropdowns - Centered */}\n <nav className=\"border-b border-secondary\">\n <div className=\"flex items-center justify-center gap-8 py-4\">\n {navigation.map((item: NavItem, i: number) => (\n <div\n key={i}\n className=\"relative\"\n onMouseEnter={(e) => handleMouseEnter(item, e)}\n onMouseLeave={handleMouseLeave}\n >\n <Link\n href={item.href}\n className={cx(\n \"font-body text-sm uppercase tracking-wide text-fg-primary pb-4\",\n activeDropdown === item.label && \"border-b-2 border-fg-primary\"\n )}\n >\n {item.label}\n </Link>\n \n {/* Dropdown Second Row - Horizontal Layout - Centered */}\n {item.children && item.children.length > 0 && activeDropdown === item.label && (\n <div \n className=\"fixed left-0 right-0 w-full pt-6 pb-6 border-b border-secondary bg-primary z-50\"\n style={{ top: `${dropdownTop}px` }}\n onMouseEnter={handleDropdownMouseEnter}\n onMouseLeave={handleDropdownMouseLeave}\n >\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"flex items-center justify-center gap-8\">\n {(() => {\n const { items, showViewAll, viewAllHref, viewAllLabel } = getDropdownItems(item);\n return (\n <>\n {items.map((link: NavItem, j: number) => (\n <Link\n key={j}\n href={link.href}\n className=\"font-body text-sm text-fg-primary hover:underline whitespace-nowrap\"\n >\n {link.label}\n </Link>\n ))}\n {showViewAll && (\n <Link\n href={viewAllHref}\n className=\"font-body text-sm text-fg-primary hover:underline whitespace-nowrap font-semibold\"\n >\n {viewAllLabel} →\n </Link>\n )}\n </>\n );\n })()}\n </div>\n </div>\n </div>\n )}\n </div>\n ))}\n </div>\n </nav>\n </div>\n </header>\n\n {/* Mobile Header */}\n <header className=\"md:hidden sticky top-0 z-50 bg-primary border-b border-secondary\">\n <div className=\"flex items-center justify-between px-4 py-4\">\n <button\n onClick={() => setIsMobileMenuOpen(true)}\n className=\"text-fg-primary\"\n aria-label=\"Open menu\"\n >\n <svg className=\"w-6 h-6\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M4 6h16M4 12h16M4 18h16\" />\n </svg>\n </button>\n \n <Link href={props?.logo?.href || '/'} className=\"flex items-center\">\n {logoUrl ? (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-8 w-auto object-contain\"\n width={120}\n height={32}\n />\n ) : (\n <span className=\"font-display text-xl font-normal uppercase tracking-widest text-fg-primary\">\n {companyName}\n </span>\n )}\n </Link>\n \n <div className=\"w-6\" />\n </div>\n </header>\n\n {/* Mobile Full-Screen Menu Overlay */}\n {isMobileMenuOpen && (\n <div className=\"fixed inset-0 bg-white z-50 md:hidden\">\n <div className=\"flex flex-col h-full\">\n {/* Mobile Menu Header */}\n <div className=\"flex items-center justify-between px-4 py-4 border-b border-secondary\">\n <button\n onClick={() => setIsMobileMenuOpen(false)}\n className=\"text-fg-primary\"\n aria-label=\"Close menu\"\n >\n <svg className=\"w-6 h-6\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n \n <div className=\"flex items-center\">\n {logoUrl ? (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-8 w-auto object-contain\"\n width={120}\n height={32}\n />\n ) : (\n <span className=\"font-display text-xl font-normal uppercase tracking-widest text-fg-primary\">\n {companyName}\n </span>\n )}\n </div>\n \n <div className=\"w-6\" />\n </div>\n\n {/* Mobile Menu Links */}\n <nav className=\"flex-1 overflow-y-auto px-4 py-8\">\n <ul className=\"space-y-4\">\n {navigation.map((item: NavItem, i: number) => {\n const { items, showViewAll, viewAllHref, viewAllLabel } = getDropdownItems(item);\n return (\n <li key={i}>\n <Link\n href={item.href}\n className=\"block font-body text-base text-fg-primary py-2\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {item.label}\n </Link>\n {items.length > 0 && (\n <ul className=\"ml-4 mt-2 space-y-2\">\n {items.map((link: NavItem, j: number) => (\n <li key={j}>\n <Link\n href={link.href}\n className=\"block font-body text-sm text-tertiary py-1\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {link.label}\n </Link>\n </li>\n ))}\n {showViewAll && (\n <li>\n <Link\n href={viewAllHref}\n className=\"block font-body text-sm text-tertiary py-1 font-semibold\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {viewAllLabel} →\n </Link>\n </li>\n )}\n </ul>\n )}\n </li>\n );\n })}\n </ul>\n </nav>\n\n {/* Mobile Menu Footer - Left=Contact Us, Right=Book Now */}\n <div className=\"border-t border-secondary px-4 py-6\">\n <div className=\"flex flex-col gap-3\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n target={props.cta_button.secondary_target}\n rel={props.cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className=\"w-full font-body text-sm uppercase tracking-wide py-3 rounded-sm\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {props.cta_button.label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n target={props?.cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(props?.cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className=\"w-full font-body text-sm uppercase tracking-wide py-3 rounded-sm\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {(props?.cta_button?.secondary_label && ctaUrls.hasSecondary) ? props.cta_button.secondary_label : (props?.cta_button?.label || \"Contact\")}\n </Button>\n </div>\n </div>\n </div>\n </div>\n )}\n\n {/* Sticky Contact Button (Mobile) — hidden on portal page where it would be redundant */}\n {!isPortalPage && <div className=\"fixed bottom-0 left-0 right-0 z-40 md:hidden bg-fg-primary\">\n <div className=\"flex gap-0\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n target={props.cta_button.secondary_target}\n rel={props.cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className=\"flex-1 font-body text-sm uppercase tracking-wide py-4 rounded-none border-r border-gray-700\"\n >\n {props.cta_button.label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n target={props?.cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(props?.cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className={`${props?.cta_button?.secondary_label && ctaUrls.hasSecondary ? 'flex-1' : 'w-full'} font-body text-sm uppercase tracking-wide py-4 rounded-none`}\n >\n {(props?.cta_button?.secondary_label && ctaUrls.hasSecondary) ? props.cta_button.secondary_label : (props?.cta_button?.label || \"Contact\")}\n </Button>\n </div>\n </div>}\n </>\n );\n}\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('header-navigation', 'aman', HeaderNavigation);\n","import { PhotoWithFallback } from '../elements';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\n\ninterface AboutHomeProps {\n companyInformation?: CompanyInformation | null;\n websitePhotos?: WebsitePhotos | null;\n title?: string;\n subtitle?: string;\n ctaText?: string;\n}\n\nexport const AboutHome = ({\n companyInformation,\n websitePhotos,\n title = \"\",\n subtitle = \"\",\n ctaText = \"\",\n}: AboutHomeProps) => {\n const description = companyInformation?.about_text_markdown || '';\n \n // Use about photo\n const aboutImage = websitePhotos?.about;\n\n return (\n <section>\n <div className=\"mx-auto grid max-w-container grid-cols-1 gap-12 px-4 md:px-8 lg:grid-cols-2 lg:gap-16\">\n <div className=\"order-2 lg:order-1\">\n <PhotoWithFallback\n photoUrl={aboutImage?.url || ''}\n photoAlt={aboutImage?.alt || 'About'}\n fallbackId=\"about-aman\"\n className=\"w-full h-full object-cover min-h-[300px] md:min-h-[400px]\"\n />\n </div>\n\n <div className=\"order-1 lg:order-2 flex flex-col justify-center\">\n <h2 className=\"font-display text-4xl font-normal leading-tight text-fg-primary md:text-5xl\">\n {title}\n </h2>\n \n {subtitle && (\n <p className=\"mt-4 font-body text-md text-tertiary uppercase tracking-wide\">\n {subtitle}\n </p>\n )}\n \n {description && (\n <p className=\"mt-6 font-body text-lg leading-relaxed text-tertiary\">\n {description}\n </p>\n )}\n\n {ctaText && (\n <a\n href=\"/about\"\n className=\"mt-8 inline-block font-body text-base underline underline-offset-4 hover:no-underline w-fit transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n {ctaText}\n </a>\n )}\n </div>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('about-home', 'aman', AboutHome);\n","import { PhotoWithFallback } from '../elements';\nimport type { Service } from '../../types/api/service';\n\ninterface ServicesHomeProps {\n services?: Service[] | null;\n title?: string;\n}\n\nexport const ServicesHome = ({\n services: servicesData,\n title = \"\",\n}: ServicesHomeProps) => {\n const services = Array.isArray(servicesData) ? servicesData : [];\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n </div>\n\n {services.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3\">\n {services.map((service: Service) => {\n const description = service.summary || \n (service.description_markdown ? service.description_markdown.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) : '');\n \n return (\n <div key={service.id} className=\"flex flex-col\">\n <div className=\"w-full h-64 mb-6 overflow-hidden\">\n <PhotoWithFallback\n item={service}\n fallbackId={service.id}\n className=\"w-full h-full object-cover\"\n />\n </div>\n \n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n SERVICE\n </p>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-4\">\n {service.name}\n </h3>\n \n {description && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-6 flex-grow\">\n {description}\n </p>\n )}\n \n <a\n href={`/services/${service.slug}`}\n className=\"font-body text-base underline underline-offset-4 hover:no-underline transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n Discover more\n </a>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No services available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('services-home', 'aman', ServicesHome);\n","import { PhotoWithFallback } from '../elements';\nimport type { Service } from '../../types/api/service';\n\ninterface ServicesGridProps {\n services?: Service[] | null;\n title?: string;\n}\n\nexport const ServicesGrid = ({\n services: servicesData,\n title = \"\",\n}: ServicesGridProps) => {\n const services = Array.isArray(servicesData) ? servicesData : [];\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n </div>\n\n {services.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3\">\n {services.map((service: Service) => {\n const description = service.summary || \n (service.description_markdown ? service.description_markdown.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) : '');\n \n return (\n <div key={service.id} className=\"flex flex-col\">\n <div className=\"w-full h-64 mb-6 overflow-hidden\">\n <PhotoWithFallback\n item={service}\n fallbackId={service.id}\n className=\"w-full h-full object-cover\"\n />\n </div>\n \n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n SERVICE\n </p>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-4\">\n {service.name}\n </h3>\n \n {description && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-6 flex-grow\">\n {description}\n </p>\n )}\n \n <a\n href={`/services/${service.slug}`}\n className=\"font-body text-base underline underline-offset-4 hover:no-underline transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n Discover more\n </a>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No services available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('services-grid', 'aman', ServicesGrid);\n","import React from 'react';\nimport { PhotoWithFallback, Carousel, CarouselSectionWrapper } from '../elements';\nimport type { Testimonial } from '../../types/api/testimonial';\nimport { getAvatarUrl } from '../../utils/photo-helpers';\n\ninterface TestimonialsHomeProps {\n testimonials?: Testimonial[] | null;\n title?: string;\n perPage?: number;\n}\n\nexport const TestimonialsHome = ({\n testimonials: testimonialsData,\n title = \"\",\n perPage,\n}: TestimonialsHomeProps) => {\n const testimonials = Array.isArray(testimonialsData) ? testimonialsData : [];\n const displayTestimonials = perPage ? testimonials.slice(0, perPage) : testimonials;\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <CarouselSectionWrapper \n title={title} \n hasItems={displayTestimonials.length > 0}\n emptyMessage=\"No testimonials available\"\n >\n {displayTestimonials.map((testimonial, i: number) => {\n const quote = testimonial.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const reviewerName = testimonial.reviewer_name || 'Customer';\n const username = `@${reviewerName.toLowerCase().replace(/\\s+/g, '')}`;\n const avatarUrl = getAvatarUrl(testimonial.photo_attachments, testimonial.id, reviewerName);\n const rating = testimonial.rating || 5;\n const isVerified = true; // Always show verified badge\n \n return (\n <Carousel.Item key={testimonial.id || i} className=\"pl-4 md:basis-1/2 lg:basis-1/3\">\n <div className=\"bg-white p-8 flex flex-col h-full\">\n <div className=\"flex gap-1 mb-6\">\n {Array.from({ length: 5 }).map((_, starIdx) => (\n <svg\n key={starIdx}\n className=\"w-5 h-5\"\n style={{\n fill: starIdx < rating ? \"var(--color-text-brand-secondary)\" : \"none\",\n stroke: starIdx < rating ? \"none\" : \"#E5E0D8\"\n }}\n strokeWidth=\"2\"\n viewBox=\"0 0 24 24\"\n >\n <path d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\" />\n </svg>\n ))}\n </div>\n\n <p className=\"font-display text-lg leading-relaxed text-tertiary mb-6 flex-grow\">\n "{quote}"\n </p>\n\n <div className=\"flex items-center gap-3\">\n <div className=\"w-12 h-12 rounded-full overflow-hidden flex-shrink-0\">\n <PhotoWithFallback\n photoUrl={avatarUrl}\n photoAlt={reviewerName}\n fallbackId={testimonial.id || i}\n className=\"w-full h-full object-cover\"\n />\n </div>\n <div className=\"flex-1\">\n <div className=\"flex items-center gap-1.5\">\n <p className=\"font-body text-sm font-medium text-fg-primary\">\n {reviewerName}\n </p>\n {isVerified && (\n <svg className=\"w-4 h-4 text-fg-primary\" viewBox=\"0 0 20 20\" fill=\"currentColor\">\n <path fillRule=\"evenodd\" d=\"M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z\" clipRule=\"evenodd\" />\n </svg>\n )}\n </div>\n <p className=\"font-body text-xs\" style={{ color: 'var(--color-text-brand-secondary)' }}>{username}</p>\n </div>\n </div>\n </div>\n </Carousel.Item>\n );\n })}\n </CarouselSectionWrapper>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('testimonials-home', 'aman', TestimonialsHome);\n","import React from 'react';\nimport { PhotoWithFallback } from '../elements';\nimport type { Testimonial } from '../../types/api/testimonial';\nimport { getAvatarUrl } from '../../utils/photo-helpers';\n\ninterface TestimonialsGridProps {\n testimonials?: Testimonial[] | null;\n title?: string;\n subtitle?: string;\n}\n\nexport const TestimonialsGrid = ({\n testimonials: testimonialsData,\n title = \"\",\n subtitle = \"\",\n}: TestimonialsGridProps) => {\n const testimonials = Array.isArray(testimonialsData) ? testimonialsData : [];\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mb-12 text-center\">\n {title && (\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 font-display text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {testimonials.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-8 md:grid-cols-2 lg:grid-cols-3\">\n {testimonials.map((testimonial, i: number) => {\n const quote = testimonial.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const reviewerName = testimonial.reviewer_name || 'Customer';\n const username = `@${reviewerName.toLowerCase().replace(/\\s+/g, '')}`;\n const avatarUrl = getAvatarUrl(testimonial.photo_attachments, testimonial.id, reviewerName);\n const rating = testimonial.rating || 5;\n const isVerified = true; // Always show verified badge\n \n return (\n <div key={testimonial.id || i} className=\"bg-white p-8 flex flex-col h-full\">\n <div className=\"flex gap-1 mb-6\">\n {Array.from({ length: 5 }).map((_, starIdx) => (\n <svg\n key={starIdx}\n className=\"w-5 h-5\"\n style={{\n fill: starIdx < rating ? \"var(--color-text-brand-secondary)\" : \"none\",\n stroke: starIdx < rating ? \"none\" : \"#E5E0D8\"\n }}\n strokeWidth=\"2\"\n viewBox=\"0 0 24 24\"\n >\n <path d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\" />\n </svg>\n ))}\n </div>\n\n <p className=\"font-display text-lg leading-relaxed text-tertiary mb-6 flex-grow\">\n "{quote}"\n </p>\n\n <div className=\"flex items-center gap-3\">\n <div className=\"w-12 h-12 rounded-full overflow-hidden flex-shrink-0\">\n <PhotoWithFallback\n photoUrl={avatarUrl}\n photoAlt={reviewerName}\n fallbackId={testimonial.id || i}\n className=\"w-full h-full object-cover\"\n />\n </div>\n <div className=\"flex-1\">\n <div className=\"flex items-center gap-1.5\">\n <p className=\"font-body text-sm font-medium text-fg-primary\">\n {reviewerName}\n </p>\n {isVerified && (\n <svg className=\"w-4 h-4 text-fg-primary\" viewBox=\"0 0 20 20\" fill=\"currentColor\">\n <path fillRule=\"evenodd\" d=\"M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z\" clipRule=\"evenodd\" />\n </svg>\n )}\n </div>\n <p className=\"font-body text-xs\" style={{ color: 'var(--color-text-brand-secondary)' }}>{username}</p>\n </div>\n </div>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No testimonials available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('testimonials-grid', 'aman', TestimonialsGrid);\n\n","import React from 'react';\nimport { PhotoWithFallback } from '../elements';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { FormDefinition } from '../../types/api/form';\nimport type { SiteConfig } from '../../types/config';\nimport { ContactSectionForm } from './contact-section-form.aman';\n\nfunction getLegalUrlsFromConfig(config: SiteConfig | null | undefined): { privacyPolicyUrl?: string; termsOfServiceUrl?: string } {\n if (!config?.navigation?.footer) return {};\n const flat = config.navigation.footer.flat();\n const privacy = flat.find((l) => l.label === 'Privacy Policy')?.href;\n const terms = flat.find((l) => l.label === 'Terms of Service')?.href;\n return { privacyPolicyUrl: privacy, termsOfServiceUrl: terms };\n}\n\ninterface ContactSectionProps {\n websitePhotos?: WebsitePhotos | null;\n title?: string;\n subtitle?: string;\n formDefinition?: FormDefinition | null;\n config?: SiteConfig | null;\n}\n\nconst ContactSection = ({\n websitePhotos,\n title = \"\",\n subtitle = \"\",\n formDefinition,\n config,\n}: ContactSectionProps) => {\n const { privacyPolicyUrl, termsOfServiceUrl } = getLegalUrlsFromConfig(config);\n const contactPhoto = websitePhotos?.contact;\n const contactImageUrl = contactPhoto?.url;\n const finalContactImage = contactImageUrl && contactImageUrl.trim() !== \"\" ? contactImageUrl : undefined;\n const finalContactImageAlt = contactPhoto?.alt || \"Contact image\";\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"grid grid-cols-1 gap-12 md:gap-16 lg:grid-cols-2\">\n {/* Form Side */}\n <div className=\"flex w-full flex-col\">\n <div className=\"mb-8\">\n <h2 className=\"font-display text-4xl font-normal leading-tight text-fg-primary md:text-5xl\">\n {title}\n </h2>\n <p className=\"mt-4 font-body text-lg leading-relaxed text-tertiary\">\n {subtitle}\n </p>\n </div>\n\n <ContactSectionForm\n formDefinition={formDefinition}\n privacyPolicyUrl={privacyPolicyUrl}\n termsOfServiceUrl={termsOfServiceUrl}\n />\n </div>\n\n {/* Image Side - full height next to form */}\n <div className=\"max-lg:hidden h-full min-h-0 overflow-hidden\">\n <PhotoWithFallback\n photoUrl={finalContactImage || ''}\n photoAlt={finalContactImageAlt}\n fallbackId=\"contact-image\"\n className=\"h-full w-full object-cover\"\n />\n </div>\n </div>\n </div>\n </section>\n );\n};\n\nexport default ContactSection;\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('contact-section', 'aman', ContactSection);\n","\"use client\";\n\nimport React, { useRef, useState } from 'react';\nimport { Form, Button } from '../elements';\nimport { DynamicFormFields } from '../components/DynamicFormFields';\nimport { firePixelEvent, setPixelUserData } from '../../tracking/firePixelEvent';\nimport { captureEvent } from '../../tracking/captureEvent';\nimport type { FormDefinition } from '../../types/api/form';\nimport { useFormDefinitions } from '../../next/contexts/form-definitions';\n\ninterface ContactSectionFormAmanProps {\n formDefinition: FormDefinition | null | undefined;\n submitButtonText?: string;\n successMessage?: string;\n thankYouMessage?: string;\n onSuccess?: () => void;\n privacyPolicyUrl?: string;\n termsOfServiceUrl?: string;\n}\n\nexport const ContactSectionForm = ({\n formDefinition,\n submitButtonText = \"Send message\",\n successMessage = \"Thank you for contacting us! We'll get back to you soon.\",\n thankYouMessage,\n onSuccess,\n privacyPolicyUrl,\n termsOfServiceUrl,\n}: ContactSectionFormAmanProps) => {\n const { leadFormDefinition } = useFormDefinitions();\n const resolvedFormDefinition = formDefinition ?? leadFormDefinition;\n const [isSubmitting, setIsSubmitting] = useState(false);\n const [submitStatus, setSubmitStatus] = useState<'idle' | 'success' | 'error'>('idle');\n const [statusMessage, setStatusMessage] = useState<string>('');\n const formRef = useRef<HTMLFormElement>(null);\n\n const hasFields =\n resolvedFormDefinition != null &&\n Array.isArray(resolvedFormDefinition.fields) &&\n resolvedFormDefinition.fields.length > 0;\n\n const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n setIsSubmitting(true);\n setSubmitStatus('idle');\n setStatusMessage('');\n const formData = new FormData(e.currentTarget);\n const data: Record<string, string> = { formType: 'lead' };\n formData.forEach((value, key) => {\n if (key.endsWith('_prefix')) return;\n if (typeof value === 'string') data[key] = value;\n });\n try {\n const response = await fetch('/api/form/', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(data),\n });\n const result = await response.json();\n if (result.success) {\n setSubmitStatus('success');\n setStatusMessage(result.message || successMessage);\n formRef.current?.reset();\n onSuccess?.();\n await setPixelUserData({ email: data.email, phone: data.phone });\n firePixelEvent('Lead', undefined, result.eventId);\n captureEvent('form_submitted', { form_type: 'lead', ...(result.eventId && { event_id: result.eventId }) });\n setTimeout(() => setSubmitStatus('idle'), 5000);\n } else {\n const errorMsg = result.error || 'Something went wrong. Please try again.';\n setSubmitStatus('error');\n setStatusMessage(errorMsg);\n captureEvent('form_failed', { form_type: 'lead', error: errorMsg });\n }\n } catch {\n setSubmitStatus('error');\n setStatusMessage('Network error. Please try again later.');\n captureEvent('form_failed', { form_type: 'lead', error: 'network_error' });\n }\n setIsSubmitting(false);\n };\n\n if (!hasFields) return null;\n\n return (\n <Form ref={formRef} onSubmit={handleSubmit} className=\"flex flex-col gap-6\">\n <DynamicFormFields\n form={resolvedFormDefinition}\n privacyPolicyUrl={privacyPolicyUrl}\n termsOfServiceUrl={termsOfServiceUrl}\n />\n <Button\n type=\"submit\"\n color=\"primary\"\n size=\"xl\"\n className=\"w-full font-body text-base uppercase tracking-wide rounded-sm\"\n isDisabled={isSubmitting}\n isLoading={isSubmitting}\n >\n {isSubmitting ? 'Sending...' : submitButtonText}\n </Button>\n {submitStatus === 'success' && (\n <div className=\"rounded-sm bg-success-50 p-4 text-success-700 font-body\">{thankYouMessage ?? statusMessage}</div>\n )}\n {submitStatus === 'error' && (\n <div className=\"rounded-sm bg-error-50 p-4 text-error-700 font-body text-sm\">{statusMessage}</div>\n )}\n </Form>\n );\n};\n","import { PhotoWithFallback } from '../elements';\nimport type { TeamMember } from '../../types/api/team-member';\n\ninterface TeamGridProps {\n teamMembers?: TeamMember[] | null;\n title?: string;\n subtitle?: string;\n maxMembers?: number;\n}\n\nexport const TeamGrid = ({\n teamMembers: membersData,\n title = \"\",\n subtitle = \"\",\n maxMembers = 8,\n}: TeamGridProps) => {\n const members = Array.isArray(membersData) ? membersData : [];\n \n const displayMembers = members.slice(0, maxMembers);\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {title && (\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"mt-4 font-body text-lg text-tertiary\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {displayMembers.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3\">\n {displayMembers.map((member) => {\n const bio = member.bio_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <div key={member.id}>\n <div className=\"aspect-[3/4] w-full mb-6\">\n <PhotoWithFallback\n item={member}\n fallbackId={member.id}\n className=\"w-full h-full object-cover\"\n />\n </div>\n <h3 className=\"font-display text-xl font-normal text-fg-primary\">\n {member.name}\n </h3>\n <p className=\"mt-2 font-body text-sm\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {member.position}\n </p>\n {bio && (\n <p className=\"mt-4 font-body text-sm leading-relaxed text-tertiary\">\n {bio}\n </p>\n )}\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No team members available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('team-grid', 'aman', TeamGrid);\n","import Link from \"next/link\";\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { SiteConfig } from '../../types/config';\nimport { SocialIcon } from '../elements';\n\ninterface FooterHomeProps {\n config?: SiteConfig;\n companyInformation?: CompanyInformation | null;\n}\n\nconst COLUMN_TITLES = ['Home', 'Services', 'Locations', 'About Us'];\n\nfunction buildSocialLinks(ci: CompanyInformation | null | undefined) {\n const links: { platform: string; url: string }[] = [];\n if (!ci) return links;\n if (ci.facebook_url) links.push({ platform: 'facebook', url: ci.facebook_url });\n if (ci.instagram_url) links.push({ platform: 'instagram', url: ci.instagram_url });\n if (ci.tiktok_url) links.push({ platform: 'tiktok', url: ci.tiktok_url });\n if (ci.linkedin_url) links.push({ platform: 'linkedin', url: ci.linkedin_url });\n if (ci.twitter_url) links.push({ platform: 'twitter', url: ci.twitter_url });\n if (ci.youtube_url) links.push({ platform: 'youtube', url: ci.youtube_url });\n if (ci.pinterest_url) links.push({ platform: 'pinterest', url: ci.pinterest_url });\n if (ci.google_my_business_url) links.push({ platform: 'google_my_business', url: ci.google_my_business_url });\n if (ci.yelp_url) links.push({ platform: 'yelp', url: ci.yelp_url });\n if (ci.tripadvisor_url) links.push({ platform: 'tripadvisor', url: ci.tripadvisor_url });\n if (ci.google_reviews_url) links.push({ platform: 'google_reviews', url: ci.google_reviews_url });\n return links;\n}\n\nexport const FooterHome = ({\n config,\n companyInformation,\n}: FooterHomeProps) => {\n const currentYear = new Date().getFullYear();\n \n const footerColumns = config?.navigation?.footer || [];\n const companyName = companyInformation?.company_name || '';\n const socialLinks = buildSocialLinks(companyInformation);\n\n return (\n <footer className=\"bg-primary border-t border-secondary py-12 md:py-16\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-4\">\n {footerColumns.map((column, i) => (\n <div key={i}>\n <h4 className=\"font-body text-sm font-medium uppercase tracking-wide text-fg-primary mb-4\">\n {COLUMN_TITLES[i] || `Column ${i + 1}`}\n </h4>\n <ul className=\"space-y-2\">\n {column.map((link, j) => (\n <li key={j}>\n <Link\n href={link.href}\n className=\"font-body text-sm text-tertiary hover:underline\"\n >\n {link.label}\n </Link>\n </li>\n ))}\n </ul>\n </div>\n ))}\n </div>\n\n {socialLinks.length > 0 && (\n <div className=\"flex flex-wrap justify-center gap-4 mt-10\">\n {socialLinks.map(({ platform, url }) => (\n <a\n key={platform}\n href={url}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"text-tertiary hover:text-fg-primary transition-colors\"\n aria-label={platform}\n >\n <SocialIcon platform={platform} className=\"w-6 h-6 flex-shrink-0\" />\n </a>\n ))}\n </div>\n )}\n \n <div className=\"mt-12 pt-8 border-t border-secondary text-center\">\n <p className=\"font-body text-sm text-tertiary\">\n © {currentYear} {companyName || 'Company Name'}. All rights reserved.\n </p>\n </div>\n </div>\n </footer>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('footer-home', 'aman', FooterHome);\n","import { Breadcrumb } from '../elements';\nimport type { Service } from '../../types/api/service';\n\ninterface HeroServiceDetailProps {\n title?: string;\n description?: string;\n backgroundImage?: string;\n breadcrumbs?: Array<{ label: string; href: string }>;\n service?: Service | null;\n}\n\nexport const ServiceDetailHero = ({\n title: titleProp,\n description: descriptionProp,\n breadcrumbs = [],\n service,\n}: HeroServiceDetailProps) => {\n const title = service?.name || titleProp || '';\n const description = service?.summary || descriptionProp || '';\n \n return (\n <section className=\"relative\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {breadcrumbs && breadcrumbs.length > 0 && (\n <div className=\"mb-8\">\n <Breadcrumb items={breadcrumbs} />\n </div>\n )}\n \n <div className=\"text-center max-w-4xl mx-auto\">\n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl\">\n {title}\n </h1>\n \n {description && (\n <p className=\"mt-6 font-display text-lg leading-relaxed text-tertiary md:text-xl\">\n {description}\n </p>\n )}\n </div>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-service-detail', 'aman', ServiceDetailHero);\n","import { mapIcon } from '../utils/icon-mapping';\n\ninterface Value {\n title: string;\n description: string;\n icon?: string;\n}\n\ninterface ValuesSectionProps {\n title?: string;\n subtitle?: string;\n values?: Value[];\n}\n\nexport const ValuesSection = ({\n title = \"\",\n subtitle = \"\",\n values = [],\n}: ValuesSectionProps) => {\n\n // Check if any icons are missing - if so, use stars for all\n const anyIconMissing = values.some((value) => value.icon && !mapIcon(value.icon));\n const useStarForAll = anyIconMissing;\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n {subtitle && (\n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-4\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {subtitle}\n </p>\n )}\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n </div>\n\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3\">\n {values.map((value, i: number) => {\n // Use star for all if any icon is missing, otherwise use the specified icon\n const IconComponent = useStarForAll ? mapIcon('star') : (mapIcon(value.icon) || mapIcon('star'));\n \n return (\n <div key={i} className=\"text-center\">\n {IconComponent && (\n <div className=\"mb-6 flex justify-center\">\n <div className=\"w-12 h-12 flex items-center justify-center text-fg-primary\">\n <IconComponent className=\"w-full h-full\" />\n </div>\n </div>\n )}\n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-4\">\n {value.title}\n </h3>\n {value.description && (\n <p className=\"font-body text-base leading-relaxed text-tertiary\">\n {value.description}\n </p>\n )}\n </div>\n );\n })}\n </div>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('values-section', 'aman', ValuesSection);\n","interface StatisticsSectionProps {\n title?: string;\n subtitle?: string;\n statistics?: Array<{\n number?: string;\n value?: string;\n label: string;\n }>;\n}\n\nexport const StatisticsSection = ({\n title = \"\",\n subtitle = \"\",\n statistics = [],\n}: StatisticsSectionProps) => {\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mb-12 text-center\">\n {title && (\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 font-body text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {statistics.length > 0 && (\n <div className=\"grid grid-cols-1 gap-8 md:grid-cols-3 justify-items-center\">\n {statistics.map((stat, i: number) => (\n <div key={i} className=\"text-center max-w-xs w-full\">\n <div className=\"font-display text-5xl font-normal text-fg-primary mb-2\">\n {stat.number || stat.value}\n </div>\n <p className=\"text-xs font-body uppercase tracking-widest\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {stat.label}\n </p>\n </div>\n ))}\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('statistics-section', 'aman', StatisticsSection);\n","import { PhotoWithFallback } from '../elements';\nimport type { Location } from '../../types/api/location';\n\ninterface LocationGridProps {\n locations?: Location[] | null;\n title?: string;\n}\n\nexport const LocationGrid = ({\n locations: locationsData,\n title = \"\",\n}: LocationGridProps) => {\n const locations = Array.isArray(locationsData) ? locationsData : [];\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n </div>\n\n {locations.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3\">\n {locations.map((location) => (\n <div key={location.id} className=\"flex flex-col\">\n <div className=\"w-full h-64 mb-6 overflow-hidden\">\n <PhotoWithFallback\n item={location}\n fallbackId={location.id}\n className=\"w-full h-full object-cover\"\n />\n </div>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-2\">\n {location.name}\n </h3>\n \n {location.city && location.state && (\n <p className=\"font-body text-base text-tertiary mb-4\">\n {location.city}, {location.state}\n </p>\n )}\n \n <a\n href={`/locations/${location.slug}`}\n className=\"font-body text-base underline underline-offset-4 hover:no-underline transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n Discover more\n </a>\n </div>\n ))}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No locations available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('location-grid', 'aman', LocationGrid);\n","import { PhotoWithFallback, GoogleMap } from '../elements';\nimport type { Location } from '../../types/api/location';\n\ninterface LocationDetailsSectionProps {\n location?: Location | null;\n}\n\n// Parse business hours - handle both string and object formats\nconst parseBusinessHours = (hours: string | Record<string, { open: string; close: string }> | undefined): Array<{ day: string; hours: string }> => {\n if (!hours) return [];\n \n if (typeof hours === 'object' && !Array.isArray(hours)) {\n const dayNames: Record<string, string> = {\n monday: 'Monday',\n tuesday: 'Tuesday',\n wednesday: 'Wednesday',\n thursday: 'Thursday',\n friday: 'Friday',\n saturday: 'Saturday',\n sunday: 'Sunday',\n };\n \n return Object.entries(hours)\n .filter(([, value]) => value && typeof value === 'object' && value.open && value.close)\n .map(([day, value]) => ({\n day: dayNames[day.toLowerCase()] || day.charAt(0).toUpperCase() + day.slice(1),\n hours: `${value.open}-${value.close}`,\n }));\n }\n \n if (typeof hours === 'string') {\n const entries = hours.split(',').map(entry => {\n const parts = entry.trim().split(':');\n if (parts.length === 2) {\n return { day: parts[0].trim(), hours: parts[1].trim() };\n }\n return null;\n }).filter(Boolean) as Array<{ day: string; hours: string }>;\n \n return entries.length > 0 ? entries : [{ day: 'Hours', hours }];\n }\n \n return [];\n};\n\nexport const LocationDetailsSection = ({\n location,\n}: LocationDetailsSectionProps) => {\n if (!location) return null;\n\n const description = location?.description_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const fullAddress = `${location.address_line_1}${location.address_line_2 ? `, ${location.address_line_2}` : ''}, ${location.city}, ${location.state} ${location.zip_code}`.trim();\n const businessHours = location.business_hours ? parseBusinessHours(location.business_hours) : [];\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Top Section: Description and Photo */}\n <div className=\"grid grid-cols-1 gap-12 lg:grid-cols-2 lg:gap-16 mb-16\">\n <div className=\"flex flex-col justify-center\">\n <h2 className=\"font-display text-4xl font-normal leading-tight text-fg-primary md:text-5xl\">\n {location.name}\n </h2>\n \n {location.city && location.state && (\n <p className=\"mt-4 text-xs font-body uppercase tracking-widest\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {location.city}, {location.state}\n </p>\n )}\n \n {description && (\n <p className=\"mt-6 font-display text-lg leading-relaxed text-tertiary whitespace-pre-line\">\n {description}\n </p>\n )}\n </div>\n \n <div className=\"w-full h-64 md:h-96 overflow-hidden\">\n <PhotoWithFallback\n item={location}\n fallbackId={location.id}\n className=\"w-full h-full object-cover\"\n />\n </div>\n </div>\n\n {/* Bottom Section: Contact Info and Map */}\n <div className=\"grid grid-cols-1 gap-12 lg:grid-cols-2 lg:gap-16\">\n {/* Contact Information */}\n <div className=\"space-y-8\">\n {location.address_line_1 && (\n <div>\n <p className=\"text-xs font-body uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n ADDRESS\n </p>\n <a \n href={`https://maps.google.com/?q=${encodeURIComponent(fullAddress)}`}\n className=\"font-body text-base underline underline-offset-4 hover:no-underline transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n >\n {location.address_line_1}\n {location.address_line_2 && <><br />{location.address_line_2}</>}\n <br />{location.city}, {location.state} {location.zip_code}\n </a>\n </div>\n )}\n\n {location.phone && (\n <div>\n <p className=\"text-xs font-body uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n PHONE\n </p>\n <a \n href={`tel:${location.phone}`}\n className=\"font-body text-base underline underline-offset-4 hover:no-underline transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n {location.phone}\n </a>\n </div>\n )}\n\n {location.email && (\n <div>\n <p className=\"text-xs font-body uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n EMAIL\n </p>\n <a \n href={`mailto:${location.email}`}\n className=\"font-body text-base underline underline-offset-4 hover:no-underline transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n {location.email}\n </a>\n </div>\n )}\n\n {businessHours.length > 0 && (\n <div>\n <p className=\"text-xs font-body uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n HOURS\n </p>\n <div className=\"font-body text-base text-tertiary space-y-1\">\n {businessHours.map(({ day, hours }) => (\n <div key={day} className=\"flex justify-between gap-4\">\n <span className=\"font-medium\">{day}:</span>\n <span className=\"whitespace-pre-line\">{hours}</span>\n </div>\n ))}\n </div>\n </div>\n )}\n </div>\n\n {fullAddress && (\n <div className=\"w-full h-96 overflow-hidden\">\n <GoogleMap\n address={fullAddress}\n locationName={location.name}\n className=\"h-full w-full\"\n />\n </div>\n )}\n </div>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('location-details-section', 'aman', LocationDetailsSection);\n","import { PhotoWithFallback } from '../elements';\nimport { isVideoUrl } from '../../utils/photo-helpers';\nimport type { SocialPost } from '../../types/api/social-post';\n\n/** Get display image URLs from post (excludes video URLs so img/PhotoWithFallback don't break) */\nfunction getPostImageUrls(post: SocialPost): string[] {\n const videoSet = post.video_urls?.length ? new Set(post.video_urls) : null;\n const isVideo = (url: string) => isVideoUrl(url) || (videoSet !== null && videoSet.has(url));\n if (post.image_urls?.length) {\n return post.image_urls.filter((url) => !isVideo(url));\n }\n const attachments = post.photo_attachments || [];\n const sorted = [...attachments].sort((a, b) => (a.sort_order ?? 0) - (b.sort_order ?? 0));\n return sorted\n .map((pa) => pa.photo?.large_url || pa.photo?.original_url || pa.photo?.medium_url || pa.photo?.thumbnail_url)\n .filter((url): url is string => Boolean(url))\n .filter((url) => !isVideo(url));\n}\n\ninterface SocialMediaGridProps {\n socialPosts?: SocialPost[] | null;\n title?: string;\n}\n\nconst formatDate = (dateString?: string) => {\n if (!dateString) return 'Recent';\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n year: 'numeric',\n month: 'short',\n day: 'numeric'\n });\n } catch {\n return 'Recent';\n }\n};\n\nconst getPlatformColor = (platform?: string) => {\n const platformLower = platform?.toLowerCase() || '';\n const colors: Record<string, string> = {\n facebook: '#1877F2',\n instagram: '#E4405F',\n twitter: '#1DA1F2',\n linkedin: '#0A66C2',\n youtube: '#FF0000',\n };\n return colors[platformLower] || '#6B625E';\n};\n\nexport const SocialMediaGrid = ({\n socialPosts: postsData,\n title = \"\",\n}: SocialMediaGridProps) => {\n const posts = Array.isArray(postsData) ? postsData : [];\n const subtitle = \"\";\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"mt-4 font-display text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subtitle}\n </p>\n )}\n </div>\n\n {posts.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-8 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4\">\n {posts.map((post) => {\n const images = getPostImageUrls(post);\n const firstImage = images[0] || '';\n const content = post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const platform = post.platform || 'social';\n const platformColor = getPlatformColor(platform);\n \n return (\n <div key={post.id} className=\"flex flex-col bg-white overflow-hidden\">\n <div className=\"w-full h-64 overflow-hidden\">\n <PhotoWithFallback\n item={post}\n photoUrl={firstImage}\n photoAlt={content.substring(0, 50) || 'Social post'}\n fallbackId={post.id}\n className=\"w-full h-full object-cover\"\n />\n </div>\n \n <div className=\"p-6 flex flex-col flex-grow\">\n <div className=\"flex items-center justify-between mb-4\">\n <span \n className=\"text-xs font-body uppercase tracking-wide px-2 py-1 rounded text-white\"\n style={{ backgroundColor: platformColor }}\n >\n {platform}\n </span>\n <span className=\"text-xs font-body\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {formatDate(post.posted_at)}\n </span>\n </div>\n\n {content && (\n <p className=\"font-body text-sm text-tertiary mb-4 flex-grow line-clamp-4\">\n {content}\n </p>\n )}\n\n {post.platform && (\n <a\n href={post.external_post_url || `https://${platform.toLowerCase()}.com`}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"font-body text-sm underline underline-offset-4 hover:no-underline mt-auto transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n View on {platform.charAt(0).toUpperCase() + platform.slice(1)}\n </a>\n )}\n </div>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No posts available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('social-media-grid', 'aman', SocialMediaGrid);\n","import { PhotoWithFallback } from '../elements';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface BlogHomeProps {\n blogPosts?: BlogPost[] | null;\n title?: string;\n}\n\nexport const BlogHome = ({\n blogPosts: postsData,\n title = \"\",\n}: BlogHomeProps) => {\n const posts = Array.isArray(postsData) ? postsData : [];\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n </div>\n\n {posts.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3\">\n {posts.map((post) => {\n const excerpt = post.excerpt_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) || '';\n \n return (\n <div key={post.id} className=\"flex flex-col\">\n <div className=\"w-full h-64 mb-6 overflow-hidden\">\n <PhotoWithFallback\n item={post}\n fallbackId={post.id}\n className=\"w-full h-full object-cover\"\n />\n </div>\n \n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {post.published_at ? new Date(post.published_at).toLocaleDateString('en-US', { month: 'long', day: 'numeric', year: 'numeric' }) : ''}\n </p>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-4\">\n {post.title}\n </h3>\n \n {excerpt && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-6 flex-grow\">\n {excerpt}\n </p>\n )}\n \n <a\n href={`/blog/${post.slug}`}\n className=\"font-body text-base underline underline-offset-4 hover:no-underline transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n Read more\n </a>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No posts available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('blog-home', 'aman', BlogHome);\n","\"use client\";\n\nimport React, { useState } from 'react';\nimport { PhotoWithFallback, PaginationPageDefault } from '../elements';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface BlogGalleryProps {\n blogPosts?: BlogPost[] | null;\n postsPerPage?: number;\n className?: string;\n}\n\nexport const BlogGallery = ({\n blogPosts: postsData,\n postsPerPage = 12,\n className = \"\",\n}: BlogGalleryProps) => {\n const posts = Array.isArray(postsData) ? postsData : [];\n const [currentPage, setCurrentPage] = useState(1);\n\n // Get featured post (first post with featured: true or first post)\n const featuredPost = posts.find((post) => post.featured) || posts[0];\n const nonFeaturedPosts = posts.filter((post) => post.id !== featuredPost?.id);\n \n // Calculate pagination for non-featured posts\n const totalPages = Math.ceil(nonFeaturedPosts.length / postsPerPage);\n const startIndex = (currentPage - 1) * postsPerPage;\n const endIndex = startIndex + postsPerPage;\n const paginatedNonFeaturedPosts = nonFeaturedPosts.slice(startIndex, endIndex);\n\n return (\n <section className={className}>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {posts.length > 0 ? (\n <>\n {/* Featured Post - Full Width */}\n {featuredPost && (\n <a\n href={`/blog/${featuredPost.slug}`}\n className=\"block mb-16 group\"\n >\n <div className=\"w-full h-96 md:h-[500px] mb-8 overflow-hidden\">\n <PhotoWithFallback\n item={featuredPost}\n fallbackId={featuredPost.id}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n \n <div className=\"max-w-3xl\">\n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-4\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {featuredPost.published_at ? new Date(featuredPost.published_at).toLocaleDateString('en-US', { month: 'long', day: 'numeric', year: 'numeric' }) : 'Recent'}\n </p>\n \n <h2 className=\"font-display text-3xl md:text-4xl font-normal text-fg-primary mb-6 group-hover:underline\">\n {featuredPost.title}\n </h2>\n \n {featuredPost.excerpt_markdown && (\n <p className=\"font-display text-lg leading-relaxed text-tertiary\">\n {featuredPost.excerpt_markdown.replace(/[#*\\[\\]()]/g, '').trim()}\n </p>\n )}\n </div>\n </a>\n )}\n\n {/* Posts Grid */}\n {paginatedNonFeaturedPosts.length > 0 && (\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3 mb-16\">\n {paginatedNonFeaturedPosts.map((post) => {\n const excerpt = post.excerpt_markdown || post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) || '';\n \n return (\n <a key={post.id} href={`/blog/${post.slug}`} className=\"flex flex-col group\">\n <div className=\"w-full h-64 mb-6 overflow-hidden\">\n <PhotoWithFallback\n item={post}\n fallbackId={post.id}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n \n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {post.published_at ? new Date(post.published_at).toLocaleDateString('en-US', { month: 'long', day: 'numeric', year: 'numeric' }) : 'Recent'}\n </p>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-4 group-hover:underline\">\n {post.title}\n </h3>\n \n {excerpt && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-4 flex-grow line-clamp-3\">\n {excerpt}\n </p>\n )}\n </a>\n );\n })}\n </div>\n )}\n\n {/* Pagination */}\n {totalPages > 1 && (\n <div className=\"flex justify-center\">\n <PaginationPageDefault \n rounded \n page={currentPage}\n total={totalPages}\n onPageChange={setCurrentPage}\n />\n </div>\n )}\n </>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No posts available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('blog-gallery', 'aman', BlogGallery);\n","import { PhotoWithFallback, Button, Breadcrumb } from '../elements';\nimport MarkdownRenderer from '../elements/markdown-renderer/MarkdownRenderer';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface BlogPostSectionProps {\n blogPost?: BlogPost | null;\n}\n\nexport const BlogPostSection = ({\n blogPost,\n}: BlogPostSectionProps) => {\n if (!blogPost) {\n return (\n <div className=\"bg-primary text-center py-12\">\n <div className=\"text-6xl mb-4\">📝</div>\n <h3 className=\"font-display text-xl font-normal text-fg-primary mb-2\">Blog Post Not Found</h3>\n <p className=\"font-body text-tertiary mb-4\">The blog post you're looking for doesn't exist.</p>\n <Button href=\"/blog\">View All Blog Posts</Button>\n </div>\n );\n }\n\n return (\n <>\n <section className=\"py-2 md:py-2\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <Breadcrumb \n backHref=\"/blog\" \n backLabel=\"Blog\" \n currentLabel={blogPost.title} \n />\n </div>\n </section>\n\n <section>\n <div className=\"mx-auto max-w-3xl px-4 md:px-8\">\n <div className=\"mb-8\">\n {blogPost.published_at && (\n <p className=\"text-xs font-body font-normal uppercase tracking-widest text-secondary mb-4\">\n {new Date(blogPost.published_at).toLocaleDateString('en-US', { month: 'long', day: 'numeric', year: 'numeric' })}\n </p>\n )}\n \n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl\">\n {blogPost.title}\n </h1>\n </div>\n\n <div className=\"aspect-video w-full mb-12\">\n <PhotoWithFallback\n item={blogPost}\n fallbackId={blogPost.id}\n alt={blogPost.title}\n className=\"w-full h-full object-cover\"\n />\n </div>\n\n <div className=\"prose prose-lg max-w-none font-display text-tertiary\">\n <MarkdownRenderer content={blogPost.content_markdown || ''} />\n </div>\n </div>\n </section>\n </>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('blog-post', 'aman', BlogPostSection);\n","import React from 'react';\nimport { PhotoWithFallback, Carousel, CarouselSectionWrapper } from '../elements';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface BlogSectionProps {\n blogPosts?: BlogPost[] | null;\n title?: string;\n maxPosts?: number;\n}\n\nexport const BlogSection = ({\n blogPosts: postsData,\n title = \"\",\n maxPosts,\n}: BlogSectionProps) => {\n \n const postsArray = Array.isArray(postsData) ? (maxPosts ? postsData.slice(0, maxPosts) : postsData) : [];\n\n const formatDate = (dateString?: string) => {\n if (!dateString) return 'Recent';\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n day: 'numeric',\n month: 'long',\n year: 'numeric'\n });\n } catch {\n return 'Recent';\n }\n };\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <CarouselSectionWrapper \n title={title} \n hasItems={postsArray.length > 0}\n emptyMessage=\"No posts available\"\n >\n {postsArray.map((post: BlogPost) => {\n const excerpt = post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) || '';\n \n return (\n <Carousel.Item key={post.id} className=\"pl-4 md:basis-1/2 lg:basis-1/3\">\n <a href={`/blog/${post.slug}`} className=\"flex flex-col h-full group\">\n <div className=\"w-full h-64 mb-6 overflow-hidden\">\n <PhotoWithFallback\n item={post}\n fallbackId={post.id}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n \n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {formatDate(post.published_at)}\n </p>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-4 group-hover:underline line-clamp-1\">\n {post.title}\n </h3>\n \n {excerpt && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-4 flex-grow line-clamp-3\">\n {excerpt}\n </p>\n )}\n </a>\n </Carousel.Item>\n );\n })}\n </CarouselSectionWrapper>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('blog-section', 'aman', BlogSection);\n","\"use client\";\n\nimport { useState } from 'react';\nimport { motion } from 'framer-motion';\nimport type { FaqQuestion } from '../../types/api/faq';\n\ninterface FAQHomeProps {\n faqs: FaqQuestion[];\n title?: string;\n maxItems?: number;\n}\n\nexport const FAQHome = ({\n faqs: faqsData,\n title = \"\",\n maxItems,\n}: FAQHomeProps) => {\n const faqs = Array.isArray(faqsData) ? faqsData : [];\n const displayFaqs = maxItems ? faqs.slice(0, maxItems) : faqs;\n \n const [openIndex, setOpenIndex] = useState<number | null>(null);\n\n return (\n <section>\n <div className=\"mx-auto max-w-3xl px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n </div>\n\n {displayFaqs.length > 0 ? (\n <div className=\"space-y-4\">\n {displayFaqs.map((faq, i: number) => {\n const isOpen = openIndex === i;\n const answer = faq.answer_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <div key={faq.id} className=\"border-b border-secondary\">\n <button\n onClick={() => setOpenIndex(isOpen ? null : i)}\n className=\"flex w-full items-center justify-between py-4 text-left\"\n >\n <h3 className=\"font-display text-xl font-normal text-fg-primary\">\n {faq.question}\n </h3>\n <span className=\"ml-4 text-fg-primary\">\n {isOpen ? '−' : '+'}\n </span>\n </button>\n <motion.div\n initial={false}\n animate={{\n height: isOpen ? 'auto' : 0,\n opacity: isOpen ? 1 : 0,\n }}\n transition={{\n duration: 0.3,\n ease: [0.4, 0.0, 0.2, 1],\n }}\n style={{ overflow: 'hidden' }}\n >\n <div className=\"pb-4\">\n <p className=\"font-body text-base leading-relaxed text-tertiary whitespace-pre-line\">\n {answer}\n </p>\n </div>\n </motion.div>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No FAQs available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('faq-home', 'aman', FAQHome);\n","\"use client\";\nimport { createContext } from 'react';\n\nconst LayoutGroupContext = createContext({});\n\nexport { LayoutGroupContext };\n","\"use client\";\nimport { useRef } from 'react';\n\n/**\n * Creates a constant value over the lifecycle of a component.\n *\n * Even if `useMemo` is provided an empty array as its final argument, it doesn't offer\n * a guarantee that it won't re-run for performance reasons later on. By using `useConstant`\n * you can ensure that initialisers don't execute twice or more.\n */\nfunction useConstant(init) {\n const ref = useRef(null);\n if (ref.current === null) {\n ref.current = init();\n }\n return ref.current;\n}\n\nexport { useConstant };\n","\"use client\";\nimport { useLayoutEffect, useEffect } from 'react';\nimport { isBrowser } from './is-browser.mjs';\n\nconst useIsomorphicLayoutEffect = isBrowser ? useLayoutEffect : useEffect;\n\nexport { useIsomorphicLayoutEffect };\n","const isBrowser = typeof window !== \"undefined\";\n\nexport { isBrowser };\n","\"use client\";\nimport { createContext } from 'react';\n\n/**\n * @public\n */\nconst PresenceContext = \n/* @__PURE__ */ createContext(null);\n\nexport { PresenceContext };\n","function addUniqueItem(arr, item) {\n if (arr.indexOf(item) === -1)\n arr.push(item);\n}\nfunction removeItem(arr, item) {\n const index = arr.indexOf(item);\n if (index > -1)\n arr.splice(index, 1);\n}\n// Adapted from array-move\nfunction moveItem([...arr], fromIndex, toIndex) {\n const startIndex = fromIndex < 0 ? arr.length + fromIndex : fromIndex;\n if (startIndex >= 0 && startIndex < arr.length) {\n const endIndex = toIndex < 0 ? arr.length + toIndex : toIndex;\n const [item] = arr.splice(fromIndex, 1);\n arr.splice(endIndex, 0, item);\n }\n return arr;\n}\n\nexport { addUniqueItem, moveItem, removeItem };\n","const clamp = (min, max, v) => {\n if (v > max)\n return max;\n if (v < min)\n return min;\n return v;\n};\n\nexport { clamp };\n","function formatErrorMessage(message, errorCode) {\n return errorCode\n ? `${message}. For more information and steps for solving, visit https://motion.dev/troubleshooting/${errorCode}`\n : message;\n}\n\nexport { formatErrorMessage };\n","import { formatErrorMessage } from './format-error-message.mjs';\n\nlet warning = () => { };\nlet invariant = () => { };\nif (process.env.NODE_ENV !== \"production\") {\n warning = (check, message, errorCode) => {\n if (!check && typeof console !== \"undefined\") {\n console.warn(formatErrorMessage(message, errorCode));\n }\n };\n invariant = (check, message, errorCode) => {\n if (!check) {\n throw new Error(formatErrorMessage(message, errorCode));\n }\n };\n}\n\nexport { invariant, warning };\n","const MotionGlobalConfig = {};\n\nexport { MotionGlobalConfig };\n","/**\n * Check if value is a numerical string, ie a string that is purely a number eg \"100\" or \"-100.1\"\n */\nconst isNumericalString = (v) => /^-?(?:\\d+(?:\\.\\d+)?|\\.\\d+)$/u.test(v);\n\nexport { isNumericalString };\n","function isObject(value) {\n return typeof value === \"object\" && value !== null;\n}\n\nexport { isObject };\n","/**\n * Check if the value is a zero value string like \"0px\" or \"0%\"\n */\nconst isZeroValueString = (v) => /^0[^.\\s]+$/u.test(v);\n\nexport { isZeroValueString };\n","/*#__NO_SIDE_EFFECTS__*/\nfunction memo(callback) {\n let result;\n return () => {\n if (result === undefined)\n result = callback();\n return result;\n };\n}\n\nexport { memo };\n","/*#__NO_SIDE_EFFECTS__*/\nconst noop = (any) => any;\n\nexport { noop };\n","/**\n * Pipe\n * Compose other transformers to run linearily\n * pipe(min(20), max(40))\n * @param {...functions} transformers\n * @return {function}\n */\nconst combineFunctions = (a, b) => (v) => b(a(v));\nconst pipe = (...transformers) => transformers.reduce(combineFunctions);\n\nexport { pipe };\n","/*\n Progress within given range\n\n Given a lower limit and an upper limit, we return the progress\n (expressed as a number 0-1) represented by the given value, and\n limit that progress to within 0-1.\n\n @param [number]: Lower limit\n @param [number]: Upper limit\n @param [number]: Value to find progress within given range\n @return [number]: Progress of value within range as expressed 0-1\n*/\n/*#__NO_SIDE_EFFECTS__*/\nconst progress = (from, to, value) => {\n const toFromDifference = to - from;\n return toFromDifference === 0 ? 1 : (value - from) / toFromDifference;\n};\n\nexport { progress };\n","import { addUniqueItem, removeItem } from './array.mjs';\n\nclass SubscriptionManager {\n constructor() {\n this.subscriptions = [];\n }\n add(handler) {\n addUniqueItem(this.subscriptions, handler);\n return () => removeItem(this.subscriptions, handler);\n }\n notify(a, b, c) {\n const numSubscriptions = this.subscriptions.length;\n if (!numSubscriptions)\n return;\n if (numSubscriptions === 1) {\n /**\n * If there's only a single handler we can just call it without invoking a loop.\n */\n this.subscriptions[0](a, b, c);\n }\n else {\n for (let i = 0; i < numSubscriptions; i++) {\n /**\n * Check whether the handler exists before firing as it's possible\n * the subscriptions were modified during this loop running.\n */\n const handler = this.subscriptions[i];\n handler && handler(a, b, c);\n }\n }\n }\n getSize() {\n return this.subscriptions.length;\n }\n clear() {\n this.subscriptions.length = 0;\n }\n}\n\nexport { SubscriptionManager };\n","/**\n * Converts seconds to milliseconds\n *\n * @param seconds - Time in seconds.\n * @return milliseconds - Converted time in milliseconds.\n */\n/*#__NO_SIDE_EFFECTS__*/\nconst secondsToMilliseconds = (seconds) => seconds * 1000;\n/*#__NO_SIDE_EFFECTS__*/\nconst millisecondsToSeconds = (milliseconds) => milliseconds / 1000;\n\nexport { millisecondsToSeconds, secondsToMilliseconds };\n","/*\n Convert velocity into velocity per second\n\n @param [number]: Unit per frame\n @param [number]: Frame duration in ms\n*/\nfunction velocityPerSecond(velocity, frameDuration) {\n return frameDuration ? velocity * (1000 / frameDuration) : 0;\n}\n\nexport { velocityPerSecond };\n","import { formatErrorMessage } from './format-error-message.mjs';\n\nconst warned = new Set();\nfunction hasWarned(message) {\n return warned.has(message);\n}\nfunction warnOnce(condition, message, errorCode) {\n if (condition || warned.has(message))\n return;\n console.warn(formatErrorMessage(message, errorCode));\n warned.add(message);\n}\n\nexport { hasWarned, warnOnce };\n","import { noop } from '../noop.mjs';\n\n/*\n Bezier function generator\n This has been modified from Gaëtan Renaudeau's BezierEasing\n https://github.com/gre/bezier-easing/blob/master/src/index.js\n https://github.com/gre/bezier-easing/blob/master/LICENSE\n \n I've removed the newtonRaphsonIterate algo because in benchmarking it\n wasn't noticeably faster than binarySubdivision, indeed removing it\n usually improved times, depending on the curve.\n I also removed the lookup table, as for the added bundle size and loop we're\n only cutting ~4 or so subdivision iterations. I bumped the max iterations up\n to 12 to compensate and this still tended to be faster for no perceivable\n loss in accuracy.\n Usage\n const easeOut = cubicBezier(.17,.67,.83,.67);\n const x = easeOut(0.5); // returns 0.627...\n*/\n// Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.\nconst calcBezier = (t, a1, a2) => (((1.0 - 3.0 * a2 + 3.0 * a1) * t + (3.0 * a2 - 6.0 * a1)) * t + 3.0 * a1) *\n t;\nconst subdivisionPrecision = 0.0000001;\nconst subdivisionMaxIterations = 12;\nfunction binarySubdivide(x, lowerBound, upperBound, mX1, mX2) {\n let currentX;\n let currentT;\n let i = 0;\n do {\n currentT = lowerBound + (upperBound - lowerBound) / 2.0;\n currentX = calcBezier(currentT, mX1, mX2) - x;\n if (currentX > 0.0) {\n upperBound = currentT;\n }\n else {\n lowerBound = currentT;\n }\n } while (Math.abs(currentX) > subdivisionPrecision &&\n ++i < subdivisionMaxIterations);\n return currentT;\n}\nfunction cubicBezier(mX1, mY1, mX2, mY2) {\n // If this is a linear gradient, return linear easing\n if (mX1 === mY1 && mX2 === mY2)\n return noop;\n const getTForX = (aX) => binarySubdivide(aX, 0, 1, mX1, mX2);\n // If animation is at start/end, return t without easing\n return (t) => t === 0 || t === 1 ? t : calcBezier(getTForX(t), mY1, mY2);\n}\n\nexport { cubicBezier };\n","// Accepts an easing function and returns a new one that outputs mirrored values for\n// the second half of the animation. Turns easeIn into easeInOut.\nconst mirrorEasing = (easing) => (p) => p <= 0.5 ? easing(2 * p) / 2 : (2 - easing(2 * (1 - p))) / 2;\n\nexport { mirrorEasing };\n","// Accepts an easing function and returns a new one that outputs reversed values.\n// Turns easeIn into easeOut.\nconst reverseEasing = (easing) => (p) => 1 - easing(1 - p);\n\nexport { reverseEasing };\n","import { cubicBezier } from './cubic-bezier.mjs';\nimport { mirrorEasing } from './modifiers/mirror.mjs';\nimport { reverseEasing } from './modifiers/reverse.mjs';\n\nconst backOut = /*@__PURE__*/ cubicBezier(0.33, 1.53, 0.69, 0.99);\nconst backIn = /*@__PURE__*/ reverseEasing(backOut);\nconst backInOut = /*@__PURE__*/ mirrorEasing(backIn);\n\nexport { backIn, backInOut, backOut };\n","import { backIn } from './back.mjs';\n\nconst anticipate = (p) => (p *= 2) < 1 ? 0.5 * backIn(p) : 0.5 * (2 - Math.pow(2, -10 * (p - 1)));\n\nexport { anticipate };\n","import { mirrorEasing } from './modifiers/mirror.mjs';\nimport { reverseEasing } from './modifiers/reverse.mjs';\n\nconst circIn = (p) => 1 - Math.sin(Math.acos(p));\nconst circOut = reverseEasing(circIn);\nconst circInOut = mirrorEasing(circIn);\n\nexport { circIn, circInOut, circOut };\n","import { cubicBezier } from './cubic-bezier.mjs';\n\nconst easeIn = /*@__PURE__*/ cubicBezier(0.42, 0, 1, 1);\nconst easeOut = /*@__PURE__*/ cubicBezier(0, 0, 0.58, 1);\nconst easeInOut = /*@__PURE__*/ cubicBezier(0.42, 0, 0.58, 1);\n\nexport { easeIn, easeInOut, easeOut };\n","const isEasingArray = (ease) => {\n return Array.isArray(ease) && typeof ease[0] !== \"number\";\n};\n\nexport { isEasingArray };\n","const isBezierDefinition = (easing) => Array.isArray(easing) && typeof easing[0] === \"number\";\n\nexport { isBezierDefinition };\n","import { invariant } from '../../errors.mjs';\nimport { noop } from '../../noop.mjs';\nimport { anticipate } from '../anticipate.mjs';\nimport { backIn, backInOut, backOut } from '../back.mjs';\nimport { circIn, circInOut, circOut } from '../circ.mjs';\nimport { cubicBezier } from '../cubic-bezier.mjs';\nimport { easeIn, easeInOut, easeOut } from '../ease.mjs';\nimport { isBezierDefinition } from './is-bezier-definition.mjs';\n\nconst easingLookup = {\n linear: noop,\n easeIn,\n easeInOut,\n easeOut,\n circIn,\n circInOut,\n circOut,\n backIn,\n backInOut,\n backOut,\n anticipate,\n};\nconst isValidEasing = (easing) => {\n return typeof easing === \"string\";\n};\nconst easingDefinitionToFunction = (definition) => {\n if (isBezierDefinition(definition)) {\n // If cubic bezier definition, create bezier curve\n invariant(definition.length === 4, `Cubic bezier arrays must contain four numerical values.`, \"cubic-bezier-length\");\n const [x1, y1, x2, y2] = definition;\n return cubicBezier(x1, y1, x2, y2);\n }\n else if (isValidEasing(definition)) {\n // Else lookup from table\n invariant(easingLookup[definition] !== undefined, `Invalid easing type '${definition}'`, \"invalid-easing-type\");\n return easingLookup[definition];\n }\n return definition;\n};\n\nexport { easingDefinitionToFunction };\n","const stepsOrder = [\n \"setup\", // Compute\n \"read\", // Read\n \"resolveKeyframes\", // Write/Read/Write/Read\n \"preUpdate\", // Compute\n \"update\", // Compute\n \"preRender\", // Compute\n \"render\", // Write\n \"postRender\", // Compute\n];\n\nexport { stepsOrder };\n","const statsBuffer = {\n value: null,\n addProjectionMetrics: null,\n};\n\nexport { statsBuffer };\n","import { statsBuffer } from '../stats/buffer.mjs';\n\nfunction createRenderStep(runNextFrame, stepName) {\n /**\n * We create and reuse two queues, one to queue jobs for the current frame\n * and one for the next. We reuse to avoid triggering GC after x frames.\n */\n let thisFrame = new Set();\n let nextFrame = new Set();\n /**\n * Track whether we're currently processing jobs in this step. This way\n * we can decide whether to schedule new jobs for this frame or next.\n */\n let isProcessing = false;\n let flushNextFrame = false;\n /**\n * A set of processes which were marked keepAlive when scheduled.\n */\n const toKeepAlive = new WeakSet();\n let latestFrameData = {\n delta: 0.0,\n timestamp: 0.0,\n isProcessing: false,\n };\n let numCalls = 0;\n function triggerCallback(callback) {\n if (toKeepAlive.has(callback)) {\n step.schedule(callback);\n runNextFrame();\n }\n numCalls++;\n callback(latestFrameData);\n }\n const step = {\n /**\n * Schedule a process to run on the next frame.\n */\n schedule: (callback, keepAlive = false, immediate = false) => {\n const addToCurrentFrame = immediate && isProcessing;\n const queue = addToCurrentFrame ? thisFrame : nextFrame;\n if (keepAlive)\n toKeepAlive.add(callback);\n if (!queue.has(callback))\n queue.add(callback);\n return callback;\n },\n /**\n * Cancel the provided callback from running on the next frame.\n */\n cancel: (callback) => {\n nextFrame.delete(callback);\n toKeepAlive.delete(callback);\n },\n /**\n * Execute all schedule callbacks.\n */\n process: (frameData) => {\n latestFrameData = frameData;\n /**\n * If we're already processing we've probably been triggered by a flushSync\n * inside an existing process. Instead of executing, mark flushNextFrame\n * as true and ensure we flush the following frame at the end of this one.\n */\n if (isProcessing) {\n flushNextFrame = true;\n return;\n }\n isProcessing = true;\n [thisFrame, nextFrame] = [nextFrame, thisFrame];\n // Execute this frame\n thisFrame.forEach(triggerCallback);\n /**\n * If we're recording stats then\n */\n if (stepName && statsBuffer.value) {\n statsBuffer.value.frameloop[stepName].push(numCalls);\n }\n numCalls = 0;\n // Clear the frame so no callbacks remain. This is to avoid\n // memory leaks should this render step not run for a while.\n thisFrame.clear();\n isProcessing = false;\n if (flushNextFrame) {\n flushNextFrame = false;\n step.process(frameData);\n }\n },\n };\n return step;\n}\n\nexport { createRenderStep };\n","import { MotionGlobalConfig } from 'motion-utils';\nimport { stepsOrder } from './order.mjs';\nimport { createRenderStep } from './render-step.mjs';\n\nconst maxElapsed = 40;\nfunction createRenderBatcher(scheduleNextBatch, allowKeepAlive) {\n let runNextFrame = false;\n let useDefaultElapsed = true;\n const state = {\n delta: 0.0,\n timestamp: 0.0,\n isProcessing: false,\n };\n const flagRunNextFrame = () => (runNextFrame = true);\n const steps = stepsOrder.reduce((acc, key) => {\n acc[key] = createRenderStep(flagRunNextFrame, allowKeepAlive ? key : undefined);\n return acc;\n }, {});\n const { setup, read, resolveKeyframes, preUpdate, update, preRender, render, postRender, } = steps;\n const processBatch = () => {\n const timestamp = MotionGlobalConfig.useManualTiming\n ? state.timestamp\n : performance.now();\n runNextFrame = false;\n if (!MotionGlobalConfig.useManualTiming) {\n state.delta = useDefaultElapsed\n ? 1000 / 60\n : Math.max(Math.min(timestamp - state.timestamp, maxElapsed), 1);\n }\n state.timestamp = timestamp;\n state.isProcessing = true;\n // Unrolled render loop for better per-frame performance\n setup.process(state);\n read.process(state);\n resolveKeyframes.process(state);\n preUpdate.process(state);\n update.process(state);\n preRender.process(state);\n render.process(state);\n postRender.process(state);\n state.isProcessing = false;\n if (runNextFrame && allowKeepAlive) {\n useDefaultElapsed = false;\n scheduleNextBatch(processBatch);\n }\n };\n const wake = () => {\n runNextFrame = true;\n useDefaultElapsed = true;\n if (!state.isProcessing) {\n scheduleNextBatch(processBatch);\n }\n };\n const schedule = stepsOrder.reduce((acc, key) => {\n const step = steps[key];\n acc[key] = (process, keepAlive = false, immediate = false) => {\n if (!runNextFrame)\n wake();\n return step.schedule(process, keepAlive, immediate);\n };\n return acc;\n }, {});\n const cancel = (process) => {\n for (let i = 0; i < stepsOrder.length; i++) {\n steps[stepsOrder[i]].cancel(process);\n }\n };\n return { schedule, cancel, state, steps };\n}\n\nexport { createRenderBatcher };\n","import { noop } from 'motion-utils';\nimport { createRenderBatcher } from './batcher.mjs';\n\nconst { schedule: frame, cancel: cancelFrame, state: frameData, steps: frameSteps, } = /* @__PURE__ */ createRenderBatcher(typeof requestAnimationFrame !== \"undefined\" ? requestAnimationFrame : noop, true);\n\nexport { cancelFrame, frame, frameData, frameSteps };\n","import { MotionGlobalConfig } from 'motion-utils';\nimport { frameData } from './frame.mjs';\n\nlet now;\nfunction clearTime() {\n now = undefined;\n}\n/**\n * An eventloop-synchronous alternative to performance.now().\n *\n * Ensures that time measurements remain consistent within a synchronous context.\n * Usually calling performance.now() twice within the same synchronous context\n * will return different values which isn't useful for animations when we're usually\n * trying to sync animations to the same frame.\n */\nconst time = {\n now: () => {\n if (now === undefined) {\n time.set(frameData.isProcessing || MotionGlobalConfig.useManualTiming\n ? frameData.timestamp\n : performance.now());\n }\n return now;\n },\n set: (newTime) => {\n now = newTime;\n queueMicrotask(clearTime);\n },\n};\n\nexport { time };\n","const activeAnimations = {\n layout: 0,\n mainThread: 0,\n waapi: 0,\n};\n\nexport { activeAnimations };\n","const checkStringStartsWith = (token) => (key) => typeof key === \"string\" && key.startsWith(token);\nconst isCSSVariableName = \n/*@__PURE__*/ checkStringStartsWith(\"--\");\nconst startsAsVariableToken = \n/*@__PURE__*/ checkStringStartsWith(\"var(--\");\nconst isCSSVariableToken = (value) => {\n const startsWithToken = startsAsVariableToken(value);\n if (!startsWithToken)\n return false;\n // Ensure any comments are stripped from the value as this can harm performance of the regex.\n return singleCssVariableRegex.test(value.split(\"/*\")[0].trim());\n};\nconst singleCssVariableRegex = /var\\(--(?:[\\w-]+\\s*|[\\w-]+\\s*,(?:\\s*[^)(\\s]|\\s*\\((?:[^)(]|\\([^)(]*\\))*\\))+\\s*)\\)$/iu;\n\nexport { isCSSVariableName, isCSSVariableToken };\n","import { clamp } from 'motion-utils';\n\nconst number = {\n test: (v) => typeof v === \"number\",\n parse: parseFloat,\n transform: (v) => v,\n};\nconst alpha = {\n ...number,\n transform: (v) => clamp(0, 1, v),\n};\nconst scale = {\n ...number,\n default: 1,\n};\n\nexport { alpha, number, scale };\n","// If this number is a decimal, make it just five decimal places\n// to avoid exponents\nconst sanitize = (v) => Math.round(v * 100000) / 100000;\n\nexport { sanitize };\n","const floatRegex = /-?(?:\\d+(?:\\.\\d+)?|\\.\\d+)/gu;\n\nexport { floatRegex };\n","function isNullish(v) {\n return v == null;\n}\n\nexport { isNullish };\n","const singleColorRegex = /^(?:#[\\da-f]{3,8}|(?:rgb|hsl)a?\\((?:-?[\\d.]+%?[,\\s]+){2}-?[\\d.]+%?\\s*(?:[,/]\\s*)?(?:\\b\\d+(?:\\.\\d+)?|\\.\\d+)?%?\\))$/iu;\n\nexport { singleColorRegex };\n","import { floatRegex } from '../utils/float-regex.mjs';\nimport { isNullish } from '../utils/is-nullish.mjs';\nimport { singleColorRegex } from '../utils/single-color-regex.mjs';\n\n/**\n * Returns true if the provided string is a color, ie rgba(0,0,0,0) or #000,\n * but false if a number or multiple colors\n */\nconst isColorString = (type, testProp) => (v) => {\n return Boolean((typeof v === \"string\" &&\n singleColorRegex.test(v) &&\n v.startsWith(type)) ||\n (testProp &&\n !isNullish(v) &&\n Object.prototype.hasOwnProperty.call(v, testProp)));\n};\nconst splitColor = (aName, bName, cName) => (v) => {\n if (typeof v !== \"string\")\n return v;\n const [a, b, c, alpha] = v.match(floatRegex);\n return {\n [aName]: parseFloat(a),\n [bName]: parseFloat(b),\n [cName]: parseFloat(c),\n alpha: alpha !== undefined ? parseFloat(alpha) : 1,\n };\n};\n\nexport { isColorString, splitColor };\n","import { clamp } from 'motion-utils';\nimport { number, alpha } from '../numbers/index.mjs';\nimport { sanitize } from '../utils/sanitize.mjs';\nimport { isColorString, splitColor } from './utils.mjs';\n\nconst clampRgbUnit = (v) => clamp(0, 255, v);\nconst rgbUnit = {\n ...number,\n transform: (v) => Math.round(clampRgbUnit(v)),\n};\nconst rgba = {\n test: /*@__PURE__*/ isColorString(\"rgb\", \"red\"),\n parse: /*@__PURE__*/ splitColor(\"red\", \"green\", \"blue\"),\n transform: ({ red, green, blue, alpha: alpha$1 = 1 }) => \"rgba(\" +\n rgbUnit.transform(red) +\n \", \" +\n rgbUnit.transform(green) +\n \", \" +\n rgbUnit.transform(blue) +\n \", \" +\n sanitize(alpha.transform(alpha$1)) +\n \")\",\n};\n\nexport { rgbUnit, rgba };\n","import { rgba } from './rgba.mjs';\nimport { isColorString } from './utils.mjs';\n\nfunction parseHex(v) {\n let r = \"\";\n let g = \"\";\n let b = \"\";\n let a = \"\";\n // If we have 6 characters, ie #FF0000\n if (v.length > 5) {\n r = v.substring(1, 3);\n g = v.substring(3, 5);\n b = v.substring(5, 7);\n a = v.substring(7, 9);\n // Or we have 3 characters, ie #F00\n }\n else {\n r = v.substring(1, 2);\n g = v.substring(2, 3);\n b = v.substring(3, 4);\n a = v.substring(4, 5);\n r += r;\n g += g;\n b += b;\n a += a;\n }\n return {\n red: parseInt(r, 16),\n green: parseInt(g, 16),\n blue: parseInt(b, 16),\n alpha: a ? parseInt(a, 16) / 255 : 1,\n };\n}\nconst hex = {\n test: /*@__PURE__*/ isColorString(\"#\"),\n parse: parseHex,\n transform: rgba.transform,\n};\n\nexport { hex };\n","/*#__NO_SIDE_EFFECTS__*/\nconst createUnitType = (unit) => ({\n test: (v) => typeof v === \"string\" && v.endsWith(unit) && v.split(\" \").length === 1,\n parse: parseFloat,\n transform: (v) => `${v}${unit}`,\n});\nconst degrees = /*@__PURE__*/ createUnitType(\"deg\");\nconst percent = /*@__PURE__*/ createUnitType(\"%\");\nconst px = /*@__PURE__*/ createUnitType(\"px\");\nconst vh = /*@__PURE__*/ createUnitType(\"vh\");\nconst vw = /*@__PURE__*/ createUnitType(\"vw\");\nconst progressPercentage = /*@__PURE__*/ (() => ({\n ...percent,\n parse: (v) => percent.parse(v) / 100,\n transform: (v) => percent.transform(v * 100),\n}))();\n\nexport { degrees, percent, progressPercentage, px, vh, vw };\n","import { alpha } from '../numbers/index.mjs';\nimport { percent } from '../numbers/units.mjs';\nimport { sanitize } from '../utils/sanitize.mjs';\nimport { isColorString, splitColor } from './utils.mjs';\n\nconst hsla = {\n test: /*@__PURE__*/ isColorString(\"hsl\", \"hue\"),\n parse: /*@__PURE__*/ splitColor(\"hue\", \"saturation\", \"lightness\"),\n transform: ({ hue, saturation, lightness, alpha: alpha$1 = 1 }) => {\n return (\"hsla(\" +\n Math.round(hue) +\n \", \" +\n percent.transform(sanitize(saturation)) +\n \", \" +\n percent.transform(sanitize(lightness)) +\n \", \" +\n sanitize(alpha.transform(alpha$1)) +\n \")\");\n },\n};\n\nexport { hsla };\n","import { hex } from './hex.mjs';\nimport { hsla } from './hsla.mjs';\nimport { rgba } from './rgba.mjs';\n\nconst color = {\n test: (v) => rgba.test(v) || hex.test(v) || hsla.test(v),\n parse: (v) => {\n if (rgba.test(v)) {\n return rgba.parse(v);\n }\n else if (hsla.test(v)) {\n return hsla.parse(v);\n }\n else {\n return hex.parse(v);\n }\n },\n transform: (v) => {\n return typeof v === \"string\"\n ? v\n : v.hasOwnProperty(\"red\")\n ? rgba.transform(v)\n : hsla.transform(v);\n },\n getAnimatableNone: (v) => {\n const parsed = color.parse(v);\n parsed.alpha = 0;\n return color.transform(parsed);\n },\n};\n\nexport { color };\n","const colorRegex = /(?:#[\\da-f]{3,8}|(?:rgb|hsl)a?\\((?:-?[\\d.]+%?[,\\s]+){2}-?[\\d.]+%?\\s*(?:[,/]\\s*)?(?:\\b\\d+(?:\\.\\d+)?|\\.\\d+)?%?\\))/giu;\n\nexport { colorRegex };\n","import { color } from '../color/index.mjs';\nimport { colorRegex } from '../utils/color-regex.mjs';\nimport { floatRegex } from '../utils/float-regex.mjs';\nimport { sanitize } from '../utils/sanitize.mjs';\n\nfunction test(v) {\n return (isNaN(v) &&\n typeof v === \"string\" &&\n (v.match(floatRegex)?.length || 0) +\n (v.match(colorRegex)?.length || 0) >\n 0);\n}\nconst NUMBER_TOKEN = \"number\";\nconst COLOR_TOKEN = \"color\";\nconst VAR_TOKEN = \"var\";\nconst VAR_FUNCTION_TOKEN = \"var(\";\nconst SPLIT_TOKEN = \"${}\";\n// this regex consists of the `singleCssVariableRegex|rgbHSLValueRegex|digitRegex`\nconst complexRegex = /var\\s*\\(\\s*--(?:[\\w-]+\\s*|[\\w-]+\\s*,(?:\\s*[^)(\\s]|\\s*\\((?:[^)(]|\\([^)(]*\\))*\\))+\\s*)\\)|#[\\da-f]{3,8}|(?:rgb|hsl)a?\\((?:-?[\\d.]+%?[,\\s]+){2}-?[\\d.]+%?\\s*(?:[,/]\\s*)?(?:\\b\\d+(?:\\.\\d+)?|\\.\\d+)?%?\\)|-?(?:\\d+(?:\\.\\d+)?|\\.\\d+)/giu;\nfunction analyseComplexValue(value) {\n const originalValue = value.toString();\n const values = [];\n const indexes = {\n color: [],\n number: [],\n var: [],\n };\n const types = [];\n let i = 0;\n const tokenised = originalValue.replace(complexRegex, (parsedValue) => {\n if (color.test(parsedValue)) {\n indexes.color.push(i);\n types.push(COLOR_TOKEN);\n values.push(color.parse(parsedValue));\n }\n else if (parsedValue.startsWith(VAR_FUNCTION_TOKEN)) {\n indexes.var.push(i);\n types.push(VAR_TOKEN);\n values.push(parsedValue);\n }\n else {\n indexes.number.push(i);\n types.push(NUMBER_TOKEN);\n values.push(parseFloat(parsedValue));\n }\n ++i;\n return SPLIT_TOKEN;\n });\n const split = tokenised.split(SPLIT_TOKEN);\n return { values, split, indexes, types };\n}\nfunction parseComplexValue(v) {\n return analyseComplexValue(v).values;\n}\nfunction createTransformer(source) {\n const { split, types } = analyseComplexValue(source);\n const numSections = split.length;\n return (v) => {\n let output = \"\";\n for (let i = 0; i < numSections; i++) {\n output += split[i];\n if (v[i] !== undefined) {\n const type = types[i];\n if (type === NUMBER_TOKEN) {\n output += sanitize(v[i]);\n }\n else if (type === COLOR_TOKEN) {\n output += color.transform(v[i]);\n }\n else {\n output += v[i];\n }\n }\n }\n return output;\n };\n}\nconst convertNumbersToZero = (v) => typeof v === \"number\" ? 0 : color.test(v) ? color.getAnimatableNone(v) : v;\nfunction getAnimatableNone(v) {\n const parsed = parseComplexValue(v);\n const transformer = createTransformer(v);\n return transformer(parsed.map(convertNumbersToZero));\n}\nconst complex = {\n test,\n parse: parseComplexValue,\n createTransformer,\n getAnimatableNone,\n};\n\nexport { analyseComplexValue, complex };\n","// Adapted from https://gist.github.com/mjackson/5311256\nfunction hueToRgb(p, q, t) {\n if (t < 0)\n t += 1;\n if (t > 1)\n t -= 1;\n if (t < 1 / 6)\n return p + (q - p) * 6 * t;\n if (t < 1 / 2)\n return q;\n if (t < 2 / 3)\n return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n}\nfunction hslaToRgba({ hue, saturation, lightness, alpha }) {\n hue /= 360;\n saturation /= 100;\n lightness /= 100;\n let red = 0;\n let green = 0;\n let blue = 0;\n if (!saturation) {\n red = green = blue = lightness;\n }\n else {\n const q = lightness < 0.5\n ? lightness * (1 + saturation)\n : lightness + saturation - lightness * saturation;\n const p = 2 * lightness - q;\n red = hueToRgb(p, q, hue + 1 / 3);\n green = hueToRgb(p, q, hue);\n blue = hueToRgb(p, q, hue - 1 / 3);\n }\n return {\n red: Math.round(red * 255),\n green: Math.round(green * 255),\n blue: Math.round(blue * 255),\n alpha,\n };\n}\n\nexport { hslaToRgba };\n","function mixImmediate(a, b) {\n return (p) => (p > 0 ? b : a);\n}\n\nexport { mixImmediate };\n","/*\n Value in range from progress\n\n Given a lower limit and an upper limit, we return the value within\n that range as expressed by progress (usually a number from 0 to 1)\n\n So progress = 0.5 would change\n\n from -------- to\n\n to\n\n from ---- to\n\n E.g. from = 10, to = 20, progress = 0.5 => 15\n\n @param [number]: Lower limit of range\n @param [number]: Upper limit of range\n @param [number]: The progress between lower and upper limits expressed 0-1\n @return [number]: Value as calculated from progress within range (not limited within range)\n*/\nconst mixNumber = (from, to, progress) => {\n return from + (to - from) * progress;\n};\n\nexport { mixNumber };\n","import { warning } from 'motion-utils';\nimport { hex } from '../../value/types/color/hex.mjs';\nimport { hsla } from '../../value/types/color/hsla.mjs';\nimport { hslaToRgba } from '../../value/types/color/hsla-to-rgba.mjs';\nimport { rgba } from '../../value/types/color/rgba.mjs';\nimport { mixImmediate } from './immediate.mjs';\nimport { mixNumber } from './number.mjs';\n\n// Linear color space blending\n// Explained https://www.youtube.com/watch?v=LKnqECcg6Gw\n// Demonstrated http://codepen.io/osublake/pen/xGVVaN\nconst mixLinearColor = (from, to, v) => {\n const fromExpo = from * from;\n const expo = v * (to * to - fromExpo) + fromExpo;\n return expo < 0 ? 0 : Math.sqrt(expo);\n};\nconst colorTypes = [hex, rgba, hsla];\nconst getColorType = (v) => colorTypes.find((type) => type.test(v));\nfunction asRGBA(color) {\n const type = getColorType(color);\n warning(Boolean(type), `'${color}' is not an animatable color. Use the equivalent color code instead.`, \"color-not-animatable\");\n if (!Boolean(type))\n return false;\n let model = type.parse(color);\n if (type === hsla) {\n // TODO Remove this cast - needed since Motion's stricter typing\n model = hslaToRgba(model);\n }\n return model;\n}\nconst mixColor = (from, to) => {\n const fromRGBA = asRGBA(from);\n const toRGBA = asRGBA(to);\n if (!fromRGBA || !toRGBA) {\n return mixImmediate(from, to);\n }\n const blended = { ...fromRGBA };\n return (v) => {\n blended.red = mixLinearColor(fromRGBA.red, toRGBA.red, v);\n blended.green = mixLinearColor(fromRGBA.green, toRGBA.green, v);\n blended.blue = mixLinearColor(fromRGBA.blue, toRGBA.blue, v);\n blended.alpha = mixNumber(fromRGBA.alpha, toRGBA.alpha, v);\n return rgba.transform(blended);\n };\n};\n\nexport { mixColor, mixLinearColor };\n","const invisibleValues = new Set([\"none\", \"hidden\"]);\n/**\n * Returns a function that, when provided a progress value between 0 and 1,\n * will return the \"none\" or \"hidden\" string only when the progress is that of\n * the origin or target.\n */\nfunction mixVisibility(origin, target) {\n if (invisibleValues.has(origin)) {\n return (p) => (p <= 0 ? origin : target);\n }\n else {\n return (p) => (p >= 1 ? target : origin);\n }\n}\n\nexport { invisibleValues, mixVisibility };\n","import { pipe, warning } from 'motion-utils';\nimport { isCSSVariableToken } from '../../animation/utils/is-css-variable.mjs';\nimport { color } from '../../value/types/color/index.mjs';\nimport { complex, analyseComplexValue } from '../../value/types/complex/index.mjs';\nimport { mixColor } from './color.mjs';\nimport { mixImmediate } from './immediate.mjs';\nimport { mixNumber as mixNumber$1 } from './number.mjs';\nimport { invisibleValues, mixVisibility } from './visibility.mjs';\n\nfunction mixNumber(a, b) {\n return (p) => mixNumber$1(a, b, p);\n}\nfunction getMixer(a) {\n if (typeof a === \"number\") {\n return mixNumber;\n }\n else if (typeof a === \"string\") {\n return isCSSVariableToken(a)\n ? mixImmediate\n : color.test(a)\n ? mixColor\n : mixComplex;\n }\n else if (Array.isArray(a)) {\n return mixArray;\n }\n else if (typeof a === \"object\") {\n return color.test(a) ? mixColor : mixObject;\n }\n return mixImmediate;\n}\nfunction mixArray(a, b) {\n const output = [...a];\n const numValues = output.length;\n const blendValue = a.map((v, i) => getMixer(v)(v, b[i]));\n return (p) => {\n for (let i = 0; i < numValues; i++) {\n output[i] = blendValue[i](p);\n }\n return output;\n };\n}\nfunction mixObject(a, b) {\n const output = { ...a, ...b };\n const blendValue = {};\n for (const key in output) {\n if (a[key] !== undefined && b[key] !== undefined) {\n blendValue[key] = getMixer(a[key])(a[key], b[key]);\n }\n }\n return (v) => {\n for (const key in blendValue) {\n output[key] = blendValue[key](v);\n }\n return output;\n };\n}\nfunction matchOrder(origin, target) {\n const orderedOrigin = [];\n const pointers = { color: 0, var: 0, number: 0 };\n for (let i = 0; i < target.values.length; i++) {\n const type = target.types[i];\n const originIndex = origin.indexes[type][pointers[type]];\n const originValue = origin.values[originIndex] ?? 0;\n orderedOrigin[i] = originValue;\n pointers[type]++;\n }\n return orderedOrigin;\n}\nconst mixComplex = (origin, target) => {\n const template = complex.createTransformer(target);\n const originStats = analyseComplexValue(origin);\n const targetStats = analyseComplexValue(target);\n const canInterpolate = originStats.indexes.var.length === targetStats.indexes.var.length &&\n originStats.indexes.color.length === targetStats.indexes.color.length &&\n originStats.indexes.number.length >= targetStats.indexes.number.length;\n if (canInterpolate) {\n if ((invisibleValues.has(origin) &&\n !targetStats.values.length) ||\n (invisibleValues.has(target) &&\n !originStats.values.length)) {\n return mixVisibility(origin, target);\n }\n return pipe(mixArray(matchOrder(originStats, targetStats), targetStats.values), template);\n }\n else {\n warning(true, `Complex values '${origin}' and '${target}' too different to mix. Ensure all colors are of the same type, and that each contains the same quantity of number and color values. Falling back to instant transition.`, \"complex-values-different\");\n return mixImmediate(origin, target);\n }\n};\n\nexport { getMixer, mixArray, mixComplex, mixObject };\n","import { getMixer } from './complex.mjs';\nimport { mixNumber } from './number.mjs';\n\nfunction mix(from, to, p) {\n if (typeof from === \"number\" &&\n typeof to === \"number\" &&\n typeof p === \"number\") {\n return mixNumber(from, to, p);\n }\n const mixer = getMixer(from);\n return mixer(from, to);\n}\n\nexport { mix };\n","import { time } from '../../frameloop/sync-time.mjs';\nimport { frame, cancelFrame, frameData } from '../../frameloop/frame.mjs';\n\nconst frameloopDriver = (update) => {\n const passTimestamp = ({ timestamp }) => update(timestamp);\n return {\n start: (keepAlive = true) => frame.update(passTimestamp, keepAlive),\n stop: () => cancelFrame(passTimestamp),\n /**\n * If we're processing this frame we can use the\n * framelocked timestamp to keep things in sync.\n */\n now: () => (frameData.isProcessing ? frameData.timestamp : time.now()),\n };\n};\n\nexport { frameloopDriver };\n","const generateLinearEasing = (easing, duration, // as milliseconds\nresolution = 10 // as milliseconds\n) => {\n let points = \"\";\n const numPoints = Math.max(Math.round(duration / resolution), 2);\n for (let i = 0; i < numPoints; i++) {\n points += Math.round(easing(i / (numPoints - 1)) * 10000) / 10000 + \", \";\n }\n return `linear(${points.substring(0, points.length - 2)})`;\n};\n\nexport { generateLinearEasing };\n","/**\n * Implement a practical max duration for keyframe generation\n * to prevent infinite loops\n */\nconst maxGeneratorDuration = 20000;\nfunction calcGeneratorDuration(generator) {\n let duration = 0;\n const timeStep = 50;\n let state = generator.next(duration);\n while (!state.done && duration < maxGeneratorDuration) {\n duration += timeStep;\n state = generator.next(duration);\n }\n return duration >= maxGeneratorDuration ? Infinity : duration;\n}\n\nexport { calcGeneratorDuration, maxGeneratorDuration };\n","import { millisecondsToSeconds } from 'motion-utils';\nimport { calcGeneratorDuration, maxGeneratorDuration } from './calc-duration.mjs';\n\n/**\n * Create a progress => progress easing function from a generator.\n */\nfunction createGeneratorEasing(options, scale = 100, createGenerator) {\n const generator = createGenerator({ ...options, keyframes: [0, scale] });\n const duration = Math.min(calcGeneratorDuration(generator), maxGeneratorDuration);\n return {\n type: \"keyframes\",\n ease: (progress) => {\n return generator.next(duration * progress).value / scale;\n },\n duration: millisecondsToSeconds(duration),\n };\n}\n\nexport { createGeneratorEasing };\n","import { velocityPerSecond } from 'motion-utils';\n\nconst velocitySampleDuration = 5; // ms\nfunction calcGeneratorVelocity(resolveValue, t, current) {\n const prevT = Math.max(t - velocitySampleDuration, 0);\n return velocityPerSecond(current - resolveValue(prevT), t - prevT);\n}\n\nexport { calcGeneratorVelocity };\n","const springDefaults = {\n // Default spring physics\n stiffness: 100,\n damping: 10,\n mass: 1.0,\n velocity: 0.0,\n // Default duration/bounce-based options\n duration: 800, // in ms\n bounce: 0.3,\n visualDuration: 0.3, // in seconds\n // Rest thresholds\n restSpeed: {\n granular: 0.01,\n default: 2,\n },\n restDelta: {\n granular: 0.005,\n default: 0.5,\n },\n // Limits\n minDuration: 0.01, // in seconds\n maxDuration: 10.0, // in seconds\n minDamping: 0.05,\n maxDamping: 1,\n};\n\nexport { springDefaults };\n","import { warning, secondsToMilliseconds, clamp, millisecondsToSeconds } from 'motion-utils';\nimport { springDefaults } from './defaults.mjs';\n\nconst safeMin = 0.001;\nfunction findSpring({ duration = springDefaults.duration, bounce = springDefaults.bounce, velocity = springDefaults.velocity, mass = springDefaults.mass, }) {\n let envelope;\n let derivative;\n warning(duration <= secondsToMilliseconds(springDefaults.maxDuration), \"Spring duration must be 10 seconds or less\", \"spring-duration-limit\");\n let dampingRatio = 1 - bounce;\n /**\n * Restrict dampingRatio and duration to within acceptable ranges.\n */\n dampingRatio = clamp(springDefaults.minDamping, springDefaults.maxDamping, dampingRatio);\n duration = clamp(springDefaults.minDuration, springDefaults.maxDuration, millisecondsToSeconds(duration));\n if (dampingRatio < 1) {\n /**\n * Underdamped spring\n */\n envelope = (undampedFreq) => {\n const exponentialDecay = undampedFreq * dampingRatio;\n const delta = exponentialDecay * duration;\n const a = exponentialDecay - velocity;\n const b = calcAngularFreq(undampedFreq, dampingRatio);\n const c = Math.exp(-delta);\n return safeMin - (a / b) * c;\n };\n derivative = (undampedFreq) => {\n const exponentialDecay = undampedFreq * dampingRatio;\n const delta = exponentialDecay * duration;\n const d = delta * velocity + velocity;\n const e = Math.pow(dampingRatio, 2) * Math.pow(undampedFreq, 2) * duration;\n const f = Math.exp(-delta);\n const g = calcAngularFreq(Math.pow(undampedFreq, 2), dampingRatio);\n const factor = -envelope(undampedFreq) + safeMin > 0 ? -1 : 1;\n return (factor * ((d - e) * f)) / g;\n };\n }\n else {\n /**\n * Critically-damped spring\n */\n envelope = (undampedFreq) => {\n const a = Math.exp(-undampedFreq * duration);\n const b = (undampedFreq - velocity) * duration + 1;\n return -safeMin + a * b;\n };\n derivative = (undampedFreq) => {\n const a = Math.exp(-undampedFreq * duration);\n const b = (velocity - undampedFreq) * (duration * duration);\n return a * b;\n };\n }\n const initialGuess = 5 / duration;\n const undampedFreq = approximateRoot(envelope, derivative, initialGuess);\n duration = secondsToMilliseconds(duration);\n if (isNaN(undampedFreq)) {\n return {\n stiffness: springDefaults.stiffness,\n damping: springDefaults.damping,\n duration,\n };\n }\n else {\n const stiffness = Math.pow(undampedFreq, 2) * mass;\n return {\n stiffness,\n damping: dampingRatio * 2 * Math.sqrt(mass * stiffness),\n duration,\n };\n }\n}\nconst rootIterations = 12;\nfunction approximateRoot(envelope, derivative, initialGuess) {\n let result = initialGuess;\n for (let i = 1; i < rootIterations; i++) {\n result = result - envelope(result) / derivative(result);\n }\n return result;\n}\nfunction calcAngularFreq(undampedFreq, dampingRatio) {\n return undampedFreq * Math.sqrt(1 - dampingRatio * dampingRatio);\n}\n\nexport { calcAngularFreq, findSpring };\n","import { millisecondsToSeconds, secondsToMilliseconds, clamp } from 'motion-utils';\nimport { generateLinearEasing } from '../../waapi/utils/linear.mjs';\nimport { calcGeneratorDuration, maxGeneratorDuration } from '../utils/calc-duration.mjs';\nimport { createGeneratorEasing } from '../utils/create-generator-easing.mjs';\nimport { calcGeneratorVelocity } from '../utils/velocity.mjs';\nimport { springDefaults } from './defaults.mjs';\nimport { findSpring, calcAngularFreq } from './find.mjs';\n\nconst durationKeys = [\"duration\", \"bounce\"];\nconst physicsKeys = [\"stiffness\", \"damping\", \"mass\"];\nfunction isSpringType(options, keys) {\n return keys.some((key) => options[key] !== undefined);\n}\nfunction getSpringOptions(options) {\n let springOptions = {\n velocity: springDefaults.velocity,\n stiffness: springDefaults.stiffness,\n damping: springDefaults.damping,\n mass: springDefaults.mass,\n isResolvedFromDuration: false,\n ...options,\n };\n // stiffness/damping/mass overrides duration/bounce\n if (!isSpringType(options, physicsKeys) &&\n isSpringType(options, durationKeys)) {\n if (options.visualDuration) {\n const visualDuration = options.visualDuration;\n const root = (2 * Math.PI) / (visualDuration * 1.2);\n const stiffness = root * root;\n const damping = 2 *\n clamp(0.05, 1, 1 - (options.bounce || 0)) *\n Math.sqrt(stiffness);\n springOptions = {\n ...springOptions,\n mass: springDefaults.mass,\n stiffness,\n damping,\n };\n }\n else {\n const derived = findSpring(options);\n springOptions = {\n ...springOptions,\n ...derived,\n mass: springDefaults.mass,\n };\n springOptions.isResolvedFromDuration = true;\n }\n }\n return springOptions;\n}\nfunction spring(optionsOrVisualDuration = springDefaults.visualDuration, bounce = springDefaults.bounce) {\n const options = typeof optionsOrVisualDuration !== \"object\"\n ? {\n visualDuration: optionsOrVisualDuration,\n keyframes: [0, 1],\n bounce,\n }\n : optionsOrVisualDuration;\n let { restSpeed, restDelta } = options;\n const origin = options.keyframes[0];\n const target = options.keyframes[options.keyframes.length - 1];\n /**\n * This is the Iterator-spec return value. We ensure it's mutable rather than using a generator\n * to reduce GC during animation.\n */\n const state = { done: false, value: origin };\n const { stiffness, damping, mass, duration, velocity, isResolvedFromDuration, } = getSpringOptions({\n ...options,\n velocity: -millisecondsToSeconds(options.velocity || 0),\n });\n const initialVelocity = velocity || 0.0;\n const dampingRatio = damping / (2 * Math.sqrt(stiffness * mass));\n const initialDelta = target - origin;\n const undampedAngularFreq = millisecondsToSeconds(Math.sqrt(stiffness / mass));\n /**\n * If we're working on a granular scale, use smaller defaults for determining\n * when the spring is finished.\n *\n * These defaults have been selected emprically based on what strikes a good\n * ratio between feeling good and finishing as soon as changes are imperceptible.\n */\n const isGranularScale = Math.abs(initialDelta) < 5;\n restSpeed || (restSpeed = isGranularScale\n ? springDefaults.restSpeed.granular\n : springDefaults.restSpeed.default);\n restDelta || (restDelta = isGranularScale\n ? springDefaults.restDelta.granular\n : springDefaults.restDelta.default);\n let resolveSpring;\n if (dampingRatio < 1) {\n const angularFreq = calcAngularFreq(undampedAngularFreq, dampingRatio);\n // Underdamped spring\n resolveSpring = (t) => {\n const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n return (target -\n envelope *\n (((initialVelocity +\n dampingRatio * undampedAngularFreq * initialDelta) /\n angularFreq) *\n Math.sin(angularFreq * t) +\n initialDelta * Math.cos(angularFreq * t)));\n };\n }\n else if (dampingRatio === 1) {\n // Critically damped spring\n resolveSpring = (t) => target -\n Math.exp(-undampedAngularFreq * t) *\n (initialDelta +\n (initialVelocity + undampedAngularFreq * initialDelta) * t);\n }\n else {\n // Overdamped spring\n const dampedAngularFreq = undampedAngularFreq * Math.sqrt(dampingRatio * dampingRatio - 1);\n resolveSpring = (t) => {\n const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n // When performing sinh or cosh values can hit Infinity so we cap them here\n const freqForT = Math.min(dampedAngularFreq * t, 300);\n return (target -\n (envelope *\n ((initialVelocity +\n dampingRatio * undampedAngularFreq * initialDelta) *\n Math.sinh(freqForT) +\n dampedAngularFreq *\n initialDelta *\n Math.cosh(freqForT))) /\n dampedAngularFreq);\n };\n }\n const generator = {\n calculatedDuration: isResolvedFromDuration ? duration || null : null,\n next: (t) => {\n const current = resolveSpring(t);\n if (!isResolvedFromDuration) {\n let currentVelocity = t === 0 ? initialVelocity : 0.0;\n /**\n * We only need to calculate velocity for under-damped springs\n * as over- and critically-damped springs can't overshoot, so\n * checking only for displacement is enough.\n */\n if (dampingRatio < 1) {\n currentVelocity =\n t === 0\n ? secondsToMilliseconds(initialVelocity)\n : calcGeneratorVelocity(resolveSpring, t, current);\n }\n const isBelowVelocityThreshold = Math.abs(currentVelocity) <= restSpeed;\n const isBelowDisplacementThreshold = Math.abs(target - current) <= restDelta;\n state.done =\n isBelowVelocityThreshold && isBelowDisplacementThreshold;\n }\n else {\n state.done = t >= duration;\n }\n state.value = state.done ? target : current;\n return state;\n },\n toString: () => {\n const calculatedDuration = Math.min(calcGeneratorDuration(generator), maxGeneratorDuration);\n const easing = generateLinearEasing((progress) => generator.next(calculatedDuration * progress).value, calculatedDuration, 30);\n return calculatedDuration + \"ms \" + easing;\n },\n toTransition: () => { },\n };\n return generator;\n}\nspring.applyToOptions = (options) => {\n const generatorOptions = createGeneratorEasing(options, 100, spring);\n options.ease = generatorOptions.ease;\n options.duration = secondsToMilliseconds(generatorOptions.duration);\n options.type = \"keyframes\";\n return options;\n};\n\nexport { spring };\n","import { spring } from './spring/index.mjs';\nimport { calcGeneratorVelocity } from './utils/velocity.mjs';\n\nfunction inertia({ keyframes, velocity = 0.0, power = 0.8, timeConstant = 325, bounceDamping = 10, bounceStiffness = 500, modifyTarget, min, max, restDelta = 0.5, restSpeed, }) {\n const origin = keyframes[0];\n const state = {\n done: false,\n value: origin,\n };\n const isOutOfBounds = (v) => (min !== undefined && v < min) || (max !== undefined && v > max);\n const nearestBoundary = (v) => {\n if (min === undefined)\n return max;\n if (max === undefined)\n return min;\n return Math.abs(min - v) < Math.abs(max - v) ? min : max;\n };\n let amplitude = power * velocity;\n const ideal = origin + amplitude;\n const target = modifyTarget === undefined ? ideal : modifyTarget(ideal);\n /**\n * If the target has changed we need to re-calculate the amplitude, otherwise\n * the animation will start from the wrong position.\n */\n if (target !== ideal)\n amplitude = target - origin;\n const calcDelta = (t) => -amplitude * Math.exp(-t / timeConstant);\n const calcLatest = (t) => target + calcDelta(t);\n const applyFriction = (t) => {\n const delta = calcDelta(t);\n const latest = calcLatest(t);\n state.done = Math.abs(delta) <= restDelta;\n state.value = state.done ? target : latest;\n };\n /**\n * Ideally this would resolve for t in a stateless way, we could\n * do that by always precalculating the animation but as we know\n * this will be done anyway we can assume that spring will\n * be discovered during that.\n */\n let timeReachedBoundary;\n let spring$1;\n const checkCatchBoundary = (t) => {\n if (!isOutOfBounds(state.value))\n return;\n timeReachedBoundary = t;\n spring$1 = spring({\n keyframes: [state.value, nearestBoundary(state.value)],\n velocity: calcGeneratorVelocity(calcLatest, t, state.value), // TODO: This should be passing * 1000\n damping: bounceDamping,\n stiffness: bounceStiffness,\n restDelta,\n restSpeed,\n });\n };\n checkCatchBoundary(0);\n return {\n calculatedDuration: null,\n next: (t) => {\n /**\n * We need to resolve the friction to figure out if we need a\n * spring but we don't want to do this twice per frame. So here\n * we flag if we updated for this frame and later if we did\n * we can skip doing it again.\n */\n let hasUpdatedFrame = false;\n if (!spring$1 && timeReachedBoundary === undefined) {\n hasUpdatedFrame = true;\n applyFriction(t);\n checkCatchBoundary(t);\n }\n /**\n * If we have a spring and the provided t is beyond the moment the friction\n * animation crossed the min/max boundary, use the spring.\n */\n if (timeReachedBoundary !== undefined && t >= timeReachedBoundary) {\n return spring$1.next(t - timeReachedBoundary);\n }\n else {\n !hasUpdatedFrame && applyFriction(t);\n return state;\n }\n },\n };\n}\n\nexport { inertia };\n","import { invariant, clamp, MotionGlobalConfig, noop, pipe, progress } from 'motion-utils';\nimport { mix } from './mix/index.mjs';\n\nfunction createMixers(output, ease, customMixer) {\n const mixers = [];\n const mixerFactory = customMixer || MotionGlobalConfig.mix || mix;\n const numMixers = output.length - 1;\n for (let i = 0; i < numMixers; i++) {\n let mixer = mixerFactory(output[i], output[i + 1]);\n if (ease) {\n const easingFunction = Array.isArray(ease) ? ease[i] || noop : ease;\n mixer = pipe(easingFunction, mixer);\n }\n mixers.push(mixer);\n }\n return mixers;\n}\n/**\n * Create a function that maps from a numerical input array to a generic output array.\n *\n * Accepts:\n * - Numbers\n * - Colors (hex, hsl, hsla, rgb, rgba)\n * - Complex (combinations of one or more numbers or strings)\n *\n * ```jsx\n * const mixColor = interpolate([0, 1], ['#fff', '#000'])\n *\n * mixColor(0.5) // 'rgba(128, 128, 128, 1)'\n * ```\n *\n * TODO Revisit this approach once we've moved to data models for values,\n * probably not needed to pregenerate mixer functions.\n *\n * @public\n */\nfunction interpolate(input, output, { clamp: isClamp = true, ease, mixer } = {}) {\n const inputLength = input.length;\n invariant(inputLength === output.length, \"Both input and output ranges must be the same length\", \"range-length\");\n /**\n * If we're only provided a single input, we can just make a function\n * that returns the output.\n */\n if (inputLength === 1)\n return () => output[0];\n if (inputLength === 2 && output[0] === output[1])\n return () => output[1];\n const isZeroDeltaRange = input[0] === input[1];\n // If input runs highest -> lowest, reverse both arrays\n if (input[0] > input[inputLength - 1]) {\n input = [...input].reverse();\n output = [...output].reverse();\n }\n const mixers = createMixers(output, ease, mixer);\n const numMixers = mixers.length;\n const interpolator = (v) => {\n if (isZeroDeltaRange && v < input[0])\n return output[0];\n let i = 0;\n if (numMixers > 1) {\n for (; i < input.length - 2; i++) {\n if (v < input[i + 1])\n break;\n }\n }\n const progressInRange = progress(input[i], input[i + 1], v);\n return mixers[i](progressInRange);\n };\n return isClamp\n ? (v) => interpolator(clamp(input[0], input[inputLength - 1], v))\n : interpolator;\n}\n\nexport { interpolate };\n","import { progress } from 'motion-utils';\nimport { mixNumber } from '../../../utils/mix/number.mjs';\n\nfunction fillOffset(offset, remaining) {\n const min = offset[offset.length - 1];\n for (let i = 1; i <= remaining; i++) {\n const offsetProgress = progress(0, remaining, i);\n offset.push(mixNumber(min, 1, offsetProgress));\n }\n}\n\nexport { fillOffset };\n","import { fillOffset } from './fill.mjs';\n\nfunction defaultOffset(arr) {\n const offset = [0];\n fillOffset(offset, arr.length - 1);\n return offset;\n}\n\nexport { defaultOffset };\n","function convertOffsetToTimes(offset, duration) {\n return offset.map((o) => o * duration);\n}\n\nexport { convertOffsetToTimes };\n","import { easeInOut, isEasingArray, easingDefinitionToFunction } from 'motion-utils';\nimport { interpolate } from '../../utils/interpolate.mjs';\nimport { defaultOffset } from '../keyframes/offsets/default.mjs';\nimport { convertOffsetToTimes } from '../keyframes/offsets/time.mjs';\n\nfunction defaultEasing(values, easing) {\n return values.map(() => easing || easeInOut).splice(0, values.length - 1);\n}\nfunction keyframes({ duration = 300, keyframes: keyframeValues, times, ease = \"easeInOut\", }) {\n /**\n * Easing functions can be externally defined as strings. Here we convert them\n * into actual functions.\n */\n const easingFunctions = isEasingArray(ease)\n ? ease.map(easingDefinitionToFunction)\n : easingDefinitionToFunction(ease);\n /**\n * This is the Iterator-spec return value. We ensure it's mutable rather than using a generator\n * to reduce GC during animation.\n */\n const state = {\n done: false,\n value: keyframeValues[0],\n };\n /**\n * Create a times array based on the provided 0-1 offsets\n */\n const absoluteTimes = convertOffsetToTimes(\n // Only use the provided offsets if they're the correct length\n // TODO Maybe we should warn here if there's a length mismatch\n times && times.length === keyframeValues.length\n ? times\n : defaultOffset(keyframeValues), duration);\n const mapTimeToKeyframe = interpolate(absoluteTimes, keyframeValues, {\n ease: Array.isArray(easingFunctions)\n ? easingFunctions\n : defaultEasing(keyframeValues, easingFunctions),\n });\n return {\n calculatedDuration: duration,\n next: (t) => {\n state.value = mapTimeToKeyframe(t);\n state.done = t >= duration;\n return state;\n },\n };\n}\n\nexport { defaultEasing, keyframes };\n","const isNotNull = (value) => value !== null;\nfunction getFinalKeyframe(keyframes, { repeat, repeatType = \"loop\" }, finalKeyframe, speed = 1) {\n const resolvedKeyframes = keyframes.filter(isNotNull);\n const useFirstKeyframe = speed < 0 || (repeat && repeatType !== \"loop\" && repeat % 2 === 1);\n const index = useFirstKeyframe ? 0 : resolvedKeyframes.length - 1;\n return !index || finalKeyframe === undefined\n ? resolvedKeyframes[index]\n : finalKeyframe;\n}\n\nexport { getFinalKeyframe };\n","import { inertia } from '../generators/inertia.mjs';\nimport { keyframes } from '../generators/keyframes.mjs';\nimport { spring } from '../generators/spring/index.mjs';\n\nconst transitionTypeMap = {\n decay: inertia,\n inertia,\n tween: keyframes,\n keyframes: keyframes,\n spring,\n};\nfunction replaceTransitionType(transition) {\n if (typeof transition.type === \"string\") {\n transition.type = transitionTypeMap[transition.type];\n }\n}\n\nexport { replaceTransitionType };\n","class WithPromise {\n constructor() {\n this.updateFinished();\n }\n get finished() {\n return this._finished;\n }\n updateFinished() {\n this._finished = new Promise((resolve) => {\n this.resolve = resolve;\n });\n }\n notifyFinished() {\n this.resolve();\n }\n /**\n * Allows the animation to be awaited.\n *\n * @deprecated Use `finished` instead.\n */\n then(onResolve, onReject) {\n return this.finished.then(onResolve, onReject);\n }\n}\n\nexport { WithPromise };\n","import { invariant, pipe, clamp, millisecondsToSeconds, secondsToMilliseconds } from 'motion-utils';\nimport { time } from '../frameloop/sync-time.mjs';\nimport { activeAnimations } from '../stats/animation-count.mjs';\nimport { mix } from '../utils/mix/index.mjs';\nimport { frameloopDriver } from './drivers/frame.mjs';\nimport { inertia } from './generators/inertia.mjs';\nimport { keyframes } from './generators/keyframes.mjs';\nimport { calcGeneratorDuration } from './generators/utils/calc-duration.mjs';\nimport { getFinalKeyframe } from './keyframes/get-final.mjs';\nimport { replaceTransitionType } from './utils/replace-transition-type.mjs';\nimport { WithPromise } from './utils/WithPromise.mjs';\n\nconst percentToProgress = (percent) => percent / 100;\nclass JSAnimation extends WithPromise {\n constructor(options) {\n super();\n this.state = \"idle\";\n this.startTime = null;\n this.isStopped = false;\n /**\n * The current time of the animation.\n */\n this.currentTime = 0;\n /**\n * The time at which the animation was paused.\n */\n this.holdTime = null;\n /**\n * Playback speed as a factor. 0 would be stopped, -1 reverse and 2 double speed.\n */\n this.playbackSpeed = 1;\n /**\n * This method is bound to the instance to fix a pattern where\n * animation.stop is returned as a reference from a useEffect.\n */\n this.stop = () => {\n const { motionValue } = this.options;\n if (motionValue && motionValue.updatedAt !== time.now()) {\n this.tick(time.now());\n }\n this.isStopped = true;\n if (this.state === \"idle\")\n return;\n this.teardown();\n this.options.onStop?.();\n };\n activeAnimations.mainThread++;\n this.options = options;\n this.initAnimation();\n this.play();\n if (options.autoplay === false)\n this.pause();\n }\n initAnimation() {\n const { options } = this;\n replaceTransitionType(options);\n const { type = keyframes, repeat = 0, repeatDelay = 0, repeatType, velocity = 0, } = options;\n let { keyframes: keyframes$1 } = options;\n const generatorFactory = type || keyframes;\n if (process.env.NODE_ENV !== \"production\" &&\n generatorFactory !== keyframes) {\n invariant(keyframes$1.length <= 2, `Only two keyframes currently supported with spring and inertia animations. Trying to animate ${keyframes$1}`, \"spring-two-frames\");\n }\n if (generatorFactory !== keyframes &&\n typeof keyframes$1[0] !== \"number\") {\n this.mixKeyframes = pipe(percentToProgress, mix(keyframes$1[0], keyframes$1[1]));\n keyframes$1 = [0, 100];\n }\n const generator = generatorFactory({ ...options, keyframes: keyframes$1 });\n /**\n * If we have a mirror repeat type we need to create a second generator that outputs the\n * mirrored (not reversed) animation and later ping pong between the two generators.\n */\n if (repeatType === \"mirror\") {\n this.mirroredGenerator = generatorFactory({\n ...options,\n keyframes: [...keyframes$1].reverse(),\n velocity: -velocity,\n });\n }\n /**\n * If duration is undefined and we have repeat options,\n * we need to calculate a duration from the generator.\n *\n * We set it to the generator itself to cache the duration.\n * Any timeline resolver will need to have already precalculated\n * the duration by this step.\n */\n if (generator.calculatedDuration === null) {\n generator.calculatedDuration = calcGeneratorDuration(generator);\n }\n const { calculatedDuration } = generator;\n this.calculatedDuration = calculatedDuration;\n this.resolvedDuration = calculatedDuration + repeatDelay;\n this.totalDuration = this.resolvedDuration * (repeat + 1) - repeatDelay;\n this.generator = generator;\n }\n updateTime(timestamp) {\n const animationTime = Math.round(timestamp - this.startTime) * this.playbackSpeed;\n // Update currentTime\n if (this.holdTime !== null) {\n this.currentTime = this.holdTime;\n }\n else {\n // Rounding the time because floating point arithmetic is not always accurate, e.g. 3000.367 - 1000.367 =\n // 2000.0000000000002. This is a problem when we are comparing the currentTime with the duration, for\n // example.\n this.currentTime = animationTime;\n }\n }\n tick(timestamp, sample = false) {\n const { generator, totalDuration, mixKeyframes, mirroredGenerator, resolvedDuration, calculatedDuration, } = this;\n if (this.startTime === null)\n return generator.next(0);\n const { delay = 0, keyframes, repeat, repeatType, repeatDelay, type, onUpdate, finalKeyframe, } = this.options;\n /**\n * requestAnimationFrame timestamps can come through as lower than\n * the startTime as set by performance.now(). Here we prevent this,\n * though in the future it could be possible to make setting startTime\n * a pending operation that gets resolved here.\n */\n if (this.speed > 0) {\n this.startTime = Math.min(this.startTime, timestamp);\n }\n else if (this.speed < 0) {\n this.startTime = Math.min(timestamp - totalDuration / this.speed, this.startTime);\n }\n if (sample) {\n this.currentTime = timestamp;\n }\n else {\n this.updateTime(timestamp);\n }\n // Rebase on delay\n const timeWithoutDelay = this.currentTime - delay * (this.playbackSpeed >= 0 ? 1 : -1);\n const isInDelayPhase = this.playbackSpeed >= 0\n ? timeWithoutDelay < 0\n : timeWithoutDelay > totalDuration;\n this.currentTime = Math.max(timeWithoutDelay, 0);\n // If this animation has finished, set the current time to the total duration.\n if (this.state === \"finished\" && this.holdTime === null) {\n this.currentTime = totalDuration;\n }\n let elapsed = this.currentTime;\n let frameGenerator = generator;\n if (repeat) {\n /**\n * Get the current progress (0-1) of the animation. If t is >\n * than duration we'll get values like 2.5 (midway through the\n * third iteration)\n */\n const progress = Math.min(this.currentTime, totalDuration) / resolvedDuration;\n /**\n * Get the current iteration (0 indexed). For instance the floor of\n * 2.5 is 2.\n */\n let currentIteration = Math.floor(progress);\n /**\n * Get the current progress of the iteration by taking the remainder\n * so 2.5 is 0.5 through iteration 2\n */\n let iterationProgress = progress % 1.0;\n /**\n * If iteration progress is 1 we count that as the end\n * of the previous iteration.\n */\n if (!iterationProgress && progress >= 1) {\n iterationProgress = 1;\n }\n iterationProgress === 1 && currentIteration--;\n currentIteration = Math.min(currentIteration, repeat + 1);\n /**\n * Reverse progress if we're not running in \"normal\" direction\n */\n const isOddIteration = Boolean(currentIteration % 2);\n if (isOddIteration) {\n if (repeatType === \"reverse\") {\n iterationProgress = 1 - iterationProgress;\n if (repeatDelay) {\n iterationProgress -= repeatDelay / resolvedDuration;\n }\n }\n else if (repeatType === \"mirror\") {\n frameGenerator = mirroredGenerator;\n }\n }\n elapsed = clamp(0, 1, iterationProgress) * resolvedDuration;\n }\n /**\n * If we're in negative time, set state as the initial keyframe.\n * This prevents delay: x, duration: 0 animations from finishing\n * instantly.\n */\n const state = isInDelayPhase\n ? { done: false, value: keyframes[0] }\n : frameGenerator.next(elapsed);\n if (mixKeyframes) {\n state.value = mixKeyframes(state.value);\n }\n let { done } = state;\n if (!isInDelayPhase && calculatedDuration !== null) {\n done =\n this.playbackSpeed >= 0\n ? this.currentTime >= totalDuration\n : this.currentTime <= 0;\n }\n const isAnimationFinished = this.holdTime === null &&\n (this.state === \"finished\" || (this.state === \"running\" && done));\n // TODO: The exception for inertia could be cleaner here\n if (isAnimationFinished && type !== inertia) {\n state.value = getFinalKeyframe(keyframes, this.options, finalKeyframe, this.speed);\n }\n if (onUpdate) {\n onUpdate(state.value);\n }\n if (isAnimationFinished) {\n this.finish();\n }\n return state;\n }\n /**\n * Allows the returned animation to be awaited or promise-chained. Currently\n * resolves when the animation finishes at all but in a future update could/should\n * reject if its cancels.\n */\n then(resolve, reject) {\n return this.finished.then(resolve, reject);\n }\n get duration() {\n return millisecondsToSeconds(this.calculatedDuration);\n }\n get iterationDuration() {\n const { delay = 0 } = this.options || {};\n return this.duration + millisecondsToSeconds(delay);\n }\n get time() {\n return millisecondsToSeconds(this.currentTime);\n }\n set time(newTime) {\n newTime = secondsToMilliseconds(newTime);\n this.currentTime = newTime;\n if (this.startTime === null ||\n this.holdTime !== null ||\n this.playbackSpeed === 0) {\n this.holdTime = newTime;\n }\n else if (this.driver) {\n this.startTime = this.driver.now() - newTime / this.playbackSpeed;\n }\n this.driver?.start(false);\n }\n get speed() {\n return this.playbackSpeed;\n }\n set speed(newSpeed) {\n this.updateTime(time.now());\n const hasChanged = this.playbackSpeed !== newSpeed;\n this.playbackSpeed = newSpeed;\n if (hasChanged) {\n this.time = millisecondsToSeconds(this.currentTime);\n }\n }\n play() {\n if (this.isStopped)\n return;\n const { driver = frameloopDriver, startTime } = this.options;\n if (!this.driver) {\n this.driver = driver((timestamp) => this.tick(timestamp));\n }\n this.options.onPlay?.();\n const now = this.driver.now();\n if (this.state === \"finished\") {\n this.updateFinished();\n this.startTime = now;\n }\n else if (this.holdTime !== null) {\n this.startTime = now - this.holdTime;\n }\n else if (!this.startTime) {\n this.startTime = startTime ?? now;\n }\n if (this.state === \"finished\" && this.speed < 0) {\n this.startTime += this.calculatedDuration;\n }\n this.holdTime = null;\n /**\n * Set playState to running only after we've used it in\n * the previous logic.\n */\n this.state = \"running\";\n this.driver.start();\n }\n pause() {\n this.state = \"paused\";\n this.updateTime(time.now());\n this.holdTime = this.currentTime;\n }\n complete() {\n if (this.state !== \"running\") {\n this.play();\n }\n this.state = \"finished\";\n this.holdTime = null;\n }\n finish() {\n this.notifyFinished();\n this.teardown();\n this.state = \"finished\";\n this.options.onComplete?.();\n }\n cancel() {\n this.holdTime = null;\n this.startTime = 0;\n this.tick(0);\n this.teardown();\n this.options.onCancel?.();\n }\n teardown() {\n this.state = \"idle\";\n this.stopDriver();\n this.startTime = this.holdTime = null;\n activeAnimations.mainThread--;\n }\n stopDriver() {\n if (!this.driver)\n return;\n this.driver.stop();\n this.driver = undefined;\n }\n sample(sampleTime) {\n this.startTime = 0;\n return this.tick(sampleTime, true);\n }\n attachTimeline(timeline) {\n if (this.options.allowFlatten) {\n this.options.type = \"keyframes\";\n this.options.ease = \"linear\";\n this.initAnimation();\n }\n this.driver?.stop();\n return timeline.observe(this);\n }\n}\n// Legacy function support\nfunction animateValue(options) {\n return new JSAnimation(options);\n}\n\nexport { JSAnimation, animateValue };\n","function fillWildcards(keyframes) {\n for (let i = 1; i < keyframes.length; i++) {\n keyframes[i] ?? (keyframes[i] = keyframes[i - 1]);\n }\n}\n\nexport { fillWildcards };\n","const radToDeg = (rad) => (rad * 180) / Math.PI;\nconst rotate = (v) => {\n const angle = radToDeg(Math.atan2(v[1], v[0]));\n return rebaseAngle(angle);\n};\nconst matrix2dParsers = {\n x: 4,\n y: 5,\n translateX: 4,\n translateY: 5,\n scaleX: 0,\n scaleY: 3,\n scale: (v) => (Math.abs(v[0]) + Math.abs(v[3])) / 2,\n rotate,\n rotateZ: rotate,\n skewX: (v) => radToDeg(Math.atan(v[1])),\n skewY: (v) => radToDeg(Math.atan(v[2])),\n skew: (v) => (Math.abs(v[1]) + Math.abs(v[2])) / 2,\n};\nconst rebaseAngle = (angle) => {\n angle = angle % 360;\n if (angle < 0)\n angle += 360;\n return angle;\n};\nconst rotateZ = rotate;\nconst scaleX = (v) => Math.sqrt(v[0] * v[0] + v[1] * v[1]);\nconst scaleY = (v) => Math.sqrt(v[4] * v[4] + v[5] * v[5]);\nconst matrix3dParsers = {\n x: 12,\n y: 13,\n z: 14,\n translateX: 12,\n translateY: 13,\n translateZ: 14,\n scaleX,\n scaleY,\n scale: (v) => (scaleX(v) + scaleY(v)) / 2,\n rotateX: (v) => rebaseAngle(radToDeg(Math.atan2(v[6], v[5]))),\n rotateY: (v) => rebaseAngle(radToDeg(Math.atan2(-v[2], v[0]))),\n rotateZ,\n rotate: rotateZ,\n skewX: (v) => radToDeg(Math.atan(v[4])),\n skewY: (v) => radToDeg(Math.atan(v[1])),\n skew: (v) => (Math.abs(v[1]) + Math.abs(v[4])) / 2,\n};\nfunction defaultTransformValue(name) {\n return name.includes(\"scale\") ? 1 : 0;\n}\nfunction parseValueFromTransform(transform, name) {\n if (!transform || transform === \"none\") {\n return defaultTransformValue(name);\n }\n const matrix3dMatch = transform.match(/^matrix3d\\(([-\\d.e\\s,]+)\\)$/u);\n let parsers;\n let match;\n if (matrix3dMatch) {\n parsers = matrix3dParsers;\n match = matrix3dMatch;\n }\n else {\n const matrix2dMatch = transform.match(/^matrix\\(([-\\d.e\\s,]+)\\)$/u);\n parsers = matrix2dParsers;\n match = matrix2dMatch;\n }\n if (!match) {\n return defaultTransformValue(name);\n }\n const valueParser = parsers[name];\n const values = match[1].split(\",\").map(convertTransformToNumber);\n return typeof valueParser === \"function\"\n ? valueParser(values)\n : values[valueParser];\n}\nconst readTransformValue = (instance, name) => {\n const { transform = \"none\" } = getComputedStyle(instance);\n return parseValueFromTransform(transform, name);\n};\nfunction convertTransformToNumber(value) {\n return parseFloat(value.trim());\n}\n\nexport { defaultTransformValue, parseValueFromTransform, readTransformValue };\n","/**\n * Generate a list of every possible transform key.\n */\nconst transformPropOrder = [\n \"transformPerspective\",\n \"x\",\n \"y\",\n \"z\",\n \"translateX\",\n \"translateY\",\n \"translateZ\",\n \"scale\",\n \"scaleX\",\n \"scaleY\",\n \"rotate\",\n \"rotateX\",\n \"rotateY\",\n \"rotateZ\",\n \"skew\",\n \"skewX\",\n \"skewY\",\n];\n/**\n * A quick lookup for transform props.\n */\nconst transformProps = /*@__PURE__*/ (() => new Set(transformPropOrder))();\n\nexport { transformPropOrder, transformProps };\n","import { parseValueFromTransform } from '../../../render/dom/parse-transform.mjs';\nimport { transformPropOrder } from '../../../render/utils/keys-transform.mjs';\nimport { number } from '../../../value/types/numbers/index.mjs';\nimport { px } from '../../../value/types/numbers/units.mjs';\n\nconst isNumOrPxType = (v) => v === number || v === px;\nconst transformKeys = new Set([\"x\", \"y\", \"z\"]);\nconst nonTranslationalTransformKeys = transformPropOrder.filter((key) => !transformKeys.has(key));\nfunction removeNonTranslationalTransform(visualElement) {\n const removedTransforms = [];\n nonTranslationalTransformKeys.forEach((key) => {\n const value = visualElement.getValue(key);\n if (value !== undefined) {\n removedTransforms.push([key, value.get()]);\n value.set(key.startsWith(\"scale\") ? 1 : 0);\n }\n });\n return removedTransforms;\n}\nconst positionalValues = {\n // Dimensions\n width: ({ x }, { paddingLeft = \"0\", paddingRight = \"0\" }) => x.max - x.min - parseFloat(paddingLeft) - parseFloat(paddingRight),\n height: ({ y }, { paddingTop = \"0\", paddingBottom = \"0\" }) => y.max - y.min - parseFloat(paddingTop) - parseFloat(paddingBottom),\n top: (_bbox, { top }) => parseFloat(top),\n left: (_bbox, { left }) => parseFloat(left),\n bottom: ({ y }, { top }) => parseFloat(top) + (y.max - y.min),\n right: ({ x }, { left }) => parseFloat(left) + (x.max - x.min),\n // Transform\n x: (_bbox, { transform }) => parseValueFromTransform(transform, \"x\"),\n y: (_bbox, { transform }) => parseValueFromTransform(transform, \"y\"),\n};\n// Alias translate longform names\npositionalValues.translateX = positionalValues.x;\npositionalValues.translateY = positionalValues.y;\n\nexport { isNumOrPxType, positionalValues, removeNonTranslationalTransform };\n","import { fillWildcards } from './utils/fill-wildcards.mjs';\nimport { removeNonTranslationalTransform } from './utils/unit-conversion.mjs';\nimport { frame } from '../../frameloop/frame.mjs';\n\nconst toResolve = new Set();\nlet isScheduled = false;\nlet anyNeedsMeasurement = false;\nlet isForced = false;\nfunction measureAllKeyframes() {\n if (anyNeedsMeasurement) {\n const resolversToMeasure = Array.from(toResolve).filter((resolver) => resolver.needsMeasurement);\n const elementsToMeasure = new Set(resolversToMeasure.map((resolver) => resolver.element));\n const transformsToRestore = new Map();\n /**\n * Write pass\n * If we're measuring elements we want to remove bounding box-changing transforms.\n */\n elementsToMeasure.forEach((element) => {\n const removedTransforms = removeNonTranslationalTransform(element);\n if (!removedTransforms.length)\n return;\n transformsToRestore.set(element, removedTransforms);\n element.render();\n });\n // Read\n resolversToMeasure.forEach((resolver) => resolver.measureInitialState());\n // Write\n elementsToMeasure.forEach((element) => {\n element.render();\n const restore = transformsToRestore.get(element);\n if (restore) {\n restore.forEach(([key, value]) => {\n element.getValue(key)?.set(value);\n });\n }\n });\n // Read\n resolversToMeasure.forEach((resolver) => resolver.measureEndState());\n // Write\n resolversToMeasure.forEach((resolver) => {\n if (resolver.suspendedScrollY !== undefined) {\n window.scrollTo(0, resolver.suspendedScrollY);\n }\n });\n }\n anyNeedsMeasurement = false;\n isScheduled = false;\n toResolve.forEach((resolver) => resolver.complete(isForced));\n toResolve.clear();\n}\nfunction readAllKeyframes() {\n toResolve.forEach((resolver) => {\n resolver.readKeyframes();\n if (resolver.needsMeasurement) {\n anyNeedsMeasurement = true;\n }\n });\n}\nfunction flushKeyframeResolvers() {\n isForced = true;\n readAllKeyframes();\n measureAllKeyframes();\n isForced = false;\n}\nclass KeyframeResolver {\n constructor(unresolvedKeyframes, onComplete, name, motionValue, element, isAsync = false) {\n this.state = \"pending\";\n /**\n * Track whether this resolver is async. If it is, it'll be added to the\n * resolver queue and flushed in the next frame. Resolvers that aren't going\n * to trigger read/write thrashing don't need to be async.\n */\n this.isAsync = false;\n /**\n * Track whether this resolver needs to perform a measurement\n * to resolve its keyframes.\n */\n this.needsMeasurement = false;\n this.unresolvedKeyframes = [...unresolvedKeyframes];\n this.onComplete = onComplete;\n this.name = name;\n this.motionValue = motionValue;\n this.element = element;\n this.isAsync = isAsync;\n }\n scheduleResolve() {\n this.state = \"scheduled\";\n if (this.isAsync) {\n toResolve.add(this);\n if (!isScheduled) {\n isScheduled = true;\n frame.read(readAllKeyframes);\n frame.resolveKeyframes(measureAllKeyframes);\n }\n }\n else {\n this.readKeyframes();\n this.complete();\n }\n }\n readKeyframes() {\n const { unresolvedKeyframes, name, element, motionValue } = this;\n // If initial keyframe is null we need to read it from the DOM\n if (unresolvedKeyframes[0] === null) {\n const currentValue = motionValue?.get();\n // TODO: This doesn't work if the final keyframe is a wildcard\n const finalKeyframe = unresolvedKeyframes[unresolvedKeyframes.length - 1];\n if (currentValue !== undefined) {\n unresolvedKeyframes[0] = currentValue;\n }\n else if (element && name) {\n const valueAsRead = element.readValue(name, finalKeyframe);\n if (valueAsRead !== undefined && valueAsRead !== null) {\n unresolvedKeyframes[0] = valueAsRead;\n }\n }\n if (unresolvedKeyframes[0] === undefined) {\n unresolvedKeyframes[0] = finalKeyframe;\n }\n if (motionValue && currentValue === undefined) {\n motionValue.set(unresolvedKeyframes[0]);\n }\n }\n fillWildcards(unresolvedKeyframes);\n }\n setFinalKeyframe() { }\n measureInitialState() { }\n renderEndStyles() { }\n measureEndState() { }\n complete(isForcedComplete = false) {\n this.state = \"complete\";\n this.onComplete(this.unresolvedKeyframes, this.finalKeyframe, isForcedComplete);\n toResolve.delete(this);\n }\n cancel() {\n if (this.state === \"scheduled\") {\n toResolve.delete(this);\n this.state = \"pending\";\n }\n }\n resume() {\n if (this.state === \"pending\")\n this.scheduleResolve();\n }\n}\n\nexport { KeyframeResolver, flushKeyframeResolvers };\n","const isCSSVar = (name) => name.startsWith(\"--\");\n\nexport { isCSSVar };\n","import { isCSSVar } from './is-css-var.mjs';\n\nfunction setStyle(element, name, value) {\n isCSSVar(name)\n ? element.style.setProperty(name, value)\n : (element.style[name] = value);\n}\n\nexport { setStyle };\n","import { memo } from 'motion-utils';\n\nconst supportsScrollTimeline = /* @__PURE__ */ memo(() => window.ScrollTimeline !== undefined);\n\nexport { supportsScrollTimeline };\n","/**\n * Add the ability for test suites to manually set support flags\n * to better test more environments.\n */\nconst supportsFlags = {};\n\nexport { supportsFlags };\n","import { memo } from 'motion-utils';\nimport { supportsFlags } from './flags.mjs';\n\nfunction memoSupports(callback, supportsFlag) {\n const memoized = memo(callback);\n return () => supportsFlags[supportsFlag] ?? memoized();\n}\n\nexport { memoSupports };\n","import { memoSupports } from './memo.mjs';\n\nconst supportsLinearEasing = /*@__PURE__*/ memoSupports(() => {\n try {\n document\n .createElement(\"div\")\n .animate({ opacity: 0 }, { easing: \"linear(0, 1)\" });\n }\n catch (e) {\n return false;\n }\n return true;\n}, \"linearEasing\");\n\nexport { supportsLinearEasing };\n","const cubicBezierAsString = ([a, b, c, d]) => `cubic-bezier(${a}, ${b}, ${c}, ${d})`;\n\nexport { cubicBezierAsString };\n","import { cubicBezierAsString } from './cubic-bezier.mjs';\n\nconst supportedWaapiEasing = {\n linear: \"linear\",\n ease: \"ease\",\n easeIn: \"ease-in\",\n easeOut: \"ease-out\",\n easeInOut: \"ease-in-out\",\n circIn: /*@__PURE__*/ cubicBezierAsString([0, 0.65, 0.55, 1]),\n circOut: /*@__PURE__*/ cubicBezierAsString([0.55, 0, 1, 0.45]),\n backIn: /*@__PURE__*/ cubicBezierAsString([0.31, 0.01, 0.66, -0.59]),\n backOut: /*@__PURE__*/ cubicBezierAsString([0.33, 1.53, 0.69, 0.99]),\n};\n\nexport { supportedWaapiEasing };\n","import { isBezierDefinition } from 'motion-utils';\nimport { supportsLinearEasing } from '../../../utils/supports/linear-easing.mjs';\nimport { generateLinearEasing } from '../utils/linear.mjs';\nimport { cubicBezierAsString } from './cubic-bezier.mjs';\nimport { supportedWaapiEasing } from './supported.mjs';\n\nfunction mapEasingToNativeEasing(easing, duration) {\n if (!easing) {\n return undefined;\n }\n else if (typeof easing === \"function\") {\n return supportsLinearEasing()\n ? generateLinearEasing(easing, duration)\n : \"ease-out\";\n }\n else if (isBezierDefinition(easing)) {\n return cubicBezierAsString(easing);\n }\n else if (Array.isArray(easing)) {\n return easing.map((segmentEasing) => mapEasingToNativeEasing(segmentEasing, duration) ||\n supportedWaapiEasing.easeOut);\n }\n else {\n return supportedWaapiEasing[easing];\n }\n}\n\nexport { mapEasingToNativeEasing };\n","import { activeAnimations } from '../../stats/animation-count.mjs';\nimport { statsBuffer } from '../../stats/buffer.mjs';\nimport { mapEasingToNativeEasing } from './easing/map-easing.mjs';\n\nfunction startWaapiAnimation(element, valueName, keyframes, { delay = 0, duration = 300, repeat = 0, repeatType = \"loop\", ease = \"easeOut\", times, } = {}, pseudoElement = undefined) {\n const keyframeOptions = {\n [valueName]: keyframes,\n };\n if (times)\n keyframeOptions.offset = times;\n const easing = mapEasingToNativeEasing(ease, duration);\n /**\n * If this is an easing array, apply to keyframes, not animation as a whole\n */\n if (Array.isArray(easing))\n keyframeOptions.easing = easing;\n if (statsBuffer.value) {\n activeAnimations.waapi++;\n }\n const options = {\n delay,\n duration,\n easing: !Array.isArray(easing) ? easing : \"linear\",\n fill: \"both\",\n iterations: repeat + 1,\n direction: repeatType === \"reverse\" ? \"alternate\" : \"normal\",\n };\n if (pseudoElement)\n options.pseudoElement = pseudoElement;\n const animation = element.animate(keyframeOptions, options);\n if (statsBuffer.value) {\n animation.finished.finally(() => {\n activeAnimations.waapi--;\n });\n }\n return animation;\n}\n\nexport { startWaapiAnimation };\n","function isGenerator(type) {\n return typeof type === \"function\" && \"applyToOptions\" in type;\n}\n\nexport { isGenerator };\n","import { supportsLinearEasing } from '../../../utils/supports/linear-easing.mjs';\nimport { isGenerator } from '../../generators/utils/is-generator.mjs';\n\nfunction applyGeneratorOptions({ type, ...options }) {\n if (isGenerator(type) && supportsLinearEasing()) {\n return type.applyToOptions(options);\n }\n else {\n options.duration ?? (options.duration = 300);\n options.ease ?? (options.ease = \"easeOut\");\n }\n return options;\n}\n\nexport { applyGeneratorOptions };\n","import { invariant, millisecondsToSeconds, secondsToMilliseconds, noop } from 'motion-utils';\nimport { setStyle } from '../render/dom/style-set.mjs';\nimport { supportsScrollTimeline } from '../utils/supports/scroll-timeline.mjs';\nimport { getFinalKeyframe } from './keyframes/get-final.mjs';\nimport { WithPromise } from './utils/WithPromise.mjs';\nimport { startWaapiAnimation } from './waapi/start-waapi-animation.mjs';\nimport { applyGeneratorOptions } from './waapi/utils/apply-generator.mjs';\n\n/**\n * NativeAnimation implements AnimationPlaybackControls for the browser's Web Animations API.\n */\nclass NativeAnimation extends WithPromise {\n constructor(options) {\n super();\n this.finishedTime = null;\n this.isStopped = false;\n if (!options)\n return;\n const { element, name, keyframes, pseudoElement, allowFlatten = false, finalKeyframe, onComplete, } = options;\n this.isPseudoElement = Boolean(pseudoElement);\n this.allowFlatten = allowFlatten;\n this.options = options;\n invariant(typeof options.type !== \"string\", `Mini animate() doesn't support \"type\" as a string.`, \"mini-spring\");\n const transition = applyGeneratorOptions(options);\n this.animation = startWaapiAnimation(element, name, keyframes, transition, pseudoElement);\n if (transition.autoplay === false) {\n this.animation.pause();\n }\n this.animation.onfinish = () => {\n this.finishedTime = this.time;\n if (!pseudoElement) {\n const keyframe = getFinalKeyframe(keyframes, this.options, finalKeyframe, this.speed);\n if (this.updateMotionValue) {\n this.updateMotionValue(keyframe);\n }\n else {\n /**\n * If we can, we want to commit the final style as set by the user,\n * rather than the computed keyframe value supplied by the animation.\n */\n setStyle(element, name, keyframe);\n }\n this.animation.cancel();\n }\n onComplete?.();\n this.notifyFinished();\n };\n }\n play() {\n if (this.isStopped)\n return;\n this.animation.play();\n if (this.state === \"finished\") {\n this.updateFinished();\n }\n }\n pause() {\n this.animation.pause();\n }\n complete() {\n this.animation.finish?.();\n }\n cancel() {\n try {\n this.animation.cancel();\n }\n catch (e) { }\n }\n stop() {\n if (this.isStopped)\n return;\n this.isStopped = true;\n const { state } = this;\n if (state === \"idle\" || state === \"finished\") {\n return;\n }\n if (this.updateMotionValue) {\n this.updateMotionValue();\n }\n else {\n this.commitStyles();\n }\n if (!this.isPseudoElement)\n this.cancel();\n }\n /**\n * WAAPI doesn't natively have any interruption capabilities.\n *\n * In this method, we commit styles back to the DOM before cancelling\n * the animation.\n *\n * This is designed to be overridden by NativeAnimationExtended, which\n * will create a renderless JS animation and sample it twice to calculate\n * its current value, \"previous\" value, and therefore allow\n * Motion to also correctly calculate velocity for any subsequent animation\n * while deferring the commit until the next animation frame.\n */\n commitStyles() {\n if (!this.isPseudoElement) {\n this.animation.commitStyles?.();\n }\n }\n get duration() {\n const duration = this.animation.effect?.getComputedTiming?.().duration || 0;\n return millisecondsToSeconds(Number(duration));\n }\n get iterationDuration() {\n const { delay = 0 } = this.options || {};\n return this.duration + millisecondsToSeconds(delay);\n }\n get time() {\n return millisecondsToSeconds(Number(this.animation.currentTime) || 0);\n }\n set time(newTime) {\n this.finishedTime = null;\n this.animation.currentTime = secondsToMilliseconds(newTime);\n }\n /**\n * The playback speed of the animation.\n * 1 = normal speed, 2 = double speed, 0.5 = half speed.\n */\n get speed() {\n return this.animation.playbackRate;\n }\n set speed(newSpeed) {\n // Allow backwards playback after finishing\n if (newSpeed < 0)\n this.finishedTime = null;\n this.animation.playbackRate = newSpeed;\n }\n get state() {\n return this.finishedTime !== null\n ? \"finished\"\n : this.animation.playState;\n }\n get startTime() {\n return Number(this.animation.startTime);\n }\n set startTime(newStartTime) {\n this.animation.startTime = newStartTime;\n }\n /**\n * Attaches a timeline to the animation, for instance the `ScrollTimeline`.\n */\n attachTimeline({ timeline, observe }) {\n if (this.allowFlatten) {\n this.animation.effect?.updateTiming({ easing: \"linear\" });\n }\n this.animation.onfinish = null;\n if (timeline && supportsScrollTimeline()) {\n this.animation.timeline = timeline;\n return noop;\n }\n else {\n return observe(this);\n }\n }\n}\n\nexport { NativeAnimation };\n","import { anticipate, backInOut, circInOut } from 'motion-utils';\n\nconst unsupportedEasingFunctions = {\n anticipate,\n backInOut,\n circInOut,\n};\nfunction isUnsupportedEase(key) {\n return key in unsupportedEasingFunctions;\n}\nfunction replaceStringEasing(transition) {\n if (typeof transition.ease === \"string\" &&\n isUnsupportedEase(transition.ease)) {\n transition.ease = unsupportedEasingFunctions[transition.ease];\n }\n}\n\nexport { replaceStringEasing };\n","import { secondsToMilliseconds } from 'motion-utils';\nimport { JSAnimation } from './JSAnimation.mjs';\nimport { NativeAnimation } from './NativeAnimation.mjs';\nimport { replaceTransitionType } from './utils/replace-transition-type.mjs';\nimport { replaceStringEasing } from './waapi/utils/unsupported-easing.mjs';\n\n/**\n * 10ms is chosen here as it strikes a balance between smooth\n * results (more than one keyframe per frame at 60fps) and\n * keyframe quantity.\n */\nconst sampleDelta = 10; //ms\nclass NativeAnimationExtended extends NativeAnimation {\n constructor(options) {\n /**\n * The base NativeAnimation function only supports a subset\n * of Motion easings, and WAAPI also only supports some\n * easing functions via string/cubic-bezier definitions.\n *\n * This function replaces those unsupported easing functions\n * with a JS easing function. This will later get compiled\n * to a linear() easing function.\n */\n replaceStringEasing(options);\n /**\n * Ensure we replace the transition type with a generator function\n * before passing to WAAPI.\n *\n * TODO: Does this have a better home? It could be shared with\n * JSAnimation.\n */\n replaceTransitionType(options);\n super(options);\n if (options.startTime) {\n this.startTime = options.startTime;\n }\n this.options = options;\n }\n /**\n * WAAPI doesn't natively have any interruption capabilities.\n *\n * Rather than read commited styles back out of the DOM, we can\n * create a renderless JS animation and sample it twice to calculate\n * its current value, \"previous\" value, and therefore allow\n * Motion to calculate velocity for any subsequent animation.\n */\n updateMotionValue(value) {\n const { motionValue, onUpdate, onComplete, element, ...options } = this.options;\n if (!motionValue)\n return;\n if (value !== undefined) {\n motionValue.set(value);\n return;\n }\n const sampleAnimation = new JSAnimation({\n ...options,\n autoplay: false,\n });\n const sampleTime = secondsToMilliseconds(this.finishedTime ?? this.time);\n motionValue.setWithVelocity(sampleAnimation.sample(sampleTime - sampleDelta).value, sampleAnimation.sample(sampleTime).value, sampleDelta);\n sampleAnimation.stop();\n }\n}\n\nexport { NativeAnimationExtended };\n","import { complex } from '../../value/types/complex/index.mjs';\n\n/**\n * Check if a value is animatable. Examples:\n *\n * ✅: 100, \"100px\", \"#fff\"\n * ❌: \"block\", \"url(2.jpg)\"\n * @param value\n *\n * @internal\n */\nconst isAnimatable = (value, name) => {\n // If the list of keys that might be non-animatable grows, replace with Set\n if (name === \"zIndex\")\n return false;\n // If it's a number or a keyframes array, we can animate it. We might at some point\n // need to do a deep isAnimatable check of keyframes, or let Popmotion handle this,\n // but for now lets leave it like this for performance reasons\n if (typeof value === \"number\" || Array.isArray(value))\n return true;\n if (typeof value === \"string\" && // It's animatable if we have a string\n (complex.test(value) || value === \"0\") && // And it contains numbers and/or colors\n !value.startsWith(\"url(\") // Unless it starts with \"url(\"\n ) {\n return true;\n }\n return false;\n};\n\nexport { isAnimatable };\n","import { warning } from 'motion-utils';\nimport { isGenerator } from '../generators/utils/is-generator.mjs';\nimport { isAnimatable } from './is-animatable.mjs';\n\nfunction hasKeyframesChanged(keyframes) {\n const current = keyframes[0];\n if (keyframes.length === 1)\n return true;\n for (let i = 0; i < keyframes.length; i++) {\n if (keyframes[i] !== current)\n return true;\n }\n}\nfunction canAnimate(keyframes, name, type, velocity) {\n /**\n * Check if we're able to animate between the start and end keyframes,\n * and throw a warning if we're attempting to animate between one that's\n * animatable and another that isn't.\n */\n const originKeyframe = keyframes[0];\n if (originKeyframe === null)\n return false;\n /**\n * These aren't traditionally animatable but we do support them.\n * In future we could look into making this more generic or replacing\n * this function with mix() === mixImmediate\n */\n if (name === \"display\" || name === \"visibility\")\n return true;\n const targetKeyframe = keyframes[keyframes.length - 1];\n const isOriginAnimatable = isAnimatable(originKeyframe, name);\n const isTargetAnimatable = isAnimatable(targetKeyframe, name);\n warning(isOriginAnimatable === isTargetAnimatable, `You are trying to animate ${name} from \"${originKeyframe}\" to \"${targetKeyframe}\". \"${isOriginAnimatable ? targetKeyframe : originKeyframe}\" is not an animatable value.`, \"value-not-animatable\");\n // Always skip if any of these are true\n if (!isOriginAnimatable || !isTargetAnimatable) {\n return false;\n }\n return (hasKeyframesChanged(keyframes) ||\n ((type === \"spring\" || isGenerator(type)) && velocity));\n}\n\nexport { canAnimate };\n","function makeAnimationInstant(options) {\n options.duration = 0;\n options.type = \"keyframes\";\n}\n\nexport { makeAnimationInstant };\n","import { memo } from 'motion-utils';\n\n/**\n * A list of values that can be hardware-accelerated.\n */\nconst acceleratedValues = new Set([\n \"opacity\",\n \"clipPath\",\n \"filter\",\n \"transform\",\n // TODO: Could be re-enabled now we have support for linear() easing\n // \"background-color\"\n]);\nconst supportsWaapi = /*@__PURE__*/ memo(() => Object.hasOwnProperty.call(Element.prototype, \"animate\"));\nfunction supportsBrowserAnimation(options) {\n const { motionValue, name, repeatDelay, repeatType, damping, type } = options;\n const subject = motionValue?.owner?.current;\n /**\n * We use this check instead of isHTMLElement() because we explicitly\n * **don't** want elements in different timing contexts (i.e. popups)\n * to be accelerated, as it's not possible to sync these animations\n * properly with those driven from the main window frameloop.\n */\n if (!(subject instanceof HTMLElement)) {\n return false;\n }\n const { onUpdate, transformTemplate } = motionValue.owner.getProps();\n return (supportsWaapi() &&\n name &&\n acceleratedValues.has(name) &&\n (name !== \"transform\" || !transformTemplate) &&\n /**\n * If we're outputting values to onUpdate then we can't use WAAPI as there's\n * no way to read the value from WAAPI every frame.\n */\n !onUpdate &&\n !repeatDelay &&\n repeatType !== \"mirror\" &&\n damping !== 0 &&\n type !== \"inertia\");\n}\n\nexport { supportsBrowserAnimation };\n","import { MotionGlobalConfig, noop } from 'motion-utils';\nimport { time } from '../frameloop/sync-time.mjs';\nimport { JSAnimation } from './JSAnimation.mjs';\nimport { getFinalKeyframe } from './keyframes/get-final.mjs';\nimport { KeyframeResolver, flushKeyframeResolvers } from './keyframes/KeyframesResolver.mjs';\nimport { NativeAnimationExtended } from './NativeAnimationExtended.mjs';\nimport { canAnimate } from './utils/can-animate.mjs';\nimport { makeAnimationInstant } from './utils/make-animation-instant.mjs';\nimport { WithPromise } from './utils/WithPromise.mjs';\nimport { supportsBrowserAnimation } from './waapi/supports/waapi.mjs';\n\n/**\n * Maximum time allowed between an animation being created and it being\n * resolved for us to use the latter as the start time.\n *\n * This is to ensure that while we prefer to \"start\" an animation as soon\n * as it's triggered, we also want to avoid a visual jump if there's a big delay\n * between these two moments.\n */\nconst MAX_RESOLVE_DELAY = 40;\nclass AsyncMotionValueAnimation extends WithPromise {\n constructor({ autoplay = true, delay = 0, type = \"keyframes\", repeat = 0, repeatDelay = 0, repeatType = \"loop\", keyframes, name, motionValue, element, ...options }) {\n super();\n /**\n * Bound to support return animation.stop pattern\n */\n this.stop = () => {\n if (this._animation) {\n this._animation.stop();\n this.stopTimeline?.();\n }\n this.keyframeResolver?.cancel();\n };\n this.createdAt = time.now();\n const optionsWithDefaults = {\n autoplay,\n delay,\n type,\n repeat,\n repeatDelay,\n repeatType,\n name,\n motionValue,\n element,\n ...options,\n };\n const KeyframeResolver$1 = element?.KeyframeResolver || KeyframeResolver;\n this.keyframeResolver = new KeyframeResolver$1(keyframes, (resolvedKeyframes, finalKeyframe, forced) => this.onKeyframesResolved(resolvedKeyframes, finalKeyframe, optionsWithDefaults, !forced), name, motionValue, element);\n this.keyframeResolver?.scheduleResolve();\n }\n onKeyframesResolved(keyframes, finalKeyframe, options, sync) {\n this.keyframeResolver = undefined;\n const { name, type, velocity, delay, isHandoff, onUpdate } = options;\n this.resolvedAt = time.now();\n /**\n * If we can't animate this value with the resolved keyframes\n * then we should complete it immediately.\n */\n if (!canAnimate(keyframes, name, type, velocity)) {\n if (MotionGlobalConfig.instantAnimations || !delay) {\n onUpdate?.(getFinalKeyframe(keyframes, options, finalKeyframe));\n }\n keyframes[0] = keyframes[keyframes.length - 1];\n makeAnimationInstant(options);\n options.repeat = 0;\n }\n /**\n * Resolve startTime for the animation.\n *\n * This method uses the createdAt and resolvedAt to calculate the\n * animation startTime. *Ideally*, we would use the createdAt time as t=0\n * as the following frame would then be the first frame of the animation in\n * progress, which would feel snappier.\n *\n * However, if there's a delay (main thread work) between the creation of\n * the animation and the first commited frame, we prefer to use resolvedAt\n * to avoid a sudden jump into the animation.\n */\n const startTime = sync\n ? !this.resolvedAt\n ? this.createdAt\n : this.resolvedAt - this.createdAt > MAX_RESOLVE_DELAY\n ? this.resolvedAt\n : this.createdAt\n : undefined;\n const resolvedOptions = {\n startTime,\n finalKeyframe,\n ...options,\n keyframes,\n };\n /**\n * Animate via WAAPI if possible. If this is a handoff animation, the optimised animation will be running via\n * WAAPI. Therefore, this animation must be JS to ensure it runs \"under\" the\n * optimised animation.\n */\n const animation = !isHandoff && supportsBrowserAnimation(resolvedOptions)\n ? new NativeAnimationExtended({\n ...resolvedOptions,\n element: resolvedOptions.motionValue.owner.current,\n })\n : new JSAnimation(resolvedOptions);\n animation.finished.then(() => this.notifyFinished()).catch(noop);\n if (this.pendingTimeline) {\n this.stopTimeline = animation.attachTimeline(this.pendingTimeline);\n this.pendingTimeline = undefined;\n }\n this._animation = animation;\n }\n get finished() {\n if (!this._animation) {\n return this._finished;\n }\n else {\n return this.animation.finished;\n }\n }\n then(onResolve, _onReject) {\n return this.finished.finally(onResolve).then(() => { });\n }\n get animation() {\n if (!this._animation) {\n this.keyframeResolver?.resume();\n flushKeyframeResolvers();\n }\n return this._animation;\n }\n get duration() {\n return this.animation.duration;\n }\n get iterationDuration() {\n return this.animation.iterationDuration;\n }\n get time() {\n return this.animation.time;\n }\n set time(newTime) {\n this.animation.time = newTime;\n }\n get speed() {\n return this.animation.speed;\n }\n get state() {\n return this.animation.state;\n }\n set speed(newSpeed) {\n this.animation.speed = newSpeed;\n }\n get startTime() {\n return this.animation.startTime;\n }\n attachTimeline(timeline) {\n if (this._animation) {\n this.stopTimeline = this.animation.attachTimeline(timeline);\n }\n else {\n this.pendingTimeline = timeline;\n }\n return () => this.stop();\n }\n play() {\n this.animation.play();\n }\n pause() {\n this.animation.pause();\n }\n complete() {\n this.animation.complete();\n }\n cancel() {\n if (this._animation) {\n this.animation.cancel();\n }\n this.keyframeResolver?.cancel();\n }\n}\n\nexport { AsyncMotionValueAnimation };\n","import { invariant, isNumericalString } from 'motion-utils';\nimport { isCSSVariableToken } from './is-css-variable.mjs';\n\n/**\n * Parse Framer's special CSS variable format into a CSS token and a fallback.\n *\n * ```\n * `var(--foo, #fff)` => [`--foo`, '#fff']\n * ```\n *\n * @param current\n */\nconst splitCSSVariableRegex = \n// eslint-disable-next-line redos-detector/no-unsafe-regex -- false positive, as it can match a lot of words\n/^var\\(--(?:([\\w-]+)|([\\w-]+), ?([a-zA-Z\\d ()%#.,-]+))\\)/u;\nfunction parseCSSVariable(current) {\n const match = splitCSSVariableRegex.exec(current);\n if (!match)\n return [,];\n const [, token1, token2, fallback] = match;\n return [`--${token1 ?? token2}`, fallback];\n}\nconst maxDepth = 4;\nfunction getVariableValue(current, element, depth = 1) {\n invariant(depth <= maxDepth, `Max CSS variable fallback depth detected in property \"${current}\". This may indicate a circular fallback dependency.`, \"max-css-var-depth\");\n const [token, fallback] = parseCSSVariable(current);\n // No CSS variable detected\n if (!token)\n return;\n // Attempt to read this CSS variable off the element\n const resolved = window.getComputedStyle(element).getPropertyValue(token);\n if (resolved) {\n const trimmed = resolved.trim();\n return isNumericalString(trimmed) ? parseFloat(trimmed) : trimmed;\n }\n return isCSSVariableToken(fallback)\n ? getVariableValue(fallback, element, depth + 1)\n : fallback;\n}\n\nexport { getVariableValue, parseCSSVariable };\n","function getValueTransition(transition, key) {\n return (transition?.[key] ??\n transition?.[\"default\"] ??\n transition);\n}\n\nexport { getValueTransition };\n","import { transformPropOrder } from './keys-transform.mjs';\n\nconst positionalKeys = new Set([\n \"width\",\n \"height\",\n \"top\",\n \"left\",\n \"right\",\n \"bottom\",\n ...transformPropOrder,\n]);\n\nexport { positionalKeys };\n","/**\n * ValueType for \"auto\"\n */\nconst auto = {\n test: (v) => v === \"auto\",\n parse: (v) => v,\n};\n\nexport { auto };\n","/**\n * Tests a provided value against a ValueType\n */\nconst testValueType = (v) => (type) => type.test(v);\n\nexport { testValueType };\n","import { auto } from './auto.mjs';\nimport { number } from './numbers/index.mjs';\nimport { px, percent, degrees, vw, vh } from './numbers/units.mjs';\nimport { testValueType } from './test.mjs';\n\n/**\n * A list of value types commonly used for dimensions\n */\nconst dimensionValueTypes = [number, px, percent, degrees, vw, vh, auto];\n/**\n * Tests a dimensional value against the list of dimension ValueTypes\n */\nconst findDimensionValueType = (v) => dimensionValueTypes.find(testValueType(v));\n\nexport { dimensionValueTypes, findDimensionValueType };\n","import { isZeroValueString } from 'motion-utils';\n\nfunction isNone(value) {\n if (typeof value === \"number\") {\n return value === 0;\n }\n else if (value !== null) {\n return value === \"none\" || value === \"0\" || isZeroValueString(value);\n }\n else {\n return true;\n }\n}\n\nexport { isNone };\n","import { complex } from './index.mjs';\nimport { floatRegex } from '../utils/float-regex.mjs';\n\n/**\n * Properties that should default to 1 or 100%\n */\nconst maxDefaults = new Set([\"brightness\", \"contrast\", \"saturate\", \"opacity\"]);\nfunction applyDefaultFilter(v) {\n const [name, value] = v.slice(0, -1).split(\"(\");\n if (name === \"drop-shadow\")\n return v;\n const [number] = value.match(floatRegex) || [];\n if (!number)\n return v;\n const unit = value.replace(number, \"\");\n let defaultValue = maxDefaults.has(name) ? 1 : 0;\n if (number !== value)\n defaultValue *= 100;\n return name + \"(\" + defaultValue + unit + \")\";\n}\nconst functionRegex = /\\b([a-z-]*)\\(.*?\\)/gu;\nconst filter = {\n ...complex,\n getAnimatableNone: (v) => {\n const functions = v.match(functionRegex);\n return functions ? functions.map(applyDefaultFilter).join(\" \") : v;\n },\n};\n\nexport { filter };\n","import { number } from './numbers/index.mjs';\n\nconst int = {\n ...number,\n transform: Math.round,\n};\n\nexport { int };\n","import { scale, alpha } from '../numbers/index.mjs';\nimport { degrees, px, progressPercentage } from '../numbers/units.mjs';\n\nconst transformValueTypes = {\n rotate: degrees,\n rotateX: degrees,\n rotateY: degrees,\n rotateZ: degrees,\n scale,\n scaleX: scale,\n scaleY: scale,\n scaleZ: scale,\n skew: degrees,\n skewX: degrees,\n skewY: degrees,\n distance: px,\n translateX: px,\n translateY: px,\n translateZ: px,\n x: px,\n y: px,\n z: px,\n perspective: px,\n transformPerspective: px,\n opacity: alpha,\n originX: progressPercentage,\n originY: progressPercentage,\n originZ: px,\n};\n\nexport { transformValueTypes };\n","import { int } from '../int.mjs';\nimport { alpha } from '../numbers/index.mjs';\nimport { px } from '../numbers/units.mjs';\nimport { transformValueTypes } from './transform.mjs';\n\nconst numberValueTypes = {\n // Border props\n borderWidth: px,\n borderTopWidth: px,\n borderRightWidth: px,\n borderBottomWidth: px,\n borderLeftWidth: px,\n borderRadius: px,\n radius: px,\n borderTopLeftRadius: px,\n borderTopRightRadius: px,\n borderBottomRightRadius: px,\n borderBottomLeftRadius: px,\n // Positioning props\n width: px,\n maxWidth: px,\n height: px,\n maxHeight: px,\n top: px,\n right: px,\n bottom: px,\n left: px,\n // Spacing props\n padding: px,\n paddingTop: px,\n paddingRight: px,\n paddingBottom: px,\n paddingLeft: px,\n margin: px,\n marginTop: px,\n marginRight: px,\n marginBottom: px,\n marginLeft: px,\n // Misc\n backgroundPositionX: px,\n backgroundPositionY: px,\n ...transformValueTypes,\n zIndex: int,\n // SVG\n fillOpacity: alpha,\n strokeOpacity: alpha,\n numOctaves: int,\n};\n\nexport { numberValueTypes };\n","import { color } from '../color/index.mjs';\nimport { filter } from '../complex/filter.mjs';\nimport { numberValueTypes } from './number.mjs';\n\n/**\n * A map of default value types for common values\n */\nconst defaultValueTypes = {\n ...numberValueTypes,\n // Color props\n color,\n backgroundColor: color,\n outlineColor: color,\n fill: color,\n stroke: color,\n // Border props\n borderColor: color,\n borderTopColor: color,\n borderRightColor: color,\n borderBottomColor: color,\n borderLeftColor: color,\n filter,\n WebkitFilter: filter,\n};\n/**\n * Gets the default ValueType for the provided value key\n */\nconst getDefaultValueType = (key) => defaultValueTypes[key];\n\nexport { defaultValueTypes, getDefaultValueType };\n","import { complex } from '../complex/index.mjs';\nimport { filter } from '../complex/filter.mjs';\nimport { getDefaultValueType } from '../maps/defaults.mjs';\n\nfunction getAnimatableNone(key, value) {\n let defaultValueType = getDefaultValueType(key);\n if (defaultValueType !== filter)\n defaultValueType = complex;\n // If value is not recognised as animatable, ie \"none\", create an animatable version origin based on the target\n return defaultValueType.getAnimatableNone\n ? defaultValueType.getAnimatableNone(value)\n : undefined;\n}\n\nexport { getAnimatableNone };\n","import { analyseComplexValue } from '../../../value/types/complex/index.mjs';\nimport { getAnimatableNone } from '../../../value/types/utils/animatable-none.mjs';\n\n/**\n * If we encounter keyframes like \"none\" or \"0\" and we also have keyframes like\n * \"#fff\" or \"200px 200px\" we want to find a keyframe to serve as a template for\n * the \"none\" keyframes. In this case \"#fff\" or \"200px 200px\" - then these get turned into\n * zero equivalents, i.e. \"#fff0\" or \"0px 0px\".\n */\nconst invalidTemplates = new Set([\"auto\", \"none\", \"0\"]);\nfunction makeNoneKeyframesAnimatable(unresolvedKeyframes, noneKeyframeIndexes, name) {\n let i = 0;\n let animatableTemplate = undefined;\n while (i < unresolvedKeyframes.length && !animatableTemplate) {\n const keyframe = unresolvedKeyframes[i];\n if (typeof keyframe === \"string\" &&\n !invalidTemplates.has(keyframe) &&\n analyseComplexValue(keyframe).values.length) {\n animatableTemplate = unresolvedKeyframes[i];\n }\n i++;\n }\n if (animatableTemplate && name) {\n for (const noneIndex of noneKeyframeIndexes) {\n unresolvedKeyframes[noneIndex] = getAnimatableNone(name, animatableTemplate);\n }\n }\n}\n\nexport { makeNoneKeyframesAnimatable };\n","import { positionalKeys } from '../../render/utils/keys-position.mjs';\nimport { findDimensionValueType } from '../../value/types/dimensions.mjs';\nimport { getVariableValue } from '../utils/css-variables-conversion.mjs';\nimport { isCSSVariableToken } from '../utils/is-css-variable.mjs';\nimport { KeyframeResolver } from './KeyframesResolver.mjs';\nimport { isNone } from './utils/is-none.mjs';\nimport { makeNoneKeyframesAnimatable } from './utils/make-none-animatable.mjs';\nimport { isNumOrPxType, positionalValues } from './utils/unit-conversion.mjs';\n\nclass DOMKeyframesResolver extends KeyframeResolver {\n constructor(unresolvedKeyframes, onComplete, name, motionValue, element) {\n super(unresolvedKeyframes, onComplete, name, motionValue, element, true);\n }\n readKeyframes() {\n const { unresolvedKeyframes, element, name } = this;\n if (!element || !element.current)\n return;\n super.readKeyframes();\n /**\n * If any keyframe is a CSS variable, we need to find its value by sampling the element\n */\n for (let i = 0; i < unresolvedKeyframes.length; i++) {\n let keyframe = unresolvedKeyframes[i];\n if (typeof keyframe === \"string\") {\n keyframe = keyframe.trim();\n if (isCSSVariableToken(keyframe)) {\n const resolved = getVariableValue(keyframe, element.current);\n if (resolved !== undefined) {\n unresolvedKeyframes[i] = resolved;\n }\n if (i === unresolvedKeyframes.length - 1) {\n this.finalKeyframe = keyframe;\n }\n }\n }\n }\n /**\n * Resolve \"none\" values. We do this potentially twice - once before and once after measuring keyframes.\n * This could be seen as inefficient but it's a trade-off to avoid measurements in more situations, which\n * have a far bigger performance impact.\n */\n this.resolveNoneKeyframes();\n /**\n * Check to see if unit type has changed. If so schedule jobs that will\n * temporarily set styles to the destination keyframes.\n * Skip if we have more than two keyframes or this isn't a positional value.\n * TODO: We can throw if there are multiple keyframes and the value type changes.\n */\n if (!positionalKeys.has(name) || unresolvedKeyframes.length !== 2) {\n return;\n }\n const [origin, target] = unresolvedKeyframes;\n const originType = findDimensionValueType(origin);\n const targetType = findDimensionValueType(target);\n /**\n * Either we don't recognise these value types or we can animate between them.\n */\n if (originType === targetType)\n return;\n /**\n * If both values are numbers or pixels, we can animate between them by\n * converting them to numbers.\n */\n if (isNumOrPxType(originType) && isNumOrPxType(targetType)) {\n for (let i = 0; i < unresolvedKeyframes.length; i++) {\n const value = unresolvedKeyframes[i];\n if (typeof value === \"string\") {\n unresolvedKeyframes[i] = parseFloat(value);\n }\n }\n }\n else if (positionalValues[name]) {\n /**\n * Else, the only way to resolve this is by measuring the element.\n */\n this.needsMeasurement = true;\n }\n }\n resolveNoneKeyframes() {\n const { unresolvedKeyframes, name } = this;\n const noneKeyframeIndexes = [];\n for (let i = 0; i < unresolvedKeyframes.length; i++) {\n if (unresolvedKeyframes[i] === null ||\n isNone(unresolvedKeyframes[i])) {\n noneKeyframeIndexes.push(i);\n }\n }\n if (noneKeyframeIndexes.length) {\n makeNoneKeyframesAnimatable(unresolvedKeyframes, noneKeyframeIndexes, name);\n }\n }\n measureInitialState() {\n const { element, unresolvedKeyframes, name } = this;\n if (!element || !element.current)\n return;\n if (name === \"height\") {\n this.suspendedScrollY = window.pageYOffset;\n }\n this.measuredOrigin = positionalValues[name](element.measureViewportBox(), window.getComputedStyle(element.current));\n unresolvedKeyframes[0] = this.measuredOrigin;\n // Set final key frame to measure after next render\n const measureKeyframe = unresolvedKeyframes[unresolvedKeyframes.length - 1];\n if (measureKeyframe !== undefined) {\n element.getValue(name, measureKeyframe).jump(measureKeyframe, false);\n }\n }\n measureEndState() {\n const { element, name, unresolvedKeyframes } = this;\n if (!element || !element.current)\n return;\n const value = element.getValue(name);\n value && value.jump(this.measuredOrigin, false);\n const finalKeyframeIndex = unresolvedKeyframes.length - 1;\n const finalKeyframe = unresolvedKeyframes[finalKeyframeIndex];\n unresolvedKeyframes[finalKeyframeIndex] = positionalValues[name](element.measureViewportBox(), window.getComputedStyle(element.current));\n if (finalKeyframe !== null && this.finalKeyframe === undefined) {\n this.finalKeyframe = finalKeyframe;\n }\n // If we removed transform values, reapply them before the next render\n if (this.removedTransforms?.length) {\n this.removedTransforms.forEach(([unsetTransformName, unsetTransformValue]) => {\n element\n .getValue(unsetTransformName)\n .set(unsetTransformValue);\n });\n }\n this.resolveNoneKeyframes();\n }\n}\n\nexport { DOMKeyframesResolver };\n","function resolveElements(elementOrSelector, scope, selectorCache) {\n if (elementOrSelector instanceof EventTarget) {\n return [elementOrSelector];\n }\n else if (typeof elementOrSelector === \"string\") {\n let root = document;\n if (scope) {\n root = scope.current;\n }\n const elements = selectorCache?.[elementOrSelector] ??\n root.querySelectorAll(elementOrSelector);\n return elements ? Array.from(elements) : [];\n }\n return Array.from(elementOrSelector);\n}\n\nexport { resolveElements };\n","/**\n * Provided a value and a ValueType, returns the value as that value type.\n */\nconst getValueAsType = (value, type) => {\n return type && typeof value === \"number\"\n ? type.transform(value)\n : value;\n};\n\nexport { getValueAsType };\n","import { isObject } from 'motion-utils';\n\n/**\n * Checks if an element is an HTML element in a way\n * that works across iframes\n */\nfunction isHTMLElement(element) {\n return isObject(element) && \"offsetHeight\" in element;\n}\n\nexport { isHTMLElement };\n","import { warnOnce, SubscriptionManager, velocityPerSecond } from 'motion-utils';\nimport { time } from '../frameloop/sync-time.mjs';\nimport { frame } from '../frameloop/frame.mjs';\n\n/**\n * Maximum time between the value of two frames, beyond which we\n * assume the velocity has since been 0.\n */\nconst MAX_VELOCITY_DELTA = 30;\nconst isFloat = (value) => {\n return !isNaN(parseFloat(value));\n};\nconst collectMotionValues = {\n current: undefined,\n};\n/**\n * `MotionValue` is used to track the state and velocity of motion values.\n *\n * @public\n */\nclass MotionValue {\n /**\n * @param init - The initiating value\n * @param config - Optional configuration options\n *\n * - `transformer`: A function to transform incoming values with.\n */\n constructor(init, options = {}) {\n /**\n * Tracks whether this value can output a velocity. Currently this is only true\n * if the value is numerical, but we might be able to widen the scope here and support\n * other value types.\n *\n * @internal\n */\n this.canTrackVelocity = null;\n /**\n * An object containing a SubscriptionManager for each active event.\n */\n this.events = {};\n this.updateAndNotify = (v) => {\n const currentTime = time.now();\n /**\n * If we're updating the value during another frame or eventloop\n * than the previous frame, then the we set the previous frame value\n * to current.\n */\n if (this.updatedAt !== currentTime) {\n this.setPrevFrameValue();\n }\n this.prev = this.current;\n this.setCurrent(v);\n // Update update subscribers\n if (this.current !== this.prev) {\n this.events.change?.notify(this.current);\n if (this.dependents) {\n for (const dependent of this.dependents) {\n dependent.dirty();\n }\n }\n }\n };\n this.hasAnimated = false;\n this.setCurrent(init);\n this.owner = options.owner;\n }\n setCurrent(current) {\n this.current = current;\n this.updatedAt = time.now();\n if (this.canTrackVelocity === null && current !== undefined) {\n this.canTrackVelocity = isFloat(this.current);\n }\n }\n setPrevFrameValue(prevFrameValue = this.current) {\n this.prevFrameValue = prevFrameValue;\n this.prevUpdatedAt = this.updatedAt;\n }\n /**\n * Adds a function that will be notified when the `MotionValue` is updated.\n *\n * It returns a function that, when called, will cancel the subscription.\n *\n * When calling `onChange` inside a React component, it should be wrapped with the\n * `useEffect` hook. As it returns an unsubscribe function, this should be returned\n * from the `useEffect` function to ensure you don't add duplicate subscribers..\n *\n * ```jsx\n * export const MyComponent = () => {\n * const x = useMotionValue(0)\n * const y = useMotionValue(0)\n * const opacity = useMotionValue(1)\n *\n * useEffect(() => {\n * function updateOpacity() {\n * const maxXY = Math.max(x.get(), y.get())\n * const newOpacity = transform(maxXY, [0, 100], [1, 0])\n * opacity.set(newOpacity)\n * }\n *\n * const unsubscribeX = x.on(\"change\", updateOpacity)\n * const unsubscribeY = y.on(\"change\", updateOpacity)\n *\n * return () => {\n * unsubscribeX()\n * unsubscribeY()\n * }\n * }, [])\n *\n * return <motion.div style={{ x }} />\n * }\n * ```\n *\n * @param subscriber - A function that receives the latest value.\n * @returns A function that, when called, will cancel this subscription.\n *\n * @deprecated\n */\n onChange(subscription) {\n if (process.env.NODE_ENV !== \"production\") {\n warnOnce(false, `value.onChange(callback) is deprecated. Switch to value.on(\"change\", callback).`);\n }\n return this.on(\"change\", subscription);\n }\n on(eventName, callback) {\n if (!this.events[eventName]) {\n this.events[eventName] = new SubscriptionManager();\n }\n const unsubscribe = this.events[eventName].add(callback);\n if (eventName === \"change\") {\n return () => {\n unsubscribe();\n /**\n * If we have no more change listeners by the start\n * of the next frame, stop active animations.\n */\n frame.read(() => {\n if (!this.events.change.getSize()) {\n this.stop();\n }\n });\n };\n }\n return unsubscribe;\n }\n clearListeners() {\n for (const eventManagers in this.events) {\n this.events[eventManagers].clear();\n }\n }\n /**\n * Attaches a passive effect to the `MotionValue`.\n */\n attach(passiveEffect, stopPassiveEffect) {\n this.passiveEffect = passiveEffect;\n this.stopPassiveEffect = stopPassiveEffect;\n }\n /**\n * Sets the state of the `MotionValue`.\n *\n * @remarks\n *\n * ```jsx\n * const x = useMotionValue(0)\n * x.set(10)\n * ```\n *\n * @param latest - Latest value to set.\n * @param render - Whether to notify render subscribers. Defaults to `true`\n *\n * @public\n */\n set(v) {\n if (!this.passiveEffect) {\n this.updateAndNotify(v);\n }\n else {\n this.passiveEffect(v, this.updateAndNotify);\n }\n }\n setWithVelocity(prev, current, delta) {\n this.set(current);\n this.prev = undefined;\n this.prevFrameValue = prev;\n this.prevUpdatedAt = this.updatedAt - delta;\n }\n /**\n * Set the state of the `MotionValue`, stopping any active animations,\n * effects, and resets velocity to `0`.\n */\n jump(v, endAnimation = true) {\n this.updateAndNotify(v);\n this.prev = v;\n this.prevUpdatedAt = this.prevFrameValue = undefined;\n endAnimation && this.stop();\n if (this.stopPassiveEffect)\n this.stopPassiveEffect();\n }\n dirty() {\n this.events.change?.notify(this.current);\n }\n addDependent(dependent) {\n if (!this.dependents) {\n this.dependents = new Set();\n }\n this.dependents.add(dependent);\n }\n removeDependent(dependent) {\n if (this.dependents) {\n this.dependents.delete(dependent);\n }\n }\n /**\n * Returns the latest state of `MotionValue`\n *\n * @returns - The latest state of `MotionValue`\n *\n * @public\n */\n get() {\n if (collectMotionValues.current) {\n collectMotionValues.current.push(this);\n }\n return this.current;\n }\n /**\n * @public\n */\n getPrevious() {\n return this.prev;\n }\n /**\n * Returns the latest velocity of `MotionValue`\n *\n * @returns - The latest velocity of `MotionValue`. Returns `0` if the state is non-numerical.\n *\n * @public\n */\n getVelocity() {\n const currentTime = time.now();\n if (!this.canTrackVelocity ||\n this.prevFrameValue === undefined ||\n currentTime - this.updatedAt > MAX_VELOCITY_DELTA) {\n return 0;\n }\n const delta = Math.min(this.updatedAt - this.prevUpdatedAt, MAX_VELOCITY_DELTA);\n // Casts because of parseFloat's poor typing\n return velocityPerSecond(parseFloat(this.current) -\n parseFloat(this.prevFrameValue), delta);\n }\n /**\n * Registers a new animation to control this `MotionValue`. Only one\n * animation can drive a `MotionValue` at one time.\n *\n * ```jsx\n * value.start()\n * ```\n *\n * @param animation - A function that starts the provided animation\n */\n start(startAnimation) {\n this.stop();\n return new Promise((resolve) => {\n this.hasAnimated = true;\n this.animation = startAnimation(resolve);\n if (this.events.animationStart) {\n this.events.animationStart.notify();\n }\n }).then(() => {\n if (this.events.animationComplete) {\n this.events.animationComplete.notify();\n }\n this.clearAnimation();\n });\n }\n /**\n * Stop the currently active animation.\n *\n * @public\n */\n stop() {\n if (this.animation) {\n this.animation.stop();\n if (this.events.animationCancel) {\n this.events.animationCancel.notify();\n }\n }\n this.clearAnimation();\n }\n /**\n * Returns `true` if this value is currently animating.\n *\n * @public\n */\n isAnimating() {\n return !!this.animation;\n }\n clearAnimation() {\n delete this.animation;\n }\n /**\n * Destroy and clean up subscribers to this `MotionValue`.\n *\n * The `MotionValue` hooks like `useMotionValue` and `useTransform` automatically\n * handle the lifecycle of the returned `MotionValue`, so this method is only necessary if you've manually\n * created a `MotionValue` via the `motionValue` function.\n *\n * @public\n */\n destroy() {\n this.dependents?.clear();\n this.events.destroy?.notify();\n this.clearListeners();\n this.stop();\n if (this.stopPassiveEffect) {\n this.stopPassiveEffect();\n }\n }\n}\nfunction motionValue(init, options) {\n return new MotionValue(init, options);\n}\n\nexport { MotionValue, collectMotionValues, motionValue };\n","import { createRenderBatcher } from './batcher.mjs';\n\nconst { schedule: microtask, cancel: cancelMicrotask } = \n/* @__PURE__ */ createRenderBatcher(queueMicrotask, false);\n\nexport { cancelMicrotask, microtask };\n","const isDragging = {\n x: false,\n y: false,\n};\nfunction isDragActive() {\n return isDragging.x || isDragging.y;\n}\n\nexport { isDragActive, isDragging };\n","import { isDragging } from './is-active.mjs';\n\nfunction setDragLock(axis) {\n if (axis === \"x\" || axis === \"y\") {\n if (isDragging[axis]) {\n return null;\n }\n else {\n isDragging[axis] = true;\n return () => {\n isDragging[axis] = false;\n };\n }\n }\n else {\n if (isDragging.x || isDragging.y) {\n return null;\n }\n else {\n isDragging.x = isDragging.y = true;\n return () => {\n isDragging.x = isDragging.y = false;\n };\n }\n }\n}\n\nexport { setDragLock };\n","import { resolveElements } from '../../utils/resolve-elements.mjs';\n\nfunction setupGesture(elementOrSelector, options) {\n const elements = resolveElements(elementOrSelector);\n const gestureAbortController = new AbortController();\n const eventOptions = {\n passive: true,\n ...options,\n signal: gestureAbortController.signal,\n };\n const cancel = () => gestureAbortController.abort();\n return [elements, eventOptions, cancel];\n}\n\nexport { setupGesture };\n","import { isDragActive } from './drag/state/is-active.mjs';\nimport { setupGesture } from './utils/setup.mjs';\n\nfunction isValidHover(event) {\n return !(event.pointerType === \"touch\" || isDragActive());\n}\n/**\n * Create a hover gesture. hover() is different to .addEventListener(\"pointerenter\")\n * in that it has an easier syntax, filters out polyfilled touch events, interoperates\n * with drag gestures, and automatically removes the \"pointerennd\" event listener when the hover ends.\n *\n * @public\n */\nfunction hover(elementOrSelector, onHoverStart, options = {}) {\n const [elements, eventOptions, cancel] = setupGesture(elementOrSelector, options);\n const onPointerEnter = (enterEvent) => {\n if (!isValidHover(enterEvent))\n return;\n const { target } = enterEvent;\n const onHoverEnd = onHoverStart(target, enterEvent);\n if (typeof onHoverEnd !== \"function\" || !target)\n return;\n const onPointerLeave = (leaveEvent) => {\n if (!isValidHover(leaveEvent))\n return;\n onHoverEnd(leaveEvent);\n target.removeEventListener(\"pointerleave\", onPointerLeave);\n };\n target.addEventListener(\"pointerleave\", onPointerLeave, eventOptions);\n };\n elements.forEach((element) => {\n element.addEventListener(\"pointerenter\", onPointerEnter, eventOptions);\n });\n return cancel;\n}\n\nexport { hover };\n","/**\n * Recursively traverse up the tree to check whether the provided child node\n * is the parent or a descendant of it.\n *\n * @param parent - Element to find\n * @param child - Element to test against parent\n */\nconst isNodeOrChild = (parent, child) => {\n if (!child) {\n return false;\n }\n else if (parent === child) {\n return true;\n }\n else {\n return isNodeOrChild(parent, child.parentElement);\n }\n};\n\nexport { isNodeOrChild };\n","const isPrimaryPointer = (event) => {\n if (event.pointerType === \"mouse\") {\n return typeof event.button !== \"number\" || event.button <= 0;\n }\n else {\n /**\n * isPrimary is true for all mice buttons, whereas every touch point\n * is regarded as its own input. So subsequent concurrent touch points\n * will be false.\n *\n * Specifically match against false here as incomplete versions of\n * PointerEvents in very old browser might have it set as undefined.\n */\n return event.isPrimary !== false;\n }\n};\n\nexport { isPrimaryPointer };\n","const focusableElements = new Set([\n \"BUTTON\",\n \"INPUT\",\n \"SELECT\",\n \"TEXTAREA\",\n \"A\",\n]);\nfunction isElementKeyboardAccessible(element) {\n return (focusableElements.has(element.tagName) ||\n element.tabIndex !== -1);\n}\n\nexport { isElementKeyboardAccessible };\n","const isPressing = new WeakSet();\n\nexport { isPressing };\n","import { isPressing } from './state.mjs';\n\n/**\n * Filter out events that are not \"Enter\" keys.\n */\nfunction filterEvents(callback) {\n return (event) => {\n if (event.key !== \"Enter\")\n return;\n callback(event);\n };\n}\nfunction firePointerEvent(target, type) {\n target.dispatchEvent(new PointerEvent(\"pointer\" + type, { isPrimary: true, bubbles: true }));\n}\nconst enableKeyboardPress = (focusEvent, eventOptions) => {\n const element = focusEvent.currentTarget;\n if (!element)\n return;\n const handleKeydown = filterEvents(() => {\n if (isPressing.has(element))\n return;\n firePointerEvent(element, \"down\");\n const handleKeyup = filterEvents(() => {\n firePointerEvent(element, \"up\");\n });\n const handleBlur = () => firePointerEvent(element, \"cancel\");\n element.addEventListener(\"keyup\", handleKeyup, eventOptions);\n element.addEventListener(\"blur\", handleBlur, eventOptions);\n });\n element.addEventListener(\"keydown\", handleKeydown, eventOptions);\n /**\n * Add an event listener that fires on blur to remove the keydown events.\n */\n element.addEventListener(\"blur\", () => element.removeEventListener(\"keydown\", handleKeydown), eventOptions);\n};\n\nexport { enableKeyboardPress };\n","import { isHTMLElement } from '../../utils/is-html-element.mjs';\nimport { isDragActive } from '../drag/state/is-active.mjs';\nimport { isNodeOrChild } from '../utils/is-node-or-child.mjs';\nimport { isPrimaryPointer } from '../utils/is-primary-pointer.mjs';\nimport { setupGesture } from '../utils/setup.mjs';\nimport { isElementKeyboardAccessible } from './utils/is-keyboard-accessible.mjs';\nimport { enableKeyboardPress } from './utils/keyboard.mjs';\nimport { isPressing } from './utils/state.mjs';\n\n/**\n * Filter out events that are not primary pointer events, or are triggering\n * while a Motion gesture is active.\n */\nfunction isValidPressEvent(event) {\n return isPrimaryPointer(event) && !isDragActive();\n}\n/**\n * Create a press gesture.\n *\n * Press is different to `\"pointerdown\"`, `\"pointerup\"` in that it\n * automatically filters out secondary pointer events like right\n * click and multitouch.\n *\n * It also adds accessibility support for keyboards, where\n * an element with a press gesture will receive focus and\n * trigger on Enter `\"keydown\"` and `\"keyup\"` events.\n *\n * This is different to a browser's `\"click\"` event, which does\n * respond to keyboards but only for the `\"click\"` itself, rather\n * than the press start and end/cancel. The element also needs\n * to be focusable for this to work, whereas a press gesture will\n * make an element focusable by default.\n *\n * @public\n */\nfunction press(targetOrSelector, onPressStart, options = {}) {\n const [targets, eventOptions, cancelEvents] = setupGesture(targetOrSelector, options);\n const startPress = (startEvent) => {\n const target = startEvent.currentTarget;\n if (!isValidPressEvent(startEvent))\n return;\n isPressing.add(target);\n const onPressEnd = onPressStart(target, startEvent);\n const onPointerEnd = (endEvent, success) => {\n window.removeEventListener(\"pointerup\", onPointerUp);\n window.removeEventListener(\"pointercancel\", onPointerCancel);\n if (isPressing.has(target)) {\n isPressing.delete(target);\n }\n if (!isValidPressEvent(endEvent)) {\n return;\n }\n if (typeof onPressEnd === \"function\") {\n onPressEnd(endEvent, { success });\n }\n };\n const onPointerUp = (upEvent) => {\n onPointerEnd(upEvent, target === window ||\n target === document ||\n options.useGlobalTarget ||\n isNodeOrChild(target, upEvent.target));\n };\n const onPointerCancel = (cancelEvent) => {\n onPointerEnd(cancelEvent, false);\n };\n window.addEventListener(\"pointerup\", onPointerUp, eventOptions);\n window.addEventListener(\"pointercancel\", onPointerCancel, eventOptions);\n };\n targets.forEach((target) => {\n const pointerDownTarget = options.useGlobalTarget ? window : target;\n pointerDownTarget.addEventListener(\"pointerdown\", startPress, eventOptions);\n if (isHTMLElement(target)) {\n target.addEventListener(\"focus\", (event) => enableKeyboardPress(event, eventOptions));\n if (!isElementKeyboardAccessible(target) &&\n !target.hasAttribute(\"tabindex\")) {\n target.tabIndex = 0;\n }\n }\n });\n return cancelEvents;\n}\n\nexport { press };\n","import { isObject } from 'motion-utils';\n\n/**\n * Checks if an element is an SVG element in a way\n * that works across iframes\n */\nfunction isSVGElement(element) {\n return isObject(element) && \"ownerSVGElement\" in element;\n}\n\nexport { isSVGElement };\n","import { isSVGElement } from './is-svg-element.mjs';\n\n/**\n * Checks if an element is specifically an SVGSVGElement (the root SVG element)\n * in a way that works across iframes\n */\nfunction isSVGSVGElement(element) {\n return isSVGElement(element) && element.tagName === \"svg\";\n}\n\nexport { isSVGSVGElement };\n","const isMotionValue = (value) => Boolean(value && value.getVelocity);\n\nexport { isMotionValue };\n","import { color } from '../color/index.mjs';\nimport { complex } from '../complex/index.mjs';\nimport { dimensionValueTypes } from '../dimensions.mjs';\nimport { testValueType } from '../test.mjs';\n\n/**\n * A list of all ValueTypes\n */\nconst valueTypes = [...dimensionValueTypes, color, complex];\n/**\n * Tests a value against the list of ValueTypes\n */\nconst findValueType = (v) => valueTypes.find(testValueType(v));\n\nexport { findValueType };\n","\"use client\";\nimport { createContext } from 'react';\n\n/**\n * @public\n */\nconst MotionConfigContext = createContext({\n transformPagePoint: (p) => p,\n isStatic: false,\n reducedMotion: \"never\",\n});\n\nexport { MotionConfigContext };\n","\"use client\";\nimport { useContext, useId, useEffect, useCallback } from 'react';\nimport { PresenceContext } from '../../context/PresenceContext.mjs';\n\n/**\n * When a component is the child of `AnimatePresence`, it can use `usePresence`\n * to access information about whether it's still present in the React tree.\n *\n * ```jsx\n * import { usePresence } from \"framer-motion\"\n *\n * export const Component = () => {\n * const [isPresent, safeToRemove] = usePresence()\n *\n * useEffect(() => {\n * !isPresent && setTimeout(safeToRemove, 1000)\n * }, [isPresent])\n *\n * return <div />\n * }\n * ```\n *\n * If `isPresent` is `false`, it means that a component has been removed the tree, but\n * `AnimatePresence` won't really remove it until `safeToRemove` has been called.\n *\n * @public\n */\nfunction usePresence(subscribe = true) {\n const context = useContext(PresenceContext);\n if (context === null)\n return [true, null];\n const { isPresent, onExitComplete, register } = context;\n // It's safe to call the following hooks conditionally (after an early return) because the context will always\n // either be null or non-null for the lifespan of the component.\n const id = useId();\n useEffect(() => {\n if (subscribe) {\n return register(id);\n }\n }, [subscribe]);\n const safeToRemove = useCallback(() => subscribe && onExitComplete && onExitComplete(id), [id, onExitComplete, subscribe]);\n return !isPresent && onExitComplete ? [false, safeToRemove] : [true];\n}\n/**\n * Similar to `usePresence`, except `useIsPresent` simply returns whether or not the component is present.\n * There is no `safeToRemove` function.\n *\n * ```jsx\n * import { useIsPresent } from \"framer-motion\"\n *\n * export const Component = () => {\n * const isPresent = useIsPresent()\n *\n * useEffect(() => {\n * !isPresent && console.log(\"I've been removed!\")\n * }, [isPresent])\n *\n * return <div />\n * }\n * ```\n *\n * @public\n */\nfunction useIsPresent() {\n return isPresent(useContext(PresenceContext));\n}\nfunction isPresent(context) {\n return context === null ? true : context.isPresent;\n}\n\nexport { isPresent, useIsPresent, usePresence };\n","\"use client\";\nimport { createContext } from 'react';\n\nconst LazyContext = createContext({ strict: false });\n\nexport { LazyContext };\n","const featureProps = {\n animation: [\n \"animate\",\n \"variants\",\n \"whileHover\",\n \"whileTap\",\n \"exit\",\n \"whileInView\",\n \"whileFocus\",\n \"whileDrag\",\n ],\n exit: [\"exit\"],\n drag: [\"drag\", \"dragControls\"],\n focus: [\"whileFocus\"],\n hover: [\"whileHover\", \"onHoverStart\", \"onHoverEnd\"],\n tap: [\"whileTap\", \"onTap\", \"onTapStart\", \"onTapCancel\"],\n pan: [\"onPan\", \"onPanStart\", \"onPanSessionStart\", \"onPanEnd\"],\n inView: [\"whileInView\", \"onViewportEnter\", \"onViewportLeave\"],\n layout: [\"layout\", \"layoutId\"],\n};\nconst featureDefinitions = {};\nfor (const key in featureProps) {\n featureDefinitions[key] = {\n isEnabled: (props) => featureProps[key].some((name) => !!props[name]),\n };\n}\n\nexport { featureDefinitions };\n","import { featureDefinitions } from './definitions.mjs';\n\nfunction loadFeatures(features) {\n for (const key in features) {\n featureDefinitions[key] = {\n ...featureDefinitions[key],\n ...features[key],\n };\n }\n}\n\nexport { loadFeatures };\n","/**\n * A list of all valid MotionProps.\n *\n * @privateRemarks\n * This doesn't throw if a `MotionProp` name is missing - it should.\n */\nconst validMotionProps = new Set([\n \"animate\",\n \"exit\",\n \"variants\",\n \"initial\",\n \"style\",\n \"values\",\n \"variants\",\n \"transition\",\n \"transformTemplate\",\n \"custom\",\n \"inherit\",\n \"onBeforeLayoutMeasure\",\n \"onAnimationStart\",\n \"onAnimationComplete\",\n \"onUpdate\",\n \"onDragStart\",\n \"onDrag\",\n \"onDragEnd\",\n \"onMeasureDragConstraints\",\n \"onDirectionLock\",\n \"onDragTransitionEnd\",\n \"_dragX\",\n \"_dragY\",\n \"onHoverStart\",\n \"onHoverEnd\",\n \"onViewportEnter\",\n \"onViewportLeave\",\n \"globalTapTarget\",\n \"ignoreStrict\",\n \"viewport\",\n]);\n/**\n * Check whether a prop name is a valid `MotionProp` key.\n *\n * @param key - Name of the property to check\n * @returns `true` is key is a valid `MotionProp`.\n *\n * @public\n */\nfunction isValidMotionProp(key) {\n return (key.startsWith(\"while\") ||\n (key.startsWith(\"drag\") && key !== \"draggable\") ||\n key.startsWith(\"layout\") ||\n key.startsWith(\"onTap\") ||\n key.startsWith(\"onPan\") ||\n key.startsWith(\"onLayout\") ||\n validMotionProps.has(key));\n}\n\nexport { isValidMotionProp };\n","import { isValidMotionProp } from '../../../motion/utils/valid-prop.mjs';\n\nlet shouldForward = (key) => !isValidMotionProp(key);\nfunction loadExternalIsValidProp(isValidProp) {\n if (typeof isValidProp !== \"function\")\n return;\n // Explicitly filter our events\n shouldForward = (key) => key.startsWith(\"on\") ? !isValidMotionProp(key) : isValidProp(key);\n}\n/**\n * Emotion and Styled Components both allow users to pass through arbitrary props to their components\n * to dynamically generate CSS. They both use the `@emotion/is-prop-valid` package to determine which\n * of these should be passed to the underlying DOM node.\n *\n * However, when styling a Motion component `styled(motion.div)`, both packages pass through *all* props\n * as it's seen as an arbitrary component rather than a DOM node. Motion only allows arbitrary props\n * passed through the `custom` prop so it doesn't *need* the payload or computational overhead of\n * `@emotion/is-prop-valid`, however to fix this problem we need to use it.\n *\n * By making it an optionalDependency we can offer this functionality only in the situations where it's\n * actually required.\n */\ntry {\n /**\n * We attempt to import this package but require won't be defined in esm environments, in that case\n * isPropValid will have to be provided via `MotionContext`. In a 6.0.0 this should probably be removed\n * in favour of explicit injection.\n */\n loadExternalIsValidProp(require(\"@emotion/is-prop-valid\").default);\n}\ncatch {\n // We don't need to actually do anything here - the fallback is the existing `isPropValid`.\n}\nfunction filterProps(props, isDom, forwardMotionProps) {\n const filteredProps = {};\n for (const key in props) {\n /**\n * values is considered a valid prop by Emotion, so if it's present\n * this will be rendered out to the DOM unless explicitly filtered.\n *\n * We check the type as it could be used with the `feColorMatrix`\n * element, which we support.\n */\n if (key === \"values\" && typeof props.values === \"object\")\n continue;\n if (shouldForward(key) ||\n (forwardMotionProps === true && isValidMotionProp(key)) ||\n (!isDom && !isValidMotionProp(key)) ||\n // If trying to use native HTML drag events, forward drag listeners\n (props[\"draggable\"] &&\n key.startsWith(\"onDrag\"))) {\n filteredProps[key] =\n props[key];\n }\n }\n return filteredProps;\n}\n\nexport { filterProps, loadExternalIsValidProp };\n","\"use client\";\nimport { jsxs, jsx } from 'react/jsx-runtime';\nimport { warning, invariant } from 'motion-utils';\nimport { forwardRef, useContext } from 'react';\nimport { LayoutGroupContext } from '../context/LayoutGroupContext.mjs';\nimport { LazyContext } from '../context/LazyContext.mjs';\nimport { MotionConfigContext } from '../context/MotionConfigContext.mjs';\nimport { MotionContext } from '../context/MotionContext/index.mjs';\nimport { useCreateMotionContext } from '../context/MotionContext/create.mjs';\nimport { useRender } from '../render/dom/use-render.mjs';\nimport { isSVGComponent } from '../render/dom/utils/is-svg-component.mjs';\nimport { useHTMLVisualState } from '../render/html/use-html-visual-state.mjs';\nimport { useSVGVisualState } from '../render/svg/use-svg-visual-state.mjs';\nimport { isBrowser } from '../utils/is-browser.mjs';\nimport { featureDefinitions } from './features/definitions.mjs';\nimport { loadFeatures } from './features/load-features.mjs';\nimport { motionComponentSymbol } from './utils/symbol.mjs';\nimport { useMotionRef } from './utils/use-motion-ref.mjs';\nimport { useVisualElement } from './utils/use-visual-element.mjs';\n\n/**\n * Create a `motion` component.\n *\n * This function accepts a Component argument, which can be either a string (ie \"div\"\n * for `motion.div`), or an actual React component.\n *\n * Alongside this is a config option which provides a way of rendering the provided\n * component \"offline\", or outside the React render cycle.\n */\nfunction createMotionComponent(Component, { forwardMotionProps = false } = {}, preloadedFeatures, createVisualElement) {\n preloadedFeatures && loadFeatures(preloadedFeatures);\n const useVisualState = isSVGComponent(Component)\n ? useSVGVisualState\n : useHTMLVisualState;\n function MotionDOMComponent(props, externalRef) {\n /**\n * If we need to measure the element we load this functionality in a\n * separate class component in order to gain access to getSnapshotBeforeUpdate.\n */\n let MeasureLayout;\n const configAndProps = {\n ...useContext(MotionConfigContext),\n ...props,\n layoutId: useLayoutId(props),\n };\n const { isStatic } = configAndProps;\n const context = useCreateMotionContext(props);\n const visualState = useVisualState(props, isStatic);\n if (!isStatic && isBrowser) {\n useStrictMode(configAndProps, preloadedFeatures);\n const layoutProjection = getProjectionFunctionality(configAndProps);\n MeasureLayout = layoutProjection.MeasureLayout;\n /**\n * Create a VisualElement for this component. A VisualElement provides a common\n * interface to renderer-specific APIs (ie DOM/Three.js etc) as well as\n * providing a way of rendering to these APIs outside of the React render loop\n * for more performant animations and interactions\n */\n context.visualElement = useVisualElement(Component, visualState, configAndProps, createVisualElement, layoutProjection.ProjectionNode);\n }\n /**\n * The mount order and hierarchy is specific to ensure our element ref\n * is hydrated by the time features fire their effects.\n */\n return (jsxs(MotionContext.Provider, { value: context, children: [MeasureLayout && context.visualElement ? (jsx(MeasureLayout, { visualElement: context.visualElement, ...configAndProps })) : null, useRender(Component, props, useMotionRef(visualState, context.visualElement, externalRef), visualState, isStatic, forwardMotionProps)] }));\n }\n MotionDOMComponent.displayName = `motion.${typeof Component === \"string\"\n ? Component\n : `create(${Component.displayName ?? Component.name ?? \"\"})`}`;\n const ForwardRefMotionComponent = forwardRef(MotionDOMComponent);\n ForwardRefMotionComponent[motionComponentSymbol] = Component;\n return ForwardRefMotionComponent;\n}\nfunction useLayoutId({ layoutId }) {\n const layoutGroupId = useContext(LayoutGroupContext).id;\n return layoutGroupId && layoutId !== undefined\n ? layoutGroupId + \"-\" + layoutId\n : layoutId;\n}\nfunction useStrictMode(configAndProps, preloadedFeatures) {\n const isStrict = useContext(LazyContext).strict;\n /**\n * If we're in development mode, check to make sure we're not rendering a motion component\n * as a child of LazyMotion, as this will break the file-size benefits of using it.\n */\n if (process.env.NODE_ENV !== \"production\" &&\n preloadedFeatures &&\n isStrict) {\n const strictMessage = \"You have rendered a `motion` component within a `LazyMotion` component. This will break tree shaking. Import and render a `m` component instead.\";\n configAndProps.ignoreStrict\n ? warning(false, strictMessage, \"lazy-strict-mode\")\n : invariant(false, strictMessage, \"lazy-strict-mode\");\n }\n}\nfunction getProjectionFunctionality(props) {\n const { drag, layout } = featureDefinitions;\n if (!drag && !layout)\n return {};\n const combined = { ...drag, ...layout };\n return {\n MeasureLayout: drag?.isEnabled(props) || layout?.isEnabled(props)\n ? combined.MeasureLayout\n : undefined,\n ProjectionNode: combined.ProjectionNode,\n };\n}\n\nexport { createMotionComponent };\n","\"use client\";\nimport { createContext } from 'react';\n\nconst MotionContext = /* @__PURE__ */ createContext({});\n\nexport { MotionContext };\n","\"use client\";\nimport { useContext, useMemo } from 'react';\nimport { MotionContext } from './index.mjs';\nimport { getCurrentTreeVariants } from './utils.mjs';\n\nfunction useCreateMotionContext(props) {\n const { initial, animate } = getCurrentTreeVariants(props, useContext(MotionContext));\n return useMemo(() => ({ initial, animate }), [variantLabelsAsDependency(initial), variantLabelsAsDependency(animate)]);\n}\nfunction variantLabelsAsDependency(prop) {\n return Array.isArray(prop) ? prop.join(\" \") : prop;\n}\n\nexport { useCreateMotionContext };\n","function isAnimationControls(v) {\n return (v !== null &&\n typeof v === \"object\" &&\n typeof v.start === \"function\");\n}\n\nexport { isAnimationControls };\n","/**\n * Decides if the supplied variable is variant label\n */\nfunction isVariantLabel(v) {\n return typeof v === \"string\" || Array.isArray(v);\n}\n\nexport { isVariantLabel };\n","const variantPriorityOrder = [\n \"animate\",\n \"whileInView\",\n \"whileFocus\",\n \"whileHover\",\n \"whileTap\",\n \"whileDrag\",\n \"exit\",\n];\nconst variantProps = [\"initial\", ...variantPriorityOrder];\n\nexport { variantPriorityOrder, variantProps };\n","import { isAnimationControls } from '../../animation/utils/is-animation-controls.mjs';\nimport { isVariantLabel } from './is-variant-label.mjs';\nimport { variantProps } from './variant-props.mjs';\n\nfunction isControllingVariants(props) {\n return (isAnimationControls(props.animate) ||\n variantProps.some((name) => isVariantLabel(props[name])));\n}\nfunction isVariantNode(props) {\n return Boolean(isControllingVariants(props) || props.variants);\n}\n\nexport { isControllingVariants, isVariantNode };\n","import { isControllingVariants } from '../../render/utils/is-controlling-variants.mjs';\nimport { isVariantLabel } from '../../render/utils/is-variant-label.mjs';\n\nfunction getCurrentTreeVariants(props, context) {\n if (isControllingVariants(props)) {\n const { initial, animate } = props;\n return {\n initial: initial === false || isVariantLabel(initial)\n ? initial\n : undefined,\n animate: isVariantLabel(animate) ? animate : undefined,\n };\n }\n return props.inherit !== false ? context : {};\n}\n\nexport { getCurrentTreeVariants };\n","\"use client\";\nimport { isMotionValue } from 'motion-dom';\nimport { Fragment, useMemo, createElement } from 'react';\nimport { useHTMLProps } from '../html/use-props.mjs';\nimport { useSVGProps } from '../svg/use-props.mjs';\nimport { filterProps } from './utils/filter-props.mjs';\nimport { isSVGComponent } from './utils/is-svg-component.mjs';\n\nfunction useRender(Component, props, ref, { latestValues, }, isStatic, forwardMotionProps = false) {\n const useVisualProps = isSVGComponent(Component)\n ? useSVGProps\n : useHTMLProps;\n const visualProps = useVisualProps(props, latestValues, isStatic, Component);\n const filteredProps = filterProps(props, typeof Component === \"string\", forwardMotionProps);\n const elementProps = Component !== Fragment ? { ...filteredProps, ...visualProps, ref } : {};\n /**\n * If component has been handed a motion value as its child,\n * memoise its initial value and render that. Subsequent updates\n * will be handled by the onChange handler\n */\n const { children } = props;\n const renderedChildren = useMemo(() => (isMotionValue(children) ? children.get() : children), [children]);\n return createElement(Component, {\n ...elementProps,\n children: renderedChildren,\n });\n}\n\nexport { useRender };\n","\"use client\";\nimport { isMotionValue } from 'motion-dom';\nimport { useMemo } from 'react';\nimport { isForcedMotionValue } from '../../motion/utils/is-forced-motion-value.mjs';\nimport { buildHTMLStyles } from './utils/build-styles.mjs';\nimport { createHtmlRenderState } from './utils/create-render-state.mjs';\n\nfunction copyRawValuesOnly(target, source, props) {\n for (const key in source) {\n if (!isMotionValue(source[key]) && !isForcedMotionValue(key, props)) {\n target[key] = source[key];\n }\n }\n}\nfunction useInitialMotionValues({ transformTemplate }, visualState) {\n return useMemo(() => {\n const state = createHtmlRenderState();\n buildHTMLStyles(state, visualState, transformTemplate);\n return Object.assign({}, state.vars, state.style);\n }, [visualState]);\n}\nfunction useStyle(props, visualState) {\n const styleProp = props.style || {};\n const style = {};\n /**\n * Copy non-Motion Values straight into style\n */\n copyRawValuesOnly(style, styleProp, props);\n Object.assign(style, useInitialMotionValues(props, visualState));\n return style;\n}\nfunction useHTMLProps(props, visualState) {\n // The `any` isn't ideal but it is the type of createElement props argument\n const htmlProps = {};\n const style = useStyle(props, visualState);\n if (props.drag && props.dragListener !== false) {\n // Disable the ghost element when a user drags\n htmlProps.draggable = false;\n // Disable text selection\n style.userSelect =\n style.WebkitUserSelect =\n style.WebkitTouchCallout =\n \"none\";\n // Disable scrolling on the draggable direction\n style.touchAction =\n props.drag === true\n ? \"none\"\n : `pan-${props.drag === \"x\" ? \"y\" : \"x\"}`;\n }\n if (props.tabIndex === undefined &&\n (props.onTap || props.onTapStart || props.whileTap)) {\n htmlProps.tabIndex = 0;\n }\n htmlProps.style = style;\n return htmlProps;\n}\n\nexport { copyRawValuesOnly, useHTMLProps };\n","import { px } from 'motion-dom';\n\nfunction pixelsToPercent(pixels, axis) {\n if (axis.max === axis.min)\n return 0;\n return (pixels / (axis.max - axis.min)) * 100;\n}\n/**\n * We always correct borderRadius as a percentage rather than pixels to reduce paints.\n * For example, if you are projecting a box that is 100px wide with a 10px borderRadius\n * into a box that is 200px wide with a 20px borderRadius, that is actually a 10%\n * borderRadius in both states. If we animate between the two in pixels that will trigger\n * a paint each time. If we animate between the two in percentage we'll avoid a paint.\n */\nconst correctBorderRadius = {\n correct: (latest, node) => {\n if (!node.target)\n return latest;\n /**\n * If latest is a string, if it's a percentage we can return immediately as it's\n * going to be stretched appropriately. Otherwise, if it's a pixel, convert it to a number.\n */\n if (typeof latest === \"string\") {\n if (px.test(latest)) {\n latest = parseFloat(latest);\n }\n else {\n return latest;\n }\n }\n /**\n * If latest is a number, it's a pixel value. We use the current viewportBox to calculate that\n * pixel value as a percentage of each axis\n */\n const x = pixelsToPercent(latest, node.target.x);\n const y = pixelsToPercent(latest, node.target.y);\n return `${x}% ${y}%`;\n },\n};\n\nexport { correctBorderRadius, pixelsToPercent };\n","import { complex, mixNumber } from 'motion-dom';\n\nconst correctBoxShadow = {\n correct: (latest, { treeScale, projectionDelta }) => {\n const original = latest;\n const shadow = complex.parse(latest);\n // TODO: Doesn't support multiple shadows\n if (shadow.length > 5)\n return original;\n const template = complex.createTransformer(latest);\n const offset = typeof shadow[0] !== \"number\" ? 1 : 0;\n // Calculate the overall context scale\n const xScale = projectionDelta.x.scale * treeScale.x;\n const yScale = projectionDelta.y.scale * treeScale.y;\n shadow[0 + offset] /= xScale;\n shadow[1 + offset] /= yScale;\n /**\n * Ideally we'd correct x and y scales individually, but because blur and\n * spread apply to both we have to take a scale average and apply that instead.\n * We could potentially improve the outcome of this by incorporating the ratio between\n * the two scales.\n */\n const averageScale = mixNumber(xScale, yScale, 0.5);\n // Blur\n if (typeof shadow[2 + offset] === \"number\")\n shadow[2 + offset] /= averageScale;\n // Spread\n if (typeof shadow[3 + offset] === \"number\")\n shadow[3 + offset] /= averageScale;\n return template(shadow);\n },\n};\n\nexport { correctBoxShadow };\n","import { isCSSVariableName } from 'motion-dom';\nimport { correctBorderRadius } from './scale-border-radius.mjs';\nimport { correctBoxShadow } from './scale-box-shadow.mjs';\n\nconst scaleCorrectors = {\n borderRadius: {\n ...correctBorderRadius,\n applyTo: [\n \"borderTopLeftRadius\",\n \"borderTopRightRadius\",\n \"borderBottomLeftRadius\",\n \"borderBottomRightRadius\",\n ],\n },\n borderTopLeftRadius: correctBorderRadius,\n borderTopRightRadius: correctBorderRadius,\n borderBottomLeftRadius: correctBorderRadius,\n borderBottomRightRadius: correctBorderRadius,\n boxShadow: correctBoxShadow,\n};\nfunction addScaleCorrector(correctors) {\n for (const key in correctors) {\n scaleCorrectors[key] = correctors[key];\n if (isCSSVariableName(key)) {\n scaleCorrectors[key].isCSSVariable = true;\n }\n }\n}\n\nexport { addScaleCorrector, scaleCorrectors };\n","import { transformProps } from 'motion-dom';\nimport { scaleCorrectors } from '../../projection/styles/scale-correction.mjs';\n\nfunction isForcedMotionValue(key, { layout, layoutId }) {\n return (transformProps.has(key) ||\n key.startsWith(\"origin\") ||\n ((layout || layoutId !== undefined) &&\n (!!scaleCorrectors[key] || key === \"opacity\")));\n}\n\nexport { isForcedMotionValue };\n","import { transformPropOrder, getValueAsType, numberValueTypes } from 'motion-dom';\n\nconst translateAlias = {\n x: \"translateX\",\n y: \"translateY\",\n z: \"translateZ\",\n transformPerspective: \"perspective\",\n};\nconst numTransforms = transformPropOrder.length;\n/**\n * Build a CSS transform style from individual x/y/scale etc properties.\n *\n * This outputs with a default order of transforms/scales/rotations, this can be customised by\n * providing a transformTemplate function.\n */\nfunction buildTransform(latestValues, transform, transformTemplate) {\n // The transform string we're going to build into.\n let transformString = \"\";\n let transformIsDefault = true;\n /**\n * Loop over all possible transforms in order, adding the ones that\n * are present to the transform string.\n */\n for (let i = 0; i < numTransforms; i++) {\n const key = transformPropOrder[i];\n const value = latestValues[key];\n if (value === undefined)\n continue;\n let valueIsDefault = true;\n if (typeof value === \"number\") {\n valueIsDefault = value === (key.startsWith(\"scale\") ? 1 : 0);\n }\n else {\n valueIsDefault = parseFloat(value) === 0;\n }\n if (!valueIsDefault || transformTemplate) {\n const valueAsType = getValueAsType(value, numberValueTypes[key]);\n if (!valueIsDefault) {\n transformIsDefault = false;\n const transformName = translateAlias[key] || key;\n transformString += `${transformName}(${valueAsType}) `;\n }\n if (transformTemplate) {\n transform[key] = valueAsType;\n }\n }\n }\n transformString = transformString.trim();\n // If we have a custom `transform` template, pass our transform values and\n // generated transformString to that before returning\n if (transformTemplate) {\n transformString = transformTemplate(transform, transformIsDefault ? \"\" : transformString);\n }\n else if (transformIsDefault) {\n transformString = \"none\";\n }\n return transformString;\n}\n\nexport { buildTransform };\n","import { transformProps, isCSSVariableName, getValueAsType, numberValueTypes } from 'motion-dom';\nimport { buildTransform } from './build-transform.mjs';\n\nfunction buildHTMLStyles(state, latestValues, transformTemplate) {\n const { style, vars, transformOrigin } = state;\n // Track whether we encounter any transform or transformOrigin values.\n let hasTransform = false;\n let hasTransformOrigin = false;\n /**\n * Loop over all our latest animated values and decide whether to handle them\n * as a style or CSS variable.\n *\n * Transforms and transform origins are kept separately for further processing.\n */\n for (const key in latestValues) {\n const value = latestValues[key];\n if (transformProps.has(key)) {\n // If this is a transform, flag to enable further transform processing\n hasTransform = true;\n continue;\n }\n else if (isCSSVariableName(key)) {\n vars[key] = value;\n continue;\n }\n else {\n // Convert the value to its default value type, ie 0 -> \"0px\"\n const valueAsType = getValueAsType(value, numberValueTypes[key]);\n if (key.startsWith(\"origin\")) {\n // If this is a transform origin, flag and enable further transform-origin processing\n hasTransformOrigin = true;\n transformOrigin[key] =\n valueAsType;\n }\n else {\n style[key] = valueAsType;\n }\n }\n }\n if (!latestValues.transform) {\n if (hasTransform || transformTemplate) {\n style.transform = buildTransform(latestValues, state.transform, transformTemplate);\n }\n else if (style.transform) {\n /**\n * If we have previously created a transform but currently don't have any,\n * reset transform style to none.\n */\n style.transform = \"none\";\n }\n }\n /**\n * Build a transformOrigin style. Uses the same defaults as the browser for\n * undefined origins.\n */\n if (hasTransformOrigin) {\n const { originX = \"50%\", originY = \"50%\", originZ = 0, } = transformOrigin;\n style.transformOrigin = `${originX} ${originY} ${originZ}`;\n }\n}\n\nexport { buildHTMLStyles };\n","const createHtmlRenderState = () => ({\n style: {},\n transform: {},\n transformOrigin: {},\n vars: {},\n});\n\nexport { createHtmlRenderState };\n","\"use client\";\nimport { useMemo } from 'react';\nimport { copyRawValuesOnly } from '../html/use-props.mjs';\nimport { buildSVGAttrs } from './utils/build-attrs.mjs';\nimport { createSvgRenderState } from './utils/create-render-state.mjs';\nimport { isSVGTag } from './utils/is-svg-tag.mjs';\n\nfunction useSVGProps(props, visualState, _isStatic, Component) {\n const visualProps = useMemo(() => {\n const state = createSvgRenderState();\n buildSVGAttrs(state, visualState, isSVGTag(Component), props.transformTemplate, props.style);\n return {\n ...state.attrs,\n style: { ...state.style },\n };\n }, [visualState]);\n if (props.style) {\n const rawStyles = {};\n copyRawValuesOnly(rawStyles, props.style, props);\n visualProps.style = { ...rawStyles, ...visualProps.style };\n }\n return visualProps;\n}\n\nexport { useSVGProps };\n","import { px } from 'motion-dom';\n\nconst dashKeys = {\n offset: \"stroke-dashoffset\",\n array: \"stroke-dasharray\",\n};\nconst camelKeys = {\n offset: \"strokeDashoffset\",\n array: \"strokeDasharray\",\n};\n/**\n * Build SVG path properties. Uses the path's measured length to convert\n * our custom pathLength, pathSpacing and pathOffset into stroke-dashoffset\n * and stroke-dasharray attributes.\n *\n * This function is mutative to reduce per-frame GC.\n */\nfunction buildSVGPath(attrs, length, spacing = 1, offset = 0, useDashCase = true) {\n // Normalise path length by setting SVG attribute pathLength to 1\n attrs.pathLength = 1;\n // We use dash case when setting attributes directly to the DOM node and camel case\n // when defining props on a React component.\n const keys = useDashCase ? dashKeys : camelKeys;\n // Build the dash offset\n attrs[keys.offset] = px.transform(-offset);\n // Build the dash array\n const pathLength = px.transform(length);\n const pathSpacing = px.transform(spacing);\n attrs[keys.array] = `${pathLength} ${pathSpacing}`;\n}\n\nexport { buildSVGPath };\n","import { buildHTMLStyles } from '../../html/utils/build-styles.mjs';\nimport { buildSVGPath } from './path.mjs';\n\n/**\n * Build SVG visual attributes, like cx and style.transform\n */\nfunction buildSVGAttrs(state, { attrX, attrY, attrScale, pathLength, pathSpacing = 1, pathOffset = 0, \n// This is object creation, which we try to avoid per-frame.\n...latest }, isSVGTag, transformTemplate, styleProp) {\n buildHTMLStyles(state, latest, transformTemplate);\n /**\n * For svg tags we just want to make sure viewBox is animatable and treat all the styles\n * as normal HTML tags.\n */\n if (isSVGTag) {\n if (state.style.viewBox) {\n state.attrs.viewBox = state.style.viewBox;\n }\n return;\n }\n state.attrs = state.style;\n state.style = {};\n const { attrs, style } = state;\n /**\n * However, we apply transforms as CSS transforms.\n * So if we detect a transform, transformOrigin we take it from attrs and copy it into style.\n */\n if (attrs.transform) {\n style.transform = attrs.transform;\n delete attrs.transform;\n }\n if (style.transform || attrs.transformOrigin) {\n style.transformOrigin = attrs.transformOrigin ?? \"50% 50%\";\n delete attrs.transformOrigin;\n }\n if (style.transform) {\n /**\n * SVG's element transform-origin uses its own median as a reference.\n * Therefore, transformBox becomes a fill-box\n */\n style.transformBox = styleProp?.transformBox ?? \"fill-box\";\n delete attrs.transformBox;\n }\n // Render attrX/attrY/attrScale as attributes\n if (attrX !== undefined)\n attrs.x = attrX;\n if (attrY !== undefined)\n attrs.y = attrY;\n if (attrScale !== undefined)\n attrs.scale = attrScale;\n // Build SVG path if one has been defined\n if (pathLength !== undefined) {\n buildSVGPath(attrs, pathLength, pathSpacing, pathOffset, false);\n }\n}\n\nexport { buildSVGAttrs };\n","import { createHtmlRenderState } from '../../html/utils/create-render-state.mjs';\n\nconst createSvgRenderState = () => ({\n ...createHtmlRenderState(),\n attrs: {},\n});\n\nexport { createSvgRenderState };\n","const isSVGTag = (tag) => typeof tag === \"string\" && tag.toLowerCase() === \"svg\";\n\nexport { isSVGTag };\n","/**\n * We keep these listed separately as we use the lowercase tag names as part\n * of the runtime bundle to detect SVG components\n */\nconst lowercaseSVGElements = [\n \"animate\",\n \"circle\",\n \"defs\",\n \"desc\",\n \"ellipse\",\n \"g\",\n \"image\",\n \"line\",\n \"filter\",\n \"marker\",\n \"mask\",\n \"metadata\",\n \"path\",\n \"pattern\",\n \"polygon\",\n \"polyline\",\n \"rect\",\n \"stop\",\n \"switch\",\n \"symbol\",\n \"svg\",\n \"text\",\n \"tspan\",\n \"use\",\n \"view\",\n];\n\nexport { lowercaseSVGElements };\n","import { lowercaseSVGElements } from '../../svg/lowercase-elements.mjs';\n\nfunction isSVGComponent(Component) {\n if (\n /**\n * If it's not a string, it's a custom React component. Currently we only support\n * HTML custom React components.\n */\n typeof Component !== \"string\" ||\n /**\n * If it contains a dash, the element is a custom HTML webcomponent.\n */\n Component.includes(\"-\")) {\n return false;\n }\n else if (\n /**\n * If it's in our list of lowercase SVG tags, it's an SVG component\n */\n lowercaseSVGElements.indexOf(Component) > -1 ||\n /**\n * If it contains a capital letter, it's an SVG component\n */\n /[A-Z]/u.test(Component)) {\n return true;\n }\n return false;\n}\n\nexport { isSVGComponent };\n","\"use client\";\nimport { useContext } from 'react';\nimport { isAnimationControls } from '../../animation/utils/is-animation-controls.mjs';\nimport { MotionContext } from '../../context/MotionContext/index.mjs';\nimport { PresenceContext } from '../../context/PresenceContext.mjs';\nimport { isControllingVariants, isVariantNode } from '../../render/utils/is-controlling-variants.mjs';\nimport { resolveVariantFromProps } from '../../render/utils/resolve-variants.mjs';\nimport { useConstant } from '../../utils/use-constant.mjs';\nimport { resolveMotionValue } from '../../value/utils/resolve-motion-value.mjs';\n\nfunction makeState({ scrapeMotionValuesFromProps, createRenderState, }, props, context, presenceContext) {\n const state = {\n latestValues: makeLatestValues(props, context, presenceContext, scrapeMotionValuesFromProps),\n renderState: createRenderState(),\n };\n return state;\n}\nfunction makeLatestValues(props, context, presenceContext, scrapeMotionValues) {\n const values = {};\n const motionValues = scrapeMotionValues(props, {});\n for (const key in motionValues) {\n values[key] = resolveMotionValue(motionValues[key]);\n }\n let { initial, animate } = props;\n const isControllingVariants$1 = isControllingVariants(props);\n const isVariantNode$1 = isVariantNode(props);\n if (context &&\n isVariantNode$1 &&\n !isControllingVariants$1 &&\n props.inherit !== false) {\n if (initial === undefined)\n initial = context.initial;\n if (animate === undefined)\n animate = context.animate;\n }\n let isInitialAnimationBlocked = presenceContext\n ? presenceContext.initial === false\n : false;\n isInitialAnimationBlocked = isInitialAnimationBlocked || initial === false;\n const variantToSet = isInitialAnimationBlocked ? animate : initial;\n if (variantToSet &&\n typeof variantToSet !== \"boolean\" &&\n !isAnimationControls(variantToSet)) {\n const list = Array.isArray(variantToSet) ? variantToSet : [variantToSet];\n for (let i = 0; i < list.length; i++) {\n const resolved = resolveVariantFromProps(props, list[i]);\n if (resolved) {\n const { transitionEnd, transition, ...target } = resolved;\n for (const key in target) {\n let valueTarget = target[key];\n if (Array.isArray(valueTarget)) {\n /**\n * Take final keyframe if the initial animation is blocked because\n * we want to initialise at the end of that blocked animation.\n */\n const index = isInitialAnimationBlocked\n ? valueTarget.length - 1\n : 0;\n valueTarget = valueTarget[index];\n }\n if (valueTarget !== null) {\n values[key] = valueTarget;\n }\n }\n for (const key in transitionEnd) {\n values[key] = transitionEnd[key];\n }\n }\n }\n }\n return values;\n}\nconst makeUseVisualState = (config) => (props, isStatic) => {\n const context = useContext(MotionContext);\n const presenceContext = useContext(PresenceContext);\n const make = () => makeState(config, props, context, presenceContext);\n return isStatic ? make() : useConstant(make);\n};\n\nexport { makeUseVisualState };\n","function getValueState(visualElement) {\n const state = [{}, {}];\n visualElement?.values.forEach((value, key) => {\n state[0][key] = value.get();\n state[1][key] = value.getVelocity();\n });\n return state;\n}\nfunction resolveVariantFromProps(props, definition, custom, visualElement) {\n /**\n * If the variant definition is a function, resolve.\n */\n if (typeof definition === \"function\") {\n const [current, velocity] = getValueState(visualElement);\n definition = definition(custom !== undefined ? custom : props.custom, current, velocity);\n }\n /**\n * If the variant definition is a variant label, or\n * the function returned a variant label, resolve.\n */\n if (typeof definition === \"string\") {\n definition = props.variants && props.variants[definition];\n }\n /**\n * At this point we've resolved both functions and variant labels,\n * but the resolved variant label might itself have been a function.\n * If so, resolve. This can only have returned a valid target object.\n */\n if (typeof definition === \"function\") {\n const [current, velocity] = getValueState(visualElement);\n definition = definition(custom !== undefined ? custom : props.custom, current, velocity);\n }\n return definition;\n}\n\nexport { resolveVariantFromProps };\n","import { isMotionValue } from 'motion-dom';\n\n/**\n * If the provided value is a MotionValue, this returns the actual value, otherwise just the value itself\n *\n * TODO: Remove and move to library\n */\nfunction resolveMotionValue(value) {\n return isMotionValue(value) ? value.get() : value;\n}\n\nexport { resolveMotionValue };\n","import { isMotionValue } from 'motion-dom';\nimport { isForcedMotionValue } from '../../../motion/utils/is-forced-motion-value.mjs';\n\nfunction scrapeMotionValuesFromProps(props, prevProps, visualElement) {\n const { style } = props;\n const newValues = {};\n for (const key in style) {\n if (isMotionValue(style[key]) ||\n (prevProps.style &&\n isMotionValue(prevProps.style[key])) ||\n isForcedMotionValue(key, props) ||\n visualElement?.getValue(key)?.liveStyle !== undefined) {\n newValues[key] = style[key];\n }\n }\n return newValues;\n}\n\nexport { scrapeMotionValuesFromProps };\n","\"use client\";\nimport { makeUseVisualState } from '../../motion/utils/use-visual-state.mjs';\nimport { createHtmlRenderState } from './utils/create-render-state.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\n\nconst useHTMLVisualState = /*@__PURE__*/ makeUseVisualState({\n scrapeMotionValuesFromProps,\n createRenderState: createHtmlRenderState,\n});\n\nexport { useHTMLVisualState };\n","import { isMotionValue, transformPropOrder } from 'motion-dom';\nimport { scrapeMotionValuesFromProps as scrapeMotionValuesFromProps$1 } from '../../html/utils/scrape-motion-values.mjs';\n\nfunction scrapeMotionValuesFromProps(props, prevProps, visualElement) {\n const newValues = scrapeMotionValuesFromProps$1(props, prevProps, visualElement);\n for (const key in props) {\n if (isMotionValue(props[key]) ||\n isMotionValue(prevProps[key])) {\n const targetKey = transformPropOrder.indexOf(key) !== -1\n ? \"attr\" + key.charAt(0).toUpperCase() + key.substring(1)\n : key;\n newValues[targetKey] = props[key];\n }\n }\n return newValues;\n}\n\nexport { scrapeMotionValuesFromProps };\n","\"use client\";\nimport { makeUseVisualState } from '../../motion/utils/use-visual-state.mjs';\nimport { createSvgRenderState } from './utils/create-render-state.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\n\nconst useSVGVisualState = /*@__PURE__*/ makeUseVisualState({\n scrapeMotionValuesFromProps: scrapeMotionValuesFromProps,\n createRenderState: createSvgRenderState,\n});\n\nexport { useSVGVisualState };\n","const motionComponentSymbol = Symbol.for(\"motionComponentSymbol\");\n\nexport { motionComponentSymbol };\n","\"use client\";\nimport { useCallback } from 'react';\nimport { isRefObject } from '../../utils/is-ref-object.mjs';\n\n/**\n * Creates a ref function that, when called, hydrates the provided\n * external ref and VisualElement.\n */\nfunction useMotionRef(visualState, visualElement, externalRef) {\n return useCallback((instance) => {\n if (instance) {\n visualState.onMount && visualState.onMount(instance);\n }\n if (visualElement) {\n if (instance) {\n visualElement.mount(instance);\n }\n else {\n visualElement.unmount();\n }\n }\n if (externalRef) {\n if (typeof externalRef === \"function\") {\n externalRef(instance);\n }\n else if (isRefObject(externalRef)) {\n externalRef.current = instance;\n }\n }\n }, \n /**\n * Include externalRef in dependencies to ensure the callback updates\n * when the ref changes, allowing proper ref forwarding.\n */\n [visualElement]);\n}\n\nexport { useMotionRef };\n","function isRefObject(ref) {\n return (ref &&\n typeof ref === \"object\" &&\n Object.prototype.hasOwnProperty.call(ref, \"current\"));\n}\n\nexport { isRefObject };\n","\"use client\";\nimport { useContext, useRef, useInsertionEffect, useEffect } from 'react';\nimport { optimizedAppearDataAttribute } from '../../animation/optimized-appear/data-id.mjs';\nimport { LazyContext } from '../../context/LazyContext.mjs';\nimport { MotionConfigContext } from '../../context/MotionConfigContext.mjs';\nimport { MotionContext } from '../../context/MotionContext/index.mjs';\nimport { PresenceContext } from '../../context/PresenceContext.mjs';\nimport { SwitchLayoutGroupContext } from '../../context/SwitchLayoutGroupContext.mjs';\nimport { isRefObject } from '../../utils/is-ref-object.mjs';\nimport { useIsomorphicLayoutEffect } from '../../utils/use-isomorphic-effect.mjs';\n\nfunction useVisualElement(Component, visualState, props, createVisualElement, ProjectionNodeConstructor) {\n const { visualElement: parent } = useContext(MotionContext);\n const lazyContext = useContext(LazyContext);\n const presenceContext = useContext(PresenceContext);\n const reducedMotionConfig = useContext(MotionConfigContext).reducedMotion;\n const visualElementRef = useRef(null);\n /**\n * If we haven't preloaded a renderer, check to see if we have one lazy-loaded\n */\n createVisualElement =\n createVisualElement ||\n lazyContext.renderer;\n if (!visualElementRef.current && createVisualElement) {\n visualElementRef.current = createVisualElement(Component, {\n visualState,\n parent,\n props,\n presenceContext,\n blockInitialAnimation: presenceContext\n ? presenceContext.initial === false\n : false,\n reducedMotionConfig,\n });\n }\n const visualElement = visualElementRef.current;\n /**\n * Load Motion gesture and animation features. These are rendered as renderless\n * components so each feature can optionally make use of React lifecycle methods.\n */\n const initialLayoutGroupConfig = useContext(SwitchLayoutGroupContext);\n if (visualElement &&\n !visualElement.projection &&\n ProjectionNodeConstructor &&\n (visualElement.type === \"html\" || visualElement.type === \"svg\")) {\n createProjectionNode(visualElementRef.current, props, ProjectionNodeConstructor, initialLayoutGroupConfig);\n }\n const isMounted = useRef(false);\n useInsertionEffect(() => {\n /**\n * Check the component has already mounted before calling\n * `update` unnecessarily. This ensures we skip the initial update.\n */\n if (visualElement && isMounted.current) {\n visualElement.update(props, presenceContext);\n }\n });\n /**\n * Cache this value as we want to know whether HandoffAppearAnimations\n * was present on initial render - it will be deleted after this.\n */\n const optimisedAppearId = props[optimizedAppearDataAttribute];\n const wantsHandoff = useRef(Boolean(optimisedAppearId) &&\n !window.MotionHandoffIsComplete?.(optimisedAppearId) &&\n window.MotionHasOptimisedAnimation?.(optimisedAppearId));\n useIsomorphicLayoutEffect(() => {\n if (!visualElement)\n return;\n isMounted.current = true;\n window.MotionIsMounted = true;\n visualElement.updateFeatures();\n visualElement.scheduleRenderMicrotask();\n /**\n * Ideally this function would always run in a useEffect.\n *\n * However, if we have optimised appear animations to handoff from,\n * it needs to happen synchronously to ensure there's no flash of\n * incorrect styles in the event of a hydration error.\n *\n * So if we detect a situtation where optimised appear animations\n * are running, we use useLayoutEffect to trigger animations.\n */\n if (wantsHandoff.current && visualElement.animationState) {\n visualElement.animationState.animateChanges();\n }\n });\n useEffect(() => {\n if (!visualElement)\n return;\n if (!wantsHandoff.current && visualElement.animationState) {\n visualElement.animationState.animateChanges();\n }\n if (wantsHandoff.current) {\n // This ensures all future calls to animateChanges() in this component will run in useEffect\n queueMicrotask(() => {\n window.MotionHandoffMarkAsComplete?.(optimisedAppearId);\n });\n wantsHandoff.current = false;\n }\n /**\n * Now we've finished triggering animations for this element we\n * can wipe the enteringChildren set for the next render.\n */\n visualElement.enteringChildren = undefined;\n });\n return visualElement;\n}\nfunction createProjectionNode(visualElement, props, ProjectionNodeConstructor, initialPromotionConfig) {\n const { layoutId, layout, drag, dragConstraints, layoutScroll, layoutRoot, layoutCrossfade, } = props;\n visualElement.projection = new ProjectionNodeConstructor(visualElement.latestValues, props[\"data-framer-portal-id\"]\n ? undefined\n : getClosestProjectingNode(visualElement.parent));\n visualElement.projection.setOptions({\n layoutId,\n layout,\n alwaysMeasureLayout: Boolean(drag) || (dragConstraints && isRefObject(dragConstraints)),\n visualElement,\n /**\n * TODO: Update options in an effect. This could be tricky as it'll be too late\n * to update by the time layout animations run.\n * We also need to fix this safeToRemove by linking it up to the one returned by usePresence,\n * ensuring it gets called if there's no potential layout animations.\n *\n */\n animationType: typeof layout === \"string\" ? layout : \"both\",\n initialPromotionConfig,\n crossfade: layoutCrossfade,\n layoutScroll,\n layoutRoot,\n });\n}\nfunction getClosestProjectingNode(visualElement) {\n if (!visualElement)\n return undefined;\n return visualElement.options.allowProjection !== false\n ? visualElement.projection\n : getClosestProjectingNode(visualElement.parent);\n}\n\nexport { useVisualElement };\n","/**\n * Convert camelCase to dash-case properties.\n */\nconst camelToDash = (str) => str.replace(/([a-z])([A-Z])/gu, \"$1-$2\").toLowerCase();\n\nexport { camelToDash };\n","import { camelToDash } from '../../render/dom/utils/camel-to-dash.mjs';\n\nconst optimizedAppearDataId = \"framerAppearId\";\nconst optimizedAppearDataAttribute = \"data-\" + camelToDash(optimizedAppearDataId);\n\nexport { optimizedAppearDataAttribute, optimizedAppearDataId };\n","\"use client\";\nimport { createContext } from 'react';\n\n/**\n * Internal, exported only for usage in Framer\n */\nconst SwitchLayoutGroupContext = createContext({});\n\nexport { SwitchLayoutGroupContext };\n","import { warnOnce } from 'motion-utils';\nimport { createMotionComponent } from '../../motion/index.mjs';\n\nfunction createMotionProxy(preloadedFeatures, createVisualElement) {\n if (typeof Proxy === \"undefined\") {\n return createMotionComponent;\n }\n /**\n * A cache of generated `motion` components, e.g `motion.div`, `motion.input` etc.\n * Rather than generating them anew every render.\n */\n const componentCache = new Map();\n const factory = (Component, options) => {\n return createMotionComponent(Component, options, preloadedFeatures, createVisualElement);\n };\n /**\n * Support for deprecated`motion(Component)` pattern\n */\n const deprecatedFactoryFunction = (Component, options) => {\n if (process.env.NODE_ENV !== \"production\") {\n warnOnce(false, \"motion() is deprecated. Use motion.create() instead.\");\n }\n return factory(Component, options);\n };\n return new Proxy(deprecatedFactoryFunction, {\n /**\n * Called when `motion` is referenced with a prop: `motion.div`, `motion.input` etc.\n * The prop name is passed through as `key` and we can use that to generate a `motion`\n * DOM component with that name.\n */\n get: (_target, key) => {\n if (key === \"create\")\n return factory;\n /**\n * If this element doesn't exist in the component cache, create it and cache.\n */\n if (!componentCache.has(key)) {\n componentCache.set(key, createMotionComponent(key, undefined, preloadedFeatures, createVisualElement));\n }\n return componentCache.get(key);\n },\n });\n}\n\nexport { createMotionProxy };\n","import { Fragment } from 'react';\nimport { HTMLVisualElement } from '../html/HTMLVisualElement.mjs';\nimport { SVGVisualElement } from '../svg/SVGVisualElement.mjs';\nimport { isSVGComponent } from './utils/is-svg-component.mjs';\n\nconst createDomVisualElement = (Component, options) => {\n return isSVGComponent(Component)\n ? new SVGVisualElement(options)\n : new HTMLVisualElement(options, {\n allowProjection: Component !== Fragment,\n });\n};\n\nexport { createDomVisualElement };\n","/**\n * Bounding boxes tend to be defined as top, left, right, bottom. For various operations\n * it's easier to consider each axis individually. This function returns a bounding box\n * as a map of single-axis min/max values.\n */\nfunction convertBoundingBoxToBox({ top, left, right, bottom, }) {\n return {\n x: { min: left, max: right },\n y: { min: top, max: bottom },\n };\n}\nfunction convertBoxToBoundingBox({ x, y }) {\n return { top: y.min, right: x.max, bottom: y.max, left: x.min };\n}\n/**\n * Applies a TransformPoint function to a bounding box. TransformPoint is usually a function\n * provided by Framer to allow measured points to be corrected for device scaling. This is used\n * when measuring DOM elements and DOM event points.\n */\nfunction transformBoxPoints(point, transformPoint) {\n if (!transformPoint)\n return point;\n const topLeft = transformPoint({ x: point.left, y: point.top });\n const bottomRight = transformPoint({ x: point.right, y: point.bottom });\n return {\n top: topLeft.y,\n left: topLeft.x,\n bottom: bottomRight.y,\n right: bottomRight.x,\n };\n}\n\nexport { convertBoundingBoxToBox, convertBoxToBoundingBox, transformBoxPoints };\n","function isIdentityScale(scale) {\n return scale === undefined || scale === 1;\n}\nfunction hasScale({ scale, scaleX, scaleY }) {\n return (!isIdentityScale(scale) ||\n !isIdentityScale(scaleX) ||\n !isIdentityScale(scaleY));\n}\nfunction hasTransform(values) {\n return (hasScale(values) ||\n has2DTranslate(values) ||\n values.z ||\n values.rotate ||\n values.rotateX ||\n values.rotateY ||\n values.skewX ||\n values.skewY);\n}\nfunction has2DTranslate(values) {\n return is2DTranslate(values.x) || is2DTranslate(values.y);\n}\nfunction is2DTranslate(value) {\n return value && value !== \"0%\";\n}\n\nexport { has2DTranslate, hasScale, hasTransform };\n","import { mixNumber } from 'motion-dom';\nimport { hasTransform } from '../utils/has-transform.mjs';\n\n/**\n * Scales a point based on a factor and an originPoint\n */\nfunction scalePoint(point, scale, originPoint) {\n const distanceFromOrigin = point - originPoint;\n const scaled = scale * distanceFromOrigin;\n return originPoint + scaled;\n}\n/**\n * Applies a translate/scale delta to a point\n */\nfunction applyPointDelta(point, translate, scale, originPoint, boxScale) {\n if (boxScale !== undefined) {\n point = scalePoint(point, boxScale, originPoint);\n }\n return scalePoint(point, scale, originPoint) + translate;\n}\n/**\n * Applies a translate/scale delta to an axis\n */\nfunction applyAxisDelta(axis, translate = 0, scale = 1, originPoint, boxScale) {\n axis.min = applyPointDelta(axis.min, translate, scale, originPoint, boxScale);\n axis.max = applyPointDelta(axis.max, translate, scale, originPoint, boxScale);\n}\n/**\n * Applies a translate/scale delta to a box\n */\nfunction applyBoxDelta(box, { x, y }) {\n applyAxisDelta(box.x, x.translate, x.scale, x.originPoint);\n applyAxisDelta(box.y, y.translate, y.scale, y.originPoint);\n}\nconst TREE_SCALE_SNAP_MIN = 0.999999999999;\nconst TREE_SCALE_SNAP_MAX = 1.0000000000001;\n/**\n * Apply a tree of deltas to a box. We do this to calculate the effect of all the transforms\n * in a tree upon our box before then calculating how to project it into our desired viewport-relative box\n *\n * This is the final nested loop within updateLayoutDelta for future refactoring\n */\nfunction applyTreeDeltas(box, treeScale, treePath, isSharedTransition = false) {\n const treeLength = treePath.length;\n if (!treeLength)\n return;\n // Reset the treeScale\n treeScale.x = treeScale.y = 1;\n let node;\n let delta;\n for (let i = 0; i < treeLength; i++) {\n node = treePath[i];\n delta = node.projectionDelta;\n /**\n * TODO: Prefer to remove this, but currently we have motion components with\n * display: contents in Framer.\n */\n const { visualElement } = node.options;\n if (visualElement &&\n visualElement.props.style &&\n visualElement.props.style.display === \"contents\") {\n continue;\n }\n if (isSharedTransition &&\n node.options.layoutScroll &&\n node.scroll &&\n node !== node.root) {\n transformBox(box, {\n x: -node.scroll.offset.x,\n y: -node.scroll.offset.y,\n });\n }\n if (delta) {\n // Incoporate each ancestor's scale into a culmulative treeScale for this component\n treeScale.x *= delta.x.scale;\n treeScale.y *= delta.y.scale;\n // Apply each ancestor's calculated delta into this component's recorded layout box\n applyBoxDelta(box, delta);\n }\n if (isSharedTransition && hasTransform(node.latestValues)) {\n transformBox(box, node.latestValues);\n }\n }\n /**\n * Snap tree scale back to 1 if it's within a non-perceivable threshold.\n * This will help reduce useless scales getting rendered.\n */\n if (treeScale.x < TREE_SCALE_SNAP_MAX &&\n treeScale.x > TREE_SCALE_SNAP_MIN) {\n treeScale.x = 1.0;\n }\n if (treeScale.y < TREE_SCALE_SNAP_MAX &&\n treeScale.y > TREE_SCALE_SNAP_MIN) {\n treeScale.y = 1.0;\n }\n}\nfunction translateAxis(axis, distance) {\n axis.min = axis.min + distance;\n axis.max = axis.max + distance;\n}\n/**\n * Apply a transform to an axis from the latest resolved motion values.\n * This function basically acts as a bridge between a flat motion value map\n * and applyAxisDelta\n */\nfunction transformAxis(axis, axisTranslate, axisScale, boxScale, axisOrigin = 0.5) {\n const originPoint = mixNumber(axis.min, axis.max, axisOrigin);\n // Apply the axis delta to the final axis\n applyAxisDelta(axis, axisTranslate, axisScale, originPoint, boxScale);\n}\n/**\n * Apply a transform to a box from the latest resolved motion values.\n */\nfunction transformBox(box, transform) {\n transformAxis(box.x, transform.x, transform.scaleX, transform.scale, transform.originX);\n transformAxis(box.y, transform.y, transform.scaleY, transform.scale, transform.originY);\n}\n\nexport { applyAxisDelta, applyBoxDelta, applyPointDelta, applyTreeDeltas, scalePoint, transformAxis, transformBox, translateAxis };\n","import { convertBoundingBoxToBox, transformBoxPoints } from '../geometry/conversion.mjs';\nimport { translateAxis } from '../geometry/delta-apply.mjs';\n\nfunction measureViewportBox(instance, transformPoint) {\n return convertBoundingBoxToBox(transformBoxPoints(instance.getBoundingClientRect(), transformPoint));\n}\nfunction measurePageBox(element, rootProjectionNode, transformPagePoint) {\n const viewportBox = measureViewportBox(element, transformPagePoint);\n const { scroll } = rootProjectionNode;\n if (scroll) {\n translateAxis(viewportBox.x, scroll.offset.x);\n translateAxis(viewportBox.y, scroll.offset.y);\n }\n return viewportBox;\n}\n\nexport { measurePageBox, measureViewportBox };\n","const createAxisDelta = () => ({\n translate: 0,\n scale: 1,\n origin: 0,\n originPoint: 0,\n});\nconst createDelta = () => ({\n x: createAxisDelta(),\n y: createAxisDelta(),\n});\nconst createAxis = () => ({ min: 0, max: 0 });\nconst createBox = () => ({\n x: createAxis(),\n y: createAxis(),\n});\n\nexport { createAxis, createAxisDelta, createBox, createDelta };\n","// Does this device prefer reduced motion? Returns `null` server-side.\nconst prefersReducedMotion = { current: null };\nconst hasReducedMotionListener = { current: false };\n\nexport { hasReducedMotionListener, prefersReducedMotion };\n","import { isBrowser } from '../is-browser.mjs';\nimport { hasReducedMotionListener, prefersReducedMotion } from './state.mjs';\n\nfunction initPrefersReducedMotion() {\n hasReducedMotionListener.current = true;\n if (!isBrowser)\n return;\n if (window.matchMedia) {\n const motionMediaQuery = window.matchMedia(\"(prefers-reduced-motion)\");\n const setReducedMotionPreferences = () => (prefersReducedMotion.current = motionMediaQuery.matches);\n motionMediaQuery.addEventListener(\"change\", setReducedMotionPreferences);\n setReducedMotionPreferences();\n }\n else {\n prefersReducedMotion.current = false;\n }\n}\n\nexport { initPrefersReducedMotion };\n","const visualElementStore = new WeakMap();\n\nexport { visualElementStore };\n","import { isMotionValue, motionValue } from 'motion-dom';\n\nfunction updateMotionValuesFromProps(element, next, prev) {\n for (const key in next) {\n const nextValue = next[key];\n const prevValue = prev[key];\n if (isMotionValue(nextValue)) {\n /**\n * If this is a motion value found in props or style, we want to add it\n * to our visual element's motion value map.\n */\n element.addValue(key, nextValue);\n }\n else if (isMotionValue(prevValue)) {\n /**\n * If we're swapping from a motion value to a static value,\n * create a new motion value from that\n */\n element.addValue(key, motionValue(nextValue, { owner: element }));\n }\n else if (prevValue !== nextValue) {\n /**\n * If this is a flat value that has changed, update the motion value\n * or create one if it doesn't exist. We only want to do this if we're\n * not handling the value with our animation state.\n */\n if (element.hasValue(key)) {\n const existingValue = element.getValue(key);\n if (existingValue.liveStyle === true) {\n existingValue.jump(nextValue);\n }\n else if (!existingValue.hasAnimated) {\n existingValue.set(nextValue);\n }\n }\n else {\n const latestValue = element.getStaticValue(key);\n element.addValue(key, motionValue(latestValue !== undefined ? latestValue : nextValue, { owner: element }));\n }\n }\n }\n // Handle removed values\n for (const key in prev) {\n if (next[key] === undefined)\n element.removeValue(key);\n }\n return next;\n}\n\nexport { updateMotionValuesFromProps };\n","import { KeyframeResolver, time, frame, isMotionValue, cancelFrame, transformProps, motionValue, findValueType, complex, getAnimatableNone, microtask } from 'motion-dom';\nimport { warnOnce, isNumericalString, isZeroValueString, SubscriptionManager } from 'motion-utils';\nimport { featureDefinitions } from '../motion/features/definitions.mjs';\nimport { createBox } from '../projection/geometry/models.mjs';\nimport { initPrefersReducedMotion } from '../utils/reduced-motion/index.mjs';\nimport { hasReducedMotionListener, prefersReducedMotion } from '../utils/reduced-motion/state.mjs';\nimport { visualElementStore } from './store.mjs';\nimport { isControllingVariants, isVariantNode } from './utils/is-controlling-variants.mjs';\nimport { updateMotionValuesFromProps } from './utils/motion-values.mjs';\nimport { resolveVariantFromProps } from './utils/resolve-variants.mjs';\n\nconst propEventHandlers = [\n \"AnimationStart\",\n \"AnimationComplete\",\n \"Update\",\n \"BeforeLayoutMeasure\",\n \"LayoutMeasure\",\n \"LayoutAnimationStart\",\n \"LayoutAnimationComplete\",\n];\n/**\n * A VisualElement is an imperative abstraction around UI elements such as\n * HTMLElement, SVGElement, Three.Object3D etc.\n */\nclass VisualElement {\n /**\n * This method takes React props and returns found MotionValues. For example, HTML\n * MotionValues will be found within the style prop, whereas for Three.js within attribute arrays.\n *\n * This isn't an abstract method as it needs calling in the constructor, but it is\n * intended to be one.\n */\n scrapeMotionValuesFromProps(_props, _prevProps, _visualElement) {\n return {};\n }\n constructor({ parent, props, presenceContext, reducedMotionConfig, blockInitialAnimation, visualState, }, options = {}) {\n /**\n * A reference to the current underlying Instance, e.g. a HTMLElement\n * or Three.Mesh etc.\n */\n this.current = null;\n /**\n * A set containing references to this VisualElement's children.\n */\n this.children = new Set();\n /**\n * Determine what role this visual element should take in the variant tree.\n */\n this.isVariantNode = false;\n this.isControllingVariants = false;\n /**\n * Decides whether this VisualElement should animate in reduced motion\n * mode.\n *\n * TODO: This is currently set on every individual VisualElement but feels\n * like it could be set globally.\n */\n this.shouldReduceMotion = null;\n /**\n * A map of all motion values attached to this visual element. Motion\n * values are source of truth for any given animated value. A motion\n * value might be provided externally by the component via props.\n */\n this.values = new Map();\n this.KeyframeResolver = KeyframeResolver;\n /**\n * Cleanup functions for active features (hover/tap/exit etc)\n */\n this.features = {};\n /**\n * A map of every subscription that binds the provided or generated\n * motion values onChange listeners to this visual element.\n */\n this.valueSubscriptions = new Map();\n /**\n * A reference to the previously-provided motion values as returned\n * from scrapeMotionValuesFromProps. We use the keys in here to determine\n * if any motion values need to be removed after props are updated.\n */\n this.prevMotionValues = {};\n /**\n * An object containing a SubscriptionManager for each active event.\n */\n this.events = {};\n /**\n * An object containing an unsubscribe function for each prop event subscription.\n * For example, every \"Update\" event can have multiple subscribers via\n * VisualElement.on(), but only one of those can be defined via the onUpdate prop.\n */\n this.propEventSubscriptions = {};\n this.notifyUpdate = () => this.notify(\"Update\", this.latestValues);\n this.render = () => {\n if (!this.current)\n return;\n this.triggerBuild();\n this.renderInstance(this.current, this.renderState, this.props.style, this.projection);\n };\n this.renderScheduledAt = 0.0;\n this.scheduleRender = () => {\n const now = time.now();\n if (this.renderScheduledAt < now) {\n this.renderScheduledAt = now;\n frame.render(this.render, false, true);\n }\n };\n const { latestValues, renderState } = visualState;\n this.latestValues = latestValues;\n this.baseTarget = { ...latestValues };\n this.initialValues = props.initial ? { ...latestValues } : {};\n this.renderState = renderState;\n this.parent = parent;\n this.props = props;\n this.presenceContext = presenceContext;\n this.depth = parent ? parent.depth + 1 : 0;\n this.reducedMotionConfig = reducedMotionConfig;\n this.options = options;\n this.blockInitialAnimation = Boolean(blockInitialAnimation);\n this.isControllingVariants = isControllingVariants(props);\n this.isVariantNode = isVariantNode(props);\n if (this.isVariantNode) {\n this.variantChildren = new Set();\n }\n this.manuallyAnimateOnMount = Boolean(parent && parent.current);\n /**\n * Any motion values that are provided to the element when created\n * aren't yet bound to the element, as this would technically be impure.\n * However, we iterate through the motion values and set them to the\n * initial values for this component.\n *\n * TODO: This is impure and we should look at changing this to run on mount.\n * Doing so will break some tests but this isn't necessarily a breaking change,\n * more a reflection of the test.\n */\n const { willChange, ...initialMotionValues } = this.scrapeMotionValuesFromProps(props, {}, this);\n for (const key in initialMotionValues) {\n const value = initialMotionValues[key];\n if (latestValues[key] !== undefined && isMotionValue(value)) {\n value.set(latestValues[key]);\n }\n }\n }\n mount(instance) {\n this.current = instance;\n visualElementStore.set(instance, this);\n if (this.projection && !this.projection.instance) {\n this.projection.mount(instance);\n }\n if (this.parent && this.isVariantNode && !this.isControllingVariants) {\n this.removeFromVariantTree = this.parent.addVariantChild(this);\n }\n this.values.forEach((value, key) => this.bindToMotionValue(key, value));\n if (!hasReducedMotionListener.current) {\n initPrefersReducedMotion();\n }\n this.shouldReduceMotion =\n this.reducedMotionConfig === \"never\"\n ? false\n : this.reducedMotionConfig === \"always\"\n ? true\n : prefersReducedMotion.current;\n if (process.env.NODE_ENV !== \"production\") {\n warnOnce(this.shouldReduceMotion !== true, \"You have Reduced Motion enabled on your device. Animations may not appear as expected.\", \"reduced-motion-disabled\");\n }\n this.parent?.addChild(this);\n this.update(this.props, this.presenceContext);\n }\n unmount() {\n this.projection && this.projection.unmount();\n cancelFrame(this.notifyUpdate);\n cancelFrame(this.render);\n this.valueSubscriptions.forEach((remove) => remove());\n this.valueSubscriptions.clear();\n this.removeFromVariantTree && this.removeFromVariantTree();\n this.parent?.removeChild(this);\n for (const key in this.events) {\n this.events[key].clear();\n }\n for (const key in this.features) {\n const feature = this.features[key];\n if (feature) {\n feature.unmount();\n feature.isMounted = false;\n }\n }\n this.current = null;\n }\n addChild(child) {\n this.children.add(child);\n this.enteringChildren ?? (this.enteringChildren = new Set());\n this.enteringChildren.add(child);\n }\n removeChild(child) {\n this.children.delete(child);\n this.enteringChildren && this.enteringChildren.delete(child);\n }\n bindToMotionValue(key, value) {\n if (this.valueSubscriptions.has(key)) {\n this.valueSubscriptions.get(key)();\n }\n const valueIsTransform = transformProps.has(key);\n if (valueIsTransform && this.onBindTransform) {\n this.onBindTransform();\n }\n const removeOnChange = value.on(\"change\", (latestValue) => {\n this.latestValues[key] = latestValue;\n this.props.onUpdate && frame.preRender(this.notifyUpdate);\n if (valueIsTransform && this.projection) {\n this.projection.isTransformDirty = true;\n }\n this.scheduleRender();\n });\n let removeSyncCheck;\n if (window.MotionCheckAppearSync) {\n removeSyncCheck = window.MotionCheckAppearSync(this, key, value);\n }\n this.valueSubscriptions.set(key, () => {\n removeOnChange();\n if (removeSyncCheck)\n removeSyncCheck();\n if (value.owner)\n value.stop();\n });\n }\n sortNodePosition(other) {\n /**\n * If these nodes aren't even of the same type we can't compare their depth.\n */\n if (!this.current ||\n !this.sortInstanceNodePosition ||\n this.type !== other.type) {\n return 0;\n }\n return this.sortInstanceNodePosition(this.current, other.current);\n }\n updateFeatures() {\n let key = \"animation\";\n for (key in featureDefinitions) {\n const featureDefinition = featureDefinitions[key];\n if (!featureDefinition)\n continue;\n const { isEnabled, Feature: FeatureConstructor } = featureDefinition;\n /**\n * If this feature is enabled but not active, make a new instance.\n */\n if (!this.features[key] &&\n FeatureConstructor &&\n isEnabled(this.props)) {\n this.features[key] = new FeatureConstructor(this);\n }\n /**\n * If we have a feature, mount or update it.\n */\n if (this.features[key]) {\n const feature = this.features[key];\n if (feature.isMounted) {\n feature.update();\n }\n else {\n feature.mount();\n feature.isMounted = true;\n }\n }\n }\n }\n triggerBuild() {\n this.build(this.renderState, this.latestValues, this.props);\n }\n /**\n * Measure the current viewport box with or without transforms.\n * Only measures axis-aligned boxes, rotate and skew must be manually\n * removed with a re-render to work.\n */\n measureViewportBox() {\n return this.current\n ? this.measureInstanceViewportBox(this.current, this.props)\n : createBox();\n }\n getStaticValue(key) {\n return this.latestValues[key];\n }\n setStaticValue(key, value) {\n this.latestValues[key] = value;\n }\n /**\n * Update the provided props. Ensure any newly-added motion values are\n * added to our map, old ones removed, and listeners updated.\n */\n update(props, presenceContext) {\n if (props.transformTemplate || this.props.transformTemplate) {\n this.scheduleRender();\n }\n this.prevProps = this.props;\n this.props = props;\n this.prevPresenceContext = this.presenceContext;\n this.presenceContext = presenceContext;\n /**\n * Update prop event handlers ie onAnimationStart, onAnimationComplete\n */\n for (let i = 0; i < propEventHandlers.length; i++) {\n const key = propEventHandlers[i];\n if (this.propEventSubscriptions[key]) {\n this.propEventSubscriptions[key]();\n delete this.propEventSubscriptions[key];\n }\n const listenerName = (\"on\" + key);\n const listener = props[listenerName];\n if (listener) {\n this.propEventSubscriptions[key] = this.on(key, listener);\n }\n }\n this.prevMotionValues = updateMotionValuesFromProps(this, this.scrapeMotionValuesFromProps(props, this.prevProps, this), this.prevMotionValues);\n if (this.handleChildMotionValue) {\n this.handleChildMotionValue();\n }\n }\n getProps() {\n return this.props;\n }\n /**\n * Returns the variant definition with a given name.\n */\n getVariant(name) {\n return this.props.variants ? this.props.variants[name] : undefined;\n }\n /**\n * Returns the defined default transition on this component.\n */\n getDefaultTransition() {\n return this.props.transition;\n }\n getTransformPagePoint() {\n return this.props.transformPagePoint;\n }\n getClosestVariantNode() {\n return this.isVariantNode\n ? this\n : this.parent\n ? this.parent.getClosestVariantNode()\n : undefined;\n }\n /**\n * Add a child visual element to our set of children.\n */\n addVariantChild(child) {\n const closestVariantNode = this.getClosestVariantNode();\n if (closestVariantNode) {\n closestVariantNode.variantChildren &&\n closestVariantNode.variantChildren.add(child);\n return () => closestVariantNode.variantChildren.delete(child);\n }\n }\n /**\n * Add a motion value and bind it to this visual element.\n */\n addValue(key, value) {\n // Remove existing value if it exists\n const existingValue = this.values.get(key);\n if (value !== existingValue) {\n if (existingValue)\n this.removeValue(key);\n this.bindToMotionValue(key, value);\n this.values.set(key, value);\n this.latestValues[key] = value.get();\n }\n }\n /**\n * Remove a motion value and unbind any active subscriptions.\n */\n removeValue(key) {\n this.values.delete(key);\n const unsubscribe = this.valueSubscriptions.get(key);\n if (unsubscribe) {\n unsubscribe();\n this.valueSubscriptions.delete(key);\n }\n delete this.latestValues[key];\n this.removeValueFromRenderState(key, this.renderState);\n }\n /**\n * Check whether we have a motion value for this key\n */\n hasValue(key) {\n return this.values.has(key);\n }\n getValue(key, defaultValue) {\n if (this.props.values && this.props.values[key]) {\n return this.props.values[key];\n }\n let value = this.values.get(key);\n if (value === undefined && defaultValue !== undefined) {\n value = motionValue(defaultValue === null ? undefined : defaultValue, { owner: this });\n this.addValue(key, value);\n }\n return value;\n }\n /**\n * If we're trying to animate to a previously unencountered value,\n * we need to check for it in our state and as a last resort read it\n * directly from the instance (which might have performance implications).\n */\n readValue(key, target) {\n let value = this.latestValues[key] !== undefined || !this.current\n ? this.latestValues[key]\n : this.getBaseTargetFromProps(this.props, key) ??\n this.readValueFromInstance(this.current, key, this.options);\n if (value !== undefined && value !== null) {\n if (typeof value === \"string\" &&\n (isNumericalString(value) || isZeroValueString(value))) {\n // If this is a number read as a string, ie \"0\" or \"200\", convert it to a number\n value = parseFloat(value);\n }\n else if (!findValueType(value) && complex.test(target)) {\n value = getAnimatableNone(key, target);\n }\n this.setBaseTarget(key, isMotionValue(value) ? value.get() : value);\n }\n return isMotionValue(value) ? value.get() : value;\n }\n /**\n * Set the base target to later animate back to. This is currently\n * only hydrated on creation and when we first read a value.\n */\n setBaseTarget(key, value) {\n this.baseTarget[key] = value;\n }\n /**\n * Find the base target for a value thats been removed from all animation\n * props.\n */\n getBaseTarget(key) {\n const { initial } = this.props;\n let valueFromInitial;\n if (typeof initial === \"string\" || typeof initial === \"object\") {\n const variant = resolveVariantFromProps(this.props, initial, this.presenceContext?.custom);\n if (variant) {\n valueFromInitial = variant[key];\n }\n }\n /**\n * If this value still exists in the current initial variant, read that.\n */\n if (initial && valueFromInitial !== undefined) {\n return valueFromInitial;\n }\n /**\n * Alternatively, if this VisualElement config has defined a getBaseTarget\n * so we can read the value from an alternative source, try that.\n */\n const target = this.getBaseTargetFromProps(this.props, key);\n if (target !== undefined && !isMotionValue(target))\n return target;\n /**\n * If the value was initially defined on initial, but it doesn't any more,\n * return undefined. Otherwise return the value as initially read from the DOM.\n */\n return this.initialValues[key] !== undefined &&\n valueFromInitial === undefined\n ? undefined\n : this.baseTarget[key];\n }\n on(eventName, callback) {\n if (!this.events[eventName]) {\n this.events[eventName] = new SubscriptionManager();\n }\n return this.events[eventName].add(callback);\n }\n notify(eventName, ...args) {\n if (this.events[eventName]) {\n this.events[eventName].notify(...args);\n }\n }\n scheduleRenderMicrotask() {\n microtask.render(this.render);\n }\n}\n\nexport { VisualElement };\n","import { DOMKeyframesResolver, isMotionValue } from 'motion-dom';\nimport { VisualElement } from '../VisualElement.mjs';\n\nclass DOMVisualElement extends VisualElement {\n constructor() {\n super(...arguments);\n this.KeyframeResolver = DOMKeyframesResolver;\n }\n sortInstanceNodePosition(a, b) {\n /**\n * compareDocumentPosition returns a bitmask, by using the bitwise &\n * we're returning true if 2 in that bitmask is set to true. 2 is set\n * to true if b preceeds a.\n */\n return a.compareDocumentPosition(b) & 2 ? 1 : -1;\n }\n getBaseTargetFromProps(props, key) {\n return props.style\n ? props.style[key]\n : undefined;\n }\n removeValueFromRenderState(key, { vars, style }) {\n delete vars[key];\n delete style[key];\n }\n handleChildMotionValue() {\n if (this.childSubscription) {\n this.childSubscription();\n delete this.childSubscription;\n }\n const { children } = this.props;\n if (isMotionValue(children)) {\n this.childSubscription = children.on(\"change\", (latest) => {\n if (this.current) {\n this.current.textContent = `${latest}`;\n }\n });\n }\n }\n}\n\nexport { DOMVisualElement };\n","function renderHTML(element, { style, vars }, styleProp, projection) {\n const elementStyle = element.style;\n let key;\n for (key in style) {\n // CSSStyleDeclaration has [index: number]: string; in the types, so we use that as key type.\n elementStyle[key] = style[key];\n }\n // Write projection styles directly to element style\n projection?.applyProjectionStyles(elementStyle, styleProp);\n for (key in vars) {\n // Loop over any CSS variables and assign those.\n // They can only be assigned using `setProperty`.\n elementStyle.setProperty(key, vars[key]);\n }\n}\n\nexport { renderHTML };\n","import { transformProps, defaultTransformValue, readTransformValue, isCSSVariableName } from 'motion-dom';\nimport { measureViewportBox } from '../../projection/utils/measure.mjs';\nimport { DOMVisualElement } from '../dom/DOMVisualElement.mjs';\nimport { buildHTMLStyles } from './utils/build-styles.mjs';\nimport { renderHTML } from './utils/render.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\n\nfunction getComputedStyle(element) {\n return window.getComputedStyle(element);\n}\nclass HTMLVisualElement extends DOMVisualElement {\n constructor() {\n super(...arguments);\n this.type = \"html\";\n this.renderInstance = renderHTML;\n }\n readValueFromInstance(instance, key) {\n if (transformProps.has(key)) {\n return this.projection?.isProjecting\n ? defaultTransformValue(key)\n : readTransformValue(instance, key);\n }\n else {\n const computedStyle = getComputedStyle(instance);\n const value = (isCSSVariableName(key)\n ? computedStyle.getPropertyValue(key)\n : computedStyle[key]) || 0;\n return typeof value === \"string\" ? value.trim() : value;\n }\n }\n measureInstanceViewportBox(instance, { transformPagePoint }) {\n return measureViewportBox(instance, transformPagePoint);\n }\n build(renderState, latestValues, props) {\n buildHTMLStyles(renderState, latestValues, props.transformTemplate);\n }\n scrapeMotionValuesFromProps(props, prevProps, visualElement) {\n return scrapeMotionValuesFromProps(props, prevProps, visualElement);\n }\n}\n\nexport { HTMLVisualElement, getComputedStyle };\n","/**\n * A set of attribute names that are always read/written as camel case.\n */\nconst camelCaseAttributes = new Set([\n \"baseFrequency\",\n \"diffuseConstant\",\n \"kernelMatrix\",\n \"kernelUnitLength\",\n \"keySplines\",\n \"keyTimes\",\n \"limitingConeAngle\",\n \"markerHeight\",\n \"markerWidth\",\n \"numOctaves\",\n \"targetX\",\n \"targetY\",\n \"surfaceScale\",\n \"specularConstant\",\n \"specularExponent\",\n \"stdDeviation\",\n \"tableValues\",\n \"viewBox\",\n \"gradientTransform\",\n \"pathLength\",\n \"startOffset\",\n \"textLength\",\n \"lengthAdjust\",\n]);\n\nexport { camelCaseAttributes };\n","import { camelToDash } from '../../dom/utils/camel-to-dash.mjs';\nimport { renderHTML } from '../../html/utils/render.mjs';\nimport { camelCaseAttributes } from './camel-case-attrs.mjs';\n\nfunction renderSVG(element, renderState, _styleProp, projection) {\n renderHTML(element, renderState, undefined, projection);\n for (const key in renderState.attrs) {\n element.setAttribute(!camelCaseAttributes.has(key) ? camelToDash(key) : key, renderState.attrs[key]);\n }\n}\n\nexport { renderSVG };\n","import { transformProps, getDefaultValueType } from 'motion-dom';\nimport { createBox } from '../../projection/geometry/models.mjs';\nimport { DOMVisualElement } from '../dom/DOMVisualElement.mjs';\nimport { camelToDash } from '../dom/utils/camel-to-dash.mjs';\nimport { buildSVGAttrs } from './utils/build-attrs.mjs';\nimport { camelCaseAttributes } from './utils/camel-case-attrs.mjs';\nimport { isSVGTag } from './utils/is-svg-tag.mjs';\nimport { renderSVG } from './utils/render.mjs';\nimport { scrapeMotionValuesFromProps } from './utils/scrape-motion-values.mjs';\n\nclass SVGVisualElement extends DOMVisualElement {\n constructor() {\n super(...arguments);\n this.type = \"svg\";\n this.isSVGTag = false;\n this.measureInstanceViewportBox = createBox;\n }\n getBaseTargetFromProps(props, key) {\n return props[key];\n }\n readValueFromInstance(instance, key) {\n if (transformProps.has(key)) {\n const defaultType = getDefaultValueType(key);\n return defaultType ? defaultType.default || 0 : 0;\n }\n key = !camelCaseAttributes.has(key) ? camelToDash(key) : key;\n return instance.getAttribute(key);\n }\n scrapeMotionValuesFromProps(props, prevProps, visualElement) {\n return scrapeMotionValuesFromProps(props, prevProps, visualElement);\n }\n build(renderState, latestValues, props) {\n buildSVGAttrs(renderState, latestValues, this.isSVGTag, props.transformTemplate, props.style);\n }\n renderInstance(instance, renderState, styleProp, projection) {\n renderSVG(instance, renderState, styleProp, projection);\n }\n mount(instance) {\n this.isSVGTag = isSVGTag(instance.tagName);\n super.mount(instance);\n }\n}\n\nexport { SVGVisualElement };\n","import { resolveVariantFromProps } from './resolve-variants.mjs';\n\nfunction resolveVariant(visualElement, definition, custom) {\n const props = visualElement.getProps();\n return resolveVariantFromProps(props, definition, custom !== undefined ? custom : props.custom, visualElement);\n}\n\nexport { resolveVariant };\n","const isKeyframesTarget = (v) => {\n return Array.isArray(v);\n};\n\nexport { isKeyframesTarget };\n","import { motionValue } from 'motion-dom';\nimport { isKeyframesTarget } from '../../animation/utils/is-keyframes-target.mjs';\nimport { resolveVariant } from './resolve-dynamic-variants.mjs';\n\n/**\n * Set VisualElement's MotionValue, creating a new MotionValue for it if\n * it doesn't exist.\n */\nfunction setMotionValue(visualElement, key, value) {\n if (visualElement.hasValue(key)) {\n visualElement.getValue(key).set(value);\n }\n else {\n visualElement.addValue(key, motionValue(value));\n }\n}\nfunction resolveFinalValueInKeyframes(v) {\n // TODO maybe throw if v.length - 1 is placeholder token?\n return isKeyframesTarget(v) ? v[v.length - 1] || 0 : v;\n}\nfunction setTarget(visualElement, definition) {\n const resolved = resolveVariant(visualElement, definition);\n let { transitionEnd = {}, transition = {}, ...target } = resolved || {};\n target = { ...target, ...transitionEnd };\n for (const key in target) {\n const value = resolveFinalValueInKeyframes(target[key]);\n setMotionValue(visualElement, key, value);\n }\n}\n\nexport { setTarget };\n","import { isMotionValue } from 'motion-dom';\n\nfunction isWillChangeMotionValue(value) {\n return Boolean(isMotionValue(value) && value.add);\n}\n\nexport { isWillChangeMotionValue };\n","import { MotionGlobalConfig } from 'motion-utils';\nimport { isWillChangeMotionValue } from './is.mjs';\n\nfunction addValueToWillChange(visualElement, key) {\n const willChange = visualElement.getValue(\"willChange\");\n /**\n * It could be that a user has set willChange to a regular MotionValue,\n * in which case we can't add the value to it.\n */\n if (isWillChangeMotionValue(willChange)) {\n return willChange.add(key);\n }\n else if (!willChange && MotionGlobalConfig.WillChange) {\n const newWillChange = new MotionGlobalConfig.WillChange(\"auto\");\n visualElement.addValue(\"willChange\", newWillChange);\n newWillChange.add(key);\n }\n}\n\nexport { addValueToWillChange };\n","import { optimizedAppearDataAttribute } from './data-id.mjs';\n\nfunction getOptimisedAppearId(visualElement) {\n return visualElement.props[optimizedAppearDataAttribute];\n}\n\nexport { getOptimisedAppearId };\n","const isNotNull = (value) => value !== null;\nfunction getFinalKeyframe(keyframes, { repeat, repeatType = \"loop\" }, finalKeyframe) {\n const resolvedKeyframes = keyframes.filter(isNotNull);\n const index = repeat && repeatType !== \"loop\" && repeat % 2 === 1\n ? 0\n : resolvedKeyframes.length - 1;\n return !index || finalKeyframe === undefined\n ? resolvedKeyframes[index]\n : finalKeyframe;\n}\n\nexport { getFinalKeyframe };\n","import { transformProps } from 'motion-dom';\n\nconst underDampedSpring = {\n type: \"spring\",\n stiffness: 500,\n damping: 25,\n restSpeed: 10,\n};\nconst criticallyDampedSpring = (target) => ({\n type: \"spring\",\n stiffness: 550,\n damping: target === 0 ? 2 * Math.sqrt(550) : 30,\n restSpeed: 10,\n});\nconst keyframesTransition = {\n type: \"keyframes\",\n duration: 0.8,\n};\n/**\n * Default easing curve is a slightly shallower version of\n * the default browser easing curve.\n */\nconst ease = {\n type: \"keyframes\",\n ease: [0.25, 0.1, 0.35, 1],\n duration: 0.3,\n};\nconst getDefaultTransition = (valueKey, { keyframes }) => {\n if (keyframes.length > 2) {\n return keyframesTransition;\n }\n else if (transformProps.has(valueKey)) {\n return valueKey.startsWith(\"scale\")\n ? criticallyDampedSpring(keyframes[1])\n : underDampedSpring;\n }\n return ease;\n};\n\nexport { getDefaultTransition };\n","/**\n * Decide whether a transition is defined on a given Transition.\n * This filters out orchestration options and returns true\n * if any options are left.\n */\nfunction isTransitionDefined({ when, delay: _delay, delayChildren, staggerChildren, staggerDirection, repeat, repeatType, repeatDelay, from, elapsed, ...transition }) {\n return !!Object.keys(transition).length;\n}\n\nexport { isTransitionDefined };\n","import { getValueTransition, makeAnimationInstant, frame, JSAnimation, AsyncMotionValueAnimation } from 'motion-dom';\nimport { secondsToMilliseconds, MotionGlobalConfig } from 'motion-utils';\nimport { getFinalKeyframe } from '../animators/waapi/utils/get-final-keyframe.mjs';\nimport { getDefaultTransition } from '../utils/default-transitions.mjs';\nimport { isTransitionDefined } from '../utils/is-transition-defined.mjs';\n\nconst animateMotionValue = (name, value, target, transition = {}, element, isHandoff) => (onComplete) => {\n const valueTransition = getValueTransition(transition, name) || {};\n /**\n * Most transition values are currently completely overwritten by value-specific\n * transitions. In the future it'd be nicer to blend these transitions. But for now\n * delay actually does inherit from the root transition if not value-specific.\n */\n const delay = valueTransition.delay || transition.delay || 0;\n /**\n * Elapsed isn't a public transition option but can be passed through from\n * optimized appear effects in milliseconds.\n */\n let { elapsed = 0 } = transition;\n elapsed = elapsed - secondsToMilliseconds(delay);\n const options = {\n keyframes: Array.isArray(target) ? target : [null, target],\n ease: \"easeOut\",\n velocity: value.getVelocity(),\n ...valueTransition,\n delay: -elapsed,\n onUpdate: (v) => {\n value.set(v);\n valueTransition.onUpdate && valueTransition.onUpdate(v);\n },\n onComplete: () => {\n onComplete();\n valueTransition.onComplete && valueTransition.onComplete();\n },\n name,\n motionValue: value,\n element: isHandoff ? undefined : element,\n };\n /**\n * If there's no transition defined for this value, we can generate\n * unique transition settings for this value.\n */\n if (!isTransitionDefined(valueTransition)) {\n Object.assign(options, getDefaultTransition(name, options));\n }\n /**\n * Both WAAPI and our internal animation functions use durations\n * as defined by milliseconds, while our external API defines them\n * as seconds.\n */\n options.duration && (options.duration = secondsToMilliseconds(options.duration));\n options.repeatDelay && (options.repeatDelay = secondsToMilliseconds(options.repeatDelay));\n /**\n * Support deprecated way to set initial value. Prefer keyframe syntax.\n */\n if (options.from !== undefined) {\n options.keyframes[0] = options.from;\n }\n let shouldSkip = false;\n if (options.type === false ||\n (options.duration === 0 && !options.repeatDelay)) {\n makeAnimationInstant(options);\n if (options.delay === 0) {\n shouldSkip = true;\n }\n }\n if (MotionGlobalConfig.instantAnimations ||\n MotionGlobalConfig.skipAnimations) {\n shouldSkip = true;\n makeAnimationInstant(options);\n options.delay = 0;\n }\n /**\n * If the transition type or easing has been explicitly set by the user\n * then we don't want to allow flattening the animation.\n */\n options.allowFlatten = !valueTransition.type && !valueTransition.ease;\n /**\n * If we can or must skip creating the animation, and apply only\n * the final keyframe, do so. We also check once keyframes are resolved but\n * this early check prevents the need to create an animation at all.\n */\n if (shouldSkip && !isHandoff && value.get() !== undefined) {\n const finalKeyframe = getFinalKeyframe(options.keyframes, valueTransition);\n if (finalKeyframe !== undefined) {\n frame.update(() => {\n options.onUpdate(finalKeyframe);\n options.onComplete();\n });\n return;\n }\n }\n return valueTransition.isSync\n ? new JSAnimation(options)\n : new AsyncMotionValueAnimation(options);\n};\n\nexport { animateMotionValue };\n","import { getValueTransition, frame, positionalKeys } from 'motion-dom';\nimport { setTarget } from '../../render/utils/setters.mjs';\nimport { addValueToWillChange } from '../../value/use-will-change/add-will-change.mjs';\nimport { getOptimisedAppearId } from '../optimized-appear/get-appear-id.mjs';\nimport { animateMotionValue } from './motion-value.mjs';\n\n/**\n * Decide whether we should block this animation. Previously, we achieved this\n * just by checking whether the key was listed in protectedKeys, but this\n * posed problems if an animation was triggered by afterChildren and protectedKeys\n * had been set to true in the meantime.\n */\nfunction shouldBlockAnimation({ protectedKeys, needsAnimating }, key) {\n const shouldBlock = protectedKeys.hasOwnProperty(key) && needsAnimating[key] !== true;\n needsAnimating[key] = false;\n return shouldBlock;\n}\nfunction animateTarget(visualElement, targetAndTransition, { delay = 0, transitionOverride, type } = {}) {\n let { transition = visualElement.getDefaultTransition(), transitionEnd, ...target } = targetAndTransition;\n if (transitionOverride)\n transition = transitionOverride;\n const animations = [];\n const animationTypeState = type &&\n visualElement.animationState &&\n visualElement.animationState.getState()[type];\n for (const key in target) {\n const value = visualElement.getValue(key, visualElement.latestValues[key] ?? null);\n const valueTarget = target[key];\n if (valueTarget === undefined ||\n (animationTypeState &&\n shouldBlockAnimation(animationTypeState, key))) {\n continue;\n }\n const valueTransition = {\n delay,\n ...getValueTransition(transition || {}, key),\n };\n /**\n * If the value is already at the defined target, skip the animation.\n */\n const currentValue = value.get();\n if (currentValue !== undefined &&\n !value.isAnimating &&\n !Array.isArray(valueTarget) &&\n valueTarget === currentValue &&\n !valueTransition.velocity) {\n continue;\n }\n /**\n * If this is the first time a value is being animated, check\n * to see if we're handling off from an existing animation.\n */\n let isHandoff = false;\n if (window.MotionHandoffAnimation) {\n const appearId = getOptimisedAppearId(visualElement);\n if (appearId) {\n const startTime = window.MotionHandoffAnimation(appearId, key, frame);\n if (startTime !== null) {\n valueTransition.startTime = startTime;\n isHandoff = true;\n }\n }\n }\n addValueToWillChange(visualElement, key);\n value.start(animateMotionValue(key, value, valueTarget, visualElement.shouldReduceMotion && positionalKeys.has(key)\n ? { type: false }\n : valueTransition, visualElement, isHandoff));\n const animation = value.animation;\n if (animation) {\n animations.push(animation);\n }\n }\n if (transitionEnd) {\n Promise.all(animations).then(() => {\n frame.update(() => {\n transitionEnd && setTarget(visualElement, transitionEnd);\n });\n });\n }\n return animations;\n}\n\nexport { animateTarget };\n","function calcChildStagger(children, child, delayChildren, staggerChildren = 0, staggerDirection = 1) {\n const index = Array.from(children)\n .sort((a, b) => a.sortNodePosition(b))\n .indexOf(child);\n const numChildren = children.size;\n const maxStaggerDuration = (numChildren - 1) * staggerChildren;\n const delayIsFunction = typeof delayChildren === \"function\";\n return delayIsFunction\n ? delayChildren(index, numChildren)\n : staggerDirection === 1\n ? index * staggerChildren\n : maxStaggerDuration - index * staggerChildren;\n}\n\nexport { calcChildStagger };\n","import { resolveVariant } from '../../render/utils/resolve-dynamic-variants.mjs';\nimport { calcChildStagger } from '../utils/calc-child-stagger.mjs';\nimport { animateTarget } from './visual-element-target.mjs';\n\nfunction animateVariant(visualElement, variant, options = {}) {\n const resolved = resolveVariant(visualElement, variant, options.type === \"exit\"\n ? visualElement.presenceContext?.custom\n : undefined);\n let { transition = visualElement.getDefaultTransition() || {} } = resolved || {};\n if (options.transitionOverride) {\n transition = options.transitionOverride;\n }\n /**\n * If we have a variant, create a callback that runs it as an animation.\n * Otherwise, we resolve a Promise immediately for a composable no-op.\n */\n const getAnimation = resolved\n ? () => Promise.all(animateTarget(visualElement, resolved, options))\n : () => Promise.resolve();\n /**\n * If we have children, create a callback that runs all their animations.\n * Otherwise, we resolve a Promise immediately for a composable no-op.\n */\n const getChildAnimations = visualElement.variantChildren && visualElement.variantChildren.size\n ? (forwardDelay = 0) => {\n const { delayChildren = 0, staggerChildren, staggerDirection, } = transition;\n return animateChildren(visualElement, variant, forwardDelay, delayChildren, staggerChildren, staggerDirection, options);\n }\n : () => Promise.resolve();\n /**\n * If the transition explicitly defines a \"when\" option, we need to resolve either\n * this animation or all children animations before playing the other.\n */\n const { when } = transition;\n if (when) {\n const [first, last] = when === \"beforeChildren\"\n ? [getAnimation, getChildAnimations]\n : [getChildAnimations, getAnimation];\n return first().then(() => last());\n }\n else {\n return Promise.all([getAnimation(), getChildAnimations(options.delay)]);\n }\n}\nfunction animateChildren(visualElement, variant, delay = 0, delayChildren = 0, staggerChildren = 0, staggerDirection = 1, options) {\n const animations = [];\n for (const child of visualElement.variantChildren) {\n child.notify(\"AnimationStart\", variant);\n animations.push(animateVariant(child, variant, {\n ...options,\n delay: delay +\n (typeof delayChildren === \"function\" ? 0 : delayChildren) +\n calcChildStagger(visualElement.variantChildren, child, delayChildren, staggerChildren, staggerDirection),\n }).then(() => child.notify(\"AnimationComplete\", variant)));\n }\n return Promise.all(animations);\n}\n\nexport { animateVariant };\n","import { resolveVariant } from '../../render/utils/resolve-dynamic-variants.mjs';\nimport { animateTarget } from './visual-element-target.mjs';\nimport { animateVariant } from './visual-element-variant.mjs';\n\nfunction animateVisualElement(visualElement, definition, options = {}) {\n visualElement.notify(\"AnimationStart\", definition);\n let animation;\n if (Array.isArray(definition)) {\n const animations = definition.map((variant) => animateVariant(visualElement, variant, options));\n animation = Promise.all(animations);\n }\n else if (typeof definition === \"string\") {\n animation = animateVariant(visualElement, definition, options);\n }\n else {\n const resolvedDefinition = typeof definition === \"function\"\n ? resolveVariant(visualElement, definition, options.custom)\n : definition;\n animation = Promise.all(animateTarget(visualElement, resolvedDefinition, options));\n }\n return animation.then(() => {\n visualElement.notify(\"AnimationComplete\", definition);\n });\n}\n\nexport { animateVisualElement };\n","function shallowCompare(next, prev) {\n if (!Array.isArray(prev))\n return false;\n const prevLength = prev.length;\n if (prevLength !== next.length)\n return false;\n for (let i = 0; i < prevLength; i++) {\n if (prev[i] !== next[i])\n return false;\n }\n return true;\n}\n\nexport { shallowCompare };\n","import { isVariantLabel } from './is-variant-label.mjs';\nimport { variantProps } from './variant-props.mjs';\n\nconst numVariantProps = variantProps.length;\nfunction getVariantContext(visualElement) {\n if (!visualElement)\n return undefined;\n if (!visualElement.isControllingVariants) {\n const context = visualElement.parent\n ? getVariantContext(visualElement.parent) || {}\n : {};\n if (visualElement.props.initial !== undefined) {\n context.initial = visualElement.props.initial;\n }\n return context;\n }\n const context = {};\n for (let i = 0; i < numVariantProps; i++) {\n const name = variantProps[i];\n const prop = visualElement.props[name];\n if (isVariantLabel(prop) || prop === false) {\n context[name] = prop;\n }\n }\n return context;\n}\n\nexport { getVariantContext };\n","import { animateVisualElement } from '../../animation/interfaces/visual-element.mjs';\nimport { calcChildStagger } from '../../animation/utils/calc-child-stagger.mjs';\nimport { isAnimationControls } from '../../animation/utils/is-animation-controls.mjs';\nimport { isKeyframesTarget } from '../../animation/utils/is-keyframes-target.mjs';\nimport { shallowCompare } from '../../utils/shallow-compare.mjs';\nimport { getVariantContext } from './get-variant-context.mjs';\nimport { isVariantLabel } from './is-variant-label.mjs';\nimport { resolveVariant } from './resolve-dynamic-variants.mjs';\nimport { variantPriorityOrder } from './variant-props.mjs';\n\nconst reversePriorityOrder = [...variantPriorityOrder].reverse();\nconst numAnimationTypes = variantPriorityOrder.length;\nfunction animateList(visualElement) {\n return (animations) => Promise.all(animations.map(({ animation, options }) => animateVisualElement(visualElement, animation, options)));\n}\nfunction createAnimationState(visualElement) {\n let animate = animateList(visualElement);\n let state = createState();\n let isInitialRender = true;\n /**\n * This function will be used to reduce the animation definitions for\n * each active animation type into an object of resolved values for it.\n */\n const buildResolvedTypeValues = (type) => (acc, definition) => {\n const resolved = resolveVariant(visualElement, definition, type === \"exit\"\n ? visualElement.presenceContext?.custom\n : undefined);\n if (resolved) {\n const { transition, transitionEnd, ...target } = resolved;\n acc = { ...acc, ...target, ...transitionEnd };\n }\n return acc;\n };\n /**\n * This just allows us to inject mocked animation functions\n * @internal\n */\n function setAnimateFunction(makeAnimator) {\n animate = makeAnimator(visualElement);\n }\n /**\n * When we receive new props, we need to:\n * 1. Create a list of protected keys for each type. This is a directory of\n * value keys that are currently being \"handled\" by types of a higher priority\n * so that whenever an animation is played of a given type, these values are\n * protected from being animated.\n * 2. Determine if an animation type needs animating.\n * 3. Determine if any values have been removed from a type and figure out\n * what to animate those to.\n */\n function animateChanges(changedActiveType) {\n const { props } = visualElement;\n const context = getVariantContext(visualElement.parent) || {};\n /**\n * A list of animations that we'll build into as we iterate through the animation\n * types. This will get executed at the end of the function.\n */\n const animations = [];\n /**\n * Keep track of which values have been removed. Then, as we hit lower priority\n * animation types, we can check if they contain removed values and animate to that.\n */\n const removedKeys = new Set();\n /**\n * A dictionary of all encountered keys. This is an object to let us build into and\n * copy it without iteration. Each time we hit an animation type we set its protected\n * keys - the keys its not allowed to animate - to the latest version of this object.\n */\n let encounteredKeys = {};\n /**\n * If a variant has been removed at a given index, and this component is controlling\n * variant animations, we want to ensure lower-priority variants are forced to animate.\n */\n let removedVariantIndex = Infinity;\n /**\n * Iterate through all animation types in reverse priority order. For each, we want to\n * detect which values it's handling and whether or not they've changed (and therefore\n * need to be animated). If any values have been removed, we want to detect those in\n * lower priority props and flag for animation.\n */\n for (let i = 0; i < numAnimationTypes; i++) {\n const type = reversePriorityOrder[i];\n const typeState = state[type];\n const prop = props[type] !== undefined\n ? props[type]\n : context[type];\n const propIsVariant = isVariantLabel(prop);\n /**\n * If this type has *just* changed isActive status, set activeDelta\n * to that status. Otherwise set to null.\n */\n const activeDelta = type === changedActiveType ? typeState.isActive : null;\n if (activeDelta === false)\n removedVariantIndex = i;\n /**\n * If this prop is an inherited variant, rather than been set directly on the\n * component itself, we want to make sure we allow the parent to trigger animations.\n *\n * TODO: Can probably change this to a !isControllingVariants check\n */\n let isInherited = prop === context[type] &&\n prop !== props[type] &&\n propIsVariant;\n if (isInherited &&\n isInitialRender &&\n visualElement.manuallyAnimateOnMount) {\n isInherited = false;\n }\n /**\n * Set all encountered keys so far as the protected keys for this type. This will\n * be any key that has been animated or otherwise handled by active, higher-priortiy types.\n */\n typeState.protectedKeys = { ...encounteredKeys };\n // Check if we can skip analysing this prop early\n if (\n // If it isn't active and hasn't *just* been set as inactive\n (!typeState.isActive && activeDelta === null) ||\n // If we didn't and don't have any defined prop for this animation type\n (!prop && !typeState.prevProp) ||\n // Or if the prop doesn't define an animation\n isAnimationControls(prop) ||\n typeof prop === \"boolean\") {\n continue;\n }\n /**\n * As we go look through the values defined on this type, if we detect\n * a changed value or a value that was removed in a higher priority, we set\n * this to true and add this prop to the animation list.\n */\n const variantDidChange = checkVariantsDidChange(typeState.prevProp, prop);\n let shouldAnimateType = variantDidChange ||\n // If we're making this variant active, we want to always make it active\n (type === changedActiveType &&\n typeState.isActive &&\n !isInherited &&\n propIsVariant) ||\n // If we removed a higher-priority variant (i is in reverse order)\n (i > removedVariantIndex && propIsVariant);\n let handledRemovedValues = false;\n /**\n * As animations can be set as variant lists, variants or target objects, we\n * coerce everything to an array if it isn't one already\n */\n const definitionList = Array.isArray(prop) ? prop : [prop];\n /**\n * Build an object of all the resolved values. We'll use this in the subsequent\n * animateChanges calls to determine whether a value has changed.\n */\n let resolvedValues = definitionList.reduce(buildResolvedTypeValues(type), {});\n if (activeDelta === false)\n resolvedValues = {};\n /**\n * Now we need to loop through all the keys in the prev prop and this prop,\n * and decide:\n * 1. If the value has changed, and needs animating\n * 2. If it has been removed, and needs adding to the removedKeys set\n * 3. If it has been removed in a higher priority type and needs animating\n * 4. If it hasn't been removed in a higher priority but hasn't changed, and\n * needs adding to the type's protectedKeys list.\n */\n const { prevResolvedValues = {} } = typeState;\n const allKeys = {\n ...prevResolvedValues,\n ...resolvedValues,\n };\n const markToAnimate = (key) => {\n shouldAnimateType = true;\n if (removedKeys.has(key)) {\n handledRemovedValues = true;\n removedKeys.delete(key);\n }\n typeState.needsAnimating[key] = true;\n const motionValue = visualElement.getValue(key);\n if (motionValue)\n motionValue.liveStyle = false;\n };\n for (const key in allKeys) {\n const next = resolvedValues[key];\n const prev = prevResolvedValues[key];\n // If we've already handled this we can just skip ahead\n if (encounteredKeys.hasOwnProperty(key))\n continue;\n /**\n * If the value has changed, we probably want to animate it.\n */\n let valueHasChanged = false;\n if (isKeyframesTarget(next) && isKeyframesTarget(prev)) {\n valueHasChanged = !shallowCompare(next, prev);\n }\n else {\n valueHasChanged = next !== prev;\n }\n if (valueHasChanged) {\n if (next !== undefined && next !== null) {\n // If next is defined and doesn't equal prev, it needs animating\n markToAnimate(key);\n }\n else {\n // If it's undefined, it's been removed.\n removedKeys.add(key);\n }\n }\n else if (next !== undefined && removedKeys.has(key)) {\n /**\n * If next hasn't changed and it isn't undefined, we want to check if it's\n * been removed by a higher priority\n */\n markToAnimate(key);\n }\n else {\n /**\n * If it hasn't changed, we add it to the list of protected values\n * to ensure it doesn't get animated.\n */\n typeState.protectedKeys[key] = true;\n }\n }\n /**\n * Update the typeState so next time animateChanges is called we can compare the\n * latest prop and resolvedValues to these.\n */\n typeState.prevProp = prop;\n typeState.prevResolvedValues = resolvedValues;\n if (typeState.isActive) {\n encounteredKeys = { ...encounteredKeys, ...resolvedValues };\n }\n if (isInitialRender && visualElement.blockInitialAnimation) {\n shouldAnimateType = false;\n }\n /**\n * If this is an inherited prop we want to skip this animation\n * unless the inherited variants haven't changed on this render.\n */\n const willAnimateViaParent = isInherited && variantDidChange;\n const needsAnimating = !willAnimateViaParent || handledRemovedValues;\n if (shouldAnimateType && needsAnimating) {\n animations.push(...definitionList.map((animation) => {\n const options = { type };\n /**\n * If we're performing the initial animation, but we're not\n * rendering at the same time as the variant-controlling parent,\n * we want to use the parent's transition to calculate the stagger.\n */\n if (typeof animation === \"string\" &&\n isInitialRender &&\n !willAnimateViaParent &&\n visualElement.manuallyAnimateOnMount &&\n visualElement.parent) {\n const { parent } = visualElement;\n const parentVariant = resolveVariant(parent, animation);\n if (parent.enteringChildren && parentVariant) {\n const { delayChildren } = parentVariant.transition || {};\n options.delay = calcChildStagger(parent.enteringChildren, visualElement, delayChildren);\n }\n }\n return {\n animation: animation,\n options,\n };\n }));\n }\n }\n /**\n * If there are some removed value that haven't been dealt with,\n * we need to create a new animation that falls back either to the value\n * defined in the style prop, or the last read value.\n */\n if (removedKeys.size) {\n const fallbackAnimation = {};\n /**\n * If the initial prop contains a transition we can use that, otherwise\n * allow the animation function to use the visual element's default.\n */\n if (typeof props.initial !== \"boolean\") {\n const initialTransition = resolveVariant(visualElement, Array.isArray(props.initial)\n ? props.initial[0]\n : props.initial);\n if (initialTransition && initialTransition.transition) {\n fallbackAnimation.transition = initialTransition.transition;\n }\n }\n removedKeys.forEach((key) => {\n const fallbackTarget = visualElement.getBaseTarget(key);\n const motionValue = visualElement.getValue(key);\n if (motionValue)\n motionValue.liveStyle = true;\n // @ts-expect-error - @mattgperry to figure if we should do something here\n fallbackAnimation[key] = fallbackTarget ?? null;\n });\n animations.push({ animation: fallbackAnimation });\n }\n let shouldAnimate = Boolean(animations.length);\n if (isInitialRender &&\n (props.initial === false || props.initial === props.animate) &&\n !visualElement.manuallyAnimateOnMount) {\n shouldAnimate = false;\n }\n isInitialRender = false;\n return shouldAnimate ? animate(animations) : Promise.resolve();\n }\n /**\n * Change whether a certain animation type is active.\n */\n function setActive(type, isActive) {\n // If the active state hasn't changed, we can safely do nothing here\n if (state[type].isActive === isActive)\n return Promise.resolve();\n // Propagate active change to children\n visualElement.variantChildren?.forEach((child) => child.animationState?.setActive(type, isActive));\n state[type].isActive = isActive;\n const animations = animateChanges(type);\n for (const key in state) {\n state[key].protectedKeys = {};\n }\n return animations;\n }\n return {\n animateChanges,\n setActive,\n setAnimateFunction,\n getState: () => state,\n reset: () => {\n state = createState();\n /**\n * Temporarily disabling resetting this flag as it prevents components\n * with initial={false} from animating after being remounted, for instance\n * as the child of an Activity component.\n */\n // isInitialRender = true\n },\n };\n}\nfunction checkVariantsDidChange(prev, next) {\n if (typeof next === \"string\") {\n return next !== prev;\n }\n else if (Array.isArray(next)) {\n return !shallowCompare(next, prev);\n }\n return false;\n}\nfunction createTypeState(isActive = false) {\n return {\n isActive,\n protectedKeys: {},\n needsAnimating: {},\n prevResolvedValues: {},\n };\n}\nfunction createState() {\n return {\n animate: createTypeState(true),\n whileInView: createTypeState(),\n whileHover: createTypeState(),\n whileTap: createTypeState(),\n whileDrag: createTypeState(),\n whileFocus: createTypeState(),\n exit: createTypeState(),\n };\n}\n\nexport { checkVariantsDidChange, createAnimationState };\n","class Feature {\n constructor(node) {\n this.isMounted = false;\n this.node = node;\n }\n update() { }\n}\n\nexport { Feature };\n","import { isAnimationControls } from '../../../animation/utils/is-animation-controls.mjs';\nimport { createAnimationState } from '../../../render/utils/animation-state.mjs';\nimport { Feature } from '../Feature.mjs';\n\nclass AnimationFeature extends Feature {\n /**\n * We dynamically generate the AnimationState manager as it contains a reference\n * to the underlying animation library. We only want to load that if we load this,\n * so people can optionally code split it out using the `m` component.\n */\n constructor(node) {\n super(node);\n node.animationState || (node.animationState = createAnimationState(node));\n }\n updateAnimationControlsSubscription() {\n const { animate } = this.node.getProps();\n if (isAnimationControls(animate)) {\n this.unmountControls = animate.subscribe(this.node);\n }\n }\n /**\n * Subscribe any provided AnimationControls to the component's VisualElement\n */\n mount() {\n this.updateAnimationControlsSubscription();\n }\n update() {\n const { animate } = this.node.getProps();\n const { animate: prevAnimate } = this.node.prevProps || {};\n if (animate !== prevAnimate) {\n this.updateAnimationControlsSubscription();\n }\n }\n unmount() {\n this.node.animationState.reset();\n this.unmountControls?.();\n }\n}\n\nexport { AnimationFeature };\n","import { Feature } from '../Feature.mjs';\n\nlet id = 0;\nclass ExitAnimationFeature extends Feature {\n constructor() {\n super(...arguments);\n this.id = id++;\n }\n update() {\n if (!this.node.presenceContext)\n return;\n const { isPresent, onExitComplete } = this.node.presenceContext;\n const { isPresent: prevIsPresent } = this.node.prevPresenceContext || {};\n if (!this.node.animationState || isPresent === prevIsPresent) {\n return;\n }\n const exitAnimation = this.node.animationState.setActive(\"exit\", !isPresent);\n if (onExitComplete && !isPresent) {\n exitAnimation.then(() => {\n onExitComplete(this.id);\n });\n }\n }\n mount() {\n const { register, onExitComplete } = this.node.presenceContext || {};\n if (onExitComplete) {\n onExitComplete(this.id);\n }\n if (register) {\n this.unmount = register(this.id);\n }\n }\n unmount() { }\n}\n\nexport { ExitAnimationFeature };\n","import { AnimationFeature } from './animation/index.mjs';\nimport { ExitAnimationFeature } from './animation/exit.mjs';\n\nconst animations = {\n animation: {\n Feature: AnimationFeature,\n },\n exit: {\n Feature: ExitAnimationFeature,\n },\n};\n\nexport { animations };\n","function addDomEvent(target, eventName, handler, options = { passive: true }) {\n target.addEventListener(eventName, handler, options);\n return () => target.removeEventListener(eventName, handler);\n}\n\nexport { addDomEvent };\n","import { isPrimaryPointer } from 'motion-dom';\n\nfunction extractEventInfo(event) {\n return {\n point: {\n x: event.pageX,\n y: event.pageY,\n },\n };\n}\nconst addPointerInfo = (handler) => {\n return (event) => isPrimaryPointer(event) && handler(event, extractEventInfo(event));\n};\n\nexport { addPointerInfo, extractEventInfo };\n","import { addDomEvent } from './add-dom-event.mjs';\nimport { addPointerInfo } from './event-info.mjs';\n\nfunction addPointerEvent(target, eventName, handler, options) {\n return addDomEvent(target, eventName, addPointerInfo(handler), options);\n}\n\nexport { addPointerEvent };\n","import { mixNumber } from 'motion-dom';\n\nconst SCALE_PRECISION = 0.0001;\nconst SCALE_MIN = 1 - SCALE_PRECISION;\nconst SCALE_MAX = 1 + SCALE_PRECISION;\nconst TRANSLATE_PRECISION = 0.01;\nconst TRANSLATE_MIN = 0 - TRANSLATE_PRECISION;\nconst TRANSLATE_MAX = 0 + TRANSLATE_PRECISION;\nfunction calcLength(axis) {\n return axis.max - axis.min;\n}\nfunction isNear(value, target, maxDistance) {\n return Math.abs(value - target) <= maxDistance;\n}\nfunction calcAxisDelta(delta, source, target, origin = 0.5) {\n delta.origin = origin;\n delta.originPoint = mixNumber(source.min, source.max, delta.origin);\n delta.scale = calcLength(target) / calcLength(source);\n delta.translate =\n mixNumber(target.min, target.max, delta.origin) - delta.originPoint;\n if ((delta.scale >= SCALE_MIN && delta.scale <= SCALE_MAX) ||\n isNaN(delta.scale)) {\n delta.scale = 1.0;\n }\n if ((delta.translate >= TRANSLATE_MIN &&\n delta.translate <= TRANSLATE_MAX) ||\n isNaN(delta.translate)) {\n delta.translate = 0.0;\n }\n}\nfunction calcBoxDelta(delta, source, target, origin) {\n calcAxisDelta(delta.x, source.x, target.x, origin ? origin.originX : undefined);\n calcAxisDelta(delta.y, source.y, target.y, origin ? origin.originY : undefined);\n}\nfunction calcRelativeAxis(target, relative, parent) {\n target.min = parent.min + relative.min;\n target.max = target.min + calcLength(relative);\n}\nfunction calcRelativeBox(target, relative, parent) {\n calcRelativeAxis(target.x, relative.x, parent.x);\n calcRelativeAxis(target.y, relative.y, parent.y);\n}\nfunction calcRelativeAxisPosition(target, layout, parent) {\n target.min = layout.min - parent.min;\n target.max = target.min + calcLength(layout);\n}\nfunction calcRelativePosition(target, layout, parent) {\n calcRelativeAxisPosition(target.x, layout.x, parent.x);\n calcRelativeAxisPosition(target.y, layout.y, parent.y);\n}\n\nexport { calcAxisDelta, calcBoxDelta, calcLength, calcRelativeAxis, calcRelativeAxisPosition, calcRelativeBox, calcRelativePosition, isNear };\n","function eachAxis(callback) {\n return [callback(\"x\"), callback(\"y\")];\n}\n\nexport { eachAxis };\n","// Fixes https://github.com/motiondivision/motion/issues/2270\nconst getContextWindow = ({ current }) => {\n return current ? current.ownerDocument.defaultView : null;\n};\n\nexport { getContextWindow };\n","const distance = (a, b) => Math.abs(a - b);\nfunction distance2D(a, b) {\n // Multi-dimensional\n const xDelta = distance(a.x, b.x);\n const yDelta = distance(a.y, b.y);\n return Math.sqrt(xDelta ** 2 + yDelta ** 2);\n}\n\nexport { distance, distance2D };\n","import { frame, isPrimaryPointer, cancelFrame, frameData } from 'motion-dom';\nimport { pipe, secondsToMilliseconds, millisecondsToSeconds } from 'motion-utils';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { extractEventInfo } from '../../events/event-info.mjs';\nimport { distance2D } from '../../utils/distance.mjs';\n\n/**\n * @internal\n */\nclass PanSession {\n constructor(event, handlers, { transformPagePoint, contextWindow = window, dragSnapToOrigin = false, distanceThreshold = 3, } = {}) {\n /**\n * @internal\n */\n this.startEvent = null;\n /**\n * @internal\n */\n this.lastMoveEvent = null;\n /**\n * @internal\n */\n this.lastMoveEventInfo = null;\n /**\n * @internal\n */\n this.handlers = {};\n /**\n * @internal\n */\n this.contextWindow = window;\n this.updatePoint = () => {\n if (!(this.lastMoveEvent && this.lastMoveEventInfo))\n return;\n const info = getPanInfo(this.lastMoveEventInfo, this.history);\n const isPanStarted = this.startEvent !== null;\n // Only start panning if the offset is larger than 3 pixels. If we make it\n // any larger than this we'll want to reset the pointer history\n // on the first update to avoid visual snapping to the cursor.\n const isDistancePastThreshold = distance2D(info.offset, { x: 0, y: 0 }) >= this.distanceThreshold;\n if (!isPanStarted && !isDistancePastThreshold)\n return;\n const { point } = info;\n const { timestamp } = frameData;\n this.history.push({ ...point, timestamp });\n const { onStart, onMove } = this.handlers;\n if (!isPanStarted) {\n onStart && onStart(this.lastMoveEvent, info);\n this.startEvent = this.lastMoveEvent;\n }\n onMove && onMove(this.lastMoveEvent, info);\n };\n this.handlePointerMove = (event, info) => {\n this.lastMoveEvent = event;\n this.lastMoveEventInfo = transformPoint(info, this.transformPagePoint);\n // Throttle mouse move event to once per frame\n frame.update(this.updatePoint, true);\n };\n this.handlePointerUp = (event, info) => {\n this.end();\n const { onEnd, onSessionEnd, resumeAnimation } = this.handlers;\n if (this.dragSnapToOrigin)\n resumeAnimation && resumeAnimation();\n if (!(this.lastMoveEvent && this.lastMoveEventInfo))\n return;\n const panInfo = getPanInfo(event.type === \"pointercancel\"\n ? this.lastMoveEventInfo\n : transformPoint(info, this.transformPagePoint), this.history);\n if (this.startEvent && onEnd) {\n onEnd(event, panInfo);\n }\n onSessionEnd && onSessionEnd(event, panInfo);\n };\n // If we have more than one touch, don't start detecting this gesture\n if (!isPrimaryPointer(event))\n return;\n this.dragSnapToOrigin = dragSnapToOrigin;\n this.handlers = handlers;\n this.transformPagePoint = transformPagePoint;\n this.distanceThreshold = distanceThreshold;\n this.contextWindow = contextWindow || window;\n const info = extractEventInfo(event);\n const initialInfo = transformPoint(info, this.transformPagePoint);\n const { point } = initialInfo;\n const { timestamp } = frameData;\n this.history = [{ ...point, timestamp }];\n const { onSessionStart } = handlers;\n onSessionStart &&\n onSessionStart(event, getPanInfo(initialInfo, this.history));\n this.removeListeners = pipe(addPointerEvent(this.contextWindow, \"pointermove\", this.handlePointerMove), addPointerEvent(this.contextWindow, \"pointerup\", this.handlePointerUp), addPointerEvent(this.contextWindow, \"pointercancel\", this.handlePointerUp));\n }\n updateHandlers(handlers) {\n this.handlers = handlers;\n }\n end() {\n this.removeListeners && this.removeListeners();\n cancelFrame(this.updatePoint);\n }\n}\nfunction transformPoint(info, transformPagePoint) {\n return transformPagePoint ? { point: transformPagePoint(info.point) } : info;\n}\nfunction subtractPoint(a, b) {\n return { x: a.x - b.x, y: a.y - b.y };\n}\nfunction getPanInfo({ point }, history) {\n return {\n point,\n delta: subtractPoint(point, lastDevicePoint(history)),\n offset: subtractPoint(point, startDevicePoint(history)),\n velocity: getVelocity(history, 0.1),\n };\n}\nfunction startDevicePoint(history) {\n return history[0];\n}\nfunction lastDevicePoint(history) {\n return history[history.length - 1];\n}\nfunction getVelocity(history, timeDelta) {\n if (history.length < 2) {\n return { x: 0, y: 0 };\n }\n let i = history.length - 1;\n let timestampedPoint = null;\n const lastPoint = lastDevicePoint(history);\n while (i >= 0) {\n timestampedPoint = history[i];\n if (lastPoint.timestamp - timestampedPoint.timestamp >\n secondsToMilliseconds(timeDelta)) {\n break;\n }\n i--;\n }\n if (!timestampedPoint) {\n return { x: 0, y: 0 };\n }\n const time = millisecondsToSeconds(lastPoint.timestamp - timestampedPoint.timestamp);\n if (time === 0) {\n return { x: 0, y: 0 };\n }\n const currentVelocity = {\n x: (lastPoint.x - timestampedPoint.x) / time,\n y: (lastPoint.y - timestampedPoint.y) / time,\n };\n if (currentVelocity.x === Infinity) {\n currentVelocity.x = 0;\n }\n if (currentVelocity.y === Infinity) {\n currentVelocity.y = 0;\n }\n return currentVelocity;\n}\n\nexport { PanSession };\n","import { mixNumber } from 'motion-dom';\nimport { progress, clamp } from 'motion-utils';\nimport { calcLength } from '../../../projection/geometry/delta-calc.mjs';\n\n/**\n * Apply constraints to a point. These constraints are both physical along an\n * axis, and an elastic factor that determines how much to constrain the point\n * by if it does lie outside the defined parameters.\n */\nfunction applyConstraints(point, { min, max }, elastic) {\n if (min !== undefined && point < min) {\n // If we have a min point defined, and this is outside of that, constrain\n point = elastic\n ? mixNumber(min, point, elastic.min)\n : Math.max(point, min);\n }\n else if (max !== undefined && point > max) {\n // If we have a max point defined, and this is outside of that, constrain\n point = elastic\n ? mixNumber(max, point, elastic.max)\n : Math.min(point, max);\n }\n return point;\n}\n/**\n * Calculate constraints in terms of the viewport when defined relatively to the\n * measured axis. This is measured from the nearest edge, so a max constraint of 200\n * on an axis with a max value of 300 would return a constraint of 500 - axis length\n */\nfunction calcRelativeAxisConstraints(axis, min, max) {\n return {\n min: min !== undefined ? axis.min + min : undefined,\n max: max !== undefined\n ? axis.max + max - (axis.max - axis.min)\n : undefined,\n };\n}\n/**\n * Calculate constraints in terms of the viewport when\n * defined relatively to the measured bounding box.\n */\nfunction calcRelativeConstraints(layoutBox, { top, left, bottom, right }) {\n return {\n x: calcRelativeAxisConstraints(layoutBox.x, left, right),\n y: calcRelativeAxisConstraints(layoutBox.y, top, bottom),\n };\n}\n/**\n * Calculate viewport constraints when defined as another viewport-relative axis\n */\nfunction calcViewportAxisConstraints(layoutAxis, constraintsAxis) {\n let min = constraintsAxis.min - layoutAxis.min;\n let max = constraintsAxis.max - layoutAxis.max;\n // If the constraints axis is actually smaller than the layout axis then we can\n // flip the constraints\n if (constraintsAxis.max - constraintsAxis.min <\n layoutAxis.max - layoutAxis.min) {\n [min, max] = [max, min];\n }\n return { min, max };\n}\n/**\n * Calculate viewport constraints when defined as another viewport-relative box\n */\nfunction calcViewportConstraints(layoutBox, constraintsBox) {\n return {\n x: calcViewportAxisConstraints(layoutBox.x, constraintsBox.x),\n y: calcViewportAxisConstraints(layoutBox.y, constraintsBox.y),\n };\n}\n/**\n * Calculate a transform origin relative to the source axis, between 0-1, that results\n * in an asthetically pleasing scale/transform needed to project from source to target.\n */\nfunction calcOrigin(source, target) {\n let origin = 0.5;\n const sourceLength = calcLength(source);\n const targetLength = calcLength(target);\n if (targetLength > sourceLength) {\n origin = progress(target.min, target.max - sourceLength, source.min);\n }\n else if (sourceLength > targetLength) {\n origin = progress(source.min, source.max - targetLength, target.min);\n }\n return clamp(0, 1, origin);\n}\n/**\n * Rebase the calculated viewport constraints relative to the layout.min point.\n */\nfunction rebaseAxisConstraints(layout, constraints) {\n const relativeConstraints = {};\n if (constraints.min !== undefined) {\n relativeConstraints.min = constraints.min - layout.min;\n }\n if (constraints.max !== undefined) {\n relativeConstraints.max = constraints.max - layout.min;\n }\n return relativeConstraints;\n}\nconst defaultElastic = 0.35;\n/**\n * Accepts a dragElastic prop and returns resolved elastic values for each axis.\n */\nfunction resolveDragElastic(dragElastic = defaultElastic) {\n if (dragElastic === false) {\n dragElastic = 0;\n }\n else if (dragElastic === true) {\n dragElastic = defaultElastic;\n }\n return {\n x: resolveAxisElastic(dragElastic, \"left\", \"right\"),\n y: resolveAxisElastic(dragElastic, \"top\", \"bottom\"),\n };\n}\nfunction resolveAxisElastic(dragElastic, minLabel, maxLabel) {\n return {\n min: resolvePointElastic(dragElastic, minLabel),\n max: resolvePointElastic(dragElastic, maxLabel),\n };\n}\nfunction resolvePointElastic(dragElastic, label) {\n return typeof dragElastic === \"number\"\n ? dragElastic\n : dragElastic[label] || 0;\n}\n\nexport { applyConstraints, calcOrigin, calcRelativeAxisConstraints, calcRelativeConstraints, calcViewportAxisConstraints, calcViewportConstraints, defaultElastic, rebaseAxisConstraints, resolveAxisElastic, resolveDragElastic, resolvePointElastic };\n","import { frame, mixNumber, setDragLock, percent } from 'motion-dom';\nimport { invariant } from 'motion-utils';\nimport { animateMotionValue } from '../../animation/interfaces/motion-value.mjs';\nimport { addDomEvent } from '../../events/add-dom-event.mjs';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { extractEventInfo } from '../../events/event-info.mjs';\nimport { convertBoxToBoundingBox, convertBoundingBoxToBox } from '../../projection/geometry/conversion.mjs';\nimport { calcLength } from '../../projection/geometry/delta-calc.mjs';\nimport { createBox } from '../../projection/geometry/models.mjs';\nimport { eachAxis } from '../../projection/utils/each-axis.mjs';\nimport { measurePageBox } from '../../projection/utils/measure.mjs';\nimport { getContextWindow } from '../../utils/get-context-window.mjs';\nimport { isRefObject } from '../../utils/is-ref-object.mjs';\nimport { addValueToWillChange } from '../../value/use-will-change/add-will-change.mjs';\nimport { PanSession } from '../pan/PanSession.mjs';\nimport { applyConstraints, calcRelativeConstraints, resolveDragElastic, rebaseAxisConstraints, calcViewportConstraints, calcOrigin, defaultElastic } from './utils/constraints.mjs';\n\nconst elementDragControls = new WeakMap();\nclass VisualElementDragControls {\n constructor(visualElement) {\n this.openDragLock = null;\n this.isDragging = false;\n this.currentDirection = null;\n this.originPoint = { x: 0, y: 0 };\n /**\n * The permitted boundaries of travel, in pixels.\n */\n this.constraints = false;\n this.hasMutatedConstraints = false;\n /**\n * The per-axis resolved elastic values.\n */\n this.elastic = createBox();\n /**\n * The latest pointer event. Used as fallback when the `cancel` and `stop` functions are called without arguments.\n */\n this.latestPointerEvent = null;\n /**\n * The latest pan info. Used as fallback when the `cancel` and `stop` functions are called without arguments.\n */\n this.latestPanInfo = null;\n this.visualElement = visualElement;\n }\n start(originEvent, { snapToCursor = false, distanceThreshold } = {}) {\n /**\n * Don't start dragging if this component is exiting\n */\n const { presenceContext } = this.visualElement;\n if (presenceContext && presenceContext.isPresent === false)\n return;\n const onSessionStart = (event) => {\n const { dragSnapToOrigin } = this.getProps();\n // Stop or pause any animations on both axis values immediately. This allows the user to throw and catch\n // the component.\n dragSnapToOrigin ? this.pauseAnimation() : this.stopAnimation();\n if (snapToCursor) {\n this.snapToCursor(extractEventInfo(event).point);\n }\n };\n const onStart = (event, info) => {\n // Attempt to grab the global drag gesture lock - maybe make this part of PanSession\n const { drag, dragPropagation, onDragStart } = this.getProps();\n if (drag && !dragPropagation) {\n if (this.openDragLock)\n this.openDragLock();\n this.openDragLock = setDragLock(drag);\n // If we don 't have the lock, don't start dragging\n if (!this.openDragLock)\n return;\n }\n this.latestPointerEvent = event;\n this.latestPanInfo = info;\n this.isDragging = true;\n this.currentDirection = null;\n this.resolveConstraints();\n if (this.visualElement.projection) {\n this.visualElement.projection.isAnimationBlocked = true;\n this.visualElement.projection.target = undefined;\n }\n /**\n * Record gesture origin\n */\n eachAxis((axis) => {\n let current = this.getAxisMotionValue(axis).get() || 0;\n /**\n * If the MotionValue is a percentage value convert to px\n */\n if (percent.test(current)) {\n const { projection } = this.visualElement;\n if (projection && projection.layout) {\n const measuredAxis = projection.layout.layoutBox[axis];\n if (measuredAxis) {\n const length = calcLength(measuredAxis);\n current = length * (parseFloat(current) / 100);\n }\n }\n }\n this.originPoint[axis] = current;\n });\n // Fire onDragStart event\n if (onDragStart) {\n frame.postRender(() => onDragStart(event, info));\n }\n addValueToWillChange(this.visualElement, \"transform\");\n const { animationState } = this.visualElement;\n animationState && animationState.setActive(\"whileDrag\", true);\n };\n const onMove = (event, info) => {\n this.latestPointerEvent = event;\n this.latestPanInfo = info;\n const { dragPropagation, dragDirectionLock, onDirectionLock, onDrag, } = this.getProps();\n // If we didn't successfully receive the gesture lock, early return.\n if (!dragPropagation && !this.openDragLock)\n return;\n const { offset } = info;\n // Attempt to detect drag direction if directionLock is true\n if (dragDirectionLock && this.currentDirection === null) {\n this.currentDirection = getCurrentDirection(offset);\n // If we've successfully set a direction, notify listener\n if (this.currentDirection !== null) {\n onDirectionLock && onDirectionLock(this.currentDirection);\n }\n return;\n }\n // Update each point with the latest position\n this.updateAxis(\"x\", info.point, offset);\n this.updateAxis(\"y\", info.point, offset);\n /**\n * Ideally we would leave the renderer to fire naturally at the end of\n * this frame but if the element is about to change layout as the result\n * of a re-render we want to ensure the browser can read the latest\n * bounding box to ensure the pointer and element don't fall out of sync.\n */\n this.visualElement.render();\n /**\n * This must fire after the render call as it might trigger a state\n * change which itself might trigger a layout update.\n */\n onDrag && onDrag(event, info);\n };\n const onSessionEnd = (event, info) => {\n this.latestPointerEvent = event;\n this.latestPanInfo = info;\n this.stop(event, info);\n this.latestPointerEvent = null;\n this.latestPanInfo = null;\n };\n const resumeAnimation = () => eachAxis((axis) => this.getAnimationState(axis) === \"paused\" &&\n this.getAxisMotionValue(axis).animation?.play());\n const { dragSnapToOrigin } = this.getProps();\n this.panSession = new PanSession(originEvent, {\n onSessionStart,\n onStart,\n onMove,\n onSessionEnd,\n resumeAnimation,\n }, {\n transformPagePoint: this.visualElement.getTransformPagePoint(),\n dragSnapToOrigin,\n distanceThreshold,\n contextWindow: getContextWindow(this.visualElement),\n });\n }\n /**\n * @internal\n */\n stop(event, panInfo) {\n const finalEvent = event || this.latestPointerEvent;\n const finalPanInfo = panInfo || this.latestPanInfo;\n const isDragging = this.isDragging;\n this.cancel();\n if (!isDragging || !finalPanInfo || !finalEvent)\n return;\n const { velocity } = finalPanInfo;\n this.startAnimation(velocity);\n const { onDragEnd } = this.getProps();\n if (onDragEnd) {\n frame.postRender(() => onDragEnd(finalEvent, finalPanInfo));\n }\n }\n /**\n * @internal\n */\n cancel() {\n this.isDragging = false;\n const { projection, animationState } = this.visualElement;\n if (projection) {\n projection.isAnimationBlocked = false;\n }\n this.panSession && this.panSession.end();\n this.panSession = undefined;\n const { dragPropagation } = this.getProps();\n if (!dragPropagation && this.openDragLock) {\n this.openDragLock();\n this.openDragLock = null;\n }\n animationState && animationState.setActive(\"whileDrag\", false);\n }\n updateAxis(axis, _point, offset) {\n const { drag } = this.getProps();\n // If we're not dragging this axis, do an early return.\n if (!offset || !shouldDrag(axis, drag, this.currentDirection))\n return;\n const axisValue = this.getAxisMotionValue(axis);\n let next = this.originPoint[axis] + offset[axis];\n // Apply constraints\n if (this.constraints && this.constraints[axis]) {\n next = applyConstraints(next, this.constraints[axis], this.elastic[axis]);\n }\n axisValue.set(next);\n }\n resolveConstraints() {\n const { dragConstraints, dragElastic } = this.getProps();\n const layout = this.visualElement.projection &&\n !this.visualElement.projection.layout\n ? this.visualElement.projection.measure(false)\n : this.visualElement.projection?.layout;\n const prevConstraints = this.constraints;\n if (dragConstraints && isRefObject(dragConstraints)) {\n if (!this.constraints) {\n this.constraints = this.resolveRefConstraints();\n }\n }\n else {\n if (dragConstraints && layout) {\n this.constraints = calcRelativeConstraints(layout.layoutBox, dragConstraints);\n }\n else {\n this.constraints = false;\n }\n }\n this.elastic = resolveDragElastic(dragElastic);\n /**\n * If we're outputting to external MotionValues, we want to rebase the measured constraints\n * from viewport-relative to component-relative.\n */\n if (prevConstraints !== this.constraints &&\n layout &&\n this.constraints &&\n !this.hasMutatedConstraints) {\n eachAxis((axis) => {\n if (this.constraints !== false &&\n this.getAxisMotionValue(axis)) {\n this.constraints[axis] = rebaseAxisConstraints(layout.layoutBox[axis], this.constraints[axis]);\n }\n });\n }\n }\n resolveRefConstraints() {\n const { dragConstraints: constraints, onMeasureDragConstraints } = this.getProps();\n if (!constraints || !isRefObject(constraints))\n return false;\n const constraintsElement = constraints.current;\n invariant(constraintsElement !== null, \"If `dragConstraints` is set as a React ref, that ref must be passed to another component's `ref` prop.\", \"drag-constraints-ref\");\n const { projection } = this.visualElement;\n // TODO\n if (!projection || !projection.layout)\n return false;\n const constraintsBox = measurePageBox(constraintsElement, projection.root, this.visualElement.getTransformPagePoint());\n let measuredConstraints = calcViewportConstraints(projection.layout.layoutBox, constraintsBox);\n /**\n * If there's an onMeasureDragConstraints listener we call it and\n * if different constraints are returned, set constraints to that\n */\n if (onMeasureDragConstraints) {\n const userConstraints = onMeasureDragConstraints(convertBoxToBoundingBox(measuredConstraints));\n this.hasMutatedConstraints = !!userConstraints;\n if (userConstraints) {\n measuredConstraints = convertBoundingBoxToBox(userConstraints);\n }\n }\n return measuredConstraints;\n }\n startAnimation(velocity) {\n const { drag, dragMomentum, dragElastic, dragTransition, dragSnapToOrigin, onDragTransitionEnd, } = this.getProps();\n const constraints = this.constraints || {};\n const momentumAnimations = eachAxis((axis) => {\n if (!shouldDrag(axis, drag, this.currentDirection)) {\n return;\n }\n let transition = (constraints && constraints[axis]) || {};\n if (dragSnapToOrigin)\n transition = { min: 0, max: 0 };\n /**\n * Overdamp the boundary spring if `dragElastic` is disabled. There's still a frame\n * of spring animations so we should look into adding a disable spring option to `inertia`.\n * We could do something here where we affect the `bounceStiffness` and `bounceDamping`\n * using the value of `dragElastic`.\n */\n const bounceStiffness = dragElastic ? 200 : 1000000;\n const bounceDamping = dragElastic ? 40 : 10000000;\n const inertia = {\n type: \"inertia\",\n velocity: dragMomentum ? velocity[axis] : 0,\n bounceStiffness,\n bounceDamping,\n timeConstant: 750,\n restDelta: 1,\n restSpeed: 10,\n ...dragTransition,\n ...transition,\n };\n // If we're not animating on an externally-provided `MotionValue` we can use the\n // component's animation controls which will handle interactions with whileHover (etc),\n // otherwise we just have to animate the `MotionValue` itself.\n return this.startAxisValueAnimation(axis, inertia);\n });\n // Run all animations and then resolve the new drag constraints.\n return Promise.all(momentumAnimations).then(onDragTransitionEnd);\n }\n startAxisValueAnimation(axis, transition) {\n const axisValue = this.getAxisMotionValue(axis);\n addValueToWillChange(this.visualElement, axis);\n return axisValue.start(animateMotionValue(axis, axisValue, 0, transition, this.visualElement, false));\n }\n stopAnimation() {\n eachAxis((axis) => this.getAxisMotionValue(axis).stop());\n }\n pauseAnimation() {\n eachAxis((axis) => this.getAxisMotionValue(axis).animation?.pause());\n }\n getAnimationState(axis) {\n return this.getAxisMotionValue(axis).animation?.state;\n }\n /**\n * Drag works differently depending on which props are provided.\n *\n * - If _dragX and _dragY are provided, we output the gesture delta directly to those motion values.\n * - Otherwise, we apply the delta to the x/y motion values.\n */\n getAxisMotionValue(axis) {\n const dragKey = `_drag${axis.toUpperCase()}`;\n const props = this.visualElement.getProps();\n const externalMotionValue = props[dragKey];\n return externalMotionValue\n ? externalMotionValue\n : this.visualElement.getValue(axis, (props.initial\n ? props.initial[axis]\n : undefined) || 0);\n }\n snapToCursor(point) {\n eachAxis((axis) => {\n const { drag } = this.getProps();\n // If we're not dragging this axis, do an early return.\n if (!shouldDrag(axis, drag, this.currentDirection))\n return;\n const { projection } = this.visualElement;\n const axisValue = this.getAxisMotionValue(axis);\n if (projection && projection.layout) {\n const { min, max } = projection.layout.layoutBox[axis];\n axisValue.set(point[axis] - mixNumber(min, max, 0.5));\n }\n });\n }\n /**\n * When the viewport resizes we want to check if the measured constraints\n * have changed and, if so, reposition the element within those new constraints\n * relative to where it was before the resize.\n */\n scalePositionWithinConstraints() {\n if (!this.visualElement.current)\n return;\n const { drag, dragConstraints } = this.getProps();\n const { projection } = this.visualElement;\n if (!isRefObject(dragConstraints) || !projection || !this.constraints)\n return;\n /**\n * Stop current animations as there can be visual glitching if we try to do\n * this mid-animation\n */\n this.stopAnimation();\n /**\n * Record the relative position of the dragged element relative to the\n * constraints box and save as a progress value.\n */\n const boxProgress = { x: 0, y: 0 };\n eachAxis((axis) => {\n const axisValue = this.getAxisMotionValue(axis);\n if (axisValue && this.constraints !== false) {\n const latest = axisValue.get();\n boxProgress[axis] = calcOrigin({ min: latest, max: latest }, this.constraints[axis]);\n }\n });\n /**\n * Update the layout of this element and resolve the latest drag constraints\n */\n const { transformTemplate } = this.visualElement.getProps();\n this.visualElement.current.style.transform = transformTemplate\n ? transformTemplate({}, \"\")\n : \"none\";\n projection.root && projection.root.updateScroll();\n projection.updateLayout();\n this.resolveConstraints();\n /**\n * For each axis, calculate the current progress of the layout axis\n * within the new constraints.\n */\n eachAxis((axis) => {\n if (!shouldDrag(axis, drag, null))\n return;\n /**\n * Calculate a new transform based on the previous box progress\n */\n const axisValue = this.getAxisMotionValue(axis);\n const { min, max } = this.constraints[axis];\n axisValue.set(mixNumber(min, max, boxProgress[axis]));\n });\n }\n addListeners() {\n if (!this.visualElement.current)\n return;\n elementDragControls.set(this.visualElement, this);\n const element = this.visualElement.current;\n /**\n * Attach a pointerdown event listener on this DOM element to initiate drag tracking.\n */\n const stopPointerListener = addPointerEvent(element, \"pointerdown\", (event) => {\n const { drag, dragListener = true } = this.getProps();\n drag && dragListener && this.start(event);\n });\n const measureDragConstraints = () => {\n const { dragConstraints } = this.getProps();\n if (isRefObject(dragConstraints) && dragConstraints.current) {\n this.constraints = this.resolveRefConstraints();\n }\n };\n const { projection } = this.visualElement;\n const stopMeasureLayoutListener = projection.addEventListener(\"measure\", measureDragConstraints);\n if (projection && !projection.layout) {\n projection.root && projection.root.updateScroll();\n projection.updateLayout();\n }\n frame.read(measureDragConstraints);\n /**\n * Attach a window resize listener to scale the draggable target within its defined\n * constraints as the window resizes.\n */\n const stopResizeListener = addDomEvent(window, \"resize\", () => this.scalePositionWithinConstraints());\n /**\n * If the element's layout changes, calculate the delta and apply that to\n * the drag gesture's origin point.\n */\n const stopLayoutUpdateListener = projection.addEventListener(\"didUpdate\", (({ delta, hasLayoutChanged }) => {\n if (this.isDragging && hasLayoutChanged) {\n eachAxis((axis) => {\n const motionValue = this.getAxisMotionValue(axis);\n if (!motionValue)\n return;\n this.originPoint[axis] += delta[axis].translate;\n motionValue.set(motionValue.get() + delta[axis].translate);\n });\n this.visualElement.render();\n }\n }));\n return () => {\n stopResizeListener();\n stopPointerListener();\n stopMeasureLayoutListener();\n stopLayoutUpdateListener && stopLayoutUpdateListener();\n };\n }\n getProps() {\n const props = this.visualElement.getProps();\n const { drag = false, dragDirectionLock = false, dragPropagation = false, dragConstraints = false, dragElastic = defaultElastic, dragMomentum = true, } = props;\n return {\n ...props,\n drag,\n dragDirectionLock,\n dragPropagation,\n dragConstraints,\n dragElastic,\n dragMomentum,\n };\n }\n}\nfunction shouldDrag(direction, drag, currentDirection) {\n return ((drag === true || drag === direction) &&\n (currentDirection === null || currentDirection === direction));\n}\n/**\n * Based on an x/y offset determine the current drag direction. If both axis' offsets are lower\n * than the provided threshold, return `null`.\n *\n * @param offset - The x/y offset from origin.\n * @param lockThreshold - (Optional) - the minimum absolute offset before we can determine a drag direction.\n */\nfunction getCurrentDirection(offset, lockThreshold = 10) {\n let direction = null;\n if (Math.abs(offset.y) > lockThreshold) {\n direction = \"y\";\n }\n else if (Math.abs(offset.x) > lockThreshold) {\n direction = \"x\";\n }\n return direction;\n}\n\nexport { VisualElementDragControls, elementDragControls };\n","import { Feature } from '../../motion/features/Feature.mjs';\nimport { noop } from 'motion-utils';\nimport { VisualElementDragControls } from './VisualElementDragControls.mjs';\n\nclass DragGesture extends Feature {\n constructor(node) {\n super(node);\n this.removeGroupControls = noop;\n this.removeListeners = noop;\n this.controls = new VisualElementDragControls(node);\n }\n mount() {\n // If we've been provided a DragControls for manual control over the drag gesture,\n // subscribe this component to it on mount.\n const { dragControls } = this.node.getProps();\n if (dragControls) {\n this.removeGroupControls = dragControls.subscribe(this.controls);\n }\n this.removeListeners = this.controls.addListeners() || noop;\n }\n unmount() {\n this.removeGroupControls();\n this.removeListeners();\n }\n}\n\nexport { DragGesture };\n","import { frame } from 'motion-dom';\nimport { noop } from 'motion-utils';\nimport { addPointerEvent } from '../../events/add-pointer-event.mjs';\nimport { Feature } from '../../motion/features/Feature.mjs';\nimport { getContextWindow } from '../../utils/get-context-window.mjs';\nimport { PanSession } from './PanSession.mjs';\n\nconst asyncHandler = (handler) => (event, info) => {\n if (handler) {\n frame.postRender(() => handler(event, info));\n }\n};\nclass PanGesture extends Feature {\n constructor() {\n super(...arguments);\n this.removePointerDownListener = noop;\n }\n onPointerDown(pointerDownEvent) {\n this.session = new PanSession(pointerDownEvent, this.createPanHandlers(), {\n transformPagePoint: this.node.getTransformPagePoint(),\n contextWindow: getContextWindow(this.node),\n });\n }\n createPanHandlers() {\n const { onPanSessionStart, onPanStart, onPan, onPanEnd } = this.node.getProps();\n return {\n onSessionStart: asyncHandler(onPanSessionStart),\n onStart: asyncHandler(onPanStart),\n onMove: onPan,\n onEnd: (event, info) => {\n delete this.session;\n if (onPanEnd) {\n frame.postRender(() => onPanEnd(event, info));\n }\n },\n };\n }\n mount() {\n this.removePointerDownListener = addPointerEvent(this.node.current, \"pointerdown\", (event) => this.onPointerDown(event));\n }\n update() {\n this.session && this.session.updateHandlers(this.createPanHandlers());\n }\n unmount() {\n this.removePointerDownListener();\n this.session && this.session.end();\n }\n}\n\nexport { PanGesture };\n","\"use client\";\nimport { jsx } from 'react/jsx-runtime';\nimport { frame, microtask } from 'motion-dom';\nimport { useContext, Component } from 'react';\nimport { usePresence } from '../../../components/AnimatePresence/use-presence.mjs';\nimport { LayoutGroupContext } from '../../../context/LayoutGroupContext.mjs';\nimport { SwitchLayoutGroupContext } from '../../../context/SwitchLayoutGroupContext.mjs';\nimport { globalProjectionState } from '../../../projection/node/state.mjs';\n\n/**\n * Track whether we've taken any snapshots yet. If not,\n * we can safely skip notification of didUpdate.\n *\n * Difficult to capture in a test but to prevent flickering\n * we must set this to true either on update or unmount.\n * Running `next-env/layout-id` in Safari will show this behaviour if broken.\n */\nlet hasTakenAnySnapshot = false;\nclass MeasureLayoutWithContext extends Component {\n /**\n * This only mounts projection nodes for components that\n * need measuring, we might want to do it for all components\n * in order to incorporate transforms\n */\n componentDidMount() {\n const { visualElement, layoutGroup, switchLayoutGroup, layoutId } = this.props;\n const { projection } = visualElement;\n if (projection) {\n if (layoutGroup.group)\n layoutGroup.group.add(projection);\n if (switchLayoutGroup && switchLayoutGroup.register && layoutId) {\n switchLayoutGroup.register(projection);\n }\n if (hasTakenAnySnapshot) {\n projection.root.didUpdate();\n }\n projection.addEventListener(\"animationComplete\", () => {\n this.safeToRemove();\n });\n projection.setOptions({\n ...projection.options,\n onExitComplete: () => this.safeToRemove(),\n });\n }\n globalProjectionState.hasEverUpdated = true;\n }\n getSnapshotBeforeUpdate(prevProps) {\n const { layoutDependency, visualElement, drag, isPresent } = this.props;\n const { projection } = visualElement;\n if (!projection)\n return null;\n /**\n * TODO: We use this data in relegate to determine whether to\n * promote a previous element. There's no guarantee its presence data\n * will have updated by this point - if a bug like this arises it will\n * have to be that we markForRelegation and then find a new lead some other way,\n * perhaps in didUpdate\n */\n projection.isPresent = isPresent;\n hasTakenAnySnapshot = true;\n if (drag ||\n prevProps.layoutDependency !== layoutDependency ||\n layoutDependency === undefined ||\n prevProps.isPresent !== isPresent) {\n projection.willUpdate();\n }\n else {\n this.safeToRemove();\n }\n if (prevProps.isPresent !== isPresent) {\n if (isPresent) {\n projection.promote();\n }\n else if (!projection.relegate()) {\n /**\n * If there's another stack member taking over from this one,\n * it's in charge of the exit animation and therefore should\n * be in charge of the safe to remove. Otherwise we call it here.\n */\n frame.postRender(() => {\n const stack = projection.getStack();\n if (!stack || !stack.members.length) {\n this.safeToRemove();\n }\n });\n }\n }\n return null;\n }\n componentDidUpdate() {\n const { projection } = this.props.visualElement;\n if (projection) {\n projection.root.didUpdate();\n microtask.postRender(() => {\n if (!projection.currentAnimation && projection.isLead()) {\n this.safeToRemove();\n }\n });\n }\n }\n componentWillUnmount() {\n const { visualElement, layoutGroup, switchLayoutGroup: promoteContext, } = this.props;\n const { projection } = visualElement;\n hasTakenAnySnapshot = true;\n if (projection) {\n projection.scheduleCheckAfterUnmount();\n if (layoutGroup && layoutGroup.group)\n layoutGroup.group.remove(projection);\n if (promoteContext && promoteContext.deregister)\n promoteContext.deregister(projection);\n }\n }\n safeToRemove() {\n const { safeToRemove } = this.props;\n safeToRemove && safeToRemove();\n }\n render() {\n return null;\n }\n}\nfunction MeasureLayout(props) {\n const [isPresent, safeToRemove] = usePresence();\n const layoutGroup = useContext(LayoutGroupContext);\n return (jsx(MeasureLayoutWithContext, { ...props, layoutGroup: layoutGroup, switchLayoutGroup: useContext(SwitchLayoutGroupContext), isPresent: isPresent, safeToRemove: safeToRemove }));\n}\n\nexport { MeasureLayout };\n","/**\n * This should only ever be modified on the client otherwise it'll\n * persist through server requests. If we need instanced states we\n * could lazy-init via root.\n */\nconst globalProjectionState = {\n /**\n * Global flag as to whether the tree has animated since the last time\n * we resized the window\n */\n hasAnimatedSinceResize: true,\n /**\n * We set this to true once, on the first update. Any nodes added to the tree beyond that\n * update will be given a `data-projection-id` attribute.\n */\n hasEverUpdated: false,\n};\n\nexport { globalProjectionState };\n","import { isMotionValue, motionValue } from 'motion-dom';\nimport { animateMotionValue } from '../interfaces/motion-value.mjs';\n\nfunction animateSingleValue(value, keyframes, options) {\n const motionValue$1 = isMotionValue(value) ? value : motionValue(value);\n motionValue$1.start(animateMotionValue(\"\", motionValue$1, keyframes, options));\n return motionValue$1.animation;\n}\n\nexport { animateSingleValue };\n","const compareByDepth = (a, b) => a.depth - b.depth;\n\nexport { compareByDepth };\n","import { addUniqueItem, removeItem } from 'motion-utils';\nimport { compareByDepth } from './compare-by-depth.mjs';\n\nclass FlatTree {\n constructor() {\n this.children = [];\n this.isDirty = false;\n }\n add(child) {\n addUniqueItem(this.children, child);\n this.isDirty = true;\n }\n remove(child) {\n removeItem(this.children, child);\n this.isDirty = true;\n }\n forEach(callback) {\n this.isDirty && this.children.sort(compareByDepth);\n this.isDirty = false;\n this.children.forEach(callback);\n }\n}\n\nexport { FlatTree };\n","import { time, frame, cancelFrame } from 'motion-dom';\nimport { secondsToMilliseconds } from 'motion-utils';\n\n/**\n * Timeout defined in ms\n */\nfunction delay(callback, timeout) {\n const start = time.now();\n const checkElapsed = ({ timestamp }) => {\n const elapsed = timestamp - start;\n if (elapsed >= timeout) {\n cancelFrame(checkElapsed);\n callback(elapsed - timeout);\n }\n };\n frame.setup(checkElapsed, true);\n return () => cancelFrame(checkElapsed);\n}\nfunction delayInSeconds(callback, timeout) {\n return delay(callback, secondsToMilliseconds(timeout));\n}\n\nexport { delay, delayInSeconds };\n","import { mixNumber, percent, px } from 'motion-dom';\nimport { progress, circOut, noop } from 'motion-utils';\n\nconst borders = [\"TopLeft\", \"TopRight\", \"BottomLeft\", \"BottomRight\"];\nconst numBorders = borders.length;\nconst asNumber = (value) => typeof value === \"string\" ? parseFloat(value) : value;\nconst isPx = (value) => typeof value === \"number\" || px.test(value);\nfunction mixValues(target, follow, lead, progress, shouldCrossfadeOpacity, isOnlyMember) {\n if (shouldCrossfadeOpacity) {\n target.opacity = mixNumber(0, lead.opacity ?? 1, easeCrossfadeIn(progress));\n target.opacityExit = mixNumber(follow.opacity ?? 1, 0, easeCrossfadeOut(progress));\n }\n else if (isOnlyMember) {\n target.opacity = mixNumber(follow.opacity ?? 1, lead.opacity ?? 1, progress);\n }\n /**\n * Mix border radius\n */\n for (let i = 0; i < numBorders; i++) {\n const borderLabel = `border${borders[i]}Radius`;\n let followRadius = getRadius(follow, borderLabel);\n let leadRadius = getRadius(lead, borderLabel);\n if (followRadius === undefined && leadRadius === undefined)\n continue;\n followRadius || (followRadius = 0);\n leadRadius || (leadRadius = 0);\n const canMix = followRadius === 0 ||\n leadRadius === 0 ||\n isPx(followRadius) === isPx(leadRadius);\n if (canMix) {\n target[borderLabel] = Math.max(mixNumber(asNumber(followRadius), asNumber(leadRadius), progress), 0);\n if (percent.test(leadRadius) || percent.test(followRadius)) {\n target[borderLabel] += \"%\";\n }\n }\n else {\n target[borderLabel] = leadRadius;\n }\n }\n /**\n * Mix rotation\n */\n if (follow.rotate || lead.rotate) {\n target.rotate = mixNumber(follow.rotate || 0, lead.rotate || 0, progress);\n }\n}\nfunction getRadius(values, radiusName) {\n return values[radiusName] !== undefined\n ? values[radiusName]\n : values.borderRadius;\n}\n// /**\n// * We only want to mix the background color if there's a follow element\n// * that we're not crossfading opacity between. For instance with switch\n// * AnimateSharedLayout animations, this helps the illusion of a continuous\n// * element being animated but also cuts down on the number of paints triggered\n// * for elements where opacity is doing that work for us.\n// */\n// if (\n// !hasFollowElement &&\n// latestLeadValues.backgroundColor &&\n// latestFollowValues.backgroundColor\n// ) {\n// /**\n// * This isn't ideal performance-wise as mixColor is creating a new function every frame.\n// * We could probably create a mixer that runs at the start of the animation but\n// * the idea behind the crossfader is that it runs dynamically between two potentially\n// * changing targets (ie opacity or borderRadius may be animating independently via variants)\n// */\n// leadState.backgroundColor = followState.backgroundColor = mixColor(\n// latestFollowValues.backgroundColor as string,\n// latestLeadValues.backgroundColor as string\n// )(p)\n// }\nconst easeCrossfadeIn = /*@__PURE__*/ compress(0, 0.5, circOut);\nconst easeCrossfadeOut = /*@__PURE__*/ compress(0.5, 0.95, noop);\nfunction compress(min, max, easing) {\n return (p) => {\n // Could replace ifs with clamp\n if (p < min)\n return 0;\n if (p > max)\n return 1;\n return easing(progress(min, max, p));\n };\n}\n\nexport { mixValues };\n","/**\n * Reset an axis to the provided origin box.\n *\n * This is a mutative operation.\n */\nfunction copyAxisInto(axis, originAxis) {\n axis.min = originAxis.min;\n axis.max = originAxis.max;\n}\n/**\n * Reset a box to the provided origin box.\n *\n * This is a mutative operation.\n */\nfunction copyBoxInto(box, originBox) {\n copyAxisInto(box.x, originBox.x);\n copyAxisInto(box.y, originBox.y);\n}\n/**\n * Reset a delta to the provided origin box.\n *\n * This is a mutative operation.\n */\nfunction copyAxisDeltaInto(delta, originDelta) {\n delta.translate = originDelta.translate;\n delta.scale = originDelta.scale;\n delta.originPoint = originDelta.originPoint;\n delta.origin = originDelta.origin;\n}\n\nexport { copyAxisDeltaInto, copyAxisInto, copyBoxInto };\n","import { percent, mixNumber } from 'motion-dom';\nimport { scalePoint } from './delta-apply.mjs';\n\n/**\n * Remove a delta from a point. This is essentially the steps of applyPointDelta in reverse\n */\nfunction removePointDelta(point, translate, scale, originPoint, boxScale) {\n point -= translate;\n point = scalePoint(point, 1 / scale, originPoint);\n if (boxScale !== undefined) {\n point = scalePoint(point, 1 / boxScale, originPoint);\n }\n return point;\n}\n/**\n * Remove a delta from an axis. This is essentially the steps of applyAxisDelta in reverse\n */\nfunction removeAxisDelta(axis, translate = 0, scale = 1, origin = 0.5, boxScale, originAxis = axis, sourceAxis = axis) {\n if (percent.test(translate)) {\n translate = parseFloat(translate);\n const relativeProgress = mixNumber(sourceAxis.min, sourceAxis.max, translate / 100);\n translate = relativeProgress - sourceAxis.min;\n }\n if (typeof translate !== \"number\")\n return;\n let originPoint = mixNumber(originAxis.min, originAxis.max, origin);\n if (axis === originAxis)\n originPoint -= translate;\n axis.min = removePointDelta(axis.min, translate, scale, originPoint, boxScale);\n axis.max = removePointDelta(axis.max, translate, scale, originPoint, boxScale);\n}\n/**\n * Remove a transforms from an axis. This is essentially the steps of applyAxisTransforms in reverse\n * and acts as a bridge between motion values and removeAxisDelta\n */\nfunction removeAxisTransforms(axis, transforms, [key, scaleKey, originKey], origin, sourceAxis) {\n removeAxisDelta(axis, transforms[key], transforms[scaleKey], transforms[originKey], transforms.scale, origin, sourceAxis);\n}\n/**\n * The names of the motion values we want to apply as translation, scale and origin.\n */\nconst xKeys = [\"x\", \"scaleX\", \"originX\"];\nconst yKeys = [\"y\", \"scaleY\", \"originY\"];\n/**\n * Remove a transforms from an box. This is essentially the steps of applyAxisBox in reverse\n * and acts as a bridge between motion values and removeAxisDelta\n */\nfunction removeBoxTransforms(box, transforms, originBox, sourceBox) {\n removeAxisTransforms(box.x, transforms, xKeys, originBox ? originBox.x : undefined, sourceBox ? sourceBox.x : undefined);\n removeAxisTransforms(box.y, transforms, yKeys, originBox ? originBox.y : undefined, sourceBox ? sourceBox.y : undefined);\n}\n\nexport { removeAxisDelta, removeAxisTransforms, removeBoxTransforms, removePointDelta };\n","import { calcLength } from './delta-calc.mjs';\n\nfunction isAxisDeltaZero(delta) {\n return delta.translate === 0 && delta.scale === 1;\n}\nfunction isDeltaZero(delta) {\n return isAxisDeltaZero(delta.x) && isAxisDeltaZero(delta.y);\n}\nfunction axisEquals(a, b) {\n return a.min === b.min && a.max === b.max;\n}\nfunction boxEquals(a, b) {\n return axisEquals(a.x, b.x) && axisEquals(a.y, b.y);\n}\nfunction axisEqualsRounded(a, b) {\n return (Math.round(a.min) === Math.round(b.min) &&\n Math.round(a.max) === Math.round(b.max));\n}\nfunction boxEqualsRounded(a, b) {\n return axisEqualsRounded(a.x, b.x) && axisEqualsRounded(a.y, b.y);\n}\nfunction aspectRatio(box) {\n return calcLength(box.x) / calcLength(box.y);\n}\nfunction axisDeltaEquals(a, b) {\n return (a.translate === b.translate &&\n a.scale === b.scale &&\n a.originPoint === b.originPoint);\n}\n\nexport { aspectRatio, axisDeltaEquals, axisEquals, axisEqualsRounded, boxEquals, boxEqualsRounded, isDeltaZero };\n","import { addUniqueItem, removeItem } from 'motion-utils';\n\nclass NodeStack {\n constructor() {\n this.members = [];\n }\n add(node) {\n addUniqueItem(this.members, node);\n node.scheduleRender();\n }\n remove(node) {\n removeItem(this.members, node);\n if (node === this.prevLead) {\n this.prevLead = undefined;\n }\n if (node === this.lead) {\n const prevLead = this.members[this.members.length - 1];\n if (prevLead) {\n this.promote(prevLead);\n }\n }\n }\n relegate(node) {\n const indexOfNode = this.members.findIndex((member) => node === member);\n if (indexOfNode === 0)\n return false;\n /**\n * Find the next projection node that is present\n */\n let prevLead;\n for (let i = indexOfNode; i >= 0; i--) {\n const member = this.members[i];\n if (member.isPresent !== false) {\n prevLead = member;\n break;\n }\n }\n if (prevLead) {\n this.promote(prevLead);\n return true;\n }\n else {\n return false;\n }\n }\n promote(node, preserveFollowOpacity) {\n const prevLead = this.lead;\n if (node === prevLead)\n return;\n this.prevLead = prevLead;\n this.lead = node;\n node.show();\n if (prevLead) {\n prevLead.instance && prevLead.scheduleRender();\n node.scheduleRender();\n node.resumeFrom = prevLead;\n if (preserveFollowOpacity) {\n node.resumeFrom.preserveOpacity = true;\n }\n if (prevLead.snapshot) {\n node.snapshot = prevLead.snapshot;\n node.snapshot.latestValues =\n prevLead.animationValues || prevLead.latestValues;\n }\n if (node.root && node.root.isUpdating) {\n node.isLayoutDirty = true;\n }\n const { crossfade } = node.options;\n if (crossfade === false) {\n prevLead.hide();\n }\n /**\n * TODO:\n * - Test border radius when previous node was deleted\n * - boxShadow mixing\n * - Shared between element A in scrolled container and element B (scroll stays the same or changes)\n * - Shared between element A in transformed container and element B (transform stays the same or changes)\n * - Shared between element A in scrolled page and element B (scroll stays the same or changes)\n * ---\n * - Crossfade opacity of root nodes\n * - layoutId changes after animation\n * - layoutId changes mid animation\n */\n }\n }\n exitAnimationComplete() {\n this.members.forEach((node) => {\n const { options, resumingFrom } = node;\n options.onExitComplete && options.onExitComplete();\n if (resumingFrom) {\n resumingFrom.options.onExitComplete &&\n resumingFrom.options.onExitComplete();\n }\n });\n }\n scheduleRender() {\n this.members.forEach((node) => {\n node.instance && node.scheduleRender(false);\n });\n }\n /**\n * Clear any leads that have been removed this render to prevent them from being\n * used in future animations and to prevent memory leaks\n */\n removeLeadSnapshot() {\n if (this.lead && this.lead.snapshot) {\n this.lead.snapshot = undefined;\n }\n }\n}\n\nexport { NodeStack };\n","function buildProjectionTransform(delta, treeScale, latestTransform) {\n let transform = \"\";\n /**\n * The translations we use to calculate are always relative to the viewport coordinate space.\n * But when we apply scales, we also scale the coordinate space of an element and its children.\n * For instance if we have a treeScale (the culmination of all parent scales) of 0.5 and we need\n * to move an element 100 pixels, we actually need to move it 200 in within that scaled space.\n */\n const xTranslate = delta.x.translate / treeScale.x;\n const yTranslate = delta.y.translate / treeScale.y;\n const zTranslate = latestTransform?.z || 0;\n if (xTranslate || yTranslate || zTranslate) {\n transform = `translate3d(${xTranslate}px, ${yTranslate}px, ${zTranslate}px) `;\n }\n /**\n * Apply scale correction for the tree transform.\n * This will apply scale to the screen-orientated axes.\n */\n if (treeScale.x !== 1 || treeScale.y !== 1) {\n transform += `scale(${1 / treeScale.x}, ${1 / treeScale.y}) `;\n }\n if (latestTransform) {\n const { transformPerspective, rotate, rotateX, rotateY, skewX, skewY } = latestTransform;\n if (transformPerspective)\n transform = `perspective(${transformPerspective}px) ${transform}`;\n if (rotate)\n transform += `rotate(${rotate}deg) `;\n if (rotateX)\n transform += `rotateX(${rotateX}deg) `;\n if (rotateY)\n transform += `rotateY(${rotateY}deg) `;\n if (skewX)\n transform += `skewX(${skewX}deg) `;\n if (skewY)\n transform += `skewY(${skewY}deg) `;\n }\n /**\n * Apply scale to match the size of the element to the size we want it.\n * This will apply scale to the element-orientated axes.\n */\n const elementScaleX = delta.x.scale * treeScale.x;\n const elementScaleY = delta.y.scale * treeScale.y;\n if (elementScaleX !== 1 || elementScaleY !== 1) {\n transform += `scale(${elementScaleX}, ${elementScaleY})`;\n }\n return transform || \"none\";\n}\n\nexport { buildProjectionTransform };\n","import { statsBuffer, isSVGElement, isSVGSVGElement, frame, getValueTransition, cancelFrame, time, frameData, frameSteps, microtask, activeAnimations, motionValue, mixNumber } from 'motion-dom';\nimport { SubscriptionManager, clamp, noop } from 'motion-utils';\nimport { animateSingleValue } from '../../animation/animate/single-value.mjs';\nimport { getOptimisedAppearId } from '../../animation/optimized-appear/get-appear-id.mjs';\nimport { FlatTree } from '../../render/utils/flat-tree.mjs';\nimport { delay } from '../../utils/delay.mjs';\nimport { resolveMotionValue } from '../../value/utils/resolve-motion-value.mjs';\nimport { mixValues } from '../animation/mix-values.mjs';\nimport { copyBoxInto, copyAxisDeltaInto } from '../geometry/copy.mjs';\nimport { translateAxis, transformBox, applyBoxDelta, applyTreeDeltas } from '../geometry/delta-apply.mjs';\nimport { calcLength, calcRelativeBox, calcRelativePosition, calcBoxDelta, isNear } from '../geometry/delta-calc.mjs';\nimport { removeBoxTransforms } from '../geometry/delta-remove.mjs';\nimport { createBox, createDelta } from '../geometry/models.mjs';\nimport { boxEqualsRounded, isDeltaZero, axisDeltaEquals, aspectRatio, boxEquals } from '../geometry/utils.mjs';\nimport { NodeStack } from '../shared/stack.mjs';\nimport { scaleCorrectors } from '../styles/scale-correction.mjs';\nimport { buildProjectionTransform } from '../styles/transform.mjs';\nimport { eachAxis } from '../utils/each-axis.mjs';\nimport { hasTransform, hasScale, has2DTranslate } from '../utils/has-transform.mjs';\nimport { globalProjectionState } from './state.mjs';\n\nconst metrics = {\n nodes: 0,\n calculatedTargetDeltas: 0,\n calculatedProjections: 0,\n};\nconst transformAxes = [\"\", \"X\", \"Y\", \"Z\"];\n/**\n * We use 1000 as the animation target as 0-1000 maps better to pixels than 0-1\n * which has a noticeable difference in spring animations\n */\nconst animationTarget = 1000;\nlet id = 0;\nfunction resetDistortingTransform(key, visualElement, values, sharedAnimationValues) {\n const { latestValues } = visualElement;\n // Record the distorting transform and then temporarily set it to 0\n if (latestValues[key]) {\n values[key] = latestValues[key];\n visualElement.setStaticValue(key, 0);\n if (sharedAnimationValues) {\n sharedAnimationValues[key] = 0;\n }\n }\n}\nfunction cancelTreeOptimisedTransformAnimations(projectionNode) {\n projectionNode.hasCheckedOptimisedAppear = true;\n if (projectionNode.root === projectionNode)\n return;\n const { visualElement } = projectionNode.options;\n if (!visualElement)\n return;\n const appearId = getOptimisedAppearId(visualElement);\n if (window.MotionHasOptimisedAnimation(appearId, \"transform\")) {\n const { layout, layoutId } = projectionNode.options;\n window.MotionCancelOptimisedAnimation(appearId, \"transform\", frame, !(layout || layoutId));\n }\n const { parent } = projectionNode;\n if (parent && !parent.hasCheckedOptimisedAppear) {\n cancelTreeOptimisedTransformAnimations(parent);\n }\n}\nfunction createProjectionNode({ attachResizeListener, defaultParent, measureScroll, checkIsScrollRoot, resetTransform, }) {\n return class ProjectionNode {\n constructor(latestValues = {}, parent = defaultParent?.()) {\n /**\n * A unique ID generated for every projection node.\n */\n this.id = id++;\n /**\n * An id that represents a unique session instigated by startUpdate.\n */\n this.animationId = 0;\n this.animationCommitId = 0;\n /**\n * A Set containing all this component's children. This is used to iterate\n * through the children.\n *\n * TODO: This could be faster to iterate as a flat array stored on the root node.\n */\n this.children = new Set();\n /**\n * Options for the node. We use this to configure what kind of layout animations\n * we should perform (if any).\n */\n this.options = {};\n /**\n * We use this to detect when its safe to shut down part of a projection tree.\n * We have to keep projecting children for scale correction and relative projection\n * until all their parents stop performing layout animations.\n */\n this.isTreeAnimating = false;\n this.isAnimationBlocked = false;\n /**\n * Flag to true if we think this layout has been changed. We can't always know this,\n * currently we set it to true every time a component renders, or if it has a layoutDependency\n * if that has changed between renders. Additionally, components can be grouped by LayoutGroup\n * and if one node is dirtied, they all are.\n */\n this.isLayoutDirty = false;\n /**\n * Flag to true if we think the projection calculations for this node needs\n * recalculating as a result of an updated transform or layout animation.\n */\n this.isProjectionDirty = false;\n /**\n * Flag to true if the layout *or* transform has changed. This then gets propagated\n * throughout the projection tree, forcing any element below to recalculate on the next frame.\n */\n this.isSharedProjectionDirty = false;\n /**\n * Flag transform dirty. This gets propagated throughout the whole tree but is only\n * respected by shared nodes.\n */\n this.isTransformDirty = false;\n /**\n * Block layout updates for instant layout transitions throughout the tree.\n */\n this.updateManuallyBlocked = false;\n this.updateBlockedByResize = false;\n /**\n * Set to true between the start of the first `willUpdate` call and the end of the `didUpdate`\n * call.\n */\n this.isUpdating = false;\n /**\n * If this is an SVG element we currently disable projection transforms\n */\n this.isSVG = false;\n /**\n * Flag to true (during promotion) if a node doing an instant layout transition needs to reset\n * its projection styles.\n */\n this.needsReset = false;\n /**\n * Flags whether this node should have its transform reset prior to measuring.\n */\n this.shouldResetTransform = false;\n /**\n * Store whether this node has been checked for optimised appear animations. As\n * effects fire bottom-up, and we want to look up the tree for appear animations,\n * this makes sure we only check each path once, stopping at nodes that\n * have already been checked.\n */\n this.hasCheckedOptimisedAppear = false;\n /**\n * An object representing the calculated contextual/accumulated/tree scale.\n * This will be used to scale calculcated projection transforms, as these are\n * calculated in screen-space but need to be scaled for elements to layoutly\n * make it to their calculated destinations.\n *\n * TODO: Lazy-init\n */\n this.treeScale = { x: 1, y: 1 };\n /**\n *\n */\n this.eventHandlers = new Map();\n this.hasTreeAnimated = false;\n this.layoutVersion = 0;\n // Note: Currently only running on root node\n this.updateScheduled = false;\n this.scheduleUpdate = () => this.update();\n this.projectionUpdateScheduled = false;\n this.checkUpdateFailed = () => {\n if (this.isUpdating) {\n this.isUpdating = false;\n this.clearAllSnapshots();\n }\n };\n /**\n * This is a multi-step process as shared nodes might be of different depths. Nodes\n * are sorted by depth order, so we need to resolve the entire tree before moving to\n * the next step.\n */\n this.updateProjection = () => {\n this.projectionUpdateScheduled = false;\n /**\n * Reset debug counts. Manually resetting rather than creating a new\n * object each frame.\n */\n if (statsBuffer.value) {\n metrics.nodes =\n metrics.calculatedTargetDeltas =\n metrics.calculatedProjections =\n 0;\n }\n this.nodes.forEach(propagateDirtyNodes);\n this.nodes.forEach(resolveTargetDelta);\n this.nodes.forEach(calcProjection);\n this.nodes.forEach(cleanDirtyNodes);\n if (statsBuffer.addProjectionMetrics) {\n statsBuffer.addProjectionMetrics(metrics);\n }\n };\n /**\n * Frame calculations\n */\n this.resolvedRelativeTargetAt = 0.0;\n this.linkedParentVersion = 0;\n this.hasProjected = false;\n this.isVisible = true;\n this.animationProgress = 0;\n /**\n * Shared layout\n */\n // TODO Only running on root node\n this.sharedNodes = new Map();\n this.latestValues = latestValues;\n this.root = parent ? parent.root || parent : this;\n this.path = parent ? [...parent.path, parent] : [];\n this.parent = parent;\n this.depth = parent ? parent.depth + 1 : 0;\n for (let i = 0; i < this.path.length; i++) {\n this.path[i].shouldResetTransform = true;\n }\n if (this.root === this)\n this.nodes = new FlatTree();\n }\n addEventListener(name, handler) {\n if (!this.eventHandlers.has(name)) {\n this.eventHandlers.set(name, new SubscriptionManager());\n }\n return this.eventHandlers.get(name).add(handler);\n }\n notifyListeners(name, ...args) {\n const subscriptionManager = this.eventHandlers.get(name);\n subscriptionManager && subscriptionManager.notify(...args);\n }\n hasListeners(name) {\n return this.eventHandlers.has(name);\n }\n /**\n * Lifecycles\n */\n mount(instance) {\n if (this.instance)\n return;\n this.isSVG = isSVGElement(instance) && !isSVGSVGElement(instance);\n this.instance = instance;\n const { layoutId, layout, visualElement } = this.options;\n if (visualElement && !visualElement.current) {\n visualElement.mount(instance);\n }\n this.root.nodes.add(this);\n this.parent && this.parent.children.add(this);\n if (this.root.hasTreeAnimated && (layout || layoutId)) {\n this.isLayoutDirty = true;\n }\n if (attachResizeListener) {\n let cancelDelay;\n let innerWidth = 0;\n const resizeUnblockUpdate = () => (this.root.updateBlockedByResize = false);\n // Set initial innerWidth in a frame.read callback to batch the read\n frame.read(() => {\n innerWidth = window.innerWidth;\n });\n attachResizeListener(instance, () => {\n const newInnerWidth = window.innerWidth;\n if (newInnerWidth === innerWidth)\n return;\n innerWidth = newInnerWidth;\n this.root.updateBlockedByResize = true;\n cancelDelay && cancelDelay();\n cancelDelay = delay(resizeUnblockUpdate, 250);\n if (globalProjectionState.hasAnimatedSinceResize) {\n globalProjectionState.hasAnimatedSinceResize = false;\n this.nodes.forEach(finishAnimation);\n }\n });\n }\n if (layoutId) {\n this.root.registerSharedNode(layoutId, this);\n }\n // Only register the handler if it requires layout animation\n if (this.options.animate !== false &&\n visualElement &&\n (layoutId || layout)) {\n this.addEventListener(\"didUpdate\", ({ delta, hasLayoutChanged, hasRelativeLayoutChanged, layout: newLayout, }) => {\n if (this.isTreeAnimationBlocked()) {\n this.target = undefined;\n this.relativeTarget = undefined;\n return;\n }\n // TODO: Check here if an animation exists\n const layoutTransition = this.options.transition ||\n visualElement.getDefaultTransition() ||\n defaultLayoutTransition;\n const { onLayoutAnimationStart, onLayoutAnimationComplete, } = visualElement.getProps();\n /**\n * The target layout of the element might stay the same,\n * but its position relative to its parent has changed.\n */\n const hasTargetChanged = !this.targetLayout ||\n !boxEqualsRounded(this.targetLayout, newLayout);\n /*\n * Note: Disabled to fix relative animations always triggering new\n * layout animations. If this causes further issues, we can try\n * a different approach to detecting relative target changes.\n */\n // || hasRelativeLayoutChanged\n /**\n * If the layout hasn't seemed to have changed, it might be that the\n * element is visually in the same place in the document but its position\n * relative to its parent has indeed changed. So here we check for that.\n */\n const hasOnlyRelativeTargetChanged = !hasLayoutChanged && hasRelativeLayoutChanged;\n if (this.options.layoutRoot ||\n this.resumeFrom ||\n hasOnlyRelativeTargetChanged ||\n (hasLayoutChanged &&\n (hasTargetChanged || !this.currentAnimation))) {\n if (this.resumeFrom) {\n this.resumingFrom = this.resumeFrom;\n this.resumingFrom.resumingFrom = undefined;\n }\n const animationOptions = {\n ...getValueTransition(layoutTransition, \"layout\"),\n onPlay: onLayoutAnimationStart,\n onComplete: onLayoutAnimationComplete,\n };\n if (visualElement.shouldReduceMotion ||\n this.options.layoutRoot) {\n animationOptions.delay = 0;\n animationOptions.type = false;\n }\n this.startAnimation(animationOptions);\n /**\n * Set animation origin after starting animation to avoid layout jump\n * caused by stopping previous layout animation\n */\n this.setAnimationOrigin(delta, hasOnlyRelativeTargetChanged);\n }\n else {\n /**\n * If the layout hasn't changed and we have an animation that hasn't started yet,\n * finish it immediately. Otherwise it will be animating from a location\n * that was probably never commited to screen and look like a jumpy box.\n */\n if (!hasLayoutChanged) {\n finishAnimation(this);\n }\n if (this.isLead() && this.options.onExitComplete) {\n this.options.onExitComplete();\n }\n }\n this.targetLayout = newLayout;\n });\n }\n }\n unmount() {\n this.options.layoutId && this.willUpdate();\n this.root.nodes.remove(this);\n const stack = this.getStack();\n stack && stack.remove(this);\n this.parent && this.parent.children.delete(this);\n this.instance = undefined;\n this.eventHandlers.clear();\n cancelFrame(this.updateProjection);\n }\n // only on the root\n blockUpdate() {\n this.updateManuallyBlocked = true;\n }\n unblockUpdate() {\n this.updateManuallyBlocked = false;\n }\n isUpdateBlocked() {\n return this.updateManuallyBlocked || this.updateBlockedByResize;\n }\n isTreeAnimationBlocked() {\n return (this.isAnimationBlocked ||\n (this.parent && this.parent.isTreeAnimationBlocked()) ||\n false);\n }\n // Note: currently only running on root node\n startUpdate() {\n if (this.isUpdateBlocked())\n return;\n this.isUpdating = true;\n this.nodes && this.nodes.forEach(resetSkewAndRotation);\n this.animationId++;\n }\n getTransformTemplate() {\n const { visualElement } = this.options;\n return visualElement && visualElement.getProps().transformTemplate;\n }\n willUpdate(shouldNotifyListeners = true) {\n this.root.hasTreeAnimated = true;\n if (this.root.isUpdateBlocked()) {\n this.options.onExitComplete && this.options.onExitComplete();\n return;\n }\n /**\n * If we're running optimised appear animations then these must be\n * cancelled before measuring the DOM. This is so we can measure\n * the true layout of the element rather than the WAAPI animation\n * which will be unaffected by the resetSkewAndRotate step.\n *\n * Note: This is a DOM write. Worst case scenario is this is sandwiched\n * between other snapshot reads which will cause unnecessary style recalculations.\n * This has to happen here though, as we don't yet know which nodes will need\n * snapshots in startUpdate(), but we only want to cancel optimised animations\n * if a layout animation measurement is actually going to be affected by them.\n */\n if (window.MotionCancelOptimisedAnimation &&\n !this.hasCheckedOptimisedAppear) {\n cancelTreeOptimisedTransformAnimations(this);\n }\n !this.root.isUpdating && this.root.startUpdate();\n if (this.isLayoutDirty)\n return;\n this.isLayoutDirty = true;\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n node.shouldResetTransform = true;\n node.updateScroll(\"snapshot\");\n if (node.options.layoutRoot) {\n node.willUpdate(false);\n }\n }\n const { layoutId, layout } = this.options;\n if (layoutId === undefined && !layout)\n return;\n const transformTemplate = this.getTransformTemplate();\n this.prevTransformTemplateValue = transformTemplate\n ? transformTemplate(this.latestValues, \"\")\n : undefined;\n this.updateSnapshot();\n shouldNotifyListeners && this.notifyListeners(\"willUpdate\");\n }\n update() {\n this.updateScheduled = false;\n const updateWasBlocked = this.isUpdateBlocked();\n // When doing an instant transition, we skip the layout update,\n // but should still clean up the measurements so that the next\n // snapshot could be taken correctly.\n if (updateWasBlocked) {\n this.unblockUpdate();\n this.clearAllSnapshots();\n this.nodes.forEach(clearMeasurements);\n return;\n }\n /**\n * If this is a repeat of didUpdate then ignore the animation.\n */\n if (this.animationId <= this.animationCommitId) {\n this.nodes.forEach(clearIsLayoutDirty);\n return;\n }\n this.animationCommitId = this.animationId;\n if (!this.isUpdating) {\n this.nodes.forEach(clearIsLayoutDirty);\n }\n else {\n this.isUpdating = false;\n /**\n * Write\n */\n this.nodes.forEach(resetTransformStyle);\n /**\n * Read ==================\n */\n // Update layout measurements of updated children\n this.nodes.forEach(updateLayout);\n /**\n * Write\n */\n // Notify listeners that the layout is updated\n this.nodes.forEach(notifyLayoutUpdate);\n }\n this.clearAllSnapshots();\n /**\n * Manually flush any pending updates. Ideally\n * we could leave this to the following requestAnimationFrame but this seems\n * to leave a flash of incorrectly styled content.\n */\n const now = time.now();\n frameData.delta = clamp(0, 1000 / 60, now - frameData.timestamp);\n frameData.timestamp = now;\n frameData.isProcessing = true;\n frameSteps.update.process(frameData);\n frameSteps.preRender.process(frameData);\n frameSteps.render.process(frameData);\n frameData.isProcessing = false;\n }\n didUpdate() {\n if (!this.updateScheduled) {\n this.updateScheduled = true;\n microtask.read(this.scheduleUpdate);\n }\n }\n clearAllSnapshots() {\n this.nodes.forEach(clearSnapshot);\n this.sharedNodes.forEach(removeLeadSnapshots);\n }\n scheduleUpdateProjection() {\n if (!this.projectionUpdateScheduled) {\n this.projectionUpdateScheduled = true;\n frame.preRender(this.updateProjection, false, true);\n }\n }\n scheduleCheckAfterUnmount() {\n /**\n * If the unmounting node is in a layoutGroup and did trigger a willUpdate,\n * we manually call didUpdate to give a chance to the siblings to animate.\n * Otherwise, cleanup all snapshots to prevents future nodes from reusing them.\n */\n frame.postRender(() => {\n if (this.isLayoutDirty) {\n this.root.didUpdate();\n }\n else {\n this.root.checkUpdateFailed();\n }\n });\n }\n /**\n * Update measurements\n */\n updateSnapshot() {\n if (this.snapshot || !this.instance)\n return;\n this.snapshot = this.measure();\n if (this.snapshot &&\n !calcLength(this.snapshot.measuredBox.x) &&\n !calcLength(this.snapshot.measuredBox.y)) {\n this.snapshot = undefined;\n }\n }\n updateLayout() {\n if (!this.instance)\n return;\n this.updateScroll();\n if (!(this.options.alwaysMeasureLayout && this.isLead()) &&\n !this.isLayoutDirty) {\n return;\n }\n /**\n * When a node is mounted, it simply resumes from the prevLead's\n * snapshot instead of taking a new one, but the ancestors scroll\n * might have updated while the prevLead is unmounted. We need to\n * update the scroll again to make sure the layout we measure is\n * up to date.\n */\n if (this.resumeFrom && !this.resumeFrom.instance) {\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n node.updateScroll();\n }\n }\n const prevLayout = this.layout;\n this.layout = this.measure(false);\n this.layoutVersion++;\n this.layoutCorrected = createBox();\n this.isLayoutDirty = false;\n this.projectionDelta = undefined;\n this.notifyListeners(\"measure\", this.layout.layoutBox);\n const { visualElement } = this.options;\n visualElement &&\n visualElement.notify(\"LayoutMeasure\", this.layout.layoutBox, prevLayout ? prevLayout.layoutBox : undefined);\n }\n updateScroll(phase = \"measure\") {\n let needsMeasurement = Boolean(this.options.layoutScroll && this.instance);\n if (this.scroll &&\n this.scroll.animationId === this.root.animationId &&\n this.scroll.phase === phase) {\n needsMeasurement = false;\n }\n if (needsMeasurement && this.instance) {\n const isRoot = checkIsScrollRoot(this.instance);\n this.scroll = {\n animationId: this.root.animationId,\n phase,\n isRoot,\n offset: measureScroll(this.instance),\n wasRoot: this.scroll ? this.scroll.isRoot : isRoot,\n };\n }\n }\n resetTransform() {\n if (!resetTransform)\n return;\n const isResetRequested = this.isLayoutDirty ||\n this.shouldResetTransform ||\n this.options.alwaysMeasureLayout;\n const hasProjection = this.projectionDelta && !isDeltaZero(this.projectionDelta);\n const transformTemplate = this.getTransformTemplate();\n const transformTemplateValue = transformTemplate\n ? transformTemplate(this.latestValues, \"\")\n : undefined;\n const transformTemplateHasChanged = transformTemplateValue !== this.prevTransformTemplateValue;\n if (isResetRequested &&\n this.instance &&\n (hasProjection ||\n hasTransform(this.latestValues) ||\n transformTemplateHasChanged)) {\n resetTransform(this.instance, transformTemplateValue);\n this.shouldResetTransform = false;\n this.scheduleRender();\n }\n }\n measure(removeTransform = true) {\n const pageBox = this.measurePageBox();\n let layoutBox = this.removeElementScroll(pageBox);\n /**\n * Measurements taken during the pre-render stage\n * still have transforms applied so we remove them\n * via calculation.\n */\n if (removeTransform) {\n layoutBox = this.removeTransform(layoutBox);\n }\n roundBox(layoutBox);\n return {\n animationId: this.root.animationId,\n measuredBox: pageBox,\n layoutBox,\n latestValues: {},\n source: this.id,\n };\n }\n measurePageBox() {\n const { visualElement } = this.options;\n if (!visualElement)\n return createBox();\n const box = visualElement.measureViewportBox();\n const wasInScrollRoot = this.scroll?.wasRoot || this.path.some(checkNodeWasScrollRoot);\n if (!wasInScrollRoot) {\n // Remove viewport scroll to give page-relative coordinates\n const { scroll } = this.root;\n if (scroll) {\n translateAxis(box.x, scroll.offset.x);\n translateAxis(box.y, scroll.offset.y);\n }\n }\n return box;\n }\n removeElementScroll(box) {\n const boxWithoutScroll = createBox();\n copyBoxInto(boxWithoutScroll, box);\n if (this.scroll?.wasRoot) {\n return boxWithoutScroll;\n }\n /**\n * Performance TODO: Keep a cumulative scroll offset down the tree\n * rather than loop back up the path.\n */\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n const { scroll, options } = node;\n if (node !== this.root && scroll && options.layoutScroll) {\n /**\n * If this is a new scroll root, we want to remove all previous scrolls\n * from the viewport box.\n */\n if (scroll.wasRoot) {\n copyBoxInto(boxWithoutScroll, box);\n }\n translateAxis(boxWithoutScroll.x, scroll.offset.x);\n translateAxis(boxWithoutScroll.y, scroll.offset.y);\n }\n }\n return boxWithoutScroll;\n }\n applyTransform(box, transformOnly = false) {\n const withTransforms = createBox();\n copyBoxInto(withTransforms, box);\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n if (!transformOnly &&\n node.options.layoutScroll &&\n node.scroll &&\n node !== node.root) {\n transformBox(withTransforms, {\n x: -node.scroll.offset.x,\n y: -node.scroll.offset.y,\n });\n }\n if (!hasTransform(node.latestValues))\n continue;\n transformBox(withTransforms, node.latestValues);\n }\n if (hasTransform(this.latestValues)) {\n transformBox(withTransforms, this.latestValues);\n }\n return withTransforms;\n }\n removeTransform(box) {\n const boxWithoutTransform = createBox();\n copyBoxInto(boxWithoutTransform, box);\n for (let i = 0; i < this.path.length; i++) {\n const node = this.path[i];\n if (!node.instance)\n continue;\n if (!hasTransform(node.latestValues))\n continue;\n hasScale(node.latestValues) && node.updateSnapshot();\n const sourceBox = createBox();\n const nodeBox = node.measurePageBox();\n copyBoxInto(sourceBox, nodeBox);\n removeBoxTransforms(boxWithoutTransform, node.latestValues, node.snapshot ? node.snapshot.layoutBox : undefined, sourceBox);\n }\n if (hasTransform(this.latestValues)) {\n removeBoxTransforms(boxWithoutTransform, this.latestValues);\n }\n return boxWithoutTransform;\n }\n setTargetDelta(delta) {\n this.targetDelta = delta;\n this.root.scheduleUpdateProjection();\n this.isProjectionDirty = true;\n }\n setOptions(options) {\n this.options = {\n ...this.options,\n ...options,\n crossfade: options.crossfade !== undefined ? options.crossfade : true,\n };\n }\n clearMeasurements() {\n this.scroll = undefined;\n this.layout = undefined;\n this.snapshot = undefined;\n this.prevTransformTemplateValue = undefined;\n this.targetDelta = undefined;\n this.target = undefined;\n this.isLayoutDirty = false;\n }\n forceRelativeParentToResolveTarget() {\n if (!this.relativeParent)\n return;\n /**\n * If the parent target isn't up-to-date, force it to update.\n * This is an unfortunate de-optimisation as it means any updating relative\n * projection will cause all the relative parents to recalculate back\n * up the tree.\n */\n if (this.relativeParent.resolvedRelativeTargetAt !==\n frameData.timestamp) {\n this.relativeParent.resolveTargetDelta(true);\n }\n }\n resolveTargetDelta(forceRecalculation = false) {\n /**\n * Once the dirty status of nodes has been spread through the tree, we also\n * need to check if we have a shared node of a different depth that has itself\n * been dirtied.\n */\n const lead = this.getLead();\n this.isProjectionDirty || (this.isProjectionDirty = lead.isProjectionDirty);\n this.isTransformDirty || (this.isTransformDirty = lead.isTransformDirty);\n this.isSharedProjectionDirty || (this.isSharedProjectionDirty = lead.isSharedProjectionDirty);\n const isShared = Boolean(this.resumingFrom) || this !== lead;\n /**\n * We don't use transform for this step of processing so we don't\n * need to check whether any nodes have changed transform.\n */\n const canSkip = !(forceRecalculation ||\n (isShared && this.isSharedProjectionDirty) ||\n this.isProjectionDirty ||\n this.parent?.isProjectionDirty ||\n this.attemptToResolveRelativeTarget ||\n this.root.updateBlockedByResize);\n if (canSkip)\n return;\n const { layout, layoutId } = this.options;\n /**\n * If we have no layout, we can't perform projection, so early return\n */\n if (!this.layout || !(layout || layoutId))\n return;\n this.resolvedRelativeTargetAt = frameData.timestamp;\n const relativeParent = this.getClosestProjectingParent();\n if (relativeParent &&\n this.linkedParentVersion !== relativeParent.layoutVersion &&\n !relativeParent.options.layoutRoot) {\n this.removeRelativeTarget();\n }\n /**\n * If we don't have a targetDelta but do have a layout, we can attempt to resolve\n * a relativeParent. This will allow a component to perform scale correction\n * even if no animation has started.\n */\n if (!this.targetDelta && !this.relativeTarget) {\n if (relativeParent && relativeParent.layout) {\n this.createRelativeTarget(relativeParent, this.layout.layoutBox, relativeParent.layout.layoutBox);\n }\n else {\n this.removeRelativeTarget();\n }\n }\n /**\n * If we have no relative target or no target delta our target isn't valid\n * for this frame.\n */\n if (!this.relativeTarget && !this.targetDelta)\n return;\n /**\n * Lazy-init target data structure\n */\n if (!this.target) {\n this.target = createBox();\n this.targetWithTransforms = createBox();\n }\n /**\n * If we've got a relative box for this component, resolve it into a target relative to the parent.\n */\n if (this.relativeTarget &&\n this.relativeTargetOrigin &&\n this.relativeParent &&\n this.relativeParent.target) {\n this.forceRelativeParentToResolveTarget();\n calcRelativeBox(this.target, this.relativeTarget, this.relativeParent.target);\n /**\n * If we've only got a targetDelta, resolve it into a target\n */\n }\n else if (this.targetDelta) {\n if (Boolean(this.resumingFrom)) {\n // TODO: This is creating a new object every frame\n this.target = this.applyTransform(this.layout.layoutBox);\n }\n else {\n copyBoxInto(this.target, this.layout.layoutBox);\n }\n applyBoxDelta(this.target, this.targetDelta);\n }\n else {\n /**\n * If no target, use own layout as target\n */\n copyBoxInto(this.target, this.layout.layoutBox);\n }\n /**\n * If we've been told to attempt to resolve a relative target, do so.\n */\n if (this.attemptToResolveRelativeTarget) {\n this.attemptToResolveRelativeTarget = false;\n if (relativeParent &&\n Boolean(relativeParent.resumingFrom) ===\n Boolean(this.resumingFrom) &&\n !relativeParent.options.layoutScroll &&\n relativeParent.target &&\n this.animationProgress !== 1) {\n this.createRelativeTarget(relativeParent, this.target, relativeParent.target);\n }\n else {\n this.relativeParent = this.relativeTarget = undefined;\n }\n }\n /**\n * Increase debug counter for resolved target deltas\n */\n if (statsBuffer.value) {\n metrics.calculatedTargetDeltas++;\n }\n }\n getClosestProjectingParent() {\n if (!this.parent ||\n hasScale(this.parent.latestValues) ||\n has2DTranslate(this.parent.latestValues)) {\n return undefined;\n }\n if (this.parent.isProjecting()) {\n return this.parent;\n }\n else {\n return this.parent.getClosestProjectingParent();\n }\n }\n isProjecting() {\n return Boolean((this.relativeTarget ||\n this.targetDelta ||\n this.options.layoutRoot) &&\n this.layout);\n }\n createRelativeTarget(relativeParent, layout, parentLayout) {\n this.relativeParent = relativeParent;\n this.linkedParentVersion = relativeParent.layoutVersion;\n this.forceRelativeParentToResolveTarget();\n this.relativeTarget = createBox();\n this.relativeTargetOrigin = createBox();\n calcRelativePosition(this.relativeTargetOrigin, layout, parentLayout);\n copyBoxInto(this.relativeTarget, this.relativeTargetOrigin);\n }\n removeRelativeTarget() {\n this.relativeParent = this.relativeTarget = undefined;\n }\n calcProjection() {\n const lead = this.getLead();\n const isShared = Boolean(this.resumingFrom) || this !== lead;\n let canSkip = true;\n /**\n * If this is a normal layout animation and neither this node nor its nearest projecting\n * is dirty then we can't skip.\n */\n if (this.isProjectionDirty || this.parent?.isProjectionDirty) {\n canSkip = false;\n }\n /**\n * If this is a shared layout animation and this node's shared projection is dirty then\n * we can't skip.\n */\n if (isShared &&\n (this.isSharedProjectionDirty || this.isTransformDirty)) {\n canSkip = false;\n }\n /**\n * If we have resolved the target this frame we must recalculate the\n * projection to ensure it visually represents the internal calculations.\n */\n if (this.resolvedRelativeTargetAt === frameData.timestamp) {\n canSkip = false;\n }\n if (canSkip)\n return;\n const { layout, layoutId } = this.options;\n /**\n * If this section of the tree isn't animating we can\n * delete our target sources for the following frame.\n */\n this.isTreeAnimating = Boolean((this.parent && this.parent.isTreeAnimating) ||\n this.currentAnimation ||\n this.pendingAnimation);\n if (!this.isTreeAnimating) {\n this.targetDelta = this.relativeTarget = undefined;\n }\n if (!this.layout || !(layout || layoutId))\n return;\n /**\n * Reset the corrected box with the latest values from box, as we're then going\n * to perform mutative operations on it.\n */\n copyBoxInto(this.layoutCorrected, this.layout.layoutBox);\n /**\n * Record previous tree scales before updating.\n */\n const prevTreeScaleX = this.treeScale.x;\n const prevTreeScaleY = this.treeScale.y;\n /**\n * Apply all the parent deltas to this box to produce the corrected box. This\n * is the layout box, as it will appear on screen as a result of the transforms of its parents.\n */\n applyTreeDeltas(this.layoutCorrected, this.treeScale, this.path, isShared);\n /**\n * If this layer needs to perform scale correction but doesn't have a target,\n * use the layout as the target.\n */\n if (lead.layout &&\n !lead.target &&\n (this.treeScale.x !== 1 || this.treeScale.y !== 1)) {\n lead.target = lead.layout.layoutBox;\n lead.targetWithTransforms = createBox();\n }\n const { target } = lead;\n if (!target) {\n /**\n * If we don't have a target to project into, but we were previously\n * projecting, we want to remove the stored transform and schedule\n * a render to ensure the elements reflect the removed transform.\n */\n if (this.prevProjectionDelta) {\n this.createProjectionDeltas();\n this.scheduleRender();\n }\n return;\n }\n if (!this.projectionDelta || !this.prevProjectionDelta) {\n this.createProjectionDeltas();\n }\n else {\n copyAxisDeltaInto(this.prevProjectionDelta.x, this.projectionDelta.x);\n copyAxisDeltaInto(this.prevProjectionDelta.y, this.projectionDelta.y);\n }\n /**\n * Update the delta between the corrected box and the target box before user-set transforms were applied.\n * This will allow us to calculate the corrected borderRadius and boxShadow to compensate\n * for our layout reprojection, but still allow them to be scaled correctly by the user.\n * It might be that to simplify this we may want to accept that user-set scale is also corrected\n * and we wouldn't have to keep and calc both deltas, OR we could support a user setting\n * to allow people to choose whether these styles are corrected based on just the\n * layout reprojection or the final bounding box.\n */\n calcBoxDelta(this.projectionDelta, this.layoutCorrected, target, this.latestValues);\n if (this.treeScale.x !== prevTreeScaleX ||\n this.treeScale.y !== prevTreeScaleY ||\n !axisDeltaEquals(this.projectionDelta.x, this.prevProjectionDelta.x) ||\n !axisDeltaEquals(this.projectionDelta.y, this.prevProjectionDelta.y)) {\n this.hasProjected = true;\n this.scheduleRender();\n this.notifyListeners(\"projectionUpdate\", target);\n }\n /**\n * Increase debug counter for recalculated projections\n */\n if (statsBuffer.value) {\n metrics.calculatedProjections++;\n }\n }\n hide() {\n this.isVisible = false;\n // TODO: Schedule render\n }\n show() {\n this.isVisible = true;\n // TODO: Schedule render\n }\n scheduleRender(notifyAll = true) {\n this.options.visualElement?.scheduleRender();\n if (notifyAll) {\n const stack = this.getStack();\n stack && stack.scheduleRender();\n }\n if (this.resumingFrom && !this.resumingFrom.instance) {\n this.resumingFrom = undefined;\n }\n }\n createProjectionDeltas() {\n this.prevProjectionDelta = createDelta();\n this.projectionDelta = createDelta();\n this.projectionDeltaWithTransform = createDelta();\n }\n setAnimationOrigin(delta, hasOnlyRelativeTargetChanged = false) {\n const snapshot = this.snapshot;\n const snapshotLatestValues = snapshot ? snapshot.latestValues : {};\n const mixedValues = { ...this.latestValues };\n const targetDelta = createDelta();\n if (!this.relativeParent ||\n !this.relativeParent.options.layoutRoot) {\n this.relativeTarget = this.relativeTargetOrigin = undefined;\n }\n this.attemptToResolveRelativeTarget = !hasOnlyRelativeTargetChanged;\n const relativeLayout = createBox();\n const snapshotSource = snapshot ? snapshot.source : undefined;\n const layoutSource = this.layout ? this.layout.source : undefined;\n const isSharedLayoutAnimation = snapshotSource !== layoutSource;\n const stack = this.getStack();\n const isOnlyMember = !stack || stack.members.length <= 1;\n const shouldCrossfadeOpacity = Boolean(isSharedLayoutAnimation &&\n !isOnlyMember &&\n this.options.crossfade === true &&\n !this.path.some(hasOpacityCrossfade));\n this.animationProgress = 0;\n let prevRelativeTarget;\n this.mixTargetDelta = (latest) => {\n const progress = latest / 1000;\n mixAxisDelta(targetDelta.x, delta.x, progress);\n mixAxisDelta(targetDelta.y, delta.y, progress);\n this.setTargetDelta(targetDelta);\n if (this.relativeTarget &&\n this.relativeTargetOrigin &&\n this.layout &&\n this.relativeParent &&\n this.relativeParent.layout) {\n calcRelativePosition(relativeLayout, this.layout.layoutBox, this.relativeParent.layout.layoutBox);\n mixBox(this.relativeTarget, this.relativeTargetOrigin, relativeLayout, progress);\n /**\n * If this is an unchanged relative target we can consider the\n * projection not dirty.\n */\n if (prevRelativeTarget &&\n boxEquals(this.relativeTarget, prevRelativeTarget)) {\n this.isProjectionDirty = false;\n }\n if (!prevRelativeTarget)\n prevRelativeTarget = createBox();\n copyBoxInto(prevRelativeTarget, this.relativeTarget);\n }\n if (isSharedLayoutAnimation) {\n this.animationValues = mixedValues;\n mixValues(mixedValues, snapshotLatestValues, this.latestValues, progress, shouldCrossfadeOpacity, isOnlyMember);\n }\n this.root.scheduleUpdateProjection();\n this.scheduleRender();\n this.animationProgress = progress;\n };\n this.mixTargetDelta(this.options.layoutRoot ? 1000 : 0);\n }\n startAnimation(options) {\n this.notifyListeners(\"animationStart\");\n this.currentAnimation?.stop();\n this.resumingFrom?.currentAnimation?.stop();\n if (this.pendingAnimation) {\n cancelFrame(this.pendingAnimation);\n this.pendingAnimation = undefined;\n }\n /**\n * Start the animation in the next frame to have a frame with progress 0,\n * where the target is the same as when the animation started, so we can\n * calculate the relative positions correctly for instant transitions.\n */\n this.pendingAnimation = frame.update(() => {\n globalProjectionState.hasAnimatedSinceResize = true;\n activeAnimations.layout++;\n this.motionValue || (this.motionValue = motionValue(0));\n this.currentAnimation = animateSingleValue(this.motionValue, [0, 1000], {\n ...options,\n velocity: 0,\n isSync: true,\n onUpdate: (latest) => {\n this.mixTargetDelta(latest);\n options.onUpdate && options.onUpdate(latest);\n },\n onStop: () => {\n activeAnimations.layout--;\n },\n onComplete: () => {\n activeAnimations.layout--;\n options.onComplete && options.onComplete();\n this.completeAnimation();\n },\n });\n if (this.resumingFrom) {\n this.resumingFrom.currentAnimation = this.currentAnimation;\n }\n this.pendingAnimation = undefined;\n });\n }\n completeAnimation() {\n if (this.resumingFrom) {\n this.resumingFrom.currentAnimation = undefined;\n this.resumingFrom.preserveOpacity = undefined;\n }\n const stack = this.getStack();\n stack && stack.exitAnimationComplete();\n this.resumingFrom =\n this.currentAnimation =\n this.animationValues =\n undefined;\n this.notifyListeners(\"animationComplete\");\n }\n finishAnimation() {\n if (this.currentAnimation) {\n this.mixTargetDelta && this.mixTargetDelta(animationTarget);\n this.currentAnimation.stop();\n }\n this.completeAnimation();\n }\n applyTransformsToTarget() {\n const lead = this.getLead();\n let { targetWithTransforms, target, layout, latestValues } = lead;\n if (!targetWithTransforms || !target || !layout)\n return;\n /**\n * If we're only animating position, and this element isn't the lead element,\n * then instead of projecting into the lead box we instead want to calculate\n * a new target that aligns the two boxes but maintains the layout shape.\n */\n if (this !== lead &&\n this.layout &&\n layout &&\n shouldAnimatePositionOnly(this.options.animationType, this.layout.layoutBox, layout.layoutBox)) {\n target = this.target || createBox();\n const xLength = calcLength(this.layout.layoutBox.x);\n target.x.min = lead.target.x.min;\n target.x.max = target.x.min + xLength;\n const yLength = calcLength(this.layout.layoutBox.y);\n target.y.min = lead.target.y.min;\n target.y.max = target.y.min + yLength;\n }\n copyBoxInto(targetWithTransforms, target);\n /**\n * Apply the latest user-set transforms to the targetBox to produce the targetBoxFinal.\n * This is the final box that we will then project into by calculating a transform delta and\n * applying it to the corrected box.\n */\n transformBox(targetWithTransforms, latestValues);\n /**\n * Update the delta between the corrected box and the final target box, after\n * user-set transforms are applied to it. This will be used by the renderer to\n * create a transform style that will reproject the element from its layout layout\n * into the desired bounding box.\n */\n calcBoxDelta(this.projectionDeltaWithTransform, this.layoutCorrected, targetWithTransforms, latestValues);\n }\n registerSharedNode(layoutId, node) {\n if (!this.sharedNodes.has(layoutId)) {\n this.sharedNodes.set(layoutId, new NodeStack());\n }\n const stack = this.sharedNodes.get(layoutId);\n stack.add(node);\n const config = node.options.initialPromotionConfig;\n node.promote({\n transition: config ? config.transition : undefined,\n preserveFollowOpacity: config && config.shouldPreserveFollowOpacity\n ? config.shouldPreserveFollowOpacity(node)\n : undefined,\n });\n }\n isLead() {\n const stack = this.getStack();\n return stack ? stack.lead === this : true;\n }\n getLead() {\n const { layoutId } = this.options;\n return layoutId ? this.getStack()?.lead || this : this;\n }\n getPrevLead() {\n const { layoutId } = this.options;\n return layoutId ? this.getStack()?.prevLead : undefined;\n }\n getStack() {\n const { layoutId } = this.options;\n if (layoutId)\n return this.root.sharedNodes.get(layoutId);\n }\n promote({ needsReset, transition, preserveFollowOpacity, } = {}) {\n const stack = this.getStack();\n if (stack)\n stack.promote(this, preserveFollowOpacity);\n if (needsReset) {\n this.projectionDelta = undefined;\n this.needsReset = true;\n }\n if (transition)\n this.setOptions({ transition });\n }\n relegate() {\n const stack = this.getStack();\n if (stack) {\n return stack.relegate(this);\n }\n else {\n return false;\n }\n }\n resetSkewAndRotation() {\n const { visualElement } = this.options;\n if (!visualElement)\n return;\n // If there's no detected skew or rotation values, we can early return without a forced render.\n let hasDistortingTransform = false;\n /**\n * An unrolled check for rotation values. Most elements don't have any rotation and\n * skipping the nested loop and new object creation is 50% faster.\n */\n const { latestValues } = visualElement;\n if (latestValues.z ||\n latestValues.rotate ||\n latestValues.rotateX ||\n latestValues.rotateY ||\n latestValues.rotateZ ||\n latestValues.skewX ||\n latestValues.skewY) {\n hasDistortingTransform = true;\n }\n // If there's no distorting values, we don't need to do any more.\n if (!hasDistortingTransform)\n return;\n const resetValues = {};\n if (latestValues.z) {\n resetDistortingTransform(\"z\", visualElement, resetValues, this.animationValues);\n }\n // Check the skew and rotate value of all axes and reset to 0\n for (let i = 0; i < transformAxes.length; i++) {\n resetDistortingTransform(`rotate${transformAxes[i]}`, visualElement, resetValues, this.animationValues);\n resetDistortingTransform(`skew${transformAxes[i]}`, visualElement, resetValues, this.animationValues);\n }\n // Force a render of this element to apply the transform with all skews and rotations\n // set to 0.\n visualElement.render();\n // Put back all the values we reset\n for (const key in resetValues) {\n visualElement.setStaticValue(key, resetValues[key]);\n if (this.animationValues) {\n this.animationValues[key] = resetValues[key];\n }\n }\n // Schedule a render for the next frame. This ensures we won't visually\n // see the element with the reset rotate value applied.\n visualElement.scheduleRender();\n }\n applyProjectionStyles(targetStyle, // CSSStyleDeclaration - doesn't allow numbers to be assigned to properties\n styleProp) {\n if (!this.instance || this.isSVG)\n return;\n if (!this.isVisible) {\n targetStyle.visibility = \"hidden\";\n return;\n }\n const transformTemplate = this.getTransformTemplate();\n if (this.needsReset) {\n this.needsReset = false;\n targetStyle.visibility = \"\";\n targetStyle.opacity = \"\";\n targetStyle.pointerEvents =\n resolveMotionValue(styleProp?.pointerEvents) || \"\";\n targetStyle.transform = transformTemplate\n ? transformTemplate(this.latestValues, \"\")\n : \"none\";\n return;\n }\n const lead = this.getLead();\n if (!this.projectionDelta || !this.layout || !lead.target) {\n if (this.options.layoutId) {\n targetStyle.opacity =\n this.latestValues.opacity !== undefined\n ? this.latestValues.opacity\n : 1;\n targetStyle.pointerEvents =\n resolveMotionValue(styleProp?.pointerEvents) || \"\";\n }\n if (this.hasProjected && !hasTransform(this.latestValues)) {\n targetStyle.transform = transformTemplate\n ? transformTemplate({}, \"\")\n : \"none\";\n this.hasProjected = false;\n }\n return;\n }\n targetStyle.visibility = \"\";\n const valuesToRender = lead.animationValues || lead.latestValues;\n this.applyTransformsToTarget();\n let transform = buildProjectionTransform(this.projectionDeltaWithTransform, this.treeScale, valuesToRender);\n if (transformTemplate) {\n transform = transformTemplate(valuesToRender, transform);\n }\n targetStyle.transform = transform;\n const { x, y } = this.projectionDelta;\n targetStyle.transformOrigin = `${x.origin * 100}% ${y.origin * 100}% 0`;\n if (lead.animationValues) {\n /**\n * If the lead component is animating, assign this either the entering/leaving\n * opacity\n */\n targetStyle.opacity =\n lead === this\n ? valuesToRender.opacity ??\n this.latestValues.opacity ??\n 1\n : this.preserveOpacity\n ? this.latestValues.opacity\n : valuesToRender.opacityExit;\n }\n else {\n /**\n * Or we're not animating at all, set the lead component to its layout\n * opacity and other components to hidden.\n */\n targetStyle.opacity =\n lead === this\n ? valuesToRender.opacity !== undefined\n ? valuesToRender.opacity\n : \"\"\n : valuesToRender.opacityExit !== undefined\n ? valuesToRender.opacityExit\n : 0;\n }\n /**\n * Apply scale correction\n */\n for (const key in scaleCorrectors) {\n if (valuesToRender[key] === undefined)\n continue;\n const { correct, applyTo, isCSSVariable } = scaleCorrectors[key];\n /**\n * Only apply scale correction to the value if we have an\n * active projection transform. Otherwise these values become\n * vulnerable to distortion if the element changes size without\n * a corresponding layout animation.\n */\n const corrected = transform === \"none\"\n ? valuesToRender[key]\n : correct(valuesToRender[key], lead);\n if (applyTo) {\n const num = applyTo.length;\n for (let i = 0; i < num; i++) {\n targetStyle[applyTo[i]] = corrected;\n }\n }\n else {\n // If this is a CSS variable, set it directly on the instance.\n // Replacing this function from creating styles to setting them\n // would be a good place to remove per frame object creation\n if (isCSSVariable) {\n this.options.visualElement.renderState.vars[key] = corrected;\n }\n else {\n targetStyle[key] = corrected;\n }\n }\n }\n /**\n * Disable pointer events on follow components. This is to ensure\n * that if a follow component covers a lead component it doesn't block\n * pointer events on the lead.\n */\n if (this.options.layoutId) {\n targetStyle.pointerEvents =\n lead === this\n ? resolveMotionValue(styleProp?.pointerEvents) || \"\"\n : \"none\";\n }\n }\n clearSnapshot() {\n this.resumeFrom = this.snapshot = undefined;\n }\n // Only run on root\n resetTree() {\n this.root.nodes.forEach((node) => node.currentAnimation?.stop());\n this.root.nodes.forEach(clearMeasurements);\n this.root.sharedNodes.clear();\n }\n };\n}\nfunction updateLayout(node) {\n node.updateLayout();\n}\nfunction notifyLayoutUpdate(node) {\n const snapshot = node.resumeFrom?.snapshot || node.snapshot;\n if (node.isLead() &&\n node.layout &&\n snapshot &&\n node.hasListeners(\"didUpdate\")) {\n const { layoutBox: layout, measuredBox: measuredLayout } = node.layout;\n const { animationType } = node.options;\n const isShared = snapshot.source !== node.layout.source;\n // TODO Maybe we want to also resize the layout snapshot so we don't trigger\n // animations for instance if layout=\"size\" and an element has only changed position\n if (animationType === \"size\") {\n eachAxis((axis) => {\n const axisSnapshot = isShared\n ? snapshot.measuredBox[axis]\n : snapshot.layoutBox[axis];\n const length = calcLength(axisSnapshot);\n axisSnapshot.min = layout[axis].min;\n axisSnapshot.max = axisSnapshot.min + length;\n });\n }\n else if (shouldAnimatePositionOnly(animationType, snapshot.layoutBox, layout)) {\n eachAxis((axis) => {\n const axisSnapshot = isShared\n ? snapshot.measuredBox[axis]\n : snapshot.layoutBox[axis];\n const length = calcLength(layout[axis]);\n axisSnapshot.max = axisSnapshot.min + length;\n /**\n * Ensure relative target gets resized and rerendererd\n */\n if (node.relativeTarget && !node.currentAnimation) {\n node.isProjectionDirty = true;\n node.relativeTarget[axis].max =\n node.relativeTarget[axis].min + length;\n }\n });\n }\n const layoutDelta = createDelta();\n calcBoxDelta(layoutDelta, layout, snapshot.layoutBox);\n const visualDelta = createDelta();\n if (isShared) {\n calcBoxDelta(visualDelta, node.applyTransform(measuredLayout, true), snapshot.measuredBox);\n }\n else {\n calcBoxDelta(visualDelta, layout, snapshot.layoutBox);\n }\n const hasLayoutChanged = !isDeltaZero(layoutDelta);\n let hasRelativeLayoutChanged = false;\n if (!node.resumeFrom) {\n const relativeParent = node.getClosestProjectingParent();\n /**\n * If the relativeParent is itself resuming from a different element then\n * the relative snapshot is not relavent\n */\n if (relativeParent && !relativeParent.resumeFrom) {\n const { snapshot: parentSnapshot, layout: parentLayout } = relativeParent;\n if (parentSnapshot && parentLayout) {\n const relativeSnapshot = createBox();\n calcRelativePosition(relativeSnapshot, snapshot.layoutBox, parentSnapshot.layoutBox);\n const relativeLayout = createBox();\n calcRelativePosition(relativeLayout, layout, parentLayout.layoutBox);\n if (!boxEqualsRounded(relativeSnapshot, relativeLayout)) {\n hasRelativeLayoutChanged = true;\n }\n if (relativeParent.options.layoutRoot) {\n node.relativeTarget = relativeLayout;\n node.relativeTargetOrigin = relativeSnapshot;\n node.relativeParent = relativeParent;\n }\n }\n }\n }\n node.notifyListeners(\"didUpdate\", {\n layout,\n snapshot,\n delta: visualDelta,\n layoutDelta,\n hasLayoutChanged,\n hasRelativeLayoutChanged,\n });\n }\n else if (node.isLead()) {\n const { onExitComplete } = node.options;\n onExitComplete && onExitComplete();\n }\n /**\n * Clearing transition\n * TODO: Investigate why this transition is being passed in as {type: false } from Framer\n * and why we need it at all\n */\n node.options.transition = undefined;\n}\nfunction propagateDirtyNodes(node) {\n /**\n * Increase debug counter for nodes encountered this frame\n */\n if (statsBuffer.value) {\n metrics.nodes++;\n }\n if (!node.parent)\n return;\n /**\n * If this node isn't projecting, propagate isProjectionDirty. It will have\n * no performance impact but it will allow the next child that *is* projecting\n * but *isn't* dirty to just check its parent to see if *any* ancestor needs\n * correcting.\n */\n if (!node.isProjecting()) {\n node.isProjectionDirty = node.parent.isProjectionDirty;\n }\n /**\n * Propagate isSharedProjectionDirty and isTransformDirty\n * throughout the whole tree. A future revision can take another look at\n * this but for safety we still recalcualte shared nodes.\n */\n node.isSharedProjectionDirty || (node.isSharedProjectionDirty = Boolean(node.isProjectionDirty ||\n node.parent.isProjectionDirty ||\n node.parent.isSharedProjectionDirty));\n node.isTransformDirty || (node.isTransformDirty = node.parent.isTransformDirty);\n}\nfunction cleanDirtyNodes(node) {\n node.isProjectionDirty =\n node.isSharedProjectionDirty =\n node.isTransformDirty =\n false;\n}\nfunction clearSnapshot(node) {\n node.clearSnapshot();\n}\nfunction clearMeasurements(node) {\n node.clearMeasurements();\n}\nfunction clearIsLayoutDirty(node) {\n node.isLayoutDirty = false;\n}\nfunction resetTransformStyle(node) {\n const { visualElement } = node.options;\n if (visualElement && visualElement.getProps().onBeforeLayoutMeasure) {\n visualElement.notify(\"BeforeLayoutMeasure\");\n }\n node.resetTransform();\n}\nfunction finishAnimation(node) {\n node.finishAnimation();\n node.targetDelta = node.relativeTarget = node.target = undefined;\n node.isProjectionDirty = true;\n}\nfunction resolveTargetDelta(node) {\n node.resolveTargetDelta();\n}\nfunction calcProjection(node) {\n node.calcProjection();\n}\nfunction resetSkewAndRotation(node) {\n node.resetSkewAndRotation();\n}\nfunction removeLeadSnapshots(stack) {\n stack.removeLeadSnapshot();\n}\nfunction mixAxisDelta(output, delta, p) {\n output.translate = mixNumber(delta.translate, 0, p);\n output.scale = mixNumber(delta.scale, 1, p);\n output.origin = delta.origin;\n output.originPoint = delta.originPoint;\n}\nfunction mixAxis(output, from, to, p) {\n output.min = mixNumber(from.min, to.min, p);\n output.max = mixNumber(from.max, to.max, p);\n}\nfunction mixBox(output, from, to, p) {\n mixAxis(output.x, from.x, to.x, p);\n mixAxis(output.y, from.y, to.y, p);\n}\nfunction hasOpacityCrossfade(node) {\n return (node.animationValues && node.animationValues.opacityExit !== undefined);\n}\nconst defaultLayoutTransition = {\n duration: 0.45,\n ease: [0.4, 0, 0.1, 1],\n};\nconst userAgentContains = (string) => typeof navigator !== \"undefined\" &&\n navigator.userAgent &&\n navigator.userAgent.toLowerCase().includes(string);\n/**\n * Measured bounding boxes must be rounded in Safari and\n * left untouched in Chrome, otherwise non-integer layouts within scaled-up elements\n * can appear to jump.\n */\nconst roundPoint = userAgentContains(\"applewebkit/\") && !userAgentContains(\"chrome/\")\n ? Math.round\n : noop;\nfunction roundAxis(axis) {\n // Round to the nearest .5 pixels to support subpixel layouts\n axis.min = roundPoint(axis.min);\n axis.max = roundPoint(axis.max);\n}\nfunction roundBox(box) {\n roundAxis(box.x);\n roundAxis(box.y);\n}\nfunction shouldAnimatePositionOnly(animationType, snapshot, layout) {\n return (animationType === \"position\" ||\n (animationType === \"preserve-aspect\" &&\n !isNear(aspectRatio(snapshot), aspectRatio(layout), 0.2)));\n}\nfunction checkNodeWasScrollRoot(node) {\n return node !== node.root && node.scroll?.wasRoot;\n}\n\nexport { cleanDirtyNodes, createProjectionNode, mixAxis, mixAxisDelta, mixBox, propagateDirtyNodes };\n","import { addDomEvent } from '../../events/add-dom-event.mjs';\nimport { createProjectionNode } from './create-projection-node.mjs';\n\nconst DocumentProjectionNode = createProjectionNode({\n attachResizeListener: (ref, notify) => addDomEvent(ref, \"resize\", notify),\n measureScroll: () => ({\n x: document.documentElement.scrollLeft || document.body.scrollLeft,\n y: document.documentElement.scrollTop || document.body.scrollTop,\n }),\n checkIsScrollRoot: () => true,\n});\n\nexport { DocumentProjectionNode };\n","import { createProjectionNode } from './create-projection-node.mjs';\nimport { DocumentProjectionNode } from './DocumentProjectionNode.mjs';\n\nconst rootProjectionNode = {\n current: undefined,\n};\nconst HTMLProjectionNode = createProjectionNode({\n measureScroll: (instance) => ({\n x: instance.scrollLeft,\n y: instance.scrollTop,\n }),\n defaultParent: () => {\n if (!rootProjectionNode.current) {\n const documentNode = new DocumentProjectionNode({});\n documentNode.mount(window);\n documentNode.setOptions({ layoutScroll: true });\n rootProjectionNode.current = documentNode;\n }\n return rootProjectionNode.current;\n },\n resetTransform: (instance, value) => {\n instance.style.transform = value !== undefined ? value : \"none\";\n },\n checkIsScrollRoot: (instance) => Boolean(window.getComputedStyle(instance).position === \"fixed\"),\n});\n\nexport { HTMLProjectionNode, rootProjectionNode };\n","import { DragGesture } from '../../gestures/drag/index.mjs';\nimport { PanGesture } from '../../gestures/pan/index.mjs';\nimport { MeasureLayout } from './layout/MeasureLayout.mjs';\nimport { HTMLProjectionNode } from '../../projection/node/HTMLProjectionNode.mjs';\n\nconst drag = {\n pan: {\n Feature: PanGesture,\n },\n drag: {\n Feature: DragGesture,\n ProjectionNode: HTMLProjectionNode,\n MeasureLayout,\n },\n};\n\nexport { drag };\n","import { hover, frame } from 'motion-dom';\nimport { extractEventInfo } from '../events/event-info.mjs';\nimport { Feature } from '../motion/features/Feature.mjs';\n\nfunction handleHoverEvent(node, event, lifecycle) {\n const { props } = node;\n if (node.animationState && props.whileHover) {\n node.animationState.setActive(\"whileHover\", lifecycle === \"Start\");\n }\n const eventName = (\"onHover\" + lifecycle);\n const callback = props[eventName];\n if (callback) {\n frame.postRender(() => callback(event, extractEventInfo(event)));\n }\n}\nclass HoverGesture extends Feature {\n mount() {\n const { current } = this.node;\n if (!current)\n return;\n this.unmount = hover(current, (_element, startEvent) => {\n handleHoverEvent(this.node, startEvent, \"Start\");\n return (endEvent) => handleHoverEvent(this.node, endEvent, \"End\");\n });\n }\n unmount() { }\n}\n\nexport { HoverGesture };\n","import { pipe } from 'motion-utils';\nimport { addDomEvent } from '../events/add-dom-event.mjs';\nimport { Feature } from '../motion/features/Feature.mjs';\n\nclass FocusGesture extends Feature {\n constructor() {\n super(...arguments);\n this.isActive = false;\n }\n onFocus() {\n let isFocusVisible = false;\n /**\n * If this element doesn't match focus-visible then don't\n * apply whileHover. But, if matches throws that focus-visible\n * is not a valid selector then in that browser outline styles will be applied\n * to the element by default and we want to match that behaviour with whileFocus.\n */\n try {\n isFocusVisible = this.node.current.matches(\":focus-visible\");\n }\n catch (e) {\n isFocusVisible = true;\n }\n if (!isFocusVisible || !this.node.animationState)\n return;\n this.node.animationState.setActive(\"whileFocus\", true);\n this.isActive = true;\n }\n onBlur() {\n if (!this.isActive || !this.node.animationState)\n return;\n this.node.animationState.setActive(\"whileFocus\", false);\n this.isActive = false;\n }\n mount() {\n this.unmount = pipe(addDomEvent(this.node.current, \"focus\", () => this.onFocus()), addDomEvent(this.node.current, \"blur\", () => this.onBlur()));\n }\n unmount() { }\n}\n\nexport { FocusGesture };\n","import { press, frame } from 'motion-dom';\nimport { extractEventInfo } from '../events/event-info.mjs';\nimport { Feature } from '../motion/features/Feature.mjs';\n\nfunction handlePressEvent(node, event, lifecycle) {\n const { props } = node;\n if (node.current instanceof HTMLButtonElement && node.current.disabled) {\n return;\n }\n if (node.animationState && props.whileTap) {\n node.animationState.setActive(\"whileTap\", lifecycle === \"Start\");\n }\n const eventName = (\"onTap\" + (lifecycle === \"End\" ? \"\" : lifecycle));\n const callback = props[eventName];\n if (callback) {\n frame.postRender(() => callback(event, extractEventInfo(event)));\n }\n}\nclass PressGesture extends Feature {\n mount() {\n const { current } = this.node;\n if (!current)\n return;\n this.unmount = press(current, (_element, startEvent) => {\n handlePressEvent(this.node, startEvent, \"Start\");\n return (endEvent, { success }) => handlePressEvent(this.node, endEvent, success ? \"End\" : \"Cancel\");\n }, { useGlobalTarget: this.node.props.globalTapTarget });\n }\n unmount() { }\n}\n\nexport { PressGesture };\n","/**\n * Map an IntersectionHandler callback to an element. We only ever make one handler for one\n * element, so even though these handlers might all be triggered by different\n * observers, we can keep them in the same map.\n */\nconst observerCallbacks = new WeakMap();\n/**\n * Multiple observers can be created for multiple element/document roots. Each with\n * different settings. So here we store dictionaries of observers to each root,\n * using serialised settings (threshold/margin) as lookup keys.\n */\nconst observers = new WeakMap();\nconst fireObserverCallback = (entry) => {\n const callback = observerCallbacks.get(entry.target);\n callback && callback(entry);\n};\nconst fireAllObserverCallbacks = (entries) => {\n entries.forEach(fireObserverCallback);\n};\nfunction initIntersectionObserver({ root, ...options }) {\n const lookupRoot = root || document;\n /**\n * If we don't have an observer lookup map for this root, create one.\n */\n if (!observers.has(lookupRoot)) {\n observers.set(lookupRoot, {});\n }\n const rootObservers = observers.get(lookupRoot);\n const key = JSON.stringify(options);\n /**\n * If we don't have an observer for this combination of root and settings,\n * create one.\n */\n if (!rootObservers[key]) {\n rootObservers[key] = new IntersectionObserver(fireAllObserverCallbacks, { root, ...options });\n }\n return rootObservers[key];\n}\nfunction observeIntersection(element, options, callback) {\n const rootInteresectionObserver = initIntersectionObserver(options);\n observerCallbacks.set(element, callback);\n rootInteresectionObserver.observe(element);\n return () => {\n observerCallbacks.delete(element);\n rootInteresectionObserver.unobserve(element);\n };\n}\n\nexport { observeIntersection };\n","import { Feature } from '../Feature.mjs';\nimport { observeIntersection } from './observers.mjs';\n\nconst thresholdNames = {\n some: 0,\n all: 1,\n};\nclass InViewFeature extends Feature {\n constructor() {\n super(...arguments);\n this.hasEnteredView = false;\n this.isInView = false;\n }\n startObserver() {\n this.unmount();\n const { viewport = {} } = this.node.getProps();\n const { root, margin: rootMargin, amount = \"some\", once } = viewport;\n const options = {\n root: root ? root.current : undefined,\n rootMargin,\n threshold: typeof amount === \"number\" ? amount : thresholdNames[amount],\n };\n const onIntersectionUpdate = (entry) => {\n const { isIntersecting } = entry;\n /**\n * If there's been no change in the viewport state, early return.\n */\n if (this.isInView === isIntersecting)\n return;\n this.isInView = isIntersecting;\n /**\n * Handle hasEnteredView. If this is only meant to run once, and\n * element isn't visible, early return. Otherwise set hasEnteredView to true.\n */\n if (once && !isIntersecting && this.hasEnteredView) {\n return;\n }\n else if (isIntersecting) {\n this.hasEnteredView = true;\n }\n if (this.node.animationState) {\n this.node.animationState.setActive(\"whileInView\", isIntersecting);\n }\n /**\n * Use the latest committed props rather than the ones in scope\n * when this observer is created\n */\n const { onViewportEnter, onViewportLeave } = this.node.getProps();\n const callback = isIntersecting ? onViewportEnter : onViewportLeave;\n callback && callback(entry);\n };\n return observeIntersection(this.node.current, options, onIntersectionUpdate);\n }\n mount() {\n this.startObserver();\n }\n update() {\n if (typeof IntersectionObserver === \"undefined\")\n return;\n const { props, prevProps } = this.node;\n const hasOptionsChanged = [\"amount\", \"margin\", \"root\"].some(hasViewportOptionChanged(props, prevProps));\n if (hasOptionsChanged) {\n this.startObserver();\n }\n }\n unmount() { }\n}\nfunction hasViewportOptionChanged({ viewport = {} }, { viewport: prevViewport = {} } = {}) {\n return (name) => viewport[name] !== prevViewport[name];\n}\n\nexport { InViewFeature };\n","import { HoverGesture } from '../../gestures/hover.mjs';\nimport { FocusGesture } from '../../gestures/focus.mjs';\nimport { PressGesture } from '../../gestures/press.mjs';\nimport { InViewFeature } from './viewport/index.mjs';\n\nconst gestureAnimations = {\n inView: {\n Feature: InViewFeature,\n },\n tap: {\n Feature: PressGesture,\n },\n focus: {\n Feature: FocusGesture,\n },\n hover: {\n Feature: HoverGesture,\n },\n};\n\nexport { gestureAnimations };\n","import { HTMLProjectionNode } from '../../projection/node/HTMLProjectionNode.mjs';\nimport { MeasureLayout } from './layout/MeasureLayout.mjs';\n\nconst layout = {\n layout: {\n ProjectionNode: HTMLProjectionNode,\n MeasureLayout,\n },\n};\n\nexport { layout };\n","import { animations } from '../../../motion/features/animations.mjs';\nimport { drag } from '../../../motion/features/drag.mjs';\nimport { gestureAnimations } from '../../../motion/features/gestures.mjs';\nimport { layout } from '../../../motion/features/layout.mjs';\n\nconst featureBundle = {\n ...animations,\n ...gestureAnimations,\n ...drag,\n ...layout,\n};\n\nexport { featureBundle };\n","import { createDomVisualElement } from '../../dom/create-visual-element.mjs';\nimport { createMotionProxy } from '../create-proxy.mjs';\nimport { featureBundle } from './feature-bundle.mjs';\n\nconst motion = /*@__PURE__*/ createMotionProxy(featureBundle, createDomVisualElement);\n\nexport { motion };\n","\"use client\";\n\nimport { useState } from 'react';\nimport type { FaqQuestion } from '../../types/api/faq';\n\ninterface FAQGridProps {\n faqs: FaqQuestion[];\n title?: string;\n maxItems?: number;\n}\n\nexport const FAQGrid = ({\n faqs: faqsData,\n title = \"\",\n maxItems,\n}: FAQGridProps) => {\n const faqs = Array.isArray(faqsData) ? faqsData : [];\n const displayFaqs = maxItems ? faqs.slice(0, maxItems) : faqs;\n \n const [openIndex, setOpenIndex] = useState<number | null>(null);\n\n return (\n <section>\n <div className=\"mx-auto max-w-3xl px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n </div>\n\n {displayFaqs.length > 0 ? (\n <div className=\"space-y-4\">\n {displayFaqs.map((faq, i: number) => {\n const isOpen = openIndex === i;\n const answer = faq.answer_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <div key={faq.id} className=\"border-b border-secondary\">\n <button\n onClick={() => setOpenIndex(isOpen ? null : i)}\n className=\"flex w-full items-center justify-between py-4 text-left\"\n >\n <h3 className=\"font-display text-xl font-normal text-fg-primary\">\n {faq.question}\n </h3>\n <span className=\"ml-4 text-fg-primary\">\n {isOpen ? '−' : '+'}\n </span>\n </button>\n {isOpen && (\n <div className=\"pb-4\">\n <p className=\"font-body text-base leading-relaxed text-tertiary whitespace-pre-line\">\n {answer}\n </p>\n </div>\n )}\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No FAQs available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('faq-grid', 'aman', FAQGrid);\n","\ninterface FAQHeroProps {\n title?: string;\n subtitle?: string;\n}\n\nexport const FAQHero = ({\n title = \"\",\n subtitle = \"\",\n}: FAQHeroProps) => {\n\n return (\n <section className=\"py-24 md:py-32\">\n <div className=\"mx-auto max-w-4xl px-4 text-center md:px-8\">\n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl lg:text-7xl\">\n {title}\n </h1>\n \n {subtitle && (\n <p className=\"mt-6 font-display text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subtitle}\n </p>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-faq', 'aman', FAQHero);\n","\ninterface GenericTextHeroProps {\n title?: string;\n subtitle?: string;\n}\n\nexport const GenericTextHero = ({\n title = '',\n subtitle = '',\n}: GenericTextHeroProps) => {\n return (\n <section className=\"py-24 md:py-32\">\n <div className=\"mx-auto max-w-4xl px-4 text-center md:px-8\">\n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl lg:text-7xl\">\n {title}\n </h1>\n \n {subtitle && (\n <p className=\"mt-6 font-display text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subtitle}\n </p>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-generic-text', 'aman', GenericTextHero);\n","import type { Location } from '../../types/api/location';\n\ninterface LocationDetailHeroProps {\n location?: Location | null;\n}\n\nexport const LocationDetailHero = ({\n location,\n}: LocationDetailHeroProps) => {\n if (!location) return null;\n\n return (\n <section className=\"py-24 md:py-32\">\n <div className=\"mx-auto max-w-4xl px-4 text-center md:px-8\">\n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl lg:text-7xl\">\n {location.name}\n </h1>\n \n {location.city && location.state && (\n <p className=\"mt-6 text-xs font-body uppercase tracking-widest\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {location.city}, {location.state}\n </p>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-location-detail', 'aman', LocationDetailHero);\n","\ninterface SocialMediaHeroProps {\n title?: string;\n subtitle?: string;\n}\n\nexport const SocialMediaHero = ({\n title = \"\",\n subtitle = \"\",\n}: SocialMediaHeroProps) => {\n \n return (\n <section className=\"py-24 md:py-32\">\n <div className=\"mx-auto max-w-4xl px-4 text-center md:px-8\">\n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl lg:text-7xl\">\n {title}\n </h1>\n \n {subtitle && (\n <p className=\"mt-6 font-display text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subtitle}\n </p>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-social-media', 'aman', SocialMediaHero);\n","\ninterface TestimonialsHeroProps {\n title?: string;\n subtitle?: string;\n}\n\nexport const TestimonialsHero = ({\n title = \"\",\n subtitle = \"\",\n}: TestimonialsHeroProps) => {\n\n return (\n <section className=\"py-24 md:py-32\">\n <div className=\"mx-auto max-w-4xl px-4 text-center md:px-8\">\n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl lg:text-7xl\">\n {title}\n </h1>\n \n {subtitle && (\n <p className=\"mt-6 font-display text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subtitle}\n </p>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-testimonials', 'aman', TestimonialsHero);\n","import type { JobPosting } from '../../types/api/job-posting';\n\ninterface JobGalleryProps {\n jobs?: JobPosting[] | null;\n title?: string;\n maxItems?: number;\n}\n\nexport const JobGallery = ({\n jobs: jobsData,\n title = \"\",\n maxItems,\n}: JobGalleryProps) => {\n const jobs = Array.isArray(jobsData) ? jobsData : [];\n const displayJobs = maxItems ? jobs.slice(0, maxItems) : jobs;\n\n return (\n <section>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mb-12 text-center\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n </div>\n\n {displayJobs.length > 0 ? (\n <div className=\"space-y-6\">\n {displayJobs.map((job) => {\n const description = job.description_markdown?.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 200) || '';\n \n return (\n <div key={job.id} className=\"border-b border-secondary pb-6\">\n <div className=\"flex flex-col md:flex-row md:items-center md:justify-between\">\n <div className=\"flex-grow\">\n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-2\">\n {job.title}\n </h3>\n \n <div className=\"flex gap-4 mb-4\">\n {job.location && (\n <p className=\"text-xs font-body uppercase tracking-widest\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {job.location}\n </p>\n )}\n </div>\n \n {description && (\n <p className=\"font-body text-base text-tertiary mb-4\">\n {description}\n </p>\n )}\n </div>\n \n <a\n href={`/careers/${job.slug}`}\n className=\"font-body text-base underline underline-offset-4 hover:no-underline whitespace-nowrap md:ml-6 transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n View details\n </a>\n </div>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No open positions at this time</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('job-gallery', 'aman', JobGallery);\n","import { ChevronLeft, MarkerPin02, Briefcase01, CurrencyDollarCircle } from \"@untitledui/icons\";\nimport { Button } from '../elements';\nimport type { JobPosting } from '../../types/api/job-posting';\n\ninterface JobDetailHeroProps {\n job?: JobPosting | null;\n}\n\nconst JobDetailHero = ({\n job,\n}: JobDetailHeroProps) => {\n if (!job) return null;\n\n const breadcrumb = {\n backHref: \"/about/careers\",\n backLabel: \"Careers\",\n currentLabel: job.title || \"Job\",\n };\n\n return (\n <section className=\"bg-primary py-8 md:py-12\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Breadcrumb */}\n <nav aria-label=\"Breadcrumb\" className=\"mb-6\">\n <div className=\"flex items-center gap-2 text-sm\">\n <Button \n color=\"link-gray\" \n size=\"sm\" \n href={breadcrumb.backHref}\n iconLeading={ChevronLeft}\n className=\"font-body text-secondary hover:text-primary\"\n >\n {breadcrumb.backLabel}\n </Button>\n <span className=\"font-body text-secondary\">/</span>\n <span className=\"font-body text-primary\">{breadcrumb.currentLabel}</span>\n </div>\n </nav>\n\n {/* Job Header */}\n <div className=\"flex flex-col gap-8\">\n <div>\n <h1 className=\"font-display text-5xl font-normal text-fg-primary md:text-6xl\">\n {job.title}\n </h1>\n \n <div className=\"mt-6 flex flex-wrap items-center gap-6 font-body text-base text-secondary\">\n {job.location && (\n <div className=\"flex items-center gap-2\">\n <MarkerPin02 className=\"h-5 w-5\" />\n <span>{job.location}</span>\n </div>\n )}\n {job.employment_type && (\n <div className=\"flex items-center gap-2\">\n <Briefcase01 className=\"h-5 w-5\" />\n <span className=\"uppercase tracking-wide\">{job.employment_type}</span>\n </div>\n )}\n {job.salary_range && (\n <div className=\"flex items-center gap-2\">\n <CurrencyDollarCircle className=\"h-5 w-5\" />\n <span>{job.salary_range}</span>\n </div>\n )}\n </div>\n </div>\n </div>\n </div>\n </section>\n );\n};\n\nexport default JobDetailHero;\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-job-detail', 'aman', JobDetailHero);\n","\"use client\";\n\nimport React, { useRef, useState } from 'react';\nimport { Form, Button } from '../elements';\nimport { DynamicFormFields } from '../components/DynamicFormFields';\nimport type { FormDefinition } from '../../types/api/form';\nimport { useFormDefinitions } from '../../next/contexts/form-definitions';\nimport { captureEvent } from '../../tracking/captureEvent';\n\ninterface JobApplicationFormAmanProps {\n jobSlug: string;\n /** Form fields are rendered from this definition (required). */\n formDefinition: FormDefinition | null | undefined;\n inline?: boolean;\n}\n\nexport const JobApplicationForm = ({ jobSlug, formDefinition, inline = false }: JobApplicationFormAmanProps) => {\n const { jobApplicationFormDefinition } = useFormDefinitions();\n const resolvedFormDefinition = formDefinition ?? jobApplicationFormDefinition;\n const [isSubmitting, setIsSubmitting] = useState(false);\n const [submitStatus, setSubmitStatus] = useState<'idle' | 'success' | 'error'>('idle');\n const [statusMessage, setStatusMessage] = useState<string>('');\n const formRef = useRef<HTMLFormElement>(null);\n\n const hasFields =\n resolvedFormDefinition != null &&\n Array.isArray(resolvedFormDefinition.fields) &&\n resolvedFormDefinition.fields.length > 0;\n\n const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n setIsSubmitting(true);\n setSubmitStatus('idle');\n setStatusMessage('');\n const formData = new FormData(e.currentTarget);\n const data: Record<string, string> = { formType: 'job_application', jobSlug };\n formData.forEach((value, key) => {\n if (key !== 'privacy' && typeof value === 'string') data[key] = value;\n });\n try {\n const response = await fetch('/api/form/', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(data),\n });\n const result = await response.json();\n if (result.success) {\n setSubmitStatus('success');\n setStatusMessage(result.message || \"Thank you for applying! We'll be in touch soon.\");\n formRef.current?.reset();\n captureEvent('form_submitted', { form_type: 'job_application' });\n setTimeout(() => setSubmitStatus('idle'), 5000);\n } else {\n const errorMsg = result.error || 'Something went wrong. Please try again.';\n setSubmitStatus('error');\n setStatusMessage(errorMsg);\n captureEvent('form_failed', { form_type: 'job_application', error: errorMsg });\n }\n } catch {\n setSubmitStatus('error');\n setStatusMessage('Network error. Please try again.');\n captureEvent('form_failed', { form_type: 'job_application', error: 'network_error' });\n }\n setIsSubmitting(false);\n };\n\n if (!hasFields) return null;\n\n const formContent = (\n <Form ref={formRef} onSubmit={handleSubmit} className=\"flex flex-col gap-6\">\n <DynamicFormFields form={resolvedFormDefinition} jobSlug={jobSlug} />\n {submitStatus === 'success' && (\n <div className=\"rounded-sm bg-success-50 p-4 text-success-700 font-body\">{statusMessage}</div>\n )}\n {submitStatus === 'error' && (\n <div className=\"rounded-sm bg-error-50 p-4 text-error-700 font-body\">{statusMessage}</div>\n )}\n <Button\n type=\"submit\"\n color=\"primary\"\n size=\"xl\"\n className=\"w-full font-body uppercase tracking-wide rounded-sm\"\n isDisabled={isSubmitting}\n isLoading={isSubmitting}\n >\n {isSubmitting ? 'Submitting...' : 'Submit Application'}\n </Button>\n </Form>\n );\n\n if (inline) return formContent;\n return (\n <section id=\"application-form\" className=\"bg-primary py-16 md:py-20\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto max-w-2xl\">\n <div className=\"mb-8 text-center\">\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n Apply for this Position\n </h2>\n <p className=\"mt-4 text-lg text-tertiary\">Fill out the form below to submit your application</p>\n </div>\n {formContent}\n </div>\n </div>\n </section>\n );\n};\n","\"use client\";\n\nimport { Fragment, useState } from \"react\";\nimport React from \"react\";\nimport { PhotoWithFallback, VideoModal, VideoPlayButton, Button } from '../elements';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport { resolveCtaUrls, isExternalCtaUrl } from '../../lib/cta-urls';\n\ninterface HeroHomeProps {\n websitePhotos?: WebsitePhotos | null;\n companyInformation?: CompanyInformation | null;\n headline?: string;\n subhead?: string;\n ctaText?: string;\n /** Optional route override for the main CTA. When not set, uses primary CTA URL (booking or /contact) from company info. */\n ctaHref?: string;\n tagline?: string;\n reviews?: { rating: number; count: number };\n onEmailSubmit?: (email: string) => void;\n videoUrl?: string;\n}\n\nexport const HeroHome = ({\n websitePhotos,\n companyInformation,\n headline = \"\",\n subhead = \"\",\n ctaText = \"\",\n ctaHref,\n tagline = \"\",\n videoUrl,\n}: HeroHomeProps) => {\n const [showVideo, setShowVideo] = useState(false);\n const resolved = companyInformation ? resolveCtaUrls(companyInformation) : null;\n const effectiveCtaHref = ctaHref ?? resolved?.primaryHref ?? '/contact';\n \n // Match the aman theme structure\n const heroImage = {\n url: websitePhotos?.hero?.url || '',\n alt: websitePhotos?.hero?.alt || '',\n };\n\n return (\n <Fragment>\n {/* Hero Section - Full screen with overlay text on left */}\n <section className=\"relative w-full h-[60vh] min-h-[500px] max-h-[550px]\">\n {/* Hero Image */}\n <div className=\"absolute inset-0\">\n <PhotoWithFallback\n photoUrl={heroImage.url}\n photoAlt={heroImage.alt}\n fallbackId=\"hero-home-barelux\"\n className=\"w-full h-full object-cover\"\n />\n </div>\n \n {/* Dark overlay for text readability */}\n <div className=\"absolute inset-0 bg-black/50\" />\n\n {/* Text Content Overlay - Left aligned */}\n <div className=\"relative h-full flex items-center\">\n <div className=\"mx-auto max-w-7xl px-4 md:px-8 w-full\">\n <div className=\"max-w-2xl\">\n {/* Small tagline badge */}\n {tagline && (\n <p className=\"font-body text-sm font-semibold uppercase tracking-widest text-white mb-5\">\n {tagline}\n </p>\n )}\n \n {/* Main headline - large serif */}\n <h1 className=\"font-display text-display-xl font-normal leading-none text-white mb-4\">\n {headline}\n </h1>\n \n {/* Subheadline */}\n <p className=\"font-body text-base md:text-lg leading-normal text-white mb-6 max-w-xl\">\n {subhead}\n </p>\n\n {/* CTA Button (external booking link opens in new tab) */}\n {ctaText && (\n <Button\n href={effectiveCtaHref}\n target={isExternalCtaUrl(effectiveCtaHref) ? '_blank' : undefined}\n rel={isExternalCtaUrl(effectiveCtaHref) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n size=\"md\"\n >\n {ctaText}\n </Button>\n )}\n </div>\n </div>\n </div>\n\n {/* Video play button overlay */}\n {videoUrl && (\n <div className=\"absolute inset-0 flex items-center justify-center\">\n <VideoPlayButton onClick={() => setShowVideo(true)} />\n </div>\n )}\n </section>\n \n {/* Video modal */}\n {videoUrl && (\n <VideoModal \n isOpen={showVideo}\n onClose={() => setShowVideo(false)}\n videoUrl={videoUrl}\n />\n )}\n </Fragment>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-home', 'barelux', HeroHome);\n","\"use client\";\n\nimport React, { useState, useRef, useCallback } from 'react';\nimport Link from 'next/link';\nimport Image from 'next/image';\nimport { usePathname } from 'next/navigation';\nimport { Button } from '../elements';\nimport { getLogoUrl } from '../../utils/photo-helpers';\nimport type { HeaderComponentProps } from './header-navigation';\nimport type { NavItem } from '../../types/config';\nimport { resolveCtaUrls, isExternalCtaUrl, resolvePortalPath } from '../../lib/cta-urls';\n\n// Maximum items to show before \"View All\" link\nconst MAX_DROPDOWN_ITEMS = 6;\n\nexport function HeaderNavigation({ \n props, \n navigation: navigationOverride, \n logoImage: logoImageOverride, \n logoText: logoTextOverride, \n config,\n companyInformation,\n websitePhotos,\n}: HeaderComponentProps) {\n const [activeDropdown, setActiveDropdown] = useState<string | null>(null);\n const [isMobileMenuOpen, setIsMobileMenuOpen] = useState(false);\n \n // Timeout ref for delayed dropdown closing\n const closeTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n \n // Cleanup timeout on unmount\n React.useEffect(() => {\n return () => {\n if (closeTimeoutRef.current) {\n clearTimeout(closeTimeoutRef.current);\n }\n };\n }, []);\n \n const logoUrl = logoImageOverride || getLogoUrl(websitePhotos) || props?.logo?.image;\n const companyName = logoTextOverride || companyInformation?.company_name || props?.logo?.text || '';\n \n // Use navigation from config or override\n const navigation = navigationOverride || config?.navigation?.header || [];\n const resolvedCtaUrls = resolveCtaUrls(companyInformation);\n const ctaUrls = {\n primaryHref: props?.cta_button?.secondary_href ?? resolvedCtaUrls.primaryHref,\n secondaryHref: props?.cta_button?.href ?? resolvedCtaUrls.secondaryHref,\n hasSecondary: props?.cta_button?.secondary_href != null || resolvedCtaUrls.hasSecondary,\n };\n\n // Hide the sticky bottom bar when the user is already on the portal page —\n // the portal has its own Book Now tab so the bar is redundant and confusing.\n const pathname = usePathname();\n const portalPath = resolvePortalPath(companyInformation);\n const isPortalPage = portalPath ? pathname?.startsWith(portalPath) : false;\n\n // Cancel any pending close timeout\n const cancelCloseTimeout = useCallback(() => {\n if (closeTimeoutRef.current) {\n clearTimeout(closeTimeoutRef.current);\n closeTimeoutRef.current = null;\n }\n }, []);\n\n // Open dropdown immediately; clear it when hovering a childless item so the\n // previous dropdown doesn't linger while a different top-level item is active.\n const handleMouseEnter = useCallback((item: NavItem) => {\n cancelCloseTimeout();\n if (item.children && item.children.length > 0) {\n setActiveDropdown(item.label);\n } else {\n setActiveDropdown(null);\n }\n }, [cancelCloseTimeout]);\n\n // Close dropdown with delay (allows moving to dropdown)\n const handleMouseLeave = useCallback(() => {\n cancelCloseTimeout();\n closeTimeoutRef.current = setTimeout(() => {\n setActiveDropdown(null);\n }, 150); // 150ms delay before closing\n }, [cancelCloseTimeout]);\n\n // Keep dropdown open when hovering over it\n const handleDropdownMouseEnter = useCallback(() => {\n cancelCloseTimeout();\n }, [cancelCloseTimeout]);\n\n // Close dropdown when leaving the dropdown area\n const handleDropdownMouseLeave = useCallback(() => {\n handleMouseLeave();\n }, [handleMouseLeave]);\n\n // Get display items for dropdown (limit + \"View All\" if needed)\n const getDropdownItems = (item: NavItem) => {\n const children = item.children || [];\n \n if (children.length > MAX_DROPDOWN_ITEMS + 1) {\n // Show first MAX_DROPDOWN_ITEMS items + \"View All\" link\n const displayItems = children.slice(0, MAX_DROPDOWN_ITEMS);\n return {\n items: displayItems,\n showViewAll: true,\n viewAllHref: item.href,\n viewAllLabel: `View All`,\n };\n }\n \n return {\n items: children,\n showViewAll: false,\n viewAllHref: '',\n viewAllLabel: '',\n };\n };\n\n return (\n <>\n {/* Desktop Header */}\n <header className=\"hidden md:block sticky top-0 z-50 bg-primary border-b border-primary\">\n <div className=\"mx-auto max-w-7xl px-4 md:px-8\">\n <div className=\"flex items-center justify-between py-4\">\n {/* Left: Logo */}\n <Link href={props?.logo?.href || '/'} className=\"flex items-center flex-shrink-0\">\n {logoUrl ? (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-10 w-auto object-contain\"\n width={120}\n height={40}\n />\n ) : (\n <span className=\"font-display text-xl font-normal text-fg-primary\">\n {companyName}\n </span>\n )}\n </Link>\n\n {/* Navigation */}\n <nav className=\"flex items-center gap-8 flex-1 ml-12\">\n {navigation.map((item: NavItem, i: number) => (\n <div\n key={i}\n className=\"relative\"\n onMouseEnter={() => handleMouseEnter(item)}\n onMouseLeave={handleMouseLeave}\n >\n <Link\n href={item.href}\n className=\"font-body text-md font-normal text-fg-primary hover:text-brand-accent transition-colors duration-200 flex items-center gap-1 whitespace-nowrap\"\n >\n {item.label}\n {item.children && item.children.length > 0 && (\n <svg className=\"w-4 h-4\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M19 9l-7 7-7-7\" />\n </svg>\n )}\n </Link>\n \n {/* Dropdown Menu - Simple vertical list */}\n {item.children && item.children.length > 0 && activeDropdown === item.label && (\n <div \n className=\"absolute left-0 top-full mt-2 w-64 py-3 bg-white border border-secondary rounded-lg shadow-lg z-50\"\n onMouseEnter={handleDropdownMouseEnter}\n onMouseLeave={handleDropdownMouseLeave}\n >\n {(() => {\n const { items, showViewAll, viewAllHref, viewAllLabel } = getDropdownItems(item);\n return (\n <>\n {items.map((link: NavItem, j: number) => (\n <Link\n key={j}\n href={link.href}\n className=\"block font-body text-md text-fg-primary hover:text-brand-accent hover:bg-secondary transition-colors px-4 py-2\"\n >\n {link.label}\n </Link>\n ))}\n {showViewAll && (\n <Link\n href={viewAllHref}\n className=\"block font-body text-md text-brand-accent hover:underline px-4 py-2 font-semibold border-t border-secondary mt-2 pt-3\"\n >\n {viewAllLabel} →\n </Link>\n )}\n </>\n );\n })()}\n </div>\n )}\n </div>\n ))}\n </nav>\n\n {/* Right: CTA Buttons - Left=Contact Us (/contact), Right=Book Now (booking) */}\n <div className=\"flex items-center gap-3 flex-shrink-0 ml-4\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n target={props.cta_button.secondary_target}\n rel={props.cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"secondary\"\n size=\"sm\"\n >\n {props.cta_button.label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n target={props?.cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(props?.cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n size=\"sm\"\n >\n {(props?.cta_button?.secondary_label && ctaUrls.hasSecondary) ? props.cta_button.secondary_label : (props?.cta_button?.label || \"\")}\n </Button>\n </div>\n </div>\n </div>\n </header>\n\n {/* Mobile Header */}\n <header className=\"md:hidden sticky top-0 z-50 bg-primary border-b border-secondary\">\n <div className=\"flex items-center justify-between px-4 py-4\">\n <button\n onClick={() => setIsMobileMenuOpen(true)}\n className=\"text-fg-primary\"\n aria-label=\"Open menu\"\n >\n <svg className=\"w-6 h-6\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M4 6h16M4 12h16M4 18h16\" />\n </svg>\n </button>\n \n <Link href={props?.logo?.href || '/'} className=\"flex items-center\">\n {logoUrl ? (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-8 w-auto object-contain\"\n width={120}\n height={32}\n />\n ) : (\n <span className=\"font-display text-lg font-normal text-fg-primary\">\n {companyName}\n </span>\n )}\n </Link>\n \n <div className=\"w-6\" />\n </div>\n </header>\n\n {/* Mobile Full-Screen Menu Overlay */}\n {isMobileMenuOpen && (\n <div className=\"fixed inset-0 bg-white z-50 md:hidden\">\n <div className=\"flex flex-col h-full\">\n {/* Mobile Menu Header */}\n <div className=\"flex items-center justify-between px-4 py-4 border-b border-secondary\">\n <button\n onClick={() => setIsMobileMenuOpen(false)}\n className=\"text-fg-primary\"\n aria-label=\"Close menu\"\n >\n <svg className=\"w-6 h-6\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n \n <div className=\"flex items-center\">\n {logoUrl ? (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-8 w-auto object-contain\"\n width={120}\n height={32}\n />\n ) : (\n <span className=\"font-display text-lg font-normal text-fg-primary\">\n {companyName}\n </span>\n )}\n </div>\n \n <div className=\"w-6\" />\n </div>\n\n {/* Mobile Menu Links */}\n <nav className=\"flex-1 overflow-y-auto px-4 py-8\">\n <ul className=\"space-y-4\">\n {navigation.map((item: NavItem, i: number) => {\n const { items } = getDropdownItems(item);\n return (\n <li key={i}>\n <Link\n href={item.href}\n className=\"block font-body text-base text-fg-primary py-2 font-medium\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {item.label}\n </Link>\n {items.length > 0 && (\n <ul className=\"ml-4 mt-2 space-y-2\">\n {items.map((link: NavItem, j: number) => (\n <li key={j}>\n <Link\n href={link.href}\n className=\"block font-body text-sm text-tertiary py-1\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {link.label}\n </Link>\n </li>\n ))}\n </ul>\n )}\n </li>\n );\n })}\n </ul>\n </nav>\n\n {/* Mobile Menu Footer */}\n <div className=\"border-t border-secondary px-4 py-6\">\n <div className=\"flex flex-col gap-3\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n color=\"secondary\"\n size=\"sm\"\n className=\"w-full\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {props.cta_button.secondary_label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n color=\"primary\"\n size=\"sm\"\n className=\"w-full\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {props?.cta_button?.label || \"\"}\n </Button>\n </div>\n </div>\n </div>\n </div>\n )}\n\n {/* Sticky Book/Contact bar (mobile only) — hidden on portal page where it would be redundant */}\n {!isPortalPage && <div className=\"fixed bottom-0 left-0 right-0 z-40 md:hidden bg-fg-primary\">\n <div className=\"flex gap-0\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n target={props.cta_button.secondary_target}\n rel={props.cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className=\"flex-1 font-body text-sm uppercase tracking-wide py-4 rounded-none border-r border-white/20\"\n >\n {props.cta_button.label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n target={props?.cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(props?.cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className={`${props?.cta_button?.secondary_label && ctaUrls.hasSecondary ? 'flex-1' : 'w-full'} font-body text-sm uppercase tracking-wide py-4 rounded-none`}\n >\n {(props?.cta_button?.secondary_label && ctaUrls.hasSecondary) ? props.cta_button.secondary_label : (props?.cta_button?.label || \"Contact\")}\n </Button>\n </div>\n </div>}\n </>\n );\n}\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('header-navigation', 'barelux', HeaderNavigation);\n","import React from \"react\";\nimport { PhotoWithFallback } from '../elements';\nimport type { Service } from '../../types/api/service';\n\ninterface ServicesHomeProps {\n services: Service[];\n title?: string;\n subtitle?: string;\n}\n\nexport const ServicesHome = ({\n services = [],\n title = \"\",\n subtitle = \"\",\n}: ServicesHomeProps) => {\n // Show all services\n const displayServices = services;\n\n return (\n <section className=\"py-16 md:py-20 lg:py-24 bg-secondary\">\n <div className=\"mx-auto max-w-7xl px-4 md:px-8\">\n {/* Section Header - Centered */}\n <div className=\"mx-auto max-w-3xl text-center mb-12\">\n <h2 className=\"font-display text-display-md font-normal text-fg-primary mb-4\">\n {title}\n </h2>\n <p className=\"font-body text-base text-secondary leading-normal\">\n {subtitle}\n </p>\n </div>\n\n {/* Services Grid - 4 columns, centered when incomplete */}\n <div className=\"flex flex-wrap justify-center gap-6\">\n {displayServices.map((service) => (\n <a\n key={service.id}\n href={`/services/${service.slug}`}\n className=\"group block bg-white rounded-2xl overflow-hidden shadow-sm hover:shadow-md transition-shadow duration-300 w-full md:w-[calc(50%-0.75rem)] lg:w-[calc(25%-1.125rem)] flex flex-col\"\n >\n {/* Service Image */}\n <div className=\"relative w-full h-56 overflow-hidden flex-shrink-0\">\n <PhotoWithFallback\n photoUrl={service.photo_attachments?.[0]?.photo?.large_url || service.photo_attachments?.[0]?.photo?.medium_url || ''}\n photoAlt={service.photo_attachments?.[0]?.photo?.title || service.name}\n fallbackId={`service-${service.id}`}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n\n {/* Service Content */}\n <div className=\"p-6\">\n <h3 className=\"font-body text-base font-semibold uppercase tracking-wide text-fg-primary mb-3 leading-tight\">\n {service.name}\n </h3>\n \n {service.summary && (\n <p className=\"font-body text-sm text-tertiary leading-relaxed\">\n {service.summary}\n </p>\n )}\n </div>\n </a>\n ))}\n </div>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('services-home', 'barelux', ServicesHome);\n","import { PhotoWithFallback, Button } from '../elements';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\n\ninterface AboutHomeProps {\n companyInformation?: CompanyInformation | null;\n websitePhotos?: WebsitePhotos | null;\n tagline?: string;\n title?: string;\n description?: string;\n bullets?: string[];\n ctaText?: string;\n ctaHref?: string;\n}\n\nexport const AboutHome = ({\n companyInformation,\n websitePhotos,\n tagline = \"\",\n title = \"\",\n description,\n bullets = [],\n ctaText = \"\",\n ctaHref = \"/about\",\n}: AboutHomeProps) => {\n const aboutText = description || companyInformation?.about_text_markdown || '';\n \n // Use about photo\n const aboutImage = websitePhotos?.about;\n\n return (\n <section className=\"py-16 md:py-20 lg:py-24 bg-primary\">\n <div className=\"mx-auto max-w-7xl px-4 md:px-8\">\n <div className=\"grid grid-cols-1 lg:grid-cols-2 gap-12 lg:gap-16 items-center\">\n {/* Left: Image */}\n <div className=\"order-2 lg:order-1\">\n <PhotoWithFallback\n photoUrl={aboutImage?.url || ''}\n photoAlt={aboutImage?.alt || ''}\n fallbackId=\"about-barelux\"\n className=\"w-full h-full object-cover rounded-2xl min-h-[400px] lg:min-h-[500px]\"\n />\n </div>\n\n {/* Right: Content */}\n <div className=\"order-1 lg:order-2\">\n {/* Tagline */}\n {tagline && (\n <p className=\"font-body text-xs font-semibold uppercase tracking-widest text-fg-primary mb-4\">\n {tagline}\n </p>\n )}\n \n {/* Heading */}\n <h2 className=\"font-display text-display-md font-normal leading-tight text-fg-primary mb-6\">\n {title}\n </h2>\n \n {/* Description */}\n {aboutText && (\n <p className=\"font-body text-base leading-relaxed text-secondary mb-8\">\n {aboutText}\n </p>\n )}\n\n {/* Bullet Points with Checkmarks */}\n {bullets && bullets.length > 0 && (\n <ul className=\"space-y-4 mb-8\">\n {bullets.map((bullet, index) => (\n <li key={index} className=\"flex items-start gap-3\">\n {/* Checkmark Icon */}\n <div className=\"flex-shrink-0 w-6 h-6 rounded-full border-2 border-fg-primary flex items-center justify-center mt-0.5\">\n <svg \n className=\"w-3 h-3 text-fg-primary\" \n fill=\"none\" \n viewBox=\"0 0 24 24\" \n stroke=\"currentColor\"\n strokeWidth={3}\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M5 13l4 4L19 7\" />\n </svg>\n </div>\n <span className=\"font-body text-base text-fg-primary\">\n {bullet}\n </span>\n </li>\n ))}\n </ul>\n )}\n\n {/* CTA Button */}\n {ctaText && (\n <Button\n href={ctaHref}\n color=\"primary\"\n size=\"md\"\n >\n {ctaText}\n </Button>\n )}\n </div>\n </div>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('about-home', 'barelux', AboutHome);\n","import React from 'react';\nimport { PhotoWithFallback, Carousel, Button } from '../elements';\nimport type { Testimonial } from '../../types/api/testimonial';\nimport { getAvatarUrl } from '../../utils/photo-helpers';\nimport { ChevronLeft, ChevronRight } from '@untitledui/icons';\n\ninterface TestimonialsHomeProps {\n testimonials?: Testimonial[] | null;\n title?: string;\n subtitle?: string;\n viewAllText?: string;\n viewAllHref?: string;\n emptyMessage?: string;\n}\n\nexport const TestimonialsHome = ({\n testimonials: testimonialsData,\n title = \"\",\n subtitle = \"\",\n viewAllText = \"View All Testimonials\",\n viewAllHref = \"/testimonials\",\n emptyMessage = \"No testimonials available\",\n}: TestimonialsHomeProps) => {\n const testimonials = Array.isArray(testimonialsData) ? testimonialsData : [];\n\n return (\n <section className=\"py-16 md:py-20 lg:py-24 bg-secondary\">\n <div className=\"mx-auto max-w-7xl px-4 md:px-8\">\n {/* Section Header - Centered */}\n <div className=\"mx-auto max-w-3xl text-center mb-12 md:mb-16\">\n <h2 className=\"font-display text-4xl font-medium text-fg-primary md:text-5xl mb-4\">\n {title}\n </h2>\n <p className=\"font-body text-lg text-secondary leading-normal\">\n {subtitle}\n </p>\n </div>\n\n {testimonials.length > 0 ? (\n <Carousel.Root opts={{ align: \"start\", loop: true }}>\n <div className=\"flex items-center justify-end mb-8\">\n <div className=\"flex gap-2\">\n <Carousel.PrevTrigger className=\"rounded-full p-2 border border-secondary hover:bg-primary_hover transition-colors disabled:opacity-30 disabled:cursor-not-allowed\">\n <ChevronLeft className=\"w-6 h-6 text-fg-primary\" />\n </Carousel.PrevTrigger>\n <Carousel.NextTrigger className=\"rounded-full p-2 border border-secondary hover:bg-primary_hover transition-colors disabled:opacity-30 disabled:cursor-not-allowed\">\n <ChevronRight className=\"w-6 h-6 text-fg-primary\" />\n </Carousel.NextTrigger>\n </div>\n </div>\n \n <Carousel.Content className=\"-ml-4\">\n {testimonials.map((testimonial, i: number) => {\n const quote = testimonial.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const reviewerName = testimonial.reviewer_name || '';\n const username = `@${reviewerName.toLowerCase().replace(/\\s+/g, '')}`;\n const avatarUrl = getAvatarUrl(testimonial.photo_attachments, testimonial.id, reviewerName);\n const rating = testimonial.rating || 5;\n const isVerified = true; // Always show verified badge\n \n return (\n <Carousel.Item key={testimonial.id || i} className=\"pl-4 md:basis-1/2 lg:basis-1/3\">\n <div className=\"bg-white rounded-2xl p-8 flex flex-col shadow-sm\" style={{ minHeight: '400px' }}>\n <div className=\"flex gap-1 mb-6\">\n {Array.from({ length: 5 }).map((_, starIdx) => (\n <svg\n key={starIdx}\n className=\"w-5 h-5\"\n style={{\n fill: starIdx < rating ? \"var(--color-text-brand-secondary)\" : \"none\",\n stroke: starIdx < rating ? \"none\" : \"#E5E0D8\"\n }}\n strokeWidth=\"2\"\n viewBox=\"0 0 24 24\"\n >\n <path d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\" />\n </svg>\n ))}\n </div>\n\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-6 flex-grow\">\n "{quote}"\n </p>\n\n <div className=\"flex items-center gap-3\">\n <div className=\"w-12 h-12 rounded-full overflow-hidden flex-shrink-0\">\n <PhotoWithFallback\n photoUrl={avatarUrl}\n photoAlt={reviewerName}\n fallbackId={testimonial.id || i}\n className=\"w-full h-full object-cover\"\n />\n </div>\n <div className=\"flex-1\">\n <div className=\"flex items-center gap-1.5\">\n <p className=\"font-body text-sm font-medium text-fg-primary\">\n {reviewerName}\n </p>\n {isVerified && (\n <svg className=\"w-4 h-4 text-fg-primary\" viewBox=\"0 0 20 20\" fill=\"currentColor\">\n <path fillRule=\"evenodd\" d=\"M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z\" clipRule=\"evenodd\" />\n </svg>\n )}\n </div>\n <p className=\"font-body text-xs\" style={{ color: 'var(--color-text-brand-secondary)' }}>{username}</p>\n </div>\n </div>\n </div>\n </Carousel.Item>\n );\n })}\n </Carousel.Content>\n </Carousel.Root>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">{emptyMessage}</p>\n </div>\n )}\n\n {/* View All Testimonials Button */}\n {testimonials.length > 0 && viewAllText && (\n <div className=\"mt-12 text-center\">\n <Button\n href={viewAllHref}\n color=\"primary\"\n size=\"md\"\n >\n {viewAllText}\n </Button>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('testimonials-home', 'barelux', TestimonialsHome);\n","import React from 'react';\nimport { PhotoWithFallback, Carousel, Button } from '../elements';\nimport type { BlogPost } from '../../types/api/blog-post';\nimport { ChevronLeft, ChevronRight } from '@untitledui/icons';\n\ninterface BlogSectionProps {\n blogPosts?: BlogPost[] | null;\n title?: string;\n subtitle?: string;\n maxPosts?: number;\n viewAllText?: string;\n viewAllHref?: string;\n emptyMessage?: string;\n recentLabel?: string;\n}\n\nexport const BlogSection = ({\n blogPosts: postsData,\n title = \"\",\n subtitle = \"\",\n maxPosts,\n viewAllText = \"View All Posts\",\n viewAllHref = \"/blog\",\n emptyMessage = \"No blog posts available\",\n recentLabel = \"Recent\",\n}: BlogSectionProps) => {\n \n const postsArray = Array.isArray(postsData) ? (maxPosts ? postsData.slice(0, maxPosts) : postsData) : [];\n\n const formatDate = (dateString?: string) => {\n if (!dateString) return recentLabel;\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n day: 'numeric',\n month: 'long',\n year: 'numeric'\n });\n } catch {\n return recentLabel;\n }\n };\n\n return (\n <section className=\"py-16 md:py-20 lg:py-24 bg-primary\">\n <div className=\"mx-auto max-w-7xl px-4 md:px-8\">\n {/* Section Header - Centered */}\n <div className=\"mx-auto max-w-3xl text-center mb-12 md:mb-16\">\n <h2 className=\"font-display text-4xl font-medium text-fg-primary md:text-5xl mb-4\">\n {title}\n </h2>\n <p className=\"font-body text-lg text-secondary leading-normal\">\n {subtitle}\n </p>\n </div>\n\n {postsArray.length > 0 ? (\n <Carousel.Root opts={{ align: \"start\", loop: true }}>\n <div className=\"flex items-center justify-end mb-8\">\n <div className=\"flex gap-2\">\n <Carousel.PrevTrigger className=\"rounded-full p-2 border border-secondary hover:bg-primary_hover transition-colors disabled:opacity-30 disabled:cursor-not-allowed\">\n <ChevronLeft className=\"w-6 h-6 text-fg-primary\" />\n </Carousel.PrevTrigger>\n <Carousel.NextTrigger className=\"rounded-full p-2 border border-secondary hover:bg-primary_hover transition-colors disabled:opacity-30 disabled:cursor-not-allowed\">\n <ChevronRight className=\"w-6 h-6 text-fg-primary\" />\n </Carousel.NextTrigger>\n </div>\n </div>\n \n <Carousel.Content className=\"-ml-4\">\n {postsArray.map((post: BlogPost) => {\n const excerpt = post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) || '';\n \n return (\n <Carousel.Item key={post.id} className=\"pl-4 md:basis-1/2 lg:basis-1/3\">\n <a href={`/blog/${post.slug}`} className=\"flex flex-col group\">\n <div className=\"w-full h-64 mb-6 overflow-hidden rounded-2xl\">\n <PhotoWithFallback\n item={post}\n fallbackId={post.id}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n \n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {formatDate(post.published_at)}\n </p>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-4 group-hover:underline line-clamp-2\">\n {post.title}\n </h3>\n \n {excerpt && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-4 line-clamp-3\">\n {excerpt}\n </p>\n )}\n </a>\n </Carousel.Item>\n );\n })}\n </Carousel.Content>\n </Carousel.Root>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">{emptyMessage}</p>\n </div>\n )}\n\n {/* View All Posts Button */}\n {postsArray.length > 0 && viewAllText && (\n <div className=\"mt-12 text-center\">\n <Button\n href={viewAllHref}\n color=\"primary\"\n size=\"md\"\n >\n {viewAllText}\n </Button>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('blog-section', 'barelux', BlogSection);\n","\"use client\";\n\nimport React, { useState } from 'react';\nimport { PhotoWithFallback, PaginationPageDefault } from '../elements';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface BlogGalleryProps {\n blogPosts?: BlogPost[] | null;\n postsPerPage?: number;\n className?: string;\n title?: string;\n subtitle?: string;\n recentLabel?: string;\n emptyMessage?: string;\n}\n\nexport const BlogGallery = ({\n blogPosts: postsData,\n postsPerPage = 12,\n className = \"\",\n title = \"\",\n subtitle = \"\",\n recentLabel = \"Recent\",\n emptyMessage = \"No posts available\",\n}: BlogGalleryProps) => {\n const posts = Array.isArray(postsData) ? postsData : [];\n const [currentPage, setCurrentPage] = useState(1);\n\n // Get featured post (first post with featured: true or first post)\n const featuredPost = posts.find((post) => post.featured) || posts[0];\n const nonFeaturedPosts = posts.filter((post) => post.id !== featuredPost?.id);\n \n // Calculate pagination for non-featured posts\n const totalPages = Math.ceil(nonFeaturedPosts.length / postsPerPage);\n const startIndex = (currentPage - 1) * postsPerPage;\n const endIndex = startIndex + postsPerPage;\n const paginatedNonFeaturedPosts = nonFeaturedPosts.slice(startIndex, endIndex);\n\n return (\n <section className={`py-16 md:py-20 lg:py-24 bg-primary ${className}`}>\n <div className=\"mx-auto max-w-7xl px-4 md:px-8\">\n {/* Section Header */}\n <div className=\"mx-auto max-w-3xl text-center mb-12 md:mb-16\">\n <h1 className=\"font-display text-4xl font-medium text-fg-primary md:text-5xl mb-4\">\n {title}\n </h1>\n <p className=\"font-body text-lg text-secondary leading-normal\">\n {subtitle}\n </p>\n </div>\n\n {posts.length > 0 ? (\n <>\n {/* Featured Post - Full Width */}\n {featuredPost && (\n <a\n href={`/blog/${featuredPost.slug}`}\n className=\"block mb-16 group\"\n >\n <div className=\"w-full h-96 md:h-[500px] mb-8 overflow-hidden rounded-2xl\">\n <PhotoWithFallback\n item={featuredPost}\n fallbackId={featuredPost.id}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n \n <div className=\"max-w-3xl\">\n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-4\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {featuredPost.published_at ? new Date(featuredPost.published_at).toLocaleDateString('en-US', { month: 'long', day: 'numeric', year: 'numeric' }) : recentLabel}\n </p>\n \n <h2 className=\"font-display text-3xl md:text-4xl font-normal text-fg-primary mb-6 group-hover:underline\">\n {featuredPost.title}\n </h2>\n \n {featuredPost.excerpt_markdown && (\n <p className=\"font-body text-lg leading-relaxed text-tertiary\">\n {featuredPost.excerpt_markdown.replace(/[#*\\[\\]()]/g, '').trim()}\n </p>\n )}\n </div>\n </a>\n )}\n\n {/* Posts Grid */}\n {paginatedNonFeaturedPosts.length > 0 && (\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3 mb-16\">\n {paginatedNonFeaturedPosts.map((post) => {\n const excerpt = post.excerpt_markdown || post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) || '';\n \n return (\n <a key={post.id} href={`/blog/${post.slug}`} className=\"flex flex-col group\">\n <div className=\"w-full h-64 mb-6 overflow-hidden rounded-2xl\">\n <PhotoWithFallback\n item={post}\n fallbackId={post.id}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n \n <p className=\"text-xs font-body font-normal uppercase tracking-widest mb-2\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {post.published_at ? new Date(post.published_at).toLocaleDateString('en-US', { month: 'long', day: 'numeric', year: 'numeric' }) : recentLabel}\n </p>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-4 group-hover:underline line-clamp-2\">\n {post.title}\n </h3>\n \n {excerpt && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-4 flex-grow line-clamp-3\">\n {excerpt}\n </p>\n )}\n </a>\n );\n })}\n </div>\n )}\n\n {/* Pagination */}\n {totalPages > 1 && (\n <div className=\"flex justify-center\">\n <PaginationPageDefault \n rounded \n page={currentPage}\n total={totalPages}\n onPageChange={setCurrentPage}\n />\n </div>\n )}\n </>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">{emptyMessage}</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('blog-gallery', 'barelux', BlogGallery);\n","import { PhotoWithFallback } from '../elements';\nimport { isVideoUrl } from '../../utils/photo-helpers';\nimport type { SocialPost } from '../../types/api/social-post';\n\n/** Get display image URLs from post (excludes video URLs so img/PhotoWithFallback don't break) */\nfunction getPostImageUrls(post: SocialPost): string[] {\n const videoSet = post.video_urls?.length ? new Set(post.video_urls) : null;\n const isVideo = (url: string) => isVideoUrl(url) || (videoSet !== null && videoSet.has(url));\n if (post.image_urls?.length) {\n return post.image_urls.filter((url) => !isVideo(url));\n }\n const attachments = post.photo_attachments || [];\n const sorted = [...attachments].sort((a, b) => (a.sort_order ?? 0) - (b.sort_order ?? 0));\n return sorted\n .map((pa) => pa.photo?.large_url || pa.photo?.original_url || pa.photo?.medium_url || pa.photo?.thumbnail_url)\n .filter((url): url is string => Boolean(url))\n .filter((url) => !isVideo(url));\n}\n\ninterface SocialMediaGridProps {\n socialPosts?: SocialPost[] | null;\n title?: string;\n subtitle?: string;\n recentLabel?: string;\n viewOnLabel?: string;\n emptyMessage?: string;\n}\n\nconst formatDate = (dateString?: string, recentLabel: string = \"Recent\") => {\n if (!dateString) return recentLabel;\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n year: 'numeric',\n month: 'short',\n day: 'numeric'\n });\n } catch {\n return recentLabel;\n }\n};\n\nconst getPlatformColor = (platform?: string) => {\n const platformLower = platform?.toLowerCase() || '';\n const colors: Record<string, string> = {\n facebook: '#1877F2',\n instagram: '#E4405F',\n twitter: '#1DA1F2',\n linkedin: '#0A66C2',\n youtube: '#FF0000',\n };\n return colors[platformLower] || '#6B625E';\n};\n\nexport const SocialMediaGrid = ({\n socialPosts: postsData,\n title = \"\",\n subtitle = \"\",\n recentLabel = \"Recent\",\n viewOnLabel = \"View on\",\n emptyMessage = \"No posts available\",\n}: SocialMediaGridProps) => {\n const posts = Array.isArray(postsData) ? postsData : [];\n\n return (\n <section className=\"py-16 md:py-20 lg:py-24 bg-primary\">\n <div className=\"mx-auto max-w-7xl px-4 md:px-8\">\n {/* Section Header - Centered */}\n <div className=\"mx-auto max-w-3xl text-center mb-12 md:mb-16\">\n <h2 className=\"font-display text-4xl font-medium text-fg-primary md:text-5xl mb-4\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"font-body text-lg text-secondary leading-normal\">\n {subtitle}\n </p>\n )}\n </div>\n\n {posts.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-8 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4\">\n {posts.map((post) => {\n const images = getPostImageUrls(post);\n const firstImage = images[0] || '';\n const content = post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const platform = post.platform || 'social';\n const platformColor = getPlatformColor(platform);\n \n return (\n <div key={post.id} className=\"flex flex-col bg-white rounded-2xl overflow-hidden shadow-sm hover:shadow-md transition-shadow duration-300\">\n <div className=\"w-full h-64 overflow-hidden\">\n <PhotoWithFallback\n item={post}\n photoUrl={firstImage}\n photoAlt={content.substring(0, 50) || ''}\n fallbackId={post.id}\n className=\"w-full h-full object-cover transition-transform duration-300 hover:scale-105\"\n />\n </div>\n \n <div className=\"p-6 flex flex-col flex-grow\">\n <div className=\"flex items-center justify-between mb-4\">\n <span \n className=\"text-xs font-body font-semibold uppercase tracking-wide px-3 py-1.5 rounded-full text-white\"\n style={{ backgroundColor: platformColor }}\n >\n {platform}\n </span>\n <span className=\"text-xs font-body\" style={{ color: 'var(--color-text-brand-secondary)' }}>\n {formatDate(post.posted_at, recentLabel)}\n </span>\n </div>\n\n {content && (\n <p className=\"font-body text-sm text-tertiary mb-4 flex-grow line-clamp-4\">\n {content}\n </p>\n )}\n\n {post.platform && (\n <a\n href={post.external_post_url || `https://${platform.toLowerCase()}.com`}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"font-body text-sm underline underline-offset-4 hover:no-underline mt-auto transition-colors\"\n style={{ color: 'var(--color-text-brand-accent)' }}\n >\n {viewOnLabel} {platform.charAt(0).toUpperCase() + platform.slice(1)}\n </a>\n )}\n </div>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">{emptyMessage}</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('social-media-grid', 'barelux', SocialMediaGrid);\n","import React from \"react\";\nimport { PhotoWithFallback } from '../elements';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { FormDefinition } from '../../types/api/form';\nimport type { SiteConfig } from '../../types/config';\nimport { ContactSectionForm } from './contact-section-form.barelux';\n\nfunction getLegalUrlsFromConfig(config: SiteConfig | null | undefined): { privacyPolicyUrl?: string; termsOfServiceUrl?: string } {\n if (!config?.navigation?.footer) return {};\n const flat = config.navigation.footer.flat();\n const privacy = flat.find((l) => l.label === 'Privacy Policy')?.href;\n const terms = flat.find((l) => l.label === 'Terms of Service')?.href;\n return { privacyPolicyUrl: privacy, termsOfServiceUrl: terms };\n}\n\ninterface ContactSectionProps {\n websitePhotos?: WebsitePhotos | null;\n title?: string;\n subtitle?: string;\n formDefinition?: FormDefinition | null;\n config?: SiteConfig | null;\n}\n\nconst ContactSection = ({\n websitePhotos,\n title = \"\",\n subtitle = \"\",\n formDefinition,\n config,\n}: ContactSectionProps) => {\n const { privacyPolicyUrl, termsOfServiceUrl } = getLegalUrlsFromConfig(config);\n const contactPhoto = websitePhotos?.contact;\n const contactImageUrl = contactPhoto?.url;\n const finalContactImage = contactImageUrl && contactImageUrl.trim() !== \"\" ? contactImageUrl : undefined;\n const finalContactImageAlt = contactPhoto?.alt || \"Contact image\";\n\n return (\n <section className=\"py-16 md:py-20 lg:py-24 bg-primary\">\n <div className=\"mx-auto max-w-7xl px-4 md:px-8\">\n <div className=\"grid grid-cols-1 lg:grid-cols-2 gap-12 lg:gap-16\">\n {/* Left Column - Form */}\n <div>\n <h2 className=\"font-display text-4xl font-medium text-fg-primary md:text-5xl mb-6\">\n {title}\n </h2>\n <p className=\"font-body text-lg text-secondary leading-relaxed mb-8\">\n {subtitle}\n </p>\n\n <ContactSectionForm\n formDefinition={formDefinition}\n privacyPolicyUrl={privacyPolicyUrl}\n termsOfServiceUrl={termsOfServiceUrl}\n />\n </div>\n\n {/* Right Column - Image (full height next to form) */}\n {finalContactImage && (\n <div className=\"max-lg:hidden relative h-full min-h-0 overflow-hidden rounded-lg\">\n <PhotoWithFallback\n photoUrl={finalContactImage}\n photoAlt={finalContactImageAlt}\n fallbackId=\"contact-barelux\"\n className=\"h-full w-full object-cover rounded-lg\"\n />\n </div>\n )}\n </div>\n </div>\n </section>\n );\n};\n\nexport default ContactSection;\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('contact-section', 'barelux', ContactSection);\n","\"use client\";\n\nimport React, { useRef, useState } from 'react';\nimport { Form, Button } from '../elements';\nimport { DynamicFormFields } from '../components/DynamicFormFields';\nimport { firePixelEvent, setPixelUserData } from '../../tracking/firePixelEvent';\nimport { captureEvent } from '../../tracking/captureEvent';\nimport type { FormDefinition } from '../../types/api/form';\nimport { useFormDefinitions } from '../../next/contexts/form-definitions';\n\ninterface ContactSectionFormBareluxProps {\n formDefinition: FormDefinition | null | undefined;\n submitButtonText?: string;\n successMessage?: string;\n thankYouMessage?: string;\n onSuccess?: () => void;\n privacyPolicyUrl?: string;\n termsOfServiceUrl?: string;\n}\n\nexport const ContactSectionForm = ({\n formDefinition,\n submitButtonText = \"Send message\",\n successMessage = \"Thank you for contacting us! We'll get back to you soon.\",\n thankYouMessage,\n onSuccess,\n privacyPolicyUrl,\n termsOfServiceUrl,\n}: ContactSectionFormBareluxProps) => {\n const { leadFormDefinition } = useFormDefinitions();\n const resolvedFormDefinition = formDefinition ?? leadFormDefinition;\n const [isSubmitting, setIsSubmitting] = useState(false);\n const [submitStatus, setSubmitStatus] = useState<'idle' | 'success' | 'error'>('idle');\n const [statusMessage, setStatusMessage] = useState<string>('');\n const formRef = useRef<HTMLFormElement>(null);\n\n const hasFields =\n resolvedFormDefinition != null &&\n Array.isArray(resolvedFormDefinition.fields) &&\n resolvedFormDefinition.fields.length > 0;\n\n const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n setIsSubmitting(true);\n setSubmitStatus('idle');\n setStatusMessage('');\n const formData = new FormData(e.currentTarget);\n const data: Record<string, string> = { formType: 'lead' };\n formData.forEach((value, key) => {\n if (key.endsWith('_prefix')) return;\n if (typeof value === 'string') data[key] = value;\n });\n try {\n const response = await fetch('/api/form/', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(data),\n });\n const result = await response.json();\n if (result.success) {\n setSubmitStatus('success');\n setStatusMessage(result.message || successMessage);\n formRef.current?.reset();\n onSuccess?.();\n await setPixelUserData({ email: data.email, phone: data.phone });\n firePixelEvent('Lead', undefined, result.eventId);\n captureEvent('form_submitted', { form_type: 'lead', ...(result.eventId && { event_id: result.eventId }) });\n setTimeout(() => setSubmitStatus('idle'), 5000);\n } else {\n const errorMsg = result.error || 'Something went wrong. Please try again.';\n setSubmitStatus('error');\n setStatusMessage(errorMsg);\n captureEvent('form_failed', { form_type: 'lead', error: errorMsg });\n }\n } catch {\n setSubmitStatus('error');\n setStatusMessage('Network error. Please try again later.');\n captureEvent('form_failed', { form_type: 'lead', error: 'network_error' });\n }\n setIsSubmitting(false);\n };\n\n if (!hasFields) return null;\n\n return (\n <Form ref={formRef} onSubmit={handleSubmit} className=\"flex flex-col gap-6\">\n <DynamicFormFields\n form={resolvedFormDefinition}\n privacyPolicyUrl={privacyPolicyUrl}\n termsOfServiceUrl={termsOfServiceUrl}\n />\n <Button\n type=\"submit\"\n color=\"primary\"\n size=\"md\"\n className=\"w-full\"\n isDisabled={isSubmitting}\n isLoading={isSubmitting}\n >\n {submitStatus === 'success' ? successMessage.split('!')[0] + '!' : (isSubmitting ? 'Sending...' : submitButtonText)}\n </Button>\n {submitStatus === 'success' && (\n <div className=\"font-body text-sm text-center\" style={{ color: 'var(--color-text-brand-accent)' }}>\n {thankYouMessage ?? statusMessage}\n </div>\n )}\n {submitStatus === 'error' && (\n <div className=\"rounded-lg bg-error-50 p-4 text-error-700 font-body text-sm text-center\">{statusMessage}</div>\n )}\n </Form>\n );\n};\n","import Link from \"next/link\";\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { SiteConfig } from '../../types/config';\nimport { SocialIcon } from '../elements';\n\ninterface FooterHomeProps {\n config?: SiteConfig;\n companyInformation?: CompanyInformation | null;\n rightsText?: string;\n}\n\nconst COLUMN_TITLES = ['Home', 'Services', 'Locations', 'About Us'];\n\nfunction buildSocialLinks(ci: CompanyInformation | null | undefined) {\n const links: { platform: string; url: string }[] = [];\n if (!ci) return links;\n if (ci.facebook_url) links.push({ platform: 'facebook', url: ci.facebook_url });\n if (ci.instagram_url) links.push({ platform: 'instagram', url: ci.instagram_url });\n if (ci.tiktok_url) links.push({ platform: 'tiktok', url: ci.tiktok_url });\n if (ci.linkedin_url) links.push({ platform: 'linkedin', url: ci.linkedin_url });\n if (ci.twitter_url) links.push({ platform: 'twitter', url: ci.twitter_url });\n if (ci.youtube_url) links.push({ platform: 'youtube', url: ci.youtube_url });\n if (ci.pinterest_url) links.push({ platform: 'pinterest', url: ci.pinterest_url });\n if (ci.google_my_business_url) links.push({ platform: 'google_my_business', url: ci.google_my_business_url });\n if (ci.yelp_url) links.push({ platform: 'yelp', url: ci.yelp_url });\n if (ci.tripadvisor_url) links.push({ platform: 'tripadvisor', url: ci.tripadvisor_url });\n if (ci.google_reviews_url) links.push({ platform: 'google_reviews', url: ci.google_reviews_url });\n return links;\n}\n\nexport const FooterHome = ({\n config,\n companyInformation,\n rightsText = \"All rights reserved\",\n}: FooterHomeProps) => {\n const currentYear = new Date().getFullYear();\n \n const footerColumns = config?.navigation?.footer || [];\n const companyName = companyInformation?.company_name || '';\n const socialLinks = buildSocialLinks(companyInformation);\n\n return (\n <footer className=\"bg-secondary border-t border-primary py-12 md:py-16\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-4\">\n {footerColumns.map((column, i) => (\n <div key={i}>\n <h4 className=\"font-body text-sm font-semibold uppercase tracking-wider text-fg-primary mb-4\">\n {COLUMN_TITLES[i] || `Column ${i + 1}`}\n </h4>\n <ul className=\"space-y-3\">\n {column.map((link, j) => (\n <li key={j}>\n <Link\n href={link.href}\n className=\"font-body text-sm text-tertiary hover:text-brand-accent transition-colors\"\n >\n {link.label}\n </Link>\n </li>\n ))}\n </ul>\n </div>\n ))}\n </div>\n\n {socialLinks.length > 0 && (\n <div className=\"flex flex-wrap justify-center gap-4 mt-10\">\n {socialLinks.map(({ platform, url }) => (\n <a\n key={platform}\n href={url}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"text-tertiary hover:text-brand-accent transition-colors\"\n aria-label={platform}\n >\n <SocialIcon platform={platform} className=\"w-6 h-6 flex-shrink-0\" />\n </a>\n ))}\n </div>\n )}\n \n <div className=\"mt-12 pt-8 border-t border-secondary text-center\">\n <p className=\"font-body text-sm text-tertiary\">\n © {currentYear} {companyName}. {rightsText}\n </p>\n </div>\n </div>\n </footer>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('footer-home', 'barelux', FooterHome);\n","\"use client\";\n\nimport { Fragment, useState } from \"react\";\nimport React from \"react\";\nimport { PhotoWithFallback, VideoModal, VideoPlayButton, Button } from '../elements';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport { resolveCtaUrls, isExternalCtaUrl } from '../../lib/cta-urls';\n\ninterface HeroHomeProps {\n websitePhotos?: WebsitePhotos | null;\n companyInformation?: CompanyInformation | null;\n headline?: string;\n subhead?: string;\n ctaText?: string;\n /** Optional route override for the main CTA. When not set, uses primary CTA URL (booking or /contact) from company info. */\n ctaHref?: string;\n reviews?: { rating: number; count: number };\n onEmailSubmit?: (email: string) => void;\n videoUrl?: string;\n}\n\nexport const HeroHome = ({\n websitePhotos,\n companyInformation,\n headline = \"\",\n subhead = \"\",\n ctaText = \"\",\n ctaHref,\n videoUrl,\n}: HeroHomeProps) => {\n const [showVideo, setShowVideo] = useState(false);\n const resolved = companyInformation ? resolveCtaUrls(companyInformation) : null;\n const effectiveCtaHref = ctaHref ?? resolved?.primaryHref ?? '/contact';\n \n const heroImage = {\n url: websitePhotos?.hero?.url || '',\n alt: websitePhotos?.hero?.alt || 'Hero image',\n };\n\n return (\n <Fragment>\n <section className=\"bg-primary py-20 md:py-28\">\n <div className=\"mx-auto max-w-4xl px-4 text-center md:px-8\">\n <h1 className=\"font-display text-5xl font-normal leading-tight text-fg-primary md:text-6xl lg:text-7xl\">\n {headline}\n </h1>\n \n <p className=\"mt-6 font-body text-lg leading-relaxed text-secondary md:text-xl max-w-3xl mx-auto\">\n {subhead}\n </p>\n\n {ctaText && (\n <div className=\"mt-10\">\n <Button\n as=\"a\"\n href={effectiveCtaHref}\n target={isExternalCtaUrl(effectiveCtaHref) ? '_blank' : undefined}\n rel={isExternalCtaUrl(effectiveCtaHref) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n size=\"xl\"\n className=\"font-body font-medium\"\n >\n {ctaText}\n </Button>\n </div>\n )}\n </div>\n </section>\n\n <section className=\"bg-primary\">\n <div className=\"mx-auto max-w-container px-4 md:px-8 pb-16 md:pb-24\">\n <div className=\"relative w-full h-[450px] md:h-[550px] lg:h-[650px] overflow-hidden\">\n <PhotoWithFallback\n photoUrl={heroImage.url}\n photoAlt={heroImage.alt}\n fallbackId=\"hero-home-balance\"\n className=\"w-full h-full object-cover\"\n />\n \n {/* Video play button overlay */}\n {videoUrl && (\n <div className=\"absolute inset-0 flex items-center justify-center\">\n <VideoPlayButton onClick={() => setShowVideo(true)} />\n </div>\n )}\n </div>\n </div>\n </section>\n \n {/* Video modal */}\n {videoUrl && (\n <VideoModal \n isOpen={showVideo}\n onClose={() => setShowVideo(false)}\n videoUrl={videoUrl}\n />\n )}\n </Fragment>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('hero-home', 'balance', HeroHome);\n","\"use client\";\n\nimport React, { useState, useRef, useCallback } from 'react';\nimport Link from 'next/link';\nimport Image from 'next/image';\nimport { usePathname } from 'next/navigation';\nimport { Button } from '../elements';\nimport { getLogoUrl } from '../../utils/photo-helpers';\nimport type { HeaderComponentProps } from './header-navigation';\nimport type { NavItem } from '../../types/config';\nimport { resolveCtaUrls, isExternalCtaUrl, resolvePortalPath } from '../../lib/cta-urls';\n\nexport function HeaderNavigation({ \n props, \n navigation: navigationOverride, \n logoImage: logoImageOverride, \n logoText: logoTextOverride, \n config,\n companyInformation,\n websitePhotos,\n}: HeaderComponentProps) {\n const [activeDropdown, setActiveDropdown] = useState<string | null>(null);\n const [isMobileMenuOpen, setIsMobileMenuOpen] = useState(false);\n \n const closeTimeoutRef = useRef<NodeJS.Timeout | null>(null);\n \n React.useEffect(() => {\n return () => {\n if (closeTimeoutRef.current) {\n clearTimeout(closeTimeoutRef.current);\n }\n };\n }, []);\n \n const logoUrl = logoImageOverride || getLogoUrl(websitePhotos) || props?.logo?.image;\n const companyName = logoTextOverride || companyInformation?.company_name || props?.logo?.text || '';\n \n const navigation = navigationOverride || config?.navigation?.header || [];\n const resolvedCtaUrls = resolveCtaUrls(companyInformation);\n const ctaUrls = {\n primaryHref: props?.cta_button?.secondary_href ?? resolvedCtaUrls.primaryHref,\n secondaryHref: props?.cta_button?.href ?? resolvedCtaUrls.secondaryHref,\n hasSecondary: props?.cta_button?.secondary_href != null || resolvedCtaUrls.hasSecondary,\n };\n\n // Hide the sticky bottom bar when the user is already on the portal page —\n // the portal has its own Book Now tab so the bar is redundant and confusing.\n const pathname = usePathname();\n const portalPath = resolvePortalPath(companyInformation);\n const isPortalPage = portalPath ? pathname?.startsWith(portalPath) : false;\n\n const cancelCloseTimeout = useCallback(() => {\n if (closeTimeoutRef.current) {\n clearTimeout(closeTimeoutRef.current);\n closeTimeoutRef.current = null;\n }\n }, []);\n\n const handleMouseEnter = useCallback((item: NavItem) => {\n cancelCloseTimeout();\n if (item.children && item.children.length > 0) {\n setActiveDropdown(item.label);\n } else {\n setActiveDropdown(null);\n }\n }, [cancelCloseTimeout]);\n\n const handleMouseLeave = useCallback(() => {\n cancelCloseTimeout();\n closeTimeoutRef.current = setTimeout(() => {\n setActiveDropdown(null);\n }, 150);\n }, [cancelCloseTimeout]);\n\n const handleDropdownMouseEnter = useCallback(() => {\n cancelCloseTimeout();\n }, [cancelCloseTimeout]);\n\n const handleDropdownMouseLeave = useCallback(() => {\n handleMouseLeave();\n }, [handleMouseLeave]);\n\n return (\n <>\n {/* Desktop Header */}\n <header className=\"hidden md:block sticky top-0 z-50 bg-primary\" style={{ borderBottom: '3px solid rgb(217, 191, 168)' }}>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"relative flex items-center justify-between py-5\">\n {/* Left: Logo only */}\n <Link href={props?.logo?.href || '/'} className=\"flex items-center z-10\">\n {logoUrl ? (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-12 w-auto object-contain\"\n width={180}\n height={48}\n />\n ) : (\n <div className=\"flex flex-col\">\n <span className=\"font-display text-2xl font-normal\" style={{ color: 'rgb(148, 102, 76)' }}>\n {companyName}\n </span>\n <span className=\"font-body text-xs tracking-widest uppercase\" style={{ color: 'rgb(148, 102, 76)', opacity: 0.7 }}>\n Concierge Cosmetic Injections\n </span>\n </div>\n )}\n </Link>\n\n {/* Center: Navigation - absolutely positioned to center in full width */}\n <nav className=\"absolute left-1/2 top-1/2 -translate-x-1/2 -translate-y-1/2 flex items-center gap-1\">\n {navigation.map((item) => (\n <div\n key={item.label}\n className=\"relative\"\n onMouseEnter={() => handleMouseEnter(item)}\n onMouseLeave={handleMouseLeave}\n >\n {item.href ? (\n <Link\n href={item.href}\n className=\"font-display text-xl font-semibold px-5 py-2\"\n style={{ color: 'rgb(170, 143, 123)' }}\n >\n {item.label}\n </Link>\n ) : (\n <span className=\"font-display text-xl font-semibold px-5 py-2 cursor-pointer\" style={{ color: 'rgb(170, 143, 123)' }}>\n {item.label}\n </span>\n )}\n\n {/* Dropdown */}\n {item.children && item.children.length > 0 && activeDropdown === item.label && (\n <div\n className=\"absolute left-0 top-full pt-2\"\n onMouseEnter={handleDropdownMouseEnter}\n onMouseLeave={handleDropdownMouseLeave}\n >\n <div className=\"balance-dropdown-panel bg-primary border border-secondary shadow-md min-w-48 py-2\">\n {item.children.map((child) => (\n <Link\n key={child.href}\n href={child.href}\n className=\"block font-display text-sm hover:bg-secondary/10 px-4 py-2\"\n style={{ color: 'rgb(170, 143, 123)' }}\n >\n {child.label}\n </Link>\n ))}\n </div>\n </div>\n )}\n </div>\n ))}\n </nav>\n\n {/* Right: CTA Buttons */}\n <div className=\"flex items-center gap-3 flex-shrink-0 z-10\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n target={props.cta_button.secondary_target}\n rel={props.cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"secondary\"\n size=\"sm\"\n >\n {props.cta_button.label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n target={props?.cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(props?.cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n size=\"sm\"\n >\n {(props?.cta_button?.secondary_label && ctaUrls.hasSecondary) ? props.cta_button.secondary_label : (props?.cta_button?.label || \"\")}\n </Button>\n </div>\n </div>\n </div>\n </header>\n\n {/* Mobile Header */}\n <header className=\"md:hidden sticky top-0 z-50 bg-primary\" style={{ borderBottom: '3px solid rgb(217, 191, 168)' }}>\n <div className=\"flex items-center justify-between px-4 py-4\">\n <button\n onClick={() => setIsMobileMenuOpen(true)}\n className=\"text-fg-primary\"\n aria-label=\"Open menu\"\n >\n <svg className=\"w-6 h-6\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M4 6h16M4 12h16M4 18h16\" />\n </svg>\n </button>\n \n <Link href={props?.logo?.href || '/'} className=\"flex items-center\">\n {logoUrl ? (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-8 w-auto object-contain\"\n width={120}\n height={32}\n />\n ) : (\n <span className=\"font-display text-lg font-normal text-fg-primary\">\n {companyName}\n </span>\n )}\n </Link>\n \n <div className=\"w-6\" />\n </div>\n </header>\n\n {/* Mobile Full-Screen Menu Overlay */}\n {isMobileMenuOpen && (\n <div className=\"balance-mobile-menu fixed inset-0 bg-primary z-50 md:hidden\">\n <div className=\"flex flex-col h-full\">\n {/* Mobile Menu Header */}\n <div className=\"flex items-center justify-between px-4 py-4\" style={{ borderBottom: '3px solid rgb(217, 191, 168)' }}>\n <button\n onClick={() => setIsMobileMenuOpen(false)}\n className=\"text-fg-primary\"\n aria-label=\"Close menu\"\n >\n <svg className=\"w-6 h-6\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n \n <div className=\"flex items-center\">\n {logoUrl ? (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-8 w-auto object-contain\"\n width={120}\n height={32}\n />\n ) : (\n <span className=\"font-display text-lg font-normal text-fg-primary\">\n {companyName}\n </span>\n )}\n </div>\n \n <div className=\"w-6\" />\n </div>\n\n {/* Mobile Menu Links */}\n <nav className=\"flex-1 overflow-y-auto px-4 py-8\">\n <ul className=\"space-y-4\">\n {navigation.map((item) => (\n <li key={item.label}>\n <Link\n href={item.href || '#'}\n className=\"block font-display text-base font-semibold py-2\"\n style={{ color: 'rgb(170, 143, 123)' }}\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {item.label}\n </Link>\n {item.children && item.children.length > 0 && (\n <ul className=\"ml-4 mt-2 space-y-2\">\n {item.children.map((child) => (\n <li key={child.href}>\n <Link\n href={child.href}\n className=\"block font-body text-sm py-1\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {child.label}\n </Link>\n </li>\n ))}\n </ul>\n )}\n </li>\n ))}\n </ul>\n </nav>\n\n {/* Mobile Menu Footer with CTA Buttons */}\n <div className=\"px-4 py-6\" style={{ borderTop: '1px solid rgb(217, 191, 168)' }}>\n <div className=\"flex flex-col gap-3\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n color=\"secondary\"\n size=\"sm\"\n className=\"w-full\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {props.cta_button.secondary_label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n color=\"primary\"\n size=\"sm\"\n className=\"w-full\"\n onClick={() => setIsMobileMenuOpen(false)}\n >\n {props?.cta_button?.label || \"\"}\n </Button>\n </div>\n </div>\n </div>\n </div>\n )}\n\n {/* Sticky Bottom Bar (mobile only) — hidden on portal page where it would be redundant */}\n {!isPortalPage && <div className=\"fixed bottom-0 left-0 right-0 z-40 md:hidden\" style={{ backgroundColor: 'rgb(148, 133, 84)' }}>\n <div className=\"flex gap-0\">\n {props?.cta_button?.secondary_label && ctaUrls.hasSecondary && (\n <Button\n href={ctaUrls.secondaryHref}\n target={props.cta_button.secondary_target}\n rel={props.cta_button.secondary_target === '_blank' ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className=\"flex-1 font-body text-sm uppercase tracking-wide py-4 rounded-none\"\n style={{ borderRight: '1px solid rgba(255, 255, 255, 0.2)' }}\n >\n {props.cta_button.label}\n </Button>\n )}\n <Button\n href={ctaUrls.primaryHref}\n target={props?.cta_button?.target ?? (isExternalCtaUrl(ctaUrls.primaryHref) ? '_blank' : undefined)}\n rel={(props?.cta_button?.target === '_blank' || isExternalCtaUrl(ctaUrls.primaryHref)) ? 'noopener noreferrer' : undefined}\n color=\"primary\"\n className={`${props?.cta_button?.secondary_label && ctaUrls.hasSecondary ? 'flex-1' : 'w-full'} font-body text-sm uppercase tracking-wide py-4 rounded-none`}\n >\n {(props?.cta_button?.secondary_label && ctaUrls.hasSecondary) ? props.cta_button.secondary_label : (props?.cta_button?.label || \"Contact\")}\n </Button>\n </div>\n </div>}\n </>\n );\n}\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('header-navigation', 'balance', HeaderNavigation);\n","import Link from \"next/link\";\nimport Image from 'next/image';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { SiteConfig } from '../../types/config';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport { getLogoUrl } from '../../utils/photo-helpers';\nimport { SocialIcon } from '../elements';\n\ninterface FooterHomeProps {\n config?: SiteConfig;\n companyInformation?: CompanyInformation | null;\n websitePhotos?: WebsitePhotos | null;\n}\n\nexport const FooterHome = ({\n config,\n companyInformation,\n websitePhotos,\n}: FooterHomeProps) => {\n const currentYear = new Date().getFullYear();\n \n const footerColumns = config?.navigation?.footer || [];\n const companyName = companyInformation?.company_name || '';\n const logoUrl = getLogoUrl(websitePhotos);\n \n const contactEmail = companyInformation?.primary_email;\n\n const socialLinks: { platform: string; url: string }[] = [];\n const c = companyInformation;\n if (c?.facebook_url) socialLinks.push({ platform: 'facebook', url: c.facebook_url });\n if (c?.instagram_url) socialLinks.push({ platform: 'instagram', url: c.instagram_url });\n if (c?.tiktok_url) socialLinks.push({ platform: 'tiktok', url: c.tiktok_url });\n if (c?.linkedin_url) socialLinks.push({ platform: 'linkedin', url: c.linkedin_url });\n if (c?.twitter_url) socialLinks.push({ platform: 'twitter', url: c.twitter_url });\n if (c?.youtube_url) socialLinks.push({ platform: 'youtube', url: c.youtube_url });\n if (c?.pinterest_url) socialLinks.push({ platform: 'pinterest', url: c.pinterest_url });\n if (c?.google_my_business_url) socialLinks.push({ platform: 'google_my_business', url: c.google_my_business_url });\n if (c?.yelp_url) socialLinks.push({ platform: 'yelp', url: c.yelp_url });\n if (c?.tripadvisor_url) socialLinks.push({ platform: 'tripadvisor', url: c.tripadvisor_url });\n if (c?.google_reviews_url) socialLinks.push({ platform: 'google_reviews', url: c.google_reviews_url });\n\n return (\n <footer className=\"bg-secondary py-16 md:py-20\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Top Section: Logo only */}\n <div className=\"text-center mb-12\">\n {logoUrl && (\n <Image \n src={logoUrl} \n alt={companyName}\n className=\"h-16 w-auto object-contain mx-auto\"\n width={140}\n height={64}\n />\n )}\n </div>\n\n {/* Navigation Grid */}\n <div className=\"grid grid-cols-2 gap-8 md:grid-cols-4 mb-12\">\n {footerColumns.map((column, i) => (\n <div key={i} className=\"text-center md:text-left\">\n <ul className=\"space-y-2\">\n {column.map((link, j) => (\n <li key={j}>\n <Link\n href={link.href}\n className=\"font-body text-sm text-secondary hover:text-brand-accent transition-colors\"\n >\n {link.label}\n </Link>\n </li>\n ))}\n </ul>\n </div>\n ))}\n </div>\n\n {/* Contact Info - Email only */}\n {contactEmail && (\n <div className=\"text-center mb-8\">\n <p className=\"font-body text-sm text-secondary\">\n <a href={`mailto:${contactEmail}`} className=\"hover:text-brand-accent transition-colors\">\n {contactEmail}\n </a>\n </p>\n </div>\n )}\n \n {/* Social Media Icons - all available profiles from company info */}\n {socialLinks.length > 0 && (\n <div className=\"flex justify-center gap-6 mb-12\">\n {socialLinks.map(({ platform, url }) => (\n <a\n key={platform}\n href={url}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"text-secondary hover:text-brand-accent transition-colors\"\n aria-label={platform}\n >\n <SocialIcon platform={platform} className=\"w-6 h-6 flex-shrink-0\" />\n </a>\n ))}\n </div>\n )}\n \n {/* Copyright */}\n <div className=\"pt-8 border-t border-primary/20 text-center\">\n <p className=\"font-body text-sm text-tertiary\">\n © {currentYear} {companyName || 'Company Name'}. All rights reserved.\n </p>\n </div>\n </div>\n </footer>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('footer-home', 'balance', FooterHome);\n","import React from 'react';\nimport { PhotoWithFallback } from '../elements';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { FormDefinition } from '../../types/api/form';\nimport type { SiteConfig } from '../../types/config';\nimport { ContactSectionForm } from './contact-section-form.balance';\n\nfunction getLegalUrlsFromConfig(config: SiteConfig | null | undefined): { privacyPolicyUrl?: string; termsOfServiceUrl?: string } {\n if (!config?.navigation?.footer) return {};\n const flat = config.navigation.footer.flat();\n const privacy = flat.find((l) => l.label === 'Privacy Policy')?.href;\n const terms = flat.find((l) => l.label === 'Terms of Service')?.href;\n return { privacyPolicyUrl: privacy, termsOfServiceUrl: terms };\n}\n\ninterface ContactSectionProps {\n websitePhotos?: WebsitePhotos | null;\n title?: string;\n subtitle?: string;\n formDefinition?: FormDefinition | null;\n config?: SiteConfig | null;\n}\n\nconst ContactSection = ({\n websitePhotos,\n title = \"\",\n subtitle = \"\",\n formDefinition,\n config,\n}: ContactSectionProps) => {\n const { privacyPolicyUrl, termsOfServiceUrl } = getLegalUrlsFromConfig(config);\n const contactPhoto = websitePhotos?.contact;\n const contactImageUrl = contactPhoto?.url;\n const finalContactImage = contactImageUrl && contactImageUrl.trim() !== \"\" ? contactImageUrl : undefined;\n const finalContactImageAlt = contactPhoto?.alt || \"Contact image\";\n\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-4xl px-4 md:px-8\">\n {/* Centered header */}\n <div className=\"text-center mb-12\">\n <h2 className=\"font-display text-4xl font-normal leading-tight text-fg-primary md:text-5xl\">\n {title}\n </h2>\n <p className=\"mt-4 font-body text-lg leading-relaxed text-tertiary max-w-2xl mx-auto\">\n {subtitle}\n </p>\n </div>\n\n {/* Image above form (mobile and desktop) */}\n {finalContactImage && (\n <div className=\"mb-12 overflow-hidden h-72 md:h-96\">\n <PhotoWithFallback\n photoUrl={finalContactImage}\n photoAlt={finalContactImageAlt}\n fallbackId=\"contact-image\"\n className=\"h-full w-full object-cover\"\n />\n </div>\n )}\n\n {/* Form centered */}\n <div className=\"max-w-2xl mx-auto\">\n <ContactSectionForm\n formDefinition={formDefinition}\n privacyPolicyUrl={privacyPolicyUrl}\n termsOfServiceUrl={termsOfServiceUrl}\n />\n </div>\n </div>\n </section>\n );\n};\n\nexport default ContactSection;\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('contact-section', 'balance', ContactSection);\n","\"use client\";\n\nimport React, { useRef, useState } from 'react';\nimport { Form, Button } from '../elements';\nimport { DynamicFormFields } from '../components/DynamicFormFields';\nimport { firePixelEvent, setPixelUserData } from '../../tracking/firePixelEvent';\nimport { captureEvent } from '../../tracking/captureEvent';\nimport type { FormDefinition } from '../../types/api/form';\nimport { useFormDefinitions } from '../../next/contexts/form-definitions';\n\ninterface ContactSectionFormBalanceProps {\n formDefinition: FormDefinition | null | undefined;\n submitButtonText?: string;\n successMessage?: string;\n thankYouMessage?: string;\n onSuccess?: () => void;\n privacyPolicyUrl?: string;\n termsOfServiceUrl?: string;\n}\n\nexport const ContactSectionForm = ({\n formDefinition,\n submitButtonText = \"Send message\",\n successMessage = \"Thank you for contacting us! We'll get back to you soon.\",\n thankYouMessage,\n onSuccess,\n privacyPolicyUrl,\n termsOfServiceUrl,\n}: ContactSectionFormBalanceProps) => {\n const { leadFormDefinition } = useFormDefinitions();\n const resolvedFormDefinition = formDefinition ?? leadFormDefinition;\n const [isSubmitting, setIsSubmitting] = useState(false);\n const [submitStatus, setSubmitStatus] = useState<'idle' | 'success' | 'error'>('idle');\n const [statusMessage, setStatusMessage] = useState<string>('');\n const formRef = useRef<HTMLFormElement>(null);\n\n const hasFields =\n resolvedFormDefinition != null &&\n Array.isArray(resolvedFormDefinition.fields) &&\n resolvedFormDefinition.fields.length > 0;\n\n const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n setIsSubmitting(true);\n setSubmitStatus('idle');\n setStatusMessage('');\n const formData = new FormData(e.currentTarget);\n const data: Record<string, string> = { formType: 'lead' };\n formData.forEach((value, key) => {\n if (key.endsWith('_prefix')) return;\n if (typeof value === 'string') data[key] = value;\n });\n try {\n const response = await fetch('/api/form/', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(data),\n });\n const result = await response.json();\n if (result.success) {\n setSubmitStatus('success');\n setStatusMessage(result.message || successMessage);\n formRef.current?.reset();\n onSuccess?.();\n await setPixelUserData({ email: data.email, phone: data.phone });\n firePixelEvent('Lead', undefined, result.eventId);\n captureEvent('form_submitted', { form_type: 'lead', ...(result.eventId && { event_id: result.eventId }) });\n setTimeout(() => setSubmitStatus('idle'), 5000);\n } else {\n const errorMsg = result.error || 'Something went wrong. Please try again.';\n setSubmitStatus('error');\n setStatusMessage(errorMsg);\n captureEvent('form_failed', { form_type: 'lead', error: errorMsg });\n }\n } catch {\n setSubmitStatus('error');\n setStatusMessage('Network error. Please try again later.');\n captureEvent('form_failed', { form_type: 'lead', error: 'network_error' });\n }\n setIsSubmitting(false);\n };\n\n if (!hasFields) return null;\n\n return (\n <Form ref={formRef} onSubmit={handleSubmit} className=\"flex flex-col gap-6\">\n <DynamicFormFields\n form={resolvedFormDefinition}\n privacyPolicyUrl={privacyPolicyUrl}\n termsOfServiceUrl={termsOfServiceUrl}\n />\n <Button\n type=\"submit\"\n color=\"primary\"\n size=\"xl\"\n className=\"w-full font-body font-medium\"\n isDisabled={isSubmitting}\n isLoading={isSubmitting}\n >\n {isSubmitting ? 'Sending...' : submitButtonText}\n </Button>\n {submitStatus === 'success' && (\n <div className=\"rounded-sm bg-success-50 p-4 text-success-700 font-body\">{thankYouMessage ?? statusMessage}</div>\n )}\n {submitStatus === 'error' && (\n <div className=\"rounded-sm bg-error-50 p-4 text-error-700 font-body text-sm\">{statusMessage}</div>\n )}\n </Form>\n );\n};\n","import { PhotoWithFallback, Button } from '../elements';\nimport type { Service } from '../../types/api/service';\n\ninterface ServicesHomeProps {\n services?: Service[] | null;\n title?: string;\n subtitle?: string;\n}\n\nexport const ServicesHome = ({\n services: servicesData,\n title = \"\",\n subtitle = \"\",\n}: ServicesHomeProps) => {\n const services = Array.isArray(servicesData) ? servicesData.slice(0, 6) : [];\n\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mb-16 text-center max-w-3xl mx-auto\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl mb-4\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"font-body text-lg text-secondary\">\n {subtitle}\n </p>\n )}\n </div>\n\n {services.length > 0 ? (\n <div className=\"grid grid-cols-1 gap-12 md:grid-cols-2 lg:grid-cols-3\">\n {services.map((service: Service) => {\n const description = service.summary || \n (service.description_markdown ? service.description_markdown.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) : '');\n \n return (\n <div key={service.id} className=\"flex flex-col group\">\n <a href={`/services/${service.slug}`} className=\"block\">\n <div className=\"w-full h-72 mb-6 overflow-hidden\">\n <PhotoWithFallback\n item={service}\n fallbackId={service.id}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-3 group-hover:text-brand-accent transition-colors\">\n {service.name}\n </h3>\n \n {description && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-6\">\n {description}\n </p>\n )}\n \n <span className=\"font-body text-sm font-medium uppercase tracking-wide\" style={{ color: 'var(--color-text-brand-accent)' }}>\n Learn More →\n </span>\n </a>\n </div>\n );\n })}\n </div>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No services available</p>\n </div>\n )}\n\n {services.length > 0 && (\n <div className=\"mt-16 text-center\">\n <Button\n as=\"a\"\n href=\"/services\"\n color=\"primary\"\n size=\"lg\"\n className=\"font-body font-medium\"\n >\n View All Services\n </Button>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('services-home', 'balance', ServicesHome);\n","import { PhotoWithFallback, Button } from '../elements';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\n\ninterface AboutHomeProps {\n companyInformation?: CompanyInformation | null;\n websitePhotos?: WebsitePhotos | null;\n tagline?: string;\n title?: string;\n subtitle?: string;\n description?: string;\n bullets?: string[];\n ctaText?: string;\n ctaHref?: string;\n}\n\nexport const AboutHome = ({\n companyInformation,\n websitePhotos,\n tagline = \"\",\n title = \"\",\n subtitle = \"\",\n description: descriptionProp,\n bullets = [],\n ctaText = \"\",\n ctaHref = \"/about\",\n}: AboutHomeProps) => {\n const description = descriptionProp || companyInformation?.about_text_markdown || '';\n const aboutImage = websitePhotos?.about;\n const companyName = companyInformation?.company_name || '';\n\n return (\n <section className=\"bg-secondary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Centered Title */}\n <div className=\"text-center mb-12 max-w-3xl mx-auto\">\n {tagline && (\n <p className=\"font-body text-xs font-semibold uppercase tracking-widest text-fg-primary mb-2\">\n {tagline}\n </p>\n )}\n <h2 className=\"font-display text-4xl font-normal leading-tight text-fg-primary md:text-5xl mb-4\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"font-body text-lg text-secondary\">\n {subtitle}\n </p>\n )}\n </div>\n\n {/* Image and Content */}\n <div className=\"grid grid-cols-1 gap-12 lg:grid-cols-2 lg:gap-16 items-center\">\n <div>\n <PhotoWithFallback\n photoUrl={aboutImage?.url || ''}\n photoAlt={aboutImage?.alt || `About ${companyName}`}\n fallbackId=\"about-balance\"\n className=\"w-full h-full object-cover min-h-[400px] md:min-h-[500px] rounded-lg\"\n />\n </div>\n\n <div className=\"flex flex-col justify-center\">\n {description && (\n <p className=\"font-body text-lg leading-relaxed text-secondary mb-8\">\n {description}\n </p>\n )}\n\n {/* Bullet Points with Checkmarks */}\n {bullets.length > 0 && (\n <ul className=\"space-y-4 mb-8 list-none\">\n {bullets.map((bullet, index) => (\n <li key={index} className=\"flex items-start gap-3\">\n <div className=\"flex-shrink-0 w-6 h-6 rounded-full border-2 border-fg-primary flex items-center justify-center mt-0.5\">\n <svg\n className=\"w-3 h-3 text-fg-primary\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n stroke=\"currentColor\"\n strokeWidth={3}\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M5 13l4 4L19 7\" />\n </svg>\n </div>\n <span className=\"font-body text-base text-fg-primary\">\n {bullet}\n </span>\n </li>\n ))}\n </ul>\n )}\n\n {ctaText && (\n <Button\n href={ctaHref}\n color=\"primary\"\n size=\"lg\"\n className=\"font-body font-medium w-fit\"\n >\n {ctaText}\n </Button>\n )}\n </div>\n </div>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('about-home', 'balance', AboutHome);\n","import React from 'react';\nimport { Avatar, Carousel, CarouselSectionWrapper } from '../elements';\nimport type { Testimonial } from '../../types/api/testimonial';\nimport { getAvatarUrl } from '../../utils/photo-helpers';\n\ninterface TestimonialsHomeProps {\n testimonials?: Testimonial[] | null;\n title?: string;\n subtitle?: string;\n perPage?: number;\n}\n\nexport const TestimonialsHome = ({\n testimonials: testimonialsData,\n title = \"\",\n subtitle = \"\",\n perPage,\n}: TestimonialsHomeProps) => {\n const testimonials = Array.isArray(testimonialsData) ? testimonialsData : [];\n const displayTestimonials = perPage ? testimonials.slice(0, perPage) : testimonials;\n\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Centered header */}\n <div className=\"text-center mb-12 max-w-3xl mx-auto\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl mb-4\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"font-body text-lg text-secondary\">\n {subtitle}\n </p>\n )}\n </div>\n\n <CarouselSectionWrapper \n title=\"\"\n hasItems={displayTestimonials.length > 0}\n emptyMessage=\"No testimonials available\"\n >\n {displayTestimonials.map((testimonial, i: number) => {\n const quote = testimonial.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n const reviewerName = testimonial.reviewer_name || 'Customer';\n const avatarUrl = getAvatarUrl(testimonial.photo_attachments, testimonial.id, reviewerName);\n const rating = testimonial.rating || 5;\n \n // Get initials from reviewer name\n const initials = reviewerName\n .split(' ')\n .map(n => n[0])\n .join('')\n .toUpperCase()\n .slice(0, 2);\n \n return (\n <Carousel.Item key={testimonial.id || i} className=\"pl-4 md:basis-1/2 lg:basis-1/3\">\n <div className=\"bg-secondary/30 p-8 h-full flex flex-col\">\n {/* Stars */}\n <div className=\"flex gap-1 mb-6\">\n {Array.from({ length: 5 }).map((_, starIdx) => (\n <svg\n key={starIdx}\n className=\"w-5 h-5\"\n style={{\n fill: starIdx < rating ? \"var(--color-text-brand-secondary)\" : \"none\",\n stroke: starIdx < rating ? \"none\" : \"var(--color-border-primary)\"\n }}\n strokeWidth=\"2\"\n viewBox=\"0 0 24 24\"\n >\n <path d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\" />\n </svg>\n ))}\n </div>\n\n {/* Quote */}\n <p className=\"font-body text-base leading-relaxed text-secondary mb-8 flex-grow\">\n "{quote}"\n </p>\n\n {/* Reviewer info */}\n <div className=\"flex items-center gap-4 pt-6 border-t border-primary/20\">\n <Avatar\n src={avatarUrl}\n alt={reviewerName}\n initials={initials}\n size=\"xl\"\n />\n <div>\n <p className=\"font-body text-sm font-medium text-fg-primary\">\n {reviewerName}\n </p>\n <p className=\"font-body text-xs text-tertiary mt-0.5\">\n Verified Customer\n </p>\n </div>\n </div>\n </div>\n </Carousel.Item>\n );\n })}\n </CarouselSectionWrapper>\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('testimonials-home', 'balance', TestimonialsHome);\n","import React from 'react';\nimport { PhotoWithFallback, Carousel, CarouselSectionWrapper, Button } from '../elements';\nimport type { BlogPost } from '../../types/api/blog-post';\n\ninterface BlogSectionProps {\n blogPosts?: BlogPost[] | null;\n title?: string;\n subtitle?: string;\n maxPosts?: number;\n}\n\nexport const BlogSection = ({\n blogPosts: postsData,\n title = \"\",\n subtitle = \"\",\n maxPosts,\n}: BlogSectionProps) => {\n \n const postsArray = Array.isArray(postsData) ? (maxPosts ? postsData.slice(0, maxPosts) : postsData) : [];\n\n const formatDate = (dateString?: string) => {\n if (!dateString) return 'Recent';\n try {\n return new Date(dateString).toLocaleDateString('en-US', {\n day: 'numeric',\n month: 'long',\n year: 'numeric'\n });\n } catch {\n return 'Recent';\n }\n };\n\n return (\n <section className=\"bg-secondary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Centered header */}\n <div className=\"text-center mb-16 max-w-3xl mx-auto\">\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl mb-4\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"font-body text-lg text-secondary\">\n {subtitle}\n </p>\n )}\n </div>\n\n <CarouselSectionWrapper \n title=\"\"\n hasItems={postsArray.length > 0}\n emptyMessage=\"No posts available\"\n >\n {postsArray.map((post: BlogPost) => {\n const excerpt = post.content_markdown?.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 150) || '';\n \n return (\n <Carousel.Item key={post.id} className=\"pl-4 md:basis-1/2 lg:basis-1/3\">\n <a href={`/blog/${post.slug}`} className=\"flex flex-col h-full group bg-primary\">\n <div className=\"w-full h-64 overflow-hidden\">\n <PhotoWithFallback\n item={post}\n fallbackId={post.id}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n \n <div className=\"p-6 flex flex-col flex-grow\">\n <p className=\"text-xs font-body font-medium uppercase tracking-wide mb-3 text-brand-accent\">\n {formatDate(post.published_at)}\n </p>\n \n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-3 group-hover:text-brand-accent transition-colors line-clamp-2\">\n {post.title}\n </h3>\n \n {excerpt && (\n <p className=\"font-body text-base leading-relaxed text-tertiary flex-grow line-clamp-3\">\n {excerpt}\n </p>\n )}\n \n <span className=\"mt-4 font-body text-sm font-medium uppercase tracking-wide\" style={{ color: 'var(--color-text-brand-accent)' }}>\n Read More →\n </span>\n </div>\n </a>\n </Carousel.Item>\n );\n })}\n </CarouselSectionWrapper>\n\n {postsArray.length > 0 && (\n <div className=\"mt-12 text-center\">\n <Button\n as=\"a\"\n href=\"/blog\"\n color=\"primary\"\n size=\"lg\"\n className=\"font-body font-medium\"\n >\n View All Posts\n </Button>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('blog-section', 'balance', BlogSection);\n","import React from 'react';\nimport { PhotoWithFallback } from '../elements';\nimport type { TeamMember } from '../../types/api/team-member';\n\ninterface TeamGridProps {\n teamMembers?: TeamMember[] | null;\n title?: string;\n subtitle?: string;\n maxMembers?: number;\n backgroundColor?: string;\n className?: string;\n}\n\nexport const TeamGrid = ({\n teamMembers: membersData,\n title = \"\",\n subtitle = \"\",\n maxMembers = 8,\n backgroundColor = \"bg-primary\",\n className = \"\",\n}: TeamGridProps) => {\n const members = Array.isArray(membersData) ? membersData : [];\n \n const displayMembers = members.slice(0, maxMembers);\n\n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mx-auto mb-12 flex w-full max-w-3xl flex-col items-center text-center\">\n {title && (\n <h2 className=\"text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 text-lg text-tertiary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {displayMembers.length > 0 ? (\n <div className=\"mt-12 md:mt-16\">\n <ul className=\"grid w-full grid-cols-1 gap-x-8 gap-y-10 sm:grid-cols-2 md:gap-y-12 lg:grid-cols-3 xl:grid-cols-4 justify-items-center\">\n {displayMembers.map((member, index) => {\n const bio = member.bio_markdown?.replace(/[#*\\[\\]()]/g, '').trim() || '';\n \n return (\n <li key={member.id || index} className=\"flex flex-col gap-5 md:gap-6 max-w-xs w-full\">\n <PhotoWithFallback\n item={member}\n fallbackId={member.id || index}\n alt={member.name || 'Team member'}\n className=\"h-78 w-full object-cover md:h-74 rounded-2xl\"\n />\n <div>\n <h3 className=\"text-lg font-semibold text-primary md:text-xl\">{member.name}</h3>\n <p className=\"text-md text-brand-secondary md:mt-0.5 md:text-lg\">\n {member.position}\n </p>\n {bio && (\n <p className=\"mt-4 text-md text-tertiary leading-relaxed\">\n {bio}\n </p>\n )}\n </div>\n </li>\n );\n })}\n </ul>\n </div>\n ) : (\n <div className=\"text-center mt-12\">\n <p className=\"text-gray-500\">No team members available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('team-grid', 'balance', TeamGrid);\n","import React from 'react';\nimport Link from 'next/link';\nimport { PhotoWithFallback } from '../elements';\nimport type { Service } from '../../types/api/service';\n\ninterface ServicesGridProps {\n services?: Service[] | null;\n title?: string;\n subtitle?: string;\n backgroundColor?: string;\n className?: string;\n}\n\nexport const ServicesGrid = ({\n services: servicesData,\n title = \"\",\n subtitle = \"\",\n backgroundColor = \"bg-secondary\",\n className = \"\",\n}: ServicesGridProps) => {\n const services = Array.isArray(servicesData) ? servicesData : [];\n\n return (\n <section className={`${backgroundColor} py-16 md:py-24 ${className}`}>\n <div className=\"mx-auto w-full max-w-container px-4 md:px-8\">\n {(title || subtitle) && (\n <div className=\"mx-auto mb-12 flex w-full max-w-3xl flex-col items-center text-center\">\n {title && (\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 font-body text-lg text-secondary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n {services.length > 0 ? (\n <ul className=\"grid grid-cols-1 gap-x-8 gap-y-10 sm:grid-cols-2 md:gap-y-12 lg:grid-cols-3\">\n {services.map((service, index) => {\n const description = service.summary ||\n (service.description_markdown ? service.description_markdown.replace(/[#*\\[\\]()]/g, '').trim().substring(0, 120) + '...' : '');\n\n const photo = service.photo_attachments?.find((pa) => pa.featured)?.photo ||\n service.photo_attachments?.[0]?.photo;\n const imageAlt = photo?.title || service.name;\n\n return (\n <li key={service.id || index}>\n <div className=\"flex flex-col gap-12 bg-secondary p-5 md:inline-flex md:gap-16 md:p-6 rounded-lg group\">\n <Link href={`/services/${service.slug}`} className=\"block\">\n <div className=\"h-48 w-full overflow-hidden rounded-lg md:h-64\">\n <PhotoWithFallback\n item={service}\n fallbackId={service.id || index}\n alt={imageAlt || \"Service image\"}\n className=\"size-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n\n <h3 className=\"font-display text-2xl font-normal text-fg-primary mt-4 mb-3 group-hover:text-brand-accent transition-colors\">\n {service.name}\n </h3>\n\n {description && (\n <p className=\"font-body text-base leading-relaxed text-tertiary mb-4\">\n {description}\n </p>\n )}\n\n <span className=\"font-body text-sm font-medium uppercase tracking-wide\" style={{ color: 'var(--color-text-brand-accent)' }}>\n Learn More →\n </span>\n </Link>\n </div>\n </li>\n );\n })}\n </ul>\n ) : (\n <div className=\"text-center py-12\">\n <p className=\"font-body text-base text-tertiary\">No services available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('services-grid', 'balance', ServicesGrid);\n","\"use client\";\n\nimport { useState } from \"react\";\nimport { motion } from \"motion/react\";\nimport { cx } from '../../utils/cx';\nimport type { FaqQuestion } from '../../types/api/faq';\n\ninterface FAQHomeProps {\n faqs: FaqQuestion[];\n title?: string;\n subtitle?: string;\n maxItems?: number;\n}\n\nexport const FAQHome = ({\n faqs: faqsData,\n title = \"\",\n subtitle = \"\",\n maxItems,\n}: FAQHomeProps) => {\n const items = Array.isArray(faqsData) ? faqsData : [];\n const [openQuestions, setOpenQuestions] = useState<Set<number>>(new Set([0]));\n\n const handleToggle = (index: number) => {\n const newSet = new Set(openQuestions);\n if (newSet.has(index)) {\n newSet.delete(index);\n } else {\n newSet.add(index);\n }\n setOpenQuestions(newSet);\n };\n\n const displayItems = maxItems ? items.slice(0, maxItems) : items;\n\n return (\n <section className=\"bg-primary py-16 md:py-24\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto flex w-full max-w-3xl flex-col items-center text-center\">\n <h2 className=\"font-display text-4xl font-normal leading-tight text-fg-primary md:text-5xl\">\n {title}\n </h2>\n <p className=\"mt-4 font-body text-lg text-secondary md:mt-5 md:text-xl\">\n {subtitle}\n </p>\n </div>\n\n {displayItems && displayItems.length > 0 ? (\n <div className=\"mx-auto mt-12 max-w-3xl md:mt-16\">\n <div className=\"flex flex-col gap-4\">\n {displayItems.map((faq, index) => (\n <div\n key={faq.id || index}\n className={cx(\n \"rounded-2xl bg-transparent p-5 transition duration-300 ease-in-out md:p-6\",\n openQuestions.has(index) && \"bg-secondary\",\n )}\n >\n <h3>\n <button\n onClick={() => handleToggle(index)}\n className=\"flex w-full cursor-pointer gap-2 rounded-md text-left outline-focus-ring select-none focus-visible:outline-2 focus-visible:outline-offset-2 md:flex-row-reverse md:gap-4\"\n >\n <span className=\"flex-1 font-display text-lg font-semibold text-fg-primary md:text-xl\">{faq.question}</span>\n <span aria-hidden=\"true\" className=\"flex size-6 items-center text-fg-quaternary\">\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <circle cx=\"12\" cy=\"12\" r=\"10\"></circle>\n <line\n className={cx(\n \"origin-center rotate-0 transition duration-150 ease-out\",\n openQuestions.has(index) && \"-rotate-90\",\n )}\n x1=\"12\"\n y1=\"8\"\n x2=\"12\"\n y2=\"16\"\n ></line>\n <line x1=\"8\" y1=\"12\" x2=\"16\" y2=\"12\"></line>\n </svg>\n </span>\n </button>\n </h3>\n\n <motion.div\n className=\"overflow-hidden\"\n initial={false}\n animate={{\n height: openQuestions.has(index) ? \"auto\" : 0,\n opacity: openQuestions.has(index) ? 1 : 0,\n }}\n transition={{\n type: \"spring\",\n damping: 24,\n stiffness: 240,\n bounce: 0.4,\n }}\n >\n <div className=\"pt-1 pr-8 md:pr-0 md:pl-10\">\n <div className=\"font-body text-base text-secondary whitespace-pre-line md:text-lg\">\n {faq.answer_markdown || ''}\n </div>\n </div>\n </motion.div>\n </div>\n ))}\n </div>\n </div>\n ) : (\n <div className=\"text-center mt-12\">\n <p className=\"font-body text-base text-secondary\">No FAQ items available</p>\n </div>\n )}\n </div>\n </section>\n );\n};\n\nimport { registerThemeVariant } from '../../lib/component-registry';\nregisterThemeVariant('faq-home', 'balance', FAQHome);\n","\"use client\";\n\nimport React, { useRef, useState } from 'react';\nimport { Form, Button } from '../elements';\nimport { DynamicFormFields } from '../components/DynamicFormFields';\nimport type { FormDefinition } from '../../types/api/form';\nimport { useFormDefinitions } from '../../next/contexts/form-definitions';\nimport { captureEvent } from '../../tracking/captureEvent';\n\nexport interface EmailSignupSectionProps {\n title?: string;\n subtitle?: string;\n buttonText?: string;\n successMessage?: string;\n /** Override the form definition (falls back to context). */\n formDefinition?: FormDefinition | null;\n}\n\nexport const EmailSignupSection = ({\n title = \"Stay in the loop\",\n subtitle = \"Subscribe to our newsletter for updates, tips, and exclusive offers.\",\n buttonText = \"Subscribe\",\n successMessage = \"You're subscribed! Thank you.\",\n formDefinition,\n}: EmailSignupSectionProps) => {\n const { marketingListSignupFormDefinition } = useFormDefinitions();\n const resolvedFormDefinition = formDefinition ?? marketingListSignupFormDefinition;\n const [isSubmitting, setIsSubmitting] = useState(false);\n const [submitStatus, setSubmitStatus] = useState<'idle' | 'success' | 'error'>('idle');\n const [statusMessage, setStatusMessage] = useState('');\n const formRef = useRef<HTMLFormElement>(null);\n\n const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n setIsSubmitting(true);\n setSubmitStatus('idle');\n setStatusMessage('');\n\n const formData = new FormData(e.currentTarget);\n const data: Record<string, string> = { formType: 'marketing_list_signup' };\n formData.forEach((value, key) => {\n if (key.endsWith('_prefix')) return;\n if (typeof value === 'string') data[key] = value;\n });\n\n try {\n const response = await fetch('/api/form/', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(data),\n });\n const result = await response.json();\n\n if (result.success) {\n setSubmitStatus('success');\n setStatusMessage(result.message || successMessage);\n formRef.current?.reset();\n captureEvent('form_submitted', { form_type: 'marketing_list_signup' });\n setTimeout(() => setSubmitStatus('idle'), 6000);\n } else {\n const errorMsg = result.error || 'Something went wrong. Please try again.';\n setSubmitStatus('error');\n setStatusMessage(errorMsg);\n captureEvent('form_failed', { form_type: 'marketing_list_signup', error: errorMsg });\n }\n } catch {\n setSubmitStatus('error');\n setStatusMessage('Network error. Please try again later.');\n captureEvent('form_failed', { form_type: 'marketing_list_signup', error: 'network_error' });\n }\n\n setIsSubmitting(false);\n };\n\n if (!resolvedFormDefinition) return null;\n\n return (\n <section className=\"bg-secondary py-16 md:py-20\">\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n <div className=\"mx-auto max-w-xl text-center\">\n <h2 className=\"font-display text-display-sm font-semibold text-primary md:text-display-md\">\n {title}\n </h2>\n {subtitle && (\n <p className=\"mt-4 font-body text-lg text-tertiary\">\n {subtitle}\n </p>\n )}\n <Form\n ref={formRef}\n onSubmit={handleSubmit}\n className=\"mt-8 flex flex-col gap-6 text-left\"\n >\n <DynamicFormFields form={resolvedFormDefinition} />\n {submitStatus === 'success' && (\n <div className=\"rounded-lg bg-success-50 p-4 text-success-700\">\n {statusMessage || successMessage}\n </div>\n )}\n {submitStatus === 'error' && (\n <div className=\"rounded-lg bg-error-50 p-4 text-error-700\">\n {statusMessage}\n </div>\n )}\n <Button\n type=\"submit\"\n color=\"primary\"\n size=\"xl\"\n isDisabled={isSubmitting}\n isLoading={isSubmitting}\n className=\"w-full\"\n >\n {isSubmitting ? 'Subscribing...' : buttonText}\n </Button>\n </Form>\n </div>\n </div>\n </section>\n );\n};\n","'use client';\n\nimport React, { useState, useEffect, useCallback } from 'react';\nimport { createPortal } from 'react-dom';\nimport { PhotoWithFallback, Carousel, Modal, MarkdownRenderer, Button } from '../elements';\nimport type { OfferPublic } from '../../types/api/offer';\nimport type { Service, ServiceItem } from '../../types/api/service';\nimport type { Package } from '../../types/api/package';\nimport type { WebsitePhotos } from '../../types/api/website-photos';\nimport type { CompanyInformation } from '../../types/api/company-information';\nimport type { PhotoAttachment } from '../../types/api/photos';\nimport { useImageCycle } from '../../lib/hooks/use-image-cycle';\n\nconst SERVICE_MENU_MODAL_ROOT_ID = 'service-menu-modal-root';\n\n/** Package with category names and first-service description fallback (derived from services). */\nexport interface PackageForMenu extends Package {\n category_names?: string[];\n first_service_description_markdown?: string | null;\n}\n\nexport interface ServiceMenuSectionProps {\n title?: string;\n subtitle?: string;\n packages?: Package[] | null;\n /** Services (used to derive service items for the third row). */\n services?: Service[] | null;\n websitePhotos?: WebsitePhotos | null;\n companyInformation?: CompanyInformation | null;\n viewAllHref?: string;\n /** Label for the View All button (e.g. \"View All\"). */\n viewAllText?: string;\n /** Customer-friendly label for the third row (individual service items). Default \"Treatments\". */\n servicesRowTitle?: string;\n /** 'section' = compact header + carousel (e.g. home). 'page' = hero + grid (e.g. /service-menu). */\n variant?: 'section' | 'page';\n}\n\n/** Service item with parent service info for display in the Service Menu (fallback description from service when item has none). */\nexport interface ServiceItemWithService extends ServiceItem {\n service_name?: string;\n service_summary?: string | null;\n service_description_markdown?: string | null;\n}\n\ntype DetailItem =\n | { type: 'package'; item: PackageForMenu }\n | { type: 'service_item'; item: ServiceItemWithService };\n\nfunction getActivePublicOffers(offers: OfferPublic[] | undefined | null): OfferPublic[] {\n if (!Array.isArray(offers) || offers.length === 0) return [];\n return offers.filter((o) => o.active !== false && o.expired !== true);\n}\n\n/** Card with image area. Cycles through photos every N ms with a simple crossfade. */\nfunction GridCardWithImage({\n photoAttachments,\n fallbackId,\n fallbackAlt,\n title,\n subtitle,\n children,\n onClick,\n websitePhotos,\n companyInformation,\n cycleSeed,\n hasSpecial,\n}: {\n photoAttachments?: PhotoAttachment[];\n fallbackId: string | number;\n fallbackAlt: string;\n title: string;\n subtitle?: string | null;\n children?: React.ReactNode;\n onClick: () => void;\n websitePhotos?: WebsitePhotos | null;\n companyInformation?: CompanyInformation | null;\n cycleSeed?: string;\n /** Show a small “Special” badge when this package or treatment has active offers. */\n hasSpecial?: boolean;\n}) {\n const seed = cycleSeed ?? String(fallbackId);\n const { list, currentIndex, nextIndex, transitioning } = useImageCycle(photoAttachments, seed);\n\n const displayAlt = list[currentIndex]?.alt || fallbackAlt;\n const singleUrl = list[0]?.url;\n\n return (\n <button\n type=\"button\"\n onClick={onClick}\n className=\"flex flex-col h-full w-full text-left group block rounded-lg outline-none focus-visible:ring-2 focus-visible:ring-brand-accent focus-visible:ring-offset-2\"\n >\n <div className=\"w-full h-36 overflow-hidden rounded-lg mb-3 relative\">\n {hasSpecial ? (\n <span\n className=\"absolute top-2 right-2 z-10 rounded-full border border-brand-accent/40 bg-secondary/95 px-2 py-0.5 text-[10px] font-semibold uppercase tracking-wide text-brand-accent shadow-sm backdrop-blur-sm\"\n aria-label=\"Has special offer\"\n >\n Special\n </span>\n ) : null}\n {list.length === 0 ? (\n <PhotoWithFallback\n item={undefined}\n fallbackId={fallbackId}\n alt={fallbackAlt}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n websitePhotos={websitePhotos}\n companyInformation={companyInformation}\n />\n ) : list.length === 1 && singleUrl ? (\n // eslint-disable-next-line @next/next/no-img-element -- dynamic API URLs; next/image not configured for external host\n <img\n src={singleUrl}\n alt={displayAlt}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n ) : (\n <>\n {/* Only animate opacity when transitioning; when settling, snap so we don't double-fade */}\n <div\n className={`absolute inset-0 ${transitioning ? 'transition-opacity duration-[600ms] ease-in-out' : 'transition-none'}`}\n style={{ opacity: transitioning ? 0 : 1 }}\n >\n {/* eslint-disable-next-line @next/next/no-img-element -- dynamic API URLs */}\n <img\n src={list[currentIndex]?.url}\n alt={list[currentIndex]?.alt ?? displayAlt}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n <div\n className={`absolute inset-0 ${transitioning ? 'transition-opacity duration-[600ms] ease-in-out' : 'transition-none'}`}\n style={{ opacity: transitioning ? 1 : 0 }}\n >\n {/* eslint-disable-next-line @next/next/no-img-element -- dynamic API URLs */}\n <img\n src={list[nextIndex]?.url}\n alt={list[nextIndex]?.alt ?? displayAlt}\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\n />\n </div>\n </>\n )}\n </div>\n {subtitle && (\n <p className=\"text-xs font-medium text-fg-secondary uppercase tracking-wide line-clamp-1\">\n {subtitle}\n </p>\n )}\n <h4 className=\"font-display text-base font-normal text-fg-primary mt-1 group-hover:underline line-clamp-2\">\n {title}\n </h4>\n {children}\n </button>\n );\n}\n\n/** Single carousel row with small cards. Title and prev/next on one line to avoid excess spacing. */\nfunction CarouselRow<T>({\n rowTitle,\n items,\n renderItem,\n}: {\n rowTitle: string;\n items: T[];\n renderItem: (item: T, index: number) => React.ReactNode;\n}) {\n if (!items?.length) return null;\n return (\n <div className=\"mb-12 last:mb-0\">\n <Carousel.Root opts={{ align: 'start', loop: true }}>\n <div className=\"flex items-center justify-between gap-4 mb-2\">\n <h3 className=\"font-display text-2xl font-normal text-fg-primary md:text-3xl\">\n {rowTitle}\n </h3>\n <div className=\"flex gap-2 flex-shrink-0\">\n <Carousel.PrevTrigger className=\"rounded-full p-1.5 border border-secondary hover:bg-primary_hover transition-colors disabled:opacity-30 disabled:cursor-not-allowed\">\n <svg className=\"w-5 h-5 text-fg-primary\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\" aria-hidden><path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M15 19l-7-7 7-7\" /></svg>\n </Carousel.PrevTrigger>\n <Carousel.NextTrigger className=\"rounded-full p-1.5 border border-secondary hover:bg-primary_hover transition-colors disabled:opacity-30 disabled:cursor-not-allowed\">\n <svg className=\"w-5 h-5 text-fg-primary\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\" aria-hidden><path strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"M9 5l7 7-7 7\" /></svg>\n </Carousel.NextTrigger>\n </div>\n </div>\n <Carousel.Content className=\"-ml-3\">\n {items.map((item, index) => (\n <Carousel.Item key={(item as { id?: number }).id ?? index} className=\"pl-3 basis-[70%] sm:basis-1/2 md:basis-1/3 lg:basis-1/4\">\n {renderItem(item, index)}\n </Carousel.Item>\n ))}\n </Carousel.Content>\n </Carousel.Root>\n </div>\n );\n}\n\n/** Grid row: same section title + items in a responsive grid (top to bottom, left to right). */\nfunction GridRow<T>({\n rowTitle,\n items,\n renderItem,\n}: {\n rowTitle: string;\n items: T[];\n renderItem: (item: T, index: number) => React.ReactNode;\n}) {\n if (!items?.length) return null;\n return (\n <div className=\"mb-12 last:mb-0\">\n <h3 className=\"font-display text-2xl font-normal text-fg-primary mb-3 md:text-3xl\">\n {rowTitle}\n </h3>\n <div className=\"grid grid-cols-2 sm:grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-4\">\n {items.map((item, index) => (\n <div key={(item as { id?: number }).id ?? index} className=\"min-w-0 flex\">\n {renderItem(item, index)}\n </div>\n ))}\n </div>\n </div>\n );\n}\n\n/** One menu block: either carousel or grid, same title + cards. */\nfunction MenuBlock<T>({\n rowTitle,\n items,\n renderItem,\n layout,\n}: {\n rowTitle: string;\n items: T[];\n renderItem: (item: T, index: number) => React.ReactNode;\n layout: 'carousel' | 'grid';\n}) {\n if (!items?.length) return null;\n return layout === 'carousel' ? (\n <CarouselRow rowTitle={rowTitle} items={items} renderItem={renderItem} />\n ) : (\n <GridRow rowTitle={rowTitle} items={items} renderItem={renderItem} />\n );\n}\n\nfunction formatPriceCents(cents: number | null | undefined): string | null {\n if (cents == null) return null;\n return new Intl.NumberFormat('en-US', { style: 'currency', currency: 'USD', minimumFractionDigits: 0, maximumFractionDigits: 0 }).format(cents / 100);\n}\n\n/** Section heading inside modal for consistent structure */\nfunction ModalSection({ title, children }: { title: string; children: React.ReactNode }) {\n return (\n <div>\n <h3 className=\"font-display text-sm font-semibold text-fg-primary uppercase tracking-wide mb-2\">{title}</h3>\n {children}\n </div>\n );\n}\n\nfunction ActiveOffersCallout({ offers }: { offers: OfferPublic[] }) {\n if (!offers.length) return null;\n return (\n <div className=\"rounded-xl border border-secondary bg-secondary/25 p-4 md:p-5 space-y-3 ring-1 ring-brand-accent/25\">\n <p className=\"text-xs font-semibold uppercase tracking-wide text-brand-accent\">Current specials</p>\n <ul className=\"space-y-3 list-none m-0 p-0\">\n {offers.map((o) => (\n <li\n key={o.id}\n className=\"rounded-lg border border-secondary border-l-[3px] border-l-brand-accent bg-primary_hover/30 p-4\"\n >\n <p className=\"font-display text-base font-medium text-fg-primary\">{o.name}</p>\n {o.value_terms ? (\n <p className=\"font-body text-sm text-brand-accent mt-1 font-medium\">{o.value_terms}</p>\n ) : null}\n {o.description ? (\n <p className=\"font-body text-sm text-fg-secondary mt-2 leading-relaxed\">{o.description}</p>\n ) : null}\n {o.expires_at ? (\n <p className=\"text-xs text-tertiary mt-2\">\n Ends {new Date(o.expires_at).toLocaleDateString(undefined, { dateStyle: 'medium' })}\n </p>\n ) : null}\n </li>\n ))}\n </ul>\n </div>\n );\n}\n\n/** Modal body for package or service item (specials shown inline when present). */\nfunction DetailModalContent({\n detail,\n serviceItems = [],\n}: {\n detail: DetailItem;\n services?: Service[];\n packages?: PackageForMenu[];\n serviceItems?: ServiceItemWithService[];\n}) {\n if (detail.type === 'package') {\n const p = detail.item;\n const categoryLine = p.category_names?.length ? p.category_names.join(' | ') : null;\n const descriptionMarkdown = p.description_markdown || p.summary || p.first_service_description_markdown;\n const packageSpecials = getActivePublicOffers(p.offers);\n\n return (\n <div className=\"space-y-6\">\n {categoryLine && (\n <p className=\"text-sm font-medium text-fg-secondary uppercase tracking-wide\">{categoryLine}</p>\n )}\n <ActiveOffersCallout offers={packageSpecials} />\n {descriptionMarkdown && (\n <ModalSection title=\"Package details\">\n <div className=\"prose prose-sm font-body text-fg-primary max-w-none\">\n <MarkdownRenderer content={descriptionMarkdown} />\n </div>\n </ModalSection>\n )}\n\n {p.package_items && p.package_items.length > 0 && (\n <ModalSection title=\"What's included\">\n <ul className=\"space-y-4\">\n {p.package_items.map((pi, i) => {\n const fullItem = pi.service_item?.id != null ? serviceItems.find((si) => si.id === pi.service_item!.id) : null;\n const name = fullItem?.name ?? pi.service_item?.name ?? 'Item';\n const desc = fullItem?.summary ?? fullItem?.description_markdown ?? pi.service_item?.summary;\n return (\n <li key={pi.service_item?.id ?? i} className=\"border border-secondary rounded-lg p-4 bg-secondary/20\">\n <p className=\"font-display font-medium text-fg-primary\">\n {pi.quantity > 1 && `${pi.quantity}× `}{name}\n </p>\n {desc && (\n <div className=\"mt-2 prose prose-sm font-body text-fg-secondary max-w-none\">\n {typeof desc === 'string' && !desc.includes('\\n') && !desc.match(/[#*\\[\\]]/) ? (\n <p>{desc}</p>\n ) : (\n <MarkdownRenderer content={desc} />\n )}\n </div>\n )}\n </li>\n );\n })}\n </ul>\n </ModalSection>\n )}\n\n {p.pricing_info && (\n <ModalSection title=\"Pricing\">\n <div className=\"rounded-lg border border-secondary bg-secondary/40 p-4\">\n <div className=\"prose prose-sm font-body text-fg-primary max-w-none\">\n <MarkdownRenderer content={p.pricing_info} />\n </div>\n </div>\n </ModalSection>\n )}\n </div>\n );\n }\n\n const si = detail.item;\n const priceStr = formatPriceCents(si.price_cents);\n const summary = si.summary || si.service_summary;\n const descriptionMarkdown = si.description_markdown || si.service_description_markdown;\n const itemSpecials = getActivePublicOffers(si.offers);\n\n return (\n <div className=\"space-y-6\">\n {si.service_name && (\n <p className=\"text-sm font-medium text-fg-secondary uppercase tracking-wide\">{si.service_name}</p>\n )}\n <ActiveOffersCallout offers={itemSpecials} />\n\n {priceStr && (\n <ModalSection title=\"Price\">\n <p className=\"font-display text-lg font-normal text-fg-primary\">{priceStr}</p>\n {si.duration_minutes != null && si.duration_minutes > 0 && (\n <p className=\"font-body text-sm text-fg-secondary mt-1\">Duration: {si.duration_minutes} min</p>\n )}\n </ModalSection>\n )}\n\n {summary && (\n <ModalSection title=\"Overview\">\n <p className=\"font-body text-fg-primary\">{summary}</p>\n </ModalSection>\n )}\n\n {descriptionMarkdown && (\n <ModalSection title=\"Full description\">\n <div className=\"prose prose-sm font-body text-fg-primary max-w-none\">\n <MarkdownRenderer content={descriptionMarkdown} />\n </div>\n </ModalSection>\n )}\n\n {si.pricing_info && (\n <ModalSection title=\"Pricing details\">\n <div className=\"rounded-lg border border-secondary bg-secondary/40 p-4\">\n <div className=\"prose prose-sm font-body text-fg-primary max-w-none\">\n <MarkdownRenderer content={si.pricing_info} />\n </div>\n </div>\n </ModalSection>\n )}\n </div>\n );\n}\n\n/**\n * Service Menu: packages and treatments (service items). Specials appear as card badges and in modals.\n */\nexport function ServiceMenuSection({\n title = 'Service Menu',\n subtitle,\n packages = null,\n services = null,\n websitePhotos,\n companyInformation,\n viewAllHref,\n viewAllText = 'View All',\n servicesRowTitle = 'Treatments',\n variant = 'section',\n}: ServiceMenuSectionProps) {\n const packageList = React.useMemo(\n () => (Array.isArray(packages) ? packages : []),\n [packages]\n );\n const serviceList = React.useMemo(\n () => (Array.isArray(services) ? services : []),\n [services]\n );\n\n const serviceItemIdToService = React.useMemo(() => {\n const m = new Map<number, Service>();\n serviceList.forEach((s) => (s.service_items || []).forEach((si) => m.set(si.id, s)));\n return m;\n }, [serviceList]);\n\n const packagesForMenu: PackageForMenu[] = React.useMemo(\n () =>\n packageList.map((pkg) => {\n const category_names = [\n ...new Set(\n (pkg.package_items || [])\n .map((pi) => serviceItemIdToService.get(pi.service_item?.id ?? 0)?.name)\n .filter(Boolean) as string[]\n ),\n ];\n const firstPi = pkg.package_items?.[0];\n const firstService = firstPi ? serviceItemIdToService.get(firstPi.service_item?.id ?? 0) : undefined;\n const first_service_description_markdown =\n firstService?.description_markdown || firstService?.summary || null;\n return { ...pkg, category_names, first_service_description_markdown };\n }),\n [packageList, serviceItemIdToService]\n );\n\n const serviceItemsForMenu: ServiceItemWithService[] = serviceList.flatMap((s) =>\n (s.service_items || []).map((si) => ({\n ...si,\n service_name: s.name,\n service_summary: s.summary,\n service_description_markdown: s.description_markdown,\n }))\n );\n const hasAny = packagesForMenu.length > 0 || serviceItemsForMenu.length > 0;\n\n const CAROUSEL_MIN = 3;\n // Page variant: always grid (full list, no carousel). Section variant: carousel when >=3 items else grid.\n const isPage = variant === 'page';\n const packagesLayout: 'carousel' | 'grid' = isPage ? 'grid' : (packagesForMenu.length >= CAROUSEL_MIN ? 'carousel' : 'grid');\n const serviceItemsLayout: 'carousel' | 'grid' = isPage ? 'grid' : (serviceItemsForMenu.length >= CAROUSEL_MIN ? 'carousel' : 'grid');\n\n const [detailItem, setDetailItem] = useState<DetailItem | null>(null);\n const [portalTarget, setPortalTarget] = useState<HTMLElement | null>(null);\n\n useEffect(() => {\n let el = document.getElementById(SERVICE_MENU_MODAL_ROOT_ID);\n if (!el) {\n el = document.createElement('div');\n el.id = SERVICE_MENU_MODAL_ROOT_ID;\n document.body.appendChild(el);\n }\n // Portal root: set DOM ref once on mount (standard createPortal pattern)\n // eslint-disable-next-line react-hooks/set-state-in-effect -- intentional: portal mount node\n setPortalTarget(el);\n return () => { el?.remove(); };\n }, []);\n\n const closeModal = useCallback(() => setDetailItem(null), []);\n\n const renderPackageCard = useCallback(\n (pkg: PackageForMenu, index: number) => {\n const categorySubtitle = pkg.category_names?.length ? pkg.category_names.join(' | ') : null;\n const cardDesc = pkg.description_markdown || pkg.summary || pkg.first_service_description_markdown;\n const plainDesc = cardDesc ? cardDesc.replace(/[#*`\\[\\]]/g, '').replace(/\\n+/g, ' ').trim() : '';\n const descText = plainDesc.length > 120 ? plainDesc.slice(0, 120) + '…' : plainDesc;\n const hasSpecial = getActivePublicOffers(pkg.offers).length > 0;\n return (\n <GridCardWithImage\n photoAttachments={pkg.photo_attachments}\n fallbackId={`pkg-${pkg.id}`}\n fallbackAlt={pkg.name}\n title={pkg.name}\n subtitle={categorySubtitle}\n onClick={() => setDetailItem({ type: 'package', item: pkg })}\n websitePhotos={websitePhotos}\n companyInformation={companyInformation}\n cycleSeed={`pkg-${pkg.id}-${index}`}\n hasSpecial={hasSpecial}\n >\n {descText && (\n <p className=\"font-body text-sm text-tertiary mt-1 line-clamp-2\">{descText}</p>\n )}\n </GridCardWithImage>\n );\n },\n [websitePhotos, companyInformation]\n );\n\n const renderServiceItemCard = useCallback(\n (si: ServiceItemWithService, index: number) => (\n <GridCardWithImage\n photoAttachments={si.photo_attachments}\n fallbackId={`service-item-${si.id}`}\n fallbackAlt={si.photo_attachments?.[0]?.photo?.title || si.name}\n title={si.name}\n subtitle={si.service_name ?? null}\n onClick={() => setDetailItem({ type: 'service_item', item: si })}\n websitePhotos={websitePhotos}\n companyInformation={companyInformation}\n cycleSeed={`service-item-${si.id}-${index}`}\n hasSpecial={getActivePublicOffers(si.offers).length > 0}\n >\n {formatPriceCents(si.price_cents) && (\n <p className=\"font-body text-sm font-medium text-fg-primary mt-1\">\n {formatPriceCents(si.price_cents)}\n </p>\n )}\n {(() => {\n const desc = si.summary || si.description_markdown || si.service_summary || si.service_description_markdown;\n if (!desc) return null;\n const plain = desc.replace(/[#*`\\[\\]]/g, '').replace(/\\n+/g, ' ').trim();\n const text = plain.length > 120 ? plain.slice(0, 120) + '…' : plain;\n return (\n <p className=\"font-body text-sm text-tertiary mt-1 line-clamp-2\">\n {text}\n </p>\n );\n })()}\n </GridCardWithImage>\n ),\n [websitePhotos, companyInformation]\n );\n\n if (!hasAny) return null;\n\n const modalTitle = detailItem ? detailItem.item.name : '';\n\n return (\n <section className={variant === 'page' ? 'py-12 md:py-20' : 'py-12 md:py-16'}>\n <div className=\"mx-auto max-w-container px-4 md:px-8\">\n {/* Section variant: centered title/subtitle in-section. Page variant: hero is provided by the page (GenericTextHero). */}\n {variant === 'section' && (\n <div className=\"mx-auto max-w-3xl text-center mb-12 md:mb-16\">\n {title && (\n <h2 className=\"font-display text-4xl font-normal text-fg-primary md:text-5xl\">\n {title}\n </h2>\n )}\n {subtitle && (\n <p className=\"mt-4 font-display text-lg leading-relaxed text-tertiary md:text-xl max-w-3xl mx-auto\">\n {subtitle}\n </p>\n )}\n </div>\n )}\n\n <MenuBlock\n rowTitle=\"Packages\"\n items={packagesForMenu}\n layout={packagesLayout}\n renderItem={renderPackageCard}\n />\n\n <MenuBlock\n rowTitle={servicesRowTitle}\n items={serviceItemsForMenu}\n layout={serviceItemsLayout}\n renderItem={renderServiceItemCard}\n />\n\n {variant === 'section' && viewAllHref && viewAllText && (\n <div className=\"mt-12 text-center\">\n <Button href={viewAllHref} color=\"primary\" size=\"md\">\n {viewAllText}\n </Button>\n </div>\n )}\n </div>\n\n {portalTarget &&\n detailItem &&\n createPortal(\n <Modal\n isOpen={true}\n onClose={closeModal}\n title={modalTitle}\n maxWidth=\"2xl\"\n >\n <DetailModalContent\n detail={detailItem}\n services={serviceList}\n packages={packagesForMenu}\n serviceItems={serviceItemsForMenu}\n />\n </Modal>,\n portalTarget\n )}\n </section>\n );\n}\n","'use client';\n\nimport { useState, useEffect, useMemo } from 'react';\nimport type { PhotoAttachment } from '../../types/api/photos';\n\nconst CYCLE_INTERVAL_MIN_MS = 6000;\nconst CYCLE_INTERVAL_MAX_MS = 8000;\nexport const CROSSFADE_DURATION_MS = 600;\n\nexport interface CycledImage {\n url: string;\n alt: string;\n}\n\nexport interface UseImageCycleResult {\n list: CycledImage[];\n currentIndex: number;\n nextIndex: number;\n transitioning: boolean;\n}\n\n/** Stable value in [0, 1) derived from seed string (FNV-1a hash). Same seed always produces same value. */\nfunction seedToUnit(seed: string): number {\n let h = 2166136261 >>> 0;\n for (let i = 0; i < seed.length; i++) {\n h ^= seed.charCodeAt(i);\n h = (Math.imul(h, 16777619) >>> 0) >>> 0;\n }\n return (h >>> 0) / 4294967296;\n}\n\n/** Seeded Fisher-Yates shuffle. Same seed produces same order (SSR-safe). */\nfunction shuffleWithSeed<T>(array: T[], seed: string): T[] {\n if (array.length <= 1) return array;\n const arr = [...array];\n let h = 2166136261 >>> 0;\n for (let i = 0; i < seed.length; i++) {\n h ^= seed.charCodeAt(i);\n h = (Math.imul(h, 16777619) >>> 0) >>> 0;\n }\n const next = (step: number) => {\n h = (Math.imul(1664525, (h + step) >>> 0) + 1013904223) >>> 0;\n return (h >>> 0) / 4294967296;\n };\n for (let i = arr.length - 1; i > 0; i--) {\n const j = Math.floor(next(i) * (i + 1));\n [arr[i], arr[j]] = [arr[j], arr[i]];\n }\n return arr;\n}\n\nfunction photoUrlFromAttachment(pa: PhotoAttachment): string | undefined {\n return pa.photo?.large_url || pa.photo?.medium_url || pa.photo?.thumbnail_url;\n}\n\nfunction photoAltFromAttachment(pa: PhotoAttachment): string {\n return pa.photo?.alt_text || pa.photo?.title || '';\n}\n\n/**\n * Cycles through a list of photo attachments with a seeded shuffle and crossfade transitions.\n *\n * Each card uses a unique seed so intervals are staggered — cards don't all transition in sync.\n * The shuffle is deterministic (SSR-safe) and the timer only activates when there are 2+ images.\n */\nexport function useImageCycle(\n photoAttachments: PhotoAttachment[] | undefined,\n seed: string\n): UseImageCycleResult {\n const list = useMemo<CycledImage[]>(() => {\n const arr = Array.isArray(photoAttachments) && photoAttachments.length > 0 ? photoAttachments : [];\n if (arr.length === 0) return [];\n return shuffleWithSeed(arr, seed)\n .map((pa) => ({ url: photoUrlFromAttachment(pa) ?? '', alt: photoAltFromAttachment(pa) }))\n .filter((x) => x.url);\n }, [photoAttachments, seed]);\n\n const [currentIndex, setCurrentIndex] = useState(0);\n const [transitioning, setTransitioning] = useState(false);\n\n // Per-card random interval (6–8 s) so cards don't all transition in sync\n const intervalMs = useMemo(\n () => CYCLE_INTERVAL_MIN_MS + Math.floor(seedToUnit(seed) * (CYCLE_INTERVAL_MAX_MS - CYCLE_INTERVAL_MIN_MS + 1)),\n [seed]\n );\n\n useEffect(() => {\n if (list.length <= 1) return;\n const id = setInterval(() => setTransitioning(true), intervalMs);\n return () => clearInterval(id);\n }, [list.length, intervalMs]);\n\n useEffect(() => {\n if (!transitioning || list.length <= 1) return;\n const t = setTimeout(() => {\n setCurrentIndex((i) => (i + 1) % list.length);\n setTransitioning(false);\n }, CROSSFADE_DURATION_MS);\n return () => clearTimeout(t);\n }, [transitioning, list.length]);\n\n const nextIndex = list.length > 1 ? (currentIndex + 1) % list.length : 0;\n\n return { list, currentIndex, nextIndex, transitioning };\n}\n","/**\n * Server-side API client for SSR\n * API key is stored securely on the server - never exposed to browser\n */\n\nimport type { CompanyInformation } from '../types/api/company-information';\nimport type { Service } from '../types/api/service';\nimport type { Package } from '../types/api/package';\nimport type { WebsitePhotos } from '../types/api/website-photos';\n\nconst API_URL = process.env.API_URL || 'http://localhost:3000/api/v1';\nconst API_KEY = process.env.API_KEY || '';\n\ninterface FetchOptions {\n cache?: RequestCache;\n revalidate?: number;\n}\n\nasync function serverFetch<T>(endpoint: string, options: FetchOptions = {}): Promise<T | null> {\n const url = `${API_URL}${endpoint}`;\n \n try {\n const fetchOptions: RequestInit & { next?: { revalidate?: number } } = {\n headers: {\n 'X-API-Key': API_KEY,\n 'Content-Type': 'application/json',\n },\n cache: options.cache,\n };\n \n if (options.revalidate) {\n fetchOptions.next = { revalidate: options.revalidate };\n }\n \n const response = await fetch(url, fetchOptions);\n\n if (!response.ok) {\n console.error(`[Server API] Error ${response.status} for ${endpoint}`);\n return null;\n }\n\n const json = await response.json();\n \n // Rails API returns { data: [...], meta: {...} }\n return json.data ?? json;\n } catch (error) {\n console.error(`[Server API] Failed to fetch ${endpoint}:`, error);\n return null;\n }\n}\n\n/**\n * Generic serverApi object for flexible endpoint access\n */\nexport const serverApi = {\n get: <T = unknown>(endpoint: string, options?: FetchOptions): Promise<T | null> => {\n return serverFetch<T>(endpoint, options || { revalidate: 60 });\n }\n};\n\n// Revalidate data every 60 seconds (ISR)\nconst defaultOptions: FetchOptions = { revalidate: 60 };\n\nexport async function getCompanyInformation(): Promise<CompanyInformation | null> {\n return serverFetch<CompanyInformation>('/public/company_information', defaultOptions);\n}\n\n/** Ads config (e.g. Meta Pixel). Returns { meta_pixel_id?: string } or {}. Only present when account has connected Meta Ads. */\nexport async function getAdsConfig(): Promise<{ meta_pixel_id?: string } | null> {\n const data = await serverFetch<{ meta_pixel_id?: string }>('/public/ads_config', defaultOptions);\n return data ?? null;\n}\n\n/** Extract Meta Pixel ID from ads config for use with <MetaPixel pixelId={...} />. Only returns a value when present and valid (numeric). */\nexport function getMetaPixelId(adsConfig: { meta_pixel_id?: string } | null | undefined): string | null {\n const id = adsConfig && typeof adsConfig === 'object' && 'meta_pixel_id' in adsConfig && adsConfig.meta_pixel_id;\n const str = id != null && id !== '' ? String(id).trim() : '';\n return str !== '' && str !== 'null' && /^\\d+$/.test(str) ? str : null;\n}\n\nexport type AnalyticsConfig = {\n /** PostHog project API key — platform-wide, from POSTHOG_API_KEY env var on the Rails server. */\n posthog_api_key?: string;\n /** Per-site GTM container ID (e.g. GTM-ABC123), provisioned by Keystone. */\n gtm_container_public_id?: string;\n /**\n * Environment identifier from KEYSTONE_ENV on the Rails server (e.g. \"production\", \"staging\",\n * \"development\"). Registered as a PostHog super property on every event so the sync job can\n * filter by environment and avoid cross-environment data contamination.\n */\n environment?: string;\n};\n\n/** Analytics config for customer sites. Returns platform-wide analytics keys (e.g. PostHog). */\nexport async function getAnalyticsConfig(): Promise<AnalyticsConfig | null> {\n const data = await serverFetch<AnalyticsConfig>('/public/analytics_config', defaultOptions);\n return data ?? null;\n}\n\n/** Extract PostHog API key from analytics config for use with <PostHogProvider apiKey={...} />. */\nexport function getPostHogApiKey(analyticsConfig: AnalyticsConfig | null | undefined): string | null {\n const key = analyticsConfig?.posthog_api_key;\n const str = key != null && key !== '' ? String(key).trim() : '';\n return str !== '' && str !== 'null' ? str : null;\n}\n\n/** Extract GTM container ID from analytics config for use with <GoogleTagManager containerId={...} />. */\nexport function getGtmContainerPublicId(analyticsConfig: AnalyticsConfig | null | undefined): string | null {\n const value = analyticsConfig?.gtm_container_public_id;\n const str = value != null && value !== '' ? String(value).trim() : '';\n return str !== '' && str !== 'null' && /^GTM-[A-Z0-9]+$/i.test(str) ? str : null;\n}\n\n/** Extract environment string from analytics config for use with <PostHogProvider environment={...} />. */\nexport function getKeystoneEnvironment(analyticsConfig: AnalyticsConfig | null | undefined): string {\n return analyticsConfig?.environment?.trim() || 'development';\n}\n\nexport async function getServices(): Promise<Service[] | null> {\n return serverFetch<Service[]>('/public/services', defaultOptions);\n}\n\nexport async function getService(slug: string): Promise<Service | null> {\n return serverFetch<Service>(`/public/services/by_slug/${slug}`, defaultOptions);\n}\n\nexport async function getLocations() {\n return serverFetch('/public/locations', defaultOptions);\n}\n\nexport async function getLocation(slug: string) {\n return serverFetch(`/public/locations/by_slug/${slug}`, defaultOptions);\n}\n\nexport async function getReviews() {\n return serverFetch('/public/reviews', defaultOptions);\n}\n\nexport async function getFAQs() {\n return serverFetch('/public/faq_questions', defaultOptions);\n}\n\nexport async function getBlogPosts() {\n return serverFetch('/public/blog_posts', defaultOptions);\n}\n\nexport async function getBlogPost(slug: string) {\n return serverFetch(`/public/blog_posts/by_slug/${slug}`, defaultOptions);\n}\n\nexport async function getTeamMembers() {\n return serverFetch('/public/team_members', defaultOptions);\n}\n\nexport async function getWebsitePhotos(): Promise<WebsitePhotos | null> {\n return serverFetch<WebsitePhotos>('/public/website_photos', defaultOptions);\n}\n\nexport async function getJobPostings() {\n return serverFetch('/public/job_postings', defaultOptions);\n}\n\nexport async function getJobPosting(slug: string) {\n return serverFetch(`/public/job_postings/by_slug/${slug}`, defaultOptions);\n}\n\nexport async function getSocialPosts() {\n // Social payloads can exceed Next's data-cache item size; avoid noisy build warnings.\n return serverFetch('/public/social_posts', { cache: 'no-store' });\n}\n\n/** Packages (bundles of service items). */\nexport async function getPackages(): Promise<Package[] | null> {\n return serverFetch<Package[]>('/public/packages', defaultOptions);\n}\n\nexport async function getPackage(slug: string): Promise<Package | null> {\n return serverFetch<Package>(`/public/packages/by_slug/${encodeURIComponent(slug)}`, defaultOptions);\n}\n\n// Alias for testimonials (API uses \"reviews\")\nexport async function getTestimonials() {\n return getReviews();\n}\n\n/** Form definition for dynamic form rendering, fetched by form_type. */\nexport async function getForm(formType: string) {\n type FormDefinition = import('../types/api/form').FormDefinition;\n return serverFetch<FormDefinition>(`/public/forms/${encodeURIComponent(formType)}`, defaultOptions);\n}\n\n/** Form definition for dynamic form rendering, fetched by numeric ID. */\nexport async function getFormById(id: number | string) {\n type FormDefinition = import('../types/api/form').FormDefinition;\n return serverFetch<FormDefinition>(`/public/form_by_id/${encodeURIComponent(id)}`, defaultOptions);\n}\n\n","/**\n * Placeholder keys used in legal markdown. Replace with actual values or safe fallbacks.\n */\nexport interface LegalPlaceholders {\n businessName: string;\n businessWebsite: string;\n /** e.g. \"Contact us {{business.contact}}.\" → \"Contact us at support@x.com.\" */\n businessContact: string;\n businessEmail: string;\n businessPhone: string;\n locationEmail: string;\n locationContact: string;\n effectiveYear: string;\n}\n\nconst PLACEHOLDER_MAP: Record<string, keyof LegalPlaceholders> = {\n '{{business.name}}': 'businessName',\n '{{business.website}}': 'businessWebsite',\n '{{business.contact}}': 'businessContact',\n '{{business.email}}': 'businessEmail',\n '{{business.phone}}': 'businessPhone',\n '{{location.name}}': 'businessName',\n '{{location.email}}': 'locationEmail',\n '{{location.contact}}': 'locationContact',\n '{{right_now.year}}': 'effectiveYear',\n};\n\nexport function replaceLegalPlaceholders(content: string, placeholders: LegalPlaceholders): string {\n let result = content;\n for (const [placeholder, key] of Object.entries(PLACEHOLDER_MAP)) {\n const value = placeholders[key] ?? '';\n result = result.split(placeholder).join(value);\n }\n return result;\n}\n\nexport function buildLegalPlaceholders(\n companyName: string | null | undefined,\n websiteUrl: string | null | undefined,\n primaryEmail: string | null | undefined,\n primaryPhone: string | null | undefined,\n locationEmail: string | null | undefined\n): LegalPlaceholders {\n const currentYear = new Date().getFullYear().toString();\n const email = primaryEmail?.trim();\n const phone = primaryPhone?.trim();\n const locEmail = locationEmail?.trim() || email;\n\n const businessContactPhrase =\n email ? `at ${email}` : phone ? `at ${phone}` : 'through the contact form on this website';\n const locationContactPhrase =\n locEmail ? `at ${locEmail}` : email ? `at ${email}` : 'through the contact form on this website';\n\n return {\n businessName: companyName?.trim() || 'The Business',\n businessWebsite: websiteUrl?.trim() || 'this website',\n businessContact: businessContactPhrase,\n businessEmail: email || 'via the contact form on this website',\n businessPhone: phone || 'the contact information provided on this website',\n locationEmail: locEmail || 'via the contact form on this website',\n locationContact: locationContactPhrase,\n effectiveYear: currentYear,\n };\n}\n\n"],"mappings":"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ACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW;AAAA,IACX,WAAW;AAAA,EACf;AAAA,EACA;AAAA,IACI,MAAM;AAAA,IACN,MAAM;AAAA,IACN,MAAM;AAAA,I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","names":["React","React","useMemo","useState","React","React","React","color","Component","React","_a","Button","createContext","createElement","isValidElement","useContext","styles","createContext","createContext","useContext","HelpCircle","AriaButton","delay","AriaButton","useContext","sizes","isDisabled","isInvalid","HelpCircle","createContext","React","AriaTextField","color","React","AriaTextField","id","React","React","createContext","isValidElement","AriaButton","AriaListBox","sizes","styles","useContext","useState","AriaGroup","AriaInput","_a","_b","useContext","AriaGroup","sizes","AriaInput","useState","isValidElement","useContext","AriaText","sizes","id","useContext","isValidElement","AriaText","sizes","AriaButton","isValidElement","createContext","AriaListBox","useId","ChevronDown","id","useId","ChevronDown","React","useState","useEffect","Image","id","useState","React","useEffect","Image","Image","color","sizes","createElement","isValidElement","color","sizes","createElement","isValidElement","useId","progress","id","useId","styles","createElement","isValidElement","styles","color","createElement","isValidElement","ArrowRight","React","createContext","isValidElement","useContext","useMemo","createContext","useMemo","React","useContext","isValidElement","PaginationItem","total","page","PaginationItem","ArrowRight","useEffect","useRef","useState","useCallback","Image","id","Image","React","isValidElement","AriaButton","AriaLink","styles","Button","color","Component","AriaLink","AriaButton","React","isValidElement","React","isValidElement","AriaButton","AriaLink","styles","Button","color","Component","AriaLink","AriaButton","React","isValidElement","React","isValidElement","AriaButton","AriaLink","styles","Button","color","Component","AriaLink","AriaButton","React","isValidElement","createContext","useContext","HelpCircle","InfoCircle","AriaGroup","AriaInput","AriaTextField","TextFieldContext","createContext","InputBase","useContext","sizes","AriaGroup","isDisabled","isInvalid","AriaInput","HelpCircle","InfoCircle","Input","AriaTextField","AriaTextArea","AriaTextField","TextArea","AriaTextField","AriaTextArea","React","ChevronDown","AriaButton","AriaListBox","AriaPopover","AriaSelect","AriaSelectValue","Select","React","AriaSelect","AriaButton","isDisabled","AriaSelectValue","ChevronDown","AriaPopover","AriaListBox","React","cloneElement","createContext","isValidElement","useCallback","useContext","useEffect","useRef","useSyncExternalStore","createContext","useContext","useRef","useCallback","canScrollPrev","canScrollNext","selectedIndex","scrollSnaps","useSyncExternalStore","useEffect","Trigger","isValidElement","cloneElement","React","ChevronLeft","React","useEffect","React","useEffect","useRef","Component","React","Button","RoundButton","ButtonGroup","Input","InputBase","PrivacyCheckbox","Form","FormContainer","InputGroup","Label","HintText","Select","SelectItem","NativeSelect","PhotoWithFallback","Badge","BadgeWithDot","BadgeGroup","RatingStars","RatingBadge","Tooltip","Avatar","AvatarLabelGroup","VerifiedTick","Breadcrumb","FeaturedIcon","PaginationPageDefault","PaginationPageMinimalCenter","GoogleMap","MarkdownRenderer","useMemo","React","PhotoWithFallback","useState","Form","Input","Button","IconComponent","useState","ArrowRight","useState","Button","ArrowRight","PhotoWithFallback","ArrowRight","Image","FeaturedIcon","IconComponent","Button","ArrowRight","AvatarLabelGroup","VerifiedTick","React","React","PhotoWithFallback","useState","useState","React","ArrowLeft","ArrowRight","cloneElement","createContext","isValidElement","useCallback","useContext","useEffect","useRef","useSyncExternalStore","useEmblaCarousel","CarouselContext","createContext","useCarousel","useContext","DEFAULT_SNAPSHOT","CarouselRoot","useEmblaCarousel","useRef","useCallback","canScrollPrev","canScrollNext","selectedIndex","scrollSnaps","useSyncExternalStore","useEffect","CarouselContent","CarouselItem","Trigger","isValidElement","cloneElement","CarouselPrevTrigger","CarouselNextTrigger","CarouselIndicator","CarouselIndicatorGroup","Carousel","formatDate","React","Button","Carousel","PhotoWithFallback","RoundButton","ArrowLeft","ArrowRight","React","React","useRef","useState","React","useState","ReactMarkdown","remarkGfm","Image","Image","useState","React","id","ReactMarkdown","remarkGfm","InputGroup","NativeSelect","InputBase","Input","_a","PrivacyCheckbox","id","React","createContext","useContext","useContext","useState","useRef","e","React","Form","Button","React","PhotoWithFallback","Link","Image","Link","Image","React","useRef","useState","Link","Image","ChevronDown","AriaButton","AriaPopover","createElement","isValidElement","Link","isValidElement","createElement","Link","useState","React","Link","ChevronDown","useRef","id","Image","Button","AriaButton","AriaPopover","IconComponent","React","React","IconComponent","className","FeaturedIcon","React","React","PhotoWithFallback","React","ArrowRight","React","Button","ArrowRight","React","Clock","React","FeaturedIcon","Button","Clock","GoogleMap","React","ArrowRight","React","PhotoWithFallback","Button","ArrowRight","React","useState","Image","ArrowLeft","ArrowRight","_a","_b","useState","React","Carousel","Image","RoundButton","ArrowLeft","ArrowRight","PhotoWithFallback","Button","PaginationPageMinimalCenter","React","Clock","React","Badge","PhotoWithFallback","_a","BadgeWithDot","Clock","Button","Link","ArrowUpRight","ArrowLeft","ArrowRight","formatDate","Button","Carousel","PhotoWithFallback","Link","ArrowUpRight","RoundButton","ArrowLeft","ArrowRight","React","useState","ArrowUpRight","ArrowUpRight","PhotoWithFallback","ArrowUpRight","Avatar","useState","React","PhotoWithFallback","ArrowUpRight","Avatar","Select","SelectItem","PaginationPageDefault","React","useState","slugify","id","formatDate","useState","React","Button","Breadcrumb","BadgeGroup","PhotoWithFallback","Avatar","Form","Input","MarkdownRenderer","Badge","React","React","Button","Input","ChevronLeft","Button","ChevronLeft","ChevronLeft","Button","ChevronLeft","SearchLg","Input","SearchLg","Fragment","Image","React","color","AvatarsWithReview","Image","Fragment","Form","Input","Button","ChevronLeft","MarkerPin02","CurrencyDollarCircle","Button","ChevronLeft","MarkerPin02","CurrencyDollarCircle","React","useRef","useState","useState","useRef","e","React","Form","Button","MarkdownRenderer","FormContainer","Fragment","useState","React","HeroHome","useState","React","Fragment","PhotoWithFallback","React","useState","useRef","useCallback","Link","Image","usePathname","HeaderNavigation","useState","useRef","React","usePathname","useCallback","Link","Image","Button","AboutHome","PhotoWithFallback","ServicesHome","PhotoWithFallback","ServicesGrid","PhotoWithFallback","React","TestimonialsHome","React","PhotoWithFallback","React","TestimonialsGrid","React","PhotoWithFallback","React","React","useRef","useState","ContactSectionForm","useState","useRef","e","React","Form","Button","getLegalUrlsFromConfig","ContactSection","React","ContactSectionForm","PhotoWithFallback","ContactSection","TeamGrid","PhotoWithFallback","Link","COLUMN_TITLES","FooterHome","Link","ServiceDetailHero","Breadcrumb","ValuesSection","IconComponent","StatisticsSection","LocationGrid","PhotoWithFallback","parseBusinessHours","LocationDetailsSection","PhotoWithFallback","GoogleMap","getPostImageUrls","_a","_b","formatDate","SocialMediaGrid","PhotoWithFallback","BlogHome","PhotoWithFallback","React","useState","BlogGallery","useState","React","PhotoWithFallback","PaginationPageDefault","BlogPostSection","Button","Breadcrumb","PhotoWithFallback","React","BlogSection","formatDate","React","PhotoWithFallback","useState","createContext","useRef","useEffect","useEffect","createContext","ease","frameData","process","alpha","alpha","progress","color","mixNumber","scale","progress","undampedFreq","progress","keyframes","ease","ease","keyframes","percent","motionValue","delay","keyframes","progress","now","keyframes","motionValue","keyframes","delay","ease","_a","_b","keyframes","delay","motionValue","keyframes","motionValue","delay","keyframes","motionValue","_a","_b","number","getAnimatableNone","getAnimatableNone","motionValue","createContext","useContext","useId","useEffect","useCallback","useContext","id","useId","useEffect","useCallback","createContext","useContext","createContext","useContext","useMemo","useContext","useMemo","Fragment","useMemo","createElement","useMemo","layout","hasTransform","useMemo","useMemo","isSVGTag","_a","_b","Component","useMemo","Component","Component","Fragment","useMemo","createElement","useContext","scrapeMotionValuesFromProps","useContext","scrapeMotionValuesFromProps","scrapeMotionValuesFromProps","useCallback","useCallback","useContext","useRef","useEffect","createContext","Component","useContext","useRef","useEffect","_a","layout","drag","Component","MeasureLayout","useContext","drag","layout","Component","Fragment","transformPoint","scale","scaleX","scaleY","scale","distance","transformPoint","rootProjectionNode","now","getAnimatableNone","getComputedStyle","scrapeMotionValuesFromProps","Component","Fragment","isNotNull","getFinalKeyframe","keyframes","keyframes","delay","getFinalKeyframe","delay","animations","delay","animations","animations","context","animations","motionValue","_a","layout","info","point","timestamp","event","time","layout","dragSnapToOrigin","drag","isDragging","layout","inertia","motionValue","jsx","useContext","drag","useContext","jsx","keyframes","progress","scale","rotate","id","layout","createProjectionNode","now","progress","createProjectionNode","createProjectionNode","motion","FAQHome","useState","motion","useState","FAQGrid","useState","FAQHero","GenericTextHero","LocationDetailHero","SocialMediaHero","TestimonialsHero","JobGallery","ChevronLeft","MarkerPin02","Briefcase01","CurrencyDollarCircle","JobDetailHero","Button","ChevronLeft","MarkerPin02","Briefcase01","CurrencyDollarCircle","JobDetailHero","React","useRef","useState","Fragment","useState","React","HeroHome","useState","React","Fragment","PhotoWithFallback","Button","React","useState","useRef","useCallback","Link","Image","usePathname","MAX_DROPDOWN_ITEMS","HeaderNavigation","useState","useRef","React","usePathname","useCallback","Link","Image","Button","React","ServicesHome","React","PhotoWithFallback","AboutHome","PhotoWithFallback","Button","React","ChevronLeft","ChevronRight","TestimonialsHome","React","ChevronLeft","ChevronRight","PhotoWithFallback","Button","React","ChevronLeft","ChevronRight","BlogSection","formatDate","React","ChevronLeft","ChevronRight","PhotoWithFallback","Button","React","useState","BlogGallery","useState","React","PhotoWithFallback","PaginationPageDefault","getPostImageUrls","_a","_b","formatDate","getPlatformColor","SocialMediaGrid","PhotoWithFallback","React","React","useRef","useState","ContactSectionForm","useState","useRef","e","React","Form","Button","getLegalUrlsFromConfig","ContactSection","React","ContactSectionForm","PhotoWithFallback","ContactSection","Link","COLUMN_TITLES","buildSocialLinks","FooterHome","Link","Fragment","useState","React","HeroHome","useState","React","Fragment","Button","PhotoWithFallback","React","useState","useRef","useCallback","Link","Image","usePathname","HeaderNavigation","useState","useRef","React","usePathname","useCallback","Link","Image","Button","Link","Image","FooterHome","Image","Link","React","React","useRef","useState","ContactSectionForm","useState","useRef","e","React","Form","Button","getLegalUrlsFromConfig","ContactSection","React","PhotoWithFallback","ContactSectionForm","ContactSection","ServicesHome","PhotoWithFallback","Button","AboutHome","PhotoWithFallback","Button","React","TestimonialsHome","React","Avatar","React","BlogSection","formatDate","React","PhotoWithFallback","Button","React","TeamGrid","React","PhotoWithFallback","React","Link","ServicesGrid","React","Link","PhotoWithFallback","useState","motion","FAQHome","useState","motion","React","useRef","useState","React","useState","useEffect","useCallback","useState","useEffect","useMemo","createThemedExport","Component","React","HeroHome","ServicesHome","AboutHome","TestimonialsHome","TestimonialsGrid","FAQHome","BlogSection","ContactSection","FooterHome","HeaderNavigation","GenericHeaderComponent","StatisticsSection","ValuesSection","TeamGrid","LocationGrid","LocationDetailsSection","ServicesGrid","SocialMediaGrid","JobGallery","BlogHome","BlogGallery","BlogPostSection","ContactHome","FAQGrid","FAQHero","GenericTextHero","LocationDetailHero","ServiceDetailHero","JobDetailHero","createThemedExport","JobDetailSection","PolicyDocumentSection","SocialMediaHero","TestimonialsHero","HomeHeroComponent","React","GenericTextHero","PolicyDocumentSection"]}
|