{
  "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 = {augiA20Il: {elements: {IZgVk43tp: \"projects\", mBQcxsOie: \"about-scroll-section-03\", oNmn0Wr_n: \"home\", qaf_1aPJC: \"about\", ZEJJDn7pz: \"about-scroll-section-02\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/izHS2D5wTRLcPEdnaveH/J78gGUBFZTHzYBe8fUe6/augiA20Il.js\")), path: \"/\"}, dyQGaiQEQ: {elements: {RHmJVCn3y: \"contact\", RoEyNTY8L: \"404\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/tLVAhozL8FCqSunJ1R36/PpLL2Gci2kaaFKOYYy4r/dyQGaiQEQ.js\")), path: \"/404\"}, izRWeepEK: {collectionId: \"kOgwlcBkr\", elements: {RlhcpBoX6: \"projects\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/n26tliNdHXA5sIgLw0ah/N0VFuZURz43hk1oOOgOd/izRWeepEK.js\")), path: \"/:IebhXN_ud\"}}\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: {kOgwlcBkr: async () => (await import(\"https://framerusercontent.com/modules/nEWWAnmbxgZBxT5JqGpx/WAUx8zM3hStKPiGhwEjS/kOgwlcBkr.js\"))?.[\"utils\"]},\r\n                    framerSiteId: \"08eddd7a648343d6c05af456906a4b5c6300a22f6ce57e41ec62226f242938ef\",\r\n                    notFoundPage: Framer.lazy(() => import(\"https://framerusercontent.com/modules/tLVAhozL8FCqSunJ1R36/PpLL2Gci2kaaFKOYYy4r/dyQGaiQEQ.js\")),\r\n                    isReducedMotion: undefined,\r\n                    localeId,\r\n                    locales,\r\n                    preserveQueryParams: undefined,\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: false, useGranularSuspense: false}\r\n                }\r\n            )\r\n\r\n            \r\n            const page = React.createElement(Framer.PageEffectsProvider, {\r\n                children: contentWithFeaturesContext,\r\n                value: {global: {enter: {mask: {type: \"circle\", x: \"50%\", y: \"50%\"}, opacity: 0, rotate: 0, rotate3d: false, rotateX: 0, rotateY: 0, scale: 1, transition: {damping: 30, delay: 0, duration: 0.2, ease: [0.27, 0, 0.51, 1], mass: 1, stiffness: 400, type: \"tween\"}, x: \"0px\", y: \"0px\"}, exit: {opacity: 0, rotate: 0, rotate3d: false, rotateX: 0, rotateY: 0, scale: 1, transition: {damping: 30, delay: 0, duration: 0.2, ease: [0.27, 0, 0.51, 1], mass: 1, stiffness: 400, type: \"tween\"}, x: \"0px\", y: \"0px\"}}, routes: {}}\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            // Fallback support for stack gaps\r\n            Framer.installFlexboxGapWorkaroundIfNeeded()\r\n\r\n            window.__framer_events = window.__framer_events || []\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        function callWhenDOMReady(callback) {\r\n            if (!isBrowser) return\r\n            if (document.readyState === \"interactive\" || document.readyState === \"complete\") {\r\n                callback()\r\n            } else {\r\n                // Note that we\u2019re listening to readystatechange instead of DOMContentLoaded because the latter\r\n                // doesn\u2019t accurately reflect when the DOM is ready. Specifically, it\u2019s delayed by scripts with\r\n                // a defer attribute.\r\n                document.addEventListener(\"readystatechange\", () => {\r\n                    if (document.readyState === \"interactive\") callback()\r\n                })\r\n            }\r\n        }\r\n\r\n        callWhenDOMReady(async function() {\r\n            try {\r\n                const container = document.getElementById(\"main\")\r\n\r\n                let routeId, localeId, pathVariables, breakpoints, shouldHydrate = false\r\n                if (\"framerHydrateV2\" in container.dataset) {\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                    shouldHydrate = true\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                    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.\", error, componentStack)\r\n\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                    Framer.withPerformanceMarks(\"framer-rewrite-breakpoints\", () => {\r\n                        Framer.removeHiddenBreakpointLayersV2(breakpoints)\r\n                        window.__framer_onRewriteBreakpoints?.(breakpoints)\r\n                    })\r\n\r\n                    React.startTransition(() => {\r\n                        Framer.markHydrationStart()\r\n                        Framer.setInitialHydrationState()\r\n                        if (true) Framer.turnOffReactEventHandling()\r\n\r\n                        ReactDOM.hydrateRoot(container, page, { onRecoverableError: handleRecoverableError })\r\n                    })\r\n                } else {\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        callWhenDOMReady(async function () {\r\n            const { default: Badge } = await import(\"__framer-badge\")\r\n            const ContainerWithStyleAppearEffect = Framer.withStyleAppearEffect(Framer.Container)\r\n            React.startTransition(() => {\r\n                ReactDOM.createRoot(document.getElementById(\"__framer-badge-container\"))\r\n                    .render(React.createElement(ContainerWithStyleAppearEffect, {\r\n                        className: \"__framer-badge\",\r\n                        __framer__threshold: 0.5,\r\n                        __framer__animateOnce: true,\r\n                        __framer__opacity: 0,\r\n                        __framer__targetOpacity: 1,\r\n                        __framer__rotate: 0,\r\n                        __framer__x: 0,\r\n                        __framer__y: 10,\r\n                        __framer__scale: 1,\r\n                        __framer__transition: {\r\n                            \"type\": \"spring\",\r\n                            \"ease\": [0.44, 0, 0.56, 1],\r\n                            \"duration\": 0.3,\r\n                            \"delay\": 1,\r\n                            \"stiffness\": 350,\r\n                            \"damping\": 40,\r\n                            \"mass\": 1.5\r\n                        },\r\n                        __framer__rotateX: 0,\r\n                        __framer__rotateY: 0,\r\n                        __framer__perspective: 1200,\r\n                    }, React.createElement(Badge)))\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", "PageEffectsProvider", "isBrowser", "window", "packageAndFilename", "exportIdentifier", "ErrorPlaceholder", "installFlexboxGapWorkaroundIfNeeded", "track", "callWhenDOMReady", "callback", "handleRecoverableError", "error", "errorInfo", "componentStack", "container", "breakpoints", "shouldHydrate", "routeData", "inferInitialRouteFromPath", "page", "withPerformanceMarks", "removeHiddenBreakpointLayersV2", "Z", "markHydrationStart", "setInitialHydrationState", "turnOffReactEventHandling", "d", "r", "Badge", "ContainerWithStyleAppearEffect", "withStyleAppearEffect", "Container"]
}
