{
  "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 = {VExZT4YlA: {elements: {cuo8GYxU3: \"our-team\", DNkQS219r: \"gallery\", exfT1EIYi: \"introduction\", FcHEb9Qq4: \"floor-plans\", iWg8urt5D: \"location\", juq39Uyc5: \"features\", qbctJhFAO: \"our-services\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/euKZndnXN41J5dQ848Yc/v1y4ceSsHzEM7UtfLdbV/VExZT4YlA.js\")), path: \"/\"}, E6fb1TP6m: {elements: {AZuAOb69L: \"gin-tasting\", D9g5SAUpz: \"2-course-set-lunch\", hvpV0R2RI: \"floor-plans\", JjtM7E1Mb: \"our-team\", lUTvE_fj7: \"wine-tasting\", MKbYU9gtM: \"introduction\", rfBeIKfwl: \"game-drives\", U_oM_pjTO: \"picnics\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/RRncHuLr7olOIlA8AGlX/2qHZ2nOTHEpy9pygWiQL/E6fb1TP6m.js\")), path: \"/day-activities\"}, ixViiJsLX: {elements: {ABUmBbgQL: \"hot-tub\", CtGhHwm36: \"our-team\", I2SbHVc0D: \"description\", JqJcXJ279: \"villa\", Mv6k_mOaH: \"cabin\", RsgiKsNIm: \"floor-plans\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/HuLz83v6RK18yl41wzTy/0K29qmhM2sf42dI0Bjpe/ixViiJsLX.js\")), path: \"/accommodation\"}, aFvVbbD_k: {elements: {At3D44BBs: \"cabin\", BZI2H3O9O: \"villa\", BZwF5QJry: \"description\", fDTi_fi9v: \"floor-plans\", GXepc_ibQ: \"hot-tub\", w3fmC2q8A: \"our-team\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/2qPCdMMzDKoWs0N6O8O3/lQqSaUxoI3gPt5zgBoMu/aFvVbbD_k.js\")), path: \"/the-villa\"}, kccQ9qraW: {elements: {dFI0y7Mlh: \"our-team\", Lv6whNEhr: \"hot-tub\", QTf51gXec: \"cabin\", vcIR6rgge: \"description\", WPgeFZjT2: \"floor-plans\", zTuz7uMWE: \"villa\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/BAFJivzq3g6bPAhUEr5x/yZLVCoZVpxmiNIdovjJr/kccQ9qraW.js\")), path: \"/the-luxury-cabin\"}, eMtS1yyK6: {elements: {Bc5fXmWYG: \"villa\", iQHjpypbo: \"description\", j_9KaloZ6: \"floor-plans\", LzYgZYGGm: \"our-team\", P6PXQTgDS: \"hot-tub\", yO4E6_a1z: \"cabin\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/8bKZsVVVmOIhM0yPfR5x/RfIm7qFJZUZIiVCvIAT4/eMtS1yyK6.js\")), path: \"/the-deluxe-cabin\"}, K36tJfiJ1: {elements: {IKF8Nwhij: \"introduction\", JtjoWLDjz: \"our-team\", XJ4HFdN8Y: \"our-services\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/DZSqj82oanT5mbAiJdRy/lsbaHLmoiK4Zy1kk3DlR/K36tJfiJ1.js\")), path: \"/conservation-and-community\"}, UaijXhuOU: {elements: {NA9JzqC0L: \"floor-plans\", PApsdKMnu: \"our-team\", qiD0qOL9Q: \"introduction\", tUFiQhuYu: \"gallery\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/R5QAhsHv646MwG6E1Div/uVxqcHy7lNgEhLFL0Ra9/UaijXhuOU.js\")), path: \"/events\"}, xN_yDkSAS: {elements: {rMYaw1kWs: \"gallery\", Tsq2lLrPc: \"introduction\", UrFnhvCI2: \"floor-plans\", vkA1Snpew: \"our-team\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/tpOvqf07NDWyOKDGQ2iS/3OkYO9ozPGQaVVLhYgfQ/xN_yDkSAS.js\")), path: \"/conferencing\"}, dskOhkErT: {elements: {HQlwldqxA: \"floor-plans\"}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/oQ55adJsSP8pUEjXTx8X/oZm6rSrZ14JaWv4SjP2F/dskOhkErT.js\")), path: \"/service-and-rates\"}, hP1E_Tv3A: {elements: {}, page: Framer.lazy(() => import(\"https://framerusercontent.com/modules/wdwsghmacshVqdXjLURv/BxTMrUOlIJ3CVEuHzmBa/hP1E_Tv3A.js\")), path: \"/404\"}}\r\n        const locales = [{code: \"en-ZA\", 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: {},\r\n                    framerSiteId: \"4e4168224a118492c912270d944703746371aac2ad2a61c7493911c10240fb2a\",\r\n                    notFoundPage: Framer.lazy(() => import(\"https://framerusercontent.com/modules/wdwsghmacshVqdXjLURv/BxTMrUOlIJ3CVEuHzmBa/hP1E_Tv3A.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: true, replaceNestedLinks: true, useGranularSuspense: true, wrapUpdatesInTransitions: false}\r\n                }\r\n            )\r\n\r\n            \r\n            const page = React.createElement(Framer.PageEffectsProvider, {\r\n                children: contentWithFeaturesContext,\r\n                value: {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            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                    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                    // 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", "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"]
}
