{
  "version": 3,
  "sources": ["ssg:https://ga.jspm.io/npm:react-dom@18.2.0/client.js", "framer:toplevel:framer:toplevel/main"],
  "sourcesContent": ["import*as t from\"react-dom\";var o=\"default\"in t?t.default:t;var a={};var e=o;a.createRoot=e.createRoot;a.hydrateRoot=e.hydrateRoot;const r=a.createRoot,d=a.hydrateRoot;export{r as createRoot,a as default,d as hydrateRoot};\n\n//# sourceMappingURL=client.js.map", "\r\n        import * as React from \"react\"\r\n        import * as ReactDOM from \"react-dom/client\"\r\n        import * as Framer from \"framer\"\r\n\r\n        const routes = {aIxubhzMw: {elements: {dHpE1nxSt: \"hero\", eYxbySqno: \"fin\", F4XeT2ldw: \"about\", IfBBZ5kQy: \"nav\", puP_dlZnC: \"about-image\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/ix9dOsIpLghztrxgDRFT/LWFrGFYzk0rd1O9YWaLg/aIxubhzMw.js\")), path: \"/\"}, IexgfYraa: {elements: {Ufc4DuaQz: \"nav\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/mxHGGTUM3yV3w4dCFTpJ/VEa80VjbXdiHGpakxASX/IexgfYraa.js\")), path: \"/works\"}, i2IcTL1IG: {collectionId: \"AeOd91rfa\", elements: {kDDj7OMNl: \"nav\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/hHWpeoY7c4Y3rHuPSelg/RxFQ0haxI2V53kf9wIco/i2IcTL1IG.js\")), path: \"/works/:e2wFxoqxt\"}, KhM_ff1oP: {collectionId: \"nlLEDkRHt\", elements: {CN1EukjAy: \"nav\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/kl6b8WSwqfLDFcdC1P6f/8OVScfOhraOdmw06OCAX/KhM_ff1oP.js\")), path: \"/portfolio/:b2Rr5R0HL\"}}\r\n        const locales = [{code: \"en\", id: \"default\", name: \"English\", slug: \"\"}]\r\n\r\n        export async function getPageRoot({ routeId, pathVariables, localeId }) {\r\n            // We don't want the initial render to immediately have to suspend.\r\n            await routes[routeId].page.preload()\r\n\r\n            const content = React.createElement(\r\n                Framer.PageRoot,\r\n                {\r\n                    isWebsite: true,\r\n                    routeId,\r\n                    pathVariables,\r\n                    routes,\r\n                    collectionUtils: {AeOd91rfa: async () => (await import(\"https://framerusercontent.com/modules/heSxGS5RaIqLEjka8FgU/YNSq6hht9Dc7C2B8tRfN/AeOd91rfa.js\"))?.[\"utils\"], nlLEDkRHt: async () => (await import(\"https://framerusercontent.com/modules/yaFe9d8bGNPms4TYqOGk/a4GnzleKNzC8VR9bOjiB/nlLEDkRHt.js\"))?.[\"utils\"]},\r\n                    framerSiteId: \"1ec9ae1c9c03880e086c60fc8836f0534673463056255af3d6305f7720f6f91e\",\r\n                    notFoundPage: Framer.lazy(() => import(\"__framer-not-found-page\")),\r\n                    isReducedMotion: undefined,\r\n                    localeId,\r\n                    locales,\r\n                    preserveQueryParams: undefined,\r\n                    \r\n                }\r\n            )\r\n\r\n            const contentWithFeaturesContext = React.createElement(\r\n                Framer.LibraryFeaturesProvider,\r\n                {\r\n                    children: content,\r\n                    value: {enableAsyncURLUpdates: true, replaceNestedLinks: true, useGranularSuspense: true, wrapUpdatesInTransitions: false}\r\n                }\r\n            )\r\n\r\n            const effect = {enter: {opacity: 0, rotate: 0, rotate3d: false, rotateX: 0, rotateY: 0, scale: 1, transition: {damping: 30, delay: 0, duration: 0.1, ease: [0.27, 0, 0.51, 1], mass: 1, stiffness: 400, type: \"tween\"}, x: \"0px\", y: \"0px\"}}\r\n            const page = React.createElement(Framer.PageEffectsProvider, {\r\n                children: contentWithFeaturesContext,\r\n                value: {global: {enter: {opacity: 0, rotate: 0, rotate3d: false, rotateX: 0, rotateY: 0, scale: 1, transition: {damping: 30, delay: 0, duration: 0.1, ease: [0.27, 0, 0.51, 1], mass: 1, stiffness: 400, type: \"tween\"}, x: \"0px\", y: \"0px\"}}, routes: {aIxubhzMw: {b4hKsWPD1: effect, gzbtZvbNt: effect, IexgfYraa: effect, KhM_ff1oP: effect, x95mB7h17: effect}, i2IcTL1IG: {aIxubhzMw: effect, b4hKsWPD1: effect, gzbtZvbNt: effect, IexgfYraa: effect, x95mB7h17: effect}, IexgfYraa: {aIxubhzMw: effect, b4hKsWPD1: effect, KhM_ff1oP: effect, syfy3rI7z: effect, x95mB7h17: effect}, KhM_ff1oP: {aIxubhzMw: effect, b4hKsWPD1: effect, gzbtZvbNt: effect, IexgfYraa: effect, x95mB7h17: effect}}}\r\n            })\r\n\r\n            return page\r\n        }\r\n\r\n        const isBrowser = typeof document !== \"undefined\"\r\n        if (isBrowser) {\r\n            window.__framer_importFromPackage = (packageAndFilename, exportIdentifier) => () => {\r\n                return React.createElement(Framer.ErrorPlaceholder, { error: 'Package component not supported: \"' + exportIdentifier + '\" in \"' + packageAndFilename + '\"' })\r\n            }\r\n\r\n            // A lot of libraries assume process.env.NODE_ENV is present in runtime/buildtime, so we are polyfilling it\r\n            window.process = {\r\n                ...window.process,\r\n                env: {\r\n                    ...(window.process ? window.process.env: undefined),\r\n                    NODE_ENV: \"production\"\r\n                }\r\n            }\r\n\r\n            window.__framer_events = window.__framer_events || []\r\n\r\n            // Fallback support for stack gaps\r\n            Framer.installFlexboxGapWorkaroundIfNeeded()\r\n\r\n            const container = document.getElementById(\"main\")\r\n            // We know that #main is parsed before this script, so we don't need to wait for DOMContentLoaded or similar events.\r\n            if (\"framerHydrateV2\" in container.dataset) main(true, container)\r\n            else main(false, container)\r\n        }\r\n\r\n        function track() {\r\n            if (!isBrowser) return\r\n            window.__framer_events.push(arguments)\r\n        }\r\n\r\n        async function main(shouldHydrate, container) {\r\n            try {\r\n                let routeId, localeId, pathVariables, breakpoints\r\n                if (shouldHydrate) {\r\n                    const routeData = JSON.parse(container.dataset.framerHydrateV2)\r\n                    routeId = routeData.routeId\r\n                    localeId = routeData.localeId\r\n                    pathVariables = routeData.pathVariables\r\n                    breakpoints = routeData.breakpoints\r\n                } else {\r\n                    const routeData = Framer.inferInitialRouteFromPath(routes, decodeURIComponent(location.pathname), true, locales)\r\n                    routeId = routeData.routeId\r\n                    localeId = routeData.localeId\r\n                    pathVariables = routeData.pathVariables\r\n                }\r\n\r\n                const page = await getPageRoot({ routeId, localeId, pathVariables })\r\n\r\n                function handleRecoverableError(error, errorInfo) {\r\n                    if (error.caught) return // we already logged it\r\n                    const componentStack = errorInfo?.componentStack\r\n                    console.warn(\"Recoverable error during hydration. Please check any custom code or code overrides to fix server/client mismatches:\\n\", error, componentStack)\r\n                    // we only want to collect 1%, because this can be quite noisy (floods the data pipeline)\r\n                    if (Math.random() > 0.01) return\r\n                    track(\"published_site_load_recoverable_error\", {\r\n                        message: String(error),\r\n                        componentStack, // componentStack is more useful\r\n                        stack: componentStack ? undefined : error instanceof Error && typeof error.stack === \"string\" ? error.stack : null,\r\n                    })\r\n                }\r\n\r\n                if (shouldHydrate) {\r\n                    \r\n\r\n                    Framer.withPerformanceMarks(\"framer-rewrite-breakpoints\", () => {\r\n                        Framer.removeHiddenBreakpointLayersV2(breakpoints)\r\n                        window.__framer_onRewriteBreakpoints?.(breakpoints)\r\n                    })\r\n\r\n                    \r\n\r\n                    const startTransition = React.startTransition\r\n                    startTransition(() => {\r\n                        Framer.markHydrationStart()\r\n                        Framer.setInitialHydrationState()\r\n                        if (true) Framer.turnOffReactEventHandling()\r\n                        ReactDOM.hydrateRoot(container, page, { onRecoverableError: handleRecoverableError })\r\n                    })\r\n                } else {\r\n                    \r\n                    ReactDOM.createRoot(container, { onRecoverableError: handleRecoverableError }).render(page)\r\n                }\r\n            } catch (error) {\r\n                track(\"published_site_load_error\", {\r\n                    message: String(error),\r\n                    stack: error instanceof Error && typeof error.stack === \"string\" ? error.stack : null\r\n                })\r\n                throw error\r\n            }\r\n        }\r\n\r\n        \r\n\r\n        \r\n    "],
  "mappings": "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",
  "names": ["o", "npm_react_dom_18_2_exports", "Ha", "a", "e", "r", "d", "routes", "lazy", "locales", "getPageRoot", "routeId", "pathVariables", "localeId", "content", "B", "PageRoot", "contentWithFeaturesContext", "LibraryFeaturesProvider", "effect", "PageEffectsProvider", "isBrowser", "window", "packageAndFilename", "exportIdentifier", "ErrorPlaceholder", "installFlexboxGapWorkaroundIfNeeded", "container", "main", "track", "shouldHydrate", "handleRecoverableError", "error", "errorInfo", "componentStack", "breakpoints", "routeData", "inferInitialRouteFromPath", "page", "withPerformanceMarks", "removeHiddenBreakpointLayersV2", "Z", "markHydrationStart", "setInitialHydrationState", "turnOffReactEventHandling", "d", "r"]
}
