{"version":3,"file":"static/js/main.eefd7927.js","mappings":"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tB,EAAAA,WAAAA,EAAAA,eAAAA,GAAAA,EAAAA,IAAAA,EAAAA,EAAAA,QAAAA,EAAAA,cAAAA,EAAAA,EAAAA,YAAAA,EAAAA,mBAAAA,EAAAA,WACA,CACA,MAEA,gBACAp4C,EAAAA,WAAAA,SAAAA,SAAAA,GAAA,gCACAA,EAAAA,aAAAA,SAAAA,SAAAA,GACA,wBACA,eACA,8BACA,yBACA,qEAGA,mBACAssF,GAAAA,EAAAA,SAAAA,GACA,qBAEA,kCACA,wBACA,mBACA,oBACAA,GAAAA,EAAAA,SAAAA,GAGA,gBACA/U,SAAAA,EACApwE,GAAAA,EACAolF,WAAAA,GAAAA,EAAAA,cAAAA,KAGA,qBACA,IAIA,EACA,2BACA,8DAGA,UACA,SACA,OAEA,kBACA,WACA,WACAC,EAAAA,EAAAA,KAAAA,IAEA,IACA,+BAEA,MAEA,kBACA,uBAEA,sDACA90E,EAAAA,WAAAA,SAAAA,SAAAA,GAAA,sBAnBA,CAoBA,CACA,+BACA,uBACA,CACA,aACA,aACA,gBACA,kBACA,gBACA,mBACA,qBACA,oBACA,sBACA,mBACA,cACA,mBACA,aACA,cACA,eACA,eACA,iBACA,MACA,SACA,gBACA,mBACA,iBACA7lB,SAAA,YACA,SACA,GACA,uBACA,WACA,eACA,2BACA,yBACA,WACA,eACA,8BACA,WACA,yBACA,WACA,kBACA,qBACA,WACA,eACA,yBACA,uBACA,WACA,eACA,4BACA,WACA,sBACA,WACA,8BACA,0BACA,OA5XA45F,GA8XA,SAASa,GAAWG,EAAS/0E,GAC7B+0E,EAAAA,OAAAA,GACA/0E,EAAAA,WAAAA,SAAAA,SAAAA,GAAA,iBACA,CACA,SAASg1E,GAAgBR,EAASx0E,EAAGszE,GACrC,mBACA,MACA,SAEA,iBACA,gDAGA,SACA,CACA,SAAS2B,GAAgB73F,EAAK4iB,GAC9B,mBACA,cAGA,UAGA,QACA,CC1eA,mBAcA,OAbA,WACA,IACA,gCASA,CAPA,SACA,IACA2T,EAAAA,WAAAA,CAGA,CADA,SACA,CACA,OACA,CACA,CAEA,ECTA,MACA,SAASuhE,GAAe97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","sources":["../node_modules/@sentry/src/env.ts","../node_modules/@sentry/src/node.ts","../node_modules/@sentry/src/time.ts","../node_modules/@sentry/src/worldwide.ts","../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/react-dom/client.js","../node_modules/react-dom/index.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/react-is/index.js","../node_modules/react/cjs/react-jsx-runtime.production.min.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react/index.js","../node_modules/react/jsx-runtime.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/scheduler/index.js","../webpack/bootstrap","../webpack/runtime/create fake namespace object","../webpack/runtime/define property getters","../webpack/runtime/global","../webpack/runtime/harmony module decorator","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/make namespace object","../webpack/runtime/publicPath","../node_modules/@remix-run/router/history.ts","../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/@babel/runtime/helpers/esm/createClass.js","../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/inherits.js","../node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/isNativeReflectConstruct.js","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","../node_modules/@babel/runtime/helpers/esm/createSuper.js","../node_modules/@babel/runtime/helpers/esm/construct.js","../node_modules/@babel/runtime/helpers/esm/wrapNativeSuper.js","../node_modules/@babel/runtime/helpers/esm/isNativeFunction.js","../node_modules/@babel/runtime/helpers/esm/createForOfIteratorHelper.js","../node_modules/@remix-run/router/utils.ts","../node_modules/@babel/runtime/helpers/esm/toArray.js","../node_modules/@remix-run/router/router.ts","../node_modules/react-router/lib/context.ts","../node_modules/react-router/lib/hooks.tsx","../node_modules/react-router/lib/components.tsx","../node_modules/react-router-dom/index.tsx","../node_modules/react-router-dom/dom.ts","context/State.jsx","img/tail-spin.svg","components/Loader.jsx","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","util/GetCopy.jsx","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/react-select/dist/useStateManager-7e1e8489.esm.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/extends.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/createClass.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/createSuper.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/isNativeReflectConstruct.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../node_modules/@emotion/sheet/dist/emotion-sheet.browser.esm.js","../node_modules/stylis/src/Utility.js","../node_modules/stylis/src/Tokenizer.js","../node_modules/stylis/src/Enum.js","../node_modules/stylis/src/Serializer.js","../node_modules/stylis/src/Parser.js","../node_modules/@emotion/cache/dist/emotion-cache.browser.esm.js","../node_modules/stylis/src/Middleware.js","../node_modules/@emotion/utils/dist/emotion-utils.browser.esm.js","../node_modules/@emotion/unitless/dist/emotion-unitless.esm.js","../node_modules/@emotion/memoize/dist/emotion-memoize.esm.js","../node_modules/@emotion/serialize/dist/emotion-serialize.browser.esm.js","../node_modules/@emotion/hash/dist/emotion-hash.esm.js","../node_modules/@emotion/use-insertion-effect-with-fallbacks/dist/emotion-use-insertion-effect-with-fallbacks.browser.esm.js","../node_modules/@emotion/react/dist/emotion-element-c39617d8.browser.esm.js","../node_modules/@emotion/react/dist/emotion-react.browser.esm.js","../node_modules/@babel/runtime/helpers/esm/regeneratorRuntime.js","../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","../node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../node_modules/@floating-ui/utils/dom/dist/floating-ui.utils.dom.mjs","../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../node_modules/use-isomorphic-layout-effect/dist/use-isomorphic-layout-effect.browser.esm.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/taggedTemplateLiteral.js","../node_modules/memoize-one/dist/memoize-one.esm.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/inherits.js","../node_modules/react-select/node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/react-select/dist/react-select.esm.js","components/Dropdown.jsx","../node_modules/src/observe.ts","../node_modules/src/InView.tsx","../node_modules/src/useInView.tsx","components/VideoCarouselCard.jsx","img/check.svg","components/VideoCarousel.jsx","img/vipad-300x250.svg","components/ToggleButton.jsx","components/Hero.jsx","components/FilteredVideoCarousel.jsx","img/vipad-300x600.svg","img/pc-970x250.svg","img/pc-160x600.svg","img/video_300x250.svg","img/ctv.svg","img/expand_content.svg","img/collapse_all.svg","img/arrowUpRight.svg","components/Device.jsx","img/BackButton.svg","img/mobile.svg","components/AdSize.jsx","img/pc.svg","img/tv.svg","components/ScreenSize.jsx","components/BrandBody.jsx","components/BrandPage.jsx","hooks/scrollToTop.jsx","../node_modules/@sentry/src/logger.ts","../node_modules/@sentry/src/is.ts","../node_modules/@sentry/src/browser.ts","../node_modules/@sentry/src/string.ts","../node_modules/@sentry/src/object.ts","../node_modules/@sentry/src/misc.ts","../node_modules/@sentry/src/integrations/inboundfilters.ts","../node_modules/@sentry/src/integrations/functiontostring.ts","../node_modules/@sentry/src/syncpromise.ts","../node_modules/@sentry/src/constants.ts","../node_modules/@sentry/src/session.ts","../node_modules/@sentry/src/scope.ts","../node_modules/@sentry/src/hub.ts","../node_modules/@sentry/src/integration.ts","../node_modules/@sentry/src/sdk.ts","../node_modules/@sentry/src/stacktrace.ts","../node_modules/@sentry/src/supports.ts","../node_modules/@sentry/src/vendor/supportsHistory.ts","../node_modules/@sentry/src/instrument.ts","../node_modules/@babel/runtime/helpers/esm/superPropBase.js","../node_modules/@babel/runtime/helpers/esm/get.js","../node_modules/@sentry/src/version.ts","../node_modules/@sentry/src/dsn.ts","../node_modules/@sentry/src/memo.ts","../node_modules/@sentry/src/normalize.ts","../node_modules/@sentry/src/envelope.ts","../node_modules/@sentry/src/error.ts","../node_modules/@sentry/src/api.ts","../node_modules/@sentry/src/tracing/dynamicSamplingContext.ts","../node_modules/@sentry/src/utils/prepareEvent.ts","../node_modules/@sentry/src/baseclient.ts","../node_modules/src/eventbuilder.ts","../node_modules/@sentry/src/exports.ts","../node_modules/src/helpers.ts","../node_modules/@sentry/src/severity.ts","../node_modules/@sentry/src/url.ts","../node_modules/src/integrations/breadcrumbs.ts","../node_modules/src/client.ts","../node_modules/src/userfeedback.ts","../node_modules/@sentry/src/clientreport.ts","../node_modules/src/integrations/globalhandlers.ts","../node_modules/src/integrations/trycatch.ts","../node_modules/@sentry/src/aggregate-errors.ts","../node_modules/src/integrations/linkederrors.ts","../node_modules/src/integrations/httpcontext.ts","../node_modules/src/integrations/dedupe.ts","../node_modules/src/stack-parsers.ts","../node_modules/@sentry/src/promisebuffer.ts","../node_modules/@sentry/src/ratelimit.ts","../node_modules/@sentry/src/transports/base.ts","../node_modules/src/transports/utils.ts","../node_modules/src/transports/fetch.ts","../node_modules/src/transports/xhr.ts","../node_modules/src/sdk.ts","../node_modules/@sentry/src/baggage.ts","../node_modules/@sentry/src/tracing.ts","../node_modules/@sentry/src/tracing/span.ts","../node_modules/@sentry/src/tracing/transaction.ts","../node_modules/@sentry/src/tracing/idletransaction.ts","../node_modules/@sentry/src/utils/hasTracingEnabled.ts","../node_modules/@sentry/src/tracing/utils.ts","../node_modules/@sentry/src/tracing/errors.ts","../node_modules/@sentry/src/tracing/hubextensions.ts","../node_modules/@sentry-internal/src/browser/types.ts","../node_modules/@sentry-internal/src/browser/web-vitals/lib/bindReporter.ts","../node_modules/@sentry-internal/src/browser/web-vitals/lib/getNavigationEntry.ts","../node_modules/@sentry-internal/src/browser/web-vitals/lib/getActivationStart.ts","../node_modules/@sentry-internal/src/browser/web-vitals/lib/initMetric.ts","../node_modules/@sentry-internal/src/browser/web-vitals/lib/generateUniqueID.ts","../node_modules/@sentry-internal/src/browser/web-vitals/lib/observe.ts","../node_modules/@sentry-internal/src/browser/web-vitals/lib/onHidden.ts","../node_modules/@sentry-internal/src/browser/web-vitals/lib/getVisibilityWatcher.ts","../node_modules/@sentry-internal/src/browser/web-vitals/getLCP.ts","../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/@sentry-internal/src/browser/metrics/utils.ts","../node_modules/@sentry-internal/src/browser/metrics/index.ts","../node_modules/@sentry-internal/src/browser/web-vitals/getFID.ts","../node_modules/@sentry-internal/src/browser/web-vitals/getCLS.ts","../node_modules/@sentry-internal/src/browser/request.ts","../node_modules/@sentry-internal/src/browser/browsertracing.ts","../node_modules/@sentry-internal/src/browser/router.ts","../node_modules/@sentry-internal/src/browser/backgroundtab.ts","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb-snapshot/es/rrweb-snapshot.js","../node_modules/src/constants.ts","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/types.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/utils.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/mutation.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/sentry/callbackWrapper.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/observer.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/iframe-manager.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/shadow-dom-manager.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/ext/base64-arraybuffer/dist/base64-arraybuffer.es5.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/serialize-args.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/webgl.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/index.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/canvas-manager.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/canvas.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/packages/rrweb/src/record/observers/canvas/2d.js","../../node_modules/@sentry-internal/rrweb/es/rrweb/ext/tslib/tslib.es6.js","../node_modules/src/util/timestamp.ts","../node_modules/src/coreHandlers/util/addBreadcrumbEvent.ts","../node_modules/src/coreHandlers/util/domUtils.ts","../node_modules/src/coreHandlers/util/onWindowOpen.ts","../../node_modules/@sentry-internal/rrweb-snapshot/es/rrweb-snapshot.js","../node_modules/src/coreHandlers/handleClick.ts","../node_modules/src/util/createBreadcrumb.ts","../node_modules/src/coreHandlers/util/getAttributesToRecord.ts","../node_modules/src/coreHandlers/handleDom.ts","../node_modules/src/coreHandlers/handleKeyboardEvent.ts","../node_modules/src/util/dedupePerformanceEntries.ts","../node_modules/src/coreHandlers/performanceObserver.ts","../node_modules/src/util/log.ts","../node_modules/src/eventBuffer/error.ts","../node_modules/src/eventBuffer/EventBufferArray.ts","../node_modules/src/eventBuffer/WorkerHandler.ts","../node_modules/src/eventBuffer/EventBufferCompressionWorker.ts","../node_modules/src/eventBuffer/EventBufferProxy.ts","../node_modules/src/eventBuffer/index.ts","../replay-worker/build/npm/esm/index.js","../replay-worker/build/npm/esm/worker.ts","../node_modules/src/util/hasSessionStorage.ts","../node_modules/src/session/clearSession.ts","../node_modules/src/util/isExpired.ts","../node_modules/src/util/isSessionExpired.ts","../node_modules/src/util/isSampled.ts","../node_modules/src/session/saveSession.ts","../node_modules/src/session/Session.ts","../node_modules/src/session/createSession.ts","../node_modules/src/session/getSession.ts","../node_modules/src/session/fetchSession.ts","../node_modules/src/util/addEvent.ts","../node_modules/src/util/eventUtils.ts","../node_modules/src/coreHandlers/handleAfterSendEvent.ts","../node_modules/src/util/isRrwebError.ts","../node_modules/src/coreHandlers/util/shouldSampleForBufferEvent.ts","../node_modules/src/util/createPerformanceSpans.ts","../node_modules/src/coreHandlers/handleHistory.ts","../node_modules/src/util/shouldFilterRequest.ts","../node_modules/src/coreHandlers/util/addNetworkBreadcrumb.ts","../node_modules/src/util/truncateJson/constants.ts","../node_modules/src/util/truncateJson/completeJson.ts","../node_modules/src/util/truncateJson/evaluateJson.ts","../node_modules/src/util/truncateJson/fixJson.ts","../node_modules/src/coreHandlers/util/networkUtils.ts","../node_modules/src/coreHandlers/util/fetchUtils.ts","../node_modules/src/coreHandlers/util/xhrUtils.ts","../node_modules/src/coreHandlers/handleNetworkBreadcrumbs.ts","../node_modules/src/coreHandlers/handleFetch.ts","../node_modules/src/coreHandlers/handleXhr.ts","../node_modules/src/coreHandlers/handleScope.ts","../node_modules/src/util/addGlobalListeners.ts","../node_modules/src/coreHandlers/handleGlobalEvent.ts","../node_modules/src/util/addMemoryEntry.ts","../node_modules/src/util/createPerformanceEntries.ts","../node_modules/src/util/handleRecordingEmit.ts","../node_modules/src/util/createReplayEnvelope.ts","../node_modules/src/util/prepareRecordingData.ts","../node_modules/src/util/prepareReplayEvent.ts","../node_modules/src/util/sendReplayRequest.ts","../node_modules/src/util/sendReplay.ts","../node_modules/src/util/throttle.ts","../node_modules/src/replay.ts","../node_modules/src/util/debounce.ts","../node_modules/src/util/getPrivacyOptions.ts","../node_modules/src/util/isBrowser.ts","../node_modules/src/integration.ts","App.js","index.js"],"sourcesContent":["/*\n * This module exists for optimizations in the build process through rollup and terser. We define some global\n * constants, which can be overridden during build. By guarding certain pieces of code with functions that return these\n * constants, we can control whether or not they appear in the final bundle. (Any code guarded by a false condition will\n * never run, and will hence be dropped during treeshaking.) The two primary uses for this are stripping out calls to\n * `logger` and preventing node-related code from appearing in browser bundles.\n *\n * Attention:\n * This file should not be used to define constants/flags that are intended to be used for tree-shaking conducted by\n * users. These flags should live in their respective packages, as we identified user tooling (specifically webpack)\n * having issues tree-shaking these constants across package boundaries.\n * An example for this is the __SENTRY_DEBUG__ constant. It is declared in each package individually because we want\n * users to be able to shake away expressions that it guards.\n */\n\ndeclare const __SENTRY_BROWSER_BUNDLE__: boolean | undefined;\n\nexport type SdkSource = 'npm' | 'cdn' | 'loader';\n\n/**\n * Figures out if we're building a browser bundle.\n *\n * @returns true if this is a browser bundle build.\n */\nexport function isBrowserBundle(): boolean {\n return typeof __SENTRY_BROWSER_BUNDLE__ !== 'undefined' && !!__SENTRY_BROWSER_BUNDLE__;\n}\n\n/**\n * Get source of SDK.\n */\nexport function getSDKSource(): SdkSource {\n // @ts-ignore __SENTRY_SDK_SOURCE__ is injected by rollup during build process\n return __SENTRY_SDK_SOURCE__;\n}\n","/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the logger, or b) put your function elsewhere.\n */\n\nimport { isBrowserBundle } from './env';\n\n/**\n * Checks whether we're in the Node.js or Browser environment\n *\n * @returns Answer to given question\n */\nexport function isNodeEnv(): boolean {\n // explicitly check for browser bundles as those can be optimized statically\n // by terser/rollup.\n return (\n !isBrowserBundle() &&\n Object.prototype.toString.call(typeof process !== 'undefined' ? process : 0) === '[object process]'\n );\n}\n\n/**\n * Requires a module which is protected against bundler minification.\n *\n * @param request The module path to resolve\n */\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types, @typescript-eslint/no-explicit-any\nexport function dynamicRequire(mod: any, request: string): any {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return mod.require(request);\n}\n\n/**\n * Helper for dynamically loading module that should work with linked dependencies.\n * The problem is that we _should_ be using `require(require.resolve(moduleName, { paths: [cwd()] }))`\n * However it's _not possible_ to do that with Webpack, as it has to know all the dependencies during\n * build time. `require.resolve` is also not available in any other way, so we cannot create,\n * a fake helper like we do with `dynamicRequire`.\n *\n * We always prefer to use local package, thus the value is not returned early from each `try/catch` block.\n * That is to mimic the behavior of `require.resolve` exactly.\n *\n * @param moduleName module name to require\n * @returns possibly required module\n */\nexport function loadModule<T>(moduleName: string): T | undefined {\n let mod: T | undefined;\n\n try {\n mod = dynamicRequire(module, moduleName);\n } catch (e) {\n // no-empty\n }\n\n try {\n const { cwd } = dynamicRequire(module, 'process');\n mod = dynamicRequire(module, `${cwd()}/node_modules/${moduleName}`) as T;\n } catch (e) {\n // no-empty\n }\n\n return mod;\n}\n","import { dynamicRequire, isNodeEnv } from './node';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\n/**\n * An object that can return the current timestamp in seconds since the UNIX epoch.\n */\ninterface TimestampSource {\n nowSeconds(): number;\n}\n\n/**\n * A TimestampSource implementation for environments that do not support the Performance Web API natively.\n *\n * Note that this TimestampSource does not use a monotonic clock. A call to `nowSeconds` may return a timestamp earlier\n * than a previously returned value. We do not try to emulate a monotonic behavior in order to facilitate debugging. It\n * is more obvious to explain \"why does my span have negative duration\" than \"why my spans have zero duration\".\n */\nconst dateTimestampSource: TimestampSource = {\n nowSeconds: () => Date.now() / 1000,\n};\n\n/**\n * A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance}\n * for accessing a high-resolution monotonic clock.\n */\ninterface Performance {\n /**\n * The millisecond timestamp at which measurement began, measured in Unix time.\n */\n timeOrigin: number;\n /**\n * Returns the current millisecond timestamp, where 0 represents the start of measurement.\n */\n now(): number;\n}\n\n/**\n * Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not\n * support the API.\n *\n * Wrapping the native API works around differences in behavior from different browsers.\n */\nfunction getBrowserPerformance(): Performance | undefined {\n const { performance } = WINDOW;\n if (!performance || !performance.now) {\n return undefined;\n }\n\n // Replace performance.timeOrigin with our own timeOrigin based on Date.now().\n //\n // This is a partial workaround for browsers reporting performance.timeOrigin such that performance.timeOrigin +\n // performance.now() gives a date arbitrarily in the past.\n //\n // Additionally, computing timeOrigin in this way fills the gap for browsers where performance.timeOrigin is\n // undefined.\n //\n // The assumption that performance.timeOrigin + performance.now() ~= Date.now() is flawed, but we depend on it to\n // interact with data coming out of performance entries.\n //\n // Note that despite recommendations against it in the spec, browsers implement the Performance API with a clock that\n // might stop when the computer is asleep (and perhaps under other circumstances). Such behavior causes\n // performance.timeOrigin + performance.now() to have an arbitrary skew over Date.now(). In laptop computers, we have\n // observed skews that can be as long as days, weeks or months.\n //\n // See https://github.com/getsentry/sentry-javascript/issues/2590.\n //\n // BUG: despite our best intentions, this workaround has its limitations. It mostly addresses timings of pageload\n // transactions, but ignores the skew built up over time that can aversely affect timestamps of navigation\n // transactions of long-lived web pages.\n const timeOrigin = Date.now() - performance.now();\n\n return {\n now: () => performance.now(),\n timeOrigin,\n };\n}\n\n/**\n * Returns the native Performance API implementation from Node.js. Returns undefined in old Node.js versions that don't\n * implement the API.\n */\nfunction getNodePerformance(): Performance | undefined {\n try {\n const perfHooks = dynamicRequire(module, 'perf_hooks') as { performance: Performance };\n return perfHooks.performance;\n } catch (_) {\n return undefined;\n }\n}\n\n/**\n * The Performance API implementation for the current platform, if available.\n */\nconst platformPerformance: Performance | undefined = isNodeEnv() ? getNodePerformance() : getBrowserPerformance();\n\nconst timestampSource: TimestampSource =\n platformPerformance === undefined\n ? dateTimestampSource\n : {\n nowSeconds: () => (platformPerformance.timeOrigin + platformPerformance.now()) / 1000,\n };\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using the Date API.\n */\nexport const dateTimestampInSeconds: () => number = dateTimestampSource.nowSeconds.bind(dateTimestampSource);\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the\n * availability of the Performance API.\n *\n * See `usingPerformanceAPI` to test whether the Performance API is used.\n *\n * BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is\n * asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The\n * skew can grow to arbitrary amounts like days, weeks or months.\n * See https://github.com/getsentry/sentry-javascript/issues/2590.\n */\nexport const timestampInSeconds: () => number = timestampSource.nowSeconds.bind(timestampSource);\n\n/**\n * Re-exported with an old name for backwards-compatibility.\n * TODO (v8): Remove this\n *\n * @deprecated Use `timestampInSeconds` instead.\n */\nexport const timestampWithMs = timestampInSeconds;\n\n/**\n * A boolean that is true when timestampInSeconds uses the Performance API to produce monotonic timestamps.\n */\nexport const usingPerformanceAPI = platformPerformance !== undefined;\n\n/**\n * Internal helper to store what is the source of browserPerformanceTimeOrigin below. For debugging only.\n */\nexport let _browserPerformanceTimeOriginMode: string;\n\n/**\n * The number of milliseconds since the UNIX epoch. This value is only usable in a browser, and only when the\n * performance API is available.\n */\nexport const browserPerformanceTimeOrigin = ((): number | undefined => {\n // Unfortunately browsers may report an inaccurate time origin data, through either performance.timeOrigin or\n // performance.timing.navigationStart, which results in poor results in performance data. We only treat time origin\n // data as reliable if they are within a reasonable threshold of the current time.\n\n const { performance } = WINDOW;\n if (!performance || !performance.now) {\n _browserPerformanceTimeOriginMode = 'none';\n return undefined;\n }\n\n const threshold = 3600 * 1000;\n const performanceNow = performance.now();\n const dateNow = Date.now();\n\n // if timeOrigin isn't available set delta to threshold so it isn't used\n const timeOriginDelta = performance.timeOrigin\n ? Math.abs(performance.timeOrigin + performanceNow - dateNow)\n : threshold;\n const timeOriginIsReliable = timeOriginDelta < threshold;\n\n // While performance.timing.navigationStart is deprecated in favor of performance.timeOrigin, performance.timeOrigin\n // is not as widely supported. Namely, performance.timeOrigin is undefined in Safari as of writing.\n // Also as of writing, performance.timing is not available in Web Workers in mainstream browsers, so it is not always\n // a valid fallback. In the absence of an initial time provided by the browser, fallback to the current time from the\n // Date API.\n // eslint-disable-next-line deprecation/deprecation\n const navigationStart = performance.timing && performance.timing.navigationStart;\n const hasNavigationStart = typeof navigationStart === 'number';\n // if navigationStart isn't available set delta to threshold so it isn't used\n const navigationStartDelta = hasNavigationStart ? Math.abs(navigationStart + performanceNow - dateNow) : threshold;\n const navigationStartIsReliable = navigationStartDelta < threshold;\n\n if (timeOriginIsReliable || navigationStartIsReliable) {\n // Use the more reliable time origin\n if (timeOriginDelta <= navigationStartDelta) {\n _browserPerformanceTimeOriginMode = 'timeOrigin';\n return performance.timeOrigin;\n } else {\n _browserPerformanceTimeOriginMode = 'navigationStart';\n return navigationStart;\n }\n }\n\n // Either both timeOrigin and navigationStart are skewed or neither is available, fallback to Date.\n _browserPerformanceTimeOriginMode = 'dateNow';\n return dateNow;\n})();\n","/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the logger, or b) put your function elsewhere.\n *\n * Note: This file was originally called `global.ts`, but was changed to unblock users which might be doing\n * string replaces with bundlers like Vite for `global` (would break imports that rely on importing from utils/src/global).\n *\n * Why worldwide?\n *\n * Why not?\n */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport type { Integration } from '@sentry/types';\n\nimport type { SdkSource } from './env';\n\n/** Internal global with common properties and Sentry extensions */\nexport interface InternalGlobal {\n navigator?: { userAgent?: string };\n console: Console;\n Sentry?: {\n Integrations?: Integration[];\n };\n onerror?: {\n (msg: unknown, url: unknown, line: unknown, column: unknown, error: unknown): boolean;\n __SENTRY_INSTRUMENTED__?: true;\n __SENTRY_LOADER__?: true;\n };\n onunhandledrejection?: {\n (event: unknown): boolean;\n __SENTRY_INSTRUMENTED__?: true;\n __SENTRY_LOADER__?: true;\n };\n SENTRY_ENVIRONMENT?: string;\n SENTRY_DSN?: string;\n SENTRY_RELEASE?: {\n id?: string;\n };\n SENTRY_SDK_SOURCE?: SdkSource;\n /**\n * Debug IDs are indirectly injected by Sentry CLI or bundler plugins to directly reference a particular source map\n * for resolving of a source file. The injected code will place an entry into the record for each loaded bundle/JS\n * file.\n */\n _sentryDebugIds?: Record<string, string>;\n __SENTRY__: {\n globalEventProcessors: any;\n hub: any;\n logger: any;\n extensions?: {\n /** Extension methods for the hub, which are bound to the current Hub instance */\n // eslint-disable-next-line @typescript-eslint/ban-types\n [key: string]: Function;\n };\n };\n /**\n * Raw module metadata that is injected by bundler plugins.\n *\n * Keys are `error.stack` strings, values are the metadata.\n */\n _sentryModuleMetadata?: Record<string, any>;\n}\n\n// The code below for 'isGlobalObj' and 'GLOBAL_OBJ' was copied from core-js before modification\n// https://github.com/zloirock/core-js/blob/1b944df55282cdc99c90db5f49eb0b6eda2cc0a3/packages/core-js/internals/global.js\n// core-js has the following licence:\n//\n// Copyright (c) 2014-2022 Denis Pushkarev\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/** Returns 'obj' if it's the global object, otherwise returns undefined */\nfunction isGlobalObj(obj: { Math?: Math }): any | undefined {\n return obj && obj.Math == Math ? obj : undefined;\n}\n\n/** Get's the global object for the current JavaScript runtime */\nexport const GLOBAL_OBJ: InternalGlobal =\n (typeof globalThis == 'object' && isGlobalObj(globalThis)) ||\n // eslint-disable-next-line no-restricted-globals\n (typeof window == 'object' && isGlobalObj(window)) ||\n (typeof self == 'object' && isGlobalObj(self)) ||\n (typeof global == 'object' && isGlobalObj(global)) ||\n (function (this: any) {\n return this;\n })() ||\n {};\n\n/**\n * @deprecated Use GLOBAL_OBJ instead or WINDOW from @sentry/browser. This will be removed in v8\n */\nexport function getGlobalObject<T>(): T & InternalGlobal {\n return GLOBAL_OBJ as T & InternalGlobal;\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nexport function getGlobalSingleton<T>(name: keyof InternalGlobal['__SENTRY__'], creator: () => T, obj?: unknown): T {\n const gbl = (obj || GLOBAL_OBJ) as InternalGlobal;\n const __SENTRY__ = (gbl.__SENTRY__ = gbl.__SENTRY__ || {});\n const singleton = __SENTRY__[name] || (__SENTRY__[name] = creator());\n return singleton;\n}\n","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;c<arguments.length;c++)b+=\"&args[]=\"+encodeURIComponent(arguments[c]);return\"Minified React error #\"+a+\"; visit \"+b+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"}var da=new Set,ea={};function fa(a,b){ha(a,b);ha(a+\"Capture\",b)}\nfunction ha(a,b){ea[a]=b;for(a=0;a<b.length;a++)da.add(b[a])}\nvar ia=!(\"undefined\"===typeof window||\"undefined\"===typeof window.document||\"undefined\"===typeof window.document.createElement),ja=Object.prototype.hasOwnProperty,ka=/^[:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD][:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD\\-.0-9\\u00B7\\u0300-\\u036F\\u203F-\\u2040]*$/,la=\n{},ma={};function oa(a){if(ja.call(ma,a))return!0;if(ja.call(la,a))return!1;if(ka.test(a))return ma[a]=!0;la[a]=!0;return!1}function pa(a,b,c,d){if(null!==c&&0===c.type)return!1;switch(typeof b){case \"function\":case \"symbol\":return!0;case \"boolean\":if(d)return!1;if(null!==c)return!c.acceptsBooleans;a=a.toLowerCase().slice(0,5);return\"data-\"!==a&&\"aria-\"!==a;default:return!1}}\nfunction qa(a,b,c,d){if(null===b||\"undefined\"===typeof b||pa(a,b,c,d))return!0;if(d)return!1;if(null!==c)switch(c.type){case 3:return!b;case 4:return!1===b;case 5:return isNaN(b);case 6:return isNaN(b)||1>b}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2<b.length)||\"o\"!==b[0]&&\"O\"!==b[0]||\"n\"!==b[1]&&\"N\"!==b[1])qa(b,c,e,d)&&(c=null),d||null===e?oa(b)&&(null===c?a.removeAttribute(b):a.setAttribute(b,\"\"+c)):e.mustUseProperty?a[e.propertyName]=null===c?3===e.type?!1:\"\":c:(b=e.attributeName,d=e.attributeNamespace,null===c?a.removeAttribute(b):(e=e.type,c=3===e||4===e&&!0===c?\"\":\"\"+c,d?a.setAttributeNS(d,b,c):a.setAttribute(b,c)))}\nvar ua=aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,va=Symbol.for(\"react.element\"),wa=Symbol.for(\"react.portal\"),ya=Symbol.for(\"react.fragment\"),za=Symbol.for(\"react.strict_mode\"),Aa=Symbol.for(\"react.profiler\"),Ba=Symbol.for(\"react.provider\"),Ca=Symbol.for(\"react.context\"),Da=Symbol.for(\"react.forward_ref\"),Ea=Symbol.for(\"react.suspense\"),Fa=Symbol.for(\"react.suspense_list\"),Ga=Symbol.for(\"react.memo\"),Ha=Symbol.for(\"react.lazy\");Symbol.for(\"react.scope\");Symbol.for(\"react.debug_trace_mode\");\nvar Ia=Symbol.for(\"react.offscreen\");Symbol.for(\"react.legacy_hidden\");Symbol.for(\"react.cache\");Symbol.for(\"react.tracing_marker\");var Ja=Symbol.iterator;function Ka(a){if(null===a||\"object\"!==typeof a)return null;a=Ja&&a[Ja]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}var A=Object.assign,La;function Ma(a){if(void 0===La)try{throw Error();}catch(c){var b=c.stack.trim().match(/\\n( *(at )?)/);La=b&&b[1]||\"\"}return\"\\n\"+La+a}var Na=!1;\nfunction Oa(a,b){if(!a||Na)return\"\";Na=!0;var c=Error.prepareStackTrace;Error.prepareStackTrace=void 0;try{if(b)if(b=function(){throw Error();},Object.defineProperty(b.prototype,\"props\",{set:function(){throw Error();}}),\"object\"===typeof Reflect&&Reflect.construct){try{Reflect.construct(b,[])}catch(l){var d=l}Reflect.construct(a,[],b)}else{try{b.call()}catch(l){d=l}a.call(b.prototype)}else{try{throw Error();}catch(l){d=l}a()}}catch(l){if(l&&d&&\"string\"===typeof l.stack){for(var e=l.stack.split(\"\\n\"),\nf=d.stack.split(\"\\n\"),g=e.length-1,h=f.length-1;1<=g&&0<=h&&e[g]!==f[h];)h--;for(;1<=g&&0<=h;g--,h--)if(e[g]!==f[h]){if(1!==g||1!==h){do if(g--,h--,0>h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"<anonymous>\")&&(k=k.replace(\"<anonymous>\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e<c.length;e++)b[\"$\"+c[e]]=!0;for(c=0;c<a.length;c++)e=b.hasOwnProperty(\"$\"+a[c].value),a[c].selected!==e&&(a[c].selected=e),e&&d&&(a[c].defaultSelected=!0)}else{c=\"\"+Sa(c);b=null;for(e=0;e<a.length;e++){if(a[e].value===c){a[e].selected=!0;d&&(a[e].defaultSelected=!0);return}null!==b||a[e].disabled||(b=a[e])}null!==b&&(b.selected=!0)}}\nfunction gb(a,b){if(null!=b.dangerouslySetInnerHTML)throw Error(p(91));return A({},b,{value:void 0,defaultValue:void 0,children:\"\"+a._wrapperState.initialValue})}function hb(a,b){var c=b.value;if(null==c){c=b.children;b=b.defaultValue;if(null!=c){if(null!=b)throw Error(p(92));if(eb(c)){if(1<c.length)throw Error(p(93));c=c[0]}b=c}null==b&&(b=\"\");c=b}a._wrapperState={initialValue:Sa(c)}}\nfunction ib(a,b){var c=Sa(b.value),d=Sa(b.defaultValue);null!=c&&(c=\"\"+c,c!==a.value&&(a.value=c),null==b.defaultValue&&a.defaultValue!==c&&(a.defaultValue=c));null!=d&&(a.defaultValue=\"\"+d)}function jb(a){var b=a.textContent;b===a._wrapperState.initialValue&&\"\"!==b&&null!==b&&(a.value=b)}function kb(a){switch(a){case \"svg\":return\"http://www.w3.org/2000/svg\";case \"math\":return\"http://www.w3.org/1998/Math/MathML\";default:return\"http://www.w3.org/1999/xhtml\"}}\nfunction lb(a,b){return null==a||\"http://www.w3.org/1999/xhtml\"===a?kb(b):\"http://www.w3.org/2000/svg\"===a&&\"foreignObject\"===b?\"http://www.w3.org/1999/xhtml\":a}\nvar mb,nb=function(a){return\"undefined\"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(b,c,d,e){MSApp.execUnsafeLocalFunction(function(){return a(b,c,d,e)})}:a}(function(a,b){if(\"http://www.w3.org/2000/svg\"!==a.namespaceURI||\"innerHTML\"in a)a.innerHTML=b;else{mb=mb||document.createElement(\"div\");mb.innerHTML=\"<svg>\"+b.valueOf().toString()+\"</svg>\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a<b.length;a++)Bb(b[a])}}function Gb(a,b){return a(b)}function Hb(){}var Ib=!1;function Jb(a,b,c){if(Ib)return a(b,c);Ib=!0;try{return Gb(a,b,c)}finally{if(Ib=!1,null!==zb||null!==Ab)Hb(),Fb()}}\nfunction Kb(a,b){var c=a.stateNode;if(null===c)return null;var d=Db(c);if(null===d)return null;c=d[b];a:switch(b){case \"onClick\":case \"onClickCapture\":case \"onDoubleClick\":case \"onDoubleClickCapture\":case \"onMouseDown\":case \"onMouseDownCapture\":case \"onMouseMove\":case \"onMouseMoveCapture\":case \"onMouseUp\":case \"onMouseUpCapture\":case \"onMouseEnter\":(d=!d.disabled)||(a=a.type,d=!(\"button\"===a||\"input\"===a||\"select\"===a||\"textarea\"===a));a=!d;break a;default:a=!1}if(a)return null;if(c&&\"function\"!==\ntypeof c)throw Error(p(231,b,typeof c));return c}var Lb=!1;if(ia)try{var Mb={};Object.defineProperty(Mb,\"passive\",{get:function(){Lb=!0}});window.addEventListener(\"test\",Mb,Mb);window.removeEventListener(\"test\",Mb,Mb)}catch(a){Lb=!1}function Nb(a,b,c,d,e,f,g,h,k){var l=Array.prototype.slice.call(arguments,3);try{b.apply(c,l)}catch(m){this.onError(m)}}var Ob=!1,Pb=null,Qb=!1,Rb=null,Sb={onError:function(a){Ob=!0;Pb=a}};function Tb(a,b,c,d,e,f,g,h,k){Ob=!1;Pb=null;Nb.apply(Sb,arguments)}\nfunction Ub(a,b,c,d,e,f,g,h,k){Tb.apply(this,arguments);if(Ob){if(Ob){var l=Pb;Ob=!1;Pb=null}else throw Error(p(198));Qb||(Qb=!0,Rb=l)}}function Vb(a){var b=a,c=a;if(a.alternate)for(;b.return;)b=b.return;else{a=b;do b=a,0!==(b.flags&4098)&&(c=b.return),a=b.return;while(a)}return 3===b.tag?c:null}function Wb(a){if(13===a.tag){var b=a.memoizedState;null===b&&(a=a.alternate,null!==a&&(b=a.memoizedState));if(null!==b)return b.dehydrated}return null}function Xb(a){if(Vb(a)!==a)throw Error(p(188));}\nfunction Yb(a){var b=a.alternate;if(!b){b=Vb(a);if(null===b)throw Error(p(188));return b!==a?null:a}for(var c=a,d=b;;){var e=c.return;if(null===e)break;var f=e.alternate;if(null===f){d=e.return;if(null!==d){c=d;continue}break}if(e.child===f.child){for(f=e.child;f;){if(f===c)return Xb(e),a;if(f===d)return Xb(e),b;f=f.sibling}throw Error(p(188));}if(c.return!==d.return)c=e,d=f;else{for(var g=!1,h=e.child;h;){if(h===c){g=!0;c=e;d=f;break}if(h===d){g=!0;d=e;c=f;break}h=h.sibling}if(!g){for(h=f.child;h;){if(h===\nc){g=!0;c=f;d=e;break}if(h===d){g=!0;d=f;c=e;break}h=h.sibling}if(!g)throw Error(p(189));}}if(c.alternate!==d)throw Error(p(190));}if(3!==c.tag)throw Error(p(188));return c.stateNode.current===c?a:b}function Zb(a){a=Yb(a);return null!==a?$b(a):null}function $b(a){if(5===a.tag||6===a.tag)return a;for(a=a.child;null!==a;){var b=$b(a);if(null!==b)return b;a=a.sibling}return null}\nvar ac=ca.unstable_scheduleCallback,bc=ca.unstable_cancelCallback,cc=ca.unstable_shouldYield,dc=ca.unstable_requestPaint,B=ca.unstable_now,ec=ca.unstable_getCurrentPriorityLevel,fc=ca.unstable_ImmediatePriority,gc=ca.unstable_UserBlockingPriority,hc=ca.unstable_NormalPriority,ic=ca.unstable_LowPriority,jc=ca.unstable_IdlePriority,kc=null,lc=null;function mc(a){if(lc&&\"function\"===typeof lc.onCommitFiberRoot)try{lc.onCommitFiberRoot(kc,a,void 0,128===(a.current.flags&128))}catch(b){}}\nvar oc=Math.clz32?Math.clz32:nc,pc=Math.log,qc=Math.LN2;function nc(a){a>>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0<b;)c=31-oc(b),e=1<<c,d|=a[c],b&=~e;return d}\nfunction vc(a,b){switch(a){case 1:case 2:case 4:return b+250;case 8:case 16:case 32:case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return b+5E3;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return-1;case 134217728:case 268435456:case 536870912:case 1073741824:return-1;default:return-1}}\nfunction wc(a,b){for(var c=a.suspendedLanes,d=a.pingedLanes,e=a.expirationTimes,f=a.pendingLanes;0<f;){var g=31-oc(f),h=1<<g,k=e[g];if(-1===k){if(0===(h&c)||0!==(h&d))e[g]=vc(h,b)}else k<=b&&(a.expiredLanes|=h);f&=~h}}function xc(a){a=a.pendingLanes&-1073741825;return 0!==a?a:a&1073741824?1073741824:0}function yc(){var a=rc;rc<<=1;0===(rc&4194240)&&(rc=64);return a}function zc(a){for(var b=[],c=0;31>c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0<c;){var e=31-oc(c),f=1<<e;b[e]=0;d[e]=-1;a[e]=-1;c&=~f}}\nfunction Cc(a,b){var c=a.entangledLanes|=b;for(a=a.entanglements;c;){var d=31-oc(c),e=1<<d;e&b|a[d]&b&&(a[d]|=b);c&=~e}}var C=0;function Dc(a){a&=-a;return 1<a?4<a?0!==(a&268435455)?16:536870912:4:1}var Ec,Fc,Gc,Hc,Ic,Jc=!1,Kc=[],Lc=null,Mc=null,Nc=null,Oc=new Map,Pc=new Map,Qc=[],Rc=\"mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput copy cut paste click change contextmenu reset submit\".split(\" \");\nfunction Sc(a,b){switch(a){case \"focusin\":case \"focusout\":Lc=null;break;case \"dragenter\":case \"dragleave\":Mc=null;break;case \"mouseover\":case \"mouseout\":Nc=null;break;case \"pointerover\":case \"pointerout\":Oc.delete(b.pointerId);break;case \"gotpointercapture\":case \"lostpointercapture\":Pc.delete(b.pointerId)}}\nfunction Tc(a,b,c,d,e,f){if(null===a||a.nativeEvent!==f)return a={blockedOn:b,domEventName:c,eventSystemFlags:d,nativeEvent:f,targetContainers:[e]},null!==b&&(b=Cb(b),null!==b&&Fc(b)),a;a.eventSystemFlags|=d;b=a.targetContainers;null!==e&&-1===b.indexOf(e)&&b.push(e);return a}\nfunction Uc(a,b,c,d,e){switch(b){case \"focusin\":return Lc=Tc(Lc,a,b,c,d,e),!0;case \"dragenter\":return Mc=Tc(Mc,a,b,c,d,e),!0;case \"mouseover\":return Nc=Tc(Nc,a,b,c,d,e),!0;case \"pointerover\":var f=e.pointerId;Oc.set(f,Tc(Oc.get(f)||null,a,b,c,d,e));return!0;case \"gotpointercapture\":return f=e.pointerId,Pc.set(f,Tc(Pc.get(f)||null,a,b,c,d,e)),!0}return!1}\nfunction Vc(a){var b=Wc(a.target);if(null!==b){var c=Vb(b);if(null!==c)if(b=c.tag,13===b){if(b=Wb(c),null!==b){a.blockedOn=b;Ic(a.priority,function(){Gc(c)});return}}else if(3===b&&c.stateNode.current.memoizedState.isDehydrated){a.blockedOn=3===c.tag?c.stateNode.containerInfo:null;return}}a.blockedOn=null}\nfunction Xc(a){if(null!==a.blockedOn)return!1;for(var b=a.targetContainers;0<b.length;){var c=Yc(a.domEventName,a.eventSystemFlags,b[0],a.nativeEvent);if(null===c){c=a.nativeEvent;var d=new c.constructor(c.type,c);wb=d;c.target.dispatchEvent(d);wb=null}else return b=Cb(c),null!==b&&Fc(b),a.blockedOn=c,!1;b.shift()}return!0}function Zc(a,b,c){Xc(a)&&c.delete(b)}function $c(){Jc=!1;null!==Lc&&Xc(Lc)&&(Lc=null);null!==Mc&&Xc(Mc)&&(Mc=null);null!==Nc&&Xc(Nc)&&(Nc=null);Oc.forEach(Zc);Pc.forEach(Zc)}\nfunction ad(a,b){a.blockedOn===b&&(a.blockedOn=null,Jc||(Jc=!0,ca.unstable_scheduleCallback(ca.unstable_NormalPriority,$c)))}\nfunction bd(a){function b(b){return ad(b,a)}if(0<Kc.length){ad(Kc[0],a);for(var c=1;c<Kc.length;c++){var d=Kc[c];d.blockedOn===a&&(d.blockedOn=null)}}null!==Lc&&ad(Lc,a);null!==Mc&&ad(Mc,a);null!==Nc&&ad(Nc,a);Oc.forEach(b);Pc.forEach(b);for(c=0;c<Qc.length;c++)d=Qc[c],d.blockedOn===a&&(d.blockedOn=null);for(;0<Qc.length&&(c=Qc[0],null===c.blockedOn);)Vc(c),null===c.blockedOn&&Qc.shift()}var cd=ua.ReactCurrentBatchConfig,dd=!0;\nfunction ed(a,b,c,d){var e=C,f=cd.transition;cd.transition=null;try{C=1,fd(a,b,c,d)}finally{C=e,cd.transition=f}}function gd(a,b,c,d){var e=C,f=cd.transition;cd.transition=null;try{C=4,fd(a,b,c,d)}finally{C=e,cd.transition=f}}\nfunction fd(a,b,c,d){if(dd){var e=Yc(a,b,c,d);if(null===e)hd(a,b,d,id,c),Sc(a,d);else if(Uc(e,a,b,c,d))d.stopPropagation();else if(Sc(a,d),b&4&&-1<Rc.indexOf(a)){for(;null!==e;){var f=Cb(e);null!==f&&Ec(f);f=Yc(a,b,c,d);null===f&&hd(a,b,d,id,c);if(f===e)break;e=f}null!==e&&d.stopPropagation()}else hd(a,b,d,null,c)}}var id=null;\nfunction Yc(a,b,c,d){id=null;a=xb(d);a=Wc(a);if(null!==a)if(b=Vb(a),null===b)a=null;else if(c=b.tag,13===c){a=Wb(b);if(null!==a)return a;a=null}else if(3===c){if(b.stateNode.current.memoizedState.isDehydrated)return 3===b.tag?b.stateNode.containerInfo:null;a=null}else b!==a&&(a=null);id=a;return null}\nfunction jd(a){switch(a){case \"cancel\":case \"click\":case \"close\":case \"contextmenu\":case \"copy\":case \"cut\":case \"auxclick\":case \"dblclick\":case \"dragend\":case \"dragstart\":case \"drop\":case \"focusin\":case \"focusout\":case \"input\":case \"invalid\":case \"keydown\":case \"keypress\":case \"keyup\":case \"mousedown\":case \"mouseup\":case \"paste\":case \"pause\":case \"play\":case \"pointercancel\":case \"pointerdown\":case \"pointerup\":case \"ratechange\":case \"reset\":case \"resize\":case \"seeked\":case \"submit\":case \"touchcancel\":case \"touchend\":case \"touchstart\":case \"volumechange\":case \"change\":case \"selectionchange\":case \"textInput\":case \"compositionstart\":case \"compositionend\":case \"compositionupdate\":case \"beforeblur\":case \"afterblur\":case \"beforeinput\":case \"blur\":case \"fullscreenchange\":case \"focus\":case \"hashchange\":case \"popstate\":case \"select\":case \"selectstart\":return 1;case \"drag\":case \"dragenter\":case \"dragexit\":case \"dragleave\":case \"dragover\":case \"mousemove\":case \"mouseout\":case \"mouseover\":case \"pointermove\":case \"pointerout\":case \"pointerover\":case \"scroll\":case \"toggle\":case \"touchmove\":case \"wheel\":case \"mouseenter\":case \"mouseleave\":case \"pointerenter\":case \"pointerleave\":return 4;\ncase \"message\":switch(ec()){case fc:return 1;case gc:return 4;case hc:case ic:return 16;case jc:return 536870912;default:return 16}default:return 16}}var kd=null,ld=null,md=null;function nd(){if(md)return md;var a,b=ld,c=b.length,d,e=\"value\"in kd?kd.value:kd.textContent,f=e.length;for(a=0;a<c&&b[a]===e[a];a++);var g=c-a;for(d=1;d<=g&&b[c-d]===e[f-d];d++);return md=e.slice(a,1<d?1-d:void 0)}\nfunction od(a){var b=a.keyCode;\"charCode\"in a?(a=a.charCode,0===a&&13===b&&(a=13)):a=b;10===a&&(a=13);return 32<=a||13===a?a:0}function pd(){return!0}function qd(){return!1}\nfunction rd(a){function b(b,d,e,f,g){this._reactName=b;this._targetInst=e;this.type=d;this.nativeEvent=f;this.target=g;this.currentTarget=null;for(var c in a)a.hasOwnProperty(c)&&(b=a[c],this[c]=b?b(f):f[c]);this.isDefaultPrevented=(null!=f.defaultPrevented?f.defaultPrevented:!1===f.returnValue)?pd:qd;this.isPropagationStopped=qd;return this}A(b.prototype,{preventDefault:function(){this.defaultPrevented=!0;var a=this.nativeEvent;a&&(a.preventDefault?a.preventDefault():\"unknown\"!==typeof a.returnValue&&\n(a.returnValue=!1),this.isDefaultPrevented=pd)},stopPropagation:function(){var a=this.nativeEvent;a&&(a.stopPropagation?a.stopPropagation():\"unknown\"!==typeof a.cancelBubble&&(a.cancelBubble=!0),this.isPropagationStopped=pd)},persist:function(){},isPersistent:pd});return b}\nvar sd={eventPhase:0,bubbles:0,cancelable:0,timeStamp:function(a){return a.timeStamp||Date.now()},defaultPrevented:0,isTrusted:0},td=rd(sd),ud=A({},sd,{view:0,detail:0}),vd=rd(ud),wd,xd,yd,Ad=A({},ud,{screenX:0,screenY:0,clientX:0,clientY:0,pageX:0,pageY:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,getModifierState:zd,button:0,buttons:0,relatedTarget:function(a){return void 0===a.relatedTarget?a.fromElement===a.srcElement?a.toElement:a.fromElement:a.relatedTarget},movementX:function(a){if(\"movementX\"in\na)return a.movementX;a!==yd&&(yd&&\"mousemove\"===a.type?(wd=a.screenX-yd.screenX,xd=a.screenY-yd.screenY):xd=wd=0,yd=a);return wd},movementY:function(a){return\"movementY\"in a?a.movementY:xd}}),Bd=rd(Ad),Cd=A({},Ad,{dataTransfer:0}),Dd=rd(Cd),Ed=A({},ud,{relatedTarget:0}),Fd=rd(Ed),Gd=A({},sd,{animationName:0,elapsedTime:0,pseudoElement:0}),Hd=rd(Gd),Id=A({},sd,{clipboardData:function(a){return\"clipboardData\"in a?a.clipboardData:window.clipboardData}}),Jd=rd(Id),Kd=A({},sd,{data:0}),Ld=rd(Kd),Md={Esc:\"Escape\",\nSpacebar:\" \",Left:\"ArrowLeft\",Up:\"ArrowUp\",Right:\"ArrowRight\",Down:\"ArrowDown\",Del:\"Delete\",Win:\"OS\",Menu:\"ContextMenu\",Apps:\"ContextMenu\",Scroll:\"ScrollLock\",MozPrintableKey:\"Unidentified\"},Nd={8:\"Backspace\",9:\"Tab\",12:\"Clear\",13:\"Enter\",16:\"Shift\",17:\"Control\",18:\"Alt\",19:\"Pause\",20:\"CapsLock\",27:\"Escape\",32:\" \",33:\"PageUp\",34:\"PageDown\",35:\"End\",36:\"Home\",37:\"ArrowLeft\",38:\"ArrowUp\",39:\"ArrowRight\",40:\"ArrowDown\",45:\"Insert\",46:\"Delete\",112:\"F1\",113:\"F2\",114:\"F3\",115:\"F4\",116:\"F5\",117:\"F6\",118:\"F7\",\n119:\"F8\",120:\"F9\",121:\"F10\",122:\"F11\",123:\"F12\",144:\"NumLock\",145:\"ScrollLock\",224:\"Meta\"},Od={Alt:\"altKey\",Control:\"ctrlKey\",Meta:\"metaKey\",Shift:\"shiftKey\"};function Pd(a){var b=this.nativeEvent;return b.getModifierState?b.getModifierState(a):(a=Od[a])?!!b[a]:!1}function zd(){return Pd}\nvar Qd=A({},ud,{key:function(a){if(a.key){var b=Md[a.key]||a.key;if(\"Unidentified\"!==b)return b}return\"keypress\"===a.type?(a=od(a),13===a?\"Enter\":String.fromCharCode(a)):\"keydown\"===a.type||\"keyup\"===a.type?Nd[a.keyCode]||\"Unidentified\":\"\"},code:0,location:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,repeat:0,locale:0,getModifierState:zd,charCode:function(a){return\"keypress\"===a.type?od(a):0},keyCode:function(a){return\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0},which:function(a){return\"keypress\"===\na.type?od(a):\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0}}),Rd=rd(Qd),Sd=A({},Ad,{pointerId:0,width:0,height:0,pressure:0,tangentialPressure:0,tiltX:0,tiltY:0,twist:0,pointerType:0,isPrimary:0}),Td=rd(Sd),Ud=A({},ud,{touches:0,targetTouches:0,changedTouches:0,altKey:0,metaKey:0,ctrlKey:0,shiftKey:0,getModifierState:zd}),Vd=rd(Ud),Wd=A({},sd,{propertyName:0,elapsedTime:0,pseudoElement:0}),Xd=rd(Wd),Yd=A({},Ad,{deltaX:function(a){return\"deltaX\"in a?a.deltaX:\"wheelDeltaX\"in a?-a.wheelDeltaX:0},\ndeltaY:function(a){return\"deltaY\"in a?a.deltaY:\"wheelDeltaY\"in a?-a.wheelDeltaY:\"wheelDelta\"in a?-a.wheelDelta:0},deltaZ:0,deltaMode:0}),Zd=rd(Yd),$d=[9,13,27,32],ae=ia&&\"CompositionEvent\"in window,be=null;ia&&\"documentMode\"in document&&(be=document.documentMode);var ce=ia&&\"TextEvent\"in window&&!be,de=ia&&(!ae||be&&8<be&&11>=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1<b.char.length)return b.char;if(b.which)return String.fromCharCode(b.which)}return null;case \"compositionend\":return de&&\"ko\"!==b.locale?null:b.data;default:return null}}\nvar le={color:!0,date:!0,datetime:!0,\"datetime-local\":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function me(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return\"input\"===b?!!le[a.type]:\"textarea\"===b?!0:!1}function ne(a,b,c,d){Eb(d);b=oe(b,\"onChange\");0<b.length&&(c=new td(\"onChange\",\"change\",null,c,d),a.push({event:c,listeners:b}))}var pe=null,qe=null;function re(a){se(a,0)}function te(a){var b=ue(a);if(Wa(b))return a}\nfunction ve(a,b){if(\"change\"===a)return b}var we=!1;if(ia){var xe;if(ia){var ye=\"oninput\"in document;if(!ye){var ze=document.createElement(\"div\");ze.setAttribute(\"oninput\",\"return;\");ye=\"function\"===typeof ze.oninput}xe=ye}else xe=!1;we=xe&&(!document.documentMode||9<document.documentMode)}function Ae(){pe&&(pe.detachEvent(\"onpropertychange\",Be),qe=pe=null)}function Be(a){if(\"value\"===a.propertyName&&te(qe)){var b=[];ne(b,qe,a,xb(a));Jb(re,b)}}\nfunction Ce(a,b,c){\"focusin\"===a?(Ae(),pe=b,qe=c,pe.attachEvent(\"onpropertychange\",Be)):\"focusout\"===a&&Ae()}function De(a){if(\"selectionchange\"===a||\"keyup\"===a||\"keydown\"===a)return te(qe)}function Ee(a,b){if(\"click\"===a)return te(b)}function Fe(a,b){if(\"input\"===a||\"change\"===a)return te(b)}function Ge(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var He=\"function\"===typeof Object.is?Object.is:Ge;\nfunction Ie(a,b){if(He(a,b))return!0;if(\"object\"!==typeof a||null===a||\"object\"!==typeof b||null===b)return!1;var c=Object.keys(a),d=Object.keys(b);if(c.length!==d.length)return!1;for(d=0;d<c.length;d++){var e=c[d];if(!ja.call(b,e)||!He(a[e],b[e]))return!1}return!0}function Je(a){for(;a&&a.firstChild;)a=a.firstChild;return a}\nfunction Ke(a,b){var c=Je(a);a=0;for(var d;c;){if(3===c.nodeType){d=a+c.textContent.length;if(a<=b&&d>=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c<b.length;c++)a=b[c],a.element.scrollLeft=a.left,a.element.scrollTop=a.top}}\nvar Pe=ia&&\"documentMode\"in document&&11>=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0<d.length&&(b=new td(\"onSelect\",\"select\",null,b,c),a.push({event:b,listeners:d}),b.target=Qe)))}\nfunction Ve(a,b){var c={};c[a.toLowerCase()]=b.toLowerCase();c[\"Webkit\"+a]=\"webkit\"+b;c[\"Moz\"+a]=\"moz\"+b;return c}var We={animationend:Ve(\"Animation\",\"AnimationEnd\"),animationiteration:Ve(\"Animation\",\"AnimationIteration\"),animationstart:Ve(\"Animation\",\"AnimationStart\"),transitionend:Ve(\"Transition\",\"TransitionEnd\")},Xe={},Ye={};\nia&&(Ye=document.createElement(\"div\").style,\"AnimationEvent\"in window||(delete We.animationend.animation,delete We.animationiteration.animation,delete We.animationstart.animation),\"TransitionEvent\"in window||delete We.transitionend.transition);function Ze(a){if(Xe[a])return Xe[a];if(!We[a])return a;var b=We[a],c;for(c in b)if(b.hasOwnProperty(c)&&c in Ye)return Xe[a]=b[c];return a}var $e=Ze(\"animationend\"),af=Ze(\"animationiteration\"),bf=Ze(\"animationstart\"),cf=Ze(\"transitionend\"),df=new Map,ef=\"abort auxClick cancel canPlay canPlayThrough click close contextMenu copy cut drag dragEnd dragEnter dragExit dragLeave dragOver dragStart drop durationChange emptied encrypted ended error gotPointerCapture input invalid keyDown keyPress keyUp load loadedData loadedMetadata loadStart lostPointerCapture mouseDown mouseMove mouseOut mouseOver mouseUp paste pause play playing pointerCancel pointerDown pointerMove pointerOut pointerOver pointerUp progress rateChange reset resize seeked seeking stalled submit suspend timeUpdate touchCancel touchEnd touchStart volumeChange scroll toggle touchMove waiting wheel\".split(\" \");\nfunction ff(a,b){df.set(a,b);fa(b,[a])}for(var gf=0;gf<ef.length;gf++){var hf=ef[gf],jf=hf.toLowerCase(),kf=hf[0].toUpperCase()+hf.slice(1);ff(jf,\"on\"+kf)}ff($e,\"onAnimationEnd\");ff(af,\"onAnimationIteration\");ff(bf,\"onAnimationStart\");ff(\"dblclick\",\"onDoubleClick\");ff(\"focusin\",\"onFocus\");ff(\"focusout\",\"onBlur\");ff(cf,\"onTransitionEnd\");ha(\"onMouseEnter\",[\"mouseout\",\"mouseover\"]);ha(\"onMouseLeave\",[\"mouseout\",\"mouseover\"]);ha(\"onPointerEnter\",[\"pointerout\",\"pointerover\"]);\nha(\"onPointerLeave\",[\"pointerout\",\"pointerover\"]);fa(\"onChange\",\"change click focusin focusout input keydown keyup selectionchange\".split(\" \"));fa(\"onSelect\",\"focusout contextmenu dragend focusin keydown keyup mousedown mouseup selectionchange\".split(\" \"));fa(\"onBeforeInput\",[\"compositionend\",\"keypress\",\"textInput\",\"paste\"]);fa(\"onCompositionEnd\",\"compositionend focusout keydown keypress keyup mousedown\".split(\" \"));fa(\"onCompositionStart\",\"compositionstart focusout keydown keypress keyup mousedown\".split(\" \"));\nfa(\"onCompositionUpdate\",\"compositionupdate focusout keydown keypress keyup mousedown\".split(\" \"));var lf=\"abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange resize seeked seeking stalled suspend timeupdate volumechange waiting\".split(\" \"),mf=new Set(\"cancel close invalid load scroll toggle\".split(\" \").concat(lf));\nfunction nf(a,b,c){var d=a.type||\"unknown-event\";a.currentTarget=c;Ub(d,b,void 0,a);a.currentTarget=null}\nfunction se(a,b){b=0!==(b&4);for(var c=0;c<a.length;c++){var d=a[c],e=d.event;d=d.listeners;a:{var f=void 0;if(b)for(var g=d.length-1;0<=g;g--){var h=d[g],k=h.instance,l=h.currentTarget;h=h.listener;if(k!==f&&e.isPropagationStopped())break a;nf(e,h,l);f=k}else for(g=0;g<d.length;g++){h=d[g];k=h.instance;l=h.currentTarget;h=h.listener;if(k!==f&&e.isPropagationStopped())break a;nf(e,h,l);f=k}}}if(Qb)throw a=Rb,Qb=!1,Rb=null,a;}\nfunction D(a,b){var c=b[of];void 0===c&&(c=b[of]=new Set);var d=a+\"__bubble\";c.has(d)||(pf(b,a,2,!1),c.add(d))}function qf(a,b,c){var d=0;b&&(d|=4);pf(c,a,d,b)}var rf=\"_reactListening\"+Math.random().toString(36).slice(2);function sf(a){if(!a[rf]){a[rf]=!0;da.forEach(function(b){\"selectionchange\"!==b&&(mf.has(b)||qf(b,!1,a),qf(b,!0,a))});var b=9===a.nodeType?a:a.ownerDocument;null===b||b[rf]||(b[rf]=!0,qf(\"selectionchange\",!1,b))}}\nfunction pf(a,b,c,d){switch(jd(b)){case 1:var e=ed;break;case 4:e=gd;break;default:e=fd}c=e.bind(null,b,c,a);e=void 0;!Lb||\"touchstart\"!==b&&\"touchmove\"!==b&&\"wheel\"!==b||(e=!0);d?void 0!==e?a.addEventListener(b,c,{capture:!0,passive:e}):a.addEventListener(b,c,!0):void 0!==e?a.addEventListener(b,c,{passive:e}):a.addEventListener(b,c,!1)}\nfunction hd(a,b,c,d,e){var f=d;if(0===(b&1)&&0===(b&2)&&null!==d)a:for(;;){if(null===d)return;var g=d.tag;if(3===g||4===g){var h=d.stateNode.containerInfo;if(h===e||8===h.nodeType&&h.parentNode===e)break;if(4===g)for(g=d.return;null!==g;){var k=g.tag;if(3===k||4===k)if(k=g.stateNode.containerInfo,k===e||8===k.nodeType&&k.parentNode===e)return;g=g.return}for(;null!==h;){g=Wc(h);if(null===g)return;k=g.tag;if(5===k||6===k){d=f=g;continue a}h=h.parentNode}}d=d.return}Jb(function(){var d=f,e=xb(c),g=[];\na:{var h=df.get(a);if(void 0!==h){var k=td,n=a;switch(a){case \"keypress\":if(0===od(c))break a;case \"keydown\":case \"keyup\":k=Rd;break;case \"focusin\":n=\"focus\";k=Fd;break;case \"focusout\":n=\"blur\";k=Fd;break;case \"beforeblur\":case \"afterblur\":k=Fd;break;case \"click\":if(2===c.button)break a;case \"auxclick\":case \"dblclick\":case \"mousedown\":case \"mousemove\":case \"mouseup\":case \"mouseout\":case \"mouseover\":case \"contextmenu\":k=Bd;break;case \"drag\":case \"dragend\":case \"dragenter\":case \"dragexit\":case \"dragleave\":case \"dragover\":case \"dragstart\":case \"drop\":k=\nDd;break;case \"touchcancel\":case \"touchend\":case \"touchmove\":case \"touchstart\":k=Vd;break;case $e:case af:case bf:k=Hd;break;case cf:k=Xd;break;case \"scroll\":k=vd;break;case \"wheel\":k=Zd;break;case \"copy\":case \"cut\":case \"paste\":k=Jd;break;case \"gotpointercapture\":case \"lostpointercapture\":case \"pointercancel\":case \"pointerdown\":case \"pointermove\":case \"pointerout\":case \"pointerover\":case \"pointerup\":k=Td}var t=0!==(b&4),J=!t&&\"scroll\"===a,x=t?null!==h?h+\"Capture\":null:h;t=[];for(var w=d,u;null!==\nw;){u=w;var F=u.stateNode;5===u.tag&&null!==F&&(u=F,null!==x&&(F=Kb(w,x),null!=F&&t.push(tf(w,F,u))));if(J)break;w=w.return}0<t.length&&(h=new k(h,n,null,c,e),g.push({event:h,listeners:t}))}}if(0===(b&7)){a:{h=\"mouseover\"===a||\"pointerover\"===a;k=\"mouseout\"===a||\"pointerout\"===a;if(h&&c!==wb&&(n=c.relatedTarget||c.fromElement)&&(Wc(n)||n[uf]))break a;if(k||h){h=e.window===e?e:(h=e.ownerDocument)?h.defaultView||h.parentWindow:window;if(k){if(n=c.relatedTarget||c.toElement,k=d,n=n?Wc(n):null,null!==\nn&&(J=Vb(n),n!==J||5!==n.tag&&6!==n.tag))n=null}else k=null,n=d;if(k!==n){t=Bd;F=\"onMouseLeave\";x=\"onMouseEnter\";w=\"mouse\";if(\"pointerout\"===a||\"pointerover\"===a)t=Td,F=\"onPointerLeave\",x=\"onPointerEnter\",w=\"pointer\";J=null==k?h:ue(k);u=null==n?h:ue(n);h=new t(F,w+\"leave\",k,c,e);h.target=J;h.relatedTarget=u;F=null;Wc(e)===d&&(t=new t(x,w+\"enter\",n,c,e),t.target=u,t.relatedTarget=J,F=t);J=F;if(k&&n)b:{t=k;x=n;w=0;for(u=t;u;u=vf(u))w++;u=0;for(F=x;F;F=vf(F))u++;for(;0<w-u;)t=vf(t),w--;for(;0<u-w;)x=\nvf(x),u--;for(;w--;){if(t===x||null!==x&&t===x.alternate)break b;t=vf(t);x=vf(x)}t=null}else t=null;null!==k&&wf(g,h,k,t,!1);null!==n&&null!==J&&wf(g,J,n,t,!0)}}}a:{h=d?ue(d):window;k=h.nodeName&&h.nodeName.toLowerCase();if(\"select\"===k||\"input\"===k&&\"file\"===h.type)var na=ve;else if(me(h))if(we)na=Fe;else{na=De;var xa=Ce}else(k=h.nodeName)&&\"input\"===k.toLowerCase()&&(\"checkbox\"===h.type||\"radio\"===h.type)&&(na=Ee);if(na&&(na=na(a,d))){ne(g,na,c,e);break a}xa&&xa(a,h,d);\"focusout\"===a&&(xa=h._wrapperState)&&\nxa.controlled&&\"number\"===h.type&&cb(h,\"number\",h.value)}xa=d?ue(d):window;switch(a){case \"focusin\":if(me(xa)||\"true\"===xa.contentEditable)Qe=xa,Re=d,Se=null;break;case \"focusout\":Se=Re=Qe=null;break;case \"mousedown\":Te=!0;break;case \"contextmenu\":case \"mouseup\":case \"dragend\":Te=!1;Ue(g,c,e);break;case \"selectionchange\":if(Pe)break;case \"keydown\":case \"keyup\":Ue(g,c,e)}var $a;if(ae)b:{switch(a){case \"compositionstart\":var ba=\"onCompositionStart\";break b;case \"compositionend\":ba=\"onCompositionEnd\";\nbreak b;case \"compositionupdate\":ba=\"onCompositionUpdate\";break b}ba=void 0}else ie?ge(a,c)&&(ba=\"onCompositionEnd\"):\"keydown\"===a&&229===c.keyCode&&(ba=\"onCompositionStart\");ba&&(de&&\"ko\"!==c.locale&&(ie||\"onCompositionStart\"!==ba?\"onCompositionEnd\"===ba&&ie&&($a=nd()):(kd=e,ld=\"value\"in kd?kd.value:kd.textContent,ie=!0)),xa=oe(d,ba),0<xa.length&&(ba=new Ld(ba,a,null,c,e),g.push({event:ba,listeners:xa}),$a?ba.data=$a:($a=he(c),null!==$a&&(ba.data=$a))));if($a=ce?je(a,c):ke(a,c))d=oe(d,\"onBeforeInput\"),\n0<d.length&&(e=new Ld(\"onBeforeInput\",\"beforeinput\",null,c,e),g.push({event:e,listeners:d}),e.data=$a)}se(g,b)})}function tf(a,b,c){return{instance:a,listener:b,currentTarget:c}}function oe(a,b){for(var c=b+\"Capture\",d=[];null!==a;){var e=a,f=e.stateNode;5===e.tag&&null!==f&&(e=f,f=Kb(a,c),null!=f&&d.unshift(tf(a,f,e)),f=Kb(a,b),null!=f&&d.push(tf(a,f,e)));a=a.return}return d}function vf(a){if(null===a)return null;do a=a.return;while(a&&5!==a.tag);return a?a:null}\nfunction wf(a,b,c,d,e){for(var f=b._reactName,g=[];null!==c&&c!==d;){var h=c,k=h.alternate,l=h.stateNode;if(null!==k&&k===d)break;5===h.tag&&null!==l&&(h=l,e?(k=Kb(c,f),null!=k&&g.unshift(tf(c,k,h))):e||(k=Kb(c,f),null!=k&&g.push(tf(c,k,h))));c=c.return}0!==g.length&&a.push({event:b,listeners:g})}var xf=/\\r\\n?/g,yf=/\\u0000|\\uFFFD/g;function zf(a){return(\"string\"===typeof a?a:\"\"+a).replace(xf,\"\\n\").replace(yf,\"\")}function Af(a,b,c){b=zf(b);if(zf(a)!==b&&c)throw Error(p(425));}function Bf(){}\nvar Cf=null,Df=null;function Ef(a,b){return\"textarea\"===a||\"noscript\"===a||\"string\"===typeof b.children||\"number\"===typeof b.children||\"object\"===typeof b.dangerouslySetInnerHTML&&null!==b.dangerouslySetInnerHTML&&null!=b.dangerouslySetInnerHTML.__html}\nvar Ff=\"function\"===typeof setTimeout?setTimeout:void 0,Gf=\"function\"===typeof clearTimeout?clearTimeout:void 0,Hf=\"function\"===typeof Promise?Promise:void 0,Jf=\"function\"===typeof queueMicrotask?queueMicrotask:\"undefined\"!==typeof Hf?function(a){return Hf.resolve(null).then(a).catch(If)}:Ff;function If(a){setTimeout(function(){throw a;})}\nfunction Kf(a,b){var c=b,d=0;do{var e=c.nextSibling;a.removeChild(c);if(e&&8===e.nodeType)if(c=e.data,\"/$\"===c){if(0===d){a.removeChild(e);bd(b);return}d--}else\"$\"!==c&&\"$?\"!==c&&\"$!\"!==c||d++;c=e}while(c);bd(b)}function Lf(a){for(;null!=a;a=a.nextSibling){var b=a.nodeType;if(1===b||3===b)break;if(8===b){b=a.data;if(\"$\"===b||\"$!\"===b||\"$?\"===b)break;if(\"/$\"===b)return null}}return a}\nfunction Mf(a){a=a.previousSibling;for(var b=0;a;){if(8===a.nodeType){var c=a.data;if(\"$\"===c||\"$!\"===c||\"$?\"===c){if(0===b)return a;b--}else\"/$\"===c&&b++}a=a.previousSibling}return null}var Nf=Math.random().toString(36).slice(2),Of=\"__reactFiber$\"+Nf,Pf=\"__reactProps$\"+Nf,uf=\"__reactContainer$\"+Nf,of=\"__reactEvents$\"+Nf,Qf=\"__reactListeners$\"+Nf,Rf=\"__reactHandles$\"+Nf;\nfunction Wc(a){var b=a[Of];if(b)return b;for(var c=a.parentNode;c;){if(b=c[uf]||c[Of]){c=b.alternate;if(null!==b.child||null!==c&&null!==c.child)for(a=Mf(a);null!==a;){if(c=a[Of])return c;a=Mf(a)}return b}a=c;c=a.parentNode}return null}function Cb(a){a=a[Of]||a[uf];return!a||5!==a.tag&&6!==a.tag&&13!==a.tag&&3!==a.tag?null:a}function ue(a){if(5===a.tag||6===a.tag)return a.stateNode;throw Error(p(33));}function Db(a){return a[Pf]||null}var Sf=[],Tf=-1;function Uf(a){return{current:a}}\nfunction E(a){0>Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a<c.length;a++){var d=c[a];do d=d(!0);while(null!==d)}eg=null;fg=!1}catch(e){throw null!==eg&&(eg=eg.slice(a+1)),ac(fc,jg),e;}finally{C=b,gg=!1}}return null}var kg=[],lg=0,mg=null,ng=0,og=[],pg=0,qg=null,rg=1,sg=\"\";function tg(a,b){kg[lg++]=ng;kg[lg++]=mg;mg=a;ng=b}\nfunction ug(a,b,c){og[pg++]=rg;og[pg++]=sg;og[pg++]=qg;qg=a;var d=rg;a=sg;var e=32-oc(d)-1;d&=~(1<<e);c+=1;var f=32-oc(b)+e;if(30<f){var g=e-e%5;f=(d&(1<<g)-1).toString(32);d>>=g;e-=g;rg=1<<32-oc(b)+e|c<<e|d;sg=f+a}else rg=1<<f|c<<e|d,sg=a}function vg(a){null!==a.return&&(tg(a,1),ug(a,1,0))}function wg(a){for(;a===mg;)mg=kg[--lg],kg[lg]=null,ng=kg[--lg],kg[lg]=null;for(;a===qg;)qg=og[--pg],og[pg]=null,sg=og[--pg],og[pg]=null,rg=og[--pg],og[pg]=null}var xg=null,yg=null,I=!1,zg=null;\nfunction Ag(a,b){var c=Bg(5,null,null,0);c.elementType=\"DELETED\";c.stateNode=b;c.return=a;b=a.deletions;null===b?(a.deletions=[c],a.flags|=16):b.push(c)}\nfunction Cg(a,b){switch(a.tag){case 5:var c=a.type;b=1!==b.nodeType||c.toLowerCase()!==b.nodeName.toLowerCase()?null:b;return null!==b?(a.stateNode=b,xg=a,yg=Lf(b.firstChild),!0):!1;case 6:return b=\"\"===a.pendingProps||3!==b.nodeType?null:b,null!==b?(a.stateNode=b,xg=a,yg=null,!0):!1;case 13:return b=8!==b.nodeType?null:b,null!==b?(c=null!==qg?{id:rg,overflow:sg}:null,a.memoizedState={dehydrated:b,treeContext:c,retryLane:1073741824},c=Bg(18,null,null,0),c.stateNode=b,c.return=a,a.child=c,xg=a,yg=\nnull,!0):!1;default:return!1}}function Dg(a){return 0!==(a.mode&1)&&0===(a.flags&128)}function Eg(a){if(I){var b=yg;if(b){var c=b;if(!Cg(a,b)){if(Dg(a))throw Error(p(418));b=Lf(c.nextSibling);var d=xg;b&&Cg(a,b)?Ag(d,c):(a.flags=a.flags&-4097|2,I=!1,xg=a)}}else{if(Dg(a))throw Error(p(418));a.flags=a.flags&-4097|2;I=!1;xg=a}}}function Fg(a){for(a=a.return;null!==a&&5!==a.tag&&3!==a.tag&&13!==a.tag;)a=a.return;xg=a}\nfunction Gg(a){if(a!==xg)return!1;if(!I)return Fg(a),I=!0,!1;var b;(b=3!==a.tag)&&!(b=5!==a.tag)&&(b=a.type,b=\"head\"!==b&&\"body\"!==b&&!Ef(a.type,a.memoizedProps));if(b&&(b=yg)){if(Dg(a))throw Hg(),Error(p(418));for(;b;)Ag(a,b),b=Lf(b.nextSibling)}Fg(a);if(13===a.tag){a=a.memoizedState;a=null!==a?a.dehydrated:null;if(!a)throw Error(p(317));a:{a=a.nextSibling;for(b=0;a;){if(8===a.nodeType){var c=a.data;if(\"/$\"===c){if(0===b){yg=Lf(a.nextSibling);break a}b--}else\"$\"!==c&&\"$!\"!==c&&\"$?\"!==c||b++}a=a.nextSibling}yg=\nnull}}else yg=xg?Lf(a.stateNode.nextSibling):null;return!0}function Hg(){for(var a=yg;a;)a=Lf(a.nextSibling)}function Ig(){yg=xg=null;I=!1}function Jg(a){null===zg?zg=[a]:zg.push(a)}var Kg=ua.ReactCurrentBatchConfig;function Lg(a,b){if(a&&a.defaultProps){b=A({},b);a=a.defaultProps;for(var c in a)void 0===b[c]&&(b[c]=a[c]);return b}return b}var Mg=Uf(null),Ng=null,Og=null,Pg=null;function Qg(){Pg=Og=Ng=null}function Rg(a){var b=Mg.current;E(Mg);a._currentValue=b}\nfunction Sg(a,b,c){for(;null!==a;){var d=a.alternate;(a.childLanes&b)!==b?(a.childLanes|=b,null!==d&&(d.childLanes|=b)):null!==d&&(d.childLanes&b)!==b&&(d.childLanes|=b);if(a===c)break;a=a.return}}function Tg(a,b){Ng=a;Pg=Og=null;a=a.dependencies;null!==a&&null!==a.firstContext&&(0!==(a.lanes&b)&&(Ug=!0),a.firstContext=null)}\nfunction Vg(a){var b=a._currentValue;if(Pg!==a)if(a={context:a,memoizedValue:b,next:null},null===Og){if(null===Ng)throw Error(p(308));Og=a;Ng.dependencies={lanes:0,firstContext:a}}else Og=Og.next=a;return b}var Wg=null;function Xg(a){null===Wg?Wg=[a]:Wg.push(a)}function Yg(a,b,c,d){var e=b.interleaved;null===e?(c.next=c,Xg(b)):(c.next=e.next,e.next=c);b.interleaved=c;return Zg(a,d)}\nfunction Zg(a,b){a.lanes|=b;var c=a.alternate;null!==c&&(c.lanes|=b);c=a;for(a=a.return;null!==a;)a.childLanes|=b,c=a.alternate,null!==c&&(c.childLanes|=b),c=a,a=a.return;return 3===c.tag?c.stateNode:null}var $g=!1;function ah(a){a.updateQueue={baseState:a.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}\nfunction bh(a,b){a=a.updateQueue;b.updateQueue===a&&(b.updateQueue={baseState:a.baseState,firstBaseUpdate:a.firstBaseUpdate,lastBaseUpdate:a.lastBaseUpdate,shared:a.shared,effects:a.effects})}function ch(a,b){return{eventTime:a,lane:b,tag:0,payload:null,callback:null,next:null}}\nfunction dh(a,b,c){var d=a.updateQueue;if(null===d)return null;d=d.shared;if(0!==(K&2)){var e=d.pending;null===e?b.next=b:(b.next=e.next,e.next=b);d.pending=b;return Zg(a,c)}e=d.interleaved;null===e?(b.next=b,Xg(d)):(b.next=e.next,e.next=b);d.interleaved=b;return Zg(a,c)}function eh(a,b,c){b=b.updateQueue;if(null!==b&&(b=b.shared,0!==(c&4194240))){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nfunction fh(a,b){var c=a.updateQueue,d=a.alternate;if(null!==d&&(d=d.updateQueue,c===d)){var e=null,f=null;c=c.firstBaseUpdate;if(null!==c){do{var g={eventTime:c.eventTime,lane:c.lane,tag:c.tag,payload:c.payload,callback:c.callback,next:null};null===f?e=f=g:f=f.next=g;c=c.next}while(null!==c);null===f?e=f=b:f=f.next=b}else e=f=b;c={baseState:d.baseState,firstBaseUpdate:e,lastBaseUpdate:f,shared:d.shared,effects:d.effects};a.updateQueue=c;return}a=c.lastBaseUpdate;null===a?c.firstBaseUpdate=b:a.next=\nb;c.lastBaseUpdate=b}\nfunction gh(a,b,c,d){var e=a.updateQueue;$g=!1;var f=e.firstBaseUpdate,g=e.lastBaseUpdate,h=e.shared.pending;if(null!==h){e.shared.pending=null;var k=h,l=k.next;k.next=null;null===g?f=l:g.next=l;g=k;var m=a.alternate;null!==m&&(m=m.updateQueue,h=m.lastBaseUpdate,h!==g&&(null===h?m.firstBaseUpdate=l:h.next=l,m.lastBaseUpdate=k))}if(null!==f){var q=e.baseState;g=0;m=l=k=null;h=f;do{var r=h.lane,y=h.eventTime;if((d&r)===r){null!==m&&(m=m.next={eventTime:y,lane:0,tag:h.tag,payload:h.payload,callback:h.callback,\nnext:null});a:{var n=a,t=h;r=b;y=c;switch(t.tag){case 1:n=t.payload;if(\"function\"===typeof n){q=n.call(y,q,r);break a}q=n;break a;case 3:n.flags=n.flags&-65537|128;case 0:n=t.payload;r=\"function\"===typeof n?n.call(y,q,r):n;if(null===r||void 0===r)break a;q=A({},q,r);break a;case 2:$g=!0}}null!==h.callback&&0!==h.lane&&(a.flags|=64,r=e.effects,null===r?e.effects=[h]:r.push(h))}else y={eventTime:y,lane:r,tag:h.tag,payload:h.payload,callback:h.callback,next:null},null===m?(l=m=y,k=q):m=m.next=y,g|=r;\nh=h.next;if(null===h)if(h=e.shared.pending,null===h)break;else r=h,h=r.next,r.next=null,e.lastBaseUpdate=r,e.shared.pending=null}while(1);null===m&&(k=q);e.baseState=k;e.firstBaseUpdate=l;e.lastBaseUpdate=m;b=e.shared.interleaved;if(null!==b){e=b;do g|=e.lane,e=e.next;while(e!==b)}else null===f&&(e.shared.lanes=0);hh|=g;a.lanes=g;a.memoizedState=q}}\nfunction ih(a,b,c){a=b.effects;b.effects=null;if(null!==a)for(b=0;b<a.length;b++){var d=a[b],e=d.callback;if(null!==e){d.callback=null;d=c;if(\"function\"!==typeof e)throw Error(p(191,e));e.call(d)}}}var jh=(new aa.Component).refs;function kh(a,b,c,d){b=a.memoizedState;c=c(d,b);c=null===c||void 0===c?b:A({},b,c);a.memoizedState=c;0===a.lanes&&(a.updateQueue.baseState=c)}\nvar nh={isMounted:function(a){return(a=a._reactInternals)?Vb(a)===a:!1},enqueueSetState:function(a,b,c){a=a._reactInternals;var d=L(),e=lh(a),f=ch(d,e);f.payload=b;void 0!==c&&null!==c&&(f.callback=c);b=dh(a,f,e);null!==b&&(mh(b,a,e,d),eh(b,a,e))},enqueueReplaceState:function(a,b,c){a=a._reactInternals;var d=L(),e=lh(a),f=ch(d,e);f.tag=1;f.payload=b;void 0!==c&&null!==c&&(f.callback=c);b=dh(a,f,e);null!==b&&(mh(b,a,e,d),eh(b,a,e))},enqueueForceUpdate:function(a,b){a=a._reactInternals;var c=L(),d=\nlh(a),e=ch(c,d);e.tag=2;void 0!==b&&null!==b&&(e.callback=b);b=dh(a,e,d);null!==b&&(mh(b,a,d,c),eh(b,a,d))}};function oh(a,b,c,d,e,f,g){a=a.stateNode;return\"function\"===typeof a.shouldComponentUpdate?a.shouldComponentUpdate(d,f,g):b.prototype&&b.prototype.isPureReactComponent?!Ie(c,d)||!Ie(e,f):!0}\nfunction ph(a,b,c){var d=!1,e=Vf;var f=b.contextType;\"object\"===typeof f&&null!==f?f=Vg(f):(e=Zf(b)?Xf:H.current,d=b.contextTypes,f=(d=null!==d&&void 0!==d)?Yf(a,e):Vf);b=new b(c,f);a.memoizedState=null!==b.state&&void 0!==b.state?b.state:null;b.updater=nh;a.stateNode=b;b._reactInternals=a;d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=e,a.__reactInternalMemoizedMaskedChildContext=f);return b}\nfunction qh(a,b,c,d){a=b.state;\"function\"===typeof b.componentWillReceiveProps&&b.componentWillReceiveProps(c,d);\"function\"===typeof b.UNSAFE_componentWillReceiveProps&&b.UNSAFE_componentWillReceiveProps(c,d);b.state!==a&&nh.enqueueReplaceState(b,b.state,null)}\nfunction rh(a,b,c,d){var e=a.stateNode;e.props=c;e.state=a.memoizedState;e.refs=jh;ah(a);var f=b.contextType;\"object\"===typeof f&&null!==f?e.context=Vg(f):(f=Zf(b)?Xf:H.current,e.context=Yf(a,f));e.state=a.memoizedState;f=b.getDerivedStateFromProps;\"function\"===typeof f&&(kh(a,b,f,c),e.state=a.memoizedState);\"function\"===typeof b.getDerivedStateFromProps||\"function\"===typeof e.getSnapshotBeforeUpdate||\"function\"!==typeof e.UNSAFE_componentWillMount&&\"function\"!==typeof e.componentWillMount||(b=e.state,\n\"function\"===typeof e.componentWillMount&&e.componentWillMount(),\"function\"===typeof e.UNSAFE_componentWillMount&&e.UNSAFE_componentWillMount(),b!==e.state&&nh.enqueueReplaceState(e,e.state,null),gh(a,c,e,d),e.state=a.memoizedState);\"function\"===typeof e.componentDidMount&&(a.flags|=4194308)}\nfunction sh(a,b,c){a=c.ref;if(null!==a&&\"function\"!==typeof a&&\"object\"!==typeof a){if(c._owner){c=c._owner;if(c){if(1!==c.tag)throw Error(p(309));var d=c.stateNode}if(!d)throw Error(p(147,a));var e=d,f=\"\"+a;if(null!==b&&null!==b.ref&&\"function\"===typeof b.ref&&b.ref._stringRef===f)return b.ref;b=function(a){var b=e.refs;b===jh&&(b=e.refs={});null===a?delete b[f]:b[f]=a};b._stringRef=f;return b}if(\"string\"!==typeof a)throw Error(p(284));if(!c._owner)throw Error(p(290,a));}return a}\nfunction th(a,b){a=Object.prototype.toString.call(b);throw Error(p(31,\"[object Object]\"===a?\"object with keys {\"+Object.keys(b).join(\", \")+\"}\":a));}function uh(a){var b=a._init;return b(a._payload)}\nfunction vh(a){function b(b,c){if(a){var d=b.deletions;null===d?(b.deletions=[c],b.flags|=16):d.push(c)}}function c(c,d){if(!a)return null;for(;null!==d;)b(c,d),d=d.sibling;return null}function d(a,b){for(a=new Map;null!==b;)null!==b.key?a.set(b.key,b):a.set(b.index,b),b=b.sibling;return a}function e(a,b){a=wh(a,b);a.index=0;a.sibling=null;return a}function f(b,c,d){b.index=d;if(!a)return b.flags|=1048576,c;d=b.alternate;if(null!==d)return d=d.index,d<c?(b.flags|=2,c):d;b.flags|=2;return c}function g(b){a&&\nnull===b.alternate&&(b.flags|=2);return b}function h(a,b,c,d){if(null===b||6!==b.tag)return b=xh(c,a.mode,d),b.return=a,b;b=e(b,c);b.return=a;return b}function k(a,b,c,d){var f=c.type;if(f===ya)return m(a,b,c.props.children,d,c.key);if(null!==b&&(b.elementType===f||\"object\"===typeof f&&null!==f&&f.$$typeof===Ha&&uh(f)===b.type))return d=e(b,c.props),d.ref=sh(a,b,c),d.return=a,d;d=yh(c.type,c.key,c.props,null,a.mode,d);d.ref=sh(a,b,c);d.return=a;return d}function l(a,b,c,d){if(null===b||4!==b.tag||\nb.stateNode.containerInfo!==c.containerInfo||b.stateNode.implementation!==c.implementation)return b=zh(c,a.mode,d),b.return=a,b;b=e(b,c.children||[]);b.return=a;return b}function m(a,b,c,d,f){if(null===b||7!==b.tag)return b=Ah(c,a.mode,d,f),b.return=a,b;b=e(b,c);b.return=a;return b}function q(a,b,c){if(\"string\"===typeof b&&\"\"!==b||\"number\"===typeof b)return b=xh(\"\"+b,a.mode,c),b.return=a,b;if(\"object\"===typeof b&&null!==b){switch(b.$$typeof){case va:return c=yh(b.type,b.key,b.props,null,a.mode,c),\nc.ref=sh(a,null,b),c.return=a,c;case wa:return b=zh(b,a.mode,c),b.return=a,b;case Ha:var d=b._init;return q(a,d(b._payload),c)}if(eb(b)||Ka(b))return b=Ah(b,a.mode,c,null),b.return=a,b;th(a,b)}return null}function r(a,b,c,d){var e=null!==b?b.key:null;if(\"string\"===typeof c&&\"\"!==c||\"number\"===typeof c)return null!==e?null:h(a,b,\"\"+c,d);if(\"object\"===typeof c&&null!==c){switch(c.$$typeof){case va:return c.key===e?k(a,b,c,d):null;case wa:return c.key===e?l(a,b,c,d):null;case Ha:return e=c._init,r(a,\nb,e(c._payload),d)}if(eb(c)||Ka(c))return null!==e?null:m(a,b,c,d,null);th(a,c)}return null}function y(a,b,c,d,e){if(\"string\"===typeof d&&\"\"!==d||\"number\"===typeof d)return a=a.get(c)||null,h(b,a,\"\"+d,e);if(\"object\"===typeof d&&null!==d){switch(d.$$typeof){case va:return a=a.get(null===d.key?c:d.key)||null,k(b,a,d,e);case wa:return a=a.get(null===d.key?c:d.key)||null,l(b,a,d,e);case Ha:var f=d._init;return y(a,b,c,f(d._payload),e)}if(eb(d)||Ka(d))return a=a.get(c)||null,m(b,a,d,e,null);th(b,d)}return null}\nfunction n(e,g,h,k){for(var l=null,m=null,u=g,w=g=0,x=null;null!==u&&w<h.length;w++){u.index>w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;w<h.length;w++)u=q(e,h[w],k),null!==u&&(g=f(u,g,w),null===m?l=u:m.sibling=u,m=u);I&&tg(e,w);return l}for(u=d(e,u);w<h.length;w++)x=y(u,e,w,h[w],k),null!==x&&(a&&null!==x.alternate&&u.delete(null===\nx.key?w:x.key),g=f(x,g,w),null===m?l=x:m.sibling=x,m=x);a&&u.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function t(e,g,h,k){var l=Ka(h);if(\"function\"!==typeof l)throw Error(p(150));h=l.call(h);if(null==h)throw Error(p(151));for(var u=l=null,m=g,w=g=0,x=null,n=h.next();null!==m&&!n.done;w++,n=h.next()){m.index>w?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;a<Nh.length;a++)Nh[a]._workInProgressVersionPrimary=null;Nh.length=0}var Ph=ua.ReactCurrentDispatcher,Qh=ua.ReactCurrentBatchConfig,Rh=0,N=null,O=null,P=null,Sh=!1,Th=!1,Uh=0,Vh=0;function Q(){throw Error(p(321));}function Wh(a,b){if(null===b)return!1;for(var c=0;c<b.length&&c<a.length;c++)if(!He(a[c],b[c]))return!1;return!0}\nfunction Xh(a,b,c,d,e,f){Rh=f;N=b;b.memoizedState=null;b.updateQueue=null;b.lanes=0;Ph.current=null===a||null===a.memoizedState?Yh:Zh;a=c(d,e);if(Th){f=0;do{Th=!1;Uh=0;if(25<=f)throw Error(p(301));f+=1;P=O=null;b.updateQueue=null;Ph.current=$h;a=c(d,e)}while(Th)}Ph.current=ai;b=null!==O&&null!==O.next;Rh=0;P=O=N=null;Sh=!1;if(b)throw Error(p(300));return a}function bi(){var a=0!==Uh;Uh=0;return a}\nfunction ci(){var a={memoizedState:null,baseState:null,baseQueue:null,queue:null,next:null};null===P?N.memoizedState=P=a:P=P.next=a;return P}function di(){if(null===O){var a=N.alternate;a=null!==a?a.memoizedState:null}else a=O.next;var b=null===P?N.memoizedState:P.next;if(null!==b)P=b,O=a;else{if(null===a)throw Error(p(310));O=a;a={memoizedState:O.memoizedState,baseState:O.baseState,baseQueue:O.baseQueue,queue:O.queue,next:null};null===P?N.memoizedState=P=a:P=P.next=a}return P}\nfunction ei(a,b){return\"function\"===typeof b?b(a):b}\nfunction fi(a){var b=di(),c=b.queue;if(null===c)throw Error(p(311));c.lastRenderedReducer=a;var d=O,e=d.baseQueue,f=c.pending;if(null!==f){if(null!==e){var g=e.next;e.next=f.next;f.next=g}d.baseQueue=e=f;c.pending=null}if(null!==e){f=e.next;d=d.baseState;var h=g=null,k=null,l=f;do{var m=l.lane;if((Rh&m)===m)null!==k&&(k=k.next={lane:0,action:l.action,hasEagerState:l.hasEagerState,eagerState:l.eagerState,next:null}),d=l.hasEagerState?l.eagerState:a(d,l.action);else{var q={lane:m,action:l.action,hasEagerState:l.hasEagerState,\neagerState:l.eagerState,next:null};null===k?(h=k=q,g=d):k=k.next=q;N.lanes|=m;hh|=m}l=l.next}while(null!==l&&l!==f);null===k?g=d:k.next=h;He(d,b.memoizedState)||(Ug=!0);b.memoizedState=d;b.baseState=g;b.baseQueue=k;c.lastRenderedState=d}a=c.interleaved;if(null!==a){e=a;do f=e.lane,N.lanes|=f,hh|=f,e=e.next;while(e!==a)}else null===e&&(c.lanes=0);return[b.memoizedState,c.dispatch]}\nfunction gi(a){var b=di(),c=b.queue;if(null===c)throw Error(p(311));c.lastRenderedReducer=a;var d=c.dispatch,e=c.pending,f=b.memoizedState;if(null!==e){c.pending=null;var g=e=e.next;do f=a(f,g.action),g=g.next;while(g!==e);He(f,b.memoizedState)||(Ug=!0);b.memoizedState=f;null===b.baseQueue&&(b.baseState=f);c.lastRenderedState=f}return[f,d]}function hi(){}\nfunction ii(a,b){var c=N,d=di(),e=b(),f=!He(d.memoizedState,e);f&&(d.memoizedState=e,Ug=!0);d=d.queue;ji(ki.bind(null,c,d,a),[a]);if(d.getSnapshot!==b||f||null!==P&&P.memoizedState.tag&1){c.flags|=2048;li(9,mi.bind(null,c,d,e,b),void 0,null);if(null===R)throw Error(p(349));0!==(Rh&30)||ni(c,b,e)}return e}function ni(a,b,c){a.flags|=16384;a={getSnapshot:b,value:c};b=N.updateQueue;null===b?(b={lastEffect:null,stores:null},N.updateQueue=b,b.stores=[a]):(c=b.stores,null===c?b.stores=[a]:c.push(a))}\nfunction mi(a,b,c,d){b.value=c;b.getSnapshot=d;oi(b)&&pi(a)}function ki(a,b,c){return c(function(){oi(b)&&pi(a)})}function oi(a){var b=a.getSnapshot;a=a.value;try{var c=b();return!He(a,c)}catch(d){return!0}}function pi(a){var b=Zg(a,1);null!==b&&mh(b,a,1,-1)}\nfunction qi(a){var b=ci();\"function\"===typeof a&&(a=a());b.memoizedState=b.baseState=a;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:ei,lastRenderedState:a};b.queue=a;a=a.dispatch=ri.bind(null,N,a);return[b.memoizedState,a]}\nfunction li(a,b,c,d){a={tag:a,create:b,destroy:c,deps:d,next:null};b=N.updateQueue;null===b?(b={lastEffect:null,stores:null},N.updateQueue=b,b.lastEffect=a.next=a):(c=b.lastEffect,null===c?b.lastEffect=a.next=a:(d=c.next,c.next=a,a.next=d,b.lastEffect=a));return a}function si(){return di().memoizedState}function ti(a,b,c,d){var e=ci();N.flags|=a;e.memoizedState=li(1|b,c,void 0,void 0===d?null:d)}\nfunction ui(a,b,c,d){var e=di();d=void 0===d?null:d;var f=void 0;if(null!==O){var g=O.memoizedState;f=g.destroy;if(null!==d&&Wh(d,g.deps)){e.memoizedState=li(b,c,f,d);return}}N.flags|=a;e.memoizedState=li(1|b,c,f,d)}function vi(a,b){return ti(8390656,8,a,b)}function ji(a,b){return ui(2048,8,a,b)}function wi(a,b){return ui(4,2,a,b)}function xi(a,b){return ui(4,4,a,b)}\nfunction yi(a,b){if(\"function\"===typeof b)return a=a(),b(a),function(){b(null)};if(null!==b&&void 0!==b)return a=a(),b.current=a,function(){b.current=null}}function zi(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ui(4,4,yi.bind(null,b,a),c)}function Ai(){}function Bi(a,b){var c=di();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Wh(b,d[1]))return d[0];c.memoizedState=[a,b];return a}\nfunction Ci(a,b){var c=di();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Wh(b,d[1]))return d[0];a=a();c.memoizedState=[a,b];return a}function Di(a,b,c){if(0===(Rh&21))return a.baseState&&(a.baseState=!1,Ug=!0),a.memoizedState=c;He(c,b)||(c=yc(),N.lanes|=c,hh|=c,a.baseState=!0);return b}function Ei(a,b){var c=C;C=0!==c&&4>c?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0<c&&(b+=\"H\"+c.toString(32));b+=\":\"}else c=Vh++,b=\":\"+b+\"r\"+c.toString(32)+\":\";return a.memoizedState=b},unstable_isNewReconciler:!1},Zh={readContext:Vg,useCallback:Bi,useContext:Vg,useEffect:ji,useImperativeHandle:zi,useInsertionEffect:wi,useLayoutEffect:xi,useMemo:Ci,useReducer:fi,useRef:si,useState:function(){return fi(ei)},\nuseDebugValue:Ai,useDeferredValue:function(a){var b=di();return Di(b,O.memoizedState,a)},useTransition:function(){var a=fi(ei)[0],b=di().memoizedState;return[a,b]},useMutableSource:hi,useSyncExternalStore:ii,useId:Fi,unstable_isNewReconciler:!1},$h={readContext:Vg,useCallback:Bi,useContext:Vg,useEffect:ji,useImperativeHandle:zi,useInsertionEffect:wi,useLayoutEffect:xi,useMemo:Ci,useReducer:gi,useRef:si,useState:function(){return gi(ei)},useDebugValue:Ai,useDeferredValue:function(a){var b=di();return null===\nO?b.memoizedState=a:Di(b,O.memoizedState,a)},useTransition:function(){var a=gi(ei)[0],b=di().memoizedState;return[a,b]},useMutableSource:hi,useSyncExternalStore:ii,useId:Fi,unstable_isNewReconciler:!1};function Ki(a,b){try{var c=\"\",d=b;do c+=Pa(d),d=d.return;while(d);var e=c}catch(f){e=\"\\nError generating stack: \"+f.message+\"\\n\"+f.stack}return{value:a,source:b,stack:e,digest:null}}function Li(a,b,c){return{value:a,source:null,stack:null!=c?c:null,digest:null!=b?b:null}}\nfunction Mi(a,b){try{console.error(b.value)}catch(c){setTimeout(function(){throw c;})}}var Ni=\"function\"===typeof WeakMap?WeakMap:Map;function Oi(a,b,c){c=ch(-1,c);c.tag=3;c.payload={element:null};var d=b.value;c.callback=function(){Pi||(Pi=!0,Qi=d);Mi(a,b)};return c}\nfunction Ri(a,b,c){c=ch(-1,c);c.tag=3;var d=a.type.getDerivedStateFromError;if(\"function\"===typeof d){var e=b.value;c.payload=function(){return d(e)};c.callback=function(){Mi(a,b)}}var f=a.stateNode;null!==f&&\"function\"===typeof f.componentDidCatch&&(c.callback=function(){Mi(a,b);\"function\"!==typeof d&&(null===Si?Si=new Set([this]):Si.add(this));var c=b.stack;this.componentDidCatch(b.value,{componentStack:null!==c?c:\"\"})});return c}\nfunction Ti(a,b,c){var d=a.pingCache;if(null===d){d=a.pingCache=new Ni;var e=new Set;d.set(b,e)}else e=d.get(b),void 0===e&&(e=new Set,d.set(b,e));e.has(c)||(e.add(c),a=Ui.bind(null,a,b,c),b.then(a,a))}function Vi(a){do{var b;if(b=13===a.tag)b=a.memoizedState,b=null!==b?null!==b.dehydrated?!0:!1:!0;if(b)return a;a=a.return}while(null!==a);return null}\nfunction Wi(a,b,c,d,e){if(0===(a.mode&1))return a===b?a.flags|=65536:(a.flags|=128,c.flags|=131072,c.flags&=-52805,1===c.tag&&(null===c.alternate?c.tag=17:(b=ch(-1,1),b.tag=2,dh(c,b,1))),c.lanes|=1),a;a.flags|=65536;a.lanes=e;return a}var Xi=ua.ReactCurrentOwner,Ug=!1;function Yi(a,b,c,d){b.child=null===a?Ch(b,null,c,d):Bh(b,a.child,c,d)}\nfunction Zi(a,b,c,d,e){c=c.render;var f=b.ref;Tg(b,e);d=Xh(a,b,c,d,f,e);c=bi();if(null!==a&&!Ug)return b.updateQueue=a.updateQueue,b.flags&=-2053,a.lanes&=~e,$i(a,b,e);I&&c&&vg(b);b.flags|=1;Yi(a,b,d,e);return b.child}\nfunction aj(a,b,c,d,e){if(null===a){var f=c.type;if(\"function\"===typeof f&&!bj(f)&&void 0===f.defaultProps&&null===c.compare&&void 0===c.defaultProps)return b.tag=15,b.type=f,cj(a,b,f,d,e);a=yh(c.type,null,d,b,b.mode,e);a.ref=b.ref;a.return=b;return b.child=a}f=a.child;if(0===(a.lanes&e)){var g=f.memoizedProps;c=c.compare;c=null!==c?c:Ie;if(c(g,d)&&a.ref===b.ref)return $i(a,b,e)}b.flags|=1;a=wh(f,d);a.ref=b.ref;a.return=b;return b.child=a}\nfunction cj(a,b,c,d,e){if(null!==a){var f=a.memoizedProps;if(Ie(f,d)&&a.ref===b.ref)if(Ug=!1,b.pendingProps=d=f,0!==(a.lanes&e))0!==(a.flags&131072)&&(Ug=!0);else return b.lanes=a.lanes,$i(a,b,e)}return dj(a,b,c,d,e)}\nfunction ej(a,b,c){var d=b.pendingProps,e=d.children,f=null!==a?a.memoizedState:null;if(\"hidden\"===d.mode)if(0===(b.mode&1))b.memoizedState={baseLanes:0,cachePool:null,transitions:null},G(fj,gj),gj|=c;else{if(0===(c&1073741824))return a=null!==f?f.baseLanes|c:c,b.lanes=b.childLanes=1073741824,b.memoizedState={baseLanes:a,cachePool:null,transitions:null},b.updateQueue=null,G(fj,gj),gj|=a,null;b.memoizedState={baseLanes:0,cachePool:null,transitions:null};d=null!==f?f.baseLanes:c;G(fj,gj);gj|=d}else null!==\nf?(d=f.baseLanes|c,b.memoizedState=null):d=c,G(fj,gj),gj|=d;Yi(a,b,e,c);return b.child}function hj(a,b){var c=b.ref;if(null===a&&null!==c||null!==a&&a.ref!==c)b.flags|=512,b.flags|=2097152}function dj(a,b,c,d,e){var f=Zf(c)?Xf:H.current;f=Yf(b,f);Tg(b,e);c=Xh(a,b,c,d,f,e);d=bi();if(null!==a&&!Ug)return b.updateQueue=a.updateQueue,b.flags&=-2053,a.lanes&=~e,$i(a,b,e);I&&d&&vg(b);b.flags|=1;Yi(a,b,c,e);return b.child}\nfunction ij(a,b,c,d,e){if(Zf(c)){var f=!0;cg(b)}else f=!1;Tg(b,e);if(null===b.stateNode)jj(a,b),ph(b,c,d),rh(b,c,d,e),d=!0;else if(null===a){var g=b.stateNode,h=b.memoizedProps;g.props=h;var k=g.context,l=c.contextType;\"object\"===typeof l&&null!==l?l=Vg(l):(l=Zf(c)?Xf:H.current,l=Yf(b,l));var m=c.getDerivedStateFromProps,q=\"function\"===typeof m||\"function\"===typeof g.getSnapshotBeforeUpdate;q||\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\"function\"!==typeof g.componentWillReceiveProps||\n(h!==d||k!==l)&&qh(b,g,d,l);$g=!1;var r=b.memoizedState;g.state=r;gh(b,d,g,e);k=b.memoizedState;h!==d||r!==k||Wf.current||$g?(\"function\"===typeof m&&(kh(b,c,m,d),k=b.memoizedState),(h=$g||oh(b,c,h,d,r,k,l))?(q||\"function\"!==typeof g.UNSAFE_componentWillMount&&\"function\"!==typeof g.componentWillMount||(\"function\"===typeof g.componentWillMount&&g.componentWillMount(),\"function\"===typeof g.UNSAFE_componentWillMount&&g.UNSAFE_componentWillMount()),\"function\"===typeof g.componentDidMount&&(b.flags|=4194308)):\n(\"function\"===typeof g.componentDidMount&&(b.flags|=4194308),b.memoizedProps=d,b.memoizedState=k),g.props=d,g.state=k,g.context=l,d=h):(\"function\"===typeof g.componentDidMount&&(b.flags|=4194308),d=!1)}else{g=b.stateNode;bh(a,b);h=b.memoizedProps;l=b.type===b.elementType?h:Lg(b.type,h);g.props=l;q=b.pendingProps;r=g.context;k=c.contextType;\"object\"===typeof k&&null!==k?k=Vg(k):(k=Zf(c)?Xf:H.current,k=Yf(b,k));var y=c.getDerivedStateFromProps;(m=\"function\"===typeof y||\"function\"===typeof g.getSnapshotBeforeUpdate)||\n\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\"function\"!==typeof g.componentWillReceiveProps||(h!==q||r!==k)&&qh(b,g,d,k);$g=!1;r=b.memoizedState;g.state=r;gh(b,d,g,e);var n=b.memoizedState;h!==q||r!==n||Wf.current||$g?(\"function\"===typeof y&&(kh(b,c,y,d),n=b.memoizedState),(l=$g||oh(b,c,l,d,r,n,k)||!1)?(m||\"function\"!==typeof g.UNSAFE_componentWillUpdate&&\"function\"!==typeof g.componentWillUpdate||(\"function\"===typeof g.componentWillUpdate&&g.componentWillUpdate(d,n,k),\"function\"===typeof g.UNSAFE_componentWillUpdate&&\ng.UNSAFE_componentWillUpdate(d,n,k)),\"function\"===typeof g.componentDidUpdate&&(b.flags|=4),\"function\"===typeof g.getSnapshotBeforeUpdate&&(b.flags|=1024)):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=1024),b.memoizedProps=d,b.memoizedState=n),g.props=d,g.state=n,g.context=k,d=l):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&r===\na.memoizedState||(b.flags|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=1024),d=!1)}return kj(a,b,c,d,f,e)}\nfunction kj(a,b,c,d,e,f){hj(a,b);var g=0!==(b.flags&128);if(!d&&!g)return e&&dg(b,c,!1),$i(a,b,f);d=b.stateNode;Xi.current=b;var h=g&&\"function\"!==typeof c.getDerivedStateFromError?null:d.render();b.flags|=1;null!==a&&g?(b.child=Bh(b,a.child,null,f),b.child=Bh(b,null,h,f)):Yi(a,b,h,f);b.memoizedState=d.state;e&&dg(b,c,!0);return b.child}function lj(a){var b=a.stateNode;b.pendingContext?ag(a,b.pendingContext,b.pendingContext!==b.context):b.context&&ag(a,b.context,!1);Ih(a,b.containerInfo)}\nfunction mj(a,b,c,d,e){Ig();Jg(e);b.flags|=256;Yi(a,b,c,d);return b.child}var nj={dehydrated:null,treeContext:null,retryLane:0};function oj(a){return{baseLanes:a,cachePool:null,transitions:null}}\nfunction pj(a,b,c){var d=b.pendingProps,e=M.current,f=!1,g=0!==(b.flags&128),h;(h=g)||(h=null!==a&&null===a.memoizedState?!1:0!==(e&2));if(h)f=!0,b.flags&=-129;else if(null===a||null!==a.memoizedState)e|=1;G(M,e&1);if(null===a){Eg(b);a=b.memoizedState;if(null!==a&&(a=a.dehydrated,null!==a))return 0===(b.mode&1)?b.lanes=1:\"$!\"===a.data?b.lanes=8:b.lanes=1073741824,null;g=d.children;a=d.fallback;return f?(d=b.mode,f=b.child,g={mode:\"hidden\",children:g},0===(d&1)&&null!==f?(f.childLanes=0,f.pendingProps=\ng):f=qj(g,d,0,null),a=Ah(a,d,c,null),f.return=b,a.return=b,f.sibling=a,b.child=f,b.child.memoizedState=oj(c),b.memoizedState=nj,a):rj(b,g)}e=a.memoizedState;if(null!==e&&(h=e.dehydrated,null!==h))return sj(a,b,g,d,h,e,c);if(f){f=d.fallback;g=b.mode;e=a.child;h=e.sibling;var k={mode:\"hidden\",children:d.children};0===(g&1)&&b.child!==e?(d=b.child,d.childLanes=0,d.pendingProps=k,b.deletions=null):(d=wh(e,k),d.subtreeFlags=e.subtreeFlags&14680064);null!==h?f=wh(h,f):(f=Ah(f,g,c,null),f.flags|=2);f.return=\nb;d.return=b;d.sibling=f;b.child=d;d=f;f=b.child;g=a.child.memoizedState;g=null===g?oj(c):{baseLanes:g.baseLanes|c,cachePool:null,transitions:g.transitions};f.memoizedState=g;f.childLanes=a.childLanes&~c;b.memoizedState=nj;return d}f=a.child;a=f.sibling;d=wh(f,{mode:\"visible\",children:d.children});0===(b.mode&1)&&(d.lanes=c);d.return=b;d.sibling=null;null!==a&&(c=b.deletions,null===c?(b.deletions=[a],b.flags|=16):c.push(a));b.child=d;b.memoizedState=null;return d}\nfunction rj(a,b){b=qj({mode:\"visible\",children:b},a.mode,0,null);b.return=a;return a.child=b}function tj(a,b,c,d){null!==d&&Jg(d);Bh(b,a.child,null,c);a=rj(b,b.pendingProps.children);a.flags|=2;b.memoizedState=null;return a}\nfunction sj(a,b,c,d,e,f,g){if(c){if(b.flags&256)return b.flags&=-257,d=Li(Error(p(422))),tj(a,b,g,d);if(null!==b.memoizedState)return b.child=a.child,b.flags|=128,null;f=d.fallback;e=b.mode;d=qj({mode:\"visible\",children:d.children},e,0,null);f=Ah(f,e,g,null);f.flags|=2;d.return=b;f.return=b;d.sibling=f;b.child=d;0!==(b.mode&1)&&Bh(b,a.child,null,g);b.child.memoizedState=oj(g);b.memoizedState=nj;return f}if(0===(b.mode&1))return tj(a,b,g,null);if(\"$!\"===e.data){d=e.nextSibling&&e.nextSibling.dataset;\nif(d)var h=d.dgst;d=h;f=Error(p(419));d=Li(f,d,void 0);return tj(a,b,g,d)}h=0!==(g&a.childLanes);if(Ug||h){d=R;if(null!==d){switch(g&-g){case 4:e=2;break;case 16:e=8;break;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:e=32;break;case 536870912:e=268435456;break;default:e=0}e=0!==(e&(d.suspendedLanes|g))?0:e;\n0!==e&&e!==f.retryLane&&(f.retryLane=e,Zg(a,e),mh(d,a,e,-1))}uj();d=Li(Error(p(421)));return tj(a,b,g,d)}if(\"$?\"===e.data)return b.flags|=128,b.child=a.child,b=vj.bind(null,a),e._reactRetry=b,null;a=f.treeContext;yg=Lf(e.nextSibling);xg=b;I=!0;zg=null;null!==a&&(og[pg++]=rg,og[pg++]=sg,og[pg++]=qg,rg=a.id,sg=a.overflow,qg=b);b=rj(b,d.children);b.flags|=4096;return b}function wj(a,b,c){a.lanes|=b;var d=a.alternate;null!==d&&(d.lanes|=b);Sg(a.return,b,c)}\nfunction xj(a,b,c,d,e){var f=a.memoizedState;null===f?a.memoizedState={isBackwards:b,rendering:null,renderingStartTime:0,last:d,tail:c,tailMode:e}:(f.isBackwards=b,f.rendering=null,f.renderingStartTime=0,f.last=d,f.tail=c,f.tailMode=e)}\nfunction yj(a,b,c){var d=b.pendingProps,e=d.revealOrder,f=d.tail;Yi(a,b,d.children,c);d=M.current;if(0!==(d&2))d=d&1|2,b.flags|=128;else{if(null!==a&&0!==(a.flags&128))a:for(a=b.child;null!==a;){if(13===a.tag)null!==a.memoizedState&&wj(a,c,b);else if(19===a.tag)wj(a,c,b);else if(null!==a.child){a.child.return=a;a=a.child;continue}if(a===b)break a;for(;null===a.sibling;){if(null===a.return||a.return===b)break a;a=a.return}a.sibling.return=a.return;a=a.sibling}d&=1}G(M,d);if(0===(b.mode&1))b.memoizedState=\nnull;else switch(e){case \"forwards\":c=b.child;for(e=null;null!==c;)a=c.alternate,null!==a&&null===Mh(a)&&(e=c),c=c.sibling;c=e;null===c?(e=b.child,b.child=null):(e=c.sibling,c.sibling=null);xj(b,!1,e,c,f);break;case \"backwards\":c=null;e=b.child;for(b.child=null;null!==e;){a=e.alternate;if(null!==a&&null===Mh(a)){b.child=e;break}a=e.sibling;e.sibling=c;c=e;e=a}xj(b,!0,c,null,f);break;case \"together\":xj(b,!1,null,null,void 0);break;default:b.memoizedState=null}return b.child}\nfunction jj(a,b){0===(b.mode&1)&&null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2)}function $i(a,b,c){null!==a&&(b.dependencies=a.dependencies);hh|=b.lanes;if(0===(c&b.childLanes))return null;if(null!==a&&b.child!==a.child)throw Error(p(153));if(null!==b.child){a=b.child;c=wh(a,a.pendingProps);b.child=c;for(c.return=b;null!==a.sibling;)a=a.sibling,c=c.sibling=wh(a,a.pendingProps),c.return=b;c.sibling=null}return b.child}\nfunction zj(a,b,c){switch(b.tag){case 3:lj(b);Ig();break;case 5:Kh(b);break;case 1:Zf(b.type)&&cg(b);break;case 4:Ih(b,b.stateNode.containerInfo);break;case 10:var d=b.type._context,e=b.memoizedProps.value;G(Mg,d._currentValue);d._currentValue=e;break;case 13:d=b.memoizedState;if(null!==d){if(null!==d.dehydrated)return G(M,M.current&1),b.flags|=128,null;if(0!==(c&b.child.childLanes))return pj(a,b,c);G(M,M.current&1);a=$i(a,b,c);return null!==a?a.sibling:null}G(M,M.current&1);break;case 19:d=0!==(c&\nb.childLanes);if(0!==(a.flags&128)){if(d)return yj(a,b,c);b.flags|=128}e=b.memoizedState;null!==e&&(e.rendering=null,e.tail=null,e.lastEffect=null);G(M,M.current);if(d)break;else return null;case 22:case 23:return b.lanes=0,ej(a,b,c)}return $i(a,b,c)}var Aj,Bj,Cj,Dj;\nAj=function(a,b){for(var c=b.child;null!==c;){if(5===c.tag||6===c.tag)a.appendChild(c.stateNode);else if(4!==c.tag&&null!==c.child){c.child.return=c;c=c.child;continue}if(c===b)break;for(;null===c.sibling;){if(null===c.return||c.return===b)return;c=c.return}c.sibling.return=c.return;c=c.sibling}};Bj=function(){};\nCj=function(a,b,c,d){var e=a.memoizedProps;if(e!==d){a=b.stateNode;Hh(Eh.current);var f=null;switch(c){case \"input\":e=Ya(a,e);d=Ya(a,d);f=[];break;case \"select\":e=A({},e,{value:void 0});d=A({},d,{value:void 0});f=[];break;case \"textarea\":e=gb(a,e);d=gb(a,d);f=[];break;default:\"function\"!==typeof e.onClick&&\"function\"===typeof d.onClick&&(a.onclick=Bf)}ub(c,d);var g;c=null;for(l in e)if(!d.hasOwnProperty(l)&&e.hasOwnProperty(l)&&null!=e[l])if(\"style\"===l){var h=e[l];for(g in h)h.hasOwnProperty(g)&&\n(c||(c={}),c[g]=\"\")}else\"dangerouslySetInnerHTML\"!==l&&\"children\"!==l&&\"suppressContentEditableWarning\"!==l&&\"suppressHydrationWarning\"!==l&&\"autoFocus\"!==l&&(ea.hasOwnProperty(l)?f||(f=[]):(f=f||[]).push(l,null));for(l in d){var k=d[l];h=null!=e?e[l]:void 0;if(d.hasOwnProperty(l)&&k!==h&&(null!=k||null!=h))if(\"style\"===l)if(h){for(g in h)!h.hasOwnProperty(g)||k&&k.hasOwnProperty(g)||(c||(c={}),c[g]=\"\");for(g in k)k.hasOwnProperty(g)&&h[g]!==k[g]&&(c||(c={}),c[g]=k[g])}else c||(f||(f=[]),f.push(l,\nc)),c=k;else\"dangerouslySetInnerHTML\"===l?(k=k?k.__html:void 0,h=h?h.__html:void 0,null!=k&&h!==k&&(f=f||[]).push(l,k)):\"children\"===l?\"string\"!==typeof k&&\"number\"!==typeof k||(f=f||[]).push(l,\"\"+k):\"suppressContentEditableWarning\"!==l&&\"suppressHydrationWarning\"!==l&&(ea.hasOwnProperty(l)?(null!=k&&\"onScroll\"===l&&D(\"scroll\",a),f||h===k||(f=[])):(f=f||[]).push(l,k))}c&&(f=f||[]).push(\"style\",c);var l=f;if(b.updateQueue=l)b.flags|=4}};Dj=function(a,b,c,d){c!==d&&(b.flags|=4)};\nfunction Ej(a,b){if(!I)switch(a.tailMode){case \"hidden\":b=a.tail;for(var c=null;null!==b;)null!==b.alternate&&(c=b),b=b.sibling;null===c?a.tail=null:c.sibling=null;break;case \"collapsed\":c=a.tail;for(var d=null;null!==c;)null!==c.alternate&&(d=c),c=c.sibling;null===d?b||null===a.tail?a.tail=null:a.tail.sibling=null:d.sibling=null}}\nfunction S(a){var b=null!==a.alternate&&a.alternate.child===a.child,c=0,d=0;if(b)for(var e=a.child;null!==e;)c|=e.lanes|e.childLanes,d|=e.subtreeFlags&14680064,d|=e.flags&14680064,e.return=a,e=e.sibling;else for(e=a.child;null!==e;)c|=e.lanes|e.childLanes,d|=e.subtreeFlags,d|=e.flags,e.return=a,e=e.sibling;a.subtreeFlags|=d;a.childLanes=c;return b}\nfunction Fj(a,b,c){var d=b.pendingProps;wg(b);switch(b.tag){case 2:case 16:case 15:case 0:case 11:case 7:case 8:case 12:case 9:case 14:return S(b),null;case 1:return Zf(b.type)&&$f(),S(b),null;case 3:d=b.stateNode;Jh();E(Wf);E(H);Oh();d.pendingContext&&(d.context=d.pendingContext,d.pendingContext=null);if(null===a||null===a.child)Gg(b)?b.flags|=4:null===a||a.memoizedState.isDehydrated&&0===(b.flags&256)||(b.flags|=1024,null!==zg&&(Gj(zg),zg=null));Bj(a,b);S(b);return null;case 5:Lh(b);var e=Hh(Gh.current);\nc=b.type;if(null!==a&&null!=b.stateNode)Cj(a,b,c,d,e),a.ref!==b.ref&&(b.flags|=512,b.flags|=2097152);else{if(!d){if(null===b.stateNode)throw Error(p(166));S(b);return null}a=Hh(Eh.current);if(Gg(b)){d=b.stateNode;c=b.type;var f=b.memoizedProps;d[Of]=b;d[Pf]=f;a=0!==(b.mode&1);switch(c){case \"dialog\":D(\"cancel\",d);D(\"close\",d);break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",d);break;case \"video\":case \"audio\":for(e=0;e<lf.length;e++)D(lf[e],d);break;case \"source\":D(\"error\",d);break;case \"img\":case \"image\":case \"link\":D(\"error\",\nd);D(\"load\",d);break;case \"details\":D(\"toggle\",d);break;case \"input\":Za(d,f);D(\"invalid\",d);break;case \"select\":d._wrapperState={wasMultiple:!!f.multiple};D(\"invalid\",d);break;case \"textarea\":hb(d,f),D(\"invalid\",d)}ub(c,f);e=null;for(var g in f)if(f.hasOwnProperty(g)){var h=f[g];\"children\"===g?\"string\"===typeof h?d.textContent!==h&&(!0!==f.suppressHydrationWarning&&Af(d.textContent,h,a),e=[\"children\",h]):\"number\"===typeof h&&d.textContent!==\"\"+h&&(!0!==f.suppressHydrationWarning&&Af(d.textContent,\nh,a),e=[\"children\",\"\"+h]):ea.hasOwnProperty(g)&&null!=h&&\"onScroll\"===g&&D(\"scroll\",d)}switch(c){case \"input\":Va(d);db(d,f,!0);break;case \"textarea\":Va(d);jb(d);break;case \"select\":case \"option\":break;default:\"function\"===typeof f.onClick&&(d.onclick=Bf)}d=e;b.updateQueue=d;null!==d&&(b.flags|=4)}else{g=9===e.nodeType?e:e.ownerDocument;\"http://www.w3.org/1999/xhtml\"===a&&(a=kb(c));\"http://www.w3.org/1999/xhtml\"===a?\"script\"===c?(a=g.createElement(\"div\"),a.innerHTML=\"<script>\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;e<lf.length;e++)D(lf[e],a);e=d;break;case \"source\":D(\"error\",a);e=d;break;case \"img\":case \"image\":case \"link\":D(\"error\",\na);D(\"load\",a);e=d;break;case \"details\":D(\"toggle\",a);e=d;break;case \"input\":Za(a,d);e=Ya(a,d);D(\"invalid\",a);break;case \"option\":e=d;break;case \"select\":a._wrapperState={wasMultiple:!!d.multiple};e=A({},d,{value:void 0});D(\"invalid\",a);break;case \"textarea\":hb(a,d);e=gb(a,d);D(\"invalid\",a);break;default:e=d}ub(c,e);h=e;for(f in h)if(h.hasOwnProperty(f)){var k=h[f];\"style\"===f?sb(a,k):\"dangerouslySetInnerHTML\"===f?(k=k?k.__html:void 0,null!=k&&nb(a,k)):\"children\"===f?\"string\"===typeof k?(\"textarea\"!==\nc||\"\"!==k)&&ob(a,k):\"number\"===typeof k&&ob(a,\"\"+k):\"suppressContentEditableWarning\"!==f&&\"suppressHydrationWarning\"!==f&&\"autoFocus\"!==f&&(ea.hasOwnProperty(f)?null!=k&&\"onScroll\"===f&&D(\"scroll\",a):null!=k&&ta(a,f,k,g))}switch(c){case \"input\":Va(a);db(a,d,!1);break;case \"textarea\":Va(a);jb(a);break;case \"option\":null!=d.value&&a.setAttribute(\"value\",\"\"+Sa(d.value));break;case \"select\":a.multiple=!!d.multiple;f=d.value;null!=f?fb(a,!!d.multiple,f,!1):null!=d.defaultValue&&fb(a,!!d.multiple,d.defaultValue,\n!0);break;default:\"function\"===typeof e.onClick&&(a.onclick=Bf)}switch(c){case \"button\":case \"input\":case \"select\":case \"textarea\":d=!!d.autoFocus;break a;case \"img\":d=!0;break a;default:d=!1}}d&&(b.flags|=4)}null!==b.ref&&(b.flags|=512,b.flags|=2097152)}S(b);return null;case 6:if(a&&null!=b.stateNode)Dj(a,b,a.memoizedProps,d);else{if(\"string\"!==typeof d&&null===b.stateNode)throw Error(p(166));c=Hh(Gh.current);Hh(Eh.current);if(Gg(b)){d=b.stateNode;c=b.memoizedProps;d[Of]=b;if(f=d.nodeValue!==c)if(a=\nxg,null!==a)switch(a.tag){case 3:Af(d.nodeValue,c,0!==(a.mode&1));break;case 5:!0!==a.memoizedProps.suppressHydrationWarning&&Af(d.nodeValue,c,0!==(a.mode&1))}f&&(b.flags|=4)}else d=(9===c.nodeType?c:c.ownerDocument).createTextNode(d),d[Of]=b,b.stateNode=d}S(b);return null;case 13:E(M);d=b.memoizedState;if(null===a||null!==a.memoizedState&&null!==a.memoizedState.dehydrated){if(I&&null!==yg&&0!==(b.mode&1)&&0===(b.flags&128))Hg(),Ig(),b.flags|=98560,f=!1;else if(f=Gg(b),null!==d&&null!==d.dehydrated){if(null===\na){if(!f)throw Error(p(318));f=b.memoizedState;f=null!==f?f.dehydrated:null;if(!f)throw Error(p(317));f[Of]=b}else Ig(),0===(b.flags&128)&&(b.memoizedState=null),b.flags|=4;S(b);f=!1}else null!==zg&&(Gj(zg),zg=null),f=!0;if(!f)return b.flags&65536?b:null}if(0!==(b.flags&128))return b.lanes=c,b;d=null!==d;d!==(null!==a&&null!==a.memoizedState)&&d&&(b.child.flags|=8192,0!==(b.mode&1)&&(null===a||0!==(M.current&1)?0===T&&(T=3):uj()));null!==b.updateQueue&&(b.flags|=4);S(b);return null;case 4:return Jh(),\nBj(a,b),null===a&&sf(b.stateNode.containerInfo),S(b),null;case 10:return Rg(b.type._context),S(b),null;case 17:return Zf(b.type)&&$f(),S(b),null;case 19:E(M);f=b.memoizedState;if(null===f)return S(b),null;d=0!==(b.flags&128);g=f.rendering;if(null===g)if(d)Ej(f,!1);else{if(0!==T||null!==a&&0!==(a.flags&128))for(a=b.child;null!==a;){g=Mh(a);if(null!==g){b.flags|=128;Ej(f,!1);d=g.updateQueue;null!==d&&(b.updateQueue=d,b.flags|=4);b.subtreeFlags=0;d=c;for(c=b.child;null!==c;)f=c,a=d,f.flags&=14680066,\ng=f.alternate,null===g?(f.childLanes=0,f.lanes=a,f.child=null,f.subtreeFlags=0,f.memoizedProps=null,f.memoizedState=null,f.updateQueue=null,f.dependencies=null,f.stateNode=null):(f.childLanes=g.childLanes,f.lanes=g.lanes,f.child=g.child,f.subtreeFlags=0,f.deletions=null,f.memoizedProps=g.memoizedProps,f.memoizedState=g.memoizedState,f.updateQueue=g.updateQueue,f.type=g.type,a=g.dependencies,f.dependencies=null===a?null:{lanes:a.lanes,firstContext:a.firstContext}),c=c.sibling;G(M,M.current&1|2);return b.child}a=\na.sibling}null!==f.tail&&B()>Hj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;d<c.length;d++){var e=c[d];try{var f=a,g=b,h=g;a:for(;null!==h;){switch(h.tag){case 5:X=h.stateNode;Yj=!1;break a;case 3:X=h.stateNode.containerInfo;Yj=!0;break a;case 4:X=h.stateNode.containerInfo;Yj=!0;break a}h=h.return}if(null===X)throw Error(p(160));ak(f,g,e);X=null;Yj=!1;var k=e.alternate;null!==k&&(k.return=null);e.return=null}catch(l){W(e,b,l)}}if(b.subtreeFlags&12854)for(b=b.child;null!==b;)ek(b,a),b=b.sibling}\nfunction ek(a,b){var c=a.alternate,d=a.flags;switch(a.tag){case 0:case 11:case 14:case 15:dk(b,a);fk(a);if(d&4){try{Qj(3,a,a.return),Rj(3,a)}catch(t){W(a,a.return,t)}try{Qj(5,a,a.return)}catch(t){W(a,a.return,t)}}break;case 1:dk(b,a);fk(a);d&512&&null!==c&&Mj(c,c.return);break;case 5:dk(b,a);fk(a);d&512&&null!==c&&Mj(c,c.return);if(a.flags&32){var e=a.stateNode;try{ob(e,\"\")}catch(t){W(a,a.return,t)}}if(d&4&&(e=a.stateNode,null!=e)){var f=a.memoizedProps,g=null!==c?c.memoizedProps:f,h=a.type,k=a.updateQueue;\na.updateQueue=null;if(null!==k)try{\"input\"===h&&\"radio\"===f.type&&null!=f.name&&ab(e,f);vb(h,g);var l=vb(h,f);for(g=0;g<k.length;g+=2){var m=k[g],q=k[g+1];\"style\"===m?sb(e,q):\"dangerouslySetInnerHTML\"===m?nb(e,q):\"children\"===m?ob(e,q):ta(e,m,q,l)}switch(h){case \"input\":bb(e,f);break;case \"textarea\":ib(e,f);break;case \"select\":var r=e._wrapperState.wasMultiple;e._wrapperState.wasMultiple=!!f.multiple;var y=f.value;null!=y?fb(e,!!f.multiple,y,!1):r!==!!f.multiple&&(null!=f.defaultValue?fb(e,!!f.multiple,\nf.defaultValue,!0):fb(e,!!f.multiple,f.multiple?[]:\"\",!1))}e[Pf]=f}catch(t){W(a,a.return,t)}}break;case 6:dk(b,a);fk(a);if(d&4){if(null===a.stateNode)throw Error(p(162));e=a.stateNode;f=a.memoizedProps;try{e.nodeValue=f}catch(t){W(a,a.return,t)}}break;case 3:dk(b,a);fk(a);if(d&4&&null!==c&&c.memoizedState.isDehydrated)try{bd(b.containerInfo)}catch(t){W(a,a.return,t)}break;case 4:dk(b,a);fk(a);break;case 13:dk(b,a);fk(a);e=a.child;e.flags&8192&&(f=null!==e.memoizedState,e.stateNode.isHidden=f,!f||\nnull!==e.alternate&&null!==e.alternate.memoizedState||(gk=B()));d&4&&bk(a);break;case 22:m=null!==c&&null!==c.memoizedState;a.mode&1?(U=(l=U)||m,dk(b,a),U=l):dk(b,a);fk(a);if(d&8192){l=null!==a.memoizedState;if((a.stateNode.isHidden=l)&&!m&&0!==(a.mode&1))for(V=a,m=a.child;null!==m;){for(q=V=m;null!==V;){r=V;y=r.child;switch(r.tag){case 0:case 11:case 14:case 15:Qj(4,r,r.return);break;case 1:Mj(r,r.return);var n=r.stateNode;if(\"function\"===typeof n.componentWillUnmount){d=r;c=r.return;try{b=d,n.props=\nb.memoizedProps,n.state=b.memoizedState,n.componentWillUnmount()}catch(t){W(d,c,t)}}break;case 5:Mj(r,r.return);break;case 22:if(null!==r.memoizedState){hk(q);continue}}null!==y?(y.return=r,V=y):hk(q)}m=m.sibling}a:for(m=null,q=a;;){if(5===q.tag){if(null===m){m=q;try{e=q.stateNode,l?(f=e.style,\"function\"===typeof f.setProperty?f.setProperty(\"display\",\"none\",\"important\"):f.display=\"none\"):(h=q.stateNode,k=q.memoizedProps.style,g=void 0!==k&&null!==k&&k.hasOwnProperty(\"display\")?k.display:null,h.style.display=\nrb(\"display\",g))}catch(t){W(a,a.return,t)}}}else if(6===q.tag){if(null===m)try{q.stateNode.nodeValue=l?\"\":q.memoizedProps}catch(t){W(a,a.return,t)}}else if((22!==q.tag&&23!==q.tag||null===q.memoizedState||q===a)&&null!==q.child){q.child.return=q;q=q.child;continue}if(q===a)break a;for(;null===q.sibling;){if(null===q.return||q.return===a)break a;m===q&&(m=null);q=q.return}m===q&&(m=null);q.sibling.return=q.return;q=q.sibling}}break;case 19:dk(b,a);fk(a);d&4&&bk(a);break;case 21:break;default:dk(b,\na),fk(a)}}function fk(a){var b=a.flags;if(b&2){try{a:{for(var c=a.return;null!==c;){if(Uj(c)){var d=c;break a}c=c.return}throw Error(p(160));}switch(d.tag){case 5:var e=d.stateNode;d.flags&32&&(ob(e,\"\"),d.flags&=-33);var f=Vj(a);Xj(a,f,e);break;case 3:case 4:var g=d.stateNode.containerInfo,h=Vj(a);Wj(a,h,g);break;default:throw Error(p(161));}}catch(k){W(a,a.return,k)}a.flags&=-3}b&4096&&(a.flags&=-4097)}function ik(a,b,c){V=a;jk(a,b,c)}\nfunction jk(a,b,c){for(var d=0!==(a.mode&1);null!==V;){var e=V,f=e.child;if(22===e.tag&&d){var g=null!==e.memoizedState||Kj;if(!g){var h=e.alternate,k=null!==h&&null!==h.memoizedState||U;h=Kj;var l=U;Kj=g;if((U=k)&&!l)for(V=e;null!==V;)g=V,k=g.child,22===g.tag&&null!==g.memoizedState?kk(e):null!==k?(k.return=g,V=k):kk(e);for(;null!==f;)V=f,jk(f,b,c),f=f.sibling;V=e;Kj=h;U=l}lk(a,b,c)}else 0!==(e.subtreeFlags&8772)&&null!==f?(f.return=e,V=f):lk(a,b,c)}}\nfunction lk(a){for(;null!==V;){var b=V;if(0!==(b.flags&8772)){var c=b.alternate;try{if(0!==(b.flags&8772))switch(b.tag){case 0:case 11:case 15:U||Rj(5,b);break;case 1:var d=b.stateNode;if(b.flags&4&&!U)if(null===c)d.componentDidMount();else{var e=b.elementType===b.type?c.memoizedProps:Lg(b.type,c.memoizedProps);d.componentDidUpdate(e,c.memoizedState,d.__reactInternalSnapshotBeforeUpdate)}var f=b.updateQueue;null!==f&&ih(b,f,d);break;case 3:var g=b.updateQueue;if(null!==g){c=null;if(null!==b.child)switch(b.child.tag){case 5:c=\nb.child.stateNode;break;case 1:c=b.child.stateNode}ih(b,g,c)}break;case 5:var h=b.stateNode;if(null===c&&b.flags&4){c=h;var k=b.memoizedProps;switch(b.type){case \"button\":case \"input\":case \"select\":case \"textarea\":k.autoFocus&&c.focus();break;case \"img\":k.src&&(c.src=k.src)}}break;case 6:break;case 4:break;case 12:break;case 13:if(null===b.memoizedState){var l=b.alternate;if(null!==l){var m=l.memoizedState;if(null!==m){var q=m.dehydrated;null!==q&&bd(q)}}}break;case 19:case 17:case 21:case 22:case 23:case 25:break;\ndefault:throw Error(p(163));}U||b.flags&512&&Sj(b)}catch(r){W(b,b.return,r)}}if(b===a){V=null;break}c=b.sibling;if(null!==c){c.return=b.return;V=c;break}V=b.return}}function hk(a){for(;null!==V;){var b=V;if(b===a){V=null;break}var c=b.sibling;if(null!==c){c.return=b.return;V=c;break}V=b.return}}\nfunction kk(a){for(;null!==V;){var b=V;try{switch(b.tag){case 0:case 11:case 15:var c=b.return;try{Rj(4,b)}catch(k){W(b,c,k)}break;case 1:var d=b.stateNode;if(\"function\"===typeof d.componentDidMount){var e=b.return;try{d.componentDidMount()}catch(k){W(b,e,k)}}var f=b.return;try{Sj(b)}catch(k){W(b,f,k)}break;case 5:var g=b.return;try{Sj(b)}catch(k){W(b,g,k)}}}catch(k){W(b,b.return,k)}if(b===a){V=null;break}var h=b.sibling;if(null!==h){h.return=b.return;V=h;break}V=b.return}}\nvar mk=Math.ceil,nk=ua.ReactCurrentDispatcher,ok=ua.ReactCurrentOwner,pk=ua.ReactCurrentBatchConfig,K=0,R=null,Y=null,Z=0,gj=0,fj=Uf(0),T=0,qk=null,hh=0,rk=0,sk=0,tk=null,uk=null,gk=0,Hj=Infinity,vk=null,Pi=!1,Qi=null,Si=null,wk=!1,xk=null,yk=0,zk=0,Ak=null,Bk=-1,Ck=0;function L(){return 0!==(K&6)?B():-1!==Bk?Bk:Bk=B()}\nfunction lh(a){if(0===(a.mode&1))return 1;if(0!==(K&2)&&0!==Z)return Z&-Z;if(null!==Kg.transition)return 0===Ck&&(Ck=yc()),Ck;a=C;if(0!==a)return a;a=window.event;a=void 0===a?16:jd(a.type);return a}function mh(a,b,c,d){if(50<zk)throw zk=0,Ak=null,Error(p(185));Ac(a,c,d);if(0===(K&2)||a!==R)a===R&&(0===(K&2)&&(rk|=c),4===T&&Dk(a,Z)),Ek(a,d),1===c&&0===K&&0===(b.mode&1)&&(Hj=B()+500,fg&&jg())}\nfunction Ek(a,b){var c=a.callbackNode;wc(a,b);var d=uc(a,a===R?Z:0);if(0===d)null!==c&&bc(c),a.callbackNode=null,a.callbackPriority=0;else if(b=d&-d,a.callbackPriority!==b){null!=c&&bc(c);if(1===b)0===a.tag?ig(Fk.bind(null,a)):hg(Fk.bind(null,a)),Jf(function(){0===(K&6)&&jg()}),c=null;else{switch(Dc(d)){case 1:c=fc;break;case 4:c=gc;break;case 16:c=hc;break;case 536870912:c=jc;break;default:c=hc}c=Gk(c,Hk.bind(null,a))}a.callbackPriority=b;a.callbackNode=c}}\nfunction Hk(a,b){Bk=-1;Ck=0;if(0!==(K&6))throw Error(p(327));var c=a.callbackNode;if(Ik()&&a.callbackNode!==c)return null;var d=uc(a,a===R?Z:0);if(0===d)return null;if(0!==(d&30)||0!==(d&a.expiredLanes)||b)b=Jk(a,d);else{b=d;var e=K;K|=2;var f=Kk();if(R!==a||Z!==b)vk=null,Hj=B()+500,Lk(a,b);do try{Mk();break}catch(h){Nk(a,h)}while(1);Qg();nk.current=f;K=e;null!==Y?b=0:(R=null,Z=0,b=T)}if(0!==b){2===b&&(e=xc(a),0!==e&&(d=e,b=Ok(a,e)));if(1===b)throw c=qk,Lk(a,0),Dk(a,d),Ek(a,B()),c;if(6===b)Dk(a,d);\nelse{e=a.current.alternate;if(0===(d&30)&&!Pk(e)&&(b=Jk(a,d),2===b&&(f=xc(a),0!==f&&(d=f,b=Ok(a,f))),1===b))throw c=qk,Lk(a,0),Dk(a,d),Ek(a,B()),c;a.finishedWork=e;a.finishedLanes=d;switch(b){case 0:case 1:throw Error(p(345));case 2:Qk(a,uk,vk);break;case 3:Dk(a,d);if((d&130023424)===d&&(b=gk+500-B(),10<b)){if(0!==uc(a,0))break;e=a.suspendedLanes;if((e&d)!==d){L();a.pingedLanes|=a.suspendedLanes&e;break}a.timeoutHandle=Ff(Qk.bind(null,a,uk,vk),b);break}Qk(a,uk,vk);break;case 4:Dk(a,d);if((d&4194240)===\nd)break;b=a.eventTimes;for(e=-1;0<d;){var g=31-oc(d);f=1<<g;g=b[g];g>e&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10<d){a.timeoutHandle=Ff(Qk.bind(null,a,uk,vk),d);break}Qk(a,uk,vk);break;case 5:Qk(a,uk,vk);break;default:throw Error(p(329));}}}Ek(a,B());return a.callbackNode===c?Hk.bind(null,a):null}\nfunction Ok(a,b){var c=tk;a.current.memoizedState.isDehydrated&&(Lk(a,b).flags|=256);a=Jk(a,b);2!==a&&(b=uk,uk=c,null!==b&&Gj(b));return a}function Gj(a){null===uk?uk=a:uk.push.apply(uk,a)}\nfunction Pk(a){for(var b=a;;){if(b.flags&16384){var c=b.updateQueue;if(null!==c&&(c=c.stores,null!==c))for(var d=0;d<c.length;d++){var e=c[d],f=e.getSnapshot;e=e.value;try{if(!He(f(),e))return!1}catch(g){return!1}}}c=b.child;if(b.subtreeFlags&16384&&null!==c)c.return=b,b=c;else{if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return!0;b=b.return}b.sibling.return=b.return;b=b.sibling}}return!0}\nfunction Dk(a,b){b&=~sk;b&=~rk;a.suspendedLanes|=b;a.pingedLanes&=~b;for(a=a.expirationTimes;0<b;){var c=31-oc(b),d=1<<c;a[c]=-1;b&=~d}}function Fk(a){if(0!==(K&6))throw Error(p(327));Ik();var b=uc(a,0);if(0===(b&1))return Ek(a,B()),null;var c=Jk(a,b);if(0!==a.tag&&2===c){var d=xc(a);0!==d&&(b=d,c=Ok(a,d))}if(1===c)throw c=qk,Lk(a,0),Dk(a,b),Ek(a,B()),c;if(6===c)throw Error(p(345));a.finishedWork=a.current.alternate;a.finishedLanes=b;Qk(a,uk,vk);Ek(a,B());return null}\nfunction Rk(a,b){var c=K;K|=1;try{return a(b)}finally{K=c,0===K&&(Hj=B()+500,fg&&jg())}}function Sk(a){null!==xk&&0===xk.tag&&0===(K&6)&&Ik();var b=K;K|=1;var c=pk.transition,d=C;try{if(pk.transition=null,C=1,a)return a()}finally{C=d,pk.transition=c,K=b,0===(K&6)&&jg()}}function Ij(){gj=fj.current;E(fj)}\nfunction Lk(a,b){a.finishedWork=null;a.finishedLanes=0;var c=a.timeoutHandle;-1!==c&&(a.timeoutHandle=-1,Gf(c));if(null!==Y)for(c=Y.return;null!==c;){var d=c;wg(d);switch(d.tag){case 1:d=d.type.childContextTypes;null!==d&&void 0!==d&&$f();break;case 3:Jh();E(Wf);E(H);Oh();break;case 5:Lh(d);break;case 4:Jh();break;case 13:E(M);break;case 19:E(M);break;case 10:Rg(d.type._context);break;case 22:case 23:Ij()}c=c.return}R=a;Y=a=wh(a.current,null);Z=gj=b;T=0;qk=null;sk=rk=hh=0;uk=tk=null;if(null!==Wg){for(b=\n0;b<Wg.length;b++)if(c=Wg[b],d=c.interleaved,null!==d){c.interleaved=null;var e=d.next,f=c.pending;if(null!==f){var g=f.next;f.next=e;d.next=g}c.pending=d}Wg=null}return a}\nfunction Nk(a,b){do{var c=Y;try{Qg();Ph.current=ai;if(Sh){for(var d=N.memoizedState;null!==d;){var e=d.queue;null!==e&&(e.pending=null);d=d.next}Sh=!1}Rh=0;P=O=N=null;Th=!1;Uh=0;ok.current=null;if(null===c||null===c.return){T=1;qk=b;Y=null;break}a:{var f=a,g=c.return,h=c,k=b;b=Z;h.flags|=32768;if(null!==k&&\"object\"===typeof k&&\"function\"===typeof k.then){var l=k,m=h,q=m.tag;if(0===(m.mode&1)&&(0===q||11===q||15===q)){var r=m.alternate;r?(m.updateQueue=r.updateQueue,m.memoizedState=r.memoizedState,\nm.lanes=r.lanes):(m.updateQueue=null,m.memoizedState=null)}var y=Vi(g);if(null!==y){y.flags&=-257;Wi(y,g,h,f,b);y.mode&1&&Ti(f,l,b);b=y;k=l;var n=b.updateQueue;if(null===n){var t=new Set;t.add(k);b.updateQueue=t}else n.add(k);break a}else{if(0===(b&1)){Ti(f,l,b);uj();break a}k=Error(p(426))}}else if(I&&h.mode&1){var J=Vi(g);if(null!==J){0===(J.flags&65536)&&(J.flags|=256);Wi(J,g,h,f,b);Jg(Ki(k,h));break a}}f=k=Ki(k,h);4!==T&&(T=2);null===tk?tk=[f]:tk.push(f);f=g;do{switch(f.tag){case 3:f.flags|=65536;\nb&=-b;f.lanes|=b;var x=Oi(f,k,b);fh(f,x);break a;case 1:h=k;var w=f.type,u=f.stateNode;if(0===(f.flags&128)&&(\"function\"===typeof w.getDerivedStateFromError||null!==u&&\"function\"===typeof u.componentDidCatch&&(null===Si||!Si.has(u)))){f.flags|=65536;b&=-b;f.lanes|=b;var F=Ri(f,h,b);fh(f,F);break a}}f=f.return}while(null!==f)}Tk(c)}catch(na){b=na;Y===c&&null!==c&&(Y=c=c.return);continue}break}while(1)}function Kk(){var a=nk.current;nk.current=ai;return null===a?ai:a}\nfunction uj(){if(0===T||3===T||2===T)T=4;null===R||0===(hh&268435455)&&0===(rk&268435455)||Dk(R,Z)}function Jk(a,b){var c=K;K|=2;var d=Kk();if(R!==a||Z!==b)vk=null,Lk(a,b);do try{Uk();break}catch(e){Nk(a,e)}while(1);Qg();K=c;nk.current=d;if(null!==Y)throw Error(p(261));R=null;Z=0;return T}function Uk(){for(;null!==Y;)Vk(Y)}function Mk(){for(;null!==Y&&!cc();)Vk(Y)}function Vk(a){var b=Wk(a.alternate,a,gj);a.memoizedProps=a.pendingProps;null===b?Tk(a):Y=b;ok.current=null}\nfunction Tk(a){var b=a;do{var c=b.alternate;a=b.return;if(0===(b.flags&32768)){if(c=Fj(c,b,gj),null!==c){Y=c;return}}else{c=Jj(c,b);if(null!==c){c.flags&=32767;Y=c;return}if(null!==a)a.flags|=32768,a.subtreeFlags=0,a.deletions=null;else{T=6;Y=null;return}}b=b.sibling;if(null!==b){Y=b;return}Y=b=a}while(null!==b);0===T&&(T=5)}function Qk(a,b,c){var d=C,e=pk.transition;try{pk.transition=null,C=1,Xk(a,b,c,d)}finally{pk.transition=e,C=d}return null}\nfunction Xk(a,b,c,d){do Ik();while(null!==xk);if(0!==(K&6))throw Error(p(327));c=a.finishedWork;var e=a.finishedLanes;if(null===c)return null;a.finishedWork=null;a.finishedLanes=0;if(c===a.current)throw Error(p(177));a.callbackNode=null;a.callbackPriority=0;var f=c.lanes|c.childLanes;Bc(a,f);a===R&&(Y=R=null,Z=0);0===(c.subtreeFlags&2064)&&0===(c.flags&2064)||wk||(wk=!0,Gk(hc,function(){Ik();return null}));f=0!==(c.flags&15990);if(0!==(c.subtreeFlags&15990)||f){f=pk.transition;pk.transition=null;\nvar g=C;C=1;var h=K;K|=4;ok.current=null;Pj(a,c);ek(c,a);Oe(Df);dd=!!Cf;Df=Cf=null;a.current=c;ik(c,a,e);dc();K=h;C=g;pk.transition=f}else a.current=c;wk&&(wk=!1,xk=a,yk=e);f=a.pendingLanes;0===f&&(Si=null);mc(c.stateNode,d);Ek(a,B());if(null!==b)for(d=a.onRecoverableError,c=0;c<b.length;c++)e=b[c],d(e.value,{componentStack:e.stack,digest:e.digest});if(Pi)throw Pi=!1,a=Qi,Qi=null,a;0!==(yk&1)&&0!==a.tag&&Ik();f=a.pendingLanes;0!==(f&1)?a===Ak?zk++:(zk=0,Ak=a):zk=0;jg();return null}\nfunction Ik(){if(null!==xk){var a=Dc(yk),b=pk.transition,c=C;try{pk.transition=null;C=16>a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;k<h.length;k++){var l=h[k];for(V=l;null!==V;){var m=V;switch(m.tag){case 0:case 11:case 15:Qj(8,m,f)}var q=m.child;if(null!==q)q.return=m,V=q;else for(;null!==V;){m=V;var r=m.sibling,y=m.return;Tj(m);if(m===\nl){V=null;break}if(null!==r){r.return=y;V=r;break}V=y}}}var n=f.alternate;if(null!==n){var t=n.child;if(null!==t){n.child=null;do{var J=t.sibling;t.sibling=null;t=J}while(null!==t)}}V=f}}if(0!==(f.subtreeFlags&2064)&&null!==g)g.return=f,V=g;else b:for(;null!==V;){f=V;if(0!==(f.flags&2048))switch(f.tag){case 0:case 11:case 15:Qj(9,f,f.return)}var x=f.sibling;if(null!==x){x.return=f.return;V=x;break b}V=f.return}}var w=a.current;for(V=w;null!==V;){g=V;var u=g.child;if(0!==(g.subtreeFlags&2064)&&null!==\nu)u.return=g,V=u;else b:for(g=w;null!==V;){h=V;if(0!==(h.flags&2048))try{switch(h.tag){case 0:case 11:case 15:Rj(9,h)}}catch(na){W(h,h.return,na)}if(h===g){V=null;break b}var F=h.sibling;if(null!==F){F.return=h.return;V=F;break b}V=h.return}}K=e;jg();if(lc&&\"function\"===typeof lc.onPostCommitFiberRoot)try{lc.onPostCommitFiberRoot(kc,a)}catch(na){}d=!0}return d}finally{C=c,pk.transition=b}}return!1}function Yk(a,b,c){b=Ki(c,b);b=Oi(a,b,1);a=dh(a,b,1);b=L();null!==a&&(Ac(a,1,b),Ek(a,b))}\nfunction W(a,b,c){if(3===a.tag)Yk(a,a,c);else for(;null!==b;){if(3===b.tag){Yk(b,a,c);break}else if(1===b.tag){var d=b.stateNode;if(\"function\"===typeof b.type.getDerivedStateFromError||\"function\"===typeof d.componentDidCatch&&(null===Si||!Si.has(d))){a=Ki(c,a);a=Ri(b,a,1);b=dh(b,a,1);a=L();null!==b&&(Ac(b,1,a),Ek(b,a));break}}b=b.return}}\nfunction Ui(a,b,c){var d=a.pingCache;null!==d&&d.delete(b);b=L();a.pingedLanes|=a.suspendedLanes&c;R===a&&(Z&c)===c&&(4===T||3===T&&(Z&130023424)===Z&&500>B()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3<arguments.length&&void 0!==arguments[3]?arguments[3]:null;return{$$typeof:wa,key:null==d?null:\"\"+d,children:a,containerInfo:b,implementation:c}}\nfunction el(a){if(!a)return Vf;a=a._reactInternals;a:{if(Vb(a)!==a||1!==a.tag)throw Error(p(170));var b=a;do{switch(b.tag){case 3:b=b.stateNode.context;break a;case 1:if(Zf(b.type)){b=b.stateNode.__reactInternalMemoizedMergedChildContext;break a}}b=b.return}while(null!==b);throw Error(p(171));}if(1===a.tag){var c=a.type;if(Zf(c))return bg(a,c,b)}return b}\nfunction fl(a,b,c,d,e,f,g,h,k){a=cl(c,d,!0,a,e,f,g,h,k);a.context=el(null);c=a.current;d=L();e=lh(c);f=ch(d,e);f.callback=void 0!==b&&null!==b?b:null;dh(c,f,e);a.current.lanes=e;Ac(a,e,d);Ek(a,d);return a}function gl(a,b,c,d){var e=b.current,f=L(),g=lh(e);c=el(c);null===b.context?b.context=c:b.pendingContext=c;b=ch(f,g);b.payload={element:a};d=void 0===d?null:d;null!==d&&(b.callback=d);a=dh(e,b,g);null!==a&&(mh(a,e,g,f),eh(a,e,g));return g}\nfunction hl(a){a=a.current;if(!a.child)return null;switch(a.child.tag){case 5:return a.child.stateNode;default:return a.child.stateNode}}function il(a,b){a=a.memoizedState;if(null!==a&&null!==a.dehydrated){var c=a.retryLane;a.retryLane=0!==c&&c<b?c:b}}function jl(a,b){il(a,b);(a=a.alternate)&&il(a,b)}function kl(){return null}var ll=\"function\"===typeof reportError?reportError:function(a){console.error(a)};function ml(a){this._internalRoot=a}\nnl.prototype.render=ml.prototype.render=function(a){var b=this._internalRoot;if(null===b)throw Error(p(409));gl(a,b,null,null)};nl.prototype.unmount=ml.prototype.unmount=function(){var a=this._internalRoot;if(null!==a){this._internalRoot=null;var b=a.containerInfo;Sk(function(){gl(null,a,null,null)});b[uf]=null}};function nl(a){this._internalRoot=a}\nnl.prototype.unstable_scheduleHydration=function(a){if(a){var b=Hc();a={blockedOn:null,target:a,priority:b};for(var c=0;c<Qc.length&&0!==b&&b<Qc[c].priority;c++);Qc.splice(c,0,a);0===c&&Vc(a)}};function ol(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType)}function pl(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType&&(8!==a.nodeType||\" react-mount-point-unstable \"!==a.nodeValue))}function ql(){}\nfunction rl(a,b,c,d,e){if(e){if(\"function\"===typeof d){var f=d;d=function(){var a=hl(g);f.call(a)}}var g=fl(b,d,a,0,null,!1,!1,\"\",ql);a._reactRootContainer=g;a[uf]=g.current;sf(8===a.nodeType?a.parentNode:a);Sk();return g}for(;e=a.lastChild;)a.removeChild(e);if(\"function\"===typeof d){var h=d;d=function(){var a=hl(k);h.call(a)}}var k=cl(a,0,!1,null,null,!1,!1,\"\",ql);a._reactRootContainer=k;a[uf]=k.current;sf(8===a.nodeType?a.parentNode:a);Sk(function(){gl(b,k,c,d)});return k}\nfunction sl(a,b,c,d,e){var f=c._reactRootContainer;if(f){var g=f;if(\"function\"===typeof e){var h=e;e=function(){var a=hl(g);h.call(a)}}gl(b,g,a,e)}else g=rl(c,b,a,e,d);return hl(g)}Ec=function(a){switch(a.tag){case 3:var b=a.stateNode;if(b.current.memoizedState.isDehydrated){var c=tc(b.pendingLanes);0!==c&&(Cc(b,c|1),Ek(b,B()),0===(K&6)&&(Hj=B()+500,jg()))}break;case 13:Sk(function(){var b=Zg(a,1);if(null!==b){var c=L();mh(b,a,1,c)}}),jl(a,1)}};\nFc=function(a){if(13===a.tag){var b=Zg(a,134217728);if(null!==b){var c=L();mh(b,a,134217728,c)}jl(a,134217728)}};Gc=function(a){if(13===a.tag){var b=lh(a),c=Zg(a,b);if(null!==c){var d=L();mh(c,a,b,d)}jl(a,b)}};Hc=function(){return C};Ic=function(a,b){var c=C;try{return C=a,b()}finally{C=c}};\nyb=function(a,b,c){switch(b){case \"input\":bb(a,c);b=c.name;if(\"radio\"===c.type&&null!=b){for(c=a;c.parentNode;)c=c.parentNode;c=c.querySelectorAll(\"input[name=\"+JSON.stringify(\"\"+b)+'][type=\"radio\"]');for(b=0;b<c.length;b++){var d=c[b];if(d!==a&&d.form===a.form){var e=Db(d);if(!e)throw Error(p(90));Wa(d);bb(d,e)}}}break;case \"textarea\":ib(a,c);break;case \"select\":b=c.value,null!=b&&fb(a,!!c.multiple,b,!1)}};Gb=Rk;Hb=Sk;\nvar tl={usingClientEntryPoint:!1,Events:[Cb,ue,Db,Eb,Fb,Rk]},ul={findFiberByHostInstance:Wc,bundleType:0,version:\"18.2.0\",rendererPackageName:\"react-dom\"};\nvar vl={bundleType:ul.bundleType,version:ul.version,rendererPackageName:ul.rendererPackageName,rendererConfig:ul.rendererConfig,overrideHookState:null,overrideHookStateDeletePath:null,overrideHookStateRenamePath:null,overrideProps:null,overridePropsDeletePath:null,overridePropsRenamePath:null,setErrorHandler:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:ua.ReactCurrentDispatcher,findHostInstanceByFiber:function(a){a=Zb(a);return null===a?null:a.stateNode},findFiberByHostInstance:ul.findFiberByHostInstance||\nkl,findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null,reconcilerVersion:\"18.2.0-next-9e3b772b8-20220608\"};if(\"undefined\"!==typeof __REACT_DEVTOOLS_GLOBAL_HOOK__){var wl=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(!wl.isDisabled&&wl.supportsFiber)try{kc=wl.inject(vl),lc=wl}catch(a){}}exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=tl;\nexports.createPortal=function(a,b){var c=2<arguments.length&&void 0!==arguments[2]?arguments[2]:null;if(!ol(b))throw Error(p(200));return dl(a,b,null,c)};exports.createRoot=function(a,b){if(!ol(a))throw Error(p(299));var c=!1,d=\"\",e=ll;null!==b&&void 0!==b&&(!0===b.unstable_strictMode&&(c=!0),void 0!==b.identifierPrefix&&(d=b.identifierPrefix),void 0!==b.onRecoverableError&&(e=b.onRecoverableError));b=cl(a,1,!1,null,null,c,!1,d,e);a[uf]=b.current;sf(8===a.nodeType?a.parentNode:a);return new ml(b)};\nexports.findDOMNode=function(a){if(null==a)return null;if(1===a.nodeType)return a;var b=a._reactInternals;if(void 0===b){if(\"function\"===typeof a.render)throw Error(p(188));a=Object.keys(a).join(\",\");throw Error(p(268,a));}a=Zb(b);a=null===a?null:a.stateNode;return a};exports.flushSync=function(a){return Sk(a)};exports.hydrate=function(a,b,c){if(!pl(b))throw Error(p(200));return sl(null,a,b,!0,c)};\nexports.hydrateRoot=function(a,b,c){if(!ol(a))throw Error(p(405));var d=null!=c&&c.hydratedSources||null,e=!1,f=\"\",g=ll;null!==c&&void 0!==c&&(!0===c.unstable_strictMode&&(e=!0),void 0!==c.identifierPrefix&&(f=c.identifierPrefix),void 0!==c.onRecoverableError&&(g=c.onRecoverableError));b=fl(b,null,a,1,null!=c?c:null,e,!1,f,g);a[uf]=b.current;sf(a);if(d)for(a=0;a<d.length;a++)c=d[a],e=c._getVersion,e=e(c._source),null==b.mutableSourceEagerHydrationData?b.mutableSourceEagerHydrationData=[c,e]:b.mutableSourceEagerHydrationData.push(c,\ne);return new nl(b)};exports.render=function(a,b,c){if(!pl(b))throw Error(p(200));return sl(null,a,b,!1,c)};exports.unmountComponentAtNode=function(a){if(!pl(a))throw Error(p(40));return a._reactRootContainer?(Sk(function(){sl(null,null,a,!1,function(){a._reactRootContainer=null;a[uf]=null})}),!0):!1};exports.unstable_batchedUpdates=Rk;\nexports.unstable_renderSubtreeIntoContainer=function(a,b,c,d){if(!pl(c))throw Error(p(200));if(null==a||void 0===a._reactInternals)throw Error(p(38));return sl(a,b,c,!1,d)};exports.version=\"18.2.0-next-9e3b772b8-20220608\";\n","'use strict';\n\nvar m = require('react-dom');\nif (process.env.NODE_ENV === 'production') {\n exports.createRoot = m.createRoot;\n exports.hydrateRoot = m.hydrateRoot;\n} else {\n var i = m.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n exports.createRoot = function(c, o) {\n i.usingClientEntryPoint = true;\n try {\n return m.createRoot(c, o);\n } finally {\n i.usingClientEntryPoint = false;\n }\n };\n exports.hydrateRoot = function(c, h, o) {\n i.usingClientEntryPoint = true;\n try {\n return m.hydrateRoot(c, h, o);\n } finally {\n i.usingClientEntryPoint = false;\n }\n };\n}\n","'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.min.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","/**\n * @license React\n * react-jsx-runtime.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var f=require(\"react\"),k=Symbol.for(\"react.element\"),l=Symbol.for(\"react.fragment\"),m=Object.prototype.hasOwnProperty,n=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};\nfunction q(c,a,g){var b,d={},e=null,h=null;void 0!==g&&(e=\"\"+g);void 0!==a.key&&(e=\"\"+a.key);void 0!==a.ref&&(h=a.ref);for(b in a)m.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)void 0===d[b]&&(d[b]=a[b]);return{$$typeof:k,type:c,key:e,ref:h,props:d,_owner:n.current}}exports.Fragment=l;exports.jsx=q;exports.jsxs=q;\n","/**\n * @license React\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var l=Symbol.for(\"react.element\"),n=Symbol.for(\"react.portal\"),p=Symbol.for(\"react.fragment\"),q=Symbol.for(\"react.strict_mode\"),r=Symbol.for(\"react.profiler\"),t=Symbol.for(\"react.provider\"),u=Symbol.for(\"react.context\"),v=Symbol.for(\"react.forward_ref\"),w=Symbol.for(\"react.suspense\"),x=Symbol.for(\"react.memo\"),y=Symbol.for(\"react.lazy\"),z=Symbol.iterator;function A(a){if(null===a||\"object\"!==typeof a)return null;a=z&&a[z]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nvar B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};\nE.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;\nH.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1<g){for(var f=Array(g),m=0;m<g;m++)f[m]=arguments[m+2];c.children=f}if(a&&a.defaultProps)for(d in g=a.defaultProps,g)void 0===c[d]&&(c[d]=g[d]);return{$$typeof:l,type:a,key:k,ref:h,props:c,_owner:K.current}}\nfunction N(a,b){return{$$typeof:l,type:a.type,key:b,ref:a.ref,props:a.props,_owner:a._owner}}function O(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===l}function escape(a){var b={\"=\":\"=0\",\":\":\"=2\"};return\"$\"+a.replace(/[=:]/g,function(a){return b[a]})}var P=/\\/+/g;function Q(a,b){return\"object\"===typeof a&&null!==a&&null!=a.key?escape(\"\"+a.key):b.toString(36)}\nfunction R(a,b,e,d,c){var k=typeof a;if(\"undefined\"===k||\"boolean\"===k)a=null;var h=!1;if(null===a)h=!0;else switch(k){case \"string\":case \"number\":h=!0;break;case \"object\":switch(a.$$typeof){case l:case n:h=!0}}if(h)return h=a,c=c(h),a=\"\"===d?\".\"+Q(h,0):d,I(c)?(e=\"\",null!=a&&(e=a.replace(P,\"$&/\")+\"/\"),R(c,b,e,\"\",function(a){return a})):null!=c&&(O(c)&&(c=N(c,e+(!c.key||h&&h.key===c.key?\"\":(\"\"+c.key).replace(P,\"$&/\")+\"/\")+a)),b.push(c)),1;h=0;d=\"\"===d?\".\":d+\":\";if(I(a))for(var g=0;g<a.length;g++){k=\na[g];var f=d+Q(k,g);h+=R(k,b,e,f,c)}else if(f=A(a),\"function\"===typeof f)for(a=f.call(a),g=0;!(k=a.next()).done;)k=k.value,f=d+Q(k,g++),h+=R(k,b,e,f,c);else if(\"object\"===k)throw b=String(a),Error(\"Objects are not valid as a React child (found: \"+(\"[object Object]\"===b?\"object with keys {\"+Object.keys(a).join(\", \")+\"}\":b)+\"). If you meant to render a collection of children, use an array instead.\");return h}\nfunction S(a,b,e){if(null==a)return a;var d=[],c=0;R(a,d,\"\",\"\",function(a){return b.call(e,a,c++)});return d}function T(a){if(-1===a._status){var b=a._result;b=b();b.then(function(b){if(0===a._status||-1===a._status)a._status=1,a._result=b},function(b){if(0===a._status||-1===a._status)a._status=2,a._result=b});-1===a._status&&(a._status=0,a._result=b)}if(1===a._status)return a._result.default;throw a._result;}\nvar U={current:null},V={transition:null},W={ReactCurrentDispatcher:U,ReactCurrentBatchConfig:V,ReactCurrentOwner:K};exports.Children={map:S,forEach:function(a,b,e){S(a,function(){b.apply(this,arguments)},e)},count:function(a){var b=0;S(a,function(){b++});return b},toArray:function(a){return S(a,function(a){return a})||[]},only:function(a){if(!O(a))throw Error(\"React.Children.only expected to receive a single React element child.\");return a}};exports.Component=E;exports.Fragment=p;\nexports.Profiler=r;exports.PureComponent=G;exports.StrictMode=q;exports.Suspense=w;exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=W;\nexports.cloneElement=function(a,b,e){if(null===a||void 0===a)throw Error(\"React.cloneElement(...): The argument must be a React element, but you passed \"+a+\".\");var d=C({},a.props),c=a.key,k=a.ref,h=a._owner;if(null!=b){void 0!==b.ref&&(k=b.ref,h=K.current);void 0!==b.key&&(c=\"\"+b.key);if(a.type&&a.type.defaultProps)var g=a.type.defaultProps;for(f in b)J.call(b,f)&&!L.hasOwnProperty(f)&&(d[f]=void 0===b[f]&&void 0!==g?g[f]:b[f])}var f=arguments.length-2;if(1===f)d.children=e;else if(1<f){g=Array(f);\nfor(var m=0;m<f;m++)g[m]=arguments[m+2];d.children=g}return{$$typeof:l,type:a.type,key:c,ref:k,props:d,_owner:h}};exports.createContext=function(a){a={$$typeof:u,_currentValue:a,_currentValue2:a,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null};a.Provider={$$typeof:t,_context:a};return a.Consumer=a};exports.createElement=M;exports.createFactory=function(a){var b=M.bind(null,a);b.type=a;return b};exports.createRef=function(){return{current:null}};\nexports.forwardRef=function(a){return{$$typeof:v,render:a}};exports.isValidElement=O;exports.lazy=function(a){return{$$typeof:y,_payload:{_status:-1,_result:a},_init:T}};exports.memo=function(a,b){return{$$typeof:x,type:a,compare:void 0===b?null:b}};exports.startTransition=function(a){var b=V.transition;V.transition={};try{a()}finally{V.transition=b}};exports.unstable_act=function(){throw Error(\"act(...) is not supported in production builds of React.\");};\nexports.useCallback=function(a,b){return U.current.useCallback(a,b)};exports.useContext=function(a){return U.current.useContext(a)};exports.useDebugValue=function(){};exports.useDeferredValue=function(a){return U.current.useDeferredValue(a)};exports.useEffect=function(a,b){return U.current.useEffect(a,b)};exports.useId=function(){return U.current.useId()};exports.useImperativeHandle=function(a,b,e){return U.current.useImperativeHandle(a,b,e)};\nexports.useInsertionEffect=function(a,b){return U.current.useInsertionEffect(a,b)};exports.useLayoutEffect=function(a,b){return U.current.useLayoutEffect(a,b)};exports.useMemo=function(a,b){return U.current.useMemo(a,b)};exports.useReducer=function(a,b,e){return U.current.useReducer(a,b,e)};exports.useRef=function(a){return U.current.useRef(a)};exports.useState=function(a){return U.current.useState(a)};exports.useSyncExternalStore=function(a,b,e){return U.current.useSyncExternalStore(a,b,e)};\nexports.useTransition=function(){return U.current.useTransition()};exports.version=\"18.2.0\";\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.min.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\n","/**\n * @license React\n * scheduler.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';function f(a,b){var c=a.length;a.push(b);a:for(;0<c;){var d=c-1>>>1,e=a[d];if(0<g(e,b))a[d]=b,a[c]=e,c=d;else break a}}function h(a){return 0===a.length?null:a[0]}function k(a){if(0===a.length)return null;var b=a[0],c=a.pop();if(c!==b){a[0]=c;a:for(var d=0,e=a.length,w=e>>>1;d<w;){var m=2*(d+1)-1,C=a[m],n=m+1,x=a[n];if(0>g(C,c))n<e&&0>g(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(n<e&&0>g(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Q<P?!1:!0}function R(){if(null!==O){var a=exports.unstable_now();Q=a;var b=!0;try{b=O(!0,a)}finally{b?S():(N=!1,O=null)}}else N=!1}var S;if(\"function\"===typeof F)S=function(){F(R)};else if(\"undefined\"!==typeof MessageChannel){var T=new MessageChannel,U=T.port2;T.port1.onmessage=R;S=function(){U.postMessage(null)}}else S=function(){D(R,0)};function I(a){O=a;N||(N=!0,S())}function K(a,b){L=D(function(){a(exports.unstable_now())},b)}\nexports.unstable_IdlePriority=5;exports.unstable_ImmediatePriority=1;exports.unstable_LowPriority=4;exports.unstable_NormalPriority=3;exports.unstable_Profiling=null;exports.unstable_UserBlockingPriority=2;exports.unstable_cancelCallback=function(a){a.callback=null};exports.unstable_continueExecution=function(){A||z||(A=!0,I(J))};\nexports.unstable_forceFrameRate=function(a){0>a||125<a?console.error(\"forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported\"):P=0<a?Math.floor(1E3/a):5};exports.unstable_getCurrentPriorityLevel=function(){return y};exports.unstable_getFirstCallbackNode=function(){return h(r)};exports.unstable_next=function(a){switch(y){case 1:case 2:case 3:var b=3;break;default:b=y}var c=y;y=b;try{return a()}finally{y=c}};exports.unstable_pauseExecution=function(){};\nexports.unstable_requestPaint=function(){};exports.unstable_runWithPriority=function(a,b){switch(a){case 1:case 2:case 3:case 4:case 5:break;default:a=3}var c=y;y=a;try{return b()}finally{y=c}};\nexports.unstable_scheduleCallback=function(a,b,c){var d=exports.unstable_now();\"object\"===typeof c&&null!==c?(c=c.delay,c=\"number\"===typeof c&&0<c?d+c:d):c=d;switch(a){case 1:var e=-1;break;case 2:e=250;break;case 5:e=1073741823;break;case 4:e=1E4;break;default:e=5E3}e=c+e;a={id:u++,callback:b,priorityLevel:a,startTime:c,expirationTime:e,sortIndex:-1};c>d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","var getProto = Object.getPrototypeOf ? function(obj) { return Object.getPrototypeOf(obj); } : function(obj) { return obj.__proto__; };\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach(function(key) { def[key] = function() { return value[key]; }; });\n\t}\n\tdef['default'] = function() { return value; };\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.hmd = function(module) {\n\tmodule = Object.create(module);\n\tif (!module.children) module.children = [];\n\tObject.defineProperty(module, 'exports', {\n\t\tenumerable: true,\n\t\tset: function() {\n\t\t\tthrow new Error('ES Modules may not assign module.exports or exports.*, Use ESM export syntax, instead: ' + module.id);\n\t\t}\n\t});\n\treturn module;\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/wp-content/themes/criteo2017/react/ad-gallery/build/\";","////////////////////////////////////////////////////////////////////////////////\n//#region Types and Constants\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Actions represent the type of change to a location value.\n */\nexport enum Action {\n /**\n * A POP indicates a change to an arbitrary index in the history stack, such\n * as a back or forward navigation. It does not describe the direction of the\n * navigation, only that the current index changed.\n *\n * Note: This is the default action for newly created history objects.\n */\n Pop = \"POP\",\n\n /**\n * A PUSH indicates a new entry being added to the history stack, such as when\n * a link is clicked and a new page loads. When this happens, all subsequent\n * entries in the stack are lost.\n */\n Push = \"PUSH\",\n\n /**\n * A REPLACE indicates the entry at the current index in the history stack\n * being replaced by a new one.\n */\n Replace = \"REPLACE\",\n}\n\n/**\n * The pathname, search, and hash values of a URL.\n */\nexport interface Path {\n /**\n * A URL pathname, beginning with a /.\n */\n pathname: string;\n\n /**\n * A URL search string, beginning with a ?.\n */\n search: string;\n\n /**\n * A URL fragment identifier, beginning with a #.\n */\n hash: string;\n}\n\n/**\n * An entry in a history stack. A location contains information about the\n * URL path, as well as possibly some arbitrary state and a key.\n */\nexport interface Location extends Path {\n /**\n * A value of arbitrary data associated with this location.\n */\n state: any;\n\n /**\n * A unique string associated with this location. May be used to safely store\n * and retrieve data in some other storage API, like `localStorage`.\n *\n * Note: This value is always \"default\" on the initial location.\n */\n key: string;\n}\n\n/**\n * A change to the current location.\n */\nexport interface Update {\n /**\n * The action that triggered the change.\n */\n action: Action;\n\n /**\n * The new location.\n */\n location: Location;\n\n /**\n * The delta between this location and the former location in the history stack\n */\n delta: number | null;\n}\n\n/**\n * A function that receives notifications about location changes.\n */\nexport interface Listener {\n (update: Update): void;\n}\n\n/**\n * Describes a location that is the destination of some navigation, either via\n * `history.push` or `history.replace`. May be either a URL or the pieces of a\n * URL path.\n */\nexport type To = string | Partial<Path>;\n\n/**\n * A history is an interface to the navigation stack. The history serves as the\n * source of truth for the current location, as well as provides a set of\n * methods that may be used to change it.\n *\n * It is similar to the DOM's `window.history` object, but with a smaller, more\n * focused API.\n */\nexport interface History {\n /**\n * The last action that modified the current location. This will always be\n * Action.Pop when a history instance is first created. This value is mutable.\n */\n readonly action: Action;\n\n /**\n * The current location. This value is mutable.\n */\n readonly location: Location;\n\n /**\n * Returns a valid href for the given `to` value that may be used as\n * the value of an <a href> attribute.\n *\n * @param to - The destination URL\n */\n createHref(to: To): string;\n\n /**\n * Returns a URL for the given `to` value\n *\n * @param to - The destination URL\n */\n createURL(to: To): URL;\n\n /**\n * Encode a location the same way window.history would do (no-op for memory\n * history) so we ensure our PUSH/REPLACE navigations for data routers\n * behave the same as POP\n *\n * @param to Unencoded path\n */\n encodeLocation(to: To): Path;\n\n /**\n * Pushes a new location onto the history stack, increasing its length by one.\n * If there were any entries in the stack after the current one, they are\n * lost.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n push(to: To, state?: any): void;\n\n /**\n * Replaces the current location in the history stack with a new one. The\n * location that was replaced will no longer be available.\n *\n * @param to - The new URL\n * @param state - Data to associate with the new location\n */\n replace(to: To, state?: any): void;\n\n /**\n * Navigates `n` entries backward/forward in the history stack relative to the\n * current index. For example, a \"back\" navigation would use go(-1).\n *\n * @param delta - The delta in the stack index\n */\n go(delta: number): void;\n\n /**\n * Sets up a listener that will be called whenever the current location\n * changes.\n *\n * @param listener - A function that will be called when the location changes\n * @returns unlisten - A function that may be used to stop listening\n */\n listen(listener: Listener): () => void;\n}\n\ntype HistoryState = {\n usr: any;\n key?: string;\n idx: number;\n};\n\nconst PopStateEventType = \"popstate\";\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Memory History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A user-supplied object that describes a location. Used when providing\n * entries to `createMemoryHistory` via its `initialEntries` option.\n */\nexport type InitialEntry = string | Partial<Location>;\n\nexport type MemoryHistoryOptions = {\n initialEntries?: InitialEntry[];\n initialIndex?: number;\n v5Compat?: boolean;\n};\n\n/**\n * A memory history stores locations in memory. This is useful in stateful\n * environments where there is no web browser, such as node tests or React\n * Native.\n */\nexport interface MemoryHistory extends History {\n /**\n * The current index in the history stack.\n */\n readonly index: number;\n}\n\n/**\n * Memory history stores the current location in memory. It is designed for use\n * in stateful non-browser environments like tests and React Native.\n */\nexport function createMemoryHistory(\n options: MemoryHistoryOptions = {}\n): MemoryHistory {\n let { initialEntries = [\"/\"], initialIndex, v5Compat = false } = options;\n let entries: Location[]; // Declare so we can access from createMemoryLocation\n entries = initialEntries.map((entry, index) =>\n createMemoryLocation(\n entry,\n typeof entry === \"string\" ? null : entry.state,\n index === 0 ? \"default\" : undefined\n )\n );\n let index = clampIndex(\n initialIndex == null ? entries.length - 1 : initialIndex\n );\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n function clampIndex(n: number): number {\n return Math.min(Math.max(n, 0), entries.length - 1);\n }\n function getCurrentLocation(): Location {\n return entries[index];\n }\n function createMemoryLocation(\n to: To,\n state: any = null,\n key?: string\n ): Location {\n let location = createLocation(\n entries ? getCurrentLocation().pathname : \"/\",\n to,\n state,\n key\n );\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in memory history: ${JSON.stringify(\n to\n )}`\n );\n return location;\n }\n\n function createHref(to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n let history: MemoryHistory = {\n get index() {\n return index;\n },\n get action() {\n return action;\n },\n get location() {\n return getCurrentLocation();\n },\n createHref,\n createURL(to) {\n return new URL(createHref(to), \"http://localhost\");\n },\n encodeLocation(to: To) {\n let path = typeof to === \"string\" ? parsePath(to) : to;\n return {\n pathname: path.pathname || \"\",\n search: path.search || \"\",\n hash: path.hash || \"\",\n };\n },\n push(to, state) {\n action = Action.Push;\n let nextLocation = createMemoryLocation(to, state);\n index += 1;\n entries.splice(index, entries.length, nextLocation);\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 1 });\n }\n },\n replace(to, state) {\n action = Action.Replace;\n let nextLocation = createMemoryLocation(to, state);\n entries[index] = nextLocation;\n if (v5Compat && listener) {\n listener({ action, location: nextLocation, delta: 0 });\n }\n },\n go(delta) {\n action = Action.Pop;\n let nextIndex = clampIndex(index + delta);\n let nextLocation = entries[nextIndex];\n index = nextIndex;\n if (listener) {\n listener({ action, location: nextLocation, delta });\n }\n },\n listen(fn: Listener) {\n listener = fn;\n return () => {\n listener = null;\n };\n },\n };\n\n return history;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Browser History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A browser history stores the current location in regular URLs in a web\n * browser environment. This is the standard for most web apps and provides the\n * cleanest URLs the browser's address bar.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#browserhistory\n */\nexport interface BrowserHistory extends UrlHistory {}\n\nexport type BrowserHistoryOptions = UrlHistoryOptions;\n\n/**\n * Browser history stores the location in regular URLs. This is the standard for\n * most web apps, but it requires some configuration on the server to ensure you\n * serve the same app at multiple URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createbrowserhistory\n */\nexport function createBrowserHistory(\n options: BrowserHistoryOptions = {}\n): BrowserHistory {\n function createBrowserLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let { pathname, search, hash } = window.location;\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createBrowserHref(window: Window, to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n }\n\n return getUrlBasedHistory(\n createBrowserLocation,\n createBrowserHref,\n null,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Hash History\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A hash history stores the current location in the fragment identifier portion\n * of the URL in a web browser environment.\n *\n * This is ideal for apps that do not control the server for some reason\n * (because the fragment identifier is never sent to the server), including some\n * shared hosting environments that do not provide fine-grained controls over\n * which pages are served at which URLs.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#hashhistory\n */\nexport interface HashHistory extends UrlHistory {}\n\nexport type HashHistoryOptions = UrlHistoryOptions;\n\n/**\n * Hash history stores the location in window.location.hash. This makes it ideal\n * for situations where you don't want to send the location to the server for\n * some reason, either because you do cannot configure it or the URL space is\n * reserved for something else.\n *\n * @see https://github.com/remix-run/history/tree/main/docs/api-reference.md#createhashhistory\n */\nexport function createHashHistory(\n options: HashHistoryOptions = {}\n): HashHistory {\n function createHashLocation(\n window: Window,\n globalHistory: Window[\"history\"]\n ) {\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n } = parsePath(window.location.hash.substr(1));\n return createLocation(\n \"\",\n { pathname, search, hash },\n // state defaults to `null` because `window.history.state` does\n (globalHistory.state && globalHistory.state.usr) || null,\n (globalHistory.state && globalHistory.state.key) || \"default\"\n );\n }\n\n function createHashHref(window: Window, to: To) {\n let base = window.document.querySelector(\"base\");\n let href = \"\";\n\n if (base && base.getAttribute(\"href\")) {\n let url = window.location.href;\n let hashIndex = url.indexOf(\"#\");\n href = hashIndex === -1 ? url : url.slice(0, hashIndex);\n }\n\n return href + \"#\" + (typeof to === \"string\" ? to : createPath(to));\n }\n\n function validateHashLocation(location: Location, to: To) {\n warning(\n location.pathname.charAt(0) === \"/\",\n `relative pathnames are not supported in hash history.push(${JSON.stringify(\n to\n )})`\n );\n }\n\n return getUrlBasedHistory(\n createHashLocation,\n createHashHref,\n validateHashLocation,\n options\n );\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region UTILS\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * @private\n */\nexport function invariant(value: boolean, message?: string): asserts value;\nexport function invariant<T>(\n value: T | null | undefined,\n message?: string\n): asserts value is T;\nexport function invariant(value: any, message?: string) {\n if (value === false || value === null || typeof value === \"undefined\") {\n throw new Error(message);\n }\n}\n\nexport function warning(cond: any, message: string) {\n if (!cond) {\n // eslint-disable-next-line no-console\n if (typeof console !== \"undefined\") console.warn(message);\n\n try {\n // Welcome to debugging history!\n //\n // This error is thrown as a convenience so you can more easily\n // find the source for a warning that appears in the console by\n // enabling \"pause on exceptions\" in your JavaScript debugger.\n throw new Error(message);\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n}\n\nfunction createKey() {\n return Math.random().toString(36).substr(2, 8);\n}\n\n/**\n * For browser-based histories, we combine the state and key into an object\n */\nfunction getHistoryState(location: Location, index: number): HistoryState {\n return {\n usr: location.state,\n key: location.key,\n idx: index,\n };\n}\n\n/**\n * Creates a Location object with a unique key from the given Path\n */\nexport function createLocation(\n current: string | Location,\n to: To,\n state: any = null,\n key?: string\n): Readonly<Location> {\n let location: Readonly<Location> = {\n pathname: typeof current === \"string\" ? current : current.pathname,\n search: \"\",\n hash: \"\",\n ...(typeof to === \"string\" ? parsePath(to) : to),\n state,\n // TODO: This could be cleaned up. push/replace should probably just take\n // full Locations now and avoid the need to run through this flow at all\n // But that's a pretty big refactor to the current test suite so going to\n // keep as is for the time being and just let any incoming keys take precedence\n key: (to && (to as Location).key) || key || createKey(),\n };\n return location;\n}\n\n/**\n * Creates a string URL path from the given pathname, search, and hash components.\n */\nexport function createPath({\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n}: Partial<Path>) {\n if (search && search !== \"?\")\n pathname += search.charAt(0) === \"?\" ? search : \"?\" + search;\n if (hash && hash !== \"#\")\n pathname += hash.charAt(0) === \"#\" ? hash : \"#\" + hash;\n return pathname;\n}\n\n/**\n * Parses a string URL path into its separate pathname, search, and hash components.\n */\nexport function parsePath(path: string): Partial<Path> {\n let parsedPath: Partial<Path> = {};\n\n if (path) {\n let hashIndex = path.indexOf(\"#\");\n if (hashIndex >= 0) {\n parsedPath.hash = path.substr(hashIndex);\n path = path.substr(0, hashIndex);\n }\n\n let searchIndex = path.indexOf(\"?\");\n if (searchIndex >= 0) {\n parsedPath.search = path.substr(searchIndex);\n path = path.substr(0, searchIndex);\n }\n\n if (path) {\n parsedPath.pathname = path;\n }\n }\n\n return parsedPath;\n}\n\nexport interface UrlHistory extends History {}\n\nexport type UrlHistoryOptions = {\n window?: Window;\n v5Compat?: boolean;\n};\n\nfunction getUrlBasedHistory(\n getLocation: (window: Window, globalHistory: Window[\"history\"]) => Location,\n createHref: (window: Window, to: To) => string,\n validateLocation: ((location: Location, to: To) => void) | null,\n options: UrlHistoryOptions = {}\n): UrlHistory {\n let { window = document.defaultView!, v5Compat = false } = options;\n let globalHistory = window.history;\n let action = Action.Pop;\n let listener: Listener | null = null;\n\n let index = getIndex()!;\n // Index should only be null when we initialize. If not, it's because the\n // user called history.pushState or history.replaceState directly, in which\n // case we should log a warning as it will result in bugs.\n if (index == null) {\n index = 0;\n globalHistory.replaceState({ ...globalHistory.state, idx: index }, \"\");\n }\n\n function getIndex(): number {\n let state = globalHistory.state || { idx: null };\n return state.idx;\n }\n\n function handlePop() {\n action = Action.Pop;\n let nextIndex = getIndex();\n let delta = nextIndex == null ? null : nextIndex - index;\n index = nextIndex;\n if (listener) {\n listener({ action, location: history.location, delta });\n }\n }\n\n function push(to: To, state?: any) {\n action = Action.Push;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex() + 1;\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n\n // try...catch because iOS limits us to 100 pushState calls :/\n try {\n globalHistory.pushState(historyState, \"\", url);\n } catch (error) {\n // They are going to lose state here, but there is no real\n // way to warn them about it since the page will refresh...\n window.location.assign(url);\n }\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 1 });\n }\n }\n\n function replace(to: To, state?: any) {\n action = Action.Replace;\n let location = createLocation(history.location, to, state);\n if (validateLocation) validateLocation(location, to);\n\n index = getIndex();\n let historyState = getHistoryState(location, index);\n let url = history.createHref(location);\n globalHistory.replaceState(historyState, \"\", url);\n\n if (v5Compat && listener) {\n listener({ action, location: history.location, delta: 0 });\n }\n }\n\n function createURL(to: To): URL {\n // window.location.origin is \"null\" (the literal string value) in Firefox\n // under certain conditions, notably when serving from a local HTML file\n // See https://bugzilla.mozilla.org/show_bug.cgi?id=878297\n let base =\n window.location.origin !== \"null\"\n ? window.location.origin\n : window.location.href;\n\n let href = typeof to === \"string\" ? to : createPath(to);\n invariant(\n base,\n `No window.location.(origin|href) available to create URL for href: ${href}`\n );\n return new URL(href, base);\n }\n\n let history: History = {\n get action() {\n return action;\n },\n get location() {\n return getLocation(window, globalHistory);\n },\n listen(fn: Listener) {\n if (listener) {\n throw new Error(\"A history only accepts one active listener\");\n }\n window.addEventListener(PopStateEventType, handlePop);\n listener = fn;\n\n return () => {\n window.removeEventListener(PopStateEventType, handlePop);\n listener = null;\n };\n },\n createHref(to) {\n return createHref(window, to);\n },\n createURL,\n encodeLocation(to) {\n // Encode a Location the same way window.location would\n let url = createURL(to);\n return {\n pathname: url.pathname,\n search: url.search,\n hash: url.hash,\n };\n },\n push,\n replace,\n go(n) {\n return globalHistory.go(n);\n },\n };\n\n return history;\n}\n\n//#endregion\n","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","export default function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n\n return assertThisInitialized(self);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nimport possibleConstructorReturn from \"./possibleConstructorReturn.js\";\nexport default function _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n\n return possibleConstructorReturn(this, result);\n };\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nexport default function _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n _construct = Reflect.construct.bind();\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n\n return _construct.apply(null, arguments);\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport setPrototypeOf from \"./setPrototypeOf.js\";\nimport isNativeFunction from \"./isNativeFunction.js\";\nimport construct from \"./construct.js\";\nexport default function _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n\n _cache.set(Class, Wrapper);\n }\n\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n };\n\n return _wrapNativeSuper(Class);\n}","export default function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}","import unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nexport default function _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n\n if (!it) {\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n\n var F = function F() {};\n\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it[\"return\"] != null) it[\"return\"]();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}","import type { Location, Path, To } from \"./history\";\nimport { warning, invariant, parsePath } from \"./history\";\n\n/**\n * Map of routeId -> data returned from a loader/action/error\n */\nexport interface RouteData {\n [routeId: string]: any;\n}\n\nexport enum ResultType {\n data = \"data\",\n deferred = \"deferred\",\n redirect = \"redirect\",\n error = \"error\",\n}\n\n/**\n * Successful result from a loader or action\n */\nexport interface SuccessResult {\n type: ResultType.data;\n data: any;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Successful defer() result from a loader or action\n */\nexport interface DeferredResult {\n type: ResultType.deferred;\n deferredData: DeferredData;\n statusCode?: number;\n headers?: Headers;\n}\n\n/**\n * Redirect result from a loader or action\n */\nexport interface RedirectResult {\n type: ResultType.redirect;\n status: number;\n location: string;\n revalidate: boolean;\n}\n\n/**\n * Unsuccessful result from a loader or action\n */\nexport interface ErrorResult {\n type: ResultType.error;\n error: any;\n headers?: Headers;\n}\n\n/**\n * Result from a loader or action - potentially successful or unsuccessful\n */\nexport type DataResult =\n | SuccessResult\n | DeferredResult\n | RedirectResult\n | ErrorResult;\n\ntype LowerCaseFormMethod = \"get\" | \"post\" | \"put\" | \"patch\" | \"delete\";\ntype UpperCaseFormMethod = Uppercase<LowerCaseFormMethod>;\n\n/**\n * Users can specify either lowercase or uppercase form methods on <Form>,\n * useSubmit(), <fetcher.Form>, etc.\n */\nexport type HTMLFormMethod = LowerCaseFormMethod | UpperCaseFormMethod;\n\n/**\n * Active navigation/fetcher form methods are exposed in lowercase on the\n * RouterState\n */\nexport type FormMethod = LowerCaseFormMethod;\nexport type MutationFormMethod = Exclude<FormMethod, \"get\">;\n\n/**\n * In v7, active navigation/fetcher form methods are exposed in uppercase on the\n * RouterState. This is to align with the normalization done via fetch().\n */\nexport type V7_FormMethod = UpperCaseFormMethod;\nexport type V7_MutationFormMethod = Exclude<V7_FormMethod, \"GET\">;\n\nexport type FormEncType =\n | \"application/x-www-form-urlencoded\"\n | \"multipart/form-data\";\n\n/**\n * @private\n * Internal interface to pass around for action submissions, not intended for\n * external consumption\n */\nexport interface Submission {\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: FormData;\n}\n\n/**\n * @private\n * Arguments passed to route loader/action functions. Same for now but we keep\n * this as a private implementation detail in case they diverge in the future.\n */\ninterface DataFunctionArgs {\n request: Request;\n params: Params;\n context?: any;\n}\n\n/**\n * Arguments passed to loader functions\n */\nexport interface LoaderFunctionArgs extends DataFunctionArgs {}\n\n/**\n * Arguments passed to action functions\n */\nexport interface ActionFunctionArgs extends DataFunctionArgs {}\n\n/**\n * Loaders and actions can return anything except `undefined` (`null` is a\n * valid return value if there is no data to return). Responses are preferred\n * and will ease any future migration to Remix\n */\ntype DataFunctionValue = Response | NonNullable<unknown> | null;\n\n/**\n * Route loader function signature\n */\nexport interface LoaderFunction {\n (args: LoaderFunctionArgs): Promise<DataFunctionValue> | DataFunctionValue;\n}\n\n/**\n * Route action function signature\n */\nexport interface ActionFunction {\n (args: ActionFunctionArgs): Promise<DataFunctionValue> | DataFunctionValue;\n}\n\n/**\n * Route shouldRevalidate function signature. This runs after any submission\n * (navigation or fetcher), so we flatten the navigation/fetcher submission\n * onto the arguments. It shouldn't matter whether it came from a navigation\n * or a fetcher, what really matters is the URLs and the formData since loaders\n * have to re-run based on the data models that were potentially mutated.\n */\nexport interface ShouldRevalidateFunction {\n (args: {\n currentUrl: URL;\n currentParams: AgnosticDataRouteMatch[\"params\"];\n nextUrl: URL;\n nextParams: AgnosticDataRouteMatch[\"params\"];\n formMethod?: Submission[\"formMethod\"];\n formAction?: Submission[\"formAction\"];\n formEncType?: Submission[\"formEncType\"];\n formData?: Submission[\"formData\"];\n actionResult?: DataResult;\n defaultShouldRevalidate: boolean;\n }): boolean;\n}\n\n/**\n * Function provided by the framework-aware layers to set `hasErrorBoundary`\n * from the framework-aware `errorElement` prop\n *\n * @deprecated Use `mapRouteProperties` instead\n */\nexport interface DetectErrorBoundaryFunction {\n (route: AgnosticRouteObject): boolean;\n}\n\n/**\n * Function provided by the framework-aware layers to set any framework-specific\n * properties from framework-agnostic properties\n */\nexport interface MapRoutePropertiesFunction {\n (route: AgnosticRouteObject): {\n hasErrorBoundary: boolean;\n } & Record<string, any>;\n}\n\n/**\n * Keys we cannot change from within a lazy() function. We spread all other keys\n * onto the route. Either they're meaningful to the router, or they'll get\n * ignored.\n */\nexport type ImmutableRouteKey =\n | \"lazy\"\n | \"caseSensitive\"\n | \"path\"\n | \"id\"\n | \"index\"\n | \"children\";\n\nexport const immutableRouteKeys = new Set<ImmutableRouteKey>([\n \"lazy\",\n \"caseSensitive\",\n \"path\",\n \"id\",\n \"index\",\n \"children\",\n]);\n\n/**\n * lazy() function to load a route definition, which can add non-matching\n * related properties to a route\n */\nexport interface LazyRouteFunction<R extends AgnosticRouteObject> {\n (): Promise<Omit<R, ImmutableRouteKey>>;\n}\n\n/**\n * Base RouteObject with common props shared by all types of routes\n */\ntype AgnosticBaseRouteObject = {\n caseSensitive?: boolean;\n path?: string;\n id?: string;\n loader?: LoaderFunction;\n action?: ActionFunction;\n hasErrorBoundary?: boolean;\n shouldRevalidate?: ShouldRevalidateFunction;\n handle?: any;\n lazy?: LazyRouteFunction<AgnosticBaseRouteObject>;\n};\n\n/**\n * Index routes must not have children\n */\nexport type AgnosticIndexRouteObject = AgnosticBaseRouteObject & {\n children?: undefined;\n index: true;\n};\n\n/**\n * Non-index routes may have children, but cannot have index\n */\nexport type AgnosticNonIndexRouteObject = AgnosticBaseRouteObject & {\n children?: AgnosticRouteObject[];\n index?: false;\n};\n\n/**\n * A route object represents a logical route, with (optionally) its child\n * routes organized in a tree-like structure.\n */\nexport type AgnosticRouteObject =\n | AgnosticIndexRouteObject\n | AgnosticNonIndexRouteObject;\n\nexport type AgnosticDataIndexRouteObject = AgnosticIndexRouteObject & {\n id: string;\n};\n\nexport type AgnosticDataNonIndexRouteObject = AgnosticNonIndexRouteObject & {\n children?: AgnosticDataRouteObject[];\n id: string;\n};\n\n/**\n * A data route object, which is just a RouteObject with a required unique ID\n */\nexport type AgnosticDataRouteObject =\n | AgnosticDataIndexRouteObject\n | AgnosticDataNonIndexRouteObject;\n\nexport type RouteManifest = Record<string, AgnosticDataRouteObject | undefined>;\n\n// Recursive helper for finding path parameters in the absence of wildcards\ntype _PathParam<Path extends string> =\n // split path into individual path segments\n Path extends `${infer L}/${infer R}`\n ? _PathParam<L> | _PathParam<R>\n : // find params after `:`\n Path extends `:${infer Param}`\n ? Param extends `${infer Optional}?`\n ? Optional\n : Param\n : // otherwise, there aren't any params present\n never;\n\n/**\n * Examples:\n * \"/a/b/*\" -> \"*\"\n * \":a\" -> \"a\"\n * \"/a/:b\" -> \"b\"\n * \"/a/blahblahblah:b\" -> \"b\"\n * \"/:a/:b\" -> \"a\" | \"b\"\n * \"/:a/b/:c/*\" -> \"a\" | \"c\" | \"*\"\n */\ntype PathParam<Path extends string> =\n // check if path is just a wildcard\n Path extends \"*\" | \"/*\"\n ? \"*\"\n : // look for wildcard at the end of the path\n Path extends `${infer Rest}/*`\n ? \"*\" | _PathParam<Rest>\n : // look for params in the absence of wildcards\n _PathParam<Path>;\n\n// Attempt to parse the given string segment. If it fails, then just return the\n// plain string type as a default fallback. Otherwise return the union of the\n// parsed string literals that were referenced as dynamic segments in the route.\nexport type ParamParseKey<Segment extends string> =\n // if could not find path params, fallback to `string`\n [PathParam<Segment>] extends [never] ? string : PathParam<Segment>;\n\n/**\n * The parameters that were parsed from the URL path.\n */\nexport type Params<Key extends string = string> = {\n readonly [key in Key]: string | undefined;\n};\n\n/**\n * A RouteMatch contains info about how a route matched a URL.\n */\nexport interface AgnosticRouteMatch<\n ParamKey extends string = string,\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n /**\n * The names and values of dynamic parameters in the URL.\n */\n params: Params<ParamKey>;\n /**\n * The portion of the URL pathname that was matched.\n */\n pathname: string;\n /**\n * The portion of the URL pathname that was matched before child routes.\n */\n pathnameBase: string;\n /**\n * The route object that was used to match.\n */\n route: RouteObjectType;\n}\n\nexport interface AgnosticDataRouteMatch\n extends AgnosticRouteMatch<string, AgnosticDataRouteObject> {}\n\nfunction isIndexRoute(\n route: AgnosticRouteObject\n): route is AgnosticIndexRouteObject {\n return route.index === true;\n}\n\n// Walk the route tree generating unique IDs where necessary so we are working\n// solely with AgnosticDataRouteObject's within the Router\nexport function convertRoutesToDataRoutes(\n routes: AgnosticRouteObject[],\n mapRouteProperties: MapRoutePropertiesFunction,\n parentPath: number[] = [],\n manifest: RouteManifest = {}\n): AgnosticDataRouteObject[] {\n return routes.map((route, index) => {\n let treePath = [...parentPath, index];\n let id = typeof route.id === \"string\" ? route.id : treePath.join(\"-\");\n invariant(\n route.index !== true || !route.children,\n `Cannot specify children on an index route`\n );\n invariant(\n !manifest[id],\n `Found a route id collision on id \"${id}\". Route ` +\n \"id's must be globally unique within Data Router usages\"\n );\n\n if (isIndexRoute(route)) {\n let indexRoute: AgnosticDataIndexRouteObject = {\n ...route,\n ...mapRouteProperties(route),\n id,\n };\n manifest[id] = indexRoute;\n return indexRoute;\n } else {\n let pathOrLayoutRoute: AgnosticDataNonIndexRouteObject = {\n ...route,\n ...mapRouteProperties(route),\n id,\n children: undefined,\n };\n manifest[id] = pathOrLayoutRoute;\n\n if (route.children) {\n pathOrLayoutRoute.children = convertRoutesToDataRoutes(\n route.children,\n mapRouteProperties,\n treePath,\n manifest\n );\n }\n\n return pathOrLayoutRoute;\n }\n });\n}\n\n/**\n * Matches the given routes to a location and returns the match data.\n *\n * @see https://reactrouter.com/utils/match-routes\n */\nexport function matchRoutes<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n routes: RouteObjectType[],\n locationArg: Partial<Location> | string,\n basename = \"/\"\n): AgnosticRouteMatch<string, RouteObjectType>[] | null {\n let location =\n typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n\n let pathname = stripBasename(location.pathname || \"/\", basename);\n\n if (pathname == null) {\n return null;\n }\n\n let branches = flattenRoutes(routes);\n rankRouteBranches(branches);\n\n let matches = null;\n for (let i = 0; matches == null && i < branches.length; ++i) {\n matches = matchRouteBranch<string, RouteObjectType>(\n branches[i],\n // Incoming pathnames are generally encoded from either window.location\n // or from router.navigate, but we want to match against the unencoded\n // paths in the route definitions. Memory router locations won't be\n // encoded here but there also shouldn't be anything to decode so this\n // should be a safe operation. This avoids needing matchRoutes to be\n // history-aware.\n safelyDecodeURI(pathname)\n );\n }\n\n return matches;\n}\n\ninterface RouteMeta<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n relativePath: string;\n caseSensitive: boolean;\n childrenIndex: number;\n route: RouteObjectType;\n}\n\ninterface RouteBranch<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n> {\n path: string;\n score: number;\n routesMeta: RouteMeta<RouteObjectType>[];\n}\n\nfunction flattenRoutes<\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n routes: RouteObjectType[],\n branches: RouteBranch<RouteObjectType>[] = [],\n parentsMeta: RouteMeta<RouteObjectType>[] = [],\n parentPath = \"\"\n): RouteBranch<RouteObjectType>[] {\n let flattenRoute = (\n route: RouteObjectType,\n index: number,\n relativePath?: string\n ) => {\n let meta: RouteMeta<RouteObjectType> = {\n relativePath:\n relativePath === undefined ? route.path || \"\" : relativePath,\n caseSensitive: route.caseSensitive === true,\n childrenIndex: index,\n route,\n };\n\n if (meta.relativePath.startsWith(\"/\")) {\n invariant(\n meta.relativePath.startsWith(parentPath),\n `Absolute route path \"${meta.relativePath}\" nested under path ` +\n `\"${parentPath}\" is not valid. An absolute child route path ` +\n `must start with the combined path of all its parent routes.`\n );\n\n meta.relativePath = meta.relativePath.slice(parentPath.length);\n }\n\n let path = joinPaths([parentPath, meta.relativePath]);\n let routesMeta = parentsMeta.concat(meta);\n\n // Add the children before adding this route to the array so we traverse the\n // route tree depth-first and child routes appear before their parents in\n // the \"flattened\" version.\n if (route.children && route.children.length > 0) {\n invariant(\n // Our types know better, but runtime JS may not!\n // @ts-expect-error\n route.index !== true,\n `Index routes must not have child routes. Please remove ` +\n `all child routes from route path \"${path}\".`\n );\n\n flattenRoutes(route.children, branches, routesMeta, path);\n }\n\n // Routes without a path shouldn't ever match by themselves unless they are\n // index routes, so don't add them to the list of possible branches.\n if (route.path == null && !route.index) {\n return;\n }\n\n branches.push({\n path,\n score: computeScore(path, route.index),\n routesMeta,\n });\n };\n routes.forEach((route, index) => {\n // coarse-grain check for optional params\n if (route.path === \"\" || !route.path?.includes(\"?\")) {\n flattenRoute(route, index);\n } else {\n for (let exploded of explodeOptionalSegments(route.path)) {\n flattenRoute(route, index, exploded);\n }\n }\n });\n\n return branches;\n}\n\n/**\n * Computes all combinations of optional path segments for a given path,\n * excluding combinations that are ambiguous and of lower priority.\n *\n * For example, `/one/:two?/three/:four?/:five?` explodes to:\n * - `/one/three`\n * - `/one/:two/three`\n * - `/one/three/:four`\n * - `/one/three/:five`\n * - `/one/:two/three/:four`\n * - `/one/:two/three/:five`\n * - `/one/three/:four/:five`\n * - `/one/:two/three/:four/:five`\n */\nfunction explodeOptionalSegments(path: string): string[] {\n let segments = path.split(\"/\");\n if (segments.length === 0) return [];\n\n let [first, ...rest] = segments;\n\n // Optional path segments are denoted by a trailing `?`\n let isOptional = first.endsWith(\"?\");\n // Compute the corresponding required segment: `foo?` -> `foo`\n let required = first.replace(/\\?$/, \"\");\n\n if (rest.length === 0) {\n // Intepret empty string as omitting an optional segment\n // `[\"one\", \"\", \"three\"]` corresponds to omitting `:two` from `/one/:two?/three` -> `/one/three`\n return isOptional ? [required, \"\"] : [required];\n }\n\n let restExploded = explodeOptionalSegments(rest.join(\"/\"));\n\n let result: string[] = [];\n\n // All child paths with the prefix. Do this for all children before the\n // optional version for all children so we get consistent ordering where the\n // parent optional aspect is preferred as required. Otherwise, we can get\n // child sections interspersed where deeper optional segments are higher than\n // parent optional segments, where for example, /:two would explodes _earlier_\n // then /:one. By always including the parent as required _for all children_\n // first, we avoid this issue\n result.push(\n ...restExploded.map((subpath) =>\n subpath === \"\" ? required : [required, subpath].join(\"/\")\n )\n );\n\n // Then if this is an optional value, add all child versions without\n if (isOptional) {\n result.push(...restExploded);\n }\n\n // for absolute paths, ensure `/` instead of empty segment\n return result.map((exploded) =>\n path.startsWith(\"/\") && exploded === \"\" ? \"/\" : exploded\n );\n}\n\nfunction rankRouteBranches(branches: RouteBranch[]): void {\n branches.sort((a, b) =>\n a.score !== b.score\n ? b.score - a.score // Higher score first\n : compareIndexes(\n a.routesMeta.map((meta) => meta.childrenIndex),\n b.routesMeta.map((meta) => meta.childrenIndex)\n )\n );\n}\n\nconst paramRe = /^:\\w+$/;\nconst dynamicSegmentValue = 3;\nconst indexRouteValue = 2;\nconst emptySegmentValue = 1;\nconst staticSegmentValue = 10;\nconst splatPenalty = -2;\nconst isSplat = (s: string) => s === \"*\";\n\nfunction computeScore(path: string, index: boolean | undefined): number {\n let segments = path.split(\"/\");\n let initialScore = segments.length;\n if (segments.some(isSplat)) {\n initialScore += splatPenalty;\n }\n\n if (index) {\n initialScore += indexRouteValue;\n }\n\n return segments\n .filter((s) => !isSplat(s))\n .reduce(\n (score, segment) =>\n score +\n (paramRe.test(segment)\n ? dynamicSegmentValue\n : segment === \"\"\n ? emptySegmentValue\n : staticSegmentValue),\n initialScore\n );\n}\n\nfunction compareIndexes(a: number[], b: number[]): number {\n let siblings =\n a.length === b.length && a.slice(0, -1).every((n, i) => n === b[i]);\n\n return siblings\n ? // If two routes are siblings, we should try to match the earlier sibling\n // first. This allows people to have fine-grained control over the matching\n // behavior by simply putting routes with identical paths in the order they\n // want them tried.\n a[a.length - 1] - b[b.length - 1]\n : // Otherwise, it doesn't really make sense to rank non-siblings by index,\n // so they sort equally.\n 0;\n}\n\nfunction matchRouteBranch<\n ParamKey extends string = string,\n RouteObjectType extends AgnosticRouteObject = AgnosticRouteObject\n>(\n branch: RouteBranch<RouteObjectType>,\n pathname: string\n): AgnosticRouteMatch<ParamKey, RouteObjectType>[] | null {\n let { routesMeta } = branch;\n\n let matchedParams = {};\n let matchedPathname = \"/\";\n let matches: AgnosticRouteMatch<ParamKey, RouteObjectType>[] = [];\n for (let i = 0; i < routesMeta.length; ++i) {\n let meta = routesMeta[i];\n let end = i === routesMeta.length - 1;\n let remainingPathname =\n matchedPathname === \"/\"\n ? pathname\n : pathname.slice(matchedPathname.length) || \"/\";\n let match = matchPath(\n { path: meta.relativePath, caseSensitive: meta.caseSensitive, end },\n remainingPathname\n );\n\n if (!match) return null;\n\n Object.assign(matchedParams, match.params);\n\n let route = meta.route;\n\n matches.push({\n // TODO: Can this as be avoided?\n params: matchedParams as Params<ParamKey>,\n pathname: joinPaths([matchedPathname, match.pathname]),\n pathnameBase: normalizePathname(\n joinPaths([matchedPathname, match.pathnameBase])\n ),\n route,\n });\n\n if (match.pathnameBase !== \"/\") {\n matchedPathname = joinPaths([matchedPathname, match.pathnameBase]);\n }\n }\n\n return matches;\n}\n\n/**\n * Returns a path with params interpolated.\n *\n * @see https://reactrouter.com/utils/generate-path\n */\nexport function generatePath<Path extends string>(\n originalPath: Path,\n params: {\n [key in PathParam<Path>]: string | null;\n } = {} as any\n): string {\n let path: string = originalPath;\n if (path.endsWith(\"*\") && path !== \"*\" && !path.endsWith(\"/*\")) {\n warning(\n false,\n `Route path \"${path}\" will be treated as if it were ` +\n `\"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must ` +\n `always follow a \\`/\\` in the pattern. To get rid of this warning, ` +\n `please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n );\n path = path.replace(/\\*$/, \"/*\") as Path;\n }\n\n // ensure `/` is added at the beginning if the path is absolute\n const prefix = path.startsWith(\"/\") ? \"/\" : \"\";\n\n const segments = path\n .split(/\\/+/)\n .map((segment, index, array) => {\n const isLastSegment = index === array.length - 1;\n\n // only apply the splat if it's the last segment\n if (isLastSegment && segment === \"*\") {\n const star = \"*\" as PathParam<Path>;\n const starParam = params[star];\n\n // Apply the splat\n return starParam;\n }\n\n const keyMatch = segment.match(/^:(\\w+)(\\??)$/);\n if (keyMatch) {\n const [, key, optional] = keyMatch;\n let param = params[key as PathParam<Path>];\n\n if (optional === \"?\") {\n return param == null ? \"\" : param;\n }\n\n if (param == null) {\n invariant(false, `Missing \":${key}\" param`);\n }\n\n return param;\n }\n\n // Remove any optional markers from optional static segments\n return segment.replace(/\\?$/g, \"\");\n })\n // Remove empty segments\n .filter((segment) => !!segment);\n\n return prefix + segments.join(\"/\");\n}\n\n/**\n * A PathPattern is used to match on some portion of a URL pathname.\n */\nexport interface PathPattern<Path extends string = string> {\n /**\n * A string to match against a URL pathname. May contain `:id`-style segments\n * to indicate placeholders for dynamic parameters. May also end with `/*` to\n * indicate matching the rest of the URL pathname.\n */\n path: Path;\n /**\n * Should be `true` if the static portions of the `path` should be matched in\n * the same case.\n */\n caseSensitive?: boolean;\n /**\n * Should be `true` if this pattern should match the entire URL pathname.\n */\n end?: boolean;\n}\n\n/**\n * A PathMatch contains info about how a PathPattern matched on a URL pathname.\n */\nexport interface PathMatch<ParamKey extends string = string> {\n /**\n * The names and values of dynamic parameters in the URL.\n */\n params: Params<ParamKey>;\n /**\n * The portion of the URL pathname that was matched.\n */\n pathname: string;\n /**\n * The portion of the URL pathname that was matched before child routes.\n */\n pathnameBase: string;\n /**\n * The pattern that was used to match.\n */\n pattern: PathPattern;\n}\n\ntype Mutable<T> = {\n -readonly [P in keyof T]: T[P];\n};\n\n/**\n * Performs pattern matching on a URL pathname and returns information about\n * the match.\n *\n * @see https://reactrouter.com/utils/match-path\n */\nexport function matchPath<\n ParamKey extends ParamParseKey<Path>,\n Path extends string\n>(\n pattern: PathPattern<Path> | Path,\n pathname: string\n): PathMatch<ParamKey> | null {\n if (typeof pattern === \"string\") {\n pattern = { path: pattern, caseSensitive: false, end: true };\n }\n\n let [matcher, paramNames] = compilePath(\n pattern.path,\n pattern.caseSensitive,\n pattern.end\n );\n\n let match = pathname.match(matcher);\n if (!match) return null;\n\n let matchedPathname = match[0];\n let pathnameBase = matchedPathname.replace(/(.)\\/+$/, \"$1\");\n let captureGroups = match.slice(1);\n let params: Params = paramNames.reduce<Mutable<Params>>(\n (memo, paramName, index) => {\n // We need to compute the pathnameBase here using the raw splat value\n // instead of using params[\"*\"] later because it will be decoded then\n if (paramName === \"*\") {\n let splatValue = captureGroups[index] || \"\";\n pathnameBase = matchedPathname\n .slice(0, matchedPathname.length - splatValue.length)\n .replace(/(.)\\/+$/, \"$1\");\n }\n\n memo[paramName] = safelyDecodeURIComponent(\n captureGroups[index] || \"\",\n paramName\n );\n return memo;\n },\n {}\n );\n\n return {\n params,\n pathname: matchedPathname,\n pathnameBase,\n pattern,\n };\n}\n\nfunction compilePath(\n path: string,\n caseSensitive = false,\n end = true\n): [RegExp, string[]] {\n warning(\n path === \"*\" || !path.endsWith(\"*\") || path.endsWith(\"/*\"),\n `Route path \"${path}\" will be treated as if it were ` +\n `\"${path.replace(/\\*$/, \"/*\")}\" because the \\`*\\` character must ` +\n `always follow a \\`/\\` in the pattern. To get rid of this warning, ` +\n `please change the route path to \"${path.replace(/\\*$/, \"/*\")}\".`\n );\n\n let paramNames: string[] = [];\n let regexpSource =\n \"^\" +\n path\n .replace(/\\/*\\*?$/, \"\") // Ignore trailing / and /*, we'll handle it below\n .replace(/^\\/*/, \"/\") // Make sure it has a leading /\n .replace(/[\\\\.*+^$?{}|()[\\]]/g, \"\\\\$&\") // Escape special regex chars\n .replace(/\\/:(\\w+)/g, (_: string, paramName: string) => {\n paramNames.push(paramName);\n return \"/([^\\\\/]+)\";\n });\n\n if (path.endsWith(\"*\")) {\n paramNames.push(\"*\");\n regexpSource +=\n path === \"*\" || path === \"/*\"\n ? \"(.*)$\" // Already matched the initial /, just match the rest\n : \"(?:\\\\/(.+)|\\\\/*)$\"; // Don't include the / in params[\"*\"]\n } else if (end) {\n // When matching to the end, ignore trailing slashes\n regexpSource += \"\\\\/*$\";\n } else if (path !== \"\" && path !== \"/\") {\n // If our path is non-empty and contains anything beyond an initial slash,\n // then we have _some_ form of path in our regex so we should expect to\n // match only if we find the end of this path segment. Look for an optional\n // non-captured trailing slash (to match a portion of the URL) or the end\n // of the path (if we've matched to the end). We used to do this with a\n // word boundary but that gives false positives on routes like\n // /user-preferences since `-` counts as a word boundary.\n regexpSource += \"(?:(?=\\\\/|$))\";\n } else {\n // Nothing to match for \"\" or \"/\"\n }\n\n let matcher = new RegExp(regexpSource, caseSensitive ? undefined : \"i\");\n\n return [matcher, paramNames];\n}\n\nfunction safelyDecodeURI(value: string) {\n try {\n return decodeURI(value);\n } catch (error) {\n warning(\n false,\n `The URL path \"${value}\" could not be decoded because it is is a ` +\n `malformed URL segment. This is probably due to a bad percent ` +\n `encoding (${error}).`\n );\n\n return value;\n }\n}\n\nfunction safelyDecodeURIComponent(value: string, paramName: string) {\n try {\n return decodeURIComponent(value);\n } catch (error) {\n warning(\n false,\n `The value for the URL param \"${paramName}\" will not be decoded because` +\n ` the string \"${value}\" is a malformed URL segment. This is probably` +\n ` due to a bad percent encoding (${error}).`\n );\n\n return value;\n }\n}\n\n/**\n * @private\n */\nexport function stripBasename(\n pathname: string,\n basename: string\n): string | null {\n if (basename === \"/\") return pathname;\n\n if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {\n return null;\n }\n\n // We want to leave trailing slash behavior in the user's control, so if they\n // specify a basename with a trailing slash, we should support it\n let startIndex = basename.endsWith(\"/\")\n ? basename.length - 1\n : basename.length;\n let nextChar = pathname.charAt(startIndex);\n if (nextChar && nextChar !== \"/\") {\n // pathname does not start with basename/\n return null;\n }\n\n return pathname.slice(startIndex) || \"/\";\n}\n\n/**\n * Returns a resolved path object relative to the given pathname.\n *\n * @see https://reactrouter.com/utils/resolve-path\n */\nexport function resolvePath(to: To, fromPathname = \"/\"): Path {\n let {\n pathname: toPathname,\n search = \"\",\n hash = \"\",\n } = typeof to === \"string\" ? parsePath(to) : to;\n\n let pathname = toPathname\n ? toPathname.startsWith(\"/\")\n ? toPathname\n : resolvePathname(toPathname, fromPathname)\n : fromPathname;\n\n return {\n pathname,\n search: normalizeSearch(search),\n hash: normalizeHash(hash),\n };\n}\n\nfunction resolvePathname(relativePath: string, fromPathname: string): string {\n let segments = fromPathname.replace(/\\/+$/, \"\").split(\"/\");\n let relativeSegments = relativePath.split(\"/\");\n\n relativeSegments.forEach((segment) => {\n if (segment === \"..\") {\n // Keep the root \"\" segment so the pathname starts at /\n if (segments.length > 1) segments.pop();\n } else if (segment !== \".\") {\n segments.push(segment);\n }\n });\n\n return segments.length > 1 ? segments.join(\"/\") : \"/\";\n}\n\nfunction getInvalidPathError(\n char: string,\n field: string,\n dest: string,\n path: Partial<Path>\n) {\n return (\n `Cannot include a '${char}' character in a manually specified ` +\n `\\`to.${field}\\` field [${JSON.stringify(\n path\n )}]. Please separate it out to the ` +\n `\\`to.${dest}\\` field. Alternatively you may provide the full path as ` +\n `a string in <Link to=\"...\"> and the router will parse it for you.`\n );\n}\n\n/**\n * @private\n *\n * When processing relative navigation we want to ignore ancestor routes that\n * do not contribute to the path, such that index/pathless layout routes don't\n * interfere.\n *\n * For example, when moving a route element into an index route and/or a\n * pathless layout route, relative link behavior contained within should stay\n * the same. Both of the following examples should link back to the root:\n *\n * <Route path=\"/\">\n * <Route path=\"accounts\" element={<Link to=\"..\"}>\n * </Route>\n *\n * <Route path=\"/\">\n * <Route path=\"accounts\">\n * <Route element={<AccountsLayout />}> // <-- Does not contribute\n * <Route index element={<Link to=\"..\"} /> // <-- Does not contribute\n * </Route\n * </Route>\n * </Route>\n */\nexport function getPathContributingMatches<\n T extends AgnosticRouteMatch = AgnosticRouteMatch\n>(matches: T[]) {\n return matches.filter(\n (match, index) =>\n index === 0 || (match.route.path && match.route.path.length > 0)\n );\n}\n\n/**\n * @private\n */\nexport function resolveTo(\n toArg: To,\n routePathnames: string[],\n locationPathname: string,\n isPathRelative = false\n): Path {\n let to: Partial<Path>;\n if (typeof toArg === \"string\") {\n to = parsePath(toArg);\n } else {\n to = { ...toArg };\n\n invariant(\n !to.pathname || !to.pathname.includes(\"?\"),\n getInvalidPathError(\"?\", \"pathname\", \"search\", to)\n );\n invariant(\n !to.pathname || !to.pathname.includes(\"#\"),\n getInvalidPathError(\"#\", \"pathname\", \"hash\", to)\n );\n invariant(\n !to.search || !to.search.includes(\"#\"),\n getInvalidPathError(\"#\", \"search\", \"hash\", to)\n );\n }\n\n let isEmptyPath = toArg === \"\" || to.pathname === \"\";\n let toPathname = isEmptyPath ? \"/\" : to.pathname;\n\n let from: string;\n\n // Routing is relative to the current pathname if explicitly requested.\n //\n // If a pathname is explicitly provided in `to`, it should be relative to the\n // route context. This is explained in `Note on `<Link to>` values` in our\n // migration guide from v5 as a means of disambiguation between `to` values\n // that begin with `/` and those that do not. However, this is problematic for\n // `to` values that do not provide a pathname. `to` can simply be a search or\n // hash string, in which case we should assume that the navigation is relative\n // to the current location's pathname and *not* the route pathname.\n if (isPathRelative || toPathname == null) {\n from = locationPathname;\n } else {\n let routePathnameIndex = routePathnames.length - 1;\n\n if (toPathname.startsWith(\"..\")) {\n let toSegments = toPathname.split(\"/\");\n\n // Each leading .. segment means \"go up one route\" instead of \"go up one\n // URL segment\". This is a key difference from how <a href> works and a\n // major reason we call this a \"to\" value instead of a \"href\".\n while (toSegments[0] === \"..\") {\n toSegments.shift();\n routePathnameIndex -= 1;\n }\n\n to.pathname = toSegments.join(\"/\");\n }\n\n // If there are more \"..\" segments than parent routes, resolve relative to\n // the root / URL.\n from = routePathnameIndex >= 0 ? routePathnames[routePathnameIndex] : \"/\";\n }\n\n let path = resolvePath(to, from);\n\n // Ensure the pathname has a trailing slash if the original \"to\" had one\n let hasExplicitTrailingSlash =\n toPathname && toPathname !== \"/\" && toPathname.endsWith(\"/\");\n // Or if this was a link to the current path which has a trailing slash\n let hasCurrentTrailingSlash =\n (isEmptyPath || toPathname === \".\") && locationPathname.endsWith(\"/\");\n if (\n !path.pathname.endsWith(\"/\") &&\n (hasExplicitTrailingSlash || hasCurrentTrailingSlash)\n ) {\n path.pathname += \"/\";\n }\n\n return path;\n}\n\n/**\n * @private\n */\nexport function getToPathname(to: To): string | undefined {\n // Empty strings should be treated the same as / paths\n return to === \"\" || (to as Path).pathname === \"\"\n ? \"/\"\n : typeof to === \"string\"\n ? parsePath(to).pathname\n : to.pathname;\n}\n\n/**\n * @private\n */\nexport const joinPaths = (paths: string[]): string =>\n paths.join(\"/\").replace(/\\/\\/+/g, \"/\");\n\n/**\n * @private\n */\nexport const normalizePathname = (pathname: string): string =>\n pathname.replace(/\\/+$/, \"\").replace(/^\\/*/, \"/\");\n\n/**\n * @private\n */\nexport const normalizeSearch = (search: string): string =>\n !search || search === \"?\"\n ? \"\"\n : search.startsWith(\"?\")\n ? search\n : \"?\" + search;\n\n/**\n * @private\n */\nexport const normalizeHash = (hash: string): string =>\n !hash || hash === \"#\" ? \"\" : hash.startsWith(\"#\") ? hash : \"#\" + hash;\n\nexport type JsonFunction = <Data>(\n data: Data,\n init?: number | ResponseInit\n) => Response;\n\n/**\n * This is a shortcut for creating `application/json` responses. Converts `data`\n * to JSON and sets the `Content-Type` header.\n */\nexport const json: JsonFunction = (data, init = {}) => {\n let responseInit = typeof init === \"number\" ? { status: init } : init;\n\n let headers = new Headers(responseInit.headers);\n if (!headers.has(\"Content-Type\")) {\n headers.set(\"Content-Type\", \"application/json; charset=utf-8\");\n }\n\n return new Response(JSON.stringify(data), {\n ...responseInit,\n headers,\n });\n};\n\nexport interface TrackedPromise extends Promise<any> {\n _tracked?: boolean;\n _data?: any;\n _error?: any;\n}\n\nexport class AbortedDeferredError extends Error {}\n\nexport class DeferredData {\n private pendingKeysSet: Set<string> = new Set<string>();\n private controller: AbortController;\n private abortPromise: Promise<void>;\n private unlistenAbortSignal: () => void;\n private subscribers: Set<(aborted: boolean, settledKey?: string) => void> =\n new Set();\n data: Record<string, unknown>;\n init?: ResponseInit;\n deferredKeys: string[] = [];\n\n constructor(data: Record<string, unknown>, responseInit?: ResponseInit) {\n invariant(\n data && typeof data === \"object\" && !Array.isArray(data),\n \"defer() only accepts plain objects\"\n );\n\n // Set up an AbortController + Promise we can race against to exit early\n // cancellation\n let reject: (e: AbortedDeferredError) => void;\n this.abortPromise = new Promise((_, r) => (reject = r));\n this.controller = new AbortController();\n let onAbort = () =>\n reject(new AbortedDeferredError(\"Deferred data aborted\"));\n this.unlistenAbortSignal = () =>\n this.controller.signal.removeEventListener(\"abort\", onAbort);\n this.controller.signal.addEventListener(\"abort\", onAbort);\n\n this.data = Object.entries(data).reduce(\n (acc, [key, value]) =>\n Object.assign(acc, {\n [key]: this.trackPromise(key, value),\n }),\n {}\n );\n\n if (this.done) {\n // All incoming values were resolved\n this.unlistenAbortSignal();\n }\n\n this.init = responseInit;\n }\n\n private trackPromise(\n key: string,\n value: Promise<unknown> | unknown\n ): TrackedPromise | unknown {\n if (!(value instanceof Promise)) {\n return value;\n }\n\n this.deferredKeys.push(key);\n this.pendingKeysSet.add(key);\n\n // We store a little wrapper promise that will be extended with\n // _data/_error props upon resolve/reject\n let promise: TrackedPromise = Promise.race([value, this.abortPromise]).then(\n (data) => this.onSettle(promise, key, null, data as unknown),\n (error) => this.onSettle(promise, key, error as unknown)\n );\n\n // Register rejection listeners to avoid uncaught promise rejections on\n // errors or aborted deferred values\n promise.catch(() => {});\n\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n return promise;\n }\n\n private onSettle(\n promise: TrackedPromise,\n key: string,\n error: unknown,\n data?: unknown\n ): unknown {\n if (\n this.controller.signal.aborted &&\n error instanceof AbortedDeferredError\n ) {\n this.unlistenAbortSignal();\n Object.defineProperty(promise, \"_error\", { get: () => error });\n return Promise.reject(error);\n }\n\n this.pendingKeysSet.delete(key);\n\n if (this.done) {\n // Nothing left to abort!\n this.unlistenAbortSignal();\n }\n\n if (error) {\n Object.defineProperty(promise, \"_error\", { get: () => error });\n this.emit(false, key);\n return Promise.reject(error);\n }\n\n Object.defineProperty(promise, \"_data\", { get: () => data });\n this.emit(false, key);\n return data;\n }\n\n private emit(aborted: boolean, settledKey?: string) {\n this.subscribers.forEach((subscriber) => subscriber(aborted, settledKey));\n }\n\n subscribe(fn: (aborted: boolean, settledKey?: string) => void) {\n this.subscribers.add(fn);\n return () => this.subscribers.delete(fn);\n }\n\n cancel() {\n this.controller.abort();\n this.pendingKeysSet.forEach((v, k) => this.pendingKeysSet.delete(k));\n this.emit(true);\n }\n\n async resolveData(signal: AbortSignal) {\n let aborted = false;\n if (!this.done) {\n let onAbort = () => this.cancel();\n signal.addEventListener(\"abort\", onAbort);\n aborted = await new Promise((resolve) => {\n this.subscribe((aborted) => {\n signal.removeEventListener(\"abort\", onAbort);\n if (aborted || this.done) {\n resolve(aborted);\n }\n });\n });\n }\n return aborted;\n }\n\n get done() {\n return this.pendingKeysSet.size === 0;\n }\n\n get unwrappedData() {\n invariant(\n this.data !== null && this.done,\n \"Can only unwrap data on initialized and settled deferreds\"\n );\n\n return Object.entries(this.data).reduce(\n (acc, [key, value]) =>\n Object.assign(acc, {\n [key]: unwrapTrackedPromise(value),\n }),\n {}\n );\n }\n\n get pendingKeys() {\n return Array.from(this.pendingKeysSet);\n }\n}\n\nfunction isTrackedPromise(value: any): value is TrackedPromise {\n return (\n value instanceof Promise && (value as TrackedPromise)._tracked === true\n );\n}\n\nfunction unwrapTrackedPromise(value: any) {\n if (!isTrackedPromise(value)) {\n return value;\n }\n\n if (value._error) {\n throw value._error;\n }\n return value._data;\n}\n\nexport type DeferFunction = (\n data: Record<string, unknown>,\n init?: number | ResponseInit\n) => DeferredData;\n\nexport const defer: DeferFunction = (data, init = {}) => {\n let responseInit = typeof init === \"number\" ? { status: init } : init;\n\n return new DeferredData(data, responseInit);\n};\n\nexport type RedirectFunction = (\n url: string,\n init?: number | ResponseInit\n) => Response;\n\n/**\n * A redirect response. Sets the status code and the `Location` header.\n * Defaults to \"302 Found\".\n */\nexport const redirect: RedirectFunction = (url, init = 302) => {\n let responseInit = init;\n if (typeof responseInit === \"number\") {\n responseInit = { status: responseInit };\n } else if (typeof responseInit.status === \"undefined\") {\n responseInit.status = 302;\n }\n\n let headers = new Headers(responseInit.headers);\n headers.set(\"Location\", url);\n\n return new Response(null, {\n ...responseInit,\n headers,\n });\n};\n\n/**\n * @private\n * Utility class we use to hold auto-unwrapped 4xx/5xx Response bodies\n */\nexport class ErrorResponse {\n status: number;\n statusText: string;\n data: any;\n error?: Error;\n internal: boolean;\n\n constructor(\n status: number,\n statusText: string | undefined,\n data: any,\n internal = false\n ) {\n this.status = status;\n this.statusText = statusText || \"\";\n this.internal = internal;\n if (data instanceof Error) {\n this.data = data.toString();\n this.error = data;\n } else {\n this.data = data;\n }\n }\n}\n\n/**\n * Check if the given error is an ErrorResponse generated from a 4xx/5xx\n * Response thrown from an action/loader\n */\nexport function isRouteErrorResponse(error: any): error is ErrorResponse {\n return (\n error != null &&\n typeof error.status === \"number\" &&\n typeof error.statusText === \"string\" &&\n typeof error.internal === \"boolean\" &&\n \"data\" in error\n );\n}\n","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _toArray(arr) {\n return arrayWithHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableRest();\n}","import type { History, Location, Path, To } from \"./history\";\nimport {\n Action as HistoryAction,\n createLocation,\n createPath,\n invariant,\n parsePath,\n warning,\n} from \"./history\";\nimport type {\n DataResult,\n DeferredData,\n AgnosticDataRouteMatch,\n AgnosticDataRouteObject,\n DeferredResult,\n ErrorResult,\n FormEncType,\n FormMethod,\n DetectErrorBoundaryFunction,\n RedirectResult,\n RouteData,\n AgnosticRouteObject,\n Submission,\n SuccessResult,\n AgnosticRouteMatch,\n ShouldRevalidateFunction,\n RouteManifest,\n ImmutableRouteKey,\n ActionFunction,\n LoaderFunction,\n V7_MutationFormMethod,\n V7_FormMethod,\n HTMLFormMethod,\n MutationFormMethod,\n MapRoutePropertiesFunction,\n} from \"./utils\";\nimport {\n ErrorResponse,\n ResultType,\n convertRoutesToDataRoutes,\n getPathContributingMatches,\n immutableRouteKeys,\n isRouteErrorResponse,\n joinPaths,\n matchRoutes,\n resolveTo,\n stripBasename,\n} from \"./utils\";\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Types and Constants\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * A Router instance manages all navigation and data loading/mutations\n */\nexport interface Router {\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the basename for the router\n */\n get basename(): RouterInit[\"basename\"];\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the current state of the router\n */\n get state(): RouterState;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Return the routes for this router instance\n */\n get routes(): AgnosticDataRouteObject[];\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Initialize the router, including adding history listeners and kicking off\n * initial data fetches. Returns a function to cleanup listeners and abort\n * any in-progress loads\n */\n initialize(): Router;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Subscribe to router.state updates\n *\n * @param fn function to call with the new state\n */\n subscribe(fn: RouterSubscriber): () => void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Enable scroll restoration behavior in the router\n *\n * @param savedScrollPositions Object that will manage positions, in case\n * it's being restored from sessionStorage\n * @param getScrollPosition Function to get the active Y scroll position\n * @param getKey Function to get the key to use for restoration\n */\n enableScrollRestoration(\n savedScrollPositions: Record<string, number>,\n getScrollPosition: GetScrollPositionFunction,\n getKey?: GetScrollRestorationKeyFunction\n ): () => void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Navigate forward/backward in the history stack\n * @param to Delta to move in the history stack\n */\n navigate(to: number): Promise<void>;\n\n /**\n * Navigate to the given path\n * @param to Path to navigate to\n * @param opts Navigation options (method, submission, etc.)\n */\n navigate(to: To | null, opts?: RouterNavigateOptions): Promise<void>;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Trigger a fetcher load/submission\n *\n * @param key Fetcher key\n * @param routeId Route that owns the fetcher\n * @param href href to fetch\n * @param opts Fetcher options, (method, submission, etc.)\n */\n fetch(\n key: string,\n routeId: string,\n href: string | null,\n opts?: RouterNavigateOptions\n ): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Trigger a revalidation of all current route loaders and fetcher loads\n */\n revalidate(): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Utility function to create an href for the given location\n * @param location\n */\n createHref(location: Location | URL): string;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Utility function to URL encode a destination path according to the internal\n * history implementation\n * @param to\n */\n encodeLocation(to: To): Path;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Get/create a fetcher for the given key\n * @param key\n */\n getFetcher<TData = any>(key?: string): Fetcher<TData>;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Delete the fetcher for a given key\n * @param key\n */\n deleteFetcher(key?: string): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Cleanup listeners and abort any in-progress loads\n */\n dispose(): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Get a navigation blocker\n * @param key The identifier for the blocker\n * @param fn The blocker function implementation\n */\n getBlocker(key: string, fn: BlockerFunction): Blocker;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Delete a navigation blocker\n * @param key The identifier for the blocker\n */\n deleteBlocker(key: string): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * HMR needs to pass in-flight route updates to React Router\n * TODO: Replace this with granular route update APIs (addRoute, updateRoute, deleteRoute)\n */\n _internalSetRoutes(routes: AgnosticRouteObject[]): void;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Internal fetch AbortControllers accessed by unit tests\n */\n _internalFetchControllers: Map<string, AbortController>;\n\n /**\n * @internal\n * PRIVATE - DO NOT USE\n *\n * Internal pending DeferredData instances accessed by unit tests\n */\n _internalActiveDeferreds: Map<string, DeferredData>;\n}\n\n/**\n * State maintained internally by the router. During a navigation, all states\n * reflect the the \"old\" location unless otherwise noted.\n */\nexport interface RouterState {\n /**\n * The action of the most recent navigation\n */\n historyAction: HistoryAction;\n\n /**\n * The current location reflected by the router\n */\n location: Location;\n\n /**\n * The current set of route matches\n */\n matches: AgnosticDataRouteMatch[];\n\n /**\n * Tracks whether we've completed our initial data load\n */\n initialized: boolean;\n\n /**\n * Current scroll position we should start at for a new view\n * - number -> scroll position to restore to\n * - false -> do not restore scroll at all (used during submissions)\n * - null -> don't have a saved position, scroll to hash or top of page\n */\n restoreScrollPosition: number | false | null;\n\n /**\n * Indicate whether this navigation should skip resetting the scroll position\n * if we are unable to restore the scroll position\n */\n preventScrollReset: boolean;\n\n /**\n * Tracks the state of the current navigation\n */\n navigation: Navigation;\n\n /**\n * Tracks any in-progress revalidations\n */\n revalidation: RevalidationState;\n\n /**\n * Data from the loaders for the current matches\n */\n loaderData: RouteData;\n\n /**\n * Data from the action for the current matches\n */\n actionData: RouteData | null;\n\n /**\n * Errors caught from loaders for the current matches\n */\n errors: RouteData | null;\n\n /**\n * Map of current fetchers\n */\n fetchers: Map<string, Fetcher>;\n\n /**\n * Map of current blockers\n */\n blockers: Map<string, Blocker>;\n}\n\n/**\n * Data that can be passed into hydrate a Router from SSR\n */\nexport type HydrationState = Partial<\n Pick<RouterState, \"loaderData\" | \"actionData\" | \"errors\">\n>;\n\n/**\n * Future flags to toggle new feature behavior\n */\nexport interface FutureConfig {\n v7_normalizeFormMethod: boolean;\n v7_prependBasename: boolean;\n}\n\n/**\n * Initialization options for createRouter\n */\nexport interface RouterInit {\n routes: AgnosticRouteObject[];\n history: History;\n basename?: string;\n /**\n * @deprecated Use `mapRouteProperties` instead\n */\n detectErrorBoundary?: DetectErrorBoundaryFunction;\n mapRouteProperties?: MapRoutePropertiesFunction;\n future?: Partial<FutureConfig>;\n hydrationData?: HydrationState;\n}\n\n/**\n * State returned from a server-side query() call\n */\nexport interface StaticHandlerContext {\n basename: Router[\"basename\"];\n location: RouterState[\"location\"];\n matches: RouterState[\"matches\"];\n loaderData: RouterState[\"loaderData\"];\n actionData: RouterState[\"actionData\"];\n errors: RouterState[\"errors\"];\n statusCode: number;\n loaderHeaders: Record<string, Headers>;\n actionHeaders: Record<string, Headers>;\n activeDeferreds: Record<string, DeferredData> | null;\n _deepestRenderedBoundaryId?: string | null;\n}\n\n/**\n * A StaticHandler instance manages a singular SSR navigation/fetch event\n */\nexport interface StaticHandler {\n dataRoutes: AgnosticDataRouteObject[];\n query(\n request: Request,\n opts?: { requestContext?: unknown }\n ): Promise<StaticHandlerContext | Response>;\n queryRoute(\n request: Request,\n opts?: { routeId?: string; requestContext?: unknown }\n ): Promise<any>;\n}\n\n/**\n * Subscriber function signature for changes to router state\n */\nexport interface RouterSubscriber {\n (state: RouterState): void;\n}\n\ninterface UseMatchesMatch {\n id: string;\n pathname: string;\n params: AgnosticRouteMatch[\"params\"];\n data: unknown;\n handle: unknown;\n}\n\n/**\n * Function signature for determining the key to be used in scroll restoration\n * for a given location\n */\nexport interface GetScrollRestorationKeyFunction {\n (location: Location, matches: UseMatchesMatch[]): string | null;\n}\n\n/**\n * Function signature for determining the current scroll position\n */\nexport interface GetScrollPositionFunction {\n (): number;\n}\n\nexport type RelativeRoutingType = \"route\" | \"path\";\n\ntype BaseNavigateOptions = {\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n fromRouteId?: string;\n};\n\n/**\n * Options for a navigate() call for a Link navigation\n */\ntype LinkNavigateOptions = BaseNavigateOptions;\n\n/**\n * Options for a navigate() call for a Form navigation\n */\ntype SubmissionNavigateOptions = BaseNavigateOptions & {\n formMethod?: HTMLFormMethod;\n formEncType?: FormEncType;\n formData: FormData;\n};\n\n/**\n * Options to pass to navigate() for either a Link or Form navigation\n */\nexport type RouterNavigateOptions =\n | LinkNavigateOptions\n | SubmissionNavigateOptions;\n\n/**\n * Options to pass to fetch()\n */\nexport type RouterFetchOptions =\n | Omit<LinkNavigateOptions, \"replace\">\n | Omit<SubmissionNavigateOptions, \"replace\">;\n\n/**\n * Potential states for state.navigation\n */\nexport type NavigationStates = {\n Idle: {\n state: \"idle\";\n location: undefined;\n formMethod: undefined;\n formAction: undefined;\n formEncType: undefined;\n formData: undefined;\n };\n Loading: {\n state: \"loading\";\n location: Location;\n formMethod: FormMethod | V7_FormMethod | undefined;\n formAction: string | undefined;\n formEncType: FormEncType | undefined;\n formData: FormData | undefined;\n };\n Submitting: {\n state: \"submitting\";\n location: Location;\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: FormData;\n };\n};\n\nexport type Navigation = NavigationStates[keyof NavigationStates];\n\nexport type RevalidationState = \"idle\" | \"loading\";\n\n/**\n * Potential states for fetchers\n */\ntype FetcherStates<TData = any> = {\n Idle: {\n state: \"idle\";\n formMethod: undefined;\n formAction: undefined;\n formEncType: undefined;\n formData: undefined;\n data: TData | undefined;\n \" _hasFetcherDoneAnything \"?: boolean;\n };\n Loading: {\n state: \"loading\";\n formMethod: FormMethod | V7_FormMethod | undefined;\n formAction: string | undefined;\n formEncType: FormEncType | undefined;\n formData: FormData | undefined;\n data: TData | undefined;\n \" _hasFetcherDoneAnything \"?: boolean;\n };\n Submitting: {\n state: \"submitting\";\n formMethod: FormMethod | V7_FormMethod;\n formAction: string;\n formEncType: FormEncType;\n formData: FormData;\n data: TData | undefined;\n \" _hasFetcherDoneAnything \"?: boolean;\n };\n};\n\nexport type Fetcher<TData = any> =\n FetcherStates<TData>[keyof FetcherStates<TData>];\n\ninterface BlockerBlocked {\n state: \"blocked\";\n reset(): void;\n proceed(): void;\n location: Location;\n}\n\ninterface BlockerUnblocked {\n state: \"unblocked\";\n reset: undefined;\n proceed: undefined;\n location: undefined;\n}\n\ninterface BlockerProceeding {\n state: \"proceeding\";\n reset: undefined;\n proceed: undefined;\n location: Location;\n}\n\nexport type Blocker = BlockerUnblocked | BlockerBlocked | BlockerProceeding;\n\nexport type BlockerFunction = (args: {\n currentLocation: Location;\n nextLocation: Location;\n historyAction: HistoryAction;\n}) => boolean;\n\ninterface ShortCircuitable {\n /**\n * startNavigation does not need to complete the navigation because we\n * redirected or got interrupted\n */\n shortCircuited?: boolean;\n}\n\ninterface HandleActionResult extends ShortCircuitable {\n /**\n * Error thrown from the current action, keyed by the route containing the\n * error boundary to render the error. To be committed to the state after\n * loaders have completed\n */\n pendingActionError?: RouteData;\n /**\n * Data returned from the current action, keyed by the route owning the action.\n * To be committed to the state after loaders have completed\n */\n pendingActionData?: RouteData;\n}\n\ninterface HandleLoadersResult extends ShortCircuitable {\n /**\n * loaderData returned from the current set of loaders\n */\n loaderData?: RouterState[\"loaderData\"];\n /**\n * errors thrown from the current set of loaders\n */\n errors?: RouterState[\"errors\"];\n}\n\n/**\n * Cached info for active fetcher.load() instances so they can participate\n * in revalidation\n */\ninterface FetchLoadMatch {\n routeId: string;\n path: string;\n}\n\n/**\n * Identified fetcher.load() calls that need to be revalidated\n */\ninterface RevalidatingFetcher extends FetchLoadMatch {\n key: string;\n match: AgnosticDataRouteMatch | null;\n matches: AgnosticDataRouteMatch[] | null;\n controller: AbortController | null;\n}\n\n/**\n * Wrapper object to allow us to throw any response out from callLoaderOrAction\n * for queryRouter while preserving whether or not it was thrown or returned\n * from the loader/action\n */\ninterface QueryRouteResponse {\n type: ResultType.data | ResultType.error;\n response: Response;\n}\n\nconst validMutationMethodsArr: MutationFormMethod[] = [\n \"post\",\n \"put\",\n \"patch\",\n \"delete\",\n];\nconst validMutationMethods = new Set<MutationFormMethod>(\n validMutationMethodsArr\n);\n\nconst validRequestMethodsArr: FormMethod[] = [\n \"get\",\n ...validMutationMethodsArr,\n];\nconst validRequestMethods = new Set<FormMethod>(validRequestMethodsArr);\n\nconst redirectStatusCodes = new Set([301, 302, 303, 307, 308]);\nconst redirectPreserveMethodStatusCodes = new Set([307, 308]);\n\nexport const IDLE_NAVIGATION: NavigationStates[\"Idle\"] = {\n state: \"idle\",\n location: undefined,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n};\n\nexport const IDLE_FETCHER: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: undefined,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n};\n\nexport const IDLE_BLOCKER: BlockerUnblocked = {\n state: \"unblocked\",\n proceed: undefined,\n reset: undefined,\n location: undefined,\n};\n\nconst ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\n\nconst isBrowser =\n typeof window !== \"undefined\" &&\n typeof window.document !== \"undefined\" &&\n typeof window.document.createElement !== \"undefined\";\nconst isServer = !isBrowser;\n\nconst defaultMapRouteProperties: MapRoutePropertiesFunction = (route) => ({\n hasErrorBoundary: Boolean(route.hasErrorBoundary),\n});\n\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region createRouter\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Create a router and listen to history POP navigations\n */\nexport function createRouter(init: RouterInit): Router {\n invariant(\n init.routes.length > 0,\n \"You must provide a non-empty routes array to createRouter\"\n );\n\n let mapRouteProperties: MapRoutePropertiesFunction;\n if (init.mapRouteProperties) {\n mapRouteProperties = init.mapRouteProperties;\n } else if (init.detectErrorBoundary) {\n // If they are still using the deprecated version, wrap it with the new API\n let detectErrorBoundary = init.detectErrorBoundary;\n mapRouteProperties = (route) => ({\n hasErrorBoundary: detectErrorBoundary(route),\n });\n } else {\n mapRouteProperties = defaultMapRouteProperties;\n }\n\n // Routes keyed by ID\n let manifest: RouteManifest = {};\n // Routes in tree format for matching\n let dataRoutes = convertRoutesToDataRoutes(\n init.routes,\n mapRouteProperties,\n undefined,\n manifest\n );\n let inFlightDataRoutes: AgnosticDataRouteObject[] | undefined;\n let basename = init.basename || \"/\";\n // Config driven behavior flags\n let future: FutureConfig = {\n v7_normalizeFormMethod: false,\n v7_prependBasename: false,\n ...init.future,\n };\n // Cleanup function for history\n let unlistenHistory: (() => void) | null = null;\n // Externally-provided functions to call on all state changes\n let subscribers = new Set<RouterSubscriber>();\n // Externally-provided object to hold scroll restoration locations during routing\n let savedScrollPositions: Record<string, number> | null = null;\n // Externally-provided function to get scroll restoration keys\n let getScrollRestorationKey: GetScrollRestorationKeyFunction | null = null;\n // Externally-provided function to get current scroll position\n let getScrollPosition: GetScrollPositionFunction | null = null;\n // One-time flag to control the initial hydration scroll restoration. Because\n // we don't get the saved positions from <ScrollRestoration /> until _after_\n // the initial render, we need to manually trigger a separate updateState to\n // send along the restoreScrollPosition\n // Set to true if we have `hydrationData` since we assume we were SSR'd and that\n // SSR did the initial scroll restoration.\n let initialScrollRestored = init.hydrationData != null;\n\n let initialMatches = matchRoutes(dataRoutes, init.history.location, basename);\n let initialErrors: RouteData | null = null;\n\n if (initialMatches == null) {\n // If we do not match a user-provided-route, fall back to the root\n // to allow the error boundary to take over\n let error = getInternalRouterError(404, {\n pathname: init.history.location.pathname,\n });\n let { matches, route } = getShortCircuitMatches(dataRoutes);\n initialMatches = matches;\n initialErrors = { [route.id]: error };\n }\n\n let initialized =\n // All initialMatches need to be loaded before we're ready. If we have lazy\n // functions around still then we'll need to run them in initialize()\n !initialMatches.some((m) => m.route.lazy) &&\n // And we have to either have no loaders or have been provided hydrationData\n (!initialMatches.some((m) => m.route.loader) || init.hydrationData != null);\n\n let router: Router;\n let state: RouterState = {\n historyAction: init.history.action,\n location: init.history.location,\n matches: initialMatches,\n initialized,\n navigation: IDLE_NAVIGATION,\n // Don't restore on initial updateState() if we were SSR'd\n restoreScrollPosition: init.hydrationData != null ? false : null,\n preventScrollReset: false,\n revalidation: \"idle\",\n loaderData: (init.hydrationData && init.hydrationData.loaderData) || {},\n actionData: (init.hydrationData && init.hydrationData.actionData) || null,\n errors: (init.hydrationData && init.hydrationData.errors) || initialErrors,\n fetchers: new Map(),\n blockers: new Map(),\n };\n\n // -- Stateful internal variables to manage navigations --\n // Current navigation in progress (to be committed in completeNavigation)\n let pendingAction: HistoryAction = HistoryAction.Pop;\n\n // Should the current navigation prevent the scroll reset if scroll cannot\n // be restored?\n let pendingPreventScrollReset = false;\n\n // AbortController for the active navigation\n let pendingNavigationController: AbortController | null;\n\n // We use this to avoid touching history in completeNavigation if a\n // revalidation is entirely uninterrupted\n let isUninterruptedRevalidation = false;\n\n // Use this internal flag to force revalidation of all loaders:\n // - submissions (completed or interrupted)\n // - useRevalidator()\n // - X-Remix-Revalidate (from redirect)\n let isRevalidationRequired = false;\n\n // Use this internal array to capture routes that require revalidation due\n // to a cancelled deferred on action submission\n let cancelledDeferredRoutes: string[] = [];\n\n // Use this internal array to capture fetcher loads that were cancelled by an\n // action navigation and require revalidation\n let cancelledFetcherLoads: string[] = [];\n\n // AbortControllers for any in-flight fetchers\n let fetchControllers = new Map<string, AbortController>();\n\n // Track loads based on the order in which they started\n let incrementingLoadId = 0;\n\n // Track the outstanding pending navigation data load to be compared against\n // the globally incrementing load when a fetcher load lands after a completed\n // navigation\n let pendingNavigationLoadId = -1;\n\n // Fetchers that triggered data reloads as a result of their actions\n let fetchReloadIds = new Map<string, number>();\n\n // Fetchers that triggered redirect navigations\n let fetchRedirectIds = new Set<string>();\n\n // Most recent href/match for fetcher.load calls for fetchers\n let fetchLoadMatches = new Map<string, FetchLoadMatch>();\n\n // Store DeferredData instances for active route matches. When a\n // route loader returns defer() we stick one in here. Then, when a nested\n // promise resolves we update loaderData. If a new navigation starts we\n // cancel active deferreds for eliminated routes.\n let activeDeferreds = new Map<string, DeferredData>();\n\n // Store blocker functions in a separate Map outside of router state since\n // we don't need to update UI state if they change\n let blockerFunctions = new Map<string, BlockerFunction>();\n\n // Flag to ignore the next history update, so we can revert the URL change on\n // a POP navigation that was blocked by the user without touching router state\n let ignoreNextHistoryUpdate = false;\n\n // Initialize the router, all side effects should be kicked off from here.\n // Implemented as a Fluent API for ease of:\n // let router = createRouter(init).initialize();\n function initialize() {\n // If history informs us of a POP navigation, start the navigation but do not update\n // state. We'll update our own state once the navigation completes\n unlistenHistory = init.history.listen(\n ({ action: historyAction, location, delta }) => {\n // Ignore this event if it was just us resetting the URL from a\n // blocked POP navigation\n if (ignoreNextHistoryUpdate) {\n ignoreNextHistoryUpdate = false;\n return;\n }\n\n warning(\n blockerFunctions.size === 0 || delta != null,\n \"You are trying to use a blocker on a POP navigation to a location \" +\n \"that was not created by @remix-run/router. This will fail silently in \" +\n \"production. This can happen if you are navigating outside the router \" +\n \"via `window.history.pushState`/`window.location.hash` instead of using \" +\n \"router navigation APIs. This can also happen if you are using \" +\n \"createHashRouter and the user manually changes the URL.\"\n );\n\n let blockerKey = shouldBlockNavigation({\n currentLocation: state.location,\n nextLocation: location,\n historyAction,\n });\n\n if (blockerKey && delta != null) {\n // Restore the URL to match the current UI, but don't update router state\n ignoreNextHistoryUpdate = true;\n init.history.go(delta * -1);\n\n // Put the blocker into a blocked state\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location,\n proceed() {\n updateBlocker(blockerKey!, {\n state: \"proceeding\",\n proceed: undefined,\n reset: undefined,\n location,\n });\n // Re-do the same POP navigation we just blocked\n init.history.go(delta);\n },\n reset() {\n deleteBlocker(blockerKey!);\n updateState({ blockers: new Map(router.state.blockers) });\n },\n });\n return;\n }\n\n return startNavigation(historyAction, location);\n }\n );\n\n // Kick off initial data load if needed. Use Pop to avoid modifying history\n // Note we don't do any handling of lazy here. For SPA's it'll get handled\n // in the normal navigation flow. For SSR it's expected that lazy modules are\n // resolved prior to router creation since we can't go into a fallbackElement\n // UI for SSR'd apps\n if (!state.initialized) {\n startNavigation(HistoryAction.Pop, state.location);\n }\n\n return router;\n }\n\n // Clean up a router and it's side effects\n function dispose() {\n if (unlistenHistory) {\n unlistenHistory();\n }\n subscribers.clear();\n pendingNavigationController && pendingNavigationController.abort();\n state.fetchers.forEach((_, key) => deleteFetcher(key));\n state.blockers.forEach((_, key) => deleteBlocker(key));\n }\n\n // Subscribe to state updates for the router\n function subscribe(fn: RouterSubscriber) {\n subscribers.add(fn);\n return () => subscribers.delete(fn);\n }\n\n // Update our state and notify the calling context of the change\n function updateState(newState: Partial<RouterState>): void {\n state = {\n ...state,\n ...newState,\n };\n subscribers.forEach((subscriber) => subscriber(state));\n }\n\n // Complete a navigation returning the state.navigation back to the IDLE_NAVIGATION\n // and setting state.[historyAction/location/matches] to the new route.\n // - Location is a required param\n // - Navigation will always be set to IDLE_NAVIGATION\n // - Can pass any other state in newState\n function completeNavigation(\n location: Location,\n newState: Partial<Omit<RouterState, \"action\" | \"location\" | \"navigation\">>\n ): void {\n // Deduce if we're in a loading/actionReload state:\n // - We have committed actionData in the store\n // - The current navigation was a mutation submission\n // - We're past the submitting state and into the loading state\n // - The location being loaded is not the result of a redirect\n let isActionReload =\n state.actionData != null &&\n state.navigation.formMethod != null &&\n isMutationMethod(state.navigation.formMethod) &&\n state.navigation.state === \"loading\" &&\n location.state?._isRedirect !== true;\n\n let actionData: RouteData | null;\n if (newState.actionData) {\n if (Object.keys(newState.actionData).length > 0) {\n actionData = newState.actionData;\n } else {\n // Empty actionData -> clear prior actionData due to an action error\n actionData = null;\n }\n } else if (isActionReload) {\n // Keep the current data if we're wrapping up the action reload\n actionData = state.actionData;\n } else {\n // Clear actionData on any other completed navigations\n actionData = null;\n }\n\n // Always preserve any existing loaderData from re-used routes\n let loaderData = newState.loaderData\n ? mergeLoaderData(\n state.loaderData,\n newState.loaderData,\n newState.matches || [],\n newState.errors\n )\n : state.loaderData;\n\n // On a successful navigation we can assume we got through all blockers\n // so we can start fresh\n for (let [key] of blockerFunctions) {\n deleteBlocker(key);\n }\n\n // Always respect the user flag. Otherwise don't reset on mutation\n // submission navigations unless they redirect\n let preventScrollReset =\n pendingPreventScrollReset === true ||\n (state.navigation.formMethod != null &&\n isMutationMethod(state.navigation.formMethod) &&\n location.state?._isRedirect !== true);\n\n if (inFlightDataRoutes) {\n dataRoutes = inFlightDataRoutes;\n inFlightDataRoutes = undefined;\n }\n\n updateState({\n ...newState, // matches, errors, fetchers go through as-is\n actionData,\n loaderData,\n historyAction: pendingAction,\n location,\n initialized: true,\n navigation: IDLE_NAVIGATION,\n revalidation: \"idle\",\n restoreScrollPosition: getSavedScrollPosition(\n location,\n newState.matches || state.matches\n ),\n preventScrollReset,\n blockers: new Map(state.blockers),\n });\n\n if (isUninterruptedRevalidation) {\n // If this was an uninterrupted revalidation then do not touch history\n } else if (pendingAction === HistoryAction.Pop) {\n // Do nothing for POP - URL has already been updated\n } else if (pendingAction === HistoryAction.Push) {\n init.history.push(location, location.state);\n } else if (pendingAction === HistoryAction.Replace) {\n init.history.replace(location, location.state);\n }\n\n // Reset stateful navigation vars\n pendingAction = HistoryAction.Pop;\n pendingPreventScrollReset = false;\n isUninterruptedRevalidation = false;\n isRevalidationRequired = false;\n cancelledDeferredRoutes = [];\n cancelledFetcherLoads = [];\n }\n\n // Trigger a navigation event, which can either be a numerical POP or a PUSH\n // replace with an optional submission\n async function navigate(\n to: number | To | null,\n opts?: RouterNavigateOptions\n ): Promise<void> {\n if (typeof to === \"number\") {\n init.history.go(to);\n return;\n }\n\n let normalizedPath = normalizeTo(\n state.location,\n state.matches,\n basename,\n future.v7_prependBasename,\n to,\n opts?.fromRouteId,\n opts?.relative\n );\n let { path, submission, error } = normalizeNavigateOptions(\n future.v7_normalizeFormMethod,\n false,\n normalizedPath,\n opts\n );\n\n let currentLocation = state.location;\n let nextLocation = createLocation(state.location, path, opts && opts.state);\n\n // When using navigate as a PUSH/REPLACE we aren't reading an already-encoded\n // URL from window.location, so we need to encode it here so the behavior\n // remains the same as POP and non-data-router usages. new URL() does all\n // the same encoding we'd get from a history.pushState/window.location read\n // without having to touch history\n nextLocation = {\n ...nextLocation,\n ...init.history.encodeLocation(nextLocation),\n };\n\n let userReplace = opts && opts.replace != null ? opts.replace : undefined;\n\n let historyAction = HistoryAction.Push;\n\n if (userReplace === true) {\n historyAction = HistoryAction.Replace;\n } else if (userReplace === false) {\n // no-op\n } else if (\n submission != null &&\n isMutationMethod(submission.formMethod) &&\n submission.formAction === state.location.pathname + state.location.search\n ) {\n // By default on submissions to the current location we REPLACE so that\n // users don't have to double-click the back button to get to the prior\n // location. If the user redirects to a different location from the\n // action/loader this will be ignored and the redirect will be a PUSH\n historyAction = HistoryAction.Replace;\n }\n\n let preventScrollReset =\n opts && \"preventScrollReset\" in opts\n ? opts.preventScrollReset === true\n : undefined;\n\n let blockerKey = shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction,\n });\n if (blockerKey) {\n // Put the blocker into a blocked state\n updateBlocker(blockerKey, {\n state: \"blocked\",\n location: nextLocation,\n proceed() {\n updateBlocker(blockerKey!, {\n state: \"proceeding\",\n proceed: undefined,\n reset: undefined,\n location: nextLocation,\n });\n // Send the same navigation through\n navigate(to, opts);\n },\n reset() {\n deleteBlocker(blockerKey!);\n updateState({ blockers: new Map(state.blockers) });\n },\n });\n return;\n }\n\n return await startNavigation(historyAction, nextLocation, {\n submission,\n // Send through the formData serialization error if we have one so we can\n // render at the right error boundary after we match routes\n pendingError: error,\n preventScrollReset,\n replace: opts && opts.replace,\n });\n }\n\n // Revalidate all current loaders. If a navigation is in progress or if this\n // is interrupted by a navigation, allow this to \"succeed\" by calling all\n // loaders during the next loader round\n function revalidate() {\n interruptActiveLoads();\n updateState({ revalidation: \"loading\" });\n\n // If we're currently submitting an action, we don't need to start a new\n // navigation, we'll just let the follow up loader execution call all loaders\n if (state.navigation.state === \"submitting\") {\n return;\n }\n\n // If we're currently in an idle state, start a new navigation for the current\n // action/location and mark it as uninterrupted, which will skip the history\n // update in completeNavigation\n if (state.navigation.state === \"idle\") {\n startNavigation(state.historyAction, state.location, {\n startUninterruptedRevalidation: true,\n });\n return;\n }\n\n // Otherwise, if we're currently in a loading state, just start a new\n // navigation to the navigation.location but do not trigger an uninterrupted\n // revalidation so that history correctly updates once the navigation completes\n startNavigation(\n pendingAction || state.historyAction,\n state.navigation.location,\n { overrideNavigation: state.navigation }\n );\n }\n\n // Start a navigation to the given action/location. Can optionally provide a\n // overrideNavigation which will override the normalLoad in the case of a redirect\n // navigation\n async function startNavigation(\n historyAction: HistoryAction,\n location: Location,\n opts?: {\n submission?: Submission;\n fetcherSubmission?: Submission;\n overrideNavigation?: Navigation;\n pendingError?: ErrorResponse;\n startUninterruptedRevalidation?: boolean;\n preventScrollReset?: boolean;\n replace?: boolean;\n }\n ): Promise<void> {\n // Abort any in-progress navigations and start a new one. Unset any ongoing\n // uninterrupted revalidations unless told otherwise, since we want this\n // new navigation to update history normally\n pendingNavigationController && pendingNavigationController.abort();\n pendingNavigationController = null;\n pendingAction = historyAction;\n isUninterruptedRevalidation =\n (opts && opts.startUninterruptedRevalidation) === true;\n\n // Save the current scroll position every time we start a new navigation,\n // and track whether we should reset scroll on completion\n saveScrollPosition(state.location, state.matches);\n pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let loadingNavigation = opts && opts.overrideNavigation;\n let matches = matchRoutes(routesToUse, location, basename);\n\n // Short circuit with a 404 on the root error boundary if we match nothing\n if (!matches) {\n let error = getInternalRouterError(404, { pathname: location.pathname });\n let { matches: notFoundMatches, route } =\n getShortCircuitMatches(routesToUse);\n // Cancel all pending deferred on 404s since we don't keep any routes\n cancelActiveDeferreds();\n completeNavigation(location, {\n matches: notFoundMatches,\n loaderData: {},\n errors: {\n [route.id]: error,\n },\n });\n return;\n }\n\n // Short circuit if it's only a hash change and not a mutation submission\n // For example, on /page#hash and submit a <Form method=\"post\"> which will\n // default to a navigation to /page\n if (\n isHashChangeOnly(state.location, location) &&\n !(opts && opts.submission && isMutationMethod(opts.submission.formMethod))\n ) {\n completeNavigation(location, { matches });\n return;\n }\n\n // Create a controller/Request for this navigation\n pendingNavigationController = new AbortController();\n let request = createClientSideRequest(\n init.history,\n location,\n pendingNavigationController.signal,\n opts && opts.submission\n );\n let pendingActionData: RouteData | undefined;\n let pendingError: RouteData | undefined;\n\n if (opts && opts.pendingError) {\n // If we have a pendingError, it means the user attempted a GET submission\n // with binary FormData so assign here and skip to handleLoaders. That\n // way we handle calling loaders above the boundary etc. It's not really\n // different from an actionError in that sense.\n pendingError = {\n [findNearestBoundary(matches).route.id]: opts.pendingError,\n };\n } else if (\n opts &&\n opts.submission &&\n isMutationMethod(opts.submission.formMethod)\n ) {\n // Call action if we received an action submission\n let actionOutput = await handleAction(\n request,\n location,\n opts.submission,\n matches,\n { replace: opts.replace }\n );\n\n if (actionOutput.shortCircuited) {\n return;\n }\n\n pendingActionData = actionOutput.pendingActionData;\n pendingError = actionOutput.pendingActionError;\n\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location,\n ...opts.submission,\n };\n loadingNavigation = navigation;\n\n // Create a GET request for the loaders\n request = new Request(request.url, { signal: request.signal });\n }\n\n // Call loaders\n let { shortCircuited, loaderData, errors } = await handleLoaders(\n request,\n location,\n matches,\n loadingNavigation,\n opts && opts.submission,\n opts && opts.fetcherSubmission,\n opts && opts.replace,\n pendingActionData,\n pendingError\n );\n\n if (shortCircuited) {\n return;\n }\n\n // Clean up now that the action/loaders have completed. Don't clean up if\n // we short circuited because pendingNavigationController will have already\n // been assigned to a new controller for the next navigation\n pendingNavigationController = null;\n\n completeNavigation(location, {\n matches,\n ...(pendingActionData ? { actionData: pendingActionData } : {}),\n loaderData,\n errors,\n });\n }\n\n // Call the action matched by the leaf route for this navigation and handle\n // redirects/errors\n async function handleAction(\n request: Request,\n location: Location,\n submission: Submission,\n matches: AgnosticDataRouteMatch[],\n opts?: { replace?: boolean }\n ): Promise<HandleActionResult> {\n interruptActiveLoads();\n\n // Put us in a submitting state\n let navigation: NavigationStates[\"Submitting\"] = {\n state: \"submitting\",\n location,\n ...submission,\n };\n updateState({ navigation });\n\n // Call our action and get the result\n let result: DataResult;\n let actionMatch = getTargetMatch(matches, location);\n\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n result = {\n type: ResultType.error,\n error: getInternalRouterError(405, {\n method: request.method,\n pathname: location.pathname,\n routeId: actionMatch.route.id,\n }),\n };\n } else {\n result = await callLoaderOrAction(\n \"action\",\n request,\n actionMatch,\n matches,\n manifest,\n mapRouteProperties,\n basename\n );\n\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n }\n\n if (isRedirectResult(result)) {\n let replace: boolean;\n if (opts && opts.replace != null) {\n replace = opts.replace;\n } else {\n // If the user didn't explicity indicate replace behavior, replace if\n // we redirected to the exact same location we're currently at to avoid\n // double back-buttons\n replace =\n result.location === state.location.pathname + state.location.search;\n }\n await startRedirectNavigation(state, result, { submission, replace });\n return { shortCircuited: true };\n }\n\n if (isErrorResult(result)) {\n // Store off the pending error - we use it to determine which loaders\n // to call and will commit it when we complete the navigation\n let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n\n // By default, all submissions are REPLACE navigations, but if the\n // action threw an error that'll be rendered in an errorElement, we fall\n // back to PUSH so that the user can use the back button to get back to\n // the pre-submission form location to try again\n if ((opts && opts.replace) !== true) {\n pendingAction = HistoryAction.Push;\n }\n\n return {\n // Send back an empty object we can use to clear out any prior actionData\n pendingActionData: {},\n pendingActionError: { [boundaryMatch.route.id]: result.error },\n };\n }\n\n if (isDeferredResult(result)) {\n throw getInternalRouterError(400, { type: \"defer-action\" });\n }\n\n return {\n pendingActionData: { [actionMatch.route.id]: result.data },\n };\n }\n\n // Call all applicable loaders for the given matches, handling redirects,\n // errors, etc.\n async function handleLoaders(\n request: Request,\n location: Location,\n matches: AgnosticDataRouteMatch[],\n overrideNavigation?: Navigation,\n submission?: Submission,\n fetcherSubmission?: Submission,\n replace?: boolean,\n pendingActionData?: RouteData,\n pendingError?: RouteData\n ): Promise<HandleLoadersResult> {\n // Figure out the right navigation we want to use for data loading\n let loadingNavigation = overrideNavigation;\n if (!loadingNavigation) {\n let navigation: NavigationStates[\"Loading\"] = {\n state: \"loading\",\n location,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n ...submission,\n };\n loadingNavigation = navigation;\n }\n\n // If this was a redirect from an action we don't have a \"submission\" but\n // we have it on the loading navigation so use that if available\n let activeSubmission =\n submission || fetcherSubmission\n ? submission || fetcherSubmission\n : loadingNavigation.formMethod &&\n loadingNavigation.formAction &&\n loadingNavigation.formData &&\n loadingNavigation.formEncType\n ? {\n formMethod: loadingNavigation.formMethod,\n formAction: loadingNavigation.formAction,\n formData: loadingNavigation.formData,\n formEncType: loadingNavigation.formEncType,\n }\n : undefined;\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n init.history,\n state,\n matches,\n activeSubmission,\n location,\n isRevalidationRequired,\n cancelledDeferredRoutes,\n cancelledFetcherLoads,\n fetchLoadMatches,\n routesToUse,\n basename,\n pendingActionData,\n pendingError\n );\n\n // Cancel pending deferreds for no-longer-matched routes or routes we're\n // about to reload. Note that if this is an action reload we would have\n // already cancelled all pending deferreds so this would be a no-op\n cancelActiveDeferreds(\n (routeId) =>\n !(matches && matches.some((m) => m.route.id === routeId)) ||\n (matchesToLoad && matchesToLoad.some((m) => m.route.id === routeId))\n );\n\n // Short circuit if we have no loaders to run\n if (matchesToLoad.length === 0 && revalidatingFetchers.length === 0) {\n let updatedFetchers = markFetchRedirectsDone();\n completeNavigation(location, {\n matches,\n loaderData: {},\n // Commit pending error if we're short circuiting\n errors: pendingError || null,\n ...(pendingActionData ? { actionData: pendingActionData } : {}),\n ...(updatedFetchers ? { fetchers: new Map(state.fetchers) } : {}),\n });\n return { shortCircuited: true };\n }\n\n // If this is an uninterrupted revalidation, we remain in our current idle\n // state. If not, we need to switch to our loading state and load data,\n // preserving any new action data or existing action data (in the case of\n // a revalidation interrupting an actionReload)\n if (!isUninterruptedRevalidation) {\n revalidatingFetchers.forEach((rf) => {\n let fetcher = state.fetchers.get(rf.key);\n let revalidatingFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n data: fetcher && fetcher.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(rf.key, revalidatingFetcher);\n });\n let actionData = pendingActionData || state.actionData;\n updateState({\n navigation: loadingNavigation,\n ...(actionData\n ? Object.keys(actionData).length === 0\n ? { actionData: null }\n : { actionData }\n : {}),\n ...(revalidatingFetchers.length > 0\n ? { fetchers: new Map(state.fetchers) }\n : {}),\n });\n }\n\n pendingNavigationLoadId = ++incrementingLoadId;\n revalidatingFetchers.forEach((rf) => {\n if (rf.controller) {\n // Fetchers use an independent AbortController so that aborting a fetcher\n // (via deleteFetcher) does not abort the triggering navigation that\n // triggered the revalidation\n fetchControllers.set(rf.key, rf.controller);\n }\n });\n\n // Proxy navigation abort through to revalidation fetchers\n let abortPendingFetchRevalidations = () =>\n revalidatingFetchers.forEach((f) => abortFetcher(f.key));\n if (pendingNavigationController) {\n pendingNavigationController.signal.addEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n }\n\n let { results, loaderResults, fetcherResults } =\n await callLoadersAndMaybeResolveData(\n state.matches,\n matches,\n matchesToLoad,\n revalidatingFetchers,\n request\n );\n\n if (request.signal.aborted) {\n return { shortCircuited: true };\n }\n\n // Clean up _after_ loaders have completed. Don't clean up if we short\n // circuited because fetchControllers would have been aborted and\n // reassigned to new controllers for the next navigation\n if (pendingNavigationController) {\n pendingNavigationController.signal.removeEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n }\n revalidatingFetchers.forEach((rf) => fetchControllers.delete(rf.key));\n\n // If any loaders returned a redirect Response, start a new REPLACE navigation\n let redirect = findRedirect(results);\n if (redirect) {\n await startRedirectNavigation(state, redirect, { replace });\n return { shortCircuited: true };\n }\n\n // Process and commit output from loaders\n let { loaderData, errors } = processLoaderData(\n state,\n matches,\n matchesToLoad,\n loaderResults,\n pendingError,\n revalidatingFetchers,\n fetcherResults,\n activeDeferreds\n );\n\n // Wire up subscribers to update loaderData as promises settle\n activeDeferreds.forEach((deferredData, routeId) => {\n deferredData.subscribe((aborted) => {\n // Note: No need to updateState here since the TrackedPromise on\n // loaderData is stable across resolve/reject\n // Remove this instance if we were aborted or if promises have settled\n if (aborted || deferredData.done) {\n activeDeferreds.delete(routeId);\n }\n });\n });\n\n let updatedFetchers = markFetchRedirectsDone();\n let didAbortFetchLoads = abortStaleFetchLoads(pendingNavigationLoadId);\n let shouldUpdateFetchers =\n updatedFetchers || didAbortFetchLoads || revalidatingFetchers.length > 0;\n\n return {\n loaderData,\n errors,\n ...(shouldUpdateFetchers ? { fetchers: new Map(state.fetchers) } : {}),\n };\n }\n\n function getFetcher<TData = any>(key: string): Fetcher<TData> {\n return state.fetchers.get(key) || IDLE_FETCHER;\n }\n\n // Trigger a fetcher load/submit for the given fetcher key\n function fetch(\n key: string,\n routeId: string,\n href: string | null,\n opts?: RouterFetchOptions\n ) {\n if (isServer) {\n throw new Error(\n \"router.fetch() was called during the server render, but it shouldn't be. \" +\n \"You are likely calling a useFetcher() method in the body of your component. \" +\n \"Try moving it to a useEffect or a callback.\"\n );\n }\n\n if (fetchControllers.has(key)) abortFetcher(key);\n\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let normalizedPath = normalizeTo(\n state.location,\n state.matches,\n basename,\n future.v7_prependBasename,\n href,\n routeId,\n opts?.relative\n );\n let matches = matchRoutes(routesToUse, normalizedPath, basename);\n\n if (!matches) {\n setFetcherError(\n key,\n routeId,\n getInternalRouterError(404, { pathname: normalizedPath })\n );\n return;\n }\n\n let { path, submission } = normalizeNavigateOptions(\n future.v7_normalizeFormMethod,\n true,\n normalizedPath,\n opts\n );\n let match = getTargetMatch(matches, path);\n\n pendingPreventScrollReset = (opts && opts.preventScrollReset) === true;\n\n if (submission && isMutationMethod(submission.formMethod)) {\n handleFetcherAction(key, routeId, path, match, matches, submission);\n return;\n }\n\n // Store off the match so we can call it's shouldRevalidate on subsequent\n // revalidations\n fetchLoadMatches.set(key, { routeId, path });\n handleFetcherLoader(key, routeId, path, match, matches, submission);\n }\n\n // Call the action for the matched fetcher.submit(), and then handle redirects,\n // errors, and revalidation\n async function handleFetcherAction(\n key: string,\n routeId: string,\n path: string,\n match: AgnosticDataRouteMatch,\n requestMatches: AgnosticDataRouteMatch[],\n submission: Submission\n ) {\n interruptActiveLoads();\n fetchLoadMatches.delete(key);\n\n if (!match.route.action && !match.route.lazy) {\n let error = getInternalRouterError(405, {\n method: submission.formMethod,\n pathname: path,\n routeId: routeId,\n });\n setFetcherError(key, routeId, error);\n return;\n }\n\n // Put this fetcher into it's submitting state\n let existingFetcher = state.fetchers.get(key);\n let fetcher: FetcherStates[\"Submitting\"] = {\n state: \"submitting\",\n ...submission,\n data: existingFetcher && existingFetcher.data,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(key, fetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n // Call the action for the fetcher\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(\n init.history,\n path,\n abortController.signal,\n submission\n );\n fetchControllers.set(key, abortController);\n\n let actionResult = await callLoaderOrAction(\n \"action\",\n fetchRequest,\n match,\n requestMatches,\n manifest,\n mapRouteProperties,\n basename\n );\n\n if (fetchRequest.signal.aborted) {\n // We can delete this so long as we weren't aborted by ou our own fetcher\n // re-submit which would have put _new_ controller is in fetchControllers\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n return;\n }\n\n if (isRedirectResult(actionResult)) {\n fetchControllers.delete(key);\n fetchRedirectIds.add(key);\n let loadingFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n ...submission,\n data: undefined,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(key, loadingFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n return startRedirectNavigation(state, actionResult, {\n submission,\n isFetchActionRedirect: true,\n });\n }\n\n // Process any non-redirect errors thrown\n if (isErrorResult(actionResult)) {\n setFetcherError(key, routeId, actionResult.error);\n return;\n }\n\n if (isDeferredResult(actionResult)) {\n throw getInternalRouterError(400, { type: \"defer-action\" });\n }\n\n // Start the data load for current matches, or the next location if we're\n // in the middle of a navigation\n let nextLocation = state.navigation.location || state.location;\n let revalidationRequest = createClientSideRequest(\n init.history,\n\n nextLocation,\n abortController.signal\n );\n let routesToUse = inFlightDataRoutes || dataRoutes;\n let matches =\n state.navigation.state !== \"idle\"\n ? matchRoutes(routesToUse, state.navigation.location, basename)\n : state.matches;\n\n invariant(matches, \"Didn't find any matches after fetcher action\");\n\n let loadId = ++incrementingLoadId;\n fetchReloadIds.set(key, loadId);\n\n let loadFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n data: actionResult.data,\n ...submission,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(key, loadFetcher);\n\n let [matchesToLoad, revalidatingFetchers] = getMatchesToLoad(\n init.history,\n state,\n matches,\n submission,\n nextLocation,\n isRevalidationRequired,\n cancelledDeferredRoutes,\n cancelledFetcherLoads,\n fetchLoadMatches,\n routesToUse,\n basename,\n { [match.route.id]: actionResult.data },\n undefined // No need to send through errors since we short circuit above\n );\n\n // Put all revalidating fetchers into the loading state, except for the\n // current fetcher which we want to keep in it's current loading state which\n // contains it's action submission info + action data\n revalidatingFetchers\n .filter((rf) => rf.key !== key)\n .forEach((rf) => {\n let staleKey = rf.key;\n let existingFetcher = state.fetchers.get(staleKey);\n let revalidatingFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n data: existingFetcher && existingFetcher.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(staleKey, revalidatingFetcher);\n if (rf.controller) {\n fetchControllers.set(staleKey, rf.controller);\n }\n });\n\n updateState({ fetchers: new Map(state.fetchers) });\n\n let abortPendingFetchRevalidations = () =>\n revalidatingFetchers.forEach((rf) => abortFetcher(rf.key));\n\n abortController.signal.addEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n\n let { results, loaderResults, fetcherResults } =\n await callLoadersAndMaybeResolveData(\n state.matches,\n matches,\n matchesToLoad,\n revalidatingFetchers,\n revalidationRequest\n );\n\n if (abortController.signal.aborted) {\n return;\n }\n\n abortController.signal.removeEventListener(\n \"abort\",\n abortPendingFetchRevalidations\n );\n\n fetchReloadIds.delete(key);\n fetchControllers.delete(key);\n revalidatingFetchers.forEach((r) => fetchControllers.delete(r.key));\n\n let redirect = findRedirect(results);\n if (redirect) {\n return startRedirectNavigation(state, redirect);\n }\n\n // Process and commit output from loaders\n let { loaderData, errors } = processLoaderData(\n state,\n state.matches,\n matchesToLoad,\n loaderResults,\n undefined,\n revalidatingFetchers,\n fetcherResults,\n activeDeferreds\n );\n\n let doneFetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: actionResult.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(key, doneFetcher);\n\n let didAbortFetchLoads = abortStaleFetchLoads(loadId);\n\n // If we are currently in a navigation loading state and this fetcher is\n // more recent than the navigation, we want the newer data so abort the\n // navigation and complete it with the fetcher data\n if (\n state.navigation.state === \"loading\" &&\n loadId > pendingNavigationLoadId\n ) {\n invariant(pendingAction, \"Expected pending action\");\n pendingNavigationController && pendingNavigationController.abort();\n\n completeNavigation(state.navigation.location, {\n matches,\n loaderData,\n errors,\n fetchers: new Map(state.fetchers),\n });\n } else {\n // otherwise just update with the fetcher data, preserving any existing\n // loaderData for loaders that did not need to reload. We have to\n // manually merge here since we aren't going through completeNavigation\n updateState({\n errors,\n loaderData: mergeLoaderData(\n state.loaderData,\n loaderData,\n matches,\n errors\n ),\n ...(didAbortFetchLoads ? { fetchers: new Map(state.fetchers) } : {}),\n });\n isRevalidationRequired = false;\n }\n }\n\n // Call the matched loader for fetcher.load(), handling redirects, errors, etc.\n async function handleFetcherLoader(\n key: string,\n routeId: string,\n path: string,\n match: AgnosticDataRouteMatch,\n matches: AgnosticDataRouteMatch[],\n submission?: Submission\n ) {\n let existingFetcher = state.fetchers.get(key);\n // Put this fetcher into it's loading state\n let loadingFetcher: FetcherStates[\"Loading\"] = {\n state: \"loading\",\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n ...submission,\n data: existingFetcher && existingFetcher.data,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(key, loadingFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n\n // Call the loader for this fetcher route match\n let abortController = new AbortController();\n let fetchRequest = createClientSideRequest(\n init.history,\n path,\n abortController.signal\n );\n fetchControllers.set(key, abortController);\n\n let result: DataResult = await callLoaderOrAction(\n \"loader\",\n fetchRequest,\n match,\n matches,\n manifest,\n mapRouteProperties,\n basename\n );\n\n // Deferred isn't supported for fetcher loads, await everything and treat it\n // as a normal load. resolveDeferredData will return undefined if this\n // fetcher gets aborted, so we just leave result untouched and short circuit\n // below if that happens\n if (isDeferredResult(result)) {\n result =\n (await resolveDeferredData(result, fetchRequest.signal, true)) ||\n result;\n }\n\n // We can delete this so long as we weren't aborted by our our own fetcher\n // re-load which would have put _new_ controller is in fetchControllers\n if (fetchControllers.get(key) === abortController) {\n fetchControllers.delete(key);\n }\n\n if (fetchRequest.signal.aborted) {\n return;\n }\n\n // If the loader threw a redirect Response, start a new REPLACE navigation\n if (isRedirectResult(result)) {\n fetchRedirectIds.add(key);\n await startRedirectNavigation(state, result);\n return;\n }\n\n // Process any non-redirect errors thrown\n if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n state.fetchers.delete(key);\n // TODO: In remix, this would reset to IDLE_NAVIGATION if it was a catch -\n // do we need to behave any differently with our non-redirect errors?\n // What if it was a non-redirect Response?\n updateState({\n fetchers: new Map(state.fetchers),\n errors: {\n [boundaryMatch.route.id]: result.error,\n },\n });\n return;\n }\n\n invariant(!isDeferredResult(result), \"Unhandled fetcher deferred data\");\n\n // Put the fetcher back into an idle state\n let doneFetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: result.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(key, doneFetcher);\n updateState({ fetchers: new Map(state.fetchers) });\n }\n\n /**\n * Utility function to handle redirects returned from an action or loader.\n * Normally, a redirect \"replaces\" the navigation that triggered it. So, for\n * example:\n *\n * - user is on /a\n * - user clicks a link to /b\n * - loader for /b redirects to /c\n *\n * In a non-JS app the browser would track the in-flight navigation to /b and\n * then replace it with /c when it encountered the redirect response. In\n * the end it would only ever update the URL bar with /c.\n *\n * In client-side routing using pushState/replaceState, we aim to emulate\n * this behavior and we also do not update history until the end of the\n * navigation (including processed redirects). This means that we never\n * actually touch history until we've processed redirects, so we just use\n * the history action from the original navigation (PUSH or REPLACE).\n */\n async function startRedirectNavigation(\n state: RouterState,\n redirect: RedirectResult,\n {\n submission,\n replace,\n isFetchActionRedirect,\n }: {\n submission?: Submission;\n replace?: boolean;\n isFetchActionRedirect?: boolean;\n } = {}\n ) {\n if (redirect.revalidate) {\n isRevalidationRequired = true;\n }\n\n let redirectLocation = createLocation(\n state.location,\n redirect.location,\n // TODO: This can be removed once we get rid of useTransition in Remix v2\n {\n _isRedirect: true,\n ...(isFetchActionRedirect ? { _isFetchActionRedirect: true } : {}),\n }\n );\n invariant(\n redirectLocation,\n \"Expected a location on the redirect navigation\"\n );\n // Check if this an absolute external redirect that goes to a new origin\n if (\n ABSOLUTE_URL_REGEX.test(redirect.location) &&\n isBrowser &&\n typeof window?.location !== \"undefined\"\n ) {\n let url = init.history.createURL(redirect.location);\n let isDifferentBasename = stripBasename(url.pathname, basename) == null;\n\n if (window.location.origin !== url.origin || isDifferentBasename) {\n if (replace) {\n window.location.replace(redirect.location);\n } else {\n window.location.assign(redirect.location);\n }\n return;\n }\n }\n\n // There's no need to abort on redirects, since we don't detect the\n // redirect until the action/loaders have settled\n pendingNavigationController = null;\n\n let redirectHistoryAction =\n replace === true ? HistoryAction.Replace : HistoryAction.Push;\n\n // Use the incoming submission if provided, fallback on the active one in\n // state.navigation\n let { formMethod, formAction, formEncType, formData } = state.navigation;\n if (!submission && formMethod && formAction && formData && formEncType) {\n submission = {\n formMethod,\n formAction,\n formEncType,\n formData,\n };\n }\n\n // If this was a 307/308 submission we want to preserve the HTTP method and\n // re-submit the GET/POST/PUT/PATCH/DELETE as a submission navigation to the\n // redirected location\n if (\n redirectPreserveMethodStatusCodes.has(redirect.status) &&\n submission &&\n isMutationMethod(submission.formMethod)\n ) {\n await startNavigation(redirectHistoryAction, redirectLocation, {\n submission: {\n ...submission,\n formAction: redirect.location,\n },\n // Preserve this flag across redirects\n preventScrollReset: pendingPreventScrollReset,\n });\n } else if (isFetchActionRedirect) {\n // For a fetch action redirect, we kick off a new loading navigation\n // without the fetcher submission, but we send it along for shouldRevalidate\n await startNavigation(redirectHistoryAction, redirectLocation, {\n overrideNavigation: {\n state: \"loading\",\n location: redirectLocation,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n },\n fetcherSubmission: submission,\n // Preserve this flag across redirects\n preventScrollReset: pendingPreventScrollReset,\n });\n } else {\n // Otherwise, we kick off a new loading navigation, preserving the\n // submission info for the duration of this navigation\n await startNavigation(redirectHistoryAction, redirectLocation, {\n overrideNavigation: {\n state: \"loading\",\n location: redirectLocation,\n formMethod: submission ? submission.formMethod : undefined,\n formAction: submission ? submission.formAction : undefined,\n formEncType: submission ? submission.formEncType : undefined,\n formData: submission ? submission.formData : undefined,\n },\n // Preserve this flag across redirects\n preventScrollReset: pendingPreventScrollReset,\n });\n }\n }\n\n async function callLoadersAndMaybeResolveData(\n currentMatches: AgnosticDataRouteMatch[],\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n fetchersToLoad: RevalidatingFetcher[],\n request: Request\n ) {\n // Call all navigation loaders and revalidating fetcher loaders in parallel,\n // then slice off the results into separate arrays so we can handle them\n // accordingly\n let results = await Promise.all([\n ...matchesToLoad.map((match) =>\n callLoaderOrAction(\n \"loader\",\n request,\n match,\n matches,\n manifest,\n mapRouteProperties,\n basename\n )\n ),\n ...fetchersToLoad.map((f) => {\n if (f.matches && f.match && f.controller) {\n return callLoaderOrAction(\n \"loader\",\n createClientSideRequest(init.history, f.path, f.controller.signal),\n f.match,\n f.matches,\n manifest,\n mapRouteProperties,\n basename\n );\n } else {\n let error: ErrorResult = {\n type: ResultType.error,\n error: getInternalRouterError(404, { pathname: f.path }),\n };\n return error;\n }\n }),\n ]);\n let loaderResults = results.slice(0, matchesToLoad.length);\n let fetcherResults = results.slice(matchesToLoad.length);\n\n await Promise.all([\n resolveDeferredResults(\n currentMatches,\n matchesToLoad,\n loaderResults,\n loaderResults.map(() => request.signal),\n false,\n state.loaderData\n ),\n resolveDeferredResults(\n currentMatches,\n fetchersToLoad.map((f) => f.match),\n fetcherResults,\n fetchersToLoad.map((f) => (f.controller ? f.controller.signal : null)),\n true\n ),\n ]);\n\n return { results, loaderResults, fetcherResults };\n }\n\n function interruptActiveLoads() {\n // Every interruption triggers a revalidation\n isRevalidationRequired = true;\n\n // Cancel pending route-level deferreds and mark cancelled routes for\n // revalidation\n cancelledDeferredRoutes.push(...cancelActiveDeferreds());\n\n // Abort in-flight fetcher loads\n fetchLoadMatches.forEach((_, key) => {\n if (fetchControllers.has(key)) {\n cancelledFetcherLoads.push(key);\n abortFetcher(key);\n }\n });\n }\n\n function setFetcherError(key: string, routeId: string, error: any) {\n let boundaryMatch = findNearestBoundary(state.matches, routeId);\n deleteFetcher(key);\n updateState({\n errors: {\n [boundaryMatch.route.id]: error,\n },\n fetchers: new Map(state.fetchers),\n });\n }\n\n function deleteFetcher(key: string): void {\n if (fetchControllers.has(key)) abortFetcher(key);\n fetchLoadMatches.delete(key);\n fetchReloadIds.delete(key);\n fetchRedirectIds.delete(key);\n state.fetchers.delete(key);\n }\n\n function abortFetcher(key: string) {\n let controller = fetchControllers.get(key);\n invariant(controller, `Expected fetch controller: ${key}`);\n controller.abort();\n fetchControllers.delete(key);\n }\n\n function markFetchersDone(keys: string[]) {\n for (let key of keys) {\n let fetcher = getFetcher(key);\n let doneFetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: fetcher.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(key, doneFetcher);\n }\n }\n\n function markFetchRedirectsDone(): boolean {\n let doneKeys = [];\n let updatedFetchers = false;\n for (let key of fetchRedirectIds) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, `Expected fetcher: ${key}`);\n if (fetcher.state === \"loading\") {\n fetchRedirectIds.delete(key);\n doneKeys.push(key);\n updatedFetchers = true;\n }\n }\n markFetchersDone(doneKeys);\n return updatedFetchers;\n }\n\n function abortStaleFetchLoads(landedId: number): boolean {\n let yeetedKeys = [];\n for (let [key, id] of fetchReloadIds) {\n if (id < landedId) {\n let fetcher = state.fetchers.get(key);\n invariant(fetcher, `Expected fetcher: ${key}`);\n if (fetcher.state === \"loading\") {\n abortFetcher(key);\n fetchReloadIds.delete(key);\n yeetedKeys.push(key);\n }\n }\n }\n markFetchersDone(yeetedKeys);\n return yeetedKeys.length > 0;\n }\n\n function getBlocker(key: string, fn: BlockerFunction) {\n let blocker: Blocker = state.blockers.get(key) || IDLE_BLOCKER;\n\n if (blockerFunctions.get(key) !== fn) {\n blockerFunctions.set(key, fn);\n }\n\n return blocker;\n }\n\n function deleteBlocker(key: string) {\n state.blockers.delete(key);\n blockerFunctions.delete(key);\n }\n\n // Utility function to update blockers, ensuring valid state transitions\n function updateBlocker(key: string, newBlocker: Blocker) {\n let blocker = state.blockers.get(key) || IDLE_BLOCKER;\n\n // Poor mans state machine :)\n // https://mermaid.live/edit#pako:eNqVkc9OwzAMxl8l8nnjAYrEtDIOHEBIgwvKJTReGy3_lDpIqO27k6awMG0XcrLlnz87nwdonESogKXXBuE79rq75XZO3-yHds0RJVuv70YrPlUrCEe2HfrORS3rubqZfuhtpg5C9wk5tZ4VKcRUq88q9Z8RS0-48cE1iHJkL0ugbHuFLus9L6spZy8nX9MP2CNdomVaposqu3fGayT8T8-jJQwhepo_UtpgBQaDEUom04dZhAN1aJBDlUKJBxE1ceB2Smj0Mln-IBW5AFU2dwUiktt_2Qaq2dBfaKdEup85UV7Yd-dKjlnkabl2Pvr0DTkTreM\n invariant(\n (blocker.state === \"unblocked\" && newBlocker.state === \"blocked\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"blocked\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"proceeding\") ||\n (blocker.state === \"blocked\" && newBlocker.state === \"unblocked\") ||\n (blocker.state === \"proceeding\" && newBlocker.state === \"unblocked\"),\n `Invalid blocker state transition: ${blocker.state} -> ${newBlocker.state}`\n );\n\n state.blockers.set(key, newBlocker);\n updateState({ blockers: new Map(state.blockers) });\n }\n\n function shouldBlockNavigation({\n currentLocation,\n nextLocation,\n historyAction,\n }: {\n currentLocation: Location;\n nextLocation: Location;\n historyAction: HistoryAction;\n }): string | undefined {\n if (blockerFunctions.size === 0) {\n return;\n }\n\n // We ony support a single active blocker at the moment since we don't have\n // any compelling use cases for multi-blocker yet\n if (blockerFunctions.size > 1) {\n warning(false, \"A router only supports one blocker at a time\");\n }\n\n let entries = Array.from(blockerFunctions.entries());\n let [blockerKey, blockerFunction] = entries[entries.length - 1];\n let blocker = state.blockers.get(blockerKey);\n\n if (blocker && blocker.state === \"proceeding\") {\n // If the blocker is currently proceeding, we don't need to re-check\n // it and can let this navigation continue\n return;\n }\n\n // At this point, we know we're unblocked/blocked so we need to check the\n // user-provided blocker function\n if (blockerFunction({ currentLocation, nextLocation, historyAction })) {\n return blockerKey;\n }\n }\n\n function cancelActiveDeferreds(\n predicate?: (routeId: string) => boolean\n ): string[] {\n let cancelledRouteIds: string[] = [];\n activeDeferreds.forEach((dfd, routeId) => {\n if (!predicate || predicate(routeId)) {\n // Cancel the deferred - but do not remove from activeDeferreds here -\n // we rely on the subscribers to do that so our tests can assert proper\n // cleanup via _internalActiveDeferreds\n dfd.cancel();\n cancelledRouteIds.push(routeId);\n activeDeferreds.delete(routeId);\n }\n });\n return cancelledRouteIds;\n }\n\n // Opt in to capturing and reporting scroll positions during navigations,\n // used by the <ScrollRestoration> component\n function enableScrollRestoration(\n positions: Record<string, number>,\n getPosition: GetScrollPositionFunction,\n getKey?: GetScrollRestorationKeyFunction\n ) {\n savedScrollPositions = positions;\n getScrollPosition = getPosition;\n getScrollRestorationKey = getKey || ((location) => location.key);\n\n // Perform initial hydration scroll restoration, since we miss the boat on\n // the initial updateState() because we've not yet rendered <ScrollRestoration/>\n // and therefore have no savedScrollPositions available\n if (!initialScrollRestored && state.navigation === IDLE_NAVIGATION) {\n initialScrollRestored = true;\n let y = getSavedScrollPosition(state.location, state.matches);\n if (y != null) {\n updateState({ restoreScrollPosition: y });\n }\n }\n\n return () => {\n savedScrollPositions = null;\n getScrollPosition = null;\n getScrollRestorationKey = null;\n };\n }\n\n function saveScrollPosition(\n location: Location,\n matches: AgnosticDataRouteMatch[]\n ): void {\n if (savedScrollPositions && getScrollRestorationKey && getScrollPosition) {\n let userMatches = matches.map((m) =>\n createUseMatchesMatch(m, state.loaderData)\n );\n let key = getScrollRestorationKey(location, userMatches) || location.key;\n savedScrollPositions[key] = getScrollPosition();\n }\n }\n\n function getSavedScrollPosition(\n location: Location,\n matches: AgnosticDataRouteMatch[]\n ): number | null {\n if (savedScrollPositions && getScrollRestorationKey && getScrollPosition) {\n let userMatches = matches.map((m) =>\n createUseMatchesMatch(m, state.loaderData)\n );\n let key = getScrollRestorationKey(location, userMatches) || location.key;\n let y = savedScrollPositions[key];\n if (typeof y === \"number\") {\n return y;\n }\n }\n return null;\n }\n\n function _internalSetRoutes(newRoutes: AgnosticDataRouteObject[]) {\n inFlightDataRoutes = newRoutes;\n }\n\n router = {\n get basename() {\n return basename;\n },\n get state() {\n return state;\n },\n get routes() {\n return dataRoutes;\n },\n initialize,\n subscribe,\n enableScrollRestoration,\n navigate,\n fetch,\n revalidate,\n // Passthrough to history-aware createHref used by useHref so we get proper\n // hash-aware URLs in DOM paths\n createHref: (to: To) => init.history.createHref(to),\n encodeLocation: (to: To) => init.history.encodeLocation(to),\n getFetcher,\n deleteFetcher,\n dispose,\n getBlocker,\n deleteBlocker,\n _internalFetchControllers: fetchControllers,\n _internalActiveDeferreds: activeDeferreds,\n // TODO: Remove setRoutes, it's temporary to avoid dealing with\n // updating the tree while validating the update algorithm.\n _internalSetRoutes,\n };\n\n return router;\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region createStaticHandler\n////////////////////////////////////////////////////////////////////////////////\n\nexport const UNSAFE_DEFERRED_SYMBOL = Symbol(\"deferred\");\n\nexport interface CreateStaticHandlerOptions {\n basename?: string;\n /**\n * @deprecated Use `mapRouteProperties` instead\n */\n detectErrorBoundary?: DetectErrorBoundaryFunction;\n mapRouteProperties?: MapRoutePropertiesFunction;\n}\n\nexport function createStaticHandler(\n routes: AgnosticRouteObject[],\n opts?: CreateStaticHandlerOptions\n): StaticHandler {\n invariant(\n routes.length > 0,\n \"You must provide a non-empty routes array to createStaticHandler\"\n );\n\n let manifest: RouteManifest = {};\n let basename = (opts ? opts.basename : null) || \"/\";\n let mapRouteProperties: MapRoutePropertiesFunction;\n if (opts?.mapRouteProperties) {\n mapRouteProperties = opts.mapRouteProperties;\n } else if (opts?.detectErrorBoundary) {\n // If they are still using the deprecated version, wrap it with the new API\n let detectErrorBoundary = opts.detectErrorBoundary;\n mapRouteProperties = (route) => ({\n hasErrorBoundary: detectErrorBoundary(route),\n });\n } else {\n mapRouteProperties = defaultMapRouteProperties;\n }\n\n let dataRoutes = convertRoutesToDataRoutes(\n routes,\n mapRouteProperties,\n undefined,\n manifest\n );\n\n /**\n * The query() method is intended for document requests, in which we want to\n * call an optional action and potentially multiple loaders for all nested\n * routes. It returns a StaticHandlerContext object, which is very similar\n * to the router state (location, loaderData, actionData, errors, etc.) and\n * also adds SSR-specific information such as the statusCode and headers\n * from action/loaders Responses.\n *\n * It _should_ never throw and should report all errors through the\n * returned context.errors object, properly associating errors to their error\n * boundary. Additionally, it tracks _deepestRenderedBoundaryId which can be\n * used to emulate React error boundaries during SSr by performing a second\n * pass only down to the boundaryId.\n *\n * The one exception where we do not return a StaticHandlerContext is when a\n * redirect response is returned or thrown from any action/loader. We\n * propagate that out and return the raw Response so the HTTP server can\n * return it directly.\n */\n async function query(\n request: Request,\n { requestContext }: { requestContext?: unknown } = {}\n ): Promise<StaticHandlerContext | Response> {\n let url = new URL(request.url);\n let method = request.method;\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n\n // SSR supports HEAD requests while SPA doesn't\n if (!isValidMethod(method) && method !== \"HEAD\") {\n let error = getInternalRouterError(405, { method });\n let { matches: methodNotAllowedMatches, route } =\n getShortCircuitMatches(dataRoutes);\n return {\n basename,\n location,\n matches: methodNotAllowedMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error,\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n } else if (!matches) {\n let error = getInternalRouterError(404, { pathname: location.pathname });\n let { matches: notFoundMatches, route } =\n getShortCircuitMatches(dataRoutes);\n return {\n basename,\n location,\n matches: notFoundMatches,\n loaderData: {},\n actionData: null,\n errors: {\n [route.id]: error,\n },\n statusCode: error.status,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n }\n\n let result = await queryImpl(request, location, matches, requestContext);\n if (isResponse(result)) {\n return result;\n }\n\n // When returning StaticHandlerContext, we patch back in the location here\n // since we need it for React Context. But this helps keep our submit and\n // loadRouteData operating on a Request instead of a Location\n return { location, basename, ...result };\n }\n\n /**\n * The queryRoute() method is intended for targeted route requests, either\n * for fetch ?_data requests or resource route requests. In this case, we\n * are only ever calling a single action or loader, and we are returning the\n * returned value directly. In most cases, this will be a Response returned\n * from the action/loader, but it may be a primitive or other value as well -\n * and in such cases the calling context should handle that accordingly.\n *\n * We do respect the throw/return differentiation, so if an action/loader\n * throws, then this method will throw the value. This is important so we\n * can do proper boundary identification in Remix where a thrown Response\n * must go to the Catch Boundary but a returned Response is happy-path.\n *\n * One thing to note is that any Router-initiated Errors that make sense\n * to associate with a status code will be thrown as an ErrorResponse\n * instance which include the raw Error, such that the calling context can\n * serialize the error as they see fit while including the proper response\n * code. Examples here are 404 and 405 errors that occur prior to reaching\n * any user-defined loaders.\n */\n async function queryRoute(\n request: Request,\n {\n routeId,\n requestContext,\n }: { requestContext?: unknown; routeId?: string } = {}\n ): Promise<any> {\n let url = new URL(request.url);\n let method = request.method;\n let location = createLocation(\"\", createPath(url), null, \"default\");\n let matches = matchRoutes(dataRoutes, location, basename);\n\n // SSR supports HEAD requests while SPA doesn't\n if (!isValidMethod(method) && method !== \"HEAD\" && method !== \"OPTIONS\") {\n throw getInternalRouterError(405, { method });\n } else if (!matches) {\n throw getInternalRouterError(404, { pathname: location.pathname });\n }\n\n let match = routeId\n ? matches.find((m) => m.route.id === routeId)\n : getTargetMatch(matches, location);\n\n if (routeId && !match) {\n throw getInternalRouterError(403, {\n pathname: location.pathname,\n routeId,\n });\n } else if (!match) {\n // This should never hit I don't think?\n throw getInternalRouterError(404, { pathname: location.pathname });\n }\n\n let result = await queryImpl(\n request,\n location,\n matches,\n requestContext,\n match\n );\n if (isResponse(result)) {\n return result;\n }\n\n let error = result.errors ? Object.values(result.errors)[0] : undefined;\n if (error !== undefined) {\n // If we got back result.errors, that means the loader/action threw\n // _something_ that wasn't a Response, but it's not guaranteed/required\n // to be an `instanceof Error` either, so we have to use throw here to\n // preserve the \"error\" state outside of queryImpl.\n throw error;\n }\n\n // Pick off the right state value to return\n if (result.actionData) {\n return Object.values(result.actionData)[0];\n }\n\n if (result.loaderData) {\n let data = Object.values(result.loaderData)[0];\n if (result.activeDeferreds?.[match.route.id]) {\n data[UNSAFE_DEFERRED_SYMBOL] = result.activeDeferreds[match.route.id];\n }\n return data;\n }\n\n return undefined;\n }\n\n async function queryImpl(\n request: Request,\n location: Location,\n matches: AgnosticDataRouteMatch[],\n requestContext: unknown,\n routeMatch?: AgnosticDataRouteMatch\n ): Promise<Omit<StaticHandlerContext, \"location\" | \"basename\"> | Response> {\n invariant(\n request.signal,\n \"query()/queryRoute() requests must contain an AbortController signal\"\n );\n\n try {\n if (isMutationMethod(request.method.toLowerCase())) {\n let result = await submit(\n request,\n matches,\n routeMatch || getTargetMatch(matches, location),\n requestContext,\n routeMatch != null\n );\n return result;\n }\n\n let result = await loadRouteData(\n request,\n matches,\n requestContext,\n routeMatch\n );\n return isResponse(result)\n ? result\n : {\n ...result,\n actionData: null,\n actionHeaders: {},\n };\n } catch (e) {\n // If the user threw/returned a Response in callLoaderOrAction, we throw\n // it to bail out and then return or throw here based on whether the user\n // returned or threw\n if (isQueryRouteResponse(e)) {\n if (e.type === ResultType.error && !isRedirectResponse(e.response)) {\n throw e.response;\n }\n return e.response;\n }\n // Redirects are always returned since they don't propagate to catch\n // boundaries\n if (isRedirectResponse(e)) {\n return e;\n }\n throw e;\n }\n }\n\n async function submit(\n request: Request,\n matches: AgnosticDataRouteMatch[],\n actionMatch: AgnosticDataRouteMatch,\n requestContext: unknown,\n isRouteRequest: boolean\n ): Promise<Omit<StaticHandlerContext, \"location\" | \"basename\"> | Response> {\n let result: DataResult;\n\n if (!actionMatch.route.action && !actionMatch.route.lazy) {\n let error = getInternalRouterError(405, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: actionMatch.route.id,\n });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: ResultType.error,\n error,\n };\n } else {\n result = await callLoaderOrAction(\n \"action\",\n request,\n actionMatch,\n matches,\n manifest,\n mapRouteProperties,\n basename,\n true,\n isRouteRequest,\n requestContext\n );\n\n if (request.signal.aborted) {\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(`${method}() call aborted`);\n }\n }\n\n if (isRedirectResult(result)) {\n // Uhhhh - this should never happen, we should always throw these from\n // callLoaderOrAction, but the type narrowing here keeps TS happy and we\n // can get back on the \"throw all redirect responses\" train here should\n // this ever happen :/\n throw new Response(null, {\n status: result.status,\n headers: {\n Location: result.location,\n },\n });\n }\n\n if (isDeferredResult(result)) {\n let error = getInternalRouterError(400, { type: \"defer-action\" });\n if (isRouteRequest) {\n throw error;\n }\n result = {\n type: ResultType.error,\n error,\n };\n }\n\n if (isRouteRequest) {\n // Note: This should only be non-Response values if we get here, since\n // isRouteRequest should throw any Response received in callLoaderOrAction\n if (isErrorResult(result)) {\n throw result.error;\n }\n\n return {\n matches: [actionMatch],\n loaderData: {},\n actionData: { [actionMatch.route.id]: result.data },\n errors: null,\n // Note: statusCode + headers are unused here since queryRoute will\n // return the raw Response or value\n statusCode: 200,\n loaderHeaders: {},\n actionHeaders: {},\n activeDeferreds: null,\n };\n }\n\n if (isErrorResult(result)) {\n // Store off the pending error - we use it to determine which loaders\n // to call and will commit it when we complete the navigation\n let boundaryMatch = findNearestBoundary(matches, actionMatch.route.id);\n let context = await loadRouteData(\n request,\n matches,\n requestContext,\n undefined,\n {\n [boundaryMatch.route.id]: result.error,\n }\n );\n\n // action status codes take precedence over loader status codes\n return {\n ...context,\n statusCode: isRouteErrorResponse(result.error)\n ? result.error.status\n : 500,\n actionData: null,\n actionHeaders: {\n ...(result.headers ? { [actionMatch.route.id]: result.headers } : {}),\n },\n };\n }\n\n // Create a GET request for the loaders\n let loaderRequest = new Request(request.url, {\n headers: request.headers,\n redirect: request.redirect,\n signal: request.signal,\n });\n let context = await loadRouteData(loaderRequest, matches, requestContext);\n\n return {\n ...context,\n // action status codes take precedence over loader status codes\n ...(result.statusCode ? { statusCode: result.statusCode } : {}),\n actionData: {\n [actionMatch.route.id]: result.data,\n },\n actionHeaders: {\n ...(result.headers ? { [actionMatch.route.id]: result.headers } : {}),\n },\n };\n }\n\n async function loadRouteData(\n request: Request,\n matches: AgnosticDataRouteMatch[],\n requestContext: unknown,\n routeMatch?: AgnosticDataRouteMatch,\n pendingActionError?: RouteData\n ): Promise<\n | Omit<\n StaticHandlerContext,\n \"location\" | \"basename\" | \"actionData\" | \"actionHeaders\"\n >\n | Response\n > {\n let isRouteRequest = routeMatch != null;\n\n // Short circuit if we have no loaders to run (queryRoute())\n if (\n isRouteRequest &&\n !routeMatch?.route.loader &&\n !routeMatch?.route.lazy\n ) {\n throw getInternalRouterError(400, {\n method: request.method,\n pathname: new URL(request.url).pathname,\n routeId: routeMatch?.route.id,\n });\n }\n\n let requestMatches = routeMatch\n ? [routeMatch]\n : getLoaderMatchesUntilBoundary(\n matches,\n Object.keys(pendingActionError || {})[0]\n );\n let matchesToLoad = requestMatches.filter(\n (m) => m.route.loader || m.route.lazy\n );\n\n // Short circuit if we have no loaders to run (query())\n if (matchesToLoad.length === 0) {\n return {\n matches,\n // Add a null for all matched routes for proper revalidation on the client\n loaderData: matches.reduce(\n (acc, m) => Object.assign(acc, { [m.route.id]: null }),\n {}\n ),\n errors: pendingActionError || null,\n statusCode: 200,\n loaderHeaders: {},\n activeDeferreds: null,\n };\n }\n\n let results = await Promise.all([\n ...matchesToLoad.map((match) =>\n callLoaderOrAction(\n \"loader\",\n request,\n match,\n matches,\n manifest,\n mapRouteProperties,\n basename,\n true,\n isRouteRequest,\n requestContext\n )\n ),\n ]);\n\n if (request.signal.aborted) {\n let method = isRouteRequest ? \"queryRoute\" : \"query\";\n throw new Error(`${method}() call aborted`);\n }\n\n // Process and commit output from loaders\n let activeDeferreds = new Map<string, DeferredData>();\n let context = processRouteLoaderData(\n matches,\n matchesToLoad,\n results,\n pendingActionError,\n activeDeferreds\n );\n\n // Add a null for any non-loader matches for proper revalidation on the client\n let executedLoaders = new Set<string>(\n matchesToLoad.map((match) => match.route.id)\n );\n matches.forEach((match) => {\n if (!executedLoaders.has(match.route.id)) {\n context.loaderData[match.route.id] = null;\n }\n });\n\n return {\n ...context,\n matches,\n activeDeferreds:\n activeDeferreds.size > 0\n ? Object.fromEntries(activeDeferreds.entries())\n : null,\n };\n }\n\n return {\n dataRoutes,\n query,\n queryRoute,\n };\n}\n\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Helpers\n////////////////////////////////////////////////////////////////////////////////\n\n/**\n * Given an existing StaticHandlerContext and an error thrown at render time,\n * provide an updated StaticHandlerContext suitable for a second SSR render\n */\nexport function getStaticContextFromError(\n routes: AgnosticDataRouteObject[],\n context: StaticHandlerContext,\n error: any\n) {\n let newContext: StaticHandlerContext = {\n ...context,\n statusCode: 500,\n errors: {\n [context._deepestRenderedBoundaryId || routes[0].id]: error,\n },\n };\n return newContext;\n}\n\nfunction isSubmissionNavigation(\n opts: RouterNavigateOptions\n): opts is SubmissionNavigateOptions {\n return opts != null && \"formData\" in opts;\n}\n\nfunction normalizeTo(\n location: Path,\n matches: AgnosticDataRouteMatch[],\n basename: string,\n prependBasename: boolean,\n to: To | null,\n fromRouteId?: string,\n relative?: RelativeRoutingType\n) {\n let contextualMatches: AgnosticDataRouteMatch[];\n let activeRouteMatch: AgnosticDataRouteMatch | undefined;\n if (fromRouteId != null && relative !== \"path\") {\n // Grab matches up to the calling route so our route-relative logic is\n // relative to the correct source route. When using relative:path,\n // fromRouteId is ignored since that is always relative to the current\n // location path\n contextualMatches = [];\n for (let match of matches) {\n contextualMatches.push(match);\n if (match.route.id === fromRouteId) {\n activeRouteMatch = match;\n break;\n }\n }\n } else {\n contextualMatches = matches;\n activeRouteMatch = matches[matches.length - 1];\n }\n\n // Resolve the relative path\n let path = resolveTo(\n to ? to : \".\",\n getPathContributingMatches(contextualMatches).map((m) => m.pathnameBase),\n stripBasename(location.pathname, basename) || location.pathname,\n relative === \"path\"\n );\n\n // When `to` is not specified we inherit search/hash from the current\n // location, unlike when to=\".\" and we just inherit the path.\n // See https://github.com/remix-run/remix/issues/927\n if (to == null) {\n path.search = location.search;\n path.hash = location.hash;\n }\n\n // Add an ?index param for matched index routes if we don't already have one\n if (\n (to == null || to === \"\" || to === \".\") &&\n activeRouteMatch &&\n activeRouteMatch.route.index &&\n !hasNakedIndexQuery(path.search)\n ) {\n path.search = path.search\n ? path.search.replace(/^\\?/, \"?index&\")\n : \"?index\";\n }\n\n // If we're operating within a basename, prepend it to the pathname. If\n // this is a root navigation, then just use the raw basename which allows\n // the basename to have full control over the presence of a trailing slash\n // on root actions\n if (prependBasename && basename !== \"/\") {\n path.pathname =\n path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n }\n\n return createPath(path);\n}\n\n// Normalize navigation options by converting formMethod=GET formData objects to\n// URLSearchParams so they behave identically to links with query params\nfunction normalizeNavigateOptions(\n normalizeFormMethod: boolean,\n isFetcher: boolean,\n path: string,\n opts?: RouterNavigateOptions\n): {\n path: string;\n submission?: Submission;\n error?: ErrorResponse;\n} {\n // Return location verbatim on non-submission navigations\n if (!opts || !isSubmissionNavigation(opts)) {\n return { path };\n }\n\n if (opts.formMethod && !isValidMethod(opts.formMethod)) {\n return {\n path,\n error: getInternalRouterError(405, { method: opts.formMethod }),\n };\n }\n\n // Create a Submission on non-GET navigations\n let submission: Submission | undefined;\n if (opts.formData) {\n let formMethod = opts.formMethod || \"get\";\n submission = {\n formMethod: normalizeFormMethod\n ? (formMethod.toUpperCase() as V7_FormMethod)\n : (formMethod.toLowerCase() as FormMethod),\n formAction: stripHashFromPath(path),\n formEncType:\n (opts && opts.formEncType) || \"application/x-www-form-urlencoded\",\n formData: opts.formData,\n };\n\n if (isMutationMethod(submission.formMethod)) {\n return { path, submission };\n }\n }\n\n // Flatten submission onto URLSearchParams for GET submissions\n let parsedPath = parsePath(path);\n let searchParams = convertFormDataToSearchParams(opts.formData);\n // On GET navigation submissions we can drop the ?index param from the\n // resulting location since all loaders will run. But fetcher GET submissions\n // only run a single loader so we need to preserve any incoming ?index params\n if (isFetcher && parsedPath.search && hasNakedIndexQuery(parsedPath.search)) {\n searchParams.append(\"index\", \"\");\n }\n parsedPath.search = `?${searchParams}`;\n\n return { path: createPath(parsedPath), submission };\n}\n\n// Filter out all routes below any caught error as they aren't going to\n// render so we don't need to load them\nfunction getLoaderMatchesUntilBoundary(\n matches: AgnosticDataRouteMatch[],\n boundaryId?: string\n) {\n let boundaryMatches = matches;\n if (boundaryId) {\n let index = matches.findIndex((m) => m.route.id === boundaryId);\n if (index >= 0) {\n boundaryMatches = matches.slice(0, index);\n }\n }\n return boundaryMatches;\n}\n\nfunction getMatchesToLoad(\n history: History,\n state: RouterState,\n matches: AgnosticDataRouteMatch[],\n submission: Submission | undefined,\n location: Location,\n isRevalidationRequired: boolean,\n cancelledDeferredRoutes: string[],\n cancelledFetcherLoads: string[],\n fetchLoadMatches: Map<string, FetchLoadMatch>,\n routesToUse: AgnosticDataRouteObject[],\n basename: string | undefined,\n pendingActionData?: RouteData,\n pendingError?: RouteData\n): [AgnosticDataRouteMatch[], RevalidatingFetcher[]] {\n let actionResult = pendingError\n ? Object.values(pendingError)[0]\n : pendingActionData\n ? Object.values(pendingActionData)[0]\n : undefined;\n\n let currentUrl = history.createURL(state.location);\n let nextUrl = history.createURL(location);\n\n // Pick navigation matches that are net-new or qualify for revalidation\n let boundaryId = pendingError ? Object.keys(pendingError)[0] : undefined;\n let boundaryMatches = getLoaderMatchesUntilBoundary(matches, boundaryId);\n\n let navigationMatches = boundaryMatches.filter((match, index) => {\n if (match.route.lazy) {\n // We haven't loaded this route yet so we don't know if it's got a loader!\n return true;\n }\n if (match.route.loader == null) {\n return false;\n }\n\n // Always call the loader on new route instances and pending defer cancellations\n if (\n isNewLoader(state.loaderData, state.matches[index], match) ||\n cancelledDeferredRoutes.some((id) => id === match.route.id)\n ) {\n return true;\n }\n\n // This is the default implementation for when we revalidate. If the route\n // provides it's own implementation, then we give them full control but\n // provide this value so they can leverage it if needed after they check\n // their own specific use cases\n let currentRouteMatch = state.matches[index];\n let nextRouteMatch = match;\n\n return shouldRevalidateLoader(match, {\n currentUrl,\n currentParams: currentRouteMatch.params,\n nextUrl,\n nextParams: nextRouteMatch.params,\n ...submission,\n actionResult,\n defaultShouldRevalidate:\n // Forced revalidation due to submission, useRevalidator, or X-Remix-Revalidate\n isRevalidationRequired ||\n // Clicked the same link, resubmitted a GET form\n currentUrl.pathname + currentUrl.search ===\n nextUrl.pathname + nextUrl.search ||\n // Search params affect all loaders\n currentUrl.search !== nextUrl.search ||\n isNewRouteInstance(currentRouteMatch, nextRouteMatch),\n });\n });\n\n // Pick fetcher.loads that need to be revalidated\n let revalidatingFetchers: RevalidatingFetcher[] = [];\n fetchLoadMatches.forEach((f, key) => {\n // Don't revalidate if fetcher won't be present in the subsequent render\n if (!matches.some((m) => m.route.id === f.routeId)) {\n return;\n }\n\n let fetcherMatches = matchRoutes(routesToUse, f.path, basename);\n\n // If the fetcher path no longer matches, push it in with null matches so\n // we can trigger a 404 in callLoadersAndMaybeResolveData\n if (!fetcherMatches) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: null,\n match: null,\n controller: null,\n });\n return;\n }\n\n let fetcherMatch = getTargetMatch(fetcherMatches, f.path);\n\n if (cancelledFetcherLoads.includes(key)) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: fetcherMatches,\n match: fetcherMatch,\n controller: new AbortController(),\n });\n return;\n }\n\n // Revalidating fetchers are decoupled from the route matches since they\n // hit a static href, so they _always_ check shouldRevalidate and the\n // default is strictly if a revalidation is explicitly required (action\n // submissions, useRevalidator, X-Remix-Revalidate).\n let shouldRevalidate = shouldRevalidateLoader(fetcherMatch, {\n currentUrl,\n currentParams: state.matches[state.matches.length - 1].params,\n nextUrl,\n nextParams: matches[matches.length - 1].params,\n ...submission,\n actionResult,\n // Forced revalidation due to submission, useRevalidator, or X-Remix-Revalidate\n defaultShouldRevalidate: isRevalidationRequired,\n });\n if (shouldRevalidate) {\n revalidatingFetchers.push({\n key,\n routeId: f.routeId,\n path: f.path,\n matches: fetcherMatches,\n match: fetcherMatch,\n controller: new AbortController(),\n });\n }\n });\n\n return [navigationMatches, revalidatingFetchers];\n}\n\nfunction isNewLoader(\n currentLoaderData: RouteData,\n currentMatch: AgnosticDataRouteMatch,\n match: AgnosticDataRouteMatch\n) {\n let isNew =\n // [a] -> [a, b]\n !currentMatch ||\n // [a, b] -> [a, c]\n match.route.id !== currentMatch.route.id;\n\n // Handle the case that we don't have data for a re-used route, potentially\n // from a prior error or from a cancelled pending deferred\n let isMissingData = currentLoaderData[match.route.id] === undefined;\n\n // Always load if this is a net-new route or we don't yet have data\n return isNew || isMissingData;\n}\n\nfunction isNewRouteInstance(\n currentMatch: AgnosticDataRouteMatch,\n match: AgnosticDataRouteMatch\n) {\n let currentPath = currentMatch.route.path;\n return (\n // param change for this match, /users/123 -> /users/456\n currentMatch.pathname !== match.pathname ||\n // splat param changed, which is not present in match.path\n // e.g. /files/images/avatar.jpg -> files/finances.xls\n (currentPath != null &&\n currentPath.endsWith(\"*\") &&\n currentMatch.params[\"*\"] !== match.params[\"*\"])\n );\n}\n\nfunction shouldRevalidateLoader(\n loaderMatch: AgnosticDataRouteMatch,\n arg: Parameters<ShouldRevalidateFunction>[0]\n) {\n if (loaderMatch.route.shouldRevalidate) {\n let routeChoice = loaderMatch.route.shouldRevalidate(arg);\n if (typeof routeChoice === \"boolean\") {\n return routeChoice;\n }\n }\n\n return arg.defaultShouldRevalidate;\n}\n\n/**\n * Execute route.lazy() methods to lazily load route modules (loader, action,\n * shouldRevalidate) and update the routeManifest in place which shares objects\n * with dataRoutes so those get updated as well.\n */\nasync function loadLazyRouteModule(\n route: AgnosticDataRouteObject,\n mapRouteProperties: MapRoutePropertiesFunction,\n manifest: RouteManifest\n) {\n if (!route.lazy) {\n return;\n }\n\n let lazyRoute = await route.lazy();\n\n // If the lazy route function was executed and removed by another parallel\n // call then we can return - first lazy() to finish wins because the return\n // value of lazy is expected to be static\n if (!route.lazy) {\n return;\n }\n\n let routeToUpdate = manifest[route.id];\n invariant(routeToUpdate, \"No route found in manifest\");\n\n // Update the route in place. This should be safe because there's no way\n // we could yet be sitting on this route as we can't get there without\n // resolving lazy() first.\n //\n // This is different than the HMR \"update\" use-case where we may actively be\n // on the route being updated. The main concern boils down to \"does this\n // mutation affect any ongoing navigations or any current state.matches\n // values?\". If not, it should be safe to update in place.\n let routeUpdates: Record<string, any> = {};\n for (let lazyRouteProperty in lazyRoute) {\n let staticRouteValue =\n routeToUpdate[lazyRouteProperty as keyof typeof routeToUpdate];\n\n let isPropertyStaticallyDefined =\n staticRouteValue !== undefined &&\n // This property isn't static since it should always be updated based\n // on the route updates\n lazyRouteProperty !== \"hasErrorBoundary\";\n\n warning(\n !isPropertyStaticallyDefined,\n `Route \"${routeToUpdate.id}\" has a static property \"${lazyRouteProperty}\" ` +\n `defined but its lazy function is also returning a value for this property. ` +\n `The lazy route property \"${lazyRouteProperty}\" will be ignored.`\n );\n\n if (\n !isPropertyStaticallyDefined &&\n !immutableRouteKeys.has(lazyRouteProperty as ImmutableRouteKey)\n ) {\n routeUpdates[lazyRouteProperty] =\n lazyRoute[lazyRouteProperty as keyof typeof lazyRoute];\n }\n }\n\n // Mutate the route with the provided updates. Do this first so we pass\n // the updated version to mapRouteProperties\n Object.assign(routeToUpdate, routeUpdates);\n\n // Mutate the `hasErrorBoundary` property on the route based on the route\n // updates and remove the `lazy` function so we don't resolve the lazy\n // route again.\n Object.assign(routeToUpdate, {\n // To keep things framework agnostic, we use the provided\n // `mapRouteProperties` (or wrapped `detectErrorBoundary`) function to\n // set the framework-aware properties (`element`/`hasErrorBoundary`) since\n // the logic will differ between frameworks.\n ...mapRouteProperties(routeToUpdate),\n lazy: undefined,\n });\n}\n\nasync function callLoaderOrAction(\n type: \"loader\" | \"action\",\n request: Request,\n match: AgnosticDataRouteMatch,\n matches: AgnosticDataRouteMatch[],\n manifest: RouteManifest,\n mapRouteProperties: MapRoutePropertiesFunction,\n basename: string,\n isStaticRequest: boolean = false,\n isRouteRequest: boolean = false,\n requestContext?: unknown\n): Promise<DataResult> {\n let resultType;\n let result;\n let onReject: (() => void) | undefined;\n\n let runHandler = (handler: ActionFunction | LoaderFunction) => {\n // Setup a promise we can race against so that abort signals short circuit\n let reject: () => void;\n let abortPromise = new Promise((_, r) => (reject = r));\n onReject = () => reject();\n request.signal.addEventListener(\"abort\", onReject);\n return Promise.race([\n handler({ request, params: match.params, context: requestContext }),\n abortPromise,\n ]);\n };\n\n try {\n let handler = match.route[type];\n\n if (match.route.lazy) {\n if (handler) {\n // Run statically defined handler in parallel with lazy()\n let values = await Promise.all([\n runHandler(handler),\n loadLazyRouteModule(match.route, mapRouteProperties, manifest),\n ]);\n result = values[0];\n } else {\n // Load lazy route module, then run any returned handler\n await loadLazyRouteModule(match.route, mapRouteProperties, manifest);\n\n handler = match.route[type];\n if (handler) {\n // Handler still run even if we got interrupted to maintain consistency\n // with un-abortable behavior of handler execution on non-lazy or\n // previously-lazy-loaded routes\n result = await runHandler(handler);\n } else if (type === \"action\") {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(405, {\n method: request.method,\n pathname,\n routeId: match.route.id,\n });\n } else {\n // lazy() route has no loader to run. Short circuit here so we don't\n // hit the invariant below that errors on returning undefined.\n return { type: ResultType.data, data: undefined };\n }\n }\n } else if (!handler) {\n let url = new URL(request.url);\n let pathname = url.pathname + url.search;\n throw getInternalRouterError(404, {\n pathname,\n });\n } else {\n result = await runHandler(handler);\n }\n\n invariant(\n result !== undefined,\n `You defined ${type === \"action\" ? \"an action\" : \"a loader\"} for route ` +\n `\"${match.route.id}\" but didn't return anything from your \\`${type}\\` ` +\n `function. Please return a value or \\`null\\`.`\n );\n } catch (e) {\n resultType = ResultType.error;\n result = e;\n } finally {\n if (onReject) {\n request.signal.removeEventListener(\"abort\", onReject);\n }\n }\n\n if (isResponse(result)) {\n let status = result.status;\n\n // Process redirects\n if (redirectStatusCodes.has(status)) {\n let location = result.headers.get(\"Location\");\n invariant(\n location,\n \"Redirects returned/thrown from loaders/actions must have a Location header\"\n );\n\n // Support relative routing in internal redirects\n if (!ABSOLUTE_URL_REGEX.test(location)) {\n location = normalizeTo(\n new URL(request.url),\n matches.slice(0, matches.indexOf(match) + 1),\n basename,\n true,\n location\n );\n } else if (!isStaticRequest) {\n // Strip off the protocol+origin for same-origin + same-basename absolute\n // redirects. If this is a static request, we can let it go back to the\n // browser as-is\n let currentUrl = new URL(request.url);\n let url = location.startsWith(\"//\")\n ? new URL(currentUrl.protocol + location)\n : new URL(location);\n let isSameBasename = stripBasename(url.pathname, basename) != null;\n if (url.origin === currentUrl.origin && isSameBasename) {\n location = url.pathname + url.search + url.hash;\n }\n }\n\n // Don't process redirects in the router during static requests requests.\n // Instead, throw the Response and let the server handle it with an HTTP\n // redirect. We also update the Location header in place in this flow so\n // basename and relative routing is taken into account\n if (isStaticRequest) {\n result.headers.set(\"Location\", location);\n throw result;\n }\n\n return {\n type: ResultType.redirect,\n status,\n location,\n revalidate: result.headers.get(\"X-Remix-Revalidate\") !== null,\n };\n }\n\n // For SSR single-route requests, we want to hand Responses back directly\n // without unwrapping. We do this with the QueryRouteResponse wrapper\n // interface so we can know whether it was returned or thrown\n if (isRouteRequest) {\n // eslint-disable-next-line no-throw-literal\n throw {\n type: resultType || ResultType.data,\n response: result,\n };\n }\n\n let data: any;\n let contentType = result.headers.get(\"Content-Type\");\n // Check between word boundaries instead of startsWith() due to the last\n // paragraph of https://httpwg.org/specs/rfc9110.html#field.content-type\n if (contentType && /\\bapplication\\/json\\b/.test(contentType)) {\n data = await result.json();\n } else {\n data = await result.text();\n }\n\n if (resultType === ResultType.error) {\n return {\n type: resultType,\n error: new ErrorResponse(status, result.statusText, data),\n headers: result.headers,\n };\n }\n\n return {\n type: ResultType.data,\n data,\n statusCode: result.status,\n headers: result.headers,\n };\n }\n\n if (resultType === ResultType.error) {\n return { type: resultType, error: result };\n }\n\n if (isDeferredData(result)) {\n return {\n type: ResultType.deferred,\n deferredData: result,\n statusCode: result.init?.status,\n headers: result.init?.headers && new Headers(result.init.headers),\n };\n }\n\n return { type: ResultType.data, data: result };\n}\n\n// Utility method for creating the Request instances for loaders/actions during\n// client-side navigations and fetches. During SSR we will always have a\n// Request instance from the static handler (query/queryRoute)\nfunction createClientSideRequest(\n history: History,\n location: string | Location,\n signal: AbortSignal,\n submission?: Submission\n): Request {\n let url = history.createURL(stripHashFromPath(location)).toString();\n let init: RequestInit = { signal };\n\n if (submission && isMutationMethod(submission.formMethod)) {\n let { formMethod, formEncType, formData } = submission;\n // Didn't think we needed this but it turns out unlike other methods, patch\n // won't be properly normalized to uppercase and results in a 405 error.\n // See: https://fetch.spec.whatwg.org/#concept-method\n init.method = formMethod.toUpperCase();\n init.body =\n formEncType === \"application/x-www-form-urlencoded\"\n ? convertFormDataToSearchParams(formData)\n : formData;\n }\n\n // Content-Type is inferred (https://fetch.spec.whatwg.org/#dom-request)\n return new Request(url, init);\n}\n\nfunction convertFormDataToSearchParams(formData: FormData): URLSearchParams {\n let searchParams = new URLSearchParams();\n\n for (let [key, value] of formData.entries()) {\n // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#converting-an-entry-list-to-a-list-of-name-value-pairs\n searchParams.append(key, value instanceof File ? value.name : value);\n }\n\n return searchParams;\n}\n\nfunction processRouteLoaderData(\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n results: DataResult[],\n pendingError: RouteData | undefined,\n activeDeferreds: Map<string, DeferredData>\n): {\n loaderData: RouterState[\"loaderData\"];\n errors: RouterState[\"errors\"] | null;\n statusCode: number;\n loaderHeaders: Record<string, Headers>;\n} {\n // Fill in loaderData/errors from our loaders\n let loaderData: RouterState[\"loaderData\"] = {};\n let errors: RouterState[\"errors\"] | null = null;\n let statusCode: number | undefined;\n let foundError = false;\n let loaderHeaders: Record<string, Headers> = {};\n\n // Process loader results into state.loaderData/state.errors\n results.forEach((result, index) => {\n let id = matchesToLoad[index].route.id;\n invariant(\n !isRedirectResult(result),\n \"Cannot handle redirect results in processLoaderData\"\n );\n if (isErrorResult(result)) {\n // Look upwards from the matched route for the closest ancestor\n // error boundary, defaulting to the root match\n let boundaryMatch = findNearestBoundary(matches, id);\n let error = result.error;\n // If we have a pending action error, we report it at the highest-route\n // that throws a loader error, and then clear it out to indicate that\n // it was consumed\n if (pendingError) {\n error = Object.values(pendingError)[0];\n pendingError = undefined;\n }\n\n errors = errors || {};\n\n // Prefer higher error values if lower errors bubble to the same boundary\n if (errors[boundaryMatch.route.id] == null) {\n errors[boundaryMatch.route.id] = error;\n }\n\n // Clear our any prior loaderData for the throwing route\n loaderData[id] = undefined;\n\n // Once we find our first (highest) error, we set the status code and\n // prevent deeper status codes from overriding\n if (!foundError) {\n foundError = true;\n statusCode = isRouteErrorResponse(result.error)\n ? result.error.status\n : 500;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n } else {\n if (isDeferredResult(result)) {\n activeDeferreds.set(id, result.deferredData);\n loaderData[id] = result.deferredData.data;\n } else {\n loaderData[id] = result.data;\n }\n\n // Error status codes always override success status codes, but if all\n // loaders are successful we take the deepest status code.\n if (\n result.statusCode != null &&\n result.statusCode !== 200 &&\n !foundError\n ) {\n statusCode = result.statusCode;\n }\n if (result.headers) {\n loaderHeaders[id] = result.headers;\n }\n }\n });\n\n // If we didn't consume the pending action error (i.e., all loaders\n // resolved), then consume it here. Also clear out any loaderData for the\n // throwing route\n if (pendingError) {\n errors = pendingError;\n loaderData[Object.keys(pendingError)[0]] = undefined;\n }\n\n return {\n loaderData,\n errors,\n statusCode: statusCode || 200,\n loaderHeaders,\n };\n}\n\nfunction processLoaderData(\n state: RouterState,\n matches: AgnosticDataRouteMatch[],\n matchesToLoad: AgnosticDataRouteMatch[],\n results: DataResult[],\n pendingError: RouteData | undefined,\n revalidatingFetchers: RevalidatingFetcher[],\n fetcherResults: DataResult[],\n activeDeferreds: Map<string, DeferredData>\n): {\n loaderData: RouterState[\"loaderData\"];\n errors?: RouterState[\"errors\"];\n} {\n let { loaderData, errors } = processRouteLoaderData(\n matches,\n matchesToLoad,\n results,\n pendingError,\n activeDeferreds\n );\n\n // Process results from our revalidating fetchers\n for (let index = 0; index < revalidatingFetchers.length; index++) {\n let { key, match, controller } = revalidatingFetchers[index];\n invariant(\n fetcherResults !== undefined && fetcherResults[index] !== undefined,\n \"Did not find corresponding fetcher result\"\n );\n let result = fetcherResults[index];\n\n // Process fetcher non-redirect errors\n if (controller && controller.signal.aborted) {\n // Nothing to do for aborted fetchers\n continue;\n } else if (isErrorResult(result)) {\n let boundaryMatch = findNearestBoundary(state.matches, match?.route.id);\n if (!(errors && errors[boundaryMatch.route.id])) {\n errors = {\n ...errors,\n [boundaryMatch.route.id]: result.error,\n };\n }\n state.fetchers.delete(key);\n } else if (isRedirectResult(result)) {\n // Should never get here, redirects should get processed above, but we\n // keep this to type narrow to a success result in the else\n invariant(false, \"Unhandled fetcher revalidation redirect\");\n } else if (isDeferredResult(result)) {\n // Should never get here, deferred data should be awaited for fetchers\n // in resolveDeferredResults\n invariant(false, \"Unhandled fetcher deferred data\");\n } else {\n let doneFetcher: FetcherStates[\"Idle\"] = {\n state: \"idle\",\n data: result.data,\n formMethod: undefined,\n formAction: undefined,\n formEncType: undefined,\n formData: undefined,\n \" _hasFetcherDoneAnything \": true,\n };\n state.fetchers.set(key, doneFetcher);\n }\n }\n\n return { loaderData, errors };\n}\n\nfunction mergeLoaderData(\n loaderData: RouteData,\n newLoaderData: RouteData,\n matches: AgnosticDataRouteMatch[],\n errors: RouteData | null | undefined\n): RouteData {\n let mergedLoaderData = { ...newLoaderData };\n for (let match of matches) {\n let id = match.route.id;\n if (newLoaderData.hasOwnProperty(id)) {\n if (newLoaderData[id] !== undefined) {\n mergedLoaderData[id] = newLoaderData[id];\n } else {\n // No-op - this is so we ignore existing data if we have a key in the\n // incoming object with an undefined value, which is how we unset a prior\n // loaderData if we encounter a loader error\n }\n } else if (loaderData[id] !== undefined && match.route.loader) {\n // Preserve existing keys not included in newLoaderData and where a loader\n // wasn't removed by HMR\n mergedLoaderData[id] = loaderData[id];\n }\n\n if (errors && errors.hasOwnProperty(id)) {\n // Don't keep any loader data below the boundary\n break;\n }\n }\n return mergedLoaderData;\n}\n\n// Find the nearest error boundary, looking upwards from the leaf route (or the\n// route specified by routeId) for the closest ancestor error boundary,\n// defaulting to the root match\nfunction findNearestBoundary(\n matches: AgnosticDataRouteMatch[],\n routeId?: string\n): AgnosticDataRouteMatch {\n let eligibleMatches = routeId\n ? matches.slice(0, matches.findIndex((m) => m.route.id === routeId) + 1)\n : [...matches];\n return (\n eligibleMatches.reverse().find((m) => m.route.hasErrorBoundary === true) ||\n matches[0]\n );\n}\n\nfunction getShortCircuitMatches(routes: AgnosticDataRouteObject[]): {\n matches: AgnosticDataRouteMatch[];\n route: AgnosticDataRouteObject;\n} {\n // Prefer a root layout route if present, otherwise shim in a route object\n let route = routes.find((r) => r.index || !r.path || r.path === \"/\") || {\n id: `__shim-error-route__`,\n };\n\n return {\n matches: [\n {\n params: {},\n pathname: \"\",\n pathnameBase: \"\",\n route,\n },\n ],\n route,\n };\n}\n\nfunction getInternalRouterError(\n status: number,\n {\n pathname,\n routeId,\n method,\n type,\n }: {\n pathname?: string;\n routeId?: string;\n method?: string;\n type?: \"defer-action\";\n } = {}\n) {\n let statusText = \"Unknown Server Error\";\n let errorMessage = \"Unknown @remix-run/router error\";\n\n if (status === 400) {\n statusText = \"Bad Request\";\n if (method && pathname && routeId) {\n errorMessage =\n `You made a ${method} request to \"${pathname}\" but ` +\n `did not provide a \\`loader\\` for route \"${routeId}\", ` +\n `so there is no way to handle the request.`;\n } else if (type === \"defer-action\") {\n errorMessage = \"defer() is not supported in actions\";\n }\n } else if (status === 403) {\n statusText = \"Forbidden\";\n errorMessage = `Route \"${routeId}\" does not match URL \"${pathname}\"`;\n } else if (status === 404) {\n statusText = \"Not Found\";\n errorMessage = `No route matches URL \"${pathname}\"`;\n } else if (status === 405) {\n statusText = \"Method Not Allowed\";\n if (method && pathname && routeId) {\n errorMessage =\n `You made a ${method.toUpperCase()} request to \"${pathname}\" but ` +\n `did not provide an \\`action\\` for route \"${routeId}\", ` +\n `so there is no way to handle the request.`;\n } else if (method) {\n errorMessage = `Invalid request method \"${method.toUpperCase()}\"`;\n }\n }\n\n return new ErrorResponse(\n status || 500,\n statusText,\n new Error(errorMessage),\n true\n );\n}\n\n// Find any returned redirect errors, starting from the lowest match\nfunction findRedirect(results: DataResult[]): RedirectResult | undefined {\n for (let i = results.length - 1; i >= 0; i--) {\n let result = results[i];\n if (isRedirectResult(result)) {\n return result;\n }\n }\n}\n\nfunction stripHashFromPath(path: To) {\n let parsedPath = typeof path === \"string\" ? parsePath(path) : path;\n return createPath({ ...parsedPath, hash: \"\" });\n}\n\nfunction isHashChangeOnly(a: Location, b: Location): boolean {\n if (a.pathname !== b.pathname || a.search !== b.search) {\n return false;\n }\n\n if (a.hash === \"\") {\n // No hash -> hash\n return b.hash !== \"\";\n } else if (a.hash === b.hash) {\n // current hash -> same hash\n return true;\n } else if (b.hash !== \"\") {\n // current hash -> new hash\n return true;\n }\n\n return false;\n}\n\nfunction isDeferredResult(result: DataResult): result is DeferredResult {\n return result.type === ResultType.deferred;\n}\n\nfunction isErrorResult(result: DataResult): result is ErrorResult {\n return result.type === ResultType.error;\n}\n\nfunction isRedirectResult(result?: DataResult): result is RedirectResult {\n return (result && result.type) === ResultType.redirect;\n}\n\nexport function isDeferredData(value: any): value is DeferredData {\n let deferred: DeferredData = value;\n return (\n deferred &&\n typeof deferred === \"object\" &&\n typeof deferred.data === \"object\" &&\n typeof deferred.subscribe === \"function\" &&\n typeof deferred.cancel === \"function\" &&\n typeof deferred.resolveData === \"function\"\n );\n}\n\nfunction isResponse(value: any): value is Response {\n return (\n value != null &&\n typeof value.status === \"number\" &&\n typeof value.statusText === \"string\" &&\n typeof value.headers === \"object\" &&\n typeof value.body !== \"undefined\"\n );\n}\n\nfunction isRedirectResponse(result: any): result is Response {\n if (!isResponse(result)) {\n return false;\n }\n\n let status = result.status;\n let location = result.headers.get(\"Location\");\n return status >= 300 && status <= 399 && location != null;\n}\n\nfunction isQueryRouteResponse(obj: any): obj is QueryRouteResponse {\n return (\n obj &&\n isResponse(obj.response) &&\n (obj.type === ResultType.data || ResultType.error)\n );\n}\n\nfunction isValidMethod(method: string): method is FormMethod | V7_FormMethod {\n return validRequestMethods.has(method.toLowerCase() as FormMethod);\n}\n\nfunction isMutationMethod(\n method: string\n): method is MutationFormMethod | V7_MutationFormMethod {\n return validMutationMethods.has(method.toLowerCase() as MutationFormMethod);\n}\n\nasync function resolveDeferredResults(\n currentMatches: AgnosticDataRouteMatch[],\n matchesToLoad: (AgnosticDataRouteMatch | null)[],\n results: DataResult[],\n signals: (AbortSignal | null)[],\n isFetcher: boolean,\n currentLoaderData?: RouteData\n) {\n for (let index = 0; index < results.length; index++) {\n let result = results[index];\n let match = matchesToLoad[index];\n // If we don't have a match, then we can have a deferred result to do\n // anything with. This is for revalidating fetchers where the route was\n // removed during HMR\n if (!match) {\n continue;\n }\n\n let currentMatch = currentMatches.find(\n (m) => m.route.id === match!.route.id\n );\n let isRevalidatingLoader =\n currentMatch != null &&\n !isNewRouteInstance(currentMatch, match) &&\n (currentLoaderData && currentLoaderData[match.route.id]) !== undefined;\n\n if (isDeferredResult(result) && (isFetcher || isRevalidatingLoader)) {\n // Note: we do not have to touch activeDeferreds here since we race them\n // against the signal in resolveDeferredData and they'll get aborted\n // there if needed\n let signal = signals[index];\n invariant(\n signal,\n \"Expected an AbortSignal for revalidating fetcher deferred result\"\n );\n await resolveDeferredData(result, signal, isFetcher).then((result) => {\n if (result) {\n results[index] = result || results[index];\n }\n });\n }\n }\n}\n\nasync function resolveDeferredData(\n result: DeferredResult,\n signal: AbortSignal,\n unwrap = false\n): Promise<SuccessResult | ErrorResult | undefined> {\n let aborted = await result.deferredData.resolveData(signal);\n if (aborted) {\n return;\n }\n\n if (unwrap) {\n try {\n return {\n type: ResultType.data,\n data: result.deferredData.unwrappedData,\n };\n } catch (e) {\n // Handle any TrackedPromise._error values encountered while unwrapping\n return {\n type: ResultType.error,\n error: e,\n };\n }\n }\n\n return {\n type: ResultType.data,\n data: result.deferredData.data,\n };\n}\n\nfunction hasNakedIndexQuery(search: string): boolean {\n return new URLSearchParams(search).getAll(\"index\").some((v) => v === \"\");\n}\n\n// Note: This should match the format exported by useMatches, so if you change\n// this please also change that :) Eventually we'll DRY this up\nfunction createUseMatchesMatch(\n match: AgnosticDataRouteMatch,\n loaderData: RouteData\n): UseMatchesMatch {\n let { route, pathname, params } = match;\n return {\n id: route.id,\n pathname,\n params,\n data: loaderData[route.id] as unknown,\n handle: route.handle as unknown,\n };\n}\n\nfunction getTargetMatch(\n matches: AgnosticDataRouteMatch[],\n location: Location | string\n) {\n let search =\n typeof location === \"string\" ? parsePath(location).search : location.search;\n if (\n matches[matches.length - 1].route.index &&\n hasNakedIndexQuery(search || \"\")\n ) {\n // Return the leaf index route when index is present\n return matches[matches.length - 1];\n }\n // Otherwise grab the deepest \"path contributing\" match (ignoring index and\n // pathless layout routes)\n let pathMatches = getPathContributingMatches(matches);\n return pathMatches[pathMatches.length - 1];\n}\n//#endregion\n","import * as React from \"react\";\nimport type {\n AgnosticRouteMatch,\n AgnosticIndexRouteObject,\n AgnosticNonIndexRouteObject,\n History,\n Location,\n RelativeRoutingType,\n Router,\n StaticHandlerContext,\n To,\n TrackedPromise,\n LazyRouteFunction,\n} from \"@remix-run/router\";\nimport type { Action as NavigationType } from \"@remix-run/router\";\n\n// Create react-specific types from the agnostic types in @remix-run/router to\n// export from react-router\nexport interface IndexRouteObject {\n caseSensitive?: AgnosticIndexRouteObject[\"caseSensitive\"];\n path?: AgnosticIndexRouteObject[\"path\"];\n id?: AgnosticIndexRouteObject[\"id\"];\n loader?: AgnosticIndexRouteObject[\"loader\"];\n action?: AgnosticIndexRouteObject[\"action\"];\n hasErrorBoundary?: AgnosticIndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: AgnosticIndexRouteObject[\"shouldRevalidate\"];\n handle?: AgnosticIndexRouteObject[\"handle\"];\n index: true;\n children?: undefined;\n element?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n Component?: React.ComponentType | null;\n ErrorBoundary?: React.ComponentType | null;\n lazy?: LazyRouteFunction<IndexRouteObject>;\n}\n\nexport interface NonIndexRouteObject {\n caseSensitive?: AgnosticNonIndexRouteObject[\"caseSensitive\"];\n path?: AgnosticNonIndexRouteObject[\"path\"];\n id?: AgnosticNonIndexRouteObject[\"id\"];\n loader?: AgnosticNonIndexRouteObject[\"loader\"];\n action?: AgnosticNonIndexRouteObject[\"action\"];\n hasErrorBoundary?: AgnosticNonIndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: AgnosticNonIndexRouteObject[\"shouldRevalidate\"];\n handle?: AgnosticNonIndexRouteObject[\"handle\"];\n index?: false;\n children?: RouteObject[];\n element?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n Component?: React.ComponentType | null;\n ErrorBoundary?: React.ComponentType | null;\n lazy?: LazyRouteFunction<NonIndexRouteObject>;\n}\n\nexport type RouteObject = IndexRouteObject | NonIndexRouteObject;\n\nexport type DataRouteObject = RouteObject & {\n children?: DataRouteObject[];\n id: string;\n};\n\nexport interface RouteMatch<\n ParamKey extends string = string,\n RouteObjectType extends RouteObject = RouteObject\n> extends AgnosticRouteMatch<ParamKey, RouteObjectType> {}\n\nexport interface DataRouteMatch extends RouteMatch<string, DataRouteObject> {}\n\nexport interface DataRouterContextObject extends NavigationContextObject {\n router: Router;\n staticContext?: StaticHandlerContext;\n}\n\nexport const DataRouterContext =\n React.createContext<DataRouterContextObject | null>(null);\nif (__DEV__) {\n DataRouterContext.displayName = \"DataRouter\";\n}\n\nexport const DataRouterStateContext = React.createContext<\n Router[\"state\"] | null\n>(null);\nif (__DEV__) {\n DataRouterStateContext.displayName = \"DataRouterState\";\n}\n\nexport const AwaitContext = React.createContext<TrackedPromise | null>(null);\nif (__DEV__) {\n AwaitContext.displayName = \"Await\";\n}\n\nexport interface NavigateOptions {\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n}\n\n/**\n * A Navigator is a \"location changer\"; it's how you get to different locations.\n *\n * Every history instance conforms to the Navigator interface, but the\n * distinction is useful primarily when it comes to the low-level <Router> API\n * where both the location and a navigator must be provided separately in order\n * to avoid \"tearing\" that may occur in a suspense-enabled app if the action\n * and/or location were to be read directly from the history instance.\n */\nexport interface Navigator {\n createHref: History[\"createHref\"];\n // Optional for backwards-compat with Router/HistoryRouter usage (edge case)\n encodeLocation?: History[\"encodeLocation\"];\n go: History[\"go\"];\n push(to: To, state?: any, opts?: NavigateOptions): void;\n replace(to: To, state?: any, opts?: NavigateOptions): void;\n}\n\ninterface NavigationContextObject {\n basename: string;\n navigator: Navigator;\n static: boolean;\n}\n\nexport const NavigationContext = React.createContext<NavigationContextObject>(\n null!\n);\n\nif (__DEV__) {\n NavigationContext.displayName = \"Navigation\";\n}\n\ninterface LocationContextObject {\n location: Location;\n navigationType: NavigationType;\n}\n\nexport const LocationContext = React.createContext<LocationContextObject>(\n null!\n);\n\nif (__DEV__) {\n LocationContext.displayName = \"Location\";\n}\n\nexport interface RouteContextObject {\n outlet: React.ReactElement | null;\n matches: RouteMatch[];\n isDataRoute: boolean;\n}\n\nexport const RouteContext = React.createContext<RouteContextObject>({\n outlet: null,\n matches: [],\n isDataRoute: false,\n});\n\nif (__DEV__) {\n RouteContext.displayName = \"Route\";\n}\n\nexport const RouteErrorContext = React.createContext<any>(null);\n\nif (__DEV__) {\n RouteErrorContext.displayName = \"RouteError\";\n}\n","import * as React from \"react\";\nimport type {\n Blocker,\n BlockerFunction,\n Location,\n ParamParseKey,\n Params,\n Path,\n PathMatch,\n PathPattern,\n RelativeRoutingType,\n Router as RemixRouter,\n RevalidationState,\n To,\n} from \"@remix-run/router\";\nimport {\n Action as NavigationType,\n UNSAFE_invariant as invariant,\n isRouteErrorResponse,\n joinPaths,\n matchPath,\n matchRoutes,\n parsePath,\n resolveTo,\n UNSAFE_getPathContributingMatches as getPathContributingMatches,\n UNSAFE_warning as warning,\n} from \"@remix-run/router\";\n\nimport type {\n NavigateOptions,\n RouteContextObject,\n RouteMatch,\n RouteObject,\n DataRouteMatch,\n} from \"./context\";\nimport {\n DataRouterContext,\n DataRouterStateContext,\n LocationContext,\n NavigationContext,\n RouteContext,\n RouteErrorContext,\n AwaitContext,\n} from \"./context\";\n\n/**\n * Returns the full href for the given \"to\" value. This is useful for building\n * custom links that are also accessible and preserve right-click behavior.\n *\n * @see https://reactrouter.com/hooks/use-href\n */\nexport function useHref(\n to: To,\n { relative }: { relative?: RelativeRoutingType } = {}\n): string {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useHref() may be used only in the context of a <Router> component.`\n );\n\n let { basename, navigator } = React.useContext(NavigationContext);\n let { hash, pathname, search } = useResolvedPath(to, { relative });\n\n let joinedPathname = pathname;\n\n // If we're operating within a basename, prepend it to the pathname prior\n // to creating the href. If this is a root navigation, then just use the raw\n // basename which allows the basename to have full control over the presence\n // of a trailing slash on root links\n if (basename !== \"/\") {\n joinedPathname =\n pathname === \"/\" ? basename : joinPaths([basename, pathname]);\n }\n\n return navigator.createHref({ pathname: joinedPathname, search, hash });\n}\n\n/**\n * Returns true if this component is a descendant of a <Router>.\n *\n * @see https://reactrouter.com/hooks/use-in-router-context\n */\nexport function useInRouterContext(): boolean {\n return React.useContext(LocationContext) != null;\n}\n\n/**\n * Returns the current location object, which represents the current URL in web\n * browsers.\n *\n * Note: If you're using this it may mean you're doing some of your own\n * \"routing\" in your app, and we'd like to know what your use case is. We may\n * be able to provide something higher-level to better suit your needs.\n *\n * @see https://reactrouter.com/hooks/use-location\n */\nexport function useLocation(): Location {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useLocation() may be used only in the context of a <Router> component.`\n );\n\n return React.useContext(LocationContext).location;\n}\n\n/**\n * Returns the current navigation action which describes how the router came to\n * the current location, either by a pop, push, or replace on the history stack.\n *\n * @see https://reactrouter.com/hooks/use-navigation-type\n */\nexport function useNavigationType(): NavigationType {\n return React.useContext(LocationContext).navigationType;\n}\n\n/**\n * Returns a PathMatch object if the given pattern matches the current URL.\n * This is useful for components that need to know \"active\" state, e.g.\n * <NavLink>.\n *\n * @see https://reactrouter.com/hooks/use-match\n */\nexport function useMatch<\n ParamKey extends ParamParseKey<Path>,\n Path extends string\n>(pattern: PathPattern<Path> | Path): PathMatch<ParamKey> | null {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useMatch() may be used only in the context of a <Router> component.`\n );\n\n let { pathname } = useLocation();\n return React.useMemo(\n () => matchPath<ParamKey, Path>(pattern, pathname),\n [pathname, pattern]\n );\n}\n\n/**\n * The interface for the navigate() function returned from useNavigate().\n */\nexport interface NavigateFunction {\n (to: To, options?: NavigateOptions): void;\n (delta: number): void;\n}\n\nconst navigateEffectWarning =\n `You should call navigate() in a React.useEffect(), not when ` +\n `your component is first rendered.`;\n\n// Mute warnings for calls to useNavigate in SSR environments\nfunction useIsomorphicLayoutEffect(\n cb: Parameters<typeof React.useLayoutEffect>[0]\n) {\n let isStatic = React.useContext(NavigationContext).static;\n if (!isStatic) {\n // We should be able to get rid of this once react 18.3 is released\n // See: https://github.com/facebook/react/pull/26395\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useLayoutEffect(cb);\n }\n}\n\n/**\n * Returns an imperative method for changing the location. Used by <Link>s, but\n * may also be used by other elements to change the location.\n *\n * @see https://reactrouter.com/hooks/use-navigate\n */\nexport function useNavigate(): NavigateFunction {\n let { isDataRoute } = React.useContext(RouteContext);\n // Conditional usage is OK here because the usage of a data router is static\n // eslint-disable-next-line react-hooks/rules-of-hooks\n return isDataRoute ? useNavigateStable() : useNavigateUnstable();\n}\n\nfunction useNavigateUnstable(): NavigateFunction {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useNavigate() may be used only in the context of a <Router> component.`\n );\n\n let { basename, navigator } = React.useContext(NavigationContext);\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n\n let routePathnamesJson = JSON.stringify(\n getPathContributingMatches(matches).map((match) => match.pathnameBase)\n );\n\n let activeRef = React.useRef(false);\n useIsomorphicLayoutEffect(() => {\n activeRef.current = true;\n });\n\n let navigate: NavigateFunction = React.useCallback(\n (to: To | number, options: NavigateOptions = {}) => {\n warning(activeRef.current, navigateEffectWarning);\n\n // Short circuit here since if this happens on first render the navigate\n // is useless because we haven't wired up our history listener yet\n if (!activeRef.current) return;\n\n if (typeof to === \"number\") {\n navigator.go(to);\n return;\n }\n\n let path = resolveTo(\n to,\n JSON.parse(routePathnamesJson),\n locationPathname,\n options.relative === \"path\"\n );\n\n // If we're operating within a basename, prepend it to the pathname prior\n // to handing off to history. If this is a root navigation, then we\n // navigate to the raw basename which allows the basename to have full\n // control over the presence of a trailing slash on root links\n if (basename !== \"/\") {\n path.pathname =\n path.pathname === \"/\"\n ? basename\n : joinPaths([basename, path.pathname]);\n }\n\n (!!options.replace ? navigator.replace : navigator.push)(\n path,\n options.state,\n options\n );\n },\n [basename, navigator, routePathnamesJson, locationPathname]\n );\n\n return navigate;\n}\n\nconst OutletContext = React.createContext<unknown>(null);\n\n/**\n * Returns the context (if provided) for the child route at this level of the route\n * hierarchy.\n * @see https://reactrouter.com/hooks/use-outlet-context\n */\nexport function useOutletContext<Context = unknown>(): Context {\n return React.useContext(OutletContext) as Context;\n}\n\n/**\n * Returns the element for the child route at this level of the route\n * hierarchy. Used internally by <Outlet> to render child routes.\n *\n * @see https://reactrouter.com/hooks/use-outlet\n */\nexport function useOutlet(context?: unknown): React.ReactElement | null {\n let outlet = React.useContext(RouteContext).outlet;\n if (outlet) {\n return (\n <OutletContext.Provider value={context}>{outlet}</OutletContext.Provider>\n );\n }\n return outlet;\n}\n\n/**\n * Returns an object of key/value pairs of the dynamic params from the current\n * URL that were matched by the route path.\n *\n * @see https://reactrouter.com/hooks/use-params\n */\nexport function useParams<\n ParamsOrKey extends string | Record<string, string | undefined> = string\n>(): Readonly<\n [ParamsOrKey] extends [string] ? Params<ParamsOrKey> : Partial<ParamsOrKey>\n> {\n let { matches } = React.useContext(RouteContext);\n let routeMatch = matches[matches.length - 1];\n return routeMatch ? (routeMatch.params as any) : {};\n}\n\n/**\n * Resolves the pathname of the given `to` value against the current location.\n *\n * @see https://reactrouter.com/hooks/use-resolved-path\n */\nexport function useResolvedPath(\n to: To,\n { relative }: { relative?: RelativeRoutingType } = {}\n): Path {\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n\n let routePathnamesJson = JSON.stringify(\n getPathContributingMatches(matches).map((match) => match.pathnameBase)\n );\n\n return React.useMemo(\n () =>\n resolveTo(\n to,\n JSON.parse(routePathnamesJson),\n locationPathname,\n relative === \"path\"\n ),\n [to, routePathnamesJson, locationPathname, relative]\n );\n}\n\n/**\n * Returns the element of the route that matched the current location, prepared\n * with the correct context to render the remainder of the route tree. Route\n * elements in the tree must render an <Outlet> to render their child route's\n * element.\n *\n * @see https://reactrouter.com/hooks/use-routes\n */\nexport function useRoutes(\n routes: RouteObject[],\n locationArg?: Partial<Location> | string\n): React.ReactElement | null {\n return useRoutesImpl(routes, locationArg);\n}\n\n// Internal implementation with accept optional param for RouterProvider usage\nexport function useRoutesImpl(\n routes: RouteObject[],\n locationArg?: Partial<Location> | string,\n dataRouterState?: RemixRouter[\"state\"]\n): React.ReactElement | null {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of the\n // router loaded. We can help them understand how to avoid that.\n `useRoutes() may be used only in the context of a <Router> component.`\n );\n\n let { navigator } = React.useContext(NavigationContext);\n let { matches: parentMatches } = React.useContext(RouteContext);\n let routeMatch = parentMatches[parentMatches.length - 1];\n let parentParams = routeMatch ? routeMatch.params : {};\n let parentPathname = routeMatch ? routeMatch.pathname : \"/\";\n let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : \"/\";\n let parentRoute = routeMatch && routeMatch.route;\n\n if (__DEV__) {\n // You won't get a warning about 2 different <Routes> under a <Route>\n // without a trailing *, but this is a best-effort warning anyway since we\n // cannot even give the warning unless they land at the parent route.\n //\n // Example:\n //\n // <Routes>\n // {/* This route path MUST end with /* because otherwise\n // it will never match /blog/post/123 */}\n // <Route path=\"blog\" element={<Blog />} />\n // <Route path=\"blog/feed\" element={<BlogFeed />} />\n // </Routes>\n //\n // function Blog() {\n // return (\n // <Routes>\n // <Route path=\"post/:id\" element={<Post />} />\n // </Routes>\n // );\n // }\n let parentPath = (parentRoute && parentRoute.path) || \"\";\n warningOnce(\n parentPathname,\n !parentRoute || parentPath.endsWith(\"*\"),\n `You rendered descendant <Routes> (or called \\`useRoutes()\\`) at ` +\n `\"${parentPathname}\" (under <Route path=\"${parentPath}\">) but the ` +\n `parent route path has no trailing \"*\". This means if you navigate ` +\n `deeper, the parent won't match anymore and therefore the child ` +\n `routes will never render.\\n\\n` +\n `Please change the parent <Route path=\"${parentPath}\"> to <Route ` +\n `path=\"${parentPath === \"/\" ? \"*\" : `${parentPath}/*`}\">.`\n );\n }\n\n let locationFromContext = useLocation();\n\n let location;\n if (locationArg) {\n let parsedLocationArg =\n typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n\n invariant(\n parentPathnameBase === \"/\" ||\n parsedLocationArg.pathname?.startsWith(parentPathnameBase),\n `When overriding the location using \\`<Routes location>\\` or \\`useRoutes(routes, location)\\`, ` +\n `the location pathname must begin with the portion of the URL pathname that was ` +\n `matched by all parent routes. The current pathname base is \"${parentPathnameBase}\" ` +\n `but pathname \"${parsedLocationArg.pathname}\" was given in the \\`location\\` prop.`\n );\n\n location = parsedLocationArg;\n } else {\n location = locationFromContext;\n }\n\n let pathname = location.pathname || \"/\";\n let remainingPathname =\n parentPathnameBase === \"/\"\n ? pathname\n : pathname.slice(parentPathnameBase.length) || \"/\";\n\n let matches = matchRoutes(routes, { pathname: remainingPathname });\n\n if (__DEV__) {\n warning(\n parentRoute || matches != null,\n `No routes matched location \"${location.pathname}${location.search}${location.hash}\" `\n );\n\n warning(\n matches == null ||\n matches[matches.length - 1].route.element !== undefined ||\n matches[matches.length - 1].route.Component !== undefined,\n `Matched leaf route at location \"${location.pathname}${location.search}${location.hash}\" ` +\n `does not have an element or Component. This means it will render an <Outlet /> with a ` +\n `null value by default resulting in an \"empty\" page.`\n );\n }\n\n let renderedMatches = _renderMatches(\n matches &&\n matches.map((match) =>\n Object.assign({}, match, {\n params: Object.assign({}, parentParams, match.params),\n pathname: joinPaths([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n navigator.encodeLocation\n ? navigator.encodeLocation(match.pathname).pathname\n : match.pathname,\n ]),\n pathnameBase:\n match.pathnameBase === \"/\"\n ? parentPathnameBase\n : joinPaths([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n navigator.encodeLocation\n ? navigator.encodeLocation(match.pathnameBase).pathname\n : match.pathnameBase,\n ]),\n })\n ),\n parentMatches,\n dataRouterState\n );\n\n // When a user passes in a `locationArg`, the associated routes need to\n // be wrapped in a new `LocationContext.Provider` in order for `useLocation`\n // to use the scoped location instead of the global location.\n if (locationArg && renderedMatches) {\n return (\n <LocationContext.Provider\n value={{\n location: {\n pathname: \"/\",\n search: \"\",\n hash: \"\",\n state: null,\n key: \"default\",\n ...location,\n },\n navigationType: NavigationType.Pop,\n }}\n >\n {renderedMatches}\n </LocationContext.Provider>\n );\n }\n\n return renderedMatches;\n}\n\nfunction DefaultErrorComponent() {\n let error = useRouteError();\n let message = isRouteErrorResponse(error)\n ? `${error.status} ${error.statusText}`\n : error instanceof Error\n ? error.message\n : JSON.stringify(error);\n let stack = error instanceof Error ? error.stack : null;\n let lightgrey = \"rgba(200,200,200, 0.5)\";\n let preStyles = { padding: \"0.5rem\", backgroundColor: lightgrey };\n let codeStyles = { padding: \"2px 4px\", backgroundColor: lightgrey };\n\n let devInfo = null;\n if (__DEV__) {\n console.error(\n \"Error handled by React Router default ErrorBoundary:\",\n error\n );\n\n devInfo = (\n <>\n <p>💿 Hey developer 👋</p>\n <p>\n You can provide a way better UX than this when your app throws errors\n by providing your own <code style={codeStyles}>ErrorBoundary</code> or{\" \"}\n <code style={codeStyles}>errorElement</code> prop on your route.\n </p>\n </>\n );\n }\n\n return (\n <>\n <h2>Unexpected Application Error!</h2>\n <h3 style={{ fontStyle: \"italic\" }}>{message}</h3>\n {stack ? <pre style={preStyles}>{stack}</pre> : null}\n {devInfo}\n </>\n );\n}\n\nconst defaultErrorElement = <DefaultErrorComponent />;\n\ntype RenderErrorBoundaryProps = React.PropsWithChildren<{\n location: Location;\n revalidation: RevalidationState;\n error: any;\n component: React.ReactNode;\n routeContext: RouteContextObject;\n}>;\n\ntype RenderErrorBoundaryState = {\n location: Location;\n revalidation: RevalidationState;\n error: any;\n};\n\nexport class RenderErrorBoundary extends React.Component<\n RenderErrorBoundaryProps,\n RenderErrorBoundaryState\n> {\n constructor(props: RenderErrorBoundaryProps) {\n super(props);\n this.state = {\n location: props.location,\n revalidation: props.revalidation,\n error: props.error,\n };\n }\n\n static getDerivedStateFromError(error: any) {\n return { error: error };\n }\n\n static getDerivedStateFromProps(\n props: RenderErrorBoundaryProps,\n state: RenderErrorBoundaryState\n ) {\n // When we get into an error state, the user will likely click \"back\" to the\n // previous page that didn't have an error. Because this wraps the entire\n // application, that will have no effect--the error page continues to display.\n // This gives us a mechanism to recover from the error when the location changes.\n //\n // Whether we're in an error state or not, we update the location in state\n // so that when we are in an error state, it gets reset when a new location\n // comes in and the user recovers from the error.\n if (\n state.location !== props.location ||\n (state.revalidation !== \"idle\" && props.revalidation === \"idle\")\n ) {\n return {\n error: props.error,\n location: props.location,\n revalidation: props.revalidation,\n };\n }\n\n // If we're not changing locations, preserve the location but still surface\n // any new errors that may come through. We retain the existing error, we do\n // this because the error provided from the app state may be cleared without\n // the location changing.\n return {\n error: props.error || state.error,\n location: state.location,\n revalidation: props.revalidation || state.revalidation,\n };\n }\n\n componentDidCatch(error: any, errorInfo: any) {\n console.error(\n \"React Router caught the following error during render\",\n error,\n errorInfo\n );\n }\n\n render() {\n return this.state.error ? (\n <RouteContext.Provider value={this.props.routeContext}>\n <RouteErrorContext.Provider\n value={this.state.error}\n children={this.props.component}\n />\n </RouteContext.Provider>\n ) : (\n this.props.children\n );\n }\n}\n\ninterface RenderedRouteProps {\n routeContext: RouteContextObject;\n match: RouteMatch<string, RouteObject>;\n children: React.ReactNode | null;\n}\n\nfunction RenderedRoute({ routeContext, match, children }: RenderedRouteProps) {\n let dataRouterContext = React.useContext(DataRouterContext);\n\n // Track how deep we got in our render pass to emulate SSR componentDidCatch\n // in a DataStaticRouter\n if (\n dataRouterContext &&\n dataRouterContext.static &&\n dataRouterContext.staticContext &&\n (match.route.errorElement || match.route.ErrorBoundary)\n ) {\n dataRouterContext.staticContext._deepestRenderedBoundaryId = match.route.id;\n }\n\n return (\n <RouteContext.Provider value={routeContext}>\n {children}\n </RouteContext.Provider>\n );\n}\n\nexport function _renderMatches(\n matches: RouteMatch[] | null,\n parentMatches: RouteMatch[] = [],\n dataRouterState: RemixRouter[\"state\"] | null = null\n): React.ReactElement | null {\n if (matches == null) {\n if (dataRouterState?.errors) {\n // Don't bail if we have data router errors so we can render them in the\n // boundary. Use the pre-matched (or shimmed) matches\n matches = dataRouterState.matches as DataRouteMatch[];\n } else {\n return null;\n }\n }\n\n let renderedMatches = matches;\n\n // If we have data errors, trim matches to the highest error boundary\n let errors = dataRouterState?.errors;\n if (errors != null) {\n let errorIndex = renderedMatches.findIndex(\n (m) => m.route.id && errors?.[m.route.id]\n );\n invariant(\n errorIndex >= 0,\n `Could not find a matching route for errors on route IDs: ${Object.keys(\n errors\n ).join(\",\")}`\n );\n renderedMatches = renderedMatches.slice(\n 0,\n Math.min(renderedMatches.length, errorIndex + 1)\n );\n }\n\n return renderedMatches.reduceRight((outlet, match, index) => {\n let error = match.route.id ? errors?.[match.route.id] : null;\n // Only data routers handle errors\n let errorElement: React.ReactNode | null = null;\n if (dataRouterState) {\n errorElement = match.route.errorElement || defaultErrorElement;\n }\n let matches = parentMatches.concat(renderedMatches.slice(0, index + 1));\n let getChildren = () => {\n let children: React.ReactNode;\n if (error) {\n children = errorElement;\n } else if (match.route.Component) {\n // Note: This is a de-optimized path since React won't re-use the\n // ReactElement since it's identity changes with each new\n // React.createElement call. We keep this so folks can use\n // `<Route Component={...}>` in `<Routes>` but generally `Component`\n // usage is only advised in `RouterProvider` when we can convert it to\n // `element` ahead of time.\n children = <match.route.Component />;\n } else if (match.route.element) {\n children = match.route.element;\n } else {\n children = outlet;\n }\n return (\n <RenderedRoute\n match={match}\n routeContext={{\n outlet,\n matches,\n isDataRoute: dataRouterState != null,\n }}\n children={children}\n />\n );\n };\n // Only wrap in an error boundary within data router usages when we have an\n // ErrorBoundary/errorElement on this route. Otherwise let it bubble up to\n // an ancestor ErrorBoundary/errorElement\n return dataRouterState &&\n (match.route.ErrorBoundary || match.route.errorElement || index === 0) ? (\n <RenderErrorBoundary\n location={dataRouterState.location}\n revalidation={dataRouterState.revalidation}\n component={errorElement}\n error={error}\n children={getChildren()}\n routeContext={{ outlet: null, matches, isDataRoute: true }}\n />\n ) : (\n getChildren()\n );\n }, null as React.ReactElement | null);\n}\n\nenum DataRouterHook {\n UseBlocker = \"useBlocker\",\n UseRevalidator = \"useRevalidator\",\n UseNavigateStable = \"useNavigate\",\n}\n\nenum DataRouterStateHook {\n UseBlocker = \"useBlocker\",\n UseLoaderData = \"useLoaderData\",\n UseActionData = \"useActionData\",\n UseRouteError = \"useRouteError\",\n UseNavigation = \"useNavigation\",\n UseRouteLoaderData = \"useRouteLoaderData\",\n UseMatches = \"useMatches\",\n UseRevalidator = \"useRevalidator\",\n UseNavigateStable = \"useNavigate\",\n UseRouteId = \"useRouteId\",\n}\n\nfunction getDataRouterConsoleError(\n hookName: DataRouterHook | DataRouterStateHook\n) {\n return `${hookName} must be used within a data router. See https://reactrouter.com/routers/picking-a-router.`;\n}\n\nfunction useDataRouterContext(hookName: DataRouterHook) {\n let ctx = React.useContext(DataRouterContext);\n invariant(ctx, getDataRouterConsoleError(hookName));\n return ctx;\n}\n\nfunction useDataRouterState(hookName: DataRouterStateHook) {\n let state = React.useContext(DataRouterStateContext);\n invariant(state, getDataRouterConsoleError(hookName));\n return state;\n}\n\nfunction useRouteContext(hookName: DataRouterStateHook) {\n let route = React.useContext(RouteContext);\n invariant(route, getDataRouterConsoleError(hookName));\n return route;\n}\n\n// Internal version with hookName-aware debugging\nfunction useCurrentRouteId(hookName: DataRouterStateHook) {\n let route = useRouteContext(hookName);\n let thisRoute = route.matches[route.matches.length - 1];\n invariant(\n thisRoute.route.id,\n `${hookName} can only be used on routes that contain a unique \"id\"`\n );\n return thisRoute.route.id;\n}\n\n/**\n * Returns the ID for the nearest contextual route\n */\nexport function useRouteId() {\n return useCurrentRouteId(DataRouterStateHook.UseRouteId);\n}\n\n/**\n * Returns the current navigation, defaulting to an \"idle\" navigation when\n * no navigation is in progress\n */\nexport function useNavigation() {\n let state = useDataRouterState(DataRouterStateHook.UseNavigation);\n return state.navigation;\n}\n\n/**\n * Returns a revalidate function for manually triggering revalidation, as well\n * as the current state of any manual revalidations\n */\nexport function useRevalidator() {\n let dataRouterContext = useDataRouterContext(DataRouterHook.UseRevalidator);\n let state = useDataRouterState(DataRouterStateHook.UseRevalidator);\n return {\n revalidate: dataRouterContext.router.revalidate,\n state: state.revalidation,\n };\n}\n\n/**\n * Returns the active route matches, useful for accessing loaderData for\n * parent/child routes or the route \"handle\" property\n */\nexport function useMatches() {\n let { matches, loaderData } = useDataRouterState(\n DataRouterStateHook.UseMatches\n );\n return React.useMemo(\n () =>\n matches.map((match) => {\n let { pathname, params } = match;\n // Note: This structure matches that created by createUseMatchesMatch\n // in the @remix-run/router , so if you change this please also change\n // that :) Eventually we'll DRY this up\n return {\n id: match.route.id,\n pathname,\n params,\n data: loaderData[match.route.id] as unknown,\n handle: match.route.handle as unknown,\n };\n }),\n [matches, loaderData]\n );\n}\n\n/**\n * Returns the loader data for the nearest ancestor Route loader\n */\nexport function useLoaderData(): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseLoaderData);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseLoaderData);\n\n if (state.errors && state.errors[routeId] != null) {\n console.error(\n `You cannot \\`useLoaderData\\` in an errorElement (routeId: ${routeId})`\n );\n return undefined;\n }\n return state.loaderData[routeId];\n}\n\n/**\n * Returns the loaderData for the given routeId\n */\nexport function useRouteLoaderData(routeId: string): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseRouteLoaderData);\n return state.loaderData[routeId];\n}\n\n/**\n * Returns the action data for the nearest ancestor Route action\n */\nexport function useActionData(): unknown {\n let state = useDataRouterState(DataRouterStateHook.UseActionData);\n\n let route = React.useContext(RouteContext);\n invariant(route, `useActionData must be used inside a RouteContext`);\n\n return Object.values(state?.actionData || {})[0];\n}\n\n/**\n * Returns the nearest ancestor Route error, which could be a loader/action\n * error or a render error. This is intended to be called from your\n * ErrorBoundary/errorElement to display a proper error message.\n */\nexport function useRouteError(): unknown {\n let error = React.useContext(RouteErrorContext);\n let state = useDataRouterState(DataRouterStateHook.UseRouteError);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseRouteError);\n\n // If this was a render error, we put it in a RouteError context inside\n // of RenderErrorBoundary\n if (error) {\n return error;\n }\n\n // Otherwise look for errors from our data router state\n return state.errors?.[routeId];\n}\n\n/**\n * Returns the happy-path data from the nearest ancestor <Await /> value\n */\nexport function useAsyncValue(): unknown {\n let value = React.useContext(AwaitContext);\n return value?._data;\n}\n\n/**\n * Returns the error from the nearest ancestor <Await /> value\n */\nexport function useAsyncError(): unknown {\n let value = React.useContext(AwaitContext);\n return value?._error;\n}\n\nlet blockerId = 0;\n\n/**\n * Allow the application to block navigations within the SPA and present the\n * user a confirmation dialog to confirm the navigation. Mostly used to avoid\n * using half-filled form data. This does not handle hard-reloads or\n * cross-origin navigations.\n */\nexport function useBlocker(shouldBlock: boolean | BlockerFunction): Blocker {\n let { router } = useDataRouterContext(DataRouterHook.UseBlocker);\n let state = useDataRouterState(DataRouterStateHook.UseBlocker);\n let [blockerKey] = React.useState(() => String(++blockerId));\n\n let blockerFunction = React.useCallback<BlockerFunction>(\n (args) => {\n return typeof shouldBlock === \"function\"\n ? !!shouldBlock(args)\n : !!shouldBlock;\n },\n [shouldBlock]\n );\n\n let blocker = router.getBlocker(blockerKey, blockerFunction);\n\n // Cleanup on unmount\n React.useEffect(\n () => () => router.deleteBlocker(blockerKey),\n [router, blockerKey]\n );\n\n // Prefer the blocker from state since DataRouterContext is memoized so this\n // ensures we update on blocker state updates\n return state.blockers.get(blockerKey) || blocker;\n}\n\n/**\n * Stable version of useNavigate that is used when we are in the context of\n * a RouterProvider.\n */\nfunction useNavigateStable(): NavigateFunction {\n let { router } = useDataRouterContext(DataRouterHook.UseNavigateStable);\n let id = useCurrentRouteId(DataRouterStateHook.UseNavigateStable);\n\n let activeRef = React.useRef(false);\n useIsomorphicLayoutEffect(() => {\n activeRef.current = true;\n });\n\n let navigate: NavigateFunction = React.useCallback(\n (to: To | number, options: NavigateOptions = {}) => {\n warning(activeRef.current, navigateEffectWarning);\n\n // Short circuit here since if this happens on first render the navigate\n // is useless because we haven't wired up our router subscriber yet\n if (!activeRef.current) return;\n\n if (typeof to === \"number\") {\n router.navigate(to);\n } else {\n router.navigate(to, { fromRouteId: id, ...options });\n }\n },\n [router, id]\n );\n\n return navigate;\n}\n\nconst alreadyWarned: Record<string, boolean> = {};\n\nfunction warningOnce(key: string, cond: boolean, message: string) {\n if (!cond && !alreadyWarned[key]) {\n alreadyWarned[key] = true;\n warning(false, message);\n }\n}\n","import * as React from \"react\";\nimport type {\n TrackedPromise,\n InitialEntry,\n Location,\n MemoryHistory,\n Router as RemixRouter,\n To,\n LazyRouteFunction,\n RelativeRoutingType,\n RouterState,\n} from \"@remix-run/router\";\nimport {\n Action as NavigationType,\n AbortedDeferredError,\n createMemoryHistory,\n UNSAFE_invariant as invariant,\n parsePath,\n resolveTo,\n stripBasename,\n UNSAFE_warning as warning,\n UNSAFE_getPathContributingMatches as getPathContributingMatches,\n} from \"@remix-run/router\";\n\nimport type {\n DataRouteObject,\n IndexRouteObject,\n RouteMatch,\n RouteObject,\n Navigator,\n NonIndexRouteObject,\n} from \"./context\";\nimport {\n LocationContext,\n NavigationContext,\n DataRouterContext,\n DataRouterStateContext,\n AwaitContext,\n RouteContext,\n} from \"./context\";\nimport {\n useAsyncValue,\n useInRouterContext,\n useNavigate,\n useOutlet,\n useRoutes,\n _renderMatches,\n useRoutesImpl,\n useLocation,\n} from \"./hooks\";\n\nexport interface RouterProviderProps {\n fallbackElement?: React.ReactNode;\n router: RemixRouter;\n}\n\n/**\n * Given a Remix Router instance, render the appropriate UI\n */\nexport function RouterProvider({\n fallbackElement,\n router,\n}: RouterProviderProps): React.ReactElement {\n // Need to use a layout effect here so we are subscribed early enough to\n // pick up on any render-driven redirects/navigations (useEffect/<Navigate>)\n let [state, setState] = React.useState(router.state);\n React.useLayoutEffect(() => router.subscribe(setState), [router, setState]);\n\n let navigator = React.useMemo((): Navigator => {\n return {\n createHref: router.createHref,\n encodeLocation: router.encodeLocation,\n go: (n) => router.navigate(n),\n push: (to, state, opts) =>\n router.navigate(to, {\n state,\n preventScrollReset: opts?.preventScrollReset,\n }),\n replace: (to, state, opts) =>\n router.navigate(to, {\n replace: true,\n state,\n preventScrollReset: opts?.preventScrollReset,\n }),\n };\n }, [router]);\n\n let basename = router.basename || \"/\";\n\n let dataRouterContext = React.useMemo(\n () => ({\n router,\n navigator,\n static: false,\n basename,\n }),\n [router, navigator, basename]\n );\n\n // The fragment and {null} here are important! We need them to keep React 18's\n // useId happy when we are server-rendering since we may have a <script> here\n // containing the hydrated server-side staticContext (from StaticRouterProvider).\n // useId relies on the component tree structure to generate deterministic id's\n // so we need to ensure it remains the same on the client even though\n // we don't need the <script> tag\n return (\n <>\n <DataRouterContext.Provider value={dataRouterContext}>\n <DataRouterStateContext.Provider value={state}>\n <Router\n basename={router.basename}\n location={router.state.location}\n navigationType={router.state.historyAction}\n navigator={navigator}\n >\n {router.state.initialized ? (\n <DataRoutes routes={router.routes} state={state} />\n ) : (\n fallbackElement\n )}\n </Router>\n </DataRouterStateContext.Provider>\n </DataRouterContext.Provider>\n {null}\n </>\n );\n}\n\nfunction DataRoutes({\n routes,\n state,\n}: {\n routes: DataRouteObject[];\n state: RouterState;\n}): React.ReactElement | null {\n return useRoutesImpl(routes, undefined, state);\n}\n\nexport interface MemoryRouterProps {\n basename?: string;\n children?: React.ReactNode;\n initialEntries?: InitialEntry[];\n initialIndex?: number;\n}\n\n/**\n * A <Router> that stores all entries in memory.\n *\n * @see https://reactrouter.com/router-components/memory-router\n */\nexport function MemoryRouter({\n basename,\n children,\n initialEntries,\n initialIndex,\n}: MemoryRouterProps): React.ReactElement {\n let historyRef = React.useRef<MemoryHistory>();\n if (historyRef.current == null) {\n historyRef.current = createMemoryHistory({\n initialEntries,\n initialIndex,\n v5Compat: true,\n });\n }\n\n let history = historyRef.current;\n let [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n <Router\n basename={basename}\n children={children}\n location={state.location}\n navigationType={state.action}\n navigator={history}\n />\n );\n}\n\nexport interface NavigateProps {\n to: To;\n replace?: boolean;\n state?: any;\n relative?: RelativeRoutingType;\n}\n\n/**\n * Changes the current location.\n *\n * Note: This API is mostly useful in React.Component subclasses that are not\n * able to use hooks. In functional components, we recommend you use the\n * `useNavigate` hook instead.\n *\n * @see https://reactrouter.com/components/navigate\n */\nexport function Navigate({\n to,\n replace,\n state,\n relative,\n}: NavigateProps): null {\n invariant(\n useInRouterContext(),\n // TODO: This error is probably because they somehow have 2 versions of\n // the router loaded. We can help them understand how to avoid that.\n `<Navigate> may be used only in the context of a <Router> component.`\n );\n\n warning(\n !React.useContext(NavigationContext).static,\n `<Navigate> must not be used on the initial render in a <StaticRouter>. ` +\n `This is a no-op, but you should modify your code so the <Navigate> is ` +\n `only ever rendered in response to some user interaction or state change.`\n );\n\n let { matches } = React.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n let navigate = useNavigate();\n\n // Resolve the path outside of the effect so that when effects run twice in\n // StrictMode they navigate to the same place\n let path = resolveTo(\n to,\n getPathContributingMatches(matches).map((match) => match.pathnameBase),\n locationPathname,\n relative === \"path\"\n );\n let jsonPath = JSON.stringify(path);\n\n React.useEffect(\n () => navigate(JSON.parse(jsonPath), { replace, state, relative }),\n [navigate, jsonPath, relative, replace, state]\n );\n\n return null;\n}\n\nexport interface OutletProps {\n context?: unknown;\n}\n\n/**\n * Renders the child route's element, if there is one.\n *\n * @see https://reactrouter.com/components/outlet\n */\nexport function Outlet(props: OutletProps): React.ReactElement | null {\n return useOutlet(props.context);\n}\n\nexport interface PathRouteProps {\n caseSensitive?: NonIndexRouteObject[\"caseSensitive\"];\n path?: NonIndexRouteObject[\"path\"];\n id?: NonIndexRouteObject[\"id\"];\n lazy?: LazyRouteFunction<NonIndexRouteObject>;\n loader?: NonIndexRouteObject[\"loader\"];\n action?: NonIndexRouteObject[\"action\"];\n hasErrorBoundary?: NonIndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: NonIndexRouteObject[\"shouldRevalidate\"];\n handle?: NonIndexRouteObject[\"handle\"];\n index?: false;\n children?: React.ReactNode;\n element?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n Component?: React.ComponentType | null;\n ErrorBoundary?: React.ComponentType | null;\n}\n\nexport interface LayoutRouteProps extends PathRouteProps {}\n\nexport interface IndexRouteProps {\n caseSensitive?: IndexRouteObject[\"caseSensitive\"];\n path?: IndexRouteObject[\"path\"];\n id?: IndexRouteObject[\"id\"];\n lazy?: LazyRouteFunction<IndexRouteObject>;\n loader?: IndexRouteObject[\"loader\"];\n action?: IndexRouteObject[\"action\"];\n hasErrorBoundary?: IndexRouteObject[\"hasErrorBoundary\"];\n shouldRevalidate?: IndexRouteObject[\"shouldRevalidate\"];\n handle?: IndexRouteObject[\"handle\"];\n index: true;\n children?: undefined;\n element?: React.ReactNode | null;\n errorElement?: React.ReactNode | null;\n Component?: React.ComponentType | null;\n ErrorBoundary?: React.ComponentType | null;\n}\n\nexport type RouteProps = PathRouteProps | LayoutRouteProps | IndexRouteProps;\n\n/**\n * Declares an element that should be rendered at a certain URL path.\n *\n * @see https://reactrouter.com/components/route\n */\nexport function Route(_props: RouteProps): React.ReactElement | null {\n invariant(\n false,\n `A <Route> is only ever to be used as the child of <Routes> element, ` +\n `never rendered directly. Please wrap your <Route> in a <Routes>.`\n );\n}\n\nexport interface RouterProps {\n basename?: string;\n children?: React.ReactNode;\n location: Partial<Location> | string;\n navigationType?: NavigationType;\n navigator: Navigator;\n static?: boolean;\n}\n\n/**\n * Provides location context for the rest of the app.\n *\n * Note: You usually won't render a <Router> directly. Instead, you'll render a\n * router that is more specific to your environment such as a <BrowserRouter>\n * in web browsers or a <StaticRouter> for server rendering.\n *\n * @see https://reactrouter.com/router-components/router\n */\nexport function Router({\n basename: basenameProp = \"/\",\n children = null,\n location: locationProp,\n navigationType = NavigationType.Pop,\n navigator,\n static: staticProp = false,\n}: RouterProps): React.ReactElement | null {\n invariant(\n !useInRouterContext(),\n `You cannot render a <Router> inside another <Router>.` +\n ` You should never have more than one in your app.`\n );\n\n // Preserve trailing slashes on basename, so we can let the user control\n // the enforcement of trailing slashes throughout the app\n let basename = basenameProp.replace(/^\\/*/, \"/\");\n let navigationContext = React.useMemo(\n () => ({ basename, navigator, static: staticProp }),\n [basename, navigator, staticProp]\n );\n\n if (typeof locationProp === \"string\") {\n locationProp = parsePath(locationProp);\n }\n\n let {\n pathname = \"/\",\n search = \"\",\n hash = \"\",\n state = null,\n key = \"default\",\n } = locationProp;\n\n let locationContext = React.useMemo(() => {\n let trailingPathname = stripBasename(pathname, basename);\n\n if (trailingPathname == null) {\n return null;\n }\n\n return {\n location: {\n pathname: trailingPathname,\n search,\n hash,\n state,\n key,\n },\n navigationType,\n };\n }, [basename, pathname, search, hash, state, key, navigationType]);\n\n warning(\n locationContext != null,\n `<Router basename=\"${basename}\"> is not able to match the URL ` +\n `\"${pathname}${search}${hash}\" because it does not start with the ` +\n `basename, so the <Router> won't render anything.`\n );\n\n if (locationContext == null) {\n return null;\n }\n\n return (\n <NavigationContext.Provider value={navigationContext}>\n <LocationContext.Provider children={children} value={locationContext} />\n </NavigationContext.Provider>\n );\n}\n\nexport interface RoutesProps {\n children?: React.ReactNode;\n location?: Partial<Location> | string;\n}\n\n/**\n * A container for a nested tree of <Route> elements that renders the branch\n * that best matches the current location.\n *\n * @see https://reactrouter.com/components/routes\n */\nexport function Routes({\n children,\n location,\n}: RoutesProps): React.ReactElement | null {\n return useRoutes(createRoutesFromChildren(children), location);\n}\n\nexport interface AwaitResolveRenderFunction {\n (data: Awaited<any>): React.ReactNode;\n}\n\nexport interface AwaitProps {\n children: React.ReactNode | AwaitResolveRenderFunction;\n errorElement?: React.ReactNode;\n resolve: TrackedPromise | any;\n}\n\n/**\n * Component to use for rendering lazily loaded data from returning defer()\n * in a loader function\n */\nexport function Await({ children, errorElement, resolve }: AwaitProps) {\n return (\n <AwaitErrorBoundary resolve={resolve} errorElement={errorElement}>\n <ResolveAwait>{children}</ResolveAwait>\n </AwaitErrorBoundary>\n );\n}\n\ntype AwaitErrorBoundaryProps = React.PropsWithChildren<{\n errorElement?: React.ReactNode;\n resolve: TrackedPromise | any;\n}>;\n\ntype AwaitErrorBoundaryState = {\n error: any;\n};\n\nenum AwaitRenderStatus {\n pending,\n success,\n error,\n}\n\nconst neverSettledPromise = new Promise(() => {});\n\nclass AwaitErrorBoundary extends React.Component<\n AwaitErrorBoundaryProps,\n AwaitErrorBoundaryState\n> {\n constructor(props: AwaitErrorBoundaryProps) {\n super(props);\n this.state = { error: null };\n }\n\n static getDerivedStateFromError(error: any) {\n return { error };\n }\n\n componentDidCatch(error: any, errorInfo: any) {\n console.error(\n \"<Await> caught the following error during render\",\n error,\n errorInfo\n );\n }\n\n render() {\n let { children, errorElement, resolve } = this.props;\n\n let promise: TrackedPromise | null = null;\n let status: AwaitRenderStatus = AwaitRenderStatus.pending;\n\n if (!(resolve instanceof Promise)) {\n // Didn't get a promise - provide as a resolved promise\n status = AwaitRenderStatus.success;\n promise = Promise.resolve();\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n Object.defineProperty(promise, \"_data\", { get: () => resolve });\n } else if (this.state.error) {\n // Caught a render error, provide it as a rejected promise\n status = AwaitRenderStatus.error;\n let renderError = this.state.error;\n promise = Promise.reject().catch(() => {}); // Avoid unhandled rejection warnings\n Object.defineProperty(promise, \"_tracked\", { get: () => true });\n Object.defineProperty(promise, \"_error\", { get: () => renderError });\n } else if ((resolve as TrackedPromise)._tracked) {\n // Already tracked promise - check contents\n promise = resolve;\n status =\n promise._error !== undefined\n ? AwaitRenderStatus.error\n : promise._data !== undefined\n ? AwaitRenderStatus.success\n : AwaitRenderStatus.pending;\n } else {\n // Raw (untracked) promise - track it\n status = AwaitRenderStatus.pending;\n Object.defineProperty(resolve, \"_tracked\", { get: () => true });\n promise = resolve.then(\n (data: any) =>\n Object.defineProperty(resolve, \"_data\", { get: () => data }),\n (error: any) =>\n Object.defineProperty(resolve, \"_error\", { get: () => error })\n );\n }\n\n if (\n status === AwaitRenderStatus.error &&\n promise._error instanceof AbortedDeferredError\n ) {\n // Freeze the UI by throwing a never resolved promise\n throw neverSettledPromise;\n }\n\n if (status === AwaitRenderStatus.error && !errorElement) {\n // No errorElement, throw to the nearest route-level error boundary\n throw promise._error;\n }\n\n if (status === AwaitRenderStatus.error) {\n // Render via our errorElement\n return <AwaitContext.Provider value={promise} children={errorElement} />;\n }\n\n if (status === AwaitRenderStatus.success) {\n // Render children with resolved value\n return <AwaitContext.Provider value={promise} children={children} />;\n }\n\n // Throw to the suspense boundary\n throw promise;\n }\n}\n\n/**\n * @private\n * Indirection to leverage useAsyncValue for a render-prop API on <Await>\n */\nfunction ResolveAwait({\n children,\n}: {\n children: React.ReactNode | AwaitResolveRenderFunction;\n}) {\n let data = useAsyncValue();\n let toRender = typeof children === \"function\" ? children(data) : children;\n return <>{toRender}</>;\n}\n\n///////////////////////////////////////////////////////////////////////////////\n// UTILS\n///////////////////////////////////////////////////////////////////////////////\n\n/**\n * Creates a route config from a React \"children\" object, which is usually\n * either a `<Route>` element or an array of them. Used internally by\n * `<Routes>` to create a route config from its children.\n *\n * @see https://reactrouter.com/utils/create-routes-from-children\n */\nexport function createRoutesFromChildren(\n children: React.ReactNode,\n parentPath: number[] = []\n): RouteObject[] {\n let routes: RouteObject[] = [];\n\n React.Children.forEach(children, (element, index) => {\n if (!React.isValidElement(element)) {\n // Ignore non-elements. This allows people to more easily inline\n // conditionals in their route config.\n return;\n }\n\n let treePath = [...parentPath, index];\n\n if (element.type === React.Fragment) {\n // Transparently support React.Fragment and its children.\n routes.push.apply(\n routes,\n createRoutesFromChildren(element.props.children, treePath)\n );\n return;\n }\n\n invariant(\n element.type === Route,\n `[${\n typeof element.type === \"string\" ? element.type : element.type.name\n }] is not a <Route> component. All component children of <Routes> must be a <Route> or <React.Fragment>`\n );\n\n invariant(\n !element.props.index || !element.props.children,\n \"An index route cannot have child routes.\"\n );\n\n let route: RouteObject = {\n id: element.props.id || treePath.join(\"-\"),\n caseSensitive: element.props.caseSensitive,\n element: element.props.element,\n Component: element.props.Component,\n index: element.props.index,\n path: element.props.path,\n loader: element.props.loader,\n action: element.props.action,\n errorElement: element.props.errorElement,\n ErrorBoundary: element.props.ErrorBoundary,\n hasErrorBoundary:\n element.props.ErrorBoundary != null ||\n element.props.errorElement != null,\n shouldRevalidate: element.props.shouldRevalidate,\n handle: element.props.handle,\n lazy: element.props.lazy,\n };\n\n if (element.props.children) {\n route.children = createRoutesFromChildren(\n element.props.children,\n treePath\n );\n }\n\n routes.push(route);\n });\n\n return routes;\n}\n\n/**\n * Renders the result of `matchRoutes()` into a React element.\n */\nexport function renderMatches(\n matches: RouteMatch[] | null\n): React.ReactElement | null {\n return _renderMatches(matches);\n}\n","/**\n * NOTE: If you refactor this to split up the modules into separate files,\n * you'll need to update the rollup config for react-router-dom-v5-compat.\n */\nimport * as React from \"react\";\nimport type {\n NavigateOptions,\n RelativeRoutingType,\n RouteObject,\n To,\n} from \"react-router\";\nimport {\n Router,\n createPath,\n useHref,\n useLocation,\n useMatches,\n useNavigate,\n useNavigation,\n useResolvedPath,\n unstable_useBlocker as useBlocker,\n UNSAFE_DataRouterContext as DataRouterContext,\n UNSAFE_DataRouterStateContext as DataRouterStateContext,\n UNSAFE_NavigationContext as NavigationContext,\n UNSAFE_RouteContext as RouteContext,\n UNSAFE_mapRouteProperties as mapRouteProperties,\n UNSAFE_useRouteId as useRouteId,\n} from \"react-router\";\nimport type {\n BrowserHistory,\n Fetcher,\n FormEncType,\n FormMethod,\n FutureConfig,\n GetScrollRestorationKeyFunction,\n HashHistory,\n History,\n HTMLFormMethod,\n HydrationState,\n Router as RemixRouter,\n V7_FormMethod,\n} from \"@remix-run/router\";\nimport {\n createRouter,\n createBrowserHistory,\n createHashHistory,\n joinPaths,\n stripBasename,\n ErrorResponse,\n UNSAFE_invariant as invariant,\n UNSAFE_warning as warning,\n} from \"@remix-run/router\";\n\nimport type {\n SubmitOptions,\n ParamKeyValuePair,\n URLSearchParamsInit,\n} from \"./dom\";\nimport {\n createSearchParams,\n defaultMethod,\n getFormSubmissionInfo,\n getSearchParamsForLocation,\n shouldProcessLinkClick,\n} from \"./dom\";\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Re-exports\n////////////////////////////////////////////////////////////////////////////////\n\nexport type {\n FormEncType,\n FormMethod,\n GetScrollRestorationKeyFunction,\n ParamKeyValuePair,\n SubmitOptions,\n URLSearchParamsInit,\n V7_FormMethod,\n};\nexport { createSearchParams };\n\n// Note: Keep in sync with react-router exports!\nexport type {\n ActionFunction,\n ActionFunctionArgs,\n AwaitProps,\n unstable_Blocker,\n unstable_BlockerFunction,\n DataRouteMatch,\n DataRouteObject,\n Fetcher,\n Hash,\n IndexRouteObject,\n IndexRouteProps,\n JsonFunction,\n LazyRouteFunction,\n LayoutRouteProps,\n LoaderFunction,\n LoaderFunctionArgs,\n Location,\n MemoryRouterProps,\n NavigateFunction,\n NavigateOptions,\n NavigateProps,\n Navigation,\n Navigator,\n NonIndexRouteObject,\n OutletProps,\n Params,\n ParamParseKey,\n Path,\n PathMatch,\n Pathname,\n PathPattern,\n PathRouteProps,\n RedirectFunction,\n RelativeRoutingType,\n RouteMatch,\n RouteObject,\n RouteProps,\n RouterProps,\n RouterProviderProps,\n RoutesProps,\n Search,\n ShouldRevalidateFunction,\n To,\n} from \"react-router\";\nexport {\n AbortedDeferredError,\n Await,\n MemoryRouter,\n Navigate,\n NavigationType,\n Outlet,\n Route,\n Router,\n RouterProvider,\n Routes,\n createMemoryRouter,\n createPath,\n createRoutesFromChildren,\n createRoutesFromElements,\n defer,\n isRouteErrorResponse,\n generatePath,\n json,\n matchPath,\n matchRoutes,\n parsePath,\n redirect,\n renderMatches,\n resolvePath,\n useActionData,\n useAsyncError,\n useAsyncValue,\n unstable_useBlocker,\n useHref,\n useInRouterContext,\n useLoaderData,\n useLocation,\n useMatch,\n useMatches,\n useNavigate,\n useNavigation,\n useNavigationType,\n useOutlet,\n useOutletContext,\n useParams,\n useResolvedPath,\n useRevalidator,\n useRouteError,\n useRouteLoaderData,\n useRoutes,\n} from \"react-router\";\n\n///////////////////////////////////////////////////////////////////////////////\n// DANGER! PLEASE READ ME!\n// We provide these exports as an escape hatch in the event that you need any\n// routing data that we don't provide an explicit API for. With that said, we\n// want to cover your use case if we can, so if you feel the need to use these\n// we want to hear from you. Let us know what you're building and we'll do our\n// best to make sure we can support you!\n//\n// We consider these exports an implementation detail and do not guarantee\n// against any breaking changes, regardless of the semver release. Use with\n// extreme caution and only if you understand the consequences. Godspeed.\n///////////////////////////////////////////////////////////////////////////////\n\n/** @internal */\nexport {\n UNSAFE_DataRouterContext,\n UNSAFE_DataRouterStateContext,\n UNSAFE_NavigationContext,\n UNSAFE_LocationContext,\n UNSAFE_RouteContext,\n UNSAFE_useRouteId,\n} from \"react-router\";\n//#endregion\n\ndeclare global {\n var __staticRouterHydrationData: HydrationState | undefined;\n}\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Routers\n////////////////////////////////////////////////////////////////////////////////\n\ninterface DOMRouterOpts {\n basename?: string;\n future?: Partial<Omit<FutureConfig, \"v7_prependBasename\">>;\n hydrationData?: HydrationState;\n window?: Window;\n}\n\nexport function createBrowserRouter(\n routes: RouteObject[],\n opts?: DOMRouterOpts\n): RemixRouter {\n return createRouter({\n basename: opts?.basename,\n future: {\n ...opts?.future,\n v7_prependBasename: true,\n },\n history: createBrowserHistory({ window: opts?.window }),\n hydrationData: opts?.hydrationData || parseHydrationData(),\n routes,\n mapRouteProperties,\n }).initialize();\n}\n\nexport function createHashRouter(\n routes: RouteObject[],\n opts?: DOMRouterOpts\n): RemixRouter {\n return createRouter({\n basename: opts?.basename,\n future: {\n ...opts?.future,\n v7_prependBasename: true,\n },\n history: createHashHistory({ window: opts?.window }),\n hydrationData: opts?.hydrationData || parseHydrationData(),\n routes,\n mapRouteProperties,\n }).initialize();\n}\n\nfunction parseHydrationData(): HydrationState | undefined {\n let state = window?.__staticRouterHydrationData;\n if (state && state.errors) {\n state = {\n ...state,\n errors: deserializeErrors(state.errors),\n };\n }\n return state;\n}\n\nfunction deserializeErrors(\n errors: RemixRouter[\"state\"][\"errors\"]\n): RemixRouter[\"state\"][\"errors\"] {\n if (!errors) return null;\n let entries = Object.entries(errors);\n let serialized: RemixRouter[\"state\"][\"errors\"] = {};\n for (let [key, val] of entries) {\n // Hey you! If you change this, please change the corresponding logic in\n // serializeErrors in react-router-dom/server.tsx :)\n if (val && val.__type === \"RouteErrorResponse\") {\n serialized[key] = new ErrorResponse(\n val.status,\n val.statusText,\n val.data,\n val.internal === true\n );\n } else if (val && val.__type === \"Error\") {\n let error = new Error(val.message);\n // Wipe away the client-side stack trace. Nothing to fill it in with\n // because we don't serialize SSR stack traces for security reasons\n error.stack = \"\";\n serialized[key] = error;\n } else {\n serialized[key] = val;\n }\n }\n return serialized;\n}\n\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Components\n////////////////////////////////////////////////////////////////////////////////\n\nexport interface BrowserRouterProps {\n basename?: string;\n children?: React.ReactNode;\n window?: Window;\n}\n\n/**\n * A `<Router>` for use in web browsers. Provides the cleanest URLs.\n */\nexport function BrowserRouter({\n basename,\n children,\n window,\n}: BrowserRouterProps) {\n let historyRef = React.useRef<BrowserHistory>();\n if (historyRef.current == null) {\n historyRef.current = createBrowserHistory({ window, v5Compat: true });\n }\n\n let history = historyRef.current;\n let [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n <Router\n basename={basename}\n children={children}\n location={state.location}\n navigationType={state.action}\n navigator={history}\n />\n );\n}\n\nexport interface HashRouterProps {\n basename?: string;\n children?: React.ReactNode;\n window?: Window;\n}\n\n/**\n * A `<Router>` for use in web browsers. Stores the location in the hash\n * portion of the URL so it is not sent to the server.\n */\nexport function HashRouter({ basename, children, window }: HashRouterProps) {\n let historyRef = React.useRef<HashHistory>();\n if (historyRef.current == null) {\n historyRef.current = createHashHistory({ window, v5Compat: true });\n }\n\n let history = historyRef.current;\n let [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n <Router\n basename={basename}\n children={children}\n location={state.location}\n navigationType={state.action}\n navigator={history}\n />\n );\n}\n\nexport interface HistoryRouterProps {\n basename?: string;\n children?: React.ReactNode;\n history: History;\n}\n\n/**\n * A `<Router>` that accepts a pre-instantiated history object. It's important\n * to note that using your own history object is highly discouraged and may add\n * two versions of the history library to your bundles unless you use the same\n * version of the history library that React Router uses internally.\n */\nfunction HistoryRouter({ basename, children, history }: HistoryRouterProps) {\n const [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n <Router\n basename={basename}\n children={children}\n location={state.location}\n navigationType={state.action}\n navigator={history}\n />\n );\n}\n\nif (__DEV__) {\n HistoryRouter.displayName = \"unstable_HistoryRouter\";\n}\n\nexport { HistoryRouter as unstable_HistoryRouter };\n\nexport interface LinkProps\n extends Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"href\"> {\n reloadDocument?: boolean;\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n to: To;\n}\n\nconst isBrowser =\n typeof window !== \"undefined\" &&\n typeof window.document !== \"undefined\" &&\n typeof window.document.createElement !== \"undefined\";\n\nconst ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\n\n/**\n * The public API for rendering a history-aware <a>.\n */\nexport const Link = React.forwardRef<HTMLAnchorElement, LinkProps>(\n function LinkWithRef(\n {\n onClick,\n relative,\n reloadDocument,\n replace,\n state,\n target,\n to,\n preventScrollReset,\n ...rest\n },\n ref\n ) {\n let { basename } = React.useContext(NavigationContext);\n\n // Rendered into <a href> for absolute URLs\n let absoluteHref;\n let isExternal = false;\n\n if (typeof to === \"string\" && ABSOLUTE_URL_REGEX.test(to)) {\n // Render the absolute href server- and client-side\n absoluteHref = to;\n\n // Only check for external origins client-side\n if (isBrowser) {\n try {\n let currentUrl = new URL(window.location.href);\n let targetUrl = to.startsWith(\"//\")\n ? new URL(currentUrl.protocol + to)\n : new URL(to);\n let path = stripBasename(targetUrl.pathname, basename);\n\n if (targetUrl.origin === currentUrl.origin && path != null) {\n // Strip the protocol/origin/basename for same-origin absolute URLs\n to = path + targetUrl.search + targetUrl.hash;\n } else {\n isExternal = true;\n }\n } catch (e) {\n // We can't do external URL detection without a valid URL\n warning(\n false,\n `<Link to=\"${to}\"> contains an invalid URL which will probably break ` +\n `when clicked - please update to a valid URL path.`\n );\n }\n }\n }\n\n // Rendered into <a href> for relative URLs\n let href = useHref(to, { relative });\n\n let internalOnClick = useLinkClickHandler(to, {\n replace,\n state,\n target,\n preventScrollReset,\n relative,\n });\n function handleClick(\n event: React.MouseEvent<HTMLAnchorElement, MouseEvent>\n ) {\n if (onClick) onClick(event);\n if (!event.defaultPrevented) {\n internalOnClick(event);\n }\n }\n\n return (\n // eslint-disable-next-line jsx-a11y/anchor-has-content\n <a\n {...rest}\n href={absoluteHref || href}\n onClick={isExternal || reloadDocument ? onClick : handleClick}\n ref={ref}\n target={target}\n />\n );\n }\n);\n\nif (__DEV__) {\n Link.displayName = \"Link\";\n}\n\nexport interface NavLinkProps\n extends Omit<LinkProps, \"className\" | \"style\" | \"children\"> {\n children?:\n | React.ReactNode\n | ((props: { isActive: boolean; isPending: boolean }) => React.ReactNode);\n caseSensitive?: boolean;\n className?:\n | string\n | ((props: {\n isActive: boolean;\n isPending: boolean;\n }) => string | undefined);\n end?: boolean;\n style?:\n | React.CSSProperties\n | ((props: {\n isActive: boolean;\n isPending: boolean;\n }) => React.CSSProperties | undefined);\n}\n\n/**\n * A <Link> wrapper that knows if it's \"active\" or not.\n */\nexport const NavLink = React.forwardRef<HTMLAnchorElement, NavLinkProps>(\n function NavLinkWithRef(\n {\n \"aria-current\": ariaCurrentProp = \"page\",\n caseSensitive = false,\n className: classNameProp = \"\",\n end = false,\n style: styleProp,\n to,\n children,\n ...rest\n },\n ref\n ) {\n let path = useResolvedPath(to, { relative: rest.relative });\n let location = useLocation();\n let routerState = React.useContext(DataRouterStateContext);\n let { navigator } = React.useContext(NavigationContext);\n\n let toPathname = navigator.encodeLocation\n ? navigator.encodeLocation(path).pathname\n : path.pathname;\n let locationPathname = location.pathname;\n let nextLocationPathname =\n routerState && routerState.navigation && routerState.navigation.location\n ? routerState.navigation.location.pathname\n : null;\n\n if (!caseSensitive) {\n locationPathname = locationPathname.toLowerCase();\n nextLocationPathname = nextLocationPathname\n ? nextLocationPathname.toLowerCase()\n : null;\n toPathname = toPathname.toLowerCase();\n }\n\n let isActive =\n locationPathname === toPathname ||\n (!end &&\n locationPathname.startsWith(toPathname) &&\n locationPathname.charAt(toPathname.length) === \"/\");\n\n let isPending =\n nextLocationPathname != null &&\n (nextLocationPathname === toPathname ||\n (!end &&\n nextLocationPathname.startsWith(toPathname) &&\n nextLocationPathname.charAt(toPathname.length) === \"/\"));\n\n let ariaCurrent = isActive ? ariaCurrentProp : undefined;\n\n let className: string | undefined;\n if (typeof classNameProp === \"function\") {\n className = classNameProp({ isActive, isPending });\n } else {\n // If the className prop is not a function, we use a default `active`\n // class for <NavLink />s that are active. In v5 `active` was the default\n // value for `activeClassName`, but we are removing that API and can still\n // use the old default behavior for a cleaner upgrade path and keep the\n // simple styling rules working as they currently do.\n className = [\n classNameProp,\n isActive ? \"active\" : null,\n isPending ? \"pending\" : null,\n ]\n .filter(Boolean)\n .join(\" \");\n }\n\n let style =\n typeof styleProp === \"function\"\n ? styleProp({ isActive, isPending })\n : styleProp;\n\n return (\n <Link\n {...rest}\n aria-current={ariaCurrent}\n className={className}\n ref={ref}\n style={style}\n to={to}\n >\n {typeof children === \"function\"\n ? children({ isActive, isPending })\n : children}\n </Link>\n );\n }\n);\n\nif (__DEV__) {\n NavLink.displayName = \"NavLink\";\n}\n\nexport interface FormProps extends React.FormHTMLAttributes<HTMLFormElement> {\n /**\n * The HTTP verb to use when the form is submit. Supports \"get\", \"post\",\n * \"put\", \"delete\", \"patch\".\n */\n method?: HTMLFormMethod;\n\n /**\n * Normal `<form action>` but supports React Router's relative paths.\n */\n action?: string;\n\n /**\n * Forces a full document navigation instead of a fetch.\n */\n reloadDocument?: boolean;\n\n /**\n * Replaces the current entry in the browser history stack when the form\n * navigates. Use this if you don't want the user to be able to click \"back\"\n * to the page with the form on it.\n */\n replace?: boolean;\n\n /**\n * Determines whether the form action is relative to the route hierarchy or\n * the pathname. Use this if you want to opt out of navigating the route\n * hierarchy and want to instead route based on /-delimited URL segments\n */\n relative?: RelativeRoutingType;\n\n /**\n * Prevent the scroll position from resetting to the top of the viewport on\n * completion of the navigation when using the <ScrollRestoration> component\n */\n preventScrollReset?: boolean;\n\n /**\n * A function to call when the form is submitted. If you call\n * `event.preventDefault()` then this form will not do anything.\n */\n onSubmit?: React.FormEventHandler<HTMLFormElement>;\n}\n\n/**\n * A `@remix-run/router`-aware `<form>`. It behaves like a normal form except\n * that the interaction with the server is with `fetch` instead of new document\n * requests, allowing components to add nicer UX to the page as the form is\n * submitted and returns with data.\n */\nexport const Form = React.forwardRef<HTMLFormElement, FormProps>(\n (props, ref) => {\n return <FormImpl {...props} ref={ref} />;\n }\n);\n\nif (__DEV__) {\n Form.displayName = \"Form\";\n}\n\ntype HTMLSubmitEvent = React.BaseSyntheticEvent<\n SubmitEvent,\n Event,\n HTMLFormElement\n>;\n\ntype HTMLFormSubmitter = HTMLButtonElement | HTMLInputElement;\n\ninterface FormImplProps extends FormProps {\n fetcherKey?: string;\n routeId?: string;\n}\n\nconst FormImpl = React.forwardRef<HTMLFormElement, FormImplProps>(\n (\n {\n reloadDocument,\n replace,\n method = defaultMethod,\n action,\n onSubmit,\n fetcherKey,\n routeId,\n relative,\n preventScrollReset,\n ...props\n },\n forwardedRef\n ) => {\n let submit = useSubmitImpl(fetcherKey, routeId);\n let formMethod: HTMLFormMethod =\n method.toLowerCase() === \"get\" ? \"get\" : \"post\";\n let formAction = useFormAction(action, { relative });\n let submitHandler: React.FormEventHandler<HTMLFormElement> = (event) => {\n onSubmit && onSubmit(event);\n if (event.defaultPrevented) return;\n event.preventDefault();\n\n let submitter = (event as unknown as HTMLSubmitEvent).nativeEvent\n .submitter as HTMLFormSubmitter | null;\n\n let submitMethod =\n (submitter?.getAttribute(\"formmethod\") as HTMLFormMethod | undefined) ||\n method;\n\n submit(submitter || event.currentTarget, {\n method: submitMethod,\n replace,\n relative,\n preventScrollReset,\n });\n };\n\n return (\n <form\n ref={forwardedRef}\n method={formMethod}\n action={formAction}\n onSubmit={reloadDocument ? onSubmit : submitHandler}\n {...props}\n />\n );\n }\n);\n\nif (__DEV__) {\n FormImpl.displayName = \"FormImpl\";\n}\n\nexport interface ScrollRestorationProps {\n getKey?: GetScrollRestorationKeyFunction;\n storageKey?: string;\n}\n\n/**\n * This component will emulate the browser's scroll restoration on location\n * changes.\n */\nexport function ScrollRestoration({\n getKey,\n storageKey,\n}: ScrollRestorationProps) {\n useScrollRestoration({ getKey, storageKey });\n return null;\n}\n\nif (__DEV__) {\n ScrollRestoration.displayName = \"ScrollRestoration\";\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Hooks\n////////////////////////////////////////////////////////////////////////////////\n\nenum DataRouterHook {\n UseScrollRestoration = \"useScrollRestoration\",\n UseSubmitImpl = \"useSubmitImpl\",\n UseFetcher = \"useFetcher\",\n}\n\nenum DataRouterStateHook {\n UseFetchers = \"useFetchers\",\n UseScrollRestoration = \"useScrollRestoration\",\n}\n\nfunction getDataRouterConsoleError(\n hookName: DataRouterHook | DataRouterStateHook\n) {\n return `${hookName} must be used within a data router. See https://reactrouter.com/routers/picking-a-router.`;\n}\n\nfunction useDataRouterContext(hookName: DataRouterHook) {\n let ctx = React.useContext(DataRouterContext);\n invariant(ctx, getDataRouterConsoleError(hookName));\n return ctx;\n}\n\nfunction useDataRouterState(hookName: DataRouterStateHook) {\n let state = React.useContext(DataRouterStateContext);\n invariant(state, getDataRouterConsoleError(hookName));\n return state;\n}\n\n/**\n * Handles the click behavior for router `<Link>` components. This is useful if\n * you need to create custom `<Link>` components with the same click behavior we\n * use in our exported `<Link>`.\n */\nexport function useLinkClickHandler<E extends Element = HTMLAnchorElement>(\n to: To,\n {\n target,\n replace: replaceProp,\n state,\n preventScrollReset,\n relative,\n }: {\n target?: React.HTMLAttributeAnchorTarget;\n replace?: boolean;\n state?: any;\n preventScrollReset?: boolean;\n relative?: RelativeRoutingType;\n } = {}\n): (event: React.MouseEvent<E, MouseEvent>) => void {\n let navigate = useNavigate();\n let location = useLocation();\n let path = useResolvedPath(to, { relative });\n\n return React.useCallback(\n (event: React.MouseEvent<E, MouseEvent>) => {\n if (shouldProcessLinkClick(event, target)) {\n event.preventDefault();\n\n // If the URL hasn't changed, a regular <a> will do a replace instead of\n // a push, so do the same here unless the replace prop is explicitly set\n let replace =\n replaceProp !== undefined\n ? replaceProp\n : createPath(location) === createPath(path);\n\n navigate(to, { replace, state, preventScrollReset, relative });\n }\n },\n [\n location,\n navigate,\n path,\n replaceProp,\n state,\n target,\n to,\n preventScrollReset,\n relative,\n ]\n );\n}\n\n/**\n * A convenient wrapper for reading and writing search parameters via the\n * URLSearchParams interface.\n */\nexport function useSearchParams(\n defaultInit?: URLSearchParamsInit\n): [URLSearchParams, SetURLSearchParams] {\n warning(\n typeof URLSearchParams !== \"undefined\",\n `You cannot use the \\`useSearchParams\\` hook in a browser that does not ` +\n `support the URLSearchParams API. If you need to support Internet ` +\n `Explorer 11, we recommend you load a polyfill such as ` +\n `https://github.com/ungap/url-search-params\\n\\n` +\n `If you're unsure how to load polyfills, we recommend you check out ` +\n `https://polyfill.io/v3/ which provides some recommendations about how ` +\n `to load polyfills only for users that need them, instead of for every ` +\n `user.`\n );\n\n let defaultSearchParamsRef = React.useRef(createSearchParams(defaultInit));\n let hasSetSearchParamsRef = React.useRef(false);\n\n let location = useLocation();\n let searchParams = React.useMemo(\n () =>\n // Only merge in the defaults if we haven't yet called setSearchParams.\n // Once we call that we want those to take precedence, otherwise you can't\n // remove a param with setSearchParams({}) if it has an initial value\n getSearchParamsForLocation(\n location.search,\n hasSetSearchParamsRef.current ? null : defaultSearchParamsRef.current\n ),\n [location.search]\n );\n\n let navigate = useNavigate();\n let setSearchParams = React.useCallback<SetURLSearchParams>(\n (nextInit, navigateOptions) => {\n const newSearchParams = createSearchParams(\n typeof nextInit === \"function\" ? nextInit(searchParams) : nextInit\n );\n hasSetSearchParamsRef.current = true;\n navigate(\"?\" + newSearchParams, navigateOptions);\n },\n [navigate, searchParams]\n );\n\n return [searchParams, setSearchParams];\n}\n\ntype SetURLSearchParams = (\n nextInit?:\n | URLSearchParamsInit\n | ((prev: URLSearchParams) => URLSearchParamsInit),\n navigateOpts?: NavigateOptions\n) => void;\n\ntype SubmitTarget =\n | HTMLFormElement\n | HTMLButtonElement\n | HTMLInputElement\n | FormData\n | URLSearchParams\n | { [name: string]: string }\n | null;\n\n/**\n * Submits a HTML `<form>` to the server without reloading the page.\n */\nexport interface SubmitFunction {\n (\n /**\n * Specifies the `<form>` to be submitted to the server, a specific\n * `<button>` or `<input type=\"submit\">` to use to submit the form, or some\n * arbitrary data to submit.\n *\n * Note: When using a `<button>` its `name` and `value` will also be\n * included in the form data that is submitted.\n */\n target: SubmitTarget,\n\n /**\n * Options that override the `<form>`'s own attributes. Required when\n * submitting arbitrary data without a backing `<form>`.\n */\n options?: SubmitOptions\n ): void;\n}\n\n/**\n * Returns a function that may be used to programmatically submit a form (or\n * some arbitrary data) to the server.\n */\nexport function useSubmit(): SubmitFunction {\n return useSubmitImpl();\n}\n\nfunction useSubmitImpl(\n fetcherKey?: string,\n fetcherRouteId?: string\n): SubmitFunction {\n let { router } = useDataRouterContext(DataRouterHook.UseSubmitImpl);\n let { basename } = React.useContext(NavigationContext);\n let currentRouteId = useRouteId();\n\n return React.useCallback(\n (target, options = {}) => {\n if (typeof document === \"undefined\") {\n throw new Error(\n \"You are calling submit during the server render. \" +\n \"Try calling submit within a `useEffect` or callback instead.\"\n );\n }\n\n let { action, method, encType, formData } = getFormSubmissionInfo(\n target,\n options,\n basename\n );\n\n // Base options shared between fetch() and navigate()\n let opts = {\n preventScrollReset: options.preventScrollReset,\n formData,\n formMethod: method as HTMLFormMethod,\n formEncType: encType as FormEncType,\n };\n\n if (fetcherKey) {\n invariant(\n fetcherRouteId != null,\n \"No routeId available for useFetcher()\"\n );\n router.fetch(fetcherKey, fetcherRouteId, action, opts);\n } else {\n router.navigate(action, {\n ...opts,\n replace: options.replace,\n fromRouteId: currentRouteId,\n });\n }\n },\n [router, basename, fetcherKey, fetcherRouteId, currentRouteId]\n );\n}\n\n// v7: Eventually we should deprecate this entirely in favor of using the\n// router method directly?\nexport function useFormAction(\n action?: string,\n { relative }: { relative?: RelativeRoutingType } = {}\n): string {\n let { basename } = React.useContext(NavigationContext);\n let routeContext = React.useContext(RouteContext);\n invariant(routeContext, \"useFormAction must be used inside a RouteContext\");\n\n let [match] = routeContext.matches.slice(-1);\n // Shallow clone path so we can modify it below, otherwise we modify the\n // object referenced by useMemo inside useResolvedPath\n let path = { ...useResolvedPath(action ? action : \".\", { relative }) };\n\n // Previously we set the default action to \".\". The problem with this is that\n // `useResolvedPath(\".\")` excludes search params and the hash of the resolved\n // URL. This is the intended behavior of when \".\" is specifically provided as\n // the form action, but inconsistent w/ browsers when the action is omitted.\n // https://github.com/remix-run/remix/issues/927\n let location = useLocation();\n if (action == null) {\n // Safe to write to these directly here since if action was undefined, we\n // would have called useResolvedPath(\".\") which will never include a search\n // or hash\n path.search = location.search;\n path.hash = location.hash;\n\n // When grabbing search params from the URL, remove the automatically\n // inserted ?index param so we match the useResolvedPath search behavior\n // which would not include ?index\n if (match.route.index) {\n let params = new URLSearchParams(path.search);\n params.delete(\"index\");\n path.search = params.toString() ? `?${params.toString()}` : \"\";\n }\n }\n\n if ((!action || action === \".\") && match.route.index) {\n path.search = path.search\n ? path.search.replace(/^\\?/, \"?index&\")\n : \"?index\";\n }\n\n // If we're operating within a basename, prepend it to the pathname prior\n // to creating the form action. If this is a root navigation, then just use\n // the raw basename which allows the basename to have full control over the\n // presence of a trailing slash on root actions\n if (basename !== \"/\") {\n path.pathname =\n path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n }\n\n return createPath(path);\n}\n\nfunction createFetcherForm(fetcherKey: string, routeId: string) {\n let FetcherForm = React.forwardRef<HTMLFormElement, FormProps>(\n (props, ref) => {\n return (\n <FormImpl\n {...props}\n ref={ref}\n fetcherKey={fetcherKey}\n routeId={routeId}\n />\n );\n }\n );\n if (__DEV__) {\n FetcherForm.displayName = \"fetcher.Form\";\n }\n return FetcherForm;\n}\n\nlet fetcherId = 0;\n\nexport type FetcherWithComponents<TData> = Fetcher<TData> & {\n Form: ReturnType<typeof createFetcherForm>;\n submit: (\n target: SubmitTarget,\n // Fetchers cannot replace/preventScrollReset because they are not\n // navigation events\n options?: Omit<SubmitOptions, \"replace\" | \"preventScrollReset\">\n ) => void;\n load: (href: string) => void;\n};\n\n/**\n * Interacts with route loaders and actions without causing a navigation. Great\n * for any interaction that stays on the same page.\n */\nexport function useFetcher<TData = any>(): FetcherWithComponents<TData> {\n let { router } = useDataRouterContext(DataRouterHook.UseFetcher);\n\n let route = React.useContext(RouteContext);\n invariant(route, `useFetcher must be used inside a RouteContext`);\n\n let routeId = route.matches[route.matches.length - 1]?.route.id;\n invariant(\n routeId != null,\n `useFetcher can only be used on routes that contain a unique \"id\"`\n );\n\n let [fetcherKey] = React.useState(() => String(++fetcherId));\n let [Form] = React.useState(() => {\n invariant(routeId, `No routeId available for fetcher.Form()`);\n return createFetcherForm(fetcherKey, routeId);\n });\n let [load] = React.useState(() => (href: string) => {\n invariant(router, \"No router available for fetcher.load()\");\n invariant(routeId, \"No routeId available for fetcher.load()\");\n router.fetch(fetcherKey, routeId, href);\n });\n let submit = useSubmitImpl(fetcherKey, routeId);\n\n let fetcher = router.getFetcher<TData>(fetcherKey);\n\n let fetcherWithComponents = React.useMemo(\n () => ({\n Form,\n submit,\n load,\n ...fetcher,\n }),\n [fetcher, Form, submit, load]\n );\n\n React.useEffect(() => {\n // Is this busted when the React team gets real weird and calls effects\n // twice on mount? We really just need to garbage collect here when this\n // fetcher is no longer around.\n return () => {\n if (!router) {\n console.warn(`No router available to clean up from useFetcher()`);\n return;\n }\n router.deleteFetcher(fetcherKey);\n };\n }, [router, fetcherKey]);\n\n return fetcherWithComponents;\n}\n\n/**\n * Provides all fetchers currently on the page. Useful for layouts and parent\n * routes that need to provide pending/optimistic UI regarding the fetch.\n */\nexport function useFetchers(): Fetcher[] {\n let state = useDataRouterState(DataRouterStateHook.UseFetchers);\n return [...state.fetchers.values()];\n}\n\nconst SCROLL_RESTORATION_STORAGE_KEY = \"react-router-scroll-positions\";\nlet savedScrollPositions: Record<string, number> = {};\n\n/**\n * When rendered inside a RouterProvider, will restore scroll positions on navigations\n */\nfunction useScrollRestoration({\n getKey,\n storageKey,\n}: {\n getKey?: GetScrollRestorationKeyFunction;\n storageKey?: string;\n} = {}) {\n let { router } = useDataRouterContext(DataRouterHook.UseScrollRestoration);\n let { restoreScrollPosition, preventScrollReset } = useDataRouterState(\n DataRouterStateHook.UseScrollRestoration\n );\n let location = useLocation();\n let matches = useMatches();\n let navigation = useNavigation();\n\n // Trigger manual scroll restoration while we're active\n React.useEffect(() => {\n window.history.scrollRestoration = \"manual\";\n return () => {\n window.history.scrollRestoration = \"auto\";\n };\n }, []);\n\n // Save positions on pagehide\n usePageHide(\n React.useCallback(() => {\n if (navigation.state === \"idle\") {\n let key = (getKey ? getKey(location, matches) : null) || location.key;\n savedScrollPositions[key] = window.scrollY;\n }\n sessionStorage.setItem(\n storageKey || SCROLL_RESTORATION_STORAGE_KEY,\n JSON.stringify(savedScrollPositions)\n );\n window.history.scrollRestoration = \"auto\";\n }, [storageKey, getKey, navigation.state, location, matches])\n );\n\n // Read in any saved scroll locations\n if (typeof document !== \"undefined\") {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useLayoutEffect(() => {\n try {\n let sessionPositions = sessionStorage.getItem(\n storageKey || SCROLL_RESTORATION_STORAGE_KEY\n );\n if (sessionPositions) {\n savedScrollPositions = JSON.parse(sessionPositions);\n }\n } catch (e) {\n // no-op, use default empty object\n }\n }, [storageKey]);\n\n // Enable scroll restoration in the router\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useLayoutEffect(() => {\n let disableScrollRestoration = router?.enableScrollRestoration(\n savedScrollPositions,\n () => window.scrollY,\n getKey\n );\n return () => disableScrollRestoration && disableScrollRestoration();\n }, [router, getKey]);\n\n // Restore scrolling when state.restoreScrollPosition changes\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useLayoutEffect(() => {\n // Explicit false means don't do anything (used for submissions)\n if (restoreScrollPosition === false) {\n return;\n }\n\n // been here before, scroll to it\n if (typeof restoreScrollPosition === \"number\") {\n window.scrollTo(0, restoreScrollPosition);\n return;\n }\n\n // try to scroll to the hash\n if (location.hash) {\n let el = document.getElementById(location.hash.slice(1));\n if (el) {\n el.scrollIntoView();\n return;\n }\n }\n\n // Don't reset if this navigation opted out\n if (preventScrollReset === true) {\n return;\n }\n\n // otherwise go to the top on new locations\n window.scrollTo(0, 0);\n }, [location, restoreScrollPosition, preventScrollReset]);\n }\n}\n\nexport { useScrollRestoration as UNSAFE_useScrollRestoration };\n\n/**\n * Setup a callback to be fired on the window's `beforeunload` event. This is\n * useful for saving some data to `window.localStorage` just before the page\n * refreshes.\n *\n * Note: The `callback` argument should be a function created with\n * `React.useCallback()`.\n */\nexport function useBeforeUnload(\n callback: (event: BeforeUnloadEvent) => any,\n options?: { capture?: boolean }\n): void {\n let { capture } = options || {};\n React.useEffect(() => {\n let opts = capture != null ? { capture } : undefined;\n window.addEventListener(\"beforeunload\", callback, opts);\n return () => {\n window.removeEventListener(\"beforeunload\", callback, opts);\n };\n }, [callback, capture]);\n}\n\n/**\n * Setup a callback to be fired on the window's `pagehide` event. This is\n * useful for saving some data to `window.localStorage` just before the page\n * refreshes. This event is better supported than beforeunload across browsers.\n *\n * Note: The `callback` argument should be a function created with\n * `React.useCallback()`.\n */\nfunction usePageHide(\n callback: (event: PageTransitionEvent) => any,\n options?: { capture?: boolean }\n): void {\n let { capture } = options || {};\n React.useEffect(() => {\n let opts = capture != null ? { capture } : undefined;\n window.addEventListener(\"pagehide\", callback, opts);\n return () => {\n window.removeEventListener(\"pagehide\", callback, opts);\n };\n }, [callback, capture]);\n}\n\n/**\n * Wrapper around useBlocker to show a window.confirm prompt to users instead\n * of building a custom UI with useBlocker.\n *\n * Warning: This has *a lot of rough edges* and behaves very differently (and\n * very incorrectly in some cases) across browsers if user click addition\n * back/forward navigations while the confirm is open. Use at your own risk.\n */\nfunction usePrompt({ when, message }: { when: boolean; message: string }) {\n let blocker = useBlocker(when);\n\n React.useEffect(() => {\n if (blocker.state === \"blocked\" && !when) {\n blocker.reset();\n }\n }, [blocker, when]);\n\n React.useEffect(() => {\n if (blocker.state === \"blocked\") {\n let proceed = window.confirm(message);\n if (proceed) {\n setTimeout(blocker.proceed, 0);\n } else {\n blocker.reset();\n }\n }\n }, [blocker, message]);\n}\n\nexport { usePrompt as unstable_usePrompt };\n\n//#endregion\n","import type {\n FormEncType,\n HTMLFormMethod,\n RelativeRoutingType,\n} from \"@remix-run/router\";\nimport { stripBasename } from \"@remix-run/router\";\n\nexport const defaultMethod: HTMLFormMethod = \"get\";\nconst defaultEncType: FormEncType = \"application/x-www-form-urlencoded\";\n\nexport function isHtmlElement(object: any): object is HTMLElement {\n return object != null && typeof object.tagName === \"string\";\n}\n\nexport function isButtonElement(object: any): object is HTMLButtonElement {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"button\";\n}\n\nexport function isFormElement(object: any): object is HTMLFormElement {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"form\";\n}\n\nexport function isInputElement(object: any): object is HTMLInputElement {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"input\";\n}\n\ntype LimitedMouseEvent = Pick<\n MouseEvent,\n \"button\" | \"metaKey\" | \"altKey\" | \"ctrlKey\" | \"shiftKey\"\n>;\n\nfunction isModifiedEvent(event: LimitedMouseEvent) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\n\nexport function shouldProcessLinkClick(\n event: LimitedMouseEvent,\n target?: string\n) {\n return (\n event.button === 0 && // Ignore everything but left clicks\n (!target || target === \"_self\") && // Let browser handle \"target=_blank\" etc.\n !isModifiedEvent(event) // Ignore clicks with modifier keys\n );\n}\n\nexport type ParamKeyValuePair = [string, string];\n\nexport type URLSearchParamsInit =\n | string\n | ParamKeyValuePair[]\n | Record<string, string | string[]>\n | URLSearchParams;\n\n/**\n * Creates a URLSearchParams object using the given initializer.\n *\n * This is identical to `new URLSearchParams(init)` except it also\n * supports arrays as values in the object form of the initializer\n * instead of just strings. This is convenient when you need multiple\n * values for a given key, but don't want to use an array initializer.\n *\n * For example, instead of:\n *\n * let searchParams = new URLSearchParams([\n * ['sort', 'name'],\n * ['sort', 'price']\n * ]);\n *\n * you can do:\n *\n * let searchParams = createSearchParams({\n * sort: ['name', 'price']\n * });\n */\nexport function createSearchParams(\n init: URLSearchParamsInit = \"\"\n): URLSearchParams {\n return new URLSearchParams(\n typeof init === \"string\" ||\n Array.isArray(init) ||\n init instanceof URLSearchParams\n ? init\n : Object.keys(init).reduce((memo, key) => {\n let value = init[key];\n return memo.concat(\n Array.isArray(value) ? value.map((v) => [key, v]) : [[key, value]]\n );\n }, [] as ParamKeyValuePair[])\n );\n}\n\nexport function getSearchParamsForLocation(\n locationSearch: string,\n defaultSearchParams: URLSearchParams | null\n) {\n let searchParams = createSearchParams(locationSearch);\n\n if (defaultSearchParams) {\n for (let key of defaultSearchParams.keys()) {\n if (!searchParams.has(key)) {\n defaultSearchParams.getAll(key).forEach((value) => {\n searchParams.append(key, value);\n });\n }\n }\n }\n\n return searchParams;\n}\n\nexport interface SubmitOptions {\n /**\n * The HTTP method used to submit the form. Overrides `<form method>`.\n * Defaults to \"GET\".\n */\n method?: HTMLFormMethod;\n\n /**\n * The action URL path used to submit the form. Overrides `<form action>`.\n * Defaults to the path of the current route.\n */\n action?: string;\n\n /**\n * The action URL used to submit the form. Overrides `<form encType>`.\n * Defaults to \"application/x-www-form-urlencoded\".\n */\n encType?: FormEncType;\n\n /**\n * Set `true` to replace the current entry in the browser's history stack\n * instead of creating a new one (i.e. stay on \"the same page\"). Defaults\n * to `false`.\n */\n replace?: boolean;\n\n /**\n * Determines whether the form action is relative to the route hierarchy or\n * the pathname. Use this if you want to opt out of navigating the route\n * hierarchy and want to instead route based on /-delimited URL segments\n */\n relative?: RelativeRoutingType;\n\n /**\n * In browser-based environments, prevent resetting scroll after this\n * navigation when using the <ScrollRestoration> component\n */\n preventScrollReset?: boolean;\n}\n\nexport function getFormSubmissionInfo(\n target:\n | HTMLFormElement\n | HTMLButtonElement\n | HTMLInputElement\n | FormData\n | URLSearchParams\n | { [name: string]: string }\n | null,\n options: SubmitOptions,\n basename: string\n): {\n action: string | null;\n method: string;\n encType: string;\n formData: FormData;\n} {\n let method: string;\n let action: string | null = null;\n let encType: string;\n let formData: FormData;\n\n if (isFormElement(target)) {\n let submissionTrigger: HTMLButtonElement | HTMLInputElement = (\n options as any\n ).submissionTrigger;\n\n if (options.action) {\n action = options.action;\n } else {\n // When grabbing the action from the element, it will have had the basename\n // prefixed to ensure non-JS scenarios work, so strip it since we'll\n // re-prefix in the router\n let attr = target.getAttribute(\"action\");\n action = attr ? stripBasename(attr, basename) : null;\n }\n method = options.method || target.getAttribute(\"method\") || defaultMethod;\n encType =\n options.encType || target.getAttribute(\"enctype\") || defaultEncType;\n\n formData = new FormData(target);\n\n if (submissionTrigger && submissionTrigger.name) {\n formData.append(submissionTrigger.name, submissionTrigger.value);\n }\n } else if (\n isButtonElement(target) ||\n (isInputElement(target) &&\n (target.type === \"submit\" || target.type === \"image\"))\n ) {\n let form = target.form;\n\n if (form == null) {\n throw new Error(\n `Cannot submit a <button> or <input type=\"submit\"> without a <form>`\n );\n }\n\n // <button>/<input type=\"submit\"> may override attributes of <form>\n\n if (options.action) {\n action = options.action;\n } else {\n // When grabbing the action from the element, it will have had the basename\n // prefixed to ensure non-JS scenarios work, so strip it since we'll\n // re-prefix in the router\n let attr =\n target.getAttribute(\"formaction\") || form.getAttribute(\"action\");\n action = attr ? stripBasename(attr, basename) : null;\n }\n\n method =\n options.method ||\n target.getAttribute(\"formmethod\") ||\n form.getAttribute(\"method\") ||\n defaultMethod;\n encType =\n options.encType ||\n target.getAttribute(\"formenctype\") ||\n form.getAttribute(\"enctype\") ||\n defaultEncType;\n\n formData = new FormData(form);\n\n // Include name + value from a <button>, appending in case the button name\n // matches an existing input name\n if (target.name) {\n formData.append(target.name, target.value);\n }\n } else if (isHtmlElement(target)) {\n throw new Error(\n `Cannot submit element that is not <form>, <button>, or ` +\n `<input type=\"submit|image\">`\n );\n } else {\n method = options.method || defaultMethod;\n action = options.action || null;\n encType = options.encType || defaultEncType;\n\n if (target instanceof FormData) {\n formData = target;\n } else {\n formData = new FormData();\n\n if (target instanceof URLSearchParams) {\n for (let [name, value] of target) {\n formData.append(name, value);\n }\n } else if (target != null) {\n for (let name of Object.keys(target)) {\n formData.append(name, target[name]);\n }\n }\n }\n }\n\n return { action, method: method.toLowerCase(), encType, formData };\n}\n","import { useEffect, useRef } from 'react';\nimport { createContext, useContext, useState } from 'react';\n\nconst StateContext = createContext(null);\nconst convertCopy = (json) => {\n return json.reduce((obj, item) => {\n const { fields } = item;\n const primaryLang = fields['Copy Name'].toLowerCase();\n const otherLangs = Object.entries(fields).reduce((langs, [lang, value]) => {\n if (lang !== 'Copy Name') {\n langs[lang] = value;\n }\n return langs;\n }, {});\n obj[primaryLang] = otherLangs;\n return obj;\n }, {});\n};\n\nfunction shuffleArray(array) {\n for (let i = array.length - 1; i > 0; i--) {\n const j = Math.floor(Math.random() * (i + 1));\n [array[i], array[j]] = [array[j], array[i]];\n }\n return array;\n}\n\nconst getAdSizes = (fields) => {\n return fields ? Object.keys(fields).filter((key) => /^\\d{2,3}x\\d{2,3}$/.test(key)) : null;\n};\n\nconst AppState = (props) => {\n const largeDataSet = useRef([]); // Assume this is your large data set\n const [display, setDisplay] = useState(null);\n const [video, setVideo] = useState(null);\n const [config, setConfig] = useState(null);\n const [ready, updateReady] = useState(false);\n const [copy, setCopy] = useState(null);\n const [adSizes, setAdSizes] = useState([]);\n const [locale, updateLocale] = useState('EN');\n const [activeOption, setActiveOption] = useState('Display');\n const [expaned, setExpanded] = useState(false);\n\n useEffect(() => {\n const htmlLang = document.documentElement.lang;\n const langCode = htmlLang\n .substring(0, 2)\n .split('')\n .map((char) => char.toUpperCase())\n .join('');\n\n updateLocale(langCode || 'EN');\n let retryCount = 0;\n const maxRetries = 3;\n\n function fetchData() {\n fetch('https://www.criteo.com/react-gallery-list', { mode: 'cors' })\n .then((response) => response.json())\n .then((data) => {\n largeDataSet.current = data;\n const ads = shuffleArray(largeDataSet.current.display.data);\n const video = shuffleArray(largeDataSet.current.video.data);\n const copy = data.copy.data;\n const conf = data.config.data;\n setDisplay(ads);\n setVideo(video);\n setConfig(conf);\n setAdSizes(getAdSizes(ads[0].fields));\n setCopy(convertCopy(copy));\n updateReady(true);\n })\n .catch((error) => {\n console.error('Error:', error);\n if (retryCount < maxRetries) {\n retryCount++;\n console.log(`Retry attempt: ${retryCount}`);\n fetchData();\n } else {\n console.error('Max retry attempts reached');\n }\n });\n }\n\n // Call the function to start fetching data\n fetchData();\n }, []);\n\n const value = {\n adData: display,\n videoData: video,\n ready: ready,\n copy: copy,\n adSizes: adSizes,\n locale: locale,\n activeOption: activeOption,\n setActiveOption: setActiveOption,\n config: config,\n expaned: expaned,\n setExpanded: setExpanded,\n };\n\n return <StateContext.Provider value={value}>{props.children}</StateContext.Provider>;\n};\n\nexport const useAppState = () => useContext(StateContext);\nexport default AppState;\n","var _defs, _g;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgTailSpin(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 38,\n height: 38,\n viewBox: \"0 0 38 38\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"linearGradient\", {\n x1: \"8.042%\",\n y1: \"0%\",\n x2: \"65.682%\",\n y2: \"23.865%\",\n id: \"a\"\n }, /*#__PURE__*/React.createElement(\"stop\", {\n stopColor: \"#2a2974\",\n stopOpacity: 0,\n offset: \"0%\"\n }), /*#__PURE__*/React.createElement(\"stop\", {\n stopColor: \"#2a2974\",\n stopOpacity: 0.631,\n offset: \"63.146%\"\n }), /*#__PURE__*/React.createElement(\"stop\", {\n stopColor: \"#2a2974\",\n offset: \"100%\"\n })))), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n fill: \"none\",\n fillRule: \"evenodd\"\n }, /*#__PURE__*/React.createElement(\"g\", {\n transform: \"translate(1 1)\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n d: \"M36 18c0-9.94-8.06-18-18-18\",\n id: \"Oval-2\",\n stroke: \"url(#a)\",\n strokeWidth: 2\n }, /*#__PURE__*/React.createElement(\"animateTransform\", {\n attributeName: \"transform\",\n type: \"rotate\",\n from: \"0 18 18\",\n to: \"360 18 18\",\n dur: \"0.9s\",\n repeatCount: \"indefinite\"\n })), /*#__PURE__*/React.createElement(\"circle\", {\n fill: \"#2a2974\",\n cx: 36,\n cy: 18,\n r: 1\n }, /*#__PURE__*/React.createElement(\"animateTransform\", {\n attributeName: \"transform\",\n type: \"rotate\",\n from: \"0 18 18\",\n to: \"360 18 18\",\n dur: \"0.9s\",\n repeatCount: \"indefinite\"\n }))))));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgTailSpin);\nexport default __webpack_public_path__ + \"static/media/tail-spin.84e7daf8292f3e91646784b30a4a1a22.svg\";\nexport { ForwardRef as ReactComponent };","import { ReactComponent as LoaderWheel } from '../../src/img/tail-spin.svg';\nconst Loader = ({ hasError }) => {\n return (\n <div className={`loader ${hasError ? 'error' : ''}`}>\n {!hasError ? <LoaderWheel /> : <div className=\"error\">🙀 There was an error! please try again 🙀</div>}\n </div>\n );\n};\n\nexport default Loader;\n","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","import defineProperty from \"./defineProperty.js\";\n\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n\n return keys;\n}\n\nexport default function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n\n return target;\n}","import { useAppState } from '../context/State';\n\nexport const GetCopy = ({ copy = null }) => {\n const state = useAppState();\n let locale = state.locale;\n // console.log(locale)\n if (locale === 'PT') {\n locale = 'BR';\n }\n if (locale === 'JA') {\n locale = 'JP';\n }\n if (locale === 'KO') {\n locale = 'KR';\n }\n if (copy === null) {\n locale = 'EN';\n }\n const copyState = state.copy;\n const text = copyState[copy]?.[locale];\n return text ? text : null;\n};\n","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function _toPropertyKey(arg) {\n var key = toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}","import _typeof from \"./typeof.js\";\nexport default function _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}","import toPropertyKey from \"./toPropertyKey.js\";\nexport default function _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}","import defineProperty from \"./defineProperty.js\";\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n return keys;\n}\nexport default function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (null != _i) {\n var _s,\n _e,\n _x,\n _r,\n _arr = [],\n _n = !0,\n _d = !1;\n try {\n if (_x = (_i = _i.call(arr)).next, 0 === i) {\n if (Object(_i) !== _i) return;\n _n = !1;\n } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0);\n } catch (err) {\n _d = !0, _e = err;\n } finally {\n try {\n if (!_n && null != _i[\"return\"] && (_r = _i[\"return\"](), Object(_r) !== _r)) return;\n } finally {\n if (_d) throw _e;\n }\n }\n return _arr;\n }\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}","import _objectSpread from '@babel/runtime/helpers/esm/objectSpread2';\nimport _slicedToArray from '@babel/runtime/helpers/esm/slicedToArray';\nimport _objectWithoutProperties from '@babel/runtime/helpers/esm/objectWithoutProperties';\nimport { useState, useCallback } from 'react';\n\nvar _excluded = [\"defaultInputValue\", \"defaultMenuIsOpen\", \"defaultValue\", \"inputValue\", \"menuIsOpen\", \"onChange\", \"onInputChange\", \"onMenuClose\", \"onMenuOpen\", \"value\"];\nfunction useStateManager(_ref) {\n var _ref$defaultInputValu = _ref.defaultInputValue,\n defaultInputValue = _ref$defaultInputValu === void 0 ? '' : _ref$defaultInputValu,\n _ref$defaultMenuIsOpe = _ref.defaultMenuIsOpen,\n defaultMenuIsOpen = _ref$defaultMenuIsOpe === void 0 ? false : _ref$defaultMenuIsOpe,\n _ref$defaultValue = _ref.defaultValue,\n defaultValue = _ref$defaultValue === void 0 ? null : _ref$defaultValue,\n propsInputValue = _ref.inputValue,\n propsMenuIsOpen = _ref.menuIsOpen,\n propsOnChange = _ref.onChange,\n propsOnInputChange = _ref.onInputChange,\n propsOnMenuClose = _ref.onMenuClose,\n propsOnMenuOpen = _ref.onMenuOpen,\n propsValue = _ref.value,\n restSelectProps = _objectWithoutProperties(_ref, _excluded);\n var _useState = useState(propsInputValue !== undefined ? propsInputValue : defaultInputValue),\n _useState2 = _slicedToArray(_useState, 2),\n stateInputValue = _useState2[0],\n setStateInputValue = _useState2[1];\n var _useState3 = useState(propsMenuIsOpen !== undefined ? propsMenuIsOpen : defaultMenuIsOpen),\n _useState4 = _slicedToArray(_useState3, 2),\n stateMenuIsOpen = _useState4[0],\n setStateMenuIsOpen = _useState4[1];\n var _useState5 = useState(propsValue !== undefined ? propsValue : defaultValue),\n _useState6 = _slicedToArray(_useState5, 2),\n stateValue = _useState6[0],\n setStateValue = _useState6[1];\n var onChange = useCallback(function (value, actionMeta) {\n if (typeof propsOnChange === 'function') {\n propsOnChange(value, actionMeta);\n }\n setStateValue(value);\n }, [propsOnChange]);\n var onInputChange = useCallback(function (value, actionMeta) {\n var newValue;\n if (typeof propsOnInputChange === 'function') {\n newValue = propsOnInputChange(value, actionMeta);\n }\n setStateInputValue(newValue !== undefined ? newValue : value);\n }, [propsOnInputChange]);\n var onMenuOpen = useCallback(function () {\n if (typeof propsOnMenuOpen === 'function') {\n propsOnMenuOpen();\n }\n setStateMenuIsOpen(true);\n }, [propsOnMenuOpen]);\n var onMenuClose = useCallback(function () {\n if (typeof propsOnMenuClose === 'function') {\n propsOnMenuClose();\n }\n setStateMenuIsOpen(false);\n }, [propsOnMenuClose]);\n var inputValue = propsInputValue !== undefined ? propsInputValue : stateInputValue;\n var menuIsOpen = propsMenuIsOpen !== undefined ? propsMenuIsOpen : stateMenuIsOpen;\n var value = propsValue !== undefined ? propsValue : stateValue;\n return _objectSpread(_objectSpread({}, restSelectProps), {}, {\n inputValue: inputValue,\n menuIsOpen: menuIsOpen,\n onChange: onChange,\n onInputChange: onInputChange,\n onMenuClose: onMenuClose,\n onMenuOpen: onMenuOpen,\n value: value\n });\n}\n\nexport { useStateManager as u };\n","export default function _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, toPropertyKey(descriptor.key), descriptor);\n }\n}\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}","import getPrototypeOf from \"./getPrototypeOf.js\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct.js\";\nimport possibleConstructorReturn from \"./possibleConstructorReturn.js\";\nexport default function _createSuper(Derived) {\n var hasNativeReflectConstruct = isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return possibleConstructorReturn(this, result);\n };\n}","export default function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","/*\n\nBased off glamor's StyleSheet, thanks Sunil â¤ï¸\n\nhigh performance StyleSheet for css-in-js systems\n\n- uses multiple style tags behind the scenes for millions of rules\n- uses `insertRule` for appending in production for *much* faster performance\n\n// usage\n\nimport { StyleSheet } from '@emotion/sheet'\n\nlet styleSheet = new StyleSheet({ key: '', container: document.head })\n\nstyleSheet.insert('#box { border: 1px solid red; }')\n- appends a css rule into the stylesheet\n\nstyleSheet.flush()\n- empties the stylesheet of all its contents\n\n*/\n// $FlowFixMe\nfunction sheetForTag(tag) {\n if (tag.sheet) {\n // $FlowFixMe\n return tag.sheet;\n } // this weirdness brought to you by firefox\n\n /* istanbul ignore next */\n\n\n for (var i = 0; i < document.styleSheets.length; i++) {\n if (document.styleSheets[i].ownerNode === tag) {\n // $FlowFixMe\n return document.styleSheets[i];\n }\n }\n}\n\nfunction createStyleElement(options) {\n var tag = document.createElement('style');\n tag.setAttribute('data-emotion', options.key);\n\n if (options.nonce !== undefined) {\n tag.setAttribute('nonce', options.nonce);\n }\n\n tag.appendChild(document.createTextNode(''));\n tag.setAttribute('data-s', '');\n return tag;\n}\n\nvar StyleSheet = /*#__PURE__*/function () {\n // Using Node instead of HTMLElement since container may be a ShadowRoot\n function StyleSheet(options) {\n var _this = this;\n\n this._insertTag = function (tag) {\n var before;\n\n if (_this.tags.length === 0) {\n if (_this.insertionPoint) {\n before = _this.insertionPoint.nextSibling;\n } else if (_this.prepend) {\n before = _this.container.firstChild;\n } else {\n before = _this.before;\n }\n } else {\n before = _this.tags[_this.tags.length - 1].nextSibling;\n }\n\n _this.container.insertBefore(tag, before);\n\n _this.tags.push(tag);\n };\n\n this.isSpeedy = options.speedy === undefined ? process.env.NODE_ENV === 'production' : options.speedy;\n this.tags = [];\n this.ctr = 0;\n this.nonce = options.nonce; // key is the value of the data-emotion attribute, it's used to identify different sheets\n\n this.key = options.key;\n this.container = options.container;\n this.prepend = options.prepend;\n this.insertionPoint = options.insertionPoint;\n this.before = null;\n }\n\n var _proto = StyleSheet.prototype;\n\n _proto.hydrate = function hydrate(nodes) {\n nodes.forEach(this._insertTag);\n };\n\n _proto.insert = function insert(rule) {\n // the max length is how many rules we have per style tag, it's 65000 in speedy mode\n // it's 1 in dev because we insert source maps that map a single rule to a location\n // and you can only have one source map per style tag\n if (this.ctr % (this.isSpeedy ? 65000 : 1) === 0) {\n this._insertTag(createStyleElement(this));\n }\n\n var tag = this.tags[this.tags.length - 1];\n\n if (process.env.NODE_ENV !== 'production') {\n var isImportRule = rule.charCodeAt(0) === 64 && rule.charCodeAt(1) === 105;\n\n if (isImportRule && this._alreadyInsertedOrderInsensitiveRule) {\n // this would only cause problem in speedy mode\n // but we don't want enabling speedy to affect the observable behavior\n // so we report this error at all times\n console.error(\"You're attempting to insert the following rule:\\n\" + rule + '\\n\\n`@import` rules must be before all other types of rules in a stylesheet but other rules have already been inserted. Please ensure that `@import` rules are before all other rules.');\n }\n this._alreadyInsertedOrderInsensitiveRule = this._alreadyInsertedOrderInsensitiveRule || !isImportRule;\n }\n\n if (this.isSpeedy) {\n var sheet = sheetForTag(tag);\n\n try {\n // this is the ultrafast version, works across browsers\n // the big drawback is that the css won't be editable in devtools\n sheet.insertRule(rule, sheet.cssRules.length);\n } catch (e) {\n if (process.env.NODE_ENV !== 'production' && !/:(-moz-placeholder|-moz-focus-inner|-moz-focusring|-ms-input-placeholder|-moz-read-write|-moz-read-only|-ms-clear|-ms-expand|-ms-reveal){/.test(rule)) {\n console.error(\"There was a problem inserting the following rule: \\\"\" + rule + \"\\\"\", e);\n }\n }\n } else {\n tag.appendChild(document.createTextNode(rule));\n }\n\n this.ctr++;\n };\n\n _proto.flush = function flush() {\n // $FlowFixMe\n this.tags.forEach(function (tag) {\n return tag.parentNode && tag.parentNode.removeChild(tag);\n });\n this.tags = [];\n this.ctr = 0;\n\n if (process.env.NODE_ENV !== 'production') {\n this._alreadyInsertedOrderInsensitiveRule = false;\n }\n };\n\n return StyleSheet;\n}();\n\nexport { StyleSheet };\n","/**\n * @param {number}\n * @return {number}\n */\nexport var abs = Math.abs\n\n/**\n * @param {number}\n * @return {string}\n */\nexport var from = String.fromCharCode\n\n/**\n * @param {object}\n * @return {object}\n */\nexport var assign = Object.assign\n\n/**\n * @param {string} value\n * @param {number} length\n * @return {number}\n */\nexport function hash (value, length) {\n\treturn charat(value, 0) ^ 45 ? (((((((length << 2) ^ charat(value, 0)) << 2) ^ charat(value, 1)) << 2) ^ charat(value, 2)) << 2) ^ charat(value, 3) : 0\n}\n\n/**\n * @param {string} value\n * @return {string}\n */\nexport function trim (value) {\n\treturn value.trim()\n}\n\n/**\n * @param {string} value\n * @param {RegExp} pattern\n * @return {string?}\n */\nexport function match (value, pattern) {\n\treturn (value = pattern.exec(value)) ? value[0] : value\n}\n\n/**\n * @param {string} value\n * @param {(string|RegExp)} pattern\n * @param {string} replacement\n * @return {string}\n */\nexport function replace (value, pattern, replacement) {\n\treturn value.replace(pattern, replacement)\n}\n\n/**\n * @param {string} value\n * @param {string} search\n * @return {number}\n */\nexport function indexof (value, search) {\n\treturn value.indexOf(search)\n}\n\n/**\n * @param {string} value\n * @param {number} index\n * @return {number}\n */\nexport function charat (value, index) {\n\treturn value.charCodeAt(index) | 0\n}\n\n/**\n * @param {string} value\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function substr (value, begin, end) {\n\treturn value.slice(begin, end)\n}\n\n/**\n * @param {string} value\n * @return {number}\n */\nexport function strlen (value) {\n\treturn value.length\n}\n\n/**\n * @param {any[]} value\n * @return {number}\n */\nexport function sizeof (value) {\n\treturn value.length\n}\n\n/**\n * @param {any} value\n * @param {any[]} array\n * @return {any}\n */\nexport function append (value, array) {\n\treturn array.push(value), value\n}\n\n/**\n * @param {string[]} array\n * @param {function} callback\n * @return {string}\n */\nexport function combine (array, callback) {\n\treturn array.map(callback).join('')\n}\n","import {from, trim, charat, strlen, substr, append, assign} from './Utility.js'\n\nexport var line = 1\nexport var column = 1\nexport var length = 0\nexport var position = 0\nexport var character = 0\nexport var characters = ''\n\n/**\n * @param {string} value\n * @param {object | null} root\n * @param {object | null} parent\n * @param {string} type\n * @param {string[] | string} props\n * @param {object[] | string} children\n * @param {number} length\n */\nexport function node (value, root, parent, type, props, children, length) {\n\treturn {value: value, root: root, parent: parent, type: type, props: props, children: children, line: line, column: column, length: length, return: ''}\n}\n\n/**\n * @param {object} root\n * @param {object} props\n * @return {object}\n */\nexport function copy (root, props) {\n\treturn assign(node('', null, null, '', null, null, 0), root, {length: -root.length}, props)\n}\n\n/**\n * @return {number}\n */\nexport function char () {\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function prev () {\n\tcharacter = position > 0 ? charat(characters, --position) : 0\n\n\tif (column--, character === 10)\n\t\tcolumn = 1, line--\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function next () {\n\tcharacter = position < length ? charat(characters, position++) : 0\n\n\tif (column++, character === 10)\n\t\tcolumn = 1, line++\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function peek () {\n\treturn charat(characters, position)\n}\n\n/**\n * @return {number}\n */\nexport function caret () {\n\treturn position\n}\n\n/**\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function slice (begin, end) {\n\treturn substr(characters, begin, end)\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function token (type) {\n\tswitch (type) {\n\t\t// \\0 \\t \\n \\r \\s whitespace token\n\t\tcase 0: case 9: case 10: case 13: case 32:\n\t\t\treturn 5\n\t\t// ! + , / > @ ~ isolate token\n\t\tcase 33: case 43: case 44: case 47: case 62: case 64: case 126:\n\t\t// ; { } breakpoint token\n\t\tcase 59: case 123: case 125:\n\t\t\treturn 4\n\t\t// : accompanied token\n\t\tcase 58:\n\t\t\treturn 3\n\t\t// \" ' ( [ opening delimit token\n\t\tcase 34: case 39: case 40: case 91:\n\t\t\treturn 2\n\t\t// ) ] closing delimit token\n\t\tcase 41: case 93:\n\t\t\treturn 1\n\t}\n\n\treturn 0\n}\n\n/**\n * @param {string} value\n * @return {any[]}\n */\nexport function alloc (value) {\n\treturn line = column = 1, length = strlen(characters = value), position = 0, []\n}\n\n/**\n * @param {any} value\n * @return {any}\n */\nexport function dealloc (value) {\n\treturn characters = '', value\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function delimit (type) {\n\treturn trim(slice(position - 1, delimiter(type === 91 ? type + 2 : type === 40 ? type + 1 : type)))\n}\n\n/**\n * @param {string} value\n * @return {string[]}\n */\nexport function tokenize (value) {\n\treturn dealloc(tokenizer(alloc(value)))\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function whitespace (type) {\n\twhile (character = peek())\n\t\tif (character < 33)\n\t\t\tnext()\n\t\telse\n\t\t\tbreak\n\n\treturn token(type) > 2 || token(character) > 3 ? '' : ' '\n}\n\n/**\n * @param {string[]} children\n * @return {string[]}\n */\nexport function tokenizer (children) {\n\twhile (next())\n\t\tswitch (token(character)) {\n\t\t\tcase 0: append(identifier(position - 1), children)\n\t\t\t\tbreak\n\t\t\tcase 2: append(delimit(character), children)\n\t\t\t\tbreak\n\t\t\tdefault: append(from(character), children)\n\t\t}\n\n\treturn children\n}\n\n/**\n * @param {number} index\n * @param {number} count\n * @return {string}\n */\nexport function escaping (index, count) {\n\twhile (--count && next())\n\t\t// not 0-9 A-F a-f\n\t\tif (character < 48 || character > 102 || (character > 57 && character < 65) || (character > 70 && character < 97))\n\t\t\tbreak\n\n\treturn slice(index, caret() + (count < 6 && peek() == 32 && next() == 32))\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function delimiter (type) {\n\twhile (next())\n\t\tswitch (character) {\n\t\t\t// ] ) \" '\n\t\t\tcase type:\n\t\t\t\treturn position\n\t\t\t// \" '\n\t\t\tcase 34: case 39:\n\t\t\t\tif (type !== 34 && type !== 39)\n\t\t\t\t\tdelimiter(character)\n\t\t\t\tbreak\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (type === 41)\n\t\t\t\t\tdelimiter(type)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tnext()\n\t\t\t\tbreak\n\t\t}\n\n\treturn position\n}\n\n/**\n * @param {number} type\n * @param {number} index\n * @return {number}\n */\nexport function commenter (type, index) {\n\twhile (next())\n\t\t// //\n\t\tif (type + character === 47 + 10)\n\t\t\tbreak\n\t\t// /*\n\t\telse if (type + character === 42 + 42 && peek() === 47)\n\t\t\tbreak\n\n\treturn '/*' + slice(index, position - 1) + '*' + from(type === 47 ? type : next())\n}\n\n/**\n * @param {number} index\n * @return {string}\n */\nexport function identifier (index) {\n\twhile (!token(peek()))\n\t\tnext()\n\n\treturn slice(index, position)\n}\n","export var MS = '-ms-'\nexport var MOZ = '-moz-'\nexport var WEBKIT = '-webkit-'\n\nexport var COMMENT = 'comm'\nexport var RULESET = 'rule'\nexport var DECLARATION = 'decl'\n\nexport var PAGE = '@page'\nexport var MEDIA = '@media'\nexport var IMPORT = '@import'\nexport var CHARSET = '@charset'\nexport var VIEWPORT = '@viewport'\nexport var SUPPORTS = '@supports'\nexport var DOCUMENT = '@document'\nexport var NAMESPACE = '@namespace'\nexport var KEYFRAMES = '@keyframes'\nexport var FONT_FACE = '@font-face'\nexport var COUNTER_STYLE = '@counter-style'\nexport var FONT_FEATURE_VALUES = '@font-feature-values'\nexport var LAYER = '@layer'\n","import {IMPORT, LAYER, COMMENT, RULESET, DECLARATION, KEYFRAMES} from './Enum.js'\nimport {strlen, sizeof} from './Utility.js'\n\n/**\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function serialize (children, callback) {\n\tvar output = ''\n\tvar length = sizeof(children)\n\n\tfor (var i = 0; i < length; i++)\n\t\toutput += callback(children[i], i, children, callback) || ''\n\n\treturn output\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function stringify (element, index, children, callback) {\n\tswitch (element.type) {\n\t\tcase LAYER: if (element.children.length) break\n\t\tcase IMPORT: case DECLARATION: return element.return = element.return || element.value\n\t\tcase COMMENT: return ''\n\t\tcase KEYFRAMES: return element.return = element.value + '{' + serialize(element.children, callback) + '}'\n\t\tcase RULESET: element.value = element.props.join(',')\n\t}\n\n\treturn strlen(children = serialize(element.children, callback)) ? element.return = element.value + '{' + children + '}' : ''\n}\n","import {COMMENT, RULESET, DECLARATION} from './Enum.js'\nimport {abs, charat, trim, from, sizeof, strlen, substr, append, replace, indexof} from './Utility.js'\nimport {node, char, prev, next, peek, caret, alloc, dealloc, delimit, whitespace, escaping, identifier, commenter} from './Tokenizer.js'\n\n/**\n * @param {string} value\n * @return {object[]}\n */\nexport function compile (value) {\n\treturn dealloc(parse('', null, null, null, [''], value = alloc(value), 0, [0], value))\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {string[]} rule\n * @param {string[]} rules\n * @param {string[]} rulesets\n * @param {number[]} pseudo\n * @param {number[]} points\n * @param {string[]} declarations\n * @return {object}\n */\nexport function parse (value, root, parent, rule, rules, rulesets, pseudo, points, declarations) {\n\tvar index = 0\n\tvar offset = 0\n\tvar length = pseudo\n\tvar atrule = 0\n\tvar property = 0\n\tvar previous = 0\n\tvar variable = 1\n\tvar scanning = 1\n\tvar ampersand = 1\n\tvar character = 0\n\tvar type = ''\n\tvar props = rules\n\tvar children = rulesets\n\tvar reference = rule\n\tvar characters = type\n\n\twhile (scanning)\n\t\tswitch (previous = character, character = next()) {\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (previous != 108 && charat(characters, length - 1) == 58) {\n\t\t\t\t\tif (indexof(characters += replace(delimit(character), '&', '&\\f'), '&\\f') != -1)\n\t\t\t\t\t\tampersand = -1\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t// \" ' [\n\t\t\tcase 34: case 39: case 91:\n\t\t\t\tcharacters += delimit(character)\n\t\t\t\tbreak\n\t\t\t// \\t \\n \\r \\s\n\t\t\tcase 9: case 10: case 13: case 32:\n\t\t\t\tcharacters += whitespace(previous)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tcharacters += escaping(caret() - 1, 7)\n\t\t\t\tcontinue\n\t\t\t// /\n\t\t\tcase 47:\n\t\t\t\tswitch (peek()) {\n\t\t\t\t\tcase 42: case 47:\n\t\t\t\t\t\tappend(comment(commenter(next(), caret()), root, parent), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tcharacters += '/'\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t// {\n\t\t\tcase 123 * variable:\n\t\t\t\tpoints[index++] = strlen(characters) * ampersand\n\t\t\t// } ; \\0\n\t\t\tcase 125 * variable: case 59: case 0:\n\t\t\t\tswitch (character) {\n\t\t\t\t\t// \\0 }\n\t\t\t\t\tcase 0: case 125: scanning = 0\n\t\t\t\t\t// ;\n\t\t\t\t\tcase 59 + offset: if (ampersand == -1) characters = replace(characters, /\\f/g, '')\n\t\t\t\t\t\tif (property > 0 && (strlen(characters) - length))\n\t\t\t\t\t\t\tappend(property > 32 ? declaration(characters + ';', rule, parent, length - 1) : declaration(replace(characters, ' ', '') + ';', rule, parent, length - 2), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @ ;\n\t\t\t\t\tcase 59: characters += ';'\n\t\t\t\t\t// { rule/at-rule\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tappend(reference = ruleset(characters, root, parent, index, offset, rules, points, type, props = [], children = [], length), rulesets)\n\n\t\t\t\t\t\tif (character === 123)\n\t\t\t\t\t\t\tif (offset === 0)\n\t\t\t\t\t\t\t\tparse(characters, root, reference, reference, props, rulesets, length, points, children)\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tswitch (atrule === 99 && charat(characters, 3) === 110 ? 100 : atrule) {\n\t\t\t\t\t\t\t\t\t// d l m s\n\t\t\t\t\t\t\t\t\tcase 100: case 108: case 109: case 115:\n\t\t\t\t\t\t\t\t\t\tparse(value, reference, reference, rule && append(ruleset(value, reference, reference, 0, 0, rules, points, type, rules, props = [], length), children), rules, children, length, points, rule ? props : children)\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\t\tparse(characters, reference, reference, reference, [''], children, 0, points, children)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tindex = offset = property = 0, variable = ampersand = 1, type = characters = '', length = pseudo\n\t\t\t\tbreak\n\t\t\t// :\n\t\t\tcase 58:\n\t\t\t\tlength = 1 + strlen(characters), property = previous\n\t\t\tdefault:\n\t\t\t\tif (variable < 1)\n\t\t\t\t\tif (character == 123)\n\t\t\t\t\t\t--variable\n\t\t\t\t\telse if (character == 125 && variable++ == 0 && prev() == 125)\n\t\t\t\t\t\tcontinue\n\n\t\t\t\tswitch (characters += from(character), character * variable) {\n\t\t\t\t\t// &\n\t\t\t\t\tcase 38:\n\t\t\t\t\t\tampersand = offset > 0 ? 1 : (characters += '\\f', -1)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// ,\n\t\t\t\t\tcase 44:\n\t\t\t\t\t\tpoints[index++] = (strlen(characters) - 1) * ampersand, ampersand = 1\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @\n\t\t\t\t\tcase 64:\n\t\t\t\t\t\t// -\n\t\t\t\t\t\tif (peek() === 45)\n\t\t\t\t\t\t\tcharacters += delimit(next())\n\n\t\t\t\t\t\tatrule = peek(), offset = length = strlen(type = characters += identifier(caret())), character++\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// -\n\t\t\t\t\tcase 45:\n\t\t\t\t\t\tif (previous === 45 && strlen(characters) == 2)\n\t\t\t\t\t\t\tvariable = 0\n\t\t\t\t}\n\t\t}\n\n\treturn rulesets\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} index\n * @param {number} offset\n * @param {string[]} rules\n * @param {number[]} points\n * @param {string} type\n * @param {string[]} props\n * @param {string[]} children\n * @param {number} length\n * @return {object}\n */\nexport function ruleset (value, root, parent, index, offset, rules, points, type, props, children, length) {\n\tvar post = offset - 1\n\tvar rule = offset === 0 ? rules : ['']\n\tvar size = sizeof(rule)\n\n\tfor (var i = 0, j = 0, k = 0; i < index; ++i)\n\t\tfor (var x = 0, y = substr(value, post + 1, post = abs(j = points[i])), z = value; x < size; ++x)\n\t\t\tif (z = trim(j > 0 ? rule[x] + ' ' + y : replace(y, /&\\f/g, rule[x])))\n\t\t\t\tprops[k++] = z\n\n\treturn node(value, root, parent, offset === 0 ? RULESET : type, props, children, length)\n}\n\n/**\n * @param {number} value\n * @param {object} root\n * @param {object?} parent\n * @return {object}\n */\nexport function comment (value, root, parent) {\n\treturn node(value, root, parent, COMMENT, from(char()), substr(value, 2, -2), 0)\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} length\n * @return {object}\n */\nexport function declaration (value, root, parent, length) {\n\treturn node(value, root, parent, DECLARATION, substr(value, 0, length), substr(value, length + 1, -1), length)\n}\n","import { StyleSheet } from '@emotion/sheet';\nimport { dealloc, alloc, next, token, from, peek, delimit, slice, position, RULESET, combine, match, serialize, copy, replace, WEBKIT, MOZ, MS, KEYFRAMES, DECLARATION, hash, charat, strlen, indexof, stringify, COMMENT, rulesheet, middleware, compile } from 'stylis';\nimport '@emotion/weak-memoize';\nimport '@emotion/memoize';\n\nvar identifierWithPointTracking = function identifierWithPointTracking(begin, points, index) {\n var previous = 0;\n var character = 0;\n\n while (true) {\n previous = character;\n character = peek(); // &\\f\n\n if (previous === 38 && character === 12) {\n points[index] = 1;\n }\n\n if (token(character)) {\n break;\n }\n\n next();\n }\n\n return slice(begin, position);\n};\n\nvar toRules = function toRules(parsed, points) {\n // pretend we've started with a comma\n var index = -1;\n var character = 44;\n\n do {\n switch (token(character)) {\n case 0:\n // &\\f\n if (character === 38 && peek() === 12) {\n // this is not 100% correct, we don't account for literal sequences here - like for example quoted strings\n // stylis inserts \\f after & to know when & where it should replace this sequence with the context selector\n // and when it should just concatenate the outer and inner selectors\n // it's very unlikely for this sequence to actually appear in a different context, so we just leverage this fact here\n points[index] = 1;\n }\n\n parsed[index] += identifierWithPointTracking(position - 1, points, index);\n break;\n\n case 2:\n parsed[index] += delimit(character);\n break;\n\n case 4:\n // comma\n if (character === 44) {\n // colon\n parsed[++index] = peek() === 58 ? '&\\f' : '';\n points[index] = parsed[index].length;\n break;\n }\n\n // fallthrough\n\n default:\n parsed[index] += from(character);\n }\n } while (character = next());\n\n return parsed;\n};\n\nvar getRules = function getRules(value, points) {\n return dealloc(toRules(alloc(value), points));\n}; // WeakSet would be more appropriate, but only WeakMap is supported in IE11\n\n\nvar fixedElements = /* #__PURE__ */new WeakMap();\nvar compat = function compat(element) {\n if (element.type !== 'rule' || !element.parent || // positive .length indicates that this rule contains pseudo\n // negative .length indicates that this rule has been already prefixed\n element.length < 1) {\n return;\n }\n\n var value = element.value,\n parent = element.parent;\n var isImplicitRule = element.column === parent.column && element.line === parent.line;\n\n while (parent.type !== 'rule') {\n parent = parent.parent;\n if (!parent) return;\n } // short-circuit for the simplest case\n\n\n if (element.props.length === 1 && value.charCodeAt(0) !== 58\n /* colon */\n && !fixedElements.get(parent)) {\n return;\n } // if this is an implicitly inserted rule (the one eagerly inserted at the each new nested level)\n // then the props has already been manipulated beforehand as they that array is shared between it and its \"rule parent\"\n\n\n if (isImplicitRule) {\n return;\n }\n\n fixedElements.set(element, true);\n var points = [];\n var rules = getRules(value, points);\n var parentRules = parent.props;\n\n for (var i = 0, k = 0; i < rules.length; i++) {\n for (var j = 0; j < parentRules.length; j++, k++) {\n element.props[k] = points[i] ? rules[i].replace(/&\\f/g, parentRules[j]) : parentRules[j] + \" \" + rules[i];\n }\n }\n};\nvar removeLabel = function removeLabel(element) {\n if (element.type === 'decl') {\n var value = element.value;\n\n if ( // charcode for l\n value.charCodeAt(0) === 108 && // charcode for b\n value.charCodeAt(2) === 98) {\n // this ignores label\n element[\"return\"] = '';\n element.value = '';\n }\n }\n};\nvar ignoreFlag = 'emotion-disable-server-rendering-unsafe-selector-warning-please-do-not-use-this-the-warning-exists-for-a-reason';\n\nvar isIgnoringComment = function isIgnoringComment(element) {\n return element.type === 'comm' && element.children.indexOf(ignoreFlag) > -1;\n};\n\nvar createUnsafeSelectorsAlarm = function createUnsafeSelectorsAlarm(cache) {\n return function (element, index, children) {\n if (element.type !== 'rule' || cache.compat) return;\n var unsafePseudoClasses = element.value.match(/(:first|:nth|:nth-last)-child/g);\n\n if (unsafePseudoClasses) {\n var isNested = !!element.parent; // in nested rules comments become children of the \"auto-inserted\" rule and that's always the `element.parent`\n //\n // considering this input:\n // .a {\n // .b /* comm */ {}\n // color: hotpink;\n // }\n // we get output corresponding to this:\n // .a {\n // & {\n // /* comm */\n // color: hotpink;\n // }\n // .b {}\n // }\n\n var commentContainer = isNested ? element.parent.children : // global rule at the root level\n children;\n\n for (var i = commentContainer.length - 1; i >= 0; i--) {\n var node = commentContainer[i];\n\n if (node.line < element.line) {\n break;\n } // it is quite weird but comments are *usually* put at `column: element.column - 1`\n // so we seek *from the end* for the node that is earlier than the rule's `element` and check that\n // this will also match inputs like this:\n // .a {\n // /* comm */\n // .b {}\n // }\n //\n // but that is fine\n //\n // it would be the easiest to change the placement of the comment to be the first child of the rule:\n // .a {\n // .b { /* comm */ }\n // }\n // with such inputs we wouldn't have to search for the comment at all\n // TODO: consider changing this comment placement in the next major version\n\n\n if (node.column < element.column) {\n if (isIgnoringComment(node)) {\n return;\n }\n\n break;\n }\n }\n\n unsafePseudoClasses.forEach(function (unsafePseudoClass) {\n console.error(\"The pseudo class \\\"\" + unsafePseudoClass + \"\\\" is potentially unsafe when doing server-side rendering. Try changing it to \\\"\" + unsafePseudoClass.split('-child')[0] + \"-of-type\\\".\");\n });\n }\n };\n};\n\nvar isImportRule = function isImportRule(element) {\n return element.type.charCodeAt(1) === 105 && element.type.charCodeAt(0) === 64;\n};\n\nvar isPrependedWithRegularRules = function isPrependedWithRegularRules(index, children) {\n for (var i = index - 1; i >= 0; i--) {\n if (!isImportRule(children[i])) {\n return true;\n }\n }\n\n return false;\n}; // use this to remove incorrect elements from further processing\n// so they don't get handed to the `sheet` (or anything else)\n// as that could potentially lead to additional logs which in turn could be overhelming to the user\n\n\nvar nullifyElement = function nullifyElement(element) {\n element.type = '';\n element.value = '';\n element[\"return\"] = '';\n element.children = '';\n element.props = '';\n};\n\nvar incorrectImportAlarm = function incorrectImportAlarm(element, index, children) {\n if (!isImportRule(element)) {\n return;\n }\n\n if (element.parent) {\n console.error(\"`@import` rules can't be nested inside other rules. Please move it to the top level and put it before regular rules. Keep in mind that they can only be used within global styles.\");\n nullifyElement(element);\n } else if (isPrependedWithRegularRules(index, children)) {\n console.error(\"`@import` rules can't be after other rules. Please put your `@import` rules before your other rules.\");\n nullifyElement(element);\n }\n};\n\n/* eslint-disable no-fallthrough */\n\nfunction prefix(value, length) {\n switch (hash(value, length)) {\n // color-adjust\n case 5103:\n return WEBKIT + 'print-' + value + value;\n // animation, animation-(delay|direction|duration|fill-mode|iteration-count|name|play-state|timing-function)\n\n case 5737:\n case 4201:\n case 3177:\n case 3433:\n case 1641:\n case 4457:\n case 2921: // text-decoration, filter, clip-path, backface-visibility, column, box-decoration-break\n\n case 5572:\n case 6356:\n case 5844:\n case 3191:\n case 6645:\n case 3005: // mask, mask-image, mask-(mode|clip|size), mask-(repeat|origin), mask-position, mask-composite,\n\n case 6391:\n case 5879:\n case 5623:\n case 6135:\n case 4599:\n case 4855: // background-clip, columns, column-(count|fill|gap|rule|rule-color|rule-style|rule-width|span|width)\n\n case 4215:\n case 6389:\n case 5109:\n case 5365:\n case 5621:\n case 3829:\n return WEBKIT + value + value;\n // appearance, user-select, transform, hyphens, text-size-adjust\n\n case 5349:\n case 4246:\n case 4810:\n case 6968:\n case 2756:\n return WEBKIT + value + MOZ + value + MS + value + value;\n // flex, flex-direction\n\n case 6828:\n case 4268:\n return WEBKIT + value + MS + value + value;\n // order\n\n case 6165:\n return WEBKIT + value + MS + 'flex-' + value + value;\n // align-items\n\n case 5187:\n return WEBKIT + value + replace(value, /(\\w+).+(:[^]+)/, WEBKIT + 'box-$1$2' + MS + 'flex-$1$2') + value;\n // align-self\n\n case 5443:\n return WEBKIT + value + MS + 'flex-item-' + replace(value, /flex-|-self/, '') + value;\n // align-content\n\n case 4675:\n return WEBKIT + value + MS + 'flex-line-pack' + replace(value, /align-content|flex-|-self/, '') + value;\n // flex-shrink\n\n case 5548:\n return WEBKIT + value + MS + replace(value, 'shrink', 'negative') + value;\n // flex-basis\n\n case 5292:\n return WEBKIT + value + MS + replace(value, 'basis', 'preferred-size') + value;\n // flex-grow\n\n case 6060:\n return WEBKIT + 'box-' + replace(value, '-grow', '') + WEBKIT + value + MS + replace(value, 'grow', 'positive') + value;\n // transition\n\n case 4554:\n return WEBKIT + replace(value, /([^-])(transform)/g, '$1' + WEBKIT + '$2') + value;\n // cursor\n\n case 6187:\n return replace(replace(replace(value, /(zoom-|grab)/, WEBKIT + '$1'), /(image-set)/, WEBKIT + '$1'), value, '') + value;\n // background, background-image\n\n case 5495:\n case 3959:\n return replace(value, /(image-set\\([^]*)/, WEBKIT + '$1' + '$`$1');\n // justify-content\n\n case 4968:\n return replace(replace(value, /(.+:)(flex-)?(.*)/, WEBKIT + 'box-pack:$3' + MS + 'flex-pack:$3'), /s.+-b[^;]+/, 'justify') + WEBKIT + value + value;\n // (margin|padding)-inline-(start|end)\n\n case 4095:\n case 3583:\n case 4068:\n case 2532:\n return replace(value, /(.+)-inline(.+)/, WEBKIT + '$1$2') + value;\n // (min|max)?(width|height|inline-size|block-size)\n\n case 8116:\n case 7059:\n case 5753:\n case 5535:\n case 5445:\n case 5701:\n case 4933:\n case 4677:\n case 5533:\n case 5789:\n case 5021:\n case 4765:\n // stretch, max-content, min-content, fill-available\n if (strlen(value) - 1 - length > 6) switch (charat(value, length + 1)) {\n // (m)ax-content, (m)in-content\n case 109:\n // -\n if (charat(value, length + 4) !== 45) break;\n // (f)ill-available, (f)it-content\n\n case 102:\n return replace(value, /(.+:)(.+)-([^]+)/, '$1' + WEBKIT + '$2-$3' + '$1' + MOZ + (charat(value, length + 3) == 108 ? '$3' : '$2-$3')) + value;\n // (s)tretch\n\n case 115:\n return ~indexof(value, 'stretch') ? prefix(replace(value, 'stretch', 'fill-available'), length) + value : value;\n }\n break;\n // position: sticky\n\n case 4949:\n // (s)ticky?\n if (charat(value, length + 1) !== 115) break;\n // display: (flex|inline-flex)\n\n case 6444:\n switch (charat(value, strlen(value) - 3 - (~indexof(value, '!important') && 10))) {\n // stic(k)y\n case 107:\n return replace(value, ':', ':' + WEBKIT) + value;\n // (inline-)?fl(e)x\n\n case 101:\n return replace(value, /(.+:)([^;!]+)(;|!.+)?/, '$1' + WEBKIT + (charat(value, 14) === 45 ? 'inline-' : '') + 'box$3' + '$1' + WEBKIT + '$2$3' + '$1' + MS + '$2box$3') + value;\n }\n\n break;\n // writing-mode\n\n case 5936:\n switch (charat(value, length + 11)) {\n // vertical-l(r)\n case 114:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb') + value;\n // vertical-r(l)\n\n case 108:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb-rl') + value;\n // horizontal(-)tb\n\n case 45:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'lr') + value;\n }\n\n return WEBKIT + value + MS + value + value;\n }\n\n return value;\n}\n\nvar prefixer = function prefixer(element, index, children, callback) {\n if (element.length > -1) if (!element[\"return\"]) switch (element.type) {\n case DECLARATION:\n element[\"return\"] = prefix(element.value, element.length);\n break;\n\n case KEYFRAMES:\n return serialize([copy(element, {\n value: replace(element.value, '@', '@' + WEBKIT)\n })], callback);\n\n case RULESET:\n if (element.length) return combine(element.props, function (value) {\n switch (match(value, /(::plac\\w+|:read-\\w+)/)) {\n // :read-(only|write)\n case ':read-only':\n case ':read-write':\n return serialize([copy(element, {\n props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]\n })], callback);\n // :placeholder\n\n case '::placeholder':\n return serialize([copy(element, {\n props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]\n }), copy(element, {\n props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]\n }), copy(element, {\n props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]\n })], callback);\n }\n\n return '';\n });\n }\n};\n\nvar defaultStylisPlugins = [prefixer];\n\nvar createCache = function createCache(options) {\n var key = options.key;\n\n if (process.env.NODE_ENV !== 'production' && !key) {\n throw new Error(\"You have to configure `key` for your cache. Please make sure it's unique (and not equal to 'css') as it's used for linking styles to your cache.\\n\" + \"If multiple caches share the same key they might \\\"fight\\\" for each other's style elements.\");\n }\n\n if (key === 'css') {\n var ssrStyles = document.querySelectorAll(\"style[data-emotion]:not([data-s])\"); // get SSRed styles out of the way of React's hydration\n // document.head is a safe place to move them to(though note document.head is not necessarily the last place they will be)\n // note this very very intentionally targets all style elements regardless of the key to ensure\n // that creating a cache works inside of render of a React component\n\n Array.prototype.forEach.call(ssrStyles, function (node) {\n // we want to only move elements which have a space in the data-emotion attribute value\n // because that indicates that it is an Emotion 11 server-side rendered style elements\n // while we will already ignore Emotion 11 client-side inserted styles because of the :not([data-s]) part in the selector\n // Emotion 10 client-side inserted styles did not have data-s (but importantly did not have a space in their data-emotion attributes)\n // so checking for the space ensures that loading Emotion 11 after Emotion 10 has inserted some styles\n // will not result in the Emotion 10 styles being destroyed\n var dataEmotionAttribute = node.getAttribute('data-emotion');\n\n if (dataEmotionAttribute.indexOf(' ') === -1) {\n return;\n }\n document.head.appendChild(node);\n node.setAttribute('data-s', '');\n });\n }\n\n var stylisPlugins = options.stylisPlugins || defaultStylisPlugins;\n\n if (process.env.NODE_ENV !== 'production') {\n // $FlowFixMe\n if (/[^a-z-]/.test(key)) {\n throw new Error(\"Emotion key must only contain lower case alphabetical characters and - but \\\"\" + key + \"\\\" was passed\");\n }\n }\n\n var inserted = {};\n var container;\n var nodesToHydrate = [];\n\n {\n container = options.container || document.head;\n Array.prototype.forEach.call( // this means we will ignore elements which don't have a space in them which\n // means that the style elements we're looking at are only Emotion 11 server-rendered style elements\n document.querySelectorAll(\"style[data-emotion^=\\\"\" + key + \" \\\"]\"), function (node) {\n var attrib = node.getAttribute(\"data-emotion\").split(' '); // $FlowFixMe\n\n for (var i = 1; i < attrib.length; i++) {\n inserted[attrib[i]] = true;\n }\n\n nodesToHydrate.push(node);\n });\n }\n\n var _insert;\n\n var omnipresentPlugins = [compat, removeLabel];\n\n if (process.env.NODE_ENV !== 'production') {\n omnipresentPlugins.push(createUnsafeSelectorsAlarm({\n get compat() {\n return cache.compat;\n }\n\n }), incorrectImportAlarm);\n }\n\n {\n var currentSheet;\n var finalizingPlugins = [stringify, process.env.NODE_ENV !== 'production' ? function (element) {\n if (!element.root) {\n if (element[\"return\"]) {\n currentSheet.insert(element[\"return\"]);\n } else if (element.value && element.type !== COMMENT) {\n // insert empty rule in non-production environments\n // so @emotion/jest can grab `key` from the (JS)DOM for caches without any rules inserted yet\n currentSheet.insert(element.value + \"{}\");\n }\n }\n } : rulesheet(function (rule) {\n currentSheet.insert(rule);\n })];\n var serializer = middleware(omnipresentPlugins.concat(stylisPlugins, finalizingPlugins));\n\n var stylis = function stylis(styles) {\n return serialize(compile(styles), serializer);\n };\n\n _insert = function insert(selector, serialized, sheet, shouldCache) {\n currentSheet = sheet;\n\n if (process.env.NODE_ENV !== 'production' && serialized.map !== undefined) {\n currentSheet = {\n insert: function insert(rule) {\n sheet.insert(rule + serialized.map);\n }\n };\n }\n\n stylis(selector ? selector + \"{\" + serialized.styles + \"}\" : serialized.styles);\n\n if (shouldCache) {\n cache.inserted[serialized.name] = true;\n }\n };\n }\n\n var cache = {\n key: key,\n sheet: new StyleSheet({\n key: key,\n container: container,\n nonce: options.nonce,\n speedy: options.speedy,\n prepend: options.prepend,\n insertionPoint: options.insertionPoint\n }),\n nonce: options.nonce,\n inserted: inserted,\n registered: {},\n insert: _insert\n };\n cache.sheet.hydrate(nodesToHydrate);\n return cache;\n};\n\nexport { createCache as default };\n","import {MS, MOZ, WEBKIT, RULESET, KEYFRAMES, DECLARATION} from './Enum.js'\nimport {match, charat, substr, strlen, sizeof, replace, combine} from './Utility.js'\nimport {copy, tokenize} from './Tokenizer.js'\nimport {serialize} from './Serializer.js'\nimport {prefix} from './Prefixer.js'\n\n/**\n * @param {function[]} collection\n * @return {function}\n */\nexport function middleware (collection) {\n\tvar length = sizeof(collection)\n\n\treturn function (element, index, children, callback) {\n\t\tvar output = ''\n\n\t\tfor (var i = 0; i < length; i++)\n\t\t\toutput += collection[i](element, index, children, callback) || ''\n\n\t\treturn output\n\t}\n}\n\n/**\n * @param {function} callback\n * @return {function}\n */\nexport function rulesheet (callback) {\n\treturn function (element) {\n\t\tif (!element.root)\n\t\t\tif (element = element.return)\n\t\t\t\tcallback(element)\n\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n */\nexport function prefixer (element, index, children, callback) {\n\tif (element.length > -1)\n\t\tif (!element.return)\n\t\t\tswitch (element.type) {\n\t\t\t\tcase DECLARATION: element.return = prefix(element.value, element.length, children)\n\t\t\t\t\treturn\n\t\t\t\tcase KEYFRAMES:\n\t\t\t\t\treturn serialize([copy(element, {value: replace(element.value, '@', '@' + WEBKIT)})], callback)\n\t\t\t\tcase RULESET:\n\t\t\t\t\tif (element.length)\n\t\t\t\t\t\treturn combine(element.props, function (value) {\n\t\t\t\t\t\t\tswitch (match(value, /(::plac\\w+|:read-\\w+)/)) {\n\t\t\t\t\t\t\t\t// :read-(only|write)\n\t\t\t\t\t\t\t\tcase ':read-only': case ':read-write':\n\t\t\t\t\t\t\t\t\treturn serialize([copy(element, {props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]})], callback)\n\t\t\t\t\t\t\t\t// :placeholder\n\t\t\t\t\t\t\t\tcase '::placeholder':\n\t\t\t\t\t\t\t\t\treturn serialize([\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]}),\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]}),\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]})\n\t\t\t\t\t\t\t\t\t], callback)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\treturn ''\n\t\t\t\t\t\t})\n\t\t\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n */\nexport function namespace (element) {\n\tswitch (element.type) {\n\t\tcase RULESET:\n\t\t\telement.props = element.props.map(function (value) {\n\t\t\t\treturn combine(tokenize(value), function (value, index, children) {\n\t\t\t\t\tswitch (charat(value, 0)) {\n\t\t\t\t\t\t// \\f\n\t\t\t\t\t\tcase 12:\n\t\t\t\t\t\t\treturn substr(value, 1, strlen(value))\n\t\t\t\t\t\t// \\0 ( + > ~\n\t\t\t\t\t\tcase 0: case 40: case 43: case 62: case 126:\n\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t// :\n\t\t\t\t\t\tcase 58:\n\t\t\t\t\t\t\tif (children[++index] === 'global')\n\t\t\t\t\t\t\t\tchildren[index] = '', children[++index] = '\\f' + substr(children[index], index = 1, -1)\n\t\t\t\t\t\t// \\s\n\t\t\t\t\t\tcase 32:\n\t\t\t\t\t\t\treturn index === 1 ? '' : value\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tswitch (index) {\n\t\t\t\t\t\t\t\tcase 0: element = value\n\t\t\t\t\t\t\t\t\treturn sizeof(children) > 1 ? '' : value\n\t\t\t\t\t\t\t\tcase index = sizeof(children) - 1: case 2:\n\t\t\t\t\t\t\t\t\treturn index === 2 ? value + element + element : value + element\n\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t})\n\t}\n}\n","var isBrowser = \"object\" !== 'undefined';\nfunction getRegisteredStyles(registered, registeredStyles, classNames) {\n var rawClassName = '';\n classNames.split(' ').forEach(function (className) {\n if (registered[className] !== undefined) {\n registeredStyles.push(registered[className] + \";\");\n } else {\n rawClassName += className + \" \";\n }\n });\n return rawClassName;\n}\nvar registerStyles = function registerStyles(cache, serialized, isStringTag) {\n var className = cache.key + \"-\" + serialized.name;\n\n if ( // we only need to add the styles to the registered cache if the\n // class name could be used further down\n // the tree but if it's a string tag, we know it won't\n // so we don't have to add it to registered cache.\n // this improves memory usage since we can avoid storing the whole style string\n (isStringTag === false || // we need to always store it if we're in compat mode and\n // in node since emotion-server relies on whether a style is in\n // the registered cache to know whether a style is global or not\n // also, note that this check will be dead code eliminated in the browser\n isBrowser === false ) && cache.registered[className] === undefined) {\n cache.registered[className] = serialized.styles;\n }\n};\nvar insertStyles = function insertStyles(cache, serialized, isStringTag) {\n registerStyles(cache, serialized, isStringTag);\n var className = cache.key + \"-\" + serialized.name;\n\n if (cache.inserted[serialized.name] === undefined) {\n var current = serialized;\n\n do {\n cache.insert(serialized === current ? \".\" + className : '', current, cache.sheet, true);\n\n current = current.next;\n } while (current !== undefined);\n }\n};\n\nexport { getRegisteredStyles, insertStyles, registerStyles };\n","var unitlessKeys = {\n animationIterationCount: 1,\n aspectRatio: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport { unitlessKeys as default };\n","function memoize(fn) {\n var cache = Object.create(null);\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport { memoize as default };\n","import hashString from '@emotion/hash';\nimport unitless from '@emotion/unitless';\nimport memoize from '@emotion/memoize';\n\nvar ILLEGAL_ESCAPE_SEQUENCE_ERROR = \"You have illegal escape sequence in your template literal, most likely inside content's property value.\\nBecause you write your CSS inside a JavaScript string you actually have to do double escaping, so for example \\\"content: '\\\\00d7';\\\" should become \\\"content: '\\\\\\\\00d7';\\\".\\nYou can read more about this here:\\nhttps://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#ES2018_revision_of_illegal_escape_sequences\";\nvar UNDEFINED_AS_OBJECT_KEY_ERROR = \"You have passed in falsy value as style object's key (can happen when in example you pass unexported component as computed key).\";\nvar hyphenateRegex = /[A-Z]|^ms/g;\nvar animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;\n\nvar isCustomProperty = function isCustomProperty(property) {\n return property.charCodeAt(1) === 45;\n};\n\nvar isProcessableValue = function isProcessableValue(value) {\n return value != null && typeof value !== 'boolean';\n};\n\nvar processStyleName = /* #__PURE__ */memoize(function (styleName) {\n return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, '-$&').toLowerCase();\n});\n\nvar processStyleValue = function processStyleValue(key, value) {\n switch (key) {\n case 'animation':\n case 'animationName':\n {\n if (typeof value === 'string') {\n return value.replace(animationRegex, function (match, p1, p2) {\n cursor = {\n name: p1,\n styles: p2,\n next: cursor\n };\n return p1;\n });\n }\n }\n }\n\n if (unitless[key] !== 1 && !isCustomProperty(key) && typeof value === 'number' && value !== 0) {\n return value + 'px';\n }\n\n return value;\n};\n\nif (process.env.NODE_ENV !== 'production') {\n var contentValuePattern = /(var|attr|counters?|url|element|(((repeating-)?(linear|radial))|conic)-gradient)\\(|(no-)?(open|close)-quote/;\n var contentValues = ['normal', 'none', 'initial', 'inherit', 'unset'];\n var oldProcessStyleValue = processStyleValue;\n var msPattern = /^-ms-/;\n var hyphenPattern = /-(.)/g;\n var hyphenatedCache = {};\n\n processStyleValue = function processStyleValue(key, value) {\n if (key === 'content') {\n if (typeof value !== 'string' || contentValues.indexOf(value) === -1 && !contentValuePattern.test(value) && (value.charAt(0) !== value.charAt(value.length - 1) || value.charAt(0) !== '\"' && value.charAt(0) !== \"'\")) {\n throw new Error(\"You seem to be using a value for 'content' without quotes, try replacing it with `content: '\\\"\" + value + \"\\\"'`\");\n }\n }\n\n var processed = oldProcessStyleValue(key, value);\n\n if (processed !== '' && !isCustomProperty(key) && key.indexOf('-') !== -1 && hyphenatedCache[key] === undefined) {\n hyphenatedCache[key] = true;\n console.error(\"Using kebab-case for css properties in objects is not supported. Did you mean \" + key.replace(msPattern, 'ms-').replace(hyphenPattern, function (str, _char) {\n return _char.toUpperCase();\n }) + \"?\");\n }\n\n return processed;\n };\n}\n\nvar noComponentSelectorMessage = 'Component selectors can only be used in conjunction with ' + '@emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware ' + 'compiler transform.';\n\nfunction handleInterpolation(mergedProps, registered, interpolation) {\n if (interpolation == null) {\n return '';\n }\n\n if (interpolation.__emotion_styles !== undefined) {\n if (process.env.NODE_ENV !== 'production' && interpolation.toString() === 'NO_COMPONENT_SELECTOR') {\n throw new Error(noComponentSelectorMessage);\n }\n\n return interpolation;\n }\n\n switch (typeof interpolation) {\n case 'boolean':\n {\n return '';\n }\n\n case 'object':\n {\n if (interpolation.anim === 1) {\n cursor = {\n name: interpolation.name,\n styles: interpolation.styles,\n next: cursor\n };\n return interpolation.name;\n }\n\n if (interpolation.styles !== undefined) {\n var next = interpolation.next;\n\n if (next !== undefined) {\n // not the most efficient thing ever but this is a pretty rare case\n // and there will be very few iterations of this generally\n while (next !== undefined) {\n cursor = {\n name: next.name,\n styles: next.styles,\n next: cursor\n };\n next = next.next;\n }\n }\n\n var styles = interpolation.styles + \";\";\n\n if (process.env.NODE_ENV !== 'production' && interpolation.map !== undefined) {\n styles += interpolation.map;\n }\n\n return styles;\n }\n\n return createStringFromObject(mergedProps, registered, interpolation);\n }\n\n case 'function':\n {\n if (mergedProps !== undefined) {\n var previousCursor = cursor;\n var result = interpolation(mergedProps);\n cursor = previousCursor;\n return handleInterpolation(mergedProps, registered, result);\n } else if (process.env.NODE_ENV !== 'production') {\n console.error('Functions that are interpolated in css calls will be stringified.\\n' + 'If you want to have a css call based on props, create a function that returns a css call like this\\n' + 'let dynamicStyle = (props) => css`color: ${props.color}`\\n' + 'It can be called directly with props or interpolated in a styled call like this\\n' + \"let SomeComponent = styled('div')`${dynamicStyle}`\");\n }\n\n break;\n }\n\n case 'string':\n if (process.env.NODE_ENV !== 'production') {\n var matched = [];\n var replaced = interpolation.replace(animationRegex, function (match, p1, p2) {\n var fakeVarName = \"animation\" + matched.length;\n matched.push(\"const \" + fakeVarName + \" = keyframes`\" + p2.replace(/^@keyframes animation-\\w+/, '') + \"`\");\n return \"${\" + fakeVarName + \"}\";\n });\n\n if (matched.length) {\n console.error('`keyframes` output got interpolated into plain string, please wrap it with `css`.\\n\\n' + 'Instead of doing this:\\n\\n' + [].concat(matched, [\"`\" + replaced + \"`\"]).join('\\n') + '\\n\\nYou should wrap it with `css` like this:\\n\\n' + (\"css`\" + replaced + \"`\"));\n }\n }\n\n break;\n } // finalize string values (regular strings and functions interpolated into css calls)\n\n\n if (registered == null) {\n return interpolation;\n }\n\n var cached = registered[interpolation];\n return cached !== undefined ? cached : interpolation;\n}\n\nfunction createStringFromObject(mergedProps, registered, obj) {\n var string = '';\n\n if (Array.isArray(obj)) {\n for (var i = 0; i < obj.length; i++) {\n string += handleInterpolation(mergedProps, registered, obj[i]) + \";\";\n }\n } else {\n for (var _key in obj) {\n var value = obj[_key];\n\n if (typeof value !== 'object') {\n if (registered != null && registered[value] !== undefined) {\n string += _key + \"{\" + registered[value] + \"}\";\n } else if (isProcessableValue(value)) {\n string += processStyleName(_key) + \":\" + processStyleValue(_key, value) + \";\";\n }\n } else {\n if (_key === 'NO_COMPONENT_SELECTOR' && process.env.NODE_ENV !== 'production') {\n throw new Error(noComponentSelectorMessage);\n }\n\n if (Array.isArray(value) && typeof value[0] === 'string' && (registered == null || registered[value[0]] === undefined)) {\n for (var _i = 0; _i < value.length; _i++) {\n if (isProcessableValue(value[_i])) {\n string += processStyleName(_key) + \":\" + processStyleValue(_key, value[_i]) + \";\";\n }\n }\n } else {\n var interpolated = handleInterpolation(mergedProps, registered, value);\n\n switch (_key) {\n case 'animation':\n case 'animationName':\n {\n string += processStyleName(_key) + \":\" + interpolated + \";\";\n break;\n }\n\n default:\n {\n if (process.env.NODE_ENV !== 'production' && _key === 'undefined') {\n console.error(UNDEFINED_AS_OBJECT_KEY_ERROR);\n }\n\n string += _key + \"{\" + interpolated + \"}\";\n }\n }\n }\n }\n }\n }\n\n return string;\n}\n\nvar labelPattern = /label:\\s*([^\\s;\\n{]+)\\s*(;|$)/g;\nvar sourceMapPattern;\n\nif (process.env.NODE_ENV !== 'production') {\n sourceMapPattern = /\\/\\*#\\ssourceMappingURL=data:application\\/json;\\S+\\s+\\*\\//g;\n} // this is the cursor for keyframes\n// keyframes are stored on the SerializedStyles object as a linked list\n\n\nvar cursor;\nvar serializeStyles = function serializeStyles(args, registered, mergedProps) {\n if (args.length === 1 && typeof args[0] === 'object' && args[0] !== null && args[0].styles !== undefined) {\n return args[0];\n }\n\n var stringMode = true;\n var styles = '';\n cursor = undefined;\n var strings = args[0];\n\n if (strings == null || strings.raw === undefined) {\n stringMode = false;\n styles += handleInterpolation(mergedProps, registered, strings);\n } else {\n if (process.env.NODE_ENV !== 'production' && strings[0] === undefined) {\n console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n }\n\n styles += strings[0];\n } // we start at 1 since we've already handled the first arg\n\n\n for (var i = 1; i < args.length; i++) {\n styles += handleInterpolation(mergedProps, registered, args[i]);\n\n if (stringMode) {\n if (process.env.NODE_ENV !== 'production' && strings[i] === undefined) {\n console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n }\n\n styles += strings[i];\n }\n }\n\n var sourceMap;\n\n if (process.env.NODE_ENV !== 'production') {\n styles = styles.replace(sourceMapPattern, function (match) {\n sourceMap = match;\n return '';\n });\n } // using a global regex with .exec is stateful so lastIndex has to be reset each time\n\n\n labelPattern.lastIndex = 0;\n var identifierName = '';\n var match; // https://esbench.com/bench/5b809c2cf2949800a0f61fb5\n\n while ((match = labelPattern.exec(styles)) !== null) {\n identifierName += '-' + // $FlowFixMe we know it's not null\n match[1];\n }\n\n var name = hashString(styles) + identifierName;\n\n if (process.env.NODE_ENV !== 'production') {\n // $FlowFixMe SerializedStyles type doesn't have toString property (and we don't want to add it)\n return {\n name: name,\n styles: styles,\n map: sourceMap,\n next: cursor,\n toString: function toString() {\n return \"You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).\";\n }\n };\n }\n\n return {\n name: name,\n styles: styles,\n next: cursor\n };\n};\n\nexport { serializeStyles };\n","/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n // 'm' and 'r' are mixing constants generated offline.\n // They're not really 'magic', they just happen to work well.\n // const m = 0x5bd1e995;\n // const r = 24;\n // Initialize the hash\n var h = 0; // Mix 4 bytes at a time into the hash\n\n var k,\n i = 0,\n len = str.length;\n\n for (; len >= 4; ++i, len -= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n k ^=\n /* k >>> r: */\n k >>> 24;\n h =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Handle the last few bytes of the input array\n\n\n switch (len) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Do a few final mixes of the hash to ensure the last few\n // bytes are well-incorporated.\n\n\n h ^= h >>> 13;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport { murmur2 as default };\n","import * as React from 'react';\n\nvar syncFallback = function syncFallback(create) {\n return create();\n};\n\nvar useInsertionEffect = React['useInsertion' + 'Effect'] ? React['useInsertion' + 'Effect'] : false;\nvar useInsertionEffectAlwaysWithSyncFallback = useInsertionEffect || syncFallback;\nvar useInsertionEffectWithLayoutFallback = useInsertionEffect || React.useLayoutEffect;\n\nexport { useInsertionEffectAlwaysWithSyncFallback, useInsertionEffectWithLayoutFallback };\n","import * as React from 'react';\nimport { useContext, forwardRef } from 'react';\nimport createCache from '@emotion/cache';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport weakMemoize from '@emotion/weak-memoize';\nimport hoistNonReactStatics from '../_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js';\nimport { getRegisteredStyles, registerStyles, insertStyles } from '@emotion/utils';\nimport { serializeStyles } from '@emotion/serialize';\nimport { useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\n\nvar isBrowser = \"object\" !== 'undefined';\nvar hasOwnProperty = {}.hasOwnProperty;\n\nvar EmotionCacheContext = /* #__PURE__ */React.createContext( // we're doing this to avoid preconstruct's dead code elimination in this one case\n// because this module is primarily intended for the browser and node\n// but it's also required in react native and similar environments sometimes\n// and we could have a special build just for that\n// but this is much easier and the native packages\n// might use a different theme context in the future anyway\ntypeof HTMLElement !== 'undefined' ? /* #__PURE__ */createCache({\n key: 'css'\n}) : null);\n\nif (process.env.NODE_ENV !== 'production') {\n EmotionCacheContext.displayName = 'EmotionCacheContext';\n}\n\nvar CacheProvider = EmotionCacheContext.Provider;\nvar __unsafe_useEmotionCache = function useEmotionCache() {\n return useContext(EmotionCacheContext);\n};\n\nvar withEmotionCache = function withEmotionCache(func) {\n // $FlowFixMe\n return /*#__PURE__*/forwardRef(function (props, ref) {\n // the cache will never be null in the browser\n var cache = useContext(EmotionCacheContext);\n return func(props, cache, ref);\n });\n};\n\nif (!isBrowser) {\n withEmotionCache = function withEmotionCache(func) {\n return function (props) {\n var cache = useContext(EmotionCacheContext);\n\n if (cache === null) {\n // yes, we're potentially creating this on every render\n // it doesn't actually matter though since it's only on the server\n // so there will only every be a single render\n // that could change in the future because of suspense and etc. but for now,\n // this works and i don't want to optimise for a future thing that we aren't sure about\n cache = createCache({\n key: 'css'\n });\n return /*#__PURE__*/React.createElement(EmotionCacheContext.Provider, {\n value: cache\n }, func(props, cache));\n } else {\n return func(props, cache);\n }\n };\n };\n}\n\nvar ThemeContext = /* #__PURE__ */React.createContext({});\n\nif (process.env.NODE_ENV !== 'production') {\n ThemeContext.displayName = 'EmotionThemeContext';\n}\n\nvar useTheme = function useTheme() {\n return React.useContext(ThemeContext);\n};\n\nvar getTheme = function getTheme(outerTheme, theme) {\n if (typeof theme === 'function') {\n var mergedTheme = theme(outerTheme);\n\n if (process.env.NODE_ENV !== 'production' && (mergedTheme == null || typeof mergedTheme !== 'object' || Array.isArray(mergedTheme))) {\n throw new Error('[ThemeProvider] Please return an object from your theme function, i.e. theme={() => ({})}!');\n }\n\n return mergedTheme;\n }\n\n if (process.env.NODE_ENV !== 'production' && (theme == null || typeof theme !== 'object' || Array.isArray(theme))) {\n throw new Error('[ThemeProvider] Please make your theme prop a plain object');\n }\n\n return _extends({}, outerTheme, theme);\n};\n\nvar createCacheWithTheme = /* #__PURE__ */weakMemoize(function (outerTheme) {\n return weakMemoize(function (theme) {\n return getTheme(outerTheme, theme);\n });\n});\nvar ThemeProvider = function ThemeProvider(props) {\n var theme = React.useContext(ThemeContext);\n\n if (props.theme !== theme) {\n theme = createCacheWithTheme(theme)(props.theme);\n }\n\n return /*#__PURE__*/React.createElement(ThemeContext.Provider, {\n value: theme\n }, props.children);\n};\nfunction withTheme(Component) {\n var componentName = Component.displayName || Component.name || 'Component';\n\n var render = function render(props, ref) {\n var theme = React.useContext(ThemeContext);\n return /*#__PURE__*/React.createElement(Component, _extends({\n theme: theme,\n ref: ref\n }, props));\n }; // $FlowFixMe\n\n\n var WithTheme = /*#__PURE__*/React.forwardRef(render);\n WithTheme.displayName = \"WithTheme(\" + componentName + \")\";\n return hoistNonReactStatics(WithTheme, Component);\n}\n\nvar getLastPart = function getLastPart(functionName) {\n // The match may be something like 'Object.createEmotionProps' or\n // 'Loader.prototype.render'\n var parts = functionName.split('.');\n return parts[parts.length - 1];\n};\n\nvar getFunctionNameFromStackTraceLine = function getFunctionNameFromStackTraceLine(line) {\n // V8\n var match = /^\\s+at\\s+([A-Za-z0-9$.]+)\\s/.exec(line);\n if (match) return getLastPart(match[1]); // Safari / Firefox\n\n match = /^([A-Za-z0-9$.]+)@/.exec(line);\n if (match) return getLastPart(match[1]);\n return undefined;\n};\n\nvar internalReactFunctionNames = /* #__PURE__ */new Set(['renderWithHooks', 'processChild', 'finishClassComponent', 'renderToString']); // These identifiers come from error stacks, so they have to be valid JS\n// identifiers, thus we only need to replace what is a valid character for JS,\n// but not for CSS.\n\nvar sanitizeIdentifier = function sanitizeIdentifier(identifier) {\n return identifier.replace(/\\$/g, '-');\n};\n\nvar getLabelFromStackTrace = function getLabelFromStackTrace(stackTrace) {\n if (!stackTrace) return undefined;\n var lines = stackTrace.split('\\n');\n\n for (var i = 0; i < lines.length; i++) {\n var functionName = getFunctionNameFromStackTraceLine(lines[i]); // The first line of V8 stack traces is just \"Error\"\n\n if (!functionName) continue; // If we reach one of these, we have gone too far and should quit\n\n if (internalReactFunctionNames.has(functionName)) break; // The component name is the first function in the stack that starts with an\n // uppercase letter\n\n if (/^[A-Z]/.test(functionName)) return sanitizeIdentifier(functionName);\n }\n\n return undefined;\n};\n\nvar typePropName = '__EMOTION_TYPE_PLEASE_DO_NOT_USE__';\nvar labelPropName = '__EMOTION_LABEL_PLEASE_DO_NOT_USE__';\nvar createEmotionProps = function createEmotionProps(type, props) {\n if (process.env.NODE_ENV !== 'production' && typeof props.css === 'string' && // check if there is a css declaration\n props.css.indexOf(':') !== -1) {\n throw new Error(\"Strings are not allowed as css prop values, please wrap it in a css template literal from '@emotion/react' like this: css`\" + props.css + \"`\");\n }\n\n var newProps = {};\n\n for (var key in props) {\n if (hasOwnProperty.call(props, key)) {\n newProps[key] = props[key];\n }\n }\n\n newProps[typePropName] = type; // For performance, only call getLabelFromStackTrace in development and when\n // the label hasn't already been computed\n\n if (process.env.NODE_ENV !== 'production' && !!props.css && (typeof props.css !== 'object' || typeof props.css.name !== 'string' || props.css.name.indexOf('-') === -1)) {\n var label = getLabelFromStackTrace(new Error().stack);\n if (label) newProps[labelPropName] = label;\n }\n\n return newProps;\n};\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serialized = _ref.serialized,\n isStringTag = _ref.isStringTag;\n registerStyles(cache, serialized, isStringTag);\n useInsertionEffectAlwaysWithSyncFallback(function () {\n return insertStyles(cache, serialized, isStringTag);\n });\n\n return null;\n};\n\nvar Emotion = /* #__PURE__ */withEmotionCache(function (props, cache, ref) {\n var cssProp = props.css; // so that using `css` from `emotion` and passing the result to the css prop works\n // not passing the registered cache to serializeStyles because it would\n // make certain babel optimisations not possible\n\n if (typeof cssProp === 'string' && cache.registered[cssProp] !== undefined) {\n cssProp = cache.registered[cssProp];\n }\n\n var WrappedComponent = props[typePropName];\n var registeredStyles = [cssProp];\n var className = '';\n\n if (typeof props.className === 'string') {\n className = getRegisteredStyles(cache.registered, registeredStyles, props.className);\n } else if (props.className != null) {\n className = props.className + \" \";\n }\n\n var serialized = serializeStyles(registeredStyles, undefined, React.useContext(ThemeContext));\n\n if (process.env.NODE_ENV !== 'production' && serialized.name.indexOf('-') === -1) {\n var labelFromStack = props[labelPropName];\n\n if (labelFromStack) {\n serialized = serializeStyles([serialized, 'label:' + labelFromStack + ';']);\n }\n }\n\n className += cache.key + \"-\" + serialized.name;\n var newProps = {};\n\n for (var key in props) {\n if (hasOwnProperty.call(props, key) && key !== 'css' && key !== typePropName && (process.env.NODE_ENV === 'production' || key !== labelPropName)) {\n newProps[key] = props[key];\n }\n }\n\n newProps.ref = ref;\n newProps.className = className;\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serialized: serialized,\n isStringTag: typeof WrappedComponent === 'string'\n }), /*#__PURE__*/React.createElement(WrappedComponent, newProps));\n});\n\nif (process.env.NODE_ENV !== 'production') {\n Emotion.displayName = 'EmotionCssPropInternal';\n}\n\nvar Emotion$1 = Emotion;\n\nexport { CacheProvider as C, Emotion$1 as E, ThemeContext as T, __unsafe_useEmotionCache as _, ThemeProvider as a, withTheme as b, createEmotionProps as c, hasOwnProperty as h, isBrowser as i, useTheme as u, withEmotionCache as w };\n","import { h as hasOwnProperty, E as Emotion, c as createEmotionProps, w as withEmotionCache, T as ThemeContext, i as isBrowser$1 } from './emotion-element-c39617d8.browser.esm.js';\nexport { C as CacheProvider, T as ThemeContext, a as ThemeProvider, _ as __unsafe_useEmotionCache, u as useTheme, w as withEmotionCache, b as withTheme } from './emotion-element-c39617d8.browser.esm.js';\nimport * as React from 'react';\nimport { insertStyles, registerStyles, getRegisteredStyles } from '@emotion/utils';\nimport { useInsertionEffectWithLayoutFallback, useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\nimport { serializeStyles } from '@emotion/serialize';\nimport '@emotion/cache';\nimport '@babel/runtime/helpers/extends';\nimport '@emotion/weak-memoize';\nimport '../_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js';\nimport 'hoist-non-react-statics';\n\nvar pkg = {\n\tname: \"@emotion/react\",\n\tversion: \"11.11.1\",\n\tmain: \"dist/emotion-react.cjs.js\",\n\tmodule: \"dist/emotion-react.esm.js\",\n\tbrowser: {\n\t\t\"./dist/emotion-react.esm.js\": \"./dist/emotion-react.browser.esm.js\"\n\t},\n\texports: {\n\t\t\".\": {\n\t\t\tmodule: {\n\t\t\t\tworker: \"./dist/emotion-react.worker.esm.js\",\n\t\t\t\tbrowser: \"./dist/emotion-react.browser.esm.js\",\n\t\t\t\t\"default\": \"./dist/emotion-react.esm.js\"\n\t\t\t},\n\t\t\t\"import\": \"./dist/emotion-react.cjs.mjs\",\n\t\t\t\"default\": \"./dist/emotion-react.cjs.js\"\n\t\t},\n\t\t\"./jsx-runtime\": {\n\t\t\tmodule: {\n\t\t\t\tworker: \"./jsx-runtime/dist/emotion-react-jsx-runtime.worker.esm.js\",\n\t\t\t\tbrowser: \"./jsx-runtime/dist/emotion-react-jsx-runtime.browser.esm.js\",\n\t\t\t\t\"default\": \"./jsx-runtime/dist/emotion-react-jsx-runtime.esm.js\"\n\t\t\t},\n\t\t\t\"import\": \"./jsx-runtime/dist/emotion-react-jsx-runtime.cjs.mjs\",\n\t\t\t\"default\": \"./jsx-runtime/dist/emotion-react-jsx-runtime.cjs.js\"\n\t\t},\n\t\t\"./_isolated-hnrs\": {\n\t\t\tmodule: {\n\t\t\t\tworker: \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.worker.esm.js\",\n\t\t\t\tbrowser: \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js\",\n\t\t\t\t\"default\": \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.esm.js\"\n\t\t\t},\n\t\t\t\"import\": \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.cjs.mjs\",\n\t\t\t\"default\": \"./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.cjs.js\"\n\t\t},\n\t\t\"./jsx-dev-runtime\": {\n\t\t\tmodule: {\n\t\t\t\tworker: \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.worker.esm.js\",\n\t\t\t\tbrowser: \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.browser.esm.js\",\n\t\t\t\t\"default\": \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.esm.js\"\n\t\t\t},\n\t\t\t\"import\": \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.cjs.mjs\",\n\t\t\t\"default\": \"./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.cjs.js\"\n\t\t},\n\t\t\"./package.json\": \"./package.json\",\n\t\t\"./types/css-prop\": \"./types/css-prop.d.ts\",\n\t\t\"./macro\": {\n\t\t\ttypes: {\n\t\t\t\t\"import\": \"./macro.d.mts\",\n\t\t\t\t\"default\": \"./macro.d.ts\"\n\t\t\t},\n\t\t\t\"default\": \"./macro.js\"\n\t\t}\n\t},\n\ttypes: \"types/index.d.ts\",\n\tfiles: [\n\t\t\"src\",\n\t\t\"dist\",\n\t\t\"jsx-runtime\",\n\t\t\"jsx-dev-runtime\",\n\t\t\"_isolated-hnrs\",\n\t\t\"types/*.d.ts\",\n\t\t\"macro.*\"\n\t],\n\tsideEffects: false,\n\tauthor: \"Emotion Contributors\",\n\tlicense: \"MIT\",\n\tscripts: {\n\t\t\"test:typescript\": \"dtslint types\"\n\t},\n\tdependencies: {\n\t\t\"@babel/runtime\": \"^7.18.3\",\n\t\t\"@emotion/babel-plugin\": \"^11.11.0\",\n\t\t\"@emotion/cache\": \"^11.11.0\",\n\t\t\"@emotion/serialize\": \"^1.1.2\",\n\t\t\"@emotion/use-insertion-effect-with-fallbacks\": \"^1.0.1\",\n\t\t\"@emotion/utils\": \"^1.2.1\",\n\t\t\"@emotion/weak-memoize\": \"^0.3.1\",\n\t\t\"hoist-non-react-statics\": \"^3.3.1\"\n\t},\n\tpeerDependencies: {\n\t\treact: \">=16.8.0\"\n\t},\n\tpeerDependenciesMeta: {\n\t\t\"@types/react\": {\n\t\t\toptional: true\n\t\t}\n\t},\n\tdevDependencies: {\n\t\t\"@definitelytyped/dtslint\": \"0.0.112\",\n\t\t\"@emotion/css\": \"11.11.0\",\n\t\t\"@emotion/css-prettifier\": \"1.1.3\",\n\t\t\"@emotion/server\": \"11.11.0\",\n\t\t\"@emotion/styled\": \"11.11.0\",\n\t\t\"html-tag-names\": \"^1.1.2\",\n\t\treact: \"16.14.0\",\n\t\t\"svg-tag-names\": \"^1.1.1\",\n\t\ttypescript: \"^4.5.5\"\n\t},\n\trepository: \"https://github.com/emotion-js/emotion/tree/main/packages/react\",\n\tpublishConfig: {\n\t\taccess: \"public\"\n\t},\n\t\"umd:main\": \"dist/emotion-react.umd.min.js\",\n\tpreconstruct: {\n\t\tentrypoints: [\n\t\t\t\"./index.js\",\n\t\t\t\"./jsx-runtime.js\",\n\t\t\t\"./jsx-dev-runtime.js\",\n\t\t\t\"./_isolated-hnrs.js\"\n\t\t],\n\t\tumdName: \"emotionReact\",\n\t\texports: {\n\t\t\tenvConditions: [\n\t\t\t\t\"browser\",\n\t\t\t\t\"worker\"\n\t\t\t],\n\t\t\textra: {\n\t\t\t\t\"./types/css-prop\": \"./types/css-prop.d.ts\",\n\t\t\t\t\"./macro\": {\n\t\t\t\t\ttypes: {\n\t\t\t\t\t\t\"import\": \"./macro.d.mts\",\n\t\t\t\t\t\t\"default\": \"./macro.d.ts\"\n\t\t\t\t\t},\n\t\t\t\t\t\"default\": \"./macro.js\"\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n};\n\nvar jsx = function jsx(type, props) {\n var args = arguments;\n\n if (props == null || !hasOwnProperty.call(props, 'css')) {\n // $FlowFixMe\n return React.createElement.apply(undefined, args);\n }\n\n var argsLength = args.length;\n var createElementArgArray = new Array(argsLength);\n createElementArgArray[0] = Emotion;\n createElementArgArray[1] = createEmotionProps(type, props);\n\n for (var i = 2; i < argsLength; i++) {\n createElementArgArray[i] = args[i];\n } // $FlowFixMe\n\n\n return React.createElement.apply(null, createElementArgArray);\n};\n\nvar warnedAboutCssPropForGlobal = false; // maintain place over rerenders.\n// initial render from browser, insertBefore context.sheet.tags[0] or if a style hasn't been inserted there yet, appendChild\n// initial client-side render from SSR, use place of hydrating tag\n\nvar Global = /* #__PURE__ */withEmotionCache(function (props, cache) {\n if (process.env.NODE_ENV !== 'production' && !warnedAboutCssPropForGlobal && ( // check for className as well since the user is\n // probably using the custom createElement which\n // means it will be turned into a className prop\n // $FlowFixMe I don't really want to add it to the type since it shouldn't be used\n props.className || props.css)) {\n console.error(\"It looks like you're using the css prop on Global, did you mean to use the styles prop instead?\");\n warnedAboutCssPropForGlobal = true;\n }\n\n var styles = props.styles;\n var serialized = serializeStyles([styles], undefined, React.useContext(ThemeContext));\n\n if (!isBrowser$1) {\n var _ref;\n\n var serializedNames = serialized.name;\n var serializedStyles = serialized.styles;\n var next = serialized.next;\n\n while (next !== undefined) {\n serializedNames += ' ' + next.name;\n serializedStyles += next.styles;\n next = next.next;\n }\n\n var shouldCache = cache.compat === true;\n var rules = cache.insert(\"\", {\n name: serializedNames,\n styles: serializedStyles\n }, cache.sheet, shouldCache);\n\n if (shouldCache) {\n return null;\n }\n\n return /*#__PURE__*/React.createElement(\"style\", (_ref = {}, _ref[\"data-emotion\"] = cache.key + \"-global \" + serializedNames, _ref.dangerouslySetInnerHTML = {\n __html: rules\n }, _ref.nonce = cache.sheet.nonce, _ref));\n } // yes, i know these hooks are used conditionally\n // but it is based on a constant that will never change at runtime\n // it's effectively like having two implementations and switching them out\n // so it's not actually breaking anything\n\n\n var sheetRef = React.useRef();\n useInsertionEffectWithLayoutFallback(function () {\n var key = cache.key + \"-global\"; // use case of https://github.com/emotion-js/emotion/issues/2675\n\n var sheet = new cache.sheet.constructor({\n key: key,\n nonce: cache.sheet.nonce,\n container: cache.sheet.container,\n speedy: cache.sheet.isSpeedy\n });\n var rehydrating = false; // $FlowFixMe\n\n var node = document.querySelector(\"style[data-emotion=\\\"\" + key + \" \" + serialized.name + \"\\\"]\");\n\n if (cache.sheet.tags.length) {\n sheet.before = cache.sheet.tags[0];\n }\n\n if (node !== null) {\n rehydrating = true; // clear the hash so this node won't be recognizable as rehydratable by other <Global/>s\n\n node.setAttribute('data-emotion', key);\n sheet.hydrate([node]);\n }\n\n sheetRef.current = [sheet, rehydrating];\n return function () {\n sheet.flush();\n };\n }, [cache]);\n useInsertionEffectWithLayoutFallback(function () {\n var sheetRefCurrent = sheetRef.current;\n var sheet = sheetRefCurrent[0],\n rehydrating = sheetRefCurrent[1];\n\n if (rehydrating) {\n sheetRefCurrent[1] = false;\n return;\n }\n\n if (serialized.next !== undefined) {\n // insert keyframes\n insertStyles(cache, serialized.next, true);\n }\n\n if (sheet.tags.length) {\n // if this doesn't exist then it will be null so the style element will be appended\n var element = sheet.tags[sheet.tags.length - 1].nextElementSibling;\n sheet.before = element;\n sheet.flush();\n }\n\n cache.insert(\"\", serialized, sheet, false);\n }, [cache, serialized.name]);\n return null;\n});\n\nif (process.env.NODE_ENV !== 'production') {\n Global.displayName = 'EmotionGlobal';\n}\n\nfunction css() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return serializeStyles(args);\n}\n\nvar keyframes = function keyframes() {\n var insertable = css.apply(void 0, arguments);\n var name = \"animation-\" + insertable.name; // $FlowFixMe\n\n return {\n name: name,\n styles: \"@keyframes \" + name + \"{\" + insertable.styles + \"}\",\n anim: 1,\n toString: function toString() {\n return \"_EMO_\" + this.name + \"_\" + this.styles + \"_EMO_\";\n }\n };\n};\n\nvar classnames = function classnames(args) {\n var len = args.length;\n var i = 0;\n var cls = '';\n\n for (; i < len; i++) {\n var arg = args[i];\n if (arg == null) continue;\n var toAdd = void 0;\n\n switch (typeof arg) {\n case 'boolean':\n break;\n\n case 'object':\n {\n if (Array.isArray(arg)) {\n toAdd = classnames(arg);\n } else {\n if (process.env.NODE_ENV !== 'production' && arg.styles !== undefined && arg.name !== undefined) {\n console.error('You have passed styles created with `css` from `@emotion/react` package to the `cx`.\\n' + '`cx` is meant to compose class names (strings) so you should convert those styles to a class name by passing them to the `css` received from <ClassNames/> component.');\n }\n\n toAdd = '';\n\n for (var k in arg) {\n if (arg[k] && k) {\n toAdd && (toAdd += ' ');\n toAdd += k;\n }\n }\n }\n\n break;\n }\n\n default:\n {\n toAdd = arg;\n }\n }\n\n if (toAdd) {\n cls && (cls += ' ');\n cls += toAdd;\n }\n }\n\n return cls;\n};\n\nfunction merge(registered, css, className) {\n var registeredStyles = [];\n var rawClassName = getRegisteredStyles(registered, registeredStyles, className);\n\n if (registeredStyles.length < 2) {\n return className;\n }\n\n return rawClassName + css(registeredStyles);\n}\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serializedArr = _ref.serializedArr;\n useInsertionEffectAlwaysWithSyncFallback(function () {\n\n for (var i = 0; i < serializedArr.length; i++) {\n insertStyles(cache, serializedArr[i], false);\n }\n });\n\n return null;\n};\n\nvar ClassNames = /* #__PURE__ */withEmotionCache(function (props, cache) {\n var hasRendered = false;\n var serializedArr = [];\n\n var css = function css() {\n if (hasRendered && process.env.NODE_ENV !== 'production') {\n throw new Error('css can only be used during render');\n }\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var serialized = serializeStyles(args, cache.registered);\n serializedArr.push(serialized); // registration has to happen here as the result of this might get consumed by `cx`\n\n registerStyles(cache, serialized, false);\n return cache.key + \"-\" + serialized.name;\n };\n\n var cx = function cx() {\n if (hasRendered && process.env.NODE_ENV !== 'production') {\n throw new Error('cx can only be used during render');\n }\n\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n return merge(cache.registered, css, classnames(args));\n };\n\n var content = {\n css: css,\n cx: cx,\n theme: React.useContext(ThemeContext)\n };\n var ele = props.children(content);\n hasRendered = true;\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serializedArr: serializedArr\n }), ele);\n});\n\nif (process.env.NODE_ENV !== 'production') {\n ClassNames.displayName = 'EmotionClassNames';\n}\n\nif (process.env.NODE_ENV !== 'production') {\n var isBrowser = \"object\" !== 'undefined'; // #1727, #2905 for some reason Jest and Vitest evaluate modules twice if some consuming module gets mocked\n\n var isTestEnv = typeof jest !== 'undefined' || typeof vi !== 'undefined';\n\n if (isBrowser && !isTestEnv) {\n // globalThis has wide browser support - https://caniuse.com/?search=globalThis, Node.js 12 and later\n var globalContext = // $FlowIgnore\n typeof globalThis !== 'undefined' ? globalThis // eslint-disable-line no-undef\n : isBrowser ? window : global;\n var globalKey = \"__EMOTION_REACT_\" + pkg.version.split('.')[0] + \"__\";\n\n if (globalContext[globalKey]) {\n console.warn('You are loading @emotion/react when it is already loaded. Running ' + 'multiple instances may cause problems. This can happen if multiple ' + 'versions are used, or if multiple builds of the same version are ' + 'used.');\n }\n\n globalContext[globalKey] = true;\n }\n}\n\nexport { ClassNames, Global, jsx as createElement, css, jsx, keyframes };\n","import _typeof from \"./typeof.js\";\nexport default function _regeneratorRuntime() {\n \"use strict\";\n /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */\n\n _regeneratorRuntime = function _regeneratorRuntime() {\n return exports;\n };\n\n var exports = {},\n Op = Object.prototype,\n hasOwn = Op.hasOwnProperty,\n $Symbol = \"function\" == typeof Symbol ? Symbol : {},\n iteratorSymbol = $Symbol.iterator || \"@@iterator\",\n asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\",\n toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n return Object.defineProperty(obj, key, {\n value: value,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }), obj[key];\n }\n\n try {\n define({}, \"\");\n } catch (err) {\n define = function define(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator,\n generator = Object.create(protoGenerator.prototype),\n context = new Context(tryLocsList || []);\n return generator._invoke = function (innerFn, self, context) {\n var state = \"suspendedStart\";\n return function (method, arg) {\n if (\"executing\" === state) throw new Error(\"Generator is already running\");\n\n if (\"completed\" === state) {\n if (\"throw\" === method) throw arg;\n return doneResult();\n }\n\n for (context.method = method, context.arg = arg;;) {\n var delegate = context.delegate;\n\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (\"next\" === context.method) context.sent = context._sent = context.arg;else if (\"throw\" === context.method) {\n if (\"suspendedStart\" === state) throw state = \"completed\", context.arg;\n context.dispatchException(context.arg);\n } else \"return\" === context.method && context.abrupt(\"return\", context.arg);\n state = \"executing\";\n var record = tryCatch(innerFn, self, context);\n\n if (\"normal\" === record.type) {\n if (state = context.done ? \"completed\" : \"suspendedYield\", record.arg === ContinueSentinel) continue;\n return {\n value: record.arg,\n done: context.done\n };\n }\n\n \"throw\" === record.type && (state = \"completed\", context.method = \"throw\", context.arg = record.arg);\n }\n };\n }(innerFn, self, context), generator;\n }\n\n function tryCatch(fn, obj, arg) {\n try {\n return {\n type: \"normal\",\n arg: fn.call(obj, arg)\n };\n } catch (err) {\n return {\n type: \"throw\",\n arg: err\n };\n }\n }\n\n exports.wrap = wrap;\n var ContinueSentinel = {};\n\n function Generator() {}\n\n function GeneratorFunction() {}\n\n function GeneratorFunctionPrototype() {}\n\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n var getProto = Object.getPrototypeOf,\n NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype);\n var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype);\n\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function (method) {\n define(prototype, method, function (arg) {\n return this._invoke(method, arg);\n });\n });\n }\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n\n if (\"throw\" !== record.type) {\n var result = record.arg,\n value = result.value;\n return value && \"object\" == _typeof(value) && hasOwn.call(value, \"__await\") ? PromiseImpl.resolve(value.__await).then(function (value) {\n invoke(\"next\", value, resolve, reject);\n }, function (err) {\n invoke(\"throw\", err, resolve, reject);\n }) : PromiseImpl.resolve(value).then(function (unwrapped) {\n result.value = unwrapped, resolve(result);\n }, function (error) {\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n\n reject(record.arg);\n }\n\n var previousPromise;\n\n this._invoke = function (method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function (resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg();\n };\n }\n\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n\n if (undefined === method) {\n if (context.delegate = null, \"throw\" === context.method) {\n if (delegate.iterator[\"return\"] && (context.method = \"return\", context.arg = undefined, maybeInvokeDelegate(delegate, context), \"throw\" === context.method)) return ContinueSentinel;\n context.method = \"throw\", context.arg = new TypeError(\"The iterator does not provide a 'throw' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n if (\"throw\" === record.type) return context.method = \"throw\", context.arg = record.arg, context.delegate = null, ContinueSentinel;\n var info = record.arg;\n return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, \"return\" !== context.method && (context.method = \"next\", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = \"throw\", context.arg = new TypeError(\"iterator result is not an object\"), context.delegate = null, ContinueSentinel);\n }\n\n function pushTryEntry(locs) {\n var entry = {\n tryLoc: locs[0]\n };\n 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\", delete record.arg, entry.completion = record;\n }\n\n function Context(tryLocsList) {\n this.tryEntries = [{\n tryLoc: \"root\"\n }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0);\n }\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) return iteratorMethod.call(iterable);\n if (\"function\" == typeof iterable.next) return iterable;\n\n if (!isNaN(iterable.length)) {\n var i = -1,\n next = function next() {\n for (; ++i < iterable.length;) {\n if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next;\n }\n\n return next.value = undefined, next.done = !0, next;\n };\n\n return next.next = next;\n }\n }\n\n return {\n next: doneResult\n };\n }\n\n function doneResult() {\n return {\n value: undefined,\n done: !0\n };\n }\n\n return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, \"constructor\", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, \"GeneratorFunction\"), exports.isGeneratorFunction = function (genFun) {\n var ctor = \"function\" == typeof genFun && genFun.constructor;\n return !!ctor && (ctor === GeneratorFunction || \"GeneratorFunction\" === (ctor.displayName || ctor.name));\n }, exports.mark = function (genFun) {\n return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, \"GeneratorFunction\")), genFun.prototype = Object.create(Gp), genFun;\n }, exports.awrap = function (arg) {\n return {\n __await: arg\n };\n }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n void 0 === PromiseImpl && (PromiseImpl = Promise);\n var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl);\n return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) {\n return result.done ? result.value : iter.next();\n });\n }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, \"Generator\"), define(Gp, iteratorSymbol, function () {\n return this;\n }), define(Gp, \"toString\", function () {\n return \"[object Generator]\";\n }), exports.keys = function (object) {\n var keys = [];\n\n for (var key in object) {\n keys.push(key);\n }\n\n return keys.reverse(), function next() {\n for (; keys.length;) {\n var key = keys.pop();\n if (key in object) return next.value = key, next.done = !1, next;\n }\n\n return next.done = !0, next;\n };\n }, exports.values = values, Context.prototype = {\n constructor: Context,\n reset: function reset(skipTempReset) {\n if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = \"next\", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) {\n \"t\" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined);\n }\n },\n stop: function stop() {\n this.done = !0;\n var rootRecord = this.tryEntries[0].completion;\n if (\"throw\" === rootRecord.type) throw rootRecord.arg;\n return this.rval;\n },\n dispatchException: function dispatchException(exception) {\n if (this.done) throw exception;\n var context = this;\n\n function handle(loc, caught) {\n return record.type = \"throw\", record.arg = exception, context.next = loc, caught && (context.method = \"next\", context.arg = undefined), !!caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i],\n record = entry.completion;\n if (\"root\" === entry.tryLoc) return handle(\"end\");\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\"),\n hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0);\n } else {\n if (!hasFinally) throw new Error(\"try statement without catch or finally\");\n if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc);\n }\n }\n }\n },\n abrupt: function abrupt(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n\n if (entry.tryLoc <= this.prev && hasOwn.call(entry, \"finallyLoc\") && this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n finallyEntry && (\"break\" === type || \"continue\" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null);\n var record = finallyEntry ? finallyEntry.completion : {};\n return record.type = type, record.arg = arg, finallyEntry ? (this.method = \"next\", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record);\n },\n complete: function complete(record, afterLoc) {\n if (\"throw\" === record.type) throw record.arg;\n return \"break\" === record.type || \"continue\" === record.type ? this.next = record.arg : \"return\" === record.type ? (this.rval = this.arg = record.arg, this.method = \"return\", this.next = \"end\") : \"normal\" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel;\n },\n finish: function finish(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel;\n }\n },\n \"catch\": function _catch(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n\n if (\"throw\" === record.type) {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n\n return thrown;\n }\n }\n\n throw new Error(\"illegal catch attempt\");\n },\n delegateYield: function delegateYield(iterable, resultName, nextLoc) {\n return this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n }, \"next\" === this.method && (this.arg = undefined), ContinueSentinel;\n }\n }, exports;\n}","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}","const sides = ['top', 'right', 'bottom', 'left'];\nconst alignments = ['start', 'end'];\nconst placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-\" + alignments[0], side + \"-\" + alignments[1]), []);\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\nconst floor = Math.floor;\nconst createCoords = v => ({\n x: v,\n y: v\n});\nconst oppositeSideMap = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nconst oppositeAlignmentMap = {\n start: 'end',\n end: 'start'\n};\nfunction clamp(start, value, end) {\n return max(start, min(value, end));\n}\nfunction evaluate(value, param) {\n return typeof value === 'function' ? value(param) : value;\n}\nfunction getSide(placement) {\n return placement.split('-')[0];\n}\nfunction getAlignment(placement) {\n return placement.split('-')[1];\n}\nfunction getOppositeAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}\nfunction getAxisLength(axis) {\n return axis === 'y' ? 'height' : 'width';\n}\nfunction getSideAxis(placement) {\n return ['top', 'bottom'].includes(getSide(placement)) ? 'y' : 'x';\n}\nfunction getAlignmentAxis(placement) {\n return getOppositeAxis(getSideAxis(placement));\n}\nfunction getAlignmentSides(placement, rects, rtl) {\n if (rtl === void 0) {\n rtl = false;\n }\n const alignment = getAlignment(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const length = getAxisLength(alignmentAxis);\n let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n if (rects.reference[length] > rects.floating[length]) {\n mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n }\n return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];\n}\nfunction getExpandedPlacements(placement) {\n const oppositePlacement = getOppositePlacement(placement);\n return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\nfunction getOppositeAlignmentPlacement(placement) {\n return placement.replace(/start|end/g, alignment => oppositeAlignmentMap[alignment]);\n}\nfunction getSideList(side, isStart, rtl) {\n const lr = ['left', 'right'];\n const rl = ['right', 'left'];\n const tb = ['top', 'bottom'];\n const bt = ['bottom', 'top'];\n switch (side) {\n case 'top':\n case 'bottom':\n if (rtl) return isStart ? rl : lr;\n return isStart ? lr : rl;\n case 'left':\n case 'right':\n return isStart ? tb : bt;\n default:\n return [];\n }\n}\nfunction getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {\n const alignment = getAlignment(placement);\n let list = getSideList(getSide(placement), direction === 'start', rtl);\n if (alignment) {\n list = list.map(side => side + \"-\" + alignment);\n if (flipAlignment) {\n list = list.concat(list.map(getOppositeAlignmentPlacement));\n }\n }\n return list;\n}\nfunction getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, side => oppositeSideMap[side]);\n}\nfunction expandPaddingObject(padding) {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n ...padding\n };\n}\nfunction getPaddingObject(padding) {\n return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n top: padding,\n right: padding,\n bottom: padding,\n left: padding\n };\n}\nfunction rectToClientRect(rect) {\n return {\n ...rect,\n top: rect.y,\n left: rect.x,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n };\n}\n\nexport { alignments, clamp, createCoords, evaluate, expandPaddingObject, floor, getAlignment, getAlignmentAxis, getAlignmentSides, getAxisLength, getExpandedPlacements, getOppositeAlignmentPlacement, getOppositeAxis, getOppositeAxisPlacements, getOppositePlacement, getPaddingObject, getSide, getSideAxis, max, min, placements, rectToClientRect, round, sides };\n","function getNodeName(node) {\n if (isNode(node)) {\n return (node.nodeName || '').toLowerCase();\n }\n // Mocked nodes in testing environments may not be instances of Node. By\n // returning `#document` an infinite loop won't occur.\n // https://github.com/floating-ui/floating-ui/issues/2317\n return '#document';\n}\nfunction getWindow(node) {\n var _node$ownerDocument;\n return (node == null ? void 0 : (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n var _ref;\n return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n // Browsers without `ShadowRoot` support.\n if (typeof ShadowRoot === 'undefined') {\n return false;\n }\n return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nfunction isOverflowElement(element) {\n const {\n overflow,\n overflowX,\n overflowY,\n display\n } = getComputedStyle(element);\n return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !['inline', 'contents'].includes(display);\n}\nfunction isTableElement(element) {\n return ['table', 'td', 'th'].includes(getNodeName(element));\n}\nfunction isContainingBlock(element) {\n const webkit = isWebKit();\n const css = getComputedStyle(element);\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n return css.transform !== 'none' || css.perspective !== 'none' || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || ['transform', 'perspective', 'filter'].some(value => (css.willChange || '').includes(value)) || ['paint', 'layout', 'strict', 'content'].some(value => (css.contain || '').includes(value));\n}\nfunction getContainingBlock(element) {\n let currentNode = getParentNode(element);\n while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n if (isContainingBlock(currentNode)) {\n return currentNode;\n } else {\n currentNode = getParentNode(currentNode);\n }\n }\n return null;\n}\nfunction isWebKit() {\n if (typeof CSS === 'undefined' || !CSS.supports) return false;\n return CSS.supports('-webkit-backdrop-filter', 'none');\n}\nfunction isLastTraversableNode(node) {\n return ['html', 'body', '#document'].includes(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n if (isElement(element)) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n }\n return {\n scrollLeft: element.pageXOffset,\n scrollTop: element.pageYOffset\n };\n}\nfunction getParentNode(node) {\n if (getNodeName(node) === 'html') {\n return node;\n }\n const result =\n // Step into the shadow DOM of the parent of a slotted node.\n node.assignedSlot ||\n // DOM Element detected.\n node.parentNode ||\n // ShadowRoot detected.\n isShadowRoot(node) && node.host ||\n // Fallback.\n getDocumentElement(node);\n return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n const parentNode = getParentNode(node);\n if (isLastTraversableNode(parentNode)) {\n return node.ownerDocument ? node.ownerDocument.body : node.body;\n }\n if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n return parentNode;\n }\n return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list) {\n var _node$ownerDocument2;\n if (list === void 0) {\n list = [];\n }\n const scrollableAncestor = getNearestOverflowAncestor(node);\n const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n const win = getWindow(scrollableAncestor);\n if (isBody) {\n return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : []);\n }\n return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor));\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isWebKit };\n","import { rectToClientRect, computePosition as computePosition$1 } from '@floating-ui/core';\nexport { arrow, autoPlacement, detectOverflow, flip, hide, inline, limitShift, offset, shift, size } from '@floating-ui/core';\nimport { round, createCoords, max, min, floor } from '@floating-ui/utils';\nimport { getComputedStyle, isHTMLElement, isElement, getWindow, isWebKit, getDocumentElement, getNodeName, isOverflowElement, getNodeScroll, getOverflowAncestors, getParentNode, isLastTraversableNode, isContainingBlock, isTableElement, getContainingBlock } from '@floating-ui/utils/dom';\nexport { getOverflowAncestors } from '@floating-ui/utils/dom';\n\nfunction getCssDimensions(element) {\n const css = getComputedStyle(element);\n // In testing environments, the `width` and `height` properties are empty\n // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n let width = parseFloat(css.width) || 0;\n let height = parseFloat(css.height) || 0;\n const hasOffset = isHTMLElement(element);\n const offsetWidth = hasOffset ? element.offsetWidth : width;\n const offsetHeight = hasOffset ? element.offsetHeight : height;\n const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;\n if (shouldFallback) {\n width = offsetWidth;\n height = offsetHeight;\n }\n return {\n width,\n height,\n $: shouldFallback\n };\n}\n\nfunction unwrapElement(element) {\n return !isElement(element) ? element.contextElement : element;\n}\n\nfunction getScale(element) {\n const domElement = unwrapElement(element);\n if (!isHTMLElement(domElement)) {\n return createCoords(1);\n }\n const rect = domElement.getBoundingClientRect();\n const {\n width,\n height,\n $\n } = getCssDimensions(domElement);\n let x = ($ ? round(rect.width) : rect.width) / width;\n let y = ($ ? round(rect.height) : rect.height) / height;\n\n // 0, NaN, or Infinity should always fallback to 1.\n\n if (!x || !Number.isFinite(x)) {\n x = 1;\n }\n if (!y || !Number.isFinite(y)) {\n y = 1;\n }\n return {\n x,\n y\n };\n}\n\nconst noOffsets = /*#__PURE__*/createCoords(0);\nfunction getVisualOffsets(element) {\n const win = getWindow(element);\n if (!isWebKit() || !win.visualViewport) {\n return noOffsets;\n }\n return {\n x: win.visualViewport.offsetLeft,\n y: win.visualViewport.offsetTop\n };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {\n return false;\n }\n return isFixed;\n}\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n const clientRect = element.getBoundingClientRect();\n const domElement = unwrapElement(element);\n let scale = createCoords(1);\n if (includeScale) {\n if (offsetParent) {\n if (isElement(offsetParent)) {\n scale = getScale(offsetParent);\n }\n } else {\n scale = getScale(element);\n }\n }\n const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);\n let x = (clientRect.left + visualOffsets.x) / scale.x;\n let y = (clientRect.top + visualOffsets.y) / scale.y;\n let width = clientRect.width / scale.x;\n let height = clientRect.height / scale.y;\n if (domElement) {\n const win = getWindow(domElement);\n const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;\n let currentIFrame = win.frameElement;\n while (currentIFrame && offsetParent && offsetWin !== win) {\n const iframeScale = getScale(currentIFrame);\n const iframeRect = currentIFrame.getBoundingClientRect();\n const css = getComputedStyle(currentIFrame);\n const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n x *= iframeScale.x;\n y *= iframeScale.y;\n width *= iframeScale.x;\n height *= iframeScale.y;\n x += left;\n y += top;\n currentIFrame = getWindow(currentIFrame).frameElement;\n }\n }\n return rectToClientRect({\n width,\n height,\n x,\n y\n });\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n let {\n rect,\n offsetParent,\n strategy\n } = _ref;\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n if (offsetParent === documentElement) {\n return rect;\n }\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n let scale = createCoords(1);\n const offsets = createCoords(0);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isHTMLElement(offsetParent)) {\n const offsetRect = getBoundingClientRect(offsetParent);\n scale = getScale(offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n }\n }\n return {\n width: rect.width * scale.x,\n height: rect.height * scale.y,\n x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x,\n y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y\n };\n}\n\nfunction getClientRects(element) {\n return Array.from(element.getClientRects());\n}\n\nfunction getWindowScrollBarX(element) {\n // If <html> has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n return getBoundingClientRect(getDocumentElement(element)).left + getNodeScroll(element).scrollLeft;\n}\n\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n const html = getDocumentElement(element);\n const scroll = getNodeScroll(element);\n const body = element.ownerDocument.body;\n const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n const y = -scroll.scrollTop;\n if (getComputedStyle(body).direction === 'rtl') {\n x += max(html.clientWidth, body.clientWidth) - width;\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\nfunction getViewportRect(element, strategy) {\n const win = getWindow(element);\n const html = getDocumentElement(element);\n const visualViewport = win.visualViewport;\n let width = html.clientWidth;\n let height = html.clientHeight;\n let x = 0;\n let y = 0;\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n const visualViewportBased = isWebKit();\n if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');\n const top = clientRect.top + element.clientTop;\n const left = clientRect.left + element.clientLeft;\n const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);\n const width = element.clientWidth * scale.x;\n const height = element.clientHeight * scale.y;\n const x = left * scale.x;\n const y = top * scale.y;\n return {\n width,\n height,\n x,\n y\n };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n let rect;\n if (clippingAncestor === 'viewport') {\n rect = getViewportRect(element, strategy);\n } else if (clippingAncestor === 'document') {\n rect = getDocumentRect(getDocumentElement(element));\n } else if (isElement(clippingAncestor)) {\n rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n } else {\n const visualOffsets = getVisualOffsets(element);\n rect = {\n ...clippingAncestor,\n x: clippingAncestor.x - visualOffsets.x,\n y: clippingAncestor.y - visualOffsets.y\n };\n }\n return rectToClientRect(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n const parentNode = getParentNode(element);\n if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {\n return false;\n }\n return getComputedStyle(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);\n}\n\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n const cachedResult = cache.get(element);\n if (cachedResult) {\n return cachedResult;\n }\n let result = getOverflowAncestors(element).filter(el => isElement(el) && getNodeName(el) !== 'body');\n let currentContainingBlockComputedStyle = null;\n const elementIsFixed = getComputedStyle(element).position === 'fixed';\n let currentNode = elementIsFixed ? getParentNode(element) : element;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {\n const computedStyle = getComputedStyle(currentNode);\n const currentNodeIsContaining = isContainingBlock(currentNode);\n if (!currentNodeIsContaining && computedStyle.position === 'fixed') {\n currentContainingBlockComputedStyle = null;\n }\n const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && ['absolute', 'fixed'].includes(currentContainingBlockComputedStyle.position) || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n if (shouldDropCurrentNode) {\n // Drop non-containing blocks.\n result = result.filter(ancestor => ancestor !== currentNode);\n } else {\n // Record last containing block for next iteration.\n currentContainingBlockComputedStyle = computedStyle;\n }\n currentNode = getParentNode(currentNode);\n }\n cache.set(element, result);\n return result;\n}\n\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n let {\n element,\n boundary,\n rootBoundary,\n strategy\n } = _ref;\n const elementClippingAncestors = boundary === 'clippingAncestors' ? getClippingElementAncestors(element, this._c) : [].concat(boundary);\n const clippingAncestors = [...elementClippingAncestors, rootBoundary];\n const firstClippingAncestor = clippingAncestors[0];\n const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {\n const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));\n return {\n width: clippingRect.right - clippingRect.left,\n height: clippingRect.bottom - clippingRect.top,\n x: clippingRect.left,\n y: clippingRect.top\n };\n}\n\nfunction getDimensions(element) {\n return getCssDimensions(element);\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n const isFixed = strategy === 'fixed';\n const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n const offsets = createCoords(0);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isOffsetParentAnElement) {\n const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}\n\nfunction getTrueOffsetParent(element, polyfill) {\n if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {\n return null;\n }\n if (polyfill) {\n return polyfill(element);\n }\n return element.offsetParent;\n}\n\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n const window = getWindow(element);\n if (!isHTMLElement(element)) {\n return window;\n }\n let offsetParent = getTrueOffsetParent(element, polyfill);\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n }\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static' && !isContainingBlock(offsetParent))) {\n return window;\n }\n return offsetParent || getContainingBlock(element) || window;\n}\n\nconst getElementRects = async function (_ref) {\n let {\n reference,\n floating,\n strategy\n } = _ref;\n const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n const getDimensionsFn = this.getDimensions;\n return {\n reference: getRectRelativeToOffsetParent(reference, await getOffsetParentFn(floating), strategy),\n floating: {\n x: 0,\n y: 0,\n ...(await getDimensionsFn(floating))\n }\n };\n};\n\nfunction isRTL(element) {\n return getComputedStyle(element).direction === 'rtl';\n}\n\nconst platform = {\n convertOffsetParentRelativeRectToViewportRelativeRect,\n getDocumentElement,\n getClippingRect,\n getOffsetParent,\n getElementRects,\n getClientRects,\n getDimensions,\n getScale,\n isElement,\n isRTL\n};\n\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n let io = null;\n let timeoutId;\n const root = getDocumentElement(element);\n function cleanup() {\n clearTimeout(timeoutId);\n io && io.disconnect();\n io = null;\n }\n function refresh(skip, threshold) {\n if (skip === void 0) {\n skip = false;\n }\n if (threshold === void 0) {\n threshold = 1;\n }\n cleanup();\n const {\n left,\n top,\n width,\n height\n } = element.getBoundingClientRect();\n if (!skip) {\n onMove();\n }\n if (!width || !height) {\n return;\n }\n const insetTop = floor(top);\n const insetRight = floor(root.clientWidth - (left + width));\n const insetBottom = floor(root.clientHeight - (top + height));\n const insetLeft = floor(left);\n const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n const options = {\n rootMargin,\n threshold: max(0, min(1, threshold)) || 1\n };\n let isFirstUpdate = true;\n function handleObserve(entries) {\n const ratio = entries[0].intersectionRatio;\n if (ratio !== threshold) {\n if (!isFirstUpdate) {\n return refresh();\n }\n if (!ratio) {\n timeoutId = setTimeout(() => {\n refresh(false, 1e-7);\n }, 100);\n } else {\n refresh(false, ratio);\n }\n }\n isFirstUpdate = false;\n }\n\n // Older browsers don't support a `document` as the root and will throw an\n // error.\n try {\n io = new IntersectionObserver(handleObserve, {\n ...options,\n // Handle <iframe>s\n root: root.ownerDocument\n });\n } catch (e) {\n io = new IntersectionObserver(handleObserve, options);\n }\n io.observe(element);\n }\n refresh(true);\n return cleanup;\n}\n\n/**\n * Automatically updates the position of the floating element when necessary.\n * Should only be called when the floating element is mounted on the DOM or\n * visible on the screen.\n * @returns cleanup function that should be invoked when the floating element is\n * removed from the DOM or hidden from the screen.\n * @see https://floating-ui.com/docs/autoUpdate\n */\nfunction autoUpdate(reference, floating, update, options) {\n if (options === void 0) {\n options = {};\n }\n const {\n ancestorScroll = true,\n ancestorResize = true,\n elementResize = typeof ResizeObserver === 'function',\n layoutShift = typeof IntersectionObserver === 'function',\n animationFrame = false\n } = options;\n const referenceEl = unwrapElement(reference);\n const ancestors = ancestorScroll || ancestorResize ? [...(referenceEl ? getOverflowAncestors(referenceEl) : []), ...getOverflowAncestors(floating)] : [];\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.addEventListener('scroll', update, {\n passive: true\n });\n ancestorResize && ancestor.addEventListener('resize', update);\n });\n const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null;\n let reobserveFrame = -1;\n let resizeObserver = null;\n if (elementResize) {\n resizeObserver = new ResizeObserver(_ref => {\n let [firstEntry] = _ref;\n if (firstEntry && firstEntry.target === referenceEl && resizeObserver) {\n // Prevent update loops when using the `size` middleware.\n // https://github.com/floating-ui/floating-ui/issues/1740\n resizeObserver.unobserve(floating);\n cancelAnimationFrame(reobserveFrame);\n reobserveFrame = requestAnimationFrame(() => {\n resizeObserver && resizeObserver.observe(floating);\n });\n }\n update();\n });\n if (referenceEl && !animationFrame) {\n resizeObserver.observe(referenceEl);\n }\n resizeObserver.observe(floating);\n }\n let frameId;\n let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;\n if (animationFrame) {\n frameLoop();\n }\n function frameLoop() {\n const nextRefRect = getBoundingClientRect(reference);\n if (prevRefRect && (nextRefRect.x !== prevRefRect.x || nextRefRect.y !== prevRefRect.y || nextRefRect.width !== prevRefRect.width || nextRefRect.height !== prevRefRect.height)) {\n update();\n }\n prevRefRect = nextRefRect;\n frameId = requestAnimationFrame(frameLoop);\n }\n update();\n return () => {\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.removeEventListener('scroll', update);\n ancestorResize && ancestor.removeEventListener('resize', update);\n });\n cleanupIo && cleanupIo();\n resizeObserver && resizeObserver.disconnect();\n resizeObserver = null;\n if (animationFrame) {\n cancelAnimationFrame(frameId);\n }\n };\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a reference element when it is given a certain CSS positioning\n * strategy.\n */\nconst computePosition = (reference, floating, options) => {\n // This caches the expensive `getClippingElementAncestors` function so that\n // multiple lifecycle resets re-use the same result. It only lives for a\n // single call. If other functions become expensive, we can add them as well.\n const cache = new Map();\n const mergedOptions = {\n platform,\n ...options\n };\n const platformWithCache = {\n ...mergedOptions.platform,\n _c: cache\n };\n return computePosition$1(reference, floating, {\n ...mergedOptions,\n platform: platformWithCache\n });\n};\n\nexport { autoUpdate, computePosition, platform };\n","import { useLayoutEffect } from 'react';\n\nvar index = useLayoutEffect ;\n\nexport default index;\n","export default function _taggedTemplateLiteral(strings, raw) {\n if (!raw) {\n raw = strings.slice(0);\n }\n return Object.freeze(Object.defineProperties(strings, {\n raw: {\n value: Object.freeze(raw)\n }\n }));\n}","var safeIsNaN = Number.isNaN ||\n function ponyfill(value) {\n return typeof value === 'number' && value !== value;\n };\nfunction isEqual(first, second) {\n if (first === second) {\n return true;\n }\n if (safeIsNaN(first) && safeIsNaN(second)) {\n return true;\n }\n return false;\n}\nfunction areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n for (var i = 0; i < newInputs.length; i++) {\n if (!isEqual(newInputs[i], lastInputs[i])) {\n return false;\n }\n }\n return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n if (isEqual === void 0) { isEqual = areInputsEqual; }\n var cache = null;\n function memoized() {\n var newArgs = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\n }\n if (cache && cache.lastThis === this && isEqual(newArgs, cache.lastArgs)) {\n return cache.lastResult;\n }\n var lastResult = resultFn.apply(this, newArgs);\n cache = {\n lastResult: lastResult,\n lastArgs: newArgs,\n lastThis: this,\n };\n return lastResult;\n }\n memoized.clear = function clear() {\n cache = null;\n };\n return memoized;\n}\n\nexport { memoizeOne as default };\n","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","import { u as useStateManager } from './useStateManager-7e1e8489.esm.js';\nexport { u as useStateManager } from './useStateManager-7e1e8489.esm.js';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport * as React from 'react';\nimport { forwardRef, useMemo } from 'react';\nimport { S as Select } from './Select-aecb2a80.esm.js';\nexport { c as createFilter, d as defaultTheme, m as mergeStyles } from './Select-aecb2a80.esm.js';\nimport { CacheProvider } from '@emotion/react';\nimport createCache from '@emotion/cache';\nexport { c as components } from './index-baa8dc4f.esm.js';\nimport '@babel/runtime/helpers/objectSpread2';\nimport '@babel/runtime/helpers/slicedToArray';\nimport '@babel/runtime/helpers/objectWithoutProperties';\nimport '@babel/runtime/helpers/classCallCheck';\nimport '@babel/runtime/helpers/createClass';\nimport '@babel/runtime/helpers/inherits';\nimport '@babel/runtime/helpers/createSuper';\nimport '@babel/runtime/helpers/toConsumableArray';\nimport 'memoize-one';\nimport '@babel/runtime/helpers/typeof';\nimport '@babel/runtime/helpers/taggedTemplateLiteral';\nimport '@babel/runtime/helpers/defineProperty';\nimport 'react-dom';\nimport '@floating-ui/dom';\nimport 'use-isomorphic-layout-effect';\n\nvar StateManagedSelect = /*#__PURE__*/forwardRef(function (props, ref) {\n var baseSelectProps = useStateManager(props);\n return /*#__PURE__*/React.createElement(Select, _extends({\n ref: ref\n }, baseSelectProps));\n});\nvar StateManagedSelect$1 = StateManagedSelect;\n\nvar NonceProvider = (function (_ref) {\n var nonce = _ref.nonce,\n children = _ref.children,\n cacheKey = _ref.cacheKey;\n var emotionCache = useMemo(function () {\n return createCache({\n key: cacheKey,\n nonce: nonce\n });\n }, [cacheKey, nonce]);\n return /*#__PURE__*/React.createElement(CacheProvider, {\n value: emotionCache\n }, children);\n});\n\nexport { NonceProvider, StateManagedSelect$1 as default };\n","import React, { useState, useEffect } from 'react';\nimport { useAppState } from '../context/State';\nimport { GetCopy } from '../util/GetCopy';\nimport Select from 'react-select';\n\nconst Dropdown = ({ selectedFormat, setSelectedFormat, setNextAdIndex }) => {\n const state = useAppState();\n const [uniqueFormats, setUniqueFormats] = useState(null);\n\n const [selectedLabel, updateSelectedLabel] = useState(<GetCopy copy=\"all\" />);\n\n const handleSelectChange = (event) => {\n setNextAdIndex(9);\n setSelectedFormat(event.value);\n updateSelectedLabel(event.label);\n };\n\n useEffect(() => {\n setSelectedFormat('All');\n updateSelectedLabel(<GetCopy copy=\"all\" />);\n if (state.activeOption === 'Display') {\n setUniqueFormats([...new Set(state.adData.map((item) => item.fields.Format))]);\n } else {\n setUniqueFormats([...new Set(state.videoData.map((item) => item.fields.Format))]);\n }\n }, [state.activeOption]);\n const formats = uniqueFormats;\n\n const options = formats && [\n { value: 'All', label: <GetCopy copy=\"all\" /> },\n ...formats.map((format) => ({ value: format, label: format })),\n ];\n\n const colourStyles = {\n control: (styles) => ({\n ...styles,\n backgroundColor: 'transparent',\n borderColor: 'transparent',\n border: 0,\n boxShadow: 'none',\n cursor: 'pointer',\n }),\n container: (styles) => ({ ...styles, maxWidth: '290px' }),\n menu: (styles) => ({ ...styles, backgroundColor: 'white' }),\n\n indicatorSeparator: (styles) => ({ ...styles, display: 'none' }),\n option: (styles, { data, isDisabled, isFocused, isSelected }) => {\n return {\n ...styles,\n backgroundColor: 'white',\n color: 'blacks',\n cursor: isDisabled ? 'not-allowed' : 'pointer',\n focus: 'none',\n };\n },\n };\n\n const MyComponent = () =>\n (options && (\n <Select\n styles={colourStyles}\n options={options}\n isSearchable={false}\n onChange={handleSelectChange}\n components={{ DropdownIndicator: () => null, IndicatorSeparator: () => null }}\n defaultValue={{\n value: selectedFormat,\n label: (\n <div>\n {selectedLabel}\n <img src=\"/wp-content/themes/criteo2017/img/down.svg\" className=\"labelArrow\" />\n </div>\n ),\n }}\n />\n )) ||\n null;\n return (\n <div>\n <MyComponent />\n </div>\n );\n};\n\nexport default Dropdown;\n","import type { ObserverInstanceCallback } from './index';\n\nconst observerMap = new Map<\n string,\n {\n id: string;\n observer: IntersectionObserver;\n elements: Map<Element, Array<ObserverInstanceCallback>>;\n }\n>();\n\nconst RootIds: WeakMap<Element | Document, string> = new WeakMap();\nlet rootId = 0;\n\nlet unsupportedValue: boolean | undefined = undefined;\n\n/**\n * What should be the default behavior if the IntersectionObserver is unsupported?\n * Ideally the polyfill has been loaded, you can have the following happen:\n * - `undefined`: Throw an error\n * - `true` or `false`: Set the `inView` value to this regardless of intersection state\n * **/\nexport function defaultFallbackInView(inView: boolean | undefined) {\n unsupportedValue = inView;\n}\n\n/**\n * Generate a unique ID for the root element\n * @param root\n */\nfunction getRootId(root: IntersectionObserverInit['root']) {\n if (!root) return '0';\n if (RootIds.has(root)) return RootIds.get(root);\n rootId += 1;\n RootIds.set(root, rootId.toString());\n return RootIds.get(root);\n}\n\n/**\n * Convert the options to a string Id, based on the values.\n * Ensures we can reuse the same observer when observing elements with the same options.\n * @param options\n */\nexport function optionsToId(options: IntersectionObserverInit) {\n return Object.keys(options)\n .sort()\n .filter((key) => options[key] !== undefined)\n .map((key) => {\n return `${key}_${\n key === 'root' ? getRootId(options.root) : options[key]\n }`;\n })\n .toString();\n}\n\nfunction createObserver(options: IntersectionObserverInit) {\n // Create a unique ID for this observer instance, based on the root, root margin and threshold.\n let id = optionsToId(options);\n let instance = observerMap.get(id);\n\n if (!instance) {\n // Create a map of elements this observer is going to observe. Each element has a list of callbacks that should be triggered, once it comes into view.\n const elements = new Map<Element, Array<ObserverInstanceCallback>>();\n let thresholds: number[] | readonly number[];\n\n const observer = new IntersectionObserver((entries) => {\n entries.forEach((entry) => {\n // While it would be nice if you could just look at isIntersecting to determine if the component is inside the viewport, browsers can't agree on how to use it.\n // -Firefox ignores `threshold` when considering `isIntersecting`, so it will never be false again if `threshold` is > 0\n const inView =\n entry.isIntersecting &&\n thresholds.some((threshold) => entry.intersectionRatio >= threshold);\n\n // @ts-ignore support IntersectionObserver v2\n if (options.trackVisibility && typeof entry.isVisible === 'undefined') {\n // The browser doesn't support Intersection Observer v2, falling back to v1 behavior.\n // @ts-ignore\n entry.isVisible = inView;\n }\n\n elements.get(entry.target)?.forEach((callback) => {\n callback(inView, entry);\n });\n });\n }, options);\n\n // Ensure we have a valid thresholds array. If not, use the threshold from the options\n thresholds =\n observer.thresholds ||\n (Array.isArray(options.threshold)\n ? options.threshold\n : [options.threshold || 0]);\n\n instance = {\n id,\n observer,\n elements,\n };\n\n observerMap.set(id, instance);\n }\n\n return instance;\n}\n\n/**\n * @param element - DOM Element to observe\n * @param callback - Callback function to trigger when intersection status changes\n * @param options - Intersection Observer options\n * @param fallbackInView - Fallback inView value.\n * @return Function - Cleanup function that should be triggered to unregister the observer\n */\nexport function observe(\n element: Element,\n callback: ObserverInstanceCallback,\n options: IntersectionObserverInit = {},\n fallbackInView = unsupportedValue,\n) {\n if (\n typeof window.IntersectionObserver === 'undefined' &&\n fallbackInView !== undefined\n ) {\n const bounds = element.getBoundingClientRect();\n callback(fallbackInView, {\n isIntersecting: fallbackInView,\n target: element,\n intersectionRatio:\n typeof options.threshold === 'number' ? options.threshold : 0,\n time: 0,\n boundingClientRect: bounds,\n intersectionRect: bounds,\n rootBounds: bounds,\n });\n return () => {\n // Nothing to cleanup\n };\n }\n // An observer with the same options can be reused, so lets use this fact\n const { id, observer, elements } = createObserver(options);\n\n // Register the callback listener for this element\n let callbacks = elements.get(element) || [];\n if (!elements.has(element)) {\n elements.set(element, callbacks);\n }\n\n callbacks.push(callback);\n observer.observe(element);\n\n return function unobserve() {\n // Remove the callback from the callback list\n callbacks.splice(callbacks.indexOf(callback), 1);\n\n if (callbacks.length === 0) {\n // No more callback exists for element, so destroy it\n elements.delete(element);\n observer.unobserve(element);\n }\n\n if (elements.size === 0) {\n // No more elements are being observer by this instance, so destroy it\n observer.disconnect();\n observerMap.delete(id);\n }\n };\n}\n","import * as React from 'react';\nimport type { IntersectionObserverProps, PlainChildrenProps } from './index';\nimport { observe } from './observe';\n\ntype State = {\n inView: boolean;\n entry?: IntersectionObserverEntry;\n};\n\nfunction isPlainChildren(\n props: IntersectionObserverProps | PlainChildrenProps,\n): props is PlainChildrenProps {\n return typeof props.children !== 'function';\n}\n\n/**\n ## Render props\n\n To use the `<InView>` component, you pass it a function. It will be called\n whenever the state changes, with the new value of `inView`. In addition to the\n `inView` prop, children also receive a `ref` that should be set on the\n containing DOM element. This is the element that the IntersectionObserver will\n monitor.\n\n If you need it, you can also access the\n [`IntersectionObserverEntry`](https://developer.mozilla.org/en-US/docs/Web/API/IntersectionObserverEntry)\n on `entry`, giving you access to all the details about the current intersection\n state.\n\n ```jsx\n import { InView } from 'react-intersection-observer';\n\n const Component = () => (\n <InView>\n {({ inView, ref, entry }) => (\n <div ref={ref}>\n <h2>{`Header inside viewport ${inView}.`}</h2>\n </div>\n )}\n </InView>\n );\n\n export default Component;\n ```\n\n ## Plain children\n\n You can pass any element to the `<InView />`, and it will handle creating the\n wrapping DOM element. Add a handler to the `onChange` method, and control the\n state in your own component. Any extra props you add to `<InView>` will be\n passed to the HTML element, allowing you set the `className`, `style`, etc.\n\n ```jsx\n import { InView } from 'react-intersection-observer';\n\n const Component = () => (\n <InView as=\"div\" onChange={(inView, entry) => console.log('Inview:', inView)}>\n <h2>Plain children are always rendered. Use onChange to monitor state.</h2>\n </InView>\n );\n\n export default Component;\n ```\n */\nexport class InView extends React.Component<\n IntersectionObserverProps | PlainChildrenProps,\n State\n> {\n constructor(props: IntersectionObserverProps | PlainChildrenProps) {\n super(props);\n this.state = {\n inView: !!props.initialInView,\n entry: undefined,\n };\n }\n\n componentDidUpdate(prevProps: IntersectionObserverProps) {\n // If a IntersectionObserver option changed, reinit the observer\n if (\n prevProps.rootMargin !== this.props.rootMargin ||\n prevProps.root !== this.props.root ||\n prevProps.threshold !== this.props.threshold ||\n prevProps.skip !== this.props.skip ||\n prevProps.trackVisibility !== this.props.trackVisibility ||\n prevProps.delay !== this.props.delay\n ) {\n this.unobserve();\n this.observeNode();\n }\n }\n\n componentWillUnmount() {\n this.unobserve();\n this.node = null;\n }\n\n node: Element | null = null;\n _unobserveCb: (() => void) | null = null;\n\n observeNode() {\n if (!this.node || this.props.skip) return;\n const {\n threshold,\n root,\n rootMargin,\n trackVisibility,\n delay,\n fallbackInView,\n } = this.props;\n\n this._unobserveCb = observe(\n this.node,\n this.handleChange,\n {\n threshold,\n root,\n rootMargin,\n // @ts-ignore\n trackVisibility,\n // @ts-ignore\n delay,\n },\n fallbackInView,\n );\n }\n\n unobserve() {\n if (this._unobserveCb) {\n this._unobserveCb();\n this._unobserveCb = null;\n }\n }\n\n handleNode = (node?: Element | null) => {\n if (this.node) {\n // Clear the old observer, before we start observing a new element\n this.unobserve();\n\n if (!node && !this.props.triggerOnce && !this.props.skip) {\n // Reset the state if we get a new node, and we aren't ignoring updates\n this.setState({ inView: !!this.props.initialInView, entry: undefined });\n }\n }\n\n this.node = node ? node : null;\n this.observeNode();\n };\n\n handleChange = (inView: boolean, entry: IntersectionObserverEntry) => {\n if (inView && this.props.triggerOnce) {\n // If `triggerOnce` is true, we should stop observing the element.\n this.unobserve();\n }\n if (!isPlainChildren(this.props)) {\n // Store the current State, so we can pass it to the children in the next render update\n // There's no reason to update the state for plain children, since it's not used in the rendering.\n this.setState({ inView, entry });\n }\n if (this.props.onChange) {\n // If the user is actively listening for onChange, always trigger it\n this.props.onChange(inView, entry);\n }\n };\n\n render() {\n if (!isPlainChildren(this.props)) {\n const { inView, entry } = this.state;\n return this.props.children({ inView, entry, ref: this.handleNode });\n }\n\n const {\n children,\n as,\n triggerOnce,\n threshold,\n root,\n rootMargin,\n onChange,\n skip,\n trackVisibility,\n delay,\n initialInView,\n fallbackInView,\n ...props\n } = this.props;\n\n return React.createElement(\n as || 'div',\n { ref: this.handleNode, ...props },\n children,\n );\n }\n}\n","import * as React from 'react';\nimport type { InViewHookResponse, IntersectionOptions } from './index';\nimport { observe } from './observe';\n\ntype State = {\n inView: boolean;\n entry?: IntersectionObserverEntry;\n};\n\n/**\n * React Hooks make it easy to monitor the `inView` state of your components. Call\n * the `useInView` hook with the (optional) [options](#options) you need. It will\n * return an array containing a `ref`, the `inView` status and the current\n * [`entry`](https://developer.mozilla.org/en-US/docs/Web/API/IntersectionObserverEntry).\n * Assign the `ref` to the DOM element you want to monitor, and the hook will\n * report the status.\n *\n * @example\n * ```jsx\n * import React from 'react';\n * import { useInView } from 'react-intersection-observer';\n *\n * const Component = () => {\n * const { ref, inView, entry } = useInView({\n * threshold: 0,\n * });\n *\n * return (\n * <div ref={ref}>\n * <h2>{`Header inside viewport ${inView}.`}</h2>\n * </div>\n * );\n * };\n * ```\n */\nexport function useInView({\n threshold,\n delay,\n trackVisibility,\n rootMargin,\n root,\n triggerOnce,\n skip,\n initialInView,\n fallbackInView,\n onChange,\n}: IntersectionOptions = {}): InViewHookResponse {\n const [ref, setRef] = React.useState<Element | null>(null);\n const callback = React.useRef<IntersectionOptions['onChange']>();\n const [state, setState] = React.useState<State>({\n inView: !!initialInView,\n entry: undefined,\n });\n\n // Store the onChange callback in a `ref`, so we can access the latest instance\n // inside the `useEffect`, but without triggering a rerender.\n callback.current = onChange;\n\n React.useEffect(\n () => {\n // Ensure we have node ref, and that we shouldn't skip observing\n if (skip || !ref) return;\n\n let unobserve: (() => void) | undefined;\n unobserve = observe(\n ref,\n (inView, entry) => {\n setState({\n inView,\n entry,\n });\n if (callback.current) callback.current(inView, entry);\n\n if (entry.isIntersecting && triggerOnce && unobserve) {\n // If it should only trigger once, unobserve the element after it's inView\n unobserve();\n unobserve = undefined;\n }\n },\n {\n root,\n rootMargin,\n threshold,\n // @ts-ignore\n trackVisibility,\n // @ts-ignore\n delay,\n },\n fallbackInView,\n );\n\n return () => {\n if (unobserve) {\n unobserve();\n }\n };\n },\n // We break the rule here, because we aren't including the actual `threshold` variable\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [\n // If the threshold is an array, convert it to a string, so it won't change between renders.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n Array.isArray(threshold) ? threshold.toString() : threshold,\n ref,\n root,\n rootMargin,\n triggerOnce,\n skip,\n trackVisibility,\n fallbackInView,\n delay,\n ],\n );\n\n const entryTarget = state.entry?.target;\n const previousEntryTarget = React.useRef<Element>();\n if (\n !ref &&\n entryTarget &&\n !triggerOnce &&\n !skip &&\n previousEntryTarget.current !== entryTarget\n ) {\n // If we don't have a node ref, then reset the state (unless the hook is set to only `triggerOnce` or `skip`)\n // This ensures we correctly reflect the current state - If you aren't observing anything, then nothing is inView\n previousEntryTarget.current = entryTarget;\n setState({\n inView: !!initialInView,\n entry: undefined,\n });\n }\n\n const result = [setRef, state.inView, state.entry] as InViewHookResponse;\n\n // Support object destructuring, by adding the specific values.\n result.ref = result[0];\n result.inView = result[1];\n result.entry = result[2];\n\n return result;\n}\n","import React, { useCallback, useEffect, useRef, useState } from 'react';\nimport { Link, useLocation } from 'react-router-dom';\nimport { useInView } from 'react-intersection-observer';\n\nconst VideoCarouselCard = ({ item, activeOption }) => {\n const videoRef = useRef(null);\n const { ref: inViewRef, inView } = useInView({ threshold: 1 });\n const combinedRef = useCallback(\n (node) => {\n videoRef.current = node;\n inViewRef(node);\n },\n [inViewRef],\n );\n const brandSlug = item.fields.Brand.toLowerCase().trim().replace(/ /g, '-');\n const location = useLocation();\n const [playState, updatePlayState] = useState('paused');\n const handleMouseEnter = () => {\n updatePlayState('playing');\n videoRef.current.play();\n };\n\n const handleMouseLeave = () => {\n updatePlayState('paused');\n videoRef.current.pause();\n videoRef.current.currentTime = 0;\n };\n useEffect(() => {\n if (videoRef.current) {\n videoRef.current.play();\n videoRef.current.pause();\n videoRef.current.currentTime = 0;\n }\n }, [item]);\n\n useEffect(() => {\n const isMobile = /iPhone|iPad|iPod|Android/i.test(navigator.userAgent);\n if (isMobile && inView && videoRef.current) {\n updatePlayState('playing');\n videoRef.current.play();\n } else {\n updatePlayState('paused');\n videoRef?.current?.pause();\n }\n }, [inView, item]);\n\n if (activeOption === 'Video') {\n if (!item.fields || !item.fields['16:9']) return null;\n const videoUrlVideo = item.fields['16:9'][0].url;\n return (\n <Link to={`${location.pathname}video/${brandSlug}`} className={`videoCard ${playState}`}>\n <div key={item.index}>\n <video\n ref={combinedRef}\n type=\"video/mp4\"\n width=\"365px\"\n height=\"600px\"\n muted\n controls={false}\n playsInline\n autoPlay={false}\n src={videoUrlVideo}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n />\n </div>\n </Link>\n );\n }\n if (activeOption === 'Display') {\n if (!item.fields || !item.fields['300x250']) return null;\n const videoUrl300x250 = item.fields['300x250'][0].url;\n return (\n <Link to={`${location.pathname}display/${brandSlug}`} className={`displayCard ${playState}`}>\n <div key={item.index}>\n <video\n ref={combinedRef}\n width=\"300\"\n type=\"video/mp4\"\n height=\"250\"\n muted\n playsInline\n controls={false}\n src={videoUrl300x250}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n />\n </div>\n </Link>\n );\n }\n};\n\nexport default VideoCarouselCard;\n","var _path;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgCheck(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 12,\n height: 10,\n viewBox: \"0 0 12 10\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M4.00005 9.04999L0.175049 5.22499L1.22505 4.17499L4.00005 6.94999L10.775 0.174988L11.825 1.22499L4.00005 9.04999Z\",\n fill: \"black\"\n })));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgCheck);\nexport default __webpack_public_path__ + \"static/media/check.ca1866b7fef82ec5cf5c8f4ac64bc915.svg\";\nexport { ForwardRef as ReactComponent };","import React, { useCallback, useEffect, useState } from 'react';\nimport { useAppState } from '../context/State';\nimport VideoCarouselCard from './VideoCarouselCard';\nimport { GetCopy } from '../util/GetCopy';\nimport { useInView } from 'react-intersection-observer';\n\nconst VideoCarousel = ({ selectedFormat }) => {\n const state = useAppState();\n const adData = state.adData;\n const videoData = state.videoData;\n\n const selectedOption = state.activeOption;\n const [filteredData, setFilteredData] = useState([]);\n const activeOption = state.activeOption;\n const [visibleAdData, setVisibleAdData] = useState([...adData.slice(0, 0 + 9)]);\n\n const loadMoreAds = () => {\n setVisibleAdData((prevData) => {\n const newIndex = prevData.length;\n return [...prevData, ...filteredData.slice(newIndex, newIndex + 9)];\n });\n };\n\n const LoadMoreButtonComponent = () => {\n const { ref, inView } = useInView({\n // Triggered when 50% of element is visible\n threshold: 0.5,\n });\n const debounce = (func, delay) => {\n let timer;\n return () => {\n clearTimeout(timer);\n timer = setTimeout(() => {\n func();\n }, delay);\n };\n };\n\n const handleInView = useCallback(\n debounce(() => {\n loadMoreAds();\n }, 100), // 300ms delay\n [], // dependencies\n );\n\n useEffect(() => {\n if (visibleAdData.length < filteredData.length && inView) {\n handleInView();\n }\n }, [inView, handleInView]);\n\n return (\n (visibleAdData.length < filteredData.length && (\n <button ref={ref} className=\"loadMoreButton\" onClick={loadMoreAds}>\n <span className=\"mb-3\">\n <GetCopy copy=\"load more\" />\n </span>\n </button>\n )) ||\n null\n );\n };\n useEffect(() => {\n if (selectedOption === 'Display') {\n const dataToFilter = adData;\n const dt = dataToFilter.filter((item) => {\n if (selectedFormat === 'All') return true; // If 'All' is selected, show all formats\n if (item.fields && item.fields.Format) {\n return item.fields.Format === selectedFormat;\n }\n return false;\n });\n setFilteredData(dt);\n setVisibleAdData([...dt.slice(0, 0 + 9)]);\n }\n }, [selectedFormat, adData, videoData, selectedOption]);\n\n useEffect(() => {\n if (selectedOption === 'Video') {\n const dataToFilter = videoData;\n const dt = dataToFilter.filter((item) => {\n if (selectedFormat === 'All') return true; // If 'All' is selected, show all formats\n if (item.fields && item.fields.Format) {\n return item.fields.Format === selectedFormat;\n }\n return false;\n });\n setFilteredData(dt);\n }\n }, [selectedFormat, adData, videoData, selectedOption]);\n\n if (!state || !adData) return 'Loading...';\n const dataToPreview = selectedOption === 'Video' ? filteredData : visibleAdData;\n\n return (\n <div style={{ width: '100%', overflow: 'hidden' }}>\n <div className=\"row\">\n <div className=\"container displayContainer flex-row flex-wrap\">\n {dataToPreview.map((item, index) => {\n if (item.fields.Live) {\n return <VideoCarouselCard item={item} key={index} index={index} activeOption={activeOption} />;\n }\n return null;\n })}\n </div>\n </div>\n <LoadMoreButtonComponent />\n </div>\n );\n};\n\nexport default VideoCarousel;\n","var _rect, _rect2, _rect3, _rect4, _rect5, _rect6, _rect7, _rect8, _rect9, _rect10, _rect11, _rect12, _defs;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgVipad300X250(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 246,\n height: 417,\n viewBox: \"0 0 321 417\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _rect || (_rect = /*#__PURE__*/React.createElement(\"rect\", {\n width: 320.031,\n height: 417,\n fill: \"url(#pattern0)\"\n })), _rect2 || (_rect2 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 284,\n width: 226,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect3 || (_rect3 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 302,\n width: 204.907,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect4 || (_rect4 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 235,\n width: 226,\n height: 14,\n fill: \"#F0F0F0\"\n })), _rect5 || (_rect5 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 256,\n width: 189.84,\n height: 14,\n fill: \"#F0F0F0\"\n })), _rect6 || (_rect6 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 293,\n width: 174.773,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect7 || (_rect7 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 318,\n width: 226,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect8 || (_rect8 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 336,\n width: 204.907,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect9 || (_rect9 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 327,\n width: 174.773,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect10 || (_rect10 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 357,\n width: 226,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect11 || (_rect11 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 375,\n width: 204.907,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect12 || (_rect12 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 45,\n y: 366,\n width: 174.773,\n height: 6,\n fill: \"#F0F0F0\"\n })), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern0\",\n patternContentUnits: \"objectBoundingBox\",\n width: 1,\n height: 1\n }, /*#__PURE__*/React.createElement(\"use\", {\n xlinkHref: \"#image0_347_438\",\n transform: \"matrix(0.00103413 0 0 0.000793651 -1.05067 -0.225397)\"\n })), /*#__PURE__*/React.createElement(\"image\", {\n id: \"image0_347_438\",\n width: 3000,\n height: 1846,\n xlinkHref: \"data:image/png;base64,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\"\n }))));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgVipad300X250);\nexport default __webpack_public_path__ + \"static/media/vipad-300x250.083a4c56a91c9953e4ad1280d4b679b7.svg\";\nexport { ForwardRef as ReactComponent };","import React from 'react';\nimport { GetCopy } from '../util/GetCopy';\nimport { ReactComponent as Check } from '../../src/img/check.svg';\nimport { useAppState } from '../context/State';\nconst ToggleButton = ({ setNextAdIndex, setSelectedFormat }) => {\n const state = useAppState();\n const options = ['Display', 'Video'];\n const handleToggle = () => {\n state.setActiveOption((prevOption) => (prevOption === 'Display' ? 'Video' : 'Display'));\n setNextAdIndex(9);\n };\n\n return (\n <button onClick={handleToggle} className=\"toggleButton\">\n {options.map((text) => (\n <span key={text} className={state.activeOption === text ? 'active' : null}>\n {state.activeOption === text && <Check className=\"checkmark\" />}\n <GetCopy copy={text.toLocaleLowerCase()} />\n </span>\n ))}\n </button>\n );\n};\n\nexport default ToggleButton;\n","import React from 'react';\nimport ToggleButton from './ToggleButton';\nimport { GetCopy } from '../util/GetCopy';\nimport { useNavigate } from 'react-router-dom';\n\nconst Hero = ({ showCopy = false, brand = null, setNextAdIndex,setSelectedFormat }) => {\n const navigate = useNavigate();\n const goBack = () => {\n navigate(-1);\n };\n\n return (\n <div className={`${showCopy ? null : 'brandHero'} hero `}>\n {showCopy && (\n <>\n <span className=\"caption\">\n <GetCopy copy=\"ad gallery\" />\n </span>\n <h3 className=\"mt-3 text-center mb-4\">\n <GetCopy copy=\"header\" />\n </h3>\n <p className=\"pb-3\" style={{ maxWidth: '500px', textAlign: 'center', padding: '0 15px' }}>\n <GetCopy copy=\"header description\" />\n </p>\n <ToggleButton setNextAdIndex={setNextAdIndex}/>\n </>\n )}\n {!showCopy && (\n <>\n <span>\n <button className=\"breadcumbButton caption\" onClick={goBack}>\n <GetCopy onClick={goBack} copy=\"ad gallery\" />\n </button>\n <span className=\"breadcrumBrand caption\">{' > '}</span>\n <span className=\"breadcrumBrand bcCurrent caption\">{brand}</span>\n </span>\n </>\n )}\n </div>\n );\n};\n\nexport default Hero;\n","import React, { useState } from 'react';\nimport Dropdown from './Dropdown';\nimport VideoCarousel from './VideoCarousel';\nimport Hero from './Hero';\n\nconst FilteredVideoCarousel = () => {\n const [selectedFormat, setSelectedFormat] = useState('All');\n const [nextAdIndex, setNextAdIndex] = useState(9);\n\n return (\n <div>\n <Hero showCopy={true} setNextAdIndex={setNextAdIndex} />\n <div className=\"marginContainer\">\n <div className=\"\">\n <div className=\"container\">\n <Dropdown selectedFormat={selectedFormat} setSelectedFormat={setSelectedFormat} nextAdIndex={nextAdIndex} setNextAdIndex={setNextAdIndex}/>\n </div>\n </div>\n <VideoCarousel selectedFormat={selectedFormat} nextAdIndex={nextAdIndex} setNextAdIndex={setNextAdIndex} />\n </div> \n </div>\n );\n};\n\nexport default FilteredVideoCarousel;\n","var _rect, _rect2, _rect3, _rect4, _rect5, _rect6, _rect7, _rect8, _rect9, _rect10, _rect11, _rect12, _rect13, _rect14, _defs;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgVipad300X600(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 246,\n height: 417,\n viewBox: \"0 0 321 417\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _rect || (_rect = /*#__PURE__*/React.createElement(\"rect\", {\n width: 320.031,\n height: 417,\n fill: \"url(#pattern0)\"\n })), _rect2 || (_rect2 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 256,\n width: 114,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect3 || (_rect3 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 274,\n width: 103.36,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect4 || (_rect4 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 202,\n width: 114,\n height: 14,\n fill: \"#F0F0F0\"\n })), _rect5 || (_rect5 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 73,\n width: 114,\n height: 117,\n fill: \"#F0F0F0\"\n })), _rect6 || (_rect6 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 39,\n width: 114,\n height: 22,\n fill: \"#F0F0F0\"\n })), _rect7 || (_rect7 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 223,\n width: 95.76,\n height: 14,\n fill: \"#F0F0F0\"\n })), _rect8 || (_rect8 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 265,\n width: 88.16,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect9 || (_rect9 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 290,\n width: 114,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect10 || (_rect10 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 308,\n width: 103.36,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect11 || (_rect11 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 299,\n width: 88.16,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect12 || (_rect12 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 329,\n width: 114,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect13 || (_rect13 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 347,\n width: 103.36,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect14 || (_rect14 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 338,\n width: 88.16,\n height: 6,\n fill: \"#F0F0F0\"\n })), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern0\",\n patternContentUnits: \"objectBoundingBox\",\n width: 1,\n height: 1\n }, /*#__PURE__*/React.createElement(\"use\", {\n xlinkHref: \"#image0_347_491\",\n transform: \"matrix(0.00103413 0 0 0.000793651 -1.05067 -0.225397)\"\n })), /*#__PURE__*/React.createElement(\"image\", {\n id: \"image0_347_491\",\n width: 3000,\n height: 1846,\n xlinkHref: \"data:image/png;base64,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\"\n }))));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgVipad300X600);\nexport default __webpack_public_path__ + \"static/media/vipad-300x600.c7e589a4b028ed6c10d353717ee94692.svg\";\nexport { ForwardRef as ReactComponent };","var _rect,_rect2,_rect3,_rect4,_rect5,_rect6,_rect7,_rect8,_rect9,_rect10,_rect11,_rect12,_rect13,_defs;var _excluded=[\"title\",\"titleId\"];function _extends(){_extends=Object.assign?Object.assign.bind():function(target){for(var i=1;i<arguments.length;i++){var source=arguments[i];for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){target[key]=source[key];}}}return target;};return _extends.apply(this,arguments);}function _objectWithoutProperties(source,excluded){if(source==null)return{};var target=_objectWithoutPropertiesLoose(source,excluded);var key,i;if(Object.getOwnPropertySymbols){var sourceSymbolKeys=Object.getOwnPropertySymbols(source);for(i=0;i<sourceSymbolKeys.length;i++){key=sourceSymbolKeys[i];if(excluded.indexOf(key)>=0)continue;if(!Object.prototype.propertyIsEnumerable.call(source,key))continue;target[key]=source[key];}}return target;}function _objectWithoutPropertiesLoose(source,excluded){if(source==null)return{};var target={};var sourceKeys=Object.keys(source);var key,i;for(i=0;i<sourceKeys.length;i++){key=sourceKeys[i];if(excluded.indexOf(key)>=0)continue;target[key]=source[key];}return target;}import*as React from\"react\";function SvgPc970X250(_ref,svgRef){var title=_ref.title,titleId=_ref.titleId,props=_objectWithoutProperties(_ref,_excluded);return/*#__PURE__*/React.createElement(\"svg\",_extends({width:793,height:447,viewBox:\"0 0 793 447\",fill:\"none\",xmlns:\"http://www.w3.org/2000/svg\",xmlnsXlink:\"http://www.w3.org/1999/xlink\",ref:svgRef,\"aria-labelledby\":titleId},props),title?/*#__PURE__*/React.createElement(\"title\",{id:titleId},title):null,_rect||(_rect=/*#__PURE__*/React.createElement(\"rect\",{width:793,height:447,fill:\"url(#pattern0)\"})),_rect2||(_rect2=/*#__PURE__*/React.createElement(\"rect\",{x:103,y:21,width:605,height:401,rx:4,fill:\"white\"})),_rect3||(_rect3=/*#__PURE__*/React.createElement(\"rect\",{x:494,y:355,width:172,height:6,fill:\"#F0F0F0\"})),_rect4||(_rect4=/*#__PURE__*/React.createElement(\"rect\",{x:494,y:389,width:172,height:6,fill:\"#F0F0F0\"})),_rect5||(_rect5=/*#__PURE__*/React.createElement(\"rect\",{x:494,y:373,width:156,height:6,fill:\"#F0F0F0\"})),_rect6||(_rect6=/*#__PURE__*/React.createElement(\"rect\",{x:494,y:306,width:172,height:14,fill:\"#F0F0F0\"})),_rect7||(_rect7=/*#__PURE__*/React.createElement(\"rect\",{x:494,y:327,width:145,height:14,fill:\"#F0F0F0\"})),_rect8||(_rect8=/*#__PURE__*/React.createElement(\"rect\",{x:494,y:364,width:133,height:6,fill:\"#F0F0F0\"})),_rect9||(_rect9=/*#__PURE__*/React.createElement(\"rect\",{x:494,y:398,width:133,height:6,fill:\"#F0F0F0\"})),_rect10||(_rect10=/*#__PURE__*/React.createElement(\"rect\",{x:138,y:367,width:268,height:14,fill:\"#F0F0F0\"})),_rect11||(_rect11=/*#__PURE__*/React.createElement(\"rect\",{x:138,y:388,width:232,height:14,fill:\"#F0F0F0\"})),_rect12||(_rect12=/*#__PURE__*/React.createElement(\"rect\",{x:138,y:169,width:328,height:182,fill:\"#F0F0F0\"})),_rect13||(_rect13=/*#__PURE__*/React.createElement(\"rect\",{width:177,height:155,transform:\"matrix(-1 0 0 1 674 169)\",fill:\"#F0F0F0\"})),_defs||(_defs=/*#__PURE__*/React.createElement(\"defs\",null,/*#__PURE__*/React.createElement(\"pattern\",{id:\"pattern0\",patternContentUnits:\"objectBoundingBox\",width:1,height:1},/*#__PURE__*/React.createElement(\"use\",{xlinkHref:\"#image0_347_625\",transform:\"matrix(0.000581395 0 0 0.00103199 -0.306977 -0.431373)\"})),/*#__PURE__*/React.createElement(\"image\",{id:\"image0_347_625\",width:3000,height:1846,xlinkHref:\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAC7gAAAc2CAYAAACSD+qlAAAACXBIWXMAAAsTAAALEwEAmpwYAAaNfklEQVR4nOz9Tawl3ZondkWckyfz/b63qt2Fu9W41LJa+As3xgPLSG0BxUe7QUwQlnBLMEA0g5ZAbgnhQTNAjdQgAQOQGCAYIIzExHxJSJ5YSEyRQCBPGFhWAYO26eqqW3Xr3vu+mXmCQebOXOc5z7PWir33yYzM/P1Ub529I1asteJz74z1j33XbdsWAAAAAAAAAAAAAAD42G4+dgcAAAAAAAAAAAAAAGBZBNwBAAAAAAAAAAAAADgIAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDePaxOwAAwBu///u//7G7wBdo25ZlWbZlWdbTlKzYGt7fJNNi+dH83sO267Ist535PbeDtp9q2dbN27rSjXlFb9tZJ5qq9u/6fvH14co/OjYezrxdevtwXd829dSbYNq19u2nZnSufqKag/ad2XOgLZ9N6y17WuZNuXVdl/v7bfnxx5/uXt/f36xvJr45edZlWZv635wO27Ku67vXD5tY39Z8mr6++/9p+Wwt3hZe184uP53yTXUP1yo/YLa3q/Zm/vp22ra8/b9369zum7Upc1o4FHnTj7fbpe1j26m4Pg/afVf/2y68beBhdevb+dsSd/vavHq37R/+eVTXtjys51Tvuq7LdlqXZFut7Yo1h9T7ff5gJR9cet/3ZX23zNoWiHVty+22bOv79t/8/8f9yZpuysV90yvbdHx40WlW6t2qrku7O8M3kzf9eLD9szrfd+z9uRj62zYat8dp/ho2frvP47xHr9/W154Sp2Mw9vtRe5W4bLNup7bSbX/q/7Yt6836buK77f2+I2/reX9te7gd3rf35hq2PdhXme3dBlge7tSmb6dt/mD7JF9XtuSa+qCtie0Yz+9+fY+vvfGcWdf1wbaITtvw/bGV1FV2d202w+N+PzzWutU8qHF72P79siz3vf6c+n36/+++2nX60/bq0bWteRu33dYev++68vh6++jc3bb3x9rp8+J0vX87MbtWtv14337Pw7rSdXu0/cKmaQ6s9jP10SH09nx9cE1a3++/R59DYV+8vya8n/x+PUM7zX5or/VbU0E4bVOnMu8+M07XpHV9tNmT3bAsy7I8u715/eLF81ftuj5eolq6Kfdgw8dy1fLpgXyGXv8O4345eAefyLtr3ifi9fJx+ru9bftDHCPXaueSfXta36dYbjR/W/rrvy2P16u7vbr/BuSL9bu/+7sfuwsAAAAXE3AHAIBPzLZtz9d1/Z2XL1/9++/vt3/k+fO731rW5at1Wb5ZlvWbZV2er2+CrXfLstys63r78uWr259evny2LMvNuqxv/h3wJiDybFmX23Vdt7eTbrdleXYK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AAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAD8/9u1YwEAAACAQf7W09hRHAEAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAQuJ7m1ejLDPxAAAAAElFTkSuQmCC\"}))));}var ForwardRef=/*#__PURE__*/React.forwardRef(SvgPc970X250);export default __webpack_public_path__+\"static/media/pc-970x250.da92043f35fe5639eaf16e2718a59e8e.svg\";export{ForwardRef as ReactComponent};","var _rect,_rect2,_rect3,_rect4,_rect5,_rect6,_rect7,_rect8,_rect9,_rect10,_rect11,_rect12,_rect13,_rect14,_rect15,_rect16,_rect17,_rect18,_rect19,_rect20,_rect21,_rect22,_rect23,_rect24,_rect25,_rect26,_rect27,_rect28,_rect29,_rect30,_defs;var _excluded=[\"title\",\"titleId\"];function _extends(){_extends=Object.assign?Object.assign.bind():function(target){for(var i=1;i<arguments.length;i++){var source=arguments[i];for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){target[key]=source[key];}}}return target;};return _extends.apply(this,arguments);}function _objectWithoutProperties(source,excluded){if(source==null)return{};var target=_objectWithoutPropertiesLoose(source,excluded);var key,i;if(Object.getOwnPropertySymbols){var sourceSymbolKeys=Object.getOwnPropertySymbols(source);for(i=0;i<sourceSymbolKeys.length;i++){key=sourceSymbolKeys[i];if(excluded.indexOf(key)>=0)continue;if(!Object.prototype.propertyIsEnumerable.call(source,key))continue;target[key]=source[key];}}return target;}function _objectWithoutPropertiesLoose(source,excluded){if(source==null)return{};var target={};var sourceKeys=Object.keys(source);var key,i;for(i=0;i<sourceKeys.length;i++){key=sourceKeys[i];if(excluded.indexOf(key)>=0)continue;target[key]=source[key];}return target;}import*as React from\"react\";function SvgPc160X600(_ref,svgRef){var title=_ref.title,titleId=_ref.titleId,props=_objectWithoutProperties(_ref,_excluded);return/*#__PURE__*/React.createElement(\"svg\",_extends({width:793,height:447,viewBox:\"0 0 793 447\",fill:\"none\",xmlns:\"http://www.w3.org/2000/svg\",xmlnsXlink:\"http://www.w3.org/1999/xlink\",ref:svgRef,\"aria-labelledby\":titleId},props),title?/*#__PURE__*/React.createElement(\"title\",{id:titleId},title):null,_rect||(_rect=/*#__PURE__*/React.createElement(\"rect\",{width:793,height:447,fill:\"url(#pattern0)\"})),_rect2||(_rect2=/*#__PURE__*/React.createElement(\"rect\",{x:103,y:21,width:605,height:401,rx:4,fill:\"white\"})),_rect3||(_rect3=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:51,width:211,height:23,fill:\"#F0F0F0\"})),_rect4||(_rect4=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:270,width:268,height:14,fill:\"#F0F0F0\"})),_rect5||(_rect5=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:81,width:119,height:14,fill:\"#F0F0F0\"})),_rect6||(_rect6=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:320,width:268,height:6,fill:\"#F0F0F0\"})),_rect7||(_rect7=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:131,width:119,height:6,fill:\"#F0F0F0\"})),_rect8||(_rect8=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:179,width:119,height:6,fill:\"#F0F0F0\"})),_rect9||(_rect9=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:360,width:111,height:5,fill:\"#F0F0F0\"})),_rect10||(_rect10=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:368,width:268,height:6,fill:\"#F0F0F0\"})),_rect11||(_rect11=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:338,width:268,height:6,fill:\"#F0F0F0\"})),_rect12||(_rect12=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:149,width:119,height:6,fill:\"#F0F0F0\"})),_rect13||(_rect13=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:197,width:119,height:6,fill:\"#F0F0F0\"})),_rect14||(_rect14=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:374,width:111,height:5,fill:\"#F0F0F0\"})),_rect15||(_rect15=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:386,width:268,height:6,fill:\"#F0F0F0\"})),_rect16||(_rect16=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:291,width:232,height:14,fill:\"#F0F0F0\"})),_rect17||(_rect17=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:102,width:103,height:14,fill:\"#F0F0F0\"})),_rect18||(_rect18=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:227,width:119,height:102,fill:\"#F0F0F0\"})),_rect19||(_rect19=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:341,width:97,height:12,fill:\"#F0F0F0\"})),_rect20||(_rect20=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:329,width:232,height:6,fill:\"#F0F0F0\"})),_rect21||(_rect21=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:140,width:103,height:6,fill:\"#F0F0F0\"})),_rect22||(_rect22=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:188,width:103,height:6,fill:\"#F0F0F0\"})),_rect23||(_rect23=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:366,width:96,height:6,fill:\"#F0F0F0\"})),_rect24||(_rect24=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:377,width:232,height:6,fill:\"#F0F0F0\"})),_rect25||(_rect25=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:347,width:232,height:6,fill:\"#F0F0F0\"})),_rect26||(_rect26=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:158,width:103,height:6,fill:\"#F0F0F0\"})),_rect27||(_rect27=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:206,width:103,height:6,fill:\"#F0F0F0\"})),_rect28||(_rect28=/*#__PURE__*/React.createElement(\"rect\",{x:479,y:381,width:96,height:5,fill:\"#F0F0F0\"})),_rect29||(_rect29=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:395,width:232,height:6,fill:\"#F0F0F0\"})),_rect30||(_rect30=/*#__PURE__*/React.createElement(\"rect\",{x:135,y:81,width:328,height:182,fill:\"#F0F0F0\"})),_defs||(_defs=/*#__PURE__*/React.createElement(\"defs\",null,/*#__PURE__*/React.createElement(\"pattern\",{id:\"pattern0\",patternContentUnits:\"objectBoundingBox\",width:1,height:1},/*#__PURE__*/React.createElement(\"use\",{xlinkHref:\"#image0_501_393\",transform:\"matrix(0.000581395 0 0 0.00103199 -0.306977 -0.431373)\"})),/*#__PURE__*/React.createElement(\"image\",{id:\"image0_501_393\",width:3000,height:1846,xlinkHref:\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAC7gAAAc2CAYAAACSD+qlAAAACXBIWXMAAAsTAAALEwEAmpwYAAaNfklEQVR4nOz9Tawl3ZondkWckyfz/b63qt2Fu9W41LJa+As3xgPLSG0BxUe7QUwQlnBLMEA0g5ZAbgnhQTNAjdQgAQOQGCAYIIzExHxJSJ5YSEyRQCBPGFhWAYO26eqqW3Xr3vu+mXmCQebOXOc5z7PWir33yYzM/P1Ub529I1asteJz74z1j33XbdsWAAAAAAAAAAAAAAD42G4+dgcAAAAAAAAAAAAAAGBZBNwBAAAAAAAAAAAAADgIAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDEHAHAAAAAAAAAAAAAOAQBNwBAAAAAAAAAAAAADgEAXcAAAAAAAAAAAAAAA5BwB0AAAAAAAAAAAAAgEMQcAcAAAAAAAAAAAAA4BAE3AEAAAAAAAAAAAAAOAQBdwAAAAAAAAAAAAAADkHAHQAAAAAAAAAAAACAQxBwBwAAAAAAAAAAAADgEATcAQAAAAAAAAAAAAA4BAF3AAAAAAAAAAAAAAAOQcAdAAAAAAAAAAAAAIBDePaxOwAAwBu///u//7G7wBdo25ZlWbZlWdbTlKzYGt7fJNNi+dH83sO267Ist535PbeDtp9q2dbN27rSjXlFb9tZJ5qq9u/6fvH14co/OjYezrxdevtwXd829dSbYNq19u2nZnSufqKag/ad2XOgLZ9N6y17WuZNuXVdl/v7bfnxx5/uXt/f36xvJr45edZlWZv635wO27Ku67vXD5tY39Z8mr6++/9p+Wwt3hZe184uP53yTXUP1yo/YLa3q/Zm/vp22ra8/b9369zum7Upc1o4FHnTj7fbpe1j26m4Pg/afVf/2y68beBhdevb+dsSd/vavHq37R/+eVTXtjys51Tvuq7LdlqXZFut7Yo1h9T7ff5gJR9cet/3ZX23zNoWiHVty+22bOv79t/8/8f9yZpuysV90yvbdHx40WlW6t2qrku7O8M3kzf9eLD9szrfd+z9uRj62zYat8dp/ho2frvP47xHr9/W154Sp2Mw9vtRe5W4bLNup7bSbX/q/7Yt6836buK77f2+I2/reX9te7gd3rf35hq2PdhXme3dBlge7tSmb6dt/mD7JF9XtuSa+qCtie0Yz+9+fY+vvfGcWdf1wbaITtvw/bGV1FV2d202w+N+PzzWutU8qHF72P79siz3vf6c+n36/+++2nX60/bq0bWteRu33dYev++68vh6++jc3bb3x9rp8+J0vX87MbtWtv14337Pw7rSdXu0/cKmaQ6s9jP10SH09nx9cE1a3++/R59DYV+8vya8n/x+PUM7zX5or/VbU0E4bVOnMu8+M07XpHV9tNmT3bAsy7I8u715/eLF81ftuj5eolq6Kfdgw8dy1fLpgXyGXv8O4345eAefyLtr3ifi9fJx+ru9bftDHCPXaueSfXta36dYbjR/W/rrvy2P16u7vbr/BuSL9bu/+7sfuwsAAAAXE3AHAIBPzLZtz9d1/Z2XL1/9++/vt3/k+fO731rW5at1Wb5ZlvWbZV2er2+CrXfLstys63r78uWr259evny2LMvNuqxv/h3wJiDybFmX23Vdt7eTbrdleXYKJqxvEmXP25jTtizP1vXN8FkbdmliPzfv63845613AfB3WdCHRdZ1XW/fruvDUMej0MPD5ZbLgszPljwd8TC42IhhsLeS4HkV72g6n/T6QUDl8fzTdvwYbtd1/ZT+F8GeLW+2V8z2LMUx+MhpX+wZN56p94l9qcH+D+b2dlme3T277UUVlyU/87Ns2qws5rUuzTF9Rp0fy6fU1z26wdOn59wHej61sCdvVf8KuvYFfyZOvoW/s/U+evOmkvt1dUx+AE8SXh79O2nvv4na+qpl23/HZWVDn14vy3KfzT/J2opttOVOm/HxPYL1QZk39xHevB78275t723Avfs00VnePfCyPTyD37a7revy6nG/3pc59bO3Hu+XW971u213Xddt27Z3x+IomN25/7Msy/J6Wdb7M7fP/TIIoj+8H/X+8bdsuXcl3jx39frx80vbg3f3j55IevDo3es3x8Hb42zZ7pdledk+sLYs68ttu78/dW1906fX25u2tmVbXm3Ldv/Vixcvb25u7pc3dbxaluXVtiyvl237zbYtv16W7df399uvf/zxp7/3/Pnd//vm9ub/e7Ouf7j4ngAAAMBBCLgDAMDBbdv2s23b/on7bfvLNzc3//SyLf/Ezc3NX/j666/+4WVZvn34i3v5IOzt7e3y1VcvPnznD+TRIHbxpj9++mEkPzzbMRMrqSKko0be/mJlObD/vsw+vd+AfN/msrwbIG4WWZu289jw+yBBW+bU9/XRIP26jrf5KJQxHvB/39fHbW3J9IeBiFPf23oetrUt2xbj02/KPXzfX4c315A37Tx4AKCp6tEP8zb75s387V19p/J1m48fWolHVBZYiYGWbHVjOGvUn9M6ZkGZdhs83O4yxAAA19B+J9zz3fzdd7e3/+/R9/Ht8XfLdtkH/9Zoyj74mrct3e+JvX5nQeyeh99Z17ff8x+3+67/D/6d9PB7ePw3w8N/k2xhmYf/hnr0fXtZ3v57I/xb7fS//NHZJqd1eP/vjIePR7xZ5n0/ssB51p84/+TmJuv743qyumN98ev+m/fvt/P7f4M9XJ+q3tzMv+nPs+/ewnnLXtLGpXVnx93D+wdk9yji+fHixfP7ZVn+8KefXv6919v9v7Ns27/18tXr/+fds9v/x83Nzb+9ruuPH7TTAAAA8NY6ePodAIAP5Pd///c/dhc4kG3b/n332/ZX1mX5vZub23/+9vbmL93c3HzTzF9OMdDLvtL3BlLjvKzsNQdiH8QOrlQnX5I9A+vXGIT/EGGBrOy57e4J11Tze782GF/PKMPmxTpn06t2e6GWUV9H83r1jurb04+9fZvtz7ltVdv5Wm0ty1xd12oTAL4k1/7OsaeeZXm6unrfEUfLVeWrttMwbfEQ5aOHJSe/t858P+59V98TuO/ptbc3ND77wMK1hit722HuIdynC2zzuXh/T65/n2z2ntmee3Pt9GWy/tr67omAx/+rha9fv/77P7189W+9evny/7Ku67/5/Pnd/3Vd119f1CAfzO/+7u9+7C4AAABcTMAdAOAgBNxZluXu9evX/9y63vwXbm9v/sXb29u/9P5/yvkUat/z/f002DY7/TRvWR4OlFXB82owLdZdDfoty+OBv6ydqnxVx576PqSn+1U2PoxrBh2qUEgvTFz+svgT/7Je7xcNe0GRmXWZ7ddsH3qh/D1B9D0h9lGYajTt3NBXFTqb3Qe9Oi7pRy/AlYW8zu3PU4btj+JzW5+P5ZrBSj4cx//HNbP9j7CPPkYfrvlZtrfNXl+WZf8DcDMPCJ7b37aOPW1noeje94yTXsC9Wiaq2ovzZgLuo+/BvWUuCbhn82a/M1d9n23j0sD46EGBPXrbQHj9UxTvT/XuCfXquDRonpUZ3YMa3QvL7p/16j2VqZaPZR5O25ZtWdP7fLG+dTn9rymcvH79+jc//vjT/+3Hn17+71+8uPvf3j179m8XjXMQAu4AAMDnQMAdAOAgBNy/aC9evX79V5/dPvsbt7c3v3dzc/PiTZZ9ezu0NDNgVQ2MzQyW9dqoVEH4KgC/FWWyvsRlM6MBzlhv9XqvbJBxtq5L2oU6SLMn4H5a5hrtzvZjFJLZ8+uOM8uNgkdVYGsUvurN7z1wMBMQ7NU7U0dV154Q3qWBvHOC9dcOAX6ooOO57ezd3rPtzAYHz+kDc2zLy/UCoJ+aj9n3a7X9MR4M+dT2+eg7xez1e+/DcZe2W31mnKZdsu973+dmgvS9QHJ8XZXv9SsTv4+MwudZ/2e+X8Y2szpm9b5z7w2HHy3sfbT+nBy1X5f7VO5RjO7nzIbSl8ly8b7W6H1W7yiUXoXXo6xc715gP/z+Zs5s2w/ru7l5v46vXr36e7/+9Y//+s3N+r94/vzu/z5RER+BgDsAAPA5EHAHADgIAfcv0/22/dV1Xf7Ws9tnv3dzc3Ozbdsy9x09H6zaVy4b+BqF4kdt9OqsBgV7fagG8+Jy1WDitQdrzxkA/lQGjT8/n28QYc4oOH7u9pmta/TLjqNwzp7wTrZsphe2GgWxYrlewP5UbhTmqgLysT/VtFGIeSZI/jFCjDNmt+e1gpyjsOCetnr7ZVmefltfMyj8OYWOr8l2+LR8SfvrcwjXz7a1LMffrzMPG+2tb1nO/4zZ892kWmYUTD+ZfXBvdhtl/ey1GZeplp/5vjzqz2j9Rv1+SjPt7vk3Qe/7+agdqFX3dnr3UmZD7VUwvlp+z/2b7D5Vr0xWbjbgPqqrF3ivlj03aP8+7P7y5as/+s1vfvxf39ys/5Pnz+/+X4NK+MAE3AEAgM/BzcfuAAAAfIlev77/p169ev2v3T179n98fvf8P7mu6839/f2OAeHZgnsGy7LycX71fl36A29x+my71YBhOxBXlW2nx/r3jLy3y5+boum1JwXwVD5mwOJjBq6ygEm2LUZBl9l2TnVVoaKZ9to6T+Vm+reudcBq2+babINHbX1Z/2P9VUhqZnvE9YnLtP3prUu1n0eh7Zn6Yvn2v9E6jeaPjs+4b59Sr532WIuqdajqu2Sd9lzPYhszbfYeGnkKHzsAd2n7Rw/V9nzsbf8xXHN/HX37HeH7R2XPtjvnO8S1zX6GVdNGD+v16q7Wv/ocObV17sNse/Zd9T0pfl7G7wrVQ3zZ+zh95jtDOz9+F8u+H85+X479yL4Ptv1ov7dVofgPaeb78CXn5p52INcLicewdrZMr952+SrMPlNvNX1t/mvLju4hbeFvvLfVvm7ri/MftpX3Mrsf1m6X3rZcm7ltPdtyf3+/3N/fL3d3z37+/fff/s27u7v/869//eO/+vr+/uedCgEAAGA3AXcAAPiAtm37+tWr13/r+fO7f/Prr7/66+u63t3fz/1qez70FgfTRmLwO6s5a7UqGwfvZgYf4zJt35ZkXhzwbAcqe4OhvelxMDC2V/VtRrbs7GCqVMDnYibsOmvP8nt+gbHXxijU1fslzNk2qrr3lpldpgpn9X4VPAvrzP6adRUEH/3aey84lcnabwNWI71Qf1Wu1/bMsV9t073H7p7j9qk9daj0KYPmveP4qfrxlNtr5vz5lAPql/qS1/0arh1W3RMWPbe9cz5bP7bs8yb77PiYodr4GV99Ro4+K+O03sN7p/d7H3qr2mz7N3qArff5PvqF99P70ffLGCDP6mgfCowPBmZ9HD0UOfpuM/tdql2HbPne98k9PtY13GcHfZdeiLOAeFXv6X5QDL/vvYeT1dFOa/sxcwL07oVV94P23s/rre+pppk+53cXsymjWu7v75ft/n55/vzuz33//bd/9/Wr1//Gb3786T/RWQwAAAB2EXAHAIAP5PXr+3/y9f32r3/11Yv/4bquv/PmF9vPDzW/H7zqLZ/9mtTSTJtpuxra6g3GzQS6Y9mZ+dvysO4s6L6E8qNBz956xPZmzJZvw/ptX57KnuPsYCmnL9w1flUxMxPyOafN+Evos8tlqvD2KFQ2Wp/slzxPr2d+zbuavmc7xl/3bF/3fgl+1L8sGJb1byYYWD3EcOm+7QXBsrp6gbus3lFf9jxAsLe9c10zoLn3OnCU0Fq1X/ZeA2Pg8UM5WkC48lT9jMHUp3ZJaHvv9Mo1jq89/4sP1wrEZut5jc//2X6ce4zMfNbPBqj3tFc97NYLsM/IrnO9fRO/J8Qyo4fUZvqSfYfLpsXvLu20UftV/+N/sa3Yz1j3qP3Rd8b4vtoWM3oPH+6pJzPzXewon+t7fIp9/nz0Q9NzsntOe5eNQfPT39G9mux+0BbKzLSfTa/ua8X/Zutr+xTvc2XtXnJiVHXO1TsTj2/X4P7+ftmWZfn222/+ua++evF/+NWvfvN3Xr++/35HhwEAACAl4A4AAB/Ay5ev/qXnz+/+ja+/evEvLtuyZL/YvjX/P7N25+4xG6qPQ1pViHz0OqtrVG9cJhswHfWvNz8b6GzrvcaA4siegeRr7HmpgY/lqKHHUfB3tOwoPB7LxF/VHAX3sl/crH7BddTXGTFoVoXHsl8HjdNmfkG1t/1mfg223c7ZL56OfuE1C9P3ls22SezDafmZkFIVHOs9MDHzwEJvfi8YN1vvpcHYmTovvWZcI2x5zvxLVcfexwy9HfX6vVd23bq22YebrtneNcp8bB/6GBs9yLXHnoeVsuVmjILfex8Cyz73Rv1vl6n60pN9TmdttH+zz/X2b9bvmYfRZh8si6+rIHv2edr7/pR9j+g9oJC1OfOgQnVsVt9Xqm01mlb1fbRstT2u5XP57OJD2Rd83lffOcv1Au1Zud5yl65P715V+1/vpGvvv/WC7bG9a57IcdvN3q/L+1DdSdu2bbm/v1/unj375ocfvvvbL1++/N/99NPLf3x3dwEAAKAh4A4AAE/r+evX93/nxYsX/9q63vyFN79qdP5A1eNhp94vWi1LPmg2Giob1Tn6Raps+laU6w0YZvNi37bl8SDh6e+29Ac/zxk8zLfnvjpO2sHQoyWwLumPRMXJpxCsm9UL/vTmjQLWo3ZiPXtD+TOBtWyZmV+7jXWd/o5+QbQNysXQ3N7tHOvM6usF5qtwXC/wlYX6Z+reE4Ac7dNRyPycwH1mNlC/55jJHoBo+xhDfDN1ZvPPCbdlDxjE+U+t9zDLnuVblwT99tT3OV3zWx8jKHnpgyQjvevpuc7t24c+bvY+1DNb58x6XGP/xc+3dtq5AfTqmhvbzULoe+o/ve6tQ1suhvGrAHusY/azPvt+ED/P4veVts5s/UbTRuH5qr/Vg2nZ9sv2T7Z9Y2i/6vfM98xzj+1LzomZ79Ej5zxs8lSE8nlsNoR9mheD5Je0F+85ZUH0OD324TQti4NX/Yx17L1XNLonl7U7Cui/70n2uq3t9Pf+/n5ZlmX5/vvvfm+9ufk//dEf/clfGzYAAAAABQF3AAB4Ivf39z9/9fr1/+zFi+d/++bm5m7b7rvlz8u39AaiHtc4N9wXB+tmfs0pDmmNpsd57X+x7vg+G0yMZdu6en1r13FmD7Sh9GxeT9Xf2XY/FZ9SX5/WpxjUOOcXsvf+AmUvWF4Fn6p6ZvoXy1btzczbE8DP1jP+6mgWLuuFwuLycXrbh1Ff4zplgeLsfRu0G/U5C6SNgu57Aumj8H9W9959Ptu/LLQ+W19cLptXuTRs/RTXqUvr7B1Xl9Q3MvOAwN7r3VGcc20fLbvHnmOit40/VIj6HE95XFwagh0FiLPAdTv9qR8siG1kYeXeZ/4514z4YFG2fOzHTBg6asuOHoTqfU7GAHq1D6t6e+H8LOTerusorD7z+VkdW6NleqH6+FBf25eZbZDNG30POrLRd7KZZeO0a38ec6neAfkJHaylKja9R2+ZbBtV952y+0Sne1BZODy7R7QWy4zsD5+/17tHVr0f1b8+6tVUT7Zt2bZt+ebrr/7iz37+/f/mT/7kT/9rO6sAAACAZVkE3AEA4Em8fv36d169ev2//OrFi//ym0H29+H2awxPPZw3O4g1Pyi1dd7128sG7+LgYDWwOLNlTvX3gvOxzqz/vfZmpl97sHXkcxiw5ql96BDiJcvNlu+FffcGJi/VBrtHdfdCgdk6jcKnWbtVIL0KasW2esGxrB9tmGymv3F6rCPOm92OWaAtW6YKq1X7rxdw603LtnkWJMz2RTTzy7FZXXuD/r02R8fEuYHovcHGj2Hm4YKPHfK79rbb86DQtdqZdW5/Rm3NPszyoZzzIMyeurPrbvUAUvV6Npjevj8nzHzOQ0ttG72g/kwAO/a3upZlYff4Oqs3m1bVVT0g1vZhzwNhvb706pgN/Z/mVZ/p1b5p+1Ctf9y3cdqoz7Hf2cMBH+qasLed3mf0Od+nqum97zi95fnQeif8p/QUQnUv5ry7VfPzsrJVm22oPZt+er0V5Wb7Ut2rattq739l/Xhqj9djek9t23J/f788v7v7/ocfvvuf/skvf/WvXrdvAAAAfAkE3AEA4MpevXr9517f3/+vvv32m//ctj0evNv9y0fF9Kcc0tpf97bjdVZ7HEDcM7hZDSb2QvBrKDtq+1RftTfOGfXflrr/0ac0YP1l+5jhxyOFT3qhuJmgb6yrF2jutT/bxl6X1BkD0e30UTsxyDR6ACCbVoXle0aB9vZ1G/6L4fEsVNb7FdaqzWwdqn5WYbg9gbbY3p6gWNXXXj3tvBj6POeXWWfamg1mntvOtR5Wacsf5Zp3rX6c+/DAU7n0oYRLA+rnnDcz5Wavv0/hWufZU7jmAwWjB4t6dZ17PYjtVEHgUZg8ez8T4j8t1wt3x7K9sHImOzdGn0fZ9Pj5Etcn21a9z9Deudr73I/lqlB7pheK/5ifDdf+/tk7lo7yGQjz2vst1b2V7P5Rds8ku5dShdJP06r5M/d4qntEvfnxntPo3k+sY8/9op65i9E1LilVHff398uzZ89ufvj+27/7J7/81X/7Ck0BAADwBRFwBwCAK3r9+v7PvL6//59/8/XX/6n7+7khojiEd92x6uzXnq5R5972Y4g8vu4tfxqMjHW167Yt+bqeymdbNqtzCeVP/7Vh+VhXtm5LMj9bt6zP0gqfMmGTh0bb45xwVFW+CnxdOzQa+1yFMXt9jmGyXhCtCmzNBJ1723fmF1Sr8tnr+GuyVaj9tMxsoD8G7KpgXFZHe/xkYcK2jd6+yPZBtm2rX9TtHY/nXDNmA+29AGLcZjPHSJx+rbBub5leG9cMBlfXmqoP7fRL+3Gtei7tQ+8XlC99qCd7fa7qupKVe2p71+fax+w126uuAVlAudeneB0cXV8vsTfcPVNfL8yeXXtmPovP3e/x86/XXvyvXb6tL/suMvvZn7XR60c2L65P1r/ROsxuj/h+z0MN1bTMnodxqrKXHiN7HOWhGva49OKZLX9Onb3A9ey9nd77OG0tyvXucY0O8LafVf1tuXj/p50+qre6/5RN6/Ulq2vP/ts+2E8qtHXENt+G3Jfvv/v2v/OLX/zyv3WF5gAAAPhCCLgDAMCVbNv24n67/x9/+83Xf+3NYHM+kBSj0XEIr/d+2IcdUz+cONgXA+OxTLVM3HJLKNO+Xpd88HEL87awTKyz2gNtv0d7qVrHTDwisvmQe6rAyjn17g3cjMK2s4Hec2UB6F7bM+HK07IzwafZ9c0C7zO/WNp7SCALi82GvLO+9oLwWQA+62tmFJiL7cS+Vdug7VcWmIv7aSaA17Y3ehCiMiqXBR+z5Udhut5xMxMcHJ0Ho+Ny5BrXtdEDBnGfzjxMUtVXTes5Qthwz7l4SZ3XWtdrfy7NnG97w9SznxOjvkXVud0LDZ/7mTwb6I7XuxgKb6+do3NmFIJu52fXo3htrALRWV+r/oyuhb1QfFZvL6Q9G4rO6s7C+G1bo8/fqq3qs7Z6veeY6+3Dkeq4mzX7OTvTj9ll9l5HnsK12jrCZ9eX49KN3bufcdK71xKXm6lvr3i/J5sW31dtxvs/cZns/kx7XyjWk03rvR5p683W8frO2TvZHtmzbOb+/n65u3u2/vD9d//df+/v/+HfOLN6AAAAvjAC7gAAcCWvXt3/3a9ffPUvv3k3HgralvmBpmyoL3sdh/KyfuwZpMrLjgY8e2W3Yno1ODha8977atqpjXYPVP1p+7st/b3WG0gdyQZUrzW4eW5f+NRcI7ByzbDKqK5RSG8mPNbWdWnfe+HA0XLnzMvWrwoFtuWrQFv7PguyZQG6mcBnFpqb/bXSLAheBe/iulRBvF7Z+LrqR9vXuGz2AEEVGozTYpvt/Cq0eM4DELN1zJwTs/tyb/3Z9uvVXwVCz7HnPL7k2nGN6841XCusGI/ljxlGz+x58CBbbiYk3DMb/O3N6x2Hs3ph2uwzc/ZztOrPOQ/DVOd9NS+7xveC7qNr3ui6Xi0zetBlZp3itb9XRxXsbh8IqLT9rj6bq2MwOxZmjsHqu8CeZWP/qs/z3vUoW6deSL5a5w8ZKr/kc/qay13Th9x+fAjxfkx1DyXae5+hKr829Wf3RtYlbz/rQ9vOGv726o/LbsvjPsf5WR/a1717RFW97bJrZwtf80LwsK6HW2hfO9nWbaff398vz1/cPfszv/Wz//7f/4M/+mu7KgcAAOCLJOAOAABX8OOPP/2Nr756/t9Y1mXZmtHebCjoNFx4+jszJBiHGM8dfnw4fTxQVQ1K1XolegOi2UBfO4hZbcleve38mQHTrD+xjqoPmTiv2lOzy4/a69WzZ7kDJCb4aM4JeF/aVu/XLGfDgFlA6qnCP3sDwdl69oJyPTHsnoXZsnb3BMJH2zFbn9ivUb97/anayPQC/qOAdW8fxPZjkLAXBpw5DuNDA3G5ts0qzJrt6+x1FeobbdsY7O+VG+kFg3uB03NlIdI9Qcxl2R9+nH0g4SnMhqg/tA/Vj5ljuSo/+1nRnvuXrNfeY2MU7s6C1Vk75zzI0gvSZ9PiNSl7WGjUdmxzzwM88TrdTot17d2H2Wdc77o7MvOwxMw1uLdtep9jo372Hobo9Wl0HayOhV7bUfW5sWef7u3bNa7po+8b16oPrmfmwL/kQGzvu8R7Qb37NDGIHu/zxD7F+rL58U7bzL2nWM+592l6bbxpp75/d80LwcO6Hm6Ffe2M70Muy/39trx48fzn33/37f/oT//01//4rgYAAAD44gi4AwDAhX766eV/5Ouvv/o767retOH2GJVutVHn0XDbkpQb1T+2N2z9ZpnLxvfj4GK/rYfLnab1tla23Gk9s62d1TEKg8f6q71wzpbKBnfh07U3kHWuKtQ3E5ytguLX6MuM0a+m7g2m7Q08xaBYFkqM5bN5o19One1DL4DYBsurwHI7bxTir7Z91ka2Xm3ZrM4sxB7705bfcxxk82aDt3uO0XNC4ee0k7UZ65tp85r2Xhf2BGev1edqn8+GmS8Na2d1zvTjmu3PtDNbvhdgr64L19J7kOWan09V6LltuwrMX+PaUdUfr+9VfXva37NM9mBQ7zOk17/2OIn1jK75sw80jQLno+8WWd+zdc4eGqj626t777ys/pkHrnr17/kc+xgPDX3oB6P4XHzs+wW9A7e6sxVD3FXIu3ev5VQuhs3XZF7b/uj+UW/6uds6Wy5br7WYPuM4F5CZe5ynqdu2LN9++/V/4Dc//vQ/ePX69fdP3jkAAAA+WQLuAABwgVevXv9D27L8925ubn5nC6PfH2KY6RThnm3rcfx+b2sne9ZubZaOdZwG8kb19fobQ+GjMPtalOkNMFaDkNnrmX5m4mBuVWc1OAtfjt4vp1ZBrKqec3/Jde+8rFzv13dnft12Ntw6E/bLypwT1m2Dfe37LCwYA4BVoL/X5xhK7f3ybOxjVqYKEo4epOiF6qvtmj1gkPVnFISs9l27L6ryl4aM94baqxDmnlDr3vPs3D6d40OGFC8Ndp8bAN27zLkPO/UepNnb1oxegH10DrbTRg8gja7bex8o2fMgwaidmQc1ZtutZG3Ea1V1Ha4++7M+jh5WmFGFyTPVeu1tI9YxOp5mHo5qX/f6N2pr1M41HlC6xkMdo2vb3gcYzm23V+bcEL0gPA+dcw/lWvcRZu5tzN4/yu7JVMH3UT+yclU/svsu7X2fNfyX1ZW1106v5vf6WKnK7Nun+2vZf+EZ7fn23uDv/Nnf/mt/8A9+8bd2NwIAAMAXQ8AdAAAu8NPLV//Kt998/Ve6gYe3f7OhtzjsVy17ufXd///w0eg3g4OP1yULjleh9EwcbDx3oPB9Hx/Xv2fAdFserlNsvxoAjfWO9vreo0IYnv2uEXysln2KX8KcCVXNhsB65S8NgPZCVm34LAbQZoJs2T6bCSvGoHPV9my7rSwcGMPdveOjF4CM09u+9gLre/pahfWrfmZ9i/OzfvWmZW3N7KPsuKvCmnv3Yft6b6Cx6uO5qjpmHgzI6ji3T3vCnKNr4p6HDmbXcbT8TID1ksDqqP298665TOvShz2uEc69pP3sfa9Po2tCVuee9ZspX4XRZx4q6rXZuzb0prXLVg8uZZ/dVV97n0d7j7f4UFAvHH/pwx7nlI3bPts2sw8CzPYh++4zs22f4rvonmvkue0/Rb/5nM2Gq1ujg6y9b5PdQ+m1tecDsopIb+G/rN54j6mqJwu2Z8tvSflqmbZ81m7vjly8X5SVu/xLRu+OVN6zuQtPtca9Pmzbttzc3Cy/9bMf/pU/+sWf/MemGgIAAOCLI+AOAABn+vGnl7/31VfP/+tv3j0c9OnFnKM2AL9nuCqLS28P5ubtXyN3s3UH22ZC3Nm8dkgtqz/bqqPymdOWjgOjsd52wHQN82Lf27+jfvf0BjyX5WGf4rT4vhrwhfdmfyH5UwzUXBqsz4JZM4HgmXqi6hc9T8tnobpMDDvHkPZsmDWWq8LzVX9HwfVsmVjnTPA1C5bHUHq1Hm2oMq5L1tdesD5Oq/rU7ocY9O+11wubtnrh+6q/sb2Z47WaN3NenHPutH2bDczOtL/nmtBum70h7j1lqnLnhNbj8k8deN0bfp6pr+r37LTZMu2xNVv36DpZla/ayNoaHctVwHnvZ0XbVu+BjyqgvfeBjN61qNefbP5se1l/q2Ns72dkW1ecPnNdnjHzIE72GZXNH+3X09/quB99Z+kdS9XncVx+9pia2Xd7w+7nXitnvr9cw8d6iIYvSe8kiGHta9Td3n9p74fEeyPZ/Y14X2Rb8n6193N6farvsOXlRheMbcn7fW7Zx+1d8PXuavb3+r37+2355puvfrZsy99+9er1D1fuGgAAAJ8BAXcAADjDtm3f3qw3/83nd3ffbW9HwdvhqHflsmWbv1tRLtY1GoaL9ca569nDXvODllu5Nqdp1cDhw4HLrWy3CpJn7bZl29d7+tjWk80b9bMaXG3by17HOkbLxjZmBk7hjQ8RXN8bfDunXC+Mfk5fMntCh706YqA6CzrHAFkWro6vR2HobB16oc3edp6pZxSonw14xmlZOLwX3u6FOON+qMKX1bTqmIj9G4Vqs/ejYOLMgwvV/sr6OBtkrwKumWz9Zsu2fTu9nnkQIfaxJ3tQYlQ2q3+0j2f70Zs2u057wv3VNWVm+XPmR7PbJju+Lwk9j0K7WZk9D3q0dcyEyHv1zRxr8bOi2maj82VP2LrXz+o61gsxV/s2O05nPqPistnnR7y2tH2a/fwbGX0mnfNdojoGZq+R1TE1c22t2o/9qOqJ4fmZBx1mVcdv73vIbL29+lujz9Jr+RDf3flUXXJwnJadPYhHbc30pboHEl9vRdlYJi7Xlsv6szXle+Vm66vKju4pZcvN9GOfXo2jvX/Jsqd59dq/mfpn/szP/+P/7v/vD/4rnWoAAAD4Qgm4AwDAGf70V7/5l58/v/tPnwZo2kGdOExW6Q2NZcvFAaFq6G5mqGt2aK0qlbWxb4itGmA81VOtbdVKNn+mbLUm1WBpLN/bKzPtxNdbUTZbpqdXz+wRAh/WNQM7o7r2BvlOy5wzLyvbCzZn71ujEHQWKIuhq3PCs7OB+Spg1gs6Zn3PQoi9tqvXVdizqquqowoKzrSRbfs4Ldt2vYceYpkq6J+pgppViH82pDsKbp4T/LvWebcs/fOqKj/T3jnXkz3t7tHrYzZttq1Lr8/nLL/3OjVzrrdh5qqPe86hva5xnOwJ7MZryEkvxJ1dH2YeJuk9gNB7qKAKrMf9WX1WzPRv9hzNjo/42ZZdl7Ow9ugYrI7F3nE/qn82PH9OWL+qp902o+8u1fLLct6+qurvPQTRm96rd/bzY+/nDFzXJR8yM/dR9rSV3U+pysSye/pyuh9zuufS3p9Zw/yZmHbVbnu/Zu8dvN79pLwv24N3eZley9myl9xlGi072jqxXOzbtm3Luq7Ld999+zd/+ctf/aVBdwAAAPjCCLgDAMBOr1+//rPP7579zdvbm3QE+5JYcVa+Ha57OqMW9g547mm3N9A4M1S2DOZlZeLg52naGspmWz++3rs9sr62g57Z+1g2louqPs0mLp72aINz7QlkXhJQPCcU1at39pdRe/0ZBbZ6be5pt/0V23ZaVt9MEC0L9McgWxXomwlbV+1XgfFYpurnbDgwBvtGIduZoGiv3ayPWbByT+C9tw33lK/WezbweMl511MF8kftjLbLzHqdc+6PrnPnhNKrbX3u9WRP+72HRKplLi0zKn9pgL13bGTn5d7r70w/etfOOG10PR/ZEzieOY97ZWYCwrFcLyger5lZwLy3TXrbefQAULU/Zz4bZgLyo7JZn6v3HzuUPXvct2Wqz7dLAvxPvR3OuZbOfkeCvtHBPbrfckn9M/eS1ubvON79cLmZ+1ijAHssE8tf4+LQC8evj6Zkr/f2aHSZqNZ479r2Ivy9tY5+++c//KN/8Id//F/d2TwAAACfOQF3AADY6de/+em/+NVXL/5yFo9eivftMF0WYe4Ny2WDW5cOrz2OcvcGNPcOMj60v6/tGmcDi6NBwSy83utRNgTXG0acrbu3PbNp8WjqrWs8mqo+XNNHTr7Acl4wr6onmgnl7fll0nNlga1eOHG0Lr3wV3yfLTcbOm4DfzHUORPGir9m2/4q7kz7bXvZ+s2GfWeCZHFarDsGXHthxlGgs9qW2bpUweo4L84ftX9OAD7+15bPQqmz/emZCeRXAeDZutryMyHpbJ9Ux8No//XCvL1+7lnmmuJ22hvGnj0nemVmymcB53M/Z+LxPvtwxal8to1m6qmuA+d8PsR5o+tpT/ZATpyWfWb0+pz1r3qooDpnTvNG3yn2fHb09K6/vWts7GtbV/U53q5TrHvPcV31a+/1sqr7Er1jM2vjSGH+a3y2feyHEfhUZfc84vxLTs49y2YHcXWfJd4ta++FZPeKem3EstmdttF6xGWyO3TrRA+ye15xXbOyo6mPa53txePpdQtxT/X6Mrpj9W7Pb29+xf23f+uHv/7Hf/yn/1SnSgAAAL4wAu4AALDD69evf/v29va/dHNzs2zF6HIcmju9jkNYMdIc6+hNv8Zg1sloqPNSdV+rgbt2a2VLt/PaZbIB0aWYls2vtm4cuuu1mw2S9gZe9/Y11r3XhYmSRy49WiQ02G9PsK6n+gXUmQDhbDhrJogZ+zLzi6/ZtCr0fk4wMguZjkK5s7+m2gbvegG9rH/ZOo7CsDPhxD2ycGcME86ERrPgYdyGMdgY+xHfn9NunDYK02bzqwDrJYHz2UBw+7cX4h4dx+3r0baslj3JHoDIzoG2jtGDBLNB1dnQd+WS4OSlwc14XI36OwrazuzrUz3nnnNVO1n/ZoPn1YMAVdB8FJ4+HT+zIdneeZ9dG2a312lau71Pr7OQ+uizq51XlakeGIjz4v5vt9tovUafvVX/LjkGZr+P9K6Nve3b2557zvPqmtX7XI/fE6o+xG1SXVdje1m7T+kp2xF05zK9u1E97b2P7P25bY/u8WzNtF6f4vJZ23HZtu0tKbMm07J22+mjOy+xb711fLwej6c8bq1qf7S3tuRVVvfM5e20VnGP9ur6+c++//P/4I/++K9PVA8AAMAXQsAdAAB2+NWvf/zPfPPNV/9sHNLLYs2VWL4assuGDnvDkO30+bH0dWLZpxo97w2Gxq0xGlBsy5y2VLW14t7KBkGzgc7ZvscycThvXR7v9bYvVV/b/vVef6DEhnA6n7heKG82JNkLDVfLtnqh1hgCnGmvDVjPBKCroPNMaGoUsOsFcGeCj1kdsc24TtVDC9X8mX5F1YMIVUAyhuxiCLyqO06Lr0fzYltxXrbMadpMoDSafdBg5pwb2ROEHgXWLw2zt9Orc24m0H+OpwhtXrp8bz+OwtijenoPUvRCrpW9x38VqO1dM2eD16O+VmXba347r7dNTmViv3vh7KydVu+hjbhsFdKe+RztfY616xPLZaHpXl3Z8m0/Y5+y/dELbsd6q/baPrXvs+1ZlY/Hwei7QdVeLLv3WjHzfSiWnX1wIk5v99PHDLfHfvEl+hwPgHjPIruHsSyP71W09z7aeySx7ur+Tfyvt223Zdyv7D5LVWfse7X8rLhs+36unrXzrrcWp9LZnaQ9axS3VraHe6qtf/oV95//8N1//pe//NU/MqgGAACAL4SAOwAATNq27fbm5uZfur25eTRaPTtAlA2LZcNZazJvaeadZzTwOOeyYdo1/D2n5mwLZ8N0o6G9WC6rr/2blc/WZwvLtNryM4OucT2qvd/276lc92h8uPznOPjPyDUDRh8yrNQahXpn65gN+FaB7jbINRucrt7HoN6srA+9YF7WxywA3pYdhSTbZWbC8r3wW7XN2rpGQcIqGBjnxWBmWz4G5OOyo/aroGcVZs3E7dTrz0wYdm+gPaqCoHFeVnYUqD7nuJ+Z1zue2j6MwqeXiufXNVXn5+zx1Qsen+ofhXF7/ZkJUM/WW4nXlXhNnbkGV/3LAru961/V7154uzd/NC+2lV1j2+t/dt2r2mn7F8tl61Bda0fLV+1EvW3V+xytPreqNuM+n/lcymRB+tExUn2XqLZ51feRUX2jfbd33p4ycLmP9A+UadfsX3vfIjvBevc+YvnRtK2ob12W9F7PGsq0faz6lNXdtlldRGa2abZul9i/fNwiWzKvt6btvHZrxb/Z63UZ7M11WX7rt374S3/wD37xV4crAgAAwBdBwB0AACb9+NPLf/b582f/wrI+Hg6rhsVO83pDarFcNZAU28jm94e2tsEwXLYWj6edPwzaLjk7CJdtjd7WruqoBlTj8nG4bdRGb7ivfZ0NtGb1VHs9zs8GXWddK9FxzfaPPvjPrI8dNM/s7VMWhpupY29Arl1mFIStguizAa1RCDjaMz8G0HttZ0HHmfZ776s2q7BwDB7GYPYopF9pg6Ux4Fr1M5s/E07tTe8dF1nIMb7uBVazaaPtX23vkb3r0VM93JDNm6knC+3u6cul4fJeYDorl7X/FKpA7OyxPdPH2XD77DVvFOae3VazgerRtWwmLNz7vDgnnJ3VkR3fVRi8ugaMgvAz4f6q71lbe86FGPLufe621/VRfe370fkXr4nVds0C9Fm78TMgu+5V/Win9T43Z/bjuarPuL1h/t5yM/Oe0sf6jsynrLovMbPcU9VdtdPeb4n3Xto7VfG+yJKUjcu39z6y5WMbse5qmdP7bDvEuntlq+Xi8ueaWf79Nopbrq1ltKbZGlbLZXsq1henZ1s1Hh3bti03NzfLsq7/2fv7exkGAAAABNwBAGDWjz/+9Hsv7p7/8CjU8PZvNhhUDQ6tS3+obVRP225vWm9waW7q1p27z7k1VGta1beGv9VgahxIjWV6Q3mxjtEwYG/Atyo3mpb5FJITn0IfOdee0NC1A0bn/MpnVf6c4N3e8lXgdxQIr/rW+1XW2f5lAd5RULMXrN4TfB8Ft0f92hOe7hn19RJtEHMmpFyV39uvNvBYhfCr7TrTRi94m9Ux2nejcGwVKB/1tTpHRuH0GNjPjrV47vRCobPHahUmnT3Osz5lfbhmQPXc47M9D6p1rALnVUi7t1zvOtLbzyPVsd0LR0exbHbc9s6hKuA829dRP0f1xj6PPlf2Bph7Dx709nN2HmfT2j5UYe/e5217fYrrm72PdfaO89hG79o7+gzP1itrM9uXM57ie9O5Rt9jzl1+r48VrOdTlt0HmF1uWfr3X9bJcifbZLm2fNVur2x2XyW+Pt1rifd9Ytlsfu8+SjV/tO6jfbT/5N8676r2Tj9nsXVKtnt8T6/2bpXT9Kr90x5s63hX17Ys67ouv/XzH/75f/CHf/yXd3QTAACAz5SAOwAATNi27e725uY/enNzsyzbNhwae7T84H028BOnPRr4SerpiUOAoz5F1xnb3zu4lw2bVcNl2bQ4aNvOb6ed2qkGNmPZqq+9vsSyvfWo6t5T9px+XcPe4VKO7EP82uSlwaO9ZY8iC8LukQU4q7Bdr45RWDdOi0G6mfBbFVKPAb0s9NgL9beveyHi2Mcs4Jyta9XmzLxqXdr5vQBi1v/YVhZq7K1z3Faj/dfb7tm02fBxb51imSrIvvdY75WNYdGsbHXsnFs2a2/2XGzrGE2r9vVe1XlWGYWlszB7tb/bOmfajW20x3/vupLVs3e9Z/q1J3heBfDj69nA98z87HyM+2hvPZnqOhs/H2Kb2WfQKDjfPrCQLTMTCs8+c+Prtmzvcy77zB4F0rN9MaMX0h/VFdet+rz+EGavwW35k3PPj7bcp/g9E96YOdBnDvBTmS1M25r/2jZj+bZsvKeS1d1ru61/CfOy97F81t7e+zNZW1kbe2TLrA9aWIp37RrOttyWz15n4l6La5zt+di/uc6tyw/ff/MP/eIXv/wX9iwGAADA50nAHQAAJvz440//2PPnd/9MOyqzhf+ywaBsiKsa9mqH/KI46DQ79LZniO2ScfvRsOmFuaCixqrWOJQW51WDoXu2QDtstzb/ZYO72X9Ze+280br1lssGk0euuYdGw6J8Sj7mr00e6dc/W+eEyNvX54Zwq6BZKwva9YJZewLMo7Zb1XpWgewqwBzXvwpZ9sKJVUC4+uXcqv0sTFrV2VvvuB6zesdCVTYLtJ/+jtqOgdCZfp0bKMz258zys+dApdrfe64lVXujByZmAuB7At1VYHbm3B+VGZWN+6QK/LZlR+dyrLeqpypXbYvsWpP9bdvrHYuj43TmeKyu2zNtZf2LweXetuotXx1b8WGBbNoomJ5Nq66LVcA6Bsfb+XsDydXnQNWPUR1tn2KZ6tyI02auLe3yex6cmNV7YCB+Rsx8N7okJF7tl6z+a4bRz/lcuHYf+BQ9xT9KYp1bMi3q/bt8to+xXFZf284Wypxzb6JqK7bT/tfeJVuaMkszL5bP2mjnt/9VfW+ntfWecwy8X2YN03pb7WPdfdmav1t4X+31WLbawtu2Lbe3t8uyLn/lKc4mAAAAPi0C7gAAMOHHH1/+h++e3/3ZdtDm5DQgkw3UxIGe099sGK2tLxvEiUOYVZlqflz+moNg66DGfH2fYhgu2yp7hvyyPXaqI77u7cVeH2J/4gDqqUx2xIzWozeYPLvcNYYQDUMy79xg+kyY9pp6YaVRqLktN9vXPUH6Uagulh2FpWcCeDHImoXf2mWrcPVMEDQLmmdBtlPdvb6172fDd1m4vSrXC8PNBCazgHDb37jes2G/KjBbBUGz+qvgabZ94r7Ips2ErKu6s0Bq20bsY/U+W9eZbZvtk6zOkepYjPNH/cmWGwWSq3ayMln59vjJ9sHsdTEeE9k2GQXmY7nqOItlsutJb3v1plXnbdbPaM/DDL1z4lyzgfq2L6P9E68t2XbqXSdjeDouP3P9zgL+2f4/zaseguid79l1f3S+9c6Rtp62X9n86to+qrPt46XHTa+e2b7taW9mu52zXjPX4L0PTfAl6x0sswdHLBfr3HOPI7Pn3/+n+Vl78Z5Dr09t2fb+R7ts7FfsW9bO3m2T3XOp7qO07Wfbqerfm3rOvRQ8bPn8erJ639R4Tj8eb6XsKF3D67hMNj32b9m2ZV3X5Yfvvv0P/upPf/0XJrsLAADAZ0rAHQAAJjx7dvPP3NzcvButzoYD49BeOy3Oi39b1bxsYCiKQ3TVYFTW3qx2oO1clwzF7qsp2yun6XH4rZ0eB1m3pb+Hs/LVYGk1SBr3fGy3WqZax9jHkWsmMa63h7mMX5A8TxXobv+OlpkJRI+cG1zrzc/Co73jpBeozkKh7bxeULAX0KvCqVVYtQpXx760wcgs2JiFY6ttMgrxZuHirB9ZELIKTcf1jq+rwGkWNK2O8V5IMWuzCqvOBmSr5bPjM9uu8fVI77jfs82veW3NjvW4ntlxUQXz2+Wq9mLbM9eAuPzoGjI6j7J51XWj9wBE74GE3sMHo3WP176q31mYu7r+9NrJ6ox9zLbXaXpcr2w/ZesRz8XqOto7z6ttVcnO6dF1LJ7/Vdns2hSvF1XfR+d4VkfWv0rV3+oY6dUXr52jYzC+ntlXe/pT2btdqukz9eytvzXzGSK0zvVUB1M7/dIvGpccsFuz/Br6soUyWzKvqieWbefF5SqxP21d2TZr563NtNhO1bdRf7L+Ze/6+zO2+LC3WfsP68tKVEttyX9VP7L62uXafq7J/Lh83PKjPnzz7df/6B/+4k/+saJLAAAAfCEE3AEAYGDbtuf398t/6ObmphysacVBozjgE4e21uR1Nvy2TL6v6s7eV9N63pff05PMTPlR76pB0VhmNKDZ61ccLG0HZ+PAb+xPNpAb+7Euj9uY3avZEXOOaw6mcySfcxjnKdftnF/+vLQ/vbD4HlU4MStTvR/1MU4bBc9jG70gai80HtvM9PrRC06eG/qOdcxsy9lgdRZabMOQ7bK9PsZA56jd2LcqwBv70ftvVhWmbt+PQr9ZfaNwfnSqv9peM8dEbGPmuJ6pM6ujF+Tu1T9qs+pz71yaaSO216vz9H60LWJYuvcwQBUqbo+t2cB8O70XbJ8N+cbgeRWmjutZtVPtn5n90pYbnZvZ8Vaty2n5OD9ru3etzeaNQtFV8H1Ud7ZOsb64XUah/KxPWZuzZj5zP9T3wmr7ZGaus73r6Mjn/F34qZ37UAE9vX+3X7rBz/03fSw728fqdezLaPpWTG/70ZZpX8cyWRtxfq9/2XKzTvd19rTxfsl9rT2sO1s2W+usvbgX2+Viv2JdW1Ou2itxudmjdF3X5cXzu9tlW/7JTjEAAAC+AALuAAAw8Pr1/Z9/9uz2d98NvpxCEUs+3BZVA0rt37ZcHBaLdWTLnDNu32ujV99TZATyOrMtcZo+M/zXLr8l7cwMwmZb5TSE107PyvWGGXt9OK3feYOj8+JRJcEArXNDZXuXjctVgexL6sn6tifwNRvc7vXn9Hc20FsFO9tle4HrLLRYtTEbQI7rck5wtVWF6qtl9wQgq0DvaNlegHfvMdALobZ9mg2OZ8dG9n7Up6wfUS+Mepo+c97Pnm+9dq4dMOzt8xjcnT0+T+Ur2bF/Wn5URxWOrurPwu2j8ycLWvfOvXgd6AWIR8Hw2XmxT+0yvWOv18d4Hcuuo1XAPL6vHhTIymev27r2brPRNSJrdxR8nznusr7EttrrYAz1V3XMPEzQu0b1rie9OitVG71lettqdA3iOOyPT82H/vd8PEDau2PZ/YU1md67C1a1eVq+bS/rx6X2ngD5XbvsTtRe2RY7Z9n4vrelquWy6e0ej33t3Q/t3e3btm158eL58qtf/+af7nQTAACAL4CAOwAADPzq17/5i3d3z/7csq5vBmJOoY8lH0qrYtJbmB//xoGmanq2TLVs1o9YV1b3hxga7fWl35NqmGzc4ni9ZrZc24dqqDEr32uj2pPt9NkB31nVtr2m6myAY7hWOGvPsr1leqHNvXWdM68qf+52Os0fBcdjqDELQGbhyawfvYDjub+QW9VVBfazwHwW9Iyydcj6UdXf63e2bff+qu8oNDlT397z6tKAdxsmjYHbbB+O+lht8976tkHZLPSf1TOzP2LZ7BzJzpOqfOzL6FiJQd3qHMnM7Nfeww6jBwd6gfasr3uWnamvt/2z19n7rD+jc6wXns6uue3r6hqahd174ezqfdwmo2tZFcrvXXuzslW/RteA0fU1zo/Xl6zdUei+amN07Z09z3r7tldPew1ty42+H1RiP4So4ahO9zza9ycxzhznxWlZHdHo3sroghPj1dXds5ll9+jfV7n03trj+3aX1bgVf2eWi3et4l2q9oip6l2Xx0dWr5/P7+7+4v39/YvJbgIAAPAZevaxOwAAAEf3+tX9X7y9vX1xGn2vht2yYaYslnyalkWao1O5asisF0o/TTu1f7Ouy83bFEIb9V7bQjF4cZoV5j+YvsYlkuV3KLfvOlGmmbZnOPNyvTWNg6yXpjhiHdmajgaOZ/vQG5weza/6GcvHAzAeuaN6R3Xn094fT1lfsvpG07L6Yh96AYAllJtZx2wbZ1eDWbOBg+sZhRTHetvpcVsP25m/OlwSwMqXrfbT5Vesej3benvtz3wqnStfvg0HjrfzfB+uGZyr9uO6rrvC4aOQfRb+PNfDOt9st5l23pd5eOzs20/nmNm35xyD76+Vse9z16D5z834sMYl1434mbFtp30w+syd7e+43McIn2bh60u+P13+OZPZdx16t9SDL8+n68ebv22ZXp/jeXjuPuotd/l+H2+fPW1k5+3pPIjX4L19z+seLdX/LHtcdknKv5++5yGbS+Xn19N8Bj00/31tf53x+++l31VG7ZxeX7vu2bKXtD9TR/UZk5U7px9xnfe0V81/f13dtvhvptG/q+brzo3+vXwqs+eEyut8+01u0K+q/7G+atm8n4/39rps7+4qjZbbwvvK233YKTM6gmeuNFn92R2AB58NoVzvG9fMEbFs982FN+ls1lCn7vd93d6Ve31//6jats/nfuOujpqtUyb2I7tqP273zfejr756/hd+/esff+fbb7/+/wy6DAAAwGdKwB0AAAZevLj73dNAWzvONBoQWpu/2eDNaGCtHShal3owLevHurwZ5Hr2/G65u7tbnj17ttze3L4N0KzLuuZDg7G+U+BmX2TgnJAV1/c5bPvPYR2+bKOA1LXDpb32zwtrvY1tNNfM6ldbW++nncI2l4UJ8/Dbm2v543Dy2+v2tnVDc1Worxd4frx+edmH63/qy/qgT1XI+OHr5vPpXZjxYT+zX6et6nxf7vQ5uDZltqT9fJ0z1fz36/Hwc/d9SDl+Jmcebof39Z2Cndvy8Hh7WOc5v7LbX+Z9oPRNmSxk9fDYn4z7pG097E8Ie707F4qlp64xndZ3LD97jZkpNzrWsjJ7g6pPsW5P5VoPfOQh6YfXgZ7TufX4uH5XIlnmfXvttHwfV+fJw+tn7XHY+2F7442YXd/ba1je98fX98ev31/3qmtlnNe7JrfTRter9t8l2bX38fLv16d3ba/ldcfP2Gw7vr+255+X7feS6vM37VHyWZlt63jdqD9r3/S191BP7ztS1re879V3nbnvEY9qK7fR+Lvm7Pe4D3G9zNvw7yaOLjtGz/1++DHl61EF/rdmqZ623PtvJ+8+FR6c8+38B21t76e9vr9fXr16tbz86eXy8uVPj+41Plyy39f4Db/qcza/Kp/V/WC5tws/f3735//4T/70zwu4AwAAfLkE3AEAYODV69f/8Hpz++79Fv6eBnO208Q1DkY9HiB6sEyYXtadyAaPtm1Znj+/W77+6pvl+Yu7pPWslsGAflMury3redbLa+v1PQvbLcvjIF4eynu4zLLUe6uts/e+V9/McGcc6pwR1/lT9Kn2+8tVhY5GywxKXNSfPX2p2j+t181Nvn5ZaO3NtDfLxn6Mg26P1+Nx2fd1V0H32M9qWu91L/DeW/+2L2/6+WbGad17x0o7Py572genv3HftOG2m5t8vU+/8Pl+3zzs9Gm5dp16AdVRyLL9leHH2+Lxr8BXgcibm1PZ9UHf2yBqu37tukRZeLHdNz0Pl4txmXeligDnOLiatfem7Ppou/fqiMdadpyOAuOneVnwM7bd60Ncn3MePIh9yebFcnk4NV+mdz06//qZ661/tc321Bf3V3a8t9fJeB3Ijpe2TL4PH3ey+mzoW5NrzJquQ1zf9jPqcXt1w6M+nrZVFR5+f216eA3Jtk+2DjOfUdV1t71e5+dquz3XR9sj/yx6/Nm977vNw+21LA8/o6rt+L7d9cE+fVx2Tb+PZNe6uI69bZ31NzumsnU8Zx9WZcOc6WtS3AZ72xnp7ffR8Xxtcf+/bflRud5nBkcx+2/1eP/iAxxo79pdk/eX9uHx98a83bad2TtoS/E+Tpspn/U7bo9lWR9MW5NX41rr1/XDnJXb22V5fvd8Wb5elpcvXy4//vib5Te/+U3ZZtafdstnWzr2c+vMz8rM3HV79uzZNz/99PLnna4CAADwmRNwBwCAgd/8+PK737696Q5zvRsGW/Oht2zILA6rZeWyeXHI7cGw4rou33377fL1118t80NpsyPevXKXjprPDCTubTfbmqO2sm3WG/A8bf21eN9O29PXbKiv6l+sI2v7Qw1+w8cJ0Tx1eKetv2onC80++KW95PXML4Fmy8/2dabfVf2z23Q2CD0b5p1pd2ZftCG3rI2sX7H8TPA51hv7EN/3tsWeUPGe8G+2HtU2HNXTC/CNQpXtMlk4fKbvM8dQL4Qag+mjOnvHx6UuCUD2wr5V3aPjOQvzVvXM7r/eMr3+VsfNTP2Z2eDp6GGFXlu9c37GngceZoLEvXp7D120y8fPs+q6k33mVO3NXmezfmbHxcx1KDuWetez+CDB7DU/62O1XK/MuZ//1ed4tm9n6uw9SNHWP9vPc79n9Mx8X9qzzp+Sc48LjmZr/s78W/8k+zd/9f4S7b2MU53xb9u/qt3R/Dg9tpetf7vtKntPgLaf1X2cT++kurt787/s+OLFV8svf/mny6tXL99cP5fl0Z2sVrZXetPjtLj1sr3fllmzZd48OfBtsigAAABfiOI3nAAAgHe27d1gSjakty0PB2CqAZw1md9tNvzXiu1uy7Lc3NwuP/vhh+Xrr79erjeg+SFdo8/ZkFy75UfDa8tS783T+5nlZuqJfeit/8zRE9f1NO1IA7BH6gufk2uEd2ZCtrN9+VBhol6ItX09E0KvQoR7AqxZvTHYOgodVv2ttuve8HEWbqwCmfF124c2rJ4tU4Xusm2dGQX0RsdZr50qIBrX5dxjuQoI7wnwx/l7g3zZ9orrem7dp/r3nF/nmgm6xuMy7vfR8ZaFhHv92HP8VudA1d/Zfs0EZavwc69vVT9672fqqPoY911WT9XfXvuja1F2TZ45nnvX4Wxdetu7vU5UnxHVNhn1s+1TdY3r1V211zue2jqzsvFztVdv9b4XNq/MBMDPdWk91+hH77z9XIPtHN3eAy4Li1fl1qRcds+huv8xK7tnkvVvC39H9yyy+b27Xu20XjR6dhu29c44917Kx7gXN9fm3d3d8rOf/Wx58eLFm8/IML+350Z3otrX2ZFaqY7gd6/Xdbm/v/9usjoAAAA+QwLuAADQsW3b7bquX719t/u3m2YGiLLBoFg2LhPL3t7cLj98//1yd/d80KOjiltqz5BYtYVO9VZ7Ldua2R5r+1IN7M4eGVX9sUy1/lUf2z5k6zfq18i1kiEfY7CXz90l4dEjGIXUe2ZD6DOhy96vsH6IEFsvYFiFEk/zTv+NAtSzQc+sjl64Pobee0Zh1awfozBkLDMTBM3WOwtVVoHwGFzNtn82vRfQr0L1p36Mtk3sc7tcFTYdbc9sH8f1qOwJJlfiMVUFXGeOibgfZh9i2BMIr86FXoC36kt83asvttkLYvfWae/nSTw/sgcfsnNopr0s1Dy6zrfLjLZXPKdjX3vHx+jaPLPtR0aB+NmwfTu96kPvGp8dU3uD5vF6E/dTdW7Fa1j2WdB7CGQmuF/1N6tn5qGCpzbTxiXfq67pU/9+yrku3fG9+whx3raM75uc25/eSRPntX3I+ljVcZpX3QVbQ/l2XrvsJbL+neo/98LxES44O9q8uVmX77//fnn+/MWyNRfHbA9We2kL/8Xl2/+q+5vxddbmmzLrsi3LV4PVAgAA4DMm4A4AAH03y7K9SY1PjhlVQ2yzQ3DZAFGcv4V533337XJ3dzfXwcOqhtJa2eBntWOqAdE4rzLak3GQtRdKj/Pi8F9vXtb3bEix6vdoCDGzZ3tdMvjLl+jagZ8P9Uuk1S+oziwzmnZJmzFUmbUzCsGN2u/NmwnIjurMgqDVMrOB1F5YOgt2Vn2dDaT2ApUx0Nj247RsLxw/CrVW4f5q2SyE2yvTvs+CmL06euvb26+XHFdVyDkeE9kxUG3P2N9RuDSq+jETGq/Wqwpx9sLFcdroHI/7qtqmVTu9Ps4cg7355177s/NxNqBclR0FnmevpaPye/qwJ4w8Cn9n169ev3vXs5N4HsSHBLJrTlz/0edQdY5n7Vd9bOvpTW/7G4/vmc/Z0flYXSuy4HxvuRmj7bF3uWuovutU/ejt10u/x836GKF6PlXVv9ez+w2z9cR7K0t43ztAT2215WJfMu19jbjsufch2mlxO1X3QzK99uP9mqOdvFXfs+lz23ld1+W7779bnj27e/y5v9RHTLZl4pEy34vHZR+9XtdTA5/6zU4AAAAuIOAOAAAd27bcrOv6PBvgKZeZKJsN8bWDQtkgTzZgtN3fL998/fXy/PmLTo+e2gUj/1fVG1JrByzjkF0crmsHdLNB1CgOJFd7fGZgtzdI2Rvgbvs8Y3SU7h2SPMoxkDnaADWXhqGvZW9gvRcsnGmnracX7B21mdWXhe2yQN9M/7L2s2Vm6syCzKN24rrOBEPb11kYs627Cj/PBHHb/vUClTOBydjndlrvoYUYbq5Cpr324/ESQ6JxO2V9q4L7p2V6Yc9MVl8VMh+taxXcnT3vMjPnaTWt7Xfcd1nwP8rCxXHeaPtW+3RGW/dsGLu3LnHfViH66lpQBYdH18m27qrf2XrE9uKxHfsc93fWj0w8FuK6Zdst62fW5kwwOa5rPD57If9qn8UycXp1ja6C4+20mWOxra9av3hMVtfXXog8tl8d39VxE1/Hc6ES98fM52fvGtwzqqv63L3W97g95+0eo+2x93rJ5+paB8LeekYH/Mz8qs12Xq9fa/N3a/5rnaatYZnT6zUst4Z5S5iX9StOj/NiG1Hbv2xebG/GlS9IVzG/Drc3N8t33337YNppK/aOnFO5tSgXp2X1rGF+PAra6eu6Luu6fKr/U5UAAABcgYA7AAB0bTc3tze3e3+9vRo+ywaA2uHAbGCnqn/btuX29m756ptv5jq3y57BumuO/I/a7Q1a9sqNhthObWcDo+2AZ7uXYvk4fwnTe23Hvrd9yl6P+hz7kS1XtZP1pxpMzsoezREHnpn1lMGia9fdC5bGMpe0vSdom4XsZvo3YzbMFgOFoz5m/cv63gu3VuWrPvYC4dFsaDf2v7I3wJgFP7NtnoVlq5BsFR7N1qkXgK/2VVtnXIdsG2TnSRUC74W2q5BxFWad7Wdvn1RtxGmx7B4xsFud53vOmcoocH9uOLTqZ6x7JpzdLpvt1942qa5PVdi4uo5k22IUhm6Pp9hWFi6Pfa7a6gW/R8ue3s8smx3XvX6P+lDVHf9W+6gKo48+93rB/Op86V0bs3XsHcPZ9hsZrVPPzDmZtZddRz/U96iTUXuz22+m34LtPHTOvydHB9He+wLnLL8s+X2Btfgb686Wa+tbl4f3QLI+tfcP2vpi+bUpH6dV77M2eqp+VH3P2munVW2ec7z0VO1U+2ne3d3z5auvvlru7+vtF/f6qExvD27L8uju0ulvVv9p/u3tzcf8RQ8AAAA+MgF3AADou71Zb262yQHErXi9LPWwYTsvW6Ycztq25euvv1pu16f4Wv+xRvVnBxarMtUgbVX3aH6cFgdP4148ze8NJFfvd+39ovzMtto7EBrrvfaA7ccgtcJ71woxVeHsa7V1zq+W7m1/T3isFyzO2q2CxrOB91HIPQZ+s9BorDcL3fe28yiEWLUZg+jVds76nYWSR4H2qt22fPu3Cr1n61etW1ZPW2ZG71jI1iUGWdu+x31arVO1beL7UUC6p7dt4/7O5sf2suMwO07iQwGjgG6UBeizdar6OlqnXsi4N78KmVf9yK4bsR/ZMTMTdM70zu/RtOocjvsyuza0y4+uz9X1uFcuC/T3Av/Vfq+Wq8Lwvc+N0bW4F15v+5S1NVPv3s/M6pzLrm2xnvZv9dnWlu99BlZGn5lVH+KDB9Wy1zD7+XlpfXC57MSb/Tf1NlEmlp1pPy4Tl9069WXtxdfZ/ZD2v6z+LSyzFPXMnKyz/1iK/a7qzqa306r2PvSF5bL2vvrq62Vd1+69zHYrraFMu7eyI7c9AnrStdi25fb2dnn58vWzweIAAAB8xgTcAQCgY9uWZ+u6PBsNxsT5s0Nd7eDQrqHJbVmW5Wa5e/45/i/1xjWeGbBrB1Rnl8m27DnLZYOuveG9bFB0W+r1ro6OmUHrbPrswG9m9kw4elrkkm3AEe0Jf58TFP8YRr9oO7PMUxgFI88Ni82GAGfqyJbrBb1nwppteK4KQVYhxGxe7Hcv6NwLccbXM6HVvcdQ1o9zgt698OEoXNuW2RNirPZj1b/R8tnfmXqy+to+9eb33o/62nu9N5w7kgXHqzYvXY/ZvlRmgvvZgwGjhw/aOuIx3NZXXY96geVsHXrvZ/UC79W1LFu3rK7s+I3XuTi/ra89Z6tzNwbOs+tlu22zcy4+NJDto+o6PJo/Wt+Za2LvmlWtb/V+5jwaXQvbaeeEyve0e41lP5XvfXyKrvVv3tG/+zNr+DtaLrsHUd3XOOek6d3zOLVf9bW9nzJ7vyF7f+m9jqqNp1rmGO7ubpe7u+fL9vZC2h4de9eqXea0R2fuc1avl2VZXry4W/7wF39yt7MrAAAAfEYE3AEAoO9mXd7+RHo2sP/2bzuUFofzsoGh0TBkHKZrX6/LsmzbttzdPVvunn0OP2Q0O2w2KrdngDkO6vYGd6sy5wygZgO7o4HerI29R1S1XCWrp1d31veZ5WbL7Bns50s0CvX2yh7VKPg3s0y2/DX7dE79M6HgcwJ/M8HZLLB4ml4FxLP2zg3gxzJ7yvcCqFWosrdOWUh75ryJYdIs1Bv7N6qzDbDGPlYB4+xXg7Mg/kw4uRfIjWXb96OHBbL6Z8T1qvoT660C2TGsG7f3TBi86ktsp62v90BJnD8Km48ebrhkG2ftVSH90YMqvfqqY6t3nmTXrBjkzs7BKsxdrWc8NrJ51THTu77MLBP33ezxOHOtr/ZpvD7OBPNH77NjcHRMxv3b7tvsmJn5fMrEAP+obK+N3mfYUwbJL6n7U/nex6couz9wST2zkeKsnWq59p7D3v5V5eN9jNO0LWmnnT7q1xrKt++zPmXrdI0TPlu/XrlrtbvHNS+463J39+zBxbLdsu3eiHsr9qa3FWb2VLZH12Vdtvt7AXcAAIAvmIA7AAB0bTfbsty+eZnMTV5nAzXtsNzM8OXjQZ0wf9uW22efyxhPNtSVbZm9g4ZxC2cDsHGvxaG5OKB6GnJbw/yqb2unTLX3e0dFNsBb9W90RPZkfeiF1nsD5jODr6Mys4P98ManEGbaG9aa/UXVve1fK/g+u833BryXJQ9LzvalCnj2HhjohQpjwLSqN+t7Fkpt16sXWK3WsRf2zALCVWh4ZPTLxbPlRm3G0HsMbcdtXAV5q+3bq6MtPwq79vrf22+xjthWVi7qnbtZ4LQKh/eC+z2jQHNldO5WDyWMzv9eSDxb5+x6FfdHFiqPfZtpcxTCbv9m618tXx2/8TiP9fX6cun2G/Wr+pzIjs9sf2TLjj4Tqm05uk5V19yZfZbVl5WJ07Nzc3bf7S3Tu45+LO1nYOaS73Ufc7340lz7YOvdZ7ikztG8qt14H2Rp3sf4c9ZWr86qzeoexFOc2PGew5H/QXndvt3d3S1xm1Z3z+LeyvZyPDqyOtv3VV1vCm3LIssAAADwRfOPQgAA6LtZ1/nvzdkwWzX0NDNcmQ30bNub989ub2e79QmqtsxTJxROQ3ZtUPw0fXaAuRdcj8HzrZjX9ierI6uzNyic1XOOOFQ5O8h85MFhPmdHDjVd+5dPs2Bjr71z6x6VO7f+uPzsLwT36uwFY0dhy2pa9Yu7vdBnte1Hge+2rZngaK9MLJuFcKtp1byq/1U4M9YRQ6/ZOvSO5SpwWgVGZ/rTa7sqP9puvWOxDXW2+zGGbHvHa7b/R9syW7demLp6gKAX+M7CxfEYrIwC4r0QedzWo22fLRvb6gXHe+dT207vGjGShb97ZWIbcV61T9t1jes8Ctv39tnMtawtm82L/Zl5EKCy9/Mw2yZZmWxaPA6y87tXx6hfs/NGDwu0ZXp1XRpCH53Tl3xXqTxFnTCWHXgzB+PpHkT8d3ecf461qG90nyPrS9vH6h5EbKvqd1b/qF/ZvHO3S6/OL8C6LOt6syzrmv6cQtyT2bSlmbY25Yrm9nlT0ed88xMAAIABAXcAAOjYluVmXZabaw91VUOAp7/DocBtWdYjJzefzJ69kA3PRXFrzw7HzfSjHfTN+jOqKysbp7eDwb3hxDj93CM61jN7DH4qx+oXOKD9mfuUQk17+toLFcfXoyDaueHxXp2zsqBorCsL6Z3+VqHeLHjc2z69MHdWvgr3ZqpAdLUPewHVOK16XwWRs/5WQeFe0LANSY7KZG1UQd+q/Sx8nS0/Cqtn27wXFh7JAvPt315At50fg8VZnTPh8azetv5e/3rnWdQGdOP+PHdbZv1v+57NHx2DsQ+9sHYWwM7C1G2bVflYb9zeWfne/qyOjdhGdny377PzsW2zd+xVfav6Eq9rvWvS6Lq010x4u7pGxOXjMT7Tr14QflTHNb+zjD5LesfMqK5zvq987r6U9WSPcw+K3l2hWe2/9WMdWzK/F1du6zgt107fmnmxnZk+Vfc5MqNtMntxumTbfqbWZVmbbdJuyW2p92Z7NFTllqZcNT/bG+20m/VGlgEAAOAL5h+FAADQsy23y5uQ++n9I9mQ3N5ht1hHNjj0sPD2mQ2kVwOrT9nWstTDcKcyW1gu1pPVndUTjYYD45GUDRzH5WfEQepMr66s3+e6NMVzxRTQO5/VScUVnXu9Hf3i67X1Qr/n6AWUZ5fNpu/ZHln4sQojVsu1y8+EP+MyWb/b91XAtRf2rULQWf2jsP/p9Wid2+MxexggW8+4XNteb5v19k8M+o8CpNk2ygKzcf/2tm1VR6//sa+98qPQc6y76mfcNr2yMUgcj93qepQFenth6sqecHu1LXt9icdy1k7vPKjmV33J2onls3KjhxViaDo7t3p1V32s6or9HYW5Y1/bNuMxFuvo1R3XJS5TnTO9c6DabzNmrp+xXNZ2fB2vZbMh8qqNnmx/jMr33p9Tx4doc6+P8W/kD7FefEqyf7svy3X+rXm6R5HdO2hfV/cg4vvs4I33Qdrp2X2A6p7HjPbeQtZeLDtTbqbNmeW/nHsDb3484/H2jXt2DX+X5eFRVB05rWx+Na2Z/mxQLQAAAJ8xAXcAAOi7Wdb1ZlneDuJkQaVkod4w3UlvuK677HYqu35GY27bUg+wRnu3bNVWNS97PdtGNthcDTJnQ4XxfW/5njj43BsA3zvw3ps/m+6IZ8ho/0uN8HFd+kuy1/6109n6Lm23F1jNQoix3GydM31pl50NNPa2ZRYa7QWis6BntX2ygOooXDpTT+zLqdwotDxqYxQ6jX3p7Z9RQHhURzuvCtv2ZKH1XnB1JoA6E3CN+yHrcy+4PNoe54Rk954nVSC5CjdXgeQY3O5dK+L8NqhfPYAQ6+rVv2efVg9bjM7T3vSZBwX2BLR7IfAYuu/1J57P1b6vruHZOTpzPI+umdl2q5bpXbeq5Xp19h7siH2qttnI3uB1r95zrgkfKvj9MQLmLWFzPr4sBlzpHbDVv5GzQPnWmTfTvy38HWmjzO3frO2svaztqp2Z+ztVm9Xr6v7IqN7P0fp2VU9fgh7OPe3Vai/uuXuU3fWaOUvWVZYBAADgS+YfhQAA0HezrsvtshTDWzHIVc/apbvsOlHmszZa89EA5555bZk4uNwOIs8un5XPBqe3Yn47INsb1M4GwbM+VfPa+mLd2fteO5lqaHNPIuap0jNf7pn1JRoF2q7hnF873dOn2ZDs3rr26oXhqzaqMPQoJD3bj70BxyyUW4W224BnFVCtwp+VUbhyJrw6+rXntj8xFBuD2L2Qbq8/sV/tMlkdWWB2dvlREHoU0m3bnfk16NnjPE6P+6jdxlX/ewHr6vjMwuVVmDq+Hq3PTAi/CrtneuH/c68Be66HvRB7PC6y7dg79mYeOKke5BiFu7OHTnrzRmH707xqfnWexP71rhu9hxDi+6q/2fbqnY+9BylGbVftZf3q1T86Di75DjLzuTL7oMg1fKh24NMwexJUgfCT2X8j9+aP7gv07jWM1qNdNrt/EZcf3acZ3Rdp+5aVv7anrv9g1rf/7/S518zaOn9juXjEblt+F2nPHaFtWe9mVgEAAIDPk4A7AAB0bMt2u/S+N68P/jwaouwNve0Z+8/LSg+8Nxp8rALjcV47rRqwrZZp65/d8+2QYBzO6w329trM5sW2qz6076ujeqY/e1zzOK7q2tPGFzaQfYaP/cuc1zAKyH1se/r0FP0f/YJvr92Z42PmV2ljyHw2yBeDqDOhu6xM7xd+e8HgLKjd60MWlI3txfJZ32eOg6rfo/5l0yq97RPbitNmHwLoBcKzNkdB2LZMto9ntvFsmLZalxh2r46Tdt7e4zmu354AchWoHoXUs/Wptmvbr5kwctVOFfqfOW6zOmOZ6gGBeA3qhZmrv73tlx2Tsd+xvbbdbDtky8fjJwvMj/bPaHv3ju92+Ww9Zz/zesfZbL3VMZBNq64xo/6OAv2jZUfXmz3fES75fnfE71Lw4cQTYG9Quy3z1P82Pk1bO22e5rX3A9oyoz6elo2x5nb+FuatSbmqvbjszDKj6ZeW/cR1rv+nPdlu9Xi3K+7tdq+efiC+OoJO9T1aru2DX3AHAAD4ovlHIQAA9GzLzbIst3HEvxeRzl7vGQLMBoketbsty/ruf0qYpxmorIbXevXFobl22hqmtX9j+Z7q6IsD1NmRGI+yrM5qILptI76O/ehNy/o0Mpu4qcpdkNjhkc8hxLR3HT6VUP8l61UFH2fC5Xv6UAWrq+XPDXDH+s7dh6OAebVMFlie2Ta9kGfWr2x+FeSs2ozlZx4mGAXkYz1ZOLsKS2f7rAouZ6+z91nItVouC41WweIYUm/LV+vf63cU90nc73Fe7HO2T6uAc7YuVf/OOc9Goe8slB770gvRj9rP5ve2TWw7q6d6mKDqS3W8ZWV6gefTes+EyEcB9t76x+WyQH9Wb9ZOdq3K9n9vm7bLZMd97Fd1nZzdNr3zdeazaU/4vHcN613Hq8+W0fERy7ZtfsjvPB+qrU/lexyfqpl/v/f+/b01Zc49WKv7Cr1/52dtxvsU1bKnewFr+C+bX/V15ClO3Gy9LtnusZ6ZNg9qe/P/4t5s7/pkR8GSvK6Oxmreo26Essuy+AV3AACAL5iAOwAA9N2uy3q7LI+HIK+tGMh5PFzYhg8+kbGyOeeszFNtgN4AdK/NOPQ3qvc0rR3m6w0XZkfe/5+9f9uSlVfarTEYY0z7/u/Tbs0n9r/s9a2JD6qoDIInNgIyKze9v3PMygQpFAghBHoUmU3SdvzpTMir9NUxdqc47809rlb4NM6I+jNR1W8LrqLjGhHGRfmrCL+qDCX26wiAVTolvIyE4pnIMxObZtF91/1e2OnTROVFx1GJNzNBcles3xXiK5FpVC/+81EhckfMHAm1M9F71maViDpqI5HQ1Pvr251qL/Z71i68r9n3qCxbjt3vz6s/xkhU778rMXLkl/rs00W+q3auyrXn3l+zqmx1bqPz1W2nan/UdlVdZGLkbJvqjzr9pzq30aKEyA8l2rbfO20jKjv6HPXvkVg88m8Ef40dya/8Gjnn3XunT3v2/j/KI8sCuD9HG/R6QUbP/F27SlDu3ylE++dp+y5C2baC9si+ZbWZlRkxT/Vxq/xqmz9Gv++KjugqO7/NV/35o/Fn3edYRLro7FRvuXyaeZ6nP/OZuzIAAAAAAAC8OgjcAQAAAABy/izTNE/L+emqarJnmm4TSfaf3T7blG83xaNqOJtG60x6XuXLkclVn9dP5UVlWFvZMaoJZO9HNJmsbPpW5yfaKzoN8jca7dtdKPBidCLsZsK+K+mKiz1HosBW4ukq6q1P0xX0qu2RSLhjZy1b5e+Iidf8kV9ROiVyzWx7/5RIUYmNI/+zNuLLVOV0RPyRqFv5HNV1JsZU4mx1LjuC/OxYIp9HbEfCdiXstemzdq3E0r4s5UuFOk/V94zR/iXKG4nt1TZ1rXQEwao+lS/rd2s3uh7tvkyk732xf9U1V/mmtit7lWg9+h7VadbvqGsz6gujcxEdf9Vfd+/DjxaAdxn1qXPvvJLfliY+4zmDdyQTl4/k30l8mzart0zr566f9i2UfdewiO/qXYayX4nSo7dmld1oW6fujrxXGunUXqADWr7qfZkWKVYfNjftW5ptJdMU2I7uTdP076ArAAAAAAAA8AYgcAcAAAAAyPkzXTRuXoLPK9l0pMy3TN8TUe9MNdk6TfXEZ7SvW3feh85Eqt1uJ4SzdP6zmti1Nu13P11Y+aZ88ZPJVYtVk+PKnp1MH53cvXIy+AUmluEjyMSHZ0SiHVRE4HvYX4mizFbC2lEhWhbNNhN0d8rqCOs7dTkiUM/sRVGSM+F0lF8dgxcAV1GVlX/qcyYMzqjKVn6q44tEsx1Br9oWCc8juoshrP3se2TfnjvlcyZojhYY+O9ejK1seZ+jPNmxZPkqMXLUNrO2rY69EnmPXh/r9ugazBYPRIsaonM0umjB5vf10hHc+7bk7Xp8n3elQDu7F2X127Wf7a/2RX5V+Uf6mzPcS4iOwBwezzM0uiPCacvIW6Mon32+jyTLPs2IT5EgXZEJ6/07g847mKwcK76vfBm1PZrnFdgfz3oW1DIGT5SmU0ubt3lzmActAwAAAAAAwAfDQyEAAAAAQM7feZr/TXNvKnF0OrCyJe1ZEciv6tvPFn6V8yNTaH4ic/SsHvFZTTCrfVG+LH+Uz+aNxOrRpO7IZO/IlGVnwjzKW1FNgKu6BPgdRkRxRwVhZwTX2b6OaLFTbmVffa/8jUTuVuyZ2ehGTM72q4jckZ01fSSmjgTHUcTnqO10oxKPiEUjkW0kqK5EuR3xdlcgXx1v5xpTEb6VHSXktec1OuaRY8m2WUF0tcBB5YvqImq70XmI2mDmd7RP5VPH4P3p+OJtZddeJpD26VUafw13xO7enrfly+ic08hXb6OTz7brKl1GtihCpc2OvbPQQNnPBP1+f8WISD1LM1JvNs/VgvR7jjsAHsujG2Uk/z36/iB6dl6mfVn++T/ywabx7wSOXPyRnUhEr9JH9bOmz9JFeaNz4dNE5R7J99rMf+Zp/jNN8/fxj7y1qvZnLdmni97i/OEeAwAAAAAA8NEgcAcAAAAAqJjvN4tVSYz99N8u4a9y1pFHH4ia6OxMQh+ZrsvKziZnR+xFPqzf1bFmE8jebuXPiBD+3ngf/fHPU79uAX6HEaHbiK2rWUWOXdG0Et9GwvVI1J350infl9P11eZTkZbXz0qEqRYDRALYyq9IoB+JNjPhufc9KlP57PNH+DKqciJhdSQQtyLkahGEEsdmQtEsXVbf1tdIyG6/q32VQDdbyOC/jwjUI3uZcD5afKHy+GPMFjtE15u35899JH5WCyzUdWjL9NeHap8qny3Ttw17/L4urC+qfmy9ZmL4bDGDIrpG7TEoIXh0DFl7UcevjiHKm7UZtV/549Or79n1E3HF/bbTp0ZlX1X+M487AH6fqIGrZ+cjdkbSqmdau+2ID+q9QeXr4j77PN4f+y7EP6urfJPbpp7t79HxVL68I/t6tG+OohqJ3iD1StjbS7fPM1oGAAAAAACAD4aHQgAAAACAnD/z97h5+fm/GDttF2H3qWm6dbua8vuZJvyZ00NNEHOPCcnu5K+fwPXpo1Zg99tJYdsyshbkJ5eVjUmks7Yjf6LttpyIaAJbfQeAZ+3aI1HnihLIVaLlNZ8ShHbqIRJKRjYywX233iMflZg2E2VeSVfUav1QgtjI5vq9K6is0mVCWOVb5mu06CISGdttWdnRcag2owTIkR/KXyWett+jc9E9J9ExZOLkrB7ssaj2pgT5Po/a7+1Z/0auT3/MauGCEnirv77sqO1GwvTIJ2XT14GqR+VjJN63NhWRaF+dzwzlZ5Smuvatz92+rFtelKcq56z4u0PVd/jtoz5V9djtrwE+k85FcDSNek62Au7u4NG/FxjNs35fn/Gj53wvcVbp1LsGvy/zwb57iGxEnO2wsnctb8oyT9MyTcuyTIs55qiWVYuo3gplrcif6fXs+6FvYBoAAAAAAAA+AATuAAAAAAAJ8zz92UQLiua7bJ5JTsjIbD5Nls/mrdLBGa5UIPpJ4qxV2P3ZZLY6+yq9F6Xb7X4KcnHb1ESzt6G2+/R2mjKisnWUkSvk6rIBXo8rxHKRCLTKG4nrKp9GotdWQvjoe7TtSH0pkW7kv4+iXInSuwJFJWjOBNSZQN8LbVU6L5q1xxOJ1UcErZGIOhL8RnUU5YsiTkd140W5/jwqAbJC2bD7MqGwLU999+Wo85qJoqtrPytDXYeZQL7TtiJxeOa/akdRWXZftAhALVjwx+fbjvLRL4aw+T1KNO+/20UQKn/UB0SCdSWIz+ot6m/WbZVwO6urNX1Flt/6kQnfu/eZikzQn20fXXBQlQcAV3H0IlvMP/vs7Z/Do/cH6n1A9Oxv3xNE7wGisqLndP/eYnb7riY6Ls/Zsj+007Rjm+8vWUuI3hT5lqz2Zy0leys0TzMvbAAAAAAAAD4YBO4AAAAAAAn/5//8d5mmaZFTi24Gxk/I+KlJxSI+lzM38zTN87x+qFJ/MPeaA4smmjP8VKCaJPafVRlq2k9NI2YT3FmZyjeVZv2e1UPXTrX9EXAdwXPyyC4+Ei9H2zoRfRWZWDASj15BJtQ+Erl2RMxvxaKdcxqJGSNBuc3XWVighNFeiFoJkKu2kPniBbCRaNn62zm2SAzq7fjtlRhZHVMkLlfHmX32dd1ti8p3nyZaaKAEyP6zqsOqjqOFBdn3SLjtBdFVf1Jd05moulv/1peOyL8Sekdp13T2b9ffyv9skUUkmO/YyOxm26LFDWq/WmjQvUdkbSjry7N8V9PpM23ajl/q/B4ZVzyqDgBem0z664mkvl4sbm123i5FeSN70fuG6L2Fsjkn23056j2H8mHNU3VYPo16LzKCOg5v+5251ZtvbdWbHfW2a3b7/d/qatn4ME9/I68BAAAAAADg/UHgDgAAAACQ8H/9r//vv9lGcLesszJzPYV26XTYEk09wePo1rtvGdnE7/pXTf91ylATwdGEsbKtJoTnqTe5XPk5ekxX84jysglxgD2VYHeafldUVgkUMwF8V6jXEUVGZd2Djmg1E5crlAC1ikasxMj2sxISV6L3LBKzTVtFbVbbOqJ6m2fkfGYCze6Ci45gNyujI8JetynRfiTUzupB2aqOMTqnWT1V12pHPL5u88epFk9k+SM7yl8leva2VVur6jAS8Xfav1+AUIn8bT1F50kdz2h/qPJFCxiyfsn75veNXINRv1oJ7tVCgCvuD9Fil3sQ1XHn+l05MzZArP6JvMtJf/bj6IjFM/xzuX+2P9IpdfKsZSzm3+Q+R+80OjJln96nsWV4SXRU/iTS2HTP3laekJ8qXtrLBjpvP9R+JXwPXLn9QeAOAAAAAADw0SBwBwAAAABIWJbp7zwtf6Ypn14bmULrxq3q7GPu7l5ktX600tUZ97ZGJo/X9Ovkt883Mgmu/OhMJFcTz1U9XtGAOzZGxAWjtv2k/Gj+I3Dhex4lgL6aM0Kz3z7mSqTq6QrAq+2VaDRL31lQEIkPO2LkETLhfCZGtfsiwWzkTzdCs6I6/k7kYy9Kzuq6I57PxKiqzjJRfieqdVa3mY+RiNmTLVboiKMrIbvP7/d32n4kUo8iSkfpo7YYnftM9B6V633y9ZsJ2bOFCqqMaBGJJ/PfXkfK19G+T5WbnXffptRxKH+ic58RLSrpCP39cXl7R7hS9H3kXpEtGngGQfqZ+v3tscoZXtn3Le9yIM9+HNnzd/Ysbz933xBVfnghubI7u7R2e/YuQPnm89qyVXpF1tmN1F2303z29vRA1H0pSBbVWudNV/VmKzI6T9M0z/MT3A0BAAAAAADgt0DgDgAAAACQ8DOxbWa4NzMrVoTQsTftpxszA0dlue/LoyYiO5Oo0T67zdpZpwTt9o4o3H63Nkb88yJsP7FtP6sWqgTwlS/RRLrfPyIiXz+PTpjbdOEVmOQ5muZe7ZUJec8zCMBGOevzsx7ziJA9E7FXguMsGnS0P6uzKrr0leLwrvDVp89EziPRkyPbmYg2ExH7/ZHwNfpsha3eH5teibAjQXwmRo/8ikS32XFb3yo6Uadt3WXiciX4VvYzgbcX/at03UUTPm90XF4Ybdtd1Y59nVQLBlR9HBGJZ2L5CnVsyhd7Hdvr2h6H31f1RdH1oq4xfz1kiwz88R0Rt/tys3amfMja8FWi5KOi/TNi/yr/IwTX0Xk+yrOOVTq8su+vyz0rfVRAPYp6c5NJgjM/1HNyRxasntkjX/w7gKhcb8+nUTYrvzI6Zas8nfo56tObM2+/qJpZa7/zNqpbsz82XAaVf+EFCAAAAAAAwEeDwB0AAAAAIGFZpr/L4sbNbi7vyJTlke2z2sA0z4PIpvCmKZyGK3/IWU1a23z+ry9f2com1pdpPwFsG5ItR03S+/J9OZVwYHGflQ3vpyqrU0ZFdXydsu6RFuD5iES+CiW2HbE/KhzN9nfLVOmvjFibRU1W27zAVe3z9kcWFmTpoujSqx9RvkhIqwSpVYRoL8BVYlhfphURq2NQQuOOqNfb9yJk5bPNo47R+1YtxlDHqXxSRKLprJ4zfFvzwvVqQYNtF9kiA3/ObLqoHUR1kYmmzwp3rS/ZAonsOskE3COoa8vbjdp+hL9uonOm+qpKYN8Rpau+NKub6Fqs7I740CE7F95mtw0+Qtw+TeeuiSM86rjgVfitBqHK7VwM6tlz9wbH/K1s+vcLVT61PTqWqG7XfUvwfd3my5pFOu/TkfM58twP1zHnz1XT/k2NSrO12CBrmtt0/7omAQAAAAAA4P1A4A4AAAAAkLEsf6aRcfMqqiiSyf3ZnOP6xwpU7IaP4bcmMr3YOhJfR4Jtv706b4v7a/NF4m//N7K5pulMtKtJ+UwA4Cflla3MtvdPlRVtz4jO1xk+7dqDe/NsIq9KgHdEBFeJsCMR99G6qcSFkdi0EkZW/lR1E4mwvX8du0qoGwmiO/sq4Wck4lVCbS9m9ec3EgHbNP6cdATU2XF50XQkoo6IroVOPdrjUuJoJTqvyq78zXxQdaAE/P6YsvOmyspE+EpA7UX4SpzeEWp7sbUSx/vPkXhfiblVOcqOavv+c5XW24zKjRZtVKLvTp8WtWslfB8Rl6eCuqDu1SIJlXdkX1TX3etL1X3UZx+5v0X2Xo2szQJch2pY1TOyesauGqh6vs0u6uhZ2ZabvWPwPmXvJSJbWTr1rJ+lVftV2i72WLwP675Op3n0oerJHsYezHzx8Vdnf9f/R+PcaZrmZ3tQBgAAAAAAgIeCwB0AAAAAIONHSRHs9rtM8tGpvlDOy1zOLzG7v+tnP6lsiabx1hYRTRiHZ3/SE97KHzVJvrg0thy/308a+wnmbJ/33+ez6bzf/ni6qDKyelQcubg6E/XqPME7cmX//EiRV8fvSqTYtTlyXJGA76iwV4k6IwGvLz8rsxMhuIPyay3DCyx9mV686330eZXI2IssKzGtt+X9idKq8lQZNo0Xs1bi/kg877dVYv2ISOydpYuuIVVnkZg9O5ZIhB61+4hOPWTXS9YWlR2fVgnmozYdtcuobHXOM7G6WmCgFkBUAvmOADvL76muXVum3abaQNYX+GOtjiGqv6gfjfr37Pr26aJ+MrJ/hEzQf4Xt7Ls6B+rzKM/yPImgHR7DkQY/m3+ZnaPPeVG66D1BN79/Bo+eixexv2NX+WffP/h3CMqOr9PR8xO9k8jq9Ah0UD8EVZG9sRrG32eT0/kktzAAAAAAAAD4JRC4AwAAAABkLMvfaZ7+TPNym1SxIheZJ/hcFTWQ/FlECp+Hn+AdOWs2rfqr7IzYjiahvQ1VlprQz8pa82T+RYKAMxPHNu/IRZBNuo/SscMF+im8qlCrK1jMBMlH7kNVfXVtjpYdCUOr9P54z4opO+LVKsJyN/JwJh5X25QgVQlhlU9rPtVelJjTH0sWmViJWCMR7uhiCv85iiyt6siLbKM2NtLmI+Fu5FckFPc+2nTVIoOz4lolDPaLC6JzVV0DaqFCtIhA5bP4/JGYOWoDdp9tf5U/2T4v4FbnImovytduH5AtJqlE8NliiqzOM7rpOjaifd22fEV5o+mzc3CmjFcdr8CrkTW0Z2mEkUC9/SbmDj5E270o3ZafPVd7H70o3L+XqN4F2PSZxNnamM12b+ss/l3KUXhmn6bppxoXW59qTDTpVqDOQrdmO2fw29a//y7L36ZZAAAAAAAAeDMQuAMAAAAAJCzT9Gee5nlamtNni/sYCdXGfHDfv6ee5vl55onfkmji9KxIe5r2LUBNKDfDWYWfs0loZVdN9vtpzK5oIUqbie7VRHyUfxQ/kd/hFQQaANeTieAy0d3V4rlKAHjWxihXifO9zW4+L6z1YtjMZiSStcJevz0rvxPB2m7PRPuqXHt83ldbfiVqrxYlVAsDImF0JoRWtpRtv6ihU/+q7I64239WCxeq+qwWe2R5lGBZlZ8JmyuxbnQ8yudqQUm0ICAS+/t2qnxUCyGiNhMtDIkE46pNKEF+VMdKmJ8tMrBp1EKBTv9c9e9nBePVfax7D7k63dH0AK9D97nzkRwVrt/zQo3E396POUkb1Wf13kDZid53ZKL3KH+n3h7dCXbepcBXLS0/n/3Zz2rrrlfPPE3LfCj0PwAAAAAAALwJCNwBAAAAABLmI4q1h067MCl3LdG82ZUn1YvGozQqfZVHCcUjm9F+1aZ8+Z2pztn9tRPl1l8/2d4RoleT6JFY4KrzqOxwLcJrcug2d6f7XEc0fdTeFfkznzplVWJsm2ZEhFnZjHzIRPI+rUJFCVdi2UicrXzKfB4VzmbRpdX5O1rnVTtR4mYl4o0WJ6j6zMiEynbxwGqrsyjC+6l8UOcpO+eZqD9bfOAXBCgxuz+Wqp2rduxtVaLpaiGHyuOPy/sV5VFl2DasxPRRPSjb2QKA7PxXixOqBSLZIofInyh9dt/oiPmfiapeFIjo4bm4d4PsSm/9s3LnubNbvrelbCtxefRuwNuq3lGoY1PpPCqff25Wz9Fqmzr+6Pju2fm+QMf+TMxf52f9zUr7lia6OqqWHRY17t00TdP050vKwJ0NAAAAAADgQ0HgDgAAAACQsvxnmqe/diomnZRpzticmZlpegKH8NN4mej7LHay15brhd8+T8eWirlVlWvzTpOuhyNtLjoWW5aa3Pd+TlM8OX6Pa2HUJtfjPXkFAdpvcEW9XCHovYozYvur20gmVp2mWFDrRbiRzciOEoOOium9QNYLTyNxtY/C3BWBds5BFM06E9yr+lP1EwnZfXRpW0Z0XJnoOhMIRzYrIXj3XNn9/thUmUoA7usqa1+RX0psbstUdjri40xkruoiq+9ogYW3qY5BHbtNn51bdbxeeB4dv7KZtcOsPI+vs+i8V74pX6vFEWs6m95uU2msj6rM7Lu6NqL99xpXZAJ+9b3jR7aAoiob4Dm4qnFGAyD7/NqV5B5NE5VvjzF6rrfPtzatz+u3Rdi0Pv08Tbvnbb/f24nsq3cH6l2B/a7eKXjbCv+cH+3rbK/Kgi/Grs8qdbb/xJn4Oy0LegYAAAAAAIAPhQdCAAAAAICUeTdbuJuUGZ2zOzrv+rNvNjZQMty4R11cORkaiba932rS2362+dTEsZ9IX8Q2VaYvV9Xn4v7Z8me3z9uqJqTV5Hw1qR1NxCuBQcSRCxUeDZFINe9WL53IwtOkBYqVaLlDN1pz5l8kVB4VHlbRlr1dJSrNxJyRiDwToapyVT5Vvs3no0srm1E060is3q0v5XslNlZi8up8ZkLlTFyu0me2fb5IFO79j2yO7OsI/rO6Vos77OIK+10JoJUdu61Tf1Wb6fRJR4Ti0cKO6rqqylHXbmS362cl2FaC/m76rNysTXbyRT74+r76PppdD/Z7tjikaxfgNTjSeDvi52y/yh+JwI+Kpkfy+OfdCP98rZ65p8Z29RwbvQeI/FD5IyF/Rkfs3rGR5Y+O9dG89ru5edZnXqZN9p2uff066e+yoGcAAAAAAAD4VP79tgMAAAAAAM/Ml+BgnuZ5mebFzbOo+UmzbZ0g2hvNCqz3Ldaq1Ut/PPeaML3KZjTRvrjPkbBc5VG21OS1nwD3Yns1Ua3yK98iO75cn6dTnrKRTWyrPJFd60u2PSsn2wYAlkpIOCI0zCIsK+FmR4Cp7HXSdP1WUaXVZyUAz8r0wu9K2GoFxJWANBOLKuG0tRUJ/LNzUYmiM+F9Ftk5EyBX+bqCalVOJi6PRMCq3qr2pc6nP/fqvEe2lE+RzyqvbwNZPXevRVVv2TmOFj6MLnZR4nprd91eicwz+6rf8j53jjtrWyp/dTxnhf/V9qwMX59HFx9lPtxD3D5CduxXHePV3LPOfvt8wD159DNS9iytnvv8c7bKe0bsXj1TZu8Aqud+W06ULvreye/Lq47D2znynmURn1+lc3gVPxMufK3Rab3yVdBuTLdMf3jVAgAAAAAA8NGw4hkAAAAAIGFZpn/TtPxZpnk/OaP0s9P0M0mzm7TZGdf75dyNFaGsU0LzG0ygPRwl0o4ma6P8Hbr21ATu+tn+6+aZp/0xqu+Zj36C2n6uJpkz3yK8f1Xd2fTquKJzlM3WjmzvbuvCdQzvSyZK9NGrrxC2KdF3JmAe4Ug07W5amycShnfsZILySrzqhbxK/NqJLu2FuZHgPTs+lT5qP51o6N12ENmJBMuZuFiJ9DuR1D2RyNn7s56fSHjdEVtnvvp9nXaanRPPak+1M7t/pA6jNleVFR1f1l9Zm5Vfyp9oAYhqY90+ofIhOpfW3shxjJRry1D4+uwushjxqdMfHy1rNG/W1z0T9/TtmY8bHsnIc3mUP7KVPSt2LtrML78vs7f6lSh6ZWR2tV2VH73v8Ha8LSVHVu8EFMqf6F3GUVA434+vczT//N8NVevLZMYJpdViu2quO2buEQAAAAAAAB8OAncAAAAAgJw/s1RFTHq+Tk3QjGh3oyRWVIMg9iDrpG2n/rKT2N129Dx1Bd5qwj6z5Se2ra2qfH9cti7t98xn+zc7D5Eg3/sXTbcqfzM7v012HPBOHBXLvSuZwPSRdMWIlbg5iyDt03fLiLadxftWiSuzY++Us+aJ6qjK54n89u0pigjsBeCRCD8Tl1fHUh2bEpV3yNqdX1hw9DxlZart0cIHLyTPhPQVmRDdlqnSZ/Vh20zk45ou88Vvr67brK35bZnIW10Dmc1s8YJPq8ronLPOsY/0i5nd7FwcWUB1xaKrK0X4nX0Az8nZwcsVjd4+U2bPyuo59QiZnLel4jXplRDdEj0vq2NoyYyFXfXsfPJF1yHOnhdl61nsPD/L7sM3823z4dqI1kXo73+naUHPAAAAAAAA8KHwQAgAAAAAUCAnbKq50sxYFBhrwNwyNEkKX4xOilbCY2XviHh+BDWprCaf7WygEqFHvtspyiht5P9om4xE8ZmPqvyszv2Ua2dRwDMw4hti+FfhlSPPHRXXdY75TL2cibBryx+Jbm3zZTaiCOqdqNZd8XMVvdqmi6JBZ5HMlc1ImFrVU1RH0UKATIgbnbNqkUGUphIvK9Hw0Xbjyx0Vefto38qGj34dHUvkcySUtp8jcXkkJleCd9Uezop8q/Oi2rA/jmpxgmovmUi+Q7RQIWub0fWRicf9QpBqYYZaDNPxqeLM4qaOSP/oQpKr7tOVHXWOsjp55fEDfCpHn7OiZ9uI7Jm2W161rSMe93775/HJpYtE25HAfH1uVs/43s9KuG7z+W2Z/WnaH2/3eb3artKo4zn7/H5VZ/rGnXJySudg/2grWDPt7nnR66R5muY/898FPQMAAAAAAMDHwgMhAAAAAEDB8vN/jsb82iaJn0dUwpO2Q3Bf/MTvkUqPGohvCKP2Or7YRpblU2JyNdHuy1/cdj8Zbsv2tn1eu135o/z15Vhf1aS93x/ZvBouVngP7iGuOyoEtZyNsFuVHwlMO/mysjvC404U7q7QVAlzM19VNPQ1rRcp2+0d276cSsReLQyweZX41ovCI0YjjNt9UTleFKz2qwUQvhy7v6KzGCBbYBGd98hmJNTt1nl0LWQieZVOpbXnRdXDSD8Q0V18kdny7cD6rdL6c+XbYnS9R+27u3Ag8/sIVTsa9cfus+d95ay/VxKdo2fxD+C5yDqGrkK2InoOzV4Crc+00bOu/afKsM/E01SXr9Kqzz7dyDsEVVb2PK2ew0fLiso9+s4Ehvk5XXP46mvefZBftVnF3GglpunO82wvIAAAAAAAAPgwELgDAAAAAKQs/9aZFTl5k2mGJydUODz7s+fHFFM8d+bMhOrZk5NN0PsJdT+ZPU31ZHZkf27uj7YpkXk2ia98qspWx1vNeSrxgff9KL95IXb8p6OA56MSgj4DSnxYiSQjYeWRciNhdFa29SErv1P3kdDY71/LiETGVxDVaSYMt3my6NuqHCUs74jso7L8PrUAwfuv7Kr2VYnj1XlRfvnzmaGE/CpydlRnkfhYCf6zhSaV0LmzvVpcourXH1e3P8sWOXT8Vuc+uja8EL7KN0q3LR+xqYiuSfs5W6hx5f3mqn4N4LO44iKMbPjtoxdp9Iyp7PhnXLV9/e5fBlW2FdkLJS+gr7Z7O6relMJZ2TuiN67SV8/oT/7g8ML494vqbUx0Zu56S1zv65x7AAAAAACAjwaBOwAAAABAwmwkDMv6f03R+pAIvZoV2pVpZp7gYrwI+6rJtGiKMNrv03hffH61vzNBbCfyK1G8x06Ae2FANvW5prF5IzGA8jnani0K8Mdo86l6HTnvVZm/zbP4AXCMLOL0SB7PEcHjEeF4N1J0ZqfyVYmDbZmRD5lvnejhViibRePuogTAUT1HEagj8bXfVkX0zs5BJjCvImVbMbcX5Wbi3eoYParurS+Z8DwS+dt06q/aXy2EUPk7kdf996gejiwwqcTf3UUsqq6jduTtZ377+lQLAWy9HFkIoMrzn6M0I/a6PnQXp9jv3Qj1GUcXCFU2EcnDe5JdHGcbvbLdEUyP5M18XJ9R1TOvEr1HYnGfLvMve38Q+bqYfxHRs3P2fqJb11H+o4x2uHSuw/hmMOdvnqqWK8le41SvX+Zpmv47/ZkW9AwAAAAAAACfCg+EAAAAAAAZP5rYfOpmFl+W9XM2fzmiIz6QDY5w79rNJqOPTshm+aKJ9WnaT5Lbifssj5/Y92n9LKWbMZVprL1MMB5NnnfE+cqfyD8mxwGegUicWUX6jaJiHxEVRoLgUZHjlRHNFVXE7kykmkX1ztJUvvhtmdjXbotE39aO3e/rthNF3frZWVCgIpT7PJ22Wh2fL1PZqsTxlU/Khi/PC9Mzn6pI5D5NZ3GC2p4JxY8sJKnSR+2gk8765dtc1Bep+q/K82V02/JRoXq2mKHLWYF4t8zq+hop62ruZRfgd7nn85N6RrTPbZW4PhNv2+/RyxqVXgnFs+dMZdc/W2f5sn1CpbyzqwTzWZkdsXzmV5WvWlBwBDrXwxy8fFtvsTq27euofSn/WZYFPQMAAAAAAMCHwgMhAAAAAEDCPH/LPKIgV9/sRAodfW9FJnjaqOjhOYkmeDsC7BGsKN1uywTfkW9euK786jbm6Hh9WdlEeOZ7JWKotncn1K++yLho4fM4I+o+IgKsxKYro5HFI7sjEeavEjUeEdxnItiqrKxcJZJWwviRsithsRI0V/a7UdArcXuWLto30nbW9P58nVlgES0IUIsDojI6ouwMX2Z0DtV56pzb6JrotKWu/z796KKZ6lhGF/Mc7U9GbZ5ZnHPFop7ROu5Ev/8Nsl9FAIAryV7CVM/iXrheidwjO5FSt9sB+OdRJSOu3i9Ez/SRQF7luSdXdIa/2Km/HcspkfthonUZq+Flmf7MfxZONQAAAAAAwOeCwB0AAAAAIOdPKYRQc4DdyZciMNdu948QaB4rB36BsxO2VZS5Kn1UfjRRH03A+4l+v2/UNzlr6fYpwX1kQ+3r1n0lhO8sSljppuGihc/jWcV8XdFmRzg+TbHItuKI4FJFNVf77iGOXcvriqJHyhw5HyOC6yq6eXUOI8H66CIJL+TuLLiIRLEjYtkjizPUgoJIlO63dSKPV+J+nyc73/Y8dq7r0ajmPp3926nbziKMI4tWOv51zkVla01/dV/VLf/IApFo/xX3o98UyZ8l+zUGgN/l7MW5PgNGou5u2f75T10o0XOxf6ZVtv2+SGw+u/32GVeJ5335Nu08Tbtn8OyYfJ7sZVdU168kkocvqsHTcatzJ3+4n5sVAAAAAADAp4PAHQAAAAAg5WsyRc61HJ6gydOk07Hzbc88z8znvQ3VhPMRe/av/xyhJvej/F6MvuaZ3f5piifklZ8+vbflfYtEAUfIhPSjdhSRrSs6EwDokAlIswjfXbwIOLPbLc+Kro8I2TPbvgyFEot2IpSvwuNREXh3XxSdO4vg3/UhE1WrerDntBLXjp6LLAJ5ZK8Sy3u7XiCelasi9le+dQTn3ePoXA8jZDY6Aunq+Dvne03fPYasXv3560Sx75TnF2SM+HmUI+fUXn+PWMSzph3x7Td5Bh/gXXiVxqSeK6PnV5vGp+uUs9qr7Phn4Wy/8iF6hlb5rfDf71f5rE9euK/KzGydBWHzI1Ei9PQMiLQq/U8Lyl7bqOayXWdBYwAAAAAAAPhgELgDAAAAACTMSpdbzfGtaTNtrJ9fXNyucj5wneF5lYnld+WqebbqPKqJ+cqeF5rbhhyVEU3ud8qthAPeL2/TX2Bq8txeLJ36SC60nV+rndGZV+XD1fOvzOcCXMVo1OKRtEciIqu/Kp0Szl/tW4X3oRvZPhN8Z3XdEWmv9q0Y9WiEYhVRvRK7Wx/s3/WzF277aOORrUpg78vpRv5Wx7d+jojaYlWW3afE3ioSfHYc/jrwtlW+rrg8smPTqDKyyOJV9HHva8fHrs3Kp66Ns/1GtQDlNwTw97J9r2jo94yyjtj9VXmWEzfSONVz2Ii9KL/flj3LRc+O2TNc9AwYpfO+qXyd8xfZs5+r59Pq/Ni6smmVPZu2cy47ZXZ4lrb+uWzOwOzOnh8X+fRnC7VrM5bp37RMf68wDwAAAAAAAK8HAncAAAAAgJw/m4kcNQ/oBfAd1smaedLzfNWc5rQw3fcUXHkWMltKmH3F5HAkfPeT3CqNb/DZSo9OuZWoYRb/MpTA3h+XmtT3efwxVhf6kTaBgB0+j3uK9kaJRKMd4ekRkeijRIUj5aio81dHJY4iwUei4pGo05XguYuKxO7LqMTTRyLtq2j3USTw7gKDiExQ3qm3TGRt6yiLYD8SNT3zKaqzyHZlMzrnqj1k52d0MchqT4nps/Zz5hofITunZ7i6LxxZWNBhpG9DLA6P44kGUClHLorsmTV6phyxke3P0nXqPBLBq+fhjljcPr9GIvxMtG9tq2NSz/jZM3YlfO9wmQQarsSN/7NTdOnZ8803G+9N059lWV6l8wMAAAAAAICLQeAOAAAAAJCwLMu/ny/ZHKXV305iv960zV/hBT+NLPCbjE74jtJpNJUIXQm/I9F7V1SfTaR3hAlqwj+ayFeT5Kq87ioSTyRIyPLe+8pEFADvwTOJASvRaCSgPXIMV0eQ72BFs6ORuo+WV4mSKzKBdCdq9vrd71d5lO2RqO0qXSSCH4kAn5WnfI988emVYLpTfiQc7l4fle2u6FyVM+K/TdcVbvv2oKLoH0EJ4yt7o4sSruxPVPT1R5Zf8Y5C83c7HnhXIvGz/dzpDK7oMCKFbvRceUQQn4m9s2dO+4wdPRf7Z3HvY/ZMngn+O8/hlQB9NP0ZRtsCb8fOMs/fZ/Pse0f1KsnvywzrMezyVKujAQAAAAAA4KEgcAcAAAAASNhNa67ziV5725hr2c3vRIG4XOKdaTXrBE/IkQnfK0XxdvLbt+SonGqSX0V5y+xWEeCUPbtaxIvdK/GEmjHNZlgrzp6LriBixA7XPoDnKr1DJLK9p8BQlVmJNCOBa0dYPiKg7pR9pBxvJ0o74s8qOM4E293zmEUB70aQj+xW0d+P+HeFna4gXnGkjqNI6ZmPWf6IKqJ3Fs3el1+12e41e6U+q3s93pOR89b9ZYizv8AAAPeiEoM/ksgX+8LG0hF4Z2VVql2/3YvSlTA9E4xX6t/s+duXdeZZMrIzku8IozcvVgOdYZ6+7+dqfBNlSsa782r0KLvLd+YtCAAAAAAAwAeDwB0AAAAAIGXe/g5upd11856z3TZU7N5ktB+egTMT5paOKH40Ap6a4I8E6pkdFXGumuDv2s3E9l7wnh17dR66goTIVkVHSBH5kdE5T1eAMABeAy8W7UTb7tARll8tFr0iCvwRG0fq6crjHxHFjtrp7MvSrGLnKyJTK/G3r0cVCduLss/We1Rmhq+H7JxdJVo+0razyP0jizrUeY/OWeVPVY7yr9PefH/3mxHLO/Wq6u2e/p6JpH9kn0+HwB7eH/Vc+VtUz3jdC7JKlz1Te5SQ3D/rdp5nrUhdieCVHfVMGz1jZ74pOs/0UR46xleg8xZqR3Jqd7Y6xqMm/CWY/7ugZwAAAAAAAPhYeCAEAAAAAMiYp38/MzdZkDD1d/oWWlylcd37Bht+s0KiyWzPI320AnHvw2z2qYlzuy1qxF5w7stSwnQfvW50Qjw6Jl/mJNJEYoJINKBsRNsiW1Gao+3g3u2HTgVegyzi95ko5JU48V7CzHtHTh+NNp3ZrzgTuTkTYJ8VUB8Vnmbi3KP1oQTNXSFwJoa3+XxE8kpEHS0SOSqg9v75SPuqLO9Llsbut8ebCdEzIXyFXWjQrcvIh2j7SKT89XsVdT4r8zfo/rLDo0X7ZxfKrOmu9PuZzhu8E1c00uz5bcS+TX/FixH/nKnKG0U9u/rn2uh5UQnJkxdHO7LnVlV32TNt9bybvb/I7HShQ3sJLrqHSTPV658o3e1S+jctC3oGAAAAAACAD4UHQgAAAACAnL9bxfoU619V8KsqOFeHbN4UDM9SIZkfZ8XRq43ITseGasRVQ/b7F/cv86FaGeIjz63burOgym4mblB+VccMABW/Jca7l1D72Xg2n5WINmsDI9GvK9FzZP9IhO1MpOztHYno3hHOjixA8H55wfhI2Upo7sXiFWva7nF2opePCuyVkN9vV/s75V3Rrx2JXG/zev+y7yO2H0HHP58evniFukCE/4lUz7IjjUI9f50hegaNng2jlzrq+dbbWu2pf+rZWB2fqkv1XByJ0VUaX773O6Lb4XRfSp05n6PtCE4jFk+GnLk3Va+F1s+uuc5/pmme5he4KwIAAAAAAMC9QOAOAAAAAJCz3GZ8zFYfxGsKvl8hTI/m+Jj3e0Gyk3ZE/N4Vk9u0Pk8k7vYC9MwHnyaa4Pd21AR8p2HbcryvvuxoQr8TPqyKnHcPjthlvhd+n3cQ4x09hjMiv0cLBEfLG4lSXYmRs8jdNvr21ZGQ17KtiDuLfD0qsu9Enb6i7a1+RYLujhBcifYrUfdIm1FR1M8IvCsbVpCfCfOVT36BgTruqyJ7V3lGFlqMlHeETlR4u039qoD9fvYXAO6RHq7hFe774Dl7sRzJf+QZ9ygjL02iZ2D73T5bKltKhK6eU/3z6BFxf/bSafXBl5E994+WP0K0eKCb92jnws3g7hx9ndWx6S83s2/+utFz1wEAAAAAAPhQELgDAAAAACTM07zX6SoNcGxAbzsz52fLZg7vybnqBHXCXVXlqghv3oba5xu/F5P7iHFqon/9HvmViduVgN3bzybr7yVI/82LT0UGvMIOwHtTRW8+KpK8p7D5qE9XiU2rOsvSjdishLxRPUTi2pFy/edRUXEn7ajgO4ugfnQRQHT8qixrvxM9vxJFj9ZnVkdZ+4ui7vvtI1HzozLVdt+fjLTPDkp0PyqaP9InZduiuj8jfr5a1I8AHuA3GVHEZhfzaKeSCdgjm9GzprJdPZ/7Z9/o+dp/9t/n4LMq35aXPcd7f490kiN5HvXMybPtIX6aysmbZZU9e0Wl2KwNWdSKDQAAAAAAAPgQELgDAAAAACQs0/KfaZpu84GV/tZvj8jmTTvid6Z3XoSRSfszqHBXk/hut1WT8tUMZPRZTZ53jtv7lfkXCQcq2xFXnxd1/J1t03TN8XShE4HPIRKajkTAjmweTdfZflQkeqXYtLL9CKIylbg2ig6v8vmo6NU5jaLPj3K14DYTxFf+jrSVrJ58NHgbWd37mPmr/LQ2IhG7T9tdBJAtJKgWhmR1N7pIoMNIpP8oMv2zRt2+ajGPortQBwAeiXqOyy7MMxdt9/nWlxc9r637I0G5F7ar5+Ps2d3a8Z/9c3dXlJ+hfBvNAy/NPE3ynB45zZ1XRmtTVms2/Nhqmqb5z5+/04yeAQAAAAAA4FPhgRAAAAAAIGc7Zt5EETJEc5Yqr0+TBQDz+b/zzGfnMOFCjoSqupqoYY5EafOT48qWmshXUeWmKZ6wr8guJjvBX0WwU3ZH9kXR9Bbxr7IXCRiOiAe46OE1GRUTVhGhR6mEpt2o2kfK7Ypjq+1X+DPCFfYjsfnVIlsvhvbfs7rOhMhZtPCsjXYE3JENX473daQcX9dR3VfHXZXTiZy++p+J1G2+I21kJGJ651cNOv1FFLV9lLPX28giB5/nil+yOMOZPuHR+QBAoZ6bsovMP0N6Gyq9fxbr+BLZ9UJ0b9Oqb9Wzb/f5syOetyL16Dk9s6X2dTryI5199qx/hmd4n/LB/IyH1MA2yZc1b/vZi9nXXbPZZC81t25jnqZpXqaZdgAAAAAAAPC5IHAHAAAAAMjR0zbztJ+LrHJlelYlhvfb7eQQoownIjsZ3dULV0/qVmUqoXjXrpp4jwTiSogerfLw2LqrRAdKnFCJJSKxg60bm8bPuNptIxdkVwzRmTHu5rkCOh04x6iYsCPCvZKO7Y5Q+B7cQ2h+L6pyqjrrREfPIrJ3y6nKtXasaFpFEo+2VaJ6b1/5n/ll//rPUVT67gKPqD4jf+2+SmR+5roZid6ekUU4V/Y7v/zgI9hXXBFZvbOQI9pu/T3zSxbejyMgNge4F1dfXJVge/08QleM7Z+/uvbUs6YSavvnOi9kt+J2ZaN6RvNpsmfk6hmz2u9tqefa7Jle5ffbr2xb3AR+m/nn/xzqPWfnUq/WXPgmGb32Wb/OM/J2AAAAAACADwaBOwAAAABAwkZDlc2oRPOVnhGtcymSZ4rn+VET1ZPYdtWk7hkhfCWQtrbVbOQZMb+f2LeT7tWqkKpML05QfmSztGpW16YdXSRwpYijIz54JIgTnpnfiMr7zlwloD5T1r0jvWf2uzYjwW03wvbZY1c2M3tZNG4vAvZpr4gknYmeM98zYfPo4o1O2qi+bJnRebZR/KPjHWkfkXhbLYQYjXDu/cryXbGIZ5SuoP1MZPmMkTru7u+U+ch8AGCpXlSs+6rnEv8c5sXW3efS6DnNM2rPP+dVdr19lb77zNy5OYwIzdWxL+7vSHmjHOl8fR6eMe/K8n0FVq97RpvmSjR+ncx4JXn18b1p+e9/aQcAAAAAAACfCgJ3AAAAAICEZZr+Y79sPqsoQ9HkTyfKkaUKAgYvSDbRfSTvGaLZy3mKG193ttI39ui4R4QJfsbTR89TooJoxUkmULBpI4F99yI+K1zoUIn/r6QrzJ8mOqnnhAi5jxM4KsGnFe56UfCV5UXRwKvI16NUwvOjguGjkaRHo3B3o4ufich9hG6E9aN2OvYiwXL1qwqqjfmo7ms6H2k9ihh/ZnFG5q+Kuh/ZqcqJOBIZvpv/Cq4S2I9GgD/Sxs8sJDibD+B+PKJR3qsjGbXbff6y9juCd/scOFJGlDZLk4ne/b4on93mnzV92aqOs2d1lU5tz7apcq2fR9rTkXbezcPKpbvjm2hW5eqS8NvtNr8OJli38efPn+l//ud//v5f/+t//e05DQAAAAAAAO8GAncAAAAAgJxZfLrhNbaZbthv6xIF6EKp8eF0ReiKSEyQiQPW9CMrL9SEuBILVJPTq53KN/vXix3UfpU/+q5WsmRkx/RIccBv9BOIDeA5ueK22RGdRmLd9fPVt+8jovB7R6C/Spzetd0RKXth9VERvtp/LyF8Ji4/Y39E1B1FSFdleSHyEf+zsm25URR5lT/yNxLYR/ZG6LbJI/kzuos3no3RuniWiOzP4ge8Io9uPI/oBCIRevaS5Owi2tn9G/EtKsu+2Mme/2yazrOffz7Nni+jZ+vItv2+2u36VJXR2fcbPJs/r0t5JfrLVr1myNZVVK9ebDmiaS7T9Pe///0vAncAAAAAAIAPBYE7AAAAAEDCbt7FB96qUBM5aj7zAPMfFBWvz5lzeCSyWbe8zsS2WtWRheqqou5lKLH5+tf60A0v1rEfiS+unki/IkJdR/h/Ja8kfAC4lrMi0Uhg+wxkQs0rxNtqXxVB+2rOilHvHaW92z5U2izPFZHCVRTtKvL6mQUdI/VR7e8IykfsTdNjhc3RtaO2jS4A6di9R56zPEvfefU9AeB+3Lux2YXNI3miz5Uitrvw+Mjzb/Xc5Z8/o4XS9llXPbNGRDb9s7NSDkd1Wu3LOPni6hB0jo9n3n9cmt8HTIf7k9dW8zQttAkAAAAAAIDPBYE7AAAAAMAR/Fyin1/1c5fdCEfVXO4c7YDXpBv2qouaNO9MgGfl+gl6n1el767+iGxEgoWR+slEFuu+6hiU0N3+vUJAkC0K6FKdu6vpRAMEgBUlDO6kfTRXRHXvRGEeqY8RX0Yilx8V1t/z/FVi8Cyy+tFo9FcsMFDR0Tv1FAm0o2OJ7B/xv9teRhcSZHZG/Koi0avyn63veDbh9rP5s/IsQn2A80TPXP579HLDf1bPnpGqNnsxE/nmUc9+3p9ROs+Ac/A5UxJf1aF1juvIsV/hH53j44lWCd52zeoyjbLbtR0AAAAAAAAAJ0DgDgAAAACQsCzTfzazNna+dJ7285E2zew+dwJ2RfPCSjiSOQ4vSncGMDr7VWTtLF9VbpY/8mNEeN05Jh+xzgvRo4h2SiivjtfbUSKDLpFgo4pOmBH5fCb/GZitBpimWJR6hDPRrs9wJP8ZYaYt7zfqrZNeCbejNEf98PmruljbWSVuvyJiuy1vmupjGzn2Vcxf/WqAEnZnPl5Z/pquKt/7oj536+ZMxPusnGeLsH7Un7MLSABqaChb/LNKJizv0F0EbdPb5zK73dtSYvhIFJ6J2T2RHfWcGYnro+fJbFHAkQUDimx/5/hHnlfvKcaHeyPPcnd9g2qK/n2pKshfMq4JLd8f5q8BAB00AAAAAADAh4LAHQAAAAAgY57+mNmVLZl21rO43WqeUM3dWntM58APHTH6yqhIuzMDadNlk95+Rcho2Sp6XySOVytI1rwqAqDd748hE6T7/JlfFlVm5G9Edm5+g5GFFr/tK8D9iQSUV4lOrxLRK7riz6vE6FeLTUcikXfqsStOHhVAK9sj51XV3Wh9ZtHPlUC7I2wfqc/Il/UcKnte7O7r8Gg09e612Y3cPxJZvhL3d7d3ztPIgo4rf1XhjD/K3quJ1EcXn8Az8E4n6MgFo/JkdRI9M3Xyrnmi5wb7rJQ9y1Y+dPYpe5lf0bOnz+dtRS+K/LNyVC/q2TgT8Wf77wHPgC/Nkq0m/E7y83+ZnWJ/9ApFvJKZb5//LMuCngEAAAAAAOBD4YEQAAAAAKCDnXP0kYhUEC8/T2nSbOZ7OuJ4gFNkAvSowakIeV1xdXcliCqvI0rwE/pKRB8JyNUEvz82K4pX6Y5cpNHKlRGB+JEyPY8SNUSLEO5VHsDvclSwfSTq+KiI/ixnI5R3OCp2HbVhBbxXRA8/KlQ9K0SOfDkSMbwqP4sUP1JeJ5r3o6Ocqwj9XaH6FdfFVb/WcNU1eYWdK9pgxKuJ26dJ+/yKxwGvypGbVEeQfaY8oWAd+sWvqmz71z9/qUXGHXG8ei70+5VIPSPKUz2/quf6LK1PV9n3++BjOXOvOvKKQ72S2Xyd/y7L8veEVwAAAAAAAPDCIHAHAAAAAMhZxKeYZFLmZ1sU1CvS+Mr55RlpJ5wka6BZ9LVs0rsjYlfpqjKVjWpbJmJQYv3q4j1CJFzIZn1HhO9XiUKu4tFlIsCAHpkwF3KORMZ+RP0q8XlVbibeHsmntp8VXHcjiXciod+Le5XxKBFwRxjejcj/myLlK8u++lpFvB3DfQdeg+4C4Sr/+jl6dqk6iyis80j51TNiVa7fpsTjyq9MON897sy/Mwuu7efo2ZeO/GNRTaJaM19dmtUlWb7umX/+zDz7AwAAAAAAfCwI3AEAAAAAcuooQdGkThVAK0sfpTVlMb0DXxxtCZGofCRdVXY1Ad/J70Xf/rP1L4oKmB1nN9reiLjDl++3Zem7iwTOgHABPoujwuZH8E6ix7VeH1m/NhL71eUqcbmPlH41kf3OMd4rYvaIqP5o3fzmddAVtSuOtIffPNZ36m9ejWe67wDEdBcTr2Tq1DPPgFFaG/k8Kv+o0ta+cFGLsbsvb9TzaIdKSWxtV8/mo8+2AIGAvPO6ZmR/dHlEQT6+P8ydsgAAAAAAAOBtQeAOAAAAAJCxTP+RapAoaFelox3VCcv0y/f/mJSEabp2cnrUVifCepY2E5f7CXolZIjKry5ElSfa7/dl0edHIvRFNh8xcztyns6mA3hfrhCLWtHjK4pPX9FnS+b/vRdGKHG0j+ZuFw1E0dyrc3D2HHWPe57r9vxbEei9b5EP6znp/ELAmm7Ud3Uulb/34JkX+8CWV+9b4QrufYFeYb9Sp46Kuys7KoJ59vyVPWMdjZKuFl5Hz7RVPUQ+jSwi94vBrZ2OrSPp4X1ZNn+yJIf2R5dWdvmECQAAAAAAAOBTQOAOAAAAAJCRTbREQbZUcGkfzCwSu9u0ReAwpng+gTNn+WhkPBVx3E+YZ7OSKspeVp6dyK+EB0rA4PNFNuzFWK008Re5Eg7YPOrY1YWcrXLpcnYRwiPKBPgMuhGsu0LFEbHps0SN9j7fO8J5x4czVL6PCpqvrIuo3HuIlDvnUYnz7XblV3TNdOrpTAR91U6VfZ82E6OfqfeO2P5VeQZh9jP4cJZXbgNwFZ2Fu89KdRGqZzr1vFU9G1qBuU8/8GIljcZuP3tfVbnZ82AlgvfHkx2vt6lePB3hFdsbXEL0KmRy3zvrL/xrj8xm9WoGAAAAAAAAPh4E7gAAAAAACZuf6VX6Vj8HaYnmI6cpnqyJ5is3n2cmez6O0ROeibhHUbOOUYOvxOzr984EvJ8F9StH7LZMwGDLVeJ75be/UEdEGqpc/9lf5EcXI9xDgNANqUYnBOCJokTfQ6jYsWlFno8US76SMNNHHL/adxsVvCp/9WHE9pXpunQWAYykV3miNEcipitfRhYL2Cj6le1nEFb/tg/PcP0/gw8A1/FbF3V1Idn96tmz+3y0fldi9uolS6a4zRY9R89T2fOnepaM/FL+ZeL29bM/5s65j5TEmV8AEXNvrYXHr/8QZjd/fTqb13y+JVn+/fe///1XeAEAAAAAAABvCgJ3AAAAAICUZfsx0+RmwceEuWENchbdCN6U7oxilO9I+m4IrepCyBiJbh4J4r3Q3aYZifzn92Uhx3y5dp+alVWoGeOKM2HNnkBt9wMdGDw3Z4Whzyaq/A1/nq0OPFkU8Hv5voqyq4jnkQ92/73Fy1YAXonArxLYd38JoUuWtxOR/WjZZ8X3Xbx/Ubt6VPkA8Ex0numqfSudMM0j3ys7kXA9WojcLcM+H9pnvaic6IWPFaB7wXv2zN59zo5E/tF3FiDDnYheyajXJIro8lBl+HTz9p8ZczzJMkIAAAAAAAD4DRC4AwAAAAAkLNP0nzRYtCUL9pzpZVWAMICn4YyQXaXLhOydaOb2AsxWkWTlVNuiGdxIaB8J1jt1dIXA5Go1273UcXRu8NzcQxj6SVKMSnh7r3JG6IqQrxBYd4XHHYF3FXn8CI8U+VflXunHSN6r2uwjr3N/fI9eVPLsi1gAPhu/AHia9IsHu38K9l9BR9wdvSjpiL2jZ6/oOKOQ1NELnqxs/7lS80bPkHa/8ntksbbPq/KP5L0iHbwKX2MZ077UZeFf10QxBjIbIyw/g+plnlktDwAAAAAA8KkgcAcAAAAAyPkj5wczDW0WwCtDzWcG85zzNH2Wau7teeZzeaRBR8czEmXPf/eCBP+vsu8vJCWoHxE2RNs7Iv0jaTMfrhbAq1lrgPvxyNvZPctSYlkrBn2V2/aZCNbqexQx/SiV3Uhgrmwc3d/JO2rDR3LvRFM/w73bZhUp/bfIyvd13a2X3z6mEV6lH4LHQHt4B9SzSPS9WlHvF+wefbGRld3N50Xh/vmkKivzWT0LZkL1TgSDzJfIRsZI3SvVsfo8Uu5V6eBVWNRgJjvN6hVMtH5Evdes3rOaD9yqAAAAAAAAPhsE7gAAAAAAXSINbRTsudLOZsG9fBQkFfCLOcU34hlO5pXThv5iyYQC0QVU2bR2MqG4vXiUKN7bjy5CW45P0/G1K5DP0h698MMZ42bebud1Nc9wXcAjeKQ49J5lVZGVX0UEe9bPR0UGj4TfftsrCTi9yP1R3FtA3+XR5+roQodRP48c173q4hUX3cD9eJX70uN4xQq5+kLuiLMjAfWZhbHquSkSn6+fs/1ZOcrPbGGALzPyw9pfiZ6/1CLtrv+Vn0fhpvDRqOao1r0vwf6p8d2Wo96fTtNrdsMAAAAAAABwVxC4AwAAAAAkzNO8ncBRutfJbJum7cSM0siq/NtCtY51E8Xoj0gAj+cVJ4EzIfgVdpRNNQuqJvt9449mObMIddGsaifyXjRbqy7Iaka3W5+j5yOr96rMqi66dl+x3cMVIIZ8XbJzd+/zeqVgfsTXrNyjx9ytxyP2RyK1d+3/5nk/wiPEtr9RJ+q4qrIeUReImwFegSsu1HsuRO08m0TPXOqZTy0q9qgFx+qZ0C9urhY5+22Rj/6FTqTU9URpqrzVM7Tya0Q0r/yAj6fz+iN7nbJ+95e0txk1u2Xz8e+yLH87bgMAAAAAAMD7gcAdAAAAACDnz+znEj1+PlJ99/OQag4zC5S8m5dc0JjCQa6auD5iR4nZoyh3Np234VeU+G3h6pAEJQKILuZKyB6J37NORNWNL6MrYO+Q1bnyJxKYVGWfaW90cs/Gb4tPX6W8VxMOX3FeHxV5fLWt6jiq906U99Hys33zPA1HyfZp5vmadnTmXDxT1PEr6V4L2YKFK9r4VdHhf4NX8BHgGM/WuNXi3ZG8K52FviNEq/U727NnHrtf+V89SyrBu1q4rJ5BvSK3ej7yAvso3TTF59A/f0bnRJUT7fNC/isHZc92fcC1bBXlQ2sw7OWWpbWXnrr0/aX683H+syzoGQAAAAAAAD4VHggBAAAAABKWaflPmkBpYrMJG11IrjW126zwhgnGJ+DTopxd0ea8AKESWmfldvzJRBKjKOF5JWjIfLqaym633Eigf6Te6KdgjEdHFL5HeUdsvrpg9BGi9keVdxbvW8dXlWdZxkT7ozxL2+/wG9eHPZZHtrdnbtsroz6+ev8G8HtkC2Q7eav93WepMz5Ei4FVOf6zF8ZnkQeyFzNVXkUUblp9zsq3L4dGnhurOhrZF9kb7Zxf4AYFJ/huD0fW1VRxBtQrGf+qpyiTsQQAAAAAAMDngsAdAAAAAOAIaj7SblPzmv7z5NJUWl5fFrwpvzlzV5U90vCuOo4oCp6PmuejjCsBgp959dH7MiGBuuCjY4yi5vnVL51y7f6OUEX5qvZHnZTygw4H4F6skbqvjqL+zLyKn8/AaCT4I1wlor9nxPdXEH1/Kp1zyPkDeDRXR+3OIod38ts8nbJUZPZIXO7TRKJ0/9wVKXEzlG1vLwt97X3K0lTPc8pORlUGgzP4Jntf6QXq1boJ+/pDXSJZN7JEzgAAAAAAAMCngcAdAAAAACCjO5+ignKt2+1cqtXjZpND9jtzOh/GVYKEIw3nqknus4326MS9pVuP0WR/FOlPiSMiYb262JWgXs0O+1nge9GJHjiy6gYV2+Ogrt+BNVL3VbaenavE/NbeyqOO/yqh+aide4ndf7P9XX3OfL2M1tOa/lUXYfx2pHsAeBaU0Lsroq4u6pFV+ZHdVNFqUBHPjwrRvT2PF9b7RdSRX5NJq74rJe+ZjrNTjyujAvgXvfnBRZgI7hYfG8Dvi16Z+PegpojN5yxOwbqRpgkAAAAAAPDRIHAHAAAAAGixaP2p/buIf2o+Mwuc7POp+VSAFmcbTifaXLTPN/iOYN2LCqLZz8qWSuPFBJmwPKu3SIgefVZiCjVjHEVFtLYiQcTR85zNVB+x312Rc5X/n0glrgF4fu4thv0Nge/RMs/UxaeIitdfOPDbIny9jNbTmv4e9RsdxzMuVjjDqy4OAHheoojjfls1TqxCLa82VETyq7DPe77cdX/1rJC9YLGi9OhFSiSS7wjovQBe+afsZc+/92T03D3BTQSeg0ig7l9RZO82bfro1Yh/zePt/3ycu6vuAQAAAAAA4A1B4A4AAAAAkLFM/74+zHquNZuzzCZwlN7WzsfafdMkJouYfPws7jmXd5XtShjuP3uBQyWoj6LfdfJnInZ1MWbR+qLj9NH+vK/KrwxfN9Gql6zzyXz1dkb6lCv6n24ERoDXBaHn/blXVHPFav+siPqePFubO+vPlb9w8Gx8+nE9W1sFuC+PvuCPlhe9iFBp1L6s7NFnPptWPTdmYnklQK/UtQr/vKK+K1+VnZHtXS0vHSlcyXcbjppktcbGp1dpoktKveLZdEPLv//+d/kblAYAAAAAAABvDgJ3AAAAAICE2U/vVPO7fiInmwPNUBGSNvOfTGa+N5kg+2pGokIf8WMkqp39HkXRi4TxkQA+EkZM4rvPN4t81WoWH9XPokQMmaAi+h7NGEd+VUJ7X+cd/zrlZz5l9t9U9Xca+v1X410FrI8gE79G++4thn6F87ksjxEOd8u4R529wnlQRH6/6vGc5VOPGz6VKzrmSnU6KjzPFpt2nwej55UsTXfhcfQs5dP45zZP97kpoxLCZ+mrhceK0ZdGI/A8ARHz9qN6RRO9grHp7P7J7fd51HfpGRHcAQAAAAAAPhkE7gAAAAAACfPsJnk2O6e9XjXSr0ZTMUpfqspCBPJh/OYJr8oejeLXtVP50ImQ11lxUpXj90chx6LogN4f71O16iUToitGhRbZvlHhfKf86Fg7HeMV0HkCdHhU9PMryh8Rxh45rtE8zxaJelQ4vPp/r3PwjjzbOQeAZ+VMZ9nNa18iXFWeeqlhy1Nl+33KTvf5Iitv/dt9HskWTKt6U4uis/rIyBYReH9U3mhfh+4iaoAEK2z3l0nVvNUrBrXeI1lnc9v16SNPAAAAAACAzwaBOwAAAABAwexVLHaCpxsgWW33k0QWHzxa7AbocZUKK4o+Zyffj07gd9Orsjuzqxk+wnsWjixLk4ksrHhiVORRhUeLqMQmVblVupHyfxNUiAAd7i0bqez7/Vf5Y+3cS5R8Zd0d9XGej+dd/X8l6dBvC8xfqa4AXpszY/zf5Iw4efTZyqbN1KNVJPGovCqSehTmOVr5PyKk9z5HgvTOyxi/SLlCPbf558YryJ7Zqu1du2fheeojGDnN0aXrRe3RWn+139tfXHaaIQAAAAAAwMeCwB0AAAAAIOH//f/5X3/+/v0zTdOi51OjoNAjetJovjaZe/3D7A60uWpyuzP5bslmK6to4tkFpAQNkW3lcyRM8LOtXWFKJjyPbHSiqVuiqINdv0b2dcvo2FB+Q80rCrngKri93w8lSt6tYZx/V7B+tOxlueX9hDaEwBzgk3jFTq2KKB5t988yI8dun2HUZ19WNNbvjt+rZ6uRFyLKt2x7pKytRO6dZzL7PNdd7KueP62v3TqsFhP8Fr9dPjyU6HWLaq7R5eUvI/WaRDXtsMu7clEJAAAAAAAAvBoI3AEAAAAAEv73//6f/8zzfJt3ieYe/Vyrn8xR87t2XllFOsoCsMGL8W6TcZ3ofiONtRKwZ2L5NZ2/kKryI7GAF0/4SIReNOL9jYQXURTDKLJg5PPIdrW/Empc1clUYdkghjp7dc4IjBHuPpZ7RY6/2l7UptR22hAAvA/vOCaKIqkfWTxafc9CLCv8M1WWbi2vI5K3edRzWuelibJvn9WUsLzzfOpfwFzR5qqF01EbOMNV18o7XnPQYd59MKj1HNn6kKqLWPP7f3FMhb/LsvwNLAEAAAAAAMCbg8AdAAAAACBhnr9mWuZp3kcniuY/M62tinCk5qEz3Sy8INXk9SNP7mhZ9/AtEiuMooTm6uIZqX8vqu9EA5yCNMqfbHvUaWRiiI4wolvP0cqajEwUP3p+jy6KAIBXZ0TA/QhGyn2Ej5Fo/aiY/ROivF8NdQZwLxjT3aieWzrC80gkPk17253FrdEz1ki08SpKgP+sQkZnKlkveFdlq3JV3agXN1F59rtayOzL79RDVnbElTcorkf4xl4eI81bpVs/+9cN9l/uwp9lWdAzAAAAAAAAfCg8EAIAAAAAJOzELJWm1U/Q+PnPKgBzNNdZzbMClNwjUlynvNH9KhLfSHTAyHaWNrrA/MVrQ4vZ7wq1P+sgKvFD1klEfqsO6qjofERsc0SoPtou6QzheXl0BO13Ft7+VjTykXJ92lc4H0R5H4c6A7gXV0XMvtJGJtKOtl+xAHV0rN555lGLZdXi2a74Wtn12/zzj0rXXZAclaHsR+egG5Ja7e9GGugI6y1K0K/KzvLZ9GevgRcYvMD9mKdpWduQfdUxTfHl5S9tdVmqpuwvveg11eJ6r1cYYAMAAAAAAMBdQOAOAAAAAFAiJnqumENcUXO09rPX1MIb8ogTOyIG7+Q7U17WoDuijMovJXToCO6VT37mdkQ4YfcpwUeUrzrOShCh6qvysbIVpe0KLyKsr0xaAxzh2YS3Hf2JTxMdwyO0LGsZV5X1bOcDctBLAbwDV1zIkVKzKkOpQEcW23bK6OQ9KtD3ZXcE7WcXqNr8/plChXf23/0+61/0bJEpbKvnykhE7zn7XKTKvsLOSFncFD+SZZpme+7tZaQuQ5vGknV90asWXx4AAAAAAACAA4E7AAAAAEDCsiz/ZKQgP1eqNLlqsmbd3pkf3TjSTAcwzG80rk5kQBUibCQSX2Xf74+E5Gq21QooRgXvdtWK2hfNGGci/2qmuYs6RrUv8uMRZIKdK/ygswU4S0fg3RWBP1Is/qzCdATY9+VZz/srQ5uFz+PeQuSrBfxX+DsiPPf5jkQhH124a33MbFTPXiNlqOe86JhGn918SOx7wU3xI6nW92TpV1STHrUbmWVgAQAAAAAA8NEgcAcAAAAASJjn+c+yuMlWH8QrIwr45edvK23tziwTj/BKqIh/Ko2iEgWoMrxNJbLw0QGV/Uio4X1Qociii7wb/VH56O1GAvxpqn1Wfp/hXnY7XBnyjclzgHflKm3MozU2nyrARsu05ZXqw7fZV/Id3pV7d6RqHJ6lOeJPJ48VWHefoTLhdPY8o6Klq0XA6vllcvk8WRT2qkNRz2fR81MVTtqW230BFFE96x4R7ANcxFK8Y/SXvOoafLR3mzd7dWPz+DUii0k+n7oAAQAAAAAA4IVB4A4AAAAAkPGtyPiKGjTFwZOjwGR+0kbNyWbz32EgM+Z24Gp+s01lF8iIDfVdrS5Z/2ZldYQNvkPIQpkpHxVZ1EM/s5zli4hmnrP8ZyMqHhVjjCwQOEPlH2ISgJVRoeq9048QCcVHBeTPIjif5/cWDj9LPT8Lnfp41vbAuYRxrhaAn7k4MrvVYtKI6plBba/G150I5NHzkUrnn23OCryt3dUHK35XwvzoeUUtWFbpowXA/lnLlquelUbaY6TWVWX6fCOMPDc/6c0BnopQPx690xxtVvbSrV49CC+W/y7oGQAAAAAAAD4UHggBAAAAAHK+te1zPV+6bvPzrEoYr4KdVXaLJADPS1d8HRG1+EoYEAkYootORR2cxHdbls9TCV0ycbkSa2TCbrVPCUd8ntFZ6ci+tzlN+li75WR1d89er7JNjwufQUcc+6pi8JVnFQAfYVny+n2nYwWAT6MbpXskz1FGFsSu246Mfe/lv3qe8GP09bN6geH/Wrvr9mpxgX/W6vjsffP7q2e1KO8ZonZXHVd0DGd9ebJBFrw0i/2g/qlXAn49x4pfv7Jum1yawpmfNxfzzCM5AAAAAADAB4PAHQAAAAAgYZ6mv/ZLGMir0nf6OeNp2k8Q+fnmJGjYVrTExCZcwW+0I7X64wo/otlPNVOr9lvflBA+u8iVL9mKlszfar+dOc5E+9bXzNYRMZGyE9msQrVdFd3wTNRFgM/lGcTo9/bhGY7xUfzGsSKq/10+qX3Dp+PHl7/NWCjiG9kzy/p3pGPtCO6r79UzktpeHcdajhqfjywuPnKTqcT33pdue+q2QaX+fcTCBuUDQMzsv6h1KVEX4z93u8SuvTAxAAAAAAAAfAII3AEAAAAAcv4tyzQt01IHiot0plEeJX5v6F73bjDRA6/KFZHrPCPChMqPSry+lqcuXCvWUAKNqtzM126URG8vEq9Egn9vV30+4p/KcyWR2B8A4H15BnE5AmsAOMeRTuRRnd/o+Pas3UhQftRuZk+9yDgqzldp/EuPKKSzz+t9GX2mqoie87pR5q/yAeBJiR7do/Ud2TvTao2KfX3i0j3DGBcAAAAAAAB+DwTuAAAAAAAJ8/dMyvzzf1M879uNVjQyV818J7w81YqPkUbeXTlyJL9NU0UpVN+tsL6TP+sIopnkbvRyn+eIACUqy6ez29bP2WKAaHsWFq5jAwDgs0Fc/nsgvAK4ime+mM76lo2tVVjjKLK5+lw9JyhFarYg1L/wyBbPjj7nVS9T1u3+OSPz9SxR9PgjzzQR927bz3ztwKuw7D5M29cDtjuI1vgro1F3EonjGdMCAAAAAACAAYE7AAAAAECDxX/J5nmnYH8nqHA0xwvwsnRmJ6uoeZ3IeN2o5tWFNSqQV2KQKKq7/+tnejPhic/nhRcjYvPItuLendJvzWT/9qx5d8ECwPvxjmLgZzmmZ/Hj02BxAcAnMHqh+4jl2cuDs8Jo/1wRLXBVzw/V6nulRvXC+2iB7Tzp5xxrO3qJEkVvz+oxoxLjr7Y6keu70QkiMf894EYEF+Mv5e4l6VGvP7LXP6LLWaZpXqblb8dtAAAAAAAAeD8QuAMAAAAAFMzzNM1q1iYLjKw0qT5vFPgsmgPtzMkC/DpHGmkUNa8qZzTadycyufoeicaV4EOVEQlM7KxxNxL8aBT3aFsWUbEjfo9Cr3XoRKLM8hwp0zMabfIqWMUE8I5i4Gc5pmfxAwDuBRf5/agW1KpnlM7C2EwZ2hFUnz3nR8aeIwuCo3pbin1Z3uyFiKJzXJnwP8vjyxk5H0cXtPKMAE9KtLa+Wvfhu4NqvYrbPk/TPC3oGQAAAAAAAD4VHggBAAAAAHL+LataqKMZnaZtoLZuUGm7LWJji0lPeFZGLhR1AXSFDCOCkErUnglWqqh7SuCRiS+8sMJvUzaUIMOL4qtVMl0huSc7n5nQX+U9KvJ4tJjrnv1rJ2o+AAAAAPwOmVKz+/CulJw+OrlfVJr5o2xHn/24vGM/W7Trx++Ly6MWx6rjyp7xoqjtykf1/ON9yspQnBmXRwuhz8BCFngw89f/zZvv3/iuIFqz47vOaI2/zZu9Yvku5+eK52eKAAAAAAAAPhYE7gAAAAAACcs0/f355BnViEZzsVE0o59Ni/3ylZ25HXh5utHJRyb4j0blrvYpoYePtB7N4Eb5lIBDidinaS/e8LYjP70f9nNHkKPSqWP1x2fTZQIVVfZZQdFVjApLrhaiVIsz4JFwz4WroC0BwDleuRN51jFNtJB0JO/k/mbj53uNGbMFrlXk8+jZQQnXfRnZ506dKnF9tMggUsdGdat86z5rKM48q77ytQufwLyKyf06ekW2pv3I9uRS5coBAAAAAAAABO4AAAAAAAXz/Kc3bdmZs470p2a+eHEG5mnebHtWaQB8OldOPVYR+CKqmVhvb/RqiiKV++8du8pXL5pXZfvQadEMtBek+DIy4X7ka7RNRWqsIjH6bfaYPKNt64pecnQF09XRGitBEjyShRsvXARtCQA+l2cd0xyNuu3HrtG4u2Pfj81HiATiWVnZvmhcH/nn91Wq1iMLnLPFu2r/kWeHK27QmR0GAPDctN95Hm3indc7nVcIAAAAAAAA8HEgcAcAAAAASPgzT1M4q1IFDBvB2JrneTenLH+O91k1AvChXDn7qMQBI/ZHBOaeedoLO6yQPJuZ7URJjDoOJcrIhCI+SqTyQ4llsvSZWN6XPdoBVeKeqxdI3JNo8YHaV22P7ABczydFD/+kYwUAeDyVwPgTOHqjiRSifqxcRTC3tqrni47wWo3VIz/9vsx39ewUlaPqprIdLc4djR4/SjcvAxJ4DX5aarRO5myT95du8opjWVeEzj9X86fdYAAAAAAAAMCAwB0AAAAAIGdJpZyDQXaXaelFeM8+Z9sA3pojAoGzEcGrqITRxVkJO9a/VpjRFUFHQo+OuKgSsVd10xG+dBjxedTumcURkc0u1eIGOm74PT4penj3WBHCAwAc4ajy8VW5OsJ3p766Ud/td5/PP3Osn+0i2EpwPk2xz6pe/DOK99EvwO08B2V+dhaXZv6vjKp3u+3hlQZf734dQ04hI48ut6teD2xMzltbXxvQMwAAAAAAAHwoPBACAAAAACQs0/RvziIPqwDJK2Lef84mDbNgzSKdjOoO8GscEWqMtuFMQBGVpfJ0Zm6V8OKowN5HW4/EIKqvUcKSqOPJIiR6H6wdRba9Uw/dme0rba32jrSzSCQUlXGETBDzSuIXgPfBC+HvObRi2AYA783VY7qj3GPhZDe6+ogfXWG2/eufC6LFsv55J3thofzOnhWUkD4aQ3ux/ZEbYbUotrs4N6rv1a/uc+Y7j9nf+digZtGvPTprbSwDt4Kl0ebmr4R/lmX517AMAAAAAAAAbwgCdwAAAACAhHme/7Um+rLAZ1H6jGjudrZfAJ6JzoT4lZPm95hpjexE4hJvv1OmF550hSN+X1SGEsGPRDtUZWT7M9vRcXWFQlEZ9yCLpH9l+ZGIBgDuTUdgfs8o958UQV+BwB8Azo+pqjHs0TIy8fRoeOJoHB9FIfdpowjs0TODGpdHi2q9YD/a549jdvmiZ5TOQtPo+KOFupFIvhNJvevLkRs0NzV4M+bvcBzqNUXULRl+xOoD61DSACDWl2la5pkHaAAAAAAAgE8FgTsAAAAAQEJ72jKYx95EJOoGB87K+JlzXlrRjgCem7MClaMXki+jEwk+IxJkqFnhTDSSid0joojqvjz7V81Qe0F8FtExEoNUovkRMcwRupHRO+3ujD+ddtkR+wDAlXyywPwZxOWfXP8AcCWjHVrnITyLRq7yqwjnXowe5bHbokWhlkxhGpXrP2djW/+M4J8HlH/VQgNfP9F3T7UQOFtIW9m8cl+2nzE+vCY/+nG/ZibqBnf553z9i87UcWy67n0BAAAAAAAAvCII3AEAAAAAUr4mUlpi8kcFIEYgBL/GIycVI0H2yuiF0BFTqPKPiKa7ebqRB5XgPIvoaMUjmWg+Esp4OtEylYhGRa68qgOL6jOKZOnTXUlXYHPEFgC8Is8gKLd8grj82eocAM7SDQPc7eCyZwFrO4oYnuWJth8pM3qOULaisb7yw5fj9yvxviJavOt9zbZ19p9ZyJCVM8KRG8vZMgF+h2UZDJGeXXJHYgQEZSzLMk0z4zwAAAAAAIBPBoE7AAAAAEDOUk5KJsHNfn5yN9KlZjalM0udF+BuXDFBP9J4VeS+o7ZWe51t2XZVrhI4+4veC10qQco07Y+/EvV0RfReMB8JwqvOSgmAlkmft0pA3yWqCxVtMrNx5Lw/gtHrAwCekU8QlD8b1DnAb3D1hdcdO47QefhW5Ue2OiJxJUiPng18+X48nUVSV3m9He+j9a+jRs2eNaqFpFX0+MzmVW2r81wwmgfgTeleDv6yVo/mNk03zkBy6THOAwAAAAAA+FwQuAMAAAAApCz/6iQnzHeDU8/rnyqqNcCzMxJlsZvmN66HqrxMjOIFJVHESJ+n408leLfClq7gJxKOVxEKO8L4KF22qMELiNbtVfTLo2VWPDq646vN7r+avwDPB1ErAeB3uWqxacURcfOZcdiAujJcxBnl74x3vW3/rK9E6lmZqy27Tx2jfwaIhPlXjOFGn9eORG/P7B85hqh9ALwn8zR/jTWj7sR3bWrtTPRZF9iLPTBvPjEaBgAAAAAA+FAQuAMAAAAA5PxtpSrmYTeR1/186aiOd/8R4JfIhBujLbSKAJhRRUIfJSs3mo31ZAIRL8QeEQ15e+ocWNGK6pxU5+MjPXYiy3t70cx3Fj1y5Bxb25Wv1Tk8sq/ya2T/iOgpystdAOCZuVKU/ilRKxHyAzwrZy/O0bG6X9DYtdstoxNWOBrHZjajtCMLL7O0ql6icXhE9Qzh6yaqq47YX0WMv5fI/ernwQpuWPA+LNn1E63LjrL41yXd1yfh+pR5mqf5z7Is/2lYAQAAAAAAgDcEgTsAAAAAQMIaMT2dvmzocufIQidonNm2fCucvuaIPkTtBC/KkfaphBOZAOVodL9qeyXuXv9mopjMlsrrZ379jLEPiaaCmCkBud8XlVmFUYvqRM1wXyFcGZkJr8rrhIezZUaz+O/KEWHYCAiAAKDHpwj5AT4DtThxhE4eu+ixOzZfv1dCcrUgNRqD23xV2VmZUT4/zvbHXInPVf1konOft1rU7H3yaf3iW29D2e0sYM2ehxSd58qji28BXpzskut0543XJD/vMAcez9fFjwwRAQAAAAAAPhcE7gAAAAAACfO8n+jcCct94OOMwWC/vqwfwT0hLuEpuFIIXAlNurOgnm4ExZHIiuv3Tp6rRPhK5OIFIpGoRH2P6iXaHwlZMp+VaF+l70R+PLPAYbQNjJyzjvDqDNUCgyvoRvwEgBEQawPA83KPDuqRNjMRtaIjjI7KUGPjkWcWK/726TJFqf2rBPfrvsX984JyNWYf9cVvy55LvI/RtpFnu5FnqurczOavynekHR95JgV4Mub5mtc7ySuAMPDHJvmyFcJ/X65cQQAAAAAAAJ8LAncAAAAAgITlJ1rQbVbmZ1LGzrNmE0EnZmLm6TbJ5H82uDM5BPD6nBXLjArXo30qamKUJxOcZ/ajDsX7UG33YhYlfLH5lFA+8jE6Jiuo8WnOCNXPiFkysU7khzp3XQHUPRiNJnkWFLkAV8FaRAB4Xu7RQWXj46Pji8jP7uryiu44fcRGtVC1k3Z0YW8kgI/+2rLtX192JATvLPDsPg+NkAnzuyL4Rywenab+AluA32fefUio1sNEl1izS53nefOuczHbAQAAAAAA4DNB4A4AAAAAEDOvgYI2ovaVrm72ooBe20keJkgBYkYmP32kw076KjJgN4p6Ribo8eWtf734/kjUS5vXR4e0aZWgxAvoI987PmZ06jja1rU/0ibOlDOy/REgHID35dG6GCK4A8DnoBYFRp+voiMgzsbtWRRvVVYmOh9dUOvLHlWC2nG7qmc/ts/sdfarhZ+jC0DPtIHO2P+iCAOXwSAAXodlmr/eMUaX2TzVl37V5LuXhE7HBQUAAAAAAPDBIHAHAAAAAIiZZx8maPkWl2dBnKsAzwqRVorYA3UWgnd4D64SI3Qjb9v03UiJlVgn26+iGR5ZNdOlI2axwnQl7I7EImqGO5vtVscdCWpUdEbLSGTMUdvW/tl+deR8PpsoB+D9QHAOAHAvOorH6HOWp6IaP6kFi9EY3I9XlS+VkF/l6ezzi0mjNNG2zG62XY3P/bFFiz4zf5Xw/urnHHXuHxWdHeC9kFef6iKnKb+8hKH1XeXunWV7zf/STQ0AAAAAAABvCgJ3AAAAAICENWr68v3fz7YsUHH1k73qu9u3TMsmYvu6zU4q2QkinxbgNRkVZxy1dxQvzhi1H0VAHM1v8yrRifczE6d4P3xU9nVbNMMd+TkFaTri8ayz9PYrPypb3qb9fCQyaCaIqo75N8Q4CIAAAABej2pc8Yx0I7qPRAY/8ozgx7jKTraQU5VfjW870c/9otNpqseZnWeKkTpS5VVj2o4PnXMWvVzpMHIt3OO9Ce9i4PXZvVNUl3/UjQddqH2vKe0PuLcsy3+GcgAAAAAAAMDbgMAdAAAAACBjvkX8tGL3H44GmFPfI/3p9/Zb+QDPzNUT/I8QDIxEeh+xUYU5y8RJlVhECVsiEYr67L9bwY0S0mfi/I54W5XnbUe++XJm90/5o/L6z0q4n9kYFVx1hVy/SVVvAAAA8Jz85tiiGjMcXczZsd1N08nbWXjpx42z2+bHx5kQXtnMxtdqnBaljT778fMy5X5bVDR3v9/XifLjDB3fsrz++z3Gu4yh4Z24BffY0FnPE73+yNba565M0zRNf/7MM1E9AAAAAAAAPhcE7gAAAAAACfO8n0PxQnc1+fOzrZoTvmXYTAJtylBzS8KvXdkAv8KV7a8jOrmCs5EgrY3RCILVbG834qGKDFlFQlSi+NG6zvKOiP6V2L2KDhn5qsQrSlgURe9U5yQ7v1k0zsyH0f335rfLBwAAgB6/dc+OhOudMWCX0fFSZ8FoZX9UfdkZM0ZR4TsLPtUiSbWwU4nts3K79aRE614oX9mMyBY/jCykrcqNRPeMdwE8W0m7uEaitfQ3A5IfTXqUd6jr5doFAAAAAAD4VBC4AwAAAAAELMvyZ1qWzZh5O+0zb/7a/TK4UDIhtKxTSm6/slNP+TPxA8/GGdH4PcTtkfBjLbOTrytqzvDRE7tEkcuzcqq0meDcR0zPxPORWMWm96IZtRLIz3ariJhZWdn+KPpkhYqkmbWlVyBaUAAAAADg6Yq5r6I7Nqkic1fKzCiiui8j8s2PUato5tFYNLITCbwzQbgae2dk4nr7XdXPyHOBL+9eVErc0UUNAO/N9sp37zijteEDl5B9l/rz/tPaK5ziagUAAAAAAPhcELgDAAAAAMT8mabpr90QRm+fb/s3EdTdZE0UXV2J5F3GNA/Ac5NF2v4NKtGJR0VcvJcoOIsq6cU3UflW1FLVvZqZjiJjVsecCVsqQX4lShohijo5me3qnGZldurpLL8hMI8WSyB2BwAAeE9G7vFHomSfoRKCq+2dhZdqbDgl+/xCT+VfJnhfv/vx5+I+R2PVCF9+tBjU2ol8zupr9FkpS5MdT/Vc0Dn/R7nXQuoI3t3As1O8q8y6uIp5+/5y/v4vyq8CgCQ/YgkAAAAAAABvDgJ3AAAAAICYZZrn3ZTLMi3TLnp7c2InE6Vbmz660bZ8pIfwLjwiOvsVdo4IrEe+WyLBelWOEmArUU1UfiZyrsKzRdHVu5HUz9avwguSMkGP6lVH29EVPfNImVddO9xNjkG9vSqIYwDgdbnq3jPSEXbSjo7nzh5HZ3Gi/3xF3XUXt87un8oTjdmzdNkzghfMdwT62SJZ/znLk+FtqIUJCu//O9y8GTvC8/L1DnKwld7j9rDJeu/F5QAAAAAAAPAqIHAHAAAAAEhY47WvMYS+tvUnVnbR2KusJhL8bZPLtDC1AxBzT/FAFfUw8mFEHBJF1I58ySJSRumjiOx2BjqKcKn8UlEo1T4vcLGRLCMiYU4VQm50gYJfBBD5Eh2rF99c3Q6jc6XSjZR9z8iYFa8s9OEu/Kosr9zsAOADqMaI9yznkQv1ovKqqOhROZkIOhtbe1G4F6WrxaRZRPcsSrwvN/I5WqCqqI6roy7tqlTPLIxQflRjbvv5qND+UeJ4xoXwBqjH6dF1+Wu+oWKXnTn/DnSe5/m/y3//jVkGAAAAAACAdwGBOwAAAABAwippX39Et8M8zUOTOj8/v3srEAA2XCka6NpSQuJMlHGFgCKLatgRemcib19OJaRXIp8sAmMk3In2Kxtrvkl8tumiuvDCIiXin9w+VQ+Z6Cs6VtUeruzQlY9R/TyTyKa6ZgAAAOB3qRbPqbSjti1+0WXXp6rsowsdO1HSo/GMH5f5MagX0Kt89nsl1K+2jywaXdN3xuxHzruv1+6zwNWMnP97lQHw3CzTMk3z9PVLR511Mbkx/dmX981AAJG/Bz0CAAAAAACAFweBOwAAAABAzJ95mv5kMzu7CO0OFX1dpfn6SeArou4CvCNXigauEOaMMiKqjyKEZ75Ugh4vnsnEOz7aYxQ1UUWXnN0/74eKROnFTfO091eVqY4jCjuXCWq6kSS9HSXwzxYkRD76srv+HCFrP/cS5mTCJcRAAAAAWx71jHe0nJF8nft8Z3Fhl1FhuNqnFptGixvXvx3xtspr0/jxt09n06vFnPZ7tQg0e1aIFjtUCzc7ovjouKP0V9CxyXgUYJqmaZ6/r8t7X5Yb81boXiYGAAAAAACADwWBOwAAAABAwPI1Xr5FCdpp1Zc42tCybNKpz4d4tuC8AG/B6EXVFS6rCzYTXY+UnwlNMv+8IGaUThTKLF9ly+/viJIycVIWAfToOegKtjKBUmS3G8myitCZ5VHt9NFU5xZirlJ3oBIBALg/j+hrz5YxugCtW1423lUKymp8MhJZfKRO/Pg4spWJv+3nSLQeCb474121SLR77Nni2dW+/atE+5HY/ihXjwNHbDH+BPDM0xx2EZtfnNxtP1Ge+dvJAQAAAAAAAJ8LAncAAAAAgIhlneMRkYymajJmlukGfn4XAIa5h2B5REyj0mUik7PCkGy7F9JHwnov1olEOlFU9lE/fBleqGPrpRup3abtCL+98MiWOxpR0vriFx2MRPM8sujhmQTritHrCnpcVXecA4DngMUmMMq97/vZOO2R5XUZzeOPKYqcHqWbpt5406b1/1RZfnxbnQdPNcb0x6mE+DbP6CKBDmfP9dnyry4X4L1YpmnXHczz/PMecxtx/YK3mwOPwD8R5gEAAAAAAODjQOAOAAAAABAxTz/TOGoetBWvaGAOxk4PRRGSDgddFpyOJg/wdNyjTV9h84rokiudTmVx/3zUxyxSZyYe96KbSOzjxTrKrheUq2Owf73YXlEJyr2gKBLvRwsBsuiV2aKFTgRSW072vdqekQnT7iEYQIQAzw9aGfh9Pr0RvvvzyG/eX68S/Wbjh6MPp9FYxI7NOnazMaEfD0+Jzcyf7rjQ+myF7Eq8npXf+WzLmJK/ka/r9lERvSr36ALN7vcjfHq/CjDK0npELCXtYnf63lF0T2v6Ze/Tuw8YAAAAAAAAIACBOwAAAABAwDxNyzRHMz2NyZ2Cn4keYUbZ/tkWzCOPCtaJJg+Q0bk+sjSj0bu75XbFPqPRyCNxts/jO6AqmroXKEUidS94j4Tp3o73TxEJ8zPBk18gEJW9fj8jNsuivnfE8Oo8q7TZwoZHgjYBnoeF5gjwy/A8coxKsD1N9RgiG39Y25nYvDMGysahaqw1Mq5bfYh8s3/tWFOJ9rOFlFV9qQWZ3peoXJvf2/eLVe0YX40Ds/F8Vu6RxRAd4b7Kmy0YHfUlKycrAwC2zLf/913/ybVSrfeOs/04b/4a0/8GPAEAAAAAAIA3AoE7AAAAAEDAskx/lmX6O03Tt9p9SUXkdt+adnHKKZk/MKnLWr7dSQTwAHABnZncjqDYR6LMBERTkmbEt0pwciQquBKFT9OYmD4SYmeibxXJ0wtrvLDHE83OK1GTFyhlYiRVTubHZPZHfvh0laDM1sVVCy5We/fiN+5VnXPyaKXzsymrn82fK3nnYwOA5+UefU93DFHl7wjT1ULFI2QLOaPFkGp8NzK+UmLvzI/uWM8T1U81Dre+qeeFkbL9Oc3E+Nlxnl3cO5K2WiwLAA9n+b4S5+X769h1Gf4KZbPsaPs8z9M8T9OyLAjcAQAAAAAAPhQE7gAAAAAAIcvfef4WuE9aQG4nbDoCc5umSj9P80ZUv5kcmqPJIyaHAe7HERGREmV38q3ldSN6Z1Enq/yV6D7aH0Vh96IkJR6PvivxuxUCeUFQZjfCin86oekiwVCW/si+qNyjZa0cWdBwhaCtorPQ4So6Ir1HC+/Plnd1fVXRZF+Ze5/bR9bVO50XgHfnHn1PZ7x35F7XGTv59Ff2R1kE72qcun6vxl9KJJ+NIbOxux+XZuNEP+7sjOUjvzpif19G5H9nm/ftyPPM6L6o7LNw/wSIMdfH8h1B/ftv9xJc32+qd6SV0N0HC1HuzVzEAAAAAAAAHwsCdwAAAACAkHmZ53mZ3ASNFJz7nN//ZXSiwe/tzNO0LHJq58u3nNEoTABgucf1UwmUKhFwFPkys+nTRNEcvYCmI5S2aSNRsUpf2V3xAiUvjq9EQ/Z7FJ29KwzLjusqkXuXI+VdIZ4fJaujRwjMu4s1Ovz2/fTe9fVowf+z8Rviu2crCwCu4V73i0xQPVp2Nl47Oo4Y9cHajRZkZvt8eZnfi/js8/jP1UKwbDGdWpSpFoGqcfdIJPTIt07+jKva8Og97BELLgHgp/9axPUmN41dl9G70TWghxXCb9L+rPth/AsAAAAAAPDJIHAHAAAAAMgw88tWdG7/ZlhB/Nas3vZThpnAsdur0EWdqPAAcJYrr6Ozog0V4fFMVMVI2JNtU/aydD7i5eQ+T257Ria6j8RC9rsSHEVEguyuD0e5qo1ckfasL50orI/m6PXM/fS94fwCwDNQLbp79GK1znjpiL31c2dxZ1V+JEaPBOqZcD0aP1b5rA/VmNv6lon4FdEive5469FjsKq8ahEBANyH7zeO85x2P9t3k5NMO/rOMfqVy2XSgT0AAAAAAADg80DgDgAAAACQMX9PMH/Psyzmv7YJMcETRXifbwXt0s4/UZUQqgP8LqNCm3ujBDdHo2NXwiUlRFLlVEL7SmTkxT4ZkYioe8yqriJxU5S/K9hRoq1KcHS2bY3k/42o7mdtfrLy4ZOPHQDgVRi9z6mFeKNk44uO4Fp9H/3Fk9Fj6EaK9+OyaEGhSqcip2eC9mg87SOnq7LWdNl4NhLzjyyQVMcQjSO7Czl/67mGcQ3Ab/DT2yW3iDW6+uZd5rLdP8pO0C4/f/ekRHEHAAAAAAD4WBC4AwAAAACELH+mZfmzRg5SovQoQntoUYjjfWR4u00yEtQNAE5wRQTFq8vvCte9sGU0qnsmXu8IkLxQ3UekVOKbTJyUCdizY/MCI/vPRuPMvkc+efyxqePtRtk80pa6vlb1dVRcFOUbtTea/pOjfTIYeByf1K5eDc4NvBud8WdnYZ0XYWfbfd7se9evaoxqx1s+jxqDKsG8F6uvf30ZmXjbj/nWbdn4uTNe8v6o76qc7JmiGourY/Dpo8+2ftX4WeWJ8OV2Fy8AwG/w8y7SXZL2vWT31yL9O8/o3aZP5yO5+/IW9AwAAAAAAAAfCw+EAAAAAAAxf5dp+ff18Tb5EkVfX/GTOUuSd42C5LGTQ6KAcj79SPQkgM+jIx4auZa8IOWMQMiXn0UArwS+HbGR2j8qsPfi8A5KlO0FOSPC6UgsHkXCzCJrRgIzZU+JgayfV4jVKioRU6fc7qKObt0f9eEMiKV6XDVOYLwBANDjyv7yzEI4+3lkzBYtUhzxS93vlcjdLzy0+dXYWI19IiF/N3/kv03vx5HdhQWRX5WY3Av3lW1/nqLFm778yKdOnshGNP6ObDGGA/g99tdpFNAje9/o33mq953+PWj5/nKepmlZ/pMnAgAAAAAAgHcFgTsAAAAAQMwyz/P3TIuKIFRHJdr9hG+StrK9rJPL85fljCq60lEQzsN7cSRS9KhIORLXdIXEkd3MRkeY3i3TC6AqwX0mKlKi8PW7t1cJmDLBj91Wpc/w0TU7giNFJrBXZR5hJN8VbQMB0jWMLqK5kqvO4ae0hU85TsurjPk+8dzAa+D7+LOi9LNEAuuzi+GOjKfXfB3hc9e/7qLFSAyeje183szvSKyvfMlsWXsd0b39ro6/Gqtm38/QtTWy2ALgs3jEe7jF/P9xGz+vT+N9hvW9Zef95cxwDwAAAAAA4GNB4A4AAAAAUHCbxt7+d9s/byIbrZ9VWrt//TwZ+zbNzfZ221eyZZfnEdxLOA/wGoxGrOwKdzq2/L4osmVU7ojAOoswacvNIkZ2UMJ2JS6yx5Mdh/JHCX68774Mla/C2/PHEPnu/R2tQ2XHUwmn1r+/KSp6FlFTdu3cg9GFLjDOM7Sr8/yOqIe2CUe56rrr3pue+To/ex0dzZ8tuLTfR8THo/vUWMoLytWYS43TbFnRgsORxYuqrGjs58fe/jj82DkS0ttxqPLf2us8b2TnWI1lsjHH6NhnpD2MPBcAgCf61cerS5m//rRQwT82fi63bfuSlqkTGX73znVGzgAAAAAAAPCp8EQIAAAAAHAR/md4ffT2o2J0L4//2taPdHSkFAC4GiUq6YrfvWDlkWLgyGcv8vEipKuF/VmeSLCjBEeVQD6yr4gWFijRfhZVNPNlVNjXOS5bB5FIrCovO79HBOLRwoorGLlW1Pk+69erizMrfntxRMV7iLSXZ65igB1XirI7th51nV+5+OxePPqe07VV1YVagDhqw6KE56uNedqP1zrjWyWGVzY6iwc7YnclrFd1VNWX8rGTPrPdWTw5wnvcqwHuwWOCTMzhZdgt36fzv2Sp9qvgITsYAwMAAAAAAHw8CNwBAAAAAGL+TNP0d/3iRetHhOtR5HYb7UhFfB8tx5enti/phDoAjFFdn51IjEdtX0VXVB1F21QRNn2kTlVeZcf/VQIcnzc6FiWI998rgbYXPkXCduuXLSs6RkVX2OePO8L6eUTcvqbNxFSjAvGrxe3ZApHf4JnEmfegK0AFgMeAEuy1OXL+uov2jlAtXBxZdKnGad5GNJ5U+7zoPBpzqvHlNOmxWDWeUuJ3n14dmxrrdOotql+1uFEd9+j5iWzfmyvKYSwCcIbZ/1zQwCU1IsJXonf13pJfjwQAAAAAAIAVBO4AAAAAAAHLMv2dpumvj2YU/WxutK0rYF/3RRM5oxM8VZlMGAFcTUfI29lWcUQQfERIr/IocbT6nh2rj36pUCKlSDAU+arSVXTF7t26qsS/Z4VsXSHW+vlqX7L8WdRSS+e6Gbl2Xv3e9uri1Ff3H+CZ+LRIyK/s+8rZPlCNjzoic/+5I+b2ZELwzmK86P5ejddUVPLsmDsLMde/1VhTjUmzMZ31wR6XP4ZMbB/50h1HqbxnbbwDn3SsAHfAdNPLtEyL+/mgMuDGwC3cR2237y1371t/7C7vMEgAAAAAAACAA/z7bQcAAAAAAJ6YZZ7mr9mV5TYJk/3M7k/Gb3G5F6xfJV7/IwT36id/j9oHgCOMRErM0nUEOUsjrY+IOeKTEpMfEc4osZMVAWViKPXdbouiYkZCpcimSp8J5ldsuV7YlAmaMiFaJjqLhP4+XbRP+aW2Z+ekI3CrGPErs9upq24ZcB3UMcA1vFqf9Wr+HiEaA0RpjmDHW/ZvVb4fR2QLEaMxRzUOyHzOyojs2m1K5O7JxrWRz9k4SZ3Dzji+WsBXLTpU4+po3KrGqtmYOCLa331uGeEeNgHgYQSXb/Xuc+SyX9+VWrsq2MeP3XmalmX5T78EAAAAAAAAeCeI4A4AAAAAEHGLFGQ23SZfbnu3UYayCZrF/We327x7P2z6eTNv/oho7Fm0pjKSE8DLcMV1FIlHOuk6+/z+URHSiF0VnbKTN9rmxTmjUTkrkZSy4Y/Bp/ECqOhcVWKmrHxLJjDywrBO36rs28UDXgzvy1fldMRxHZ9GBE5XXntHBPGjZdyTo3XBvRjgvXg1sfiIv6OL5UZ4VF84ck+MjjcbM2bjErW9EoeP0LHjxdedBXvZsYzcu+1YR6XzAvFq3JWN2yI/lM+VTbs/O97uGHC1XY1/qvxX03k2ubK9AsDV+KjqVdoV/54zQqXxdm7bv7ctdBoAAAAAAACfCgJ3AAAAAIAW2wmYTMS+7o+227/9ou8vYs/IyiY6PLwPV4k8smiRZ+2ORtEcFftW5Vaioo6tarsXSC/TXvDjBdxePKRERDatEpNHoqJMWB/ZsfttVFIVLTQTYFXpMsH/SDuMxOxn+/fO4o7OAop7Mtp+u+er4h4RUwEAXgG/AOrK/utRfeFIH16NfSIRfLWY7+hiyWg8GY0zqkWCdns0PqyE453FiX6/8iEaFyqfpiBN5Z/6brfZcV+0PyonojtGVHaPLli8gmxxIQvzAJ6FZdcH3xh53zcafCMKCKLE7vPMsw4AAAAAAMCngsAdAAAAACBimf4s8/Rnmm8Tw+vkipp40SYW+XmatpM5VjAfRTxa7GT/wflgoq0DPIJ7XGejER0rlLAs68+8KMdPgivhe1amL1sJlaJI4F5IHvkfHaNKr0TwEap8JR7qCs864qOqfjORXObT0QialXBuREx/ZblR2itF9EfrzPvyDCKNTn08atzA+OQ54DzAGa4Qfb8KZ/zvCo4zgXh1L+osMPPbo7FGNCbplJnhBeHKl3VbNm7y4zK1UFKVnS1a7I4HfT6/T23PFk2Ojp9GhPHZmHvE5ggI2QFej7l4J9nfrvat71GVuF3/ouVs/wAAAAAAAMAHgsAdAAAAACBk+TtP079p2U/WqIhC0c/sdsXw3m5kszKTTTp1f2YYAF6dEUHJqFjZR+i0NjoRJisRfBV5PBM12fRZ1Eib19ta845ELF23K9HSPO3tdmbo1XGq8rv5vI8Z1XnMyvD7KzoLLM7YPZK/c+0cVVk8kzrj6jq3jI4znqlenoHfGqeNLlKCx/PM5+EdruMjgtwrFnWN3Nuvphp3KaJov2ZB9m5/tkiyKqezmDHzUW1TAvpM9K0E8Jl9NT705WW2IttH793RuLZKd5R36A8A3g/93nL7JQrAod6D+u1729s83QjvP/afedgDAAAAAAAADwGBOwAAAABAwrIsPz+FG0UZ8vuySO3TNG1+WldFeI9E8T+f3QRPVZ61G6UBgHtyxfV29cxuN9qk2mZFRvZfV7itxN4qamgniqi1GQmq7Oez0WUjcb0qf8SutTOSz+aP0lT5VL2p4zwj+ovqX9kcKeNeiodH3yNfVblxhagTNGrRDsA03f/aiu6j9yrj2ex3F4L5PEc4shCxc36i7dXYb0QsroTmkWjbj/Gy8U40jqnGeXabEqJ7EXs03rTjlWocqhY1qnQ+TVR3I+1hdp+z8kYWSVrO9jXcuwCeEf0u0Gz70ZXHkdZjO2Mokfz6PtTvJ4Q7AAAAAADA54LAHQAAAAAgZJ7m2U8P3/5TEzA2nbN0275st3cniJadEHRr+zcgEjy8DkcES7/F2WifSqhz1J6KmNkRkmf5o7TRfhX5UonjfdpKeK9sZiKh7LwoMWoV3bMjTOuUnS0syESykZA9SnOkvXUWKHTSHBEBjqbPzse973W/2TedFYLeE8YYXzzLvetZ/ID7ogS8R/jN67e6/z6KaAFXZ/wTnYfs/HTHVb4cv2BPCdCze/OIgD3yqyt4V8JuNQbJBOAdoXy0PTuHnfF35/oave7s+eukHbEbwf0A4N2w+vHsVyGP4n9Rcv1u37H6dGvO794VPQMAAAAAAMCHwgMhAAAAAEDKvPmz39uPZiSjEAVp10hJ+wmk7YS8nwjy9kd+AvgIRIKH1+ERItWs7HumXxkRtWeinU76I9e+EvX4yJpe0K1ESF5ApfJMbrsX/0THr4RLkXDqjDBb+ajsqLLVZxX9c3H/Iv9m8U/54r9H4i5VRuR3t812RWBnxGJXCc1GeWS/1D1nnXzvxiccI1zLvcYVr9oWR8YJV/SrVf0f6e/O1P2ISHolEoJ36yeqg9GFkkcF1dO0v7dnCyOjcZQfC8wij120OLn0fiyj6sUL3dXY0Pvl81fb1JhOlW3LV+WeGcc/aizzqv0UAITMtz5IRW6fpincPlyUEbqn9ubVo2map+nv6YIBAAAAAADgJUHgDgAAAAAQskzT9DPzssFGGjIbdxM+Nk01GbSzl/Gju7/ZjCagAOBZuPJ6tFE2FUeEJ5EoKbNfRbL0Auxsu7dfiX2ybR2h2cixZXaVyH7druq0E71TCQWVH9Z+Vl9dkX6EahMd370wbd02Ipw/0pY759mXm3GVGPMetkfqp3NtV/keyT3r/R5lwWcx0oeO2r039xCnPvoaqur/7EK8K/JGi8ayccDIPXC0DXbGX14AHtlR5R8RV2cidyVqn9z+bKFflt9S1YlNV9V5VqeV7Suuy0cJz7lnArwdy63/+HkvKS719L1lqlW/BfDwgUFU4JB5mqd5+d4/z9MmxDwAAAAAAAB8FAjcAQAAAAAClmn6N339K9J9Rx1apt1EjxK168jsg2L0YD7pXhHbz/4UMcB7ciTi5VV2o8iZZ6jE4VH60f1VtNFKAO23RaIovy1DCZaUKKoraorE5pU/mdBtVCTv/VA21feKjlgsKj9blGHznKFTRpTvEVxdztH6+hSRyCOP8xnHO8/oE/z+eTk6frna70fWw2/XuSW6D3fHP0fKUwvjfDnR4jplx9ufirSz265sdYTgHjvOUGOOjk/rvu6YSY03I9+8jSPX0mgbUOmvXmT3TNcTAFyD6NMW+3ErSpdCd5E+YzH/Re9JvV0AAAAAAAD4PBC4AwAAAAAEzGKGx/+UbhWRXX23kzc2zZDoPdx823FEWB7lOSOaJ4o8vC/3mml99AzuIwWyHaH6NPUFQKv4KhNtr/u9KDwSQUWCpUh4lYnZ13Irf6KyIqFbJo5TIq0RUfsZIaM9rmohQ5ezwq5H3IM6kVejcwrvwdGFFffmGX2C5z0vlQg2Ew8f4Qpxbfd+FpU1uujrijFadJ86Wx/Z4jl1b/bjEy9C9zaz+3tn8aL1RQnJ/XmyebJjjMZlnUWJKu3IOY7q70qO3l+iseyz9j8An8XRQBB3yzff+uHq1yGjd6FZdPcqGIfOd9s2E8EdAAAAAADgY0HgDgAAAAAQs0zTOgW8jSxksaL3vYFll07ljfLYiEbT6kwwrxP93O8IiNEB3pmuuKtLlq9blhJT2e1rp6dEThmRmN13olEE0yzK5+T2+XRK0O7Fa51IptH+SICmxOXVcUR0heqRGH5EjHVGUF/5oD7fgxHBWOTLPa7DV+bVjuuTx0+vdq5ekXsIZhUj7bjb710hhFdlj6TrLCgbte3J+vbO8Y/UUzQu6FKNC9RYppPPpusIxqPFgdkYsjNmiOqyEut70XuU16fP/IjE/FE5ma2Kamy2buuMjz75ngbwGI6+e7tPvmXoVh29c/TvRu27zCit/z67vnp16w8CdwAAAAAAgI8FgTsAAAAAQMFtOmYbsehr31b4Xk02eYG8F8Cv/3mbP3m+56T30+Tbn/SNIsNXUZuORoMCgCNRpn9zkjYT70RipxE6IigvxMlE5Ov+SLDkhVSVWFzZj8qsIpqu+2aRZhbblY9ROd6XjvjK2snaWSZq8iKwqt5mlzajU+8jqOO23/3nqMx7XY/dcjr1rGy+q9jjHY/rXcdY73iuVn77nB0VMF9tTwmdu3VzxXgnK+uI8LibthJJd+gefyaEjtIeqVc/LvH3HX9/6Sxyi1BjIrs9a0fLFJfjRfDq/m8X/mXjms4YzZcTocT56jg748pOear8q7ii7QPAI+i8wxt5J/gVyb1IkvQHnSAe9t2lT6/eac5/5ul//8//+e1BGQAAAAAAAPwSCNwBAAAAAHKW7XT4TXweZkj2d37W16db1IT4fNtnJ4CUTSXMj/wmgjvAUUbnW0fEYVdRiXc6wtqMUSF1JOzxgiorQFLRKSOhuC/Hi6vsXyUW9wIkL6LPylSCKbvP5rPHq0RbmVB7RBSt7Kvv1SKC6Ngy8b3y40ie6rpR4jJbjqUr0DvLyH3V1/NZm/cWu8EYrzXGIlDmM3D1SThqL1pQdRVX91Uj/Xv3flXZq8ZAlZh7xGaXM+M6NfaJxljReCYiu8/Z8Z4fI0QL2rLxrfLDb1P+R4sNqnv0kTYyauvowoazthgHALwi9j3faECLShi/+8XJb2bxn8qvgnSo95n/9//bf6b/x//z//WfIecBAAAAAADgbUDgDgAAAAAQ83ea5n+3qfNFTg6pCRgVjd3a8EQTQ1687omiHUU2RonyEOkd4AhHon5eZetKjoh6KhtKSGVtdkTs1o5K21lUoCKbKn8rHyNRWMfeur8j5lblZGJu9T071sqHjp8qjxf5V3SE8JG4fUq2V/uegTP326uO7Znu+c/ky3uzUNXT7/QPr1LxVwpjr6znbFGYJRI++zFEZDtD2ajud2rRWEecnW2P7uf2fhkJ2L2/kXA8WyDox2Adn9d8VuTebT++vGis2PGjs2DQlq388d8j8f/oOCoa7xy5jl6lvwF4fqpAGFGes1RBKrpBNtY+ZFn27z5X/DEqe1E9eJH7mq8K0jFNyzTP8/Q//+f//A0PEgAAAAAAAN4aBO4AAAAAAAHLMv2ZpuVPLovTkzlq0qeavMondW721z1WYG8nhyK7IxNfGf4nhUdAGA+fzWj7r8TNHe4hgLniOs4iZFYi8EgIpNIfEal3hU5WYKSigXZseDveXlds3hFTRaL7zFcvzPf+2jQRR9rLmTYWCcjO2j3iwxX8lgC/WlTyW7yjaH+aru9jYVw0mtl5JM9yrVUoka7/3rmfd4gWb41SCZxVX3dltOwq/cj4Q1GNVdSxZYvD/Dms6kYJ+1f72WJDJaaPyhltC0okH9VHtaBPpemen2o8PtpmRsc43FcA7k0uHo/z/DZejv7VI9+Oxb7fjN5RRhHiowjwUYAPX5516g8/LQQAAAAAAPCxIHAHAAAAAIiY1yhD61c9mdMRba+TPpHYXYnQvYD9J8/883/SxijZJFRm84jIfdRHBPEAZ/HConWbYlTEesUkcxW9s0pvRdqZoChfqpTvO7MgoCP8tuIrJfyKxGH+uDvCrMqPSgQ3BWk6fXV38YAS+lZCfIv1LxMNnxEUV+lHFzjE2/dajhFfz9xDEZE8ljNCR4j7gl5d5popzoemEjtfvTBmxFZH6OsF2HZ/dF+N7mFXPK/4e7oau6kxnc+vtq9/I3H5JLZ7ooVu3qZfWKfyHx1r2jpQx9EdNypR/8jxe78yugsAn/WZ9zf7P/pegBGyd2e992pf95HFpPfvBqNfllTBN9bvuqRaQH/bPz1vFwkAAAAAAAAPAYE7AAAAAEALHXlom0JP6qzbMiG53+6jIFmB/LfBzX6bbhQvqr8q0vsVPENEK4DXZ0R8NSqetQLzDp10I9E5RwVJmQ/VcUTCsiiPEskpQV3mYyQUi3xb83rxfCefEvJ1xPNdKvGdSjcioo8Eb1H5RwXF1bmLyNpdvH3ZFfHoRSjvCnWjeVYF0ZFFJQPWd+aftR6m6T6+/dbx3us6VH20EjWrtNViryi/LUfRHYspf6xfR8Y91nYkTK/88T5V4ytflvqrbPtz5oXxncVr2VhtdDHgyPFH2OO4euFHh2ysXvkSXTdX0V0AAAAVnXdn6n3h9v3l4nry+eevf1fo31N2f7Gy875xtbd8+0PwdgAAAAAAgM8GgTsAAAAAQMzP7M5tSlpPyihRuxKcd7dZu+vfn3Q/c+TLLm02aZT9DLAvr0uW/uro60Rzh8/mzKxuN++Za2xUJJVtUyLlrsgsEqVFIilVXkQnOqgSEUVirU40VmXTC7yUWG1UiK8++zyVoKsScC/T/jyo+vC+KCHcJNJ1v2ccacej103VhkYWpECPd6zPTER7hmdWEI0e8z0Wdl1pq1p8FHHVOfL3rkfSWbR1BeoeZu9lVy3i6iyYGhGXK/8qUXe2X/li/9p6iYTmnfGa8jsam9ltncUHfowz4odKY+2q8WAmRO/Wb+Tbo+9JWTv/7fvjb5cP8L6oX2bM3/ct5v9vdIXptkz1bnTdbgN0zO6/dfsuwMdTj08BAAAAAADg3iBwBwAAAACImef5K1iQnWzJJnh8OvUTu3YCx0466YmcwDEzko8mj9Q2H/U9Sh/lH+Hq6OtEc4fPZkSEfTTvEUaEOkqcFAnsInGQyre4f55I7J6JjryoqiPAUnkiH+x2Jb6fzDa/ryPYUr6rNMofn84fi6q7jghMif8zAdmaP9uf2Yt8z8o6wui9qVroUdXJUbI2cGRRwNX9yiNFbu8gqKsWlDwPcdTNkfOQXRfR4ptHLAybpvyecrSMql+8og1f3VaO1EHUDx0VFld14+/Xnft0t+wzVPcmtchN5esI31UaNbZQYxG/uG70muzch9TiPDXOsvuqcY7ytSvgj/zKeMZ7zBmfnvF4ACDjWHCI2fz/1lb03tJ/9xHelS8+iIfym3d/AAAAAAAAYEHgDgAAAAAQsUx/52n6e/t6m6BRkzp2n93mt3t7uQvLZuJnLW36/qaE6pHw3gvsrf3KLyaYAF6FVxGhKIF0R3zcESTZdJXdqjz1PRJkVWJ99Xd0cYAXmtkyIgF5pwyfLxL6Vz4e3e4FfNanI4JGZW8S3/2+7r2uI3h7tmsxq4uRerJceYz3HGccPb5X5zna4BK68Szn4YgfXvga9b8q31kyse49FvF06fbZPo//3BGoVz541CKE0froLJY6euzRvuwenC0I8EL0rMxojJLd55TwuzNOimypcZGv76icTIQ+Mobx+Z6j/wQAOIIXn1uyX3bcPm3e3i9uflHSlaOE7T5Ku7XnbXu70bvH//73v/+q4wYAAAAAAID3BIE7AAAAAECClZXXabVYXEV9zyK8RxNHN3/25Xa2eZ+qMkepygSAV+OR4sNMuBXR8e8qsVnXno1w6j/7Mioh4kg02UxsNyqE9OJw+1eJOCeXrssR8acSqVlR5aPuNR3fO2LNe3BlPVRC0257hvfj2c73o8Xy2YKYMwLto/j++mzZZ85vJKhWC7RUOfeoo44w/gp7XTude5a6965kgu7Vtr83qgV5o+e5Sl+NE0bGdvqpV6eN9nfuYR1Bv7f1LItzFFnf9Mx+A8AI3fdr6tchlSj9ti8WmHd88u85o1+/jATz3pbzDj0DAAAAAADAh8IDIQAAAABAwl42oH9216exaSNxe5TH2rYTP5vI68u0S9+diMomuSI6AvgsPxHgAa7iN0Xnj/ShW8YRwdERUWJmS/lQRTxd03gBW+WHsp9FM123KTFdJlSvRGSVn7bcSOAYlZmVnYmqlSi/8vNKMXjm1yhHFnzY8q66RkfsnC3ztwTTvynUvlpc6mHs9TuoPvS3Ge1TrrxPepv+79ULcrKxiy2ze56qe0iVrvLHL0TrisCzPJloW5WnxO/Khr8fR2k9avzh90f+er+vWlgVLZg72yZ+S1zOgjOAdyL6ZcgV9X7tbNCK+c80zbMWpKtyfUT2yif7y5Teln0fqoKBTNM0/fnDuBYAAAAAAOBTQeAOAAAAABCwTu4sy3ZyyUc/3wjP3SSP3+b3WTv2exTZfb9FTyR1yaLFZz6N2AeAK+gKwR4x8Xv0uo7E35l4OhNh34uqPBv1Uwm2VtFUJh6vhGFe+B6Jtyv/MrFzJHxTaRSdcxCJ7qpjruyNRFrNGBWDdwTxo0LSTJRZHWeHM2L5TvqrFglUx7hM810u+3sIec+WnXFWfHlFHjdubB3GPerzbNs+U9a9y1QLl86Ure67XTFyZucoZxcBKbL7i1r01S1bibHVff7IQrA1X3R+7T+F9aMzNlCLwux4RgndrR1Vjz7f5L6rOqrE7ov4bPd7snGlOteR4D+7H3fHotG4J0p/hM44aeSav7J8ALiakUAWHv8+Ln83uX8vqd5bqgAePo/6xUhl0/ttg3zYFNN0ez8LAAAAAAAAnwcCdwAAAACAgP/9P//zNeUtIgXZyEJ22zTtJ2/sBE0UjUgJ49fPNo+f6BkRnavJrbOR1bOfFJ6m/mQcAFzFK4hXuqJEJQK3eTI7SuzVXSQQiboqAVlXiGW3Z75EwjYvJovEY5U4TtVpJNY6Iu60vkXive45iegc2xEhfoQSwXkf/HF3r6WjQskrBc+ZqDBidJGAKq+TZv759ZrH8Izjl25dZ4tWOnks0fVlxEitIu5Rn5moNePoooyu6HXEl4hKpH2kDNVXRdurvnnkPqpY7+9HF3lE98VIOH1kIYsSWtuxQGZzdCxgicT30X2nI3ZW9r09W2425vF2fHmdMpWPtrzZbYvyK0G9+h6VGX2PyK73I+3iKFk9juQBgGflaICJ7Fcj7X6/LXqvp95bdt8j+nelPip99n5ym/7r3/LYBwEAAAAAAAB4IhC4AwAAAAAE/O//3//8m5bp75953ky0+Amgxfxn8RHc/URQNqmjtt+2bQUhXRsqUvy9uJdwHuBzqYTEjyzvCpteeJYJepUoqDrmSGA2Kjb24kIlGs9Eg5FQzQtQK7FVV9CmxO/qnyrD+10J+c4Kq30b6NiL6vORqLZ7RuQaiZHteejmj/Z3Bf9eVNix7xkR048KMz+F0QUJGVcJrd+JzkKBs2JyZeMIWb8d3ScyWyPbOxwR2tpyj9TRWh/qftfNrz53yowWBURlVIsFojpQ93plU+Wx3zuC70pIr8Y0vgzl5+L+Rqjzae13xoCVj96Pzv1N2cnOYXS80fHfu2+95z30k+/PAK+BCsgxgnpXudr1YnWbZ8QXFbnd2hEifzofAAAAAACADwWBOwAAAABAxDz9WZbpz00SsJ1wWT93oxep/PZ7R9StJBK6/NivSvg+wpkJs7N2EcEDrDzDtXBGBDsqYO+Ixs+iRFtH7axY0bjdNrnvmWjabz8rnMrEklWervgrSqvSdNJVeWy+LL86N520a/ojRHVUiRk7ZY4cc1eAd4QjItNMmFkJObOFMFdwdiHHkbSRIDZrh89wH8i4yr/qGqrSdekIgY/YsIz6N7pgRpUV9XXVwieVPlqkMtIvR8Jmla9bjsqXCZAjKvsjCway+1skGld5vai/44/CL6Cq6lH5pGx0xOV+n/2sjtvatWJ4b1+14epcj1wLUf6svKwfycqutgEAXPNOLbLsxeVe0G73K+G6D7hRfe8wzzN6BgAAAAAAgA+FB0IAAAAAgJivWevlJkC30YRuifYTQJZsMsdHhrf2IofWXH6SaWuzP5l1Vig+ItC/kntGoAd4Lx5xrYwIxo7a81E+M/FnJfLr+tCx6UVYkZArEuV68VrkayYErESfypavT58vEijaPP54/XFUAsDueRwVJtr8HYFbJI67An8897geu2L9zuKQewrFozY6KtQcEdUeRYk6R/wZLavDEbHts3CVf53z7PvVLN29GFnIMIJaBBN9j+5fowLbzJcRYXq2aOWKtq1E2EftnW0bVb3c8z6zEt3DVb/mRerqn7IbLSzJ8lcoAbvy1abv3OszG919o3QXjGRlP/b5GgBeh5H3YVFE9syWf4fZsVMRBQ3xn5fNf185l2X5d7hgAAAAAAAAeGkQuAMAAAAAZMzTNM+z+RoL2W0atc1O0bQno5QGYt6Wo0T3dnvm3+pLNknVjQw1MsF2JGITABzlEdfaGeF6lxFRWCWwtvuuFKda4VhkvytgyvJVEUoz4fji0ihxflfwrETuUbpq0YLdFi0u6IrYOiJH74NK32lHPm3mS+bDGZSA0LeRSIh4D39UGZHIcbTv6C48GbGZfb4aJS4+I8SFL7JrPjq3kQBYfb6CR497HyHkvkKYngmxr/DF3ueye5n9Wy14GhFUqzGC8ie6//p9kW/VYjFfD2pMcAWd48ryRWMVu81z1PfR+/PZhVT3WNwAAI/mmd5jKV/Uts57TJtNvbPMfpWy+y5S5VMR32/7p58Sp3MdMAAAAAAAALwwCNwBAAAAAAKsfMBPtqjvNtrQRkS+7KMcqajnNhL8z/ZQD7YV3Y+ifmLY+3bEflVPR+0CwLMzIgS2HO0HKlGd7TwjUe2oqEsdoxeaZZFNFcrHTIAZiTizdFZ0Hx1zJTD3dkYWB3TKX7dlfnXqeORcdoVtIyKWM4KX7sIHuy/bX4nyKsH5WfFO1SccFa+eFRgqm+rz0Xo4Wm/3Ez7Om+p6HlFWDy9uPeJ/R/ye9e8dOgsvMnuqrxvpE4600+haquq5s++sn2f7ocX865z/6J5WjTVsOdam8l8dixKDW3uRWFz5vX1y3Y9zsvGKOh517am2kfXxnXFWdg1GZVy1KKhzD1XnpzMG4jkX4F159HusUUH9Yf9m+/EmZPf/qX1rHpvGB/lQ/qn3otv933+XaRN4BAAAAAAAAD4LBO4AAAAAAAHLNP2Zlq8xc/aTvNHP+f5sd7uzn/+NJnY2eZabYGCe9hNeVZR4O+GkIiV1J8T8zwcDAMRioatEripfJRqsyugIgaOyrUgwKisStXn/vHC7K5rvCDIjMWNHkO+FXJXALRIURosOIrG5r9dI6Jd9V8I0X35FJACN0lXi1MjvqxaHRPU5whX39EqIfi8fs+1Vm/F0xfS+P+rUn7oGru4nr2BQVHVX7VHnfPxWXZ1ZeJH1vR3h/KjdyM5oOdm1Fl0H2f1U2YiE7lHfbvdl9yzrj++zs3t5JGS3+yshubc1i3/KT19uJI5X6fy9tOqbfd37PNX5iIT30TFNIl23rVfC+NH7UOSvKjMri2djADiH+qXGSGw+atN//t6wK8f+WqOKAr+Kzr2wPSL69Ucler+9r1zHl/SrAAAAAAAAnwoCdwAAAACAgGVZ/s7z/MdOpESicz/xM01xpKXuz/n6Ca15mqd52UrbJ1eWmuSqxOdW5B79xHEm7LfHnE1UAcAnk4nLImHXqLjJfo8EapWorxLBVkI1m74SqakylAi8IyL0grKuuDoq2++zVEJcJfRWou+ozvxx+bIzP7wgT5WlfM6I6uCIwM2MG+b9tn251TVwpI2p70pE2xH5dcq5Kn0ljuxsz9rLUdGMOk9HRPFHqdv2skkyKpAeFE61q9H3D9U9QuXv9vEdRsrwafznkbakxMPRZ3XNKjG3yuvLzOruSL/jxdNnRWjVNaXqKOuTqzT2vqPKy86TGsMoO9H93d8js+uuul9Ugm6b3rcVdf+25zNqW1UfFI0xOtdWdN66Y5zqGs7GRIpsjITwEgCuR72Di969Zfn8vm6AChWx3SUI/cjeh3qhffaOdBbbAAAAAAAA4LNA4A4AAAAAEDA7EYKPdh6Jwbd5M7t7mxE/kz6z3abL8yJ3+9PANm03Gn0UramLijA/mgcA3pVMEHh1P9AV7521vxIdUyXSjmxUgreOuM+mj8R8kZAsE8h3hOu2zEpcqcR6VXuIxO3edpRvzZsJVtV+L060dlW9ft+DF79d0RHMZgI7m39EWLimqQTOVwiMMwGv/XyFaDbz4bgw+ljU8s41p9Jmdnz+s33dPevclqHrP6/Xkb4zOoaqfU+N/SrtiLA86xNV/1n594hzpsrOFiJ0UX3rKEoUXd1Hfbqono/6FKGE8ZHvSoxu00e2VzKx+BHRdjVm696vK5tV3keLHTuifAB4Rx7xfmrklxWzd3pZZPfRd3pR8A4V2MK+d4zei44I63/SLt+W/iBnAAAAAAAA+FR4IgQAAAAAiJg3f+QkjZrwySZ0snwR8qeDTaQka0sJ0VXUJZ/WR3E/OoGnor0fiepOdCaAT+Rq8Vhk/0wZXaFxBy+Yy0SulXAyirLaEe6t+1WaM2LlSpBv/1rfO6LprK67aUfOZbRAQJV3FV70GPk7UufKtvoebbOcvVazhRARWfv1n7v+VaLMetvSD1seUImUj/QtnqP27tm+V7Q/56q14/cVYvAjAviz20fK6Yq8FdH9pOtD1A4jX7I+qSuY9veVTn4lMLf4/kkJ8aP7lt9f3XdsWasofRb7M6KxhLdn773TFNfBVQtBRsdfUdvIxPojdq+4vs7YAQCoqQJiRAEqPNE7Sv1rjbcAF/7dYSVY70SXT9/17V59LtPynXxZFvQMAAAAAAAAHwoPhAAAAAAAGT9zL4H4phCDjwrFz0RJjyay/CRTFI292t/BTnwRhR0AtnTEqSrdGZF1RKd/UiKozHY3XSY0VAKwSKRXCeRtGuWft5UJ5L3IztrLzldHhFYds/LZfl7Ev8xOtM+L/6bge2ZL1WE3r/clEm1fKU4+ep/uCtJt2myhQed8K5uT2K/aZXWcI8ej8o6U1bHnfblCQBldl1cv+Bm1p85/ttjnHnQWj6h0V/t1ZlFDdS5GRO02j+/DM0G3Qt03fP+tyu745/3q2FH5R+rO18nstlV5qmuvanO2XPU9E3+rNFU5/rM6zs42nzfrc1UdZXWd0R2LjfDo/gkAnoEj78eueh/WFbln7ybtO77Q1iokD+x03n3aoBnqPeRmn7sVztP848Ouvudp+u9///ufsHAAAAAAAAB4axC4AwAAAADEzNM0zeu8SzYhlInCI+G5opoE+9k7222LS6N/pnj1ZXSiTUWn79iI6uNQ1HoAeAO61/UR8VAmAq/SV36M+m2FbErYZtN3hLXKj1UgWAnII5F0ldaWE4m2rdDRi/4q0eCI3ypflE6JMSNhYcc/VU4lnjwiJM18UO3KplXC044ANWoP2Xd1vrO83t8oTcSZ6zdK74/HH4tqU5nPmbD1CFV5Z6mumSjPqKC5sqnSR9tG6zQ6xhEfOumOnGt/fjMh9WhfXaWJ0nfumXZ/99qPyrPfo4Uc0TnM7Ki+0ffJvl6jhR/Z/dqmifpLdS+pROT2WHzfFB1/ZKt7nWf9eVWGHRuoskdE9N0xWXZ/694vRtp7xKjQ/gyPKgfgM7nne6dRUXwn6rl/F+cF5dk7uG609dnk6f7yZOf9pvVxmZa0K91Fm1+maZ7pDwEAAAAAAD4VBO4AAAAAAAHLsvybpunvz/dkUsdPGMWTRfNmomjdFv3kb8RN5rBN7yeNov3V8Xifo+PKojtl30fKBACoyYSAR8R4nkgcFvVVlSA0Eqtnoqlsf6fPtGI8Vb4tI7KZCe6UEDsTZ1t7XmSohHNKXKhsZ4LdTNDsy1VljZzTLJ0VR6q2Eok+o/rzdMV3Kl32vbKbXWuRsLQr2DxKR5yuxLCjfUqUR7Wnqn+4Z51025bPU/U79xTlZ1TXT4U6hkqIfCVVf6vK9v1m5Lft0yK6x+ptdfq4ymZVbibYjsrz94Z52l+zqo9TZav+KhKuV75WPqhzp+5/XlifCfj9vTgThWfC/PX7yHVl+9MqX+fePYK6NiKOlvXI/u63+laAz+C33zuNREWfpv17OPXeUQngLfa9YycARva+MnqvactW7waVLe0HfSAAAAAAAAAgcAcAAAAAiDFz/V9T5f3JLzuZ0xGAZ2mVT1vJxbybmOpEZzo6macmsWy5XljvRfUjEe0B4FO4p7jgnv1LJHbtCOiy/UoIF4n4pqm2HaXJBMlKiFt99uLtyW1XZXmBubfdEVRHdZEJkbP6i+pf2aiEfL4elW1bxlGRn1osUKW3PmZ0haZROeocW1tRmzvSL1Ri50hY6n2LxLyZMDWzbdN0hMcR914QUBGV0ekH78VoOdt2dwsIWonNO31hVp4vx2wJD8H3M52+Xn3OBM5d+96u2j7SPqpyfL+Y2fZi7qwPV8Lxzr1H3YtVv2H9UPfBTn8Y3VOy/jM657Y+KmF+1lY83TSd6yNLF93bqvq7B0faMQBATvZ+TL1vq4JjqO1RGV5s7t8zRr/m6MXrNm0l2F/Tpu8A7XvP789EcAcAAAAAAPhcELgDAAAAAESY+ZOvqXItztZZdbrdT+1OTWF76Nd2gkkJ2FXEJDUpFfk6QjTRpoTvPt/RMhUI5gF+kytEqY+k42/mX2dfJNj1ItqO6C4qNxNzV/5VdpSIrCto9EJFJWbzxx2hhIk+vxLDVfUXifoysaPdXrUhL2jOBNO+XJtG+ZcJbTvtxvug6uHoNZ0J1SPR5dHyOv5E25Rw9V5+WO5rf0wHdKStHLF5BWfP0bbdLctoXa15s/bd4dbelrKqIpHv0fKV2PqIvay/6PbxVoSt8nTubVmbUNd1tcAk6hOrc7AU+5W/Nk3Uh/s+qnPfUWVX/kV14oXyUTmde+EoUdu5Uog/6kvXbnSeEWkCvCvd4BYrIyL1jr3MTiQs/3mX6Ioc8du+W6zembbeq4phCT0nAAAAAADA54LAHQAAAACgYt4LsLOISTadNjdPSpDe9cXbUmVHkdrVzwFH4vLoZ44zVIQnFT0+spktDDg6kQcAj+bVFphc6W8kmusI6kbE7T6Pst0VDXdErF1BqRez2/zKHyVw7oi0u4sSfF1Gx9UVqo6Um52bKdimyvHi/cyfrli+quPqHHeIRHxKKOnFo90FD5V/VbutjqUjoMyu6+h6GKWb142zhoq8Sjg9kv9onYz6VZfTq6ujCzGyxTHT1FtYM1pXWb9pBdJr+z0i1s/E8d5vtb0SjauyIrK+Pav/TruP7t+ZGN/vq8Thvmwl9lf9iT+GbAFB9F35YP9Zv0baYfd66Z6HTp4q39UcFeyfvbcBwLPSjZ6ekf3a45H3XNaefRe4f6c5f3dP+l1i5WOW3pffid7u7S2v95IBAAAAAAAALgKBOwAAAABAQiW4jsTi2XcvAq/K2he+z9+ZeFI/I6zSKY5MpPnJs67P58pnzgsAjnCFcCgSmWViplW0dkRcqARemaDWCuwiMVklLPZiyIiOqNqmUzazusj8i75n9v3nSJzu60cJByubnq6YtSPmU+L6rOzMXkcoeYSOmDVrp96f7LsSvR5ZCNK5hiuiNEfqcyRP5Ht27XXKu6otjNK5js6Uk9k5Ww8j/daRc5IR9XfVIpAzdK/zTp6s38iE5mqb7ydV+er68AsEonxH69Tfd6q+crT/U6h7uv3u/3qf1P3Hfo8WHniiaytbXNC11b2fHOGRz5084wK8Ot2ADaUAvGE/itKu8sxuy5TYWf0bfU/q96eYbn+ZFnsr+pdnBAAAAAAAgHcFgTsAAAAAQMCyLP+mafqbpjETOH6eJouuHu3LyCKge/G68rGy3RGRXyGEPxIZvmub6HYAn0YkMlORRzO6wsNs/4jQsSvUq8SWmQitU7YSxFeiv0w0rcSAvixfXnSeuuekEvlF+axPanskhlb1lx33FOzL0lkf7L6rxNDedlSnSqyYtd1Roe+apxL0Rud4xJdKiB6JVqtjzhYEZGXZMu6VZ02bCYnV9az6FuVDdOz3E2LO85H6XtN38oyOI6P6VWLfaL+/HjIB9YhfyifvS9TGM9993ijfmiZqT96nqMysDfoysjGByp8JqyM/vW3ve6e/ULbVZ1V3/trz95+sPizVYoLOsWZ9cXdbVHfWh+jeeWQBwW/DsyrAu9ONbp69p1tF7uoXJCMBfPa+LBfN7yXutkwfPd77nf0SZPRrjuH7x+S2skwLAncAAAAAAIAPBYE7AAAAAEDMn2le/nxNr+cTSMu0TNOsRecq7SYS0aQnfOxnPyE1z3riyJfhJ5TsRFIlLlcTbt1I8fY/u9/+PfoTywAAMUos1xU1KdFUlXdEMBmJpSMBshLrr3Yqoa4t14sAfdpMQBaJX+2+Ssy3iH++PEt27D7diCDSlx/Zi0S8kW0lOvRiwKw9KUFfVP/KF3t86pxE7awSPkbH3hG7qrrORIzKn0wwmrUJ70uVJ9rfEa0eFVpeJaJ+BFXZVZu+ltuPGPlrqvKxW4dR+676XY9qf5HI2l73mQBY9Z9RX6dsqGutK6juCtOjcqPrXPV/HdF01J9F7TG6b2V1YfNH92qL6ouj+2unvar00X0sOg6fPzoPiuoe4T936zTzoXOfys6Dal+dPuKRPIvQHgDuRfcdl3/Pp969HX1f5t/5re/e8l94nKZ5nofKVb/a6N8F2vJtOv/ZJK6H4AAAAAAAAPBRIHAHAAAAAAiZl8lqadatbiIqEpGvaZS43OPF3t72Xoy+tZmJxbMIT62fCHY+qe+qbDXZVU5miXKq7WfTAsBvc2bW+oh4vWPr3n1IJKT2IjblTyW0i4R+VnBu00X+WT8i8bYvNxMpZ2XM075M/zkTh0Yi0Ujs6MuzflRizqhsVZ6vN3Wc0XnOlB1ZvsjvqN2oelBpqmtI+ZuJVzNfbN5MwHvkOt3bneWhjQiiR/yK2tZZztjJBLWT2662Xak86oiI4zT6XI4wKqhVVOl9v+HLjQ6iuj9kfXTUN3eF16rPVLZ92bM7J9X9x/ug+h67bUQBl/W9Nn91v8vE5Ot+dY6i8+fvJdl9Omon6j6myvKfbTn+WKN2HF0j3XtJ93papv25Uu3D51Hfr+qjUFkCvBsj78OuLnelG9ndR3T3dhT2DaQSnOt3lPuAFXub8bvHKNJ86xco1RBpue0CAAAAAACAzwSBOwAAAABAwGz0BTICu0NFMbefdz8xXKhwOlGTrL1qEkxtqwT3SpBe5e1M0FU/n2zzdvJUPgDAs1GJkI/YO7KvStsRHar0lQAu2leJftX3SpAZCYRHhLaRMHnd3hW+RnWYCelsO8mEdZHQMMobCb4jKpF3JQpUosaOrUqIqpQgURmRyNV+V21XCT/zsm5jHCXkVHm67W9f1q3Mypa2sVvJOHTNKjFs1rftBcB9keZ3jlCQ79N2+pNqe5TurJ1b+u3xVP1s1Ia+x9z7k5mW3SNr95mN0bFoV0Cu2pyypa73qC+Pyuv6FvucnxJ/Hag+pzpPXRH3+l0p56J7SKcv8Oekc4+ufI3anPU/61uzcqwd698SfFb7qn4muy91yNq1Ou5OOVeMNR8vggWA+3ImSnqH7L1h9I6sEpBH32Oxfkd0brYt25zVsaj3nlF6n7cLASwAAAAAAAA+GwTuAAAAAAAVSz6hkkU2V0RRzFUU9/W/n+2LnnBSEdyjiPLeTxvJvYoIlUWKVzb9MVb5zqa5Is9z8er+A0REYrIz9s7sj9IpYVwnf6e8jri3IyauxLEde6NkQsBI2LxuU6LrTJztBZBKZKfEiiOLEyIBpLdVifq6RGLtSMQeldk9n5GdjlDW5hkXL+u86jx2RIq5OPw2PjoudjwfAXy13ekv1rR7IWkk+p7nSjCcC0NzcXzlZyftSAWuovSoLL9tpF+NrrFHUF2367bomhjpr7bp57nq/2f3Obp/VPce1Y8f6ROj/i+rM1vW0XuhzRuJpKP7lW9bUdv0daz6uuje4vP4Pk8da9Tf2nJ8nmybOk5F1udEHG0vqoxO33C2rM5YDADeiaveI1WRzo/+mqLdPhLV3QeymHf3o8l1bft3elXU+2rRQJQ3zDN/27xmkA4AAAAAAAAvCAJ3AAAAAICYP8s0/blaZOwjumdRmH7yrOofoUexEZJkXrN/ta+isftpKBV5qRKrq+jtR/Kp7Ucia71+JPdX9x9A8Yh23RUKjnKlaDISxNnPkUjtrJDwSJ6sTiMxb7TdiwkjMbwSMitxdlQfXZFxJPSuxPe2HJVeie8yn724fvr5/KXpyI6lI+70IkifrhKYdlhFy5lQdkTcGJ2DStRYix6VTubL7awe3JgtPCXKRtZ/7Otrb3txEcqVSDoSfH7V47IcEWpGQt8umTC22z6qa32/SKDmSJ/4Pa4V4q84fSScVv1rV7Cry94u8sjawz7vNp/6PLvtkRg6Kie7T0T5KqG290/1n8r3qJzouKJ74Yh/Cn+f83S3KTI/lR9HUXWg+rwzNn+LzhgDAF6Z3wiIMPKOyr4z7L4zi94JRsE0bu/9VPlxORV7EX2erjwXvBoDAAAAAAD4WBC4AwAAAAAELMvyb5qmv2omRU7SdLRlIn8r+pGZX1cidP9dRVCPhPTbCEy3bVGUpk7E+mgSbuQni7M0IzYA4Nm4+rrNBHNHheCdGfQrReZekBflOVp3XWF8JM7rosTc67auKqErBrfbq3MWCRq9GNLvjwTqlQDSpvXCSF8XmcDxtv1LuDoielXtJhLyK1GnqlN1PlQ+VVbWrkfFyJld64cX4m5t3Or0yHX1PQ6RWas+SQl+t3W7LN62PyeRODn+/iXKro5XXQtefF3l7dRn55pWfmRCYf89E3Z/j5HTphfX8c+607nqe0YFytn1GYmtVZ8Zoa7RTKBc3RNG+uDM1kjfttqKznm0rep3q7Zd9f2d/JGfHXvRufbn0+av+sqrxh6+bGUjyvfsvIKPAHA1s7zPjFFFOr+VE+evoqFX4vEoqEZor0imo79v93nh/M7fZWunHcX+v8u/VkIAAAAAAAB4OxC4AwAAAABkuLmWdGJodmmSpH6SyU8GrduqCOjRdjtJ5CeX/ASSmohSvll/lCi+45eaxFKTX92JuNeP0A4A96ErzKoEvEf6mExIVvngxa/r31GR2NG+MRNKRvXYEeN5YfcRUXFHQBeJ+6x/3g/vaybYtMfhP695I1F8dY4qwW/UDpTgMzpufxzWt2293cTQyt+ojpVf3s4o27q8CW8617g6v36/OjdRXU1ue4WqY1teJOIWpe0UR+OC0lt0+qgd2c+RmDo735EPVX/YaR+V0Kx7fW2Pa79wJOub9m36K6J+1s4jQXhVrupPbTpV377/idpcZtteY/a4rM01T90eer880b0Ozgiuo360qit1b/DXR+fz5L5n7Vndo+x21abW7WrfSPtcUf19h047VnX6SDrHc2asAgCvRP4+qe4vWsEqinSdd2EjwSasjShdJFS3wyK9Xwes8O8yIx+XafkZ0y56lag6mGmapum/y/K3lwEAAAAAAADeDQTuAAAAAAABt8jpepLmZ6Jn2eZpRyByEz3RZNWymH3fRc7zNs1advSzwatf1U8WeyF7lMYym/3q2NQx+Qm1KPpTlv9KiAQP8MqMiLaqdFeImSIbo9tHyzzTL0ZC7qiszI4XP2fCSmuvK7odOd+ZEDQSS2Yiykp0qkSSlb9eJOpFkMovW6baZ9MoMWf0/WbrJoaO/FZldRht69t6vGlhlMi0Ixjd257n6Lx6G6PXRCayrtqW2xvu7tTnV3n7qJwqr2q/mcDX59N244igXszrF1d0+kfli+p/JvG52qeuVd+eVBnel6iu1XcvAq76duWjLbdq39ty4l8lUGLxuB3Ps7WVl+mPvRbGq/3+uFXaqD0sk66v6n5nOXLPzPA+VnWYlZfdcyJ7I353xzFXjHeOkN3XFTwXAsCNSsTeYeTdlv6lxb2dSgQfvRv06fTx6eNSxxFFdI/y/BxX99H1+7Y17wfsAAAAAAAA8CEgcAcAAAAAiBATLlLEvYrOD4oLy3xitxIK+ejvyn76U8EmjRXEqzRqgizaH5VzhOonnO9hFwA+mWeZRx8VZI34nYnZbZpMRB2VGwkgKzH75NJ40a23MyIi9fmPHPuImDsSC2b77LZMsFmJ9jKRrKrTiEj4qGyuvm7FxX7cchMxq7rtCM6r87qmyc7dKprv1EElMPUicOWXKj8XMe8j6Sub/rP31QqX6zKFF8Ff5Zu/rtY6zq6Z7b7t4op52pfr61Jdx9GxWRtZnxGdJ2V7pO9VvkZ9orc5u3/KdvQ9O94Idb6j7ftzkQdmzfuvW2R8f7788atjVHgBu2o7WX8Y3bOqe07WR0aoNFn/otpndW1XfUB2bXUZrc97UtV3ds58WgCAcap3cD5dJHpf06hfVvTv8HyACm/b/v1Ku3xtmW+WfZlKRO/3eZ+zQBstvm9z8WJJAAAAAAAAeHcQuAMAAAAAXEQkHu/k65JJ4ZTovCojizjf/Znhkaj13fRH6nHUj6PlAADEHJl57wqrzlAJ/yIB6RR8r8rqlq8EcKo+InFmtM3azcSjmb1KUO7TK1Gi98H7kgkrq3YRCTQ9I+K97xQ/SXx9ZILuSAz7nepHXG3F1rJ0lTvY7o/Ln/fMprWdiUczorIicaoS5+bn5kvom4lEM7G5T1vZsnaiPqASvmbb3ZZZtZ2o/1DbIsF7h0oEHJ2jLK29zlX/oT5736O+strWqYOof8+eLjLUvaObb/3r24C/VqI2O3J9qzTW/jTptqfq19uIyrRtwe+L2sLR85CV7/E+qfrJjvvIea72/bZiMeqvo7QA8C6MvDM7SxRBXQXQ6Pxqof31RZvHY22qtFX09ep4sgjzyo/KXrATAAAAAAAAPhwE7gAAAAAAMf+mafo7TcmEyy/Mc8cSxdiZKrq6irpkIy35STgfgUmJ4atJtizN3aLhX1QOADwjz3A9jwosVf7R4+gIMKt8lTjyqE+VKFkJwo+IVTNhohfPHqkrJcS0RKJBtT++i+/tVyJAK2RU4kj/uSdivInRVdkdwWMlovZla5s3ob1aWKDsdPZngvJR8X9mN/uuxNmKW7p91MorRLCdNErAnF0L6/ZM+Pw9ply29TLP0zS3wnN2RPoV3fqrhOX5edSLRTK88Dryyba/rL6jdqds2r8ZShQ+IoSOFg9E/bgvT6Xrnk9bv/46VMfTbWvZfTjqv7LPyu4ZsXmV7+j1UPkw0p6upFs3zzBuBIDfQkVJvzIAQkfUrXxQ79msTfXri/to7Pqdn/28D2bRE6d336F5oX5WH50AGPOMnAEAAAAAAOBT4YkQAAAAACBmnn9mea6b6Mp+brjiS3N2E19kP/XrI0D57ZkP6qeNq0hSUQT5bEJMTdgdgUjsAPArK45+OCqatn/99q7NTHydiXk7YnYlrItsdgT7XkxYEQnV7baOwK4ryu4cz7ovEiZGIu7qXHSE4lV9ROWv25dpXx8dMbgV0WrBs9YlL9O+zEjEuc87FuXdnhMvmvXiVZ8vE9l2fNqKtHu29razPPty/XmOhdb7hQKdBQOR0NoLblVde7sZZgy4ZPUbtTGbRmydlR9eHL6YtHu/NNl+Mx5evG+dNujt2Po+cn9QZahr0/dRqr/w+Ssxvi/L+lT57H2q2ptPH9m0af2xd+6T0T3I13Wvjeh93Xtb5FNUTlZnqswrBOxdW1faOCrYB4BXIHrPddZeZ//oLxd6O5H4XJUZCcQ7v6aoglJ4n3bC88St7NcifbmdbRWqjlprIAEAAAAAAOAtQeAOAAAAAJASCR5umx8a3X1jM46E5CezlDg9m2CLtlVRrWzkqOonlZVPKhJ8ByKxA8CWR/cJVgA8Qpa+6gczAXaXEaFhJoRW+ZRYdt3nBXWZ8D0SHGZC7lVcGNmOBH4+zzzt/VV+RiJHL+r0tiPB6eT+qmPOjkcduzoO64f31ws0lTDSipO/c21OV3R+O2JSJeq1aaK2UrWH6JgyEa/yUR/DTaAdiaf9efNtTaVTZELVbVvKROP78lTbjsqv8G0qwrdPu02lU22/Kya2bXB7Dve/XDBN+vxkomZVptpvydp4VEZUB5Ug29rJ+qJ9uu1CCZXfnpvoOl1c2sjPKn90bH5bdp+0bcG3rcrumj+6L0b9qCLrB7Prx/fdns61p8qL9vmyR+n4ck8bPCsCvAv2ndMoVbAH/+uFR8vplKX2Rb+YuO6vgkpE7/2s/RGfonz+PWL1i5GdIBnevvny9WdBzwAAAAAAAPCp8EAIAAAAAJDxPd+STadHYuwowtCZSFPrVN60zD+2op9W9pGd/M8WZz75nyy236ufO+5utxGjzvzs8c1HAHh+HiUwqsShj0SJC1eO+tkRza32R9Irgeu6vfKz2wtnImPlpxIjqvIicWTmoxcHZiJjL5qMhKSqrrzfkR+T+xsJfCOh6yTyTEFaVY+ZyNXv975+53LF70WxFiXS9fs9kS+qvChfJJKOyoq+3/Ku5e6jgH+PdX6KiMS96778+Pa+jPQnkRB6L5KNI/Jn27UoeJ4zH9U1owW327bl+w0vUvZ5Oudc1UlEVVeZXe9PVlYmuFbpfJkdgbf3UaePf1FB5c/6yMwv1TZ83qiPXr9n5aoyVR2r/m9NF/WZc5BHpY3qProOOn2RytdlZIzgy3iGsdYz+AAAz47/ZcJ1myd7bzYidu/8cqOy3xGcq7/2s3+fp2z4d33T8nWvP9KjVr/g6N9Nqu2Rn9//+/oKAAAAAAAAHwkCdwAAAACAFuNigZs0Ip+HaQvem1qC7GePbfSmKsqS3Wf/i9Ks9qOfJfZRpVR0qs5PNkdie2a7AF6BRy5FefSyl0hYNyJAHikrspEJGtf9Woga24+OrYvNr8Wr+vtKJg6PyISbSiyYiXczYXBURiSaj/L4eqlElJGNqC1V7SJL5/3K2rrbsigB8NG2pM7D9u+yZAJyIWKaIxGtT58LhlfxrxYBV2L2jP2x7EX0ikw0npW9CvKja3afVm/bisy/fI5Evaq9Z4JeJSTOfFBlqT5lL/RXdv2vFNTn3PvYEa1Hwn+VN6qvrK/tUvXRvj6VX97n/FrqbfNUtrwN72f3HuVt2OP3+ewxjx6rbz9RvWd1OTKuGGkfUXvu5LnX09qjx3sA8Ap4kXcVWbyKUt4pb2S7Sqfep3nxuApE4X2OxPX2vZt3K34SGgty4cv02/xCg+x9ow1mUS8oBAAAAAAAgHcFgTsAAAAAQMDsx8uVzkelnfoTWh2HfqZ3Bkz6nzpWE2dZ5KjRiTovnO/+hHR3AtFPfrV+1ths80J7AIBjnBESV4L3qgyFEtlF6SJhXSbKrMSY0efKn1psGwsofRpLLNPY+qbOjRdtRjaUuLBT/1n51bFG5y8q3/rayV/ROV/Og11xSiBZlZnVi7JjxbWRCHdxkdUzW+s21V6UCNnbqQTP2Xcn9tlVV9QOs3a6fv8WF82Ti7RuI6/7+vdtSbUr5bO6njOxtxJEqzag9is7lXDe+6bZRoVf/1aiaHUdVnamdPvtdGXtp2pbSpRtt1fXmhexRw9L3f456kuje4nq/7PzF/mX9WndcxLdi6L0UfmjCr6s3YxwT+Wgb/+/QdWmAeDdiETT1XuuM+VZImF99h7N+6ve2algFVE0dG9rE0l9rqPFR7Y6abL3bploHwAAAAAAAMCDwB0AAAAAIGCe53lWs+CdOaAr586tbkGIWfzP/WaTW9VPLEdR2lWEqCwik/JN4cX3e45PckX+KWE8k2kAv8mrio3O9BujYuyITMx5FiUGG7FthYFKNBkJDbs217wdEeS6bzaRpCsRYiWmVsLYSMTXEfB7W5EIuiswV8LVSFi8uH/eNyVCVqLmm1haH5fJvTmETNBfjQ26bbISNnvb6nij9MqfWfzbi86/6iGqS9UuOsdeHdt++7JMiXBebVMi6kzo7/275ckjcvp26Maxs00TUYl/q/Osjjkr07cde91FwnyfX53rrd3t+RoVf/vr3+7z272NrO+O8vlyMzoLFSL7kV8+jaU6Dz6t8k+J3atrIOuvM9tXM3Jfv0JM/9vPXL9dPgD8FpXQ2gvfR8TfWRlROaNkv6ho01RR4LXo390N3GFEAvSuqL8L7+UAAAAAAABAgcAdAAAAACDjGXSXbrZp+dm47t5GW/eTV1ac7iM9rdtvtvf5lWg+i8aURVSvfjJ5azOfgOxsr/LYCTiiRgH8Fq963Y2ISK+4mVSCyrXsUXFftl8J/CrBcSSAzcqPBIaVmN0LMiP/bvn3Il7lX1SfIwLJ7Jg7Ys9KuNk5z9W1lQtot/syW9t6WpZIeHxLF0d110Lmrb+VANbayRYEeLvOWks8rcTAmTh4W+6ydESwSiS8iO0q7yT+ep+CcduyvSa29REtAIjE1Kpc1RYWIXj3bfPWx+j6s+fe+uHt+bzLFLe/xUW4X+10zrPH+tY599F5V23OH5tq/9H3zHaVJ7svqH7A+hidB3v+qnKi9uzrxB+Dagvde6234X3KODruUdfcWeLnrufgGR7GAeDZOfIex77nUoEcrn43pN43RcElfLT2xf0Xpe8I6bWteXs3KIYpqo7O/ApkxTzN0zzPz3qjAgAAAAAAgDuDwB0AAAAAIMPpJeQkUXOaJY1iNKKJ+fZlu1lPZHlRu5q0U1HNI+G6mrTKJtkyQb2KpL79rkVpnUmxLGKVP551fyci1hEQzQO8I6N9xb36AS9M64jIR/ZHwlFLty6UENT389H2TNTohZIqv0KJX6v6657HSNi9uO9Zfn9ckXB15Pj9sUbCdX8fjgSpXkR9i8Z9Ex5XQtnI9+i4fD6PF8Fq8aYVa6/CZR95/kt4bfMrIbDC++DbWiS09en9cSu7XZF1JOK1+fPjugnRI1+9KHmT25UXt9F4EYpqc97+Lc1NB6XaRHU+9+dqK6av2nbcbm5CeSWujvB164/J4/f58+zbTSQK9z748rNrMqtz5aMtQ1H1aWq7/dUOvz8677rPuG3L2k73fhj1veu+yE7nPtqx8yiOlq+uJQCAmM6v80XvurrvgTrvddT7L1VOZiuKiu63jbyzy+zf3sv9GL/9HbhVd6O8l4RVk//mDwAAAAAAALwvCNwBAAAAACLmeZrmeaNvOiNWTvPO659gzsZoGOZpO7XjheQj5drI7Fn0qCwqVPenkm36UV9VBCu7L4sI3ymnM4l4lMo2AniAV6QjSLxHmVekubL8oyI9b9eKmvdl5QH7eoLmHC92zM5vJNDM6qLKq1CiyUpYGfkQiZt9eV48WYkpveB1+one/iXijUS/3ufIJ5/W+hV997a1AHcVUc/zTbj89VcJfbPv9q/apvZ5HxcXHX2Z9uczEmArvsdM4XUTCXf1dyUn8osBbj5VYvFKmO3tqvOt/J2mve2oban2a/eNXKf79rWtr/01eXuwiPqZTFnmxe3qus+uc2XDX9vKXtTGo/4mOo71s/dR3S86fXlUf+Y5YfHl+Hyd+tr6uL8mRu872XUweh+v2pHnkfrAo2MSno0A4DhHgxZU75T8eyhP9cuIKl3liw3EEL17i4JVdKOo796NzboOf7bN9TGkxzvyuPSTfpmmaflX5AQAAAAAAIA3BYE7AAAAAEDMTUse6Wq6Op2wgKaweqcZOi5oVz/DnOW1E2bZTx4r4Xu3jMim3+4nDRXdiFwdP0bF56NRvdR3AIAbmeDunn3Hve2vZDfVSKC4flZiTC2Q39IRylZ5u2J2K86d3WdlJxM8ZqLhLH0kGp2KNJlQ2Obzn5cgAndUjhKNe/+V8FvZ2/oRiW+tOPvWtpRd1ea8X4uxaf1TbSSux2XZtoM8RqWvL5V4cULq6Di8vVXAexPy7s/nYvz1bbkjEv6y0TtGf16U79rQ1u9MlK36HVU/6ppYP99s7BdKKMG4alv+s/VXn+OoPe7TeZRPfr/fHh2/8ktt8+dP9T9Vf+X7VOWzzx/VobLRE4Vv+w1VdtVPZWXZfb5vynyLjn+k3FG6beKIvSvtAgDcGBWbR3m9DR88InofNvr+RwWdiH610Yrbo19MtH5sIs4btcAyLZvutxL3H2Znct5vn3984IYAAAAAAADwoSBwBwAAAAAIWJbl3zQtt/iXSg8zwCwma4YmieY4R9dOFElKbfeRn7JI7377aq8Tsf1qEXlnwrD7M9RKxJ+J7BGrA3wKj7rWI3FhRxTdoSNSrMR1Wf6OCDwTlqr0vowjfkUiukpclw0Eur5EQttMdByVqfbdxI5fImVVTpSv60PlkxW5VwJ8jxeG+rRKHGvT1SLrWIDvfVTfdTvZL8KofItE6t9jrqU6b5FQ26dX9Vn5equj7XnsXNPKl1uZm18gGr58s/qIhOHK50zY7M9Pdh58farzoQTZ2TWo/Bm5Zr3PUZubfhYxxHWRXUvZ9TGZz16g7dP56zmra5Wv8iFLE/UtlqgPtduUT/4cZGT3nc511y3n3lxRfnZeAQCuJxK7V++pulHS1S8QrttV3izyu8pn32tlgSU2QvYg/c842ZWn0+a00+9ugUuw3XsGAAAAAAAAnwQCdwAAAACAmHk3sxLpkkIDYmbmqE4w+z5I9NPG1c8dR8L3kQmvzuRaJCRXee8lKo+i2fufiwaAT+aRfUB0IzhzQ4jyZiLATv6MI3WmxJCVEDJDiRX99iit2qbEtVkeLSjZf472R6LW7fetgDhbHGDP881fG+l8L+adzXYvplbCXyUIzcS76pj8cSi7ynZkT9WjKkf5V7X9TCQcian9/ih95nNUpzZNRSX89cL9yPZe8LuN/B7VY9W2I/F5tC0T+fv2ktXt4v5ZX7xv/rM6brsIJfJflZn5ZslF0fv+oWpXEVHf1xV2d+5lUZ/aac/VubVp6jYcb4vE/ZVv0TVw9joeoeOrArEhADwHWRCCI0EVjgq7/TsqG/jB+xQFiFA2/bs6H7Xd57V5MtvV8S3jqxFreIUGAAAAAAAAgyBwBwAAAACIWabJzL8oDUuiB/DRlTqTY6FgenYpDkwKzdM8Tcu0meSKolSpCTcVLUrlt5Hbo8nErBwvZlfRrqq6zcqtom3ZcgAANFeIy1+BTChqt3kqcbASqEZ5IlGvElV2hMeRv5lQN/M3Ejj6NCMCwkhg3BF2Hm2Te2GujiI+KqSdjFBeC+l7vnUE1539e4HyPI/6oESwXaGtz1eJpjvtTPVHZrw277dJ72ZbfnRNVALujojYb7PHnv2dxfaqrMy+FZrbvFFfUB279bPj2+KEY51yv8fIO3/V+bH7VTnqOonqO6NKE4nTFVG9rudIHUsmSld5sjQdv9R3b7OyF/mR9WM2zUg/3+mbnnUsw7MYAOyJAhGoz9WvEEY21u+RKDwSskf+Zf7792dKDO/zdX5VsSp3t29Z68rYMuYi8f1d2N3qjy7EAgAAAAAAgHcAgTsAAAAAQMA8z8MSAstmAumgkXDCKImkFE3MRRNadnJORXr6KTI5CJ83Q4nbo8jx9rsSuvvPIxOY3pdREMADQM7RPuIRfcvRMkbEzR2RZzetF0h2ha6VCFGlz3zx4sNI6NwVgkf+WXGu3+cFqNkCg0gIus+rBbNWNJuJZL1A+ObDPE/TsmTiUGs7EoQqfxReIK7szd/+GvHTUo32rBheHYNPZ8XB2zr+EpEb6dBsz3V1Pt3WeTL59XFO0+QWKiiB99e/r6GlbzuVYNu3kWibKtum8/n39be3HfmVnc/sWPz16332NtTxTmLfLPL4/crHWAx+a7OZuD0Tfq/XZ1fAbttQ5a/PG/XXWdvat41tP6LqOiJqM/1rbe9rdV10yc5RRNZ2ovTddK/AM4+tAOARjLyHyd5PdYTo23di8fu0SnCugkHYNFHgCPXriT5dFMk9C/pwew9n/VzHjXv/I/w7z1IEP3KbM5/nr/97lRsVAAAAAAAAXAwCdwAAAACAlGAO5R5TK0swyeZ0JV/6o/6k3mZiy2TzonAV1X1N50XwUTkelT6bJMvSj0Tdqn7e2dvrHNMRETwAfDLHl0fdn3uXEQmVq/SZaHia9kJrJay8CTR6t8qOED0StkQidyXqVX52fPAC2Uq0molcbT1v63y7bs7XsxJUbkXMt/zb47ht96JnZVv5nB1DdlzRObBi7r2/2237sr7yifHO7Nvb/viWZXH17P1YTJRqf2x7MfuyTE687ut246FLY7dH52YW2zxewOzGcHN0Xq142x/f3v7WTvca8+cvqpc1knqVLipfpYv6hXm6HZOypXwY6QOifnTbduI2Y8uJfLBlbG3qPreqzyyPrzdfprep7wXal6jeo3qOfMz6rooz9+LR++zKVULvewvGo/P8zGMrAPgtRt/VqF8S9Oz3x++l7C8eRnajyOwR/r2V+oVFa8cHtojefdk8y+b7Oh7T/pUR5Gd9TD/bsqFk9Kj1fStftqswAQAAAAAA4MNA4A4AAAAAEPNvM3UT6WmCiZrhCN8i+bIse31GMg/moz8pYbqafIsmvGwkdyUI74rko+jrSkA+8pPOZ/KsfmRRsez3LAr+1UTRtgDgk3iGOfzIByUcHLHVEYiqchazLRJB32wvGzVxx9+9oPkYKr8XQ6o60CLUW+TvdVt0/D7NqI/WT+9TVJbNl4mEvYjW24+Ep/67t2/Fz5Fwe92XDaaUSDUWeHsh+lYgrXyNxdW2rKzNbsX12TWoyr2Jqm3UeCtI3oqT1XHbbepaEYKvxe9Teb7sbsX62zL1goSsnXuh9r7d7O3tvBffK9H0+t3/E9Z3dRO146hNqGP3wnN9/a5t4NbedDsXXgd/v7+FUdbXtJ2Hmqzvqu4Pdp+vf9X/KNvq2LLzkPVdWTlH0h29N436mNG5dgAAHkf17qmTP3qv1f2VQlW++nXBKHJ7JZr3+aP01TutysZX2r0Pqqzh20A2hPJD793+eZqn6d9giQAAAAAAAPAmIHAHAAAAAIhYlj/T5OZtKl2JzW5zBmnLibJIbxXkz8TbR4Th3nZXeB1FYff+ZT9hHAnlq8jraiKw45v6PhJ9fi37CkYnUQHgHbmneKzTvygR80pHCKnyVH4oAWIlHo3yrd8HbtyyzExIHJWthJwdAelNNGyjWe8jf1uiOozE7ll9ZIJgZdsPTJRtK4T2bUoJpZWtnH30eWs/On+qHNXW1jRebL5Gq57NtqzMThvKxNeVqNqWrcr1bemr3q2ofB8cc3b/lC/dfkAJ4n0bVW2mU47Pp/JkYnVf30plpa4j25614HtvZ+/3bWFB1j9E5zvbLxViX9+WySyaGSmre+/wdqJrwl+H6txbW77f35axvSYjX6Pjq/pmRXV/sOkqW4/kzDPGvf1HQA8AY/h3JyO//NdNr7Dvqyp7/v2UCiIRRT9X79L8vjMC/Fv+eU0g0+9QRYqk7XeeyVBmnqZpngd+xhIAAAAAAADeCgTuAAAAAAAJ86wneZTOZzNxU8zJ/4Z4uSOa7v5scvQTzip/+VPGk44MNSJ+z9L6fKrsTBQ/cq4QpQPA63OluCzrEysBvdpf9bGRQHn9fPSYOuJ8v+1M/W1FyHv7SuSvfLAiXC/EjBYJTOJ7JXj3vil73rYWF3vRuD5mJbpWZUTbIkXOWldZvZgci7ejhLdKPB2dO7s/EpRnbczaztLqcn1U+u05ievhSyjtj2t/3Htd0l6IvE+j2q49//0+4mY6EmBv/d3Xpb/ulBC7ElVv/Z3n2UT/98eoBPtdEXyVZnELGkaE+Xa/sp9de9X+6HvFV33tfwWgumecHbd37ytH7gedejrKM4vHn9k3ALgCH8bgqiABZ+14wXj1C35Vmuzd17p/NIDEyPu5I78KuPlRpOXA+y0x9CyjvddDlmma5um/3B4AAAAAAAA+FgTuAAAAAAAR8/QtlDAkky8yYnuhe9gIuyMdQ6Kxumoy0PsTTWT5CFPRTx/7SFYqnU+rosxnE2qjPmYTjyORr7zNq88BAEBNN2psxBGVwSPKsYLVSLzbtTcq1FcCU5s/EjP7tHvRduzHyDnsHH+1aMD+9QoUJSD2n70/arBjoygrca7/7sYHi91eHbOyG6VR56UvhN3qrm+2qojRe8F+JmZW4nZLJkLutCVrey8q3415f/IsThxu29D8LfSvxOLT7lcIbsL527/4lwqsvQgl6L/VzU3Qrc5Bx66va3Xe9+VG19ysnjN2dkb9Ug8Oi2u/6npXtjOBdXVtqnqq+sPKnyytEsgf6Ru6dPw/K56/imfxAwDgC/+26Uj08chuJ3/1DicLpBBFP1fR2Ts+2zQqQIMVwfttKl+bnUt+kDZt34cmhxCWXw01TDmZG1+b/VgGAAAAAAAAPgkE7gAAAAAAId/RJpX2IdNoNDQpmwmvZcn1TE4nkcVhn6f5R88RicqVmDubgKtE5p2o8Co6ezaBV/mnylzcf7acSrivbKnPyl+itgPAeY6I695xcU1HwN1RS0T7sxutEmB3ic5H5Z+6+VcCWptGDU4iYa0VpMZCZu2zPz4vbN/6cYs+H52v6BjVZ/vdH1d0jroDNnvefV2pY9rb2B6r99dGlFbn0te1EvWrY/bH5/dl7d7bnp2PtrzZHKMSNH+PteZp2pdbD5RvdhNl02abb3fLpOtH1ZFF2fG29v5Xkex7/cfteLeR26Nr7LZg5GshgrreVf8TCb+/9/6Y0dfwzcaRPlGVra7pvd/7CP5R2cmzyV0VcB3bVf90xjYAwGdz5H2O3Tab/9S+LL8v3793yv76bVV6JWCP3uWp7919nt26u+hRxOY580yqhj7r59nu5h4JAAAAAADwySBwBwAAAADIyLRw9nOkV4p0O5nmoyhfTiAtbl9jAiqbtOsK3lWEdCsqj0T2nclA5bcSt2fC/TMoof2V9gEAbryDEO6oT9lN0NutROheoKuFtXu8gFaV3xVYKoGtEo52hJxKwKrEuVH+WPy6jcitfIhEmqo+/GcjR/kRPytbdps6B0p07G2pgZYV7GZib1We8t2LoNWxZ23IH4vaV+UdseVFw1+2b8LfeRcFcx+hfluuFvh/1cVNIB/5q65J1S49lUjct++oXny/kKWN89k62Ird/fmLxeJ77XVcD7fI+rb8EYG9Ga8vW4XabXGBKtf6FfVVlR9dsf/2+74t2XTVA9X3lo06r3NvUX12xAkR36/ZvqfPAACPIRKsR/h3Wuu2LL393AnikNlUUeDVLwF2fxlQ2bj9WWR5yheTqLct8WWI7q1IDrOXaVqWp3z6BQAAAAAAgMeAwB0AAAAAIGT5zzRNe41ad3ImS3d2dmZe/8yb713bKpLUSjY5tu6PIrBHePG7j0ylys58qaJEdf3J8t9LyF5NXmb5AAC+eIf+QIletSh0+z3rmzNbmQ9b8etWhNoVxUci0OiYYoGmLkeVEd38a3H6sgvRqOyv25SgOBKW23xWFFwtPojE+F50vi9D+b+NUB399SL57THKKpJ1a/N5PzNxsE+j2kUmMtZl+7LW47Ci5q1Yev5JM8+TW5Tgy+ps62xX4mLVvrfb4ujcSsBu7fs0cZ1tFzZYbn4ui1oU4BVZkfi6EmD7a8fvs2XZPsbbuvm7jz4fXWt7Mfw1fJW3vy5X8jbcewDrCPG/BYlzdH7vwadK8j71uAHgHhx5NxO9c7Jk72aqd1WRT6rcbvCETMi/ex8milfC/mGSqp6nef8M0SkuGuZHQ5eN3a9xzDs8/QIAAAAAAMAxELgDAAAAAISsoROnWAPh9/U0KzpvhUlrJGoDBqyp/WSbRU282ckyNdmnJvKyiFaVyD3zK4qw1Z1kjIT7zwyR4wHguRnpQx/Rn0Xicp/G/v3+Vh5KR0weCWy79aTSZYMOJbiubMZpvgSgkWjYfo7O5WonTr8VK0fHsvV1e26iQZcX33gBe2TD+2nF195W5KcXx0ci6ep417IqssGkKlu1x9u5WhYrfr8JnfcCaS88t/srsfe6v65Lv9jk5ls1AO8I4f2CiK9tN4H3Pp09xu3iDTP2HereojYU7dv6sPUxvib3C1o6CxOqh5px4us3vuZ7+22azNdVxJ/1w1ffn577+eJ+fOpxA0DE1e9bOgJ2m65jx76LGgmw0BXK+3TqFwojv6P3YyN+xsy74Uf4zix6vKqK9mv0tobj9N/2l2X5V5QAAAAAAAAAbwoCdwAAAACAgF1gRk+lL1m3RRM4o/oJU85eptKbFEtZ7Me9yDwSoldi8Y5g3dtTUeK9nUqkryYZs8m/kbo6s7Dgiujwzy7GB4CjvONClugG2unHIoFuR5zp85+t20z0mvkQ+XOGyo6tpzVicZVu5SvPXv+pxKO1MHsvJF3cvpuIWguevVjZiq4zRY21mwmGrchbn9d9RPPOecxE1rc0eURyP6CM6kJ9VmJzXyfbOr5FF/fnJYr4f7Nho8Pvj6MjVNaKp7j9dK/naJHGvIlWvxe1q+vitn/7SwLK547I3m+rjkktEsjSqevDn1tlWz3IqDZ0nLjdW7JzHQn6s3pRNlTfyBj7i6jeAeDZeJV3A0qwfZXvHTvV+yH1/sn/EuGIL1UQhsr3UTvdNJEXxkjql82yKW/kFmyLbT6uzfOMngEAAAAAAOBD4YEQAAAAAGCETN+hdHWRXqWjD8n0WC7dZvJJCNVvxWYzRvsJvvVv9bPOmd3Z/Nf1Kfrp5iiiVsdutH9kUjUT9StbfhJ1VERf1TsAvAOjwtnfZlQ4MXJMRwTpSsi8fld1e2J12YZI5J4db7fsTLA98tmLybs2rR/+OP3gxgvRlfB0Ly7e2vv6q6OEx+Lz7TF1RP+R8mZ2IvZ5suVtI5qbe/qPQHprS/uztbk/htlEzVd+7gXve5G1yqs+b89DXe/TJv3ehjrPsWh9X4b337fLI31OJMg335bpW9j+lT7WXG/P+Zo3L8viz310bm29VfUX+Rj1h5lv2b7o4WaM7S9CZP1R3af2I+RXCb+fKQ7fdr39dxN/19cQADwHr/pLb5VovBsVPbKTBVjovEvJBO/d9zxKpK7euWVU9ZC9o7qibWx8dmvelmWZ5qUoQw179oXoR62f8uZp5iYEAAAAAADwsSBwBwAAAACI0fNImThd6cCi/JtNA9M1szMx+93xRGF3Is/n8SJ1n36dWOtEc/did5/XTxpmkbYiQbma5KsE9urnorsLBHz0eZs+sn+GK6LAAwAc44p+rNN/ZeV40W4mzu7YzUS0maBztC5GBacdoWslZs7s++9e1BwJ4FWabHFBVPaWm9A0Es/bcqtzm/m4P5ZV6LwXe9vve4F0fPzrtu3+L1H6Nu2X+HdxoukIXyfWfiW2Vnm8wFcJ8dXxROfI+rmYSN2zESZ7P73v2b5JpImwx2L9tteTGfft6sHbmUyk90rcrI4n66tUXlW3WfuPbGlubXEeXKjRYVtPt0Uik4veHtnz58uK471fnX6v4oox9dkFBffm3mXzXAIA13PJLxU28vt3UNEvDdr3Pf49jxexZ++4zvgbvZs7977JHJcbaizL9y/5qGG1H1aNDv/V8Mna/tm+jKxwAwAAAAAAgDcDgTsAAAAAQMAyTX/b82aRpspvC3Qny7Ts9WvfZc9+ImcpJBTzVsRdTf7ZCTIflWrdnwnHlT2bz9rKyrcoYXkkFo988gJ5JYbP/PATmFV+m697nBmI2AE+BSWMfUVGhI9HxRdr/kxMqtLbdNH2TMh5xl9lLyMSYas0HfuRqHbdlw1QFvFZjEt+yt/a20ZF974ogbAX71bi12qfF8UrP7bbvMj+dqha0LyP/nwTDe9FulYUf1MH3aJZe1+9eH2r7fnKVwnap12+r8jzkUDblrNNs82zFxVvTa7He/NRR8rWQvKbnypdxf7cznNVx5PZ/yX+1jqqqJ9Q7T3qq/x2Va9qwYCyF+m9smvoqw7sgor94oqobUX9haKzkGCnYAv8ONIHZ32f9/MIR336Le491vjNYwOAV2b0vUqWR+XPgjFUZXZ8U+/SVBqf37436/ihAkFUjNftrIfq+/Vm2zLO3FbW4YIXy1sfELcDAAAAAAB8NAjcAQAAAAAiluXf7fP3Xz/hUmnMsnmYpg5gJ8QWoqNbcfMufTXxlU2OdSLBq7zZZJ2K2p7ho2dFE4U+Ovy6P4s+P8rIwoE1/VVR25UPAPBuvPL13fW9m+6CG2iadkQkHt3YI6H3iB9ReV7YeZWwQwl094qVTEeyFWkr0boVc2ciWU+gnBkQuG4jpGd5lGB/L+q/Has/D8u0PU9KkLwdMG7L6bBPF0V5V+JyLSpebpE4BaudrXh+Mdt2OaZpWiOAb+toK6T37cSrmPznr8UGvaj2axR8f9w3e9uFC+o87Nvw9niz62Nt7/4hIfJbtaW9PW1j39b2v3xgnxW610334cX7mfV3qu/K6qjyVUWaVz4p2xlHBfSvzKcdLwD8Bt33Fkfe03R/sVC9IxoRhqsgC+rXCCs/lO/RL/91fTzzfku9i9t7tcv0lefIo0l9i9efzTgQiTsAAAAAAMDngsAdAAAAACBiE+5yiidyOgHxlJbHpz+gNehGmOoQ5c0m3vxnP8lXRXyvxPV+8s/+1HM1qanE/t5+B/Uz1Jmt7jk4cq7UROQ9zjkAwJZrJAVj4sQRYfo9qFazRduzQcEREelZqnKUkH7+FutaAWsm4I7ErJVw1/vh81gxr7ebiWtHmEVkcSva7gwAK+FtJBC3ou8u+rgDvbrJ09m3nvcM3ea/RPN2oLt8C9Tr62grjvef9QIMVb5ftPD1L7Nty7ALFpTfTjAnj6sjbvc2swUdmRC8oxTr95XRgoeNxZ/rwfrTFZCrzxvrDTtRO4/zEvD1t6DiAT6VLCBAJ/DC2XKz4AjdfFFEdoWPxG7fV40EO6jSqqANo/VVnY9lCe7SZkgho7VXw52R7apsAAAAAAAA+HgQuAMAAAAAhLhZl5tmZ7tNTbpEepUsTVOrZcUdhycBlx/51m5XNmmmolZlP73s7XR+frkzcacmTjtC9I6PURkjgvhOviNC9U79jXBFVHsA+ASuEZXXGsoj5VTiXSUqz6IOj9ge9at7fB2xuC9L+X5UUF8JVzvC3ajMSGDs981uuxL7ZudLCfOr87/1cR+BPlbpeIF1xVY8P3KejiiCrGBaqZIiQbX1VX337a5z/WwH0/M8SVH9VyR+75/0Tm5dxfVxn6Pa1s2nbZqR83Mkj06/jUpf5/+qs+/x+bLd1yt3RVeajlAficivWoCy8UCUkadp6PbhLlDxAJ/Kle8mRt51qfdHKlK6Txv9AqL6xUL13irz1Ud6V2mVsD36FcSHEQ3Vo9tuZ5gRPdJEa/l2NudpmaZ/fisAAAAAAAB8BgjcAQAAAABCzKyKnWjxQveRgI2eTkSjro4swf6U8DzNk/kq82eibB9F3UaoiuzYCFbRhJ2a6Ksm/5S/vqzIlv1bocpWkeqjvB2qiPNdiMoOAFdybQTcR4ge13LWfeqGqtQTI4J0LfTs56/2jaSJ0u2Fy70I+r6+osHOKsDNbPnPkQpm79/2c1csrATNVthtj8Urbcw4YrbbzixyWO1k+SKR+DbNtg78QgD72Q9SI5G5Rp3Srzq9KZRq0fDtfN+iqKtFDPZ8OVFbq+l3FizM7p/3waWebdmqv9gP+m/nZhWm+zKqfkD3Jz6q+jxH4nsrao+u11GRfeTrPv0tcr+1UT2gqIUWHR/UdcC4FwDg2elEU/dU70dG3rN0bVgxexSsIHoHlL3vqgImRPu9iL4T0CGijEY/94M6GAd9Idu/0ba9czd7YboFPQMAAAAAAMCHwgMhAAAAAEDAl1xjvn2J9EJeT1RpkKI5I6tDU9qnb+HKPJvdTa3gYgQ4O6H3wBxWJWL321S+KlK6n7SL7C7uvwg7WRj9dLUv237vTiJmk6P34jfE7AjoAT6L4xFw79f35WWOlNtSUwR5rkp3FH+c0XFH4vIj58fW1+zEyZnA1atctO+bX6j5iYi+OKFvT7h7iwCu8s1BBHXrx5wI3ZVQ2teBOkY/YFSDPuVvJhbO0nlxuU2TDUatz5P47o9f2f/ankdRtz7uxdw5vh61wuqrHdh/dv/+PHlf9cICNaDXx6HSqbrPF4vcfFv960e4z+tye51k51565HwYodOej+z/bX7jvgcA8PwcfSdy5Jf5Vqp3UJ3gCev3KG0UCCEq09tTUd5tMIk1zZHFAeP7v+/n0ftMn1Qbzrf5Ry8/FLfpN2UsrbESAAAAAAAAvCcI3AEAAAAAApZl+c/PnIrSwCl9j9qWaTEqzctOO5REdVLlWLHYtKQalOgnlPcmt5HRbZ5uxPUKL0C30eJVmjVdZGP9bm34iUMfid7ur6JwVXVX1Wckho8iz2fcU1D/CPsArwnXxZ7opnQPgaIXVXdvvCtXiTMzum3kaFuqFSh7oXg06HAe7VxSYuFIbFzXtxdh78vLxPte0L2K1LMFAL6dfH32Yt9bffm0yu7y4/c20rYqcxsFvaPX8cfzdZxVxsUsFFD+TDsbW4G3GXPNixGLa1v741Z1tW9zXz4qPzrnvRC37dzNxf76XFRlfNXN2l70rwj4Mtfyvo4lX8RhPJm/2ngviv56LUSLALL6OdpP+2u7Urqt6eo0r8GzC/ABAGquWtB+1k4WGGH97t9DZRHUlR3/rid6r+PF5r6c6N2Uf9ek8qj3Tdl7NlUXnmP7zXvF6tSp95yL26/y1EPXsPw/CNwBAAAAAAA+FgTuAAAAAAAxf8OZnWjixWpIbIDHWNuy3+Z1O7EuZZoWI1xXOjWl7wrmhUYmILsTeuu+jijai8ujaPHRxKAq235fbUYRuPxEpY/6HmEnLyO/jkYeq44VsTnAs4Cobc8z9U9e1Jr51lFfdMrx2zptRK+K24tEq9VzHb9yn2yZN7GxF65nYtbZpYnrVAtwZ/d3Evt2lqRYet23LfNma3W7/2sFkch9+onivRUs1wLpPdnig47AucN6fur2bqOH722otmL3T9N+oLsrYbNAYE2j2779vF94sI9abwXUkUD/6zi2xzj/tE3rxjZ6+vcn054U0XHczr2qs52V74j4nZOvxPu+TdbXyc6D4a7xy4f9wodsYUXqwagDD7GL5g4A3onsHUPVXVtB9tl3Fdm7D/8ORr3jicqPghiowANeRO/F9DavEqxH9rKo8P4Yjx5PlDYqbTM0iN5lmuQ7U93HEzXE98OhzrAIAAAAAAAAPgYE7gAAAAAAMets1FafM7ttFqXj8dsVkW7MThwZ8czPZNeI/isoO5sMy/YpMbpKW4nV1XafJppYjETp3sfo2Cq6kdczu0eirl8VNe1qntUvAHhGHtlf1HKbfvpKiDvqh7UVC1fXtEoouRe09ur2JqrtCKi7Zc7fUaStHet/NBDKhdR7e1ZErAZUmfA5yuPLWEXGoVsFWyXPl/hY2TtSQCyiz+112pm3E7WPSF3kz/P3p524fd3vRdb63Kz1dqu/7HqK9uvzmZ/jnsD/9tkLtjcpg/wjfVTnc8X2wWWeR9tlMPZPsqho7V/pF7EAYLTPrrafVb+du19ds+CkC0o/ALie7nN+1QONiK3PUInILdmv4kWidl+GLzv6bt9d5QsFtu/SlGA/yqO2y3dTajyU3Ed3Zfoh2za5LkevPczxQ38xlPxav8r9DwAAAAAA4FNB4A4AAAAAEJEENyo1N9H2TJCeaZk6ZBNJyeRSJNS2+28u5ZN5I2QTjdlkYibGtz/97H8GOovIHkV9VxOnqtzIzhGORDsbLXdJZytjiBgP8G7c45p+/n6ir4+4UrUY9btX15cVDFdCfi8sN1Z2bt1W3q1212jlq60vcffiIkXvy1RlWFGz9/tLOOuF81v/v8qcN3n0ebYrCO+lSs3CTtbSMJ0uGIPsDnK/SEIJj+NyfXl+hef3t+UmnN6bjxdkdIXOaxvSbThbvDCSxqeN/fYRyL1bKmq8Jl/Msk9XpckWNKzs/T0ibq+II/x32+AZHqow/2V+41if/74OAOfoRBS/N9G7Ib9NRTavgi5c4ZMvU/kVvYNa91fvs6pyI84fsxorTN3h6HZfJH4ffYfqx7PciwAAAAAAAD4WBO4AAAAAADF+5my/10cbUvj9StOTRUYSkzvSy2wCqKN/EXarCOX9SF+9ibxt8ftoVrm7tUg/+ilq5VP1k9BK+J5ti8rs/vR0ZuPYZF8/KhgAvCv3uOZHbP6OUGE82u6Rm2iXrdA69i32IRKp2/1f/7Y2tlGd7aDmtv1m2y0EWwIhTHoMWx+XRSxkm/dpv0TOWjWzjfq9rUcdCTwWMSsft9uigWAm4PULCfSx2Ijoe1vx6sibANwvAuispKz2VReKF6HnA+Ja42zbhto+S0F/bb8j5lb1biwk4u14f5TeXmP7c6sXl2zTGM+m9Xyv/t8WnhwlW4xT+aK3rQsi8geeiHv2v/fmVf328HwA8Bs8+tn8amF4J7BAVL56Z5P9WmAU+bwjKlfvcFQU9ijCuxWzZ3VYBU5QAv5uNHxpM19LGBna55/FtpHh9G2osv3u0xT+LtPyZ3qfGysAAAAAAAAMgMAdAAAAACBgnuY/8zTXkzzrd6vb8JMz6z77b3KfPd6W06tvvgg7P5NcHSH9xlwi8AkmKndlCnuVWF6ltZOFI1G8fBob1UsJylWErSiP+glpVZ73MaPyv3OcI4wuNrC+AAA8L48Rod8HpR5pLnjaCLnFvXL5EpOvQvE12rSO6uyF7C0Xpi+BbSPVHInmt8L6/f5tWbe/ubB8lFgcnA3W9lHnd6mU7shEnbf5b4J+P5hczCIFda5XMfHWXy2CV+wXQGy367a1nvs4cr9fTLEey85akNuN2+a9rzdfNilDf/LFAjW6ratFGGpxg1+AsK3bfZT7rX19/cQLTsb6xSzt0X6wo7A7uu8YvYDyvT7tPfnYAweAQbII52cE8/4dTOeXA/27G/teJnufEr3jqgT32bui6BcCo+AN1TEp0nc66h2mS7NNN3+N40aG1dGwwA93Zrdv9Skb5ot3q8uy/GdZFjQNAAAAAAAAHwgPgwAAAAAAAcs0/WeapniSR4nWfXDD2e3z+X36aoIo8sfZ2UVvX+38bMpF7KqcapJSRcfyPxet8kSTf97XyJaPmJUJ4VWErmzy0UblUpORlfC8MxkZRQ1T+226w5G8BvYfTQsA0OPqfkWJZh/JmcLVajR/47+mvrwAei0ji2DdsDqtg5HMjI78Hh2fMhSJv68h1zh3y1qckN9yG7DVeurrr49aSOyF1iq9P8+Li5ivUILy1Nlt7nktZxV5d8TWnQKUeH6zZXMu7eKQbsT4qk3phQH2+L4WNqzX5y3yuxbA7wXymYLMH0e/jStb+88jNkfKO2mtZS5bNNAu6ayBX+JV/QZ4L66MqH4vsvcYnQAHNq16D9Oxp4IVWFvR+6MM/+5JvQtSPnofvPi9Kv+q9zOdd3fLZAXtSbn+sSR672m/279reiV4n1zaiLWZAQAAAAAAwEeCwB0AAAAAIGTZT6NEeo5oomZjLklrJ3w8KuJSFoXJfN/ZWaMfHZgbqqK323Tqc+jXlIvTVTpvK5qAzMrroMTvaltU76OR3LMJ0Sxdx96R/T7tK0yyA8Bnc16QeKr0O9o9aztaaXfbH0ewbt4zvyOP3wS4I755MX8W2tHnUeiBWa3hnwNxejVAcyKsjeB7W8/+WG2k9O0iAyUKj1Y7nm0f1hdl24yr1rHkkvu6sfAjTN8vgOisq7BNMxbTZ8dQ8dVe1K8a3MqbN8c8EvF9X9btPFozUV18LQzxDyTnBP6rsP6aPjN+WDq+bqbfvoasMpQFALicM+9cuulH3hcpIboKEqDeG3WCJqjvalskgM+CPJx957JMy7TMvXd31rNFletF6VasPk3727PargTvFSINARcAAAAAAAA+FwTuAAAAAAAliw4YGulMlAg+EsAvLp3an4h4ti5+iV/m9fOdJoDUJN0Vk3CqnCoSWPcYsyjp6nh81DAVRSzapsoeYT13vykor6LqAwDAOepo6ef7/30Rvi9XEe/Hy9WHcvS+cUY0vFXgqMjYHTHvj6B5c1wqY7YC8tsrI17f+/qV7+aTjxgdOdtd8DBP+SBUWF70woKbaHz+GmvuIqj3zpuO4F/zdb0UwreNYLsj/o4WHmR5rlpsoj7/1gKd+44162OKyv//s/eH7Y3jSJY2DDirpnt2enb3+f8/8t2Z6a7MtC3h/WBRCgbPiQhQlO1Mn7uuLEskEAiAJBAkDqHq+TXXl0YvR/ya/Mq+CyF+V+55fhCt8j5rH/0SH3tWVhGZ+zRskYVs4YXohYB7xe40zx5hOQtffQhVLc8+M11CThZeOUG8FlsQQgghhBBCiK+LBO5CCCGEEEJQ+mVSxUyksBWM7H7/14vY2UTPcJM24QRSN5+R28XJn13zjlvxM5rA27qFBebWDkuX2UerqHuBvJ/ItBOSbIKz+lPUlZ+bRvsqK7RnPGKiL/qpbSGE+GwctyLv+/V1txWtaQqwbfaFKYZdhbrWflGae0W5xwjkvWKGOYy2E5XOpAtLPewq5VhsjZQ8Vpg/Vy6HlbMNLm9lkjjrWg8rIp8HvVBRe+kgF5bffjlgXS+8In8j9u5t/A7E+P3qy3rbsn27qv1R1K7be1X19zp/5AsDe+3/yi9y/sq+CyEexUe/oB6tlF5Jv+SJFieIBO/2+dDsr+qh50bI39k2jp49VRZ3KJfDAqtsuEb5UCiJhOhLmuydNfveZfBcdF3Oxy7+IIQQQgghhBDi45HAXQghhBBCCEJv7TKpMjlBhLajSSG7atF184hXTdrO9mzSjmYmwqqLH2Ykeq/KZBOanPSTjtEkZDZJaVc9t6ug+33Ld7vNTyh6+2zyFE2kVich2U9k75m4i8o8aqJ0tlwhxO/I5xQW3L/q8Vpp8SixKQL5flst2/5trTaQu5fyUApXv7z99q26XYGJgUnqxNr67ULsM1PTzAR1pPSLwHpZAX69Sn9NhNt7v710sBFEXz4Bl9bnzGavSQOVQ3fw5uitrrGf22MCRF53XYC2frdjsfUnU2DlMNH8Vlh2eylg/SKBPe8e0+nw/iVi1pfJfincD0SEpeM2Q1bG+5CV+RE+CSF+Hz6bGDhb7MCDftGOvYQfLYJgnxVVFmOwf9lzIia6Z20eLZCwmyj7zKFf2THxHAuX/ed12LV9p5IJ35dt6J/NbzLcFx8KIYQQQgghhPiVkcBdCCGEEEIIwmjtW/OCITtJY7+7jKu/aB/6bm0N8G9JZMUxmS4GTSSh/YX5tWjCzvpcWV0p+znnbJX3mZW8ImF9ZCNbcZ0J9KuTydHPXs9OeEYrnmV1vYePmDiXqF6Ij0TX32PBb8gxQcfbytTZQI/sR6uEW5H/4/v4MbwgmIvNe4+E6DnbtkICdK+uidsTH5tbMLcW8CP1jss5bmLoN/tbP/jLBj6oXG+PXlJgq33i86RfVx1fRPNoNfAxrLC++hLD2s85LZMvI2qz2wsF67yzLzRsfXyzaeJF8kKCbTu62mro0/y10Ltti/tF/nU/tucmvh6z8/CIMQi8+PkBQ1tW5kf4JIQQR1ARkt9jyz/v8YsYIHG8LZ8tgpD5bm1EvzZoxfE+TfQMaIqjQnRn5zr22CG5u232GWI0lPv87Plo4Rnl5ZeEnkCJQgghhBBCCCG+ABK4CyGEEEIIwfmj2xkaO6GDhO72LwJpmqzWiU0QRXavrhXmeSJNVZa9F1bG6uttt6x8xapoe7Zil99uJxpRXvST0NHPRHvbqN5oWybOj7bdIxjfY2t25fcsz3vw2VajE0JE/CrX61pdsV9YOFPfSOS8+LSkw8LldboKWVpuuyY0vkd8bm2Q8QfWt1JmJ/6jlwdQ2SaeMMl756t1t7ZePfy2b7Te8QsGN9HzpczBV87nq/Az1dHW0LrN7XZ/Hnhufo0xrkLtyL9HvhyzbjckML8I2cZaAP8m9vYqrLd9678x6zbanr92P/6ctQ06X7Y3DPMrgvubGJbvmH58e876F1sw2+uoXt7XWez1y1RUCPFJYb+G5/dVbPiX9NmiBewX/lCeygIHdhsSrc8QLeaAVqKn9itNZ18MTOoZ1WMTn0YhMnq2yG5d7G0Wen7KRPE2Tn0Li/8cQ5oGIYQQQgghhPiK6GZQCCGEEEIIxnCTcUxTZcXpkUgd5YvsOl+2FCbZRltPKD0aIIQfY25FcvbT02hfa1xM71fzisrz6bxYHuVHovloBbDqSup7BdxVW2ziuOrHHv9Gi4+BEOJ35atd9/eKze1bdLdtW5G0+TZiESfbx4TLjKWceGX3uP5IcLrYY2LfHipt8jKvqcYiqF0LgfnK5VgcbkXSNdEteLnNidGXoqLj7H27HfdIfYSC0lvZrM3j1cRtuttfLLgfYMVw/LKAy70pw/q9zmdfJBgr/2/nFhKxR9cATl/h7aUH+x2laWmajVcbV3xwz1+GsDZmr/tb2ZHo375MkNkBArqSHztiz53C+F+TL1NRIQTgqPvsWTub5z4k/+wv3KHnOfbZixe327Kj5x/sVwTRauzsMxLO+1/zy+Io1G607WvvcbKCNuWNt4ecOT4cit6Z7M2HeFgAz+yjfVkaIYQQQgghhBBfCgnchRBCCCGEYEQTRX6yZbtgI7eBJoSsQH7ZlgnlTd7dE2KVSaOdE0szK4izFbf8BCQTkvs83g//3z2Tr9HPSu9dkf3IldyrPs3UY7ZMTw/KE0KIGl+lD5kfdNcCVEuHAs+9ok8vJN6f3/uChP2tMf93lAzKrLMW46IgjpWJxfle4Dxfx0XIfQsc519yyPNF9J63qa+nDaAXkf488QsfseDf+nbvidVb79tV0/H5Hb8csl5ZPj8mj1yVnJ8ry/kSi9l9/Vmavef811mRXQgh6kT32dGvsmUri9v87IV/+7myuMAevIC8kj5b0X1Jx8TqVb98G2Z1h/YPbK5V+fwdxxy2KMcSrg/wL7PFykZCehDrHfWLMkIIIYQQQgghfj0kcBdCCCGEEOJe/GSOnfyxny1eEO9F7naSxxnvqwzANhLf2/KqKzb5/BPYVbXYRJQXWtOV260vVhC22AcTk2zlLZ8PrcJuVwZD+VGabDJ0dqLzqEnhPaLye4XoErILIT4z8Qrkn4lZH9G4MTuWkPH6ruYqrtrZx0Z0/PZ9HQSgVeDf0tb8rAmbBxGgIyFy9HbjWKW5+ef3o7KWdEgQDTwe6/rfPo+VyDqytfVvC15tfpVikwaXy4+Djxsrx/Z2XZv4LxBb5wLrbdv7Fx3GyFdN39r053hz23LhP3+hpeCBO0fe2vq28XbMyEuQ7rrA5xxOnx3XfSvZH832pQUhhPgVqLzAv0fMnb0cn/kx81wDrY5ut0f7/LMdxh4Re7bNP1+KzEPfJsadWf9LXFzyL9ytRO5M6M5cCZ9purzWhn3n1cWl1V8YEkIIIYQQQgjx+yGBuxBCCCGEEFXQykNWPF6d4PETOH47EsMbTQyc1qno2pB94HM2KdcHnlRjK35Fq4ah75v0/WZ/EcdUV2D3onX7k9ZskjSqCxO0VyZSkV/vAZ8A/Zz+CiEE5ph+aEYbwcSXVTF1ZjPGv2l2lN1qmWZruipzVHitwbFom4m7a8LvuqB7vY0L163Avl8EvkgQexOu38q7iaHHGLd4ZvBjtxX438r2PtrV0m+fOzlXs/ZbC/IjYfjWPhZ9z5yfXsAUielnyojaGqRuvu23fjBjW7/eVi1/u1mI+yB+3a/ben3sGdELFDefgBfmHA29BS+CcHH8tj2P1qrd3w/OvrQghBCfg3t+iW7Zd+8vufkyIlvRAgN2W2YD+Z61hS0387eyjT1fegTXMoJipgXwLM7bhkLIoZuNLC1yq1JGe1vkQy+gCSGEEEIIIcTXRQJ3IYQQQgghGKP9+fYhEHz7yZhF6I72eezKRMP9s2moLaTcIt+ZL748K3YhedjEHVr1nP1sdWQvEpqzic9sxa7VilruO8rrJ0j9CmG+jmxlMzbRma32fuSqXHyidV8ZErsLIT4L+4UO86Jr9vleanVYhNVzgt6oLCburuTd1n9s0piczkYw/o1bmkXAnYnU/TYrAs4EzZGdSAT+ZneY9B2Wjcj3mxjH1MlvW4uJ++VlAC+aX3y0ad62v/kPXlYMykJUVui+tdntZQB0PjOseN+Vvtqfrey5pJt9QWWd3mYE8SY8X+2Fd7OR+7A+RkwQXj0+cTko7619va/xdbWvg5Sw/Bhqv2TxeD+EEL8es6uD2+cC6HlOZI89J0LPgvyznMhf/2t+kc8o7wz3PBfJXjaItiXhdO4XjUHHNo0Rrvdunov6Z5b+uWM3f/0zT1tG9JzVxOSXeFuRghBCCCGEEEJ8USRwF0IIIYQQgtHH03XGxU6w+NWJrpM5Yz2Rs7IFtnmbUTr43aqKQFl+G7PXzYSZzbdD/JD9JPXMT2djYTaYsCysXlWd5PS+WD+y1b1QWUhA7wXykcD/SI6agGX+SfguhHhfspWQH1BiKPKu4fNVV5VmAt5IMO0FxBWRPl+dvS5GXmPET2P9HeVF7bPFK2TW+Vk94xXbfR4fpHV3/G8Kn7fVrrG/vD3XeW5CdSzqX9vyQaj9t/ZjXZf1/t63ZWXthbazld9v5Syfx8qvvUJoT+UasufWbLHrcyrOnJ3jbwluL0dkvvQ7tVz4Fwbm8S9boJcvZqkcs1kkkq+1gdpJiMdTXQ38Xpv35mXPJ6K80bOQGR8qIu/s2YNfmADVIVpowabxiydEvln/9hyX6sr0KH1YGtpZds/FDO4WYIyxDieZ3SUNegbJBPIFf/tTR09LhRBCCCGEEEJ8ASRwF0IIIYQQImCRLK/wkzMuNdRdIUG8nZ5ZJoCiiZ+NQaTUMrtH29oB4va3zcmsVzQBVeSYCV28ujlbJR1NUKK0fhLRitV9fj+ZWRWoIzv3rtaetan3/97J1yh/9efIhRDvx++9Suv79zMzosCjxJvRKterlaHh/rk22gpul8Ck9jJBRbDbGq/7shp6JOqdXZGd7bdCXfxygP/uxdtjk7ayurZfydztheVHwuzqIbZCfrwaeWy78nKH97MqKM9WVH+EYJe9iDD7ywYZdiX9zN7UyvKdflltsy8VhOY6s7OGCd1n4avy3/q89xVh/9aDpRDiwVQF3/e+yP6oF+GjlcyZYHzvcwz0HAY9b/Db0DOX6FcA0TOQ7Ff0mI8sbeTDEZSeqZDne+k2xOYNxix9s7cK2LdI7M6+I5H9W8I/WxvSNAghhBBCCCHEF0Q3g0IIIYQQQhBuevO+FqMvZKsj+TxI5L58RrapkH7tHcSXjT5HE1aZf7DI2sxZtnpWlnczidjX+9lPXC/l+BXVs5/NxivJ56tuMSH9nslutpqab4+sHfdMus6I4yuTx0KI9+Mrr9J6lLh/r5262DoTj8eD9dHHeF1f+3bccQXFgvK4ThWx9KwPNg/+PK5C+EWEn/nk7awFxGOTb/3ZnxP7T2Yk5LerkcftaQRuV2FzX9lF6Y8WiR8BOm7b/ZWXCOoVYSLumdXP6fEZ9AsU1dfKwUL86osVM8cY16tPvxBwHF94sBRC3M1H3/tW7tOzZx4ojb23z8ThFeE6ew6Cns3Y5xxMsG5tZCvRZ3WJniGhtOwZkU83vW92OJo59djzxey5IBKgo+eLzJcZcfuyDdg6n8fT0BtpQgghhBBCCPElkcBdCCGEEEIIwmpeJRKuVwxZ7EpHfvLGf6arF4EyrA5twjc/medF49W6jjauZVdWx4JpRn1lrdbeVqZkq7N7kbn/aydTmT/eNkofrVx+1KrmVQF8tPra7MQ7qktlslcIId4f1/cd2BU9/iWB9xNW5u0Si+0r7fpoMWrVh2hF7sue66e3VdXXguStyNzig8KojG7E5bdgbWubvQWJvpsSevw9f1lgMjYgBisrvN9E/tsXBNiK6llZcxxxrW1txL9IEFga2+/bPHOC+sXOEdfhzDHZC36hJvYj2y6EEL8zH/VLadFzDvR9ZltUTrRgAPqFvNlFF/yzo1miFweyBRFIRjgcztQNitKjqiGzPlzzYar/V4GVE+03tp96H11vpAkhhBBCCCHEl0QCdyGEEEIIIRhjmWIZqz8b2ETNzGTPulz8vbLiI1ntCPp1mbQaw4jAx7iKl6Ym0az9hifs/OTjKo1ZTSr7mefVtkt9/CQnmxhFq36xOlZ+mjoTsNsJU7aafGS/4r/dHtlgPjIkVhdC3M979SP+5adI/NinRdL3pPFl+/z2L6Ky0nhmA9kiKegethp1tYyq2NeLdFEbd7MBCbr9auW4bfw54xPVxsveB2wbL2jf7ttYuthb129d1nYbLtfaCpxvi4/MftwG1s+lvvm5PFrrcbpb2lVpwT7k2+1vtqL8/WJ61qd0uK/3vvGLlxMdH5dybK+fdbnb68zuY+edtX/P/kqeuO/+/GRteEAJD7YvhPjssOcj7D7/iJfs2XML+4yiIoCPnk1Ez56s+NzaQQsa+EUJWHmVchlRm878+l1gBJY5ZdM/j6xUcTMot5vQ3f9D/g63DaW16TNxu8/2JDmDEEIIIYQQQnxVdEcohBBCCCEEo7dv6w0DC9f9PJNddQnppZCAHa1+RATygS4qLy8TwK+SXibRDhKaIMH2PdjV5pk9/3PW3h8kHPeTpJVVxtjPWfvJVfaz3+gnvCOynxJnk7sSrQshLA/X4h01gEwS16vmU1XMPSPG7H0rxGdlMTGzFbAiW3vhYvt+iH1U3k3ouxUv23rast9WVh8wfWW1ds4o19G2lReU72d50fD22ZdZPU+sLVgnIqyeOcZvtt+CyoqI/O0FguWgxmVhcfrcCbikZm2wPqcCO+QFE5Zm68X2vHp7mXT9EkedeuJqvaxf11ImfHrUrzY8fnxqrU23fwz7hYOKH8US9tn/BLzL8RTiN+HolcSrZc68YB+Vky02ULHjf3XP+ugXN4hE6mghBP+sBPm77K/+yt9sPd8FLzC3n5P4cB0ouXTRM8WlTPbc0+Yfbht9bjlWf4QQQgghhBBCfD0kcBdCCCGEEILSL3NTRj1emVSxKx1FQveSC9u8nfkzM4/GJrq83+8FEw0BR9AkIsuDJjDtRGW02ln2s9vWHsobrVjPJj/9RK6fxK2Ayp7hiJcPhBC/Bp9xpdwjRHCzKw3PC1dzkGA8WlWelY1WKI/K3Nt+sUi3xsxK2ItA+iaUrvqUp92WddyJjl88GOHKzdVfDIi2sfpVhOLL5+WFAtuEfIX7mo/WmBfhr30bmxc8mH374kfFP7g/OB8ecY3kfuKd/hcH8vLjhLOi9sq+jOgXCSKy/mqPT9PHdsR9xx6qvw6wSvMJx+Kj+YzxhhCflUcLpLOVzP3zh6rQ29uOVh3Pfg0Pici90D0qN8I+a0F1y/yKxP+0zsSlhxxrZpIJzq/fwUPCSAifPTu0Inb23BI871zlReUKIYQQQgghhPhySOAuhBBCCCFEyqIyC5LsEZezFZXsdrDy0WY1y2h1JO+XX7XJrpiU+XsH2YSo9SETZ/uJxEg4ziYrs5+V9uJ1P5HJBOuVCVw0keonbL0/bBU0X3a2WntFvH7UJKuE8kKIPRy1EvlMuv1l8sL86ux7V5Wf9e3e9tsveO60rnx1eC5yra9Wvs1TaYPOBDUgna8nKZ2Wm50DdiV4f15uReqLDyA+uojYfbm3z9hHVA6ybb5t8kci7er5xM69tQC5h+1oP8+cW8xOtM1vP6of2SOyns2T1WemH8CMsJyljHKbJWL4VdI7/D5ChP3efbYQ4vdmzz119mwiI1oEAJVj8/jFBPxzD/Sif/Ssg22zPno/0LMgv3CAf56CBP6R6J75SSFjE7Wx59BleewzRvS8MRKe+2eO/jmit8nGYiRcZ0J2CdqFEEIIIYQQQlyQwF0IIYQQQgjC02YpyiCxnRSyKxXZ/d2lZTajSabl40Y9lviEyrOTVpEQntn124L2ySYpe+vXOkWrb0Xi62iSFJW3bJsRgs9O9KLJUpZnPeG69tOm8durE9A+H/J3Zp8QQnxGqmLBI0SF2YrUR5f3XmVYQfZRKywzMWssZN8Kvo9iBHGLL3MtFL+JxPlq5UGZcLsPEPtKaOxtjMh5HzcRYfrscV23Ay47/CWECZF7vB/Ed+R4sHOrLmDfCs/9ixG1F1hay28i+kG/wJAb8Lc33s7iR1S3ip9TAvbUWNZXrMs8YiX2e2DXrxBCzDLz8nlFPF61WRFz++cQ2bOG7Jfp2Av71V+oi9Kg1d+9SD5bBT5akf5wHjGO+fARPgtkb8C1tTg9en7oReyonCg23IS5l2N3Hn+O0b6RXEIIIYQQQgghfmMkcBdCCCGEEILw/Pwynp6ykNnMvCBh+7J92VedqELC9quAZ/C0fjvwZUqDg+bviN3IcDaJWp0snBVjZz99bbdlYnr0M9l2H5sERnVDZa1XGssngrMV2ysroaF6ZeVWydpdCCF+dT5CvDizijFbSb3Km1jUiqIjgbR/06/mY2t91Y5r8e129IhWg6+WGeWNxL+RnXl/8NuHNwF7xa/j1E9r23PHD51nm/aYFDsf9WKFT1950QIJ+Ver1Bdf1Jj0Evo2f14FLx840XW1jWfPjfcUl8+2+3v5Vn1JSAghZomeZ6DnF+x+/p77c7RyO7K5p4zo1/JseVUBOluN3dqLvmfb7+FwmyD2Wv310OeT2duGtWQrn+yzUhwCp270p/bU2tCoKoQQQgghhBBfEAnchRBCCCGEIPzr+48//vjjskAQnUZJ5le8GJx9RoJ2nyZKiwTn1sZYfw0hNlcTcLMiucqEovGzIojfC5sQtZOp0crpdn/0c9v+r13NPVrRnf10Nlq5jJXlP6PvqPxspfm9PGJCWAgR89uI6t6pHo8UIh5hN1sRGK5k7PbvE+HiwIWvpowVwIsY2vvY+whF6xutzsjqshVcR/jjPrf6s/n1GdoeDDf+Aj9WqaH9QMxs8t1sD3gebcX6tRPlzca4vgRxW0ndxR/ouCZtHJ2rm2u1INSeeTHEGp49l/YQnYN7hfPwfHJtwc71uMyxSjOffx97Xs6h299ZgK9V3IUQR4Luq/fca8/8Cpwvg4nM0Yrudlv0PIItGOCF7uiZi887zH+2DO9DZSEC1gZ0P3veB7bBBQV8HhT/LeVkZflngt1ti6qT+H79bG2OtvYL3RJ093eC7n9GRwghhBBCCCHEl0ECdyGEEEIIIRhj/LmZsZmdBGptK3JH+31aNAF1TeJmhZhYA2zfTLrZtMy3RbB0++D8ALawvg0ktQqrZqqEBehsn0+Tba/85LZNiyZm0Qrt1Z/prk4mR6uuzRC9YDC7Kv69ZQohPo5fUfT+Xi4/Uog42uPbHvo+kv07yuj9JvpldUIrsi9iaMt63+2zFeeOti6v0o7Wxtu/vtoXrehdPU52RW9bFvLD1zmyeQ9sBXBcRxtkbl88uKVNxFxX4bwRvjmB/FilfSuu8iIBPb+cj9twgwvsoc2JFwuy41dpL/Yyytu1xV+YmMGem6b0t30uHfJxppw9eWeP/aF98wG2fsWxtMLvWi8hfjfuvc9GgvNBnlJUFirwz0qiFdbXZa1f7PfCdAZ6hmEXE2B+IjvRqver9hnFZzi+uEjs3UD7VuLc5bmkfc5Y6b/tc0YvRPdOdJO2uc/s2SPax551+nJL/hcfMgohhBBCCCGE+O2QwF0IIYQQQghC70/jOgMzWmtMHB7B5mDs5BCa9EKrLZmvmy/RXzP5dZ0Mm/B3I9YxInQ4YdjNvwOpTK6yFcP8ymBROj/JatOhydiZ1ebZKu8z9Z4RyGerpUVtitpqBq3aLsTHggSBD19J9gGX/dQKzB/Y7YT+EeHxDPes5Bztm/djXPNWVhmPbd38oNuBAL6ywjTbVhGcR8dqnf4taPJ+za7EHm2PjlHFll8N/ObjWmG0rfNWaM3E2W9/B9x+Me8yxf5DGyD/4lOY4GprK+6+2vDfrxuQnXXG7UrpcaXQSxy3orhwa6/w+OaOueHY2+4Edr7fs9DqjA+bF27QrUlxW5V72ugoHx6BVpsXYs1nfWF75h4drYLu/67F4Wu7mUAcPUNBvzyHbLFfoYt+Lc+WwXzx9fdp/D5Wzsp+39YHle82roXiybhIn61lUKG62Ra94NdBkjicXtfNPXPcPOu0/za2xvqZaMgnGzSFEEIIIYQQQrwbErgLIYQQQggRwSZa/EpEVaIVnex+PwnEJoOicphf0eQRqNchK3xX54a5toemR2L1xTe26joDpYtWk9+6s86HJk0zsbn3wU+4ZnVhK6J5H6urw1eF6pVz4bOKBMTvw2cTi305HnCJL0LQkvDuF+pi3upzEfBQAfVR5cT79qymvM37FnjsE81vy7Krvu9pEys694LvNWZ87rhN2CrXrK5HikSP/mUBv6I7F89vA1C2Qny0annWjvdi6xG/CMDF3dFLCOELIu1NOL9HjI2OQbRyfuUFmeic9KvqV3yMykK+wZcfSLFHXyMrm4VjvNr2DnHD7IstQojPwWd+YTvyDb2ov2z3z0tmyFZNrzyrWPyxgnC2+nqUny62MOH/so3VaynL541WpzcbrMPT/pXrZp8fsv1WQO5fBjNjdRAib20Nt82mYeMxrFKv3b9dy/m816QQQgghhBBCiMchgbsQQgghhBCE3lsbFZE4mpDZM+/iJ5uYSB1NNC1+oAknxNXnvl5lKcLXE32PJqcC4cmViXbrrW/Ss0nBTKSfCcC3K5utheTIJvUZlJn5b7dVxPfRimZ2z5GCc1/mzErze5BYXiB+NbHYZxTkfzafIoHvZ/J137k3NnmPWhl4Nl20vyKSZ9tw3kCUVRSnZtTPjbWAe7uV5HKi2tlzce+K0vnLEMtLEyYGGlhEjb7vwwnD7jyfNytyt+337crpc8ei+lJJfu4P6M9e2Ir4Fb+iXzi45zjb82fWp9buaJf36t+Dtrn7mB50XgghPhef/T60+ktsmdi98rzCrwhv9yG8qN3aiYTmzBazl2HTsgUIWJ4Q8xzunhckRhvb52uZiL2TtOw5XvYccJg0XiRvvzOsT5XnmmzbbXP2xFEIIYQQQgghxG+KBO5CCCGEEEIEzK4JVTK2TAahyR40ieUFPszmpDtvaUAiP1nFxPJ+taiosbLJrTBrPDnq00QTodHPY89OQDIBOrLJfIp+FjsSiFdWFOPifOzjDJVJ/b22q3zmFfWEqPIZBfkf5dNeEeBnEQ8etgr7ZN7seDFhczV/ld5H633QlabXbcILLbWds4mE0NV60XSF9sqE3LFwusMVr9fb+ua8siJuv9L4W9rlpYmb8Nrajlecd7FR3/qI8vpV1GdepsC/DtDpMbzWp72lQzaYbV8Od3Brp/JCQvVanPKlxe31CJhAPlzN/h2E3LvsP9Cnkj/BC1pCiF+XvfehM8L4I34dzd+P3/PLbPYZA3sOg4TqTLju93lRfvY8J/K3sgiAF+aj50PeVun4GTN7XoRY+eFF6zOnHXt2Zz9TexN+D/PPZk2fT5LnkKE//VtrQ5oGIYQQQgghhPiC6GZQCCGEEEIIzp+pKAGqzckmP/ljt7fK9rWSabPZr6qUEaVdiWm8goen5SsuTczGbQRD+c9Po0lNtPpltkI6m4xFq7b7fcweWrU9Wl0+8wuVxz4jYT2bpM0mYJn/ka8z+x+94rsQ4n14T8F5tLr7e3PPqtULve/XY3Lx8j6R8kwZ1s6Szm+baZOtYB3HIV7gXbG35/y0QvpF9D2zojVOOwqiYTP297XI2Nd97y8drNt2bF5EiGyyVdSz48JE+lm5K9vj+j9qPzrnvN+rcwTs375M0GnEMvOrChXxfNS3PKK/ZS+OZKvZb9qxm2Pc1y8jlFbZr7u8KfPm2H1tNPvrFR9C4eULIcR+HvmLZ/emrTzPYNvQi/j2pXj0HCF7Kd/nQWUt36NfxoueC0TPYNBzlcqv+jER/kc8m1iVaWMe9KyQPT/02/wzSZKnr/+H7YxxK9snY9s2hQRlhOPueBoPfXVNCCGEEEIIIcRnRQJ3IYQQQgghCGMsup9AuI4mYBahOZt6sXmnpmciVZnzxX+2k2ORIB3YuU6yZeJ5JuC/l75zYtkK/h33TmCyiVI/Qey3+bLYSmVshbSqCJ3l976znwNHNv02RjQZjyayo3zMt6MmmyWoF+J49l5Vn0YsWKAkziQvj0Vi1nsE+yivXdF7xk64v5AvEnZn4nlUj0y4PZP+3vNsjBHWD22PhOxIqG73ebF2tBL7dVvHbYPF52OVd9EiV9qKvRiBVtSfIU1feMGAXX/2Sy+0E6vL28uX6zz2s2+P6NxmYv5Kve55cYTtW/zfc62wfsC+NHCE7Zl01RdhDucDJXi/0ngqxEdRvQ/8rL8axp5nZCu2VxYOqK6Izu7T2Urs7FlAZcGA6PkLq5ttk6htsucXM9tBBXD6mX66t+2Ygp5HQnG5+cwE6ex+AT637Lc/qGxYLxtkAP82TQlV928vmSLzQgghhBBCCCF+eyRwF0IIIYQQgtB7D5RcKIPbx8TebKLJT1xFszeLsIZNaKFJMO+r9ZcJ5GdnkEi5mxXAKhN6B4gzNqu+Op826YMJ2Ou+sZ1oRaum+5XJvE2+ItrWtp0k9qub2b82j5/k9pPVlQll7/fMlGJFmB6tCoe+Hy1IRz89LsQvzWeY9f8Cl1O1ipsh6A4Be2Q3Ek/vEZMiQejVDhGLIoEzssN8gULfqz2/svjWFhN+2/rvFbr6/L13+kKBFZkzX6/777heUd1vG7DQ2BfqRdzdiJUyEX8kyh4mtsWrn3Mblu35FcQp4NxD158VqFeIVsqvrGjO7JSvS9cG7yVczq6VmV8xePs34Ar/3ibz4ZYoLzOz+W4i98mydvv1BcZcIR5B9b529tfJ3uu+co94PbLjn18wAftCtlo6Sxc9I2DPCqovvM+s4H7vcSrnvz5Cmg3GzV/0nG6xnT3z8zbp88a+3eTz2meEkbDe5kGfo3TQ4FuCp89wnyuEEEIIIYQQ4kOQwF0IIYQQQgjCQwQQyKadaCpMAg1rxwmarpNcSLSOBO2RQH5TaOKbLRekLU3qVSbKJkAremWrfHlBeG/9Kmq3frGf0UarojMhOkrHWilbZQwJ1tFqZb6ezB5Kl6WfSVMVryM/j167S2uBid+G31Do9j5iRPdyTVZmZTibELPfI0DP8t+7wjMSyXuBrhX+Lr98g1avJqVSP65hS1EUW14J24mhM7e2ItlxrVc34qKVn2MtyN6sbj6WNLd0ayH6HHwF/1Wqxk5ee/z2rq7tRfaemRcz7N+bf9eAMlyZ3tuxZVk/bZ2rYm1EnLeHvs30Nff/+gDe7q9llq+6enypzw7K8ftWLzokZtELCT5j2I4HjzeVY1Z94UMI8THM3NOye+cZmNjb72fb0Arskcg7K8e+vM+eN/j7dd8OqE70vv6gvpDVGaWZEfLv9QHs9AXhZ2H+OSF7nshsZc/15nZvQc8xmaE9l4Yd1/XMRgghhBBCCCG+LBK4CyGEEEIIwSFag7XQ2W+OLYJ8y3afn8zf9IuaaqAyM4E4ErFbUTxbBcqm8WVxvdTNJqrbUZNe0MxWFA0ng90RpsLxyqpU7Taha/PaiWAvfo+E5QwmOK+smFaZ6I3KunfVsz0//y2E+Nqw1Z8PLoWW+VXwq2Xbz0hQHwtix3UV7zF6G2Mr9DapqU/VFdczkbtP2913/9mnQXX1YnaEjTGQXzd7FVXQ1p+tnfV31n6bVfnNCwmoLHbdVV5iQCurWwG7tx19nhGhRyt3R+czysuoCZNR7Ln9/G6rijtmXmhgK9JHtrkxnNb+isBMWb68Tb0iYWDgFyrj6GNVHm8my/2oc0qIr8ye+1l/f+1/kY2VgZ4zRLa9fZQvu79HInef19fB708XHehgG0hf+XW50Ub5F1seAWxPNDYtdLfPjolRVX0+Zh/hn+UxnybG9BKTl8rbfQV7WCmEEEIIIYQQ4ndHAnchhBBCCCEIo7Vvmy1M3O7JJoC6+TeZvzcnWrB22ASUXVnJl1tZ3WmpuhfFR75GovcJVhOXBZtwMhSJrtpawcaE8KEou4OyUDkENkHsJ65Xq8mbvNGEdGWCmqVDq7lVV6SLVoJ7NO9R7kfVTYivQiTK+5WuvqPFhZsVwHfmZ2xWwS6Jd3mam1B1tN7njhxb8ZqtLp2Jk5Ew3f6zadarWbsx3sZBgIrQG616v1d7dRPb9tb77Z//7rctn29/b9eW9a+6Ov4g+31bzAqVZ36poII9h+j18CDd1GrFfwB6aeGIPqRy3UffKzYym4flTa4t+5m+BAL6ipn63XO93svs6fAVX9QS4leHPROogF6in7XHXqRHzwX8L9mhF/2X/NlL85XV6mdf1DcZKXfd10dZk7Es/HzEC1koL3sGyPL2dhn0THr0jHGmCWfF96agm7Zdo5sQQgghhBBCfEX++GgHhBBCCCGE+LSM8ed6dU0ktDbb7aRUtBrTxoZLM0Zro8eTWtUJtWyibJmUGiAt8i0qD01Yscm1y1+2Mtna/MATalczvQ0jnoP2nJCdCbh9GljWsj0Runm7VQF6JHa3f1E6NAnsxfHZT3D7nyDP/Mr897az1etRniq2jpkfe9FK8+JwiDhgZmXd34mwzvh9pU8Jq0f5uLrzwq56vdefpeyNCJSUVWOdGfkZrZ7dmheV489VvzahlRO/RrbtNru6OFwJ2tiOhOBWyB6x8u3yv95bO59v204XQ+fR2ji/BW+jjXZuo/Vza+erizYWwCHeIjfrrbf+dCu0j96evr3tfXp62zZGu30+j5UdZ/Sqh1raYnXc3X4mTPbt7j+3xttz097ZdeR8svuia/V2Lb0VkB1f9oIGKueovj962WLmZYOsPdj2qO38/pI/JM3MteXNHdLW4Bx6BHvrKYR4LDMvgTMBeWYnerE9un/36bNV3tn9/mIbidXRL+cxv1l5VaG5rSN7dsOe9dwFeO7Te/Aci50Oq0eHJL9/RuZF6d42iXeu36M8w+a7rHbv33btIL234/zf+IHSTorjv3371n78+Pn0/Pz69O///i3PIIQQQgghhBDit0ICdyGEEEIIIQhjjMsvGmdK5sv+KFlkx04+XTc0Olm1WkHUmkOfo0koZMOWF01eVcqy20ia8sQj83W0m7jdTNCFE44F0Opj/rP/jiZW11XIxd3ZhDH7CXOWPysP2Yt+dpz9zHhlYp+tJFfJcyR7bN4rihe/J4eJyZho7wDTn4WKUPQeGw9hUnhxzdZ7G4GjZWGpLd5+AX5lbeMFpZu0d7RrVNd1Oi7wZUJXLzpf1bOb0MK64ITCm/0oD9lm64baGImSM1F+v4SLizh6FdL10c7n0U7n0c5jtNP59CbWPp/fEp1bOz/19nTxrZuCh6nwk2kGrklaRNlvf/swqU/9TS3/NFobbydcf3pqT0+tPT19a996b09Pb6X0/nSxffm/q7APWZlY+vo9ED/7FzQQm2OAtGP2nNoYuKXJWI5l99vAOWh982J+X7+KwD6qky0PMWWz5W1REV77dOxFkNhQC/sqWl+aocW3d5Er7hz7ncZrIUSMvy/ce4+YrbbOyrPlVn55jj2/QOJ1n6byrIP5wQT5XqQ+84wArRSf1ReVCzLF4wHYxxZDaO0SPyJ76DkYeD4H/dwEHO7vAJ/RuOkF59d8t1/12exneSuwth3Rzm3i3ns7n85/nE4naRqEEEIIIYQQ4guim0EhhBBCCCECtqKOZBImnOzxM0JOyG6TIbHWRdy0ttW2k05okotOKgWuobog0fvMnC7zozavtU1HJvn2THrOsojo7SphbMUwNHFr01cmie0+NnmN7Ps0/jPyDZXDyn6U+Pseu0f7KnG7QDxcbP0bKeaitvq0K87uEWC2uuA7t8N9CdPu2P8IslW30f6F0srORVHpOj9XyGbHl4nZ7f7QRr+MJWNchcPncW7n13N7PZ/a6dxuvjnjVyH805t4fdl2rU3fjlK2pnQE68uf3lpfYpFL3qer01e/T6fWTq8v7aWbEvpT++Opt2/fvrVvb8u8X+p38e9Sl94HPd5LldulCSrHtbTqeSSIvuxjNurX1DpiQ2L1SHweidlnVuxOz79rpvZ22JJrcrUvsZutql+pV0Xwfj3t2vb6i8qPTqjdq79/wnHrw31KXkAQ4nchuy9k9+SVX0Or3s/7+3cmPEdpkK3s5fuZX2CbFaB7sTtbJIClQ89TKuW6QnLMsyhW1q7nTPY5HHrelZm0YnZvE9lBwvhVuUlnPlYNsU2Ksl6DFL9j4hnLGK33PnrvGmmEEEIIIYQQ4gsigbsQQgghhBCE3p/clkxh7fZfJ418vmgiZ1H2IPXPZfN1eceC0D5K5kXt0VQRshFUfbXN7ytMDm4o5IkmeFm+cvnAPrJTmVxFNphQntWL+YfysAlgVH5kf8aXqpA8SnevqJytdCeE+DVB4r3KyuWjtUNEd2k5dsxLYOLcd1+l3vnU2v7yo5XLq2JUtFI3W8k783VJs7YxaNuXjq/zIxPu9mvmNzH76Xxup9OpvZ7HWv28KW8ZawOfgv1Ma7Ton/z+JUrw4aAP3dpSH5Ozj9FeT6O9ns6tjdFG7+3pqbc/nr61b09vn23J957jbPVzJBTvrS0L0K/YU/6eX6FAIveZ8+xtYyv3X6U+ZKzT+vzMbliusXvvqvO2zEhwX/HriF8OOapf/si+/d343esnRJF77oErv4zm07Bfddv7Yncmso+ehVT2L9+9vapo3Kdjq80zXzLosxzTlJv9KHCaLxgHcHY7e77GyAK7zaPNfhmwzredvvx1Q2yfKUKQuL3KpZDKT+sIIYQQQgghhPhtkcBdCCGEEEIIBhN108kZN9s07PYdhUaTRd2U4X3KhC3IHTvpNYJ0Eaxc659VV/XL5CDzh5RfmahEK49XfsI78sFPvrJJXDRJ61dr92L2rA6Zz5lgnlcRTyKjnxX3bcrsRKvAeT6D4HxmRTqU9zPUQYivympBwEAw/R5+tIsPmUiVrdRcFkACcTb7XuVecftc3ltjeLGy92nYz0joavb7fXtXXUYC6pl2ecvzVsfTebTT6bW9nk8XO+MqXt84bv28JQCSsLUY3YaKUJDO/Cyk82X4cNOHd2NZVf482sv5tb2O1sZTa3309se3p/btz2/t2xII9rG6Jlrbfy6zlddnXohA+6MXT7LV0/05PdpcnVYZVwXftrHroNqeh/WPoN4V8bn/XvaneB1H9tALEVnae8jGqoUvIYQX4jfkqHt6v48JwaP7cvYiO1rpHL28Hq2Izp4rZIsPVJ7fZAsTZD5EzydmuGsVdvb9ZhwHbstnZgcFeJlofU/1xxJmTDzfePiYZc51PXYRQgghhBBCiC+LBO5CCCGEEEIwRvtjLTK4Z+Whmwlog21n5S1LxfpJHi9UZ5Nmw6Xxyii07Vpkb2MAYTpSPvn9bF+LJzIrbFbyuvgbTY6G4mSv3OIFw/1MEM/NcKH17ATvss9PintRvp947sbfaJV35vc9xy/zP/LhHh4pUJcAXvyKfLTAbrb8WV+PEHNHZCswM9FptNIws10RrFZE8JF4l+Wxvs2IRZfG8HkjAXvmh8+3SeeOQe+XOAaUBVcCJ+fM7di89fSnMdrL62t7PY02TuNS6Lj8IpATtxfoBWHZAAHkXp0w00RVw1YfVi6rp4822vPra+uvp9Z6e1vZ/Y8/2r99e3pLPdY1Q82EjgF9MWLqfMwF7IjKebOyB/JE9hj0NmIpF9waLPb3tM3GPtm3lGH/RnbssWOXxSEv3LCTejk3d4wfmUj9Hsr+sBNBCFGC3L7v5qj7vcq9IxOpL/sif9AL7JXnDP7X3qJV2v2L/EwoP/vsgK0Cz1ZwL63izk4E+9xrtrNlz+Na8TPzy25DY0BUlk8zyPduEzYz6AFDfl84LiVX3DWvTXf0VSqEEEIIIYQQ4ldGAnchhBBCCCEo49t6lgZM5GxgSyiZTUuylekgbaWYigtojogJ5K0QrN2EYG+7xnbCDk3gsTLJ/tWkZHci+sTuak7ssqF3MyE53Hdbl8hf0JZWPA99S2ATz9FPdaPV4G0eNEns96GfM2flV33L8kX1RfiV7u9lbee4SVImKMhW0BPiV+AeUeER4vi9AsxZ+5495TFhrC3nOj4B4UelvFkx5UZsCvbNwvxEAuOlHO83MlESzBIRbPRywMbuphzeoGjVdn9OWmH7uZ3b6+tre3k5tzbO1523cPE+JSoLG2/bfFxTszfAtuVzxWOmq/J5b011O4Dn82in5+f2PHp7+tbbH388tX/7xh9RZy8brFbbb3h7GSB83rT7HUJxb2fxM0uXiceHObCj4evyYS/1XP+Xtwe6rpbjtGmPwomYtj+y1cn1VDiWS11p2sDno14ouDkihNjLo+7Q7vllsCxfdq+P8rMXxn1adk+LRO5MrB7VhdlDPvt0bFu2ajyz7TKE22Gd2TOvJd/mOZ8rywZaldOEPZ9CzwPZuIQ++7ybfO65p/Uf5QvHJVLRpR0GSqfnKEIIIYQQQgghbkjgLoQQQgghBKODSTEkRN9hdz0BNJJ9XtWV2I8mm6w5p2LqrbfRx2bfdZsv10/MRSL0aBIQ+D/62PrpywbmbH2Ga9eNML1tJ4rDycbJ+Ta0cnu0khibNPYid/TXp/dlZBPZiMrPhKO6IZC4HvkfTa77n2OfpXLlzgjrjxava7V38Sswu6rxe9m6m4pItShQ9yuHW+Gp3d5J/k1597bDwEJaK9b220NcOyAhMKyXE8BGZa/Eww2nraxWz6ied3ZV7Hb1+W3sen05tefzqbXTuLWZa7zZQ8hCJf+5CtNYsTSRPmrZ3t1ftH+rgerX/9/SvV0E4zzay89Te26n9se3p/bnn3+0p6en6+h/9dM0DhS3k0pWfolgdX4F5y6CrfjvP9vV1SOxOhPw+/1on02TCrVtHH7nNeN1f9SfoCz4ssy9fhFbvu+d+lWPLE2yf28f9dG/rCKEqJGt+D1zvxcJx+29ffQSe/S8gAnGkXB++c6eU1QE6dlq7lG+yjZUjyN+XQ49Q7rs2D4fsoEQG/dmn51FY6NNj7ZH6dF+awsFedSpAORbFnASxmj2KaEQQgghhBBCiC+EBO5CCCGEEEJQupk+SZQZLP/dadfb38QNfe2WTcomqFZGGpyMC1dMj9yrTtqxvF7InpXt/Uf1QfvAxCRcjQv5bfJGK6CzldSR2HyvYNznr0zczvx0OfK7uvob8pXls2VkK6HP2GYi+opNNqHP0mXbMn9n8gvxGThSYPepxHoP8CUSJKbi9tbWgkwiRmdlRiLYzQrvXhBsyoblFYWuzDcq3CTCXityn7VdhQlw7Sr8/am1l9Nop5fn9nq6ibVb59Vm2yvRZDWcW/btJdND+XJ9M/k8KERb/39b7hJun87ndvr53EZr7W/fvrU//vzWujmZs9XL4flqnI1+bYHuu/wvexnDXp/LauTw2gkOVia03vwyArG16StMG4T9kit/Svh9LbzR6yjzYVU36/fs7ZcF1N23T9jeyTnHymBUVutH6T7VeCnEJ2Tm/rG17X3XnheNs/tclGbPPa9PH61cjshWNWcC+aooPhKnozogn7J87HmKH1dhmqPwz4p6YVvyLCrcvuzz2DHR5rXl2LEzejaGCtvTbGycRuM4CzALjDb+OJ/P33Z4KIQQQgghhBDiF+fpox0QQgghhBDi88JmaaL9e8z2YB/Kz9QWwTY08YbSUPVRW09KIUWUnciLfEMTcfZz5APyM5oXNvu6V/wFaSNGG28vAzQsHPeTz15gXRFH+9XQfN5r+rFOf/WPTJhHovpoEnjPZLrd70Xt7CfL0aR5tHodss3arEL558x3IAG7EI8jXXX8CLuzIgwimN1DJsRk7CqTCDW7jSMC+1GZSHh/FQS3XHgbYdOwz9tM7vtGHN3baK09P7+2f/71s/388SZuR0k90X4WwiDtT6aLsnlZ2GbpbW03soFCNe8fKweV6e2ycnpr7fn11P76/tz++vHcXl5PbYx+PZidVGIlzF6Sm4brfX0+eCE3tGXq6IXrmQiZnntke/aSxmaF+c35SgTS5nP0wkr4ixSmDW15q+LJCVG+HolvHZRVhtTv3l96YGXcyz0v6twF6xSE+M1gLz3vuU+r3J9W7sftPXC0KnnlZWqbjq18bj8j4TjzuSoY9z6ge3brK3sBgJW9SjN52KaPvwuKNumyODLbntmKgjYfJEYxgt3nA71uv+wkq3f2fLC4U89ThBBCCCGEEOLrIoG7EEIIIYQQhPUESqT+ZspvlLayPUtrZqKY+ohhq1FVJGWC86x8q8raowhDzbpjbmszKTsjXAFqrEj0PZw6ZZj/UHr72X8f7j/kh7ezlOnLR3Tzn83HVj63E9KVMqIJeSR8j9ojKmMGJCxYSrzH7my5n8WWEL86jxAEpisdT45DG3FlVfS5o4zhvqN0vkwv/oV5ij4wO5E/pZWSgzIrq3tvd7bWwHHurbXz+dy+//zZvv/42V5Op9sOl87jI8eszXx050MmEoKsttk0kZj8bdzG/qIybPiF6sL0Uj6f38/KH35Hb22M0V5eXttf37+31+fna6qr5guI12fOM7/NC+D96uPLLykhMXu0IvxGiObyos8V/Es493aFdDV8Ep93dgI5m2HbWNjLBjhMmyPp447gl11pnd3CCvGL8NmEr9mK6l4E3tr23o69EI6+R/eFaFXzynOJzCefDon6K8L4PS+YV1+yj/zc+BA9c+om3SxWqF5Nb8rstw/8WRkLFNF29Dl05B6qDx49OBJ+evpc17kQQgghhBBCiPdDAnchhBBCCCE4/xbv9vIivw2lQ5uCCZ/VikqXyT8/34NMMCEX24aqwuzOzit1NzE361t1+7KvKtIg9diIuqlQDwvmR1urAJFIe52NT/x6cbhfaS1a/ZxN7DIxu91vBezILpqQZ2L4PSupR2SrrlXF9Cj/dg742EnUI+19NiGHELOsBNV7xpbA7hHMrKR8z0rpDQisq9Byi6JwKuZtdWF5tj0THVOuwmXQ53uhuRcggbJo+VdBb2+9t/Z6PrfvP362Hz9f2vmcibI27u5Kk2FDPS88b2YbKnOtexoryRD6u3xm9rw2qnLp+lZEZUUC+DdNeW/Pp3P76/tz+/7j+RKD3YTmmxcZzPnM/Mte6tjUYyx5boaRcNvaXT53Y8M75FdJZ3ghPHwJJ7gfOKJvjK4jKOqP8kX3A9EFteMlgGU1/0M03O8glA+LV/gnviB7hMUf9TJw5V7Uf49WXV/SRs8L0Hd7f26fHbBfO4vsMLy/zJbdx3xHInn0Anzl2cQUdtzZG8+jQAmNz9fwATxr8uOffbbk06L0/jPyDe0bdoMleX6HjG/S3TtgmcIvcYaGQCGEEEIIIYT4mkjgLoQQQgghBMdLqC5/meq7MN1iTdDlRNnXvs7iBF20LGsnUlpFk2Q2PxOXBKKUdIIZiRxZs3oll99n8vTWUzVLtDpayWdiz4vPKxOuaPKaTUhnAvboZ78jMbyfFLdprH9spTZml9XPE63QnonbK8KBqJxfg1/VbyHWLILQRXh41Kl9yAq6k+qJtEwiMu3ReObS7gKOx+bzVbDryuzb7Uv6WdBK174snHH5M9Y2UJ1QjENAbdp7b6+vp/bj53N7fn5p50s5WfNnoVAkQkcMl65S/pKeRah2GxOTV04z3MQ9vHS9bxHJaXAL73pr5zHaXz+e24+flxXdLweVicyRqNynt9syrHB+nX7rxyqPaUQorvf5wPXnXxhJRfogD2TntR79YsNKk1e45Vmljcqf7IfQSvx76OaCY/V+D/F5WoWjfJCKUHwi9giXszwVAfcMM/a88NzaYPe76CV1JACPyoz8jtJmInj20r2/T6+8lG7bpfLrbf75RG+3X9O7S/AebbMBlX9+1dznmWdjrBxfpreLAs5NAOVsbeh4Fw30bMUviQ65lHAjjLaMwxqchBBCCCGEEOIrIoG7EEIIIYQQIZGofQcDfXYzYYFpKDhhrvmJLiYiR3k9TISG5p/2UBEHZmIXMPnmV1N/M9Vvedp6snVEUi2weTWh3JcJWVO29yXATlBHE7l+opf9HHj0OSoDieKZ71GZmZi9YtP7wCazmd2KsKHi4+cSw2tSV/xePOTquvcyOdqp4T4WlcuZyDQVoRoRLPJlsWHFssvqiMw205XM6E1Wq0+P7b61g27/RBnI3io06r2dzqf214+f7cfLczslK7bTstpWyI20Rj4PssN8Rdustor5ZT8XdMhh+m2d2Di+1VH5ELRS18zX1/O5/fXjuX2/CN2XVfhXviwCcFZJtBkJ1JbyB/68rOxuz7sxAl1YsP3qQ6FRkJielhNcPPQcygT0rdAPFdPMpi31OcUOA9pyJ+q4/s98nyjjsPCt2O8/vBwhfnGil6QfVR4SY9v97KVzZg/tZ0J4lg+J52fbY0/7sRfuZ192vyTYBinIVhQLREFV9ZEg8eP6OYjHN3Z8wIRik+HSIv/QczLvS38zFsWKSdSyzdnpl130g+wIIYQQQgghhPg1kcBdCCGEEEIIQoezRG97bgz3lyQr7bvMPB0xv1oRwqN9fgLMTvL5z63hibaqf2zyj5EprSI7przrROdKtDJWSUvlNzwB3I0yB61+Fq2I5sXZ7Oe27QS5nwy2InU2QYyE7NcVz7IJZABbkS2rf7SSXLaaXLS6XYUsbUUo/7mE70L8ojziMjrI5t5FArMVlUsCxQPrYAXslXT+r01z+7Lel62yDtM5u94+EiuzVbpZOZvyLt9fTqP96/uP9uP5tY0xzLgVE0WA1UOWnR4s/VrnZMdvrMlCYvjML6+Z2uMnysvCTJSflWdDz97eHmr31to4nd6E7j+e2/lywJfzxJ8vqDx7HvUO9GHuPGOf7a9SXH8dYXEeXS/BdcmuPSawR1hxfyaY99evLS8qB12jfvsjFlu1/VVI8aL0LytcPxNbq/asHpOPDBl3HIPwFzbEb8fveE+TvQi9UF3pPYPd//o0aH/kF3rRG/0ymRepR+Ww5w+srpUX9dH3mRf+K89BaH7TX4W+Zs/nUCA188zJ22ABjw/QkB2bf89zs2WcQj77oGrlA2u/SsGrh25zWWnibv78fv2UEEIIIYQQQogaErgLIYQQQgjB6PSL204mWuj8CxOxEyWB2zwqig40ubZsr07UIbWUTYcm7GZVW9YOU4ihfV6FZcre9VPUGVWBTBtt9PV365MXl3sRerZ6O0qzdyJ65XOz4j484e33eZG9X7UdTcbP+Fh5EWDvsa6I1yti+bny75mQ1WSu+L34VX5dfu+VVxqmqwLNO/GCWNT2K18ScfogY3W0Snxox/jo2yP6bgW41fOpP/V2Po/2/cfP9vL8821bwyHFKp/1AWwLywSfWeiEtvMwLFtpc1t+hcopyXzyYeNsG1VCShh1X06A8/nUvn//2X48P7fWWnsyJ0ZFRH7bsf68rMQOk/rzr6/PZ3+9QD8CH1NfA2bE8Fl52Ysk1+/Vskk/VCmT2jwIe8xYOYeVn4ktj7DT2q7BDP3Chvh9ecj9c8C9968V2MvQGez+F+2LbGS/PBatqu5hL3lngnW2kjsSnqMV3ZHIPBKeRy/ZU0BSv9L9w7BjNBur0CnDROvLWJ+dZ9Yuegbny7Bp0faqYB4xfKIgcXr5gAYLHpfODDKX8+Db+Xz+Vs4khBBCCCGEEOK3QQJ3IYQQQgghGL11LGu633ANs/rRStRFRPCVovzk1/IPTZbZbUx8nk34RU3G5tCsCN8ryZhA36QfXok0q0bLJiarE5erLHwSuZovmjA+UpTA7EcrvLFV4pBdPwGOeK/6ZHmOnVC/p06/iBpY/HJ8lNB8eCXsAbxHXSplVP2orHh+WJ3si1dISFQdt4HdZZVoJvjc1KFSVxN/9MsywpEwuCo2/ev7z/bz+fktX++rUCcywXRMi6sNfJ7NH4VT/nIZ7p8P2bKyq1QE5l5bNRsCRulsGzEN16odLyfj+TzaXz9+tp8vL613cO6471aITs9jl34pzueBbdbX5zf75QG60nwQ4z+k38v6iMm8s30iatcjeJfxblaUHrXXTP0fLURXGCoSZu+ZHnkPuOf+LROYz5aHfrUsevk7ekGc7bP33+jl74rIHvmLxOUzL6X75wLhMf3ofq4SxEX4Z1aXbXBBCvRczQcytv9nwc+Mb+g7DTzHKlnJZkSpPeuR8yXltzY0IgkhhBBCCCHEV0QCdyGEEEIIIRjn8ed6A1J8L9szJXmVguKtXcQPkSLIK5/2UFEc+TL99srnrFw7sWfLQP4hnwoKttUqZYuwxiZeCZNqE+CzK8ShFdRZ2ply0AQ7SoMmzK0QnAnSmX1ro+InoiIYyPLNCijQavaZT1+Fr1z3d+edpu7fYwVxXvjB5tAYdLdRUkbFjwmovGNnG22EnCYWuOjF7xJ7WoGuX4099OO6A9ta7Hmp1HIgrukWQX0ipl3EzS+vp/bXj59tjHUvxnRFzOVIhL58Xoc6aMzERKGPDWFQWMdCMEalLjbMitrG+nPEpWfL8iFdJIpH7ff6emp/ff/ZTqdLbDMu51vFCW/fFeDP7WHSLec0Emrfrpeb8H5zPAvX/VKPza8aeL+IaD4vYGc+AKxPUMdHjUvULqqj66OqTDUX8Ye+/PSRkj6FfyLho4TpiEjkvSd/1fZMWWildXTPHZXv90e/vMbyoG2VY4l+hc7aKb8InwVfPm0Gigv9s4PsGVLVF+87exwYBVxIwO7T+zRszIoCUhZkRtxzSdtA7q7L2pxHy6n1kWOhEEIIIYQQQogPQwJ3IYQQQgghCNvJPyszam07i2TJFAkzKguUs/OJIza5Vimu4mpk34vrMx8qqiy236u//L5MkbX6evsvo7qCmRV4RxPFcPKZiV7IhDQTZbPJZ78d5Y9Wj1v+7hGAR8Lyatosf5QvW4musoLfvQKMzIcZ++8pOj9yZX2R8IuKyQ5dIRfYKtmfbbtf4bQmbXEVyBbqsNLHeFG6y19ZbfpmjPswGn7xAAl6vRDXioOXFeKvtgbxy30/n87tr79+tOfXl83uW5jQr2FUFJlF+5CG6C1P3kNXTteK7inzy27P6srKz3RKFZuLXyh0Y/aql7St8y0UHe3H83P78fN5m97E0d1n9obRZ+Rsu52rqzDYnrO9vb1ssZzb3h9TGfbrCP7FkikRtr1/YCQCwI2v5cIn0vtrfGdfndoYoP1MfzTTzpUXrcI+FfgGP1PjRbu/Ar9TXUSJ2fvK6uriM/cvPi361S+0WnrmI/KH3aejcqJfUkN1RIL57IX3aNV2ZgO1j/cj+8z82YUPVMZlvF0FrKDM6rMrCxsns7G1mma476Buq2CKBaQ+iETP6q47jYl77kWXIKhkAyXcBirwVyyFEEIIIYQQQnwZJHAXQgghhBCCsJ1o87NHVgkzO+ESSYgY4yKKuMxMRcqfzB0v4kETX1Eer5CyzcEUVQtoUm0lmnEqOKSM8lQOwYyopoHjX1Cp+Z+jrk4Q2/SjDegnWz3df7eC92jiH4ncl79oApoJ57NV4CIRt/0PTepXy1i8qlAVT0Qrv8+snhf5cMRkvkTn4pdgsv9trcE+N1yBd0Y0mJRztUm2oZWS7yESm78l2O63AlffLotwFpZhheSXNrsm7S4tYCM2R3VY7G/1RJexEucLV4W3x5f5Od52jjHa9+fn9q8fz+3c7Uqo66SLADoLo6Jwi+l3UFiyb9TaRpwNfM/sRuktUV2Z9ewSQu2O8tnQsnIZoPZll9LpNNq/fvxoP19er3vsNbH6RQDfl5jr6VqnJc9yDZl/1/5oMWfsDWNvEbdbm74yo9X6m6v75GD4aw79EhR6YQT1BRvRfTUGD/xj6VfJiS+rz5kfhfaxNjb9XGK+khC90CMA94grxS9FVSDN8hy9enzlpXckcvcrr7P7W5svF4jjsnx53pbPY+u0pPNi+0gE7xcDQPa8b8ivyovkFUrHvDI28QKwPZSGjW8+eEPBnN/uy4oCJV+23+79s+VBloGJbC/BorgoWoaFblMOLd4uhBBCCCGEEF8ZCdyFEEIIIYRgPLEplEhCk6Ut0Jd81sbbDij68m5UimNp0JwUm+Dzk2UoHxSfte1EnmkmuJK5n7SzMNVXRNRW1g90mJHAZlEygbLZBHNl1Tlkx/uJfMrEABVRAFvJ3e5nk+jIZ7RifCQ29/vzleHXNirihKPIVsRDZGKOR/j+nqu9i69JJIx+6Om3iEHvKQOIWkGSq7gTioiPUF6YcqG9Qh3TVYeX/U5o2V2a1tom7sjE+KwNoAAe/PV+orzsWD+11p5fXttfzz/bOI/29ESH5hJIGzQD0yX5/UwKZMv2+ZjOyodNKI39Xq3bLcxbxmhOJSzLTu0o1K2Gu6v9/W1sfX09te8/frTzeS2Uiq59u2/z8ogPzcC1cl3R3ca65vvmmnKNM8DB3KzCPnm7wVaFhyx94wjSRfG53z9zn5LE9vZ4MP+nxwVjE63sfqQoHfqW3YNlt51CfAFmV2Zvbe4+CN3b+XvUSOAdlY/uiVGafh1x1z5kL2tHL9Oj+kW+ZfmtkB+J9pkoPvK/Qpjej4/d77747n9qpZt2qTxzYi7MjIeR4N3+W/Zl4292SYT72eBzxKDHIk5UQdLAeiNMCCGEEEIIIb40ErgLIYQQQghBiKYEbzKlTFFi0zactrsPw25kipC+/ehFIPfMATEFFkuTqZlQM0WKLk8kkrETgVF5iV04CVwUllwnWYMyDxcXu3nHaAKZTXLPCAMi2zV358uyeTPBvc0brZDOVtyz+484VrkgP26PR6zMrtXexXvyaXUIxK/ecvH2atV0YAOtOn7PZXeXYN9hV5H2zqOX5/r1f9tjaVezXtnta1GvT+/L9Om8H4v9xedlxWxcr9G+v7y059fX1ocXbs1jw5ksykOfI5sVWzbPTJTJymFhWAUmKvf++tM9y4PyZ1TCxEjbtlzn33/+bD9eX6+rfme/SLA6T1vbiN6Xf1ch+J6TzjXY5lcQXJlLlr19LVrxHK5cP0h1Cid81bf0ZR4U6y+7spP/DuCLAAfYpe1iTlq0yv5hDgjxiTj6/uSIe7lIiO1XZ89eIEf35GiFd58uWvXc2qiuNu+/s3pY2ArvKC2q/8PvPUehDD+erwbW9d/NAgeF8je2/GebNgtimJgdPTdD25fvTCcexifbZyTzoKh0W8b2s83r04/rXiGEEEIIIYQQXxcJ3IUQQgghhGD03nNVd0WhbWeXoDo6cmKVZ1lhNZ203SuuOQpUfia87y4NU0plajNva7YdMpFNNe9GLLhTYA7K9ivHMXsdNIKfhM9sVPCT8P4/BFv1PSp/RliP98eT8Uu+IybjMxuPEl4IMcUD1QKPFB0eyiJqsaJSoLxFK/l6GxvMWIhWUa/4tQckzq2I5YfztbvtPt1qZepuhmngeyR0va4479LAVd9BPZ5fTu2vH8/tdDqHIcbMtqpOOdIqVQ9hRTzO7FofozDLh1O2zIomC21DEbLXVEVtsEdwb48LC7myfW8C9d5OL6f2r5/P7Xw6xwVG3xsWnsP9UWO4Ey56KcRvy67tTg4wWhmeluka9fqLD5muMBPz2XR7TkSbhfiy5wUA/4LO0S9shSu3j8vp8NnGTakLxScgE563hu/lmCCb2Yt+4QyJ0tm9+W0l9rFJn9me3c9Wd89WfEf5WBuyNvP22HOGe9nUJeuXKsLw4nOza9lIjN7A5wpZEBnZY8+6bFB4d7+NlPYVWBRWGehZxNouz2c1GgkhhBBCCCHEV0QCdyGEEEIIIQi9taftFA5SuEWzT5FcaWYG7K2cjagHFZ1NhN0zLZSJczIRD1NxISWZFdUwJdWSvzL558t124ZfntP+Cw4dnWiOxHyXnbOTvuEq5mNrb5hGiib9cR5c7j0/B+/FB2ySnO1jK7nXhe+47pVV4e8hquNsORK2i0PJTqdfXUJAtBN+lWKbdti+36QJm6ogvNyIFUkeu2L5PaJKKJAF+5B4syqIX9la8pi6LrYje6htrvIVG1NshMZvxr+/vLSXl9etXfc9Gco36WZ6WqYxquRZ8s2Eclk5e/RVLDRkQngEkiSxKLjiIzoFqqHfcGlpAefRfvx8aafz6aKbcteEOa+b39Zq1+iysvsmaYcfr3miMqBonviCfhUh9PtS180vN5iyR9YnZvjM/oCCEwe2ofFpu/Fi6g5Hl1edBzuZsracwZy0n07c3lr9Xkt8ambvIz7bfUf117kq+fakze6TfZqqT9EL6OhemonSfTq/LxKy+7/MBivziH3Zyu/T52P2TAqlIQHR9VnR7HMn9jypuf2Zbe+bH5f83+lLl90cFQINSBqFgd3xARuj/Xk+j28TTgghhBBCCCGE+E2QwF0IIYQQQggCXMD9ipcjIdlUJuuJJntIweNNqgyTock5ZDZzfcYtpGDydkbLJ9q8qMVPAjIhj91+7/w7Kw/ZNmnhRKsTwHsxc1mQPdpVcBWl762v0zmXIiF1b33jr/edle1Xbh/gP+S7bw+0QlwkxK+sDL98zlaQq6zyV51kjwT7rOzoe/ZT8UKk3Cu+O0LX9IBTtVwnMNxCsblNy8q6Q9xHBdygrNW7VhMiWu/PqkxXB19GKKZ0bYfE8Kv9xl9vO8xvxt0xzPB7+dyGEQr31s7nc/vrx882Xs+3cl1VUWRWacojTvsgbFjtR+HNjN09+5igHoWHTHMclbHkY2VY++gzs53on1O/WPreW/vx/NK+Pz9v09oTClXKGnWG/cruw6Zlfjs79lbEXj9X0b3tI6JYvMgwH9gvN6wSHyV6LlycUV8FN4N+NxX2gzLhidxubf4wMfqvFOYd3Qa/Ut0fxKOE5bP3D0ffb7D74XvZK4hG91XsvhndE1d+sSu6D595PoBeVre/mIZWiWeiey9iZ/fPWR1HG/T6Z2Uu+6I6zpwb6KX/6VOLBWn2e/S8yd8r+L9ZeYttG0AxW2yst+NodO9SDr6KEaCPf/rmQ2A3Mu0DsMtWjQ9CCCGEEEII8SWRwF0IIYQQQggCnsyz8h20v4M0Nt1l5mlRa5UopqsqtxDexWg/Knf56yfe8LwUL8+r02zaTGRYqbsVDWUZ2ORfZa5vx3GA/vTtxDf7WfDr9usptp6Ej4T211VL3cQzm/RGvrCJcDa57tPaNGh1c0QmLrB1zo73HgHHTJ49Ig6J2MUuXH/14SvBPqL82fHO+DDbHuX0qAsn48hKNGm3L987SJ8Vn43jYeZ1/pWI1og5N364Oi8C1EiESuviBD2roXaVp7fnl1P7/uPnagfToWaapcPCpkEjPlouS8t8Y1FntI3qjsA21FbIh8jezsuSnrIVbVZ0TJk/vu2fWm/n07l9//Fz/Ys+iZHr+b4c/+C67c5huCr4Yqubaw4cCCtoZ7+CwETv4Usthb4D9gNHhCug7Ghldp93eQGGnZSreu/1946xZHdZga9wJf8i7EWrT8FHxy3iYRx5b5P9Apcvz99zshXPvfgb3ddGL3TbtEiIXn2xm73QnQnSrZ+IaDsT/LNV4y+JKWw1eL8/2paeM3ufXfnvaDsag1GQFT0TQn1t9kgRleXzLX/9MzgUECMb/nMaIQPDvvzrjee47d/kB0FPiLn+PuuYJYQQQgghhBDi4UjgLoQQQgghRBkkVbLf7aRNIqkZ5nM6seNnzoKZnYpaKDFB06EJumgyb7jvSOXl09htbE7NN8dOEcRKwOR9mm1HNpk43sqJJt8rK5WVJ3rdnCFbnS1fKRxPQFcmppEIIFrB3rYPm1hHRBPle1Z/s+nvWQUwEts/ajVGIVb8KqfZHSKFcf1foYz3EEMMV4wRVNo0fv81bzaWVFwwYlc0foaikEjw6uyvyin6aeuHhPQsrRWsLtv/en5uL6+vq18tqQ7Z1zJaTfgcsSmn80MXicAj3yt1QWl8tGrDqkzzlInDs5DIt0GlnaP2sduyMJJtK0i0Vvz147k9v5xa6/32CwLWXjc+9bYSo0fX0dWWMwjbGdix9keU1vmyuc7IdQd/rSLKy4R9yI4ry5eLhNorgX9gwxKtuJ76Vjlx3wl6PBzXY1/RB7o6sbb9dHxRQeNXeMnVC85nsKJwJlRn+SJbM/my9Jkf9r4Xieutb7ZM9NI6q5O3XX3uMCuO30P04n7Fl0viLSgAqgZD0Tjgg6uqD3470nfvadaJOHwfvjFAJDZYA9tnnna7t5/cnAghhBBCCCGEEBckcBdCCCGEEILR/dqgnkxCE6WPZrPQjFk2ATSJn+DLJvlGq0/A+clEX97yHamb0MQjK49N6lX8s2Wisr1tN2e3mdD2c35++534iV26UtxK8BestNawGPs20bxdZc5PNvv87GfH0cT0Ki9oT7Yint/my/Rp/ertyC6zt7YV76+C2iKr43sg4b14L1LRHugz716t7x1EixsfmZbD74/YeVky0SIVu7aGhY8sLUiP6olWsvb2oIgX5O+ttfN5tL9+Prfz6bzRBkWgSI0dnopWKDuFKmLqe3rcTIBe0e8ifZX9HOmyonKqmmEUYnmbLA3zJ/Ivam9W1+fX1/bz+edVLG5ZvR8JGgkKyvst/eYcGc6OSXtL5OyCSl1fBnHlDvN98+sRpiwozjfb/C9SrMpxeaJ+27ff8s+/NEOPG/OVYU68jvwlZeweL2Y7CVT8bB0rRb5XqHf0OKsQ9ZfgHkH0vb+iVbmXy0DCb3afO3tvXRXgR+Jzdv8YicGje062cnr0Qvz0yurAB5AgvsYr138Uqy7jin++Y56B9U1wGti0+6NYnwUwe+tbCS5t2mr8HhIl9gGJf7DG0qKGI+WQt2C/wss/QgghhBBCCCG2SOAuhBBCCCEE55udyqxN8kTqEy/XsTbRZE80u1ac2MmSMXf2UGker5zqZF8j2yrqM5t3lbVjP5nyzB4a1zbXydpPJLqIfuKbCrfJ6vJwlbqBhQR+hTm/z0+SV38q3ovrkVifTcKjVeStTfZz76z+8Rx3TUiAfGPf33viVhPFvzjvcfiQaHMHULTnh81ATDpfYPJ9FtIGo02KQ32ywK8j2h2VtVoxGamQ/WYQ3viVrKNzka1w7et3DQmWdKO1l5dz++vnc2tjTIUB1p4HhT8VIXR1e0amcUJlVE5ncig3UWpVX4U+szIysqjWl5XJpLwfey5vlueptXY+jfb9x/ObL8GFOIbzHTWQiS0XMffstb3pOr0m73JSXa/xJZP57l8cSYV8qPxuyiPOhf08ObCbPHdc6LBtx62NSm1fFRrO5jvy3iHpcxeOFMunfKJ7o1+F3+FF00j0fQ97BPJRmex+ubJquX1ROno5u/JLYPYeF4n1WZ3Yy95H3Mv5F9R9+dUX7hnQxyQAGz0pI3r0tjFGNi+DuH8u5Z9bobK9YD4qG423WaDjt6NY22+bFdBvxudK5IwK7yawyPL4iBKkA5v0xEIIIYQQQgghvi4SuAshhBBCCMH5tt1kZ6e6+Y6IZroi2RFPP9J0jpl5R1YVJkrxbviJwcgPP3mYiczB/r5MovnDEDTndWI1m2uzfnj/9ii7rMjR/Fc5PqvJ4LHdhkTi0YrlN1ODthFcwa1Q13Cldl8Xt42JztFPrLP0yK7/jHz0ZWYC+Ch/hhdJzOZZtrwXH7GivJjkPQ4PECZvuEfpO0tWlh+rkvRkkcAtzNeJOlhha0VkyQThVTtpGUjUs+QzZV/9uJTrxepeODrGtmzky0rsC0Q7P19e2vPLSylScllX1Wvmu/0c9ao+X6Zf8vv3XhJRvtnLxYdRUdQ6g7WXR684LzjtYLoZf7K8kbbMnmPX8G+M9tf3n+31fN5khgJvFkdawyb/cu5vft0iErjZokjftVyj3l97HY/o5DflrfxCMTGK8dE9AvrstyViP/piwFinGWTf9TbgnosgOz6+/tFJ7tPs8YXtenRsUBhbpUascchK2O/EnvuXe9jbNouXR7Zb9KJ05I+9n2Uvd0f39sim3R6J8yMfsxcD2D04g9nLXiBAzxloG0fjDwvS7OCOggD7PKkCG4Oi/p/5U2W4f2if3zZje+McMlJ6GNTiBkCDfRYgGGu99kxKCCGEEEIIIcTvhwTuQgghhBBCUFbSrVabfEEzbVkeZAPPtPXr/nec5LZCDv/ZYt1lE4mVST7/lwhnNquo++Zywp3VhHxVeOIPn1W4BafDZoK3bye0rwLzJC8SmTORdvTT5ks6P8EcrYrufbA2fP5MyB4JIryg3pYZ+et9YYICtt/7gNKh1fhYG1VWEPST/RW2bYzPkUfwESvKizt49KG62J8Sfx9Q3lRZaCwI0iMhaGu3balA3Ity0HdTxkYUHvjFBOGtLeLb22cGW0l5I851ok3q29ju29SJ+M1sWqHtTfTb24/nl3Z6vQmLkf7oCH0l06v67Si6YyFIVn60nemUsnAq2s6oaFQ3dt01FZ5/Lj9q66rPleg3040N4xTqKvy23t7Ox+8/frbzeeD+wBXK0qzOJdMf2Gt57ejNVvcnnP8MbCOsnV45odh1WznoyK6tD9rHyjL9KFwh3ya/nCh3/fpFlje7DYzul1i+6sX4WahckO94u/q7s4rFP/A8mRF4V1Yyr7InT3c+IL/Yr4HdbPBf/spemmZ5/H0d88tvs77MvIyNQPejtk7ZMwWfN0qbtTF9EZ9h+9hsHHHPgzZpUd7uvkf4tCjoWb77bawPtXXz+X2Qg4KeQpyCeRtkx6YSe0EHAkVZZQdba/3b+TzAIiRCCCGEEEIIIX53JHAXQgghhBCCsVFGRLNF2TYmV0LpKoqTBxEpgiJ10rLd22JzWZGNSLyDJgLRZJ/Pv1dgwfxEE6orgd8wSbl4+2prmLREmRSJ2pEY3E+A2/RoBbklDZustivE2f+uPoza5Lz12bfLYp+tkFcV8jOhQCRS8G2AymXfWR3R96rgPmJWUBHlFb8ZRx7eoJ9/+Mqwrrw9earixqwucAX1lVJ1XZ4XXy5iy6xM72/axsGYSgW2blzepCuIQtPQyAh5r6u4gzHat6NdzXq03n48P7dx2q6a7WEynCiUQCFDNbRBZfl0NlzKoj3fPFF5FZ2Vr3flNIrSeI1Va4VzBBTCNFyzlzgKv7zN5S8N3/o6Lcrvvz/13r7/fG7Pr6e3lxbtuXz9Hy50ue7Qyx/2mhwNXBfL30tjoWt27Qiux3W7sbH6lQXWYBnsgAxTN9I2nX65bHJt3H1appO7fIYv9yS6vVlRfJi+enK/863elyPrNH5FPnkoH90ToReCjykvv7+qrHSO0iDhd+4P37a6fy747dNn95xmx8YH//yA2bQ+M2G9vf+nfvv4N2i/1T24eTZCgzhuKA4O7b+M7v5V8/kx1ZY52ydFcTcaY6Oxb7YsaNA34iDpevLZNgjj8kznFhx9G2NI0yCEEEIIIYQQXxDdDAohhBBCCEHodFLGgiZl/ERPVcZUVJcEIprDyNRbTFBi96G5rj0TlIF4Bm7zvlUmESttGdnxE4orkRFwNFOTXT9u1UqzogA7aY18QYL2GQH1uDkGJ+8jf6xttpqdF6tHK8tZgTwS+jNBAXsJIZuEj2Ci+OrxYwJ5b+PeVRAleP/F+d1EWxGTda2IyEO7fsg2dqtD0mZMCOoQrSK/8Wv56EUuiS/D+jMaXAn5KrJN/FzE6JukQMzczb7Wb/Zh9DRa+/783E6n82ZI3yOGjkTMO6OwVJKTHDaabkZrxaLPSrkz+5CWa1wSIM0VbHN3vP1lMezGBBbmsbRR/kqUb+mtteeX1/b8/NqGzxEI5ux1tiqzr6832HZjfT2GzUQuFno9V04gltZuI/cE9pcZUFr4KxJtvd/+Asb1+2IvuoBQ/QudycrnR9Pb6gUHdv7Y9BWbDycSWx5t+whQu36l2IkQ3Qvce2/A7uH85xny1dHXabN7W283u89C96vs3rXiM7sXZiL86mrpLtMK1g4d2Ru4Ppt0/bZvybf6Wzzcm3vxqzkXdPtHadVT1fa1JHamY8uyDwYvxA9fHhtvo/7U2/f/kG8ZWRAx3Hf42d/UZDc5wOFr0myAvpydt7eF32N0FkIIIYQQQgjxCZHAXQghhBBCiDKZFGr5HsltLCjv8jmYMVuURY/gCPUYmxiESrYkT+ZTpFKL8qN89rAtvmXNXFVZechkJhQYDJwmm9hmK7Wz1dR9GjaJjoTbaDU4O0lfERX4Fd2RSB19nhGSI1FCeSU5krZyHCL7KJ1/CSBa7XBWKOLrdPQqikci8X2BRzbRBzd/uFLxTuDwGY09ZIyBwvNgzOg2zVH0wNyiD3KioI3Qkwhp2IKci9i0G8HpQLa8O25MHs3lXbKP1r7/vKzc7kxG8hm2b09z++pE8p0ZzWTlNKvkDU7Lqw/39upRSMb8Wr5HbYKi5msa5/R7j0xVLV5vrb2cXtvPlxf8qw3WFjBmXxBZpFqrld2BiG4jBI8uAlDuqt/z+7IDfbneYbuAvJt0UYOyC3cRTF76GVvnVVsFtlcvBSBdXpKnSqX/w4W5/KXCCuUkfXeZmc7syHHtveIOhZfhvcC99wazL/Vuud2XVu4FsnvjaAVy5Ce6n2VUX3i293LZKvFstXe/7Shu3ZhpI9uHJu277PP55nyYqFPW77JgY8ljH9k1t6+ZfTbY8vayZ0kR0XOqaIxLxn7YLtWADvpXGcArACfTt8lGWzf0xjkhhBBCCCGEEF8MCdyFEEIIIYTg/HETO9gZIz97haRHPr3f778jZYq1Mba7HwmbO5qdtLN5ogk71lyVMha7aLISzZ0hPxbB0VVVk/iRKdIqijWffgYoKloLFfyK5evs+yYH2eQ7+o5WfZtZST7yAX1HQv1ZKsLvyup81o9oP7NfEd/Pcu9K7x/BZxbfi4QDDt2U8K9stD1WG0FsT9elIi4s1GUjLHfpoVameOyWFdw3frnPUFzq/eitndpo//r+47JKI0wWbsua4z6ZHf9eEUTPbvchitcqQUcMaFelvHu4RwY1GwKivLNlRpqvTEPWWmuvr6f218+X1TXgf5kg+hWJAU5YK35/27DOB1ciX9KbRryKwG16KxJfnEwumMXuGEHSrG+L+kSmbxt48yZNdg2gAxlcwHcNDXvi+JkLNSMRQqLzLcQLOitlCnHh/hXgb/dDe+8FmCC84hta/d2/iB3ZWnyfSb+U6/NELzgffZ8U3UdXXzRYPUtxHOYverbUzDaWnonBh/uH8M+PfMBSEZKjfKysagDM8s/mSQ3NPBjzn9HDNx+kwEgX0N/nWagQQgghhBBCiE+HBO5CCCGEEEJgemutb8Up0QQOmrGKpFCZFAvPgD1E9FfFTgb670y8vqSLhHBImOHFL5VJQTQPh3z1aS/fr8K6zL+Mxc/oWAFfNz/v7ROQr29ZtpPobIW4m5m+LjcACdjZRDxarY4J4yP/bXq7kp73wZaN0lRXUffpt3XL28qv0Fcpc2abL6u6f4+oQALzL4rvbnacBn3z4RNzhKDQi73vKXdWeUu2X/3p7rv5jOKJNMZYBK9GjLsRuyO/QPnL59O5tR8/n1u/OsbN7KWiO7Kf/RAdaZ6yMiKdLYsao5CJGgU+MA1xD/ZVJE0sxMp8QmFjlK7CJhIHguyZcyjSldl6j/O5ff/x3Fp7Wq8YnhQIrxVTqH8pZHVZoPhvRgiXCZ2DGLk10I/09efBDrAtt3Iw/EUX5c3uIZA/WXnVfDsIx4pC//tufCZfqvwKMccvSPaidPTy7xEvHVfSRr9Q5e9FM6G5z9fdf96WvWfd+5Ly7D0Xe+l89pe6pu/1SLVW9Q6qvusXyaoBRoQPeOxYlzWBfa5jx5csaLFl+H8zPltbURpf9t33N9lgVY0WfUO0tj4QlYH9snX650iEEEIIIYQQQvwuSOAuhBBCCCEEo/svXs5jt3vlxqxCzUz2jOW7t+nUJZ9JWLC4GqnC7F/blEwlhdLY/Z5MuNLN5KmfoPRlIIEPUkvtmV8Dh/S2a9z2WT9JpXvrcFe2gviybxH0M6FCNFHvJ/0ZaAW+TITAVnhn9qPtXiDP8OXildTXPsz4yfJkflXt+O3RsRf7BTdfAne6r1qq2O9tfnn+vU5F4F8qPN97Kvj+OxFHej82msxJpTBdPf1i3B+D66rO3tcOfCNtZm30SxnL6s6b+ndXRxPS2KSn82g/nn+2dl7nJVl9EcBJ7HsFdAiqWlzI4L77dOwrijyj8nuLL1O/fdAvcSTrL3FWTqb5qqRnoHqO1togxrpJhEK61sh17OzbMs9jtJ/PP7Z+u5Ad7LqVHWm77PUV+RbEsFc92Njuo8513Bb2xZZh0mci+7CPAfWPrqmN78H39MWb7ESeESN6+1E/2sxxuauTaesV/D+aR471FdufpR0+PXMNlf1q10zemwf8/mfP/QtbZd3u9/bti9rofjETxLNf6WIvOtv7X3Qfze7dMtH8CAauZR+7X5++H4L9dRLgvhW0PjbuUde4BpPrPNTest2OaX6ARj6hZz6D7EN+VAK06rgx8yxptm/bM3a11nrv7WkTvCMHuvvHCmXRlk3vTobrvu0gqft3IYQQQgghhPi6SOAuhBBCCCFECTvpwmbbEoXKxp5Ng9QW2xm4McyWj9KuzggpfFV8E9q/qImb229tMd8a2Z+JWLyfaI7NT3BGfrJJ1sg3vy05xqONVRo0ec1WV++tb/KifEigHtm327LJdLT6nC3PrxBvV2iPxPfZqno+jW+fmZXvEEhgEa1Qn5XHtkXHZM9KgEek+VWQ+N/A+qlMADkDEoTMwsQpvhznH9X9RH7M+ujGp5VYnQhAr2Lxy79ZPzMhLlxV3QorzbZhy/G+IDETseu3rVZz9ul7a6c22o+fz80NZWVgE0RC0GC7P3VYOJDR6Zfa8O9PnSh0QRFm5C8Kw+y+5biyyHWGKG8mgcpCPGbHa9YqbNJ1vB1F6Qvn82jffz7fxshxa0t/DQxkwBbg42Ubqi3b7bXtD9ZYl99uWbDzoJ9IXwq69BHd+utts/7uso/2DSY9E4Bn4viVHfshOvlniMYgWDjZjTR9zHZgq7yC/zuEPQ8t4vcJQT8BURDltzym4av3lswH9OK1v3/06fy+yKfoXnO5z0L3rDatLzu6P2QvKEer419L7uv0qzz9tj0je2kd+RG9CL+yFT0TcfHwdTd92xJ8t2MnGhczfIA0wDbmRzSeZfcsPl80vu0ZqybzjtVgbTP6KMj/Q2kiJ/wB99EvjcB7u73GKIQQQgghhBDiCyGBuxBCCCGEEAQ8wcdUB0wO5Cd3/Hc2EYRlPOGKre9FplpiTeSrlymo2IQimkfz819eyHLVHI3tXBqar2tmf2u4TugwzU4kPuB4op8rt/vYanT+J8X95DoSTdsJfj+hjlZER2m8fS8QyCbbkUA8Eo2jCXg06Z+tpocFCFyEgHxFxwCJ4O3nTPQxI06IfEVloOP/O4nevyyZOC4QLYbU9VM1QJ8+VW7kBxpy77AZVnERlFrthhXnkDxwM9juha3UTTb2+XYZW5+Xldupb6w9++JjfxMFf3++7j9arsIiqWq+6PTwVC8Rug8cs6jMSkhCL2t3nFkYFYU/e5gJj1AomeXxx8xnWtUPtHcUgVMnre3zaD9+vLanp35b3dynN07aF1CuQmen5+rmelts9H5JBq7X7py/lrHYAPtd6LdemT25tumvVrh0LP9mu9uH6ti6O46or56NrVkadjLMpp8hG9/utf1gWWD24pW4j8e/jLrvBOm4B059YcJ1dG8WCb2X/VEef1+IXrLOyvPp0T0wug9Def19JLsPQ/fTvs7sHh61UUb1/FnKZPeCcHsWZJiYeFXvvTH5kjdK7/f772w8YUGKHWvvGX88mb3sHmJXt8BuDqxh+5dt8zat7UrEt4qy/zifxzfmsRBCCCGEEEKI3xcJ3IUQQgghhCBsp2Xs7FA0KZOB5EsTkqaKymcv1bzR3FU0/2XTeDVRRc1Usc3wk3vMVjZhafPf408zE8+23Kuwaf5AsgnwVVnu+2oifiX6WovOfb5MWO3F78xXJBJA9lE9ZtL6bb4eUdux8rbCiVwgsWzzqwIyMT9rp6iOFR9miEQXe8T04oP5zIfsPX1jfX0mEkF5LZlAcZDdLM9kqLGIZQfyw44zk8KblT3iy2rl+oDT+dx+/HxuT30Z8LCbGSx8WFyItEgM1DS7dUGm7L2RYrTPHo7okHb0pd9sVLXI91yeWfgVlVE5rdAx2+tvJbzzq9231tp5nNo///qBHVrSLu2eHazuTNj4jOTdrBbv+5qoj2lvdVpd5+AC6n47uVhsXdH+1XfQT21WaQdxMqxP1rfNCiOTNrP2rm2zp+PxoIuveEHatoO3Eo8eZ2c6vM8cj3xCqjH3kS+f1uP87f1hljd66dduj1ZeZy9hoxeekRCdvbwd3cOiekT3nDPHY48o/ZIxvLetsEq/imEu9WMxZc04B8Tfqe+s/8/6yaxJWJ/px6Rhtu+5J/DPlND+anuz7dFYydjYYpVkN0SVBq423C1d7/2yRYOGEEIIIYQQQnxVJHAXQgghhBACMMb4dm7tD7w3mlhBMhykdMhkOndMTO/NOjtftDc9aw4kILdzX/6zzdfc9ygfEugFYp7Ndrv/zjk2OHlbmdiF2WJn2Kp2M6twR0J1u4pcNtGPJvwjQUQ0UT+7wh9iRsSflefrj/JEbRP5hfyoiBgqq7OLL8SeQ76nr9tTTiVP5ktVvMKGaSTktmMEEp3swY9V3g+U3m+q6kja7e/su1PLKs/UT7Mv9Ke3a6/44+fLdWNFAwtMXdOl+p8R24wOJwoXrk06IZKaierK9hu+FO6V/qARZ6b82bRIGvXocPReG/acWYeNvY3R2s/n182FthKP97Za5X0lSL787yrrcn3EWBeIdWJW2O7Tj7ZaPd6WH4ruL36vRPTBLQ18IcYf3KBPgau3z94eRZ1LpNdbvmZxvttHf9XiiBM0Gpd80oE/b+wgjvI1g9VB2sXdRKuRP6o8dA+5t3z2IvZS1owNdG8WCeX9PSyyG9nMymf7Kve1zA4iupeePi6rGKbwrAD1NQeUff3OYnaUrjJW2P7Upo8++7yz9wJRIITuN7y/UbAatcndZFGy/8wKRQfHH4Al3TZAeGsmSdyFEEIIIYQQ4qsigbsQQgghhBCQ3vtmdiabVUKqk9bwLJ2fzEHprd1+3XI4kVKMkU0eZoKQRBizKQd9RiKZiqjET35aweKMcLEy0crS++1J/s1UHqjXvcKGaELfTuCzSXv7n59g94Jvbz/aZleC93X1ZVTBk/RYqJERiSlQOl9azTdeLmrXqK1my8xWs78XCex/Ed7jMFXVupO+hIJuJrC025ACF+WfgQlYWLiQEaTZuD/p/3AfNu1ZHTdHa6P19v3nz1UG5k7kGtNRQVe2wVxoi51ym5DlDoVN5s8o2o90VyhdZgelHeRYLd83+uqgMB+q2dDL250Jsew5moWXkewqO5Wjy/Zal97a6+nUTq83kbsXk/fWVgLw5Xhft1+2rVZgJ451vw852dvqOhij5SvIW9iJxnyK4vP4ZOPl24scFgo+Vw5msC3t1ir3TTP3VqhwNAYcPR5n4+AeZjod68MXCQkfEUMjofUjiX51Cn3fc4/FyvH7Ix9Qmmx1dr/Ke/RCNnrRG6VlZTHhO7q/Q+WztonE7i5hnWwAJfuGH5yZDT/W2L++j+hgn/WTBQPVewLvWwQbI6vB51L3PZet77/ZeDFhmz0niY2xgcQPgv5EYI27zjfsW2+P796EEEIIIYQQQnxCJHAXQgghhBACA2ZbvHqioryrzMAwtcd28mcjZMm4dwJoNj8TKNiJu+G2Rfm87WjuLPMVTZLaspmyDirb3LbM/0hIUxKxrQ1AwfilPUviAZDE/yx5JJSIVmJH6TdljZtonQkHrLgAfV6+e2G3/14ROixbbRnRKn72sy8DtQ0TJ1RXtI+2oe2VY2e/zwhHjgbZl+j9i1IQHO4yi2xYRWpqYOe+KiQEuL5l58rwAvOO6mHGpNVKyAVB6vVzd7YvbVat8nZV6t5+/PzZxplbyKKhLAorDcFBBaJTgp1G3q8Ke7VW1+9JhFol0nJ5vVWWdvEJvB3azG7YxtXLcHPMwXkfnOa0rFk9tG0Tlvf782t7eX1ty6ru41KBq2jdxZn+UtsU7K9L35Cu79h8tn2ByzKIHUima2u3ul599PF+RfRXKCe8J6gQXYjV8QHlrda1YnNG+Li3rGiMfC/2tvXGzK8RPx4VW2cxdFVUfk+7Rfc73nYkxq68qM1WUvc+VFZh9+L16gvLUV2YKN2XaX3M7u1snWbumdiLzyDh/bA4tNp3Lemjfrj6zCgKDFmAYMtmz4NYGci/ICYPqVyGWeDLxtCZcTFNmw3UUSMO9883/OwBEEIIIYQQQgjxVZDAXQghhBBCiBJ20gWpNezfBZvGT+Z49QObKFrbHosqpjqvs1e8V52Is2mZGKQiGqlMNtp5sA72t7aeJ7O2vYgFlR9NgFq7bF4O1cH73Eja5HjCCe2LSuo6aR2JUZLy2IQ5Wrndr1bn96PV6/x/fVnVFAgVvE92Yt9/tuWi8th2JKRgwozIbiSKYKJ8m97bRy8uVIQhs0KZIwRAlRUD9/ryHitPik/CzKEGY0m4OjuzH4ka76HgS+qvAa6y3J37dgzstzI2xfh010JuZdlyl31LyOHT0/GMaF16b+3nj5d2Po2wnfzQ7rsHOEwXhsBNIYQ0hBnrdLPaLbQtGp5pqASMjc2H3Af08oc/Vbx2y+5b2epp8TC0ivzL8i8ZUJgZ2WK6r9nuxEf0lqfe2svzSzudT7dr02c0BjfXIDkZV+dMd+fEcgyQLXjQQOVY4/kTgmHzs7jYlofyo89LXhR379HAZW2BTvyKXW8zu70jtje7997P7YWdgx+AfwE3os8MsgdwRMz7SB/eLsf72mTG59kXnm266J5wdQ9ZtInuS6MXk60fyD/vp/cHCcqZoD1rJ/ZidCa+rwjnnYGQmXMHXnszp14UWPnxB40TNj8KLvzY0UFab5/1/yggQnkecb8RBU7ej10BKhocKwMYjNDJ/sgRf6DssxUhhBBCCCGEEF8ZCdyFEEIIIYQgbKdustl+NLOGZuCYcsTaSHj0DM8eAQvLg+a7IgELmtNCNjJhSyTq8WVFwh00cegVaKycSOiD5+4gXtyxErVbPxjJBOdmgtxMUjNRd2YHCQjYhL3d70Xe1dUA0bZsBT1WByTa9/aQr5EN5r+1x8QYWV6GtRMJ5e8R3EQijT12K3keIRASk9wj1Kj2Wx6glYCrs0d5bF8f5N0IxzcJ4rKYxm61sjEaT3zZUdEXcetVwDpublzL8b5l443zp9u81tbA6e325dg8td5+vry203jd1pWYHi5BeJhNmqqehzbxAD4lAqXCEE5B+QbYWdXp9iTx8IVmaV2y6qULr0uwDR1/v79HCUBadnnv7XbYZYTK3uzsvf14fmnjPLbhYTftGsWgDbe/vTbtKu1bh7Z5N2lM2fSUiGJuJApEfZ1Pgxxc8lVut9j3bLsvs0J0AkW3fCiP1/AB2+nYlvn4HrxTeVMC7XcIDysvnjIe9QIn96lW3hG/5FQRh1dsIAF4lD+6p4nuX/39kW9Ddg+FyO6xvCDei/kz4XpWRph33LZv8k0+HzgqLci8HY+G298aHz9YOvvZ9rs+xmeBHEsble3z2jzsngKR3AvAcn0gXD0kG99ZobYym4idpK1W3jtPAu53folJCCGEEEIIIcTnQQJ3IYQQQgghMGQWBm3OZDRIrWHtoFm8rIwHUpk3ukfRteRn5WTiu1k/ZnxFgp97JgqZkMx/vkdkQ0RH10lsKpjaMUEIbGUT2mhVOiR+RyusI8F3tnofE5pHP+/u65IJ0FE+5FckUEBp0QqBWb6I6AWBSMgxwxGimNk8WuF9kkc0V1VJjMqf6Y8r22bwfSbxxa5iDtNEeg6b325HmhBgf2w+gJ1eDGr3s3EnA4xzq3rMiEjNtufTqT2/ntbOjFzDenTYE+lyN4myNnQZo2ZG2mMKKTdyZ4zJEKXHYYfVfy3H34c0aTkd2O/bj8llxI9Pi/2f2V5Jk3VFq8sOJP7Xz+d2Pjf4Swm9N7xie7/puFb5XP42QP7L907OoY2ryJfSBdPWL+QQP65loTSZ3s2k6/bEZTF1ZhP4ViJL6/0JL1ryt2o/s3sPM2PGO96afiYeHYPOxuLVe5vZsvfeF6B8VdF5a7h90a9bVVdCr27z/mTt6vNn9WbpsjKyF729bbAD5ova+S1Gc/tnYuFlX6WfzZ6zsMdlyAcf3ESxeOSP/YziYFZGN/98/e33vfdPVfbeB7RG9OOR02hQruzz6VBkus1/CXmlaRBCCCGEEEKIL4huBoUQQgghhICMb6P3P8z3JP2MusLPlCG1M5+Re/jCRe8lWGBzZX4uC00i+nkw73OkJLPqLb+difmQqND64UE+o4nZvW1t60DOh+skNmij3nobaHnIq5iNOJace2yV9uhn2VF5mSCBCQiqIgDrS1Q2W43cC/K9zWi1wmz1ePvZrxhf8Z8R2bJ+RfbuWp2P2JFY/Q6qTfeoPr1q955+zlIRpmREwpd77S02o7ErylsprpsivDgyG9My2/PutKto9eLbKj7pb9f68/PLNkKqFBakqUZYfntlCF9Wvw+lPED3tTomgT9UJpSUy1jOiVJa4AcLk4bPENhC2BDjETpcpEFDXQbDR95s38xlxMLBp9baj5fnt+NrGh12C3b/PQWj/K7R/C89pC+0gD54+A/GXiaw39hFF6izCbcfFVvvAYkvD+rvV3kr4tIjwqn3bLsP4Kg49l4iPyovps4Q3XNEAvE9onm7Qnm0P3tptyL69uVYm/7e025HZWT1selnj120L0sf+Vx5qToqI7sf3+zfM5AHzylCuyxYsX2/Hzei8aDyjMfnQb7ZMliM78uK2iDaN2PH++ftTBNFyVH0VMEfxKW8QlTX3yLTMYYeHgghhBBCCCHEF0QCdyGEEEIIIRhjJdNoeFarOpPkpURo1srn/RyT8LuYEa8xYQqrvm9Cf1j8pKOdFEXKMnso/Jybn9eL5vuYr4nCik5uR5OxRXVfb33VTtfJ8rJqqkYkYI8EAWiVeT95H63YbsvLhAdVIQcSmUeCdeYzyl/1y9tEK8tnPvkyfFmsvfauyI5EEbY8idofwJ3ix0/Fe/l49LAaCWOYQMawEXozIeNi8tKfD2C7J2WF9Jvt1YrMib3V6uHWr8v3799/4nwND9XEtc3fsRixf4HLlebYNPd2WFrtYodnBAVmujB77DLN6iqaHDhN9t02XXZJsGg3DUn67U8WzkXHDIVtVaiPY315smONyi2GXxvb59O5/fj5ekt42emvZXo8hjnvWdy8mKremlgHO+mPUCxM7HbUmD7Wn2lAd6JeV5fPTtysM0Hb9+SxPkZpKxdaQPn8r94nfCSf1a93ZjYOZi8QzzIT8y/70cu8e/z35VX8nxX2I+E8uw/zLyX77f5ezoME9PZ75F/kL0vrfbnuj5pn5O28ap9KU1f78j3Xun1eU7EzGzB43/1znWjMy/LabWi7tTcThNk8WdqD7nH49R09nPLfWYP5yicBzTZCPPpOTgghhBBCCCHEL4IE7kIIIYQQQhDWQg87CeNn3uzfBr772brm9kV5/L6BRSgfwcwE4r32bJqKsAXNnaHJReQnE9CgQ+3tjiAdOQ3C1dKd+MhlTE+pcTlfrD/Xbagts2NQmFKcXUW9t956X6/Eh8QFzI5d4Q6tDOi/e7FEVZDAVjdngpN7BCBoOxOpV4QfVljiy5j1sbJCYHUFSHEHM806KzS555AxNWyWZ0ZUswO7KjL1oWRoIm1mfxFs2jSgjn68X303x3awMYGVT8KPAbZlNpGPP55f0mDFD58sDdwPzrUsPBjuy8y7XtlpOqPbzfZbfRUbosdlQyUkWv6GoZkxsrcLuOZD5xNLC9zI5E4z9jY2XH+Iukcmu7J2Zrus3ns7n0/t+eUV95OZ5utqBzjsvg+wLf0+XJE+RiycaP56gn0J6vMqfQ3pQyGz2/2+SF8X2cpu82aw5+hMnB75steVyrj3Tn7duwL7vTHpZ1kBvrX6PUCUv5quGtdHQvLo/mtcOgIkwEcvUUcv7vqy0Wfmb+U+yfpTeekArcSObEf3gOGLAdUYmrA6LoutKDDb6I2TNHVHuA00Fpltm7bzwU53n3152fObGb+XMgrxfYkwcHsEUcOwQIKl8wFNdJDZjco2SNCTBSGEEEIIIYT4mkjgLoQQQgghBIFPGmfKh0gJYCd97KSNn71C2/YoBx/IXgGI3YcmUZHSKPOjKlxEzWrLYEqn7v5ZGz3JW2GPam5GaHlJCyfFo1P1muwtUTdiRS86uGVbCw28AKCyUh52B6+GjlbDQ6J3lpb5xUQOUfnZ/kxokdHNf6id2UqHWVmzvlTrwY57dBwE4Igu/72aeEb96fMcAWkrtOJ5mrfQN5awYx0S2RTs0pWVK/44YU23+Zy2ZFMOGue9jmisBZj9qbcfzy/tfD4njpkiKiJX5xIbvvzQTg8rMXDUYc/sZWX5EMkexpmQwUeZy7ZN2R1/ZWWxEAo6AYgkT4FbhxyfvaFalKHk52jt+eXUTqfzzQ67ttH24Yre2Qdc82QCPN9fRcd1bPuPbn2bvUfwfmVCy4odBruPiMre68eReR9pywBfnrr7ItrHR780mZVfimcPrMKMyD178RbdR7D7s+q9hi3T3r+gl5GXz5FdX99oFfW3cng9WVvY+8jKfa63ye5zo32+rdD+ENR/L9tn8TEiCiKaSRN9R1SCiqXc6JmMyTP84Oj7bvTMKRprrZ92DPN2sjrZsu/l6OMbJNi+m7o0FHpgxhozu+lBBzw5oca4vHD1seOAEEIIIYQQQoiPQQJ3IYQQQgghOMl0FFOJ+azRZI2f9PHSLWDHick+DXsVStXJUdsc1eZGedgcWnQ4fVno0PjJWD+n5/0YZJvft3FzO0G+8a8KS+v8YOKGaKW65bPNlwkxKpP4kYACtYv3haVD4gUrSmAiD2sXCSyYTe/3vVO1kZWKYMRvy8qJVkys2Mj8+9JUhBOPHAM+4/hSpSoy8TqMgq4CbjM2oN7CluNFQpfxItRp9LYWkHfjQiTKdJ+7KWd4XYpJN+w2YHclWPVCowvPz6/tdDrPXdUF8Wy2GUVNKGt2es+c/lEoE243G7N2ykIr1F2wUKnir7Wx45AckBhn9afsbvoxNpY/0C9zzW6OQW/t5/MLDuSzSqL4NThI3fcFWR+FGO5fUKZ/kQj2NW2dhn635fs01ZOhcsJHbUL6uNDHyr7qhXhEWY8iORe+GlMx8cHHaU8Mje5JmG0kPq+Uye4z/L0gej2XvbSL7if9S83rPPx+hdlH/vn6oPzZvVTU1qhc9GKwF94TY/eDnmegAMuXGaS5+sz6bx8fV/xjY6EPYEjMC+1aorr78QjZYfcc3kaFqJxq+izPNQlqvKqxyk3ssh2daAiz/Ve+RxVCCCGEEEIIcRcSuAshhBBCCIHpbbRv9mttwobNdkUyLD9rFilXflElAZrEnK0KE8pQhRHJH002sm1I/NjcdjTZCgRBmwle5icTELEJcnYKoe8LbCLaTuhmDP91/V/4s+qTsIn/Pba9ICIqC5XHtll72aqE63Lm2mlGzL43XXnlwA/gs/p1CL9x1R7GjvGk23zRUFvUdsAXz6x+g4hTVvl835vZZD6Z/P3i20jGFlqe3R0Jki52X06n2MgegM9smAtPhYpoasKd3ZfqIgD2NiYNzlanUha7FHbpWc25em/0ukfH9Qi8hg76Za6z4bdf+PHyil9uQcI4RiKeW12vJO1d10trl9VU27ZhervVD51EUR/mbfrbpuw2CfXf2UnCLhZ/kI842SrX+T1xwKyP99SJCUIfyS96K/wIsljY35Ms+M9o1fJZ/P0eEp7f80Jr5B+6Z0MvVWflZ/eWe+pQfTEACfY3aQYQ8V8+9t7n+o09g6p/JoKeI5AAaXMemrx9CRLQ4zPf//qxozIuoGdIw/yz44Tfhgb66JkLq4dnz3Owd2LA4MHeRLDgxf6zedlN1WQj9Nb6U2+TZ7oQQgghhBBCiN8ECdyFEEIIIYQAjNGeWrMCdypjMfv9d6/MqORb0qP9vbU+3kc8kMF8qG5r7TjBSHZYWHP6skdRHGwnc70Ap1D2uH3IJ0+z0475F4k1V5uL9fV+2d2Fn4m+V9AwY4Otnp6J2DPRgV/Bz5dTWb2xupr8rN0jQKKNSl0+iuzXAMQvQFV4WGHmVFiEp5UhHYl39lIVrFb7/SydrycRHW227QxXeuvt58t2Zeoje4os/Embjo6F8X5Uzr6dSZ6gfKahQqL1UjVIIi9rCk+NSl33nACTbXj0SHB1GRgewb4ZzqdzezmdY6FcpRyvPVs+sz5sIzrc0lm/B44lW6m+jcu+qE6sbpH/va1F9VGcj3R23lkmzozi+4++B2NEffx7see+5Zq1mPEThn7VmLgiSJ8tt7oCe5auQsU/dj/B7jH8X7YqOrovigTslftAJmiP/GerqVfuNavtt3pWsHZke6y8XrjaP/l+MIuJ0bOPHazE0x1s875Vn+NEaSv+ztRptv7+2VFrd/WVJXbYXg7D0yYoZsZQJOrzMBtLvkpDrPb3IU2DEEIIIYQQQnxJdDMohBBCCCEEobeGV1eEKRdmJ2nQrBxSOvfbx0dPiFXIRCvZtkg0zSYqM1WbTYPEKF6sApRbUHxu87N620OXTa6y/EiwUxUkWvsM4Pto45oPihvGbV+08ny0unl1FfBI/HD11fsOyvL72E/KZ8Lx6op7VmBRyWOFHJngAtXHc88q60zg77dXVri/p2x2jPz36kqMEr4/gDsFLcxkay0fz/aUy/Iwsafvu/3+mXLB+NPtvpm+OxorUXmRjsRunxX+MIydn6+v7fV0jpLcTRT+zDQjsrtv547CqgTi39Xh9MdyFA/viPezS96HW/6grPKYL2kzmnoddU7uPfmu2QI/avcHMT+fX2IX2fWPtrP41+aJYlKzb1h7qBwQ65ZeGIoIzne6CfVnka2KVm/ZH3U2R3VqR4+rFb+OGOcexEe8OPne8eLsCuILmTj9s8S96Je7/HcmgEdxPrpP8fdd6B7M56usnO6/V3yJtrP76sp5Ht1zezF4+gLD3n6hgn9ewWza/pSlBc9loD0f82Z20fMc9t2ObcN9b8m+5vb5bVWqz74eySrAQw2PKslucprbxhrOpiP733Y/jTG+4QRCCCGEEEIIIX5nJHAXQgghhBCC0ZFgoyqhshM80YxdpKCwaT/HxPXhVNRTfjIxyo/223xIDOMPUyaYQWWitExsxE4NdopEgsVZ8U0wn0hXi2tckLDsezO9XcluXTSfrIxE1GzCfkYkEgnwGezn7pkQ39a7spofE3j7tvbl+byZcCOqF1u50H5mx71aH1Z+dHyylx0yPnp1+T18iDiJ9VGIbKjaQSiIzHzaKwy8V4TJfIjGqUX8iezfc6ra8c2PE358qI6fFX+gZmu015fX7a6sTQcxSbZH7h15aDeFThgoH1JW98RQv8SmA6TrIB+9zvrKjcjF65dN6NTb/msR+HO4Di+JEb37M1XJfC3ZGaP9fHm5rUjuHUOxalZY1M+gfiISJs70w8H5OjXW2PSVWN3my+xm21nbRcfh3nO/2rccFdYk+sFpfr1w63CieP4o+5WV2iO/ljRoFXSUL3oB16+mbv/L7C3xPRKRs/se72dFgI7qvKRh93KRLfZSNUvny72W15PzYscguGl3119VfmltZRc9M2H9Mhtj0aOv6PGXj11ZP2X3s+cvkW/RM56lntHzmKi8KtkzGjbeHBVrBfBTBTUMGxzRQyxky950dPc96uuoYSGEEEIIIYQQvzkSuAshhBBCCMGAcyvVmazK7FikvOGze73DzZ8fJCLxgrpoMhKlK4rnwmZnPmYTuWhej6nx3IRq7307WRwJJG15rO1sXlRuNLHMjgGYRN+6dRE7DC6IuObdiMvWk/1MLL/J09YT+kxEzn5OHtXJih5QWV7MgfL7Mr2Qw29HLwRk5UeijIqYvrIiOxLVeyLxSSQayUT1UVm/onC9yofUjQk9PhLUDKivYv1klOdoMh+yulRseGGRtRvpSmaOqS0jEyWBsnrv7fvzC7Ydtf1wH8F4X9ESpYe32BahnUecQ5f2HsZ+Ft71zYc1paqaRJXD0/3GpJDd3UkxY5oMidDsPmfLh1XD7sTZwqJ99jDk7L2dT+f2krwc0ntbC8VnGxmlr4j9TCW6L3sTz5Gio3JoJrANxdeowX1aP2ZE+ZpJk5UPmBY0z/bTR1K1l9X7E8QP9wjJj4q9Ki9vvgfr+4X1dkvlxVkWr6N7JfYyLrLBROHRfRsT5qMyrD9RPuRjdv9iBf7o3gTdA7J6R1zvmVkWF/9tbKMByPfrzG45ENkBe04RPQuyee1+/9ePM9F4M3MvgewdfWlHcYv15dGg+wq8Mdjm0/uBNzow1SBBCCGEEEIIIcRXRAJ3IYQQQgghpogUa5WZJyijIXZtOjd5W5kI+2xUJmkr2+2+qNn8fBmaV/OTnSyd3+7TIt/sRLKdhLUT0WxOEAl5lr9s4tnnZf45m3Xh1jblSixdMbQRl+GDvBIkFM5zJoDOhO9R2UgIXhGtIwG8Fz8goUlFVBH5u6RD9WDpK2Ww7Vm5dbbClEcyLTB5Lz5qDv+zaQey4XTvIUFC7SPzP/JUiQQ4bBxA+3pb1yPToPiyQVm9t/byemrj9Rz7bD6vRNqRyAm4s7HhvwfC2Gmd5uwxdcN66XRzsVzl9M+Gdm9geQGtDfMi2uXzeYw2zm/7lv3XdDaNeYHNiicP7T6qxirHJdJLVTE2oAlwTlPpFzr/Dc+v53a2J447yJfDkp8YqIBIyDdxLzGsLWOzt7d+YGVm5uRgIkXogPteSZtp6zL8RRn0uauVkj/b2BoRHa9f4F7zo19+rMTJle2R/eVvlHe775YexelWqD1zj+FF4zYte0kV/YfSIdE5E6nzemPfmX2fJ2uLqB38PWTl5eQVs/3m2sHbvtX4NbbPIqDJXgu4WLk27eJD9izFP4fJygzGSZoePY9BY2F1PHzEM7hq4BiVe0Q32C+FwLZFNwf+oFWi18pNRjBgk9NUCCGEEEIIIcTvzx8f7YAQQgghhBCflKfW2rft5khlhmb4vALDz+wN8J2pz9bffonJHTbXxbZHE3e+yarpl8+svO72R3Nz2QSo95FNFPtTws3vrUQMzhYVODC7SLhi0q5ESwGrMpe8vT7D61e1ywQeTDiPBOho9T9Whhcm+O1o9UCU3teF7Ud+L3nsX4av7+JlJkqJViSsiDf8SorIBtvO8qDt6+nsx/dqM2W8q2jqo0RkH1HuI8QhFbwwZsaXaOhH+yt2Z9oBpc3yu/Ggt/YmkrV5nY2NSR+muO2vp9GeX15af+q3NB0IXo1Pg11WfVs+i3WqYYCtAk03G1Cx9C6Eo4cLaYKiskCa9LTprY0x2rc/vrV/+4M8+h3r40ROCWS6ff/5ko7hdxEdk6y9IgFdoUxaf3Lcut3P/DPbcKuN9uPnc/v3v/0bzbe7uau3Lb5MdJGBfSOqd8U3G1dHt0ERM30hs1u9AFj51u6eMaZazuzxrPBB8UcW/35W23uYFjrvgInG2Xckwl5A7efvO/x9VvYyb3TfU30ZwNqNymdieE/lWKD7zeg+NmvjjeCc9aFuLAvv//NKbNM6H+A9PRqLi9t662ubzM9gfEljJZs36oeRryyQnB1Pjr6n2RPvtyN9uNzHX2LEeqGoEaOAorX8pGAufp6+XQghhBBCCCHE+yGBuxBCCCGEEJDx1Fr/Y37+xCtrNnZdOlo+sf1RKsidsAm6aOIuE93c48OMOIT5hHxHZS3fo1OClLESt2+EbaQCiYAHCheXdBMCv+sE+w5B4IzgHJWJRAY+zdzqhuu81h/kWyQaR7767cwWWmUQ5e2XoziC8jOiVSaRcCQSjEQ+VMUrWX0+SqT02cRRh/ELDiOUqiCxIm7cCz+tt0SCmply/Fi0sks681ET7W4E8FH9em/PL89ttLc3AseSD2VD4iqwn2mRKMb/SMvk067SM1Fz4uvsvlFIM12eSzJae1uFvbX2j//17+2PP//Y7Gf52DYU4nz/+dzGGOsVqzPfKnFGFjNVCyO7KpccTYPOncaPayWsvRrorZ3HaC8vp/bnn99wG1QFbsv10M31bPPba9s7aW1c9q3sRLG7r2x2naDyra3ZGDMrq/o5u0gqnVTpwO9gZpz7BfidxO1ZmXv92b4UGt9LZOUge9E9i80z+6IyKjdbjd2mt/55mIB+Y2eMyxi/rTPLw+z7fMw39HLz6rvv39jjIhc3hW0yWuvdbUeD+LpC68+o3/UBQBQ0OH9GN3WNxpsMloa1m/3L+m9f16iM7D7jyP5+5p7iAdiY4S28YzcDKFLce4Mzl6cSdwohhBBCCCGE+D15+mgHhBBCCCGE+LT0q06oAFI+oMyLaiSyUSjpswoZZsRLbLufNEVNVp3bYqITa9tTPUQrRVmSZvmMJpvR52gC2JZXqc9ASY2aMKqv45oPpA9FFd1N+I+1sCESvlsiQQQTY1d89KuVL2mrYvlMGLL8tSKRTDTPhRvr0iIhRRXmg1+l0bfRTHnd/GfJLETnVaX8I9rkCHuHcs/c/qz7e8qqjAN78HaBAGiaWSElK6vSj2YiTGZ/wu71o22Xij2kX2H0NxMvr6d2Pp2xpgeNvYNUc6Zsn98YHO47zoBdDIuf9G3XqVgRcA1uf7Q3gfT5fGp///vf2//9P//Z/vjzj02Ygi6hxWYSQmzyd5YIHM+0Cb1G6t7rqZKc6LVgsVl93IZQ6kUEeL219nx6bWd7nTBtGfB745LvH7NzjMSyw58kPk908iQ+hvVC8XJGJZ629iv1QDF9NW5+z3DhEZq/X1RHeJS43b80m72IW9m2J25l9zP3ituzl4JtWWy7F31X2ozdD9j0/l4E1bfk9/V2d6zqvyp707/jOrAV6WnZ4HOWNu3vB6n7cp9NxjVvYxcs9rV2/RiSXYpsTKmU7UGxA2tPNu418L3KjnH6s4GuSDwo+oGxMpj7z+ggFBrqLfknuBkXQgghhBBCCPHeSOAuhBBCCCFEQL5IEFKOITXIAlH/IBXTZh8X934aKtNN90wc5mpY/JmliSZio7k2NpeHJlaXv4v9rA6JUIz65G1YsY6r5xgj9YcJD/bMKW5sOcEBYiOoNsnGWK8myPyNbLZRz2M/o+8VAQzz14s5vAjDp2e+sTRVKisaVsqZPT+YyCWyxdqI2Z9lVsT07lREI0eWdU+ePX7OiCGRzmKWoI69gTiApb/nuESinokxYPXy0vI3E+9kwlfw/dxGe35+af1prsL2pcHrRztuHi1ZwTowyGb7IMc/KSvUl1XiGHZ8LufCAGnGGK0/PbV//Oc/2t//9ueqSX1I0t0/Hwah0IdJkprfDgyvjrMvBBUWtffMtZ71I2Z/qlc29YGXqdsY6tzQgVk4j/b8+vKWKNOPsTZj/WT0OWuApXx/3Frj5/RsvM76uVkf0YnNfHLXFh1PUL19moxHj9n39J0zY26WJ+AzaRKrAunZ+4yKzQr23qCyUvisXbbP389Ev8ZUFbJH9pDt6ovGUKzecJv5e6yjzkW6uvwI2mYzXoz1PtLXWcE+xfeZra2v49lqV551LOmiOA75lfnmx8qR/EN5q9iy2HOce/g8XV/IMLcQt1OYBV5sezU4q958bPb1Mc76VXohhBBCCCGE+IJI4C6EEEIIIQSht7UYa72nSqTG8TN9XpKEJ4t6qsT5xcjEKMu/TMBjt2diIJvWCmJsmeg7mpNDoi2WdrFTEXdVVXjZ5Ctqh8I5NDv5D1eO22mrNSBsCPyNVoJHviDxQyRkX8qw+ZAwG62M6EUVmW/eTvSiQSQOz2B1XOxWxPMzK1Ye8WLEkaKUmXIZHyrW+kXEErv8PCoPU/kmWLHq6CwOcOVEOo+9fXlkd7aNXGjRkZ9FO7319vP5tS78N+XacmCRpI6btGy4QWIpJ36qDpWtE+1uVZMz1sl7C+K36FjYWMIL48ZoY7T27//+t/Z///M/2p/fvm1Mg2wUVLT9N0bDP20UxUYorT8H9wrwDuoH7XEefkdU5CXjTBuHl8lTb6fXU3t5fW3di9wjg+WTeimoxQ77fNm1vaSJYnmbntmPzpmonr6MyB7aFgky0e0YPWEIrF2qOsBK2ihdlrdah9k8E7x3PJWJp98bH99WXnKdtY9epLX3EfhXlm5++XsUn8/mR3miFdij+yrkg69TJMT33zf3WKBp0Qry0X7vb3S4rvayPs1RfSkjSZD3s35bZCt6lLWA6umfmUS++fzZ2IVsZzbt9i8Muqvnn6+RYeNBXHbgUHCQHLzR+hjSNAghhBBCCCHEV0Q3g0IIIYQQQgTglTsjJU51H7L5RWbbquKSPWmi8pgYhYlB2PyaF+plwiIksIwmcZlPNo1P59VVFR3ExU4vL097SR/P2oNNRfvONlvpbxEjeMFDJEj32xfxAdufrSge7WertLNVGJE4PxJzVFaLZ+l9HSJBPqvjHpHNPcIc2w5IRPORfAYfPi33iPGy9FVhZkWECGxNDzW2/410HnvstrbWkGRio2ib8XEs+is2hiBB0SXPy+nczqdzLDpiglSzbebFgbujoB5+xUycM3CXS1fSsrHzFcUtY7R/+9u/tf/v//yj/f3f/m1VpI0ovU53jG3bLz/qgmzY4t8E+mz8a5dx1VWdVHq12WoMq4K6LK0taDYPSovEfyYNrGbUB5F26b23l+fXNsYZX5+2P2B+sn8m7fX69ydLJH6sbMuw7cHiaVTHCBaTZ31xJW5GF0bFj6gsZpvtXz7P2GZ29nKAjShm+oh4aqbM7CXYI31hq40jcbffx/xCgm1UJy8E92nRfUy0KnrUxpEI3duI7tVs2dkLwmj/fBi6vk/a80L4VQSfxBPpi8R+LF/s+n4WpIXbqn1RZMOPJWzsqPTZMPYp+Mt8s2X7mDfK82iOGl/vZIkNe+uXUI81YCWiZY3M8lWCpKuDQgghhBBCCCG+IBK4CyGEEEIIgXkabdzx87czMy9sAmerbLAalF+W2YnDTNAYiUaiND4talw2+cn8QCKdaL4OpbfpsklhBKq7FzEZ27UV4YB/GVdhIre/mqTvdbFDaMfl94LuSBSPbLLVCFH6SNxexZbLVk1E5SHx+xFCcPQiQUVY78n8YML9THAvPimVS3dGwDhr25YRbc9s7RH/RGXMjCnIfiTWqdgY668gzOC2e2ujt/b8+lwW68L6RqKnKH9mF6UnQtlS09vjVzxWU6dzJri15ZrjcB7n9vT01P7zP//R/uPvf8MmLnlh8/d21aiPVaaJ0Cmo6Kq5ig1yPUTovGJOVRu7en1Ubdmy/ffIJ3RuLrjr8Nxae3k9rRNFsepiD8V6yLdxEbKxa6caV2dxc0V8iI4xugXyZc/2paQvoDYyoaW37dNF17LPWz2XK77fM0b8MuwJHJaceV720qz9jITe95afvViKxdn4ry8ze0HX2o1ejPU2WLyf3Zd5gfpsm0ZCfHjs3D2pTctvt9f3fxUfSEJIfl+Ey15ty7TGtm/KRNSszyNjyDU/Gy/sv27+oX7f2otiOlYPlNZu/+z9Hzp++7u5/VzbaVzE7miwRTcOnaR9pI9CCCGEEEIIIb4aErgLIYQQQgiBeeqtf9uf/ahJnfVE0XWe8iMmvR5FRWA4I8JpE/ujMqvlsInTmbJZfjtvOCMg9LD6JD7eJvetqcLJF01Ar+xyAQnLGdlB4vCbS1tRRSQEQcJ0L6BAabL2qQq19whnqkL/KG8kTq/6vmdVQwnYbzxiddCorN1k/SJK86g+e8lbtc/Ehsumih8zYiGWrlKOH/9m2jAS3rJtSFDUWmu9t5fnU2un9vY0cWZsQt+rVMSbWfmPPq88FSFqNEZSrVBv//kf/9H+8x//qz3120uPNonVJF2/D6yDiyRJSBf3ZgtXDlbHGg/a5LoLnTOV43tUdxldL7ZI5OemoVr93HHnam+t/XxZVnHvXEBYvQZHWy+8j/ofL0hk/tn00Wfk195+FbHnmN97nqALhtmt9AHL90eHP5EA9h4+LGybKzh7QXVrHa8OHtmubp994fWe2Lga90e+efF5Jv63+bKXY6N7LfTS6+xL0BshuGMt1Of+R2WHL0EP0vYj9/+ar3rdzsRbdpyLnq+wscXvY3rnqGxkE+1H/s32mTRQ2sHey/GefO/Zz27aNhrQ7XYWOEQn0Awmfe9zvz4ohBBCCCGEEOK3QQJ3IYQQQgghGP0oOUCmglu+ZwoSAQmEinTOzaePbCz7IzFVZbKUlVERxizl+0npSEBj01ox08Sc4GhjaiL4OiGflHGd1B+3fIugIRZzrIXakdiBCUOQ6CITkbDVCtEq7zMr/qEykD9MyF8RR6CVEu8BrbI4Kx76KO71b8/K9Xs4YuX9mbLIjpxIqMKEoplWImrCSMi55K2IY9j3JUvWt0Yim4p4J/MjaXu42/f5GZNjQW+ttdN4W1V6RoQcce3/4/0b0dWOMnZRGdNn7N/hy+l8an/8+Uf7v//7P9of3769NcPlerieWsA+FGSv9Xdv/8Zau7uylcVPQfmrQti+iPceUmysNMDlXT3me/tPY/+p9/b8cnozlcWPvfF2XnSSWd+Evs9cb75/ZsLEjEhwidIwX+znWbFlRKXsavnOZibI3aRJ0h4JLPdzh3wb9sRW2b1BFFtnAulMOB/lZ3lQuZW8My8eV3+RKcvr762yNrIrtfs0VeE9K6uSz+Yvbe+XezAvxi2cgldbNES3gt/cHiyf9alIp4wE71lM7u3b8cr7UBmfovEl8wURxTbZmPFesehsnHkEAxUZHbwKUdrKTZANXH+xgUcIIYQQQgghxGFI4C6EEEIIIcRd7FGx7BeyI23clwFNgnqx4QyR8BsJNJF4cM/E43D/EGyiFk0u+79sItr7YH1B/tl0RWHRzOqI1q4Vms8IFCLbs6tgR+J6LxrxqxmiNMj/SAgeCVJ8udZ2JCSZXe0QrUYf2fVlV1dhjPxELwkcKRyPyMRBWf6KcCo79u/OkcK/GaFzVWyZlTdL1H9PCs039lDedVe3LdeLfiKbl30bbUcmuEFiy0jYQ0REL6+nBpUv2ZiYCFaHTYPaA9lBoLKJBsyKhulhRsfO7589XyfP2fN5tKdvT+3//OM/2z/+19/fXO638MXq5lYLfQ/zZ/k8Lvt9m7jAcvg0m+uC9HTR+cfO7ag9UMzFqAiIo7iL7IdFV0J4Xw7aj8R/zvbp9dReT6fNuXM9Jr3xOnk/UBwXXW8+nU/DYubKeV7dH/VT9rPv01j7orL3XMfML3Y8iuPp6soieTZX3x5h5+9Gcvz2vDBoRdOV/NH9C7u/qdhEn5mfPi16Cdfm8zZYWlYnb4u9qMxeErZ5vG10P8KE7EteJH6P6gKP7dhuj16MqJ4fIVkfTsq1/t3dB9g+1/ZjLC5kfSrqj6I+Nuq3/X7mb+SL3+b3eR9R3JGN+Xce/k/JtX62EaObBH+Ql8aMTqBNYcAmord+2CIkQgghhBBCCCF+JSRwF0IIIYQQYhd7ZrMi9UMj24il33EyLWN2Kiua2LQ2kTBmuP0+vZ+3y/ysCL+iPGgilpUVTfaa/L11Xr6fz6xM5G58mZhwD9JZ8QATUt9KXIvO29imjWzMiI+ZKBvtQ+KTSHiR1ZMJ4Cti8oxMCLOkiVbIt5+jlehRmo8ka3fEPYIlb+dDhO5HFMmEJnuIRJI7RYNh+qrwxqafybt0RWi8eO/T3o8bbAxrlxjDai1Ha8+vz9uEY20atgkTDSHfXP6O0kTHHeUdqz/h57uJRGGsQPD9fHmL4R//8ff2n//xv9offzxdX2y4mjb12hxS0+aL8L0bn/xlGp3G3vZdetqK0Ky6r54kjmns9sBgZ/siYZ1vQLQ/Kr+39vz62q7xlO1PmE1f14rgz8a0M3Eb07RVbbD+NOon0MUbXWfR9YaOQ+RjVDd2UWV93j2wcxl9J31svajPEadBhv3oByWwr7B9TxyYvYA6I5rOfEZEK6ZHwm/00m7kk90WrWLvXxKI7t2sn9UXClhZ1TzI59aL6d42XvchoXyY15U5Depvrqd+X6dz+8Oy7ViA0rHt3h8/9lX6Ye9vBkuT3TvMtnd2CX7Ardv74W/sqpF0dKPBAhNU9pb+1llJ0yCEEEIIIYQQX5A/PtoBIYQQQgghPiu1ye2ZWa1ATZZ4spSziJTGaF9T5I6IxCb2L5pAbWYfmSgOJ2V9ej/XFwn9vM1I8GSFR36SORPTzdL9V7Pq4NQpPK5pvdCDCQpYGi/GKK+G2J2wYLQ2et5IFaFHtNIgs7mkRystLvusTfuXrQzJVl335fltlVUTvRCfiT4qq0wi31F6tAKkb6O9Qqs9ebP0e1cGnW0zUPDU9V6t+672nRVGVm1mHFFmpM/I8iDhUOSTT5MJfpjNaBypEo1Zw2y+9M0/Xp4bXCOjm6Kj8SEatwKqp1ZvrQ2uL6sXRHaVqTpLvo+Lcvlvf/u39u9//xtMfnW1x6cIqg+LHZnWjJ0mjFUo4tuUVgSktemT8yQ996y9JV1FGDdzPkWCOh97sjqTOpxPo7Vxvh04FtNG+rOsP6lQ6XeqfWLmq9+HvkfMjg3oRPfbUDwece/+CpVxwLf1keP0URwYP1zjF2AvEljPbGdEgvYZ7ompkT9LmshWJGBHAn6ULrLltyPbj37Js2ofCfVhv9tdmrcP8RjDYGNBZme5r13d6o59fqA6zuYbwd/W8mvd9ru+TVCZzJfMPipPgOHXNlhlUFtOukoAsLfx+9N5DGkahBBCCCGEEOILoredhRBCCCGEAIzRvp3H+JPP8lUnYyJFz34kbk9AQik2PxcJRJAd+y8jEzBF83qZn3YCGE0Go7zj9m81GQ98WQkZKj4Hk9azqxHuTbNM6lMRBxIjtJvQAq5CyNrElXsTaay3s5URM9EKSxutlujTIlFKJHiZEe1b4TyyXSVbbREJ++mxT/gsK5B+hB8PE7ffMi8F4X7oHrFPVuZ74suMhK178X1pRXQU7SN9PBRqwXFntNPpfIs7fFo//vhyZsZc8H2THIw1YbNHYuZK205rb+bzjTHaeYz27Y+n9n/+9z+u4nbrgo/7NvIh22ZmeF+FPn27fVnhPXL9KllK6nS1C2KdTRMHYvIyM8ePxUj3ittYfITEeeicK9Th+eW1PbEEFd+j63HBihF9nMuOle9PUJ2yPjOyWWVPP1wQjt59C/iOlOOvzxEGtdbAfchHlV/8XgG9dJqVe095e2xH9wnoJVd/H+Nf8s18jwT/1jbyD9lBfkdp0bbqSvEmw+raqdxnThONHfYzuwdH36NnDCgmzMZl2y+i8QyNGT4+9OVlY+Dey6Iy9rCY+F4+UT+7B3ulVVKtiYIMdqLWGWO0MX71FhZCCCGEEEIIsQcJ3IUQQgghhMD01trT/bPuFSVX3cYn1FR8TphYDokw/WQumnvLhHvR5CybiGZCULvfi6WiieDu0iHBTyQs2ojniGghE1lGJ2kgJEPi2inxgWmXVCRidqcCbeOCF8Xjcrbilky4sRbI941PqNysvZi4PRPI2zzMJ5suErdUjx9bnZ6RCVdmsP4/evXIih8TGQ4HtuGsFgFd41m/gOzOpp9Je6Qs4l5xLLPJtrO23KNByfZdFNEvL6fWzkE6bycTSfn9aGzy9URCLLD9aprFAJHfLF0mFGPlRWO8TXpZVv0f/+vf23/+x39ce1s/5G9Mgja5DufkUkbNavejKq2q31vbqNyLYrvB0mZc6tnN51U5M8dlJ+UuA8Vf/vxGsV1z6W3y3trr6dzO48wPHvIjEi7abagPY7FuRkUsyASOTNRZ6b8q/qF2jo5DZmdvv/ogyjEQuRd4ZPyTxZqPLp/Zz+45Zlc8v/flxUp56OXcI31j9is2I7E8us+x9zOZ/9F25k+W3/szI3q/64XQC5v8mTlyD3+1k8VzM/0lGxfQd2bX7q/GrVHctzDTV/tx5d54odL/V239lsycJOhmEX1GZWSvWwohhBBCCCGE+B2RwF0IIYQQQghGv0pqPg9EmPBlOErUmE26kklkOD/H7DawffnshTUZkfKMzRVGgj4vavKfMz9mBEfDTb5v5vMPErjsODegQNuLy4DhbMXAaLXCBSYMj4RAbLV1Js72aZB4Jyo/E8JH/jGbfntVbH8P1ZUlZ+p7NJ9ldfkrmWBlhqqYpgoTb9r+JdNGVMtBn+8l0nRkftgYwPen0ZiXpaOxxWgvp3NdzBmNa9GYFI0/i29MAFssPh3jlnIq+pxMmJUJry+cx7n9/W9/a//f//5H+/OPP655rXwHaZM3Qz0pi4UyyC7T+g6f3qvnZ4ReUUUiLm0CG8Pb8senUmZic4BtKfa8ZeceitlI+p/Pp9t+b5f4vbHn01T7ItbnonTMPkrvY0+WxtuoCjULfcZqX6qpS+zMCEg/EuDfI2OQiu3Z+PERPuyxF8WxTARdFXd7UXg1HVupHL1MGu1DZSGYb0v9bTscHWePNkw/vW6T6urue190Lb1MnZmr9ikzfvjB3PetPl5m5VYuGTs22GcLvk+Nyoz6TRTTV/prZu8oPnsfv5Nr017b1h8AdAPBbr6qAzbaHwQPffLXF4QQQgghhBBC/DZI4C6EEEIIIQQhnjyJlGTzJVVt9svkYbRu0bLvt1zbqCJMyoSZkUjNTsx6QU8misvEhtH2LB8TFnn/KtvH5dzeccoigTWdnDf2s5+SX/m6+vrYkzhbsX1JEwlL3rKsBRteJB4JRdDKgSx/JtT2ghmUfrZN7UqLqDxvG4l2ZsVNe457JEyZnQg/bOL8EfPvj5rTj0Sgs2Vm6e+tQ9Rve7EkG16ZX0wQOXNKVoRBrhy04nY6lvm+d0bAydrM+fZyPrfz+YRtsnMGbQeC3U0+nzcQ8HZ7XK2oipXBzoVIPIt88kIx1K4N7Pebx2hP33r7v//7P9vf//5vb/GaHZYv31Ecd93U39qhux1j3P75PEiHZsytsHZXbiTBJTz12XHfF4pgm/6csNuyc2PZx2KnyIfoOkIiP3QOsbKMb6fz+c0cqkvU52R9F7peO/js7fnyUV2tb8N9r/qDfIt0ctn1zcpD/Vd0DmR92b1cQ+w7jD4gXqj6s8tv4O8jhYyRjzOriLN7nGz1cxbz+zRof7bavL93ie4LmJ3oZV1bZyTy93a8P+zz8r163xDdz7J2Xb30O7Zpp2D3wLeCr+lsedfjWokXmc3onj/qwz3VqqO+Mou3/HgR9Zsd/JuNvWe27+HIPv6zsoo9o6A2uHnY7GcNl11AWx86KkoIIYQQQgghxJdAAnchhBBCCCEwk1NYldlN/znLiybRiQlbQl///e2pHCkmWEHCm8gum9QtCAXhRHTFFpooRmX4srygitXDpkcT7SuR3NhsSycZL+XftTrjA4VEVERhjsFYN8Lms1810H7OxO6R8AWJ1qOV3JEN+z0T7CDfM1G9tbv3GGdCHesPsxkJiR71okS62uMBxW7KuFeMwwvat29P+vcUiPj+1IOEpjOwPtOLjHx5kWaElRN9j/yp2PO+XPx/eXltPQgmuv/Cxo9M0Fptw8v24dPZMiKRq/8ejHdh+mVcZeMu+m7429/+1v7zf/3HrZe+2Ftpx81wu3HBdgmLYO6inev9Fv+xcMM3WRQCMVsryBAJC3Hb00uO5ff7mU9RrDRTFusfIjEebFCQL7se+1uf//r68nY9Vq8r+xnFlCxORDEpi0WNj6s2Yto21I7R9Rr1KaR/oLF3dgtWiTVZv370PdfF31Dom5XJ+jrj756XHit1zV4MheUeHtbMxZ7RiukozyKStrF6xYfMryjWzWyhWNn6yfLa/TaeZvcoNn/WVmPc7jHY/YbNM/sSBRPIZyL5q8B8BjYGZGlceZv76awfisr0/bu3w+yxOJXBxoEofmN+ROM2GiOqMTzbxnhE3/2rMxp4hsgCKT/Qv+cNnhBCCCGEEEKIr4YE7kIIIYQQQmB6ayOY8pqZMavOWhYnhUa/CY40j7QFiV/YRCkS3ti8Pk0kKkR+VA89m5xGIprFFhPxoTlGJwSCgu2ZucmL2Cpsl7FNT0ULSJTkyittiyDnABVvgEnvjbCnY1GI/WzFGpHAfLWiYFu3F7LPhDhM6F1Z3ZwJQioiIS/Az8RNFSLBEPKzstJ9ZHeW6iqTFZ9my7hu+wBhxqNeGDicipuZ4KYiPo32RSKdjjdvNkb9K9OasDLZ+AB4eT3fggyUbyRN7McpNh4jX9n4Vh0jvKCqIqxi+yKB7Q7GGO2bUw91+8G0W0dt4MpeBO2bcMN0Eb29HUrWvCv/XBHpMUZjdxBLdJumYnuT8fLVt00Uv4DKdl+GPzdR/OUbjqWp1o1dr6Dxe2vt5eXUVqv+krQrOyC+7I3kq/ht86J9e/B5K6JD1oaV9q/4kgkwm0s3ce5N+7J3v08L7mt2rZC+o30rLzLWiq4XvufXe1AcGQm9IwF5xQ/04qv9zF529fE/ehE2E6CzMqP9vk7sJdyVn32bD+HzoXsfVr731wvIKy+j0mOYjAubPDbmqcYuqN9C8Qv6brej/snbjvp8Frf6cd720X4cRfhY1dqOxjDGUicfZ1bsoNgB+SYM/iBFjcryVuwnLNfql1nFQwghhBBCCCGERQJ3IYQQQgghME+ttW+3r3snUu6d8EmsExO/lfB977xYJniKYJOdy0TqzOSpx4ukqhPNfsLab2eTx6x87+uMcJAJwux+JgrMfJoVvTUnLggEYysxdzI5WhV6e3EFEpv79JGovCLozlZnZMIPZCMTtnjBz+zKitl+nG4r3PGiGWYPpTtCWHWvqHuvmAt5En19Dyp1+WVE8B7UN2bCxWpVfV9bzccEldbGrA/ePtj3+voajy+RADTa78evTKzFykXjjC0/Y298wMRRM370dfwWVbM7W+NSJtDZrfJstM1W3LzYWfaPthLAX8Mn392Mtnbcncthz9BXScEXnJ6lXX1FxwSJ+qJQYeB0FTbJKyI+e4CiOMr5/Pp6WptHbYj8N2Vds7D4Ep1cmW3/efb2JzleJVsoJrVU22qVBVxs3uZsmQdAx9jM1wh2T/lJxvN7/ZiJYVmcjmxEL1dW4yW0ijmLXW286/NlL7lGwncmno/SsvqwNMy2vX+plIXupWBZlevhOjaR86P7r4F/PvtquAycsf1dB98Dfzb7Kvf1/j4eBSHs9syPlWxsQ+UF7UO3Vep/RBf1Obq5XxwfhbZWa9jqs4XWWm99jPEtSyuEEEIIIYQQ4vdDAnchhBBCCCE4iWo2IlOd7RM79pYLc8doVPj+S3LcvNh8uRWhHssbpUdipmpe9h2JbFB5fnLa7/d5/N/s3GJzmlHdfbqofbyt4cQFwWR5Jua2+45YcTxagdyniUTuSNSyh6UcJJyx+xCszEhEY/MioQ5f8RKvijlT/yNF7Ki9lj1Hw9rzV6PU/rPixTkH5vF90dFNn4UFiHtOu70C0d7aaYw2vLq5KvJEYmOWxquwmW20jZWDfEVlMCHXaFt7Vb/Yvk3acfVhaebrKuw28mR16qZZx/ofc802mS9nY9/4dB3S2fnkIuWe2bbbZq/TqF17W9usHG9//s1cb0zTiNIjAWAkBiTl9dbby+lET6eNbRTvZT42cAzZdbwXdoKibTOxZ9Uu2w+EoX252B45Xu2wScfYrB+MIG111At698Qz2SrpFY6oB1sdvfICLPMDCbUzQX1kI1pN3QvdmRg9uheoiNtZXpQf3TsxW8e9LNre5XrdHCf244BH3WKwPL5/tGMfG4vt/gY++/Ky5wfeT+QTSo++3xOr/5q3VZ8UdHIs35NAY3+ZTxK4CyGEEEIIIcTXRAJ3IYQQQgghppiZmMnUT4+ZYfutxO2tvb+opDrJnInyGNGkMPo+IyhH+aIJZiYCtPOUaL7SlzMzj1mc0F6JAli9KuLIheSSy1YCvJd7RdlUNDK2ghMmyPYCmGgVR5bfimIqYiUmZEEif7YSJbOT+Zv54stncNvzwqaMfLX57bH6rfDV/ejqVUXMVbFulG6vwOnwsKS3l5fXOK/vTyPf7VjC+mu0PRIrM/vIrt3PRM9I5GzLZj6zOiHfnZ3rEGbyI5OjrT/Y9GP5bkAaNPtljK22bflyLb+vh/aRCXzNvgG2bRz0nyuiPH/tzMQ2rHxUli8jizGoKJhsjM5XVo49b86jvb6et74iG77N/HlJ6jqsnSgeRed/dkyZLUt0vfv81fIqRKLJapxZYSbGv6dee+qwyTLg5+V7NR6M4rRKHHNPXO5jS789exH1aH8W+96vWTG8F6tHvnrhvP3s420k2o/i8yqZv9F9CcrH7gM2eaPrGju6tjP87sHTbky5e51evAgr/YL9Vx0fSTwC7dvPbNyw24b73EBa5osv8/jbcHEX7IBGNwaWKJif4y1G1QkihBBCCCGEEF8RCdyFEEIIIYSY4iPVdsuEc2t+YdXfmkxYtaTZw4zIxKeJJm+9oG9W1Gjz+vlC+x1NBrOJaD/hbCfGKz6xyXO0D4HqwcrrBXGJndyM5ltZfifQ2IgmQNtEom+/vyqYZquTR2KUlVDItBUSfrB6MkFLJixndbF/kUjFrshuCUUpBFZfJrKKBDPL9mgVzozsvJhlxofeell4utr2GbQBFRHjkbY9R7dB1XffL8/mn7HP+tlI6NpGO53OW7tovPQCK+uDz8N8jXyOhFuo36+It9jYx+IBcL30rIzUruljR7uK1Fcmxy1lZ9esaYu+/DO7rmHEWCeHTUyOVV/s+4yV73Y7ij9sXFIV21nHULuw48riJRQnRed0c2lJu21cRucLiufQOd9u28Zo7fV0av2p47S+Xfy1VWlnkmZTVW8P+RyVhWLlmfzMQWNr10tgR/TFUWzPYuFK/ju4N75BYmv7X/QSYSRInI2VZl8qRHGn3c72V8r1ZaDV1iv5kR9LHrQSO8pbiYGjFxaYD3Z7tZ2juP6oONsYbG0Edq+3S0m87NJf2z4S07q0h5KNPyy+r8YlLObydlAMg2JYb9/b9uVmfkV1/Mx8dv8K8FPojsBZCCGEEEIIIYS4EwnchRBCCCGEALyJhKrLbG1yu88HT/AYMRTcfZRI7itQFVgycRCbSLbCLSRgimz6bVWBoC0X7ff2/CSy9cv7hESIbPJ6NFzvq9Ku8csClUsEWWMMLtYyvlkhuC+TCdmRj14YUhVtIKFztAKhz+uF4cgHJNDOBEeoDFR+tKpkJhpiQh8kos+EIf5FAvZigfenKnjyfiPx/GwZRxKWMSsMzUSOEb+TXsH2iZngJtsXaT5QmX4syMRCEazs7v5lQtfeWuu9PT+/3nZWhEhMmIrEWd4HJJbybYrGOJ8GtWEmjELjd3RtDPfRl2n9LYq6rnZcsmU7eo9rtHYVss8sYmnzrJrI12upwtju25SHjgM6biwtw8dAlTho+cfEcf4a8H55srpGedG5wGIzFguRbb23dj6d2vl8uRmw9fbxW/VY+O3o2m3u/gK1r7fljyG7/nysx/zLAO2+Guv3Hvs9adDxnenfjworsn7wQDJx9D1k8XclDkQvO6JY76h6RC98InuVeNLWBcXh7CXVqP28AL4S01bSoPuH6KXW6GXT0C8wRlSP1SrdCI5JFmePFqdjfXGEjyXY/a7vr1n8taRH/X5UFhrfmW3mp9/P+kU/FqAx+x4e1PetePwt4cPo6/+5v9VgZdmenbz76K3rWacQQgghhBBCfFEkcBdCCCGEEALw+nrqp/O5P939E7izSsJIyXOZgN7p0i89GZRNlkZU2ysqA4mm0ESvz7PXF+afF8x4QZP9jCa5W9tOHmciM19eNklfEdN4H6J80YR5QfiGhCSL6OK6Ml8ieopEGpkYZEZg7fNlImsrXMFikNgHtm/PSujZSpC+rbwQH9uqd1pe9B75WrGDfEQvAkT2r+kmXPDiql31eKSA41ceRxjZML1nX1WU4/vrSr9cYYB/rXH7Jt3p7FbbRXVElyhqR9TPz9Zxbx7mRzR+I5GwB41fvswoPgDZRlvHaH0pZyly3NJEEeKqyDHaX399b+cxrjrolT3QptePJn5Y0l2rtDiDKuG3IaLt9lpY/Ijw6VE+f64i3RU6PyKfI/s+fybqQ+e2Pwc3PvX28nJq3Y8xWdzpP7N2q8aH/lihdkH7sjL2xs9ZmmpfVIlvo3OTpavEvQAW+xUzm+L61qekrD1AGzvMZrGoJxOmV1ZTr7w4ycjiwcoLp5UXU73N6EVYb9faZ+2B4vKqP+hzVhbL4/dnoJdUWTy9aqtxSdeDczdyA/Sl0G9mh41NUazCYjA0rrB7eDQmReOXLSfyyX/2/WEWK2Xj/97xIbIpWmtLjLfZ4jdGuQ3ZQdl7ozN2PwsVQgghhBBCCPFrI4G7EEIIIYQQgJfX1z/HOP+xb+7lntmzSFVV0PqMtpn0WQmZviL31p2Jo2btRhOyFUGV3Y4mkb1YZ2ayN5qTzOYr2eR05P/svr76s6Uw/4qEF0z8jv5WKItCrpq0dbmZsCVa3dCnw8WuBTCZcMh/jlaF3COIYSs03ux0uA+J/z1VfzLhGBK0o1UnERUxGc3jvnshU0hVePfefAZBwqwPR6avima3p/8cFfEPEVq9nk7tfD5jcRLahkTJyIeKgDQaW9E4g8ZkLwzeO/5HwjI7TiFhWiZIM8laW8dnmxWy/ecOQhIXD4zW2o+Xl/b/+69/tp8vp9ZG37rTb3nhobFjbgenChunMyGgL4gJ7PznSACYffa2o3jL20+DblLWLFlb+OS9tdfz6eYeOI60HH+N+PM1EiP6/UsaRvW6r8DSZTFlZC8TUlZ9qKababtVtm1ckMUBe168RGXt4Qgbix30AmT1JcuqLzaOZXFW9WVDe2yuL9KCPJEd9HIoSpO1QyR6P+JFhsyfrM2idmbfM3uVbZvtztzGftKP0ONQbWI7dmZjV+QT89P371mM6cfADj5nZdr97DmKL4vZq/Sn98R6ImF2oFw4to+50vf+wqYQQgghhBBCiF8dCdyFEEIIIYQAvK3sjPewHPW0ccnb72ZbMqWDfO799u+34z2nuGZEh8wvO4HNhHw+vc3jJ3P9hLgXaaEy2AR6RRQYCctYWSgv2u/TQVvdfW93C8wyoXckKM4EMF4Qfv3e54QYHiSMR2mqzcJE20isUhJYt7VQCNn0gn4vyolELd43JACqiOCtTVRGZP9eZsVnRwnG3rXPnCz76Dbe40PdTDYYF8pCgtZlu98fiTh9uUjIa8WszW0zeV9Pp1uSSEwcle//VgSy3hcmvmXlMbtWOOZt++9I2OzHNiQUY+O6H49J+11/RMTHaaNtXlDsZntrbfPy4hij/fd//6v99a8f7empt6en3lqgBfIL9bNhetiylkysvVqw3bcPOj7edgPpvLPVcwQJ97LzOopr7Plpj39yzKk9+x3VaZiizud2Op2v6TcvR9jzn8GEjxGzfcK9zJRRPQ+y9O99vzRzf3FNGieuCqgfwrWLqA241dXN7V+2v2KfieSjcipxpt+HPlvbNj+KhaOy7b6ZF18rsTDyl9Uh2h+9uHvPOThWb4XtyA8y7Xlx9LrqO/pVk7cE689Rldk+FK+wPjhLi9JYO2h8jvL4fTN9bGSvmoeNsUeNGV+VjkKH2et1NpiYKqMarQghhBBCCCGE+M2QwF0IIYQQQogp2EzYUTNkyexkv68kzeMV2SE2WeVFgiW2zU8qL2SiPAQTmfn6IAElspH558uIJrf9bGm3H4Fgrm8FEKsV8TIxAfoesQgGCwKRusmtGIbZsis9VoQ6V7HKRejBRC5sRUW/j5VfFR15//zKlUhg5EVG3f3nV8GskolpquJ3my8S6lRWoYz8gfvA7sr58SkpulsRae0u4979m+QkQ9a3RkJeL+D1f1n/vmybFSOt8r9lPp/Ob0n82LMOQ7a2qmVHwt+s/2bHyPvqxzs2nqPvyD/btqhdWF2QUMxk3qyePlZ/uJ9+26W7+P7zZ/vv//lnG2O0J6dct0M5M7lxdRjR9Gg3Mfyy0Y/pM8K0JT1zxh4Lnw79ja4rtq0Sk/mGi2xm1zfDl+NtUvrlhZRVMBX7a9P5MpbDWhVEsn1R3Mquq4oNlrZ63h11bt7D0WLQcrH3GZ4Rql8+tNbIOElim4rtvfXw8dueGArFoWzl7mo8btNEcTfymwnKWTomWmdtEdn3+2dfVN0jet/0c+4zypu9FMGg55mLx67piv3uJn7fczr7sthf30asn/R9ko/lkB0WU2VjbAVwbO+2KeYwp/VtA715ePv/ZhWNBw1mrbU2xtMY48/HFSCEEEIIIYQQ4rMigbsQQgghhBCE7WRNKdfhfqy4CJX8qp3X3WC7XQFU84JF/ESx3xYJc7IJZC/aWmBiFyY0zMSTaKI6EiRWJqzRPutTJnZCeZsTE3Sy3dsD/s6KGO4RPUCRwsA+V0TRi+ADbQ996dgesoXIhN9IgB7Vi9llgh8kdLdkQvRICFQV0TAxENq+Z/VQ5rvfv0oTXQN3MGOPXn+zA0lUZCR2q5Tj+7Hr182GmEjA6uvMhLFsH/uM+rJIPBT5ikROy7+KSGiM9vpyfjvvWf3W2kU8NnX3Hfnh07CxyI8taNyMxi+fd/mcHUuUf9nnx2AmakOxgy/IDiGjtd5v7i3fbTHXoi4fentL8/Ly2v7ff/+r/fz+3K7Lwa/q2DdVuGzergC/7LddkfGN1hHtu1YGpO1uX6WPqFzDVVuRDesf2hfZZOd5VnY1JjQHsPfWTq/ndvbX7Gxf52LF0ghhT8rMPttXOVYz9crKy4STqPxKmXtvrNI+omb7HuE3snUP0UtqVz9JEUws7mM6lKaybbHhxdjILnsBNbPJ9mfC9GW7jZXZvUDWBt4fH8NHtlg9ouOwuRciTbHUjcXSWTsiYLuuwuj1sU5h8cVbYdsYzcc4yMbKnLtWUQzF/GL9hR1vWDyD4kDfv7G6+u/+r68HSr+3j0S2o2OEtmXxdKXMr0ZYf3xABnwweeTN4sps10ESQgghhBBCiK+JBO5CCCGEEEIgenWWxVNRLNzP7LTOLq2+4FQFREyc48VdSEiDRH5+H8LbioSUyGckCqwIJCO/bD3Zfu9fBXe52QlWtprfShBhf1Z+8hqJBBNHiI2qq1l7wYhfcZzZjcTbVmiD9vmykZjGCuwzoTgTvlvYPrsKpRfSR+2A8HW2oLpG4vxspUvEnlVFPUcK4qk/hSJ2C4omy2Fp6Gqf2baoj2JCWyZM8v2eF0H5PtH32zOHsiomYoKn3tvL6bR9sc+LQpGgy+Lr5f3x496Sx5eHxi32melqfH40tjW3z/qIjk0kIsvKD7J14+MwO1cLsbsx+nRu7Z9/fW///Nf31sZo/alv6jXMsbLD3bU66HCTsXpVdTRmR+deZWxHIkF2vjBxnvVj5vrJYjaWjl5PZhuziXxmNn08dj2mo51ez7eE6DzNjom/HvbEXzP5snS+n5mIC/2Lf24n/nxJn74UlcWvUZq9FM7hyouHmSg6e9EwzN/dtqANohiH+T2bx5djRc62juyl0ioon40hUQzNBNfoRVMfz3tfs7iZCcijWB7lZW0J6a31Ds7Hsc0fCd2v24LDQl9KoONtHKdf86LrGfW/y2f0zxP1PaRvh3253+ZjGhYLLWmYLWTHj7NRnObLRt8jonGXxCObfBl74oEvylt/0MhiGp+gccb1f0IIIYQQQgghvhgSuAshhBBCCIEY7WmMPfHy0eqGvAw7AYWE7F9W3M5EZ7N5GNFEsk+DRE5ocpnZY3btdzTJXAGJ9bw4Cti8LqCFJsytX0zkZSfGUf2QLbSPCNOQWAmunpe1bQVQj1mxMhIXsZUXI/F0JkDxAhMktPECGPu9m/+YbWuHrU6J6oJENpnQJoKJ5CMhly8H1SsS51RtLnZn7FTqnInB7hbRF68PKByqZQyKTgqPBIiV8jNRUQWUNssfCZ5mykXiLNR/g3qNcW7jfNraQ/6xvryBz95WBOqLu9uPxFboO7OPxiw0DvhykdDNl+/HtYRowctVVV2s0Htrf/14bv/93//TXl9O7WlZtd374ny3i7ujcAGeKjCOMk5uKgW+o7ZF4zb6zkSFaL+vVHbORSI8/3lPbLg3tojqDGy8nsx1G8WavgwkWFz2sdjTp9nTTlHsjE5CVBbK28y4M5Y/xTFjFMdylmTPWBHZvWOY3jvGz+ajImTSllFclW2feTGQCc9R2mUbe7FxyRuJ05GPmU0kMrf5mA8or/+OXtT09wZeiB+1L2vL6PumLcxAgu4NkL/Xe0xbzrjZ8GXPxsf+5QOzwxY6329Hn619GzP4cpHtaH+WF332YwUbp31sN9q6XWbjW1/GkiaKJ5iNyrHZ2yd/cXon8R9OTbZXDv4cvbdZ54QQQgghhBBC/EZI4C6EEEIIIQRgtPGttf7tcSXsnZgZrfexFnRojgdzhNDwiDKX7bPzfNEEOcuHhIVR/kr5RFS2+TnqaAI+EkExkRQTNCExpfcRCSGRKO5IXN3ZapTRdyZIsd+v25zQo+ZinNYLrpGQZkaQgz5H26J9SGRvv1v/qitasjJ8ed63SORftWu/M3+9IJ35hKicf3uJVu+c2o6NHwsTHgYiy6uQqpKHlen7OCRiikSbPu1MGtTve59c3tPreR1MIHEu6uNZ+dUxp5t/1m9bFhO4ou+VMc/7t3fcZsI1+9mLwWzezZjx9r/VUHVJtwy3zy+n9l//9c/2/Pxzu9o+8KVfjdAkzSa5aocuX8byd7TbCvDDOwnqZ49ra9v2ZuN25KQvk13bzaVjx9ufX7MCQ2sX1cGXHbUH2+bLd9dBf+rtfDrheAy0S7l7rcSc0fnvt2d92ayQsTimpC/FzcTGrA/M7FR89X31TN6VmTGd562YWqYsbrsnHq0IwrPtPj6M8tp9VXG0jze96BzliWLJ5a+168Xn9/od5Wf7svgxi3/9dZedG6u4d4zNNmN4ZZMYW/91fqC0bPtmHHN+rMry44lNi8aOKC708QMrl333vqJ+m/31Pvo0yBarS0YlDhMfwJg8HnsOng64EEIIIYQQQoh5JHAXQgghhBDiUKoTNvsmdhaR0dE8wqZIAGKlqbxePMXEf34CGYkHrT+2DPTZp0XiMSYOYOIgmw9NqDNxmf3LQG0cTcCzcg5gZlXJGZuV1TJ9eZEwh60sjspiAnBrB5WFVp1EYnQkqI+IhPBoxcuK0N4Lmtiql1XhObKL6jdzXsy20z1Q25E48YDrKK0TKmNGeDhMObMiw0jwm/VhjEx4W7EX9f9m3+vpnPepmaAYiZYjf6xPbL+3v5TBRGdeZIXs+3R+PPVjGBrTorGM+bSq29i6ONrmHYPb99H++a/v7V9//audm7sWvI+mrE1zg/Yfl8KvAnazr1sjHVQ5O95LGibw83Vg9qvbUHsz4V3Fd7vfXx9sO8qPzkHky5IenWMkrhqtt9fXM7YFXNlsiISJyBYTezLu6f9ZP1zpM7r/2uk+yp5+G9mYTT/Rv1BxbpqVC8qjPDP7Mvs2/lts7LHDfPAxpS/Pl223RfF5lD96odPGkNavSl7kO8vj7frtLN5G9YlWS2fnQ+RTSZwO/Arx/Wcli39Ra10w3laNBSr1iE5pNHZV62jTsr63asvmj8aCmT5rlsfdyoiAfNiuPEg5/uAt8erumEIIIYQQQgghxC+NBO5CCCGEEEJAbpMzm5URP5LeHrJiu1aB30llfo999wI6hN/OJt3tRHvkz4xAqCr+yiAT6dcJf7Q/u+RYuzBbgfjgKgKZvMyPFBD7Pqay0npW/IxwqVIXJG5Bgne0umVkM1vVsbuDG61wzvyM/NkrpoqEPfesIs9sZmXP2p0V4380Gz+OuPyWvqEi0GSw/EwsWunTvV0kfmW+dfcPpXNjxWitnceZi7VQHb2wCdXNip6QANmnzcZINGb5dkK++PHRi7+q5wHyGY3jkSgsGGuXOGy4Y/Pz+bn9v//+Vzu9ntpTf5qK1669sctzdXuJKXvflN/7thlJAevvvv7ZuJ6J6CKYAJC1c+RXtewsZvPnOyvf7/fnMmo3cI731tppvHJNWSbinBWHsnM6U8Tt6bPd9VUaj6LzLasz6Zt2j4PVOlfHC5DmHkF4BWaLCa4t1RcSmdieCakzn1j5SLSNYsMsXrRCbW9r+Ry9KJr57f1CL1lmvqLjg9o5imWjlyBQfNjNf7N1vBhYXaPM/oZqDHYrHI9VUXrvX5bHpJm+B2Axl/c3i6t87OP37SGKYSt91pEcdxsuHHlIXLlgHsFovT8NPbcUQgghhBBCiK+JBO5CCCGEEEIQ+iecPTnKo8+k2f+07BH6RPkywVWUlwmx7IQ3Ezqy8pmY0E+ao7xeJOYn0Zkwy3y+irrZRL7/5+tZETQMks74cxVpJG0/u3JlVOYm/UZ8mF+gaGX1ih99rF/aQWWxVc/RCphVoTT7jlaSzMROXliE7LJVJ7OV15kvSLTuy8hWYq+sehkdjwpVUXrpXLljxDlaGL85J6Jru2bwZoeJUZlgtLl0oP8tvxgX9WeL3UgkW+nHQ3o7vZ7b+Txy4SoTg9l+OsL7ZMcP9N2W47dHImM7ZtixA41VyDdUn0g068fjCk/9rcjR3kTml8/L99Zae3k9tf/+n7/aX99/rps2OjfRmNnXtm12/6tAvV3SmOO8iODLcaNtO3Z++rZl50EUH1h7lfOqgb/eL/YZnZNZnuVzFnuxGCe6xlz9T68gf9Ru3jcWR+7l6NsnHzv1YIyJ6oCOBTt2q2R5haA/bJwix/FevCAallk3xm0FZbEYJIsJUMzGYjwUl/mYMBMVRwJuH2si/ysibl8n6+Psi4r1l0FxfM5E/EyIj/LT+4xL38FibPQSQOYfLoafQ5UXla9p7PXH4gGbh6VBfTfqd30dKvFSRNZnRbZR7MvSVcbNR48ZR9kX80y1PTqpjz94vfc2xngao3073LgQQgghhBBCiE+PBO5CCCGEEEIALlM0Y/XtUOv7bS6iqFmRukTtk2SipNn81k4mnmMiP5TeT9TbPF7oNNq2LGvTC6rshD0TAKAJ7khklZWHyrBpWNuxMpitSaqi6D22PDNiqijlRhB8ydB73/hvxStInMKE6Gtf1sIVtHJkJvCxadarZbbNNpueHR8vNEdCG1tnL+Bh/jIBfW89fDkqO2/uEZUv+dHxmiUT48/YqKRjaTcCqKOuaZQ36uMQgZBpdQ5c+qxVHTMdiBdPMaJ6FARDvb+t3v4UCV8Zti9mIis0PkUiXp/f++QFZNn4U7E9I9ry9cnEYjT9sB/fsvbleIz2z399b//81/c2xrk9+XNpKa+Bz27buKS3IvXr0D7abWV3O1S48wN9hnX0x3UmhsrO8ah99/YJ9hpDMRKzWe0SK3FedJ0xUeGSz/rexzbG39M/ohjL+4PSe9B1jfqlmduhA+O50E6Pd7O0dKyM+uiD6pGNtaMNeB6Houk9N419HYOsd+GyUKx49Xljvm++Z8Lv7MVBJOq2+1Bcy0TcXgSeied9eTb29eJ6Xy576ZTVsxoTVl5cuO6Lxu+2PZYw5h/E/3FJv9kcxIrOfCTYZ/36Js4kft8G0rbtNwux12pbNfasxEj2s/cP2WTxIosxsjhgL9mpmY0zYoqoe7/uKh/Tew9+nUtv8TTG+OPdChVCCCGEEEII8WmQwF0IIYQQQgjAaOOptc+0OlAHn2L85FVJqCTupyIuzIRIkcDOp/cT4XsngdkEthdYogl3JOLz4sxAULgRD3gBWCSas9v9P0YmlArybgQ1/jqLrtCsLS/568LkbpomEa8kYiZrYysuz/1hK10yITgqy9vzPqH96ypygREU5xA7CCZuh2IuYjISY6E6Mv/2+MzKZN8r7W33MbFX1U+WlvYN3Nj7gvoSdJ2P/HhAKsIiv58JmYCdMUZ7PZ3aVW6diViRoHjcbKV9KxK3graC6ZtLF6XxPqOxwZZfEdpGolQ2viVC1u7K/fHjuf3Xf/1Pe319vW0ejdcR7duUdekDfdrlkPdbTHj9YZXebsL7dtsXiqiNnZV/SGiHxnQ07mexki0LtQM6X71/kV1va8YHdJ6h79VYD+27/Bvn0c6nsX25ipUTnev2WEW++Pgssse+o/zsWpyJtRhBHLo6vkF36H3ajI0fcH+VtQUUOSfHjcV+UdywtAeLZ1g5KG0Uw9n9l2I3NphIndUni6F9bIlsZHbWNmrHDP2NBPSZveUziolZHG+BL+qR+wt/HoyxFej7Puuavl/KyvrdoAlgXO7jArttyePimqsfaNzqYJv3j/WBLH22DfRVq+0VorERlWXTPLqPK/T/ogZbECN6Dri+5Co3HixgO55rL/gB46wQQgghhBBCiI9HAnchhBBCCCEQbz99+623eBJor/H5SaCtMiXzS5M/B5MdslRkVthfPWZeyIjsHnH8WZ2qdfWT717YdP1oRBBRu9kJ+Wo6uw2JEphw0GLFDl680n3StTgCCmuCYxQJt7khTiY6qaywiMpHK0lGZe0RozHREBKbo/SoDkyw5e1E7eHLrqSdqQfKg8qNOCoNSnuPmP3hDP91YqxFfQLrS0BZ0IdIrJld/14QG3Dtdyq4vnd1dDMRq/9s0q2EahWRlu+Ph9vpNTOo3e0x8+NDJiIj4xHFj2XLv97Wx7Nkq9/E5K2119dT+6//9z/t+4+frfendlEM3hJE7YnGk5VA9/bFH+dF/GSF7asqDHcIlqCYHLfh25Sdt+y4rQp36RBV0WNVSGjLRb7NkvkX2fbXHLp1uPrY2+t4nS9/ltnzfG8Zs9cj+s5so89RujAZSDiCfa1tz6l3HDozcXQl1mBCclTGLOxlOfYy4S2Wwv6zbXv8Wpe3jnln4623+ty2sxdAUdnMF1ZmNebNYt0oBozyreLdVYgQv1AAjM1tz8j6/8yXKDbMyvDjX1aO3+b74axfq451KF8Ut1XL8OXZv4h7jo1YYV9g9LBV3G1smh9YtP+xB+npSSeBEEIIIYQQQnxVJHAXQgghhBACM9pljmfXz7SX2SH63OnOQ6vxuzJzePYIcpCNmclfJuJCIqgqVrCGxIX+7wB5quUYG9fVf5H4pyIyq7RbZf/Fn9k8K4H+xV8oLvEizJI7fEXM6irdfsXGzSqNgSgrW9WSledFMeg7s19dcdOntW1VbRvkw2z5rB0y29VVQytCoFkhl/exKkr7NGL2AlO+oj6MCXzQ523hdbHmNUvgb2DHrno6U975GulcDdWEo2gcqIiekOgZVrmvPzJBmC3X+5AJx9D3av+Mxhs2fjOda3/b9a/vP9r//PNfrfXe+pM5johMlIva17m0Fi+Z7OPtH1uFfSOSQtcByrt8ttcDEuX548zsRNejzxfBjrM/p5AP2fFB1wfyz9Z7RsDpztPeL9dyG/u0ZagtmG7tiHuJSkwX5W2BH59keKJ9eUWQuhMfA6D4Aq3avVCNNY5kVmhv/bb+2r8sNvPicQRazdyXU7Hj68KOg61H9NIjejnBx/X34M+DME4FxWXHkfno7T7s/EN9caWviMYUO07s6XfYWBbFD9G9dtZ0KHaajFHvJvJ/Jr+gVJ/3MeH72/Z7BlIdJCGEEEIIIYQQj0ECdyGEEEIIIQjvo5GYnQTq4WpMrIiNaOlB/HYi+qPrwwRDPs0RIiImoMkEgKxcLyKMJtcj8Q5Kw4QGmdCUpWX7IoHeHnurTWMjcvDi8UcxK+YmRmBali8SdLMVKZFPXmzFVgetCL3RCpPVlTU3K002XHdfT7Q98it7SeEecU9VzD3amwgS1Rn5cI9PR4mvVhw9lt0jtGSC3Aq+WSLRbNSESAxV0cn31s6vJ5yACd2tUDnqs5kIfUZ07vOjdrD+sG2+LvaYZe3KxmM/HkZjS3dpL/teXk7t//3XP9vzz9f21J+2+VC7zYigr3ZsX3xLa1dt705k3U0GGHOyc58dH+YnO6a2TVE84dulIuxDx72D/ciXil3ksz0/kLjd+478YeeS2zfOo53O2zgkPD5+PwNdZ8wGOlf8d3bdVKjEqHuoxKSO6dXK2TkW7a/YMP7470iw7dOguGZm7J6NGaxAPHoJMrKFYkZ2LJB4G8WeXjwftaevCyoH+YvE+yg/s2X9rbQz+rx8j9prY/tyzfqV2Ff7AdUY/PJhtW36BUXjQykv6zPYuO9Bfasf0/z4wPp7ZNP7FMVR1W1sP7J9dKz9WXjHen3Ec7FDnvf1hz+6mObWlr/riSmEEEIIIYQQIkMCdyGEEEIIIQLuX8XoaN6mnKcmzCKhW9HOvatBCQISWrV23KwiE8VFojAvYMyEPkxIOMj+ZV8mTENpmDDK++nFkN19z8SWVRESEN5BUcWkKHEj7BjLH9xYSAiD8ldgIpxI2G2FMpHInK0QiVavtDbsKpWRuAjZZvVDK1Rae7PCrkxsxFb9ZHXOPs+yKTM4X/eu0M7Ec7tXhY2EPtF+4gvMUxExVXyJRLhVjhR8BkLWbtKclw2on/f9KBIjs3KQqNfaqI53TEhnxylWFhOTMX+Z4DgaN7JxDOzrT719//6z/fNff7XWxlpcjsY17wvbjsocbwmG346Gh0sbjHEppr/9g/Ffts23aXP7EPZ8y9o1sp+BzufMFotHvI/eRvU8Z4JIbwuVdUk/zufLKu5xujL2nGT1Qvt9PBj1GTPnxyrbA16cWhdAj9fhZWftQdKzmILRzX9rc+u4ysY0NvaqvMSH4sYoLmBidhYzPOK4R8JvL8RnMay3E700kJVf9TWLIytx3FRbXq7namwVvhzg4k8kpq8c600dV+PayPuXKL6w36PPzMVsLJiIGaANFFtF26rx22x/VGHfLcXxNhYeOHR43vu5mI/X7hHYH+v6/dZubfmOB1AIIYQQQgghxKdCAnchhBBCCCEYn3YiBU8SRZNa906wSbj+DlQmtBkz4svle5Zn+ewnxZGQ0KdHfiEfFj9Gw2XZ715Q5feztN4XJgKwNqL2sSb9hbGIPyoiAmbTCIqsXUZF9N56XbSciWaWNJEAnomUkDDepo+E3WiVz2ilz2zlSv+3ulokW/0z+my/e9EYs8/y7SFbqTMDidzQMdtzjiUJd+/3597188y1mYlTi/1EBBJ2UR+isir7nPB0tNFOp/O2/+0u7dbpWz8XCcSQoIqJd6siscUGGmeQP94PJLj1dnzZ2XmAyrSf7ZhlfO1P/W0MYeOZ9wUJz/yxcuUMN14vQ1Z2WrHDOtgGX89Ke2eOLMczal9btj8nWCzh7VTiGe+nv16Yn/Z4svPI+l+Judh113s7n048YI+uMda/oT7B2hp2E+jL9vSRUR943bSj4733PuZ67cy9tDXWjRTvn3JnHQetDw+Pz5CdJY1/0Q/56sdVFAP4GCYTvqOYMWpjJO63L0r6OvmXKVlM5MXtvl4+zbIve6ES5fP7qy+lVoTzqO2Qn9XraDbfqt7LG1OA6rlvX8q8ZNzWEfWvaEzxfZf/m43nW+fwX7aN2Vm2W3/QGIhimmbyeKJYroqtx739qHgI9hd59uY/UhwPSjjUWO/9UINCCCGEEEIIIX4NJHAXQgghhBAC89Q/Xbzczf/fuHfyaZkI+4ifUBatNt9nBUKREKsV0tl9UdlIPGj3eaETEnixCX0g9JvyDfmI8lYneVH5xbxQXDHatC8zYpFMqMxE05kge/nOVqSs+D0jqkL5szxslUq23dc5EjYxm0jQjURQkaA+q9ejiYRi7KUDlM62CxKyWTbiqp6fw0djj9GuMgtCy3sPa+pXVSjMxMDWhrWziFnQ4I/6MEulKaMxpCIA8/uQwBcJwex3ZAuNXV6E20n6BrYhoVkknEO+MbEaKi/DiZK78eEqgGqXz30bA9pV25fTwwqmVu759q7EFFldfXpblj8ukUjQ2vHnIjtOfr/9juw0s8/a8T6iGAr5El0DBXu9tXY+ZwciIYsxg33Xvsz6ONvtor7BlL3nhao9wHHQbTqq/D12sHh5/d23lReEe1sd/OcF4+gFvCiGYHECirGQ71l5kZ2onr489LniD7MTidmj4726hsz36IUD5q+P2Vj8u0f0TmOqsfbZ1mWzDfS/vv6rfK5voC/UsO+LXdR3+74Yjdmsnwf+rnzwn1HMYcv1fSfr0tE45WOmaIzcs8/76P1gPkbxYJXKsPa4IeHTw4TtVcH7Evv9GvSnMcYfH+2FEEIIIYQQQoj355MJdoQQQgghhPgcjNa+jdG+fS7h99t0rp2EWgmP3MTUzETVrzOp9UWJhJZeAOXT+7RVwSKbmK6K0pAPbL/3oYN/S54oH/MlSuu3sfas9gXRxD+xMUxHk4lYslW/M9F4tEKlXw0zoypgX8pEIh0kWPL7fF4k1ELCfFQmE1pFdWEvD/iVQVEeBip3Vhi/d989aXez0SJ93OAaCfmTjB9HpWwkPmq8rU+v5+0e1FcDri8sZMIlNuYsxYyR9+FsLImEwz4fEx9XYILsbDwkIr60rMWuD0B9vbxQLijDxo2LaP2abdzSoHyb6kfH3J+DrO3YvsqYb/NkYyyKf9ixt/sjm8jvqJ4RWTxjxZW+TXz5vbXzsgxrxQ90/lZFhFkcWDwvYd7Al7tE5Ykfs/GPzRdtv1cIz2I+uz+KTXyeGUFzJv5meVgsE9Vl5uUFJKxn+Sov4UVxtU/n/0N5onzeBxTjWr9nzx8fr2ZxYvZiQLSN3W9s0nfih+vHVmn2XP9M4J314aiftTYjO9kYFd23zsaUbOzxcUY2jlXG5Whb0k/DfXvrPMNHxui/EWP53+d9NtjHGN8+2gkhhBBCCCGEEO+PBO5CCCGEEEIQPuM8Wb/MtK7mFt/R0c8l+P8FeOTkYHWyOJuIzgR6kT3kBxOe2fxIBO5FexFVwaGv++yErRdL7IGJARdR4bJxx7XFVq5EaaL0SJBUFQAzoZHHrwS6bJsV3yxlorQzeHGOXfXSbotWHo3a0+9jQvrK6qHId7YvyldJW813r6jvHtHf7LGOjuFdtqsi0vfG9Y+rul72PfXezv0MBa6rNmBjABMuMcEsGq/6xbdIJIZAgmjvGxpjfPnITyZGs+MSqUvqLyubtlly8th6ekGfNTXG7bM3MdafV2L36xgF/I2OgR/Do/pHx90LC33a6LyptnV2blSPsffJf0dtEMUjUfzEfLuo0s7n1tooOGt9jdol84nty67nSplFcL89P05sxoWCT48ay+4ZS9kLd5ktJniuvIhXfeER2ZmJO5iw3Nv1cRj7nNU3q08k/q4Kw1lMHsWW3o9qHLf75T6QDQnZS7aWtEmfksXapf4Z9bNLf7ns8/etaExm+7I6V+IPmw7VCcU4kU8s70fCxppfhK/0/Ksv//ukdX57YfMXPZGEEEIIIYQQQtyFBO5CCCGEEEL8anQ34b3oY99hIuq955N++QnFiv8zbYpEeEzINwua0GeCPibIWz5b8QCzZT8z8RfKi4R8KB8SIWTtw8Rjs0DhGUs6uABwox3hohi2WmMkBEJpIvEvsrMS4YztflZWdSV1K3Bhoh/vN7JdFRAxMhE/a/eoHXYJjQq+ZHmOsMvs7Xn5oFqHqkivyj3H4KOA/lbEsF74PFo7nzfhxDZttp+lQfh+rip4cv5sVn23IjU0NvjyvC9LHutPpd4Wnz5qw4rgbUavi+p3+d6vSqV2abuG69HbepX39vbZit4pfnxm6dHxsft8XYiocpUO2UHxiPezBddSdj3Z+KZ6nkTngLfJ/CmKOc/n0Tq8sAMf2HnhbF//JrFKuh3tq/hAwGNCICJm58Devi3xKXtZr/oi32UHzYOIYkIWb9l4EsWE13z9ls/HYKxO1RcXkZ++HJQ2E48j2HFAYnQWqy7pI1E6850Juf3LaUyQz+q52ga7O37BrfaZfqgcf830j62H/f14q3x+rznji+/r2X3rbB9g8/u4go0NKBZatkf3+FkbZGMo63PvDYtnYqUs/SfhV9FT//LPzcr8IgdECCGEEEIIIcShSOAuhBBCCCFEwmdaJWiZ5IVSDjsPXpjg+hUmwT5R0x8PEzXb/ZX6+wl/Vk6WH4mnkA9IEMBs+rRIROgn2TMRwkwdrc2VtmktGlnVF7Un+9tAWl8u8w+1a9TWzYhV4DkTC46rgu6q6BcJf6i/rW3TgjLZypver6hOSKgUrZgZCZuW/5Zy/F8muK7a8vVC7RKlYfXKXnKoHOMjROS2fSKfspVQV+mIW3uE6kioNlVvWKTz5GChEPQvK8P3u621Mc5tvJ5u21ZaNtfOM6JP3+eRPjjMw9J4gR0SvLHxwdbR+sSExsi/xK9r+dnYjuyj/j8TCCKBMvR9tDHaVcBuh95ufF3E7MP4CF+g9CLAZNxa+0LqhPZ38g/tq4zNrr2uvx6A0i5k8Q/a52MKBjp+lfqg7df0o53Pp6DQtm1HZBPFMxV7WTpmM7tmqr5UuZ7fm6AlyLK/M6++OFhi8d3YQ2J6FE9F+ZCvqc+Dxyk2TvI+ZbazmMh/Z8JxFoMwP5FfLFapxKEWFoNHbW3jRtRcqN5MfL8ZP0nd0L71R9xOsDwQv1z7XR8ogXu9lQ9sjGxgO/D7+n2mj/HjDrIdjYGzsUQUP9myOtjH/PNU+uvK+BUx21W+V7//yTj6OdwS51XL8duX7zYGzPmog3Nw4wkhhBBCCCGE+CWQwF0IIYQQQgjAau7wEynB+/V/b1jXPpGbX5eZeb7seFUm4veUEwmbokl5NKGeidu84K/iE5u4nxEzojJWWc0sLjtmSIxF2u4qPsnEC0fi7L01GxZRUcGLtXX5N3cKr8Ux0QrgkaCcCXuilTJRei8k9/aRmBkJm5DvyA9UBhL/2FVHkcid1cfn9/XMxGnIT/Q9Knt2Xyauj2D1cQbLeRlVnzbpSiLO3BMmtCOJd5HZPZ9GG09YNJf5MCX09GJl/7lqgwmuqmMFStNNWl+G/2xtZuJfXz4TzPlx1ZeNiMZSVOblEG9egET6R1N2XzSIUDDlxs8B/vnkSKAXEdlln31+5HZ06lb8QueK3Wc/25iAfWbHz5dpfIz6pdF7e23jdj+A4hh2nHz6aDuK87K0qH2yeC0TtBb6kVsWpPzL878l4y/J+W17X7Y6Ahs3sZf9/LaqXSYCt/FMNIZ395+1632LYpZMRI/K97ajFw4icb2PvaxtH+cx4b8vA/lfOdeAg6u0h5xTqB/Zk//69VJHNK4G+SCVPqC7f1kZvp/2adn+yC9b16hc71vUN1b77so4GLX1zvhT1Dh6EQdmb/Me12jwmWFfnXNV597vJLHPYw97YUwIIYQQQgghxC+FBO5CCCGEEEIAxlus/PTZVhD300jWP/Q5WrXpiLr9LivFl6mInx5hNxJeIQFThBciMYHW8j0SDto8aDI+EjBZgRMTXPm8XhiImDkGzOdMCOdsUPHJ7LFxvtAJ3Es7INFPJKShwp6VACR2NFr9syLajoRQyOfKapdoxVHUDkxU78VWzDbzyduPhGXeT/ZiQCQWmxVnITFVlB+Jz2z5UblZ22V23oOq4L8qrn/bVe94omvoKK52rbCq3TadxmgdiIfH7cOVVd160Wfbv/t+lvX1kcjVjxEovy2rMl4in7OxCAnRMsHbZrwa6/SJ4HiPYHZ1/C7B3iJq6ubUaK1dV3ZftvWVjbWvK+F0dMwQvr7eThQvoFjAj9ssnbdTEfRV/IjO1yXNbDsF58H1kl6W4WdFny4Cd1/uzDWHfNqjd7NlMLFlRnbN7sjux7Zs3Lw1vt3Cx2dkg8VmlRfDqr5mfTOKn5AtXx4Sp2f+eCE4SmNjDSsW93my48XE5UiAPsNsO7HjYF8C8P6iMqt9/sqHTbiCY7eN7cv1ffWPjbFtvZ36iPrlLB0bz7NmqPTHe+xmfWU27lfGhqy8CDb++c87Qoe78j2Kz+bPB3PEczUb9+3Z/9HolBBCCCGEEEKIr4kE7kIIIYQQQiDG+NZ6//YZxdnX+dHRNqsw+c+bVTsXG0asdE8dK5NfR02QsZ9SflceVWZVZLQXNgFftYnyI6EfKiPzwe9D23qLfaiIDLPz0PsaCSciEdq97BGBLYKTVQdgP66FVKVfpaDalVg0w0Qv0cqebNXN5S8TjC37kXgcrdqJ6pKJjb1oiYm70D6WFq3Y6fcjH1Aev5+9dOD3V45T1vY+nxeXMbsRSPTH6jtjj32v5KlwFZ1+tpgB9F2jtXZu53Ke3vq6P6yMB95WJuBCdjMxGhI12/K6+Yd8Qn6gtMx3Zjcda3ps1wnper/0ZRXBsvs8WrsGSzbu6z2OoW77+vVzOGwwgZ39nsUIaBz3xw+dE/b7cHn8ecWElHZfFE/Y7ZVzE1ERJnr/BvhH7J1HsX/Mjof3a7T4WGZlZKJOlr/oJ6wzOQ5+bIvik5WZ4jXAXvhC9qsvrDHxdCbOzwT3fsxlbYPE3EhI7vOgcRz7HMccqN4+pkExUKVtbbms/tmLcMiPKB4DDq3SoHK8n6yOLJZF5V0y3NKQPqnarun4Z9P5MRr1z5V+IuqP2VjL+n10/5f18z7d4ksUe7CYB6WfuX+diUHR+FrJ8xF8VLmfkNnnav55IctvX2Ac9vtno/dPLb4XQgghhBBCCPE4JHAXQgghhBCCMaJZzY+ht9vElP+78C4TUn6e/B3K1GRWABIHRKKuFuxD7bznUmB2MsHhjG0mSCC2N4IML1aLfIpEkXcSCnCW+lUEXVWhQiAaqYp7kZg5EtxUV7pcp8fCbST2RsLoGVF9JnCLRNXIF5SeCYS8IKoihKvY9/syQd2McLxSThV0DmVCt+oqpxWhlz83q8fdGQn7sb2C/FnS/IuQbaN1i6/HQsEr+8u2VR82a7rS51pxmi8jE8ZWhGuZf0ggFon0NrGT2eAFcmb76rggYRyw3boZFi/ipm78RTGVf+lxWcVzkxSJ+azfmXCPkbWlTxulqR7Dmfgoy9fdvii+ysSTNk10/aDt54l+ZMbunjT3pA8ojX9VgejBlPtRqhHexgCZzUgMnm3Pxg0/LqJx2o7JFV+25eKxlgnR2X5E9mIfGudZWh97WNG6jeEq4v5Vu/atfRTzVV4YKMURrK9+M7DZfrXZXRtsbkPAfQDr5/x4DOxNXbvReBD1tWhM9f0u+zvcNt//s/rYv96W7fd93qgt98RYaBzP8jyCzPdHlfsbgBar8N9/n2dovfXR2hjjz4/2RAghhBBCCCHE+yOBuxBCCCGEEIxPOxvkJvedGGnZZj+jtEv6dCUnsP0zzDNmh+fTrjy1FyZGYBPhVXvZNrYfCYf8RL396/NFdlBaLwbzk/I+LWivq9gy8scTib92igEqK3Bu8kbCzT1d1cyxBmSiIivcuYp0/AR824rX1+LiyL1cuGzT+pU+KwIwVEe2MueSJhKpZ/W15TLBFRPCI7/ZaqFMJOXFVKgdKjCx1YyIzMKulz1i7OgFAmRzj2D/khGWkbXrXoH5zVZ64b79cQLYVPiIhGiB/cXcRuDmhVxozKjCxhifho1VHtanR03K7Nvvvh/v9uvmRKmPLR4gvKv+8s1w+7rzc9n2tt0IMn2bRgJCmw7Yv6bzAj801vtxn8VFs0TjfQU0ZqNrB9R/9bKD389iAd/m4+2cOo1Rv4XJRJ/Rtb/3mj2A6CWnzfYd5WYvQh1RRhvE1gUmzB5uW/RCGPpubdv8SEztYydkN3sRrPIyQjY2V+wjYTizF43tFRE5i7l8mkqcFpHGCSOPG8KXP9D2ifg/2nft06K+/uZkfJ/TLvVA94HrRHX8+OHjE+Qnah9Ul0rZ9p+3Re75O+vY99zTe38+ktny94XKn5I9z6vQi4gW+50tiPGrYc/9MYY0DUIIIYQQQgjxBdHNoBBCCCGEEIhPOgv0tkrTuH5uLXfVTmzNVIvOoSYTaRV+9xXfD69fNqGPtmc+oP2ZKCzSUHrB2YxdL2Jj/rG0gRhgYzMTVERCMuYLEyqQfFBojyiI7VKhNvBrjxgmE2WjtDMCHrvqpbXk0yBfIhGRFxR5n9DfbBVRvw37fhPgZTbRip8ojd8W2cxE7iw/ArW7tZHZsS8Y+HMjqjvyoXpOTdEL9q6XExe8rSD9iD83o3pX2nZrN09/Hm9WR8/Thtf67BiLRGTR2JCI3WD/bMcGVJ61tzdGiMZgXwZL58ce+9365rZvXjjo5t8wf1fip74WrLMxGm0e23/XtFFMggSC/rgHZVPxMBtPG98fXhIrnSgYl1GbsVgDiR4ZINbo3a2KzGI6256gjN5bO49TG2efHSUOfLRlonxZ/d+B2RfVLjvj78ZGJDxHL14N9536AGxFccJW+J3HYT6WYgJ9X7Yfq9nLeagONg/67sutvECGhPc+JmHxURZ/sXqxWMXbR6Dy0AsCTHReOW9WPoP4pdKudHePz63NvsWNYcpE/bUfzwv3N54xBu/7/GU+bu0z1TehsSmLVVYFtzy+qOwjY20p7qze80a8R39+TxkH3gJ8NHueV7Ff4PGf9zyP+oChvMQYw1z6n9VLIYQQQgghhBCPRAJ3IYQQQgghCJ996iSa3Oo9ntSKVnWP9kXMpP2k7w8cxu76vVe7zJRTFXF5EVskgMrOFSQwYBP23ge/vypKsGWg7ZmIb0lXrWMm3kT2YRIugFn55IV8GRt94VZ0Y0VLVgyGRDyjDb7yIMDKc5CwqCoeY+ImL95iK4ciwVZUvhdUIbtWQMZ8Y2J+Ww57EQHl6SDNrV1vIMFXJBRjwjXk18x3xtZ3LFxjwH2jUP7gbZ4SXm5bkeRtDz5GsTXg31VzZsSzfWddLMipQHi7EYlVis9EwpW0dlxg/W4kSkNCMybca3j7Rpje3D4/jlqfzLbee9xusN3Hrfr9uulWJKjTVUfYG3ip0YwtNq+vA2rPaNwz585GKPn/Z+9vtyPXkaZtDChJ3XvP7fM/TXvZ77K9/NzT8I8qkIlAZCLJqpJKrbj29IgEgUTigyBYDIJs29aJF4+1E/OpkrrFfsyu7dhWUb4sb+tz268PIZk5Rit0Ff6ULxnYvOrIeR2ajgXJLNy3lahTe89TxjmGd/318q8m7Oj46omSWVgjx9n8q9dYJfFQuD7POWwZRt/YtR5F8hi+mifhPGM1n7Rh2L5e/Vubnoh9OacmrPpJut969zZz4kW/z8+RvfSeHylhv3cdZfs4duM4gmHe9RxtOeM8DfPmKwxv/I322bb1J7p3ZPXBYNdilvexrvBcXsmXBPcsXvBVXxU8u7BFfOdx50X+DhrZEkIIIYQQQgjxc5DAXQghhBBCCM5bqfX15ssnHlR5D9XYCvBZUXyU39F0wvBZdXVvPlkhID7Ixwf17IG9J5KKxFOeaMvLD48zUQX6hfGifL28MD2IF6djkS+OX3eJVlv/k+8gKEKqpQ7+HBWieyLybnsl+M6IrZFItJ4RNXmiNOvDIPSHY146C/rn2cA893R1srenHe1aX5ng+qhYisFsrNoqm+/pc2CRrJa6jWWna6DOu+jvI+p3sNdsW9fr6fmnxNqV1Xi2YhUfjtNx4kg1EBFYm97eIz7gtYmJ7oi/rpjMiWP7DtqdhNVMhBblweJv4u/ZfRvWWtkF7I3P4+a54qSCikV4rH69spAyTBwRJXrthOJJ+4/ZN/tD/8RyrYSdiT69eqErw39bGVfb73az/Wp2Ks+J4atBZeM1KLqee3Gvx8qcLpjn4AtoLuQQm5t4wumUSNjh6t8eG+2hWJ1PmUdfufjcxs/6vOfL46NvfB7DX9Kb51vRPCIrSGdp7Hw0SsvywvKs2jOaR27XDhJ+FwfGIZofb9o4H7xf8u7LuDP+PZoNZ9f/6D6O2WRzH/vPpmskvJH4rCw2LoJ2mY3o+CN47DT0r+CexRnuSZv9HW0QqDv5rX4TvG6vnP2azlFvE9XqnjhCCCGEEEIIIf52Xk+wI4QQQgghxCvQ2qW09vbVbky0Eq6CPK+0yR9y9Xj4oAvTZx6WrTiT7keK4g8KAp+Wz4pV27CH7oEAzxU5rERhnnDAi4/2+vPRKK4nyMj4wuIwgYTdj/xBUQezXRZimpW4Dcp7RnDcShsFgm0UXK1gYraV0N3zCUXzaDMSV2Xs97how4rk2Oqjnq9ocyWQ8oRentgNJYSsDD098zsSuGVXLfXIiP9Y/UW+HRbRZwS2W59eC8+G/L3zHq/Xjn/R2TO4TfKf6q1NqWaDwVixHGNYei/ujdUKuCF27DPiVSrQY9eBjFbGE+qxtJ5YDoV1WFeszvG6g35krp+1Xlds73XT5nlZKyQM0kxkwqLyrfz2yo/962BfO3x9h/Rbv2LX3LO6K9KH+lx/uh6tzi9vHoEcmWd7cb3+d8g0rJROxkSsA29sPzLXGNqx2m4xti/6etvg4bCdfXlpJR7n1zc/fs87Tt+2v+PLcN3v3DV9nF/NjHOvMb0n0Gc+efl7LyR4YZ6do6xe9vPmUbjN9gc7j7ohbtH8YtHW97hwZD7ArtPR6YzxV/mw68tRvHTsOp29Rtq/tkzRdc6r10d0l9X1ULwcRxaoYHHtb4L06y8vQDMO/u1fghRCCCGEEEIIwZHAXQghhBBCCI9XfcLjwB5g2X8sjpc2m8ezWD24yvjRkvFehiMP5u/plkfrJBIBsFOEicc8uysxm5duFc4EXkZwTfNBobm1yeo+40cUL6pTFEEGadNiUE+IyR50nxABUfGOqees2NgTsTGhGArYj4qWPOGUJ+62ea2Ea9afaFVWKyjLiI+yeXP8+mFissiPVbfLrlqK+2f7nHc8Y8+N05L+OALkYWXulahpMHe0LkzfbWPfnfpGLeXPn//yuvOE2SU+F0/xqGuzGcOil//C/Ow4mCkajqVO226C+8w1NLqeRH0nEtJN4uM2iNtxXmjFTfZlx/2FyHYLa2DXgfUnNl+I6sZk9yjRnSdSDuuSG7q6NbwJWtZtHtiabAxR+DVqSzPYauW/0ZzxbD0+Qrw/HZ4GG3rMG4OyLzetmNwk3SR66S6Tb3SNR6H2ar5h5z0V/ptf7httZq7zY5dq1C/EE9SPInd+bWJid883li/aZWJ/ls6bh9o0WF60l5mLRP7a9iKJH0M1dUuuOWEZnPEjEu1vY+DqngmPefGjsZXte9cadi1q5l90LFsGu58Ze9l9pxc/mi88qq+syio+ldUXGW2cjo2bXaxiPPaozvRotmuaeqgQQgghhBBC/EAkcBdCCCGEEMLjFdXR8Lxp9dDKipTYqp338IjqOWsjVY4Hl/epHPXzs7smyy96CO8Jq9gDfBQBeEI9T9yWESZ6/jBBAhM/eEIJJoiLxAcIE1biPpYbhBaHBclY96Te7ErIQ9yASCB+VuyM9ql4qu3HIvFTLxOLd0YYvxJwjSuhzumZGA39YflgPNyPyrasn1IGv0LB06LKUKjH/GH7y3yJ7z0ds5mxtYqz7B/e4YRI6IwQ84gAEM+/YfV2Nq5Fdj2R8opM/Kx4mcWhmkCcLF3/0LqzYy67Vky6PTI+9njDnIz7QPP2WNX5lmdQrj/Wp8KF7GS+hHNGFHK35tRD5LcnIMR0Xvwj11YnrJa6tnPktGTixCPnyOo8vLUxCm7DNCjWxKZaiSg9SD7bkOLZePJ8db7m5cb9IYHj4/Wa6ucZzTsiP/HFOTy+srMS1M/zkNHXUJh8g11HvXyZyL6Y/tpfvMI5CxOOr3zBcrK6xDjWTnZ+iqJ+158Wz/cwzerljCNzINaeYVxnrG2tnVopfktj6oCOgfbayO6biglrJn6D8DOsxiWbn+dXgThH8vHyZeFenWXtP3msFZ9HtMr66lRlLzKiHYw/fdHR/P9rsY3hr+icEEIIIYQQQognI4G7EEIIIYQQjFd9bAIPoXCF9h6Gxz2hd61z3NTq6Cceoq5WkX8030bcXkr8UPrR5XjEA/qOFR1EwkBPOMCE2yufMI0n3O5xvbytqAGFjV7eVnzRj0cCjLbHcQUoTFR5h9hs2O0CRE9AGAlOPLHntus4CWWNxLi4YucmJoJVqD0G0W1bx++HjgisJt9MWm91UEzjieGY0ApXR2UCJk+MzsRakbiL1cFKML8f43HwJYSVAJAJ/GNmgRoejV6QCCFuxoK1++l9OHpp4mHUUkpp5Y8Rpbmwcz8SpkUMWsAgcRTPGxe9a5CDHTO2PFbVPLkyC2qHDbymeNcXx77JKByDt7QJrc91PlSn+eBV2FgG4fumWzdhk2ONiEO962Xfjq7l2Mew7EcFjhmRYkbUaH2j2ewvT9H87z2Fb2MDXt8yY1n789/Bl+r50+u6kmqwfcXJs+4RXF8eQfZFpPz0ad2hVoJrPAey4uSMsJ1dz+11NyOqjq+ve1+y8w68fjObNl1PO1+/9vxrHV/OWAnRednn62PmZa9IwO7NU1j5vbiZ+S6z46VfvbTA7C77cjNxvK7gdaPM3BriLsPxelDhn73XwuuqPV6MHTYPWI3r3tyBpWNzDesLK5OXbxQW3Rffc78ovhXR73ar37eyv3/Zlx3tfu7q+NW096/2QAghhBBCCCHE5yOBuxBCCCGEEISrCOpFnxreREdWqLT65PAsapq3sw/N8IEY2mN4IvuUjZNP2V5xAf5T+LqUmEgQGOUV2c4+TLcP/FfxrO2MTZsuEsjZNCshmydWwDhMwMd8J4LGabVbJtBg/rEym/IMgiq0kx3CEkIMT/jN0qzESzmXcoJtzPfoY3kmFGOiNeZbxhaK0dE+isMwnfsSQCCCQpE5K0emrq62eB10C5E4z8aMwrN9o906dVQHK3+yAuuVTXt63S0FaXlhJPMnEtgNbdT48cNEQuVEugb7Y2A/BEaz1xQPMtZWdMgTzLHrzDAGk7yi64VHVI9e2kXd23mQFTHtLzNWPg9r0DxDGpu9GSvx+hZdL1eCQtzPCAdXx7rdbB9K9mt63qJIswTn2qptyfHwhblbGmp2NWexfQGMuHOAIQ3P895rsx/HFumx92zRyxvsms3SrwXYflpmp5pj7JqB19p432e3vX4Bjb2Eh357aRBvPoTi++iat6qXjB/eMToXqHdc/8k1+Rqc/zKAZ5fCupwXF+9h+EA0/2Vu2zH/aLG6TbxnYvMHO2Y2SGePoT/MP68cFu8+MbLhXRuxjCwdC7tz+inyfNbvStl8WLzsQhWljHPC+TfAF+1cL+iSEEIIIYQQQojPQwJ3IYQQQgghOCjFeinYp4eZ8BwF8N6K7iyNtWsfmNmHYCzPyN9M3DlxPioTc/2VZLrl2WeTUZrIpidAy/qxeqiPYi/7F4UPnh9eWA/HfWs/Eiz0cE/4mRFK9LzQ/4UNKiKyYomVoKVBGodw9ccEGXHbVpagXEz4hHirazJQdM7yZQLtjOALyxXZZwIumxfLl9n1xG9evWHZmJAd8yvgG0ufFeTbtFkB5Epwd6RtzjP3CdeHB1+LPEEc84Xttz9lGxcm3x3h65DnHdOirYcwu4WUDccvb4xdhe0ZDF+ISKWB9MNfHJ9xbD3iHxPLEdtD/0+1xTV2NEdkL0zaFd1n4dPuFz3H8XrK3RqJ2pldszI2GaY+aV/AuKwdTdnpuU78PTX2NEi3MmH7TEtOvky0aspa6Vupe5LpBZHAPe+FNWYb01yzYNchpnPNy+gjkfW03fh1B9t+dT2c8+Zzgl5X3vzmrhe5FrZGG/t1hc0vvGvfXE+jXRSy9/DoHPGucei7N8+KbOL2Kr7XnqfnFyRrvOYux6rRodF25BaO1d61jWHGtqHskT2SnoZ1v7z7MsT668Vj91gZn7z7O8wT7xujITi6xllfvXvWjE1xGjpNfLH6Zb8FrlgJ4O3Lj6/WoWqtt/sWZ34ihBBCCCGEEOKvRwJ3IYQQQgghOJdaWn3JVcBR/2WfKTcejmHeqk/RPhM9ebbO8IhnVXre9YV4wgFf8cS3PdtMDHdEzMZsWRsZEQKKFpjwwBM09GfFTKzh5ZVhJfRgHBWFHon3hDFzE8+QvF2xb+vVjQMbT39EXG39Qh9RxHWUSAhYyX8sb1YeT+yOwjWW5xw2itFYXkyc3/dR4OYJ17BtrvF938Z4vP5CFoex7b06m4R60Tlfgj68iGPJCOuGoS6pfX2ooCoh+u0CFjd/FH15AjlPkEbyxOOTIM8ZM4Y6NHlOLwNYe0O3YAoq4hfOxeBcH9Ky9Jd6HQ+3OdztPKllEr1780a+wueYH/Z5OrZ6120bnr22MxsR5FofisexfZkttIHn+j1z0kD86Y4Hps9eYzg/+0f1a+b2Wz51OYylCMepwCc73q4E3vdV+X5dwnwqNOgkYG9x+VZjeCSgj4TkTKRNX2xyrsUY/6gwHO3xOuDzEfyL/lh7+3xlPb/yBOdR32HlmeI6WTLBfoZNpBmMo+bAfNyzG41rFrzWefGDsei6Gbx0FeXv3Yuwsdi75nv3XvY+yG6zMrP82VzDm4/Y49G9pGfL82U1T2P1FHHP4PjDuPf3pHt+GzuaN87lvJcY2XHM73o8mmC/AJlPTgohhBBCCCGE+CuRwF0IIYQQQgjGCz84qZfxQRVbld1bocnGy6y+7oqaui+LZ0yv+ILAK/q08Srd7qwf0YP9TDpP7LBiJSTLiDg8G6syRSIJZmslzMR4K7x8Vv28x1mJCY+eL1lx4iIOE2JFK6JiGhTk3QOK69AvT2CGwizPNqZlYB4o5vYEX9kVSiM/mCDeqxNMb+tgJVD0fB3b3Bf8RcRd3BFmOX708Eybuo54gjYMq3tIyv6SljvfUQCzKJMVwqaIxttATEz3rc3+N2PHprPjoQ2j0WdRorXv1hUI2mi8lfhudmYWzfU5XmnXTZOvFbJHc6F9XkcibZNI4ov5S0Wmnqjv7NzBcrDuVi8/ufESx7rgOXMROvJy1TTmhgLHhANBXVXbR1vZ+9Kifs+82JXxKRJ5H/HHvniB107v3N2Pc5v2GpV5uQqvhXid9K47UVoWF+dLo+3xBTfPbxRu0xdXFuX1iNvPm+/xurd+4l/aPm1x7Z3yLdPYtmJlnzHk2a9DdW5LSOTbwDjRdRGHDLwuWlb3XVEeq3x72CPviU/Me5bpkMz9ILv3PAvzLXMvzHiV3x/+Er7iZ8TVQhWrY2PYo0/A+3np3++EEEIIIYQQQnwKErgLIYQQQgjh8VrPdUopRjQTxWmz8NwTs0crvjMb3sMz76GTt7q8KPc/SGf2VqLrLJHYLLKNQjvcxjzQnhdvlZ/NJyNisPHRBiujrddV3bI4VjzhiTq8Z8lH+4RXBpbnqiwHn2+HojtPDOnYiVYIHfKC4wknp7wOr4hJYEKtjBCMCbJW6SIxXUYwH4ngInEeiuqx7pgI3yuLfWmh7+O2t/oqEwGuyoh52+30aqcJ+0lNa15M26/dObdCW7XU63W4rkWh/XAYz4xnVggb+hGMTW5eFf5hPiwsCxurcJyO4iJ2bPXGc+wkOC9bzfOYqJ340Fc7Hg41kiFPvmU2vhhJJoJY/9l2uNV1KDQP6imym7kW1KQCLRpLDr1sgn34hB/ZFaVLLeXPnBUkXfSzo+LJHmVRnlbi9mnBzQIbubIviWF8+gJa4PrqOt7K3B+8OUskfN794XMcdv07Uu5934/HrtsV/kO/cHs1P2DlGucAs+/evPDUS1/OXDBTl9m5lefvys7t4OBnmOeBectwfmI3Y/dDR1ndf9h8VlVt72fYvQteH5j/7F4vyg/vy5jfmAbx5gre/deZucsqr6Nk0/kDx7fkq36b2rrEg/L3Vmb3FrzwbGzb7kT4K+k3Jq1cXnghEiGEEEIIIYQQz0MCdyGEEEIIIQJe7fHJ9PC8zdvRypzRJ4r7cU/E3tPYFUCjPCbfP6kyVw/yXuaZ2KOfG7KH8o/GU28eERgeqX8Wl+U1K572cCaAiFVf47YngMT4q3Ixf62fkXAirZotftnhuCtCywhOwDYVHx0VJhqbVrC0WlH1XqLVUqPVSyOxGrOH6djKq15ZUdQdic5YPsxPT4zPfF6J3nefRuF7uOKoOR7VM8LEcyi85+K/vSysnra4jdfF7IdXL/1oTHPOiaxQbxxO+MsEUXtn8wnjQV0VJlYu0J/M+NGFrF5bdJtszNmOFRJ+5DrE7GYEaywMrwuhdrG543+tlV+rVmP7gkmXvgknJ+dolezi+OrX/ZCB40fvq6ifylxDDwg5B7vsum+uN+ifYzS87izHDa8fs34d9a1E/tvmpHizmycmw7fzltVC2ys0pJq8Gx5w/MIXoohbbtuw65Brr+1pvDEzupp515ej8xV7zWI+zHHnsOglMDzuXSvsNRrrzxPp49zAm+d4dcT+RnMeJvjvMVmZPNz6arlzJarvbgcPh3ZX5yoZv6J5ZB+/0n0xO29nYXjv0m31sc2GNXMsmwf6iLa6fe+a0eDf6r6w5zFOvOZt/It5sn2/274mXnucmJO8Ap/529SwqESQ/xFRuk3Dtr3f7PBrjlN+L9gPa729cHm5lP/+989XuyOEEEIIIYQQ4guQwF0IIYQQQghC7Y89X/ABTyn8QRU+rIris3C28ruX1lsRPsszV8zK+KTV5A9yRLz9yDw9kQCKJBzhGk3rCRqsyAJFGUyEFwkY8G+UxhMtYp5RfTCiNvPEcygGYfVK6psKZo4I9KimaBSKTfGMEG3P4v4B2xPBoYi6b49CclyBdBbJeSJkTxjsi7fy5bBlyeQbiQlnX+qwhSJzFLtjqqUgestzFNV54jxrA32wZfD7ii8ItPlakSb1fzlm8n5xM5CAC/6wjmiyO8brUChvhYAV4tcyvVSTOl8jX8+MfZgWBXJZcbEnmktS+ywT0g4vAaBNsB8JsefjTsNv88Z2+zcE7y82mn30pWEix989y7qVfzgXo+vjwiZLM9WPI+BKXzdM/47GraPgNafnhXmHVJK/FclFc5Ckj+N1bzw2ZpK32R3a+r3DeK21U7Q62GHXS3b9jF7+YWHjPGMx9jth0TXc83F6AQuuabTvOL60rcb4OHy15+dt7UTX4WiflXMswzWm5/84v+j9YJ4HDN5DtUfnaVTmVdoIb56K4vRbIB3rp7zZvTmp35AD4ym7Ji2/PuHdu+B1N+NLLaM9by7DpqeZ+6FoPoH3RZkwtJ/l6Bh9zzxIfBpHfy+LvrjIROmRffv7oE2L6cc87rhReBLdp9+/Psr//f/x/1QPF0IIIYQQQogfiATuQgghhBBCEFopb6WVy6s936GiGvPgKgrrAva+nS0bxmUPx4bPGlff9r3C+Gfwam38kpypo4x+NHow74kUrLhh5VskOrACiZWvR/trJHJgggtPhGF99/zMCDcIKVF65rhph6X4ZyUgmfR5/iqhuxbIF3hFZIRKnmCL5duGTmmFd9wmCuExfpQ3yyMSc6NdKqpy/GTbo8g/Tmv9wHKx9o0kgMwWK58VemfEhehPJFJMwQRdxodIYL8Seh7xh5U9Ms2Eoel8cQzr13obv61tTsdxXGDXBSRRf9MLBfZ64onmMNxr4wr7B3FFzsCqD4w9uZZa6zQHrDaf20E7h+vx3FU+76Em+pO9BnvFxXDsexkh5BbUhuuLx0ogPflLrldoa8u7+XFdWFluc/5W2imxGhNMMytWeH7E9ihaj8fpeVza3z/GF3x8/yoNX/nJtlf7LC/vurhfD3odxHhC8dk282O0Y33I9reVCJzFHecMUb3vL4+tfFrV1paWzCtXaYa+WRfneoLtupCZk9v7HHZ8DBzHudiJGe+eAsdM57o7+dTvU6J7Bbtv72vYvMkZ24c02WtFK3N6DGc0iBPNBTLzE3afl4l3lEdeq0Uadqld/SbGxOaYDn9nw7Cs2B3hcV+189TbS5e1/P/+f//n11d7I4QQQgghhBDi85HAXQghhBBCCEp7ay8lwzaQB1sr8CEartSOD99Q1DRkX8d/qwd3dvsra/Tsw78z9r+MZ9avJ4TAYyg2WNlEQQATOTBhgSd6xHQoRqjwj/nDRBNe/lh2zGslnmBxo7q2vniwchcnzEvr5OGuIlnPi39id+yJS8LixDm7ZSzXUVF0Ns1qxVVmOxKg2xVNMa2NNwm92x7HW/10t+X7wvzPhnlxeNf3BzYrDMzAXgCw4Q3CuY8LwVvj4bbNeDlyokuWd2+nIX2fK2C7tbHtvXiHRP3emLEJdeL+7PmQHj+HJJCgj02mq0zi56gbMaGh4xOtQ7hGpMSkji+umHqMNEch4qhSmpm31O1YNF+jYbYuHdg47vUVkgG/ju/GT8NekMnajF60aQ36yHaqrcayvN+OkY3LFjSObSHD8MHGqZ7/ffCXb/yvhngvWbHr+JEXlLxrKHs5Csd9dq6z6zu7PkcvVFXir3edZi8J7Mf8smOaPU7sKyvX6nrI6mU1r1m96OD1k8iPyB4Lp+V8wBQ3PX9Nzvk9If/SXhZ7T7K4P3DDo7Edj7OxHsM8n5iP3r1Qtj6y8VgeLC8vHrP3hb+Z/EQyv2et8OZN2wtnLY7LbLHf01b5Yhr87c/+hsd+73vNrrePdZfLa3oohBBCCCGEEOK5SOAuhBBCCCGEwzHZ3CfRSulerVbU9I5nREvRQzC0z1aFRwH9owTl94jIPR8e5dtLvA7xAPHFIdtM6OD5wOpn9QA/OnYkH0zHBA9MgNAHAbbvldkebxDG4mB+6I8n8DxabywPG87ypWaSYpqsXzRaImKmr+O4ZsVcTLS68CEjvMJ9trosE3xlxPRsPxK3u/GIiNEXq81+MrEbbntCQ8yLCf3sPhPXo208vTx/VuH9qBf/iHDSw5Zx3eZx2NinbJyb7WbTVHNNr2P6oWs8QGRLHI76w2lwTN02UekzCpfpGOaNs4TqTiYK74yZ62OJ+9mexXzeZf0e50/tVo7RzjVO2+pmK+odTTcJWgNBXxs7bRw/w9QVxnEw2ydXfX31coh7vgfZr/pBZvxoY3HXeOK5qXw2Sa6BPPGzlwfmxkTS4zg9/s3AxOG2rSIhNvpkGcP5mD9fe3Pg9Rev8fY6bfOKhOgZET/Li9nyfAgKFNqyZWC+HGHVnhHNjItpzo5d5rq5waYq915So/sYNvZ7+XnXT3bf08Ojew12/4PxvXsaljeLl22b4Hp1uP7jIS6ftwg5+1vRs38nsl9SRPuZPLzV4ZmYfZUef68b80++EPfJ1FqvfrdSXvAXWiGEEEIIIYQQn4AE7kIIIYQQQji83sOd+GGOFaTblZpQrM7AFd69FTytmB1XgI9WhH8UbDWrryLjwyv4+TCe9SwRBRYr0UIxxz0hNwvHMBQiokCjmX8rUQezbf8ygYYnhlz5nRVi3uxvAhnPjldXZ9r7gMIsEhSlRE6RoHVhdyVU8sRTnsB5VRa0h+L3jM9MiLfygQnGM6JJTxhn14RlAkPrM6vDjCgzKltcVznBWxTHE+qhPxn7mbLu7eMdz4Xtw4sn3rsNNe16wo+as/MDe1oU2J24h8X5mupWKBo8eX1unmo4OzaXMojk2UseKzvZfji0NQiYxr/2+Gh9XvH9WJse6WPpuEyMGZ0cPeowUV3neeTllmhV6a1tz4osvbk7jnt2Myma88iMh6twe4yJ/nM2cmN23fbnVdmbiY/XYu/ajPajOQGKv8dr75xmv9Zy2951B0Xn43V9fInO1kGD/2ZxPRfA4/H89dgvyxaWnesveMRLWV7brmwv4xw533FMc/yycWjeqzGFHc+EJcbXIV50P9DvfTCOd8/k3StFZbXXBJveu1/LYu1mJ2+re6Nn/1bww7TAL7HgAJAVsXtp2TazywXr4+9n7De/77CC+zb3rqU8/6QRQgghhBBCCPGKSOAuhBBCCCEE4QlrjT6ANvzp2NXV8fPH3qeQ6cOsyuNYsbu3MtRKQI++3MuZh4SPFptnfPiUh6yf1VHvrb9ICMHCM2LBjFjAE0zY/SP5MJEE87XCdtROGNfm49lNtscmJGpJn2xZsu2Avj2xTzYyDoarrbLxynEwK2iyf48KoD2Rn7eSLQrVVratf1nBtxW8MSHdfJyv4J4R2mPeWN4xX0/TxMs1CvT9tmR1w0SPkdiR+TQcr3EbjG0cw3wdhYe9rlZC0t52C+HcAV+8OJPQP0jmHafC3cTY4gkqqe92zDJjYiTMH+oXTLbScgK6oavMfXXzt5Iwmxc13SZ7pZRBmI9zRW8Ot8VpxV+5/g5ou5zJxhssEgLTqL/cdSfABKjkurWCnR/2hQgqnC/mB396WVz3o+u5m/Ct8DFnP2VJX7wdxRcx2FmKL1ZhWmvTv47uYez6yvKzdcz8Ztf+8Vox2/X8w3LYbawjFg/LiL6iH/Y6iXGj9kIb/pwprmOIMsTx2ic6X6Jr/RGwrVfzOzZPWGTg51lJGJ8ADflnWPpm7wfs/cLZ+76evv9j9yCYP957lDLm792/RHMDdh9l/bjnWhN1+6P1trpHvJcH//4h8hxZTd1uR7+1sTTR6u6rVePp/O8V3xIo9lR5Tf+EEEIIIYQQQjwXCdyFEEIIIYTw+RYLcK8enkUPy3q4FTt5q77bVeGZPbbyuyewX/GMin/RZ3U/m6id7QP/hUBwmUfU9ih2AKEjFVFUkw5FHOibFW40CLP2EZsH+svKsGJVB6t0XhxbZiYydPaPCsNdvwbTvlDPbq9EQZ5IG4VnbBVUFDsxQRQTrUe2Mzbtf55ADY97AnMb1uN79geRJdSXJxz0wli7cJ0T8beO9Wlz4na5LxWURl5/8cSNTJgWCdSZCHF1brD+U0i7eOlL80Wnrh+3aokEfuif3c8K8az5jADUxpv6s2nKQQg8do7rn9aG8SsUGIKfy7BZsevH3w5F/ZMnZ+dzvYVf51S1tNYmMRSK3WOM2BbngNk2NlAB8VEzUfyErdW4tPlVxnE051r+vM74556jbLxpZWvvyGbkB6sZf5Qe7fe+193DMRz76b6P4+W+Vcl/pYzXTISNtfOYPNvAa3BUZ1yUPec395/5emv3R+F3oXFYn7RxxrpCv+d6mssxxmHlQZjdqJ+xa2KIO/b0nlQhfE7rXQPjbP3jwwtEmXMb5sJ0HGTXj8DWzdC4711/WFwWx5vX431Shftse0/gXRvtKW9toX30oZE4nv8Mz6cj3HMvxtrg7H3cveUQD+PIb1erBSHOLBjhieK93/e8eJs934Wvo76oX0IIIYQQQgghPgUJ3IUQQgghhCC01t5KfbX5cvwU01uJKVpdPSNAx88Z97jsYdijROQokP8Wbxp8FX9j3VhhRCnHy4gCQqt9WQkWMU8m7Ij8Yse888LzBUUhK1EDEWy6cRl4HOtpEGSYyOgjE5sw3+7ps2f7wpY8ECgRoRiLkxXAR3jHPWHUEWE+E8Vj3igORJ8iwZkn+F6lj0SIzP+xG3If2EsF6ENWSLrb2cV9zeSREW1jPWA9Y93bfHvKrPAOxZ2svin9+grtFQrTAwFWxt9su9tkk/+3DuGJF6f2v4nWhzZxyuH6d2TsbnE5N5OtLoWLW39D/9G5aveC/k/G5n2e1dwvAdn54z4P88codO8o2XPVcmTcXcXBc7eHbSLjWodji4yOlafGY+3gG/jB/P5T9/FsdV27uUvz4nFnkbY33vc9Po3xrqXjeGzD0T8b5o2T3jUOY7LrFhsTUeAdjc82nSfKx2t228LmY9EcgZVx9LFN+WbqCvdX/ZqlHc6j5PlD69bOOwu20z7A9/ET6edOZqw4BPFp8xchYcM1ytrrY/C+cciXyR/mh3e/Es3rWRnQd7ttm8ererxfyMazfzHcY+XLPURtlC0Xs5HsS+J+ot+dvNXSo8UdInssjrcqO6bBbS8O2vRWkN/SvnzHenX/hBBCCCGEEEI8gxcT7AghhBBCCPEatFLeyil5zudjH4xZUVJmhXXc9sTsLB6GRb55rITrkThfvBCPbJ+ztpgIA/H6GwodQECT8osJRKzNCuE9rJU5f4yLtj3hAxN6rAQcs8ZrIRRpY9wI60+vU8f/pSDoYJ5MQHwPTBjnCcVWArRMuCfM9kTbq9VrWTxWJiZyZh7PwrnZJluFdszFF+3vgkDfj0HYRtrdEwN6YkQutpzt3tOfsL+Mq+v63RuFkF49s74xCFGJiNbasHlgOPXrxMU5avMwzjBEkHNv0lfPotLDvp1o6tZgLGN1bsfDwJepnBg/699N7F9rLaXOc8RWyvTiIp+fHWjvSCBG+vHa3LrfZNJH4yrm4/WHI75nz6Vr887jg2Xry219zbmem85Yvpq7l5u8DUS7mWnWHnec8ET1Ol/XvBfJdv9sanbNwvrB69GYpkzpmZ9z3ntodC3M2+lxW8FRa++fNswv29F5iAezdeS8zYy/dM7hXwypXSbsZzbaNvjOea98PFp31t8pjM21vfhlcU3Eewt2zPON3Zswv+w8HsOsPc9H5iteB1ke1fytsO+V8f4pf+6e0uNI/qzNjtoQD+fo1DYjOEe8Fdftv/67nJ2XeSuwe7/noV/WBgvbr/avRr36ed15+1pfhBBCCCGEEEJ8BRK4CyGEEEIIQahrWegXwN3xhOzeSlKZTxt76Vl8zM+GRem7P6s4Kz9zifL2j/ISq8t/9XPIR4kJMsc9sYgVRkQijSP5e+IPJnxg4gvrWycjOmkkHpbFE0JkfF0JUljZpqBEp4sEKKt0d9KuCkBi+qRIKcqHkFkhdWVvJQhEm56gz/qDvvhxono6Juwct1spZRYCRuJA49IWbgXyXvr5lGlTOuazV9erdvPTsaLkRbnj6RqL9m2/s6LHLExY69XTbYOWPcrTOzcwjie6D5znfnhj9RnfnLRWTDmVvTn1SWaZK1HunjQ4X24+Dulr3eZ/1cazeZvJzCauskXfwvzp8Uoojufvo8diVs8ZgXnkDxOdH/Y9O7+BPOMk+fwngXJj5yxxaehWFY7v/6FoeMsH4jezfT2ee1GgOXGja14p87U2vv7O4d4YitdNPo2a+0k0TnOP2Dhu6wGvgLwM0VgajfW+1TkP9pflx/Jhx1b9OyrHmniu4dnK+vZUmvkXzdWZi959A2LvqZg9zLtBfO9+hd0TrO7XVjajtPfgX+YeRzAXEa9F5ouHLG7fj9Kw39G8vKzo3cs3+p2M/VY3f5XxNX8FLaXd/K/lz58mgbsQQgghhBBC/EAkcBdCCCGEEIJRv/TxtUsrha6Yiis3TenIw7aeDh+UWVvMbkZgHgnXURif8ZfZxu2QJzYm8+ElRO/fjVWdrUQQpcxichuOwvNs/ijcYP6wbeYPbluRCPoY9Vn0xcbPiERQmMLiLfIfREFR2xwVcGTPnZPiFirX6uPhiYHCExuHouBF+Gaz5XzK2M2IiUe/d2kbFdom6wpFoTZP+xfDaLmj6wL10ZZmFhV6YlYUzq+E4tbeKPjsx0qYHsuPoV7Bc8LQsQ/0knjCyqPCXVcQX+fzIOOvh9d/cJvm1SBsIdyxdRPJO71xJKTmhJthPiUuc7ut1s5c4i8+GunsNFlk85nb+W+FUuQ8j8TiZ5hE2rd+Zo+P510sHO5/o5czvG1PyM9s1lL36y7Op72GItDyh/FLqdWef6OtM+f5Kr9u2w+b64aVC8+/yFOvXsYceRt5Iulx3Jpt2/iNhEe+RvlG9ZEdT1fngHetYvnbdmNxsL5o3iiwdMaufJ+ssDe3GcngEPN5eaun27WD5nXm8pY9BY/YtvPG6FrnTTeO+FDJth3r8J7Gs4H3QpEPtkxsKnrkEvPVP/Tot4IvIfr9ySOzIEMkVGdx+1/vNzxfgB7/NtePsy8v4r6Xb2Xn1oswXuGFEEIIIYQQQvwkJHAXQgghhBDiG2Ele5kVpFCsfvSBHlvV3cvXE8pHD88yvkUi+Xt5lhD96Ket7+YzHpKffdh5VK+SFAnSNK3w/BrEyTCqwdbbaLdBHNzPYtNFNjx/kVX+s55pDdr00q5ssuP9ITyKpTJt4rXPJARYC6Q88dURYVs2/hFhuif28sKsWM7Ls6fhYr9ZcLgSSjMhqBXrefmgfxnh7xyXCyRZWqwBzzaK+yJR3qpsOeHo2H4sHIWWLE0t9XrddexZMv3D868LerFemJjSI3ueeH6dEVezupteKDTXki3eNjTFPm8CScd/K/K0tj2/sQ2meLU7fLM/uGfOjzYkIHHXpF7eqLnzOHPubzbbfE6gsDfqC56gmO1H5x7apvVB6hT70BEy1yNs80bi0HQQkn1ZwMan59M2HiJ2nGTxeZ/Yhd/cl36NRIH4dJ5BXij+tvnNZR9t7vHLlJ83Xu35zNfoPrZjGq8cWA97ucdx2uvPNi76b320xz36ee/liz7nro28n2G+fXy4BZwDT0/n3gPLeZjVeMvuI2wYzP+3F5XYfB7vh6J7F+/+xYb3eLiN+dqyeHPznraReAX2o7n+kbaI8jiS7iwHr7V/O5+xQMA9v9Ec/S0tK3j30uGiDqu8MT9rYyVqt2mugYfdfjpXP+OX3oQQQgghhBBC/L1I4C6EEEIIIcQ3Bld1QtF4Kfsx7zPFkRAd42I+LD8LWyWLrUTFHshFnBHre3YGX+83+ffChBDZdI/G+hKJJYqJY7ezT0ZRKIHpMC8UemT86XFXQpNi4uE22mb5r+qIEYlUGEfaYQiufpzFfm7Fz+K34xNPeir8PWZgstP3dyFnWZbBEx6O4jcbf3YiJ0afy8fLzONlBJtWqMjEfSycCas94SR6eLjNII+xnnI2RyHmbBf7ko0blbWHXP8H6Z3ziolUbTrWN206JFufXjwmYLX15f09nWdL+Nyc/lv5OZYVSnfbLN0YhYhmwVQXBbXWBe3zJOo6H6p8HlnIfA7cWYpTsS7t/IvE9/reSiQcXk9IHuwlA2afnXOR/06Gbnimz6YExXav4rjjr+q9chYF4jatK+pf+tjDbD2P540VqeP4h+MkjvnbNdLE8sYyW09jOW1+fj2gz9WE279jvhjezP/b9P65YG1k2iIai/BawvIskMbmO/t2Yt4DtiPa9cRx887YXNWXXw9lnkuevUey83XvPgDzw2OeX32/52Pzgv2hjM38w3SYD7tXyJQL7UZlR1rJ+RhxNM/P4Nzp8tdwVAx+9rege0XuXv7Z1dvtb2isDDacLR7hrUIfrTSPvxf2eM9cSOIZ3P1CkRBCCCGEEEKIb4sE7kIIIYQQQlDaW3nx+TJbbck+qLLbkwgdHs5hOmZ3lcdgv/Aw5lPkfz/mCeUjogd23oO/1fOyZz7we+WHiU/nnrJbgYLXgIEoL0yH9j0bXViB+aDogmHPSRTL9HCWfyPbzHfP3x7O7Ns4aIsd89KmNX9OxEbiNIxyRPBHI7g2mHjtCFTcdVQE1cBOG31ppQ2rTEfiWW+10zm+L7BGu7Hru+huFJ77IsOtTERUlhU923AmckeB4iyEHNPOp99chyga5OJcFNPOR6zMktlrk81eBtyfRd97ucrsn9MtIvFfJDz26tsjI+pF+7MQNSdGRtvbcd7Zl+3tHtvMEtFpjfszqzP3JYM6t0O7vbG31UctpdZ6+2ecMI620e1t3lXrfrBifQxFiscFfk54/dkvu9fvUuPSoN9sU7usxkgbj/W/e8gIaSP/8Dy53NTt1tpcd7nrHwvzxpco/Zjznv88RcE+ganHemf5eiL4eTy0ZVrNKbyXi7yyxnXo15DfxpFwOx471mMW1sXK5jjGx7aPkk7Xx6SDc/t6Tcjr1MzTvPKjr7XfRK7m454vnr/svsBOE6J7jFZ4eud+o80Dxl4me08T2cP7ICwD+sfI3mNkbGU4OnzHp1Mu/dE6ERv3/F4S/Q70DJjgPPP71ZH4PQ5b2ILZyq7kLoQQQgghhBBCvBovLdgRQgghhBDiy2jlrZT6CM3KQ2nb/932W+5h1PRAD9KwVdgxDX4u2YrerQjdE7Ef/Uyz94nlDF6dRKvNZ+zds+LXimfa/lZED/5XrMQUGC+TLwo3UOBhw1c+RAIQZsuKKJiQpJIw9M8KVDwq3ZztRH4zm2dEI7if1jj1gWlMc0hcNWmc7n/SP4nCbiJTj+miw+pklUcZBc49zqo0TCDu2UXRriegQ3H2Ks8ovx4fRXhWQI95snx2caoNj0S3bfIDbTOh5UqIyk5+IoU2tndf0NbcTXh9lVJKuaxfdoj95hydMOXFsE45SiG1xfutx9Bu7Pxva6EvO+YJX7dyNNuruHiU9amMH2NaLNMce+775SqQh4vRNn+KDVJo+1nRFRmzojq2ccMXX6xwk+TJiF6+YXGZ0PvIqZA6DxNR+MsdsYlaxjKwbG09s3pfnX9ezdmjdQrn4zTvzxXKPJeGCeLZ1aoU3qfmMXcvu9//Ro/xRYropY1jeNemsU6Ic0P+9hrXhnN/zXVMW8d/6k11wnTm+ryZo+pPajRlD7r8EM7Gp217Hopz9zjsXoDZw+OenUiQjfHw3iS65/LqNKpOe6wuwjNdLtvVvTY8yrHTSwBHvvjnpX3Eby5Hvz4Y+cR+PzvytUK2yvtZ3/hdxWuw/wapE0gIIYQQQgghfiISuAshhBBCCMHoD4Ze8PmJJ448I8JmInY8zh6UMTs2nvdp5ZV/eIytPrUfjO1kPxOdeUYm8fkncs85txIfMP2PPc9RHBGJLzx7GMdue36h2IEJRJidSL3WxSaer07ahr5Yuj2vPEw4g/GPti/m6dTxIFDNiH+8vO4Ehd9jto3GZTZuCdy0mH5e8dZTK63xxLWzYL7LBJmwkgnuRrF7tBJuRqR+zWM8busDhcazkNPm2SV9XGyMeRwVHdtjkY9ZWLtgGCuz7XHWj/FFhMdOfHjdz+XIpM/WUfRCgj2O9u1/Z8SYq7ZkolY83zL5Dv208X47pRnGXzi3WoN5Th1exjksInPGo+x5s6oD78WGSIiOROPLKj2eK9O5sxi7rb8r39h5nfHbnnF9rGxB/DFt75u27eZ2HEdT3vf76Oq1z2izkbhjLmPb72lYnmVIif4xNex8pKcZ++f+/961Cq9NzJcjYy27djCbfimMrTq/FLBtOzdFS9F/9ec0g0tRkRfVcZdAntn2zFVyLnv3AtF9gGM7LGc/jvHsPUl0XxLNgz3RN7s/qGXM08ZbzbXnE8iPw+51PFb5svuDI9OZI/cO+l3g6Xy1hnn1G9GZRRuyvztFeXhfIbTHUCiPab0vPO5fM/ziyl9wuUjSIIQQQgghhBA/Ed0NCiGEEEII4fFNH156nzX2HnKtHp55D9JWgnf0wYt/5uFhY6KCEzxqZXjxYM7W8yod0/94aTwxDAooon1rB9N62yxtJMxhYhkrjokEH0zsEoliMI0XNyonSbOQROWEL5iXRzTeWAMrIZZjKxLy2eN9OzqeKY8nuI6EsisBNu5HdnZx+C7W9MStY3ijx5i4PCMCx3hjPcf1jkJKrM+M6NgTpK7isXL56fe4ntARe167DQJ7XrVcKsaPO/qq7tEOCsdtmM2LlZnV4yoMifpUJCqu5j8s2y3CZGdVf0wAjXXg9QMsj7UTnWdjmW/5bgL2sXfsf+v2oqI3z9nD/Tb1z63Rx6g+znJUVH80L89Pr9+wtGjjzBjt2cXtenkr+zQAlalzfusxbB9D9nTo8/rln+txfk76/ZqP7SyN3zZ7f8CxqRas8zEPfn2b68Pmiayu+ysbq7EGx73oOhyO+c4cLUs0RrXaSqmBvSCb7veh8/YR92zenNe7D2XzcQ8cjr05OZtTe3ZrmV+Et6dcdO8AeUx1be2gvQLhuG39bottj6gevPJ43QXDo/rI2vwMvjLvT+bRiwsc/Q3nnvyjRR7wtzj8IiLaWPkVfTlxVWY3j0t56b725097/2ofhBBCCCGEEEJ8PhK4CyGEEEII8Y0Ynu0mHoKhUJ3Fs6uvd7sojPdWUrdpWRwvv5WvUbxnssozK+rv+xLEfxHRQ1nvGNdzzftMsIFxPOGEJw7BMBYP4+I+E5nMeuLZd/QL/WXps4IWz+8p+U0SxQQu0TnEypd9IM/GJgz06s/J667VRRc2IjEkimMnIV0XPsBxlieK6HYJHxcQMl+YqJf5izChoicGRLFjC+3uIkmsAyYKtCI6Jtq2f2fRYx3+29Pa/UJtFQjHsuYYpaxMJjkOG7O/GTyBciTe9ITjkeC8H5vr2W9vzMv2I2sjEnqiqNWL44lro/7llRWhomXSN6Lza8t3mryMvWTyp0bzF162FatxIYqL4X3bOz+z5wzrg16dZsrp2cjW1WqsxPZ3hd11f5FlbvmMD5WWYZeKz1886Hmx8xzPu1Lm84K1+d7vyxSf+W3/G9tiLj87n3A85LbsiD5ObqL26THGeh7r1oPVadTn2dh2pG/lufndbJ5j3aFtvMZmYecTiTQeH/8cZ3UPYMJdn1hw7zZ1ES/jE43S5jm7d4/Q4J85PvQRNu9tEM4uJ949QeSbF9faz94rZMOPTLO8ftC5/1YgzlucggnDo30vTeZ3rOhLhsw+E7nb39YwD7ZAA+bPjqNttwyv3M9qKaU0aRqEEEIIIYQQ4geim0EhhBBCCCEo16cnX+0FsktI/Adm3orp/WFX9ACNPfBiD+y8B3yrB26ev9GK7yigZ2kyeZ1dxSoLK8ejVx8TSaK2xGOZNmJpIn3gSjjha55G25FdFK+wv0yEgaKWyE9rA23ah+A231Hv5W97/hlqqbM9z09M59mupSwFNYUcj/Wgt0Nt6RtLkxHt7uG+QM4VrNU5fj+O4mEuEB2FakzcjAI2T4Do+cvEfp74FMWRLF8sy25rFlVmxaezyHEWDFYoy1638/buAxMf2nLPQmr0w9bL7us4SPTzqV7i/obiVZsXxtkt+/0H+9kQXutkC/vVls4UH/vICrS7PP8L6UNtLFOH1mGNj3txvfxZ+3v9FsW5NK963b7+u3pZyizIupZ7M4wODmWcz9N5XGBlwTTdjv0bjTPeOOL5ZI9nz32WnvmOdnscbAuvT3jt5sX1/Kv1cp2TgjWv39q67rH2so3xsV67ZU9AvZfJXpbntkYbrF+z8ZvFt3naCY8tA/try8facb/2zGMiK/vR6Sa7ZrG+ydqRpaW+Nf6llSHNNkySMb1hqlZKjce5TN/PEpbv1tRTXwzmbSedoH5tPnhp2Lx9FZfNodm9gZ3Xs7RoA+3hvDiaA7Pj6Auzw+51FvcBQ9xuPxP/Wei+/q+B/U7Wya6ejuAcyvt6YhTHHrcCeBvu5YPxWHo85r7QeN9Q/QSqKa9ORCGEEEIIIYT4iUjgLoQQQgghBKW9lZedL8dPnLwVo6KVpNgDMBSYe0J09lnkSNztfZp59VlltrI8sx09lFyt1nVUnM/yWPFyzwt/OkcbhAkysqIVGx/FHSgu8Xyr8NfGZaIWJi7B45g384cJYVgdMEWXJy7y7BcQdQXCShbWBVep+kQ8UZHxb/PNaZ+VIC0UllGTVmDmCOpOvKGDAmbPF0+QOorsRsHpSuCKPkTiPJZurmMUV+4+2dAuTMSy7vJHFOKNeY++zSLBHhqJE0d7vauOdcLCPHtWjlohfPf3Vra21woTpGI+LD/bZl5fzgiGS+H9diW+9ESpGLbKdxbp7rZYH2RialfU2Ma0rh+lbXGZ725+xLbn83Z88ImMJPVqZXgZst0st6uBqw3+YgF7UcHzm7ES7K/Kaduzmv96Gjs2YdujUJoJ9T2hvCUSaPfj0Xnn1evKBsbr5zr3oUzlx4txK7bsfj62lqN+vsfZ9+3IhKn9c43XH/Ovj3K2pzNRfDVe4fjeTBp7/Z2nOV7fGPuP1z9a2dsFkjp2Z7w4eE6UGp+TPU63OcVdDu258/3MnGXwkTpS3eCba0cz4mHzxdbHn7bxuJgPhvd9zJ/NvSO/WDmYH57v6EN0v4J1AHPqJVH9efc4q/Kf5ch9xL1ZPcjO38hn1k32y4OI95sS/m6W/W0q8xVFTBctIPH9+lczvn8754UQQgghhBBCPIAXFewIIYQQQgjxxbTy5jwm/3LYwyqLt3K7Tcs+nRwJzNmDM7afWSUdV2Jf2cjYtUTliFbrYgL4Ry8QhXoA8c2gqkCAiUyyoLgF03thK2GL7XgrwQuzGYlYbFwmWLHHPF+Jz5uo6owwyEsTiFDdODYsEKKOZrlQ1RPBMUFvD79WwWpgjQ9n8fLxRLZtUeko6GM2ejyWD6OSTsTrzxMSNifN3OHnGLPKzNZFJID1xNTc9lwWfHEABeZ7F92PcyF4KZdabzrAY1cjT7hPRZCBD/a4tc3C+7Fa6iZoQYFtJFa2YdjmmX63FIKW/Txltlb2vHMkys+rbzxOy9Pa7R/2sptk9DbpGVfJNHVWr1ZXPnphXv9l/q7qxhtHVjDB/NEXNbCdV/2KCe8xj2iMwPphLwHYY2+1lHq5mDxtfbGxupi4c1nY9ty3R1+9stiatwJ5OzLz9GM46xs4TmJa1u+a8XzMt20xZsbryDUO84udZR54A9JD+Zjrkemzcwo+B7mL1bCG92NOex/LAG8gD5r00m1z2xN1xJJ4U6do3u/Zsse8aRD+Zf7gXD3KA+bE1DfvfgmnXav5Ovp14BQK7X4Dvvsi1c/UID+ybla/M3lCcRYvEpFnVn/3vpp45quAbGGL1dcPa3a8+WK0grsQQgghhBBC/EwkcBdCCCGEEOI70Vq5XIbdTJIBtgr66lPMLA37tLG1xwTyRx7QMbuRr97K9NnPSWM+2TyOoMdx35yo/b3GXQlK8GGyFXxUZ7vBP5ue2fN89TXBc1rPFtpD8Yo97glnmJgI07K4nriG+QDYVUpTMGHNUbFBSn1zMv5SLBYlXYvbViLfa5y1WJil7SJDK/5c+WvTWLlvK+MJsx/xbXvC9UhAiyJM9GmUcc4C9T3fUYxst1BaycTAazH3WO5a6u2XQF8sGQlUraCT1c+Ul/EHfffawxfG+uFRX/NE5yw8EiDbvCKhMdpelcMX9M7+o1B6JSamud+WZve/8rMPwK01M9er+5zMO49AlMv89mAC75WYmfUrL7537KiwNxqjPEE4O2cxLqujSNQciuyddmB2rQ07eq7rBdvK9+361+bDxPzNHMU4dfCJ1YWt135u7HU6e3lk7PGOdY/r5CnGm8dK3jb+eeKdA6t44/jL0o1j+dF5ivV7sH32hqdNG9M8Lu1jYi6YLm4rt5tZki4zz/fmx8wXPIb3Ajgfj+4D0E4Es2nn7/ZflM/KZsaf1f1WXcTD+6OMXfFQnv2byqME9JnfpdiCDOw3r0ik7i3u0NOxNJhH5GsUt9tcLfQwOuXnJYQQQgghhBBCfAUSuAshhBBCCOHwks916vZ/LkywjQ+12KpOPX60AjrLZ/WpZZYGV8PyRPj208usTNbHjAiecWQRqLN5/DjOClteDVYOT1hxpD9kRSEoMMF88prG0R76zYQsGf/sX8yjh6Ewh9lhaT2qs83sWtvT4bbHwzR2n/29F2iLUAybUl6wLHxx9j1xM3hC9VH4XW/NMwo4W2ADxdGsJL5HGHMWmvqCxwo1tPvA6q0L15nPsdBwrq/9lOweVDgyCj7nep/9q2XvV0xky8SXntAW2+ke8TB/AWA+juLXTJ5eG48iWD8dF936fkZ5YTltGhRCs/ZY1elYL7ftm1B9FznV23YXut/ybb1v2PaGuU/3jy4FynzwfbT7WNdR+SIB/UoMz/zyBPHYHyO/bB/xbGbKGeXpid+xbJf6XsrW3+bxZ7eNvvEyMR+rc9wrX48f28a+16a0mTbotpoJr2WfDPh5j2UYbc/Y8dlL54+Pe1lxVB9tsevomG/EeE4cnMQkog9+3zFH2nysieuGlw8Lt3NBdsybu6I9bA68dLcy24n8snZwHs3SOXPZsM55F+Lzd4yDdcBsoK/RPYR33+TdZzEeNQdf8bfcw7449/6mcs8i3t7vTtFvSt6CCKvFFNhiEVG8KK63oAT7CqG1xX5zY7+1jTY+64Q7SCvnOowQQgghhBBCiG+PBO5CCCGEEEJ8U9gDNbbCFG57K0jZFabYgzVPwO6t2u756MVZfTaZrYrF0q9WuHoker7m8Ar14vWBI30jEsuc9QMFJ57AJpMnikOsaMWKevpf3C4Qbn30xCqsPDYvTOMJdzy7NztLYTcTAXl6tWybo2CJbWdpgUjrVk/1+n+lNF+o1q4Hb8m4PS4kn9yZjt0rZO/+1VJvGeCK6myVbuyk6MtYD5FolPs/2kGRuB+/dz0UgWKMUcAZiVW97t4F8ExOan2yNmcZ+SjYHI+MZZ1F00Ohlv0ABZUohF8J0W06a9MTrKJYFNvcE4xmReBM0D4Lf8cXGDLnGPOdlc8TW9s6ms8b3xbWM/e5OgInUwcgrrrGuW7s8y9jG+efTh2tBMkRti3Q9koEj/aZHZaX56PX71ib4djAbLKXJ6yd+dzPjdd/Wiv1UoYBCNNGgudZhB0dH62wcR/rhPmCQngWh523fb9uqbDOxzE16jdzSbFdo7ryXrrg18J56ta2cLvP8mX++30jHqeWNo5OEWqZX3w5cT8w+IeVtch/2qkYHtj15pARtouxvNi8OAvvdqNvbA7PJh/eab065t0jMPC+4Uj9Id78PVOH0dRwFZbNQ4Qc+dpeKWX5W9E9ebI4nrjeW1jB++INhq1+K+vHcEV3XGHd+yohK4dNuyqX5wvGuZ73998jPoVX9k0IIYQQQgghxFORwF0IIYQQQgiX13t4Ut0n9Ym0J5Lhw7KVoD56QJlZDYvld1SwfiTu0Qew3sPCe/JaHRMP5rPrmuWHghIrIvFEGJFIB/eZQAXzY/ovJmCpsI0+YTj6tBLCHBXDoF1bDvTPy/eI3bPUnHhzyHPh0xY/EC7y5HscLsIbnbCies/eJPasXDyIYmEuct7/Rr4zu3Md8/xRRIyiRRS1X4u0CxQLHr+l8kSxzPMKR1H4uPvDhZQsL962vL5tqrdaIc1og4nX1yLqcX8lAvfiDWWqo7DVE7TbtKyeVnn2OCg8xvJY+0xYzkTOnjCXiaRXYuio3Bwc6DF8t2AF7D3OtZuMg+JWnsbrCcuVEbpHYJ2PpYjPieglBeav3bfnJbY5E6f7wuk6xWfHPGwfs+Vg+620cqm1XGpfuX0eVTHPcTrQtrBS+iU6XjF/H7nmscMKum159nuZ/EXf1jJrG3ZG7/mMdZjJZ98fYddMTMvGwXHctL54Y3FmGrKqP79f5tgmH0EO4HtmnhqRicvmnFM6VKQ6Nlbzb5YfHlsNr14Ysx/Ni9n8FOfwbK6PZVt1LpuOxeVTHm6H+RmlYf5F9xhZjraJuAvv95Gjv0WxxRNs2NHfTzwBeSRI7/urRSSihSMwzuqrh2yFeOZjtBCE5yumtau37/FeUzLQ+tjQysdX+yKEEEIIIYQQ4vN5zbtVIYQQQgghvp73ekxu+Sm0Nj71Xa0wNaaN97sNPMZWmsJjGI62aoVn1YsHhcxO9mFg9NBz9QDzbHiGzOerxQPJCjA+GxR5WP3Vymfv/EZxjmfHE4ygEq7BPyTyk4lpIt9tml1lx0VZUR159bQSykSCpiP95U6hTCgM9srQZjHeNZg3mrdy7lWouqep5eDVr4+5gYKJia1RkN0NrUSrR8O841xMvLs9is+xRFhFdTiCW0z0uQs0uZ/4H5bBl7yP4lWW1ubLhNYrUGTLhLsoFGbbNq0VrG52GvdnbJvq5oFp2P4saB23UchufWfidSaCZqCPTAyeEbN7dsZzro5zxFpLu63MXmGsG+Z/e/TpqxpRvSGZ+ojS9HLZ9EfE80ycbmHt6dV9dI5EfrB+j8esHRRxW59iUf6l1HoxR8ZevI/Stm7RBq8zrD9+3u9W7JnD0s911C9347Vkrp8Zm24cD1gdzROBMd8xF+vPXgacNJUhjj9ds30LL+7j+MJKyvyfcxtPajqnWNrg+aMvy8nP0Xl3v+fbN9aurOa/tqnOgvNUdhzzx7n9al68ss2IJife3LiSOOi/7eKYB8vHpon8ZF2V+Y/3Ixh3dU/h5S++Fd5iApkw73cvFKOzlc894bj3u1dkD/P0Fm9YLQTBQKE6Y2WD/h6YSfhVXMcHaRqEEEIIIYQQ4geim0EhhBBCCCE4b1/twIpIsH5WML0SwXt5rB6wtcafLXurXdltT5R+dPUtLyziVZ/tfWs+W2SQFUR8NlxHxQUvKJgpsM/ioPCE2fBEN15eGJ8JejyfUURDBwTHD0bPw0uTFRR5dp8JsR8KRbPt42Y3iiOn43WsrOZU7CysbjZZz6xEHbpNHWMMRwH2Jo9sKPzzxaSegHW3GQlRr0erOYl8YfStDLcy18HGuNVI2O4bLw+Xro8KMCsw5MLRNtVtKa28vc1THBRyM0Gx/Tvbjep1PJ4V1R9p40j0a8MaqRP2IoFnn4na+/5KwBuJ6qP2x7yZ6N76YLdbafNLhqUMgvWtV1UrhAcB7C2M9Uvc914ImPzCPJx+4QndWVnRHmtbL19PQI7pWV6Rj5G43iv/yjds6z6+XWotpf6ZjnVr9vI9jiDxuTj6NDOKsjPjwD7WjgL63WIp7CUHsN+KsTC/9DBPT45e4OfJxChQx7Yf/65yq5BibCssOxPij2PYnms8pzg0FfeEk9AObuIp/dmbVGc7Mm2mM1zoH9msezi/vM7dw851vTmzPemiDlKNz9jkNn12XhtVe4V/0RSJbbP9Fej7qk4y9lf3BFEc8TKsFgXIiLqPLFbgid9t/NVCD2jLE85jHt7K60zwjnbZKvLeSwHe72osv+v+650or+eREEIIIYQQQojPRAJ3IYQQQgghCEef0X4W2WdN0YM9ZmcV13uYtvKB7WfLwB7SRYJ4XOn9qI+rFe0fLXb/seL5Z5U7I2p4Vh732Dsq2ECRit3v2xkREKazf2uJy4qilOpsYxp7nIl/MG8m3BnVeJybDSpYXbUh5p0RIWXsWjuZfhSVO5MHjr9zADfQ/AjRmrRsc4wxi38rSeBr5PYVga3Nleh6F3728D2XavYaVFoXWnqC12JS7vqzURSONm06JpC1nR/FmaOguQy5WG+qic9EvP3lheu17TGDoyck98Sy7osWxk5GhBoJfpk43MPzk/Uv9A0F6574nfnbt5lwOiO4t+kjgXYt19Xay+0LQO6ciswLa7FiMkgL/nkvlqz8tz5nBdaRbWaPCd+jumaCdraNab38Iv9ZXPbSAMtvStdKqW+tlFa32LMIvpd7XTbmp+3x83iFtuYLl/WmDEdx4jGeW317GuvruGI6xt9t739bwToex2omLLc+YRxvlGdHp3MztILpMM4edlS4H8c/ONkFU6Mom03YnLxNEZkof+tO2bkQZOvatPuD/TbaiOZv0fRoqoLK7czd7OqzLTvGtfk32Pf8WGH99aY+jOheIPI98iEb/0i67DxcpPiK3zNWv/VExyN/o9XVmXCc/TZ2RhceiegZ3u9Sq8UhMCyzivwr0S8pryi+F0IIIYQQQgjxfCRwF0IIIYQQgvCqj02OPECzKzlFdmxczw6uOLX6DHT2waC1b+NED9W8VayyZD4v/Yh8VujZ3IM5+iD2bP0fTXdPO1uxCwoyqvln4Zoqri3KioS4RmwUvzSIh36x/LF8mDcTH2UwAikq4vJEQLaeUdPGxFW4HYF1R6OsFBvJ+Kz+PVtRP3GT8k63Cy9nI55QnMUcj1UnXvFalwocR1FkLELNCnX3ssaVxgSpKDbtns8nepvis87mCVaxPTbRai3lcrlsYZ5oG8OYoHlcfXkW4EYvCXjnKLPtifYxfzxubTLfPFG4F+YdW5UZhdC1VFhFfS1oR6L4tq/3fnoVA+/zm+v2vmPnY95qo7XMbTmf13xFdfTbaztsd4yz6o/ZfK3/zGaUD8ZZxY0E7Swtsx2lvRko7/XdTe+m2+q2DqHc5z0uu6x77GPRPlbVoTe10lsiey70FKXEo/B+FdnHWj8V+0oBTkUwDh/D2EsTXv/i48dsc75GWC/m8YrDj+1p1v1+MmcOe1fmJd7ltEGc4sTDOI+EVTubK+I8kvrT+By321jlf2Le5sZlc+8o76h9jt6HeWTrZEWUjvWpyIcfxFFh8+o3oTP5Zn8HOkL2N6xM/mwV+exq7nZ+hek9OyxeFva7ms3Lhtm54cvyg89NIYQQQgghhPjpSOAuhBBCCCEEo27/93oceMB15CEYPoSLxN+RDXww532e2fuEM0tjt73VtaIHi6v8MoJ/zzbjFVe96ryyb5/KmXrowpXP8gEFNVZE0mDfE95gmBcHhTMtCO/5Zfw3fg4CqToeW/oalXVVFza9sV1LHeJuYtOV8AXjRGGZtCxdUL+uUBJFVhngWlenDkETULrYMHvljASw/XgviB+3mbhchNfMf10gOApd905jV9TF1X9RoNhz3qWeKHrc22kQbbbZX08suRLbW5/2OpptTuLvfh1svGwMK5b1BOcsPopBrb8V/vPyY3WREcB6QmZPUGrTMIE/bjPbK+H74FPiPLX15eVrbWPfbqXtLw9Oia/9pa/QPuS7uXnrVXX2G+slejkiOobbXhk338q4Mnkm/LZB25qlX4n4o7J5fYidE0dfamDtPZyTb5ctZjSe27EOhc22J7cyjg/7uWstsZq0MvhROD97Ml578BKGxwrkiP5jWBtKatMxeDs3c9jvq2P/8cbA0Uc/3jzVYZOvSq/5vJ/belr0O7hO0TJH41dmLrbI3zQbt3tkHsbmzVlfMvar+cfieWXwbGGe0byX5e81NatXZgvT2q7H7i+Y/9H8OUq/apfVkOnd/zxjPv8Xcu8L+GfTZ393yq7Ojr8Leb9/4G9O0e9E3oIQ+KVD9nIgE5WjUJ79Hoa/fbHf6M7U+eprj6/KN3RZCCGEEEIIIcSDkMBdCCGEEEIITl6l99kkHtCdga0g5cXzVkDHFaqi1dhxhdDOsIJUm20cfSCHDyu9B4zoG/OX+c945QeGr+xbmkwZvDjPKj+KJyIBzhEikYw9bgUrmLf964k87DGM54ld0K+etpXZhhWFWX0W8zUSHqG2axXuQURqrbRj/QPrKOtDHyMhs0Hw2AoVlKb9Iul8IeUowowzjGWoqxjWFybU7tsZG8xmlI4dt6L33Xe00ab/erg9WooVGI+dYRC8Vt4WntgWBeWt7HXsi8BNfuBnu3b+8na5lFLncnlyVc/fSNRr25S1uQcKwb24URzW3igW9wTwrC5Q7OlJejE+E77bcOsHE0RHIulsXdhV2q+TIjt/sQP2GH+bz21Ju8S23n0tHYX4818r4EYhN8Zj5wGrczY82HysXWvHxvXKwtoQj2HZIrD87JgdF0rp14zZS3tp3seGsnll7ewjyD6SsfKOtvGcsZfyZnIc0+4j6ZgWG6oN3u554qUO+wpjfY2zJRvjR/1+LzX22vmlieh8t8c51m9zgtaeck6L17nZzh5vNp080bekdfgTxo+agM2pxmGK5E3SoD0M8+xE4av5Ks7DG6RBWzhHx3hoC31nzWrjRWk8O4gXj/kbzeO9e4gsmXk2n8adz1OcIlp4IEpzD5FgPCOaX/1Gwuzh70qZLydiPGYDfw/rf1crzmdX1I+/mPjKJ0wttdRXdU4IIYQQQgghxBORwF0IIYQQQghGK+9f7QKlgujR4D2kyj4stMLx6IGktyp6dNwDHyhmxOsroTpbId76duQT1YxIfP8ZaAX2knvmmhWqPAp8FuwJcUoQ7rGKj8ITT9yBoMAlEuFYwQ4KhTA/JiKKhDUoePFUdV4ezA7GZfl7f5kN9C3Rhl2o7vW5QfCP4RXEZni8jcJJ6qeTHxWsNSeRYRdpnmMUNnYx3xi2+zL6lhFcr0TxNj/Mu1uN7GOcOJ8GYcWIDG35MR3mzzp63/aEnL6yzOb/dnkb+hDzLRKtY3jfZ6LgSKjNjqHXiGeLlThKm8UTuUc+WCE884MJ4T2htZfWsuz/rQu+iIi47qpB9iGL1vr/mT63na5+P/bCMkJePl7M/RTr16ubSQxO2hC3o7JEovYeFonlPVtROTB8iNNKudRaLnUPZaNQT8kv8tZXzjhNsG3iqYVtf27Df9YaG8dsW42tPqZhY8lYf36NzHHm1GWK559/1ex747w3WvWcsX796wC26Xxt622D/RGcconGV+7WYnzNTiCCucxkazVfZHNHliaa27Hu7eXrzVXx9PNPwdmm55M3fz9y37Dyk/nR4PiReruHe9Nbzk5mxWmOCMg9Mr8v9Xj27yreUb/YKu1obyV6Z+m936mirxuy/Fd1uRLdv/IJ0kqTpkEIIYQQQgghfiC6GRRCCCGEEILQSnl/6EPUF+ARK3dHDwG9B3WRLxg/EqNHK2QxsTl74LhavSvzMDS7ytezyH6aWxzgs9vyaDt5ApOsPU8PFcW3ApxZdzaKWmx8zJPlxUQ5VnTEyutp1SLhj03v+YygMAh9aRAeCJS6UP0h/YuIka6rKYNozatXahLTzYVZiTjRuU3UD+Z8ueAoUKylloYL8zFhyCRNpJGmY3Xa5yv9tiHFDBegR37xurOSSC4cHz25tvc1fO4Ss69j2Cj8vFxKKXUUPqLgloszRxG7TcvE8mzf85EJlr00kWiepVu9VMBYifOxDExEbfPx6hn9YXmyFaGtTVYebP++Avt1rnA7G+relyt0lz3eLYYZJyJxNmMUK/ursbO/nijdlhv78UowPow5QT/I5Illw/ywvaxN7GOrPsr6SCuttFpKfeMX0C567iLzPdz6NObRx5v5MtvMkT2kl9r6uE8N2OSgwnaBtLaO5r6A22XwJ5q02PzIBbzfB2x9CPve9Z/X51d9aW+DiOha602qcIIy101KqI7lYlV5ZN+G42VtNU8Mwxw/M7ZX4ZvpOvzZttl+NFfGOSfORZlPmMeqS2MaZpPB5rJkvknzmoeax/BZ92SP9PmH44ml7/2tJLK7+oqeFwcF8meE4N6XDK1/6KtXH+y3p2gBCUa0snwU1/PltWml/fnz8dVeCCGEEEIIIYT4fCRwF0IIIYQQgjOrx745mYd5Rx9sRQ8Z7YO81Yrw0UpUR/yM8kQ/sw8KV35kHz5+BmceJH+1zy/BI+rgjLDkiK1H+rES1VhRjrWJwiGWFoU+nj+eKIrVGfoT2WZ+eb4hXG83i5NsHizsACtxaCgcvZWHitaYvwVFg5Gzu1BxJbg08lgMGNKsxMSUNho6JCqseGwX1e6rCVv7VkDpdcgu7t6zWIl7Y6HrngevZz9tRnjt5d+Fm5fLnJYJg5mAl/mFPvhiVO7jqn0j4TPzJyISg6NdVm4rOM/kk3mxYv2Sgu9/nO9VyF5vE6F9rrD3slpvw2PrIdfBco87ntjXleDHc8oTeKNfXMTMy2PtM+E6CtvZebTyyTuWCWP93+unGD/rBwrpGZdSy9vlvfg3L3iOz+MPP688Je1e5wXqYI8zl2Es5TymzfH38dj2ATw3x7qpkN4eGUs/+tpum2zCMZZpqBHapHO+vVyjL2MZWR8vZb9mTXm43YmPw2vw5mnOMkzGqq2HV9i+a+7d6OZm384b2SU96tqbXaZsdba9+XLfxnks8zdTtzgfjebGrH7tMe841lWmnY50MZZuqPeTtsSSR97zHxGJZ2zcy5Hfoh6xSMGRrx56izkwm9kV5e0/7/cttgp8zv4DKuhJtFJf20EhhBBCCCGEEE9DAnchhBBCCCG+EY96mvMMUTNbmQofuGVWP7cP7Hq61UNJzx6zcVTYzh5crj45fZTM57afJUTXI8IH8VmCjFV7eX7Mein/GBPOYDjaWpUf46DQCcVPNh/UqEXCHoyDxyJxEQuPwk7Vxyz6iwSP7jEvSTS+lXil4lmxd1wo3EoLks5iQ27LiBXrHj7773UMzHM+OorHR0HhSvjfZYjWHy6WHMW53rG4TmZf5jzxZLLCybk8dv9yeRt8Z0Jhtu2J4f1SjDYi/5BMHpHgHbc9oXokumZlxmOeMJltYxxmyxOLRwJurItm9K/7HOJms44H7PHxxb1d9HsVv9/6fuNjlyfujl6g6H89wbuNs2prr+0b/Md8YaAfnsie+ZAdVzw/sz6WUkqrpbxdrha61Sh9nXzCMnljB7/wXeulDMdj+w329vKOPjeyheffOK5UiMPKhflb63WrnTHvuYbG65T1jdW6PxbPfqI4f78yDifndm56ZK4ztI9k57TzpY3sezdpmM+irzOfxu4+2/S2e9we32uKVrB7jGk9H1g8vFSvplnsuBfG0h6dB4dteMA+8w3n+Xh85Z94CI+851+tFH4G+1tN5st7uO8Jva3dI3XAvhBoj0VfImS/iXm/H3m/oXmife/46uuFq7ba54VxvK+izyaFEEIIIYQQQvxMJHAXQgghhBDC4dWer7ZWHMnEYzjyELGDwvFI+N3j2AeF0epTGSG698CRrdi1EqP3PL2HhexB5tHPXEf5r9L+jUL0H7N6/NG2WwleVrZXIhWmdWKCG+9Bd2Sfpe35ocinkX8MJoCJBD22HLiP+jxf48Z9tflg3ja/Wkgkz/H84cGvQV93TKjp2jzjC9p3hG0oTPB9ZuJDY7/Z8FWnIP4N8ecG5ysC76JH9IeLJXne+yngqfHWdJHtLuiciV+c6CLhVt4vl0B0OedrtyMRORMpe3mwlZtnQXzsj03riaGt0Br3bTr0ORJSe+k80bvXLiiKZmJsJuxe1XMdNrpAvc8nSym3Vd1bX9X9Nqa022SnDhOpvSyttGHsYXWA9Y3lZfWB7cXi2fphMHueWBzrdzyv5heCsCyegN3btv5755BXbq9P9f1LRXuFxmPtsvtYJ28jxjKwCYPNs/uPtkfVazO+8TF7z9uOgRVs+JMjf3zrlnZBOJvccH/mI6MNet63OtR9/7u3+ziJ2esGkmw7UXs5vrayjQujc8E1OpqvoZEW5H2LsmfT/KhsHtjThzYhXjTPwbldNg075k9v/Dk2K7udU7J8V/N97MIsf3aM+ZO5l/Bg9rvNO+ee4muJFjfIpGW/hWS/AsjC7O8++HtTBPuiIC7MYH8L8n6/Qr+j37S81eWjxRzw9zb83esedj/Sg/yn0krR4u1CCCGEEEII8YORwF0IIYQQQgiHV3usU+ssPTmaPiJ6ILlaIcqGrYTiaJetrm4f1HmfYfZW5vL8svv2YWD24Wf24eGZlbL0rO6b4QlqnpmfJ1rJaK4iQQ07bsU0KLyxmqtC/vZttMfyYumYuKin83xn8ZltTMPytr57gh/ml9cekXDJEzNFx1ncZsRzj+qHq7GrBOK3pB+zYL0nXSRe2W58p7odYvelmm1Mt3xBgIB57t0BO4YnqPf9mP0aO6sn8C6lC1trqZd8h2ECbrvviYJZGVCk7Imhd6HrWsyNfjLhshXORsJ+K7C2aVB8juVF0bInZsfyRXHZCwA2rXe+WJFsLcVMOK5H93i3v20/B/r/X4Xvt75Sr8Kidjvsic/ZX/TJ+s7qMLLpi/nneCx/z7cetsqHvXQQxcPzkLW5J4j32hb7UCulvF/ehjx2gXUPwzpEcXUrtkX5tGOcGOAosMeqW1wclfr/1ymdtc/bby7fCPpj7W05Ok02j8ncPjvn/GvWXvrKarTacK8vzRMx/97ixD1icAmwfWgwbVyuzd70oAv8Gh864vnD5mizw/58F+duhcTDeS/GY3NHjIdzQW++yvJBsKxsvh3NLTN5RHmzbS+vrK0ove6Fv4xHvnB+9DeNzAv+TAS/+s0HfxvaFlkoc5xVvtEK7njc+w0Mf0fC36CyC0Z4v4mh+D5TxpgXPSFbkchdCCGEEEIIIX4oErgLIYQQQgjBaO39q13weOAzyCXRSuwYj3322fvkMrNh7Xgi+ehT0RGeyN3zOeODLd8jHgyvViQ7cuy7cPfzya96vhkJSrLxPZiq7F6bUTomuEFRjBXs4PasvcrVj2cffcnA0jEhExMxWQEREy9V8m8Vd/OjcUES+uOVaSW2wu0ojDqxyDsUvnXx28rWHgcFl55bKHyPRLwU77oF/s42uwB9XCHd9yHvEwpDZzujIJXF2bscF5IzMe/s5562lduqz3VMg2Vdiajt9hFxrick5iLktu3XoQyrNvV99sqFInb0CeNhWby4kfB99YLA6uWBCv9h22+p7GTNWTK0kW44zXNauYrfSZmYQB37FUuH9YZCdSZ6R1j/w3M46qPY7l68rA+sXB6eaJulneO1cnmrk4V91NlX/Z6F3ONFauzL6J+Nvx9Bv/bL6zxJ4C8H2LD94jO3lf9VBqwRfr40cL9ulooTf6j/xse5zLUQpf673xju2HKC7csEOeaxaRhmp/lUY8muAbWUVtsQNMWrlaQleWXLjfNQ65udp2XmRjauTcMu9Wwuh2Ml8wt9Qz+xzrw5tTe3RbLdgMVFP3D7iO0oH+/4WfviFPd8ge5ZeL8R2d9mWBgKxxkVz0/IM1qJnq0sj2kyv9ngb0ve70jRVwcjMfvKj3Q71+Q93pfwqn4JIYQQQgghhHg2ErgLIYQQQgjBeVmB+1nOiMJXn1RG2/iwja2yHuXH9iMfcAX01UM+tIkPJvGBY2YVLCaSx/yi9FH4akX5jI2/mmeX+Sse+M8aKC5sWfmWOc7ESJ5PdttLw0RAVujjCY6spq1BmsgXzBvzZaIZrENPWDNotogjXh1kRUhZP5kg4+Z3bY5wzM375AnjJhuFo/NR5t+1crhQkpofBYULXyJ/xrhcTDoJEO01LKi/lYB1Fq/bBs60CxsY7KnCFHk93Ip24WRupVzeLumh7sjLBkwsH6287Nnw7ER5rrCCaf/FgJyP3rFDL2WUsW5QML/y1RdmG2tWrGqPb+PPLe867l/nRm3XxkP+s9C4DcdZ+fAYlmklKLdxUDC9EsSjv2dgLzegbeZv9IICbmMfRZ9t2KVcytvlQu2Voc77sWrS7xcgf4Tx2fPyVLrjsZUg3L+0jjb3EQ0voG0b9fxzcLywMnl893Xl3Jzy0EU5TzUbdexbcT/eLqQFNq57040SbFfvYPbcQTVpv2FD2/eZHcLs5fZoPmxuZo8188/r8phfML+ktlY8697nJ95H/mDOiNqP/o5xluzvKjYMFyfI2sDfu9jiBkfwFntgCybYvywsKof1NaoXlmeGr/gJJEctVaOVEEIIIYQQQvxIJHAXQgghhBCCUevrPjg58nDqjqdTTAS+Ep33Y5iWCdAju9EK6ewTztGDwGgFdoyT+Uy2J8SPyNi/d/W0R62+9iOF8h6PrItHtM8Rf1ZxURNWyiyqzqT1xENo0xP+eAJu9OWITyyc+RH5b8Jaa1zshHlkfOM6uljgxHysRpTnaqTPdLrqt9HELCQdj3qF2iviqAh4jj5X4Frwt2pIc7zGAsg95d6ZJoFr6/EjRd5stdusYHf05xrHEza30kz+s7i0lT/lrb6V1sbVvz1R7bpusXRcZMzsROJnG3/1ogGKwaNVwzNgH12Jo7Mre3vhKJ6O/PbyGn1st+u6mYgY8brdGOcRdfjTzP/XUkutvF6isqx8jsTxng227fUf7Mde23r+4b4n1mZtyET5Uf7RywF4vF4qfIkB67MOJYfUpQx5jeWb62Qe131BfaMWtjTOaVgxnosdI9lRO461PYmT12iXRqe+9jG6lDoLxt2x/wTbecwmbl6axqN5c7LQ1YPloPMxknFUHKw+Oyfsx/o/O69DoqkIzjOZ32z+ZsO8uaT1C3052i2yc7OjU7/qbB/x5dl8dn5iYPU7Rub3Ic+mt4/H2G83+FsS+90pu2AD+0KfTRst2sAWQzgi0mfHs3XqCdkz6V5l5f6jNGkahBBCCCGEEOJHoptBIYQQQgghKO1ln6WiqCjiEWLlQ6s9LR7KsQeC7LPT+AnnVX52n33C2tr1VrliaZk/TGCfJfpENctL/EVk9UjZ0/sR/eOsDU/IY202+BfliWKfKC0KkTz/rJ9WBBWJvCLxUFTmFegPO17Njq2HjF2XMw3c6KYfm4s7e33HLhrRpicgo6w63+PwBayrLmhVN6VwZVymQ3Uh7C7WnOxvMVHs2YbtMpXlKnp9e7uUevFFtCh2p2Xcch5FsVbkvxKVczGtn98qHiuLX29+/iuhMfqGon5PuJ0RwjNbURld8XjFuWMd/lzj3GxuJnt/KsMkpYFfVjyO7c/q3HsBgdXR6iUIZnsvYdyfLJG/kX/2uC0btnHm5QyWHu2z+KWUUi+1/Gl4hOe1i7F7+tFX+/+jz9dRaPen29hjjsdmv+ttzNni1ULjWX9s78cYxcSweP2mlgrjsfXXs9OCS0sdyj9c9Jpvd66fRD+1l4zNJLG/Nel8jk8ueGHPuv+w9ltUr8WUI2HTzvM8W8XEYZdjts3y8sJx/loWf9nck3VxG4bpVuX1YHazaaN4Z+fI4ks48/tOZGO12nhkM/NlPS9P9ttS9AW/lZB+FZ6pNyaM975u6AnNj9Rn1idMM325sMd98ZO5/WkfX+2DEEIIIYQQQojPRwJ3IYQQQgghKPVpz/e/M9GqVFbczh4+rh6sMbqt6MFqtDqXt9p6tBpXtEKYt9I82vAerNryeA802Wr3aP8ezqwE9qN5Rn2sRD1ZPFGMFzcjdGKiGZaOCYSYZoylx/1Gwno8Jv5Bf5m4ySvHSjSFAiQqKiPx7XasmYvz7QI5VidZwded48QoPjya7ibm9fob1pfXZwJBoW/Qwas30nYVHG+Tg9ftWeg8yjGZUHW2sxZmMoEsk6Hvm3jECC7JSVtLLW+1lgsZ+LOrnK9WNL9FKijQjsTJ1ra1H+XhCe5Xeazyz+QVxT0Sz181ey8/E4av8m7TjgnZ5jV7L6OrPt8mL7WUqxjenDOewB/998LO1mf0wgETlXsvG3jidS8s0ye9l2OY76u+H9FKKe+XS9kvGlint7B2Pd5jjSNa93X3xG/H/v92Rfo9TTHHbZjNY0/D+jnmvYdMZRp8GsuDIaN/WJ5j5/rog9PKFSYAcBLiyHT9493sFOflZnN9un2FY29c4lV2bmCvw16ajC1vXtf/4lzHzrtM3FrNuYBxPN8wDtplc5TheIW41U9vT71oLsvCW+HlPjqPOzJfs3PbI+m+8v7wznmteA7el/nusYWia2/hguiLfdGq7V58/G3G+63H+73L2mHxIz8yv0dh2NFV8zNfX5yv4K9I+9qxSAghhBBCCCHElyGBuxBCCCGEEA6vKPQ9K3B+9GeIo1XOs3l7q3Hhcftw0xOGW2H5apUvtlqWfZgYfXaa+WVtsGOZ1dijVecjX87wLOH8X8sr102Dv/fYsUKbDtOIofCGPQVvJB7XpY1pvHxtHqsyW/uReAnFPVbwU8yxSo5hfgXS2PyYUAzHmC5K8+xG9plvd44TLRwQfEXUKFs0gkLPzwKiPVtXsYerCBOr1at37dzV0Vlcip1+9qlNW92wZ2fPeF75eK8/Ln5lIdd+xMX3vKP2Znm7XAY/MqJlJvrF1bytKBXDx3KXIRyPRWHo0xERfA9jIn2vLpiftmyeqJ4J0ldC9tTq3aSd5j7onNeTkuy6fT1f9j4yWroGbiu+mxieONwrZ+rliCH/sR1wH/3w2hNteKu2M9+8PL3tKIyB58uqbmq5foWhb8/c+kl/OWELHet/rx+bNJ4w7uMlP1/6tu2r+7iw+79vxRfCBhcRWyKvzayo3q9Kv56vLwnh+IzGgklNm8tRmnNeVBJ2K/JwLV3NRXjAOJ+hxYW5SFTcWrpjs7+T7Toej+YrQ8fYx66t/OgXsxvZxDnZat6xlaePlYWX0WsX9IP5GKXDuarnbzQnjmwfmU6tpoavfL/0Azh6L/9Kv3NZsfbR34zY70VeXWA+3m813oIF3u817At9TCzv4f22dVS0/zN4oY4rhBBCCCGEEOJTkcBdCCGEEEIISnv/ag8YZx9GZkTW97ASq2N4Nj574MgeNlq7q9XZUTCf/Yw1WzULw1je+NDSe9j52Q8uM4J68RexErIwFWMjxwqJh9ssDVVJOvs9DH1mAiLmGwqYUCBU4DimweNMFBXVjVfXznlGhXWYh1efK3EWs7tyjPk5iLwiJRjJZiU6Y+64Y9KJQbKOdVyNmVH0Ogokx5wq7HmVxOJEyrcGKf2OFYtuMY3Nz+uke5zL29suIjT2s6toM588sbqNn1nhmgmoPcE0S2/jewLs1Qrdnoh7teozE3FjXUTtmvN3LYIurZmXPG7bMNmZ+5ANL0bQfsux7eXx6gTrgQmfvTZlomi0GYnPMdxrS6+OIzAdWxk+epEhEsavBe17/D+tlff3N/oCz9i3eH9GwfgedktbxyNXAXRvx7nf7vXsh3vjRe9v80W4+48Xu2q8twLo4MWQihtRXbMxFFdeX9HrsNH50v7SyV6+qV6scDi8LmKfHNwe7VE7qFD25gVQL6kbCNPP7NwOq3+aK7QxDXMT64bNS9lcCi/P9l+zieYi0O4TVQOWF31czedYeS3RXMrr4o++7zsxNROP5VH38s/+LYL9PtNZidvZMfZ7DROXs9+CzsJ+y2H5Rr83WTL1EP3+tUp7lPA27MvRYCOEEEIIIYQQPxUJ3IUQQgghhOC8vfKjnVcj89njztFPN0crtmcehEYPUo/YydjrYRkfVoL5s3irjiF/k6j95R91fnZd35ufV6Eo0FmJbjAeinqs0MnLx8Znx5gNlh7tszriGroxHdqxPmCY55tXFs+XQXRlbGTbeXmCtOHP6IYRpUV1MYU5mU6aseji4R9Ks9UxiDGr2b797VJU7sDoTGbFaRQhI754nCvYsqtcMxt7t7x2JCu+b6WUt0stl7c3SMPFvxX+W3vC/fZWeWZxVjYjX1BsvAKF1ysigTQrFxNaZ+0yX+02isj3g/U2N/EmYHWfMzQjXt+UWsOf62rgdczb+u21afRyg1feqC5RKJ/pQ6yvZPuHJ8JfEb0kEZVv5Ucttbxd3mCMa0OcfvHgowqMi4PP+//vdjCGVQXPtq9lmq3a/SHfSZBrR+XMRdnatH13nHwM4m+3zuP+mGuq5Jg9CPuDfujNXYbsem2ZmxFvvjMnHveHpoHJUTQfwiZq5XYzCHmzuZMH62ZDfdwiYB6eX8x3azNK581/vCb0bLA00RSE2ZnOmYWfmWMef9F9o4g5Kv6OFlKIxNvsa3j3Cuy9BRLQl+zXDdnvNt7vPzbf7JcKWZx76uARwv1SHnML9gyuQ6EGIyGEEEIIIYT4iUjgLoQQQgghxDfi1R42ZcXq+JAv+/DNPviM8sLVsnAVLU/Azj5Vvfr0dLSqlvfQ9tFi8kz9HV1V/xl81or0L/+Y80g9pIRIT+BoHpHuzYvX91HQhEJuZu9oX6qwzcRKq7yYEH0psnL8rRAPhUsZmAAKj1lf8RhuM/FUGcOOiapJ3lu+bOAM4t/SpEUMVIjnO8ZXAF/ZtsJhrxG8jsfM7p2KyUO5E7w+fNFl96mN8W57XfDeSisf7++0Hj1B8GxvTrsiindE8Hu3YJyJj4xvnoAehdHz6th+GdnK5GdEO/twuv832bkJaLvIvcHSott8qJo+XOumS910o+SizsqJq5tjGCMqO9arJxbvdmxdrtphBWvfrK17XpTwVn23Ni+XWt7fLmVcGz2j4h3zHMXwR+qpkb15vLEj3Vx3e57XVePnl2eil4UmgTx6U/uIXU2KVkp9pEiuwvUsslvnzWoDrMrRT0qNVEyUPOfc6/ZupjWo5+1YG+OuGPLq+RM/omLQvG4NwOZYEZn55soXnFdFeXvHW3Asa/vZsHmi+Ovo04Aj9/DebyPe7yartNYGs+eJydkq6hjm5YFi+8xvR155MivEZ+rGs/+T2aaqQgghhBBCCCF+HBK4CyGEEEIIQdGTkwzRilSZla4wXbSq+erTzNEq7/iAdCVS92xjmVg4y8/zOcuRT1evVqOPHt5mP3+dRQ8gT+AJX+618Yw0VkhUzT88zvJgel0m8GF6O5vXEb89AVFWNITltWFefj3OSkDG0tm/kX9Y59bPVbmydrPH3DRUQTwfGqJZcagt2Cg8xnwnwSNZkpCLTpuNAH7Ook0OFqaSfyUop8myoCCUnQj9L9TDZs52gm5rF1U3E/r+tq/K7Ym2+77961G76NPBW8WaHX86W/Xx/LMi6ZVgH2F2j64074Xvq1jvQt8tDkwKNvFq2/7PqMn2eP1cYn0Cy5IV+mfK6eGJzaMV4j3RuV15nqXz/Mm+iHG0/Mz/oX+2Ut7fLoVfTG36nm4fJ0ZfvAF4Hx28Fe8H0fjWd1AFu/vXHF/HsTV73pO+3+YxdlzdfxyT/Hbj15sxClxsh7kKlBPGe59GN+OuY8/XTILdpzakCcxHczmvK9nj5BJ4/dtvXNpsZ5jX1FKaabtmw8cyTT7gfMjOxzK+e/bQ9rPx5sGfdZnU/dxfzfQ7Q9l/zziyKEG0b/OKbLLfgjx7keAchebsNw7228/RRQHYbynst5bot5ssGeH8I2it6ZQXQgghhBBCCPFySOAuhBBCCCEE5ROFVQfYdHYvhLc6e7QyFRNcs89Js89MW/Bh5OohY3TsqBg7EofjSmL9eHZVL7SXCV/5nxGvZx9OZ3jEZ8bFJ3KmrZkuzgqTMtoxmwaFQ128g3YaCUexj6ejQ2w8u+2JoLz0qOuzYq6ofDZvT2fI6mu1vfLb84ER5bcSukV6RU9Q5kb21CfZRi7QN3EQN2Hu4IeN4eRTmIjUlGGobyuCrLfNdhPOWhHmWJlG6rqHdxuLwbsOFbF33Pp2KaNA+hxb+rrv44rwbGXvZ68In/Y7OGZ952vv1ylN30Z7GG9aIXzrLnM+R1YSL6XcROw3CXEr5bpyO/YVZzK1G5mion+e6D4TlqHCf8wetpEnsl+J2VmeZ8+No2k8Ib19qeft/b206WLJLjilFFMHtj5Ggf7VDq523koXu80Deq/lMTv7gkUxadj+fBHBGp7bmV88WoUxFukvbCybwpazDX8i5j6NvjCnvBsl/9Dkz9Tk0eTlFhnnI/0Qu7xiU67meNYWzskKhDE/XGOYpl9jWqp9ouoYyonxMuVdcWZ+FoVFc6tnwNpRvAzPeiE989tCVqxuwzyxd1YUH9mwf5kv+LU/Gx/F6FnxOsuH+RStJJ/h8768V1/6N5y2HkGFEEIIIYQQQvyFSOAuhBBCCCEE5TWfm7TPfqCdIHoAFgnPmQj8kYLq6GEtfrLa5p8R00crtB9ZBT2yc2QFM7TpfdLbpn/26uqZz4F/Jq/8oPYpHG3fR9TPrFPz43UhkZcv16/N+0SbScO8NHbfagRxP6tLO1IeG24FVuhXq2N8zy+sT0+I5vmS6TNe3aHdCn8LxEMhWca/nmCojjMXxW6DORw3FBd5QkVsOjzPt2qCTaNViLOACpzDZOMa1vtq7v1ILe8fl/KH2R2ymI8dCRtXVI7ToAh+JYpmq20zG2xV6gzWf9xeiZ9ZnvM+lKPCPuCtRL7bvrXl9FbhdWKwrdJZ69DDyy3s2ld53pd6merWI/IToS9AtP1YD7Pprfg7epHA2rgeg3ZpvK9FfZadh0cF/Zn+OL4QUcql1vK2jWP7YA/rqu9/G1rh/ZWvSD/7to8bZbON8Svsowfz+NhM0D5+5lbIZ3vwN7ouRRFwvrKVF/taaNzE8CbH5i9uR5e6sOs4F2G8Bhezzy5x3ReMj77jdjQv8S67aNf66s0Z2PyQ7eO8iJUX09n82TxzxZn5NTk1TtkR4k7Orjy+iuP97sF+S4m+Cmh/a4oWXfAE9CtRPfutKLIRCfXR3wjvK4GZ32/u/Y1n+EDJi3GrPmkahBBCCCGEEOIHoptBIYQQQgghGE1zZY8zD83YQ05PMH5PPj0dfnY68oWtFM+E7plVvNhnsqNyRCL2SEh/hKOrhT3iofWKZ4vrXyXPL+UrhDAojmLiKfuXCXiifQRFYFmYcAx9jPLzBF4ovmL14IqUjAAP66ca0R/L25YnOo5lwX3PN8/3lfBuqq++YrTjp91vXQRYZ8Ej82HJLmCdEvSwOgVONgahZTPO2vCpD5HKruU2KHmdvgtPbcPPihMu/IwqZbe3r8q823yvb+VSmcB1JivIjcTf0f69omH0wYY9YhXuo+k9X8Y4SyMpdpFypUlqVy/VelvZvZThDUpykbervdc2tme0ov3ueuz8+PoFCNjr2IeilddX8VBgPezX8UgEruru+YNhmRcruMjc2GmtfLy/jw5D/eG5vW/ihaIfXLUef/Gl4di5uW1fmhjHpNHOTZK/DU1R/VSwsqeb/NvGejLOuvMGp/9vcxdzncbr0LbBLtYR2P+qP6/wru+Tu+Zg69dMqBuWfjW+2Kak5Q/8xj7izVs8O9E8w8bFPGwXaHDMuwSzsnlNy+ZdrDysDlgcIU7gCcCj319WYZn8zqzGjvEif9nvLEwI7/0mw9Jg3tFvPx7oQyS698qDtjJxo9+3Vmm9fI8e+2rqKzsnhBBCCCGEEOKpSLQjhBBCCCEEo7a3r3bhJ8Iecp5Zrco+0IxWZD/yABJ9YulsGCuLXQ0MH4qyB63WVtbHez9/zfzH/az9H7dq+mfw2c91V8IjBIVBuM90dZjOYyWEQh+sbSuSwvyYD0xMlfU1EnW59ttaOIaCLTzuibXQD6wLGzbVb53j4CE3LfoZiIrJoLIJvFmfsW3MxIaecHESytXb/1Ydiw32Udw+kEZ+Nb8vUf8zJwkKPD3a7X+j6q+WUj7eLmFaTziMq1Cz1bbPrJpuBawZITHz94yYvZP12SsjE7SzusqIxFHYMwiDiS975Y0X8LaJO28bbT9m87nq4MlEqpZdGE/zPQbrN+ylBMwH+xaLF6+cfp4jL0pELzVYWxjH8/1SL+Xj/a30lxhsTjQf6uKcx+CH16+2L4rwC1WdXtwZt+3LF4Mft5cubE/AMm3x7fVkGPLYRLXHt/18LttAn+NP51eb4hzr8tcyRnU8XKuIT4lAqIcebeE7mxM5rqXqD+czeAnDuZEXz/Nh8Me5PrP5gecvzmOidNbH1PzDCSddO6zbaK4lxA17yc6uWJ75OtxZvIUFPPG5/f0mWj0e01vbnvg9+pqd9xsUE7FHX9rDsMyK75i/5Wh4hqWYv764ZEA/MAkhhBBCCCHEj+TF71aFEEIIIYQQAy/wYPuznilFn6rGOBZ8qOkJvtmDUba9evC4EtHbvFZ5MHtf9QzvyOe2MzaynC3vX/escyUwerRdj6zQaBXXxvHiHfVtFT8jxkKhV7Z+rXjLE2qhPSZYs/l7gqwG8a14jJWB5X2EQZgWGAnFWHXeZf41u7PwyQpfV+K/6h0ocB1tQ+6eoLS6Pi6UbBmRYjOBQ5smTohQoLKwwcTSpZS3aWVolu0shD0q0l0d2+zRJnzCRAjq0gr0o/yj1cR5Nm2KZ+sORdmeOHoLd6piF4qXecLTz8dab0HjRKfdJlLbou5mpXe7urjn5z3tw+onKh+mw+Ne+13LMadd+Z55EQHxyhLaaDxdK6W8vV3MMVQP0oycPHtbkkS1x2YqXGJ4s9fDebyVuHsus22bvpGse7xGZsZj8GaKiNXlVg9eIOFCzZovmh/R46DatHlRO/2mw7jn1YE3N9rGDhJey1znLM4QVrkfmfmLvY57c68hbzP+VRInyueoj5kuium9forxva71FXxl3oJy9p69p2Uc/RKc94K+97uMtzK73bfCeOafJ3hncY8uEuDZZL8jWYF+9BvWV/5uscy7tdc9te/p4EIIIYQQQgghvjUSuAshhBBCCPGdWIkfnsxXPk9iDx29B5f24aX32WqbPnM8WomL2eh/vZXPbRxPaO99NvuIAP4RD1A/s93P5vXXPeu8p92sSOaz6sUTABUnrIOiqRVnBEWtjGOn5yMKhlCghaI2FGpFafGYd9zGY9vMXkSdNnYbkbDNK7+X9yQua2sxYVSHAW0Vf8jnSIe5iT1Jkmt13XkyVbLTxX2eS8wT2xZTP0KRL3OCKxG7yPpSS3l7r7cj+1+3/IHPVgzd8xhLw1d+D/MjdqyvWab4RwRcpp+wVbxXK3ZHPnl1xgTdke3p2PSZmB68TzSqmZjsK3GjiHYsOxOSHy0zLWMb4yzL5xz30nrpo1Xfz7bryscj1FLL2/tb4QNHH3f7+TPb33XNmN6vj2GwZuK/YUyxF4NWXNvV9hc2cs1jcUO7W0J2kbzVBa44795HzfW5v0zVxkO1mzd1QucXDbaJHe8a7bmIYz5N1qDaoT+w+Y7nspe3PW6b3qsL7AZbGqddcG6A9cXsYZppftlGXydfitM3wJ4XtprXoZ/M1soHZv8B93mn+cq8BeXoauyrL7RFvyN4v8NkfUE7bEEA/Iu/3WR8iETv7Bj7Lcn7DQoXVsiQifelv2vUfFm+AvyakRBCCCGEEEKIn4EE7kIIIYQQQhBe9cFJreXpXw2Oiv5ZD+RWK7MzsquORQ92vTBv9XX8zHamftjnszEf7wFr5Nsqz8iXI3yGoP4rbP+VZIUynVVfQrGSJ3Zifnh5oCDpSL6R3QjMy9YTs+PoCAd/rNhqJbrCvJlojeU7pK9cqMX8Rr0hE8Ux35m9CsJjVnfMFvq+Ehezem7GcEWBZo9LfHPLNFYE1xnujvhiVKfzDVpGUuFdcGeFl0OU4KKGwvjuxlAHXqVSo8azWj4+3q8Cl5tTKzH1PXTbVtx9XBRelmmWK363qH6oQZfVit1M2L9KG9mLwq9ifGfiY8Kvp9jeF1vZ58LT8FSvx5i4na3knn1ZYSj7g6bhp/stmxuavloKL9eRFy2OvjjSSilvb7W8Xy4Qab4YTquPt/HYWDx2UcCL2pjHLpjeV/fnmPFti5acPKSqchGpmrKx6+1gY7zozi+JFHMCkMsaxkG86xGby9Br8s35aY7Qltc6GO0g7zofys5NbNw52z2+18VqKaWR6xnajcr3iEsTKyvrK7T/HPTjjO1+/Cvvgx40JovHk/ltoxO9fI82znxRjq2+vsqLrejO9ldf12N5ZRY6YDairwBGRCvNH7VzlIf9fPmV44wQQgghhBBCCOEggbsQQgghhBCE//73T3s1jfv+gO65jj1CxH7mgSCuoHVWzIwPMb2Hl+xhZ/ZBLHt4uVrJiwnTs6L4aCWyTFrvQe6ZPp5pe/EFMBES4+wxPD6JcRc2mA5vlecmfoL4nhhsZYuFebZxexWf5cVsYHqMGx239mvzxWPM775aLqvTSIhHBG2tGTEd1wWOQi2v32TG+C5+27b3dNNq6/VmdCh34W0/YSWfUCjWJ9D/qB8wAagn9pv2sWKZIzbKKEody3RN1yWu/c++v1fWW612geU5m+Q8ZCX0PgoTBGfk8PxlCDg+RVl3UCbmdvO82WSicDfPVg7F53GNMox9XqZe2721sh8v14lM77etFXdiFrWxfUHini8gnBH9s/Y402/vfQmBwVbqT/nVWnm/vJm+Oo5Z3isTZejfOKB5Fxk7ge31UMfx9+rUmA+9KGA2rNwwYaZVAxOdLbt9PBviefMFV03djH94ISlQh3YCP9bN4JNNQoowhFW0gfHbGNbMzlCkujdHg7TbuQy+smt2g38I+mjnIrY7sHnNYLeN8aP5rNfdWFwWztphlRcLW12/Pbz5hJefd/wr7rXuG/bEE8n+nmDjH43LFgxgIvKVgP7IaudMwM6+fOfF7fmz33nY1/NseXAhg8yCCN0OO/YZv4/8lIUAatVoJIQQQgghhBA/EQnchRBCCCGEIPy//q//9/vH+/tXuzFQ00K9B+bnsFpJ/Rkrg2fxPkMdCcNxJfbIH2/FdvZZbUzjceYh6NHPiHtpvpMg/Tv5+ul8xaNeq43Ljk/ZNrQCqFWcVV6reJFfGRET0wU2Jy7GZ4KlrC9RGOYfiKmqTdPDmdht3hnzQ4g+cHAmqkvM0xOCbXmbyjs0TqAwEpxoDdoF1DBdnBflmRG3W0Hm4IYt+4GTfKgTPGQc2HSQtrGvIR8fH+XPLc/V6ucrUFzsibU9wfaUd4vjLG3DudGaOb4ad9CXmw/zmthc1O2uWF5IWQ5e88J2GQTtc8p9QCCTJdvtmciZ+IAi8Wyfwb5yVBjP8u/7dEVuz4/EhIMJ4TPltL7EbTbafrtcyvv7ZRiWrscxiWczGqjR2jimjnbbeJ3bHDD9yAqq6bhJsmfXQz/AJKqbn4Oh6drjTfCZcrHHxwm6iWC3e6Nk5hvd1HTD0uL01fpKJicVDjfy1+J1h1rmurNlo9dpYmPwO/DDpsM+YP3HfRvP68ZRnCjcHouuCdjmR+9TMH720nrsEvw8dF/2MqBYuxQy/TzQb7zfTXAqgUJ39AXzZe/ZMT89Ab133Msv85sVitmP2FgJ7XucnyI+fz61FGkahBBCCCGEEOJHoptBIYQQQgghCH/+++f9FZ/a3rMC5lG+8kEc+zQ1e3DLjnvi+iMrhUUPN73PZq+OMx9CvRnAVpj34tzDkZXVxA8EhU8roRPyiH6VFZFlRFhsu+exirOyae0wEVMlxyPRFhNZoajKG0uwzcz+IbHyFLUOf/bjlfeRWYl5i23sREI1Jry7GauY+GjfzFChQYYsncpnQsHJL6aI8cxGjW2Ena6a73as7en3brSH/fp4L2/1Moq/7+Doau5MkNyG8sV2M3lstg5MrbyV2iMx+z0r3t9f945Kq7812doutPWWXTVv9h0t09WDY2WIXgJ4FGzVfuZDdvX5p/hpxujWWvn18b4Fzl+c8HyIlL379ljGQNE7jWXDxWQ+Nlx34HqBbcDEy4NPHnZyHAy2ree5aM/h2sGuK6a8KWFznceZBm1YjU1qC+u4mXG+H8MbkELapFBfJuE6KxebD9UypqfXtwW1jr6xtNglPV8wfzbP6sdtXlhP0RyT1dWZcp+J/2p8d/8/ka+4r868DL8SgDObnmA9Y7Mft2LyI1+0y/wOgr8b4UIGnv8Z+6wsK/SbyiNppbTyWquQCCGEEEIIIYT4FCRwF0IIIYQQglAv0ZPtr+WADutxeX5ypishuLfSVxZcbZ2t3O49qMXPW3vH8Riziw9TV+Jyb4X5ow+nI7xV6L8reqh8Aq/tPQFPJOxhYqMMkcjZhh3tp5k0K2FTLcUVTWHctAAO4kZpmPbwjBCrlFx+yCAiQ+Gf2UGbaNuOsVgA1gaeuM2IQGf7TI1C9ld9PnXAq4sgf0/Ix/JCsSXNo95EjpmGxI7RTEgrf9qf8vH+7q5k/SiB8yOFwQ95CZBUH1t93q40TlcHN7Bj96xSnmf3kbfj1a9mJyi3SUxlabZ4j2237qkXFr1EcMZuKYUL19nYWhJlXZ3TD+Dt7a28vb3dfDGD1vYCir3Y3saBdtvfxg50ek9jz/45HoSToPmFAVAP1zomamZ7i49u4sUWJ/9z8vHYfE2oxYaTvmGvV5XbgIIHTqCjdbwON3t8P7emobnvbNsV2qCntfXsuBUKsescx/q6urTYeJgHph2a1ik789Pb9/KM5lVeN4jmbX/JvZH4fO69r37E/SwTfkd+eceOlsX7jcV+9S96kZ+lt2J2G8eLm/m63urLf6v6Ep+E2kAIIYQQQgghfiQSuAshhBBCCEH4zJXSj+Bob74l3qevPfBB5Zn8vM9QW/t921vI1D5UzayojmkzK6eh/czDXhuPifAxLoMd/2yB+KPz04PoE2TaICvoW4mTsu1jxUbZgdDTc0aiuFJ82yjQQpFaVleMvkRiqrI4xvwoZfbLis48+zatB+bDfEyfw30QM2maCWNiOJavl98m/IPEpwVr0PhDu9ThEN22+9atBumr3YCGbKXsAnZHPVitKpE5woSkNt5+4O39UuqF/3R4dEX2KZuDUDFyMv97xdjeyuorYfs99rNYoX3ft5bn+IUrv2CCcl25v4zH4IKabZNMnHY7p9jq7UP9HJwIH17h/8ycgQmIT5nx6/d9Ow/h/N+iQB3Vth/bRMTYT8a6Sd/7bH2mbBPONk3eIuVxMZNY4v9kYz+2+bgVB8deUy+TS22wFAwi8XF6Tb7Fj661pe31NhuY87BVN+QJbdswYduvpTgcsPmP7UNH+y+73nnXwAZxMP5qLsXmYGwbw9BWNC9dncvhfOOBvOK9yyv69IPwXvKPWMXN3iN7v5Gg/ezvKhk8obrn2+p3E+9Y9JtI9KW9I79HPeq3iE/9TeOFz/dX/Z1WCCGEEEIIIcRzkcBdCCGEEEIIxos+N9k0Kp/MM0TOkYg8m+6MQJ49cI1W7PJE6d4K8AwmkGf7GO6VAW2zf6ysDKxPJpL3/HhGv/DqUSuxvwBMWOgJkRBPVLxq10iYlO0Tk4iL5B+JmpjIDH1g9YK2Vnl1oRor46qOrdivmX30wyv30I519MMK6AYhWOX+b/54J3P/10j5iMCOtbP1FUWOk59M1ZftuMZfFJAO2/YiUvz290R7pUE5bWe4Gay9LGC71yU61uYMx+bynNnzvJRSPpjAHUVNxtYkKA7bL2awOympII9WRsF5dnx48LWl9vNnme0YaRDuruybbSayH9vj9vc2cdliwgSolnJdsd17K26YIDj958y1wDq5aXIrtb+Vc3H9yIqf+FcfctwlsBpOY99O7/O11vLx8UbO5ts/O8S1Mo4TNnwxkYqP2nHTZHjtOGHdjX0bGq+yODbKeD67Pm7XHGd834ZDZxzv+1vfbkOYLc1w/dnOd7AbOlrGdmrgq3ftttdYe5BeM9vsx/ZSQo/nzBfw0tH3M3MY75h3HWBzC6/+wnlLQNgejj/ZdN588V4efF06TDROP8P2D+WM8Dtjs8N+w2DxPL/Y7wN934az3xsiQXqfUjjv17lfwUMbHpF/aH/14oC3MvwRXu03jNTvZy/m84DGECGEEEIIIYT4kUjgLoQQQgghBOclH+t8llNnV0i/h8zDvyMPCDOf1WbCcjyGD3ejz1OvHrZ6D2jZqmPRCvNn8IT0Xjwm3D/zYkGG1UP2Z+QpHsRKAMSEiFFbomAJ06F2DYVY6Bv+RX9W/WoSlJWxzOgLE4bZv9G2tcfyxfxY/kwg7vluy7ASQfY4Q/7NF7x5bWhtODpEWmfM1iA0JPFpPTgJsB83829aaTjwgfk72K7QXmbbrbfBmTKIV41Z14HWI3Rx855+FteOSsZWavn4eC+t/SFZVpPKU1DtvnlC3vyq0Ytj0XUtk0f2Ghtd58tVcO6evxkWaVcrki9XlbfKMhO2rdiOb/AFb7Tdu3p93TvHkUR8+0Ce1XaY5pRjMf6cKjsZc9mK9WOSVj4+3st4/vbJ4u1fLdeXExibGHg8zv33ytQd9i/4/AWNuufV7EFQKLeyv8AytK9pp23cbPH+XrG3sDqOv3YAHsbifdJrR8hBFD6UoRRb/1DkW5rKry2QfBe6m+OkHvdNMpHBF8aGMZFddMw+dh1onnBMmq5d0F5oC/Mo5Ljnbg9rZHvFatzAMmbHFqdKH8KJ8e1hPLIcn2n7JF8lQF69IO+92L6ymV1AYCXq7nEie6sX6xMfjKF5R4J3L3+b92rV9ZUfXjlseEZk/0ge1U9fTXB/mO/uvxBCCCGEEEKIU0jgLoQQQgghBKO1l50rf4bQ97usTnVvnt4DW2+lL3vcLmiKwndcMcxbAQ3zYA9pmcic2fDyW2Ef8K5WfGe+PYKVHa+83rF7+fYPfp/JWSGi3Y9ESewYpssIiqK87TEqJjuA548VfXm+MFv2r+entW33vbQY7h1j9e7F7RFQ91hJ5IW2bsoTt72220Sexphbd0EngjINOr1aYGCEY0wRZ8WUUx2aOrGCuuncaKSfmASYB2PK15a7r/xdpupgHeLj48OIVK+2h31MSvAEwZFQeFq1HfOKzlt73Qwi1noTPGfHtkgsdsunluoLjhdpV3m4aYJYS7zlUps5VsZtL+8jK5tHfeKQgByFZ6UNgmt8GaPZzmOLNwmJwf6ZOY9XjEjEa+LUVsv729stmj3/KwxjWJ46/Kvd3mHlcQavvaCeh/H0Np61ZlxAX8hJPoyVFerRnkNmHBvMOuO5DWRfxHCpZV+B3bSJ9efMvAmbJJz7mEk/XqPHiOOhVR9Mjq+0zHjJwbmLTYfXQjYX8XxgfmCacB7jcHROyOZL93J2XioOc/R+9rPuE8+I0+9JhzZQEI4v40f5Riuf48rp3krqKEJfLTAQvZjPpjmeCN+zf4Tv/lvCvS8wPo16fH4thBBCCCGEEOLv4GVFO0IIIYQQQnwxH4OY5EX4Do9z7nnm9EjB9JFPcrOHnPgw1Xv4eWSl+CjOykdPAM/sreJ5aXGV+kjwjsdWK5kdxfoRrbD/jGecem4acKSNUZB1RjCUDV8JnY76kREfrtKjwIuJuqK0CJZhZccKywZRYDmmabT5DEK7Nh9j/kW+43bkC2tHVgaa71ihw2rDVgfaJR2b2LKMZQvHBld9CGnrGNZMWMb+0J6LxmzFGdB6OhR/zvFaaeX97a1sKxlb2D7rd0kmcbR3LvRjDxirqZj6wHlvfe7bTxUGnTGNKjF7wb6Fc8EQKM22bbv5AhdMJkgz4uJse7jxjhZxJbR1s4Fzt5Ty/vFW6jSgVtP/vYF8HGR72Zo995fOszDs75B/WFd4IYLk2fMQx/VU897K3Mz+UF2RT6Rcgw8wnk42ME2Z47HrdBfOb5NhYmgoexv7RGt+e3jzErw2srh4HHHr6kRY1FW9vFn+mevRPUMZnqLir+az7xMzL51nf/dY/VYQ5RV93Y3dt7PfBlYv09s82YICnr/R7xb4O8VXis/P/EYjdqZpjxBCCCGEEEKIH4ME7kIIIYQQQlD6E3U9QTnK6qHhI1YVO+JD9iFi5pPfbGX26GEq+sSE40d8tPG9ldAwz4jVp76jVdMi0fkj0MNf4KfVBwplkZUYmsXN5NnjP0P84ArKTDgTcHv6Rc8WirmiOJ6gDNPYuP04E8BFvli7uF+K35ZMFBj1jYSdpeC13f4PRX/Mp74fmRz8BlFmLeSC4eRrhYvbLip22mjb7k8+zpXFBMtvl0v5eH9jBnxWAk96mF2Ukukfec5mBJrlWlfW58PC9kx0Nk48ktsEopUyqtfspCdSl03u5usgFMc/W4D2TPtHhLSDpt2MDfVaP+/v76VdVfp7Ak8UPr3wwgbfMU3t+y3juLU5W5mibceMP9WGYxqiZmZjaxd703q82Zjadx606Yr9tF+QCQfm3Zrx1Rm3N59P9nvvOosm2VdHPLvTdbztYVj3OG/w5jBeXp5YHW+3h+px6grz8ru4nw8ee/aYI0RAdkX2zOrpZ34HwfirSz4Tlh/5Ipv320Um75XtSJCPZL6S98jfJB69IMCzeImXFxm1lPbndb+0KYQQQgghhBDieehmUAghhBBCCMIri2u/wTOxkM9+qJfNL1r57MiKX7hyu7dyGX6S+4ivaO8RLw0wsX52Jfejq5FlfTrzyfjv8ND4FH9buaK2XbV7JNQ644MVbGfyZzaO+JIRmjGxHfp7xJ8oLq7MjCI2q4/E8CP59rQVCsBE655tVh+b6HuRP9oZ8okEmrcd5ifWRSSgmxoX/LDbrgiykeA6/KHpur1JuD035liNV2daKeXX+7vj0+heuB+KSA9ARa8Pss3yOrJfyi58P9InD8Y5JA5vCV/sEqfexCWcbBz0sZRYDP+oeXgktv1qAt9aa+Xj47281VvEygYgSFQ9BTHE3zbrueteH6ganohtOOwKvRvEhcPDPujjaaKVaLkZI8ZWw/PCjsU9cuQfurNl0/b9UnLnHzZdraVUMvlutWwru2P+zKYXz+bXSFhkh4VjP2LXcO8aj8eG41CXnh9s3sLIXB+Ozm28tEIcIHPPy+75HyHIzorZIz/Qlo2D781FviPeC/ar/LPv5bGyZFfHF1/A9XL69tVuCCGEEEIIIYT4fCRwF0IIIYQQ4pvx7GfnryzuP0tm9S72cHP1EBbF7J5tKwLPfhI8WlHMiuTtSmtHifxnfh7J4yseBuuz39+IqH+gZg700EP42X6GaVcCL0yL6fC457Nnj4mvozysH1mBonv8piZblT0ShDOhHIvaxX+esBDjh+JDY69v2zpBXzCswkEUyA2+4AA5B22rCmNepdxEiW30dzLI8iNxJ/Fov0CY/cG37ixVII9iTk9UX1q51Ev59fG+C7ejvr8iihP1QetvRnR5lmj8sddm+sJB2YXb94xRC1qBFag39ypp/359dJRh0Rt+e2Iz+Rj9uEbZbXa/Dq9of5SjYtWvYNWfnTSXS719NQE7H+tUeGJ4F7d5s9G4fbfOYzvG7auu0zEBBtVm+uzmFg7czM7N6V60ZgoxvKSzl73a8bgWuOaYySI7tzcz7CJy2/euMTY9lmMLa/zY4Icz0NWbkVqcmwnY776wS4p3nbZhrPux+Fhmr1tZPzxbnu8snJ0O2TmRx5H5oJf2Xr563BKneOSX6Fa/O7AV1M/k4+WNX3Tz/MD91Uv3KCjH6QWz6638HvnB0mR/I4jyYGTL/x2oq3FZCCGEEEIIIYT4IiRwF0IIIYQQglFre7VP82YWAHxUPt8VT6TNHhTbB5fegqXew1b7wDV6MButHIa+MTvRqur4oJb5kFnZHT/pHa04770I4JXPI1p17dH81au6/+1YIRQTQ0UCqiPDN4qhorQZu1bTV8vaH08sjHlGwjEmsPPyQFFYK+uTZBKQ2YHDxPHKir5bHwY/SFwMY/XRBY9WkFl7mFeWPgDftkPBYJv7oRUSD2LIQuoAB9YCfaNBtLbnORg0eXqdppdnypt1imryNxU6+HHlT/tTPt7fy+XyNpv3us+q32fDmGjzHpsZWD9c+cWOn/A1O/9kAnIqKr/16xZ9jgaXWsVwPOe98df6sKj7w/Nsrx8cbOOHzu9XeWfPAdOfWi3l16/fpRT7JYA+JrBxgRgZjuMFycQPTdjjZHC3QXb8jOaemKddBT4c/025axnrAcffUvbV2fv4NvjU9rBW9uvGdh0xhXDHZ9hcXYPZXIBdO6f2aHvcaY7Sjy36c3RNxmsx7g91XsrcLmDPy4/F88ZW9IedYyyP7HXJg50LX8VX5i1O8wxxc/Q7wjPyjV7E975q563ozlZSty/+s7xxmy0SgD540xbc9vB+w8kSfenuO1Kf0ZEfyIu7J4QQQgghhBDiSUjgLoQQQgghBKO1y6s+PXlRt74UbxXzzGpg0YNItnrX6kGztzqZfTCMD4ltOhvfps+uIIa2VwJ09JvFQ1G/9Zlte6ziPKNvZ1fMFw5RmzCh1jPzzbaZJ2ximt8envX/jGiKaQ49cZanTbT7nuALw1CghvGI1nEIZ+I7r+zoK4riVr5aOzbNsm2qidNKqQ2EgG2Iyt+CKmZAsOnrot3aHuDV45S3IwC1dVzKVXBJjaIQFOP0Aa9BHaNS0XO2ldm5seN9vL3Nh71zy8O9jnoXrHmbipRXokd62LHjVUNWyJk5Z5iwsxQuUk8QCbcjixUnOahiwzfcsJtUx+dF3R8uZ2BvKVof5ivJfFHQG9hM2YryMH3uUmt5u5TSyp9rwDSW3DYG36D8rm/7gWozZYLlYSzu/QLzbJB/cIG79Z/hKwPsPLPnDis7O29a2X3Z6jPoE8N5jErNW5i9hrI8vWs0Fg7HRzbMNjiO/aLXMZ2DtNku9t3sHITv8LhelNX8a2UX5w+srrx2OQprx68mW1ci5JH3eZ99zxitnh5x5KVu9lK897U492MuJtyza497L9Kz3zy830m88kXie5ZPlme0/Sv/lrdN+b7aESGEEEIIIYQQApDAXQghhBBCCEIr5eN1nnTvVPP/X8mrPZjzVgLz4jIiETk+wM0I6Y+IufFBNj7oXfnIHj4fJSPij9JgntED7iM8S1Tw6D781wrmo3KhGO4Iq/qPhEtM8JRhJTCM8jyanyeY6oKtSRC32PdEa17cVXusxG5MLGfjZoXE1gYKFV2R4sL20P5t+EPrZ7DbQAzZSByS5xYwqXp9Ueh0fgTqGiuMtHFpP7r5Uc2BCh0kPEfauBmdF8PGVY788fFW3t4vRrsJGWXOFacPTas7W3vgayiOXo1bR8YrrzyZcq7GKu+8O0EtdauTiicMU5DZGEylxj4V03b7X/aVo7PiWXZeZtJ4IttlUltvC/uD7VZ+//6I020HzfiFkYcxxZxEcPov/cFtdk0axmNycWul2JXa93whTnT9i66bbvuYBNPYXMcKqMSwd61j189hvO/13KAdiB1vHoUvlPQNZm813tUyt210zWx2x8nj6Hl0Zm51dI55Zh56x5h7OK8sn+GPOETmi2irsNWxZ91HZn/3YELwzG8LnoCcvRy/ejHe++3AE8BH6Wx8th1xNF7263ad7/GbwRfN8YQQQgghhBBCCAcJ3IUQQgghhCBcKhEivAAoDfkqXvHB3L0+ZR60RnEC7dggwI8E65lPgq/wVm4/Ilr3hPz9eMbWUTGAF+cRQvTP6K+v9tLHp3G23PcKTLPp7xGneuk88Z8l658V7GXSZPKL7KBQ/Gh6jMPEcZgfigExXi1mgCyjWNETn0X+oijSxovqG/NMiVojVc3BpF0E2leV74LLLZ4ZmO2xTYxYSX0t5jJbPqgU8pRMpZQ/rfx+/9gG1rOrjW/2sseZkNSjosgb7AxZLISczI+VKPIe0eR2KhwbpGg7bP0dJiBwUawY7n2y5RbeapvymwTdz7ruul0zbsdw1fCTeab9weuGIxZurZWP94/yXu3P9bXUZh1nhVgMZky8bY9vh+2ElJnHvJuJ5wzcPXiaJJGTOTr3WPJtrCRjX7tF6uOqZ9i6sY0xZNykVU/q1L1Gm/xYWabtNvyZ/GyNpClzWXpYtm69eL2uWXoE64f55NlYjb+D/YMM+R80cu8c/wXvmz+dT75P+qz7R5bPvS+afyarl+ozfjEhPFshnm2v7Hk2shz92pwXL/oa3Or3oh/7G8GTUHUKIYQQQgghxM9EAnchhBBCCCHEX012ZfOscPseP/Cz3ky8Hj1UXaVFG/d8qtzmmw1/JI/MQw+WH8xKDPXo+r7nvLxHZOrpAc/aj+qlwd++3ch2ZJzlgYJvbL9IpOb50/etgC5Kb0XBRCNZSpvt1zK2A+7bfD3hakZI2IpTD22MVwoM1liGwuvYg9UdE98N4lBItF0cTPuv6mA66HR0Jo6s16xqreXX71+R4RyZc2IV5iYPIkfnNjs/WDsTfe5g36vaCBN/8/+e8W/zOzYyd/3V5AKzqSUUdC8zfD4Nz+c7+9dgi9hIv6Bg+tfl7a28v72VP+DI9fS+dTj7Asqw/K51iA1CjmKQ+dnMsT62dKH4dk0CEXjr/hWoxx5vvngOdcQE1OiTFbKjP70oq2p3htLBx17feP6jP9YQVn0tvK+x6xzb7uXzxhp2Xbf/vGs7zb/GdVfLXNcRbdrgeQ8+wP4jxg/nFNh2jpzvXzBm/XW8SB2uVld/9krqZ0XaR/zCL7vZ/BEUpXsru2Ma+7dvMz8zX9mL8sPfSPq/lQA/87vPEe4Rrb/iwhAhL/zDSSullMvr+ieEEEIIIYQQ4nlI4C6EEEIIIYTDyz3b2bQfr+bY92D1cDhawSwLe0CcXQFttVpZtPI7xvO2bT6ZleeZj0cf0h4Rzp+x9SocFR58a1b+ZwW+X0lUBiZ49rY9cVooiDNxsmK8KKzejHvCsUHAR/zw8mHHPaFdZZHNMRQPr4TCTAhn2yUUrh04ZrFlHPwiKkUUQ7K2t2VAUaU9XuHAMNA6ykgrINx8tYP54OgeQOsCRaKVFnnMvpWPt7dSL5dZu3pifKNiYK/vM2HqI9vfyw/j3DvO3ePXIu1yVX2mSvPi0Yu43azD3wwVJwFR//FEustMgmMnr8GpMt7GjXhF/UJPzV/v79emaaVc3yTpR7qqr0C5ekCf7NlzOSqkHQ+MUbvK+BahjedB92mLU8fxsJQyCNEru2C0W3aoXLSuV4w+5juciw3qpe5jYi1kwgzb03UIygzFo3XszRmicaIu4rjdjRxo8C9KOl3P8bpS9nrDvor/nsWR8fGIH1MZD6Q9y6vPh38Yq0veM3//8d4bW90XMr+8+3j2u4MVmbPfAaL8rXCd/WYQCegx3+4X2jkj/l/5fE/6e/MXz6WWKk2DEEIIIYQQQvxAdDMohBBCCCGEw6s9uNqf1b2YY38ZWd3XKr19EByttm7xVj5jq7DhyvS4qvvqQXPft357K8lnV8HHdN7xaGHYKJz5jgsqe8eezdkXIf5anlG2M6ITJmB6hHgFRbYoukNBWIFwbz8THwVaTDSJ6bNi4eKEWfvMv0HY10ZfjAZz2LdiPE80x+yjTStOtPHtfoXwoVx2YKmkfhuUz/pphaKev1ioOvy5+tTG+sU6aKYg2/Hu1y0h7ddEfGrt9gzdvlNHf0y81lr55/f7lLTWOtfXVg4SXspakM0OY3k9E88Sq2Xz947d49dKeMvC8BMy23FwbrrQoqoOd/f/onhbWCujsLnMWUzH2Fh0hNU4a8I3EfvRaxgbb9CO43crpby/v5X3t8t4fm92+3kI5xYO1s22HTphJx62XU0FD3VN2r1CwOZPhTi3Y1sW0UXtlr6CjT7uYl9u3Z4ZR4dqwPGs8mtOw3SkfJjemNztNbc6p/0pDukQQ151zt/mWQq0M/jHbE95lLmeKyTw5gRkeBjTJ/HmLdm0tP0Sdo6e42f5rHzEw3mE2B1XHGeXXCZezwjPMz4euedmvzNgHuz3DXyxnvnk3ft6vzes/PRWjLd+/dX32c+kkTndi3Bt9/b+1X4IIYQQQgghhPh8JHAXQgghhBDim9CYKEg8HPZA9OyKYvjw+Z7PaKMuDR/+eiu6RzbZZ8kzK65HAvKVH1EdHAlnx1FL9XJfYQBe3b+X48zwh8KtHnavKCsQb6biRjYyeOI1rwyRvyjc88SkkTjOq89JmEf88cRzTHw4iRnheIQn+huEmm0Idv2wkax4kuXXsAAQF4Wd2/F6FS/a4z2/QfTpdJoefxokjTDUZlyhgmop2+rLDdLeNi/lUn79+hj83kQxTNTJ6on6Pad1V8922/Ugtj9hX2X9NmnP9fvoeObFx/P39nfL98jFlcY1yjzM7yh4DntxMmFZDo6zbW84/5i1Q05vV+Ds+HG5XMo/Hx+3U9YImrt4uZpBpkIGw6SzGb+dgXkQh9e5bw/poRw9eCgfu5AQGtke6qbxvlFvfuK4a8eZwQVwsLUyryJfTF8342uv+1ZN3U8J/XbHtp7Gauev3a62/c0NiVvF5iYAr8vgtpsnM0nnM5Uf+6y57GpsyM4FLL1ev3o+/tX5/zAeJVzP5oUvz9v02ffNWP6ZFeEjwbkV3ns2M/f6LH+2ivxqpXbvJQCbZvV7yb2r8Ove/MbROepnsX3dRgghhBBCCCHET0MCdyGEEEIIIQittV9f7YP4ejIrgWdWRF/ZWa0y5j0ExxXMMg92V6uaHfGbPYSOHtRbv+9FD6Dv48vflblXJHkvB0WPp+ydtZlJ86z8snaP7K/0j0xAzE5wKrgLfEDRWig29NSAhfvOfEHBJCbo+UyCRSNKbbf0W3hXAxHXUMyHwsMaRJz8736ZuEyEuYlK6y1JKx9vb+Xt7W0fUyKR4arf9HSsT6x4lAjaE6uezL/Z9k3EPwW71m7t3MaLNSrtKvR1ah8v9AmfmKDW7kfjzrOvT45v7ssIJO5mJ9OOrC/d0rZWyq+P98QLrOzEsn3LHmftagcyO1m1kzZUa0MSO7b0vtXNVujn2yrjt8KztxHtGIhYV7a+u5sbxkrqY5nbBm32eqlwvPtErw1kTIZDe37EiWG3jf72OnUzMMFYn8Oq7hA/8nV6eYDEa3YnOn4g/zNk521sPPfA681X8dX5i8PQaWrj22y/hzHxe1akffSLYDY/7x4/+loaiuFXeUW/e9j82Ev794j777nHXf3m8yN+f3jkuP1gWmnxXE0IIYQQQgghxF+LBO5CCCGEEEJwaikv+BCLiSX+YqIFRj+rbdiDZ7u9enh7ZOUzttq5twK651f0QJ2t2h75dPThfU+zEtCLr+fL2+EeMc9XCIG+ur48zop/j5THyyOyea/YeBBOdpt1P27jonjUivzYcRtnElr2/YUoGY8N+bcxHNPUMpZlqt9WtpWEJ+PgSzWGrTizQV2hwHV7O8oYQ+Gll08/fgtvpZR/Pt7H/ENBJdp1gHqjq2dnyIqxWf/F8kAVhLaz58BQ1dW3ubLnCbBD0ba5WPc+j2/LDau3f95AOAmYsuLW2RAfA6i5SNm2yHu1X+fw1lr59eu9vF/6+dfKIBTv25NbNhA7qRVmG7XgINauJh6MH/imypCN7QtQLhdvkrxIsrlvxzLSCHgebuL7RR6ILXs/F6JxjBooUC+39rTHvPRUlA1ts8Wr4zXK62v9WKauPbwx5Mj49pXi7a/MW/w48N7ce/G972cvqXipZnmxYyuxd7RiOtpGf1g8T7CfeYnf7tsX9zHes17QXq0qb337+6kvKyJf3ToIIYQQQgghhPh7kcBdCCGEEEKIgJ/xEOt1OfJA9F68B82eoNsTh3vbaPOMXox96ts+BGarox95KJtZoS1TvuzxlS+Zld++O39TWf7qJ86Pbievrlj4I57mR+JLJuz1iI4/oy8Pesy2b0+CP8CtX0/BQrYH0TqE9/1BtO0JsMFgK3ABMX9R2MqYfCEiTwwYbNWxLtFPuxLw4BgINU2Rainln1+/yh9M6/UzVqajMLHoGTGl568Xd2jzhT3vGNbL1jWg3dE35qsXZ+inMHmJLs72LTWrKGN9Fonq3/oT2bgdm8TmvZ5Wfcob69h5nRlXWZlsOZgte8ogJt7b5a18vL+NH0/YzsNaxhddbBxmOGifYcy4ZWbHMGt3EDSDoaPL42I/a2XuB1j2Bml73D7Gttsxtx+tGodEb6Vsq9e3auoAMmGmse5omwfHrMFayvAyQl9dH8cdG27TTT5BGJ1LOG1p26eSOF4X+G7zwL9pDv4X8Rn3Rt4K4I/0wROeM/vR8Jpd0RzjsfxZGdEv9m4bfghmGt7b+JeVIfL/0Rz9DeIzf3P6HrxiodttCvDdLjRCCCGEEEIIIR7B+1c7IIQQQgghxGvzig93fjbPesiYseuJvpl2LHpInXnQzNJHAnbcjvw7gvfQO7LFHnpHD/kzrNKtNHv38gz7z/b50/mbh0tXnJY8jlgRH674HcV/VP5HQGHoIIrsYsDmCDExvrVJhNY2PBK0oi+DGK/MdbGFEREoxu8CSiboddvnZgT9GOKALcx4EHY2v4xUu3kTRW6r+kIdbvEat7ErrGe/cHsqVyutlvL+VsvH+3v57//+d0+GvpfFvivCJO6yuq6l1FJHcfSRMTZqv368BccT/oX5ZvLO2Lwdb39K+d//839uSdskCmoHJwS11vKnma7E+iI79zw/Mc7mmBN+dpz19r002bb1wlb9uF3r8vevj1tABRGxKWiF/aluGpxreNLbDhtUSLN5GqViNcfQBBuP7bhuBene2FNhYxqrWaPZ68btGjT0ZfQVx1lT35vvph6xTEMfNvmxcxKvW16fZfXK+lEpYx3Z1eWPzkmOzCO8S8AKL+4z5yhHeSVfBOVZ91vRC+HZfPGednVfuhLS27yzfq7CvZXUMS+bBl+Ij+712e8Yq99IvBfm2YIBGbG8V7/RbzBn+Ini9mr+/7W4+nR07iqEEEIIIYQQ4u9AAnchhBBCCCEYL6o6fU2vvi9HPst978NST9jOfDiyihh7wOs9HI8eItuwqAxemawt9sCb+Y5YX6MH62dFCffwDPsvOsyIM5wdG1zhm/l7VJSZEb2dFbJNx40oEHWVLN/BXxQdllFk6eXP8vLqcfLbVNIkYMSBlBhEEeR2qM31udUzDto9feN+T/FvBbRCzsk3EI92f5hAcovvqJKm1Xp7/uMuO/zx8Vb++7//W3YRKDGFbmfFhqxvEWFow/ph7RX55PmH+TL7Xjm89CwtO49sv1/5bI/XVv6v/8//twznaeQnOw5hm0ie+Z3xrYN14o0dno+eHW876xvWP0uTKbPXd1oprbTy/v5WLpebKTznWinDiy6DT+bc7uPWkN4k6Hbscc/nbgs7RytjmBWrs3NrEH53P2B8skJtdqHb6q3eDrGBAi5iQ7ubzmm3sQ6HsqNdU0b0DfPDsR/L6bh8bRd2cSxj/Vk/2HhpfRxeJnCuMRmy43KWR9o6gzfneaRd8bLgveVqNfFoxfTsl8yivDL5Y7zVS9Hey+WZF+PZyuw2vfdbAnvBH4Xy3e7qNwi2j36j8N0TzZ9h9ZvQz0IVIYQQQgghhBDi9bh8tQNCCCGEEEK8Itfn1a/3cKfWmhcP/UDOrAq+esj8qFXAvIexq1XZWdjq4Tp7AGwfPEcPtG386CE2+h49ZMZtb3U1Joa3Ph8RyyPPfmh95KWEb8/fPAZ5ZWNt+JB6cDoH0/JlTK36GhN4rWwPYkqgC0CZ4M76E/k1CBONcLDnmRWl2rxLKaXVWXDY2i72nOyCyBD9H0SaxDYKY5eOlrl8my17rTdOsJXto3ZnZWxYtkzHsf7gYLyX461eyu9/fu32Vu23CVkTcU0SVwTuJljECTODtNhe6IsXxnzAvh7lE/keicJKKbXVUmst23/V/K0QZsNN2KVephXgp3KgP6xreeeIrSe7jdpftJcdv9AW+oN4ZYr8w7Rs3KytvF3eyu+PD7/ZKlQSfaml7Meos/2ctcfJSbb1V1tR1aSv/jiPdiZXwG875mA4/rPpu0ifnkswnmH5tgntfGifkGL84o9HOH5GNON/93cqN1yPhrzbHmbTIBWMTvUYYK81tvnvnbeenR956bL3v6s5nDePOcvfNr9/ET7rvilaSX0VN/PS9r2wl9f7tpeH94K5d0+P9lCUzn5LwLQYp4czgTzzM/M7SOaF93t+s/nr7tXv4p5B8VN4eQeFEEIIIYQQQjweCdyFEEIIIYQgtNY+XvLZSS2lvqJfL8KrPJzEB9LRQ91s+ujBtFdubwU470F3xq+seL7biVaIz7yQsCpbls9Y4T3y9VX65kP4m8qCHCnbs+ohK0xDUCB6JL8j8ZgwcWUn8gvFhJ4gluWJRq2YkIkDbX7WbyybZx+dmg7BADjFaSZvI3q08TaxKaGWcl3R3XFtaAuWP/i22cR41fy7VdAQpw/6Y96ttfJ+uZT39/fRn1LWfSXZD2m06mxjIta+VDBK9jPnlLUVxffKmj1/0X+vH0R5sfRB3OGlz1U5WXtEAlPmk2friPgWx5asuDUKY33DG7OonUv555+POdEwrhmjUd/e2g4nb3WMs03eFheXZjfMydp3K9lvfZJqsu1jVB+Hpjqzx0ljD9cDM44PRWiz7e1rF328IuMclrNPYNPX3EUHnvoD3gB0vyI71p9MfqavrM6zqQ+19TX3mfPnaOwawtt47fNg4+HK/t88p/0GrF54fiaZl7SjsEfhib3Z/aMVnmfvozMCdsw/IyhH0b33e0eUnsXL3jP/VffWL0RrrbQXrtzr77RCCCGEEEIIIX4aErgLIYQQQgjBqPVyfeb2SU9Y07yaP9+flaj7UfZXZETlK/vRKuds5beMwJ49/M5wpF6jh+j3rNr+2URl/SyxxopXr8NvOcTd6/NRwWcUZxMd3uWRTySaY8JP61cpo0CNiepQ6xgJga0A0goXhwHLhFfYn3y9RQg/60H8s34P9h3nN1/RTxBZTslR/Nn9LeBzj9fmOqXlq2TTCmLRBqhE65CwtFbK74/3crlc9mqIRIeDQHU2P8SLxL4szUrsyfJHPzJEAuoI1t7MHxbH6yusrm1ftWGYX1YY6p2bWZ/Cfp7wISuKzbZHdny129mxqie5Hf/n13sppc56c/bVhnYzPpTDGaOsINqeeGzla3aOsTF88M2rTDNJ3MrTYCwBm7iieoV/g1PFH9O3MAisxq9hvHTKN/h7s8fGrSMTOWsbOwdeHzBKa3NfCKp/uR2NKf34qmj3jG2ZeMz+FJY0+urz3L+Us/cX4fDyJM4K6r374eg+NlMv0Yrl1k4kIGdCc+YvrqoevUTPxPbZ3yTYse19ojaGCSGEEEIIIYQQQqyQwF0IIYQQQgjC62os9RTwWZwRcZ+xjUSrnOO2d4zZxG18MJ4RvEd2VoKElXge81894MYV6OzfKM2KZz5cz9j+7Af7ryK0d/mOQ9y9PjOB1z3txITBK84KQa2u0BPOhQZIMBPbTaqeevvH8jB2+nEU+FJxdD9hjaAwFFWjT7f/G1YnBh+mPM1fJuLc9mspFVWpbReKDhWBYs3b/w15NCPKtWJaSDcJL0kZ8MAtq39+fYy60u6iZwPrOxJEM59sWq+ds+cqS7dKO7SlNYUXVic/lqetL6//4Dk49Z1FHlmw7VhbRnl7ea7Et6s8ozEA46XHqRNgW03lauXX+3t5u1xIOlNRzRioXoWAOLqU27hjCknruc7baGfqr3WMEwqSzWRyaBcSeTgGg0Qre52wcdg6ZMewbRN8thtsbJ36BanfzDGvf0ZjXrRvA225DimCk/Gy49uzYP3qU+eDrz45fn1e5f7imfd1R7/IZo8d8QuF4Dbc3oejD/iVNi8ObrP80f8onvd7Adpi+38Lr9L//3b0JUshhBBCCCGE+LlI4C6EEEIIIUTAyz6s+ksfDr4K2c9+ZwThq3zwAXD0sNl7KI2ryDExOIvj5WEfnEefI2f5M5t2mwnr7bZXfibOP/opdM9uRmB/howG6avGmE8XGLzqWPrlOBXzyPbJ2LpLgOccz4iCI3ue4LCUq/Bz00TawcFJEokyaVwrKgRBIxNM1rILJVHk7om6K9l2RcNt9IvR6yQSCQ+2IF8reu151br/RSE1s23i1Est//7za9ToNoiHNlYC5Abb9hiLjzZr8jjbxnwtg5h3jNdsfTeIazXJqzKw+H3/nvGVCXKz+1G+3rnY63KVjw3L5JkZa1gbeeky9ui5ysM/Pt7Lx8d7aZtwu59TcGLVrlDswW0c46x9XJ1961844StQl8b56RiL3yeN5AQZXMMGM2PilgwF2yazbfzsdknDe32JTaZwzLJthi8isWJMJvE6xOJkIrThDzWP15m+XQufwLGxjZnw0kWsrp+P5N7x7K6MxauQEV7fw6GPMTSeb+a3AnavfrQMeP+/umeNfpvw7LOX2DFvPIa2j5TrqI/fgb9VuP+S/A0dRgghhBBCCCHEYSRwF0IIIYQQ4hvRPlNk8MPxPjf+7E+SZ3zAtGylN0/Y3sOickSidGszerjPPkXuieYxvnfM89cLO8pZG9/xE+uf/mz4m9VPmrvrsZ8c5fPq6IzPm1CwFi7Cg33Mo04bPH0PY3YncSpRv0ZC2iG9UwlWWGkFkdUeIz62Mg8CKHJnftVbPBsnEv+2Mudt6xbjlXptM1wJ2upKmc3Sy9OMP9XUg+0HtzzKaOc6ntfy8fvXrmVlomdHN4v2pjqyNnDbhrF8rd2zgmkvPvYTmwfLKxLJMv+xL2IfXfm4KhfWlXsOHbANOmZ6PrMyMX/sX3s8245e3/Hi2f0ez9Z5lNct6FIv5ffHR2mbgB3L0PbIzaTc8oDMcGzr489Wtm7PTPaqSbBNymZ/h0xq2f21+XYbrecxJhvLViGt8bO0uS23Mpl6suMr6w+9bNauN45uddfttdn/Kb4Z39BeNAbV4KSI6t49Vsf6SV3L75xYsPp+BrRd4fhnz1vFl+Hdo3jibrxHfeQ9TuRLz9t7Sf3oS+FoIyqLFZyze3oUpkdlsHl59+NeXJtX9HK9TevFf2V+mqb6GzSJEEIIIYQQQogfhgTuQgghhBBCEOrtKdZ3eOAmPg+2ipp3PGvvHh9WZFZIW63EhqL0zKp6LO0qXWSfPXSPfM2A9XiPIMJb7Q7zO8PZPiI+iUfVddbOI0ReTJgZxbV/s45iHkfTuzaJ0HAlbGWCVubHIKbrg46JPolSF75iHLS1hYO4lYkoI7+byWgYz+veX6Z2BFAYa9M15pgpYG1lENBbW7WUj7dafn+8l4blZMWKRM8YH4+tBJLMZhQP8/Pqzmtrm0e232B+XtmjvCObPa617/lp8eo5iof5evteGIvT7dNzOtj3zi1razWOeOkwDM61t0st//7+KPuq7LYBogzQt1sFTNHtBAQnfWDftvm2krwtS4W0hfexqK5wbJvO+0qKXhdVAmNZLeP+9Jam42StZXtJy+v3Pe1w3FZCDeoCbwpmF4ZjR67n2bEgcy7hWLXyc+XHI2DjHZZPc9tvwyNf/D3zda5H47183Y9FXxTz7rMZ3svceJ+J98Wsjtg9+OpFeM9nzOuel/hXL6wf4aeJzj+Tl63al3VMCCGEEEIIIcSzkcBdCCGEEEIIRmvvX+0CQw/yOPfUy9m00cPkR+SdfQgePTjHh9H2AXdGhO2tSLfyo+8ze16+drU4L45Xx0fqPhIkeHmvbGV8uUc8/xlpxDfhUSKvzxCKrfKwIkUbFm1HKw8zsSDoEgcRoCcYbGZjKeqss6i0lLKt3LsSHXp+kGy2v+hTLWaQ38OaVfViOiYERkErqzsqYMUwI5y9ufXx8VZ+fXzsInebFxOaZvoOg4lxPVurerf9xdpC21HdRn2S7UfHbH6srlg5sW1smbDema/YJyJWdW7tM/E0E9J655/1GWFlZvbwGLODx7z2tP/M+VdLLb9//bpqqu25inlgG0x1WcsgtO5hNg4tpxmD7HjWzDFrqxK7Qznb7Gu349XtRNCZBt+NOrOWslVidO5vps0EdKhL5wI6TdwalNGE49cwmruzZqt7O5GP4mYvGBbSMPdc/585d/iMeYn4FB65inrmy17e/eNqP3uM5RmljwTv0TZ7gRvv4a3YHMmu1I6/B0SCfO8+P7qfx+1nEdX5M/MSQgghhBBCCCHE5yOBuxBCCCGEEIxa3q4br/k06yc8ZDu6GvdZHpk2u5J45pPcR/w6+onv1cruq9XoPFCobtOxz6hnfIkekK8E+Ece/mePn40r/kI+o/2/pI8FIsJs+gxMmJvZTgkcSXg0hkWiVSvwZgJUz6dBIJsQMDKfKtmZylGHP0M4lp35zQS8VrS/1QMR1FbIu5ZZAFpLaaWWX+9v5f39jdc19R+Oe8ewb9iw1XUL43s+ee3OfPT6RyPbpcz1f2ROYvOyZVnVaSlj/7ZhGGeFretJEO34wOzWxDG7z/qRDe/7GU2wV85sP0KfbvH/+f2rXGybNttYJW5v63s//9j52ozomomvh7I74uaGDYdhPXmfxKEd5hikC2mkjdpePtsQqTZpZBOua0P6NvoQ9cWhnz/gAt3KmPfqWuUddOsYx+PA+LPmG9HYKQQhu1I43geuXrY+soI6Ylcy9/LybOAxb9V1zAu/opYF7TMh/cruMwTq9ywEcE/bHclHXGkv+hvo7XKpFhNCCCGEEEKIH4gE7kIIIYQQQlBqK6WW+mJPvF7Lm+fy3UT8R8TlKAI/ChOQs2NeupUQH1eJY+lZGfDhP9rz6iha6c8Txlt/PDH+ox+Gv2KfXL0k8SifH1r2s33/1QbAF+wPaQIt4umCbXYS6bfBIm10hOgxV0mmCEyM6+XFhL+beLQRWyhgxYF65SLUTRexTn6QAXcFip9RMNqKI4JkIlSwi3Vl+kQrpfzz8VEu72/rNmMiZetj5AP2bSb8xviR6Jz1NQxjgljM84jQ2xNwY36YF/ptw+xfLw8vP2sPt9F39tcjKmPkkwera68tsY+tfFvlNdiu5d9//yn10k/PCvk0SAONsdkG1fM07pAK6fmxc2iKX/e4dUsMUaytPrlqcM70SaF1wpmo2nMO+yAdO4eCja57/WEaT26RV2M89o8oD+ZTBm+sY8eWiU+4EsV71JwG23ao21ebyIlXxN770UvNAQH4SsSNNjOcecHdrtDOVmrHuJ4o3cvnzD2f93W0Z62Mfs999yveg//dvO5Y/ae1j6/2QQghhBBCCCHE5yOBuxBCCCGEEC6ttBd7mhbppMTOIx7G3mMjEp2vxN5Z+57wGx+yR6upe77g58/ZqnIsXSRgZ3ZtGnyYHtXTqu6OiBky4CfXs3Ezdu/lkSvSWzJ9+DRn07/WcPw5PKvMTLTLiPqPJ05N5Y+CSLCLQlB7zBMir/azotvI3iBY7gOVEWQyoSjmi/XENKdWADsJkSsvA4plmQB31e5M4GmPTenbrEDD/Ex9tVLK7/ePXTSLIkj8m2lvr43RDisPE7AyoSuW2+aD+Q9ldvLwykP7AvGHHYv6OtZtFk+IzMrsnXuOpjoUFWM7YV6YDn3C/aivo01WVyzfWmjdt1bKr/f3feX2Wsr2wkg05lkBu628wR/TsK2fQzZz44RX1qFv3DJslddRP7eHY7f4o/Mz4dt3OHFlcYxtb3yxfg5Eak3frdH2rbKOzqFW8afxxoz1y/MzikCOTdeOT8I7R7eD4m8gew94L/d04WgVc++LY4/I64i96MtnLG50n+8J59nK83g/762a/4yV3I/wKIF99rcB0evqdSvl8morkAghhBBCCCGE+BQkcBdCCCGEEIKwPzd5recn2wO413Lr5XjEg8qjNqIVyM+kz6SLHkjbON5DchSS2wfdbHU8T4xuw6zdaNV1u492PZ+OPHg/IozPrjCfWd0vWgUPw5/9ePZZ9h8lmhcBnylMY/mgyJP584j2PHpNm8SBt8RWmMgEqDZt1BG9MlL/QDR5pD5Q4Ilmqd8moAtn2QsAzL8hjnexIn7YgzSZV/DqRKnlUlr5z+9fszA3mnahKLqUuZ7Qd+YaS2PjbYJks49xSyFtArZX/iaqbbC7En4zG0yDHAnLvXr14nl+e3VTyL6tpwj3QlrmtmNgnTRnGwXgkY4bbZRS/pRSfn28lY+Pyxhva0OiSLS2trwb9Je6h095mzDrt9d3mf89Mgrd+5cjJgOtDCutbxM1ko93LRv6iYnUV4f3fKfnvdfBgnyR6Xpxywj7fynOGGrqwLP/CI7a0bxLIE8SDLMveD0S72Xj1T2c97I2pmH3b8xmdG+L99ZeHBuG97mYP/s62tGXqbEOWF0e/erZZ0mMH9WndA+ap23X5RdF+nYhhBBCCCGE+JFI4C6EEEIIIYRHra/7/EQP6V6O6MF65qHqkQevq4fnaM9bHR3TeGHRCnBsRbhIvM1Wqlt9an4lWmDbTHjPbGNYpr28fJk9r01edmy58Qz/Xr3ML0Uk3r2XM0L1s/6cbfNDebU5/lHB+WaKDRDWFoiy7ca22nEd01E/DjqHIktPANrKLswc0t4SVVMY2g9AqBqJhqfMzX7F/PdD7ebKf37/KqXUcQy1dT0JTkm2K8E1CmNRwJzt+/0v+oMCaK9t8BjaYX6grpjF89JF9WZ9wjDct/1glW8Px36DbWDzZ36i/11A3cMju2gjqge0h8dYXMy3H7u59+v9Un59vJfWheJD3Ao+oWDcsV+NQ3bMac64x/zHMmxhzmSl2xraqO1phr7MxhuSd8+Dlad2O+CTjVd7xASnxn4njNULnSSuJo4kjJ2HK46U7VlzCPG9SfaLM4LgR83z+1TGE4Nn8l4Jt498xctL64nHWVq2arznl/fls9VLBeweNlodfnU/6/mViX8vumf8OnTpEEIIIYQQQgjxikjgLoQQQgghBOfl5srNPEnUg6fvR2b1bxv3DFYsHsVh23bfE4XjSnLeg3ZP4O354j2QZ/ajT7FHeWbrn62Ul7GfIbUqf3m+aED8ELz+huLRZ5Lpy5HQ+Ix/KJL2hLzUNhF/D4JUR1E6aDwDNdRDABF6D6ug3h4Eoe0qOm+mfJvPdlAlCuJJ5Fz3P9PAjWFm4EUhbC3l39+/dj3rIHYdsxq2sRm8/uOJm1n/9wTorNmw/zT4Z8MqhKONFSxtFBfttxaPA1gvrA5YmWweFi8vej4RW6zebb5RvU2C7ML7j2ef+RvVv7Hxp7Ty6/2t/P74uIrb3bEFK9PaquC7VRKaePac385Rp1FYmd3x/zZG8INj8GGRtWkcHEdKgTGjgcjdjENDkE3P6vzsxSPyrRwr+4oj5/d3RAJVccO73/Sohd+3MZG4twK696Jzxle8n46+8OWWgaQ9Gv/oy+9ePlFZsl8oO+rPvTwzL4nnYy6vvMiHEEIIIYQQQogfy8uJdoQQQgghhHgFaqn19VSmtdSbWkAPnV6TlZj7zOfEj+SBK71l0q5WR8eV49hnzVdC+SzMLhMZsFXoVyIEzIOFZT9Pv7KZWXHe4ytP7XuHvJcbMn86mfaIhLzPJMqPCZ1XtpgYlO17Qlu0R48RMTceR/tWaLzt31HZKCDf9LJ9sGp7nAY+oWC526tmAGxmf9CcEoV4g0HX1tsmSCbi0C54baVcLqX859fvvflYvXtCatbOXttH9lfxMyJ75p8nBEedsxVme0Jru+/F68cqHCBNN9jG823qH0Ee0TkUhTOfWBovL0/Izvxp5F9P44nemd8Yf8uvld9vH+XXx8ftVDCZ4NccbD7TWNR4uaYvQtjCOif1NiEidqYCYFyrFjXpq0mzbSfHsmlMYSeQd3KxsccJt6b6yzre+EHbvpfNm8TxYOGg+vrWPPK3hkfYilYf7+GRsPuo4Nzmt/J/9VJ05t7UE7bjau7Wp9XXydj9cre/egEAhe/f6StkK3S/muFVG7m9rGdCCCGEEEIIIZ6LBO5CCCGEEEIEvNYDMKZqEq9C5gH2I4hE15kH7NlVzFfHmWCA2Wf+omgeH6LjQ/voQb/3KfbooT/zgZXRxvXAh/9eHRy1+RXcm+93Fzz8lWTbZBLGfkKeNu97aCUYFFlcCEMRb9afVriAe5XmrgKDGLWLWSPBKRUQO4qtrR6YItczjLt1DLMCeLDdSimXt1L+8+8/pdY6WoymPKjrtW2YEYl7xWBxmcia6YqtvUB7OwnGbRwU3Tbyl9nBsMgHT+eMeOLvM+c35r+y53U9FKjjsVrWfWETiju22DGn3Vut5dfHe/n1+700HAt6RFq+PpGxedfRfmu3eKvGQ9ts0mWc3iZcZa6fzPi01Y+ppMFFmByOxsm2CYvE5auiY1uuyjIdwrE1mW+KhEL2lfhGrorvydHTAb8gdtRG5kVkJmjPvsDsDnsld28cfZEMBej2/jd6uRtfSD/yoj1L8+r3sOIHUVcTFSGEEEIIIYQQfyMSuAshhBBCCMEIHlR+HS/ljABeZWWz1UpzuCK6ly56GI/b+GCfCRBWq6RnV31nggCWxnsQb33MtlN25XsmNDizEn+U7t64X2Hv0/mRQ6X3JsfnejHkyQS4GVAAe5Yj4v6oniI7noC2lLKtiL60UxO+eiqmPngGolXGNuCCqHb7uxKjGreo77XwFaNv9kCA3Eor//7+VS4XexFyXGB12tvQ88dLz4TjLB4LjwTgnnCd7Xtx0G4kQl8J1HscTwBv06AInMHE3+w4tgkVVIM9mz8eY3hCbRS7Yxr0azUGQLu0Usrvj7fy8f5e2p92y9OKpM0AiOdCLXvYFneh2txE8aSDbOWwjRxcE+zq7Oz4VG/WJtq9hQ1t7EzMpnQkbxbtzMTNs+n1l+EEWXHiAkUnjcfNfAp3zxtetWA/lzNft/oqmKg8uj89avfIvZ/3ArN3z4r32NEK8pE4PVqlnm3bvDGdN2w+ql4x/Sv1JXGC7TL/0g2pi4wQQgghhBBC/EAkcBdCCCGEEOKbgFo58bo86+FuZmV1tiqc9Wm1QlyPmykD+9Q55hU9uGefP2e+rFbsWz1UxxXwMmXLCCFWwoaePiMaiEQMK7zV7JndrD3xSTysrh8w6Dx63PIEqisRNqa7N/+zaRwdZzq9OyCRRA0GDapOJn5YYes0+Nv4XYRqBLF2BWb0q5lMbDi6ZoXlVuGK4pitzclE5majXkr5z6/fpVwu48LVnu6UiaZZ36GCXRIXRc7dh6jNq4nHbGO+2f7TCvcHfWP7GG7/MbwyWLv4r8K29d8e9+xmxgQvzLa7p7tGn2wYa+9VeuhPf1or/3z8uorbC2E4P1sZROmtmAkJOtnLxQp5c2Tz2UykJieyJwz66rDVQT9ZWYSKkSGfyCdv39i39XageMyUnycZD1djgMeQxnHKO+em9EfyegXYiSu+ksz94yM5ex+8EreftWVfiF6tfO75YoneuXE/KBTcf+Lq8d7L6OyFcLyXtj56989MqL96ITvzksQ9/ehRfVD3sPfxHaqvtfbrq30QQgghhBBCCPH5SOAuhBBCCCEEgclFvhqtiPV8XvWhaObhciT8RvBBdmb1dLYKHW57nzKP8sU0Rz+FvhILoJ/e6ntMVB/1B09MkMV7EcGLuwJfFLjH1rfnO5XxM32NBK6fARPgruK+Eq0UuhIzi+eld4+TAdn1oxJbRhVZIWwTJhvhKRUdg4q3C1kngSdRAvc426Fm9quptwbxd1vX6m3lf37/Km+XS2kopLV5WPEztkGkrUTRaqCnnYTcaBPDPYE084mJq1keTOwa2bY2bR7MV0/UbcuexaaJNMtYHnZOsLrBOJEPuN3tYJuytKzcIFRupZT/+ed3ef+4lMbUmFu6to8Z+AJL/9qCk8foH5xLQ144kcDCmHQ0vwr73TbeBZHKr3CsRfa6v7YemF3SANiWdvV5d5JLHXX2TWfD8YbaowHEhxMXVts3j5yDr3i9HHh5B388j7438F5wzuR7RDCOxzP3Vd5Lwdl7Pk8UzgTe7L7Yu3dcvaTsCdTxn2fPq6cVR+M+4oWEe9CL3Xfy8sN1LZd6UYsJIYQQQgghxA9EAnchhBBCCCEYtb6V8vgHvvegh2/P55Xa25L91HhmBe97H/ziauh4fJVXtOpdJt9IGM4EFWy1Oy8PFoZ5etsZMu0YpfGOR+1xjwj/WbzqefbX49X7Z7VHJCjOpH1E/qeOe6rHefdxLwtYha93zEt3E2rSC4KXzhGqb2LLW+AmVCUG7erKXSDbTLxh8C+zrW0ca+Xf3x/l4+N9Kta2bYXKKATFbdD7DmA1ewJstB21O9PsIiy+zZsJ6Bv8ZbaYKJ7VXSH7rI7sPtMJdz/tNsPLE9OgrdXYFPlnj3t5RGlJ/Fov5T///C611tL+BM61m9FBcM58NufV4MvBwXpTNG4GylQocq6554ddcd6r12bytYEoxB92PYVlJXFWE8QytyuFTfymjWuZhxcR4uxDv2KHfDJjx8vyApPLH849c2vvvvJeu/f6Ed0r2ZXOPdiL1NZu9p6IvYydFdBHL1Z7L35797PZ1dRtGox/9D7waPyVb69wH4rovnTnm1TFN3FTCCGEEEIIIcQjkcBdCCGEEEIISnsr5TUfwtVXdEpQHv2pbm+Fc49HPLBFQbsnIM8K6SPBhPeQH/1B8QB7cH9U5M1Ww/PSHhH0r/I9kt6z6a0K+Aj7z0BD2DfhHkE6IyNYPcqj/WP73okzCGRBIP40pzwHbBLPCRBvDlEa7KNS+kjj1VEgy/xrJu62WYcovz/ey9vbW77LsP7qCaCj6mFFZWJulgYF8J6wG/HSe+mifZa3BV8MiPqrd2wlLF/Z8cTykUjdS4P+sONoG22i4JvlV2r5zz+/ynLd0M1mC9q7TzKgcb2XBFanHx2j+gSJGb0JyhsatkJ5CIPNOd869i0bvjyJSV1VHJMKacMT4+OQ1xMU5V85z/rSudWLTDB/MPfMraP7g7P3Fhl/jgq2o3yje0bvq2Cre9foXrD/ZaJ0PH4ETJP5oln2PtBLF/Hoe8fvKID/SZzps5/Nq/snhBBCCCGEEOI5SOAuhBBCCCEEoZb6ko/qt4d+r+jcD+SZgmL2cPvsyuH3PPC2eaJIILv6nRUYoO3MKnqr1fnsX9yOVtiz8ZkoAeOz1eOPvnQQwYQeR1YYvIdnPyzWw+hvyDME6WfxBKxH/GOi5XsYRMVGFesKZBknnNiSoKr5puLtwtVBhE0ac/MTRK1b1JVSmjCkgwmL9Wk73szmnM8/vz7KP78/do0uE4GjyNzG8QTvnq7V2kR9P8b19jOC8QbxIsG9Z4eJf1Gr7NVVJGxHEfFKeI5x7TGi4XbTR37YNNhW7C9rM9a2HqYf/Sml1Mul/M8/v66n95lxYxPwQ8fc6uwWYfKRZLbsF04H3bKuTn9zBlRc+T2ckE0bJ6m839xl1im3ZzvM60UVmDiuiB9LZs4dxfFWKM9+CesM3ovLmXxXq83jy8veNgrW8R7vTL166VYvS9t7wtXXxjAffPnZ7kcC/7M88j5V94tfy8vX/yf9LiKEEEIIIYQQ4vWQwF0IIYQQQghGrS+nEWitDRo68XWsVpz76gdvmP/Rh5Ur0QPbj1ZJ9z7HzsTuUX6RSACF96uV4p/5gkBERoTxLL6yX371OSH+Qu49V7z0mb7qxml0M29rkXl4GBShNP86H3NXf0YVSReIgkIYhdrNc7SCT2wwH91qrZX3t0v59+PXHL+7EYmnUeRcy+g+E8J72zY9iqlRZI8+FpOOHUdBOPoe+cS2LbbMjfzzfLV2vbkns+P5jelsHFZ+m36z04Y/08sMTGBf4LhXfsf3X2+X8p9f15csmo0z1RdMQqyYfcvPZIovlkznbiVi9QWsTJsPZuJK4wQdyJZvUm9G6U3jpicBTIh+ZlzESaVX7sg8HsAOljYUA0PqXRy+LnqDi/jOZMTpR7909Uyil53vWV2e2ff+efenqxeZmd+rF9LZy9SZl7m9l7BZPt79ZrYMK+5ZpV68Lp/1Yv051NGEEEIIIYQQ4icjgbsQQgghhBCEez6Z/Uxe9nnTD2PVLzIriGc58+D4WSuysVXlojxXAvaM0HyVl3euYr3Z/G0ab2V6lieu5hcJHqLVAVmaR/YZz+4jRCKfwauNu51X9evleKG+xFk4mGrno0ogsu9pJT3Tmzg36f8koC0gmI3sdJEpKJcbhllTMOAz9XftfuEASGxspmp5e6vlP//8LvXtsuvnbRY9jBXJq2ubngmdVwJo6wdzfSX8joTjiOdHt4MaVa88/fggzF7kwfZZXTNfsHzs3Ir8x/obLtROnuiTTc/qgKW59cVfHx/l968P3u23/lPn9tgmF8y+PS9vmTEhe7sVbLBReR1O5w6qVW/ObsGN1xutFysMZ5Md4o8dP7a2b8PhkEMX26Axs8smu9mtToq0oXWyL5tfeIPU13kxhP+geddnl3UlwmZ496TZ9NEq7ZiPjbO6F2YCeS8v3Mb7L+9rWpmyRPdSkRAebaxE9fb+lR3L+Gpt39P3ftI5+nN43Ru5pg4nhBBCCCGEED8WCdyFEEIIIYRgtJv05JWe79SqdYu+IfcKlz9jlfjMal2eMHu1mlxmVcDMKnPZT7kf9Ttr01vxzoN9Hh7ts9Xp72nXlZbrq8ezIwKaZ3Pm+fhX19/LwoS9L03GwZWI/GAhXcFxpFxGdxYDzpQnE5RGimZ7/OZgs2HMT7tJhLC1zXEbhPX427Ee1AfOPiG7lH9//Sof75erwAVcdUFh8yZMJvE8cbgtlifSjvKPulO2K9nyBlrmQRzudCfXPpY1K4b36sWK0NF2t4PHs/WLNm1ZPQE+8w/2W2nlcqnln18f5d2+UGH9HQy0fZM2DCQaVnEv13NkKF8d/ozHHJH4NJaQTuf17e53d2uqa+NIdfKfaE6/t+J+z8iJE+zIeCxx3EvidaefNO96dlmj+zcmID9y/3nEd+++zIvLXixe+ej5FYnr2X3aKp/MKuaesD0jrMf96KXsyLcVmZfpI3G++Hto9N7kVailXl+g+0FXBiGEEEIIIYQQHQnchRBCCCGEILTSXnuu/KrPnUTIox8GH10pzsNbvY+tLIdxcWV077PumNautocr71lBA/7LCOSj1QiZoOBou0Tl8uosSh/xyHjPFSN8r2fNP0k09XT+yutRslCTkPZEx0JhLBOXDGFtzmYbHJmy95Y0VGANGZVN8FqZKtaxz+ysqtHGx3ocLhi7sd8fv8q/v39dU1nxNRNQe3568Vx/mRoOtpltKlImNpiw3IMJxjHdygYTOjOx+Jntnn/mGB730mF5MsJ7VqbqHOvBrZSP97fyn1+/y+VyGdMy3604vfXtm3PMv8F/x4nJf++cXo01bdwM6zk70XC2md1Srj4O8VjHA0F/aNDjhS7oXnuLH0/mLPtK0fC9L2Effu/PuY9i+0wAvlqpnAmymR1v1fcV0YvLqxXlmQ27HwnwvZXjsWxRPXl+R0jQLr6eaydsrX20Jl2DEEIIIYQQQvw0dCMohBBCCCEEoZby/pqKhFf0SdzDUUEBe3jNYOKAs6xWh/NE6NmH6vafPZZZVZ4JHryH/Ji/9ZfVFfqUWZ0vW8/eCojeywM2bOXDkTwfx1r5cCT/aQXDg96Iv40XVQ22AkLTsz01oy5aRKcro+NxBopQuzjXGRhvh5Y+LjH5osifCvyvG621crlcyr+/ryLkhkJeJ6tJcNzgbygOr2PcvkL1GVH7Cms307WwHNaGJ4ZneXnHaX3YfkH8tD6x9Kk6d2zjNgq3sf4i0fzQdVr5/eu9/Hr/KH+iimFtY232tNvYUOdEDf5hx9lsN9gvhXaw8IUGVFCWuM23JMmOPOQdvb3gAeXIph/itvi8/Uzo2PzpXogXJNMbvVXEny0uXq1o3uNEfqy+tIVx7L1W9qXsKA3eO3ovR69e6PbKgveqNmyVtodn6oili+Ic8UGIFa/fd1oppUrTIIQQQgghhBA/EN0MCiGEEEIIQeFPdybR5RMfOE+2W9sfcr78wyeR5Z4V7+5Nd2SF9xUr8QAKwL3FhL3V9SIRebSqu91nIouMMN0KKTwBBcvTK2tkI/rs/CPbHsMfYfuIjaNCGQ15P51XVg3e6cdTinHkjJkmG7tYftDdMkXx0ew8dVegut0Gg7onr1d5y39+/ypvb2+hdv9qv82i675dFtuTTWPA2jk6SHlFRiE+hmfF7559V7QOtrBMw37ldYh+MZ/6X/bCAZatQTj6yHxe+dD7ddv2Siu1/M9//ikf728kcR2SDttknj5nZycekVi97UGhXZZHDW4MUmp2ksTp1BW2bT2kJwGkk7P6jBrSvhiAfoyR7kSzj89HdY48UnR65H4Q708y919Z292+dy90Rihuv/6F92DhR2zq7It3PxatAG/DcX/14nn0QvbqRXMvbyHOUF92DL76VevL3AAKIYQQQgghhPhEJHAXQgghhBCCUUthwgj2YPdZDxOjB8Kv+thJfC/u7bv24f5q1fXVyyHRZ9y91fI8YTljtcrfKp1XPk9okVn5fWXjbLwVrPxn7d6T7hVXiZM4RHw+7ERYnBwrAe8h1XHCFBMjYzwUTQ8nOXtjhYl2g8F0i1a37dZK+ffXr/LPr4/yx9pmQtlVFaBY3W2WQPCMYat8onBb91gmV9BbRt+nNvF8XDjNypYpp5tf8f3P2LZ5YF6eHSvOv9Xrn9LKx9tb+b/986v0RdevLzAwI5nzFN8IwIlPMX3Ymyx5eazeSmhj9JT95LiAxdq2z45TvWNHky9mg6jra0v0l0w5X3BS8mLufB5//0QsujdY3U/dy+qFZHuMvXR8lEjwfTRtBib6tmJ3fGk6c7+J9jAe2l2tqn6kTqPfmiLfe9pXG9bE63N9x/V1O476tBBCCCGEEEL8TCRwF0IIIYQQgvLiT07+/mf/4sl85mqAGTHF6iF/tPIdW4V9tcJfBhREMD9wxUEmaFiJ4I/wCLHHmRdzjr5E8Cibj7B3JB89NA/4SXXzrLJOdj2RZyNCVUdYPdiKBLBpp5zkJJ4nfO37DQ9apRnLA962qVOEvcpuIvlWWnl/v5T/+fd3eXsjP3MygXhmTGDiaFumSFAdCeS99w88sfoWHwXMDn21+pUAPtMlovckIgG79dsTt6/yjtJs+Ta/HQJxfT/8769f5ffvj9IudT8wlaVufc3ptHu8w5NzKBQtO77xEDCMGVnbbAJXTJmjbL0OkhhTphcJ2PjivWyQ8c1Ll40TvZ3xSRdD3ev9tTxLePzIebW9V1jNr6OPV+A9oHdv5X3Bi9llovnovjD62pYXFh2LviqG+bIyHv2KFQvP9J/MS9Zn0f3SX0x0O/HF6LIohBBCCCGEED8XCdyFEEIIIYSgXB+frFadLuWLHvC96EMn8X3IrhB4r2h59Ul4L+5K/GE/N29FC56YHsUTPYzZsceYzxkBhldumx/6yPaZ3TNkxSf3ckQ48uix894XGsSCn6QquLusTqeb7HaBLlOToMByJbRMCGBLISeEl4bEm/Smnhj9Fn8SqJa1+HoQcldSNTehMRnf//n9q/x+/zWnadNGzCBiJ+VGU6xKo2r1xO8hdewSrF6aicf0ucznWoyIm/jhicWpGBzCq41MwiPBP/MFzG39AMvV7WIfuO2/f7yV//xzfSGibRf7INPGKgDitanQTgG8Qjdi3vhE+w360M0ubFOfmB3wYQlOaFg2fQJlJ2QoyDc+fOZ1Z5issPbEY0JcWc3lMyuBd1Zz1tWq3dm0mbx6muj+Ce2we6uj9zqR31YkHpXDE9hbHzE9E9+z+znPNpaX3afife7qJeR72vsoR+6XniWcF19Pre3F751f2jkhhBBCCCGEEE9CAnchhBBCCCE49MnJazzsGYVd4vvyWQLf6Fhm5fSVzehvJN5AgUBGYI7xPYFAJCbxhN1RHTEB/MqGt6I7S3d0tUKW1tv3/MwKW3r8Z6ziLv5yzvaHb9+PDlykW7kJwc8owE5MBtKqpIP5O5rdQ3atjVaMKgziOML5Vlp5/7iU//n3n/L+drmGWZ3qNkA1EwZuTcL4RWdE/a8nYN/K1MsAeTMxMMazfk7xHWG7p8/17GSaHX1i+u++30XNUVlZ/l75V37Z+jW2WrmKtv79/bv88/GxNy2K8G15Srl1IOZwK9SxajdYnOT512zc5tRbZKuSTc9fz45XhhWQhrZh1AkH55ZBz+XVb7i+/cXyr8BbpZwdt2Gre7PVPRTec6zuYzIwEbZ3jPl8730ArnqOLwazPKP6Qp+8+6ys3/ii86pOohXeWZwzwvFH3XvdI1rX/d/fxNf+1hj+9qRrnhBCCCGEEEL8WCRwF0IIIYQQglHLu3foS1esWoqRX12IISyPbq4jIuhn5Oc9pD+yGmGEJ97AlQSPrlDIVnH3BCSRKN/6gmHsuF2FcLXiuyckuXf1xyNxzooXPkv0oOHvE7ArPWdQm+Rg4uaHwFTIZ0/kTPgTTnZPW8zya9d5UGut/P71Uf7zz+9yudTyZxII190Osx8Vg+mVNyE1Dv6BnSgvbKpIB4zidy8O6woekeididnxeEaQ74X1cCtSt6J3T/COZb+l78G/P97Lf37/U+qlmrkyE3E1x69bppUVzgZhgReNNpVl0VC0/F6F4ObRAdmW4Wxak7yR8KyNb8eRNzPu4TvX0ffj7IueR+en3ovCq1XLI3tZAby34jnzzwvLvAC9sufZ9O75MiJ1T+jObHltdkRMj/E8YfwRgX3k0728gg9CRP2wlVZq1esUQgghhBBCCPETkcBdCCGEEEIIjvvgJLNS9Feh5z3iq/E+z45x+rEsKEBnx72waNU/5hPzbyUOwXiR6D4r7MBjzEZmBcjIZibfo2RWlL+XRwrwxQGaJ/58dD59405R9nflVB2TumIrnZfmVOfqzRgnSVtFwiyiAe/ogTYfs2NuLeU///wu//76XerFU9B1O7FrQ5buMaOoHvStnlLOORTpiiORN2qjPaE5CtKzwni0xYiOoe9ufbfhzxBs6zfBx/tb+Z9/f5ePj7ebuYzA2hOz171jhWTfIGACexYPg9lbFidpNz86dSXMvmNMHkyfHNPZ+cAz+GLOvBTwaF6lLv4eHrE6+ZljZ/PP5rcSmEf3HN6Lvt7q62zbu79jq7l7fmH+aN87FuXPymfDWF2s7r1WX/Ly0q042jce8SKGEI8kNQaWUv78+fNRSpOuQQghhBBCCCF+GLoRFEIIIYQQglC5Kuzr6Q95v9YL8cNgguzs59RXYnZPmI6CciaIwNXPPWGBl0ckJogEEn07EpZbofsqP7QXCSS8tFE5ztrwyrjy74iA38t7Rbb/ie9Og7+vyBnB9jPyZCexjQ/HpxMTVc8JDgiN9yw8VZ0j9t0E6Ea8SlfRthOk/Xhrrby91fLvP7/K2xv8DGrFtn070qWiOHslYB9AET0R1Vubk0i+zHXdFuGreNgtmD54VbSMYL3HYcJ6u79t85cWXNtO8O9fv8qvj/dyXdnfOWdoenLRH4yvVPyr40HQ6vZjO4dYpUdjEWv8weht03urAuOuOg5hM93r6M4BckqOvr+CwPsVfBCP4uj8vOOJmrtNduzoy8BHX/z0VkRf+RnZ6fsrMXePz8rMVlNf+Z1ZCX1VPi989XIzu2dlRPeUEY+Odza++El8zXUrN9bVUtpLvc0mhBBCCCGEEOKTkMBdCCGEEEKIgIxA9NNXDdbjHPHJeKvzeRwRRqwEHNEKg57oYZWnF9/Lk60+aMX1GbwVC4+AQv6M+OXoyn/ZFR0fucL7qr/cu+Lld+ZvL99LcbpPP6mRQn+iPNkxHMTL4zqXa2alds4YQmGtEddS88Hg1Er55/fv8u+/v8vb26U0FMNGwnZ0cdMwdz/qrNe19vqq2Fb73GC/lDl/9KlBuJsf2Wf2LVQsfPsbvE+wtlOmpuOr3JO0zO9IQFj+lFpq+fXxq/zn39/lfXihwRFtNwg7fd55RG8M9MmAo6pkyT2fat/2+3/oViaPyUCiY7kvEDzgZiZzzn453lj1SXmLjUdc8u6d/3o84qtER+6B8B4i+kpW5l4j8h/toujdu5fyXmRFe0xYb/et/dW9jmeLxbW+RC9ZY/zPQl+1En8f1xNIX6wUQgghhBBCiJ+JBO5CCCGEEEIsOLIK8tP5FmIO8V155PNCJjRAItE7EwrYldGZICEromfntLcCoSekYGlwtXbPXwZb9TwScdiwsytKIivB/qOEG5kXC47EP9tvj66S/xXXAT3D/0Qe2b4ZQfGK02kzCxuujh/JvMLflQ0j+KQnFQhnPb1+wzyb+cPzbu1PqbWUf37/Kv/+/qfU+lZaa+NC98wNln8pV2FyJPjuNpr5y+zY+J72l/ljxeKe/97xUswgSmxtx43QeiVe93C7iGlfK3q3YSy/MsZttz71++NX+c9/fpeP93p7h8NTdbPGKN0YcdTxwT1ohfIZZXmbN2kdsDcN7K5XLs9Pj8zbC1NnOZjNZ9zQvMgN04u48ZM5+0LqZ8BE188kmmuz+wtMk1nJnb2Ey+5pvFXcI8E8u1/CF4CjVeCPzquj+f/RleA/k5f57Up8T172/lMdWwghhBBCCCF+KhK4CyGEEEIIwbmuhXinoPPhDxdf9mGT+BvIrKx9xk7Gnic+8ITxWYEGyyMqp7e631mbqxUR2b4V4DMxPgrnj64oeXZcOirSfxSRv/cIg468vPSsVTvFX8rDrv11+LOM52X+tL67UiM7TFFB1O7mlTG8Vlu31srlUsp//vko//7zT7lcLuXPVhQjlI8E1hgYCvGLM9jYgb+MVem9L+AJ4JmdJUaIXcvYDHZnEr+T8trmayS8FO7X8n2M5sbr18LfHx/lf/79XT4+3scXFjxbp0/QVcWTrKY4WWG5V4krorcy6rjr4h1cdb6sL/fgdlhhOVwt37ceM/O4I+L2R8z1snNLJgLP2MyW+cz8ma3ujvmu7DIROtpfzau9l1gzaZlPNm/mF4uL4fcK5bOs6lCIn8ntmq9zQQghhBBCCCF+JBK4CyGEEEIIQWnvmVhHPgeeyjUrtrwvG/GCvKKA9p7+nF2prxMJyFEYEdmI8rGr/3mruWe22erqaIuJIDBfxBNesPRZEQw7lqm/Z+KJ+70XGzJ95uy5c8859xmrI2oFxp9OG/4s43n7U3o86c4KRVuQzDvAwo929JUYPmJP01opl1rKv78/yv/8+l0ul8tJ6bM3SK3igOB4iuK8rNDj4j9MsugWW1jmvYDBh6CvMGG+LRvWCeY91QOI7I0Pvz4+yn/++V3e399uK7ZHjgQX3ylasztJoopfhXvHsVG94zZ9lMcjLij32jiiSl3lv/LlxSbVn8nhZvq+k41Hf33qkXZWc2qcx2a/cMRE52x/NX9m9wTsPmUlRM++MOqJ5SOfPbu4UrtXJyvfI4G/l9/Kb0+cf+RFi6hdz/CKvzOI1+Paz9qLXhJuc5yX9E0IIYQQQgghxLORwF0IIYQQQgjOKK8JHiQj96zulVkhuV70dPJv5DOExWd49MPwSKiA2/az855fnug7IwCPBOWeUKH7w4QCq5UNMyseokjeqxfPnidgt7YyfpxdRTKzWv13WZVwdT5+ht+vWjfiq8h0CEfYy+INffzkBchNFol8jwp9MWwl9A2ONR73crkK3f/z+7qi+5aLjb7QqLuC8pV7XVS9pW9z5l3YbrXOrEpQE3303YU2bfh+Yzq3aSNlvXMI/N508rWWj4+38j///C4f75fS6i1i6xXk+diGPzkGRf2RhCfir/L3jp99OeUzWJ3HJ5KXUvaTYWXvlSbVr9pG4iyZ+e8jRMWeWNrDm8NHL5Ou5uk2PCOIxzxZvtG9hmeLCdq9exv2krVn28NbPZ7B7g2zfeQMZ1aQf8XfGcRr8Wr3ndOLi5XM9YQQQgghhBBC/AgkcBdCCCGEEIKyP93JPPSNHppGotKzDxr1WEd8Fl/9MJyJCbJi7VJ8oUFmFXFmJyMOx23m75EVDzEdhtt/kW/oV0S4QG+wumK0cj6L/+gVCu9lJYKRQER8DvcoTDyVNYu3Eomiku20U44BK85lPmQzvFfkWncB9aWUf//5KP/593f59Xa5+tDfBWC6+ozbrRGxtRnUu04ZVepT8ZsTPh6ewlaiddsEFQPJ7pGXGurt/2hXq7tdrJ9Nj37deL9cyr+/f5X//Pu7fHy8myJ5fbg5fkb9AV/6wHSZxo76c8TZkyt4UeBLOfDSyeE4ifKmqvMZSr4jJ6f4zuD9RXbV9h5nFY5za2/+n5nT4z0H5hPNdz2fmIA8Kpf1N5prY7kjQTnzPSMyzywowNLicc+njG3PvyzZdFq5XRzGmz59ARXmhnUOFEIIIYQQQgjxQ3j/ageEEEIIIYR4de5dhR1XNss+jHbpD4fvMCHEI7BiCRRfZAThLJ0lErF7QhJmD8+9lSDbrsLHVgnEcls/Ml978FacZ3Y9orheeDQGYdnOrhR5RDiC20fr4Bkc8b1z95gubmhVvhFWH4+sn6i++zEjuK5nFC+Yx5nyPLpfeCpws3fb/fX7V/lVSvnf//4p/+d//1v++9//3cU1k3DcEaW79Vb3otVStpXlbdjkYh2S76r8kmvObggnkVETYXjYHEawPsWxFxkT19Gnt9ZKLbX8+vhVPt4upV4upZRmrjcZp5cOcx8Pcc85GlTAK2LdXb6hd/YYyesw2ZcMnlHn36Ad/2LOzsfuncd581qWTxQnmh+zuN7L86vfIqJ7NHZ/g3lG4n7mf+Q7u2fDl4ExPLLnhUd5ItHxe19yfcZLskdemH41vrPvfzfzRPQR97tHbHhxa61vuvUWQgghhBBCiJ+HBO5CCCGEEEIkWAkvVw+z8YG1FdDmfeiJ8mmEeCZftRL3SsjgiRgicfLK/8xqi15+nrjCG1Myq8ijSIXFQ7+YSCRKb32MBPFsTPPSrAQvnk9H7JyN+7fx/couhcvOSrC7inNvHpvq2uS3gApSyeB3iJSqOsG59O3m8/vlUt5/Xcqf8l7+93//T/k//+e/fR3J4f8Hl/tOF3MP4dXE7XVjwlbu2mrxjmHYJqJf1AN2r0q2tzDSP6x5jIdif7x+3v6+vV3Kr7f38vb2VsptDffW/sR+Px2v7jD82YL6TDYZH06cE7b/PHu4vmsS2R7k373jjngG0dzm7Jzn6MuLZ1/EPBo/K4hnc3KMFwnfM35kX9hfidCjl4hX92NeXGYH73mOvHQc+b8KO3L8aDyPZwryn82r+/djcX5nuZcjNljcP62VWsrlW93eCiGEEEIIIYR4CBK4CyGEEEIIQagg2Mk8jGEPV1na86LDXfzU9FRH/CUcebC9Eil44o3MKoFR+ErsvhKBR/ueIIMJPbxVEjG+Jz5hIncU369EMh6RaIb5wdJkYGIWPJ55WeCRRGV9BGdtfi9xewaJDa8cEJ3fnc/tb0WBdhB9Y1JDP8CXR6U/5lO7xa2llF8fH+XX+8dtVff/U/63XXXb/fgMDo4m6227zscierxsEawLti3ZuxKo1Wb5eeJ2179+UZrroo/pl1rLx/tV2F4ut+jTBcimjwpRSLzI0QwZ+zd7T1uSNisw9+oteLsgxb3pA15yeH85h0R53tzGmz/7qwjn7Z2J582VM/c6bM6N29H9gQ1j9wfsL/rBwOORuHxVhuh+gL1Y7OWXFbazeKu02cuARN7ipXjZ+8fbL7Qv658QQgghhBBCiGcigbsQQgghhBAzb620j74TrbRsyT6cPrJamo2/aZL0UEd8A46Ko+95uG8FC5GwA1mJRKL8skJqHDtQJHFUMIHjgifssGJ59C/KMyviuWcFNq+OmUg/my8r8xkyPnhpIv/u4ZlC9WcI8p+HFEA7R+vipHp008W2hQnvYB+oHuzX3ZzPs49d72+X8v72Tym1lf/975/yv//9b/nvf/+3tHYx0zQr8jdZT8W+BTYS55Q2+ZawjruH7YTvJ3gDR5uF7BijllJaK2/1Ut7e38r7+1u53AbeTTuPDm8XDnToyBsBxNdDkJc2BtOgvDzVv6M0XniU5tYPXl1Beco97+WGxXika4lYsJrfR4JqGycjXo/mYKv7De9FVu+vzZvdT0TlXb1Ii0LyzP0K4r3Ua/ON7iG8sEikznxe2V2l+S6c8f+7l1kkuePe8Fn3lrWWcl2+/fJ440IIIYQQQgghXh4J3IUQQgghhOBsT06Orr5270OdWKj5bZSI4ptz7wPsI2mz4gFPPLGyh+cmHmeC82hVQc8fzOOo6NlbWTFDpj6Y0BzzXcFWRcysLrlqE2YnsnfkeIQnHPps0fdXCc2/j7j9EXyVmPoVOFnuKdlKKGyPZ/L84vaYimMDYtFwqze1XCvl7XIp72+X0srv8ue//y3/++dP+e///m9prZQ/5TahJFp3bt6K3RuIvY8UDPJo86GxqOgc+ugc36qpHzeC6u3NzFJabaW2Wi5vl/J+eStvb5dyueyi9tYGY2WsnOyEJOqfkeg5Ixx3fAvdOtO/I1/P5NPOueHiifu/gqMvAjh9+It5Ta8eSzTH+V4v2nG8Obgnco9E6hgnKwpfzbvRrndP5OWxEr6zF2mZ4H/lk5d3JPbPlIG9cIz5HIXd23wn8fcjyiz+QoLz8P/P3r92O44jWdogoOMekZFReansrOrut9fMmv//p2bW9LumqjpvEZFxdz/CfJCgYzRuu4CkJOpoP7E8jkQCBgNIgiRsA8pgTeoZ7efnE3hOzzP10W8YhBBCCCGEEEIWQYE7IYQQQgghmLmsyxBxRuLcsCAjWKu9aaWU2gVVDOw8FfcImO8lgJ0RD0S+ZoQ1mVX70CqHSOyu83srOlqCcf3Z24/K0qtDemJ8vd2qsxawWH0iWulR+2BN5MmI2XX59+4Otyj/3nV4TLYUgd6i/HuxkZ8XEbNn897tMVJX0DFOsnp11aLhehLelGN5eTmUl5dDKR8/lGNr5fX1WD5/fi3H1sqxvJbaSqlFrz5Zg89nCeySU16aQNtLUeJ2S25r7G/z/a2dHW2lHA4v5eWllJeXj+XDoWc/tRe+dxvtDT/rPIHQG9rXedBMBKvca7GmrMFrwE0bHYvMpAF0Am7h21Lu3UfNuc/t/7b3L+8ZZw/PP3Mh5XS/JVTPYInZLXveJNHMZProXQL5F/kyKirX70dW/siWtqHfL6x3m8iH7Dtu9P60hUiekP2hn4e3YbQPNdPyOiOEEEIIIYSQp4QCd0IIIYQQQlzaLKgcMRr8TqdvrbR3v8YfQVwzYL7H1eY8nzwxA7LT93ti9UiwnhXAZ7YjsXeEJ0jR3z2/9T4klJd+WiKbTJ8lxedImLJEaDLaF2d83tIWuTX37ri2KP/aIkMtNL13myG29GukrpEyLXOhz4XVrb35cKi1HD6cVnevtZTjayufj8fy+fW1tOPxLKOupZRjaeVw0rDP3PZUhChp78CRHUO0NEmvBd7aXhVe9afSWtp5y+FwKC+HWj4cPp6E/j1HrW9tc2kjSzyNjp93TJ2HgMlx9Y7pyPHOANpR76+tlHara3QyoyGZx0oXKVy9CQQjLG0P2fa36l/vw/Jnkrzf93juWVrmFiL0/t16b7DKy0ykjXxDgmwkUo+e37166H3oedwS2Mu81nM8ag/rXQS9s1hlo33We95W4vORdz/EHt+xCYmoh1bqYXqxof6oMzo2MMqb/bMBPUeUEEIIIYQQQshTQIE7IYQQQgghgFrqm9zECOB4KxlrRoWis31V/qG68j1z62D4HgPvo4LnKA0Sri8RLUQrOiKh/IifVl60CqPOawlsvIA0SoNWJ9RCFgu9sqJnO/IVCV2WBsaXBOEztrKgdiXPQiSAvHYHvKV9WRdP+AoV1E6eUcHwVukiMja0iHbaRrO+/FDLx8NL+eLjh/O20wrvx/ZaXl9P34+1lNKO5e2JT3ZgskzlYhX7pFtKmH7Z0By7ehX59iZov2yth1LLoby81HKoh/LhpZRaX4T2+S1t6w2QBomTdWUTAvhZmd65mUm79Lwy8jW9b4trwWqnDepzMSfPlWsR+ZZpgz32r9uK4m/xPHHLZxY0IXKEbHpP2K2fe7t4Onoujd4R0Hfkj/VsjPz33mksPyJRviWeR/tlmkxbeD6i8qL3nUy9l5CZ4KCPAWKP79iExNRi3eNHxjO9fB5oQn7ncKjl9fMr36cJIYQQQggh5AmhwJ0QQgghhBCXqRDBC6RsuUowTn+O8NT18ojWWqmMCu2SRw+GZwQFo6KDtSIFbcMSUFiCBm8/KisjdrDE3JbwHgletC1vFUavztr/qNxRIqGI165bB7CXTEZawtLJUHuDAoK1jHRc2wof50QC4QyRsHitiN0ja+PWN1ElUJ40kRKVn3dK8ffLy6G8lEP54uM55bGW13YsrbXS2rEcj6Ucj8dS6vlvKXIK5nnl9JPduRheIK/js7h9KkGf5m+lnUXsJ0HR4VBLLbXUQy2HUkp9eSm1tckC5GkhOzz90Plpnaco7dJrrYFtppMDbHFNZOrvpd34WmiyHO/4LOXafeAeeO/1W8eWz0uj7+UZgbn3nC3TeJM8tY8ZfzM+ZsrwfPdWQPfeb6IJrH2CgAeygXzJpNH21rxDah8Jee+MnudWn7Xm/dHO18rLy4fy008/v3x+fX354kBpAyGEEEIIIYQ8E3wLJIQQQgghRNFaO7TSPqDYChKjeqLQLUXvJ1HU8mg/Re3kFmRXKx8RHETijEgcjVYA7Hmz5UR+eUJ1S1zviUk89KqNWeEJKlf7LsvwsATrUVlW35j5nAmWR31yRGYiwBI792KtQD2f9xmEidfmlu23tCwkat3jcVc+bnJ6IgF0mRt2hduWmLqcn+9aKbWVl1rPz2svpZxXgq/1LGtvx9LOEvd2bKW0Uo7ttZxWWVerxuvi61TnfuiTJuuh1FrPK2W+ydwv94XLNmG/dfveBAej4VuUZuRgeWmNYwTT6WOzxXl9y37xPZSz1XEnJP/8MvIu4gnwrfeNvgLx6KTRJj5YwvVIfI/wJp1aYnRLPI7SZsZAkC/ee1JPNyK+1XYjkC/ZMu7NViJ+QrZ6f106oVyPSejPtZZybOWlHY+HbTwlhBBCCCGEEPIoUOBOCCGEEELInK4qKqXMAzBW8NNaDQ7lXx48OimKsjp3KWqX4nYK3ck1yQTal6wQFokuPDG754Mn1LDSa7GH/puZCONh9R3SX+QLsiN9QmVof7zV2Pr+USENClBbYpalK1Rqv0bqE/m/pN8eEduvFaJb3K6r30ZZc612IKXYYtvsdkvEfGeg+0mh9VAhlj1PRG2VGadtSp3+9v0kNq+llHroneXHUkortZ1XdK/a5zb1U4neS6kXgbys25uYvQGPM+dDos3dQ5O8UYblR8cfnedbsNSWFNlHvo+e22iixlI/I/+eaeLTM9V1Hd4z8TXv/9YztefXlujncfQOUlW3Xc+dvX7/8J5rrWd0/Xwtn20tMelSobf3bmHZR/tH388yfkfvk0vE4vcWmFPcTm7B2jFN7x2/o/dP+8nTfbbW0mqtPOsJIYQQQggh5MngTGdCCCGEEEIAE+mSEpOiwLFcVcxdjS0IBPmrk9VSZyIrz9ZjrNjeGJXdNSOnUFaIsISMzUwaS1xs7fPKkUFYb4KLzKPF0npVQkv0gwT1/bMuX/dTWsCCkHmkP7pP8gTkOh0Sr1jCdlRnD0+cYrUV8jtzzLPpUL5rpCWjeI37yA0/6ntWbO0JtndIxs1FVdHta4mlpRD5mszLuKzk3k4rqx/PEvVTv93EvzL9LLy+7EtPYBisZ5Q8M7tqZmz0YUOnQ/mUbbhvhD4NYUm+EcH96MmdaQuEVZeVExxC+4/Cg/SXO8B6jhydCDqaDj1v639eGfpZFz1rWu8YyEf0nI5soXcOWR9UR+1f1LbW+xtqIy2O1+9CeqzDqscaovcvnU4yIpbXZWXzEPLwgJNaXwOjEzsy7/1WX9knefZnXkIIIYQQQgghzwcF7oQQQgghhAAsqRISomZXIvLSoHLk3+7VkFSkVgaAyE255+m2hWBiRGeng7rW6oUoGIxseb6MTIyxBDjIRrSCYeSnJX7Xk36QHS2it8qw8qJ8UaDdOkYRUX0y+TsUsvusa5+MANMSLe+NTENYwvS17LVNIrz6e3WyhMiWyFgK3Ve2+dAJr4XPBXxf7IixLWoXy5bIN+RiVsxtpVsqKI9sL2nnPoVgxIelZd2CLds8tu9N9n1s9uf/Vs/uI89f92TJ5Er0Lu+931uTOa0Jp97zdUbALZ9TUXmWnTWibav+uu5SCI/qpOsgy0eTgrWPqM7ZOlh1suwRQk5E79Qj79ho7EL3IZ0NnrwJIYQQQgghhDwoFLgTQgghhBACmEhNAhFoVjiaKletImeucrfMPOTeIvhHWGX+mXmUwP7alR61gEIKMjICdIm3WiESnlu2squLW+XKbbMAsaqbXtFSf5f+eX2iXtFRlo1WztQ2IjG/9t9abVLbslaEy+CdB9J3Lz+5BZlO4EE6tEUrgqO6ZW3s6SRd6sstjq0WIkuxu9X+KxSE08SBT1sfQ12/rP0RYTfIGuLVd+k5sLTtrn3d7F3Ktb1vsaj3Ufpwi/35v9UzyuhK2kvsjTzL+SsBb0dmAqTnI3o+lvv7Nv3egCZfWkJ7rxzkPxLOI8E5epeJ3omWCmE9G1vh2X+U92FC1tDEI1w0Bir/yn3epJP+3Zvsoj/Pytn1cxEhhBBCCCGEkGtBgTshhBBCCCGYJv9oUSYKkFtBnS25BInLNsL0e4vbCbknSGBtiUhQ+sietJFJi8Tk3n6ZRgpIvJUS1wpLPMGR/hv1lR3LVwu9AnyWSAS1tDuM8t+qm2Vv/t7Y4ohmbeh06GK5lQg48nnNA5Ylil7aTpn0t7oy9aSITDv1NJGPqB7a/pbnh2erqb9rWXOMlkwA6OjJEnK7PC56354YbTvb/5FngPuyewd3y15eOa2JjxmhvBZyR5MbtcBci0KtyZNoAqr+bIlBM37JtCOTSq1JpMg/5I8nqkflRf5b20f7kT30O3vwgZBSSil1/KnI64+syfQRuu+r5/svF8cghBBCCCGEkOeEAndCCCGEEELm1FbKoYtMdDC3FBxgjoLL2cC+m28SPPKDO621MA0DROSZGRVURdewFshn0na8lcYjIhGMJzhBgpVuM9PnWcIcXba1WvsoS0XklijeW/lyhGyw/posLf5eorO9iN0IAh2ctSLgrVhj71onnRQ6e2zRSWgbUtje1PYo/7CECZSVFclHvqy1tRbwMJ8G+evZsfbV4ovGR8Tut7whZcuyj+u97585+vEho6yZXDkhOE9Gni2tCZjahk6HnoGjVcq9Xy2S+VFeXa7lu+Wn9d3a1n3wJvVbRBN1R8ZCshMQsuWs+RWBW/RPfCYme6Cf6lGfNDJ5H6W3Jg65K7pfvvNiIYQQQgghhJBnhAJ3QgghhBBC5hxKKR/RakP9OxKza8GoRgeIs0HfSXBHRPaj1dez4vWlIneu/k4eEW8Fcv15rd3MyobZ1QylDSSoQXWwxC2W0MbquzxRueezFst7ZXs2vRXSR8QnS9o6QyQCWCuM2XIiAGLEvy27/ccQNL5H3lvDT1QvyfRry7OILpCM6DzaHk0+iOrn+VjVZySmb2rf2gkHGVE+8m8r9A1paXnad0/0bonYt3yuvuUz+l7eB67dt+2lnm8svSdnJwuOCMYzEw3R5xFb1UiTEURHz2eZCY/6OdISmevn3lExp/Vcr+2hCaoS9Gyv/dO+RBNus5N9Ub0ivPcQr9zR1aBH9mX2E/Lo9HG9t1P97aJC/dmSX0mw+uTs9Xvps0o5tEZdAyGEEEIIIYQ8G3wRJIQQQgghxKAHerSw3Qrs6FXOIsEryq+DznOfpP168TMSm19DjM7V34lkVMBwLzITSSwyqwdmxPJIaB0JteUEmp7OWiESCV70Z+2HJdpBNq366HrrYLbXJ8oyvDqjPtYTvuh9uv2s1SYtoVBE9tz2yllq08pDUTqZok+IRz+olljYS78Vo+J6C0sMvcTXbJ6MeN6yNdrmVnmj6TNljpbTBftNfNf7tmJLe1Rcztm2TfYsakXvmtmJ0yifft5C6SK8tEvEkNI/+VfjTaCUabx9Mr98fvbaJRLBR/5HAnzr2Tc7kVKnz7yTIJ/0e4T1nK7HRyKhvCdkt94XrPcQa9LAWvbcBxByLbxLKHOfQWMPeh+adHMpv87TSp9qKR+O7UhdAyGEEEIIIYQ8GXwRJIQQQgghxKKeBC9RcNdbbcz6nAmYWulw0PdN7D63w+gs2RePfEquFcKXkhO1633eqpFo34jQA63+KPs1vV33gyif7vOiOlpCnEjkYvWzkdDK82nJ+ekF8TN5r8leRemP3A9szz0P0q0PxFZ1XSsuXyq41gJoS5y+lmsfF2k/IyZfUieZJyPu1umX4JVjbffKQvaWHt8tr/PROq61u4Xtx2Kv985S/GcqL41la4k4Pfs+i/JZ3633Xv0ebonBR8TUnl+Zd3ttNxKo64mVVl2QXZkvK67Xz/Fogqf0Wz9Xo3IykwS0zxbZMQ7k23tjz30NeXwyY4F9LLHW8xORMfap+4XoXToz4TqaWPPmTkvXhxBCCCGEEELI+4MCd0IIIYQQQizOwRMZyLGEpFaw3grCIwGotB8FsKf2/ES11jANeS6ucTo8eqxxzaSTjK1odUW0KmJmxcaMSN7z0xMJock9GeG69B3VwxKzI1GN1+ZI7JM9D722tfreqD29IL4nfLJAdbHqd63rzzv/1sLbkmSPHei1hK5b1VWLy0d9GvVjJP3ejmfUNiP+XvPYb3luZLdnJkrofBk/rUkDS+qYmYAQbc+y5poio2x1b93CjiUyjJ7Bsn5ZomckhvSey5BgPPJpyYRDKSqX9mVdtPBT70NprQmc0XOhtqlF8pYfuj7RhILMPi+9Z3/kfBnxJSOizeS9F4/+Dk32zeg4YFUfdF+TeT+1JunItOi6lXbsCS8HPp0QQgghhBBCyBNCgTshhBBCCCGAegmb1FlQ2lq1KFqVCAV+rCC3TbusWqT/nuzMDbXWClc6IhKeDrclN1FlLH0py0VHWuBilWlNtPFEOZbo3bLtBcmR2AeJhrRd2Wdr/70AurZn+WfVJxOU13jtNSLYuZZAZw/CH7KUtQfPO+n2chORdVwqOt7Ch71fKF7bZH1v6m82z9K2uWWbXuN87ja3qP+9rressP9WxwqV45c9v3fe9lq99r3beo9cKhTWzzEZu1nBdHbiduRXlG5UwK2F89FzZkaMj9JmBfmRuB/5rAWomTprAb91bPUz/vjYhV23Tvb8HbWLylhbFiFPQS2ltHlfI8n0B1afp/tYr5yJ/eQ4AyGEEEIIIYSQ9wcF7oQQQgghhMypQuEOAzF9uxX07vv7NiuAjAI81nfp3inv9G8Wit0J2YaRSy9z2aE+AJXnCZ+tFSQ9X/QkHpQe9WF6kg5aKVJ/9kCCdDfIbdQpCrJ7K8eNiNozfll+ej6sLeMaUEzwiNxL8H1LdB2j+qwRXCPOCiDU1nd51KrGZ49rO7rUPsp3jfP13vW36tTAJ5nn1teuV96tTnZUjl/2/N512wtz63vnyKS7ke3ddvaZa2T/EqxJg9a7txaS6/1WGd52T8yp06IyoraUz+mRiN7zV0/qtNJ7z87ReSH/WoxOCkXbrvmsma0HIaSYt8rRPnbpNW32w6X1kdBlhgkhhBBCCCGEPCwUuBNCCCGEEKJorRxaax/P3/q2UspY4N/KM7JaLwwMXYLpuQhtrfUigqe4nZBtyYqavSCvJbpGdqzt3mqTFloIo8VNnmAHTc6R+XRgGglwvAlC1iqccgXJ0cC5N0FgZgeUbZGZMGCtvon8Q6BJVveAt5BHIyP4fg+IpR1n2/TnpXVGbenYcpve2mk88KVpxueloPK3ElcvsXON83VtXdbmj+uES8i2xVYisPfSVzw2o5Pi1mA9g3lps++8GiT8jvJGaaKJj5kJoNFqwp4N+ZwaPafrNAj0jGwdo2isAeVbQvZ8jASx3qRcQsj1mY0R9r5ikkYlSfbvetJ7z6vvG9ZEf6uvI4QQQgghhBDyXFDgTgghhBBCyJyJ6sYTlfa/oyuRyQCOJdjEed+Wlo9E62i7FLtnoCCePDMjK3KvSYfE4agfQKszWumW+IRseKLzUdEPWt3RWgkOiaRQ2VrQYwXGLT+tdmtGvm7PEuJYgnaUZpQtbK3t0rOrj5K98B4PTFZovrXY27ORFaxHae51vCw/rXa1JhKMoO1Y9rZcpdM6d9aUcY9jFvv81iev92/7/n3LY/q8bL3itSdOjyYmRs8nkZhcP99Zgm/vnRuV4602rJ8r9Xs9euaVvmn73uTLzDO6tC/LR8+1yD6qD/JP+43eK+Q/y2+rX/DOm5EJEFue24QQHzk+KN+B6yQN7mMQmXfDaCKO/H7aVt18hBBCCCGEEELeNxS4E0IIIYQQYtADKWjl3czqu2jVISvAj4LIk7QyGH/J187bRECqtZkoXW4bFayPiOGX2Cdkz0Sn89biYkugom14q0D27dmgMSoHick9P7x6ILERmtxj+aHL0qvAeZOLRgRX2j4S+GQEOrpcqw0svyzxmMfosdmarW1e6zZyr9sTJwB4PKJKZUQkbR14T3y/teA908ZrylkrEO90G9qXjG/Z8kePE0g5S+qVfa3zu5bIZ79fHvNr+/vGrc7r94P3HjmSZq0PSyd+IgF6JJjWz1J6W2aCZ2YinhZ9W8+88nNG1C73Z/xEeTSZ59+MIN57NrXazJuksNW7hZXXK4MQsj3Wu6w1mUii+8To2kX9iO7j3gT37AgIIYQQQggh5FmhwJ0QQgghhBDASdiNAyij4kEdCPIC4bKMSaC5vMlyeja5gjsSu8u69O2jgvURWmtXtU9IKXGQdO+nYCQ8v7ZAKUKKdSTZ1SelKMYS8ERtgIRDfbsl3tE2dDBef/bEQRmiPjzyKcJrK09Qj9J49tcwIl4YtbsWT2B3LaIJHzHLHFx3LO/dYSLn7ecvO4/Mey0sAXYJto+ylZ3I32z+DFv4LG2MHse3vPH1sM7X+bXs2cP71rfWWguPN+Nmfv/cdx22fobL3GvX3I8z/lrPV1Y6z0a23JG6WM9YerKifib0nlUtkacn9rRE75aoHE2i9CZqynK1z9YEgkiEr9ONEgnh0fbRa4QTBQm5Afo6a7ifKyXXn+vJMki0jvDE7qWUD621Fzs3IYQQQgghhJD3CAXuhBBCCCGEBHiCUy24RAHvbPDeWyntkqaU4q2SjlZvz6TbAorbyS2ITt29CyA88Ug20Ku/W6tNIrFTVrwSiXc8f7SNvh+tPOn5hj7DfhEIi7QfWtiOVpLU+UdXsETpMmJ01B7RBKi1ZAUGmXL3eM3d43a0vsxlDbmu3D0dPCnIHvFLNsAakXTEFm21xKel9bi3CHrUb+s4Dlp5gEdR38UHqMBNmLbDyKQySe7+tH2bP8J56BG9k+pnqMzzgSfCjoSSmfZEkyCtZx3kvxaYWxM2rUmY6NlTPn/qcr13gWx7Rs9ysjzvWrDE+5ln/WuQFfZvZZeQPXGPX0S8lJmYBFMKHofITm7KjI/qd/DT31ZabaXUcmi7en8hhBBCCCGEEHILKHAnhBBCCCHEZR48GQnCe4IMbxU3aWcevK7nz6eV26WwXK/WbonOR8TocoV4Qt47WRGNlX5EPC7zWMIUK58nLNJim9FVE7PCEm/VS5nGEv9Yeaw0GR/0Nk9c1Pdnuze0GmfkC0IH7DMr4Hm29PcRAc9I+uwKfqNscXsZOY5bwFviNVjaqFa+NQfpWiq4JT496sk26veyej73tThynj6asnPJgZ3WMX9/W34SZc6/Nedo1v7a62DJs6z3LNy3ZQXdcr9+brPy6MmIGdCzFyrfspepj35/lxMrLbxJA0hI6j1Doudu7zkc+d7T7q1/HfEHtcve6kMI4taLRszG+dr5X327O2YmsqNJP6hvk1iT1W1n6/n/j/ZMQwghhBBCCCFkLRS4E0IIIYQQMqdW41l5abA3EqpmgzoyaK0F7DI41T9nhOlRGk8of08ouifXICP+SAdhV5Y5suJjJCSXebOTbrztVr9lCcg9UZH8nPEBCdi1DSREtwRcOii/RTuhPt/br+vjlbF2ggXyd4Q1t4Nrdtu3vE3t45a4CyfuzJ6E6Huilmc5P7bvj7TBW7fjRU6WKF+nzdjNpt8rfZIv2jfdeIt+elQILsm8U2ZF19eua/Z5KJp0Fwm45feoTkhIntmOJumNTFDUn7066uMXtVc04VHWxfI7ep72iMYgvO9bco13Kw4bEGJzGeuTjxVO/4TeV5f2Eei91u6Xp4t7EEIIIYQQQgh5HihwJ4QQQgghZE4t4lkZBVi8YLgUSqJgdiYfCsKf5EpTQbu1urpcxX1axlwEvyRItAdxOYNb5B6gU99b1XsrsqsvWnktUfgIWlijfZO2rf2j9dD9oV4dzrNnicwjAVFkQ+4b9cW6H4y0B/JFk5lEFa2qN1JGlLaDzjvLhx3cZlLcz0+/YGvvo7Rrjmll1tVtL88Unjg9K75uZRuR/l7a5DpY4in7+/r2yJ+jTf1FLJ3IEDux32upv7uAPVfq29bYjSarjTyLjT63Ze6rXhqrjaPJet6kyEydR9rbEo3rFYSR3xnBud4eicrRdvRMjJ7RLOE92o6e6az9mUmyCFRXr1xCnpVrj4ttZV/bQb8G2YotVLfGD9D7uTUZqNvz0lnfCSGEEEIIIYQ8NxS4E0IIIYQQAmjqw9qAiwzoRALQnn5WRitFikZkMKp/tgTvKE9PP/f1zcYehOx78IE8LreYB3GNU1QLmSMRtpcGiWci4fKIIFsHvGVZViDcOi7Rapc9jSey0vv1Spc6H1ot1OrzLTuojvp75If03fNBigi8dtJ+W1xjn+XHCKn74gJftmRkksG9ua0PWx6QvK1158FIA21VP2THE6d74utrsH2b7OFaWA56Zh6zsIVIWaUo1zoPRp4bVM4Fe/aHFuxZaa5VtmTLe1wkUJdpRv2wBODZbXK7fuaxfJPPVpHwWz/zoecoT4SPnj2jNrQ+o3NHjxdYaayJgdGkRZ02InP9Lzk37/XMRsg1uPaiC579JeNkcqxP2770j+Xtr+yLrPdvqw9G77KRGN7u3/b5q5KEEEIIIYQQQm4DBe6EEEIIIYQATrGTVoqx6lkkKI1WS/MEoKZQESzUKAM9/fNkFSYhVNcBMCtAlAke3TK4xEAWWcM9xXTeJJaIEVHRNeoYieW1T5YwKBImSTuZlSqz/aWVJiOCQr574nhLRCXTbyEiQxOkkDhfb8/6EhG1tTdBICOKi8r0hGRR3mvk0UI0j2VtPs00LKQ1fLjNLXXLTumanfjSxtjKp0eS+0bk6rLd+bfE0PYn/30fUb02X9c+Wgy8Fd1cdA/eYlLUWjL1X7p/rd1Slt13sm1kTfzTgv+sD9FEAWlLT+JDaay86Jjp5ywpsET5MueeTGsJzZHP1rMa8h1dg2gsQqbNiObl9qxAH/lupVubhxAyxxOy619otNLqxTHQGFtrb08WqL+K+lf03u49T6A+z+3n2XcQQgghhBBCyNNCgTshhBBCCCEm8yiMDrxYQecoAB/Z0nnmAf42C2Z5+z0xO8pPCFlPRkS9hD3N+UCC9r49m1+n90Q3llAIrQSnBUta0ITE96i/zUxUiPKiMqPJAJYYSZMVwkViMdQWo+VEaUeFjGvO9bWTSqLteqKB3V5YQJLwyLD3DNyqshcZz43KI9ux5Ka652dd6zl9LP0b27fPln1QNFnt2pOZbK7TF6wV8UciapkuIzqPnn88G9bzzmh9LBuW0Fs/A3nPZtn3cO2PVVYEKt8Ts4/4iT5bx8/DOgezx23JdcbhBUK2odYKx+u0UD1aqKK1VqxffjztK+VwqKUv8tGCyW7WRBzUv3rvUzKd7X47P6XwmZ0QQgghhBBCnhEK3AkhhBBCCJlxCR/PtmpxIgo6o4C7/IvEoJZwYRLgmQTl58J0uVp7T2MJ2CMBfN8/uno6hfKEXIdrieWX4gl6dV/odSNaeI5E6Tp4rvtN+ddbJU776a2Mifz0tiEfLfGX1XZWPVH5I6KkLLLca4mpPYH+GrFchozoD6UbnawBSh5IK3IZx3gP138p1/bj2pXUB2Benlu/nRyDddTyvCKhfdR73TX0Lk7CUkp8z5Zkhd7L2aZdvfc79L6o96+5D1kTrvU7LBJgez6h5xSUTv+N7u26PfQzofcs5D1zoXTediT8954Rrec1q7yMAD0SrWefWRHPNUmOkH3gLUhhpcvaW+KHHBt0xfDt7W80BuEJ17d9V+gdbnk5tkZdAyGEEEIIIYQ8GXwRJIQQQgghRPH6ejz8+uvnw+HwUkqJg/0WMlCOhA7DK63NAuvz1Zp08CrCCrpFqz9ZLMlz7YAeIWQ50SXt9W96e0ZgJPPLfUh0NCL0sSYWyX7cEuajvt7aJvch4ZO0bQm/ohXsonuPvu+gOiG/ZdpRkfua7jk6P2S6NYLvTH08wZrl01paEzoS5xyX26/B6DPJY4vl4gPn1m/Tum/bkPlzspX3JJIeY0299fFafvym59izHosx9trvWP2j1YdHou/MhDtPDI3uq95ksjXCaZlP1s0TPeqJhpbwXorc1/hlPWcsmUiI3u8Rmb54zXOJ176ePyPtmJksSgjJ4Y2TRWNooSB9sGy0uMVpLNF/1/Lek2S/KN9lRyZzIbvzypSXQoE7IYQQQgghhDwdfBEkhBBCCCFEcTweX0opL28rHJ22eyIBFIzXaSVa+KDFDlBY2U4bdMwHCdO1GBwFxKLvHluKzbPlLg3oEbJHbn06j4jLM3bWdgEoQO6JvjPleyvFRf6ilTmRyL7/9URSnn1vshMSDyA/kNgrEtcj0YEsKyMwsAR00je0LzomI+dmdpuu9xKsNozKRoQ+LBCeDdnfgIzg8hqsFRAuJztRcK0fMnOmTD/N23HKnkzXvhm9p2e3WuZC9PcjTF93Hq87zp5YO5svsz2zf0k7RP2jdb+W+aPJbdpW9DyUQQrIrfzWM4/1/KDF6zofsrnm+S16LvHE7VkBtyXcz05gQP6h76h8/czm+Zlh5PzOXid8RSfvja3Gurzxq5EyltpB+9AvO3b759FPUe68L5J9p7yH9LSj/dQt3mEIIYQQQgghhDw+FLgTQgghhBAyo541LK1owUZ29TtPnCEDQyjADwPjUMDXJp+10B2llelkMGskwCbzWfvRZ0LIG7e6NCJB+hIR2NYiXM9HJObqny1hvCVI1kF3Kwhview9gZNnS/7Vfmsxu/bBEsZpkA39HYnOLNGUJ2aTabLHdMl5FInuM8KwTDlRmVbbRj5Y/qB9a8VhW4jL1tiw8m7Rz2XOs0GLyXQ550/Hbyt1X6bMbKNunU6zbTs+Brgub+enbJOxcyIjJN36uWFbe5Yxqx3w+1X/nBXDLb30ssLmDJn3PasMLfiO+lJvQph+RkHPMkvEh7J86auVznoG6+VocWT0fKDrhp5FLPuWbzof2obe0a20li9e+hF76DnZKmvL53YPitrJe+YWCytYZWTGz7xxv4w9OSYo8zf9F9x7vMlCup+13mczzTtPo70jhBBCCCGEEPJMUOBOCCGEEEKIpgdoQFA5CupH2y0hJBIDyIB+7dsOBygVkSu0W8L3yepMdbqiOwqMWcGwSNwe2fWgIJ6QbbmGIG4Lm3qiT4QWsfdtKF23j8qM7EX9s0zn+YrKs4RXut9HfluiKyQmGxESWKIo716H/NP5pX0tTkPlRb7J72iyQNZGRCTMj3xCebbmkW6TmfbPXv9qyxJ3eoljqVN9HkqwThx1j+M8XuZtFY57Pfffzk/poPwcic9y9rfW2+k+dMmkoxgr03R7JPD3/ET3liiN3HbN8yojWtb+aKz7i35ukPW2nmUswbmXTtqSz23Z50H5DODVJftMF4niPeG4rkv2uSRb1y2eka3nO7lPH7foOuZzCSGPQ2b8bPQXEE1BuxgnPO0rpZY6eWqxROs9/bS86Wd0/+ifUZ4cnF1DCCGEEEIIIc8IBe6EEEIIIYRYtNP/kLhwldlmB611OZOyZgGkeXCqb5cBLE/MPiooj4JpFLST9wJXJhxjaXt5IiUvHepDLXtReUsESVpMLm3rPt0SYnviKnk/kMIwT8CPBO1IqBaJujIiO6vMpQI9D09knp0gkSkrI7awbEQrG2bIphu71uT9fiTfOkaEo/IY5n28bmUsceeglVU+jE4w2YKxeuKCx/wZa9j3el9efo6diMThUdmjeQxL0E62j4/63GhSWdSHjAjNLTuRbf1M4N2vM/7JfZn3UKuO+rnCE7n3Y2HdW7MT57SwUW+PfPeep3S66NkoI463sO4F1rPUCOg5LHqm0cfJsrMV3nnJV3hCxvDGvbYYE7NsoLE/uejFdHGM899LZrs8NNFmpD+OmKetkUuEEEIIIYQQQt4xFLgTQgghhBACqGVbUXvGjieua5f/yfRtFpySQav+Ha3W9FbONJ/eN/dxnm5NQE6XkRXIUxhPrs09T7G9iPgyfmQFXJEttAKcJ7LK+OWJ15bY0dutbVL4hMTcMvjv1ROlGxG5y++Z44OECno/sqUFdJ59mSYr6rQE/rJMTzS/RGwoy7byeOI2936eECeu7X/efHsztFR4v4Sl1961+r5RIaIvtr1XB43Lvdf9Qp9fnS1E8nG526fdDtQAbZWwdk26JeeH1Vf4YtemvuPPmfL0vpFnkbWTBUpZ3kdbImxPQD86kWXk2UbfIyPxoXdv1+nWPF9JPyzBOtpm3cujZyLvuSSzrW/XvmXb3/puMXpOjNqwziHvPCWErGd0IYgIPYaHfs2xf7fGAa18Vf19yyPtTreNVE+/MxNCCCGEEEIIIREUuBNCCCGEEKJpJ317a2WJ9qaUEgeWvTQo2DwXALTL3yWi8EwwDOX3gmPXhqJ28izc6lQfFedYaTJdQJTOEntlhGaWvWhCkVUWWo2ul4mEVVp0jfZlfNZ2MkJ2VL7Oo9Nov1Ae7U+UNtqH0lrtjLZpf722HREXRun0Pl2OFGZYwjerXT2sCQ+WTZQ/e74hsuL9LEvOiTnLnzXWiV77M1L/vr6DXmZhbbnL22/0ernF5ImxtFs+p85tTeuLKz86wWTkvnotYeqICBv1u/JfJPbNioG3mPwzkjYSeCO70bOHtc26n+h9kd2s8Bndz3R+yyfrfoeE4J4w3Lo/Wuec9UyA0siyLbt6UkL2vNN2pa21rDnHo3roMkaeKwh5T2w9rpS1N7LKOsqXHcNDInddDkqL7m3e/QGh32G9+57HjYYYCSGEEEIIIYQ8CBS4E0IIIYQQomilHUqrL6WUiY5lJMjiCdpkUNlauQ4G66tYTQkEwWqtk0CX/N7395We9M8RR0E1nT9iTdBw61XiCSGYLS+rrBgP5dP9o9UPWmUtDYCPiPe0bxm/UD+uheZI+BUJu5CwSvtgicws4YJlR5eJ6pn1G9n38iMROxKuIR+tcmXZVj4rr2fPakdZHiIjRET+Lb3eMvsi+5FoBdnPiO1jcWC+w8r0bXGa7kx/xloqJJ5nkluywt71LDe8lTj7GnW7/ePh+YFckL2HeP3Z1iy5L+r+FN1HlmD1j9juKeG1hG1Wu6P7cNQnoWcCfZ9H5Us/kEjau49pYbK24d2nstclsoVE4tqH0fuZfqbwnm2Qv9GzYHScR5/pIkavlTUTUzLCUotb95kUqZI9svUCDXpsDaEXm8iI3XX+rN96DFCPE5o+9EecwXFP610lcx8d2Xe2xV6FEEIIIYQQQp4QCtwJIYQQQgiZU0s9PysDkcFS0cjIdri/2fKkHqBCgSod4OrpZV75WQbokK2MGD6LLsezh+oR2SXkWbmloGSJAK4HvCPxriUAsgRgMpA+upJl/+wJvj3/tR+Wr5ZwG6VFtvV+ZF8L3jKCbemXvt/lBMjTPNb37L00I5qTafUx0fXXws3oPNNkxZ5bCZZlO8m6Zcrs+ay0GbHJkmMtt9/zNozK9/1BFYmESm9l+fh2ousFlXlLbc+Wx1HWbSu7uXtdL2yrdtvG+TUCVyv/Wnv6/pnt91FZlmAZbXv7nrtebtW/WM8o6D4i/cvY9frPjBBep9Xly37Qer5AdmXfhkToVl2RON97hpFY+ayyvOclVJ7nt+WfvgdHfmt/9bUU5d3quT1q61sLzvlKTt4bo8J0ub+n6Z8tsbk1nueNzaH8nqgeLobRP1+22fXJvnuM9HXxu2ErpZQPrbUXPyUhhBBCCCGEkPcGBe6EEEIIIYRgzHBsJEpYi29jvlMHp3Jl4DxavB6tRmWt6p4VwcsgX9avDFuvykXIo7F3QYknFI4EuBZIcO6J9DKiIy0s1qJpT/RlidF0OUhE5QnWLIG8/uwJtjwhGGorKYaTInq9D+XR23Qbejas9pefI/G3117STiSAQ7ZQ+hERb0bkkREGjlwva26PUbst6XdGRPsjRNf79HtcGLperwc2nhUBb+qJc76PHKNriTkzZYk91ys0LDu3f+31ect21oyIvXW/lT2XvOsv2/ZIiO3ZQ/eXTF3RvU7bz4oBrWcI/Q/ZkGJ81H46r/Q78i/b/1vt5d27rTI9wXmEfm7IPBuuva9lrvlsO6zxaYu8t4Kv8WSvjKyi7tnooDEwWYb1i4uIzGIQaKxtVlabPi1Z9wiEfEfU78rYn3l+j7MI/9CsB2VCCCGEEEIIIe8WCtwJIYQQQghRZKMlS8QVXt5QUFBa6eEmJBq3AmT9b/9nrdBuBcVGgmnWfm9FqhG4Mjsh++EWAsW1gh8toI58jvaPCLGQAB7VyxKTy31aKCcFa30/EmllRXhIbK791OlROZEAAt3ndF0QlvjLal/vs2XvGufzEiHeqF9LRKLZsr2yov3Za2nNs9T1kc9C079ZLHFrkMu1dysikeatJlZ4ZPrUWxKJ/9f2B95+3d/c+zqy7iPZexMC9d2WaDuLJRqX5UUC+Mi+vs96x8p7JkDfZT5LzG599oTufRvKY9nJ3MtlfZf0K5k8lg00KcA6n6JtEWuvP92WzyT6vnffRYjFluL2TBlosQlkQ47teeN41orxs3o5ffTIc0nm+yjVe0gmhBBCCCGEEPJuocCdEEIIIYQQRY+Y1FpMtfsywdI0/5r9eoV0tIo6ErHL/Ch9dpUoKy3yQ9taGhikuJ2Q25C9RPd4SUZiIC0SQ0IyS/CFBFxWG2TFlpYIPLKP/JP+o3bQ2zLCYi1c83zMiPm1TygfSiNFduiYWT574jVPAJfZZrGVWG6toHgpXvtm22HtdZHZfxvWdXKeMHa0/7TOW9vOWhEWuk7HbI7Wc8k9xZt4cM971Ej/YmGdP5lytvIB5UXC4Ex/tfZ4eH23vN9Y9/FMn2Ld83Q5fb8uF6VDttE+T2Bu2c30L/L+qT9n7k9RGmlHt48W92fuAUvvj3r/3sThlj/oOVNvJ4RMuce4UEZoHoFWUI/soLEz9OuJnp0ufE8vPDHw7LG2f91D/0wIIYQQQgghZP9Q4E4IIYQQQohibYzFEiyupZ7/e7M5/Yx+yhjR9+sA24gN10+jsiNBQYrZCbkf17j8IiG3lXZkBUspNitlrB4jfbQlRkK2smI0bbentURv2nYkrlsrWtZCPl0mEv0hkSAqNxK8IbGdl1cfGymys8qQIMF9VAedX58jS4ThI/mQn5Z/I/n1Nm9/xves2HsrsUsk1FwjIMxeN/Iv2pclMxFkSkuJV6PytM1RvHp6ddniPrTkPPLKXSsMLwVfo6a+7AoCdWl3yf1S96t6u5VeErWx5Zd3DUTXGjq3lrS9dZ/RdYjOvdF+z2p3uR+JujP3O32P7P4hn7x6I3/Q8UPnzdo+ck1fN4L2aem9aunz6dZCUApLyV5ZIvre0n4m/VY+dNF5dnV3SyCvx/KssTdtQ26/lDMpU/uAJ1FZ6T0WPYez4yKEEEIIIYSQp4QCd0IIIYQQQhSttZdSy8vy/Pa2EaFPZyI4EOIitPqSDGr1zygQNrU/DXDJvN7PGEeBMe2jtrk2KEgIuS9biI9GhdtWuZ4YLeOnDM5bfbEltIuEYZ7QFwnhRsW+lqjAE/EhMRzyTQu1kbjPE4RrW0gkgdIin5Bo3rIXCTc9QYXlKwKJ+Cy/pC9IAB4JCpHvGbH9tYjacIm97PZxkXadfI+O8Yh4fWn+PLUUNfVyqUjdqnM0EcAv03u+zOS3uYZANQIf1zrbt9Y31F9msfyIhNtWP2Ud/xHxt75f6HuH5QMq1+oD0bNB1O+NHCfvOohEeJm21Mdc90d9O2o7lN/zPdqP0GVagnTPD9QOsg1k/sx9Ogt61ssI9q30Fmuu++i5IrofZYWg2f4EPYcQsheuPU40aj8aT1tLxn5msQhrLA+t3m6N50Vk3l01I5OD7H1v45EcRSSEEEIIIYSQ54MCd0IIIYQQQhTtFDM5C9y3CZ9EwknXn4QIBv0sMfrpYiRAR+n0Z2tFqOzKU9F2zwfLf67yTsh9uccl6An3suI9nU9/XiJysvppTxgW2c+KmbptKYyLRKxacCaFbEiElxFxW9sikaQWu3kiZE/MqOuE9nvnjlXe0npbwn/r3IkmEHh1s2xbROms/fq8tHxB3y16HbfQDdn1arPzw5okYW1DZS1tR+tYef5r35b0v/YzZGzTExwtLdu7ttFkla0YtznPsJUoPSw5uH9Z/bNOp8XFnn9LQNd/1J9lfEDXquwzPFGwJaDO5O/prPup1ZbovNV9jvRP7kP3BlQPfa9CfZl1T5PlZMTmqGy9Hfms8eq4hFFxZSbd2nd0SSRWR+feyDNfhuia5ms0eWT2OA6U+RVFtPhDJm1PD1dbB5/RuGC6zQbeLay+LOqjrXduv7zz71lu8cJACCGEEEIIIeThoMCdEEIIIYQQRT396yH8+f4VopalNi75zn8tMbu3ktNb2W9idC1c1zaiYFgUmEN+6PItO2vKJoS8T0Yue08s5NlBYjQrLxKE6/ItwVsW5A8SD2oftJDNSiPLQPXQvuj9Xnvp9FocZwn6pB+WEFgLrT0R4qgg2zteVnt7adB3dJwiO8i/jOAws906j3W5njDUOt8souvAEuV6/nkCy7X+ZG1mhNnyvPHbDT+HXuMR6JqPVdZxGT1nPPu3zLcU3V8uEfEjgbK2afV1GWEwEkxn/bHuS5n83Uamz/dsSFtRXaJ+T7dppm+PngmisrTvHro8637s3af08UNifK/9Ms9KW4u3M31J9r5hMfL+Piq437o9UNk71P8SshnXGAfKjKdlx6ZQerSKui4b2bPKzfxyIrItfYN1btMnT0vE3v+u6Wuie+qMWtBjMSGEEEIIIYSQJ4ACd0IIIYQQQmacJe6lwADKSBDHCrJnbUzEAaVd3Il+xrjvRyuvW4E5nb5v63m9bVos79m3hPUofZaMsJ8Qsg33nFuy1SUdicwyQrqeLhJxIQGaLDsjLPZsan8jIaC2lxFmI8Fb/6e3S3QdkeguK6b0BOmZNtR5rbot8Q0JBT2/vbrI7/rYWudMVjQ54oMkEifrcyFznWYEgEuEtpEPnq2oDbJp0X7rOhsRsmZZ209mj+OIsGlclF8nvmTsd5861jmrr89cHbSQLM5h9ftL3yPQdZZpV0uEvOac8voES2Dr9VMjIGFd5v6gj4cnBEb3Ue/+hvZFzxA6nWVHH2N9/C1kPq8/1OnQ/TQ6dqPXqbc9un9GjPbVI3jH9J7PxoSQ9WTH1kqJx9VkHolc4CH7y4foVwz1OFxkQ9tz/axFLKqB3/cirjUEd7LbPjTqGgghhBBCCCHk6eCLICGEEEIIIZAeyV9pZUD8Y+Xvbpx+lFfuW27YWkFKr+iUKUMG6qRfMlhm/Yyy/o6CddZq9cgPzTVXead4njwr0al/bZHPGvtIdOoJUT08cdyID1bZSIS5VFymRXpIIIcEmJ44WufTIj1PEBGJ5ZFNWbZlx6u3JYD1hJvapxGBRySOtMpH5UX1HBcPrz9vZVtkRYgZwfRSrGPtnRfROSNZ268tze9di6PtFYl6R1ly3uVZ76DV93gCWEuUrf2xhMPWObd0YkW3iYTOKJ0+xlafZfWpGR+9+4lO6/mqbXvnpPRT/s20h0yPBNyZY4Pujyidd87pNtR+ZbHaX9rS54Dlo75fo+3aNvLH60vlubukz4ruf9diia9bQsE8IfchO36EhOceSLgux83k2Jsep9O/fijtyfE2PQ6H/lnjf28b8BPY2j7Om7yUo53+1XJorVHXQAghhBBCCCFPBl8ECSGEEEIIgewrqtzE/zueaHySV0SjrJWk5F8ZJNMBMy/whmzpzxFWYE6n0bajdBlGBevXFM8T8shcU4C09rK7paBV28iI+CIforyR4NiqvyXyQyI3aWdUyKhFd57I0hJ2o7+WMB7lt8SGulwkBI4EenK/FmR6AvFM+46IMi2QqNTa7/nRfffsoeMeCeHXiF9km4xeJ1G7IGwhNLY12vYZLF+97Z4Q17KTEbUu7fe36GdlfzIq1tZ20DkZXfP6e+TDFgLwTF2z5YwcR73fusdZfTJKmykHHV/Lb6/fktuR4F2WE/VXuh6WgFx+Rv0kahtLYK4/W/c4y0/tE0rjXR9ePotMf+wdv6hvjbDOQc8fqw1v+ep3SzE/IeTE0gUMtPgcjRNFK7f3NHqBCD1GZ9lH5SCRfMhAPxfdb+S29c+M57ZppVWswSeEEEIIIYQQ8o6hwJ0QQgghhJAZrbZSDq2Uq4ROtgqOI0G6/BsFsZBQvX+WgnYdTMv+fLMsH/li/ZzyiHB8S5H51oJ1rvBOnoWll85Sge7aSysbjN/iEvbEgBkhYUaYlUkXCcYsPyOBuSde1GKwrNhSlxnZQYJ1S5iIfLYE7Rn/kaDQq6clskT+ecJabzsSa8o8Xl5P0Gm1i2dT29FC5JFrbEQYI8+/qByrXUaupVEB5Ui9R0XKyPYW/WYkIB4RuaLz1EvvbZPlW4JmlNcTzaK+IHt+IHsZLJEz2oau1b7fOuez58CIaB7dT2T5+jqMRG+RwNrCO86R6NyzmWmz7Hmqj4u+b+ljl73f6PNB969LxIfaLyuPheV7VK+e1xO2yzzXEptbx32LflRyS7E8Ie+Vrcdblo4HWQtI6O/eOB1axMFbxV0vQDHy64fWQhKjbPH8NlxeLf1/hBBCCCGEEEKeCArcCSGEEEIIUbRSXmppH+oVAidrYkgyLuQFrpAw/VT2PGiG9sn9SOiuA2toNarMSlORED8jzt8zXOGdPAtLL8etLmPvUssK17MC3TWMilo9sXGmrJH8UgyHxLKZsjOCPEtsbAk5LQFtJBbsNi0BIRLRoe1aiI18QgJDhBR8ah/1fn08dBvq4+S1i95n5ZX+aHGn/qvrr21Y+yyhayRk1Pa8Olj2PBFsJr/crgWZ6LPGOj9GrrHItrd/icDXyu+l9XwYYamgVl/PCE8cax3bvs/qF7Yg0+9GxwL5o+3pviZzbqC6Zs5d3Y/ovgWl6zZ1WtQ3y/RW2Zafui66XeQ+3XaWv/Kz7o/7PnRPGelTRvphq64IfY/w0krfvLK8trTIXk+3eIYkhOwbNN6SGSeK0iwdh/LG4azFI1B+REYcb60c38vVNkYXl7g3J1cfx19CCCGEEEIIIdtBgTshhBBCCCEeG8dPPEFW7EeFC8rL1ZqsAJUnbkcruaO81irsaKV2/fPK1k8yo7Sy3CjAl+HRhfKEEJ9bXMZbCxglnjBPb7O6Pr1diqG1TSSei/waFcRaokTLPy1Qt+oaiQq1/0tEuVroKLdr0aUlkMwcZyRSRN+12HBEyIjsyu2en7L+ljBdp7NsWf5lxJvz7f15Yex6sM6tjGDYsmWVN/fZF9pmiK5BdM1bNjL+emWiNsicm1b+bHssEaXL7RmhsyX4RoJwq82tZ33dd2REzdFxR/0Q8g31w9E7idfXWucA+h71I9b9Sm/z/PPqIvttC6tv0/Yt33UfLcu07hu6T5L7Mvf/3pbZY5i5/rV/3jNC9rkge8/O2tyapWWu1YTyFZSQ6xCtpt7TWCueIxvZ/UsWfvD8sPLpcTJtw9unscYQvS5qbf9HCCGEEEIIIYSMQoE7IYQQQgghiEtE/75uXGin/+lV5dFPC6NtI4E7HXCzVleX4nQtUNc/l4xWhLd8yIrOvRWuUJlRXQkh749RAdES0eVaPIE2IuMXElDKfZboHInh+r5IAGj5pkV7njjUEo1bQlBLUBmJ8bofnpAVlYlEhjLNiDB1RFiNRKqeKLR/jo6/JfT2hIdrRXlIEOpdd1ocaz2YoXNhxFck4LV8R2VEYt9I3Gvls7ah7ZlzzrKj+4XR89Nrr+xxyByzEYG25c+IXa/NlpblnQvovNFlWn1z5l6CrnNdX0/MjY4p6rdRGcgndO5ZfqL6oONgnYveOS3b1hJ5o/J0m4+c80sE4shfVH6mrp1sv7D1M9EjCby9e+KW7cLXUkK2x1poQe8ftddBYvJsXplPjqtpAb4eQ9O20PifLjdaOV58OaUpy5+BrsXpnlQLF3EnhBBCCCGEkOeDAndCCCGEEEIAPWayl9i7FcPRgS4tKL/kV4E9+VPF2o4OnHnBMG1T/7VWZreCaiiAZwnZoyCe9T1axYoQ8rxYAu8leKKwES0FEoBbolhPfC3/egJvnU8KHjVZgS2qg5dvtH0y/lkiakuYiISKIyJCzxdUTpQWpbcEsVZ7ewJ95EN0nFAaJJrNiJa99JlzD7WFZd9CH/Ps+Z057y1GfUPbUL8wIhSPzmMkYLb2W/1Ipu0yQirv2rX88+z1/J5IfIlYOSO8Ru3mtUHUj3o+ZY6R/IzK0sch02+j/jR7b9X93prrzGPr/Pr+kBFCe9eXtuPlWfIMkz2Psva8yQkZGyP31Vvh+b3l6yRfTQm5Hmg8LEP0a4DIzlLb0ZiXHruzvnvjbbFvyzrgvfXbhBBCCCGEEELeFxS4E0IIIYQQYrKjKPNMPBFHkLzVpLIibxkIk6J4HSDUf9Gq6UioLoNxOignyx35GWi9z6q3t4IWIWSfPFLw3BOFScFbRryGRGIZYbQWtGfte+lGBPtZuxaWyNQTPWZE2PLYIOHnyG0gIzrM5kX7dV217/pzx5rUkAWJp9Hxz0xeQJMFtA0kLvfaxzoP9bWFrjXLFy1E9US5XptoXzLIMpecQ6OC7Kwt+T0S6qK2QALn/hedk14/ZQm2PSwx90gbo3Pc8zvqm63rNVun6Dz20L5b7e31KZm2k9eHdw9ZIorX9qI+P+p3kH+Ze5fMn+23dPmeX7K8LV5NsnXakiV+j7bfNZ8LH+mZkxCSG8fxft3PSq/LQALznjYjpPfSW3mj8T9dL/Q5s3BErfXyq5Ej72qj7xmLON0fa2lcw50QQgghhBBCng0K3AkhhBBCCJlT21ncvpfISWullIlYw442WSunW6u6W9vQzyP3vygoJ/PrVeBRANBKb/lnrU4/QiSYl/5my7HS3VIoT1E+eRb2eqovDehrATOyawkqtSjPso/KkrYtkZjcnhH8RcJnvU3XTYs2rTwWqH0s8aS2icqw2kvb0nVB9DK9/fKf1fbI10ybWIJJKcpE/lhloHrI44j8i85h6a/3GfmobaDzxxMUZ9JqnyMBanTMZZpZuQuOsXVMvHyRcBb1MZ5YuO/3+rXs9Wzl8fZF/Yw+3630yKaVHqWL9snrWrerdV5Z94dMX2bl72WgdN55h+4Z6Dq3rivr+rL6V89fdP9Atnta756Iyo6uEVmGd+54Zeg+3sqLzhsrTaY/yPbto2TaTLPEj1s8D+71mZMQgskuYDCyWIQ1TuUJ13saPX6Gfn3RsoEWlLDG4HQ+bzEHr05LQM9JV6WV2kqjroEQQgghhBBCngy+CBJCCCGEEKJp7aW0+uHa8ZmFMaRz3jhg5f1EMVoxHa36hIJjeqUpuQK7tUq752tGdO7lt8Tz8vuIT6XYQUsrLbK9NEi4hFuWRQiZszagj8TUfXskLNXpRsWgkcgZ/csSCRY9QbEU6WnxrLSnxYGekNMS/WXqhUSxUdfb6yD/WnZ7erRdl4/KRgJjT4ws2zgSZVqCYE+Y6omEkSjVE3siHyIs8a22YYlirWvSE9FG6dG5q/e1VuDkSq/enrA5smHl8wS2ng2dbonY1Stf2kPlovKQKDgrqJU20Xmk9/Xtuv+yzh/vXLQEyNH1jfpJ1G+MXEuWUHzkOEd9AioL5c346223+k7ti9XX6rRW347uYV6Z6L6v048eew+r3bdo66XplrD2+YsQch32MAHfGs/KEI2NRQsiWL9SqMe+rPEwbd9a7b3vk3+9Olm+7uF4RdT9u0gIIYQQQggh5EpQ4E4IIYQQQsiMWkviWXltsH5RDOkicPAzeytOof2jQa3sCvIyYCc/y33Z8lDgTwcBkRjfshWJ3jPtseXqV4SQOe/tcsrWR4v/Mvmz4t2+fYnQ0bNpCbJRPks0OuIHEpUiYaeVV4sXkcAPicCl71rIquvqibIj4aSVH4mp9T4t6M2IIpFvus5Wessv63gg0W50bWhfLFGqtm8JZ9Ex9dJbZI+NVR9LfIz818cxOp5WfbUPKH+27ujc8a59nU7WxTuv9HerrfV5r21H/RTaZ4l/9XVi2beug+g89rDqr88XK63V9+o289rLOnet61wj7aP+SoPaHvkqfYquFdmfRP0x6he9+qDj62FdT3IfOue2wLufRfmkn1G6pfsJIY/HFmMi1mrn2XErb9GCERvalha6o1XT0XhTplwkgvfyopXiM3V+vDGrvf3GJiGEEEIIIYSQW0KBOyGEEEIIIZhTBCUhJrwZdepOFJSKAl06AOet1G66VG3BOVphyhPeeyJ7K7inV8RCLPlJ6p4O/Yz00sDgo6yMRcieeORLxhOrLmU0vydw3MqHEdGsZSNbpiUotMSQWgiIhJha6GmVHQmoUR7tjyyzf0aiSSTSRaB28YSmnrB8pBwtHI1EyEiQifKjtkaCWqschFdnD0+UrO1rm0gkapWrhbi6bHRsrfRWPlQ39BmVo+3rPOj8sc5HhFWW5W9Pq6/dDFrI7InEvesh08fpdJ7Puh/wyvcE1nq/5Yt1zD0xOBJYZ/p+aVOfn6PHTvsX9VnZa9BKL/OsvZ9H57SVPnMtRETnTORXtr8k2088IGRLHnEcIhpnWooeG/N+hdBb0AD9CqJOpwXo8q/2QfqSWYzBW8zC+1VB7TNeFAKaviNV/J8QQgghhBBCyLNBgTshhBBCCCEPRGs9mDYepMyKx3V6LzimA3DyOxK2Z4KB0U89Z3zWaZFAPrPau2ZNMDUzYYAQ8n7IdtFWt7C0u/AE3ZIthQtZQTYSvlrC2I4URI4KCj2hsCW4jnzSQk+LaH+3oYWbUdmRXxmRKvLDsifLsgTOkbAa7beOpyVm1nkRVjtquxlRd+Z81nmz6TPiVUvwjQT1yB9LCOsJZKNrV5YtfRips1dWdF1a/ng+6/NbnyPoeFvnWVRPqy2Rn94x9PzV9kfvE6hcq74jxwPti/oiWYbuvzSRHyP3UX1PiSYFSN8s/zLnd8a3bB6vbTWe34/KPV6nojL5ikf2zqONQ2wlyI9+0bCT/SVA/T36VcJM+UhMj4TxyC895mUtXIHw/N7f2SLa4I5eEEIIIYQQQgi5DxS4E0IIIYQQghgQ7Swyv0TUUN4UGFPhzHLhNFplXWL9FPQW4nBtW//ss+cLsumtsqXTjLSXV9dHXAmNELIvRruRSMinRZCWuC3bDUbpRsRzkUAzK1DOom1HYlHkb3afJcDUIklPUByJPT2xprcNiTjlNlQPnd47v7Qg12sXTUZYrMtC5SBkmqw43vKvf7bOKZ3eEhFLgbjeL/9Jn9Bx09913ox42qqrdx1K39ExkX+1j9Z5nemfovPc+pzpvxCe4BnZ0ILtvh2dP7qdIiG1dc2hdOic944jspMB9WeyTAQ6vzPXgbaN+ibrHPLONeS/ldbrtz22fk1Ycqw6VjuhdJlt1r5baGjv8fo1cr8h5FnZUpSe/XW+CGsFcznuJD/r1c/lr/qN/nqfVb5O4/np5dHb0XhYtDo9XnSinX/Och3b3g/q5A8hhBBCCCGEkOeCAndCCCGEEEIA9cqRkyWxv1Ya9Mr7eWIJWtUpG6zTAbroJ5NRuTKdJ2DXgn0r8BfVOVq1PSOijwKrS9rDs5fZT1E9Ic+BJb6zuoCMSDRjR+ZbI4jL7hv1e6SMSBQr8yIBd99uCf503oy4E23v5SJBMxJWonRevoxYWOOJbEfsWiJtSyQdiaX1NiS0RQJZJFaVgmAt9LX809s84asnLNZtYqX3fNc2PFH0yGfrvLauHe+zJyK27FvlSZs6bSTOl8dLn28Zgb7+PHqcUB59HkbCYqsP8XxGdfXOP+RX1B5ef2T1jZFgHB0/fZ16/TK6t1j3U+u6k3mi/d5ni5HHea9ts2T6cOuejM5tyy5fUwh5XrZaJd5dWXxBGegXBy3b1uIRkVBejzNZv1boLU6hbWRE8rr89eNQtWylIuf9gBBCCCGEEELIVlDgTgghhBBCiKK19lJKednl6kBq4aIo0KbxAnpI3O2JzXX5WkBvrdiOAnVydSydR/88sxXoi1a4ygZDs6vHW2Uvyb8kLYXuhDw2WwvgkF1PIJopN0qHyrJEv1F9MyJxCyRk9MSikfDZEzNn2lcKLLUoUwtOLVG0Jaz0RMmRMFH7iD57+ZGwEdmRvluiYvTXK1O3vVWuFqxm9kl0eV6dLfGvd93INrHKRgJeaTc6P9D1i2x67e6Ji3teXY4+BzOCWo2uoyfkRT707ZZw1+rbRq6lkXplBN7WdqtPldeTJ3y26ojqJ9vau+ajenn3nEhMLtN5yDrqtvD6O9Se0X3HOgYojz73s/eyJc8C2fvqqN2laQght2XrcYCMvWuPPWy5+ntmzGrEB0t4bn23xqm0H1b52V9H1ONkGeF8zDart4+y9n5GCCGEEEIIIeR9Q4E7IYQQQgghc2op7XCHuI5PKxeVQXctu3K6TmsF4rzgnU5rla9F5VGQEYnadXAvEs0jH6Kfts6uzIW2WytySV+tsqyVvDwf0P6tVkgjhIyzxeUXiQizAmTPLmLLrmNE8IkElUgMmxE4IvuWb7o8T8iYESV64mEpArYEiEjAivZrAWsk6vSEnfq7FlJbbW+JyNGx1fXVImxLfKrFuFqE6wlmve+RoFmXtcSWJb727FnHX/tiHTfZrvr4I+Gu5ZclcEb+evW0hMUZMXVPh46DJ7T2BNzW+WfVBZUxorHTfUbmWOv8PW0k/PaI+gLd3ui6y1z/yCY6B61+UJ/HtZZSnPPWu5asvgu1Aeqf0N/o/hBtk35n7iey7FGy98os1rWKyr01fOUhZMrW4wBZQfU1sQTf0S/ZZX+BL7M9GqOKbMl90TiVlz/z64AjbZFZyGKy/w4rfQzcWw7H04IkhBBCCCGEEEKeCArcCSGEEEII0ZzFFruiFqlvd+lBsyh4hvJdinME2l4Q0Ftp3QsEal+X/ix1ZvX46OepR4K3UfsicfvSn4/OlkkIuT5bX4ae+HaEa4rpskRCyVE/luhpvPaMRIHWfiQitvJrYaslyixlKgiVAkNLgOrVBYmUR0WZKC86pjI9EqFaYkndFigfsqvFstF5EQlWdR2QT16dkf96v9c+ffuISBX5huqphcfRcdW2R9vMSuOJlUfOQeucQaL/jFBZ7vd8Qu1jpUfXvVW3qP+Q6bPnsS7H88UTq2ftyvPPOi+j9rjkVe2c6WM9H6N9S++Buq8ePb8j8b61be2+DKi/LuU+YnbEXvwghJzIjjMtHYuS40jZhQAiUbjnS3ZMSP8ioScylyuso/SWf3pMzBOiLyUeK9zjgOiZk/qeugZCCCGEEEIIeTL4IkgIIYQQQgjgHqsWufTYExRDjK24FQnNo1WjsoFKGdDTNj1Bu7Xqu84n7VoBUe1vJkiaRf8stJXG+p5ZLT9js+cnhLxftFhwY53D1ckILDN5MwLZa5EVgJYyJm5dI0RHRCJFJLJEfkt/IxEw+m6JqS3RLhKzW6JiS/Qc1VODRNFIuJoR3Wp7nu9WmVr4Lvd7QmdPpK/Lknks4bvON9Le0ldL/KzT6f2yvXW7j4qCm1EW8qnbygjRLb9Q/a02sOzKtNl01rlj2cpc6zq9PDaeP+h7lB6VpY+bVYbVh+l0+pqyys60QXQcZR792fPVszm6b+l9lhBCIrKi65GxlrVjNHLsx/slQ00kOh8Z67HG0LxfJfRWlo+E6KNjQCO/YFh293OWb9RS9+scIYQQQgghhJCrQIE7IYQQQgghiv3qBltB3mVXz8quHK4DcRY96CaDdCiQ6InAR8Taug7eqvLRT1VLn0dW90JkArBRUHXtylzX/slwQvbEs57uSCjnpbEYEW2O5s+yF3G6V19PvKqFisiOJQz3RI1oIkBGfOqVHQk/LaHmqHjT8kX74wmlPSEzEhSPip2jtowEpEgga4leZdtawlrvnNBlevXxtkcicU8kHNm3BNTapiUw93yLjoW2abZ7UpiPfLPSePv6tsw1GF0LkQhcl6ftyIkCyA/Zjt75q+u6ZEKA57/M6x0Pa6KAd75a58lSIbnHFhMXtmQvovVnfWYjhFwPbwX1aAEClB599vbpcSS0mANKZy3ggMpdWofRPI+yUMLUz8fwmRBCCCGEEELIdlDgTgghhBBCiMU7C8hbK6Zn0o+UgYJ/SAAvy7AE6Uh8rldO99JK+94K8l7QEdXRSm+tsGUFPVFA0yoTffa2ZWwR8ojwFF5H1H5r91+TjDAV7cuKGT0Roic21uLQqEwNEnciMeqoz6gdtABW59U+aMGt3mb5aNXDE9tKUa5Gi28ReiKCrpvcp332xM/IZ8tPWQYScHvnkCVMl7asdpR2omOs6+tNFMj0B8iGdb0gsTsSUqMJAtpGRpCvy7PO2aw2DLUt8lHatdowIwzP9GXRsfTKyByj6PzQ1648dtb5bwnjoz5J55Vpvf4vuga9Om4h0I6uo0wZjygU987/R+QRjwEhj/DuP/JrdqXYY0t6f7ftibn1rwLqfzLfiCgc1ckSrltjXj1PNF6UXeE9/auMO1wg/XJPLrW8u4FaQgghhBBCCCEhFLgTQgghhBAyp5ZdrgpUJ6GcsZ8YnjKyorqVXwYDrbxWcHBJWei7/CwDk7IMa1V5vQK9t+L8iN/WSl1Wvuv+tDQhhOTZUgODRIhyXzathedrth6WKNVKlxFWZ8TMS/3RglFPhByJOJGYWpeBRN/6s/ZHt5UUnkbCWd12qK7Irrat6xCJVz2xLGqHyLZOr4Xa0TliCaa1qNs6LrqdkT2dJ3Ou9vK9+lh455TlN/JVt4POK/ehcxyJrnXdtH/WdYjSWf6h+qBrQV+Llg+WDeu80X7rcuXn6LpCtrw+PHtMNUtE6dq+d75F6HOi19HqR5cwkn/L+/MWZHzfm89reW/1Ic/B2nGCrQTynh00ZuMJwTOLDGRWVM/6g8qwxpFGfjlQp0fjVnq8y/I3sy1HHwrd2/jSuQ13OU5LCCGEEEIIIeTaUOBOCCGEEELInEMtte4vdjIN56xdyRuWsDC/F3TL/tRzxp71HQnQI/G9Lsvbb5WrV/tCeD8xrYOill9bCtgphieE3AKva/VEmCNcqzuLhJpaCDoqFNZCyYwgVtqPyohExFroawmqZR5LuGsJdT2/rHogYbhOG5Xl1V3WAR0zT6Qry/NE1tqG9iNqH+sc0+m888erT9TuqH0iUXQkUEbnyGg7aLtaTI6O5+h1KdOOiJiRoF76l8mry0f7UF11edq2dx5l/EHninfeRccO+eqdX9oHfey3wrKV7bOuVX6Gez3WU+xNyHOw1djBiB1vkYL+F42VZMZk9IrueqV0TwRvCd/lZzT+pH21fmUwIlqp3SpzlCb+vzcOHMsihBBCCCGEkKeEAndCCCGEEEJmMGgSgQJ/ltDbCg5mA3reyla6nEzg1Ptp6iitF+hEK3jJPGsE6+insr20hBCyB0aE20vtX9uuFuNaAlOrnpaAVYslkYjTsuMJrS1RrJXHEstaWHW3RMZWHUb2ZXyQ9bT8sQTfqHwk6o/KtYS7+q/VvlY6JKDWdiLRcyQqt+xq3xBIyC7bH4n+o2tgFEsknREuo/yWeB7Zlekisba1T4vydRuNXB/W8dB+Z75n0cf6Wv1+JJ73iHyzrjPLhy3YwtajPfZTm0jI+8Ybi9hqgQY9vmKNs6Bf6Mus4o5WWkffvXTWavMeUbmj+Zex95vK3v0jhBBCCCGEEHINKHAnhBBCCCFEw8C7i7ciuU7nCdO9VdEtIoG33I9W59LBSCRM93762luxS3+XK4RFq32h77rtkA2Uf7QcQggZZa0YeWs8gfcWZES4WqwbpUcgYba2I0WYGcE0EtGO+uWJwPt+LdBFvnjfkYjYA7UTEk1b9dffdd7sBAOEV340IcESt6M0o5Mq+j4k9PWOjyVa1/uRnUw7Il+8drCOo1UH5JNVd/05e53I8yZ7/sp8I2T6O+s4b4HXj6BrykL65on99X4PL13UR+l02p53LZI8fA0h5P2RHV9A4xTRL/pZ272xEmsMBuVBY0DWCvKRaD3zK4R7HIuZ+3snR1za+V+trbSXe3tDCCGEEEIIIeS2UOBOCCGEEEIIZJdRnV1grWKO0mnBN9rnrYAlVy3PiMQtRle/sgKhXn28fDKd/mlsmdayP+qztV2Xu8cAKyFk/9yj68gIF/XnLcqIBJqj9jw8QWgkHEbbs4JOrxxt2xPWR2LQUbFwxOg5oQXLWfGvFqZrG9GkB08E3G3I7ZljK+1LG9KmFg8vmdSAytLtqc+JSPSMyhoRHfeyPRvIX2Sj12GJ+Bn5obcvFbB713umPeVnef5mr5k1ZPsx6/rQ6b1rbGRCQnStZ9oy2w9ny96niJAQQt7ILmyAPiNbmZXNvbESKUzPTP5HYy8ojSwrk0f6Ffm/dFxn7VhNdgzsUcaEWinl2MqhHSlwJ4QQQgghhJBngwJ3QgghhBBCFLWUVvjTty5LheaIzErpmeCctQK8JxqPVoRHPunV36OV13XZ3krsVjATBVKzvuuyLV8JIc/HSBdw7+5iK+3FFvWIRJc9zTX0IkisvVS0Ggk2vdWVdRq9LRJ1o7Itu/qzFiUvFY+i/LLOmQkMWWH0kgkasp5aQC4Fy0ikrfPpc9Y6PqOif/ndO08yeNdV9rr1hP5yWyRmRt8jXyNROxJ3W+Va10e2Xa2JBqPHZc0knjX+W/2KZyfTH6+5TqMyRvNtdY+45b353s8BhJA51xYnRyuso/I9n+SYjR5LkWMW0SrpyA9rzCPyRZdp/Qqg57vl58g4ls7rpbke++7o6+l/HKwlhBBCCCGEkCeDAndCCCGEEELmJOU9t6Od/7crp85EwTbvp6jRT0fLdPp7Jogo7aK8OiAZib6R4N4TtWd/ulpj+aHF9RmhfGQ7YutA+aOsCkYIsVkrDLwmIyLMSPBt5feE4BlbkWAzIus3EqV3IeVSsWpWvNzTjYhwIx8swXdkB+2TgmJ9TFF76e1aBJ6xE02GQCL0qB7eueTl1/W30MJrbduaEGCBhN/WJIhICDwigo8E517ezH7vusuI3K3vozZG9l9LsJ4Rs8vrQW+3rmlr8oe3baS/Hu3Xb8HovfSWPu+hfQghU249Yd361b1oW99ubUMLCujP3kIC1q/9Wdst//Tq7d5iCVu1/bXGSpbb3eWo4+m/fQ3TEkIIIYQQQgi5ERS4E0IIIYQQomitfNiblrw7cw9dgSc+z/w8NEKvtBWJvrUoXu/XQnlrBS8dtLRW6pL7UR5ZB1SvzHZrWy/HCrreIqg3UoZXjyX2CCG3Y0s9xbWEb5nu4xaiu0hoKckIOLWdUbG7FFcjEXZWDOrVS+9DwmZL/G4JWUcEtFrMnBWDW/VB+71jYAmus+X0/NnJEDKtNylBHxctXs/UQZdl1UWfu9ov73zzfPCE0dpeLy9qS08gL/8ie9k+xBKfjxxnvU1PhBj1ZSTdqI/6fIzyRRMnvHNBkhH6ozyynCxLH1HXPtpSLE4I2ZpbTCr3xmQ85LhPduVza3V37zuyb41NaPtZUT4aa0ILN1hjZUvGRpYe2/Gy2r4GQiH795AQQgghhBBCyLZQ4E4IIYQQQojmHJtqO/zl22woZ0tBcSYAmV1ZXZP5yWtv9XQUlEQrdXmi9OjnpXsaK5iqy/FWJsv+/LQW9EeB4FGWHi+EVV+0qj0hhIyyRfex1sZo/oyAc20ZMp8lLrUEokioni0r+mylR74i4bEWHEficQkS/COkSFuKipGQXuaR5UqRtFfnpSBfZP1QHTPbM5MMPNE5Oi6eqDwqIyOM7ulGH231OZI5Zz1bVr41AvIor75GdDp0TlzjnPT8lt+3fNy71aPjmr53LdEElmux4WsiIWRH3GNSuScSHxlzQAsPoMUOtA1PBO+J8COBvieY1+WjRRa0DWRbkxlXuQX7HLlpZa+eEUIIIYQQQgi5PhS4E0IIIYQQoulim/t6gUk6tUdBsRU4tAJ2aDUuy5beJ4OLaCV3ZFem84KIelV3L522G612bwnhZX5Uhy2w2slKNwJXcCfPBE/39axpwy3aH4lK73VcoxWRve9ePl23LeuXsYUE6iiNtpvJY6WJRLjyuGsRMRJiX+NRy2o7KcTvZWePv/QdpfGE32vFv1sKobXIHF2nkS+j53mmD1jaRmhyhVeG3qeP2z0f/TNlL51Ms7c8W3Kv8pdMGCGEPBeye/JE65ZQHC04ILdlxlO8X8GT9rxFEyKR+ehiB6g+o4sRjIjW1y50MJ637nMcVLB3/wghhBBCCCGEbA8F7oQQQgghhABaub/oAXOfcI4nvM7iBUOjcvW2a6xArlfe0gFRL7AbBX316l5WeagumUkAo6A2zNryVjhD7HGyBSHXhKf8ekbb8FqiY0/4G/mRJSvOXWLf81kLpbPtlvUB2UN5M6J1aXNE8G/Rhc6WSHxNm4+QWb05Kt8TPWtBd28/VMbSenori+tt/bsnss/6gcq1xPRR2R5rj8eI7SjNkr7tGufvyDUrWSuqpiB7W/isQsi+8cYGovfrLd6/ZZebFXHr1cxHyEy212MzepEDKTjX22S+bLnoV/x0vqVEv1R4P/bgg0OtVLgTQgghhBBCyBNCgTshhBBCCCEAxkwwmRXL19qMVjjPBP50cHOJgBytwN6/y/QokIvK0nmssryV6nWdrLIQSwXtGTKr0hNCyFZ4ot4tWGpPCzizK5kjLPFzJOKNWCrCz65+7qXxhM1e2Vb60baQov7IP0sEPyp4zvgTifalD1pcbLWHPl7RZIdISG1NTvBs6nTWXysfKm9kMss1dGJbT37I9GUjk2BG9mX8GUm3pr8jhBAyZc37dUYkvhQkykbib2vsQ+6zVjJHwnXr1/bQ4gSeHbl97ThFxo5Xv30I2ufs0a/WahGjtBxgIoQQQgghhJAngwJ3QgghhBBCDCjMfSMSbFtpdHr9k9ReWZkgpecvEnRrH7RdS7iOypc2ZXlolTAUTO3bo9Xxkchd27DawLPjrTqfZY/BT0LIvtni1nrNlYxHBeqatSsuR+VqmyMC8S6OHq2XFkBLe1JIrQXIyAdv2yhRW0h/lgiJZZ08f9dOOhg5TzJiZi1uH/E9U660n53wgITpax4hlkyW6H4tFXHr88HyYW0fMsK1H8PQ+Y8mgqB8W7NVXdf6xtdDQp6HvbzrWuLuKD36nl0wQJMp27KNVkHPjAVl8qFfyLP88QTp0Yr5upysYP4W59C245b7vcmd2rK9tGP7cG9fCCGEEEIIIYTcFgrcCSGEEEIIUbTSXmopdS8BzVLK3n8oOIUODm61Yla3hYKb1k9S62BntOqWXjUsc254K797q8aPCPezq91HK9lHrLkW9nQdEULuz726hKywewuB+hZcq2xLmLsEJHDO2t46nUbXU4q9kSDdEsD3Olp+jLTByGNPJJr3RNSRvyPlov1ZUbvnk1VONLkDTWLI0n0fOfe0wFvmt8oe6UMyvmT9ReeENcFjaVl68sSa43Ev+FhKCMnyXhY8yAq/M3gT/rO+oLGJNW1tLTogy0N+L623t2q8LmOEpav2Wz6Mt2k7/auH3Y0/1to9aqXsWYVPCCGEEEIIIeQqUOBOCCGEEELInEPZaTxzTy6tXfU7u+I7CsiiVbOQgNxa4ctb1WxNWlRmRlSeybMkCO1NJpDB3pFV1ZD9tWkIIWQJ77V72VKAqcW2W4s7PVGztX1kFe2lWAJc5KMlYrdWps74jtKMtP2IMDoSnHu2ovaxhP8ZW5FY3duebeOt2tQTq3vnzJ7wzomlQnR5bXir1kflr+EW/cUIezvuhJDHYunq6Vun91Y+l2ghN/oVPGQ3En5Hv6bnpZfbrbEWT4A+smhAhlGRv4WX/3aLFNRSSrvruKMt2C+lllpa2Z3+nhBCCCGEEELIlaHAnRBCCCGEEJP9qCm6J+8lkpNdAV0HU6OAqiXQ9vJlgrAalMcL0lorzKOfvEb2MtuzAdFsMDubjhDyvNyra8gIdxEUJp7Y8rh14etoHilkRqtMX/PcyoqoUd0sYfOIEHwJS+zJPEvbc209rlludkKCRWZyxog/EffoL7OTTtbYWms3Y5N9NyHkvbBk7MFj5JflluQtZT4WgH6pTqfXYyN6Un1m5XM9tuP9Gp4eM9piLCObzxPSb13W1nkfhUtT1j2N0hJCCCGEEEIIuRUUuBNCCCGEEALBAbN7IeI5q3j04Bdaictb0UuvUu79NLUOgupArF4xHvmm7ejvo6L9bKB0ibgdbYvOj3tfB4SQfXGvLuGaYtM1t8lr3WK3tnst8fWon31F6GuvAG2RWdF7RAy/NVL4v+Qc0HksO9nV0kd80Md2pJwl+yy842Ltu9Z1PHqO7G3l8lL25w8hhOyFpStsj/7Sm84brb5eCp6Ib/2Km0b/IpwWnUfjF9Gv3yHRu1Uvq2wrbbSy+pKJ/2tZslhBxHZjNAtnEG+M3Ubnvzf0hRBCCCGEEELIPqDAnRBCCCGEEEibBE7uLQzvpa91Y4vg173aYslPT2fyo9XU0fZMcNkrE+2zViXr6J/dtoLAfZ+1/drHTAajR/MQQsg92HJl4y3y3sPu1mRW1LbSb32bWiK2l1zTtyxS+I/OgZH27TaQnez5hY6vteo+Srv2PI7yt4FfE/AmuOzlerOOl+TW5+ZWbbN0ogUhhOyV0fft6B3dE6ePlGf9et3SFc6l32iBAG/8Avnh/SKetWI7KtfCazM5hiEF8do3a9GDJTzKGMgevTw9d/JhgRBCCCGEEEKeEQrcCSGEEEIIUdRS2+n/637K+RrsIdC016AcCrRmVuvq3/UKXzLIGdnzfMr8ZLf2SeezVo/3fpo7sxpcJNxH9YnY4vzY6zlGCHl8rrFy+2iZz6LNyKyQnkm7ddlLyh8RTy9h6er31j5LeL6UtRNCsu13q9t/VJ/R1eqvwb3b65rn+5qJFoQQcm328C6aefcfWYE9IwKPJuuPCskz4xZ6mxaZ97xo4QBr5fZMfbz8CC2Gf5+0079aV/9y5Nb0Q/V+254QQgghhBBCiAcF7oQQQgghhChaaYdSSm1GWCcTJNzcox7Eu1GJ9ya7MpO1wlaUBwVI0Upj+qe/dcA1WuELidT1CmFRG0RifL16vF6BfsT+iNg942smzzPBgCwh92dU2HoNcTC7gtu1wZbHb0/HzVvRXa/8fa1VwEfP6+yq+GuO2VbHaMTOtc6La0+qyJTfWePHEz7uEUIenFu+p2bf2TtIYJ0RansCcz3JP+sb8hX9Sh36Z40fWOm9tFnfvO/dnvz7bLRWTuL2O9+3cfufz5fD/sT3hBBCCCGEEEKuDwXuhBBCCCGEaFr5UEo7LBf8bB8Quwimy3MIRbIrr1v7Mj/3PeKDJYLv26zy9KrwOl/kmy7XE6Br4T1Kn7Eh/dSi+UzbbSEI2OL47ZFnFPUT8mhQjP6+yK48numeozTXEmZ7vzog9219ri5ZVT6L5+ujX3O9Ha65cv6tWePHXupACCFryPw62pr92TSlxO/K1oR7TyyuJ+5nVmxHYxx6TMLyPypjZDJ+hpFxkWuy9/GA2koppV79lyMzvzqg07dSSm21NuoaCCGEEEIIIeTp4IsgIYQQQgghcyoMqswTWZk3dWbPYrut6xqJ1JG4XK9gnrFt2c3m0wHZ6OevZR69zfIrKybPiv69n/L2tuuylgaC1wT9M0F2Qgi5JjvXo+yK99pW3qrp1v5rldu3b1FmdhKA5toC+2uy1TmK7PR2GGmPa61oTwgh5DZEq6hnxiLWjAvIcqxfdMu8z8tfi9MT3nU6yyb6FTuvHMSSBQ8y++/N7scz6m1+NXLRcTo99760dvywvUeEEEIIIYQQQvYMBe6EEEIIIYTMaaeoTn6lbyugN1YoZiL6XmT5emR+Hnsr23rfqGA9E8jNps3Y6HZkUNhbzR2toC59ieyjn/GO6uIxstJ9Rry+JhitA+2EEPKsPEIXuIV251r1tOy2Nhdse+n79j3olLI+b40lsM+Wf89zeavjZv0SwEjdan3fK9oTQsh7YMk76JrJ4VbZGT/kAgDWhPfsmAESuaP3/+gX37Qf2RXgUdkyD1rpneMFy3h7to0Xb7gjbX+jooQQQgghhBBCrg0F7oQQQgghhGh6YEdsaq1dfqhXB+S06BYF/vpP6iaKnTAPJo0Hc24Zjlob/BrJb/30tiQb3IzE9Oi7PuZIpO7ZQnm8QK8lYJcgAbzchwT2I22HguCZNt7qp8Wj/DsLvhJC3hF76V724sdSspqjrevZxeuRkFjvX7q6+RKW6rGyPt+KbPlr/VyjX1ub15soIf9muPfxIoQQso4l76CZ1d3XvvdmJph7AnL9a3nWeEe0PbOiu5Uffdb25f6txgOeVSSPWu8ebWGPUVHeTgghhBBCCCHPCAXuhBBCCCGEGNRZ6GS+qlR2pe9a36wNBd3QzzkP2nnkAFAUTMusHJ61OxoMHRF49/RohTErrbaPVijzfhrcwvp5cS9tJLofCXqOpKVgnRBC3hf36tat1cbJ43KvSQY8jwghhEgy79MjeZbYtVZkt37hzRsP0WMRSARvjYehsQvPNvLhGhPin1WwPkJrZTcPOXgc6raLdxBCCCGEEEII2Q8UuBNCCCGEEAKYSduR0NxZfSrKZzELEOr95S2owyDdcqxjtESovSQIi1Zuz4rudblecFmntVajH10ZfgmZn0DX+0avny1XiieEEEJuyZrbVuY2zcfGN9auzN/TsU3X4a2GTwghEXt/3/ME59l83jZrn54YH70jez55QvfsYgTeCvVoTGQP41x7P7euwandT79bee8jgM67Uk5+Pd+RIYQQQgghhBBCgTshhBBCCCFzXpDcIr1i+oqAnCt+L/cPNN2S7IrkW7K0PC0m79/RympWgNkSdlui9J7OC2hrW1abIn8zK58tnRAg0eL6zK8jjJQny7kXzxggJ4S8H3agMxrC8/fR6pIlc5u5161obZtvccyuddxv2abv8dzlLysQQtawByG0h/dOXor9np+Z5K3HBKK2sNKMitVR2XK7FPLr9KgNUPlLhe7RQhJ7P1/2xC1uzcO/htkobieEEEIIIYSQZ4UCd0IIIYQQQjStvJTSDjp4Mgm63dajU/kXP+5Q+B24lSh46cQFT3iOVkSPfsa7f7YC4dbKalEgFwVzrRWxrJ8M91Z0GwmGI7yJAO9FGL7nYPp7aWNCyPV4tG7C8/fR6nINbnlLqnV9m29xzN7Dcb91HXb86EIIIXdhi/em7K+RRWX3d+XoF9oy9jLjEdYEfitfpg7STySMzzDyC26oznt+T1/CJufoBn5o0Pk40vaTX7Lczi1CCCGEEEIIIQ8CBe6EEEIIIYRYhMEhvIrV4uISKd6BPsdk7cr3tw5OLikvG/T1xPP9uxSAW6ui658nt3zSAUcdGEdCe2sVN/0drfoerUonfdZ1ROVbZSP7S4Pn75X3FtQnhDwWj9oF3drvLcu75e2Pt9rH5VbH7lH7AELI+8QTYa+dgK3fn0fE2ZlfJ0O/KIfSe2Mn+v0/mmC/9a+uaV+yaZbafm+sebe/jJNc/rcdI+N13oSHWksptb7Pg0cIIYQQQgghxIQCd0IIIYQQQhAg9jIJCpZlwg83kPZOg2xZtgoWXwsdFB4pUweIZYAvWlnNEoOjoJ8XqLbK8n4yHPmOQCL2aNU4i2hlL716nK5bNnD6rMLu9xrMJ4Q8Jo/aJVl+X+vW8qjtREgEz21CCCLzzrL0fdPDevcefXf0Vqwe+VW26B0cic1HxelojEKmle/23i/VRXiCe403mT5L9hwikn20h3NOHdqxfbilL4QQQgghhBBC7g8F7oQQQgghhDhYP5nsiXC9QKsXvItX9y7lUJ9XCBKt+p0NTnormWexgsDZ8qMVyJGA2xLFe6uzybyeHUvQrvNZNqxAN/I3swI8yoNWrZPbl4gCHpU1dXpWYT8hhFwTdq2EEELINqx9r78maKK7JSS3JsWPjCFEk7rldlmmtQq7NQ6RHe/S7/iWwN5Kj8rNHG++w16f8+roBa72cVM/zudL0eNUpZTWDsd2fLmPZ4QQQgghhBBC7gUF7oQQQgghhGje4ilmcK5/11yCc8EqVJPiNvyJZxLjCcuX2kICbCvYm1kJHQV6UZBZB7C1H9Y5mhGUo79WcNoK0ut6W4J0a6U4D1QmCt6Prrb/CDDATwgh+6LfZtbcbti1kz3D85MQciuWCMC3Zsmvl+l83vt8JCi3yrQE9noyetZ3y19dJ/RZ+2/9ytpIW1qsfZ9fsjDBU5NsqpHjMnoEK7J/Oo7va3CHEEIIIYQQQkgIBe6EEEIIIYRAptGvWuskIOOtAu4FzlI/k+yktXK/NwEvIhJl3wsrKI2+R/56K5Jnhd/RaumeED9jV6/YNhIojn5+3Nrurfrm2Y/E9JEvezi/CCFkS7bS9lxTI/Ss+iPecsie4flJCLk3t3w3W/IrbSif9UtpcptXL2sFeOt7RmCPJsYj+rt+ZuwrWrTh3gLz7Erxe+KW/l7KGixyaCwoKlt8f7RjRQghhBBCCCHkulDgTgghhBBCiKaVj61Nn5Vba+4iRrMATBDUa62FsaNJkLCUSUQou9LX2v1kHVlhtSQ6tlbQ2gtSo18fsH623PPVEspnV5zPBOj1dinSv/avHSwV/3vwGiOE7ImtuqRrdm3sNgkhhJD3w9Aqzxus9r2VH9lffrPe3zOTu613eGs19pEyLNF9th1kG0SiejSx3vMp2r6EtTb2tsL7rfzJTHaQabcGjRN5Ez9qdnl5QgghhBBCCCHvBgrcCSGEEEIImVOrkJObQTqZQW5PrAJdqx2WQdur+qSDlZFI2GJvQbz3hreCWin545Nd+dwrw/vZdL06m16dPVq9DfnY06PAuBWwzPgm7WdFB/fkGtfYnupHCCFbw0cTQggh5H1jileDFc2zNrNCcg/vV8TQxO+lk7HRxPOtfnXMW8Vdkilv7a+3oUnrW7J2csSzvmO/nXvnDU4zXHv8UP+i4fSaumrRhBBCCCGEEEJ2DAXuhBBCCCGEGPRYSv+rBcITUXuxA3+XgFFP66zQnVldi8KvfbDV6t6WMFwG96MV0ZAvmZ8uXxKEz6wwb630LvdHPmfa11sV3ruWRn8Gfm9wYgoh5D3zAN0wIYQQQpJ4731bre6+RXqJfs/Uk7aR//odGL3D63f96L1Vlu3544nQs5PCvcnoGZ+0rZHJ6Nd+B19i/+neuWstpbQS/9bkCev4X8aLSjxmNDmnC7juiqu3J4QQQgghhBDyJFDgTgghhBBCiEXrwnS8evYl8KLEuvZP6U4MpFfJOifve2bCrz0LcvfsW0QU0Nxq9TErUL627SIhOirHCprLACQS4Ee/JCCJxACWj0sD4aPtuHTVwCjP2v2EEEIIIYQQ8t5Z+ut0HWsS+Vo/kHA88+6IxO7ovRsJ1r2J43o/2mfVez7ehH2z0kTw3fY2bNnOtbVSSi21VFNV7p0bM3sFTxSR+cLrsrXJzNcnm3JACCGEEEIIIeQMBe6EEEIIIYQoLisW1cmf2Spbl0Cl2C/TvdkDRCuWzYKpJ0Mo/rPnlaX27FuEFbzz0qwtbyRobK0c59nu+dB+NzjpBCCl39Gqcnr1ds8n6Zf3c+jROYZ8z/7k+9Ljm5lcoHnka4UQQgghhBBCRrF+7WsEtEo6su3lt75rkbglOLdE9dkJ4J7PenK5Lh+J1S1/o7IQkcg++z7+aDyCSH/Ltm3i/1F53viRNzHE+nWAWuts3PX8ReTtH8KqEEIIIYQQQgh5Z1DgTgghhBBCiKKWWi7rBDmraCFx7kzQq7br9LYP1k83D1bG4RECdntiifB8C7Ji7GxeL8iN8mZXpdP/ZN4o4B+tFof2ZYiE5uavLYjJLBn7KL/8qz+vgdctIYQQQm7Jg2oTCSEPgp4YvcVq69I2KkfnHRG5o/z6vRXl1+k8gXpUnvZRvnejtDo98hPlQxMQRhkdCyPbEi6GcP57Ojb1suBHZuK/PLeHfCrzc2y2QEKZatnPi7kfjsfjh6HCCCGEEEIIIYQ8PBS4E0IIIYQQMudQazmUs0DdWv0araT19v28rf+krvGzztHK1RNbpZRDnaaxoAj2fixZdW6JiH1EcG991yuvR6u7e/b1Su4yYGn9NLXlY5TGm1xi2UFid0scYPmk7a4RsOMJLP65kxHdLymXEEIIIcSCjw6EPA9rf8FqSbqsQNZ6f4omZo+8T2feU608noDces/LioilP9G78Mgk7eh9NiOAHzmm3rgDuQ7hCvuXT6djc0hMFrFse+fz5Hskuj+PozYxlnr+cyitvLiZCSGEEEIIIYS8OyhwJ4QQQgghRNFa+1ja+VkZBGwiUe0pyKeCPUYgzwp4TkW2dfZDwfJ7ZhUy6lK24RorcpcSB/qtsiIxQDaAjALlVnAfBfCtIHsUENe+RnUZnTzgiew93GDsQjJiieh4bnHOUUxACCGEEEII2ZLsO0ZmpXVve/RO5f1qmN7v/dqYZzMjtJdlZ37dK7MauywHvdt6q8OjMpFt/dl6Z/Xej63xBKusyA65Fefjdlrm4+04Fv86Mq2BXyjQ52+02MLZwOVPrbXUQ+XwJiGEEEIIIYQ8GRS4E0IIIYQQ4lDLOdDirHqtt5cigjNAsIoCqVDwW6QwvYn/l1KjvHp16YmVNz/IGLdYcUwH/GS5Mk3fHgWHrTRITK3rh3zp6aQPKOBpbdN+jQa+LRF4ZgW7zOqAaBLLksC+598Ia8X1a1ZTJIQQQgghhDwP9xojmE3QB+/do+L4bLm6bO+dUe6TPlpjMnLcB40foXfkbjPji4X3a2HRgg2Rncz+EWG9ZMQ3si3z9m6XldR1Om8hA3Qd623Rrx1Ie2/XwjndkecFIYQQQgghhDwbFLgTQgghhBCCEKsV6aCOXoXLEpq31ooO5UVB0J5G5j3lqWeVej25lliRm1yPaEWzLN7khyVkVrCzAuwSK7hoidmjlfWs71JQgIQFyIcssg7os5Xe+j6af9RPiyXX8hIhAvsMQgghhBBCyK3Ivveid1IJEtUi29lVp5FAN+Ojfoe23sX1d+u9U9fFWrkdlbH1u52cwJ5517zX5G6ynir/ryZ0WNdGdI3KfRO7/bxSZZm/AlAvrhFCCCGEEEIIeSIocCeEEEIIIWRGLX2t81rwSunZoCdaJctKJwNB8/QyYGrbQGVLqpfe8s1z/ImJgtER1ipva32Sti3Rtic4t8TPGQG4Lhud/95q6DrIb+WTtpF43VvlHYkWvIkq3vfMioK9DItrrUTo2R9dfZ4QQgghhBBCRogmGaOV0PU+bQvtQ9tGBdb6PdQb70Hvzpn3zNFJxtbq7hky7Z3FEjhn33/53rlP8HFpYvxv/qt2o2MhaIzlcq1NE6auv1oPnJhPCCGEEEIIIU8IBe6EEEIIIYRo6uV/BQV1JHCVaCNtKTg42Fq7BHTKeRWjy3ZhR4vTvRXJUABK+z0LAsOUXCDpWmRXrOuMrl6+xcrfGXG3npyRsY9E8JbfKKgf/XICyh8F462V/iJfIrLtk/F7ayzbS8qkcIEQQgghhJDlvLfn6cz7mjdm4eFNNEcTo1G6jOBcv5N5eWUeSxSe8cHDy+dNJMisqq0/R3bXnq8UKufZqm9AYyJT2/2XLNtlXFOO0Xh+WLZrrRNbl+tU5Lvk7fnE5yq3EUIIIYQQQgh5SihwJ4QQQgghJMAKpIysWKSF8LMgo/h7WT9e2p/8UHC5/JRvUcFGFNTV5Xv+ojzktsif/5asXQXNClZnVl7zVtJCK9Xp8qJV+zwfdbkWst2islDw1frr+ZKZpOCJCTIr4F0z8L+l7S1ssc8hhBBCCCHPynsW/Gbrlp00HdnzJvzL9z1vdXadJ5ps7Y25eNu88rZ47x+daH0r+O6XxxrLGWEyjlHUOXlZrKPJDHDVdu9XCcwxK8tXJXa/lGNsI4QQQgghhBDynFDgTgghhBBCyIz2oZyflScBHvCzugUEIosIbKJA5uzz+d9EnNv/dY+EJzLY07dZYmNUJqwxCJ5m8pDrMBLMjgTZ0mZG5O79FLoMtOtVuWRa6ZMn3M6uAGbl8c536/qzysqI/WWaaCJCvDrashXhPbwAs8ar673ENe9Z1EMIIYQQQsgjkxWfR6t9j05qzoi/LytFi3c2/S4YjZN4gnhvvEUvYmCh35+tCdronTF6j48me3t13/qdlPhs1caj786TiRkFXxf18l/wq3cJf/TK6+5Yy1sBMxvTcR2OGRBCCCGEEELIM0KBOyGEEEIIIXMuz8m11EmQpQdzLkFJsb2UaZBRYv20bxez16KCwXpVsXYKMzVlUwvse55J2c4+uX1JgIzcH2uluGiVOM9etOJ4FIT3yrKulcwqYKhsqyxpT5apr0PPT8tXr3wtFEAr/Vn1GsVqm5HjFNkkhBBCCCGEvB+WPu9nfpkqO7k5846CJg57aJG5JbjN2rKw3vPQO5i14vVFKGxMENft403GztQrMzGb4zu34V7t7E3MmGwvZSZgn3yv81+StOyfP8x88RZpCMZqDq21j7NMhBBCCCGEEELeNRS4E0IIIYQQMmMqXL8EXfpnIxgrg5GXldmLH7QBOy5lTeyL5JOfEy4FBkwn/hlB1KWgYOuSvOSNrVZNy4q/NWtEDvqvrotn2wrUo9XtkABAf5Z2rX2ojVAZKL8XiLUCxluRPa46ILzFxBVet4QQQgghhLwPrv0rUpEQO3oHRNvRe5n3joj88vzXdrzxFfSeZy5mAPzx3reiNEjAjyYLoDRRe/Cdb7+MjPG0Fq+w3oq6roxrT447dht6dXdrgr2e3CF9iBYaEBmmvrdyaK1R10AIIYQQQgghTwZfBAkhhBBCCEFIQbmx4tBsVecyDUzq1d1REOgSmO37UVkX+3iV7KywFgWYRoOYus5ohTEPrgqG2TKYfI02jsQC/byYnP8Dq/chcbnc7wU/vYB+/yyv10g8YAngpZjBE3FkRP0jeH5aooZo1ULUZh7XvG4ptCCEEEIIIWTOLZ6Dt5gMiwTopeRXjLaE79mJt1E69A5nvdNZ76OWyF7asSZKWwJg+V2+v1lie1SvqIxrjTNwXCfP2iOAxh0TmUxbcqxSU2uZ7ZOWWmuX1dut6x6VNynbGY+c2et5xf5aKwcICCGEEEIIIeTJoMCdEEIIIYSQGUbQVAViZDBSi9NHAn4ySOS7VEsp9c075dNlmyh/yYraHtFqbNeCItcckfgafc/ajfJng5UoGCq3jazm1/dpAbslfI/I1i3KK+vitcna89oS9GfyyPRL/bAE/yOMtOtS2H8QQgghhJBHwxNQW2z53JsdN7D8Q2LuJWVZ5aGyLPG4nuir3yEtgbks05p4rNON1FvXyStXp0XpM+92S9+vlrxfk7lgXDI62byPHXoLEHjCc7RvclzL22goWoSjL87R83kLEVgs2tfaxDdCCCGEEEIIIc8FBe6EEEIIIYTMMFYAM0SzOtA5CZ7KYGqxV5y+lIwCToZ3tf+T4tbyFoS6+CfKLmVcABuB6rU5XCFsMVlR9ZoV2aIAKlq13SO7Mp+3gqC1ijvapv9p295qfiP1Qn4gvNX/vLQZP7IrLGbQba1XZ9sDe/GDEEIIIYSQUZD4Oko/Sub90Ns3WiYS7VvvE96kaeSHtUK6VYbcJleYttpar44eCoYDobv0Qf/18iG/dHkj+dekJ8tB544n5DbF6+o8zmJe+6ed09XbA5/khJGeXi+8sfTcuuTjuz0hhBBCCCGEPCUUuBNCCCGEEKJp7VBaTlOtA6L6c5HBVEMIj2zN9zfxD68spldeEjvgKk/SDvIjSxfVby2c12U8AlsFgz3h9rXsL1mRTQsTotXuPD+ilbwaOIez5cvyUDta25HwAgVvdZpMnXpaT+CB0nvftZ+aJeIVRFbIP5LnWmx53RBCCCGEENK5x/PtNd65t5j8mnk3kt91WpkeCce1UD3y2RLgZyccR3Yin0beCXt99Tuhl3+N6H3JZHOyPeZxjY4P2FbL/BpE5cG88jzpw5jIVzXWoie6z64/MEYaTcQXX7QDs8U9CCGEEEIIIYQ8DxS4E0IIIYQQomilfMwqqs0VuYC4U65kpPOKsg2q+Df3oZ0DPnrVMctX5NesDkY+U1R/hdXkHo2tgsGZ1cK3tt/JiKujY6mFA9lgvz5/rfNRpovaCq3UZ5WP6qavp+g4oD4hErFb7Zk53qPHxdtnlacD0t6KhoQQQgghhDwDe3323eKdMTsukBFLZyc8o7Lk+5T1HqnfDfW7CiofCdL1u9voZAJr4QD5bnyL9/lepjlWBb6TPJtNAHDeqd2jY5xHaBL+W5bz9aS/G9dX96/2ctS53PNo0Xx2IYEQfW2Vt7FSnrmEEEIIIYQQ8nxQ4E4IIYQQQsiMLkQtU6G6jKQEQlFotQdpHBFpacbS8bMFjECwcmA1Z0sUnNmWES6T27K27S2xANpuCQQkOg36nFphTIndUZ5MENUL7mfSeMJvWRe0Sl7kcyQ6t0DHAbX7yIQUb3KDV4eofTzbo0RCEkIIIYQQQt4TI8+/1/z1Iu89Sr8bWCuxSzt6vMIThHvvHmhCMxKU6wnHWnyv312sCb7eu6Ke6C3L8Vj7TjM6gd2bcMBxHR/vOmjqu94/sePYsvJZ15RXzqW8zLjDRQFfpmOT3jgCEqMbfYLnS+4c5ss/IYQQQgghhDwjFLgTQgghhBCiqOf/SinT+Mk0WjXLNwnIyABQCQJXeh8IsL6tWSS2iZWdrICrt4rYTHjbg7ginyWOv2bQEwWYiU9mBbcl+bc8Biig6YkTLGGD/oxE1JZQoWOJJZDPyGZG3KF9sFY9HxWBe9cmalcrkDwaVPb8G92+htGVFQkhhBBCCJHcahXtreyvXX37Gu96aIIvemfTdYjefbxJvEiALr9bE47dMRDDD2u/906o30+z73kjxzObdumk4IwY/9lxJwc4+Ube9dGq6HpMQY7dede4HqPQNifndDkPT9Zy+YXIqC6z8UcwkUT+1Z8zXNLX7h0hhBBCCCGEkGeCAndCCCGEEEIUJxl5m+nO0/lB0DQM4EQrZZ2zH2QauaJS4I8XyJ0Gs2q4klR2tailgdGlQVticyvxhcS7BpCwHU3SCFc9c8TbGUG5toXEE9I2Ks8T68t/nghkBKteutxO1AZrxA/3wBP4E0IIIYQQErHVM+QjPYtm3teyeTNjC8i+9Q5iidq7Df3cjwT00o73nhC9S6HyvTSWqN5Ka9Upy5IJvhw32ZbsObS2f9AleBMz0HhF/64F8v1zK/NzsZXzuCAov+eTf/VnK/0amvjQWntprXxcbZQQQgghhBBCyENBgTshhBBCCCEz2jl4MtlyYThOJQ2hzOdVjjLBylbKaTUlR8QaiYflqlDNyBNhiXOtwHPGnv5urZSGynoEHs1fyZZi4uzKZZ7IwUoj0+kyIxFGtOpZ/yyF8JZNa0U0VI+RldxGsUQl1nXqHecRH6K0S+tDcQYhhBBCCHl0ljzTrllZO/uMn7Vvveeb4w4Nr+6O/IsWCtAidk9cjt73rDGXKH/0rpgaywHtMsrIavNb8cjjGNfiWm1yuT5auyxT7gndkRfRpIzWzgtloDG2UvTvRi4H+IEmq4Rm+v/OXcSxNJ6QhBBCCCGEEPJkUOBOCCGEEELIjDqLFMmvmTgkChTJzLOgDgrMiu1vdpq5mpJXfi9nEngVQbPRlcx0HSyygT+z/L7tHQRVH0WcawX8vZXPR22N2Edpl4jCtfAgu4qhXokdgcQVSLixlVDdqoM3UQRNGvHyej5EoozouK8R0VNgQQghhBBCOqPvsHtgVGDt5fPIrKzsTVC3ROn6s7WiusXSydOZ985RXzyiSfaRGD+b1nu/tSZQez5vzd6unz2SHstIpJmJwBPpo8n/XdR+GdcQeSfpEv7Jcl26kD4Q3BvG0cZSCtXthBBCCCGEEPKMUOBOCCGEEELInEMpdRZTiYI97kpJ+rsXABMC9Lmavp42qQCU/rlruU2vmJbx21p1Wuax6rQ0oIwCwJf6GX6S7ckKyGV6a/vIKoCZNEjkoc9zlCY6ly08Ebh13Xg+ylUNtRhEl5ERoOv8nnjfsyP3jQjfPcF8Fu1/trzI1si+pVDsQQghhBByX7aadB09120hlvaIBMz6uXuNP9GkX8s/Oaaw5F0IlWfVFdVXj2no7cguGidBYx3Wu6b8q+1G75U67ch7p96+5Hhz/GR7lkz6n6TbsFxvQr08x72xkPPG0yIa3ru03gDGA+3MeNJMNk8ppdTzMh91cQsSQgghhBBCCHlkPtzbAUIIIYQQQnbI4RTgmW50QykrVmcuBRSGilBO6FWWtCgcCWizgVMr4D3bDlZ8Q4HgES6rS62wQdZxTeGuFkdY5Xkroo8ImSPBdLQyIRKQZ+vg+aCvlyXCeymYRxNErFUDUbmWcAPls7ZlVh9E25dOqsiuajlqPwv7J0IIIYSQ58B6ll6SP0o38i6mfUHfdfnoXcbzOfMOINOjCciZdwRrAnB2TEPvy7y76cnHWiRslYfeIbPvnWT/WNd4arJMyQnZvX5k9r7uvPMjv8x3bLH9ck72sTd5fqpK1FpPQngx5lhLYhEQkKaXOUZTfwkhhBBCCCGEPBNcwZ0QQgghhBDFRUhe8+ETGJ5JBm1moRoz8DmJMGFbrZ3yO0HkNxPz4K4O6lplWCuxTba5pV8yXtLK9MjzVuZBYwaJ74snVrDwjmG0IjhaFW+teDkjUJfXBfJfB6D1d3ltdXtSwIEmhqBVBdF25Iu3LbxuHREKmnSAJglkr0tLcBNh9T+effYVhBBCCCGPzchzpszjfe+MvE9EaS0/s75n3uOtdwfrGT6aTDsqILcmmva6R+9oMp3ert+d0DZUtkxjjXWgd7W+32oj/a6SeQ9BdbW41qRZvv8sx3v3jto1ezSH+pziT/Swzmtvssblc78WSymTn1CU6PwD7/vw2h0+N+t59XZOMCeEEEIIIYSQZ4QCd0IIIYQQQjQVfnQZXoF4mtksa2JTLn/krGpWzyswwSBXIFrNCEJRMByKhJMChNbaJFSF2tGU/F8pGJwt/5mAx2WByETnl7YtgYNOb9nptoauRUNIj0Qj3gSQqB1kW2mBuPzsib4zK8lFYg5P7J5pb5Q/I1BH58pW169lZ1Q4TwghhBBC9suSybWWEHsrokm51rN3ZCNTnves7k1a1e8loWAXiGbRhNfMu5oec5DbvPcWbStzLniCZGviw0jarRgdSyK3A71PRhM3NirYHIOKxuwy5zbut+x9vTzLXqZNVrVNa+UswafEnRBCCCGEEEKeEArcCSGEEEIImTG4InX/qwM2a4NbMGAlAl3JwJoWnc/STorEq5N5AauRfTpQ3RKBXCmAR8Fz1MpbB52ll8+6Etraei8NBI+WOyK6R2Jyz8aIQDsOIMerLXp1sVYmjPxF+bQ97aO0h9JlxP1LJh5kBDxbXo/Pem0TQgghhDwr13rH2XJFeCstmgSLxPV6Iq1Mh9Jn62SJ6ZfWB4nfUXk6rbUflRG971jvStruEkH6TYTRZFOWHJfMRI9S7EUU5PhXKcY1r9M7E/HPGSc28LlY3xbVAGYm5/6C8YDV+EOAhBBCCCGEEELeMRS4E0IIIYQQoqiluCGTueR8YRmBXUsgfwl2BYEzFHgqQuDaeto2Xdm9CRsoaIxWVItWrkPbe9lWUNtCB+Ssle+vFSTm6mrL2GPQPgwEF3/lceu8j1Y2t1Zql2WifKhMKWiJBPhWXbLicSutvoa3WinTaj+9yuNW7OXavvW1ssdrkxBCCCFkD4w8J3nvDUvsZbF+4ckTsVv5eprMOznKJ98XRsTg0XN9dlVpKy8aw9A+eu9u1rscSjtah6Xs5d2FvGH+akIBkykKnpSROYcy44mT8UBv7E6W187fnVOrC/BX49XTyVVKpa6BEEIIIYQQQp4MvggSQgghhBCi+PmXX+vh5WAGjfT20ZXKrKBXmLu1Umq7+DEpH4hKYeCptUteuU+uji5tZVZn7+WgoN0sj2UDbEPljISE1wR8Kfhcx9pg+xaC6Gw6LciWq5yPrj6IhOtIdOEJx3W5lhhD543ENKhOWpxhTWyxfF1CRjCDRPLaB1Rvy3Z22xq2tJc5725dHiGEEELIHln7iz6Td83ERE70WaYN34cdUbn0I1MnT7DtvR9oEbrcnhWj67powXdmoq3XntG7jayHnvArJ8JmJ96i9o8mQ0fveUvOh5Hnco5ZrCOaFFFKbsL4mvKs9/GMj6fxwamIXZ5zphC9l9nTyjK6OVSscb0vpVtrsy1vC8nPyq7lUKhrIIQQQgghhJCngy+ChBBCCCGEKH76+ZePH15eZtuRuL2UnChU2lgaFGullNLwSmly1fVS1Cpi6nsB/rpCURkgQyL6c1Ctr0Cl6zjxzQhCV2UT1bGey1jKrcTxz0xmBb0MI6v9oXzIJ7QdrS6IRCGWeEOXvUSYov1Boggk0EDii5EAuc7r1W9EZINEQqheKG9k22of67tXj7VCfc2t+4x79lEU0xBCCCFkhGs+O4xOSl1iZ62IHtlb6ov2J1t3+ewv/3r+WO8VKB96DxwVb6N3E1R+5J+3LSrf2pYR3GdtWvs5BrEfvDGE8Dzuf+WxdWz2tHoSt3631ulP44NiLE2N280m3+vyez8yGzt8q+uk7m6tY/SVcPHNTDFJfPaplLJuWJAQQgghhBBCyANCgTshhBBCCCGKQ6312ANGgkwUJQqhejZS4dcqVmB/izzNbclArF6VqSSCvTKQJgJfSOQ+zVbfgnc6oKbSdfv6MxLRy89WYCxCrgJ1S4HCM7HJSl5KbD26inrkk7XiuUwrz1u9QuFS0b0n1tDCBjThBNVF+6MF5dG1qm3q+o4KZrQf2pYnpkF9gmVvxBfkh96OysryjNc/xTeEEEIIGeEWzw5Ln8n0pEwEmmyKJnVGvljP6NZze2YCLXr+HxGK64my1gRYbVc/n6OJtHI/Qtq0/ItAz/mevRH70XEcEa9ny3vGd4tr4rXn0n5JLy4hy+njZ90+GruaXNdlfg1Z/cOkTDRJHfQXkj5OZy6AMUm57tpBRGOh3vhr31/LNhOaCCGEEEIIIYQ8FhS4E0IIIYQQomjnVZB0QGWWDmyL8sDyet4e2AoSz8I5OtCEAtmGuVmQvn8HQfbLTwhrMa7YLgNql9zJoGJmlax6Fut7K5157QdX4HfSZ1gquiWYLUQI3rlk4a3YiP6i9JmVFqNyrG1ewNvyISPij3zoNrPXqkzvCW4ydbFsR+lGgt6j55fX3mvxRDRb2ySEEEIIIVgYjZ7BM/nlNiQ0RcJxZA+9N1jPuNYzOppEK0HvJd4zfuaZ0hPpI1G8tq3fIWRa9D6CJs5ak3gz9SSPz5p3texbkzUulilz9h7c5gs4THyyrrtgTMKbtO5dyxcBfv/+ZtTxchDkc1m/QjwhhBBCCCGEkPcLBe6EEEIIIYQEyOCOXFlIrgiu02bsdbQQvBrpVGpbtF6mwaFLAMsK7MqVkwsO2OnvkwCe3NaDzGA1NpR3Yl+V4Ylte3qZ9hI8h7mmNieBdCf9VoyKbsk6oqBtKfmJCZY9axsKbiMhiyXyjsqJxN3eio1e4N2qzxLR9VLR+JKJCaNlROmuKY5fCvsOQgghhJDtV2POPs97qyJH/owITKUY3HpXiJ7ztf+RyB0J4b138mjCp1V29J4vhf26PFSWldZ6r7j28zSf16/HyFvUquMgz9GonDI9F1H5reBxOZ3vYktPbnHGkPRCE94keqv/wgtaiBHBOh+rlHVbQlW2OBWbEEIIIYQQQkgGCtwJIYQQQgiZgVcU6n/13gbS9c/WKu9IpB17oXJ4gSz0GQWAwfZZvqQ42xSX6yB5MYL6hjj44qsKxsn27YH+zIp46DN5TNYcQy+465U3KkiP7FnnacYnHRzPim+i/ZZQ3hKN6BUULUF/FHzXny0/LZGQtuEJ50cmOshyMwIeK2/G/hoh/NJyCSGEEEIega2fa0beAfpf9LyWEYHr7UiInnlO9mxqn+WzaySe9565pW+eWN8T0FrP4922fDYfPc4Z0f/Wz9iaa9t/Zm71NoMWcXASxwZbm4jQ5cIS0GSZ9jFyIYlLHnn9Kr/Dd1Mhmm+tAdF6E9VqBf56pPB1CeZiH0G6NWUSQgghhBBCCHl8KHAnhBBCCCFE4cWqUEBGCq2bSmMGbMRqTTJvVK5cqUna8ZgEe/vn/lfmV6J7a7UmmeYSoJ8laG++avGpIUZF9dEC9llwWooE+j8QrJu6hsUG5PEYncQQCTcsOzL/iDDaOq8tf7RgRgpTvBXfLXF5JOqwBNtm0F3Z89rMWwkS+RSJUnQelNfzPxKPR8co2r+F4MoTNj0L7IsJIYSQ63LNe+0t7uNbiJW999CRSabaltxvPdvK51b0boHeX6xtkSDee47Von34rm2AJsEifzLPtpn90jf0DqC3W+8qcr9XH7I/bvWOkJkornHPHTV25ZYZTJwp5Tx+6IyJuX43tSDF7Lzvn8W1NPmWwGmLETv2OConcBNCCCGEEELIM0KBOyGEEEIIIXNeSpkLveXq7SjQ04zPGmufXvEdpcsEhfrqUEi4CgNaQuyeDQL31aiqyAtFtsFKbDqor9P0NtF2L9tA+i6stwJfkYiXPDZIsCJBwotI0I2+R6sMRoFXb6KFFnLL1Q2t9LpMTzSDVnPUvqO6egIcS0Cjy+1ptHgf1UHW2RPIZAX5HtFx3Gu/sSd/tvCFggVCCHlM9nQ/Ij7Ze236vXCB7SxIuOyVIZ+bLdGz9nNte3jvuZZ/lxWaDVG4/Cufk9F7DnqWjt5hrH/6eV3nRf6humXbQ76vWCL7pRMa0PuK9y7xXvqw9/Ys3VobXuBBp0XnKhKTZya5jLSvNZFcT7y+pKt1NiaHrofLOF6vn/YpMQaHbFfwqU2+lcl2iHd/8PIF+zqHQy2vn1/fx8VKCCGEEEIIISQNBe6EEEIIIYQojsf2UkocgJFU8C+DDhjpz7r8yLYUll+CVf2vDHzLAF7S11lZpZtvZvCuSAH9W4LZ6nUSS3ArP1f1V9cjE7xeImwgt+GaxyMbFEfnYSQukX8R2Xpl0lmCGBgsL/N6W0IWSxhkCdAtQQgSlyN7/XMkctftiwQwqN6yrSyBzgjI9laCmCXn/Wge65xeY2OpL5bd9yIwIoSQZ4LP0u+HSOR5y2Otn9+yz9vo+dabrIie7TN4+fSzakaoL7dbz8ayjtJ29Nw/Wh9dnpfOmyQaTUqQNkefAb300XF+FNY+6z86szGfBQLzybVx2jD7RULrfbGIdNb7dOTDJd15bMx9f5X9nfg+8au/g3db6l3aFZHrsvt1etmn+hq3duNcxhALHuv0M9fy8eOH8o9v//mysVuEEEIIIYQQQnYOBe6EEEIIIYQodGClqb89TRegrwkhWqshabtWsGeyHQjJpU25mlIPXWUEoijYJ/Oi4L0U10shvF4tSwcbUVvK/JpMEO9iO7Ei114Cwnvx415sITy2tm2VT4LEK0tFFdYqjd515gXi+34kgtGrJsqyLN+s7VpAkBHISP+sleSsellC/mw+JHyy8njfR/yM7Nziut9CoH8tYVtGuHKrvvHZ+2BCCCHXZc/3mS3u89nnuaV5LSwhuFVG9lkavfPqfGjCqLYTiWgz9fF8lH+9ennl6DbJTkDU7xbIhq575v18lC0mtO6JR/R/zTV8Tdp5bEoKx7Og6zZ6n9TndxVjYV6/BAo/7ev5el7Qx0zsge2zVN2fXs6q0c0EvS16mdod9Xkmgq+1vL6+fryOc4QQQgghhBBC9goF7oQQQgghhGjq/CMSubd58rR5L2xUwWcRpoY+XOzKAFYT4SkV6I6CyLPAUs8vVngqKmCNsESzlhi+rz5lrXiHRAVSvD8RvMt0RvkRWwZm1whltyz3vbJUMPwoq/uN+mRNXMkKri3RuiVaQSIeaUvuQytrIrxV16MV9rRdWS4qJ2LtpAuvTfS2kf5p6Tke+bJXbuXrI7XJHtljH0oIIXviUe8z2f7dEjLrNGjfVgJ79Hk2aRt89srPPL9a6XseT4iOnrnRc7acoKrzoufzaPKqly7KK9/bkZ8RI8c7MyH3UZ5BHrUPyDA63nQtvL6lgm09j3cOZca+zPdtPcEleles9SSKlzaMMmUeYXSexsgL8fpCY3t0XMP3UmBnVudSH+MiJ4QQQgghhBCyGRS4E0IIIYQQophoxM9/q/qrtzfxD9pU371QUgv2m/mQcGDyBQfks2U1seLUm8lYCDArr05Xk/aCiihgPytLC967n8Bu5G9qlTxQpwwZ25l9o9wreP5egvYjqyxa+dFna5sViPfO2SWrH3rBe28lyF7O6LUkr7/MSpDRhJBodUlPfO+JrKLt1jGM7HqCh9FVDpGoyWP0vCBkLe+l/yeEkGcgeu7bgtH3nqX3EfmM1L+vfZYf9VFP5JRpRyczZiYK9HTWO8SIyDx6N7B8WfpeO+qjN6E2k3/N/q159mfukdYendB7+YzGcoL3LjlW5U0YtyZU6zGnybUDJoJY/l7sn76cdvfPskxtB/R50ieX1qbHJWh3tBeVMjJOiuzosVhCCCGEEEIIIc8HBe6EEEIIIYQoeuynC81RIKVvb+p7z6dXHEIrEcm0aDv6nAXmN0QL0P5E5S8+S6F5sX+iXX6fBOfKW+DNyhOJyrW9WeoFIt9RgWn3NVVGsO+9BrffS722rgcSuKxZjTASeqBVFbcS7Ee+6MksXn4kmtcrVEr/kV20kqX8ZwX3PTG9LDOzYp/02yrHmzCgbVllZY7hknOXwmRCCNkP7+VZivhkj/MW50M0yS8SQmbE1nIfesaK8i15L7P8yT73WWLVSFSdnUiJfPGeLaMJ4ehZWfsY5c34Ie3oz3qbNwkUfR4V+689/6P87G+vy5r2zVzHmUnf0YQX/e6JJmxfxqD6vuQ7InzfbOqXzVT/29R+q2fWk2qgiB58htezWZN5GjkeGqWTInWZB42TWmOjbdHIKCGEEEIIIYSQ9wAF7oQQQgghhDh4qw2VMhdX11Jmonjrs06vBdtRwCiLLDO9epPFJGA+X53uVKAhapXB8Z5G2EQCTymG79svQlWx0tVFxCvqi4KemuyqeHKf13qpgKAUGiu/GLIbYwsx7rWEwt12Riwtr0sdmNfXUcZfLRTXn7U9HRTX5er6WEIgr44yb/aas/zu+awg/qgwCtmxjpv2wWoHy5fsMYy4tUgnY2+kzMyEDUIIIc/He7sPZOpzy8llkXgdPetEjIq6PWFztD96xkOTIL1yvPdFS/itn4XlM662IdNqcbd8hsyI/pGPyPfMMcyKyzPCXeQjyo+e1d/b9U4cVvRz2fNk1t8E+1F+9E48ubZbm9Sllmm/ZU0+gden8U6svWzdHnqPtNomm06UMVvcw2guPb5pCdL7Z/nPMovqPPOHEEIIIYQQQsjTQoE7IYQQQgghcz7KL1X9RaEhK4iD0o2EcScBnYbLgfmc4N2SQLK1apYOzPegXztlgoL6vvpUD1rN6qRWzZIi+EmZqD6GcMDy9yKKB8HMqA1gKyIBAbBjCSauEcB7z8KBvdcNiVE8AUgUdEcC8ZH0SFBj+av91j5mV3v0BOOyDCQW10IA2YZIvG8JmmQ7oD5A2kFlekIilC4rrtJk0o8IkUYmEkRsLb4z+8Abivz2zN77NkLIbXjGPnEvdd5KfLtlfbayNVK37LuRNVFTlin/6u3at8yzl35usiZTWu+x0p5+FrXqYj0fomdVbd8q32sP9B6NQJNQvbbKPnNmy8+CJsAusUEeg8n5aOzPgI65Nwk661OUt6l97Sxudxc8MK4/WKbxnqzHxy5jTGpfL0eOoZ03uj6aAvPEtWW1rtyux08jobqub3W+E0IIIYQQQgh5TihwJ4QQQgghRNFaqa20ycrq1qpEep8MwKDVjCybqcANWOwJrXRk58+FhmbBQpQvIZyscr/UoJ82unm07WilKylSn7oZf58E0HSwPylQ1X5mgrVLg7KjUAQQMxI038J+xrYn/lgqcvbsZYU2GR+ilSVlfss/LdTRE1+kjaxQGonZb3HsM22aEWNlfMsIn/bCNfumPdVzCey3CSFkPWvuBdHE11tyjXeDLcXy8nMk5NbPOt4z8sgzj/XcFwm75bNkJNLXZaE8ervcpm1EkynR8zx69rUmDUb1sPzx/PYmH2RYK25HPmXYy7X8bOyhH/WuPc3sekYTVYxrbeS8RP2hlQYUNt+ny174zhfl8MYsq0iDtntp+ja0vapENVLLE0IIIYQQQgh5l1DgTgghhBBCiKaWotc88gIzUrSO0reCAzZInN7APlh2m5Y5y9dXl5LBLxlQljZVOi9AjmxBdFCtqn0yTQ8kahPCv4ktEGiUYnr072KnvAXmLWHr1G9HhG4E6EcEwdEqgWSMJW1nBaTNiRsJ4bH+PLJS4sh2zx8rr/XdE/V45/dIm0tRDBIEZYVMkSAJ+WnZl3Y8EZS3zbOFVvFD6UfP3ajP8SYOXIuRCT7XwJuoodOtKWOLNIQQQh4H7/niFn3+NcToI2mjfJbAeimj93B9/5f+oOfZ7OTGzLG2nj3Qe6iVF4nV9XMkSpepg+V3th5eGd67UnYyb/YZNsO1nv1IzNL2XfvukBlL0f2TdU2pTKf3M2DP8+FSnt4HJmgjH+D1JcbLUJmtj60toOnPszG/aTpv/BLac75LqvjnpuU4GSGEEEIIIYQ8LRS4E0IIIYQQotBy6zDQovDE7Do4pNOikE07/6+WOhG0yxWUULDJXblJBs9KEFREglYUXBLBPFykvQqV/NvtS9G6LGO2urNR1tIVkHU6JADW4om3qjQcmFRMgn/dvpPeyvso3Eq0f0/xgiUE2oOgwhPoeCs2ZsUpiNHrTH/X5VsCJW9FUCRwyopukBjdExNp8X6mXeVfT2RxDWHdNc/LW0/S8SYRINb4d237hJBt2MO9l9yfrSZeWc8jeyBbt5HJdN4zmEY/+3gTR7OCcW+/J6bPiMB7Ov2saAnktd2McH0yCdtok+i79Xys0+v3Tv0sNHruo2dU+dcVBYsyrz2ZcMt8ZD3etZZ5v9my3D5OdrlmC+7D3fEi5ae+7uU4VO3jVvKdUPdFxe/bwonfQVvVmdfj1PP/dHvF5ZbLwhtyjHPShkY+TxBvjZe2Vko7tpeUg4QQQgghhBBC3g0UuBNCCCGEEKKptZzXa4Krr6MVjKyAjP6MbKAVi2bl1otruSoE+yfC8IHgoiUmv9hxBN3eqlrSr1LmQUAZgJyJEMQ2nW5WVrDClVxtS5YxW0Wv4LYoQAwg63RJBupenCDrpIgwxXVYE4J+JMHB6CptMt+aiRVRPnTdeCKf7OqLpUyvH4QWAnl2pZBHC3y6Lc8nJEjXvujtaBKK9klv13VGdfME7Znt6QkvRp1QH4TyeMdEC0vWio62JDWhR/W9KN+Sa/YWwqu9tDMhz8gtRMi8xh+Ha54P1nPKrfCe3dBna5vnt3cvtgTf3nMWei7xBONZUXlU35F3Ub09O1ESPXchLHvoGVb74R079Jw3cv5b/kcTB/Y28YPsg+jdUvcTa/rPyzVVTmM+pQChtXFtWu9HFwH7ecxJX5MX213k3v1Ivv9e0oNr1vLHMCIHmHJ5sCE41uSNZ6JtWRtWr+H0sKXWWo6NAndCCCGEEEIIeTYocCeEEEIIIURxXriodCm0FJ+DtDOxesdaxaiJv1rIHomve5xLC+IvK0YZdl3b5yBclnYWsksxuGVvIn6X6SPRJxCr93IndlV+FISf5FeCeA0Unqvvl1W6nPxd0D9pIyPAGYokVN30/ntzfw+2xRN6R/k88XB0rEbzjdrT1wkSlEd5IjKiGK8sLZay6mTZy+SxxPye2KqXgdKhPKiMrCjLKsMS/MuykQ0kjEJiqnv0JRlR4FoRVSQsW0J6VUOKvXbNHu6fhJDrs/RaHxV8d7zJh9fyQ2/TzyCWiDoSc+vv6HkLiTi9ZxZt10tr1cF6l9ITK61nso71vCfFtyiP/m75FZWLPntpLFuaJZMuUJ7M5AnPRhY+L71frPPImuCx9lyYjPkI0bl1PelrS57Zs+ta9aG6j+l59LgVqvfEZ/GvlOn4Yv9+GVsDec8OwfJ0Hp1i5k3ro5aiLwJ+ylR6PNQrxxv7rCDtDD66E0IIIYQQQsjTQoE7IYQQQgghc15KwcEVKVSX33tgRwdrtMg8E7KzBPU66DPxzRBbV/Ud2TMDYjoAV/GKTjCNCtTPhAeX5FhA0UTeAoKenjBjUmbDK0/3lbV0rWWAEwkbZBlSPCHzlzI9VlpkEa0w2LfrQOFM7F/m7XdNxlfYelzuLXzMCliyfkbibJQeiYrWCGQs0ZM+ny2hU1PXciTKzoi2tV+jxz2aCOP5oI+F1d9YfnnCNeSbLFML8a30ns+Z7VuyRjSVzTtaj+z1tNTmXriGOHQPvDdB3d7b+1bcsh3e2zlUyn7Ooy39uIboNhI/j5YZPZOhdJ5w1BJcy3woXea+Zk2U80Te2r5+RsoI4RH6eQbVA9XHK9uzgWwhoa48PzLPolmBb/Y53BOnW2Wsec9Yy176HbI9FYy3dNYed++6h+Mz8rxXfl3SW32s6mfkdWb2TyBNF9+ripxcEr5N/FB+SWDJ3v3E3DNNUC9Lfggfij2+WNVnmUfaqM5+vQ2NfZ4HGi3vCSGEEEIIIYS8YyhwJ4QQQgghRHFs7aNeOelCm4rXR+QLaCUjJGb3Vla6xNiUDcumFthHPp3KeAvk9UKh+BLZMwSdE2Gl488sIKdE7k0H+4TPsFzhU0bwmrWLxBBNbfdWK9PifST8KC0WrpBxrtV2a+3u6ZhG10okrkb2tKBdi2+sySJZkRISXGm7SMzlidytlflkuVY5GkvAJOuJxP1hf7pClJ0VOKH0yO8lPlj212C1WSQ28wSBXnr9eQQ0qeG98J7q8ggsmaTzHvGEsCRm6+t2abs/Qv+RnVyWtTWaLpPHeh7x7oNLRPqRyFuLrqHoU5ARl3vPH+g5NSP4Hj1fvedEL73VRsiHNc95WUaf66NyH+H6JbcDjhltYVdd2/ovui4vec5+XfKrd5wmPk/8NcZudHnnDeZ2Xa60v+TdajPa+X9qzLGUYq7UjsYb0RgnqpEWu5tjsKElQgghhBBCCCHvHQrcCSGEEEIIAfSY0iw4Y23P2BR/UcBnsoqUztzsAFNUprdKkiVSVxtOgTbHzsyuFZSr01XgZ0F8ta29JZybUmXNJgoAAe1EWCHy6KCjGaT3xPJJ8STyGQlbKQ64DtcSuS0RxVhC5iUCWy8NEtF64nJUhiUO1teCJfCJ6hQJ3rUNJMBBwnlLyK7Te+Ikqw2stkV1s0DnQSTQ7t+t+lvbpBDEE4VlJhdE6TxGz41RogkGW5S/lc9LRXW3hPei+5OdzMJjZcO2uQ/6/hqx575wC6z6rRU1b+FDZ4trBU0sjCbhWJMGIwF59GxjPaf19MhXjfVcgT6jCZDRc8fI8R65ltDEg6j8rFjfgpOtbs+9+gs9bpOxdUmfvAYW1031CZNxNvT+0s/5cj7vdb9x3n7Zr+2pMS7pB+LSdvpaO9u66jEFvjXx9+KbGve0xirlfiR212UjkbweZ9S2Lp6enOMzHSGEEEIIIYQ8IRS4E0IIIYQQAmgqRCUDL/17/6sDOVI4PRNdJ8ufCdNrD06X0kobXj1e+jLzwQrIFRwAg6svKcG2GRi3xOHAJ5lnVg4QyjdDvKi3RaJZTQ/yeQJgJMzNiBcoAFjOloHNewRJrXMqs8LkaDnZ7Z5YB+W1hOBeuZ4P2i4SJEvBjrfCndUPIBE8ytPTeqL7zGe5DQkqtD+eSCszEUYLpqWAyzrmI6J8NGloRMw0es6PsKY/tQRd0XHdygcKNW7Po91/eY74PNrxfFRGxOodbyJPZpLYPdm6348m5o0Ki0feLTK20T0vK0qX6SNBd+ZdKXouyrQRErFbPo1itb01cdGaaLmVP1lGrrFRn5a825D1XLN9zbGRUmZi78zkGesdZmJHl48mYDh9Hxonm5ybXnsFgnTzXVWMRU1sST/V+FZV3+FnUYYcl8tcmZM0wsZFrI6u1aLaruLxSyl4n4nQlQ8ynbavbWsbWli/aJURQgghhBBCCCHvAgrcCSGEEEIIURwMwXcmkCRXL7JWOmrqX5ZTMM8RJVycmK9UpX1Uhmd+eoEqWUaEKVxBogVHqIoCoD2I2KT/VlDynEaLSKQQAYkqWptOdWhnPy95UDlA3NBtolX9TH8DgfyIoHSW10iXsbUXtvTlUeqV9dMTSSM7SJSEhE0jK1Ci8z8jwOjnKxL9eIIgK300YQCJ6T0BOrIR9SPIttd2Oo0ndtdpZR7tS7b9o/NnhC2uLas/zLRTxjc0caBjTYoYmVhxL/bUr3X25NM9j9VSgTCxuUcbLRF735OtfF3S1voeuVXbXbv9107cy9jP3FussrzJA6gs9FmLr3WakUlf0hZ6nrPejfRzh84fPRvrZwLr2VALVEffrZCfWXS5a4T7EdHzsvdcmZ04sNQP8phMruOCx4iyk2dk2lbK7HqdidNVvj5upK/5yz5wrR+MsR3kJxrLQf3T7JrR57l+H10xloPsXr52H1W+yRiW07YTAbruj9rbmGY/7nAcSZSJ0vT8+nPELO3ZMB+LCSGEEEIIIeT5oMCdEEIIIYQQSCu11P4ruDN04MYL+PT96HMpU0G83m5I6PygUFu2wrv0b1aXKLDmCQ9AulqAYELaAIIE/XnWpmcbOih5ERCIMq0gpRZmXOyLwGUVQdNLoK4HOR1xhvZZt5sOxGos8WwEFE8Y6cjjgIQ5fXsnGzj3gviSESGxV7YnrMnaQNe55wfyHQmoMgJ05LO2b4kfkNg9W3fkW0ac7YH6utE8Ml+0Paor+mzVTdd9VDC5pg/1RH57EXLtsU/fo0/3YrGwieyKRzqnvX4MfUfbs/W1bKHn8CwZ/64FEoEvfSaynv2jfPo78scSL3s29fNf9hkACbNHykbPY5ZPliDfap/IN3QtIFGrtotE8kuOg54EgMqyfM+Cnjf1d/Qcu+R6ip7BM2mX8kh98L0YOaZR37203Nn4SN8u0pp9QnBN6jQXO+CdzK2H7mvEdlmWnrjR62O+i5Vl19XMlvG5c4SZ6iW9HruUn+VxuKRrc/H8RAyv86qitehdl41E80is38S/Umo5LfjB654QQgghhBBCng0K3AkhhBBCCFH0WM5bUAumCX8hVwZoGtguyYRoqpVQBK5G7IXl9eDdyvyWL1Zg/5x5ZssS5ugg5mV/UYFHJGAF5SA/tV2LyTGodfKv+2gJSSIRJfJvVNC5FooI9oMn9FpzXniCcJnGOhc8kcvacxWVa4m+9XWFBEiZOujJMFb6jJDbKkf64gnbEbre1kQY3U6o38keH0sgom1l28ISW+n2ifzzhCueID3jo5det9976ycpsN6e7Lna05KYe0w0eeRj4/WDnth4ie1IpK336fI9wfBS8W/2fPH69WhbRlSM7puZtrf6idFnD8te9lnEshX5g55drDL69iV9o/dMZNXROuZIIBudy5n3SpkXCfOtPBboedcqf+n9Zk1/u3XffM9nlEd5Ppqdm1bCjeuDys1s0/lrSZy3YKyniGvZew9E9prI321H41Hm+bCgXeF4IepPytv4E2zFYBzLHqeb5rHE6nKftqvTIT/Gx0VbKbWV4v2sJSGEEEIIIYSQdwkF7oQQQgghhChqKS/OPrjNC/xYdjLi+EnQ5xLUalPBPArQB+WnECs4eQL9WnLC8Ev6TPBcBiTPtt4mHBj5deBTlm8JYICIwRKcj4oOPEFvU74h8WlGtLNY2DOcg7xntJgnI35JndtBedY275xGvlmTRiyh3KhgyPJNl6PTRCKoEUE5KlNuywq4RsRvWR8tsZYl6IvK1DZHhHuWb0tEYtJGJl+23dYIou4hptpSxPsoYrA1RHXMTNQYzfOobClKt57R1vp0L64tAo2Eel6fHDHa/6P82p+tGb3PoXxR3tFzMvvcn7HVfUPPQDqNtJcR9CM/0fuS1Vb6OcwqE/lkPQMi4Tl6TsrUL9o28vw7+qyMjs9oX4CeE0fzdta00zNw73ovvU9cxlZ0/gXjCiPnPRrfuYizwWQU5OPle62XMSE0bqL7DzThZNYn9LROXa1rMn2td79AWlkHdBTg+xZKBz2Zjj/qsT0plD+lDe5FykZm7FOPl8ry9d/ozD4e28cgCSGEEEIIIYSQdwYF7oQQQgghhChaOwVMPBG6Duro7Tpo5Nmp6rvjmfPN3z6SVuP52Ovqivn09xb/dPvUATvQ52d7CyDK4GkXlNe3hBPfxJeJHfnZXu0qFrbpuk/a1hKFiLxbkA2abik+I3PuLYyQjAp40feRvBlfRiZwbCG8z+TLXBNSAOEJyzreqn+RSDAjhut9jue79XnNOTrS5iNCfK8v9MT+yHamz5bnYXRcvWN1TbHmUq4lxLdYM0nhURidzLGFzSxrnyO2PhZbidK3ZA8+lLK9H1l73r0oS9TXZSdayX7XyjN6n0HXgC4rY3fL/lyWqT9HfkgRaHRvg+JI47kiWz4qQ98TPWF8xkbk82j6nifaho7xkJh3gCXP4BnWnp/Z+j7afZqMvWN5z9zo/cJ6J0Mi9pnN/i/IOyur2P2y7Idm/UWdr+6OxoBk+snfUbptuMvpy6x7YKbInGdwQYuq/vZ9fXxNjxM29W+JP964qZ+CEEIIIYQQQsh7hgJ3QgghhBBCDHRgxlppCK1EpAM+M5G38c915vK3zjZrdNgHCe9RusiOdikTXkLtVooTLFVpJitvlbdVx7CduViqWmJTIVbXglq0CuDEFyC6SQX3ge1erq7vxGaLV3TPlL+lAOHeYoZ7l78Fe6tDJH6KBNvR+blW3Konm2RWANVpM75EQqlo9VK9LdNPRCueWvuR7xlRVq/DqJjdEgfqvlqWYeXTNixfM2LEqA6o/azzIDqf9Hb9OTrGljhsS4HbFiLmWwh999YHLuVR6jEiaCtlfl7uRfw9wlpR/5ZkfLmWr9n+ZYtjvKafiu6lOt/oRDvv/iHtWfckr3+0ji/a7tXBOw7WPTi638vPSBAv7WhRurRrtR16PvTqiJ4TUH2i44BsIkbv5ZnvWTsRUd6h98yBsrbO/4j3h1tyjb79Vm0eTRLxnn0zz+mTfrW1icC81orHu9p09XfUEqnz1Xm3dX1P3r/OO9KCeHNM0Hq3MLZZY4+ovMgfaywPlSvHP6OxUCu/9Z0QQgghhBBCyHNDgTshhBBCCCGKWUD7/BcGhtr040T43uIgkGVuSUBHC+0jMXsUaFq6uhLKfxEqIDtGe+NC34KcUqjyZkMJxs95JkIJIRqf+NuFM/2zF4jUwntDuDFzX+33BCmTfCsC2NlgpieqQN9Hfdo6rP/oQopr+a/FQmvLuaXYVQuaLEGYJdCyBBbRNk/4ZNnPXK+RGAv53Osk28ITf2UEZ/N+cuqTJeCwhHRyHxKDbymgigRBqE5e+dFxz5QX1W+NEAgxKooaSe+JKK/JSL/yCH39yDn7SGwleN6iTW7RrqOi2VGkgNgqZ/Rcyvo3OrFhCyLBY7av7qBnhDW+ovsZSuM9U2VF3Fl/dFno/o7qj+7H+nyz6oHqr++l3r1VP2d4xwmJ4NFzhNdGKJ3eHj3HZMXs1mQATXYSRDavtX8E1NeMPlON+LJlX/l+7qInMufQ1uVdI5++jq3+RaeJ7Hn9XCkFLkYgbUQTbC7b1PeJb9pPo7wa9fnouSkaFBRYY4Cm8F2lkXZ6Hi1Q19ugD1LLD8qvxnY0HinL0+V6InhCCCGEEEIIIURCgTshhBBCCCGASBxe1QcYJArimFFwCWWohzfn5CpJE2F9sQNEelUk5NNlvxeQ1OUgcbRMjwKmhijT8q30IKoWc5R5fS+ChP7Z80NjiNsjoZclTPHqJ+ugbXiBWi1o6XmhX8pHvc0jE0w182pByUI775VrivW2EqUPT2JICiOscjzxeDQBwxOBS5tLRM0ynRZzaN89P2WfgMQu6LqOPmfFklbb6joggZwnIlwjRkcggV00YUD7bAn+9H7LR6/vzpC5DqLzVe8bIdNm2fy3YqStrbTR9mv2uZJHEOTfikhcOXJMlrbr2vP5Gsdzqdh89NxfQuZ6GelLrPvWWh/1/cHzy2tDaWeJIFmjn0usOnt+e/cuT1Dat3kCeI9IEO09R0ifZX0tQbrMq+uNykBpLT8j0HMGOqciwSzya6lPS3mv95v3Vit0Tt2ivI73nmDtn6U3tqGyoncu9Mwu04/2xVZf2P2r9bzCe0+v8hexT/vSiur7gvGxYvYVY8dei8Yt4fvFR7EficwzAvNZ2XWaDn3WeSLhu/RF+679h2N8Pe176yQIIYQQQgghhIRQ4E4IIYQQQojiLfDSLv9HwRXvewcK44VBHYCS9ub76qQgL0zmBcHSaPGAUcYlmJexOVkOyhHPpBw8Bx9bM4OSs7IccateKcxKN0srBRci/1twEJSpfK2WHUfAe8m7sVBqYr8kJipYeTeMPLbs+fVgRKLtJWQFOSM+abteumvhiawyYuSsv5Y4zPLJEqYhu3ofSouu6UioogX0nmDMEpvIvKNCHEsUnhF6W6KbEXElmmSg+3XdBuhYoHohsV22Xax7hpVutN5ZthKVZsrJEp3jnu01Qud7sZUweUmfvgc80do16xOJ+jRbnSNb3HuRgNvKd0sR/hIhsb5HIVtRvy7TLZmElBUnZwTdXn5kK3tPRe8jSOyuy5f9u04v2zwrYLe+9226/dH9BYlcvfuQNckA1c3Kb5VhPRPo8qxzM7rGlvRhW/Y1S/ZtmedZufVxX/K8kCUjLJ8InMG7QrYP7/suz6bKX6v/Q/2AeS/oNmSfsVA8r8eYZn1mMH4EGWhvLQiP0mo/0JjgZJzKLCP5DpjMpUXtI8zaot73mZ4QQgghhBBCyH2gwJ0QQgghhBBF7aGsdvku92VtFGHiQrssO2TnyQaKUF6U37V1Xt3KyoeE9k39HQovyQDlSD6AJ24xg60DwsSZkMIQPvTgaRf697RV7Ef5LB9ba9N2UmKNrNgD1WltMPBewcQq2/MdMSq+uwVLhLylxOfGWnGQJ7azRMieOEvbliKJrBAu6ysSeun0+rr2hOaegD3yNRLLWfu1CAz5lvksvy8R81vtiEQukWAnK7b12sKza92jrDpHIrrM+Zf1VR/jLfqd6NitKScjth2dmHErIlEnSm9xLTHzGpaKf/v+zHkTlZ/p+7M+bcEWx8m6V3QiofKa6yA6Jpnz1rvnSTtavDjim9ceOo/lc+ZcGcnrib4RMh2qmxZ+62cFy7/I3sizTlQX6/lA+tj3IaG5TIueaTLncnQ9eHnkX3Q+rr2eMv6Sx+PW9+Lh8s5jPM3Iu8T/WZ7g+r4kAza8iSj6mqvF7iuz7z7ys9UmGq9vkyL6wAhyqLRSyhHdQ3T20Ms34Xc2rfW9Xv43LVkK4rXYXAvlEd44Zfe7iX8zn+FGozBCCCGEEEIIIe8WCtwJIYQQQgiZUV9Ke/s541GBefHyGJEnLzg0iTPVN4+QiF766wWKLvmCoJwOlnmidjOoVisUh6fb1gggmsJBT0irbQofZ8FUHXhV5VwCnaJMT2CXFTNkxeueKMQwfAnqZgO7qMw1oowlIhXyGETHLSv2yogTslhC46x4yRLSRT5rgUdUby3oGLk2rbKRyESKM6TIDQnnpD3UftK2J1hHPiJ/+2ftQ0bkOSIi9+xabR8JpzMCyWhCQWRv5PxHokBrQsA18ISF2Wsh2ubZyxzriCUia4vRiQnX9nere6zXX0XiX4/Rc0Sfy7qfGy1/a64ljPXO8+j6XnqdjYi2vX36fPf6yWz/u9WxtoTX2vfoWd0TrWf6fJ23f7eORf/uCcw9f1F5ukzkc+r9A/jh2Y58yvrm+bHmvp7h1uLne5VJ5tz6PmNez6edl/ETea1mxxes/Rkbk/1eWre0M3IsKOjferqZfyqvWxyy39Svya3tIwa3l+KPwy0ps6ltTRYiaqvHKZvarscLkX86D7JtUqd2m3acEEIIIYQQQshTQIE7IYQQQgghitbah1KPc3H4OUbY4ylI+H1lxyYrK+kAUxQoM4XzqChnH6q/zDfLK4Kr2v7FlrUqVkmKos9/5yth1fDY1Fov/kGhhPzsiXtUwFeL6T3x5yVYbPjo7ZvY9dqt11F8npUBgtYy5VpR5BqBM9kXo0JsD0+MtQWRTSTU1vnkteEJ6VBdsuVb+TUjkwUy4m9PcKhtZe1JAb1VH0+oGk0akOXo/ajdIzFORmRnpckIK7PXiieyH702dFveSnQlfV0i7tbHz7omPOHmluLELUTZS/NnhWZLz69riTij552ItRMGpJ1o8oAlZM7649lbkj+yMypcl/usesm/kaA4s8/qx/u2JeJ7796K7t3ZSUyTZ3Bwrsg8luA8ErFnzkNUd+9e5gnxZb2y14vXz8oyI7uyrtpHz67Mg3yx7v0joOM3miebFx3vrd9vtprUsaZMMmdtG2WOYva+hp7Fo+dz9LxvnVtWnzjzA9jx3rmsc7uPd3n+mH2T8EOXh9JCIXbU7iBfcfqrS91FPqts6f/R8Rn6ILZV4zP0rc3F6xbN+Iy+Z7HKZi9ECCGEEEIIIc8JBe6EEEIIIYQo6kVFDsIxdRqAgvlLHHipIHObfTC8aHVSjiU07/ua+m5hBaNkoCwTUIrKuAQn5XYtvNEij5EyWyuldmF7w+1jBG1h4FX6AIQwOmCKyoJlAGG6tFNrnQjW69uOidBEYgWQrfSaXuZE2ANsLuFW4koy5RHEKFnhxNZlWmK4rQStI8Io6Qu6ZjOCT0/cpwUrlr1I6OiJ6jIiciQWjETLOr/lnxb+WaK5SBxp4bWZFvVFbSHrgMSRmTIRSFyk28XKNwK6ryEBVcaGJTr0zj9k61r9xT370CXHZSRt9pxH5/NSUX6270Rles9rqNzR9vOEzBHW9W/14VG/ia7j6D4VXeNZobbu06y6joLyZc4rT9yO+rzMvRfdC7XoM/JH31O9NvN8ivrs6Ljqcw+VqdvLuw/LNMg3bT9j08O6VqLzPdsv6XvsiH9Re2aInruWco/3Kr7LbYPVitGYQscTtVv3BimmLqKc1tplvMHqV5Fdq2+Az4IybZk+/0qrF5uq/xu5N6O+Tr8fpcZEnDJK91v7I+o4SYv6r5NDs7yWL9I2Gh/0xgTR5xhcN++z9iWbx7se4PdaSmvlg5GNEEIIIYQQQsg7hS+ChBBCCCGEzKil9rBMayLC5WSxFODnKJQORLUoiqXM9s/6u7RrBoEMN9F+K0hl2ex2rCZCzXJNqdjFdmvlYAQUtQBkEkyu9RJsnAlFiiGEQeXUeklvCSkmgeUyF2D0vLMAqhJ1IUFOL1/bLYlta48PCs5TDvE+Mc8/J/1azOvJESwh0ZcnnIzw0npi6Ujo6Am+I3G2BRKMWXktoVvfNus7jc+oPJT3Im5peBIOqjPy3zoHUbnZ8xW1uyWk0T5Zwhnr3JA25F+dNvIlKifyPRKJeumssqx2jK6BTN1Q22QEoe8JT+yFjuHSdrGEnda5kBGdWj56eaL+37NjnWNrzxWr77L6Ne1/pk+KnuOiPsHzO7Pde5ZditfnZ33V/aXOI23q75FA1Oobs30yOh88/6P7seWP5T+yodNZ+a000XMIOtejZ7MRv/s+KabNXD/Z56WIzHW61fWxh3JIjtH+F74n9/5wIx+svmlybdU+zjUtV+dB/T96ppv0UUWMT+lzVV6PZx8m41vOc/Ulj9MOk8+9jjrNQFvDa83qQ8H3aqTVY2PWUCLK19Rfa1zPKvMyBhWV5+zsZUY+6HStlHA8UoLT1tJaewmyEkIIIYQQQgh5Z3AFd0IIIYQQQgIs8fYskdQgq8w6eGPaMqI8rchgY4PJkc1apq6hgJb821Q+VAbKZ6EDXjqYV4ojLpIBWfXdLu2NWUDSErlMM8H8rkgSCTBag7ak+EMKNC7plB1ZBkov/bmIPkR6qxyEJz7Rn7281nkYHz9yDbIimKUiv2uKbDIirMw2JO6KBINrkeLGyE9UticCtvIjUYq+/i3xtPZZisg8sV9UB1Su3IcEdbJcT5QaHUNZT5lei3EskZ2HblfUt2fFgvI7OuaW8NECiUazbaV9se4fls2ML54YspO9Tq6Fdw6M9Esj5WVFmlky58kS9PUkyRxbnW4U2Ufp7d6x0f2R59fIPsuu9hHtQyLdUTFu9n6o96N+D/XB2mbm2Fp1yYi+dfmyr5bHXt/H0D1XizAjUbvGy4PyoXuXLB/5hcq2BN7oHmOlie4nlgBW2/Hqnbl+o2vKOn/X9LOW0H5JfzMkXF7Rr41wzeduMs6kn8+kD2x4WPat5zmrn61n4bcW1evnf2nPKhv2hdb1di7PelaP7glW2SZ9f61v4xDnui+9jrz2QONu2VI8kbgurzrb9fgdOrOkyDwaS2xlml7n977r7cj2MtgHEkIIIYQQQsgzQoE7IYQQQgghilpLaeVNoIwCQB5LQy718r9UyklBUQBNB5h6epSvqTxI6I5s6vyzPINCtqK3h4HIZJAzbU8mHTuqrZSZoL5vn9mSIhNQ3ixAfA7SttZwmwZCmcvxVUKmNYIMTzR0SZO0dS/hxrMLRh6l/ksEiFZaJP5CZMTCa4lEY55wyhKyWSIvZEcLTDKCQJRf+6SFlEg4L/NbtmVea58lyvbEhkgki7brNFrQrtvByh8dP8uuJRrN1hfVwfPJ8n1UCB+JMKUvngDUynstvDJGjq2HPgYZAbZnYynesfMEZ5qsSFbaj8rPlIP6GU/0myUjtNNlZc4bfU3I898SPEc+WWV5+/V15wnHPZuoLih/1k/kF7KJ+jhL5GmBzhPvHm/1R9Z14vV7ut31duu88q4zqw+x+m2L7HuB9Qyl8y6532SQ939ZlvV8l+1TdL6MH1H/fYv7Frk/UCC84j695l06esfJPt+LnVAALwxO0mp7l75NXrfgXeDiFxj/qML2EO1tXG9R/omp8/1GbzfSW2J0tE2Ou1l2tA05pofsWbay/suyre/R9mif60R7+1OjtIQQQgghhBBC3jUUuBNCCCGEEKKpIuyjo1JWMEXva/PsOrm7TdmbrK9V58ZbUZtEMCgKhOl96HNP38RntEqUZ+8S7DTSZpiIOGpNBfEslvhxKdcKjkbiJiVilNtK8YU90KZVjmAm/NHBZJXHE0ZGgjRUnnnJGDa2EIEsPrZkF2x1LLaatBGJhb3ysnnl/khcZl3j/TMSJlqi0MiuFqxZokOZVovndF0sf6Rd2UdGQjxvXyTO1ER19EB11scgEoMjX6K2QAJJJGBFZXjlI9sZoRYS7noCTbnfOie3EHJ7ZMRg2X1Zlojol6aLbJiCtWKf+6P3b09E74l2dXrrOpGfIz/C5yRAVjwdtZV1XXvPf959JKqv54e1H4kNvXpZ/Y20o+8nuk7yvufd4yzfo74ClS3bPzrfLPF2hOcPuldb93/dZiPHPHvcs9uj8jI2M9eqxHsvWtsfR/kjH713oq3KIPsm+26QOVcsm601PFEebPPuV601OPYw+aufWXtaVNa5jJlgWvtfyuwX7iZ10+9A0vez/da3eeMkA/0KInN0UJpIyI7SyPE4Pdam0yG7qEw9lofGAqPvl61tJL3a3vL7LojhVy1mnx1RdpmEEEIIIYQQ8nRQ4E4IIYQQQoiiopCJjkCBTEgdngmSaVE6stdDi9UwqoNjWSYBS+0PSDNqV2/TAbtRJsHX1lCTiw0qoHvZvFA41gU8RmBaB3dRYFfus8SXUtwysSGD1eK7KZjMCkMTIifddpHoaeKG8HG270qCDsY8n4dRoWGWJeJWKUpbe25b+bN1qkb/EPU7XtmyfE9wGflk2Yn8keJHz18kILXqYZHdj4TnSBifaSPUp1piViSOREJGy2YkKPZEwJaQCv3VbYM+o7+RKHNEJBbVwRLVjl7DGdHZ6P6l/ni+WGWO1j8jwPbKyohbtc8jglhkx9qO6jLyrKjPVes8z7YH6uNGrkmUxvqeTY/K1te4J2i36hG1d3QuZ869yDa691j9pKx7pq+y/Laut0jgH91rrH0Ro9fWkuvQaucMS/rXJVxDQJ8hew6RfTJyvxjp6+R7eB9nsPpiz6fo/JrdY1t7K/P8Xf6dPF8O1DGq7+TZVqbR9xPnmqzFv2ajqzl79Xl29JChHgND5VTxV49vdaG65YfM08q8/G4H+WDVtx9Cc6xtQUM27aDBxPTZyev3woQQQgghhBBC9g4F7oQQQgghhChqBc/J9bJvHiHKRlyMdG/i4bF8wq15cqDSR8L1qv419c8tw0iDmgiVY9lF1dXl6bQwkKpFeAUIj0BZkHNQFx2ktBBBB6ADgc9MGNTLb28rm00CuEoc1eubEtuA+kyC4SJ9a81tNyvIbol5Lsc2EKBdi63s30IAsye2qu9aMZEnCLknXh2WijS1bS1g06J2XY5VriWEzvgbCWU8/5EN5HdWcJoRkko7lvgyK/D0bCJxoSWktmzJ8iNRORKNRqJbr65omyWWymzTbezZQ8ffFX6Junj3EdQekYh1ROxr1SWDld/yKaqvJbIe8Unbk3ZGhKn6XPWIjjVK44mcte1uy7umrb5Q5/GuL09sLPN6fnsC6J5eC8b1eaHPb6+fz/RPXtuP3kO0oDuyi9BCS/1Z29E2I1GoR+Y88+6t1jHSNnS9UPnoc7Yv1Nu3fn6K7hteesSSZ76ROu3hWX4PPpB9Ic9gdK+Y3JtVWt236zTdxux5EvT3uqxaayl1PqFe94PnjaWd01uDXpNr1bgHhM+i0HKObF5LGG6NY12zTG0Hjf9VlU6O0/UmBHfDi7C8irwTw4FPnh8Q0YDmeGAt01+2JIQQQgghhBDyNFDgTgghhBBCyAwZXBNbpcpaRoYyMRYZHZLbmvruuFPVd/m1gfxmYMjZblVFC9R7Hq/qmX2zAKuxr+q0VYW2kmIAVzjmpK1gW9FB3YQPi8UdKhgMRTlnH2Tg2hNGys+9fWFAGvkiyoAC12LXdeYTCLT3dN2+Fmyh8iwybb6FmGStUPvR2EoEdY02ule7a5GehRbdWefOiCjVE+Na3710WUG7J0L02sJLbwnY9H4kKreEgJYo2KqrJ0pE+7JiR10fJL5EvlgCVr0f9e+ePSQcWlpH6Z8uy/PLEnFa2ydCLuGrd99CAmlPkGvls4RVmevYE2Zm+w5Z1kgfjETEHpYIFp03GRE1uu5QmZG4WpehP/fvqKzM8dZ2ovTyOkb9kf6rry/vnMlce5YPGQG39WxoPTd6fT2yOXqOItuyvTJ9knXe9n2Z9o6emaP+TPum/bf6EF2+1946T9T/R88S2eNkHQcvrdeeiKgfQHYiX97zszi5Prc6e7LP0egZd9JXJtKi59FLeaC/R/35ZZ+yUYJ7f1VpCng+8wiv56hvOpeJUlnjUxF6HE1+7+Nll7EWp7xMufIoyLG42ViZSGMNObby1vw6XRNfZk3aph/dHrtN/iwfPJwU2ErytkUIIYQQQggh5B1BgTshhBBCCCGKKj+J4MlJtCu+RFEwGSVCQZhaZva9yJYVEEsFjEoY7wtF7jLwhQJyKDjnFdntWGm0H7K5dHDzmCgvKsNrvmNr0yDiOYCsg4zNCNhCgIgDBnbPZbXWZnkmAo8yP4ZajDNJkxC5XIQ/0p74651UGXHlJV0gaImEUpf2WcASEdY9eCaBziMcD0RG8IXyjAjZRwWxGYE2Ei964tRMOdl0uh6W6CZTjhaMe+ktwbTO64mxdZnIn8h3XZZlzzpPrDIiW5Ft1JbysyeSjQSfCE/YlRFao3uXzouEWp6/WbFZlG9EPBqlz9i2roHMtZN6JinTa0OeL971Fh0jdG5lhMSZfUikPIqupxQUonQS7xhoe9JHVAY6VqgfsUD3AOSbJ/qWZSK/rb7YKgPV32NEvG35m+kb0X5dN++cl+0nP2evhZkwtGKBPbr+rHZBbeydB5Y/2oZmaRtvmWYNj/ocSrbjcq3coIzZ9vPfkecpfP+e2rOoUvDt9NO6T4PXuPRF3x/LtA+ajAEseHZc3Au0lh6Dssa4kC9V/JO2rPGzS1ltOi7WVBrtA/Ip4+Ni0KCcpuHd8rC6vulBLJ1Yn8v+DwoSQgghhBBCCHmHUOBOCCGEEEKIpkea9PJEGh15kp9lFCsDinrNAjvnSE4DwmRgchaLqoZZVbSML2mXrPgWikVlo05WEBHZ0ft0+VsGoScCEmU7EnOdjlO8CrIUrKByvWDvpXwRINb5Z+Ka8z8kfKsqj7SF9k3806IXkLa1t0hk1H66HtntbsD/ymIYxJYCmWcS21xbuHRLLBHZSD5PjK33y+9LhMZevpG0WkRsiQLNPnTwHBgR0iGxqxb4eeJASwyMbI36mxXxWmJRy7a2g9Ii8SK8VwTnh7RzKKUcDrV8ONTy4cOhvLzUcjjY1wQSab681Nk/VA+rPbJk2k2LcNF5Y4l7PcFr5jrI1kf7lRXzW+czKl+LllGfMyrsj+qhWfL8kMW6zrXwPPIDtY8l+LaEz5a42HreyV4HmfuGJaLX57dly+pLtcDR6tvQ9RUJ4S1xuHVdenVGdbDSIazryrOl2zR6VrbyR2kzdUL+v6fnM49nqSexQddS5v11bRnngtLPk5afp339f36f2MctZnYSvlrPX7W+TYqP8vUxiugZGI5DSXH+4L0/k7qPAaGhOm3HOlqRPrzWRBrDL09rbtVPj73JD5cxtahxxKBd6xm1CL3YbRISNECtlboGQgghhBBCCHkyPtzbAUIIIYQQQnaJFJnP1M0qrReAsYJDWgCvI2dym+OehRR8W3r5EuxDZen00mVZBR1Y00HBaqTTny0/rir1PYvFoZi7aS8a3K8F51rgYwnkSlGiCuSDztfaOTL65nffL1dku3wGoir52RPfa7o9WZ6sp0Uk+MmIKDN21c7V9u/No/p9Kybn/U7ESUtFtiP5skJnq11QHxD1TVq0jmxmhZmZ4+b1mciWtU/b03aRaNkTBMq8SPQZiSOzItWsmFLXCdVDp0XprHZE4lIt9q21lno4CZF+/fVT+fnXz+XTr8fy+vq51FrLxy9eym++/KJ8+fFDOby8lNfXV1PgWWspP/74a/nuh5/KSz2U1lr58PGl/OmPX5djK6XLnZDgGNXRqnemTXQ61DYyD6K1/r9SSi2l1na+hTv3WXUvbq2VQ63l9fgmCDuW0zZLcKxt6b9eXeQ2T9gcldk5HqcT6uohPiZom/YfXb+ZdkVE17xMh/oIS4Qd2UPPZtazmNdHZ5+/fGEkflZFfSSyZX3PXmfRvcD6jNre6hOie1rmWd2zmamDJSCX/TDq36wysvcpvT3zfDCy7z2wp2fJvbC39xA9dLLYTrJea+reTjf7nKjauT9bflzGYMBzbd+Pyjg7N9/W7YHtMxtVjZH0skspzfF1tn1Jf9Penim6D1udFxZ6WFCOa6EhvZLYr9OVUmZjcLKcNXWELVmn+ya2o4G8gjINAk8Ie9+xtY8rSiOEEEIIIYQQ8oBQ4E4IIYQQQoiiltrMIIunxEZRK7lN5tGRMWRPbgORLisAhopFeSJkuqX5UNDPsl3F/lmgVOU9dKFGMWJpIj9K48bjUAAV+KOt9EBuTyuDzDod+ozLUCWdg8hIlCPttG5P1Aedik3mEQHiy3klgtZaYHURxHTbgbhtEgQ3sIRcWW4hUBgpZ2v2JCq5JRmRkSUAiwTPS/bdGi3QXepXNl9GTJ4RyVkivqwgT+azxH26/MgnC++ats4nVF7GHvI9s90ShFoCU297JPyV+SLB5vT8PG37+z/+Wb7/8dfy6fPr+d5ey7G1Umsp9Ydaavmx1JdSvv7qy/KnP/6uHA61tOPb/a3X63A4lF8/v5Zvv/2pfPj4obRjKx+/+FD+9IevS2nzawPVF/mKzkeUP2qrbNpaa/n8+lr+4z+/Ka/H46kdSi3/49//WL74wh6aRcfuUGv569//Wf75w8+Xx4bfff1V+bc//64cj9HxwX9Hz5WMkFrvr7WU73/4pfzlb9+d/C6n55D/8d//WL78+NG0mxWNj9wfo34tc1w9kb8ldl5Th0i0bdVtyXNDxg9UVt+W6UuttFY/bm1D90Yp5p48f4Jy9PGLRO8ekTg+mgSgbUVt49lC557n86i4PfLj0Z+7SllW/1tz6zbb23vIFt5Yz1bW99Ce4ddw28n0fczj/N49GUYS7+qoHDhGIHyS9ybv+fxi9+yLHI+4jOX0bWLsAY1tLD1u5rgPsD96bchxEm9ILrtd20XfvbL0WJlO79lA423Ivjcu16zcqGDnwMCxp6ixCSGEEEIIIYQQAH/KixBCCCGEEEUr5eXyBQRdqgzm9H89bRP7ZhmNTRXvQ3YmsU4jSzZOhIq1XNEBNR1cQzYsO1Y5k6aTAVVgHwoxJl98IbXl48WGEMDNgrOWgE2W7aTTXCw7gg9v20w40wPLStwjv/dyZ2LyLhRS9XKD8iKoPqubDHADOxkhVgPpMmjRzohIyfKvszcRznsn09ZZsd8W+7JsKQRC/iBh5RpfPKFf1q4n1NSCQ5nOEiDqPJ5QXm+z+gDpoy4/audM/ZBgMBIfon3ab+SHbk8kZrbsoHbRZYyIVQ+HUn765VP5f/9//0/5x7c/lXY8lg+HWl4OtdTayoeXWg61lFpbKbWV0k6C5//P//2X8s/vfyr1YJ/nLy+1vBxKeXkppcuzap2eN/r4WfXVddDtp8uOyJwzrbVSz0Ow3e9ja+Xv335fDhMNGz4v+ueXQy2/fPpUvv/xl3I4iOuhvqWLrtvI30we2V76vLdt9Lq/XXv1cCjlOD8OslwpUNZpMn2CtheJhD1BfxYtGtR2dPvJPF4/ZAmkUZ+h7etjha4Vz1fU1lZfY5WXbV8rXVSO/D56HK17g4U8L718qH/3+qSR8xn5r4+jdW/I1HGUSNx+La5Rl0fh1m29hhFPb1kv3R+jiS4Iy0c4/mE857nIPg1sn5V5Fq/P+gEllJf5dT29Pno2xOU8xwqjE/se0oJ5D3AtKHvSP+Mvsj0po04nBDQjr95+GZJRadCYFvKnp/Xqe40rZDr+U/EOvQ1VrMGPOZ+dRHp8ihBCCCGEEELIc0GBOyGEEEIIIYrW2kngXutbxEoEb9zgjBVtMdTezYu0qXwNbEN5LyaDKJKq1tyUita18/+8QJ8VuENl6/1Vlw/SR4GxiW9dcBLkuQQ0K/7ZcLn/bNj2RYjHw+A1EJMjskF+LeiZiWQSApAewI4EON2+PH+gMEvVcSZiCms1FdjrIP+lTOGTtq0FWBZIVOblGRU8RPvINlyzje8hoFoyKQSBRCxWGinOzGKJ+JA41RLxZsqw0kd2kDDUs2cJSeVnL42VT4tGtf+o3SL/PFGrNTHA88O6jyBhcf93OJTy66fX8l//55tS60mM3ss5Hks5tlJej60cxXPPyYdWXg61/Ndfvyv/+ObH8vJiDFNe7gFnP4SgW4s2IwGzrqslPMuIYbWNSLAqv9days8/fyqfj60cDnN/5Dl6qttp2zff/VSO+twN6uyJ9SyxM7Lhic2t+mf6HpnOEjGbojvQbpYN6Ufkd+SvzKcF1rIM3V7INyQ8RuJxdK5a9c/2s949JeofZNne8UJicFQ+akP9PGodD9Rm+hrStpFPcpt1nmt/tS19PK369c+6vlY5yGaE1ddvhT6no3tx5lxc4mvmWeIez3DkjYzw+95Ez7/e85NO49YN3Ad0fnRfuJTb3t5/a63zxQFk+oL7jUsZ6vq9+NTT979On4jua6heBbWZcW/fAjneJMcsovEpyw8kOm9q32kc5a08r0xUSz3OpsufjL2A/ZZdXcbFV5CvWg4jR8+GJskr/Ig3Wo2gG3CStYZ1JIQQQgghhBDy/qDAnRBCCCGEEIUVoCmluAEXuPyShRX18qJapyjm3DUUKzz/D7noFVmKiI+q4JQMdiHXWpnuaypdVZ+tfVFevW/mY9Km5iI8KbaQSJcHjBiBPBAIXijGmAWfgXgGCWoKCFxfvsuguMgXBe8v51JCcDMR9LxVcN7Ojo1a55MQaq2ltrnwHQXMPR+zQraIqIwMexN8kBOjx2WL45gVbWWFYWj/EtFXJGaxxIxyH+ynBssZ8bV/RoJTS2yKyrbEnKjP1AJQVOdIbGuJJL36ZOxokABU7rMEs6218vq5lf/4r2/U/egkbP/yyw/lz3/8uvz7n/9Q/v3Pvy9f//bLy76e/8PLofztm+/Lt//8oby8vFzKrLWWJlTx0amqRWFWfVCdJmWCY+UJ1tAxmgvhpvelLkr75tsfyqEe3POuf/7ll1/L9z/8fF4Vf5pe++8JZZGA1+pHMuJl1AbzNvK3R30T8iNTvj4OW4iDo3PB6h+8cry+UvqQEVfq/Ugoae33fNTpta+RHzq9t6/bQP1QdJyt6zVzz/GefbVv0idPqJrFSzsiIrds6/Nyq2eUrZ9Zr/WsxWfr/RH1ARLvmr2GL1Ef4tmBAnD1rm09M54z+NeW6stqAf1b8pnzbTxJ3QfE+IG+gS9tcTluIByb+qH8XQM6Wk38i9Kj4T4LOXzW/1ll6e/RMKAeE9PDiGh71HrSX10WzGsZbKnd/uCdHDyUA5Vt+u/NN2O8jRBCCCGEEELIu+bDvR0ghBBCCCFkd+goU1WfddoebUGRlq2iLyDKNYsTCR9aMdIE+0op82gZSC+TWFXv6XTAzwvYWYFIvd86HBl/PPs6nWfLAuWZtIMQLEX2w9DummB/IDy9BNaVoCgS4LTW3uoFBFGzOishU6a9tT86nw7oI99HRb1LRMBL2aqsrOiZTLGErxmh4i3xBKwjeVCa6JwZKUeKDlEaT8SZbWstfES2M/asY4+wzgevDpY4WPusy5HbJ/cQ41h5okvts25/q70s4e4XH1/Kf/7l2/Lp8+tFeP359Vi+/OJD+R//9sfyxceXcrz4W8rvv/6yfD6W8pe/fFt++PnXcqgnW4dayj+++aH87re/KbUe3Pu8bh/dBodDKYfDoRyPbw9o9XwnPrZ23v7WpofDtKTjEduV3w+HOtF8nfVkk3Sz9lffXw61/PDDT+WX331VXl5eZufU5HMp5f/848fyctDnV5mJz3T79DrWeiil1dLK8Wyznuv7thJsz4OExW+C+HLy93gs3bvDoZ7sHNvleHsixXaxO/e5llIOL1LldPrbj9vhMN33+no0r4PDoR/503lwOk5vhZ6O/dv6L33fy+GlHFtvp9P/WzmdO9Y1OBXSn/xs7dTO7XwO1lrLsbyW46svpkQTHnS5uq7Wtev1jai/sc5ftD1zv0C2Mv0mOgdR3qVsJfC+BVuWs5dnmEdiT89+7x1zSGVADD+zmX2uleL0syjdyysF6VVtn+UJ7tOTZzy9/5To4lP3E56T3e+ep/R7UoVjEbLu0pfJ/Uj4kXn3uOQP+n3ke0XpxASBy/kh2gI9SOjzSOumLfTYlLZj2bXGt6xtDWyX5TW1rahtlo3RXspM39Q+q+FGBgUtMgdnNrjGsQ1CCCGEEEIIeTYocCeEEEIIIWSGkFI38dWMuJ73eWnldyvqpRXeOshT+24c+ak1EdRqb3YuQbJWSlsYI7LiXEviW1HzyvI8G5Yt3fxaOmX559Ul2n8JUlqCQZBnIvKR+c7pI6FtRoSBhE1IsDRbAQ6Ir2ReuWodCqL3FeyaDNAb9izBqk5rig7KmEDCA7WVJdzbm5h8b/48Ap544z0InDKib0vwbG3LlGN9HxGgW2Wg42OVp8W6nhAUiULl9yXngyX0zAjXI3tIDO/56eW1mLRZa+Wnn34pP/z4azmc8x1bK19+8aH8P/6vP5XWSnk9TgVin19bORxq+b/+xx/Lf/3lu/LdDz+XQz0J0l9fW/nrtz+Uf//T78vx9TgRjwkPTsKbNvf1cKjl82sp3/zzx/LDDz+fbJxuwqUeDuWrL74o//L1b8pvf/uxXG6xrZXvvv+1fP78ehZNlfKbLz6WL7/8OKuzbKPv/vnTRVh9LKV89cXH8tVXH8tb04DzGgixPh9L+ef3P5d//ePXSKN1yfbzr5/Lr7++tbP0TT6N6XPncKjl9bWVv3/7U/n5p1/Lp9fP5Xg8lkOt5cPLS/nqt1+W33/9Vfnw4ZTuIoQD/h9qLeVQy48//FT++cMv5ZdfX9/E8rWW3375RfnD735bvvjipZwW3lfnOnhqrHV6nr68HMovv3wqP/z0y0WAX1op5VDK73/3VXl9PZbvv/3lLEw/CeG//uo35rn/zbc/nG2XUmopX335sXzxRT+2rfz6qZUff/yldDXX119/WV5fW/n2n9+Vn3/+tRzPK4XWw0v54++/Kr/77W/K4eV0rur2kW3+8y+/lm+++6n88sunU83b6Znkw4cP5evffll+97uvysthPpnCuva9ftd6PtL5vGvcegazbCAfLB+je4g1qce6D3nPh1ZdPD/QvcHy/z0+A5AYtteVEQLrLd5alr6PzYTL2edd/d0RxFvP1TKNzgN9MvrNbq+97Xhrj3M++Hwr9rXuky5HiOf7mMSkbDEpwGOyXz4XNfSUUC77J+/257SHgseJtEgcmlXpLi5pv/Q+lV9+R+n0Ps+mHEdraptrTzhT1Sarnh5wbDAagNMFh4WIfMg5PXh3sVv16U8IIYQQQggh5AmgwJ0QQgghhBDNWQx1+TzZbvxFNrzvVnodIBqNRjnmm7ArTbZqBNHaPL12U6KDitJEazhQFtmrKh3ah8o1MYKVVtmZOF51bC6JvVlB4ar2e6ubTTfPRUr9+7FNVz+/BMyN4HQTNnt6U0Ag9wnfdNBdBtpDIVLp51Pip6nPtjNi+Gk2sDo8FBSqfGB7RmCBBGdbCeW3WtXwEbiVYOsewrCtyxyx5YkWLQGkVU70fQmWSMgTKWaE3FY/GwlMPfGSJaiPfLAE+ZF43bPrTXKyhKeo/Wop5bsffymvx2M51L6tlv/+5z+U1spspfTO8XgS/P7pX/+l/PTrp/L502s5Hls5fDiUclQrrKt7W2vHcpmo197qc6ilfPP9T+Uf//jh4uPhUEsXw5djKz/89HP57sefy5cfDuV//c8/ncRRh1peX1/L3/7+ffn4sZbX40kE/T///Y+X1Ur1feTz58/lL3//vpz13uX12MrX//NfT2L349tq4tO/4J7aTivX//OHn8rvfv9VeamHSTmyHj/8+OupHjU+5n3/y8uh/OObH8o33/54EpfXt+eW47GVX46fyy/ffi7ffPND+eMfvi5/+uNvy/E4tdX9eDnU8ssvn8t//vXb8un1fLxVmf/8/HP57oefy1e/+Vj+x7/98bKC+eVeWio8pzqHQy2fPn0q//W3b8unT6cySjm177/9t9+VD4dafvnltfz923+Wl7PC/cOHl/L1V78xRdjffPdDOR5Pp9GxlfLf/vh1+fLLj+dHhFo+f/pc/vrN9+XlfJp99+PP5fVzb4Q3UV05Hsvf/v59+dvfvy///c+/K19//dX5PJ5epy8fDuWvf/tn+e6fP53Or8tjUC3H1sovnz6VX779VL757ofy3//8h/LVVx/L6yt+3kDnnv6Mrlct1pbnoe4bPfE5mtCDROE6n2T0fmPVDaWL9kc+6D51rf9L81j30qX3/jXPDGufN7Z4Xllig6L9mD0/77daU+/MqA5oW+a9TRO9h6H3w3NG01evbHci0/m5x+qD5TZkEwngS/Ovk9PYT+vOn/LrsnqdjPpcxPElviYvYznedZsYt5ncA3X2osa8um9iu7Z+sSHq2vQ+YUvmj/ajcrQfegwNfYZpq13WIpr0SjmBqMbnib2CG8VyXFdc7mB3TwghhBBCCCFPxyFOQgghhBBCyPMxi5mg6FhT31HkSefTabV9HRmDPlSYRgfYPFN6h+UWsmOV44aO6/SjjlWhsuV+6WNPn4lraX/LWRhtNT/ahg7DxP8o8No/6ECzFHr3TUaZZmBebpcCHSWumwWoZXlKAKXro8U2l+A58KsLpybiqvIW6JblIiHWpe7nciZig6KOu/RF1H0iKHCEXEgAK9tsWFwj20HZcvMZAocs2etgpPxH5NGFTRmx9ZK8S9Ki6zryZ42Ybk06LSS2rmuElVYLRrWo1PMZCce17Qr6N50/sofEq5ZA1hPA6jpHx36Wp5byyy+fLuL21kr58jcfysePL/N7J7iPHA61/Osfvi5/+tO/lP/n//pz+X/9rz+Xf//zH6blTvr3UmqdDmXWWsvhUMq3//yp/OUv351E54d6FlfP+/8Ph1o+fT6W//s//nG23cq//PbLcjJbT0LuXz+Vn3/9fLnFyvY6HEr57rufS6kn0XdrpXz12y/Lb7784iLMN0Voxj3n82sr33zz42VVct1erZXyz+9/Ki+H6bko0+njfHip5f/3X/8of/v2+1LqadV8eC8up0eEv3/zQ/nP//qmHA7z8+PDh0P58adP5X//599La618ONRy0NfG4bSi5qGW8tPPn8r//o+/ltejbH98zfXtpZTycjiUv/7jh/L509uEiVZK+f3Xvyl/+N1vy6tqvtPEBvtXGGQ79UkQ/fx5e5Zp5dD3H2o5vh5Lf3rU4u2u9/uPv3xX/vHND0WdiuXlUMtf/vpd+ebbH0/n4NmNYyvlVYjlajlNMPzf//H38uNPv5aXF7//t0TpWmAu9yEbuk0ivP4UPXch5PXeP6P+x3s+2/r+Yolfo/49W2Z0j7AmLZQyf0610nlE7eWKTp3n4i3KvpaNR38GvAVLzu1btWvkmfde1e8TMB+4P2b6rlk56l215+/vmnLb5HlK9XO6vzbLBn7DfKpPnT1vSN+kDfVu323JclDbaT9kfS/2RH09UmejGNOY7VI29JiRLGc2HlTE84+wI8dhojNfexXVp6rPrc3rIP3Qfrvv8mC/zqfbJOOnSTSA1cq8EXVFdaPr7bpxzvvPT+JJRwkhhBBCCCGEvCcocCeEEEIIIURRS3mpmciSFViReaP07W1fld9RxKt28a9jR3xuyGfkq8jWg219X5S9ibK6y7LJdOxKx79QYFLaQkE/mVbbtA5VFKhEfqG4G8pz+jIXY89s60CvJwhSdmankiFG7/tmZcp0IpCNBI7Svg5wt3OwvLW+gnq7CNK73xMxU6mX9DoIrleXk8I72OYNi+Vhu/QsMJWRFogWumhijdgd2Y98WVsWuR7XEvsMn2PGtbtFOZbYWZe9ti22mFwxE9ZEoqEyF1xG9jMTY7otT9xu+ay3o2Nr/UWfQ1G6kzYSx04EWqWUdizl06fjZd/rsZXffnFaHbuJVditclor5XdffVH+8C9flQ8fTuleX4/Tcwy1Z3uzU0spv/z6ufzlb/8sHz68DXN+fm3l2Nrl+eoo6nA41PLp82v5/vufS62H8vHjh/KH3311EWS/tla+/+Hn8nKYi1U/f27lh59/KS/9eJeTALu14/TeAYRfRdRL7ns51PLtdz+VT5+Os+rWWso/vvmhHI/H2b0Tncunbac8P/38qbxUORnstHr+8Xgsr8dSXttbvpdDKd///Kn8/Zsf1eSAVn799XP5z79+cxb0n3w4vrby+fVYyllD93pe+r3W0ySB18+t/OVv35XD4c2n01PBtIJSW/fTL7+U77//+bTyfjnZfDm8lH//t9+XdsS/3IKuueg6mbexzn9qm0M9lMPLoRxbm4jrP7wcyt++/aH8+MMnkbeVT5+P5bvvfy4fXno7nU7Vr37zsXz15Rfl/Eh0eU778FLL3/7+/WWbfFay+hJLbIj6KjmZJhIsorazys/61bcjQenI/QMJ0qN+1ttv9YNe3565t3g2dHmon9gre/ePLOORjqu++mbPOWL75Xou8TMhmigGRezgOSZ6jnx7V36z4z1j6bI9u5c04m/Yt9bpuIDsf5BQ3/IXPqRY+7bg/P5fij0uZGY1tlnjQmgcSJal8+nxKj0G1tS+6djRmN/aP/kdjXv1dH18UdfJKnBVryBPSKtRdCHRwdXDZ+f/t2PjL9MTQgghhBBCyJPBF0FCCCGEEEI0rbyY+3q0yvqO0oZRp+nmyYaeppVSWp0mlJEyFRTStjw3ZwlVepTvErQLgnM6uKfdlmlQfu3LLMBtlI2axSrDChJaVdPxt1ZKqSL4auXNbEPH7bTDEAciG5FgcYEYdrJS28yUEDFK+2dBWxezdVEeunykCKAH6WWZULQv/LKEpSMCKPNzsc+zEULRaykXwcHWbGURCgk3tE/y3FOYtKRstMLkWmG+J5zO2nJFPINY9RrxU/dvui+0QCuLWmXLPJFdVIYUa3/6/Lm04/Ht2aGW8uWXH0O/5OfX05dLesvnk79d4F1KO563H0r57vufy/H1tbwcPpRSW3k9lvKvf/xt+dfff315Tvnp50/lP/7rH6Ue3oRc3//4S/nD739bSi3lX/7lN+Wf3/98sllq+fGnn8vr538p9TC9bf766+fy+nq8iMBbqeWr33xRzvpueAxFpS/C55eXl/Lxw6H88uunUsppZfhvf/i5/Lc//HZy7D+/vpZ/fPdjeTnUcmytHA6H8sXHl/LTz7+WF7Hkey/ncDhNOvjHtz8WseB7+Xw8lj/9/rfl97/77Wml8mMp333/Y/nHtz9eVoZ/Ka188+0P5ev/P3v/2eC4jmsNo4uS7cqhw06Tnve5//8vvfeeM+fMzA69O1a2Jd4PEiUQBEjKVZ2x9vSUzQCAQRQlLMJHBzg4WKEfSeWv3gwk7EA8995js1nhh5dn2KxaeO/w5v0N3ry/wmrs8KZxuL19wMPDDuv1aiB7EzIdndvD9x6/v3qP1aoh1xLw0w/nABw8PJqRaJgD7XOJuK6R30PZvvdYrVv88vICm83w2rz3Pd6+v8Xrt9cTyd8BePP+Gicnl+j6Qdf9w30wAr73ODhY45cfL8fo+UMbXr3+gLfvbxD4hPfbHa5vHnBytKk4VKrvEaTrOVdeqiPJqFm/1AjCGb28/JJ1WCOaltrBy+TWRm3d2te+fe5Vjyn/WCy9Lz7VfdSwDKVrvGbNyOGpn0lK9ubKhOdI7bmXH0Th5PIpXZAtXqOZsly3iPGZt5aUTUnmkz3K4S3N5lrU7BlV2exdQLRBqrVnbCt/V6Tu/2pECp9r3uXQNOndlyZLez+m5WnyovcqmozMw3au3JTnMrKpMaD9wA4kSi/k+Ms6bmMuPfedNkB8EePgLXCfwWAwGAwGg8FgMHx3sAdBg8FgMBgMBoMhhYd3skOGer5y3quQz71tDqlTiMuh5Uiem36N18/lSnCyilKVkmNOzPd71oPsJ6NdQPMlnxjvWmaWqENLo7bmhpvLLYE7MEXH6MIoaMEZjPFfDRFh0uv1SHERGUCJMCkSyJizPOrrkZQQbOZkA3VucCe/QCzgRLlJv+AkL5EtszYwOU9K5flI5PanhBQl98u2+NvBp54b+5Dbct/3IbWX8BQEwX0iA0v1a6MFL5FJ+2zffssd/JHk5vpjOmwU2owxKjpdyxuHtm2npBoyW00bpM9Batd5vLw8xf/9Pz/i+fNTrFcrXJ6d4MXlCfp+JpSfnR7ixbPT6TbVjOTxvh8izx+sVjhYD+T8tnHoOo/3t7dRv7Rtg5u7B2IPcHaymSK90/mQI9QNXz0uz0/Q+znt+sMNHra7qU7jgOvr+4HYPeo7Ptjg5PgA3pN7M5P//up2aqdzDru+x4/Pz/D82RnatpnI6s8vT/Hi8gS7bo4+3wN4f30bthXYdR3u7rYTWb7vPdabNX75+RKb9Xqw3wE/vDjDi8tT7Loeu7FPPTzu7ndzfyFdBwZbgFevr/Ew/hpASP/h+TkONit0o30clAgv9bPUN9J0pHO8B/DLD5dYb1p0oR3e4eWzUxwerKco/40D7h+2uLnZohlnY4jyPh82cGiaoc92XYeu6/Hs4gTHhwc4Pz3Czy/P8Y+/vsDBwXoiU0prEL8Ow19+6ES63qS1V1vnxH2OclhA6sPSOpU7VJOrm1u7k4M3rI623mn69llvS/vHz4WluquJu4YvBvuS2x+LpddwwGNI9do9tbRv2/c6oO8I+P4HSIn1fP0ebvNsPXHzL4NRuZNMJjtHGF/c3+FeINguyVzSb0tWC09sSV6zLVh3+HsV/rn0zimU4e9k+LsoDdH8UGyRdPI6jmXQd11THn09xHUownLvxEQIL6eSNx38PSb9rr1Uo7J5R/H3ndoLMmaCwWAwGAwGg8FgMBi+T1gEd4PBYDAYDAaDgcEDgBs9LD6kZDxL9DvP01jRktKcJy3n7JFs4d47iSHOy1Wo4vmRapem1cgo1Sk5sniTcmUqmh/plXyGpaGS7OJp6vBI0eNKeoSoazmoU4wSwahDviCTk6emyJxBDrVtJLnnHOtFh3qOsMnaNxHnM0TsaUycU/XT9KgMaR+Xp5qv5GuktC+Z9P4l2/at4VOTzR5L8PuU9vK1L0ei5NjHbokMpBEwl67PtaDrFSehltpUSyTNrYXDwSrCaxnL9n0seykpVrVNIY4HhMjmZydHuDw7hndAv/PofY+Huw7bbYeHXYe7+4eI4DxEXR8PXzXA4dEaDx+2o07g/YcbXJwekXY53I0E90BQu7g4SUlBnLTG+jWQ7g82LVarFl3XwQHY9h7v39/ipx8vses6bHcer99dj/sRB9/3uDg7xN3DDhIGuQ43t/do3KCr7z0O1xucnx6j63pG+AXOz47x/uoe290OrRsiodzfbdHtPJrW4fbhYWxP6Gvg2fkhGhdHeu26DhenR7i73+LoYIXj40Ns1i18P8wLfgAg1G0bhw/Xt7i6vptJ9N7j+OgAF+dH0Zzy3id7kpo9w1xu2IcM25F4w+69R++Bs+MN1qsGXRfr2Y3k9H//9ja6id883OP4aCCor5tmGCnXwDng7u4B//2vP3F+eoTj4wMcrFrAAX/95RK+9+jHMZjaVtmuEsldK0/LavIlOzjpu/q6Lch+ijWR9gG1Tdonltbpj4GPSTKu0f0xyz9VXcPHgXgo9YnmYkmO+Ay88LlGtJc9d9Fny31A7dSeRxNCMSkvrYNVBx6dU5+vi9eSc/MvxxE5/HlWksWfiUt7Lt0Etu/OWxzX5XrYM3oydzJ9RWXm3gdx+VLdmvK8nZybzfnauXQxz8VtkVqdpAmdL9bNvZgS5Ve8hcoV0fJqOicz3HanMRgMBoPBYDAYDIbvF0ZwNxgMBoPBYDAYGFLnmAOcBzxjcOc8VZJnSvKQcW+cJpPXpzZQmZIzSZLvlGpjMzVnH1erOZm4WdzknA+LdjWVoTn6NHB7JX+aZC+XodlZq7+kR3UdEod1ttxUvM7CpB+p41gjMDFieuJQJ0IlouWURkj0ImFcaUc1YVWQP2URmyaS5igz5HGSVNQXo3wn2M/bnUMtCWApCeWpSVSfk5Rl+PaxhIRO6+xLpCzVfYzsp7JBqqfV0co8hmQoEUM13S4iCSNaU/u+B/3ByFJ7qg4CcBKZj/lOw/o9rOXvPtzgw9UD7rcP6PvhluCAiTg0E7N9+B8cPPoeOD46wJt310NEdgDbhx4P2w7rVQvnBuL4/XaHZrwFHh1usFkPkb7h5XWb30tnwvXwfy8uT/Dr7++wWjVo4fHh5h6X9/c43Gzw6t079L3Hqm3Q9x7Hxwc4PNrg5n6LYDm/V213Hbqum/sLwGbToGkdeh/37yDb4ehwhe3VbiKy7/oeXd+jaVs8PMxR1XvfwwHYjJHuafv8uBn45YeL4XCgR0QSH5pOBs0Pkdsfug6///kB7fgzRd57rNoWv/x4ib7vVV6btIaIc4dsUMKwh7J0uNw4NgebdbypmWQD69UK63WDvhv6xAHY3nfox83zwcEa6/Uau+0OzcjW77sef765wpu313DO4eCgxcnRIc7PjpKDKrRdHNI9WSJ1S9eSRFLX1ooSaZMT5HPXbs6upySWa31X095PQcze917wvcD6Iw/t2l+6R/+Ue3rxeVchkFNExHKhfHKgeOmzErGNr2P8XpqzlcvR2lBlU2E9TNZb7+GjvQQ5WK5hJMVrbRCUsjtgfE/cdz/NdXK7o34NWikhn1hT6mH+HoZ+1t5j5cpqbahBrg63wY//x9+F1b4Q0l5DVnVY9CXz5o13LFcs6ZMG2rPvNF+1TU0yGAwGg8FgMBgMBsM3jqZcxGAwGAwGg8Fg+M4wMqHc9Jl8qGU8U+dOzsHDZUnOqxqHVMGuqC0S85oUzDnguLuLq/Xss2fpEOolXeXSPFpfMt0L6Zq9XJboWBTK1YLK1OyvheQjLMnKRo4LdVxhwoAT0XQiVDK9BdLZfBnFhAFKypTIA0v7TWw7JQCwMp7Ui4jvgp1OkJ8jaNB/PC+HfSNuqqS4RdJmPBUR5lskLRnxP8U+BzL2neul9BwRFJBtfcoDHZp8rVxVtM8987k+jcBVisgsrYsA0DZDROpQv/ceD7suKVc60BRI6JLesIpNJGog2QQ0jcPN3Rb//T9/4PfXH3D/8AAHYNU6tI0byMbjpoAfBpi55wPRe71qI/L+1dXt9Pndh5vIrrPjQ/TsZsWJwBycYH50uMHBZkUL4M+313joetzcPqBt5nny4vKU1HdRHfrZ+/g+3K5W6HvFHgDtqsXcz5jGEnDou36+dXuHpm3gmnQMw9+u94ku+d45fH71+gOacfPpvYdrGvz8w/koQ79OOFmeIjfXNbJxuM+3qwYge4FZlkfbOqxcG/Ve7/tJf9M6/PWnS6xWDbZdP+152saNHz1u73f448/3+P/97x+4ur7Hqo1fzfO90dxfs52cZK61jbeT94VWRus3vkZINkh9XdqnlFC7pkp99xS6avKWQF7nDAYZ3+L80NqUO8STlGXfq54TFV05UnZ0QIgRv6X1jz9TTjLmQinZPKM75Isl6JonSiDlJNmFdwbk5q/qWPIuQnovkssXZQt5nuVL70+ktFBXeisivR+SdAZ901gperhtEpykmFXWZET94uP3YAmkF2BJAaF8rnG0I3knhq186SLVXugx/d/gkmgwGAwGg8FgMBgMhgoYwd1gMBgMBoPBYKhBcLZwp0uuvOQhow4eLtOxMipc5ORKbBTsCM4uzdSpqM/4n/xcJiNO7R7q89IcpNyvpTkvNfm5MlJXc/30Mx2qwXFZZxeXz32Bpekj+QSHD276Lvn/ajCVzxDDovLE+S0R3v3APoOLslIyQtRfBZLqRCgj6VJkulx0OE4Ao+32zDZKPpCIBLwdnLRHy0Uk+ogYN9v81ESVUuRL2o8fCzU+a6nO14qvgbT/qQlRn6JPlkbEpHVyBNdS+lLwNYISnrTyGhn3YyFHIisdBqB1msYN0cUJIfj29mG8RQiENEH+btfh/qGDaxzakZDO7Ups8eM92Tm0zuHm5g7/+68/AQCtc2jGt5273mPXDdHI1+sWm9V6uqfNcmMbnz8/Q4/5/vHh6h5932O73eH2dotg3mq9wuHxBr5P73n0ezzunDTUo2kczs+OhijwI+5ut/jt9zdjNHzA+x6b9QoHBytCyEeC+RDALMuzFVq8/wEId9lAxJ5Jcz7S6ZwDfOG+IxKS2ffxX9s0gIujem+7XiUiwrlwBDWyMZoe9Prv48Nmsah4feiFQx5UVu/9qIvc70n5vhuuib//8gI/PDtF6xp0vce2n/uwAdC2DZwHfv39Lf54czXN11xfSutKSC8dpMgRv8UDfUznEhJ7DrUE9CXE/VLdpcjpyh1U+hg6v0Vis4SvYU/1JWHfZ4nF+/TCusJRa1PNGjDdtZz86xPSuucgrzG5dmjrp4TpmW98Jk2eW8P+Znw2DvKnfqnRw+5J0rO3U2Spz3vsnl9jj/aOQeIdJ3X5eKla8jxp+i95J5Kpy/9JkPKidz6CPLB0XpdCe+fD9Ur5pZc7ar9zQ7xSlnfwmCbs2mJD6WD4tIg6UFwGLyt9z0ya4drT8w0Gg8FgMBgMBoPB8O1iVS5iMBgMBoPBYDB8X/DTPtnFHpTgEJK8XDQ953TJebVCmhc+Rx/99CX5+WIuV/rM/FXTV82byevHHLMEXEypWyT/VkQa0uowRZJzUXM4Svq4jNRHN1PANCfoVNbNPxe+Dz0lNxRTnmPzc/yuEXDKDvy4x6Q6Doh+Fj2kTbaQPJVQwO1m+qKId0E2ZpKARsCK5CAmB4R6GslVJHERgkLSVp7G2jfJzpDCKJIofwvJK5+bBJWdqxLJI1PH8DhEkSaF9K8Z+9j/JbS5llCvjV2t/NIY8zUvF0FVIpRp2KxW2G47eHg0Dri5vQf8CeCaea8ikPiHNOCPPz/g7mGLVeNwcLjByfEGx0cHbHPg6J8IPTxev73BwcF60rXrPVZNg2enxzg6XmO9WuFg0+L9h1v89sd7DJzqmSgd6vW9w9HBGuu2Rdf1aBpgu+twe/eAvp/vv7uux8XJIdaNm4jp/F6j3accu0f0vcfJ0SHefrjBbtuhaRw8PB4exs/eY9sDl8cb9GNQ8Ing49KxaRqHxjl0vgcwHEAborAL9CXvATTYbndT47z3aF2Dtm0B9GibJtqT9F0P7zsAK7GtbeNmYiLrGw4H4IdnZ/j3q7fRxu6PPz/g6C8btI1D7/kcj6dGNx4CkNrW9/00z8qHTAabuynyevorM84Dne9Iexxc00Sy+37Y+11enuLy4hjbbY+b2ztc3zzg7n6L3nus2mbo51WD9+9vcHK4iQ4vUJ0lkmnxkNuCdSGUz4HP8ZK8Gln8+2PW7ZxtHwMfU8/Hkv0t7Ae+Z+y756cE6BoZ4pqt3Edqnl2mdbTyOUd6juc28Oc3fvB4SmPrDP2s7XVo3lSHPmuH+/tQcb7fs+dcWhYAnBeisYc6yjN0dKCJ1ykht5eT1nCQZ7TcvaWseSrH32vknhtrdNW8spLe7SzRy99DcW52wsmmBxAUmdw+rzWkZCh/0bakk5X09J2ZG140ajaWOlbsJMWmWrjoj8FgMBgMBoPBYDAYvjNYBHeDwWAwGAwGg4HBAU2VB+YpHDa8nua4WqomMLALFb3k/Xss/Kxeao7qlPKxD403gWLkIYkyNT+hR2pX1p7YtNjpTdLlCj7x6VFZs6DZEc/7KqnLHKcITu7ayHDUOS+RCpxMGkhsV/REpHSWnhCbWSHav4GcwKdvQhiUbMxEvssRKRzrk1y00hIc0jaL8yBjGyV5LSF7PYbk9jEQXZefmYT/vaCWTP0tYMmc0g7+fGwsuXYfO0ZPMcb8AFFFDZyeHiKcB3RuIHz/+eYKbeMSOdTG1arF23c3uL2/R+OG6NlX13f48OEufVmp9I/3Hg/bHbquI+sl8Oz8BP/P31/ixfNjHB2s0TjA9x53Dw/RwhTK0+9t43ByfDjdY5rG4d2728EuUvf89ACAfN+kf2e7GRnNz3e61brBxdkRPEifubn+unE4Oz2a5aYDEfXratWCRmS/uX1A3/cjH47ee4bvt3dzZPoeDm3bjpH0HTYHq2RLenO3i8iSQRYA/P7ne7y/ukO3Gwj6rknn0nwfd2gah7/8eEkORHn4vsc///MaO0Ze9wBGsybsuiG6voTttsOu52NC5HFypPe4vd2KshyAm4cHbHdkbOGngxXODZHZm2bIu7m+xcO2w6ptcHF+jL/8/Az/9x8v8ePLc4QRDM24vX9As2DfsWSPUtoX1ERLlwiglKy6L7iu0tqzNEL0Y+37VvEt7ge+dnzKEflYvzpQcziGfs4eoiPPvNqB5iAnIn97H92b+LOWdvgsWc8YuX2SJbwLcHzdonayZ3RKwIdWJ22k2BbeD0+Fp5CUkqXl9Jr6+14byfuIyrLSeyLtnY4mO/f+asrXiOM5ZBQ9agqIDRwT+Us0yRaaFz4r7zKj6A9LJwYtbrd2g8FgMBgMBoPBYPjuYAR3g8FgMBgMBoMhhxJzuuSQKXm4pLLUkcSrUccorccdSU74DlKOO7KYE+pRPqOCl88r6TRZ8n3lbMoS4TPmcVI51yd95rKl7pdsE/19jKwWnOtUX9GhWkHijhzjzEFPClUTwqcqTMdEuufpBSR9wqLYTeOQIxCQqHoSaSr8jfKZvBJ5METOi+SRPJWwIZDVxf7l/U+I9zW+X3X8C/mfE16YM58TX5ItS/E5x/dz6K5aWzIHVx5L8tv3Vxa+hOtQOvCiHXDitsf2O5wcb3C4WU9rY9s4vP1wh1evr9A0QNuOkdJHmW3r0DTAm3dXePPuGo1rRp0DefnF8xN44Y6q9VvfAT1pSrtqcHF+hK7z6DqPvh9I6l3nI5J6ej5qJr+dnW7Qzjw33G+3uNs+wLkh4vrhwRoHmzX6PeaQ1O993+Py7BirVZPcSzwcnl2cYNVmXuGyMTo+OpjqN02D7a7Dq7fX0aGDpnFoVy3+/PMKu65HM3VMj6PDDdp2GLOjzWrOw3C/fvfhBr33QxnM5O7376/x7v0t/vjzPf7579f4f//5B66ubqf60jXYjf357Px4isbunAP6Hn+8/oCmiSpg1a7gEO+FX7+L2+YcsF43uL7fDiR7Ze7w9KZxuL69x/39dpi3RJ5rHN6/u4Uj+wQHh+PDDYBhDv77t7f45/++wn/960/8z69v8O7DHdq2Qd8DXdej74Hz00Ns1ptpzg5N3W/vlCtXtYdT9iMaQVyL3vyUyMlbSoDP7rc+Ab6Etd7wdaBmplSvCXi6vSx/zpOuqX1/zWHf6yN3+JdHXRdtyzwrT3blyPfMds/+RuU0HcMX0Y4acLL90nVYXMvjAtn8pyCd5+QtfeXm2D96DWjvVHLpIY3zuks2l2Z03MeFwppMR/7Q1xhFhRWGSe8e1ZciknEsX+qkx0wkH6m1G6zBYDAYDAaDwWAwfGcwgrvBYDAYDAaDwZCAuLb8+Df8KbKNM99rVSs6IjqPxn5e6ihSmN1ZMUo/5Bx7E59Y0y19zxTRfGZA6qPzLF9RlaRLfVDyyVGdUlluI3XGAtRBXXA8K7plB7fbK0iYRCTS/JQlx3pC6INMdovKMLIlj4zL7QAjXUjRRenP1QcCg0iGFwjskS5qBytDI8yD6ZPIVxEhXugPF+rPlZIyRTBi/qdAra6obV8AviRbviZ8qRFhsxFC9wCPFlpTPmdTrtyS/KWQCOwacY2X4X3qe+Dli9N5q+Q9Vq3D2w/X+K//+QNv3t1gu9ti13l0XYf3H+7wz3+9HgnwbiI/997j8vwYB5t1Yp+fdMftkMai73o83O/Qtg3a1o3EZ+DXV2/hfb4vg46D9RqHh5uIOO/G/LYZCPQYbxX18yrt81nv8Pfy9AS9j++/q5XDxelxXg8dk77H6clBRIhvG4d376/xr9/eYtft0Pce9w9b/PvXN3h3dTNEuJ8OIDQ4Pz9C1/Xoeo92tcLx4Wbexzlgu93hf/73Fa5u7tH3PbZdj1//eIc/315jtWrQNkO/tw44PT5Mxo22JRw+eP7sBMeHB9MYOedwfX2PV29vsGqbqD8ON6tJZuMc7h92+Oe/XuNhu0XfAw+7Dv/69S3evbuZxo2OwRxUN90DtI3Df35/g6ubB3h4NOMBhN/+eI+7hy3a0K8eODpc4+hwPRyicA6rxqHHcFDjYNXi/ftr/PH6PRyGgx1t2+D2douHh2100GK9WinDWvdrCvuSS6PIxCRdk8Pt2WdNfexaliP079MPHxNf6n3R8GWj9LqhhBqi7RJZwHjts7zSoWjtmhT1FCKS82e7yTaFdC8dJAtrXfrMXTROzYpkDDevqHztIe/s83CFHUugPQ+qh8i5HZDnl0YSl/IlGdIbEC6zZsS0V2NaXeVVWBW091KSzPAupuYdVEBuLZjSWcWI+C51stRB7IWUOAaagdLLOvWFIBcq2FMBP/yf8RoMBoPBYDAYDAaD4TuD/AbdYDAYDAaDwWD4ruHJ/wOpa2qRmLr8IJp698hnSrQVHXxOrqd6Gx37jsFvOhVn9SKxCgF+6h3uodzDHzs6ruIA20ycTgVP6wSEdnDHXYkMoHRZol8aG+781HRRh3uubdoszNkfSMQ0cpxnEeokROQFRW4V2Yjo4kSEiBAukc0z3yc95DOEz6GuFs2P2sQj+IXxSMgHjJgdCANTOd72kD7q4ETZEunSsfpBriPyNFm8jNT2qc2fCLXEPUM9jEz38bG0jx8bhTmXT6/rfYmmEsFXIrRKesL33nts1iv89MM5fn31Du24tq3ccEd8/eYKr4D5kJ5zaDAQiYO8zgPHRwd4fnmKrqtbk7wHPDzW6wZN6+AJG/23V+9xenKEtgW6zuP6+nZcx/W+5uknJ4e4urlPSGVN2+D44JAs8fX9L+6dxr7tPXB2usa76xZ9100VTk+OgWaI8q1jtrH3wGrV4tnFCf54c4V21No6h7v7Lf75r9fzbQmIIpzvdh4/vDzFetXM4+A9nl0e48Pt/aSlGe399fd3aMj8CLK899h1PS7Pj9G0A4G9acLmcd7F0H1J3wM//nCG/+9/vwLcoKNtGrx/d4XjzQqHR2v4Hmga4PTsCHd/fpjHxAHb3Q7/+583GKcdnHNIg947ckued2yD/eSaAPDb7+/QNMPwd/3QDzSSfQ+PZ+cnUz85B5yeHuL99S1WTQM/9u2bdzd49/4W63WD3gO7bQ/XzKRGD+D4cL347NqS618qW4p+rJXJ7fly+R8bOb18HSuV/1aw773hU+Br3QMusXvfNqoE2M/YXxGpnKUFiO1Vnj+ka5JkJvfd8BxGn8nUZzdaZ7SBQyLAa23O3bcl2/kzNn8+o8/5k3xprQV7r7Dvtcye95OWhudJ/7hf1KLvWKaxFfJFGyrL5HjTpddO0juchW/2xPpanlg3TG3hXZ3f5/IWOku0gb+4ovVKHablJROU6JIGXiovvdQrbHUnk7++24fBYDAYDAaDwWAwGB4JO+lsMBgMBoPBYDAwSPGEPSqcflqBfYje1DnkQ2WF7U2dQUttIIzrHHE658zj4h7tcPLxR26Xh2xD4uPzgPOxX63oeITeVi5DI5+D5HOfniRT+kzT6NAtdcT68P+EbD21gRJ9MnJLDv4gl5aN8hJ5s20RuVIjWXKytqBHImTliJtJJHcoRKAxfxoDSlhgOrLEk9Dvo7Nfi0xIyX7he9QHRBeVkyP203bT79FcFUgaUv8twT4Rqfk4SmNbS079EvA1kre+BHwr/ZZdW/aURZEjqtZgH/K9tsZ3ncfpySFeXJxg2/VTvvcDyXfVDGTltmmwappITtf3OD06wF9+ukh5Mj6OuCphvV7h8uwED7ue1sT7qxu8fnuFD1e3I8kOaJoWTdsW29z3HieHB1iv24jIDgAHmxWadog4z5Ffi+d7ybwGx2TbdtXi8uwQu65H3/doWofL82OR3B4I2dMXZv/F+RGenQ116T2mbdxIHp+j53vvset7XFwc4OLsKDpk4P3Qx3/58RLdcKpgUhmi4zfj34nc3nscHx3g5fNT9P0sp0QqbJsGzy+OyXZgsP3XV+/R7zxc47DrPM5PDrHZpDFb2nGeBXsCmaxpmknetF3Okbf9QKQPdjdjGwO6rsNPLy5wdDT/2kDfexwdbfD84hRbMl6hn7fbHn3XD6T5MW+73eH55RHWQlsSmyrTtbLSviMXrT2UyX3P2aSV/Vj3at6e5BBlZm/4KfGpDxIanhZLxu9jjPU+Y7r4YJ4iI3mWYGWka42SnUVIaxCRMz1jga7P802I3wOjZzK+fxhuUtlnV5Dno/DcxonqpUMy2j5GqlPg8mb1VKNUP9hGbXqCuctfTZFXTkmZEsc6eV/C3hXRcvx9DU+j72foOy5JF5DaLH3mZaSykf20wvIXO3kl0ssrqpN+V6cGed9BX9xwHbzzaCdyfZL9vpCfgd3eDAaDwWAwGAwGg+H7gxHcDQaDwWAwGAyGSkjEd5JZqhx/rnHKJGWCBU4uEzFWoTuwmPMpkMDhSTE3/yuaOjqnIt+W0saSrFB3kpGr52c1Ujc4B3iX970ldcg/zT7ur5OcpmK7hLqSY3Uul0pa6m6mbe1HJ33kWKbEAVFAHTGTEhjksfLpR4GULkIgAyQkLJLHSU6cyMCJBp449kNdGtk4aRMjxUdRkJ0T2++FdnD9s/jyuC8lO0hENkcc16WIrPvonOpFX/IHhXIRFMNnjTCUj/T8ebzgRi7bD99Kvz2WgC7Jegrscw3V2ND3Hs8uTvD3X56jbVt0vUfnPTg3u/dDxPau92iaFj+/vMRPP56j77xI5PYAuq4fZXn4wJgeV5Ou63F5cYRn50fo+h597ydScts0A+G667E5WOEfvzwf6vQePXp0PUBXbXqgq2mAy/PjiBDdeeDk+EA8VJXIYGRf7/uoT4a2xnK6zuPs9Aht0+Jh242f03HxvUe3m+VJY9N1Hi8uT/Dy+Rmcc0Obfbwm936MTu4cfnh2jh+en0fkdirrYLPGP355jtW6jfqZytr1wxg+Oz/GLz9eoOuYbd4PNo/ldl0f92/ncXlxgqPDNXa7Dp0f2rfre/zrt7cDQRxD3718dgqPQRbv994P8+L0+ADPLk5x/7Cd+pwSIOVDYkO53iNpXz/29V9+eoaz04OJvD+V6TyeXZ7g5eXpMMfHQx699+RwnxvmQA/8+PICl2cnhej8KXLzL1dHOzBWS0bP6eIk+k+9jmu2fozDRY/Bt3J/eyyW9qv124ylhzSSgyyl8oI+8TmCleH6xIOzpEwgn2trkXYoRzrk7IR8ek+YiO60LexZMHqWF549pDWFH8adycDxIXII/cf7cDGeem2inyvJ+xyUlL+Uv517V8JlOBe//5HsoiT2aK4qn5FJ59+pjen7m7iep180xrtmIP2uNNLlymrk96rBIW9Xci/GJPnh81Mt2+zlncfX+QsgBoPBYDAYDAaDwWB4HPQQMQaDwWAwGAwGw3cKD78CBoLxHGPzEU4U6tzR2M/UCaSyjRUvEXWMaU4wzQFFyU61TeT63PwRGP3FOZZ4QTT9m+gD6R5Bvhv1TwHdiAjNoTl1/6gnR4Sn5kiOTV5eGhqHtPtkOfmotfVwE4FPs1fVIzm4KSkAoc/Tci6UVfKDLK1+XGz+GfsSGZ7+LHyw1Y3Ecy3qngein2bnZIaoTrCZ6Ax1QjmqK5TRSY+xDk7coGUcqZc23U+2lSDJ1MCJLdn5IukiMmrtCzY+FcwJbvjSUFrLniLquybvMXpLNnX9QIT++1+e42G7w+3tA27vHrDb9VPd1arF4eEax0drHGzWABy6bmYKUxv63uPkaIO//PwcDVmHenZYpu88fnx5gYuzY3y4usPddgff93AOWK9WOD05xMnxAbrO44dnp9MtItq3sPb1ADbr+LVp44CjwwO1H3LpTePw08uLOdENEeU5HIC//nKJ7XaHw8ODqG+CrNPjQxwcrKcGNK2DF0jSnfc4PzvCxfkRrm7ucHPzgO12II63bYNN2+Dk+BCHRxs0QERul+5Pq/UKf//LC9xvt7j6cIf7++0Q1R3Aum1xdHSA05MDtK1LiPLeexwdbvDzj5fTnrp3wHrVRrqaxuHnHy5we/uA6W7jgL7v0HU92jGq/uHBGv+fv/2Id9e3uL65x3bn4fp+aNdmhdOzQxwfrHF/v8Nffno27IS8x8HBaiQkpuPT98Pff/z1BW5u73B984Bt38MBOGhbXJwO86hnfUX7q+8HkvvZ2SGur+9we7fDbtfBw6NxDVYrh8PNGienh2ibZiLof05U7a8q5XwuPPWaGbCvzI9lz/cK28cNKEUPD6DXdI6YLtXhn2sOv+V+ZSbI8N5HD+kamb36eUZ4/pJI8RoxndeL8jE+vxT6e3onQA87s/YHYv2+q0HNM3rts1mpnMS1VudLRR7nU0u865xO6T2J9ipNg9TvWlpErvczkT5XV7Jfss/XksQ1ErySp84r/l6RD4pWxw3voKJ3ctJAUlmazJK+GjAZma4wGAwGg8FgMBgMBsM3DiO4GwwGg8FgMBgMKRoQcjtAycYZdwr1wGnOHO4Fq3T8jNxQIkTRKzmeJJY1UOcZ0hjazLsUNUNgbC/yb0l9xLI1r6on5amJXD/3yXHHo+Y843U0P1+N83huwkxAL9VBYOBXkGbmOoRgMP2lhzdS0GjskUPZxRJpBDxBSOz4nwyLWGXygQAhAh4lqdNIeZKdE8mdkBo40SOWM9aUCO28LM0TiPC0Lby9uQiFErGiRC7xpI8mO0JfS6R6N82i6K8EKQKiY4QTjdSiQSrPiSw5mUv1PRafWp/BEPDUxMgaeUt18oNHlETWdR5t0+Di7AiXF8fCbWIoM5CE5bU2yFqtVlit4teX0iGlruuxWq3w8sUp+Oo22NTDOYfDww3RF24VadsbB7y/upu+d73HxdmhSN6ugXMOR0ebKE0i1vUeWLUt1qs26bdQdrVusd7M+TQyLi8fooMfHx7i9PgYob9nQnY/RIRnOsT7Wu/RwWPdtnjx/CykIuxqvAcZ11geADRtg+PVQSqXtn+09+goLTf0j4/KnZ8e4eLseLIh2NSPdqxWLdbkoMJcis0hcuqhaYCL82NcnJ+Q9mGMOj9HY8+1wXmH87NjXJxTreNfjymK/VPhsYTqr52M/aXZ/6XZ81TYZ54pj2yGR6C0N32Kvat06FaSnTuYW5Kr7bOn5xT2zKfZEj1LsmdE/jn7zEbyh3cK8QFpXt8JafuA99lSXvD0rM2eiQuvVBIZks7kGbtSllZeex+j1V3yjoXbvRSRbU5+9UW/83StfKJkyeW59H0drSMZJMkTberlctJnDjp4PC1XXoKY7uymYjAYDAaDwWAwGAzfIYzgbjAYDAaDwWAwMPCYYQO5veBqXOJFyziHPAZSTFJl8LLGVSTnUSggeRZpPSmLe0Rr7XeCk8/FZdSoVQImbjNPpypd3m+W87/V+ta4n5D7/iRfIHfGavmaRdT3SHU6WqJyrkk2z1KIEIGkLkb3lggLnkQrZ3U8yY90FWwOcqktE9mayJ6I5s7BUfI515chNMx6x2trLC9GaxfyovYTeyi5HiSf9gEndUSHAASIJBBBhtzAmEAeiPmRbmJ7lmA+yltC/s6VyxFlIr3MZtW+JySkG7nd8LEgrUefOuJvbSRYDdohIIqu93C+XodIPBMIahRxukfXDX+lcqkOJ7ajccCu87i+vkXjGgBD2sXpycBAF3XXtU/75Y6EtM/EcoJdjVqupxs6Z5Tlk76tbc9AZKfkJ9onsb1pu/afCxQ0YnppY8QPkOVkBsSHL+ZaTVM55g6EwB76NiaMPeU1/5Rrx2PXhqfEl2SLYb9x+Fp2Up/zUKNEJq+xZSoX9vAMdH9fkhY9F2B8niX3hdyBXsdkiIdZgz1Ebq6Nuf2AZC99Tq1ZW6kNklxPnuUkSdNzGyOVL0Lm2XIppGf3JWRw6b2FBP6+pTivWDnpXYr0/kV7l+Mz5STdNWWS90msYZ6VLb1vEsvnOpnqK3Uq7TSpU6XykmEUSX0HoJHLJJ1V0FmDReXLez6DwWAwGAwGg8FgMHybaMpFDAaDwWAwGAyG7w2x02Qiv+aqcG/dPnCzrpJNSRJnVlfAq18gO8wcS2dOusl5x2Uu7BtajVfNNY/nlRy1vImRk9Wn+nJOUsknKTk/Q1nJoas5bDW/IU+XvotdL5Ckc3JCnYQoQOUoJAKJkC1BnRaEZED/BdkJgSLooHpIdD8pejuVP5G7GaFebY9CRonJ47yxsd5If6iDFGKEQ40MLtSf5leOMMPs4f1dIydHJHRsPKW6gfiyD/YlJpmb/NvD13g44VOT259CXy7ad0CtnppDLDXjuoQwp313jcPd3T16H4jgwMFmg/WmRSes4UvsKZH2crZrBP9SmvSLHPwe+Dmxz/W6T99XGrNY71ON8ZeAfdeGj7XmltYXg+FLwWOu++IBzlK9whrklDz1+hrvxzzyOY0SLsnO2UwPK2vPL/xz9NyGtL38OYruI+hnbRymtrDnOWK00jpEBPimYvxECzIE+tK9aC4ml1uyJkcl6XMzz5PKM2jvSaQ+0Ejv6nwXdGm2aHzsKjidC74EybsxtdCoi7780V728Eu+RDDng1jzQgvC9Mu9fCoR5jkhv4RsufKzgsFgMBgMBoPBYDAYvk0Ywd1gMBgMBoPBYGCQ/C9zFPf5e1JJQ60PpujNG529k2crU1f6rsmnHkzJC8jral7IjOPKFfIlkzS1pabwz6JKn8qkcC6vT/M/8i6U1NJu0PyBdEg0kn+Nc1n6qxGQeX9F7ZAIXRjJA7wsyY8i0ik2RnUqCfFBNiUXiLJIvkbuoOWTSPGUdB7IE8yOhNTOiB/eMwIoLU8IGzQK/lSX2CEREnNkTUrqKM4XRs6PiKYRWb/OqTxZoZB9NDkSCZN+/1gwN/m3h2+BEFl7ve0DSgp7SjzG3hqifI5AWBMNtta+vgc+XN2jCcs6gNOzQ3i/vI0fey7WkuOfSlYJpYNMtXqf4rDD0vbk9hRPqYfjY17rkq4c9l0blpZf2l4jtBk+NvY+JKnsVUv3HP48pkUnHwuLzwIaKDFdO/DE9+OiXGHPHp79tLZM31l76HOb9jwzPbOQ5yL6fMX7I7KJktSRjov67EGfFdlh3jExraMcKNCebaQ+i8rQdpHPNciR96HolZ7/ScXYJqWcJkN7PUWfRfl7FKmMxMvmr6xK72qkNOndCi/DdWplo/TScGkdyhukdQA1iF5eyYsJJkOyQXuRNU++YdqXiOu1SOQX5ObKeQ/ssRc3GAwGg8FgMBgMBsPXDyO4GwwGg8FgMBgMDKJzUqDxFn9AWmNPL4Uf9I/+nCg90sPTVdYxyedlJF+RJJ875aRyRJf3Qj6RF/nQvFw05+vSzE66iPGtfbAN5a4pIdTRHLihgOQsDfXoZ0l+Drw+tUEaJq6nyoeZRLibneeRQ7iSqJ7VVQlRskIwqCFPTkQLSvgg3yEQFSb/MIv6N/QDSyO63KCgSAyhbZjy2feEKKO2NG03lc/JbdTeMSMrr0ji0KIkzolVNn8LBGaDIYennOcfi0Bbioj+saBFf831Wc2hmoDtdoe7+y3CuaNV2+L44OCzrz21Y5glvClyn2p+LOmfx5DYv6R7wL4RdHn04Y+BUnT5RVF+n3ANWRrZ+ksab8P3gaeIvp6TsfTaW7JOSwdVPEvPRVFPnmlYPt+r8719Qjj38y9keZIm9g+95l18SFg7BKDJnJ63cusI6Vv67DNtAHL9oKQvfQ6ODhPnSy6Dl99W7fuKKnrWB5JnYV5WelbWypfI71L5qQx5lyP95dBeoUnyc/n5hAolTEH1bU4awNqXWBUdP4yt08uUZIZlovZdaS38WGm4NFcLaxsMBoPBYDAYDAaD4SuHEdwNBoPBYDAYDIZaTFG9gvMzEF6V8twL+Fj1k1ifJtZ48CRPXalezgMoOdA0P1bJgwjioHTLHK5LyLxUlydpNV2j6vF5B68jH6i/m5PReVdzn6Uj/zRQWbw+dzTvNSUTosSclvTXHqT2KjIJj0SIlEigyZ7IC1KEvlBOkcHJFQnpm5IuQhqxTSNXaOlhvCSiSInwFR1oUCIahvpS9EaPtE+nNmf0RuUE8ozU9kQWIb9Idabx+QRk3c+BL8EGw7eHj0Gg1cjhT0WYfWpys9QHkpzGOXy4vkff9/Deo/cex8cbrNf72fqU2CfS+WNkf2zUHDp7zPyqsgGcF8Z3SxUyFhwoeIz9+9StuV8vlfUpI6faPfHbxpc8vrmDVDxNKreEkM6fZfYlxtN1MyGAK+Rwam94PpoI3uOePDwX0AjnEumcy+R/s8+wCmGdFaIKpucIh3h9kp7h6POfZCt/Pgr9tc8MTWTV1NlXV/ig3CtLJO3SDK0lg0tpuefsXN1culSfNj3ordHveUJBN81Lqi19ebUPpHeLS97VSZ0nyJz3QoIMTZeQnv31S25nNXwYOOM1GAwGg8FgMBgMBsN3BnsQNBgMBoPBYDAYOLxfz44xHzt4MDhrHPUqMadMVGdOnLEHL8SPLOqoKnVs5ZxbmgMs5wijZTj7R6vv2V9an6cL5jnJVs0+DSTfp0nZalS9lka/zwTiOr/c0mHPOXY1h62WNzmwBWf3kn7iMqPyGWJGUe4jyVLZKIORHTFZjpI5pjRePxPhkH7m0RUD+SMi6O0RDZITXjh5RZwLGrGignDByQ6B1MJtofmS/bloyVoExqCflpHynzqi6+cg7Wn4EmwwfPvYZ56VDqyU0iU5JYLzUyNHOJzXVI+7+y2atkHTNHAOODs5QJ/j5iwgI5bWxyV4anL717D+POW88HBw8Gjc0PbGOTRtkydiPVbnHvZ/rijmX8N8MHzd+Fhz7GP+IkIu8jkw75tLJOenPHwi1qd2VN5rI6L4XEB/JqWHhwWb6TPEpKNizOkzq5QePf8IexMtQn1Rb6jzsSKqM9lA4Or6+SD7Qrun53Hl4EUtUVxK50Tx0muakMdfHQU5uVdQku4Ah7i+JH/6HN4DMSPVXnVp/vQKQKife+UWleWGgX2WXjBJrHwugxvF39WVjJNk5+po7ws1KHLE33crLXFLTz8YDAaDwWAwGAwGg+Gbhv2Ul8FgMBgMBoPBwOAHrgtSVwxldwcEMqufSosOHC6mxo5Axp09uNP/e00OdX5pXsJS3RwkBriWn9NLvYRudCRyh53W3ZLnVciPivJykmzBXA7N76h1t6RSGyKaJnVzyZnM5Yh5Xo5Nym3TbNCGw42yh0QH7lXWfKOUPBFXSGXQNmTzkRKo50jrLrA3JlkxSVwYFUlPRv9EPqdpyDjzqZwQiZCQ2cQo50xmVIbZFhHjmF0a6YTLEv3zAiGS2pQjTJaiT4aDByWSCifK7kuU+pJIfI9pRyILBRLJE+oyfNmoIduVsC+h/bHl94W0dtb+gsbffr6Mvvfew+cY7hlUH8Ba0C+OrI9PiY89Ntr9LFdmqU2LdHiPo8MN/u/ffyD6gB5e3XRx+TX6HouqXz/5BHpL6QbDx8BT7os+hu6I4K3U0/bCvNxjDxtF9byHZwdUORF/eqYin+lBXb6nj2wPOoS27vPrFfyZRzrES6Ow82cf7RCt9nw0yeTyx3ZNMqDeDhbDA3BkrlDStmTPbMRsO3+PIMl4jH2RWva39AqG2qXJ1kjjyuscVYY2JtOrMxfLL72HieQ5kjZWlN7/xIqFPN6BQtmoAiesaxMk+3AnyMw1XnoB5InimskvTZBK0HeoQmZGmcFgMBgMBoPBYDAYvjdYBHeDwWAwGAwGg0HA4FcKjkSN3jtDc8yEyOvZ6jk/DeW+TpYUHDu1JHOtvPSdOttyeiXZWS9khqfshK+KN9UlBTMQnH9O+C45XWMneCxGGmbeZdJMoj5MDVQ293V6Vq6aWE3yS1MUSIkJot3EAa8SGUKk84yuHHk9yR/J0HWyxgjoIP3mpREissHEM9L3FPWXkA0pASPo8JkIiLScFiVZiqIuRmVMSPvCEpDRM7UR49ygeqkthEgikkMgzBlGyOT1kuWjIlKmpkvCPgQVleD3iLo5GVo7NKJuaUnO5Rm5/fvBvtdMCZ9zDtWQ5Ur1NZJ413v0Huj98Pkp+byPIQfvE8n7Y41RibwpocbuT03c9uMYh3+999mFtXRo4lPgeyaY233rcXjqX775FHjqX7dYsn8r/XJJskdHvL9a9IsmQ0K03w77/KWHfmj0bm2tDnku6OC2SXXIvtyx7zyKe2gHTZ+Jv276Kz3f8HZGzwOZA2KcHE8PzYo38pCem2PC86/0uYTSs/5cMNM+xK9WauSVbNRe7/B28vcNkuzyG7O8DO21kS/kS+9H6Ksr8T1OycCaFzQ5aO/jHPSO0oySpi7Nq3nHKOnkE2myzeuXRO7F0h4oBgaR9PoF9QwGg8FgMBgMBoPB8M3ACO4Gg8FgMBgMBoMI4lRVS5TIi5mIRBxCsbSuIE0Sr3kqU3FxHf7Zs3+0To4RzfVTb6wTyuQY2zxN6U4v1Iu+Mmee0+wPvnMis9Z95tlfjhIxPaRpTlip6ySHrxfqcDs02zU4pIQKzck82agRMBSSszZtgTxRxY0yx4KiLZJ83s8imXoiTDBihXNoKMFbaqtEIk+KeFGvGimRfOcEiBzxfXaCpwQZWnaKmB50EoLMpCNEnBwSorZFl1kgjwo2TumcoE8IHKqP/zHkUEFGKUKtNPer9ZWifj5CFiUYPQbfM1Hye8dTjP3nnD+fOmr2U+ExBN3HRt5/jO7cfepLWke+BPL/14wvvU++pLn2PeNj/orAY+RW1a0oU/PLQaJo9rfUT1HEcO/n6N7jvl+KYh7VU75Ltkp1woFcKYo8bRN/VuHrP32eoXt9TrCfbAvPSNJ9RDnYSg/nSs9eyaEE4fliVJDaM32QddMy/FlH+gykzzGPWVklQntJnsTPzvUCfV3jyV/+rkEjkefeg/C+k95jlOpqz/E0j76/KfW/2n+e/Mm9nyp955AGj3dwSJNe7LAyXnrpw2WUJgH/rL08AitXk8ZtfvQDa/yh9B7WYDAYDAaDwWAwGAzfHozgbjAYDAaDwWAwVOBRThTifBLlVDrEZj8WddjW1VW/cxm13tIaRxZ3lGlOvIzzjqZlm7pgeCgpO+dQjQpIyS7+Ljl+uYmJ89eXCe2ST5I6nxOidt70xOacjXzIeB6vF4jLNT7MQJam9qp9J5DFad4oMDsPqPycfbIeH3/SSO0kImFkm64sIphExAoeFZH1gUgYqYx47pger9SjJPXkcvYsIr0S7TIQxKf6bo7gTyPB86iQUjRJNaKm0Eat5/lcypGYBnKDfADhy6YA1uMpIy8bDF8SlkR4r/3lhCXya/QulflY8vHnvI6/ROK0rWsprE++PTzVIReOT/HrEI+tu/cv/lQehOTRy8Oel5Oga0judE88Zqj2JmlO/kUSmibVkdoiGChHSKf62PPKtHcWDg7zw69RNvKc4gRsj07tqoqiz9tVODCds0c6CD49Q0tjSOQ+FpIMypHO1ePP35qskMffN0ifc+8xKPeap0vyJJslO0uvvDyrVHz3U/sOTeoQCdLLk5zskM4HiH/WXgTlOih5wOafXc05oCymq1wbsH3wVGR5g8FgMBgMBoPBYDB8lTCCu8FgMBgMBoPBUMDgiHMROV2gXib1pOjtXI5WvUio38exk3Os8bRaljKH5AzkzNgaRjOtK9knlaW6MljqX4tEMl+dVC4nv0QqD98lXyW3Qeq6ksM45xSmTm5tiEqO8pKzPrGlQEqOHOoFT6vzFYOvELmBmQSiES94BD9pakaRGBPVgl4pejnTo4FHf68htnCSDY/eTu1M5BHCDpcVyOpiZP5gZ0WbqP6gM8mrjKo5fcuR+0u2VJd8GnzJxMKagxOGj4cvkRys4Uuxdcn8rClbQ5x8LEoyv+aI+d/jevGlXAuG7xvf4zzMRQPP1kOoVt7zaMR18VBkae+q7GEle3gkdRopnduUHXtm15L7T1KWkuDH78mzUHi+YDKi5w/27MEPCnAkz71k3NX2KF0SRctXxixJKT2bQn6G5dzm0t2xxBEuyiAHiCVOtvZeQLKB5mnvQ/grn1oudyhbel2Ve5U2XAvKO5SngNIYJ5WhL4dKD8Kld28akV2zrSY9oypvasWeWXvn+RgQcdW/kmkwGAwGg8FgMBgMhm8GRnA3GAwGg8FgMBg4HHxw63j4yYHiMDt03PifT7xMfqoX/krOnUUOn8iZQ3UtqKtFfsrZI5mY83hRZ54WXSrk5xx+NC+jTrRRKDwTXdPy2VGQ9CvGaN0skcMjnQV54XNEPndxGQ+56z0RUHQUh7yK/qHtWjpFIqe4QCSP+9qJ/RryeKWlLtRc+SoitvBdu8wi0sSQUCUzIkQo0RlpudqIxSFiPI2YvjiipZYebNSirRfaECBFow9yJfK9JmcpuYnLyEbqXyCnpuy+0dS/P9ro94eviRz8Ndlai1IE3i8R3yOp9UvD1zZnDN8X9pmfn3JGB2Kwtm+Myir7NpEDmpGV7MNpXuaArEQUp5HExTawSOOJLdMDn74nlaKUSwdVVd4rs4vbHtlBPvNfghIPBFA5I3kd0J85cvvtSRa1I9yXpYPB7BmzhmBdezCgdA1M+eOzX4mkL8llr0KKz96A3i4H+Zk7h5wOT/6CfX4K+Tk48qH0Okr6LnZ/9YAiftHCZHk+YCXwd181dWomCZ/spYmTU1Vz4WTwFCR07W3Rk5PnDQaDwWAwGAwGg8HwxcMI7gaDwWAwGAwGQwK34l6gmdjOSoo01zk9EOFzdTgJnpLquWQfbNnHp5NxcE36JHay5ByTZEkeziXeZcrkJuW8F/JKdpA0r6QXXW6UV8DaEZHmmX7JX6k5f+XZo8vioPIlgjUnxPOh5E0Tg4yzcrzrc/1Y02a9cmaSR+RmKtzN/wq6s33L67OogzUEZ05w4KTyWHxKUKFRCB0hhtA8SuwAJ8LQfqDR1ok8cU5JpBZCaKHRImmeRAyh5UsEJY3sotUpEoKYTZJsTYc0HlE+laNq0EmxgWhSIh7l5JZQavtTEC+NQGsAhiWgbRyaxk1/v1QMy+KwBjY0xGcBXyNR+Wu0OaBh8+mxa00Y8+kf6sfeYPgSse/1HW+Zl19XSwnj+4D/OpB04DGxi+5PWfka+3L7vSWHDymhnduXRF4PnxU5lEicO8iaI7lPupl8scyCX+qJiPlsT8nJ76EMsMeyy+eCUGRqP09nn6UI95qsHKqfe+mzkpCffX4g/6R0Ondyr17Cd0mWhBw3eslqEbo4ec+glHdC2cQg8tVJiZnOEPVK751yyqT3UBDyeH3JALGxiNuiyaLQCOyZd35L4KmsSHx+Nnxc8vk0MLaLMxgMBoPBYDAYDIbvDKvPbYDBYDAYDAaDwfClwXs/7ZNDlPZAVx9piSQ9OFX9VL4GNPr7kp/wpfoiUnqp+hIXUM4hx3XV6M7Vpzol2ZptDqnjUQKXK3UZd1jWyCbeYgfAExI5N3USLzg/ubqoPinPCbWSP1PzZYpkAKEctzvni+XDIPpWOSmbyZXapH0XweQPFfOT0Y9lOMFhsolEA4zK8OiAhKjhNFsoqYOTMiqjBNL6KoJu7+FpOaUeJc4H/ZyYIka/FCI4lsBJNAkhJmmKTtyJbGMkIcdl0/KQ5xIn4XO7c0QfqT1SBE9OpokODPA+VuTUILlWCzKWjN8+BLh96xm+Ttze7rDdbacFsW1XOD5af26zJoRrsGkc/vXvN3jY7uAc0HuPZxcneHZ5gr7/tngytRHnHxOZfmnd2vJ93+PD1QMcPHrvsV61ODk5LN3eVbStw79/e4u72wc459D1HhcXx/jh2Sm6b2zcDd8Pag+6JfuiPfWV9uW5fdPiPU0uyjXZn5f2jDSN2k8J0dGzh7DHo/XB93LDl/gZgR8MFeyP7AoHVaW9biC5M/K+1B9SG6bDrPSZhhDZ+aFaumeddJJ2c0h7eDGSPC0jSirIAeBZmvZZqp+U43twUp7+XTpvpefhRAJ/ntxTNn2W9iRNK0ft0epo4yS9M9Ce/XldrX5JzyTbpfmJ3viSi7nj7P1MZAd/8aAZW/O+iQ8IfVGTKBbqeqGM9oIn9/IlNxjSix1ug1Rd7LxPB+VYC5zzxmswGAwGg8FgMBgMhu8M9iBoMBgMBoPBYDAwOAfPievBKxTI6DzKukg8r6Dp0kjvHJEszp2dmNVxnhb9nVTMM6IFZ9ckU3OScZkesjOQO/8kuyTnmySfy6ZlJbuEoqIDktg4VRc8tZr5GoKc6pkRfPBIndCsSPRdan7J4Z4bFrBytb5N5xCRByS7JVsl/zCFVCZSynQmchiBgSNHmJDs4XKZsLmeFhlSIJmEdK/0H89PyOiUUB3qavIZ+ZpHjQSXx4kxEplJ0BcRZ5COHdVN+2Ug54xrkELezxGdpj4pgJOdRFI6K1uLiVAUvhfkaIT5Jfqeily+rxwjt38/aBqH65tbvL26na6bs+NDnByv9yYkPzWStdyFexSia/NbQi3x/DGRl5fWrSXc7/oer95ewXuPvu9xcnSI09PDfc0clSPa7zm+9zMYvkU8wb2YPyrxPc2gRidg18pX85nM2sN71E76aznqHouV5TYm8gchQxojhTsqi5Othf0gb28oR59ZuN08jfYBf+bi+2fanojMzp4HgHRPTBE9kgsk+9yaX3X/oPOMPZtwG+ufT+VDreIzJ7eRPWcmsgvf+fM4fUYVXulUcZMdS5PeFVCd0rsDDu2dgfSd2g76mU45xR5uh9gP5HLQbM5dT9XIvT8qKdBeWgRwWbyzpMGk9fjAai+D+GSgf6U2MJlx4A5S3KX5JWjllsjISQc8fI/2kYIMBoPBYDAYDAaDwfCVofncBhgMBoPBYDAYDF8iZkebQ0p210EJ8NxT5ZlHijp4JNmpA2h25JKvhTqiiEFfqTmit5f8LXliueOO1smRi7hTLvGasnSqj8Ox/AUOS69+Sct5yWsslWVlpGqOfZhJJXlzHPvLu4o7uSW4TBmvlJEc396n0yfnqJfSSk76PkNC0XQkOl1gOlaULeSLRBVejxBIhq8+IaaAkFM8qQeBPJI32LGvAjldIL47Sr4J9pGojtyuQH4BretSmRERRYgiOekmadKBA43QQ8t5VoeCyk3ymUwpiqcmQyPC0/6cuuaJmL8i4cjI5YZPDdeibRxW47/mS56DiWnytVi6juw6+3hwAFZumEtt26BprK8Nj8PT3HGfBo85VLIU+145ycFJKlM5FET3TDy9oGzSKe37lkSFj54BiJ18fynaJZG7Qx3vk708PcQqEeglHZT47rnMtJGZrHT/S9vnhHLSQdWcPC0fUJ532NgRgcXnLP4sRp8XpO+JbmaT9Hw4ldMOHGe+R89ig8GKJbq8kEafx/nrEe1VhvSeIGcBfx8gpUsySvrpM7j0fF7zbE/LT7I8+czrjYIjncyA3CuY+LpF3OkSpJcdqkDIAyrVkV6ccJn83Zo4CYW83MudnAz2fXrf6bw4h/h7S+29aC4vuXvwZZjU1d+7hrXsi7q1GwwGg8FgMBgMBoPhE8AI7gaDwWAwGAwGg4jUrRLI66WSNYR4T/JriPP1VlbAEQdTqbqvKCs5C3PeRq2e7E1Ly9NykpeVOwiXQJMl2UvLlbzNAY4RMNLs4a8TfKGCT1Dqiqm8n/P4X+5rFcyMwLuFlom+c76woDukl4ZqIoJwGWN6ylP04tThUyhqy0hSKU6VpyIz1sghxBntUki+S6RwjUwvkE2yBKSR3BMRYITIkS76PJOJEsISsV8iKSUkHDd/9qROjvRE5wofc40UxYlJQZ4U6ZHK2YfomqvjFxBo1Lrs8yIZGZk16SXZn5Lc96Xgm29zdnH6wiDtGaRi3/qYfUV4zB55ggMaNxy+mJbWr3CIP7bJX2GXVOFLWJK0w3Cf1IbKcvtEYX8sqkjoJRmV5TQy9rQ/VQ5aTmnURqafHn7k+9loHx4ZHh8CzdmcOwjKy0f7/QJxPSeTH3ylhxI02VM6KV+yg49/sX1EplPGJDJHsVHSkHtWp+1ZMvelZ+IaW3Pzmr6CKPGxvfA99zltt2yD9DqmUCXW4VL7fa6yZJzSmEgEf3FCk6IXKBnZXA4vQ/9K9aSyNC981uo7lu+Qtl2ql3lXlbzH9I4XSEADgEjYN0r7kqAiX8SN3WAwGAwGg8FgMBgMnxSrz22AwWAwGAwGg8HwpWFw5BIHa4gUFDlzFIcr5sjs3LlDv+fyuBzyY+LDd6/Xq0LGZ/Q0Px2s6HRInXH0M3UsSp7dhHmZ0SHVy3mSNVlSHk8rdNdkEnOcllx3JQ4e9VWKXePk7uX+W6mZJf6X5iedeBSknCSD5qu+ZIXsUUs81EqVCACaLWI9gZSSpNFI6TTKo6SrMmLjZBcIKYV/F6JRTnaPtkxzgxHWozlVIAFx0o0vtENqF7dZSpv0seiaUnT1iBQlkImkyJ05IpVGuJII8R+bvEZ1aFHjpbxapNd0TDZaIpeXn64Hw7eFhEH07cMI8J8IT9DNXefx8w+Xw9Iz3ny9B7r+6xvDj311fR9X76fH51gvwv03ug+T/dCUj8eN+7Rf33OvkNgo6Rjl0312bdkoXUij+6lQN+oTEnU9ipDODnAuOvRI2+sc3Eian3TkngWA6ZBp8VBj2FPz6OjKQU/dXB8/yyh6kjL0AOyY5LRDxTWHjZmtUSv4c0GhH2m95FltAagNol1A8nwtXXNLrkFJj8Z11srloNnmXSrrsetHJF97QRGUaQbyNJf2hYapjPYyRXt3JJHINTulCSDJqjGaXl7wKRk9V4fXLYzcvo9rmlz6PnWyQbA/BBShfxWBBoPBYDAYDAaDwWD4zmAEd4PBYDAYDAaDgSH8OC53sKTOlrQcJ7dTdy2NAC8R2kO6RK4PElRGcw5j+SpnlpRf66DLORypF5Q48hwGh2nifGM6nSPlOLPbsTq8Pq/H9TCbkvbluozpGUgQcZ6ndkAoz5ITcLtdnFUD3hypm6WuEYZsKpOrQ8tyOySUunqpA72mvGR/sCGQfjSS/SzDy0NLiScCYUKTJ5HRS/mcrMLJ3374Mo9NhkRCyTVRHxCCT3KpMLKUuDyNMimhKsjwxOapHZw0H0j3Slsj29n3iOxC0sM4Re1HPDaLo4eSwwYiH4IRoXIyZsIHI4kXbNqHZF9bZymBfiJqfeek9s8ZsffTY5j9bePwsOuw3fXwPeAaYLNqsFqt4PsenFvctuxa9EBfICA3jYumVt8ju34CSMlKmaFpm+Emvd3usN35iXy1WTVYr1fwvUf/hMTV0J7ttsPDtgfg0TQO63WDVdui74GG/A5n7wHP+8gNO83QMO89mgZwrgG8R9f16vXYtg5979F1OzzsAHigbYB21WC9agGvk8Kdc7Fto61973H3sJtugwfrBqtVWzW+g+Cwdx77xwMP3Q7b7XD3bRqHg/UKTevQd7q8ho77fJvJlHdwjcN216HrOnTdkL5ZO6xWq2FPXSBkhj7Z7jp0u37oOwes2qEP2sahy9hs+HKh/fqMttYX79tYThIt7SckwnV0cJDtNWpkcpvB9nS5X9gpylvQf7VlpfsBJdRLkcqng5aKndoekUcUj/6GfbRymJPutbV7WBRhHel8qT3cSp9tIuQOloY9uWhZagff00f9vSeRnLeD2x4Q7slOI91Dfs7VDvMmusLzjJCnPKqLryuk+rnn0qxNSh3P0sXnM5Ke06np4d9rRnZ6V+JY+cwEc6GspIB0StR/NS8npIEJn/mAagNHZeXStBcj2sBRfYJsRxvN89UXDUPZZcEs5EbzYBySzNrAH7x87j2pwWAwGAwGg8FgMBi+XxjB3WAwGAwGg8FgEOEnZ0ry072gRPW4hhb5nRPdqbOoJtLRZA33QNY1hekpUymitkhOs4zDLSpTcAR6Wj6jK/E7cy8w0RH5siWnpeLddcEmRoJKdPJ2k8+JXijfeVXmnE3Sx7+Tg1eD0t9eyebNkMzWymgOe6lsMnwjx0HqFj61qI9ZspOTJrjehswHWq+hxAsmn6apPmJKvA52ElJ5iay+D/ygOLZP0RMR7AnJJiGZsKiYvN+9EL3SUx2MPJKQfPx8AUdkILGBow7eJnZgQIr4OZENOVme6aW65vXHpWmsrhgNlcsa+yo3Z4Isza6I11CYP5IcTuinNpYIYVrbHkVQ/67I3TpqItR+3UT42fZd1+F//v0Gt/fb8Z417yfW6wY/vrjA4cE6Ijj/97/+nMnaHjg5OcQPL04VArCDcx7//v0ttg87hEovnp/j9OignnSe6e+mcXj74QZv3l4PNrh4T9Y2Ds8uT3F+egTAP4qvF+4d19d3ePXmCttdP21IHBy8B44OVzg/Pcabt1cABhLf84tTnF8coe+GudPtdvjnv18DbiC/X14c4cdnZ7i52+Ld+xtc39zDAzhYr/D3vz6f+tY5oOt7vPrjGlc3d+h7ROPme4/1usXl+TEuzo8TYnrbOrz/cIc/X7+HaxrAAz++PMO7qztc39xjaMncls2mxQ/PznB4uBn6NNd3HoAb6r5+f413b6/R9R7ezew454Cz4wP88PJiqOJT+/7921s83G8B59B1PS4vj/H84lQk2betw83NA/58d4Xb2y2aJo4i2jYOF+cnuDw7Hm9xqYymcbi5vscfb6/wsO3GqUb3/cD56SFePDt70r1CeXf/5cr/mtZAyc7H2K4+Ju1JmtcO/JXGL3msY4cDI72MBL0EnEAd/ibPKDVzomaPQvaxiU5hb0uvyUQyzWP1qE2hPRoxPCG5j3vl5BCCQsbX9pHS+NC9dWlvyUn3uX5woQzRo0kuHRzQHp9roD0vBps4wjzXrgf6uA9eTuiP5Lk0I4uX8UKaBKnfcs/tybMMSePvGHJlNZ1eUJ6rRxV7qWOlxtApnHsoJzLUgOYV6c6zvtHK8xcVUnlur5ZPZfLvyYApmMZx3KfwyS0OPlWXDuRwqCUUV+5BJF17l5n7hcrwnZbjhHlJ7nCY/uvYKxgMBoPBYDAYDAaD4WlhBHeDwWAwGAwGgyFG43tspAjs0ncwh4xcRkIczT33eXa4zxofR4VRnEJEsBrJXfKaBnBHJZTPknNQc8SFJEd81JoXeZSTEg0K9aiDV3Ku5jzVJeesJGv8GzXTKd3L+kRyCmt+UUAfKs2xrtWj5XkZzi3RfLmR2YJTnH/WSAeRHBCihkZiYMnR1BOi+mnXFyeYRASdOVHMpzJ4vhQxUp1KjJAe0hLidJBFCObzeMX9lSO75EhSEclDifpI2xSRcHIRHJmtCXmHpWvRKqPLlvRbRFxiETEp+acqOmjoB0aQd8B0MEARojTdT31D+02zZyJQjbojojtrN4+kWWobtTU5yJBrG5D075eIj0Wm3Fful9xXS+Ccw/3DFg7Aug0HZua29TuP//31NV4+O8Ozi2N0nUfbOpyfHuHPN1dom4EE/eHqBpcXJ+P3eK1oGuBh1+Hhbgu4IRJ4u2pxenyQRIZPEO1H5DW6aYB//Wcg6LeNI9Hl4zH64/UHvP9wjb//9SVQEz1egAOAxuE/v7/F9e0DVo3DStD38LDDq9cfpqVjIGbPG55hzXdomgZhF7pqWrx+e4M/3nzAqmkGorb3aJpmanrTDOP1r1/fAn6IiN60iPWP9V69ucLV9R3+8vOLQQdrb+eBdmRE/fv3d2gwRsFnbem7Hv/6/Q0uTo7w4w8X6PtevR04B/ge+Pdvb3Fz94DWhWj/8Vh8uL3H7b9e4e+/vIAT5ozHcCjAYYx879NleOB/Ovz6+zt8uL4bIq23IepyXPj12yu8v7rFX3+6xGrVoO/nvLZ1ePvuBn+8/oC2cVgr8+fD9T2uru/wt1+eY7NeqdHxl+CpVhF1HXvsgSdNH/ZbA0vb7q8de98XBNLzRLR2aYT1abzJfZ4Tm1UiNZERySqa6JLPjs0vuo90Qt3JxrGe9Is3dJ8m7aeSQ4zsc9I2zP1J80S7QPbiRJYUKZ3mky+xPOUwTG7vLcoloAcLkjYxQnzySFy650n5mh2CzZJOrW4JSx7XeV7UZpLmhXSal945dJtyciR9mp3ac2xupPhzO5chyuWVnN4Hkw2OFVBszQrJQRs4r+QL9Yf5rtTXBjyU1SYw/6wNVM0WgNtE5CVPZtqEqZkMtByxMxdJvSaiO3+/yn8lk5eTZE3P7AaDwWAwGAwGg8Fg+O7QlIsYDAaDwWAwGAzfG3xDHZMzNWV0wCN10Ew1icMm/JdGb48/56IXDd/95HQb0pm15D9uBy8pQhOc87qG76UykjNRchRq8kKWVLbkvS15lTUHZk5ezustyZbsrFSXgDmGRbNdXFSiVXGfaPi3t7PQpU3muvi1xPO1bvJRnkvkSHqr6UCCg1SrK5HQRZGFdE4eocQRrk9XwtccXV8yXRmpJxc5ltrqSV0pimT4p8ng8jgmYhW1nfYBJUwzcpYWFX0J2XQiV1WUiWSTv24oJEYh5fWiOcyISW4hQXq6JiSyGCEnif1aq4McDnCD0VNejjSVw1NFLH4MtHn7GOwTbVfDl9BH+4Cuz13vB2IxuRmtmgZ/vr3Cu3c3aBuHrgPOzw6xaodXlM4BXQ9cXd2gEd5aOge8e387RWr3cDg7ORj6uKbPMkUaB/zn93e4GcntAX3v0XUeHZG/ahwetj3++a8/yzo1fW2DX397i6uR3E7R+4E0DoT1mmQS8iWH90DrgA/Xt3j99gqrphE5yc457HYd/uc/b9C4gewOzOMXjRsGsvrdww6//jGUZ1qJ4KGsGwt1vY/I2845rJoGb69u8dsf7ya9EhrncH+/xd3dPVqnr9Gtc+j6Hr/9+V6cM5NhwVqh85xz+M8f74aDBtNcpHt2oq9x6LoO//uf12PE+yG3aRzu7rd49fYabdtM6V0P7Po+ihg/NNvhX7+9HaL2Z/CpD8A4ZX49pR3agTRA2B9nSLHfAvZd66P9Nrmfqf2ikNKl/UP4vPSXZCTie829lu5TxH1tkCPlB52V85bvR6Mo6rQtUn1Gbuf7L0kPtZ+3lZdL7K7cS0UHNsNBAeEwQ1J/qDTJ0Na8af8XdFUcdkkOhBYQ9tFJmpAuKFP1hD157XNi7dUoPWPXyNbsqHktIj37a+8TJPu4MO35P5cW2SU93Av2JfI8KycZoj1McaG5Fyq0MwoNjezkE4a/PIHwnf/V6uQWugymazvX3pxducmHuIwTG4Ho3ab03lEirkvvKbnMHCR9/FC3wWAwGAwGg8FgMBi+DxjB3WAwGAwGg8FgYHBu+JFijSYw+4aYw5w5dSKZlFijOIv08nGOaLNoZ6XnTGVJZerU+pRyzsmcTsl5SH1t/Ps+kBx+OZ1cl0fqLOTtJfUddzRyeUSl5C/OdaMmMjJbceJK/k7J6V47HUoOdU40yJWN+6J+oHOO/33coUVijvCZRteOxocSXiajnEoOWqo3yJCISRrZJgsawVGycdTFiThcdmQPI3UPDvu68Z1KUTIXsYuThqb+J+QobqNIzhfKcUjR5TUZGpLxVohmki258fM0fyQj1ZLoSnJjc1MbNXIklf+5iQmOzttafGLC+efuo73hga7z2KxXuDg/xtnZMVzTjiTnoQ8b5/DqzRUeHjo0DeDQ4PBgPRGA29bh9nabiG4ah67zuLq6m/qndR6nx0foupkkXE8Yjfv4Ydfh+uZuIpt7eLi2wfNnp/jx5Tkuz09EovPN7X2WqC2hbR3u7h9we/eAdTPf5breY9U2OD87xOXZEVbrFn3vF0+/btePNnnsxvpNEyIaD8vCqzcf0JAW9d6jh8fBZo2TkwOs2lVEym4bh+ubB9xvd8X52XmgWa1weX6My/NjrNfDHAhjs24bXN/e4cOHu2zfDbcWh7736D2wXq2wWa8AxH3SOIebmzvc3cWHE2boHdi2Du/e3+Lm5j4i73e9R+McNpsVmraJDjg0zqHvgd//fD/VcQDevbvFdOgJg+3PLo/x88sLPLs8gWsbcu8CfN/jzbsrxebR8s9w2CW3h3sS+RnydLL/fYK18Gs4MLTUxoSArBC5Qz7PyxGQabTznF25iOFcP0+LSPlEjrRnFonXZK8r6Y/KEjv4gcXoUKCyj1VJ7Lx9glyx/zL7IK2tiRy+B6Xfx311bZR1fhAhN5fC84D0rJp7pE4TJWZ0IMpW1BfqhedL6RmTPytX2crmt9TmxBRFl1ZWelak+VJ5+rlkE3/Gh/A9u2fP5FE5kzz2viFbKZdV++JDe6kgdeqSiSVNJgm8jDYBS/p4GVYvel9YOxHp3yU2hHLS0kXed85FnZpGP/O62rtTTopPAot8pY9HBoPBYDAYDAaDwWB4HFaf2wCDwWAwGAwGg+FLg8dAXKkpmYvQHn5SV/uZ3eEzojwJA7l0+BDMmuQ4wPm8U4m2SyeseNVO0cHFnWaSc1FzrGWQ6OX1ax2DJYdkKLPEQVYqz9tLy7t5DBM7SH1P2yx8VnyNE2ENjnxnIiTbs0PD9ErlteZw82k+bQMdBqltNL/koNf82RphIOcbzhG7pDxJXzGSJoBAPJ4V6L+9oOlViewj4TyQbLhdswmB8KjMhmATsTUaq1EXJ1PztqmR4pU2qPUEkroU7T20TbIlylfgJNkgfctkqIcJMpE9E9lELy2jRVeV5NHxjq4ZRh6juiSSW2QLmT/R5wxqeSmPwT5E+aXLfoQlh0+eiMT/KHs/Gdi15YBffrrAyfHBcPkBcC8G4u9vrz9g1QxpPYA376/x08tz9N7j/OwYN7cPQQTut1tst31EfnYAbu7u0fkOq6YFABwdHWC9bqvIiJMQZrv3Hk3TYLvtogIODn/9+RnWbTMtIafHG/z71zfj0uLQNA4PD1ucHB/U9dZ0rQKv317H5G4P/PTyDOenRwiBOhsHvPtwiz9eX8Wm121TsV6v8PPlKY6ONnAO6Hug8x7Oe7RNg7Z1w+EA53B2cogfXpxPa0TjHK5u7vH7q7eTQueAu7st1qf6K+Vd3+OHyzNcXp5Ma7ZzwJt3N3jz9momlHqHtx9ucXp6SE0W++z87BAvR9sAYLvz+PW319huuylaPJzDzd0DDg82sSS2CZKmx5v319He33vgpx8ucHp8MNxO4XB1fYvf/nw/7VPbBri5ucf9dof1aoWu97jfbifCe997/PxjuBYGe55dnODfv77F9f0DWgzk+q6nh2rnOTnY+mWtAE9hjXRve4r2fgmHpzhqbNrngGNJx7SPAHvUUPq5cjnJyqJ7kBqI5ZQ9Fv2s7a/4nkWzN8iSSPd8P6pFuef75pwMDdHzUWWdsTACgV2yU5UT+qWirB8fSrWhpH2NwlxTwffNRPbQ335KFOezsrcHmB1I57f0zJnYP9pY87wY5JV00WdVDv68q+mq3RdK7ZO+52zKyeb1pvoF48Q2EoFeSU8eYKSHb0luTRluVK4zlnSU2kmCzpye0mCqIsLOIt5nVmMak/g9ofYkKOpT6miR4Lke7T3rV/BwZDAYDAaDwWAwGAyGJ4YR3A0Gg8FgMBgMBg4P9B5o56/jX08cmLGnKiatU7LgTIKXIrWD5HEkkeB94vcXvYA5eXHpuVwugrzkCEt0aF5iL5SNFUV1E5kuLSOK4l5a6gDljE2SN2XTz9yBSuVyr7LkxdYgebi1IoIO0bdZ8HLXOsFDwajLAl8sNWWqkvPTSrq1YZR81ZwoIDngpUuhlgCg5Vf3GQUncyNtT1a2j1cUx+Tl5KiR0iXiPCMhhfqBrEPTE+ILIVD3nh3OYbYWSRpUtkLqF21Q4Ik9CTmJE7IZMUqSL5HNItJWshALfcdtHHUmhHJKngrErIp28+ig3GY+vpOdtM1EF20btZ/rkMY9R2bTyG6FpbAKi37tQLD/Y+KpSJZfB39jvup7D5webXB8dICuI3O4B87Pj3C/7XB1fQtgiAZ+d/+A7W6HpmlxeLDCwcEK9/e7YUkFcHf/gNOTwymKuPfA1dUdGjfs0HoPnJwc5nhudS1gZDqK25t7rM+OR3K4x3q1xsvnF1itGqxXK6xWwyjRSOclXc4BDw9b3N/PUer73uPy4hinp0fYkb7rAVyM5P+b2/vqueW9h2sc/vbzc8DF9oWd348vzuG9w+39A+7uH/Ds8gS+B1wz7kC9x/HRBqvVClsStT3cA6QW997jaLPGxcUxur6PCj27OMb2YYf3N3doB9Y4Hh62eHjY4uBgjb6X5/xqtcLL5+foO0xaV63Dzz8+w//8+8+o7P3DFvpdJYVzwO39Ft2uR9sO2ne9x8tnpzg/OcRu+mUAj+PjQ7zsPX794x3apsF6vcLxyQaNa6Z+5Wv39c0DTo43EZn22bMTnHeHONyssWpauAbjLxxQu76Oq38faL/88THkannaPZSXeYxt076ukvS996EtpT+nveCe9nPi+vhFLsO+h7LTczMnQxfaGo3PkBDVD/sUqf10fyntu7j91ftMoSxPk/aiSb2xHWHvOq0bJD1qR2gL0eHJnjEhums3RLbfzrZ7fMgsdk3mWaUG6mO1Qprne9DaZz5eRnpOqXl+4TK4TVJ5rX6pvPaMKsml5fnrhtq7YVR2NDSpTxqQyFUaJ70fSL5IA0kHY8nkkmRKAw1WTuosrl/L19JynZ+bZE+EpU894vs9H8vRZEq/YCnJ5YT17HtCUe60PhqvwWAwGAwGg8FgMBi+M9iDoMFgMBgMBoPBwDBybgAgcdQMPi4eTSgtl8gUHDdaJCOZLB+c5IPCELU9LlN2EpVsSmUKzq5MXVIgK1N1FPK0omMdsiORyQ9kOS6POnK95pD0pH7O28zzFFsk+50me4GsyUapquQwluqGfligWiIe8CGU/MPcDM1/rXUvryvV0WRMhBuk3aINg2flIrsZEaOGZAFSj8IBMTFFIKo4EHJPhmw+yWP6ckQjKaJlYjdiQlFE/FFIQJEcSpTSokcyEpND3DYpkmeJpMYS5/ZoUUH9PNo5chwFJ4pP6SBzSCCkSzok8rlIauEEK8ci4yI/J6Uo9Mn1Vtl+nq+S2/cg8tXqlrA0suw+tnypEZc/Psis9B6nJ0fiNdf3wOnpAa6v7+AxrDFdB9w/dDg+atG4BmenR7i+e4/1SIy8urnDyfEQ3TsQke/ud2hGma0DTo426PtEXd5cYYi8B9abNrmB/PbqA169ucLJ4QFOTg9wdLDGxdkRevTwva8mtlM0jcP9ww5976cI7p33OBsjt3P08Dg62OD69iG9R6jNdPj5xeVAnu7k8gOpusfx0Qanxwe4f9jifrvD/f0W9w8dHrZb7HY9Gr6m8L0X1euB07Ph0AH6NO/s9Ajvrm+nddY74PZ2i4PNWrSx9x7nx5uxybPCvvdYrxtsNms8PGynvXvfCaRMF+qmA984h/v7bcTbXa8anB0fDgR9aks/kNz/+nODo8MDtO0Qib/vegy/AuBwuFnjw809WjeM84erG7y/usHJ0QYnxwc4OjrA8cEarjlA13XovU/6aR/UrG/afiops2At+xxR059CZ+7em0uvIcaTwh/9Pifum9n9l+7R1AN2Jb2UlB3yw2E4oY60/3HAQMwe63AbODl+0kVI+lEZYSySQ46sXdLfqI1KG7wPv0QhE9en5wp+oEDYn9E6CH0SDiNkkBD+6V+6n+ZypL22QpCvBb/H16wtEqRnyH2QecSNnv1CGa0ev63l8qXn0GiuMzn8OZLX4TZL+bl6kl76DiDX/gROucUnD8CIOmd4VovLezooxQeSgi7JaN6g6WIU5OU6j9tBZZTq8YFX9kfZd0I10OQC4NHT6a89pu+/0nd7GgkdzgNefsdYiuzO5Wk6qO36u9AEjZZhMBgMBoPBYDAYDIZvE0ZwNxgMBoPBYDAYChhd6khJ7QMGP9bsiFEdTGAOI1FXHO09djANuhoffG6ps0iLHs/zxIYQGx4F5rxL5OW8x7yM5MjTHIaSk3Esz52tqtdZ8lw7ppI7amlZzSYo5QLPQ6heU49WpE5sbqej+cy8yExl6HNdFumX0ga/aLHLSg5+ySdeIlRoJASJxEDzSkOs+ecdoJJFuG9eHPNAupHyJAhlc9yBEM3cCQT2mgiWYKShSU8gORGSey2qomcKxO6IJM7SqY172RKIT0JkzCm6OUtP7BKieoZ0Xq82mq0neT7UD2Ma9AmEthxpi2XI7WV21pDkcsTA3JjXkPr2iRjP86drXWhLtj6pR22pJZfWXNvZa/gzkEnrMNjUOIfVqkV8YmyE91g17UBJGSN19wC2u27Yq3iPo8MDrBtMvLubmyHC+3rdonUNbm7v0fc9msah6z2ODjfDZ4XALcFneni9bnF+doS3H26wbgfuzGqM6n11c4cPN3donMPBwQqX56c4OR6ijletnxEcuq6f728eWLUN2qaBlwjzPdCuGtTPIqBpBsJ+jvzfOAfXNHj3/hrvP9xhu92hH7U0GAjabSNdy7pQB2DdtJCKeA+sVsNYTkuTBx52W3Uf5ACsVysig14DDutVg4c5EP5ARE32tfP/83wPYLeLjd2sVnBCu4OU46MDeO+x2/nkmnz+7AQfbu6n9oUDDDe3W9zcPgD4gFXb4uL8CJcXx4BPo7fLbc2jlgxdmqlhHxMOuj1mPQ6on7V1qO2Tx6yXxUNsFXbscxCLfhYJ6JDvQZKc5etSBkuI/YpuKS13eC46eDnagAX9H/ZHnspQdE17V2FvQ3VNstg+On5OnMdG0sltzO1T6TyICP8cubEWCPbzc6Gy9kB+5tJ6nD7/ZPcwPC/Tfl6Wf1efwzL1tTL80Zk/e0rPrJpc7ZmZy+XytDSarpWRyjrygedxVK0UoyL1PjI+72cXe+3hWmqY8DnSrQ0oLcgf6Kn9Wqcp9dSyYH+1iUDzpUlRglZ2TE8DcLC1Ffr7Qrk8VRDL12RLf3PQgmhIxPnwjpWmGgwGg8FgMBgMBoPh+4KddDYYDAaDwWAwGGI4Dz/tkyWyN3fdcodP+G8ui6is9Hkul0YtmsqNjjVP6mv2cfK7SlrPMYoEO3meKnMJmyXncc75xaiDkHl/VYca16E5WCXbafmSl1iSo8mU5C1xdhby3Ph/4S+vs5T+IhEeOAEgUuPisnzYuJ9Xs82xvxrpQLOR1tHKSXVK8vkU1AhFGjkiiUbJ7QjkboUcXdLDhEVRKJO6EhFaIxAFWYEUVCC2i0SkDNmp6lILpB8AIuEqkJUUgjclW3MyHyXqU/k8Sn1CMiPkIU5Kk2wvIdLj5gink2RGfHKsL0JapHuhHVokWA5O9C/JlOokZLeidbLcUp54/RXq83pLiI607r7ltOv2qbGYFOnnFdA7NxB6nXCIBsH++VpxY32PIVL3etVEEeC997i6vhsI0b3H1fXNdDl7D5yfHS2eJLlDfH3n8cOLM/z4/BTe+4h4HMjezgH39zv8+7c3+K//+RMP2y2axePih8jdBKu2VcfXj3bPvO6K+RYOv2Tyd7sO//0/f+D311fDQYOxjatmGEfvB/L1oinhRlL3NE5x5aZxaFqywXPzUq0JdA2m8nEfeTSuSeaAPIel+rR8ej1r7e5Jn1B5fe+xWrX460/PxkMY/VSuaca2j+l/vrnC//tfv+Pq+m4iwefwVGTl6nWIrfs1yO1Lltr/FO2tvZ/UEK9zEO+HNWUq7pN8DPg9PujS19v0L93vaAe8OHk7iYwe9qsKyVu7x0r7WE7gjvZfpN3criJIO/34XeuLyFbWL1E5n97beLu4DSoK5PagV/1esY/X5BXnnqCjdEXUXDHSMw5H7vlLK1ubLtkjvEZI8nker+NYvnTv1Z5BtTqlNkTPnoV8DqorKePz+j3PlAYqly91qINsFL+3h/+r6RxlEDytT18u8MHO2JGkSW2UdPB6S25zFZNd3N/6OY+/I9TqRW8Op/kQv6PM/cIjf98pv/PM78dLv0pZs28yGAwGg8FgMBgMBsO3BSO4GwwGg8FgMBgMBN77Bt6tp++CEyipgxAJjZMLfPTZj96u3E/5AjFZPiHIk+I10eA1e6Q21MqtdsYRT24kk9fPsflqkWNx8fyc9zmka85XSabkHaeoaYfkVF0qo1CVN8PzAjXqvd7UnL86pGm+Y9F/7PM+8RLpQBreJa5Qye4aokCpLEcNyWQiET0RwS3oreEHFMk5KLdVIwLz6JacgMwjVUpkZCmSeFQGymVeIO6JxBVWVtRdIiuNZYPtGtmSRw6lRHVP0mmZ6oi7QltCeqlfooiqmf6Q+qYUaVbMZzIei49JEH+sjdWEs4+MbAR7ldgX1oIeqJyHo8ToW997XJwdoRnfVjZNg6vr+4HofveAXTfbt163OD7cQAl+LWri0UUlC/ve4+L8BP/nbz/i5eUZ1qsW3g9R4gPh3bkhsrvve/zrtzfY7naPnlsDebIwzj5sqh5/PXgP/Pv3t+j6HqtmJs8HQnvTNDg63ODl5QlWq5bvRjOSHaIYm6xfevghdL9m19KGuLRWSk6NiydDxb6Hbi6NqHQ99D1wcLDCP/76Ej/9cImDgzUchl8coPMnkN1/+/M9rq7vyMEN+Z73KQ635FB7GGqfvH2xdM3VLKghBeeIwTzKNtWVuy9rh8U028P+IbFbuZ9HZZgtpUOO0oGwIEOtQ8sp+0M3VIrrZvqP2s2/ixHWtYMEwvhJhx1526SZkbTJOTihbnF/uWD+1h7GC4chE/sqr82q55fQb6QOgOnQ1tJnrdxrAckecX9ekCGV5bJzz3iSHdR26VUBtzP3TOvJv9IrgaUIMiXdop7c/U96wGf1os9aJ/MXBNxYqSOpLGmS0IZKsjX7qAxH/kmds3xbq3f2PrdEvleZ3i/GedoTvvQOMiGfz8sy4GYdtLxGdI/sYZCCfvD3rNKvYPJf0HTS2BoMBoPBYDAYDAaD4bvAqlzEYDAYDAaDwWD4/pBzDEnOm9l3NTtmJIL64DtLo7RznXLkdSdE7cvXyUU+GgskDiI3eLMSuVxnjkAfRZ13qcxEbs5JFWyUnJGaA1NygvpCPv8sOVklcLmSzRrGcrMTUbBjCST7ITc1yuBpgn6HmfTF1Wm+W9qF3AZtWKfvzMEuDXtiX0V6blhypAJqR1J/JGIPefOVX5oCPD/6niEu1UytGopEQnjguuYQtTIRh5NZCKFHI0SpOsa8WnJtIA/VRqucvhPbpqjoYzqNzEnb5ATd3A5Jr2NlJnspEYv0LSePe6n/w+cMWW4iyEjkL2SINjR6qtA2jYxeQ1xM7l3kez0Zul5+SQ+NFKvZBcjXKJS6j21Ddu5Dvl6fgjS6RI5ebrSwBx52HY7adco3cg67bhtd884Bq1WLsFZ577FerbBZb3D/sIVzwK7r8P7qdoh0TWy+OD1E2w7E8/rG1rXPe6BtgcvLY1xeHqH3wHa7xYerB1zd3MIHVr0DnAfevrvBjy/PscSU1aolfQNsdx26vkPbphHJQz/Urf1ltK3D23fXuH/YYb0aenWIoN/ix5enODrczNExvcP7m/vaGw+893jY7XA8nxWN2tFve3Rdh6YdR9MDm3Vadhnqe0XimK3bBrSBD9sd+t6PY8HuIR5oGwCNg+/JWh7kuUGqc8DZyQHOTg4ADzzsdri+ecCHqztst918iMM5vH13g7OTQ3ThlrCoRcuu4dyBIw25NfJjoUZHjuSbW/encqjv55IuHhm8FtXlCRmc7lU4WbzmQNk+mPboGSJ5lM72sNF+go4J+c6jxkvpoj62T9NkJ7Yr36f9vEsPYXogIbNLeya+v6Pge8NJd66dvPxoJ82fZCv21SKaJUxHsh/S6gnltTTpmSrsobXnRw3acxXf+5Z6hD9Bae3W2ic9d0rPxOEdgNaXvnKRkp74Sm0t9UGSL9nBB4enaR1XmkxFYyA3OtfYmglUsiVnB5+s0oCEND6Jai9RoZz0Li28iSi+B1R0lI/Azzq09JJu/muT0jvRNOo8e4Y3GAwGg8FgMBgMBsN3BYvgbjAYDAaDwWAwiJAJECFaOy/p2H+c6E4x+7Zmxw4lp2sOIUcdcw6JvlLE9tLPFteCR27i6UleYLkF26k9NU69eABE+3ma2h7JY+0R2eionZq3mOZzBy6tV+lVntRz52+urs+UGW2UzPWsDG+rxH/RhsknH3QzuR87N6ySDJ7O8zR/Ogcfci6rVF+yIyZF08/5KavpeRKXrStIkcjAmm7FiZxI8On6mOUJCES5hAyvRJ6UoqlG5RQiV+QYp9E5CwQqyU4x0jotw2yl5Kr52pnzaLpKRFNI1ROxnRHmeeRON1eM9SgHKZI2E1u1cRH7hZWtJbdPfVIg5mkycqT3KqIm65c9qCKi/qWQCB1PRTItERaX4u7uYZ5fJL1pgNu7Lfo+XgU3mzaq7wGcnx5O9jTO4e37Gzxsd3CNmwhfx8cbJuvx8N5jt9vi+vYer95e483bK/Qe6Pse69UaL5+f4B9/eTlENCeqt7tu3tNN1x/7F+kBNusVHH0r64G7+y0ahZj68NA9av7RexUA3D90E4nde4/DzRr/+OtLHB8dwHug6zz6fiDW97u+dAnOtgK4u7kf7ebtAK5v76MA7g4Om4PHxl+J54E8l+UGeAesV5voAN/uYTeMRZOuW9vtDv/9rz/x2+/v8P7qFg8P20m2c8OBi7v7LV6/u8afb67QdcCu69E2Kzy7OMY//vYcL56dRDZ2fY+un4mOS8dZitKdLfuItaOaSJ/LUw6FPdUaVHPwiB5Ci+7JskDxPq7Jp22h9z91r8v3PYXPXG6pvVr0c97nyYFAer9RbA86eZtFYrdEVhfuw3w+S3K4DHHuMIJ8UqIw36T+cJJ+Vj66w+158GGsRIVH9vL5t+TZhUMaZ20F9cEWUqakl8pqMtcC3xfnHnNLeQHSnhxKvvR+Zx87cs95vKw0LaJn0+i9iQz+rJ/TV8qomkf84TmrSJBXesdS86BM86nR0iCWbqq5DizpBfSXFbWoqJeLjK6Vl4JTAJjeG9L/OKRgGdIvU2qR3MeKky7JPk2nHORjLjUtV0/zCGQwGAwGg8FgMBgMhq8IFsHdYDAYDAaDwWBg4EQkgDpxHXMSzf+vkdpzjp3YaRR74LgjabBtYL/w+hrhXNKXi8BeQ3TX6nNw/VLU+qjJGb+dh4fj4cNL4HK5A9OzvPF7SoBgZSRbufNU8qhrdSrar8oe52oS4c2TP4Qw5Yle6vMVfdQFh/DUZUyeVFdrouTbpt2SXhWx+FzXcnk1Q6TJ4DZqMtSymciMyRiQ6JwlMkMWPoiLo3rP+cwe5+AkkpdmOyMN8X7hkS4TgpdAUJfbkZK+ozqZCJm5epxQntOf1PFpVNFcJE6JvKXWDXYz0hdvy2yeF9PLzWL2CaQ9kdA3HgzQUIq2qtkQvmvENk2jRFbXiOs1RLMS2T4i6wtjURPpuJpcrxui6q61QcKSCNBa2aZxeH91i/PTQ6w3K/T9YG/btrh/2OL1m6upbt97HB1tsFmvY6K69zg7O8Sb9zfY7XYjabgn2QMZe7NaPxkhNtj+6x/v8OH6HvA92qaBa4DTkyOs1y26rkfXDdHPN5sV7h86tHRf4YdVJ+zTtl03nzNyQNvORP6+99ishzZsdzsAg9w/317h8GCN9XqFvvNjPYe7+wd8uLqdCfEu3YFxoiov4cZ64aYdEXwBHB5s4AF0/Rw5t20c/nh9hd73C+YR8P72Hmc3Dzg7OcSu64f1rHG4vd/i/YdbrNqZ2d+uHY4P1gPBu0qDjIgT5+KdzXz3STX43uP4aA3nhyF0AJqmwas/P+DwYI3NukW4g3adx6s3V+j7Hte3D7i6uUfXdfj7X1/i+HCN91e3+PX3d2icg2uGXtxs1jgf+6Hrhnl2fLTBH2+AFVtK+H1fO1xVusZzB3vm/pDzpPvPPiit2YlNFfq0e0R23Sa2aETwku7p2qFpC+4j072D28bvKVSPRDwP6zyTKR0o4wT7qO/IHiW3p5Du5zX3FH6AcNo3ISyV6f5CsoEiKreQmE7rSTlTO9l+U9pr1u4/uT7tUAeAaa8s7dMrH5NVaM8yUjnt+UaDeo2T/OTxNIy7ULZGf+7RlLe19pkv2Jl7dqTPm9p45MYnqlc7KILuXHpOXPqsmS+bDpxQT5PB0qN3FPxvzQSX7JAGUcqfFh3yPemM1GZN9vQOS5tE3M59QGQlZG+mJ3mvx/I1sniO/D6n+OFcDeYI69K7Qv5ulAa4oME80ma6KF+VE5X10y1yr+j0BoPBYDAYDAaDwWD4qmEEd4PBYDAYDAaDQUDENRj/Dm4V2WOlO2QyOibKzezgBriTiTjT2GeqT4q0pOVrstXI8RmnmBY1Xq3jBT0ZJ6B3I7E95/TMeao15yz3XNfKk8oJXvCBcFJhK88vQXDYeqmuIIs7tSe+jFA2EL2SuuGLi+VpfuIlvl4+VDVkDKlebkh5HU2Gpq/S/52Um0hrDlFgdZEwMZatJUrQ75ruqjYw0ommbyD9jOULxH2RoFVAlrwikaslHZwwzojSCYlbIKTnIpnm2uOBidQvEaIigqFCfA+E86gvGFmM14vsYnUTUiC3mdjLiXETAUvQKcqtIJprpEaNtJnYi3g+JsgQ5paQGjnZlLeVX/NLCKFSH9UQB1XipGBbcg0IBMt9UOw3AP/89TVeXJzi8HAzEJ4/3ODNh+uoXOc9Lk6PxsuEE2yB09NDvH5zNZPIp7YA52eH6vIjjU0VvMfRwRo3N/doCBn9f//zJ14+P8PR4QYeDtdXN7i+vkNLonuvV2M09m7on/uHB/zn97foR2ZX64C//eVlFBG8aYCzs0P88eeHSVbfefzvf17j+eUJDg8Hwvn1+3u8e3c9rWvadVFLEJ71N+Qe6PDh+haXF0dYt02gEeHXV+/x4SpuqyRr/j7MxbUbDgvc3N3j9PQQKzS4vXnAq9dX0eXZ9x6Xp8cDGbwT1vcFyN03s/dTDzQtcHJ8iKuboa3D3Orxr/+8wvHxIQ4O1vC9x5sPN/BdPxOLARweHeFg1aLrPY4ONlg1DZrWoR8jsv/x6h222w5np4dwcLjf7vD7H++jSP2ta9A2QNeX7v7p2ltDbs+lJ2v7ULhq/a5Jr7VjX1SR058Q+xwqK42JePiArNe5Q3LS/iLUBykTzRe2l5IOs9G9CCXDhzxeTzzkR+bRdNBSINnTe6h2iKGGWC4h2s8MCWqZUTiAdN8m7vkqbcjKmDTKc9UpbeVjwTKTOtp9cep78h1K2Zyt0b6MpWltW3R/zuigdvHy1G6eBpYvyZf0S3K5HMlmqVJyHxd0SpDSc+1XhUgDpG26+eRYCmnQ+OTiegv6PJT7Tq49PI1fEJmy4QBjUsSP79PYBEiCOnDblRc2+SjmMaL3iR5RvVxgC16fpgxrYBginXjOA2jUBsuQoOlIytUvuwaDwWAwGAwGg8Fg+MZgBHeDwWAwGAwGg4EjcUDlizqlhPazvCGvbAZ19MR6uMOKO4U0+TxSUq3+Orv3d2pxvZNjzs8OOhWSN1lK5/lLHGSSLI0NQIvSepKjltuqOXpV5kNFGSlPKquxGXgdod0+Y7s2DLTJHmlXTHU8pqiqVC2E77RuzUyUdGs+/BKpQRvKyBaJhyInV19JS9q6pPysII0oS/Oo7IhUU0MOovYJUUs1exJdgm41+qbUlkryOrdXItyLRCCp/Yz4BUC2jZKyFEIjJ69xoj8lrWVB+kcj8YlEEu/hAxlPI/1JfZUhCCbRWikxPVO+FDVdNk0nZtYsvVorakigj46SzNqtjVduzmTTpUMlJXiPxjn8+eYqmtOBOAwAfQ9cnhzj5OQAXZfasut6nB4f4M3bmBTvvcdq3eDs9CiO+k5QMzZAuu72Hjg7OcSfb6+ja9M5h99evR/kjcsMJXx7D5yfHhJ7hj5zjUPr3bQGcPS9x8XZEd68u0a369GQ/nn1+iq6p8zE+PI66YGRPO2m7xTOOfgeODk5xPsPNwAGvb3v8V//8wrrzRrwHn3XoR/b6ns/RiRncjJ2NA748OEW797fTmm03/re4+BgjcvLY3Rd3YaslkS9FF3n8eLZCe4fduj7DgAmQuz76zvg+g7wDm0TX3MewMuXZ2jaBn3vsVq1uLw4wZ/vrrFq5mvvzdsrvH53DQeg73u0bYPQFb0HTk4P0Cd7fn19kIjANVgS7V1D7UGKGhvpYY2S1McS63mdoF+qX5v2WDsqDJ32AMmWnVx/4j1vyJDXH7ZPCHNdI5drOqZywVai2yvrQyjrnIvKBDtL7QrEfy8Q71UwmdxerQ49IBC1LVNNfYQq7YEVWY2ff+ONlsvKY/Yu1Vu6h+6Txp+LcrZJz3UapGc2+rjqWRovF+krPG/mbJ3vuKltNfYv0Vn7IFfqu6RDQnmtIbyzpY7X6tP8XFquQ6kN418xmnpOLm9PKKs9iPN0z7+Oe28hWkDpN8LC+zvpHZeal1vmBDmlIBm5MvP6S9eT2a4SIZ3LldrHP2uo+L01g8FgMBgMBoPBYDB8B2jKRQwGg8FgMBgMhu8K82/fPlpQ7BCinz35j0MmcxOnlOTvJ/8F3TSSEv0sRV3X7OBRoHLtlP2Lyx1Sop4aL7guUP4bPuc87Zp3WHKUhn85fZIMzYGac84mXvmFOgpTPCHEaXa6QMLSZZTUar7jqayTy0nQupH7yelwlWRIdu1DCKEypClXInxwXVJ5SZ5Udz9U1CSkmmi6VhDG1UiUvFyQTYnuTDfX6YT8KU8gfgU9JXupbJHIpZDk1LYKxHwaRZxHMtWi1I8NicpF1yEjQofvUWRVhRTvadtJVFap/3lU8andCqlf0sFllvqB2pT0CCPulSLxOtIPXE/NXC3ZLerD8rWJKBLl5XSpNrDrq7Qu8jSPgZTduIHUTInNXe9xeLzGDy/PdJK6c1i1Ddar+LWl98Dp8eH0eQm0fqVo2gZ/++U5nHPoyRwObWjc3BbvgV3n8ezyBIcHa9We3NrW98Bff7xE2zboe2LHqK9tHJpmIGT2lQ3OrdShPV3f4/hwjfOzQ3T9TDJqGodut0PXdZNOD4/zi2OUek87WNKStgR0Ixn8lx8v0Sy4Kz0FgViT0LYt/vLTBQA39QkAtM4N/8hU7Pthjfn5h0scrNtpHve9x7NnJzg73mBHSPvOAa0bSP+rdm7xtutxcrTBs4sTeDL+iyc3Q2mNydWLDkUt0CmRjGvHK+ExKnsJSec+cyKJOM505w6FUZ1VUb4VOVwmIOxhg0yyb6i990R7FJqeFpx00Pxw/xOjswsyEh2kvHQwctKp3JczDYv+igfG+F9+784e4JDbNNXn+yVeP2/9YpSePVTk7v+CDqpnyf1eKiOVyz2riPs15bOmQ2uD9ChOy0ZySCE+/KX+l9rhmTJJRu0aO9VVKkRy/fyn9FxYPad4R/IOFvRnB5UPWEjj8qWB5mVrQOV64bOEisGJCPbs4qmJwJ7LT/KK7274Opz/hcdqe/ihuIIc+l5RIrZr6fw/ybbpfRT9azAYDAaDwWAwGAyG7wZGcDcYDAaDwWAwGGI4wDfzl7L3ZCkNJUdqz0Vz4k6/muhJXL70PXIkKc2VSPGS7bl63FaNWC9iH64Pd45OnIgFwnKOVJ7HnbLhs+YEzn0vMZ8l5540dpLTWLDN0TQBM+Ellhd8uZr/WUKtP1KSsZQAsZgQgrRrc0PIbZKmgJQmlamxU5JLkZCpF8gsl03JRDndJSJITlZp/iTjrhF5SGRS1RZGsIJCCisiQ3jKrTlJFFWtrECU57IpOdG5WSbvMykqq6fpAvFMi7A/Eb3GaKcSQdIL9k9tlQiESdPTulJbonzhYMA+iOaa0B81pHcaRb0mmr62HjihHifpawRBcT1d0C/zPYKTUgD4Hr33A+nXezy/PEHbANveo/MeXT/8241/X16e4G8/PkOfimN2OZydHEVlGgecnByoxPgcGgDed+j7Hn3vB5vZvbHvPTbrFn//6wucHB2i63vsuqFtoR39+K9tG/zlx0s8f3YSEaKBIeK57+c+4fb6SV+P1WqFf/ztJU5P1pGeoKvre7Stw2ZV+hHO8Vp38+WW44B57/HjiwtcnB1HOnddP45Xj4P1Gn//5SWONxt0Yz/4vi/OnbZt0K7aacxpW4bI9cf4P395MR0k4J3TRWOU1+XHMn3v0WOYc/EeFcNY+EFm1+1UYvOqbfF///4SF2fH8PDY9v04B/qojw6PNvjHX1/g+GiDrusjOX3n8dMPl3h2eYzeD9HhOx/PoV3fw3mPn16c4+cfL5II9qU1jpcp9U8ujR6ASg4/VchW12CmS1uDpgNJwv1jLJRtiyRT+y59Lq2dWT2sndMBK/oP9WMlra/8HqRFsZcOF6jtUe7j4d45pcsLdFKXY9qXuYqn6Jr9UdAjHMCi8zfpA8W+vDn6HmzfufIpkLSTHUiQntWi+qEa+yuV0fJLsrU86RHa+/QR1qHcBk/KR/IUe1TbnP78lqubpNGlDHFbKErjE+WXHrCEfLFKzYO2ZBgfNJ6uyckZQ+tKA8QfxEuTgdetmbBau2rxyJcfxXdiPl+m5tcbw1/pPR5ZSZW/s7wo0nuhcWqE+PG/HCE+1TuY45xD3/XrrGKDwWAwGAwGg8FgMHxzKHlHDAaDwWAwGAyG7w3OA234sl8EcsmvVyDoCM6nUtlBF3dKYXIWcXK5lM7ThmjBZS9cTZlcnX3qTz9l7FzcwdTpmfNC+/lj9GHibbIo+TnnLE0TmjLJonJCWWovd+Z6libJd0pTR66NJ98j2TWQ7CCyPLNJ8nlPav1YXpCX2K+x8DKOeu6vLvnpub+8NJy5aVXy03NZmg219WrLRGQg6MSOkm05vTwq59RfnIjkPXpJbiBCU1kMDQDPiFZBf0IKoYQ1lh9FHCVktkT3I4hKlBSuLj8FUrPHSCRjBGpKmEuIXUy+SuLDPB5ZwpvcuEgerT/ZFAj1YnU5Em50HdDItaT8vpGaZ4L/OM9ykVYzBxJ49Hlud0mGJovWkSLI88MByXUqkRvB1l6NcMjK0znG9WcPn5A6fe/x7PIUz5+dTnOibRpcnp/g7m6L+4cddl0H1zgcrFscHR6gaRy2u54E141tmOfAGLV8lOu9x/HRBofrFfbgt6PrPf760/OpM4Y+8wm5uO+H+/fPP15g153i/u4BD9uBIA3vsVq3ONyscXCwhvce3S7s20aZ3uPgYI1//PUHgJJ5GrJ8krYObQR++uEZnj/rcHt3j+120NU2DQ4PNzg6WuO3399je9OJ53l677FaOfzj7y+HvQCG+68fDx9wDGMP7PoeP7w4xeX5MW7vH7DddfA90K4cjjZrHByuh8jiBy3+n7//iLCbbODUQwbhkMDffnmGu4cdbm7u0I82bTZrHB2s0a5c0u8Y+26zXuH//O2lKJfPy74Dnj87wfPLU9ArJoyDcw67zuOXny/g+/nu1zQQ9fd9D+8cfnhxihfPTnB7t8XDdje1dbNe4+hwjdXKodt5dF0vXit97/Hy2Smen5/ifrvF/d0W3TjOTdtgs2pxdLhR7aBI7gUorztL1k+NMD2RnQsHt3K6pHU/2uaSfYQfEmQ5vDy7j4tRvIXv030hV5YQ8nOHmvjhOX5/jWwk93EHJOWmz7zddBxoPXLvjdJJPVEOwtrg4Bj5XrpX8fHQDkskexDM16A4dqV9DOsnde9C9l9SulhH2FvWIjkQiXHMcnurgj7teWSSjcrngsJhBvrctO+zSa1dyTyWynnMz4iSHYohVDd/TqM2Tvsc8p3n8TpZewv6SoPEx5nv20KZyNbSYAm2aelqPt/gsofEaPpSeySBfCJpE04yUroQcpeppr/20o42zai3tVI2fQ/kvYcjk117R5cjqGtk8undGJMnm+Wiz7zu/E4x1hASNN1SNHYuWwrIoQX0qHn3GrZTxYIGg8FgMBgMBoPBYPimYAR3g8FgMBgMBoOBw9f5x3gEdZozkJpSOXqd1CGkyaZ5kmNL+65GhkfqTJLKUpK8pEOrR4woE+jHTpPkTN81R2gGE0kiuLup6FFeHDGS6OBOUEDWTR3CXtAxN0QxUtAl2BlIAYlvVtJXYk74WV7Wnly7FTWJTGK3KECQMxEg42LRZ961S4ZqCcUl5/OW7Cvp40MkdXWO11Djh+d8Bane9JmRcIryCbk9zZoJNVxuDXfAj/JzkAhPqmwWyTKSXUN2IqS4ZiStJdNbIdMDhGgjEeSUQwJTPmurGhlXahutS0jo2YirUpuYvKjMWI7aqiFL9GcEfVGORgT3NHK9i/K160ki9U39JMiQiG2x+V6UycvQcZDskCIX+2DD2IaIrEjHN8zTki2kLTmyvZTO5Q5/gaZx0wLv/RCt+uBghaOjNW0K+q5H39PpKhPsgYEkfH1zD9cMc2vX9zg9Oaq7ZgU4AGjm/u8dgF4u6/1IXobD4eEGx8fNPPx+IJR3fQ9PSNeO1Xdu3HPIl2aib7fr0DYNzk+OImH9bowC72djpTVyOAtA9p6eWyWj6zyaxuH85DC6Ae16j77z076tGU4eAW5oP2/vhHEt6L3Hum3w7OJk7oN+7LtuPuQkXSvDfGJ9JNg+EcOIbULXwPm4TMqHJaRpzKTzo8M1To43kwEegO/HQxHj+Gpk5d1uIL9vDtY4PFhHy8fQfo8uM//4uhTk80NVe5Hd6b1HWB9yh2z4+kPLldYTgOxH6JoX1rBABg/l6PwQCNJLDm3xMVaJ8FTPaCfNlwjpSZ/QdVjqA3bvSmxQvlO9SauVfokPv2GuSezkdaZ6jGjO9zcJoZ/OTeVeItlN7fDARL5fimQ+SPeKMC5hrrE5xeVMn0nbuP1URnLN8HWa5Wt780hFKV+7DoT9N5/X4jVO0qZrm9kqgadLdWc7lLYIsrT2h3QPWYcmv3ZuTWuFkp4IzsimNs7rWyzc8wpSZW4QT2PGJu2VOlaSI9lUmoh0wGl5bTB5Z0mDj3CfxzifM2VrJoBmd9AjvhBZCD/u/fjnYBpph0T2Lr8LJLIyDU2CWIT9EqmTJdqHviDrSM07zFKUeYnsLrVVIscz7HObMBgMBoPBYDAYDAbDVwwjuBsMBoPBYDAYDAwFrsgEzeHCieCTXKGO5hCSZM/EBJc4fUoRnKSfBuY2SA6vJT9BnCtDnWYaeb6ogzozqYOz5HGXbKP1c05j+l1xvKrOVVpPck5rjljmARed8R4RgTw4yckUUc1V7eNppc9C9Zyu4M/lXSD5y6cu8PP1yNujkRQ0e/gQSE2O/PDEqFxfam2uIURIHAVuT47HIJFQNPA2iCQcQuQWZURObhDCQWbkExImXecEmwV5nDPB5WiQ+iOpl5Mz2hLNVTIpRUIUb59AlJNs0cpI46G1gc/vYC8lXtH6GuFcI0tJZOTos0bq1mSSNs/XvCAzECFpVWZvaLk2L2hf8LYCSK4tmsc/a1CJ7ZivFWpHSf6UViCyJmR25frJkU415HRSLSFCd0gcxnsm+daA99+u67Dd7dCMbdqsVjg83KDvxd+GyMqlbZnGui//6sJQf4j+rs2hRN8gYP6sKKGy2rYBPHBzu8Xh0QrOz9dLiHZ+d7+N7oftqkmv3axlaV9E/d3Lh5bm+TU3kJdT+8QNfadkqRtu2qzSvS2UH9bftG3zOoKJrJ/YIvRHkFsTYT2X7nuvnaNQ2rJMX7JPyMzR6OCPslaNBWWyukDGFtd+l39ikNb7aRVne4zpHsHWS04Ozx2WiQ/k5O9T9G9uf8CJ0ZE+1v5JPivHidSSLRq0+7dUhliS3A/Ggloj4zx+f85BI5prxHEI1zojv4PnFWzSnhM8syXXltz+aLoPagRzAdqolvbCudmg6lb2cSV7tGcezQa+R5f27BqoDv7cw8ePl6VlaD2vlC/ZxffQtdDmGTc27AcmfrPL1FUaTzneajnSEUEPlaHq4cs4SP3SZOAPH5J8RU9UT9Azkc5p/dLn0sZBWlKECtnADUtAJ6CP5YZ3Y7UE9JKNVB4vo0VWj9/RBYPHvx5RWQnae8glvzCZk0tlAPJe1WAwGAwGg8FgMBgM3z7sp7wMBoPBYDAYDAYGL5B39oEjLiLdKVwgsiB1uHnynyP/UXm5COi0jEYs1yIqSY4p/p/aruCcFRxvk21edrxN9bnYnLOUIHEIUmcvdwxzL7nkNYefB3YJOyDkaV53rk8oGukTyod0Tx3bUh0ui7dH6mufftaaGImPeRpRPc9leTYkyvUYcWcQd19of1KHfZCGTxtSP/3fXI7X06aTVJ7m0673LJ2PPx+yxMYC+NhEdQgJK2mfc1FUzck2QkaTSG45+8TLVhi4ResxI7GWZMsimN0V9WiE04hkl9PNyXgFnblotY7J47ICqTEQqyWCIJWhEsEZmU8jC5aIwBNZkvYba6dEApz+JuS+uSwnMnPbuJ2hdo4Umv3O9CZtJX9zhwQ0SGT4QAyUyJWJHTUkNz5vlTZH6YTkN61dSnum9V6ZV/xz0zjc3d2jH9voAZyeHGLd5nZUcvvUscmMWWKjMKfVOU7mdR1Z2eH1uyv8979e4d9/vMFvr96j2803vg/X9/iff7/GjoT7dg7YrNci2akG4vpS+K7VEwqJ5ONF62jBDgnaOFcfsIC+PiRlkw2NXna61xauQ7pucmK22AKFhC2t7VyneD0HWwWidUTcFq7h5N6lkI6jNZfci6Y1jcsn9y1+vdG64XukU7nHiXtWaoOQXppXyRot6OB5YV1LiOoScd058d4c3XtqifFSGWVcJLtmk+L+lvou1OP7E96+aQy5sbk1g80zQNiHjvOgZH8q2iflJbunuV5JRF+CMD+yZVC376dlPfnO8/l36W4r6ZSeVaQy4nMH00HrepKn2UHtlNpH86a6Xu+3dA7GeiIDBF08T+zDdBuV1Jsq0wY6xW7twZB2OJOjGs/bxQdWgjR5+EThEyDpNCFNaos0EXJ2cNRsdKJsp5ervNj99GLDs/6NSe4aeT33ri5aJaRtLpEvvc+T9Ca7Aqfbp9krkfW1d4S15HYuY8lhXYPBYDAYDAaDwWAwfBuwCO4Gg8FgMBgMBoOAWoexXp86kWIEV5MU1UiyI7hvGpeWzUVDp1GRJNm5qFClaO5SHk+n+rkMMYJmZZoKzaO+z2BKDt1IjuZlFspyb7vmTM55/HkRzYGtMQhGroZYX9GllpGc0iSJEwxKQxDsisowVkPOoS+Z6ZnS6CuRTdVwm6ldU7e6lHAhtVHKF0xXpwTtxxyfQCKFSHV4Wok0IumkRGAJ2hRacvnl2lstM2NnliAukKgTclUg8jLiUSSXk9aoPMFWrjeak4wApkV6FQ8WkLKcyO1D20g53r4cyV8iuU+Ea60O5D4e9Iz1JGIf688pv4IknmuLRObORfaV6nrah4SAqZG2E9lCPpevkuYzti6KUCyUEwm2AsE0qTMI5oYOfwrt4Wgahw/XWzSTLQ4XZ4dQgoEnkK6XfcHnvtaHUx4h/NYc8vj//vMPODfs8VaNw93tPf7r+nc0zmGIVe/RNg2aZh6Tg80aB5s1um5JbHB9btT2UakcJ8lKaxZfv5LrqVJ+lI46rplmhzSmtQdexsLxPbY093y65uXWXA3aHKwZZ+lwDEDuEUqbcmNUc83VrGn0/qldS9m1kqxHnCiemydcb6k9pTVRapun9106D+g9mt2bqS3zXlYfD+k+HK3rYmti2/lfTW5ODm2jc07Vy/cHEci+pISwV5/6j/W1XMmJefRAZw6ZR6JHoeY5YInOcL/hz2hBjrjvX6ij9Gwh2pXJ43JLZWn+tI+W7HCy7tyzJs+PnqmZnV6rE/KSRIiDkLS3drJJD6o8vVSPN84hrS+1g37nZXLyuQwnpNdMlqWonVBSOS+UE8WkVwV/L6aR2DXSO88LJHopkrtEcpeiqfMy9KKrWw3Ldob0feQl8ivuCQaDwWAwGAwGg8Fg+LZgEdwNBoPBYDAYDAaGTxERqDZ6UZyXIZU8wvGUk8EjswdI5PicE06qp9mUi9hUdMzyjxk2RSpTLuxzod64Tdpn6XsujzpUuXNYcrby8oJj2vM6EiQ5XF6GZSD6fwucqKRO4fJz1D7I3RH0aaQNKivRn2lX7q80hDW+fOlzDlSuNDQ1kOrmdO0Dj9T5vJiMw77nCFKLsQeZMC8ulZdEYBVQ20fZyMKeRUwWyOjRd0Kk49Fgl/RDKaptlK6UG/QNxCs32q5F5Q15QR4lXEYE68I9PIosWyDKS2TRiPQokO2l6MghnR440Eh7kQyhDD1gMdFmQh8wW2g/anNUiqQr2aRdk5Jd0oGYWsKwcw7391s8bAeCu/ceB+sVVqtV0r9ZzhEjWWt6eR9I9hSj/WImaIZxrbmSmtbh5bNT9H0f6Wgbh6ZxWDUObTO8uqVyn18OdUo25fKLZSrsX6qfk945CXhqo2JfaX3R6k7pih1UxlSnoj0aJEJwQsCmpOYFa2nOntprjNfm/UbHgsqmh5l4XVpGs6l4QIJ9lkqHccyuZ5rdgizpM7xPxl/6J6394j2Xg/cJs4PP56Q6ab9YRljT+R6hNOdon/ExluplxzZ3qGFkCqvXmLKWluY63S9qhxCCfFFOqMu+J3ZAnqdPAY1LHBeq+yUS3s4am7U1kT5D0DRub+65hz9H0XQnfOefqU5J197PL2wR4u3Sxrs0T7SH1eJrDUFwduykhdOxv1JHSmn8I7clN/n55KDpXK9WVxpUlrD4/ZdkU6nsY8vRxxjlHRclvGvv3mKRLvtdkxve13FiPbVt318GCnW1+tSGku1Vuj7WwmswGAwGg8FgMBgMhi8WRnA3GAwGg8FgMBgIvAd2ux2aJ/aaxITwPWUIJmmR32ddeWcVdzZJhHQa+Umqr0WeonWzpHUhnzv2Jjl+Ts86/lyQswCBEc2TS443zfuec8yWPPxUFnVMU2++BMlhnWMA8mrcCS4hyCx682WfdiLas39MAO+C4PCPeK9EQfiscAkq2AR6l2lVJRKINJS0bMl3r5FFKro9kc+nAk+X9FM7cjZGuggpN5LByH6cVC3J1wiKRGhiazrWKQGOfElsKcpTyGY5EhXXV4JIxCJ5OfJgLVRiHCXZEX05IlnUqgyRUSRYTnYAQCG6PjL9zMirIKQ8tT9HEmSkkh2g8FIbgz0KETQiUwqkykg+I7xze4PsKY2PVYaUrRJ8BSIrzZegzZGcviVIxsgBb97dou97eO/Re+Ds7BBd16MnIdynQw3UDgjcrtwBhUJ6DflfIvBqtnF0ncflxTF++fES/TQHZBu63gOuwd9+eYajw/U4BfRrJqc3lOEk3RpIhzg8+5zcv5R+zJHYS5Gxtbq5gx6c+Fs8/CCkTaRcpQ2hL6aIyeza4uuUJIcfmpDaWQtpHaTrSu5wlqSftz9np2gPhPs+IRtLJPXJrvlLWncBNP01a90EQkxPDkuwe0TUp6Ps3L21l8aMHMRI7he5e7Qw92oI/1E7JUjXgLYH0PZO0zgX+prKZ9e/2IdsDkXrVF6T2l4xVev3Gj2V0B756LWQuwb43qkh9ybtkVK6j/J1XXpGydnAy9M6Nc81XiijNVscFUFAeS6khTzY+NYOtNJxw15bsLMkmxpRY0PpPYXUafS2yXWNafPajXSQ+QSr2RTVPCyTwjWBE5SMcpklkCZ4kO9lwjp//1ZDDuffxXdl8OJ3/lkqkz82mqImOrtku1a/RsfwNdPhBoPBYDAYDAaDwWD4ZrH63AYYDAaDwWAwGAxfEvq+X223u3XT1p8FLZHMAcmZ4ydfoOzfS2V6wZEjOao05xXNkyI3LYmgJBHapahMvI6WL5HopUhP2mdBWWCBAMj/DLMLvyWuOVqXOK8lR6zGHqD5PL1mKLgTOejm6RDSWVq2idw+TaZHCMQ4fffM/5jtTp4ZfOZEX/jMm+LGcmTIIznRT8IzYgFvm9SVPi4y5PuYlMDLS3UmWaQwnza8G9SpwNqpDT39zvVwaENdKsOnRDLVMkS+3BTNpVMyvTq1M6SfKJK2RiIUylNSW2RLKXopJWjlyEhCXsMIcqXyJbIhb3N0AEEiZAtk6PkU0fCZRyf2Qnt18mCwZy4fXQOKDE50lUiFtL0RmTvRHRYcksfaKBFFJ9mh3bRtpJ+pbj4+EuFXJO3xcZXGkNnouXwIa0OO5M7m63xrje3X2lhLxI3q9z1c43B2cgTAwzUNjg43kS5t7qqHMcZ8CSIZWrimOQlWOzyhrX9hjtA0OIeu63F6fIijww3efbjFze0D7h+28BiikrRtg7Zt8PzsEGfHR0OdPrVBWtu1MYiuFaV+GOfcoZpw3a7aFucnh3DNIHc9RtunNuQOFvD5ol5nSnrUp0A2TWtLkifYF13vyro/7xGUe0uo51xyjwHSa1Yl6yvgZcT1hempvV6lMcwdgFLvGUPF6LqV+itKY3OjNLbc3ty8i9JH28T7XiwgbhuZHznkrovweTpkLcilZG3H6ol2avppfcTzPbdu8PZHct18wGufgwdFZNZlYqQ6dk4ok6yb0nzI2SNAW1NDmiN/S9D27DkdcyEHR/Y0/LADXeu5Pi5bez6I7hdI2ybJA6vD0z3L55+pAC5fLMcN5dA6A5ifQblhTG6kWxnkyC5SxgO64UIHeKlTtIkQbaZl/WKa0EapjpMaSAe2bgso28uhDm6uirYnnN8LlX6BkEY8V+X4WGZOPieza++nuC2Sfu29H4/YLsmS3gVy24fvs1wuR5NR826U69OI+UtJ9waDwWAwGAwGg8Fg+HZhBHeDwWAwGAwGgyGGc9zbHzKg+R6XOVlip1W5zFxQc6TPjiCN3K6BOsG0ejkHE3eUhTRORM8RzDU7F/1ksdKR3HmYI8yTxNRhrIE7fXl9msedzF7Il+oCCXE8wsRSQcwU2MMRLDqjJce/5DDX2Bdj+agNvByx2QExIZ23j/eFY2Y71hUZUkPURYFo4OTiCRFDaA83VdUlpGmftSGU5OWGO2drjXyNACPVkS4LLjM3XZaCy6wiDS0ghFEdYOQwTUaSH74rhHTNDs4TqeKL1LSn1H6frviciBdulZ7r5EREzQhCZo/GjhGMq4jS4bbNiKiS7QkhkOsOOoNtjAQqkVo52Vw61EF1l0irkawhIZI9pRcwXYuEuD21lxJqmWxuA0idSC+zxyHuLwkSGT7+7PDDsxMAA3naNUgitwtCRZn0O283t4n3CSWwcoKsetiEy6bkaPJ96utB6RSx+fnlMV48OwEwRHd3zqFpJlFDP2hzS0pT2soPfIyNT8oW5ymGyPKHhxscH22AfhDTY4hCXZIlEsBB1rsCKV6Tz9Nyh0y0dYJ+V8slGvN6Q95EBubtpuRvwebcOigRyqN7MdErkbslsrVEUNf6MWkDs0kkHXPStiJzydyJygDwUl0gWg9K695YktRKFMbtd266J9G1ibcnuo8W7slJn0CYUwXw/RiVO+yX0zke1il1/0HJ4nQt2YPgru0P40LL92s5Gcko5+aVYluUTgn2Qllt716Um8mXrFX3oMSOJfr42Eh7fbqPK+n3SGVoOmv3OtN+tCB3uHYwP5c6lldSUguhIyYR6s1j/KsZnrOJ6tPslJa1oM9l0jSdJeQGlsuitucm9fKlJUGJ+K4GRRDSQ72cPIm8LRHfc7ZJZXIR3GM982ByIj7H9O4s3PMRhqSu45eS23WbJdmovFEYDAaDwWAwGAwGg+FbRH1YSoPBYDAYDAaD4fuA5lZ7Cn9aBOoMrgIxQIp0rleT80vR23Okd0f+C2U5yV2KCFVjY000/KlMyfPP6kUOPaVuRGwoDRKdLdxhy8stsJV7/r1UbiwT8WZKDnOtPUI7nBPK065xSrbilPdSP3H7pD6saR/SJtRUS9SRgsHenLkiWUiok8hQDAqkC4lbk/ANXKo/M1xRGS5PAiesaDKlOpy4otnA62qXkhfyqX97qY25z2rdkaCq1edwwExILBCytIiplNwszTluh6OkOibnUVDI19NayQmBJF8l3QmEXJEcrJDbA2GYEk0jnk+G7BzZOo6PSEDUSJSkfET+DtlB7lgW9Dur44W+StqrEB+jOUZki4TTDOk8OzvYGHq+QAm61E0ULcdtYH3Se6Dre/S+j8jtiS5y7eQiDwcdElFaPFhS6FONcJ1oJv1eIigDQN8PxPbdrp/kdt3wT+uHWjI2tzdaR0fbk2tS0JPoHwqj7z06eHSsT7XDGzlbnZBHy0htLs45gQyc67ssuT5jW/jLyct0/CeSNVnHpDLcJqpH6kdOKJ/K0bZk1lRJHrU3V3bqGzbnaZmkv1mbJdkS8Zu3X+z3cd1zrLwknx5soTbG63LaXgnODVGzQ/u4LL5WhXu8do+g3/2cEOXVkNuZwPR+C3lco/uatF6ye5JnaVFRKjfu0HRPUGyCPAbh+ixB3ftOtsv3ymJPhzHPFKFrLd835/bkkhz6l++Nw/pC90d8H03/8f7X9pu554dIh5f357ye3uMxeL40X5K2CkYmz3dLLp+Mkb5Uhm2fprK5hpQemvhDSdUkFeRIk4jawycqbwOXSdOlesmmndXV5NMJrYHnO0CKiC5X1cnZS0jxGhFeqqulaZHfc3bRuo53gqJXeqcHyHvHmveFOYJ6LfQDA/MHV14yDAaDwWAwGAwGg8HwjcEI7gaDwWAwGAwGw2fCQjoCqZePuC45unLgUam4c487vGqirdc49iTnmlaW13HErbUkolQo7wZvp96XEhug1o3G60hOWymfl6mRidFZrrEieDskx7XCYvCSTMamEM0tObolkDKRP5X1TeKqlbybnLgg2Fk1lIVC+3AISmp8SMjo5no1TgKXrbu55amh8SmoiTmyyRKiEpVJ69b0WUm3VC7pJ+eGlyMSQTVjY6STE9BGcMKmVCZV5Ka6NeT0qL8korhQmJPLsuTbEnmOEMElcuZcjN6nhL6RiLiEsJ+zgsvyJI0TR6k9jsmg0Ww5gVKLsBtFrQ3toOTFMU2Tp/W9RnIU7WE2hfLS/MvNVYnoKWEibJNyw5o8LOJ0fKn8qa7SRi1tIogq5WoIy7wsbYdUzgnzWur3WnCSrUbq1Yi4tTpq8xyZp/vIA+brOEdKzkEbTyojNx+4LVy3JKNkq3RdJq0hJOU4OSXPU7tEYjhbn2r6TrUr5CM/7xMbK8jOESFbqQOhnzn5PLceQ7Ent14unb90jJL1nunRZJXW7mkvEfJYu/i9cBQalaWfa+6VizC2NTFb01uxD0lkKHkew687RGND7OH7QECe51Vrk1Svwk5dq7x/1vak0qNX9ppV5Cf3apbH9+aSrZ5UzPWBpq/UX0m7SCVpfx8+R89qTEiubDUEG3IPL3tfWbzjcg9lpUmgyZc+03q0k3ITitqS0/mxwduUu5AkCOX98HInkV2KnK4Ffah9j5bYINTlkdx5UAj6HqxEEOd1qL5SVHlNvued5h3mFxNSmbx9HxXOofd+/XGVGAwGg8FgMBgMBoPhS4MR3A0Gg8FgMBgMhs+Ip3L/aIT3mqhO3BGXRDov6Kv5GWfJoVgTBYojsl1yHgvyaiLRCxW5Yt1RnTcgXzZid5G/xAme9EmuzRIrYakjPcuOIF9H2RMhgTMuwmdHSTmI2sbJBtkuDX5WRtBIiWdSYq6CnkyHr8RbqCGYRGlEiNZujXzChyXHe+Bp6pTwcTs5cYbblBv2JfwMzR5+aWj9qo1DDiLfYyQaLl2TxfIDu7Ca5ClFtQ3oE8bPTAJMjWEXx5QcJtrYi9y2DKkv0S0ljzocIfN5ZMh/1CYim5OreSRix+sGnRL5OEMa9YJ+2n4a8VizUawT7MY8r2uJmpIsKZ32cVRXIW1PdYW2ctI9R440PpXhJFWhzdSOHJJ8iQivHDII5aX0pUTxMD+mscqRaen4ZHTVENij7xXkWr0BCqmJzy1C4Oe6NBKyRNKmeerar9nE8qRI4JoMfv1Quz0pE3328SEcrscpfcLXSE44FonriK+hnL1SXQ7pYAXXz4nvVG+JxB7lK/I8yaP1PKmXGyeqVyLAw+uHpKaxkeylaWRctTbzgy3iXitzIECTF+aGREin9xbP5DKBi9esatQS1TNrU5HsTu+RUjb0vW30me4H8hp1U7S0TBvS+5Auv3aUatpcI3PaVzDTcv0T7ZtdXIfvs/lzjGZLaa9PM73wT7KNp5XGXCunPuPw9H0mFRcuKZMeXmr0LulsKlcaSFovN8mk9tDPkiyqt9SH2sU72px9v6E95El28zrad0B851NDKC9Bei+W01WKEu/Jf9L7sxIJn0esl96HafVL7wAfg8f39CBl/P/HizIYDAaDwWAwGAwGw1cFI7gbDAaDwWAwGAwcruyA/eTIcBolx5wWPSqk5fJ5uvTTw/wvdcLlyOwlfcnPIwsOuVykLQmaE1C0hYqiTuUFLATRYZubUMEBzJ3RgcdYmoGSl1/7HL5Tx7HUPu6UzjmSpfosbRLHuYGC2ogdKjnoBad34venMgR7l7hsp6Yoc6CKqCPlO8AzAoimXxpiTkSRIMl1Wp5Lh91B1p+zlQ9ZDZlFmq45QlCOB6K2D/K4DGM7R4dest5H+iihzSMiiEWEKYFMl5CvSV5ij0a+rjK4TGjOEusK5N2pfiDxMQKnKJsRl6MouqStnDgo2SURIyf9gVw4HmQotVey2SltiOaVMI8iIiUjkSbkYqkckTORKYk+KjsZC2I7Ezb1PSfucsI8J3fSctk1gY1D8o+2WyLGAkMEf97GoC/0kzDe0fjlCPrCHHXMdhdXmOeS0BeUEJyMQYFsTG0MNmiHKKS2TLqV/GQchTxqZ9RmSY/QLk4yl4jB0sGO6S/kceL6S4co1O2QskZIoHNUO9gC1nZeViPplwjn0QELIJmjYR5qeoDMfbpkLyWsh/RQj+njRG5OHKdt4fqLRGneniCDyYr6jOTzuSXKop8z/SneD9h1xueFdo1SG0tItu+V46z2bYaoP2YUDHLZPRi9vwLL9lPJNTvO8WS/FPTwa2tM548knvybE32UF2fNefEH2WbtEcqTMhxannjdZb5zGVq7w56E5/O6Wnsk26iO0rMBB9XDnzO4bF5Psql6nlGh0sTI5RNlLqdYe2DzQhlp4vA6uQch7eEsNyC1nZ1DGDxpYmVsnd7fhCU3N3JS+3gR7+P2eCaT2fUxo4prbZHI7JIdub6Q3qtJsh5DTE/ruHGJffo+WzbV2L0YgAsX4McbToPBYDAYDAaDwWAwfKEwgrvBYDAYDAaDwZBAcJqLOZ8Og79dILwJzqwS+dsJ//HyND3ntMvpCbZozjfNTimSPM2rdeBpDkFOpmeZdWkZiHKZAzbJKwuN5Sy1U9NPZXHGAZdL69O0XHtybXNCNteVIwgoaVOS5MQvgchL/LpCW6VAj8XpQgpI3S81WeMecPO0IZLSeZ5EpNF00XyN3KPJ1eQH9EJabg3mPIsh0UVlNc5Hqc1cd3ZsFUIcgIQEx/kyWZsWREutsXSY1x5zKE+XyPFxaUFlGiE8R4wLJGOxXI7oV0GAlMjX4S8lN0MgR0b2Y+6bNIJruOco+gUipRuJfjkS/TQPaBu4vNBv3k/R/CMCukC8LEUbDiREx9JrbnVadGWxX5ldkQxKXNTmAL9uaF/SPmAkW66r9jbgEc+FiFAfdIe+E0jAPHJzRJoXiM48PyHVZuxM0ihxGvH4qJGuhc+cVB305cj1ybwn9msEb/5Za5dkc25O5WxLiKsCpgMqbN3gfaLZoh0wCWni4RvEfSzNIVWf0tZgu3awJLkn8WtrUKrKlmRQRPOEtIEegtDqeyanRIinBw34+i2R16M8Kpdch7l5JNrMxt2NOqV+jmxn7eTtksY0tyfQ7M/ZXkJUclx3p7mZuQ8sPcAgK0/nhWPpYOmL9mmI97DaXls1r5Am7edL6zrd00qycjbyPa5kh/RdStNslfb0uT26hKl9Pu57ONn26DmDXxJpkqwzNIg+nHCDhYciB1bOM33BuMRQZi8dWAh/iw2A3tGSztoHGtZetTxtH5eTG3RHP6aRx4s7TzeX5ekuTBhBRClqOS2XVx+ekVLZmjzpnRxNl9698eATUl/xck8FLUjGx8BS2Xr5j2ejwWAwGAwGg8FgMBi+XBjB3WAwGAwGg8FgiOHcF7hPlnymAZrzh0eNksjlUuR0ydGm6aUkcqqv1mFIHXhcHi8rpXHHIW8vt8OhMmpkocgkdwlzLuej4w5irTx1SOeYDDkn+j5OcT4BuQ7JHlanik/DiQaSc12oExNwBHE+/qeJAjDzfiXZQiVPdNLPvJrGNciRVni9EtllX5JJTRk+NJJNtfk5SPwJTkDKkXOGMchHlubTtYYwlMOkUySJ101jsaxAok0rFNbaXCRXMmGdUFblrQuku4TYxkmJGRLyLMar32vmKa8TyL4S+VIkajOS7ESsnA0SdVcRExeQDqcllJDkAyGcE2LntSollGoE2uhaDoNM28kGnpJSE5uFMpEu6eABFyKQoGmbI1uHAtn7uHagJHzn0aun7wIZOOjjsuk6lJCQVcuEtgg2T3b7uL+Cnfxa1ci32ryXyMW0DRIJWyLr8/ZLbZNI8tIBjImczGzIkeyTNnqf1Evm8VguR0B3SNstXQ+0nud9py6e6ZykttN/4r2LE7LB1gtaVtSOdB0Txouue7RPtGsiGS96nWXWPal/+fhI12SUB8Cx8Zz6iRDfeR5tI5ebG7907ZE2hqTdkhzSbnEuQ75OpuuA2seugSXk9SCT1q8+aMPGNt4rs1qVZPec5YmE3LwispyQxvfNjpXV9pncTkfK0jRpf156BuB7Q4fULijfOaS60nMC/8x7NFkqhHp1IyvbCCePVWQDmO2sDpWXezYQn7GlgZIE88+8HivjqBxtMJYMYu0kot9z7cjl7YOcfZpOAJzELdYZ/0mBEES4Ob8ofyyTkzflkSLa+zRKTJfeP5VslwJL8PdkXA7Pr4FULttPrk5uSV5NYIwSonXqsfPWYDAYDAaDwWAwGAxfHb444o7BYDAYDAaDwfA54b1vPfxKdeh/UmtiDL7ONKJTWk73+GiR0nleKWo7/yvZkXP0hbqliFZcHv+s2cNlRPp9am8SESvnOXdEj+ak3sfplptcJRaC5tmvrR/SA+dGs6nmAuBkAIk4MKYVfeySQ14iDSh1xOFxgSSk19W6iGMmljFCAy838oACoQO5spibptmgDV+AxOOgcsHKcq7GkqkokXKkOtoUlPIkOTE/xIllNb6K1uWPWc+lucXJllq5AE7sSXgqGjmQkQJzxFqJaC2BEuxclCaUJXKnucVJsIJ+TuJLyOU5FEjNtC9lwiC/n1DRPrFPIx1GtjNSJyd5RvYGwqckR/hMSbNU5lhwGQlx1B90eNaX4vUhtSEjV7IliXBMCa8K+VrS6Vg5+nnqI9Ku5IDBOI6cpE3nsQbe71wmJytPZGCU1xdK5Jd0TZc5hL5UbJfI0xrZXZzvTIc0/vQ+IV07oUykD/M4SQcMJFujtSKxohJkneJ28HVLF+HV9YeT/UN5cXtCr3+BFE7tlGyI+oXNRV4myOJE71L0b66Pz4vkvizNXZKujS1NAyOgjxWnfCfYHl3jpD/ooSAPRMT33AGPHKFdRHTPTW33bH0dbGdjxu8HZKwo+Ho91Zeu/4K9Yharz+/tWQj3kWCftB8qioN+T+T6tP2qY3+jz3z+cbtZ+aV7RmnfmasrPeJw/Z7l5+4vUvlpj8bK0X7SHqdE+ZlO0J5b5v4f/kX7NcWu3ATMtp0JTOyVBoh2AL/UcvWk734syjtDGmBtotG0ukunrhy3iQ+EeONGaqe64dzTLqqvqpjTJ5pH8i4oqueCWV5MD5DejfH00nsz+h4sBy1YQ+ndmlaGQrOTv1PT2htq5eRL0GzP5S/F3vtCg8FgMBgMBoPBYDB8tTCCu8FgMBgMBoPBQLDUn/gpMPsV66zKOcYGeamzK+d0ypHHS4443b7YkSbp9Ow/yQbJzlTX/JnK4c7NYhQx4bOfPNmRIVNasU9K3jmRoaHYtM+k5awGwhdS9YZyGjOD25NrA6ujEic0GVIfsIt4IhpUMjiyJvj5c0IKQoEfRf3x0RwS9Cj20Gbw7s01j5NlaB2NJMR18rpa+dw0XDJFc2vxfB3Xy5aITBp3Iydv6bTWLp/asnGBOBptjmSczCsp2usC23STZiIijX6bI4dPunIEOE5y5qRlSZZAnp/JgT4tS2XmSHXMjumzZAMjdCbRsJkMTrTkEZoj+USGJHuyTyHcc0QkfqW+Rt7nfSERXBPC/5ARpyvk3Kj9whwLnyPiIpl30dhQUrVADJbaM32nBGHSriSStkTKV0ji0xoikKNpfT42tE4yDozwy0miCbmfE4cVW8RxDW1TSPNUDr9us2ulQGLOkV0TwjbtG2E86HwPY6l+zxC3RcIx0jkcSNaRDiDqb2o7vx4k8DGWDgOE9kv3KOn6dUp7xA0N6/PSmiyNhVAwHkuX7sYHWdyUeM5GB70C0V2Qo9kQ9b1CIA/5fB1P1hU+D7xPu4Hch0qQ7lMi+PhQXSUd7G/Fdjm919TUUcpN+mnf8ZLamFTq5ftlbe3VZDuljFYvt1/nsvn33LNBbq8f9JXGj5eR2kkL0DStXu1zQa5tnhaQliBFiGRz9SBzeZ79C3UUwyObuH5tsuc6i+RNZ2P4pNE6vnYCcJ28vGY7zc/e0Bfoz8DDZ2VF74lov4mTF2qbxAOD5L3RZAtL196n1RDbaTn6H5eXe59XStfaUFOvBk9BVN8bSw6lGQwGg8FgMBgMBoPhm4AR3A0Gg8FgMBgMBoIv0VUS+1ZTR1Ltz/xqDq59nFPcYZaL4CTLjx14vKxEeOeOwxqEOvv8FHJKrJDll/QXlACucgxqHc2SA15yXNOyEtujZlqU2BGcpMCd+hKBgNYTSABij1LnvOSUz09BVVeUTXT48J3V16onPtgMMYB3iVZGS+NkmiUzXyPvUKKOVF6rk7MhR9DJ2cLla8hNB0kGt1OzOdeftTwWOs1r7RsSCMFXKJcdjz0jqNaUT1CpKwtO7tZkKqRkSnJWyYEKqV6MMsx1kHQeqT1XN2lHgTAqkYNrx1Ik7FAyqzLOtXNHItdK+RJpP4p0zkjRMyk2jrJeQyqmhG1KBp4I3dxmaf7QvyE92Kq0W/rMieUSAVoiTFMbQqR57YCHRIKP7BHmmzhujNQtzUl+iCUWq68ZWh7tk2TeC7pLMuj6OI1bzi6az8ad6tQOCEQk5lEGLUsPi3CbwdpdWnG1uZ9DmKvi4REil5bTDnnU6gxl+OGT6BCFdBgE5J6mzrP42hHvhcK81w4raDKkvtbmEV0fEsI7P9iikdnZOgXadrLn5O2akpiOmgMl2pZY27qXEA5zaHr4Pqh6T6hMN74nXfLoUvN4sKT90r5L61/P/kn9ndv/e6Ws1M/avpCPc+1uTdpzLq7INtHqnlXbbHsijm2ePSunP5Bl8iR7K+r6xICM3gXPg5ECaUC5TqqDlqeTZemiwPWX6qjiC4WVvs1Gaw/5ir7pP+HQDA+kkAt8IL3zyr3fKbVVepdVqpMjrUvyawn2JV1B4hcFvsgZDAaDwWAwGAwGg+G7gRHcDQaDwWAwGAyGrwA5CsxTOsWoM0/6WWYtYpUkpzaiOnfESeR2ye6cfRJRvubnpFMscf+j7DiXNPgCAb/WzCV5EgtCKlvjdOcMQF6XO9VVRoMgWyjj6QeJKBD+SmMhsUEkW7yQzPOdkC8xVqA2ZW/nLCeoKKZlfcB8OPhfTsLhxBwJ2jBruqVyGv+iNFScIyJxarSpXkMmytkj2VXSXSJ70XRN1x7LTQJxeVhAUFeJk3StJcTPEnlelLaAcB9FQQYjHSpE9SlPIHhK8iNiqkI81hCVXxhlmPefRErVoktP+oj8dD3yM1GRtYuSMyfy6gIiKLdNiiTtQ5vCN4dpzDjxPHwOBN3QnkmGNibCIQfp0EEt6LyOCLMK8Z4S+0O5pD2cOM3s4gT4goHxV5Yt2ZxEXackfDZ/p3aTtmjEf80ufghg/BLpBisTzYeK/shdoxoBuiiDtoGXxbz+SOOaMWaxXVM9usZK80qQm5XNieqjHvHgCpMNINEHYX7AOXh2mITbwOXKxYS1kOTR7xKmfQtrH5UfXUus7yjBe+p/qW8rDzRMZX1+H6e1o6actgfie6k5g6zTUXJ8HWjb69x+RrJj+izNKSZbqk/TcvstbrNkg/f1djvyL6eb5zvo7aN7cd6PNf2a25vyutwmrX4CellLyqXLQdBZBamjuM7cg4RkEx+A3AMFTdeMp+lSh0oTRJAxXweZcpJd3BapfO7hQqtb++BRKFMKIuDDHlACs6EUyXwJ0Zu+m4JjzzKYgy3wd068PbmgDbwctZGT7SX9POiDFnBiaVAI/l5uhl5/ScCJJ8MkatGqYTAYDAaDwWAwGAyGbwBGcDcYDAaDwWAwGBgc3BJ+0yeBAyWBLYtIrjm+pHKcgM7rl+RrOqmTkUfJKunIOegk0r3U3pw+jfQ/2Dl8yiGq7+v7LZTJRvAqOb+ps5yUUx3HWlMkB7ZWV3J+O/KXpzv2ncvgZcZyuWvQcVYEr59UENohEQBKbA6B/RI1m+vRCB+Sfi0NKRdCmxKRafOUjHzBkRxuP9Ju4nJLvBHO6chxP2ogEdaCHXTqjYWjfKkOTePDLV0GSV6IqBz0EeKg0oBIh6RX0p2DxrWprUOh8kd4NNqMDF5uKDuvQhrpVyRIS3Jz5NSCSTl9EhmcEz7FaOc0onNiUOF+QeULZF4J4f4vLm0CwZQTNDnBtMreDDkTGNstRRMWDhck414TNdnLMiTydBNI45xUGsZJsEMkyhPyaUL8Hu12Po6An4uQTWXSayHYyYn9YH95eya74m5K2qFBJIdL5UKeQMye7yWsr1m/8n4uRZaWbOKE95o1LCIisz7l5Xgfa9HbOaQDAQDgmEw+j2jdiIzO+kAqLxLR2aEJeHku8jkXHbDJ6E5shtyHXEZSH/Fam17r8QGJqIlEV81zWXaO5epJn8a5RA8NqOv+UIHYWrgP1N5TMe9D1Hs1s7x46IXU4/s1DXS9L9nB9zrSvipOSPdtUV2+hnK7Cp9r90i0LLdDuD2J9XJy6b5Te9TQ9qgl5OY67xe+J0/aKtT1uc28AA/ynCbZVrvhXfLwwNP3efjgm36PdFC4HH6BSgOt2VV6MKAPOiX7a9vrEb8j4DbSCy13IS28yBxcVE5695G8vxlt1d5p8PISQTtJdw5gMumv/UXBEEb9S6K182AKuXdCWrtz7+I4ub6kT3rnxm2VglLUvMNagqeWN+xlnlSkwWAwGAwGg8FgMBi+AhjB3WAwGAwGg8FgEFDlNPmEjpXBz6g7q2oI7zkn12Mh2SORtyVHJSehc4cbj2qV0y/pkxx3cZ0cYSO2TWqvJj9LXFfSisg5zINMR3Rr5UtsCO5QJzpEJzrPk+rTclwXtYNy0yhhgHz21GaNnSHY4KSy1F7q85/6lJVh7BQXbJWGk8iPilBZvP0+bZaEHMHGs4SpK4T+kLgcyRD6tLs0W5bYneN4zMQaL6aHtGjqMRKkRNbxQrqmW8qjJDca4Vbl/3BSMJe3EJ79TUjbSr2cPpETIxBFc/wWDRrhdSIMVsjIIYmsS3RIBM4SoT2jaJZJ28LJojkyfrIAcRWz3KgNgZRaQSilEZd9hpDJI2VTmbUESdEGQsQP1yTX61k9Pjcaen2xsjQiNiWYJ7bQscmQdktRsqc+DH+pTm2sBZmOyHK8TbKUaM5OOkm7vNA2aX545bs690PbFNl0jmjzkdo8tVs5EEDl0rIObLzJtZbaHh9QAABP5IXriM8R59xUjtsy2QfEdgntpPJ4u8T+YWWkOZUQ85lNVIZGgOcQD9gIti6HE693qidL1pfI7S6WOewJpb38AiuF9QqgfZnaRcelRF6f9gH82iF20vzH3v8GIbwN9T1Ct9HJHlIoJ35X9ElbdM/+geVx3XxPVtqj8S16KCvt0TT90j5Hq8PBdST7WeFfKKfJ5mV4/+T6ktvF+0ezM5mXTrz0kjKqDWTBUvtQG1QpTUvXJg/tAKor14Fcj1RXmmi0jDbAXG5u8vF2UCxdQMK2Ei4/mZfm1S45QjuloAQU2jsWUgDaeyUpzY8vFzgBntsi2cbJ85pO7d0T1ZnYRf6T2qCR8MUDAEobpDzp3Vzclvn/l8r/WHCD4ie6gRoMBoPBYDAYDAaD4WuCEdwNBoPBYDAYDIYYkgvxC0BMBOTOsZKDcJCQb1bOgSjp08pLJPNcuRrnGI/8rhHGNadirt5EzCF5JYdgzrHI2yU5TLkDU3Nojom0Mjcmyk+c1p61hzvYiYM+VsPKa6SBWueiREjgdkoMD42E4CDrp/a6+LsLXSPppXaGpvN0iWTgx48SCUKyX7KtUBWAxDWMwLkbkknSUObS6OfQd9o0CN9zU5XXk6aONMTSlOV8FYmklbtU2BAmnx2QJ/kKUWIlYhXXz/XVlpOmIqc+pJ9ieTl9akslYrCoVS7vgISAPrWPRWXVdNCxViGQCcUyvD2cEC1WkzXXkErzZHrWV4zMPKVpeogNSX4FiZ9H5uYytTYkJF7ZsPnfkn5V0jgZWoxSzev7NFq1diBgCdk9Nw+jaNpC3emvMkc4iToX0Vo8WCCQb/nBCEoUTw4zEBJ4dJ0zQrvUZyrpm9ghRQ6ndZPDKgIhXjogMMyzcC8WiO6kDySCtxNskiKB8+uCR+inZP5gP/0FAd5WrT84PJMRbEraQ/RSu6N6mq7KQy18js3t89G80lA8YFSyQ1nL+IGgnP0+TsjrC8VyMmoOq5C86R5esFXUzb6PBi2SIdlW1wtCufGAyPw13x7H/vE8COnS3paW1Wzn6ZK+6RIk+bV9QfWU9jGlUZb24vS7eC0rsnj/TuV8vJ8S96Se6dQ2/loDmCGOfI7KOUGUtkFn9bLIPZhIDwocvL30oYDKlLZyvAy3KZTV6kv6tbSafpAuNCbHhwHX+kirm+vDGvvobQs6gb3qvZXHVL8m4AAlqvMypaAG9F0UJ6vn3u1I7QkytPdp3Eb6Tuljk8pn+a7iAezzwDnA99h8bjsMBoPBYDAYDAaDwfBpYQR3g8FgMBgMBoMhhkPtPrmOD/JoBBfa4INMHXM5B1q9jnx09yURyDXnWy0pnzvxSu3l9Xkadx6WImuRhKQ+l6UR3bnzk9cpRXePoDEepO/EOZ099CAQCGIxjqQnHvEYOeaF5MTfh7FRksvbI8jxEnFBkivZoLFXAlGhhrRAxsYh/h7ZqPWLkJ7rriwfxMcf913KcsNLv3DykMYTQaaMxrHRupzLoXV5d0p2cBKbxmeRUCpL9dX0hfSZGKrlPGpsNXkTKgmRQ8U46n1JhkRmW9KOmdBFom5PSXTyK581uTSKNE2j9SkZm5QrSefRjbPlKalYIBhHckMVRV+RXEvK+SFB70PpewESuTm5ZoXI2UVdpbILiPcS2ZnaRsvVEOazkawzdiTzT/hcit6czZcOgWiHKJg8fghhCfct6jPE/Zib49GtP+gk9uSiy48fZj2krjTXkoju0OfFlErWBPUwCi0n6Bpk+7l9GujBCrLe1qwRcA5OOByROxQS8kPfi/kCkqj2kyrh/pCzWZCBcH0UroHH3BP1u+1y+Txif408aQs8ZOS1RjKEssm6Rj5n916kDR5AL62fkr1RAX3/wrbOiSzPynpWRtqax32R1pH0JPUyMnkbaNm99zKKfUF+sqZC6PMaxdNz71ifCB/PEWVFFttHn3dUQ2kB4S/Pl/IkvXxi0L9SQ3KdG/7WLga5SUv10TrSRpjL0FBq35Ts5AcSbp8kP2fDkm1g7QUhlMu9hwp/+XukbECBBfk5Yvpscl5GrkwJte/6cu+farQ4h2XPe58Aw70G8PDGazAYDAaDwWAwGAyG7wz2IGgwGAwGg8FgMBB471sPrD63HRQ++X8dpchVWpmlpPilDrngXOSR2Gl+zU9T859mLtkiRUiv7iM/2yU5PHNO0JxNvF6Vw7GaMRPbMEVnK8mUygQOmKScOu05yyPn0JfIAlyWVlYjIJTASQoSeSB8zfUJt60Ex/5x0QJZRLQpA88+lHgiVDA3TdQlCMwRWpLucRlCFuQpwuWW6lH7NT6IxGmRyFMStHI13BZur9YX2uVXIhPNGXJOOr+c2M+1mGwSiN4UpTGbE8sycvNHAyXZ1ZIINXAC85iYpknIEKNroMl2NN/PkcrdaC8noHPCrhQ1XMNEkBUItlzmTKalLLZM/zBb5/Us7ufpus3ISqKOQ5hDhQMNpWjvoYw4J5gtUlkeCV1tEx0zfjhDIc1rtlLd2ajqQhuDfm3u8HZFYylFHZf6lEXe1g4DBPkRUZzM/5Iuse+4LsE2j7gfJTJ8UpevP0Ecs6v6/uFju8V+ZGMZ2U0IyNp80/KkPplsqF1btfsTIeWL9wxf92QylSvcT/a9C0Tzn/wjBuTtK3yvqRPZw/Ujvw4lspV+XWoX359JdkFJC7L4uNTsT4Lepdtxrqekq/S4Itmj9UHOrlyaV8qoCLewTF6UzzqlWpdnfepmcZ588LSjtYuQD2hII8bwbUVST+o0vvHnDwhLFoTastyOfRYdqR/4hFcfujC/X5mWf5+3Q7oQtPLVDyULUH0jHNqmRUqvuVvk3n+VgkWU3gPx9Jw9mt2590k17720AAxaRPlq7Hvz/EiIprvBYDAYDAaDwWAwGL4rGMHdYDAYDAaDwWBgEB2/CT6dTyW4trwv08prnFcamXwJND0ludJPQufyKDG+NqL70nJSvuSc1CK05/oz7afZkbrI0bjndJvs0ogBy4Rl4eFnR7rGHFniSA/lNZIAZZNQh3+OMeVIvQVmJPJrnf8SSHsmIgjLzzUhB0m9JoNzTjingn6gHAqN2KPpzHE8aDsTwpZST9JVyyPh/BZtKHPTlE47re0Z7kmW7FWTNghhUgSipjgmBbJxtf5K4uEsmpBY+fcCOd/vETlw77ubQJIO6REWkAk5xH5TCKtyUWGcCgRWTmSmxGvHvot2FqJ308/hrshtlqJDRwcAtD4Yy6mE7lyUdEqUZ3NQ1TnqTfSVDjWwuS2R3KNxKJBPI3IyIy5LhHOJ5K22UbCVj1GO/B7JVgj7DoBTyOpJFO9AdNbmQ278JZsEHSWI41Q4UBHpKc1lzNcnvfa0Mjy1dKgiFTQffJnmRWZOazJqrv0SHPR1y5fGSyP1V6zJUxaxg6fl6kz3/IVzKaA0zrW2aOD3Kn7YIjnwgLgvps+ZeaBt5Wvt0tL5mOT2cNpWnm7Lc2ml/Snfz2ltrtlnantpbpckn9uU2OxjeWIdl2kvaYjnAyAJFRRQWcEmCU6SK8kvTShp6UomvpAuDYLUsSGf9oc0aWh6aVBz9Xkat5eX0yZdZlJLv1gXyc5NRmJb1S5/j8VLeu+yz7urEjGcBlXQgito5PHa6O45mVK7cr8sWJKRe5+Vs3WfupEcr03Cz4296foGg8FgMBgMBoPBYPiKYQR3g8FgMBgMBoOBw1GSluY+2ZtCtzec80+m9jE/j/xYl9JeEcwLdnBnYS7qO48mH8EhqUc/S6T4mgjyc4JT7eGfsygxJSYygp+/U3ik6axMNaln4g2ObZKYFyUHPXW4S2QDyj4R2h5FqCuZLdXXykokhRzxgbe1hpRB8ziJRDY3zXOyadk6iLsZQjoHb07Cl6vQGdVn32umdU6PZGMor7VR4sZQe5J+5ZGChbq8fviuTQ/OOZEumahexbVZ6rNEAr/+hTqSfFUezSPRlqMozTURgCPidAUqiOaUzJvjHPWYbS8tYbXRhkXsQWYXSeOpgIzKvLWushyX2Qv9EAjDkc05QjoQj49AwOZ2luwCnXORALJXyESalsYoSiFzm7aXy/a0PLOj6pAEIXvTqPUSIZsS2CN7CPk5IXULkc9FQrpGmgaRV2hKFMFbGvsF1zIn04soRdomc3Rqo0LKj+7R5PBEYvF4CCC67+aI8xnbUtH56PpTezRlwngXkTnco0X31w5LUHklK8RfehgUFGrK260Sh1TjgCZ7oFw+O8yi3YvpHqJm+0jrzV/m+6pkt7a9juxkyOnX9k9aO0o28TStrrR/5d8lu0vb73gtj7f0kl05O7hNVE74nNvrcZnTZ1ffv1OaNnEWbeAy3/nk9aSItKnVOp4/A/L8ko3cFi2f28LrlC5qLovX0+prbZVsC9+1tizYaEarf85GQYd459h7kxuq+/k9gcP0XmU0NoH0Xoe/P+HytTKlIAfSOx7JFvoOidcLn7VI7DVEc4k0X4unpHy70Rbt8OTnxDzKBoPBYDAYDAaDwWD43mAEd4PBYDAYDAaDgUEng3xKK7huD+9dkQvIUeMoW+IQy/0s8lKnnORc1OySykk/CU0/c5s0YnvkmPQ+SS/ZQPVpdaf6rHu4PTnHLauop5NuTAjnGmtHAHVCiyQA/nkJkaLE6BC+Rz9Rz0gSSTs1IoXEYpLIDRL5QSNoUFnMfqeRFKhMrV2Cqen8SXkRqp5cOaq6htwRyhfmUmmqaTwPiYBUkq2RxKiMHPckR2bTpnGOoFUiSNE0adrxMtyeHE9FmhO8nak9+npTs6pzm9VpX0MWX2BDQqpcGrmZ2aYhN36qLZk6RYKcQhqlhNEs8RhY1Bc9jyy+lNBCCOlOsgWYSM81xPxpXLwf5lNFRPFl5rqZFJ4hCTvnVB1utJUYk9hGxytHNnZK/SzGvpEOACTzhJH0pej7UhskclMUiT3pn7zNUoR7Kfq+p3ZlyP9TGwXt1ZGpM6R+8ZDCOG9Cn0f28+/hgEzt9UTLFaKWZ4njmf7l7dFNccl4ScjO0yUHcjQR3C4id/FDkSCzdos76c58F3WM14l0X+f3dPrXsXxuS6RnwaG37BqEdN8ibYUhlJX6iafxfYj2vXaPULNvou3OldHGVmqDVI5DkrkU/PGAzg/JpuK+goNV9Dyv1LmSsXwQJRlgaT5OTvTwjig+yLA28M9Ub037aF9I8mqg9Q/XW5hgfnjofRLUvKdYBLpg5BWzMXcYVHPlXrcz1KMyCmXC99x7IPreiJeR3v3QdEpyl+qXIL07yr13+5iIhmjP++zHRbx3NxgMBoPBYDAYDAbD9wEjuBsMBoPBYDAYDAJmVw4lm3wGQ4LekWO01IRawrkYzXyBP6sm8rjmjFPJ4ErdUgQsLXKX5PwsReriztO0DYMLUIvWVdMGCU8ShavERinomRzdJSe+xrTgumtslNg9kv0aAUBid0j2LSUmSLIkmxhpIlIh2VgiY0hmsv6IuHW8nMSGUZow1efrTPjODJF+tVymJugmSIQoTVaubq58jgsT8rWhkQhfUsTZmulUImxRmfxy4Pqy9pE0TohaenlSXUsvGQ3TXKgkJuQuPQAzARqCfTxqNqnDIwJL8pe2m0eRztbLRJEfjRyioS8hPQuk3CXwREaJ0FI6WKASa6Vo7kIZN+oIUcpzbXI5UjAtQ/IkUrdItmZ/JVtzNqlEcmb3Pr8A4INMXlci5VfKlw4liNHrpWjRFfNuIscjP5c5R672IEPtzI/vlfN1w8crN37JfGHE+IgcHykn6aEci4gv/mpARQR6UV+uvBYZPXwn4xVBGGsesZzW4321ZI1SSxZk0LWbj4W23i/RL93H2BaweP/K6ZNGe5Kjza0CpPs/33ZqHFVp68r3T3xflGsLh3qPR9yftE9L4yjt7ahcroMWlvZhvO7SNVvah+UQ7z3lPXV2T+eiP+le3onFY2NV4aySJFfqKG2zOn6O72VCWWng+MSg9XMDyGVwaG3OXpyZOvQC0/Ik+yI1Lu3r0gWrgB8Oz72nkT4LBad/2vuZZQh75NJaH9vHSee8bCnAgpSWC2Kg6ash4peg9XctEX4JvqaY6Ml1YDAYDAaDwWAwGAyG7wJGcDcYDAaDwWAwGARMLp4vwXkSnIXc8bsQOceVSPYWij+GeM0dfbUORY1szvOpnlL0LckxyEnwVZHU4RD7oWO9pahjOR25vOyBgMIQ0ehvSdR94iR/lKOzpmrOGS+QGCZuFHXke+R1cYYRJxdIJAKalyNsaLZTeJad8r9SOQr7xUv2ReOlDL1ApIi4ED4lDlVd5Rq7qKIa/SzxTlT9PvojymRFk3LS8Es6a/iUfHosIXGVuCiavNKU5WW4bOlzjvuT06+VnS5LgfyXmzL73l3oMhDJZyTcEj9Ly6uZ5tIcSsaUEO6z0ZczdtWMTZEMLCxASy/lfSKn13DluHz+d5JFCMQRsVYh7Erk2yrQOUSIyCWCbk3/7Bt9XsMUhX8BkZiTjpeSkHPR3wsVYz3sMEpE+F8gN0dI58geeqBlUJ6vi6KrSyR6Rk6PDgKQdA18za2dW9IWh9pJxyAi7e87dxfap8ELNuTWX9qfNaheJYRxovZM9x62Lnmej3Qflr33fKSIujX3HOl+qm3Jpbmrbb95ux37zvP51l6ylbcjl8/1LoWw1a56RKmFZ4U9+cCfMYJsN6Z5+jejNOmf7ALBknLPNUFWqUNoOW3hK+kJn6VnJe35r2RTzSZSaJv4/iA3EZde1nTRKGzO1UP9XrETc3qJoJ2LPL4kcjmPjE6DFOTqSsEIqEytDG9nbdAE3kaaJ72zqj4g8Ag8hdyY9B/2Io8W+1EwbCX2Xa0NBoPBYDAYDAaDwfC1wgjuBoPBYDAYDAZDDksYWR8Z+0Rwp/hYTrUa1DgScxHVpWhZtT/lnIuczh2eOaeq9LlEPq+N2s6J5pozWXI2F/W4ON2BkdiorBIDRIIn48NZJrWkAY08wNkmnAFE65RYQTkGTIn1opXjuiiRgnz2tDwX41M1UwInYEgsIcW0EgmE21RERTmJZBO+UwJXVMzPn0vdS79ow8KJURx8akpTiRbgQ6pNPyBtHxeXcGASAkqZTCYRvbRymkzJNlqWy+L8IMl8kVuTI8sywqE2HjW3YKlvJOSmcO3ywD9H9leSiR9zHy+1oWr51qKOV9qQ7WMXz5IoSrkgR9PpMfeXGEGc5if6x8/sLwKRuETcZsTnWamf520u+vgTHCCY7KgtqujghHWXIeiHyPrad1pvv18JkOtQgvc0Zi7e5fz/2fubnUmSJUsQU/WIvPfWre6uRg0xPcRwRZAAQQIEAb7APMO8IbdckBuCC5ILDjcEiOEvOMAQsyB62I3pnq6u/6p7MzPClQs3VRM9eo6omPv3RURGyklEfuZqqiKif6JqLsfUn/1VAg/qdHrINLct69v+YgXe25DnWb7+iwXjs9G9m9vD575wOrrXzmrOrRmFf2Gn0gs9u3RmN7Mc+y3iP+laFrDvCjbbucUmhVZidtu1Hdd53N8U8lfpUmkdbHv8SvvZuaDqcqUtrFysy2gXb+oSWQi0Ffc8IezcVM9SZ7ts2qIw0hGbBqUivIqxjSl2Kg4aNcB2Hc+uI86F2aw6mW2Wi8iLZV6B0fsW3+2oF9ojL7p38vizJ5NX8x/TvSOd9zzs+53lJX5Hrk1nsiPf91hyO8q5Cu97nl87zn3iVzUjkUgkEolEIpFIJBJfAUlwTyQSiUQikUgkFL7FwMk72/ReAbRnA7Ae6d37OWhbdkcKZwHQMw/PvzuB3Tu5XdWJnURv67GzFYGk8+hPZD/TV0twOsrK2pECkIlyhZzgMWkskYLpZPajLJS/MK6IXMUCwo+RaYgMI2ajKgq2NJQDsqIjYsgRbXGVDMOISDubGPkKy7CutNeW8IVl7dCQpFLHPlTsybDXzCbMt7NJIVK3XVtg+mxUHScyq7ZXMlletN22S7jthWzFYWJ1W2wVRGx7vdRfMTQcYjjDqP/VE7gDsq/IaJCyO8Va6XctV0RZcWr2khIgNbv2KSLzhkC+hS1j68hkBU4fR9hTxVV+TFefn93RDXjtc5C8p3HVCfCEcP8e5PeOe7fj0EN90OHblnvRo0/NSelTPV8gqj87r/Gkcbj5pNRVtsxT9NbN25LdI3N6A1wD5HoGNuCWUZUpJq9ng+IU78qo9Vrl34HtQZQ+K1vqP9yqKsfqwNoUx4iqt2dfKca9CntHH9Q5DfNEdHv7VdrZovFDHqFt5F6ZxraRnQquvk+Ui+qzgtmmNPpMCO04vYhdyzrwIs913rOe2qijbbsJNGVv6z27lPYHCVJOEbCXX27DNGUDNblu8ymSuErzTlu3enbfV7DvTrzvlXb2WqhT4KP27b5v+5qHUsz4VuyY0Qrf7ycSiUQikUgkEolE4vtGEtwTiUQikUgkEokVdQSHp9SvYEn5sqElRQb/UmA/7awQOdVrR+Rm9Z0DwCQYDJ8jJ4+xk8SuBFttWe/UMhYYZvVm16M8O9nVZV9Mhs63GQNFERM84gUSEhQYqQFJDFECAtob0cnqxhhQrIxJH0mKJcPqR2SMW6xtj5sVPi/67D8PFxwV5YcoptA10WGdjD9kiWXKHHbPG06MsMVky6HvtL2aZrYOyN9RQ8jKxDZAuVie8XWm9j5ICDdBEO35FbFQeR+sA3M3rFy/9voZ0yJuh6GWsvjUSeeGAM50sxJdz0zg26wrJr/XDgupmOg2SuPzNXoK+kb/EBfVewFUF9bRnDTfzD9r1xhHUdKybRtykrol4b85xKnti35z72lLNiflo/7QCwyeLiCOX+kP78T3KmxbxKA9prz9O2RCGfrrAEjyP06djyKydr0iS40R5ceUXLumbe2j+9j1mm2LmF5lp9h+TXnUOrVdN8w/WwbLqz3Jzrer7R22cWSN6HlZH490M/XsuurtL7w9Ry+P99S+YbGv8nxbkAKqj4m65Zpu3PD+kU73I+6CTIzDtF0DqAFukw/7pr28N0HZc9ju+QnvKbtwcJlBtvxiGSvLJrWauBunJp/BlWMhbVcjA5XcU6eqL98BtMdfvhvk5dT9Ky/x705htzY1+E99V6R+DY+d1r5OE26zemqJEvYVrhLYXz0R/lnUeityMr/TFnSn4/J+OpFIJBKJRCKRSCQS3w2S4J5IJBKJRCKRSBi0Vj6UUj/WUp5jd7wX/Ljjm+OVk6OuBOC8wOGz5b0TxHYEekZCt+R0G1y1gUwksqM+Kx9tiP40uNKJ+rE8C+yq+pbCSVprEHq6GWPS4DWyPSKsJUX+sH8tCYExxKbrpueULY+Ehx1Qrypr8xl9wySvrkfehehiZAwTsG1mLpzvV1j/euydi35zFKumaJ3vYd4wjL2qioxc1dOjvKHxt81lGf/G47RYHaO8EYTdp4a+TUfOVICrNOm3Q3M3Nb3PpZSF9GuvFW+pf8Y67NwIs4URzFSdIhytnm+3PDcgq7N+QZm7vnkLeIRc5jLxLyPu2/bYwiP+O2Xkad4X9Xn3IzuQyBhZ2gjafDqpO9gfIMC18SmQU9t3Y9ubd6UQIpKq65X69LEgxsNqUCvRFwNU34bGqMByArxD1rcvSVRIR5n4QsUOaltBDPYFGeK61y5TWwKpn+WNbi+8NWPXx1f8+m4dd+0I6PH8vdqXoJ/FtXqUB8EsXz0U2X0L8+Oe7lJWmSxPz4dg7Yn2MLA9gdpbRGeIt++rLAPkU6fUe3ueZdOoGr/47TEpYBsibNwdVCdaWcaYhhui3ebR2zztNpxsYrBB423+dxN6mVDENiGfnrxeAuuUkfnMdzGRF+Z9Yvj6vUDkFHXvu5/I4QXyhHmQgbpVOtq25tPkdQv1HcrXIJt/nVPdd08k7wzSzKdL+Yp2JRKJRCKRSCQSiUTiqyAJ7olEIpFIJBKJxIRm4iY72tqXwSAffPlY2lO48pPM3snoqoxN252sjuXViVv2ryrn2Rn9iW6WtjuVS51IZv9GAstL3et8f8iqa3Ab5U02XY19qmlliQasOi6L0JRT+RjTZWJVb3Qoe/u1ZQ4x2xRLyX4uJN1jxVSn6RW5I8JuQxJHpH8JkUp1Y5TUtjNdYegmZKEo36eVmRzGumIpV7V8tI+R4hb98NnqUveZ7mi6SrNlFHCo7JYrNfyVPmwbbIu3RohEVma7nlmid7yvS3BeIKDZiT7btn2MdYLz0kdIti0X+4SUp/cEgZmSxSNg+S6S21ldqQ9r5sU6OD2838d6vOuO88mN5BW/0PuhGn2RXypQuIv2qYSIfxWXy5BT11/StRl3bFuwlenZUC7Yvfs1BkPAZ2sY5mvmugPze3J227PdHoKtMWwOe2XQPk+n2sa5bWVsUPukBorZltFucVEG2+sot4DbZhw/laSxcoVc288ok7X7lfl2dfwwm+g95+a4FdmXe/fHs1mhDdkwv0FdLsq+4nX6w21CXfaZh00KNsj632lpb3PZ3SS/Omm6TG+zw/Sic2B5o4tiK2XypNNle37jKMpFidfqewzv1+UsaV99V4LfEahT3RUxXhHIrWxmP5Ph3Yuctu6dBh8hm38NEvxbQa2JE6IPSu+C+m4/YpRIJBKJRCKRSCQSiW8XSXBPJBKJRCKRSCQkmmV4Lbe+LH65QTKLaECSEcYjgUJ+StcqG9ORZO79/LX9D8GCoSzPMyeAqRPhIy8J0MAwBtnPD+G29myV95A1fOgEAX4eJE4oBg1jz+x0F0I6wDyK9eTBY0Z5EeSdLlb2EssU8jJySoW0SqpMiFQ7wpl37xWP94wORt6y9VQyXRJaWbsdxNNrm8Z4LCgb7bZdGBl2lIxGiJyKX4SkOgS7Fx2aiq8UycfyY/+r/vPuRz7TdjQnHnuIjP2d+7jikqw8NibtOFJjgHHfIrjCw5tOwieMzE7El+Owl4cT9UcaIezusPiTWolt7fz/cqRyjXGENgRxdpq+KydAdI+8MFCZbktoDsiZ7gcYS2Gf7Oh9eg4K+6JrzvJZnOL+7Jz2wNaJpx9lRNvu/HBE39YPkGv0URFZEV8XsYOtf7vx4NnItl94v9S5PyNrNNYrWj+0wa5jKMtbH1RfqLZTexVlJ/PbI62ZsnZ7D0Kp7aQhrNw3hXWFaJC3+bJlWFZvo8OysE2ssmG34Cuj2vEcqTZ5alCwzS2mRRyy1eENLPsZJ7tTb/WdBuZpzs9oyeds4UTYL7vZz/gdRYQsjmXw+wObT/2KHJLKrx4EoHCFzO8R01VfKfJ9FO954vp7k+fZmuhmfAsEm+vcxr5vGyQSiUQikUgkEolE4ttDEtwTiUQikUgkEgmCkyADkeN2XGB0/P1iWIeGd1TwBeGdNu4FZiP3e3oPpnqnkHllr+TFtOV0c5I3Wv9IEHh3Gr2SXwo/FZ7KI+bu2ogR78e9icy2FJz/cuExQgS7v2N02s9Rdhkyi6q5LnC9021lqrpcZb0xEgjLU0/iVCmH63Pak97iw4Wb2Bw5vmotG9x1hNzmdU0kdO5xf1gT2uERJcTZcqqM4i8xEpqyebrvEE3tMEc51s7+T+WvZfYHnjy83tmDUMOZTd8CabY8cxfIvbJy2Unkns0RwgZzLx6vS3HSlLylbIXPT8piaVfmwCPTscaJ8SnnbeUrb0QnGzvShZMT2e29hyl9vT3yo6kBmzzINq71vA4QtW093Lk1vbRmyWHFbw9W3mI7FxRp0JdbxVh4BWodYffGZ6ifRyi7Ok/U2oOfmf9nZXANefbo1J2ftlBrWr/22omte1Hs9g4dyp+oPRBbD7H9d+sUW7u9fQHqVnnUeME2rqWMF4mYoaxeNj0K3CPttq+eLiajFUiEvJNcMRiac89mmrJs1lLfEHNvs3Fe+ifSAZ7cK2CDvcBntUipScs2OWyyM9gtmJeRTa6dI77QXtHvFsIgzntHqldEc+8F/90v1LHvZqz8/n2A/f7HflfCvu9QxHJmM6uDR2LH76HYdzbMhuj3Q18KX8YWouMVP7Erd3Fj1lryGhKJRCKRSCQSiUTi14Z8EEwkEolEIpFIJAgmik49/k1hcpuzvs5ICqAxNsQvDM8ECJ+hIklytQhk7spjMBbzsvzCAKrHBoHxFDQkznsBZnW6/C7wq+y2p+up4HOoP6vJGyEi7Jg4EX2MOcT0ERJGPQ327dzd89hLyGaLEFAU2SIyRXZt22bOWtux3wQRRTXzYuIb+cxJHzC+tmSzwHCMkM1sU4x7E6lG262GKZLSPL4Tk6uAK9lkM7EH70Wm40KIK7ov7KnbijBo/3p198iODLs2xf6NLL9eXzNdi80XiaOjf2qdPnv2KBlYZrisTp4Knuit5Kq0nbRIm26xaVdvuWDt84r76n1s59+r7hDHDe2H1rZ6XnbLwfEbymXayZazOzhvTKo7rbVSnF9TmPywlU90qZPzQ+24+cUB5IUS5VS3LU9/6YDktTo8H6+2NFhv3GZc3cZ5a7e3TqCN/TPa6dmxW193PFi1hjPZNi+zG/OxPYEtG9n2Mvl2fUf5kwyzr6qsgsS2V1AL7EvJ/Z7O2nn0l9nSN7WRYXvZvvaR7C5MAzRMI/IXVK53GVyYiW3wMJ995vCAEwc3c+g0lg5oc35lj9WFg5lMguU5Em1gbTSSjEDPGdg6RrDb+KDuJX0/U6bn/032Z78rsHl6PiSVq+8X2Av+mCcC9aK+9wt9jJSviOpo0+7AhC+FaBshOf+9T3Kf8OqG9Y1NbaX95m0lJhKJRCKRSCQSiUTiW0cS3BOJRCKRSCQSiQmbMPZ7xZGcGFqtitzyTrZ8Q/BOAo+Wv3ofg7S7U86iNpw/RR6zEQPQjGBu81g7dwHmdZRz4r693gWJo+nDgAvjd38iffFZRT1dK4gY4bOZbB5GBFF2eEQbZDUpdhWzVX1G5g+Ty8oq9pUi2ogi1PwI2837jPeMIhmPVzLaertzdWzXOtwuXr6sTbXrSttVWEYNxR1RzrOVEtqOz0gy2003e09NdzX0kKdUylpPlV9NlS7Dm34eLww5VJFp6N1HvZFxZOUtbUDWFm9aR9wvtvm9n55O8kXkXV/J+7q7psp6BUj4jKjcDOHZznNa/An5Mmsgz1X3WEuwHSJ6xIsTz6IeL4xWTLsiw1zTPdWGlN4eBRdZDJN8Qkj3XiyIQPkkun5AX7AT9nEpti8QqbUH7WZryg5Ynn1m24SlPdF+yKNk2L94n6Whr398qDL/DsNv9D5qfGvYr3FdxP6xNmLeSspG7VV9g3ms3Ta9VbhXtbtTexW1Lss1lcj31mME3dc4myumu6EAsWmibXsYSdvJbjaIA+Y+mSWCjN1kYGWUjt1mtZa1ExvLSGSgc/CcQe8f9aVIZCNyJU9gwzKeQ6lDMWlMx84GK7+UMpGZj35TL9x73xsw+/HEdVseZXnfM+xwlby+Kxexg5V99aCFyPc/V4nnUZuwHu9Kwken9VYbwTfAY2y+Z+UTiUQikUgkEolEIvEtIgnuiUQikUgkEonEBBYrMZHL1qOKTRd5p3CL5AB9pfDOlzg16q0Ddx6Jm5HJvYAoC9Diz23L4KMkhKyncbFT3Xf2Ty8GQKAc8zRTlp3cpuqLaW5PHQwUDM5fQStNB1cV4QKvPZ0ReyyTxhI6GLlhxyJSfgPJIsolMSKIhS2vmF0mb8W0QvJ5dhP70MRWVtcZ8iIsk+equTlzNkV0qetlz6/4QzZ/sx9AP2s6NRV2hDdFfmPdy+xWPBwc4h73iQ1xr42wrtgFOAVQB+pHHaycbR/WBpiPtR/qVu5kJsZxCQtnC8i+V93QW6yQXp8gb60U3TY77MYHpu3cNcuLhOOoy2+E8Kyu5fLV+zxgw5Vtox0rTA4bP1d/CcDDFQL6Tmszp8hfsbW3ecQSJKWjXc9wICNbllda3PUlPc/mlH7Pj3h+C+cka6tK7qttSnQOWxmeX1BLNY4JrL9a45gNrZRprLzSl3Yd3fnP6Lj29gn2PvPlbM1nbe7NEeVvLVh7L/3a/DxqDO/0s3pM7W4KyLZWmzRTsJrr5a+tW18KjCGTaG9jxezalVUDFiduNck48Ngkt5/pggvXqJtNcLYZw7qwScI2Pigr4nx2i4HnACp+DKxIQhYjKo/n7ubL351Oru7hdxzs5HOrA1+m9+pgy+DL98oua4+XD3UxQnz0Jf9nCPq7738iZX6RIP46kUgkEolEIpFIJBKJr4kkuCcSiUQikUgkEh76cXWDrUDoChjzu8pWYzImG454qwq6Pss2exGvBu/egyDvBURVHnZiu01XP4mN8NpjCfJOl5q8ruyP2DGRyYVM78etMbhtZdvyZ94NdkF+mFY0mD2RVITGK+SPrjeST+lSpA8mkzGxkA3FSCKlLO2z5PVs9wgjx+fGbGdgBBMsd4EhOAhA9MbGBla0QnrbEJp2upx7rIr23qKXu4DxmZVRQwavFfdHAYeELce6qjoELaaX2c1sUFyqqWyb071lkNVL5UV9/R4b2qy/8N6kW5B2l2nrnCSt3MluuiD36wqXbCeP5VNto3R2MHnMnaAub55EdLDTu6/uRjy5UxItvK5eEf13OLH72R0Ym3fShtbkrwMw0D4Fgrw35j0dO16kh50fulLeG2tRu7y2j4yFaPuz+a3mXWTdwLxXoNYttm6ONFDktZPn+9Hnv/L04a4Ffa5UvT1kn739AHnqlPNXrel2m2nzK92tcb3MHlz/2H4gsq20/v3S+FL7SiFkSq6mfofxk7uLDhTSiKE64MbN29yUojtNPR+ofXe0gdlGztvosk5XuiL7bhy0VxY+NSFUXUrx+zsyMDf3lxPfjzQkfauT2Vn+2UR++jrLhzax70YUgV2dEm9ttXLxGn91TtnP7ML2UFCkfJZvd/1rRKMPsTbDl7JE6fx1908ikUgkEolEIpFI/FqRBPdEIpFIJBKJRMIDMuy+SkTn+0CEfP6srCsyd4HjnV7vxLMoWHDWI7TjNQtOs2Ay5lGfI3Z4siJ9u60fEBfUz5VT2yhDB+4x9pbHhoowczG/R/TwyB6KlcSuGQPIY7B5jFEv/w7ISPJIIwhyv+I91iakzhMRrs6m9Q+S0EbIO5PL9xhp60fXXNSjymA2RpKLLEVRAlyUrIndvBDeHXkeJ2mSScq340Z0qrKpYYdpv4ltXSFN8Z4mWcLmHbzprtIi3DeWpjhvO71LuwWx44v19np29f8W+DZsfrL+Ya7xccNbX+M2PDP2vLKqr6Pj7i2hxtEljqEh1keWP+Xur/p5Nce8JdvLy/JFl1vVTztbPFj9zEdUkc8Dq08zN2yavWZ+e+ff1DbN3ldr8M7fKr3DvsbXD1l/YSeDt12hewhPHt+Wr9dkT+Rum8iAYHuNSxCVaNW4WpEHx88qZL1254snjE266IYMYQcNdqiSjfapzQ8u0moRt7rZRFL6dg6LTYhdOykHdHUweQsPwqRFv8/wCNQ7crX3nQP7HiP6PUk0X+RU9Ksv/2MZlLM72f3qdxW7fNvvGt4AX5U4H5kT3c8deXdrhCfjffGldvyJRCKRSCQSiUQikfiWkAT3RCKRSCQSiUTCoJVyK7V9OK6P6LgTkVfxFXOK3yvGLHhreV8QbxksZKeLPwsMKmNgFU8qa0fHP/vz1uxk8l2QVgV7UVYEqo72njq5ngib8uxOsa+l+oQBQOQE/qexI1tEGFkeU8qTg2wtRqpAMgwSbRQjymMKgY3V2rtj+UFaLeX8QQvU27sZmWiKlGMvKzQhI8jYe8TeXXN6mOxgOo1Mhcg9JXqx02PrbXQyzg+K7ie1Kpm74XzFqys9jL+kpgXLg0PQ5ULVOW03zcQOgOpF2yLXrO7dFpwyyDu7AtY2uzEoxwzkYe0vpiaVxdKYbRF+3Ctw+7GurWH7bh5jr61RjfxDHdO4NfrUshBB7zc8cX035pit030k9Ne+/+Cyus4rwHk8/tY6pWEZz24mj41JO94xD157241Krq2dTKaVy3yZ0uf5fA/og3ZrHfqEjl074FbB6vLWEbwvthtLuZ0vslD9OPI1rruZxKv9YuXYD8s21FnPmV61xu7GQWOFhSzvfkjPO8Bb0+UAr+eeSQq0ZXcT1zNqt1iyQRuZYN592hiB8mrCevrUYuZNUvaZLXLP1J1B2UjSXnkuvXrK+GxCm+57vwhn/9p0RQT3XjKPEvXRNpRhT3SP/loeylYnte++W7mCtySlvxdxPoSI0zX3aw3Y6i6Gb4z+/PZe8hOJRCKRSCQSiUQi8c0jCe6JRCKRSCQSiYRFa7fSysdSehwF2HAYtaGsGRLtuco0MrJHnP3VgM53FhC6cmKaF5z0fsYb5ZxleNDWK+PpiPyMuPpsg7h4itsuUK1OhFc/G77UuZ1kOK89pjQxFzD4vdj5FmyZUtb5qViUsry47p894oeVvzCT4FqyGctKovHsdJhUbccUY7IO2xYOTuVFdIKGzMqIP4OVWWTfNJKGchQBUmXyCH7OAc0hLgBrV9tX1aT3/IoTtcuj1hXFn9oRJ4npVPZ03co42dYj6Nk2t1OkX3ukUJsW4T8xoh+bunY6srx4zXSwe4oPxvq034/W7wK/heqx6VhOkT/RHVWRf+fGr1KD1JSPyJnytLamFT5WOqFbtYUHHFeqLaZ+EA6HjWEL1U9MnvJRdu5NY97bsJr28fR4dd8t26MenjN2dNh7nl9lnz25Xrqau5H+Q1vV+sTmwM6HsK2E8hHe3Gd2oQ9g/gDTzTaEwo5J5ruUP8M8OBa9NXay29muqnnNtjBo66TzELLUo/I+YDaovlLjvmC6clCH0YttjWZ7fr3yCrJOD8iZ6hbBlQmL5SIDsedl9WCDycpkiy3ul71BTSZuYx3L8mM92ICLtjGWuVqOte2VPrKfaTZ/BE/35X67rXnNvd2L7YqkvjsBnX3Ge+pAAbSDfefgvYSPBwjsbLF6UMb2e4eAbC/PVVL6Wx688HVx82vuLcQsbyQtLMpZaBOJRCKRSCQSiUQi8d0iCe6JRCKRSCQSiQSi2ogcEGQiDI9SC2UNesyBUJDHIwxFyv86oYKfLFB75ae0+2cb+FWBWu/nxpXN/W8kgM2Cz7ufDvfI7x5Z3ZLqW2kTGa7W3gZzENr7uXGiYOiYbN6N8YU8QwrU8b+ZlIEEkSNb804vY8wm6ROIjUg+wfv4eUfUiTD1PEJKxB4GZJ15pB3Pnl29GKnmuK4or197hBqwbRvEv3LL64t2/pm6wSEa0WoZEhmr/iJHcGz6LUVCY9hxqqbP5oPkCh0C7fSs861FvuJNeeaz6WlldLmKs8fg1t0pi/Yr7gf+w/bAscHqaMvoPlhrrbY7TI/6jO6AtS1zN3jN2mjq+8pXVOYGPPtYHgbG61F9gnl244MtR1e2eGos4WdsA7UUsr+7tlKke7TBG/doh1cGy+/mVSnrPPLGihqDdn7R5axe80/M3/V7qvx75GFjeOtDTJpqx902xes7ZpOau54OZZfS640JlUfZjnMNr9EmvPbAfPRSrnGfJ7bAcYDxdjkZ/sJzjDYZBn9TA8oqwAmqFnHYi9AtPshaRAX2dyOft+c29yeRkQXgyNPsr8WxibvbY6sNA7tXSpHPZLuFijmgnSNni0zUMewQaQtZlLyATdLxvtIbIWfbNPV8zl7m9z6rX4dTeZQMTPe+q0A7sUz0ZYGr36nsZONhAR4i5PNXT2n/qqe8T2jux0vwNv8B1ev99po9iUQikUgkEolEIpH4RSIJ7olEIpFIJBKJhEEb/+s4IsStPCL29Yiu7lgqu/QrTKpSSmnND/KrYP6XwjvqeiVo+Uw5L3AdPTnM3ldydyetYzkWfGUE+MjJ8hhMxpPUmB4vmL7e61yEfRmvfkNYEBPZHgsaBpE9gX76OwkrpcojzovPiOv3C8ljCSQeWQOJMGDbkt7lWpYY2sHkK1lKhiWZWJ1Khq3DjgVmy5A2q0LG4rLZdePJ0t6rYCQrLy/YhOQkSwhjPCImzhSZb4JsaR62EWS8wk2yqtlUZNdKBhtm2NRs6CCBEOvA9KOMK1MXoXRieZy2jKemZLOxgTyw0LDenNqN7azaqddB6VRtgPpYfts2WFfvpG41xjxb7LjZ2Yj3PDcQdZeYPzJPvDS0LboFxTbw5pgnp9S62IjLiYcr4yQCnHs7GbWsfaF8xGQjEUrnZa1TGi7jBdILuWfTdn6O+VNvS6Pa3/NXamuBf5UPYePO2uttP1COhepvtBftUPPQ81FMltJv11zPN1kbqaxWJu7fZDNUQK0Ri86dQycNI7Zfe5lMgE5aJqfMQ/Q26JBKOmpZWpqwRTkH5djNPdrW2LZkAzR+KUPpUYOc6cCB6zl2b2HynA3DZhMmn2WJo6EvVqk22OTbEaKfOSGcfW9gn4kVcVsRsJWN3svuKo96Cd5e74j9WBcmF+vKvo/Ywcpn9mL9IvLeI+8vG8eerT2ui/ljslxHZD6qhcmqrcX/paBEIpFIJBKJRCKRSHyXSIJ7IpFIJBKJRCKxQy1lPt20luVk95Gv6Gh4JCbm5mnXgklvwQJ6RdcbwSN/vzeeCWRGTlFn5G4lo+dDIjgLWjN5keD2zn60RcqZGVu83IiTVqpvISiILlAn5S3phgQxtc9uODFSiSJiKGaYx7zCz4r11NOQ7Wb1Wf3IEkMZaB+WQygZ2B54zcgySu6OJGM4PEs8W/UjEozUMEWbr8Brt+P+Yq4zFqpJa3DfJVNxcQsGgY7oHBwG0QZsmOy6sLSDQAb6Glyroc+mDxtKzFaUbUxiZi7D3LMXbUK9DKzcbsorl9PgPk77nY2oE/tVcUuYC7LXONWtG2DyUJ+9xv5T2xnVx55MBWZ7JC/qxnoz4BjbjZtIutfvni7PxXty2DXKGGmtzW1mHCFbSrzPCDb2WTlv3tgyER3MD+6WUJzTU7nWpjSmP7ob9eaMku3pUFsKZRubA+ijIjZdybebt7v1y5bF8e+1CcpCe5rJjO1I591un+LYMfoHZKj5HFrDTOHaynriuXCEbv95jrvAHmnnjMjgo3unoFObsqlKmP2odH5qMWGdwJwK2xh5CzNeRya/naTe5PQcw84RqsXYltlMsDo1+GqzfWH5le8JPOJ5pGwpJUS4vXrSurXN/noaI8arF/EjtquX9r02YS+t7054f8a2Z3C17C6/Iut/t5h81vP9IOWqz9FN+K+pLxKJRCKRSCQSiUQiMZAE90QikUgkEolEwqCWegYod+wDFfSpFZJJEEYFk987mPMLjgddDVa+ZSCSkbER6pR3zMNk7wLSEf2709SYvf0vBql3P9XtBaZn/WfaQlIQ9kRBT2hn6YwogXZ4DD1kf0VIHCpNMYp6fu8+5tnp9+zycEWOy2I6gAQWRnjZkWRsdhv8bmVvh2JvelA2OXaNfBCUb2DftIwAA3CIRnZnL7exnd7ejSmR1NpMNPN4U4qjxEhdC9eprWVtk0W7GcsrW1Veln/XdHjtTTckQLJhXsl9zMOAPBDGC2E6WV28NO/ezp2yzx5/xXMJvS6qjVh7MDswf618hWXjW7khBubylB3sPluKvPKs7C5d9clb7aKWMdSaXGbZXwts7wr/MC8D86feOGFzwOpWn9FOlc76Q9njzeMC9+w1G6eq35Xdnp5IHttPTPeW0+bo9LZBXba1Y+cPntk+SYGHMOyLKyLYtcxbfR+p4PqxCvcuDpBhj5N/Wf/q9GfWX80exTF8Sfb2+3a/pZzKToFyQmxfqRZOb4JgmmeXN3DYRkuVZbJRrjfAnpo4jizTNviLaNdEzfkj3xuol7NLKfwEeUf+zm5GELfP64wYb0nwSt6rp5CrdmK/yOYR8F/Rv5P1yndA6uX+7/70dlI9b618C/kUwa7bzbdEIpFIJBKJRCKRSHx/SIJ7IpFIJBKJRCKhgMHfKZB+JCjWErIjrjBvIM+IZy9H532b+FZOuHqr09etrKjM6ElfjNweyYOnuLOytpz3U+ERvbsT5/Sp7/s2UHar0+Q8m708bn5F5tix/Xafu+yun+nxSCWMVcfINIyIg2UUC4+x7PC+143M11lCD9qIeRDKp7I8AaKSylc9+VhGkZDYZ7zXSVgREtAOURmkDUeTV56VkcAoWRDk7YiC7HpKq35fRDh06j42A1PBmtQSHHfy2LSrcF/ZeYUfyOQ8S5C8khenLNbJJUSash4fj3HrdnZ5YDZ5MsccMGSZiHvqnxkvkc0rNSY82PGkytl7u22nlcvS6Jwn+VW+aP2i45otU2qus37HZa3n9ZZUTNuNnasufbd8BR8NQu18xW+ytrPptr7o/3COR+aP2rJ47aPsR904/3BssvtMNh1rpJM826iwxvN5c1zpUvda4bbu+qivx9VmVgY5gxXLu2Mb5DVjw/LOOOazelRjVnKpHI03eCObCiubOfBWYifhe5sadBZe/QN9teDKBsPJt31Oe6FsK22s2buXso9MrlxFmt692B7N65s2v2Su5Kpn2itEb/V9hvd9AiuPtu5+Le4tyeGRdv+Sp78rfCvfh4WxmFvlj1K6C1FYvsjzdkMlkUgkEolEIpFIJBLfGZLgnkgkEolEIpFIWFA2mom0INNj+Tlqy1og5fCaBaDhflsyvzNeDCz9Uk+4ipDNMb+CIox7+Sr8x/JgfvXz33h62o4sbvMhsX1XDybfC8arNPUz5+EA8ZbbwOUMexrpN2RFoZ4dy4wxiXbTI0qgUew4pQeJMF5+S57xGLpIqhHyFqIXQpG/FJMWbRB2TKranM/tBsWyZPlQNuos5SQIOONlWUqEKvy81JFlLvtht8tclwuex9o1xAjlE0/CI3OVpfu8rBOf7CrnwiOt2nuKJOhNWZSDZbypv+hpmhCK03fH3fPcm1cXbPMdQZXpQ3nMFaANERKo0qvcjy2v5DA7nB0g1RGV68ny5LF+iMCbW0qv7Rs1J1SbYtvtXCmTYdOs/Ww8s/lUK+9DZZuCN16iY04taczvsS2JmqtqjqKNDJ4P8rYfyp8we3f+aDcu2bhTba6w88WLLkcBXf+8jF4+sQ7XUjTpEMV7jbHZX9L+Jp1TxSBpRscw46JTa22WI7LNStUAq2AX6hULF9q96GeOz3Mildhg87AFabcfZY4WNyus7BhQvvzWOzGCai+vzEQUMwmi9/G5N0KmVmR4/DUzD/Z5+RXsvkcIEfeNHO85X7UVEvt3z97e6enR9n/mnodv9Xunb9WuELw3ubpfebZ6av2KbCKsL35t+iUSiUQikUgkEolE4heIJLgnEolEIpFIJBKIWuYT4yoEWaeACgZ/qglG1zMAxNgrzzCtrgSTdnkZAeAXHItjiAZLvSDylVPP2X0VMPeCyIq47un2SOksnQW7dz/LzU5uq6WWWs/yluzutZ1qH30a/EhcAv9esN3NU1d925PePSDDaiLFELJGNDjLWGgLW4/ksWnWJofURHUzIo6V5fmQZpKQBVc36cVJRxuxDqjX87doA5OLZigfbcWifKe/23JhRDQgtBmCVFsyK2Oc24aExu4z/pPiQ1HeAxC6vGFf4YPHc1BADgaVLfR6PC+cZt7wxXsef2O3HaDpdbZVyUX7UB9r0x33z3MhaEeDf94WZ2eTx4lhdrJ8yl4LNRaY7arv0e0yHVe2X3ZORXhFOPaVHrxm/3Aby8YYW3ownelS2I0z1GPt9OZa/4zL1yDSboAyPX+w6CC24TXTheO7kns4zrzxwtpJybFlvL7ENo34N2ZbpP8YlC9kbaLkev7BWx9Yu22W+0WGtY/uH4zcBvdYPZa6mMSI72AfcG3uf9tuka3EbuWwlSzTwFh/6qDYQgz1cRddbC8jr2FelOulqUGj8jLndWVieLq73ibSpqLVrw+x7xK5N1AX+qK2KEefZZe3QuZ8u+ff/rnnjb7krk5MV/CexZlNaBfKUC+Ss/a0vw53hfCPdlgbWBu+B8n9LRB5qf/Xg8d3O6XCmsQ2PfZabdzYJmRVuU+za18y3BOJRCKRSCQSiUTiV4ckuCcSiUQikUgkEhat1NLKbYmoNHNhmTA2sq8YICz+gsySSQfK6YHLtspnZaNQrJhfaLzolZ+o9gjlr57AtTvdnJ207tkW+alyjwAftZPJwdPdx+fGA+ysXdd+Wgn0bhs1HhyPEPuXk/GhSZAAYG7IdqXzHAO8ikmliCBX5iDzJcwOtEcRU5AcpBhiO3n2HuZTLDGEFwC39UJyjiJPqaD7RcKQJVhVo3uowT4JyqVNwMorAsFiJElaxjzoIvo8VQ2uFW+hlFNuVB7jY+3Ke/KsTLwflcmGv5W7G05s+Nv8WM/dtML2x88o1ytn8yvdzEWgbusmItuinc2of+deMb/Nw8orN6PcndKJeT07vT7HdvTweLmM1wddJKbt2oBh16/Szov57OdIe7B73hha9BGf580nlGPz4DLnccE8eOXsX+zT6NyIws6DoQjA2squBzjesY3UUuktdZEx5Y1xb7yoOaV0XF1HUG8vO/QKocyXL0KYgVigmb1LoIzqh+2Y9hZc1SHC6VYspxZSvIdCWHk2EK9MUvzs1QWvWRml54qj9tKxjpGJhtcbvdHTx7mYhglDZvhZ37F1R05npGz5fAh5UL569lXP7UyG1e29FK6+F7DYnczulfVeXmffXezysjZ59TuXV/DMdyffLN7A7Oa9+af8FfOdbHFnmyQmj+ksj/Xrfm8/OLkTiUQikUgkEolEIvEdIgnuiUQikUgkEonEhHYrtXxolqFoT/1ClsZUFCLvtclA/TYoPt2r5y0M6HvkgWcZga+U+Ypy3yoI+awc76QzFYC+Kt8GjCOnikV+/lwR0fs1s90G+bE8BuKt7Sj32ZPhVHDcg3eCPUtjRAY3qB9lWTm20eB+lGRzlcmGvoTpQmYa5omQY5g+pd+mK+anIiWhLI80tPPHTnqEN0Xl1U0XsUC//czSWfs49pVOamM3j3943+O+sc9h79ZiXKm3Xi5ofcwUVsPH42YouT0fG964VLPhrdrnmXZBvp3VfQXM1iv8t51cz6V47dHvX+EBWqKtJ9d+UPJrWeUxF8TGTTP3kHOqxtnoh/ECpAb2j3IBeO2loU1qK6o+KzuwPRR2S4aam6x/FsnHSwNooze2VH9F8jPb1Bxv8A9lMOx8kx1zng8a7WYSo/1q8+/8V1+rsByTxez05Ea2Sjj/lAFLPwdsZjLQ73l7rq1PhITqTAQqixnE1mqy7aX19Sai/YvOUdX9SuehPuZoC0nzJuHVhddzjMxOtNXT20qRz5Nq01GLbusQyCB3yoef0Wwf2HKmOEs71z+ih87Ztr1GIvmV59VdHiTBey+B05fJwV5GjMdrlOl9B3HpF82CULawe4k3xLObcYKll5hv9QruNgVemiO7tfbBkZxIJBKJRCKRSCQSie8QSXBPJBKJRCKRSCQAjQVWanvcqA/yiwx6twoMpU3wzua1Af0dA0SxHFQQiQW7+7XHfnkPvJfcbwAYkO7XUVz9yfOdLhY8xuAyO3UNg+HqlLXoKXJIhJ//ctlo89X2fKvAOdOL7e/pumLHqOcu4HsWOO9tmU8mDyMaIXOO+TjlLyKMNrRBMeqUDNTDmIpWlgqsKxbkLkgv7FQcpUnuLs8xDZAgJ5UxWxlzr62XURUvTZ+rZU1+b9hGbzAZblpdh4TlwqEqb6hYuZE8Ht6K+rNzHf0zGz67OngcQLyP2xDLaYuMz8jYVbwY4M/J+1KXdcuHIr3tqkv9ej7mepX9eE+NGXR7Sh/2hecaS1n7BPvRc+3Kvav5rZY8HEu4BKBupt/DatvjV2LYUoKyFbx+8sZg/8z6qJVzfVD9i2V28r3lnuW3utXn6D1rG12S63qvkPy9kKon8znKH7L7aA9crkIYPMek5DiNx/pPmdG6rN3kZmYppxNZmEwH2HV2mZjenkbJtPLQHm9QqUUeZUQ+I5SuiAzWLyDPPY17s/ejwDbY7eHHNcn44kZlekk40u4m7erztXqJWf0yGjvJHW1XJ66r5298WZ3JU8/MV+v9Fi+So6y3Ir4nvnU8Ftb+K0ET0OeoIeZtuFVZ3GSRzdy4VWsOxEQikUgkEolEIpH4lSEJ7olEIpFIJBKJBMANBUYYJuVIs7//vmMyOQwOGzKd7ivSRDQQz/Tu4Ml+6zDTLyxs5f3ceDQY7BG7d/oUPNI7nkyn9HlEeXWyOiMGIAFAnQ6vAug93Q3YH3PnSlC/6z91tpHCVei6X9e1zfw291hzRILSHq7OUUukYUQgRliy5Czm4zwiEZOnPl8hnXnyhJxq70f6hti3nL7u2axIchvC0GKTsTdMZmTrIlnzoqaw9Foe7RHhdimyK5Up9Nv7UX5f/0uJg0UPdyYHCZ07sGmGQ5iRPxlweKtpgPrUsLrCHVRbI/yn6hkB1m/rVus5F9XqvKSQrWMx19gXdsyyPvM4iaxvUY+q525o0fHY06Ew67tG/u10K9eP9VJymS2s/FWobbiS680bJnsnj+lkn6/q9dqilbK8iOVx2Pq4YHK9JZXJk2O3XlibRLo39qRNVxYCJtRURM2rZ+RPssx9ukazTmBOiiV5nWYmZVMD0tpRymoLTrDdYs8WBKvDc5pKJtqMzshbvHueyD5MOexxuTF8Z4fKd8E5vA2peZVR6c8KvQ0iNqsXtZks9utk3jP27lnvyjPkVbK61R+RrfLgdxns1PmrNiW+YYzuqeM8j0trnsp3ZSPCNsGTPzyS3891JBKJRCKRSCQSiUTiG0US3BOJRCKRSCQSCYoKQWYTOWfH7Fq2XTMR7V7WC/awNBKMp4FExp65ytbxWFK7z0g+eEt8hcDVM8Ha94Q65c07LR2D4B5JW/20OQtgs5PrmCxlhy1j77HT71Q92Ul7i+2tTWOVBfd3n/skUnVH+4addIpyGTvZYUSHbIRBFpVvfQzzQVfsYEQmZReSgPAf+j4mwyMCYUDdY715hC1yvZC8mF2KvNWXHpJG82O77HCRHTiSpnnmlIO+WUR6pLUyDzXkSGw5Zi3QBG2W52S7DNq0SBoJ6BjDY0PSU0ORDQeP67abymr679yB2lZ425DdFkXlYbZcmdL2H5Nj21NNN8MVWvJbvbvtFtqPfVXLXiaDzYvtyOrPbBt563mf9asabzv7lL07F83GqJpzrL1UOTXuVB7Uw3Qwt277tprMVm/3CWp8e+Na2bHzQfbFIjV/K3zw/B3WXc0FtsRjnqH7EOz5F7x3dTy+RK4Tlbm8xkQddTF7ENbAnmIrw35WutWiENkzoV3efXsP66YWhN0Cv1uUvcmxk9NtYPvUZzYXXV50UUXdxOl7ZGjvOScOUnhT91eekZ59zpoI7LVOadYu9ezMnsPZae+KMK9+8WzXP0jWZ8/hV19iV/IT3xmY36h1vb/bJOzkow5WztvQPu8OEolEIpFIJBKJRCLxHSAJ7olEIpFIJBKJBMMIBB8XrZQHi+SIrEwBlvZgDnjBexVYV0SDztAwZPp6qyTPG8ALxO8+R1lK3wgiJOq31rULCu8CxnPAukyBb4Urp7XtCOaR0+eQhM/KRYjeETK9qg+7ZjrUyfHK7u2J8VbHcA8zIQFtwBPuZf0qvzelNZJ2lN0YvMignxkLDIPNTuD50pzyfApjANpySg5Tz/wzkra6j1VBfUba8trRyvf6ppMVrX4vsI+kLkYUYNeeHASS8HbEM6fLlyKHXiREMnHuSCI3l2FhlvAlY+PLagP7IqOZ8kQce717/f7oWjJvMQmHzQ7IJUETdlwUm74bqkqmSvNswOkZqbfqE+z7PsbD/b26ZKprV0fmyrBOqs5jy0rkoBuzYyrav5gn0ofP8p1wHHrzD+uE8tmYwOXE0690qz7FspN8GCeqX9k8Ylv/7hO8OWntwuVi59emuh2Fld1MrzdGWJ9hGTae5Jhq4CdroIyx40q7MCxthcJkZl+RWjNZ+WXrQwZtNddUEd3HOTa2sh8Uu4HAZOBA3+07lG0qvcI/tC3qtBv8VffRJk8nTnZvkqh0qPt4+XfyQcdLwabcpdPil1srCTt6grm6552QHpW3qxOzd5QR6nbPtP3ae+kc24s9E0YJ6dR2ktd7pt0R4r3nZybrKq6USbL9i0B/TZpzuKSdv2QFUYfnT3Ez760ftZsTMSSRSCQSiUQikUgkEt8bkuCeSCQSiUQikUgYjLhKux8JEJ1hbJtaD1ZRZxgQtonHHsHA/ggCdbmkDAaPFCOmwH12T5EIPLt/odiShd9J19UgPgsg92BeNPAdJmWbcjuy95UT4bpMexodnkzH8qgAOsuDpHjPDmWnOknPQ6uz/R7BwepHPao9TUEug/iF5XTF3bBuB+HlFMAxsaXeAUgAYj42Gvje5bX5dmWu1Fn5zCgpCe4Ngp4iIKCvV7ZeINEt64oiuTmJVWWCujW8V/1mU+KmoUK4SM1m7rojxDCCLV+PtBlblhm5cGkyEC6Hss+/kphoIc3fOqh0W8blq7TzMytv3YsaOt50ZfkxH35WXa22bWzqWdsV0K0gv0fa2DS/EtOXOrXVZrQHdfe8u3aJ1pXp88qzelibsJ28JW73YoJtO5SNY3bIJDLU1h37qsD9qJ/BPvaWxS2cjMrv0qWrPvynrT/rCzuGA9uQZZ54YwgTpzYnj16l+PVCke7yYHzldG1lsDV5NxlZWjNte8HBL21YSZ1w8LLJzwYYDkY1KZvIqwav2iftHJRyMGwg4WBktqi9pE3D/bD6izaydLYIMvsKpKOd9p5oqy3xu5k8uw2YgwhBOvIMe5Xw3fOEnt+MTHzmVDLU8/wV8rnNHyXpR15oVzaqZ9Mo2R9fYN++kO3YE8WVMlfyJhmegDUJ8UF2zZN+TG1IvM2aJ1f5OJO/lfbar6gkEolEIpFIJBKJROIXiSS4JxKJRCKRSCQSDNVsle0Rrj2a0trJOhintzOGXVvJDfhZBazb/FEGj5A4oNhmETYWY+h4RAQP12Ob3yVeDfLiad9XZXgB+KhMPAGdkQCsvgi5f0cMV6epqzrtT6Rb7Yu88EDltvn+TveV4LrSvxDY50zUtkLa2OYP2WUJS4t8kEnETXargLryOUqXIhF5iLDcqnN/R556Bh4hANNsuyBLc1eeELg6YY+29W6tEG25nOyO7SRIEJMqs7SyPIqLVs0He60VcTTWt4RYt9jotPsyPcV4dc3bEUTEx8n8HZFko+aKaSOtrtsIq3anb+cKuizkU+I9ZmuDPFNTgLu1Y4zZXqGSqi+tjXKa2TlFbGauZ8cz2kH1Ya832o1lIi6Qtf2u/E6HbcNWHv2w2+YuY6pBu1XezmqMoewGn6N1QVnuPeNbRhso45xHE2aP8zhC0yv5x/cC3BcwROrD7JpuPzER1BxqoFciuJdZ/DIMZPae9GgTYgv6n9nwucyydimnKfeV533a1t0WK0Otj7i/LGUdVEzHziGjLcbmKa/aq7B7u8GLfc/2ZqL/BpgeHEc7J0/adHoOwbFjEuwvUb0C79lidwI4e/m3kvzsOY6dHo+EefZSs3qutfCI9+xZ1bMV63iVtB9t3yvwyPSh5+JvGO91kMEvApFNofWlsGbVCvetXPTTzBcz/27/OrqXMj1rLUluTyQSiUQikUgkEolfKZLgnkgkEolEIpFIMLAg9MQIESwGZJDA7fl4SShjA0UmyMNIV4ud7B7ex/Qow+gV/IpjilcRCSwrwncpOuC8C+xeDZ7v7GI2eYRyJM+jnN2Jd16bzOnaPiXXO/XwrQPmlmDh1kmyrxhm4sSQQ/3b1kAm/vwbKb/zOTaP8m0skK6Yj0wH6mMkJmUfg0dUUtfeZ7SFtS0jOXnkKnI9ifTWCZWmxgOzA9sWyk4fQcbSvG0VNzXR1f5DMGIailN5GKGtkKYS8t0pJMiEtRCiB+wbprYBm5zqXoKo+vTX4yq62GSYpkIjusR4Q3uUe/L4k/1+Q4Fl5f540xxxxR3vuJK7/sVp6sn0OJqs/dj8ZUnMHzW4yXhRnouydrgITACvryLid2U9t0WXMjOPRxN5ftNTWOY2Y3Nhyitu4rKE48QbW9LeYN/gFsmWfUtfI+3yypGJ0Opqt11fljWxmD7GBvX2cyjLylAOcLe/IGq2/RRxWOyemuDosFAG7g+9fXMl/xisLHV/Z3fX56Wj426luM8E3gKDeZRtpZQwadnJtnsZ+9nnVFaeEdWRLM7SvGdA73nbI6R7RPX+XGf/805YjwCJ75GXBvo91UdX+uBXTRj/mnim2ZVP857lyjke5B4OfSHzQ9FnyytrQi3jReQrv26SSCQSiUQikUgkEonvA0lwTyQSiUQikUgkDB5xoFpKuT8S2hFZGUcYQTRnBI6qFeCwgwxLbTAcimZXGTmMALR8toH8Z9k4KD8StGKEiFd0vopvOOj1Xief2SD61XIW7MT4iGxGLGDXNi+S15UOj4TAZPc8EfK7RxTwcIUcP67ree29IMDq9BaEgjcfeyxAHmFUMjkeASpKHFLyLDxiFJZngfwdUUiQzKgOd61w7IsQFnb1s3LY8gbrx9Mj55AzSNie3eS2t4x53InqZXgSrjhGEPTyBLEbbkOkkW0J7/Y9O5QTmQqX0WYdDf4tRhhbnnEdWL7UtSt28KYx20rhNNm5JM+1eTYu6SSj0m+ntLVf6UdX5bVJtA7U/UV8SoVr4hRqKdP7olhkh+iY33FdVV7WVraM2sIzPVbO1u6j0yPEL49ny+pdl4uznLvcmJvKD9D22HQkvR1tWFXumcXGW6RwXXX0jXZiDeo5mv4o6dXdawc7WHEQs72ZGvi4j1B7KIaIw1YOCAfurh1YebZoKMftTo4gvP4lsuTePar34iLvPm84t555Bo3Zgs9Az+1cGMGcPd9GfnlM/aKY91k9l3ovgXuE9Z29r2L3LPpLO8n9F4+dH+2I5FGb2tr/1HGr763lWrdbI2we3D/Yw0PEfm/5nMMukUgkEolEIpFIJH61SIJ7IpFIJBKJRCIxoZpITikn+wKiL8geKib7RHhYIjkr22gXzFFQASHGFEOZOyaZF8BXzB5lh7IhovNZfOXg1478/Ey5CLyfWb9CPFCn0EV02/LsZ+GvkM53xG52Kp0iD3in73kn6Xkn3jG7lZ2tNDoHJnJ/ffxjsobNHqvuApQ9L8l7XFzzYcxnKH9VdZ6l7ZERqMhKmK5sR//nMRWjJACPvcjWFiZLBf+xLht5y7KHSyCocccJaeuJgIe2sbUUxI3yRG8jH9rORiXgWZ6QHRPO+trfcVNcPc+0SZfNgGPSlgMFSt+lad9M/kO/0id14daoOEMgWAfJexFtfqWro67S285tXXfAoN22zv7dDWtvu8byYh95nKZ6ZPCWA2W/zGAyevMbx0G0nydxwu9hm6Ie1v+yni3O54osq9VeBOahJ4+4lOvbBUFo2wnYms76RjnUqGMja3+VH4qum1qPceLAWst8IrURP5u0CjLpuqoGk9ivTDJNuW2z4h6pkWsrKDJx1L6Q3fecE8uHTnPsW2CwNVLmGUQW/mY/zpWvp4H7PetW1Spgeka6WE+PrM307PLjSe09dR0eqxxMizzLMeI6Pouq51b1/BnRa59N1TWzJYpnnv+jbZX4xnBlzu4eCnabWDYElF+lag4hbG1aNpWnvD6jE4lEIpFIJBKJRCLx60IS3BOJRCKRSCQSCQ9LMMcEu5u9aCRIJOhPCznNlG1GHsTVqxcoUqSFnhZhdO0IBSyoH4ktXSEDfAexqldI6u99CtuOyMBOb8d7XvkOlBENyFtiAZPBTn2396wcJAgoeHLxfoSogC8YYJ1YXiSrqJcALCl9ymPIOBEih9sX4laEnBHBIsfWR5F1GvxblT/0R9h4REarbQ7UR1iHVma/L0hiru9UZDNBuKK2KB9r60vIb52EWppZenY6GKLrCpIhdi7BI29F7gss3WvbovI8dHRf1V3XYSxFeOMdZKJxHt+EFbf3JT/UbnEq3HuSC8e4jV6be7xdbwphnitbIu+GamflEuQUwzkqUKt2a569zJ2wa+WKrHnYP25/OONCfW4iUy2+PizmThu42eVO/REZIHvR87wpzpS+4MumNjDltv0vMkSWut28o/edzroyl3sdF39zZKy7dntyWx0uhpOkweeA0GXc2zoyR2KyjjXcJLI1zv0r8qqx6p42b+2sfK+63TcxWVYf6t3JcBcI03g4trAx1T7syqK7u4d6uh1PwDstPFpmu3mQt+cM+PyELx9H7duBPWt5L32r5020BwnnSibmwWdsBbRBPcv1Nou+QODVg/317ExC+zeAq65g91yHDyPEV1J/r2RFntmWOohKje9H27IJfc4jJhKJRCKRSCQSiUTil44kuCcSiUQikUgkEhParZZyOyP7PTh4/L8d7AXFnrIsEhVQXwJAFQI3c/RmxNsxAI8EARZ4ZxGgCAvKplkdrExEbiQmuiML/ELwaoA+etK6F1xXgXqVl11jXq9OO3unU8qBTLAjonvkgy6bnbjnnba3O4lP1QsJESw/3rOf8b4idbAxoPqptfb4iW+QP2SQrnHHmEwORJUdvyPbXMm7ku5Nt4CPom1h/SojmEUC/taGSODfyvN8eE9XPnlHNMAlSsmy9e7dz+pyhaCmyqj1x64f3loiCGoqK+Nm0DzRsbUTFskXkb0rv1l6cJll2emwsmTHZspC5uhSb7sy2jyRaYHTSA0HtT3D+9tuIMYvW5k2y7HbxLHlo356j1rM3rDM039j5pS4m47YjlYPy8e2qcx2mqfN6T3Jm48RF8w/+OWwGNv2K3twO684XX0e0ZdY20ZnYJBMfp7Id5clXCs27a8T1rTwLtm2E0vftUH0GSTqz1EmOpoKn21aZNu1W7uN7skHm3W//1gYtaXAX9A1bFFO0nMOxO5lH8omfoN9oQd0DFYetn/PgzCObJkfTJfa72z61d2v7vZvHiLzvq3Pc95z48M0/gzIFSjTZnm8KLzcW87nEvXMasvi8xDqtTKRWB8l1LPnNPzL7rF8aBOzk+lW+aNzhelW9kVejvZsitxLXETEF+yA/srb/MK60MrDj0zlPN9KN21Pom+glg11IpFIJBKJRCKRSCR+zUiCeyKRSCQSiUQiYdDaeRhgNQEdG67tGeeouGJgtJUBZItB8SlxCQ6xNGMWBvqtSBuYeib2uCvzSjCe2fZKfPQXFgBTp9xF8uI9Fcxm8tiJcJjO8qItHtGb5bWkAXWiX4ScjvVV5AW8r0gH1tYIAd4jSPD664GpSPOWyKFeQmBk9an+xP945IXWNgQNI0+2EyEr4cmGk7xCxrbymzvyVyRtJ9OSyJAQ5vkmvLcjR/XPjDDGCAfsXv+MdWBktEry4/qA7d7mf1NzYpvhOoT2Yl7Slo3opPqUbHsvQoywOhhxo491HAveOPSmO/YR5mN9eAUbYt+Oh+dNhajaHbbNs+y71jwer6aajNEhE+LisHFS16QFlqPTbap8upGii/rxoZWJ3D7laSTNEY7uBYf4Mi6IXm8aWdmYf7HPaZCoO3+m3KSf+Cg1Rqi5pP0bpC9FxPjyxjpLGO2sxsCV/TzJK4tvynlZw/7jytpvdRgF1Fe4hQPpdi2299laLta96THQOoeIwZE1l+0J7P3j7+Jn2D6G7R+YLWoykvmlXsicZOJfT4cCOKGx94wsAmy9dvYzrrzFhza+f4rYQaCeF6+Sk595YdsjoasXeNU1ew5hz5e7ejD5OzmsjP28axv2sjN7iYA/Rz8PVZdLLzA4cJ8hnxgvCYGrzwC7ZxMmH6+JzsUEZy2Ta4wUFrm3blZ3+6lEIpFIJBKJRCKRSHyfSIJ7IpFIJBKJRCJhYZlR018WR5H0nDVtBJ0gHdk+hNDwSG68TCmx4NfVeCYSGVQeZEXtZH0JvB67fUH1deVXgsER4vdbyL6CyOnu3gl7O9kMV0gCTCY9CV20Z4yIcMpQJPUG9xmRXp0Y/woGaeYUepngQsnnmzxvcoqfIg1dAZZXAfn+l5G5mE1XSIJWtkeQUvYyMppafpCQFiF/Mbs8/R5xT5Hh0LaukxEykIjn2WehdNq0q24O12UgCkb4GFNdWVti/0dJdru8gkjJEi/w8C7JZeOz7fIYviFDhXLYDG3KyO2MupXJBjKvpuEOaRQrTye0xaJyapmIu0pPCI1eltKEKFIPnNKY3auP55ImFxSs1xUOVVsuUKkPWqcaG5OTyoi+JuwFmZfcXGT+RSaONwDsfRCzZFdllf7A80orZby9TLPvJiPTF2iT5ZEyIBbzUnIhm1DePsHzE2ytYvlQpioj/P70V+2zou3P9mFqfWXld/DG+eQrleO8jkHwd8bz8owh7Iycwt3zvZRe+T31kjOzUb2YzeR4djFivHrRFu9FCfcKEcK9evbTz7mn/ivPU177dXk73YkvhGeeSSJQC6z1kWytnobDkbnvZfBZzD4P2bKoa+eDd8+NomB1N8CJRCKRSCQSiUQikfhekQT3RCKRSCQSiUQCMAKgI4hTj/Tz/3OBejIn2L2HNJO3zPkjAX5LMmL5VYCIyLmUXgoPTvV0yRQKpEcIM18R701Wfyudr8qM6GTk5egJbpHrLjNqCyOoIwkiarM6BV7l8eSy0+O90+yZfJs2nRK4EOPamudV1NnGtxg7SscubdRHkO/G9c4E5h+V3/KIeUzuLg2JABGgDYpQhmWq+cfsiBAKmK22Dkiq25HYlGxGQmOEPWZzhMTn6bBlWDtb8pxH0DjKNLQB7Vb62T1PRjuzbqHa38v77OeNnoV/Epj/O1LoRLYR2ZgM2vzPuM1NJ7zqial4M8aQu3T67aB7dRpsuVXj9aFz4UgLt0lb8yu3bIHLgtfHUpazh1Z9sp2PFwYDujsKc4Nyu3ZCmJ8z5SJ63Srt1mQ7zpi/e4NtjEJbJo65RpJegfu7tU6MnfGRrT2eL21r0vJBjdfIhMF8OGlUWzEZWAYno1s8RsTejg/cw2HbPPtotWnLaQ/8BZ5l1S8gbfON7G3Jp9L9Z7yjTJvL6Px+H1t9Vwjd0Zend+0RHocbO5Qs9Zy5ewH8mVP4UW9vzyvjIfEkgj59QK2XV/03ew5CPVefS47RUPvCib7V2rF7fvGAPnaoczaqde9TEolEIpFIJBKJRCLxfSIJ7olEIpFIJBKJBIVhrjQTNZoCOxD0mdKPaM8oavO2NRiFQa4GEbFa/VBOiBlD8vbPSC70ZOwIBkz2jnUVJVB8Qbx18CxCGn6PYPOuHs+crr47efwVuZH2iZxkvzulrpr/FCHeswn1KKK5d5Leat/aV5bo3W1BwsIlnW0ldQxCRjtT7X0rN9Le7LPVbyquqq3HAck7dCGxakceUEONBfDV54iMHTnrCtjawe7t7EFiWy28XRTxbVcXlk+1g6qP1w+eTbZOWG8m3/49/lWm30tj7RftC092z9O3FLheB93rlA11eu0c2RtUuGXKb4c8kdfgXngFMW7A4xnh9eVV1rT7svVT+S/scRoz1PSTtwVbuqlB/oAPomMl4rvO7aojMNDeIoO7LW1wLTo40teVzM8Gn7uwZ8b3ArS38aktpyn2UStU5hDCBMMjy9UxuxsndClmpDi1Ziu9VpbNg22h8qN+40Oqvc/y17WctIHZ2T+zibt7bmL9y9Y31i6erdYmKyM6FkA/7cppPj7xK0VOu9MXI6P7vFnQNXt2bRTFtHZqgc8+n149CVynXT9V/FGqLWneZ/vMgc88+Oxh87/Fs7N6Zsf0Z/sC68b022c+LPuMvrfIk3Dg+ewrQzLiT6x/t9dYTq0p6jnErCX0McM+g7BNidqovD4lT2E5TBOJRCKRSCQSiUTiV4skuCcSiUQikUgkEgZT/GcJoEDEv7aTAdFPZl+kmXIsuNNUlGaOHg27CBFvlSlEInmEBcGUPEvUQEIGI85cDWjtCHbfEa4EkL9UsFmd1ucF8G2QX9m5OwWw54mcro5p3k/CW9siRPWInYz0zYgXHimhS7I2zvWZbd0RQLw0j4iOBA2vXbB8xCaWTvuyBU9NVKSBww8NXYTQ1/CFogJ5PP8iiICh0x6v+EAkQDBChJLD/LBXhvlWRQ70/LIFI04okoVK89YtBayLV3eP9GHXtSPvQjLeDVNnLOk9BZFv12nTD3IY2XKMJOmRIBnRUa3j0D6L/lKmdwGnvx427RriDUL/TPkrMWUhRWrdboYo1N5qUUQ+v7r/ET6slCLrpba+2yoEbX2GO7ot57UhzK++bV+MOv51gnwthZP1xfhn6kNNImxnJm6V4b+Njumjyt948nRPyTd8NGq/muCeTisQ/Rnz654TwbJH3mEva0ebhgNUjI/WGpdjP2Nb2joWcp9dow9XUOuhWiN27WDz4pqAY9JbT5ntkfoMPy8ybsbYS4jsDwrfA3vwSNpbArezT1WniUee49hzAHsRFvXsML1oa9KeffEa7Wd29nv4/ObJsHqQrP8Kqf7Ky8MRWZG0bx5fw+Sr+/73tMMbTp5dqpyqj/XxZI3Z7sFFOblXYsKIzdwnveXmOJFIJBKJRCKRSCQSv0QkwT2RSCQSiUQikZhQjxjQGkRp8/9KabWUduRvnRXzuE9PFB6fgQ2xENMEY0QQTiZ4BDRFYGAyVSDMC16pfEw++4zlvcDYLzJW+20a7REbXj1BEAngHrH6ldPwPKJ55BRyW9YjsityhM3P8qAmdY+dPojEiYX0YYg9kdMRp3yVkVfWvlKkFpT/DIHHk2lubH3PaHvmJz2ClBfwd+5RUn1EPovPW33op7FM/+wRA7eMBCKTpeE6gHIjaxLW0bPHW7fQrn7vKCeJl0wWa2O0BWVYWRtCCN4fYiJtbgmA5rr1e8qdbNZcWt7hh1R1H8co2iv0yzTS1nRYtVKq2kMg2ZKMh6mo1wa2zdjeySvT4FrYwhCl6kTzNfzgjPOtzKNtPZl2jC/5dnB8ylCj6qDsFWlDjMpj5tO0rcd80NdDXJv+xFfEqJ9U99ncsP9Y3l3Hk/uuL7tqm6fL+r7dvFe67TbpyvPT7tmI/WW6zb9lz4Z9gz6E+J7q+Vqsn5KvoNoY5eHeg6zFrowdVD5cd9h9Bm99xDyTuLa/J2TtiNY7hF6gdGxpZtPh6VRldy8027LsRdgdSdx7TlE6rV343LB79kGdu3RWx91zWc/3LMn9LU6c/y4RXkDfCMH98YJn7dz5LZVXPePhsw1bSzxYP24338oW9Ne7Nces2dPzOlk3dvOp2syJRCKRSCQSiUQikfjVIAnuiUQikUgkEonEhB5ALSYY1EqrPW1lIWjO2cHMqJUEmWoZp77XzuJYBBiTgDUzm+uU2+THMjaPJQZ4pLoIMUcRMjzSgwrgMVmJp/Eq8T5KdGcn/Nl7UTsUEb6R/7wy7ORC78Q8dSr842+Z7u1OA0RECR824DvqaILBUT1Izka7EZb8z8juaNuRYSaYFf7CQQjMF1T8eNjf1vTDwNcRIA3FxMT7auiN2I++mBEP0J8zIgTKU2lIfLM6gSxKy4p8Y/1lZAlcn64Q966sNcz+KEGvkutnbFLyo9jJaHMWSwKlanDsRMlAME4q9iWUt4TW2vPVUtpuf2PSG0lzwUhAnj5FHCJj/op6esPo2nCGfGG7/SODGvvRveYrrjIwvvr4YNvUrRwcf8zfVDMGmcxDccN0VkaYIRHZr6v8rEGcPllu2XbwdO7altng+RGWb+dPS1llwnrWsF+ZnXYdYPW31yyvWi+ayY/rJdbB+fzUL2RgO0d9diQ/21+wvJH1jmDsgZ7Zu+G4ETLsHprKIPfc/V+b7z/zfBV+8XNji3pWwmcZS+COnETOSO2ePbjv3z1n7F4aZnVh+tBepdfW/0p/MR278p4NV/L/KuAu6l/QhlL8PU7P96yfUv7Jrh/Mh6p1k62xTB57llrsaKW15ndDtJ+gLR/P661rmXUWRm6fDXz1u6tEIpFIJBKJRCKRSPwykQT3RCKRSCQSiURiAYZaBCHLRQ/Qlpmt1cznft16/lbG77m3kWFWawkfQwyQADCwX0rs/hXigwULikXJULvAGCGLffWA50V8jwFqdvK6um/BSOlYLkLYuGJf1+MR1DGPZwsnT3RyA78fIWoown4krzpdEeG9HOB9ZjJsPhqMFkH7qwSWIUvIVi9OTJlJ8url3wiMfGb81oMsUE8fLoh5OxLVog/Td4jmfUY+EiiYz0dCyNSnRDf7bNIa6uyCIiQ+e62GhVofdzYykgqSWpgMtl6ze2hnmZvYXevtVgPFOKTAqX9ZG2M6ugY2pkR7NPg81YGRimz6G0zram30yKJ4X+FZEtTGHfR+rKWsp1VPAwJssO7Rs82Ze7YsNfNZv4Q+hNhvx4erho0HNX76Xys3uo1TPuNKOfQTLC9LvzLuN7632nZgZa5A+VXmq5VvQz+jSHlqTVX3mL9Q9USbvHmFupU8NVd3cPZEss9YmSs6WLrnF9Rzm+c3q70ke0qla8rW1j0I3lc6bPrF8e69GMvysPxXZdg0RSBfXooFOYxQH9mXv5UdHhFfndRu/+6I8wj2LIgyWRmrh+l8D5J6kni/ETzfhTHZbA+N/jOyJqv1Dcvh/tldd+q5B2J5ds8ymHeSc85FW0h55VLq+/ZFIpFIJBKJRCKRSCS+eSTBPZFIJBKJRCKRmGACnkiicSP0NqdiqzE2GL9uNgpUSynNBHwgmDSFgpB4YINYXgCLEQEY8UwBySYYgIvGaK/Gcp8lTn1BfKsB6qtBdxbIVyfWXakzI1YoKGIEfr5KJFfX8VMA62IXq4siol8hZuz0REnxuzyM7KHaW70wwOxnQDk7Gz0iydq/HBhQZ5dPgZG/jA9cbLziH5keRSzwynlEMUZIsHkUYYwtfWhfg39e/l27sLWuQBrmY2Vt/md0j351bGM2KbKKai+bRxEGzdZlqQL23a6OERKNZ7snU/W/N/YYyP1hFhkTSx/ZeSnqu5yafBWs7V6Z75gGY432O5Oh6hWxzZEzbsH4nLoDdFQ2lhHe3hVFXq1DIH3Zf+uFRe+lMYnNGZdohsYYGawfmd/w5h4sSxLYBsrfeT6BjSFiB5W7sZ3Wcdc+nr7IeELCoFrfbL5n2samMd/Cyih5WI6lq3bdjVMcHyCnVbOP83wspC17P7oG+BPovV46jsh9ybb6qD/bb9vT2DvU84dF9GXWnpfpZER0JscjxKP9SLJXMr267Z4tvWc0TPOeE3f4Vr8DSLwxntlLfWkwv23Xc/t9YSHX0TWTfd6tQ27hK2UTiUQikUgkEolEIvE9IwnuiUQikUgkEonEBmc8SLCpSp1CvmXkrVBuPeG5TdEjI7ZWzphT5ASPvOGR2iyBAckZqEPpxzxg8mSfks/s2UERSIYoh932PQbILtbpatD9CpF9dxL7M3ZEyc+vyvHIGjtCRBXyJ5l1JnWgHCR8KL2ezRaoC/WyOjKyDMp79iUC+zkyThSpZrLdIVshuWY7RqLTIjK8JVmy+gS4iN6rRNBdGebzcW3w6lP0fZf4EGlvRaRs8C8CJcPapQh8O86FIo8y3TsSI9ojSIDV6rXyVLtcJTiifs9eex/7h8Ejb3p22fsLAVLkw3u2jxu5532O1OfZPQaTsdnrXJoDjKDK5gDYEqaEChtaKfPLAru9oFKKYytqGI6V3ZhncypiX0+P9IWzbkkdam+u7kXqrdaUq4S2Z++ZeTiNC9vXhfwtZW1rNq6xjaJrL1v/0D6WF9N2EL6d2u6NB9UOiOi4U2Mede7sxvKllNpg77fzuWP7rJzC2yPysuhuL2zNVc8O4WexttZ/R7zevRS8Vznvm9Vp78omVlY9Y/Vnjyuke5XmlVXtceVF22eRZPeviLdu+ujaHdkD72yLPFt5svCZQNmEMqJ7mZ2dS7YWW4c2qPX95moikUgkEolEIpFIJL5NJME9kUgkEolEIpGwqOcfHjbpZPYjitPOoKxlQcwhYRsrOnOWOhNNHwGfzsQyUaLWHsnMKC9AxUgrqmKM2McCW4roxghSO3KFCrRdISwxRIhe32NM7I3r5AX5o6TkK0T3iMxImpKNhI8rRHcvLyOQq7q30kozc3tHQmFEEUsQYac57sjraLe1YVdPJQ/vnXXn/cOC0s+9LHH64X4ZOXVyh924ag/H/zo8/70rY5eIiD2sO3aEiAghlOlhsjwintIdJeJF1kUsg0RHZiNrL0YY3a05qAfLYl6WRxAnp+J2DWbtYtOYPRE78D5rN7X3QKj+3RGCmj8smpKhxqEnzNZbjQ81ttn4wjK7NGMfNRP3bqw8wiNLsb1cgTa1eth8iMC0Kx3DKg3qu6gz9klT2LhW/g5trFAOZTL7r+zNvPorv8n271iOzXd1bYF9zexi+uzYaGVtYzZW0X4295TPZr5O2dnHDfa9zXekXVrrn1kDWHnPdq+flC/dwVtvMc3zWxG9an4o3+zpmATs8R7k4u0zjlFp972R/T7Lq3Sfe/DHtSKi2/3wVL62kY+V7fnZM4NNV2VVPZhMbBclD+vG0j0gmd6T856k91fxrdn2rdkzoB9Jn0Nk/bS6n0n39qhsvcWyai/IngVoNrbJInZae/BzXTOMl7wnW8z8A51sbtZSp69KE4lEIpFIJBKJRCLx60AS3BOJRCKRSCQSCYpWWoXY0BGA4fGcM1LziDPVs8gpEVTMEZyFEDpEQqRHBbEY+UQRBpAssguEeYSpCv8KyeuRISwJ5go2hJyWka+nEDlVcHcCd/Tk8Sv2PHu/28HyIomdkS2idfBOLVSkEk8WI5Eg0YOdTu6RMSKkfSSrWF2KxKLrQ3TVQkn+eH1+9sZhjLQk21yYrepziYCE7v5NmRUGSAQQbeupd21j/h/JlTuShjfcmewIuaOQPIwgifYJIqNcv1S9me1WJpZDPTbN2rqTr9Zo+zc61HAPoe7ZNNZXjATJ9h/+dJ71on4o24isivaiXtbHO3swHxsv2L/WfjRQ9f+uXRsx1fYH2tevlVxvTnd4eciec/rI+p9xpTYybRssPCnbJugrWjnJT2o+s3HBoPbXth2x3zfjV447No9289uTjW2g7MIxY+uHsticR9vVPbX/R93sfv+s/KLyYXi/jw3Wr6XwNlPzGcdQxMcxXZF8u60uG9tLljbda+fFiZ0ehd08UojMi6XIlUZ+4CrxluXH/fWz+zq2d1fylmeyWpYy5x53ta3Cf0oPI3vb5wX2Iquy0yOLK7I9k2OfO3bPOartrvZ7hCz/niTub5YgHsS7Peusiq7jLZpWraWRfGrfqeyya4pay60+b+3EMoE9sPpeY5HB7EGbxgEe5P6ynq/zjc+LLzTWEolEIpFIJBKJRCLxzSAJ7olEIpFIJBKJBKKW0loP4BoQdpEfPzrvIh20h2lXQghhR7VulLID0q0Ij0SFRjOSWv9rZTFdTC6Wt/nxmn3eEVgUeYXJ+lbwjrG4twqKRwnDPe8zJ+e9tT07MFIHI5bgfSRdIBk+QrBgNkTyMbmMOLIjnexI2TvCuyrrEXJkOhLmplvsNMrVw1q5EfIKO6XRfFjTiTjWVi+PS2H2ZbmthH+mXcme2lCR5KwPxzVFEdR2pDxG1GCEB7sGWRtQjv1r+5a97KR0KpKet/6ydRNlE7tGGq6L3uee9sxaHEnfEWQwb2S4RsaAlaf2CbhPgTo3Zvtun7BrN9YfzHYrf9fnVjbawfJ5bWzrGSAsTeWUTWwPGXVL2L7Ih2I+hdgkp+BuX+jNT6Y34jojvs7ex72vN0e9tmX5vTRmU7/vrL3URpSJc0WNcbY2MH+NZdG2XZ1YPmUf5mfzXuStta5to+xS+ex91W/98y6PQmB+MlKwu/bv5j5rj40dz+ybWo29ZPqUHqhDZH+Oe1Cld5ElxKqXWKXMtn+RdVf/pWzj6bjPR3I/pnsEfaoX9ETTPR0Kiqwbse/Ks96reLex/r3hS3zPs9vv98/MFs8+5Vu95wOx790+s2AZby+gsMtfy+M5a7eX3QjZk9hnXxh99k0kEolEIpFIJBKJxPeDJLgnEolEIpFIJBIL4oyCNRY1U1FPeXPOQdxsZ8nHHx7xGgQ9Ra7ZmRzJGyHuqDJYRUaoscTIHRFE3VOBuR0J8D1xRcc7xuK+ZJD7WwqoM5KCysNwpRySSpRuexq8va/y2XtKJjtB0Oa1tjGSDiPyR15UwNMUVT3VywGM4IOEkldOR2QvKlwtO9lBil96eYQRBEGG0nNZ1ymQlnfJbB5UNubTd+WNr5c945FIvHWHpREiZS2VExoteUSB1SVK+MN7jDCs+ByoC/MzsosixygyTYV/thz+9cg06p7V7RFfrAyWzsiWjNjKZHn7klZ0uzEdkb0Ta08rC2WrtvXmWYQY5ZSdzMM9mTfGbV6yv2pMnx2nF7YN7unrVibOK9xfsjHPrnd+bTfGVX6bj+nYzQsGNo6ZTcqu3Viu5PoKVFt6etFmNjfVM8UOns/yQNaSbd4r7aXaV/mBZ/tjiA0W9tbjTb7LxOoAaluJjzsS97Mv/O5OOd/JVvsvj1w98m1MVvtmdsp5iCgP+98d2PPCrq0idXm2TOS5IVJP+QIs5Hmvk9V/6Se2/+JwZahe9ecszds778rjPp/dY2m4V4uC+vlzoV3mu8k/xvET69T6HYS3UehKcu4kEolEIpFIJBKJxK8RSXBPJBKJRCKRSCQMWmsfWim3UjUB0aKa/6/B1kdqWfK0UuoZ9WpHNOhxKlvPa2TVen5SxCkvsBYl4KC5O+IF0+PpZuSoXRtjcPAtgnUo/1V85/G1tw4gXj3BLyorQnRnZPIoicU9mRGgCBOKII/2q5PjmY1KHtYVSfBIkFEEe3u6pEcU2RFddv2rCPYesZ+BtVX0JYYrLzvI8RElh5lyqu4xOPmenLr0xHNGqL1iYiuPX6iP2MTWtJ2+GB9ipNH+8tbSXRojouCayBCpF5Ico9gRQK1utdbuSJ7Yp3aNRnm4v2A6mJ5dvzTR/bt2xT5T9qIszGfltcLt7+XUvkqNJ6W7X6N+1h+2j0sprZWTQM72k6ws04/Y5WVzhI2/ngfvVZFXyX/GhTaRhrqVDjb/r/gVqwPlMTXMXmUn6+uobd64jrSFkovpUTuVv8fycN1a0zp2siO4uk5dGRe7ex6CdZrW/ifWHY/UPekJClTE8CtlNpllmVeefSIvt9q8+NJjZK/NXqLFspjG2tPuQb3nEI8s7j0fsBdxmd3smcPashtPbz42Xij7zEu6iXdCZF3y8qs8z8i1/9g+yFvXyF6O6r+6pmzwOCRd+K9Whu+yPmx+hmynfcszIPM3fS6rhjrSHn8+PF+zRCKRSCQSiUQikUj8EpEE90QikUgkEolEwqKVW2mtPk4semDHlZmDuj3wg5GctoRperrliDx+bvcMNT+iRu0kBjJCkzFSngzMSB+zeZp4YfNivClC4LM6+98uY0f2YMSzV6AIU17et9D3C8ZbB9/fO5ivTtqLEm/UieWKwM3yIBnDI88oAo9HfvcI+rY8I66wv+xERrxWdVZ1iRJvrAxFwvHKspcW+l9FkLfXkVMfsRyzYbnfxv/ceigbdgSZU46Tz5lqsx3mUyW6d+Q/RqqN2OOROcT9ZRx4REWUZeyc6sjWop4eXdcYVD3YZySweLaov5RAQnR6Q8dNcwfUfB0h23jti/uFfo1lBqEGyuEeA+WgnUVcI6mIXYMtFCzvbmzZ+2zfhHs4+5eNA0zDPZ3XZ6xt2J4UPyuwPN48UH3T/7L8dc4u28rahG1L9tlLXlHfpfq2D739J4491S87Gz3ZHVf31vg8gHaxeVMgv9LXnHyeH8HPzL+0ngR+X8ny4PnIXTtGfUSwX8L76aC8+tgAvAmiJ50fCaUUvodU5dRLhrtTuq/a6toFdns2KJlq/7fbw9t8KAdJ5Uy+9/Is5tvZFyWXey8Oq/Srz4yeza+8tHAFSVr/RnClG55ZC5WeyN6iXzO9bP1kezq2ZqBckE1fYHbQzP9Zg7KXeOZ5NpwkgdfY4l49N3atteQ1JBKJRCKRSCQSicSvDPkgmEgkEolEIpFIzGilnvGTtsaxRbxsPnuomOtObZ/KNxatqqW0YnKf9xsLdnVh5h4N7PdKWPKIR85qNqnN6Yy8goQXDLipANxiqPis4l+t6LrsZDO5ihzzteLUV/VmPH0gQpqIytmdTK7AiBxI4lYBYUUUVycoKtI0O4WR2WZPSESCuCLQeHrtfSTPeyR474RHRWBHO6yM3cmPipjD6uHV++G6maw1sF9LPV5k0iSel8kxAYIGEhDqfHPGzocLP7mtR4vVtZUm6zTavctS4q6sE5H1QpE8kciC5ZvJg0QXpsPaxgg1VtZubWflkWzL9hrjfl2JM4V8xrQIgcciUhcrz7ZdE58LpDHsxog3r1DPbt9iZeLeDG1EMpQap17ZXRq2d+cQ4RhV9cD9ILOJzRVmmzdvMD2A5TBRnLcecSziirE97fODne82bylrnaJ6iqnTzjf3dJy3am6pMeyN6QjRD32AancEGZNUD5PjjS9WXs0LBU9nJG8k7cr4i6AJoar+ZbNGR3STPLsXFu11dD8UfVnRpnsvVTIszwRtTsOXT9neke2H2UuruIdXL7iyZwOUr9JZGWarynMVz76EcGVPrJ6TFKL1+VLk+MQbQ60bam1ieTFN7YPZvlrtiZh9mMb2Wbh3iUwNs7bX8yLgv2HjUlc/tSs65SP7jrZUcP2m4cxXMTmRSCQSiUQikUgkEr8yJME9kUgkEolEIpFAtIM8cgR/PF6NDbfMMbK5FIaCmiPRhpdnGVUHvbqYUMCq7OVM8ahWMK6kiBASitzk6bZkLo+khdcewYaRjPAe2vMKfgXx8KtB/7ckCbATAb28HhSZxivHSOGKiI5kFiRiv0Lg8PJ4pBfVdkhyYcR2JPpgG0RkM5ujJ0oyHbt6sXyv9PvI13xZi8x2yrEyr8AlCBH1C4Fe+Tvml8+CZz7P3AoiHPKcC9tO0GasrkubKOKqWiPUurAjs+BfBiS/YDm2ttn1D9dGJr8U3da4DrL1dddWOzINs4/Zo/Yqz4wRZifa00geta9Ae+y/3fhn7W3btpa1rRlJiY0T1Vc4rrBv0T5vDGFf1TKTtHsepo/pZO2KZWwa08XKs35kbWXLWHvU/Ec9qE/tP9X4QxlsDno2X9inL7bgmMW/2AfYpswmZqtX98gcUT5R+QYF1XYoO7K+7eD5Gqv/ma1uI/sHR45dG08R7fxLfXt17VN7xpF+tV7EvmWtbue9XUfQ+jn5IuRxm5/qOWBl9RcVvX0o083kM1sxryKle3Xy7LP32H4y+oJB5KWECHEesduDR9KsnKjeZ+xJFN+3fgnZah1Se1i2l1Jy2nLB99BMt7cX8a5xj4FpLL+3n/T2g4hhJxQeS8DhZ7y1wORdZNf5o/20fj9a53yqvROJRCKRSCQSiUQi8atAEtwTiUQikUgkEgmEIYZ4HJBSbIxljUqdHJM6yVhD3hvmSi3lVss4VX4LMGUKLtnAUEBerSZY7hF4ULbKYz8jAYcRiiJ1jraLl4+RYa7Kf2uw4OYu/1eIv18N+r81SeBrkQ4YMYQR1dXpilHSxUSocYgq0XQkpnvpzFalixFYPOLLjjyEMnd2sPKY3u/tXyiY9XhEnyvE9B2538sXGedVLRJ1HacuiWO4fEEg25FNxtpZOckD7bqwJp1Fz/kn2/UK4UbljchQZMHdmukRUdD/s20CbkxsW2+JKwH5Sg+zX61XTLZNY+s+pttyrM4e6QflRevtyYsQrVSboQ68ZvsP1bbevoXl7/m88YFjycqO7kOYPqYH/+1kBshUNA3HmzdmVF+fG/q1bZh90f1bxB+we4gr5DXWLld1YL2j/g8RaTM2ZtVYYHl37WCvVX/ubCxmjSb6WmOJRCY+swl5Hqa96W5c289tLv9I5nsxz7Zpr0KKefug/rRs95D4QuHyTCv0272BR+TGvIxMTknjbc2rbFb198jxzfyH97267Pa41j62H0edVpYtx9pX4UobROA9i0TkRl5IvYJn6vDdQa0DX0r2lf2Bty/DPem07jh+0O6TvP0I2095+2CU6621r7Z/gw/j8Szi//dzcmRr80cmfvWf0Di16GfeRCKRSCQSiUQikUh8t0iCeyKRSCQSiUQigbgU6+wBUht6URGoU8HK77IplknzyHFvpTB+xCW7MUjmBMpGgPsKMaRfK+JQhCTF7PJIXB7xxcraEXeUXZH6vwdQfjSG9wuM9X0rxIBnyMvPnEK4I57s9EfysDKRfOpkxx0hfEeMZ2QWe9okkmrWV4BWwg3Td6V++Hmuo09+YS8bWCiCOtPvEsikCk6ckrocbp0jXtYjhKNoa84LHOjrlegrLkLyMBy7d6RGlm8WPq9zdt3x1q9n62vXcFtm8CtBsEcGZe1v68Du4VoeWV+h7LY/UC5rR0UEYrLUZ1W+wV8se3UPYOVd3ed45CW0KWoX6tv1oUeqUteqrb1xz/pR7c0quVYyrui3eaw8NiZw6870qDqJ+UvtQpmq7TG/wpX9rrKH5b+6nds9P6h0NcZ2bREdG97YFfcW4nUT95ROvA4Ayc874u+UJ6CLvmC5KTcR5MWD624foV52RII1k7V7kZDtKVEX/qdsx/vYXoxsH93PRuqh7PJI8aysV09vn6ls8eC1567cledFb5/OxpWnN6Ir8c640sS4J1f7x92eadf1+Nyg9oh93UC7lM1qbcXnC4Lhc1me6H64PW4+/IUyiBmIKXW6JX1JQ1+zvjzT7OLrtVMikUgkEolEIpFIJL5rJME9kUgkEolEIpGwcIgbnLtyBklt/GoWdYZSy3R/DZue8bbj6urpRIpgw+6ptGFbxcT1OkIws7qiBL8reXbkLEYmY3Ij5Lgrdr2CqySht8QXDhh+y8QAz7YdkWhHrNjdU6RyRgLfwSPCRMoo4g0jwCiijCXBoGxGJPLI/ShLkaGitin5kZcJprapzj1SHu1Z+kV2U+XknTa3p4fK9DE0k6/qtmXlHkXWOi7k+50Zg48Xs5dVfUswjK5FIt9EGkQii7XpBWIGLULWP3mqIdMd2Rdg/uia7NjAxu5UDtdtZTNbxxkZ2craretev6Eeti/a2Yj6mG5VDtsH9UbKWZKUlYXtz+xaN7i+bpyPqh3Z/SinCucby4My0S7WrsVJUwj6ssW+6Jy7uk+N3Gf5d/2i7FV77Z0NO794Nd3T482PUh5kuyt9LuTsTdko8GQN3qC/T1yLXSMJX4EiTivbIuu5spXtQSNkf9xrRmyJtq/as3qk8is6mf3RchG9V54LrshQzwNX8Uy5Xb8+2/+JL4wra0hH5DufyD4mssdg2K2DbF/FYPPY/ZvIt7xoxWRdQDX/vzYXGr1c5fvP/fM3qLP4PMA9kUgkEolEIpFIJH59SIJ7IpFIJBKJRCKBqKXYaAxyf+zhSDZXPXIgcZCFolkYHK+a+V+FIFz09DYZEJ7iX1rOlN8LxmHg7yrhhpGmMJgXIYIpOzZku3C6lfvWgTXWtl8jrp4Bw4GrJ/cx4syzOhUZvOex1/akM3UiYeTExivkpx0BfQfvVEjlt3ZE+/6ikZWhCGCsnRhJKlrPVlo4iH8k0Lp5xKwIaB8If+WNEWvHyNfmvLv+xjHM1hqvn3eEMDnO3slv0pcZDNFwSgdblpNsdyRrgrpclKVPRhrmYWOA6WGyGZEbyUGKuMPkevmufGb7BaXTI6qzz1g3m351P4HyUR5uMiMyUO9u36P2FZExweTu7EUbIuOdkcrw2sqy9cbxGPUBjOSm5OwIa3ivl8H+9eaKIq+pNti1P9rilUF72enbkTl1pf3fE6wtWd0h3+TLld8K+IDdsxV7YU/J8u4xguC0R3RYgFHKsCJpe2u02tMokjmTGdkLYZ3ZPobt5az+Z/a+TBf+VbotFGmctS3bG+0IoijTI8+zNK+9I3LemyDOnn8idn2X2DX11/LLV/Sy9SS6L2Lr7jN19vZF3nc01lZ73deS3Z6b7UcQu/rsyjNZpH2Zp4i+4NyOyu+e4boBsw/zDW7l+E608i1KIpFIJBKJRCKRSCS+byTBPZFIJBKJRCKRQLRSeohF0fbwE4t3nX/PkPRDsmZadYLmnK+a/8/3piB3nYP1lIxHqqCC16FAGwbmFEHJ6lWkOJvGyrLg4E6ftRE7KUomY/quEHquEK2wzCtEul8YXiEfeCTkL4VXie0d+4CwJgBFyNEeqcorvyO17Mg8SCaytjMyNZJWJKl80bPqVEF5lq7qytqK1YnVmQJMx3oynUy2R0ofn8E/7cbojvAVGaM9SRHbPB3eSxoemf5NiFSOiMmeVs62xfLeWlA3eYrJE0Uj9rE8V2TaddOWVcShK2QapqfLvVp3K4eQbyfSP+4XejruEZQNTfxjpF9mn9WB+nbtiv3B9kfe/sezJ0KIYnLYmGJ7ut1+Ru1PsR3UGLbp6j7qY+2tt+b7vRjbv/VrLB/ZTyt47Qn2L/7QayNmGyNG7/oyIpfhmf24qv9VO77AftojOcu11viw6JqNcpUvm/c7sx6PAI0k8olIH6jfjiDP6hHZB+1Izmj3jlSO+xZsG29/FH32QBuisu3eie2VXrErsufCdnxGbtSeCNgzBepZvhO5gF8UMT6yzlhc3cN9DUT2JzuwfQ7uv3qat0fDvLiXULrw2tsvqD2pBfPr3jDdDWHStqNq7fnnK/1d5PpA0UTj13F9Nn4ntrfS7peNSiQSiUQikUgkEonELxpJcE8kEolEIpFIJCxMYKlNwRWDWmnMqwdozjTF2Gil1SVlXFkqQCGBIRUUx9gTI4ZGyAXmw57MwgJsikSjAohKlpWHwbwq/ipiFOqJBIGj5C2mH8vs4oJYt2eJOizPtxq0FniGTMACr295amDEpmgA+Er9oqQMRjhmRHCPpB4hrmPaszYzgs5OrpW/I/1HSeLMnl0+1pZIgGJEqogNu36KkMGQdM+IP6qPvPGB+WKc2Hgf79YmtKvXj5HC2Nh/D4Tm8uHPR15cfxgUEaYc7Rc5tlCtKX6H8b9KLpSTbe3Ut51MFX+tZDax/YndAzi2yn0AEox2Ntg9ipXL9gpMRyvaVmazlYf7Ldz/eHK99kEily1j/1pyF8uzqxMSwyLAtmfXu3vdPmtHRA7aqtqJYdfPu/nJyjKZV+b5Dp6Mt9pbElumNeLKdhDsYX7y0nqwmz8beKTbuAkxArEjIKznWXvU+r57QU7JiqzpVoZHalYkcFXW6ld7OLXHY0R1rLPVo9Blo92q3tH9jrenYvt8D9hO3ksMXwKe7a/Y8wox/qtit86wz8+sC+p6p1fJ9fbHV9c2tZfx1uzdfgCh9upsrWa6sJyqo/NMsOylmK7oeBjZzUauwnP3+LN/Xl7yDTt4h5xVsH6OmD/2nfWza0QikUgkEolEIpFIJL47JME9kUgkEolEIpFgwIDOfGuCjSnN8S0bpIf4VJslnaEdG1gyQR+jAE+iY58XtFJqrdNP1e+ICkslZ5N4HiRdzRWc/7JrpdPmiwZXkfyFNqB8Zq/N5wUyu3wVnNwFSVX934KkdFWuzfcKLpa/Sgj+Erhi0zMkpEiA+Flyk0cEjxCMPZtQz07OjjzvyfHsYgRqlIH+keVRNlnSz478vSPdH5kWHT3d/gIHLUt0eDo94vuurz1C17w+OW5I+EvbZ7u+9dKjL2vI+fMCZ3Apf4UEI7OQTLDeIZEsLMf4fBx31E6PKINljY1IgFn0E/IQJb+oto0Qe6DN6kOJXp9tfkVQYvsIBOb39hcMjIzl2YxpKAPTvc/KdpWnOnnVfoq1OdtX4j4PdTS4p+y2421H7ooQw9Q9b4/p7Zc9WZEyO3sKzK1X/d0r2D039L/Gj0wvBC1FGr237E3ICfQvkcUfAp4osn95DtFKK63F939sPY0Sn62NkbU5ui9VMrw1PLo3UWWvkrRtfXf7YmwjJHWrPZu3T/PKee2HZHL8PqBf2794jfVjelQdvH0zk8HGzNd61rsyF7H/fzGIrD3Pfg8Q3Z9h+ch3D2xv463BEai1kn2Po8o08k/twyx26x7uT9g+y9u/KnvVXnAq0qaXwHCsy+5q8sMih6V1yvpEoi9sDXJ82Gj/r+NDEolEIpFIJBKJRCLx9ZAE90QikUgkEolEAmDD5T0UU0sprbViDwTE4M8ZyC0mMGMJnMiHmdks8ydL+mr2z6TPI/lJohuDCIItMo4KuIHpAPEmbBcjOSEhjZGkCknzgpcMhIw3lY8GNa/G31iA05PvYdcmu7Kv4JU2+Mah5tsV0g8jonj5PVui5PBnCSVXiR3MN+1s2ZFjomT1HalKgRH3FRELCd8e6X8q09qSdlyU0kw5YuqkR1SFtbVXr2hbMUIXg0cwW2wCMbZvPZL/Vu4s1Cu4z+usiw03A6LsyKf84ehy2ukgsm79svJN1Nf0zc203SCVUcSlWqgMiR2JiKV75CYvzZKDkJh01R604+pewgLHgdqfsHVbfe7tz+qIeyQrfzc/1Lh+dj1Xfcl0vQWX8Nl9p7UB6+uR+HZ73wp/UVfUrmfgjdln23pTDte3t0J4P/Le7ehme1vlV/cvuB/F9TVCKo/sydh67e39kLjt7U9QJitn94XKRlZG1dOrM8qwbYl13RHfWV09m1g+VVaR3xWiNjyDt5Dx1niLunwX+BLfA5Tif0ejdKnriE27vdROd/8c+S6G6fXWeZvO9mooD/Oy/aIqC2V2vk2uMY37UabY+ir2csv5fLEa3JaOs3bxTVbkx6wSiUQikUgkEolEIvF9IQnuiUQikUgkEonEBhWubIypmn82PKM5S/OZaMWUW3lDx526BpDsX8dgN21LEqlrHpeQ6xF/+n2sqIp1MZmMWKUCgCw4iUQvRghT8lkeG6z1yEkqmIl6MH+ESOaR9d4Sr8p9iyD5S+rf1oArhCCGHcnH5nvFnrfCFYIM8xmu39jgVfK/R3BipCjMy4jXjACO14ycb2W7L0k41WqlTfeRQMXIVjui2lthIcELMob3Ylbk/kNk7wsHg1+pSWYunCKXx2XE93vYkYOUDZUQ6eaNC7fB6lMEJbsmcm6KxjMuueHHs44y76Vub3uS1Y68pOxg+xK0z+5hrtjd2rXxpUhSLM/FcUf3P1enXnQvw/rkChHNXrP+YYS1COnN208yuT2N2R/ZG6v7zxD7rkD0kedrXT/skRpV2nQbfJynW3H5lH0X2+nVPWf32bu1K7KHQZke+VrJUyR2Zjfewn0Y0xXZAzP7lc0oG4norC54n7Wnt/fDvO+1L8f96Kt62Tjpf9/62WmHiM5nbPpFk9Pf0vT3lsXW/1134T7S25Pu9gb2O6GrUPtI3CNc2fuptV7lj9iD9502sc+LV+aNN1+YP199qVgrKpNfp1zNdKL9VhUJ8N37JxKJRCKRSCQSiUTi14UkuCcSiUQikUgkEgAbKl9jbW3h1GBs6YzBWYLkGa7hpeays0Ht8VP19ZSnyA9IfpwqJQg0tswkixyNpIgKU9WwQgrRYB5rXA+KaKfK2Y6MyGekJM8WjxyoApMYFI2Q9VTgNdIG742vpPctSbxvRfRw5xDgWbutjh2J+Fl4PoiRrvu9K9gF0W36lfookhLThzqRsM4IUTvimP3ske6ZjeqkUIQldF0lyuFnz3aPbGWTFjubvfTrwnDm5e2PebeyqfkksZZSq5BVjR1AKnnZB4n1YksMJGs7rkutwly1RCJL6mHr1RU3siP5IFF5s549+mH1PVL3lixcZ7tYXe1aDDLdPqa3xiDxy2HZRdYq4NJLFi/uG0L19uqo9lRXiHG2b3ZENJV+ZW8ZhbXjCdI2ne+ROaf2lhcQISAzqBeUpnU6OuYixEBmH3Xdld5n6zyzTbXB7Hda3CdczINr7Y6EOOdp59ipcz7cwyhyuNLR8+GagzZ6bYx7J7avYPtKNsZYu7B1GPfJuz0S1tWWsXKiBO3onML55JHwVRraHinr7u0C9j6DiL63eJ77ReFqc+6+J3gLqO8+omuTV2a397uyfis5+N1KRJaSc7XOV9rN7sN3ealYnZndm/2YzcmemddnfB/Md68+vl/ZPI8ys5y3GsqJRCKRSCQSiUQikfhlIQnuiUQikUgkEokEoJayBLdqKaUaYhtyzTwOxiOg7OnrgXLL05kjWtX8H8vitSUkIBmikZM+I4GphQDiBdu8xlB558rz4KLX4BgAVISwnW0saMvKImFJ2Wvlem1RyX2FLdlN6EedV+D1S7T8N4wveUqhR755K3kRYpoiLb2q28sXDbYjycbTy8jM1ucpH8nsYWQvZZuVjX52pQb4erBMlFjIyFmKkMaIS5aktRsLHjGM1QeUu/3IiGZxrGS/txrXVA5bb2ZTODZEGNZm6v4zdZ3z7cmgw96d39901SBVmrzDfrWPaIW+YMd0N2Of+zKHqkd07WUEJdiT0L5wCbo1Po5wDd/sJ5Z9GspCeU5fuHYUqHd0b8hkvoJm/jZIi+hTeyRv/Efmu2ePNya9tOhejPUtuy9k0TWZ+DH7gozCssZc2e86vpDZqvQr0vR2/UIddU3vz3B488q6Oj2rwfqqZDK7WdmpRm0uy/ZQ575A73/sZ88OVk7VG2Vhnn6NewbUo4jmbI+3G09q7Y3saxl24w/rERmzHjCfN77V/vEK3voZ50vhSpt+04hU4S3W3Kty7N55951IIXnYHprJaeLas8vLe3XtVc8HVpb6nkmlsesrbR/di6GaZRs9d0gjxvTvL725ZFfiOj6DbvL/82q3uUkkEolEIpFIJBKJxPeKJLgnEolEIpFIJBIW9SBM9ShWO0MrXkzJi2exvHOMbA6Sn3p49IqRKZGwuJAOFPkKZKr8S1ljmktEY4FBjGKxIKcNZL5C0umBVBYY9YhYNhCrgqoIW8bLqwK2O2KYqp93DwPKr+AXGEdUxJ23kPUMlO5XZL8VEeUVkk4ESCTa+SNWnqV5JC2vrPV56FPRDkVgR52KqMXI2ywP+m5WJ082y4ekd9SD9ijSOSNgqT5c2ocMFSRRYTsoQuIk9yh5FYqwhrZshLhyF5mNyDS+f6fzbYlXh6xjfViImzvS0Ejar/2MFFqtfit/p3MUa6v8ZxEhNe3yPiPf3ld5rm4sS5nX+kh5tS+LgO1dPFJWVG53G3Zv6dXjiSEg/cvFPmb+aZF19eHAwaXx/srYuyA3YtNL8/QJfUz/pXIm6zJOYPk511durzdGTrs0aRvtV2s+I5sv94kZPjldk6OZHZE9XoRAzerDnm/VHkW1Oe7lrC3Yxs/uV5/Zz6t9ndqrqL3RTr/qq2ftjuI9Zb8VXF/+/sq/LJ5xx7tt924Pwb5L8eDtR5kdV2SrPQ+mKxvsdy/q+yBHb2tvONZovZdFSAKfEddiqx/EZ8qehjLP9Fash519u13H1hXH+4rvy0+cRCKRSCQSiUQikUh8bSTBPZFIJBKJRCKRADwOaa/2wxpgaWUEaSLcaRUmP7lFj/9Xk8uG61upw5azrAr3rKTInlRLpcEwSnCDiuzKjoAW40V4DbQDI2kdaZM+JncXwGSRs0bSo4FbWw7T7F8l14vVoTy8x+xj+p/BVaKWJ+O9EJD/DCHkLfGtkjwYmbqnvxWxdkckVsSunUxG0kEClCIDrcH89SUhZrNHkFYkK0ZYU0BiV4SwtBtb0Xb16seIDP3zSIM1Y0eCQzl9nWFkvegY8YhKuzHwCrZ9gcl2HRBr3CpCv2DxJqhGLhHvjekpnyUnszWX6J0/0sq7ttmytZLyOzKUqru3r8C0q8Mpkp+t72ovoMbYVXIZ6mV62D7mGVlUvBa6zG+cK/Omm+rfEYKv2KjG6tNopP6iPjsfsOyRVZ7ofWJb6NcWENBkUV92yVaSNq3tlfts+8ykCNS9fGlvtYZocvucq077mh08ErPaO9l9EObzSOvWPpufEcm98sqenob7OfvX22fu7lk7sQ7MbpZnt89l48jrk52sCGzbXp1nb7k/SgiIvd50n12/le4ovD0q+97E5sPvN3bfZez2U7in7J8r+Yw2sH2g+q6E7QPV91kXvudyn61F20xz15EdWhnaPMeZv6+lmO9DZ39r16E6cj/uMln41GV9+yxv3lbiFtN6ykQikUgkEolEIpFI/DqRBPdEIpFIJBKJRMKi6RhcLaX0E91n8tQZlHnkrzLW10NELJY2x97OUP1Im2JbnHzQ780S1joyhALZV0hlXvyJ3WOBSFWmPkg1kphv02w6C4jaexHyHQYfI3WJ5EM9z8LW7RmwstHg+1fAMgZ+ZXgLkqtHBn4PEq1H0NoRk3c8TUvieYYM19NZ8N8jvc8B/5XQxAhZ/drm2dm2+v226PTASE6oX5GoPILaSJu4kH4dVHonTLL27HKxLW27eCQyb+1kZl0Zo1iPTSYUusom65lLKp83Ca5OuTfYEDZdYg7ko7appgu6mZ1+pmeMl50OVff3XONYs+z2Fz1d3WPNc7UOfR/xKhgBzt6THC/oZ7NHmu7wjfaKV/a9AqG5ALffbD1tpw1Wl3oeYPoXfy9sZaTjWW1dyjA505q/uN6L/SB8tbc2LbYRnxvqHzLmvD3NNE6c8YDrMCOgqz5hbRwhW48ydT6N15av8BnlePW/2raWaG7LqHEdmYOe3t1+U6VhXe3Y2825q/siT9YVvMde/l3wCzHzXeB9T9Cv37J9XnluZkTxvs5Hv9tQa/XOLtw7oE6PbM72Ct53NdF0dv+Z9hV7O7UfYi+YRXyi9veop23rwYns87OxKgPKTNk5tZIB98y7dYlEIpFIJBKJRCKR+GUjCe6JRCKRSCQSiQRiBKVO4vqIN1VLHmdB7vP/DJYAXwoPQmFsa8rROHnSJe05WMgDfrzpufJXArIqGOoR/ZR8FVy0+b2gq0eQ79dXAphXg9Q4EDzSFhs0tXC7vwZeCfRuswQr92IbvEKE+5Z1vaLzWTtfIdrMlKvVFkaIUoRtlk8RtJB4hXnYPUYC88jvnm06bZXJ/jJyHLOXtYdHXFOkQrQHy1ibVLvt7GO6lT5FfJx0BIelqu8l8plY5OUY3BFe8LO3XhTRxu/odhZ9DrlZIeI3Bvm2Yvoi7Gk7ZP7Auq5JsG6ha3ap/NNQ10TLS+3BSG5CZ7+W+8WlqDcPakhGVPa7liPzzpO986muni3f3iHfAlss+iLTrgzq2d3z8qJ+RfreyVFy3TqfgqmeEJEP5mBoXTLpzG+r/Y3XF8va2jxytj75m9mx24NF7FZEfKZjt+9CWzy5Kq8aY8z28DoFn79FAvqXsGlp0y//+PN1sVtDS3G+FBJ5IniPrmXE8gr37PcSfc/k2aL2NV6ZXd28PZz9p2Qr+VhO5HvLeeU+B2zKbH1XX27bfH/2h7Hdiv+81wo+y67dvW4mk+CeSCQSiUQikUgkEr8+JME9kUgkEolEIpFA1B7TeZYAM4ma0ntoiIVwaDzNkrCOiwb/PbKd//UgFJIhMP+jntfJKNbgbVgrQuQ+le5lsbxAGHFNikThWIAS67H0i0lnA6CS+zsymEpv4q8Hpl/pvGKXyr/Tf5WwtyQ/wYB4kTTxJcknX4Po8ozOV+2MBOYjhK0dFPHYI7XZdCRAMSJbhLio0hipjKVFSPBsffAIX7hGINHLK2vXGy8P1nNHSre2MNJ9//sKoZHpRhnbetUzbbRV5XI9+yyxlLWb1UHLO/Wm9XmCIOUSoh1QQkw96oxr9wY7EqK5WUpbSThybWOiSN5tGxjSrZWB43frx55xq8teyxci7QAy2ajzW5HqSpzQGPFFz+BpWZE976rMlTd/9NejCDpReTaB+zHrX1WeZ/3OZBOsnTtC8kl42+vx2sobP8y/RqCI0ox8d1We8hNqTUAbeh66b6m6fGR/YK9fJWPv1nhly04m2qZ8nEeYV3lVun3eVns0VvZr7PFfwVv5XoZfWltIRJ7f30Ou952CB/b9hadjV4/ddxLKRUaI5Io47u3drrRHl+99RxGVF/r6rNoPUNwREOkzAbXm7ebf2dT6ebDB5wI+8WG6XUsQ1n/qpsZ79f3cUiKRSCQSiUQikUgkvlEkwT2RSCQSiUQikUA0EjOyxwTRnwM+/wI/aEo7aRvz6fA2/6QHhU06NflPYSLQEJksECVJcab8IK1hAK2Zso5pS4CNEd+8YK4lFdr7KmCr2lUFNpXMBv8wfzQgzIK3NuBaCm8/0gbUXtSDaTtcDSKqej8TeKbivxNCxDeIK6e/vYoIyYwRl7x8USAxyf7t921e+1eRwZlNSGBjn229dgQpRt7yy/H1gRG7LCHBI9uxzw3+Y+1l6+AR+JltHtGSIUKYi8jzCG6WmD7GZ+PjeldnbDPV3jsowuTVNEQt1+c91s3coLKu9HetfO4t44+tiyXQDs6eyy1X1rpZkikRSuW9vsY96aNhL1NLfbR1xJyxVbto+6ZfXIj2U7LGPHymeV6xk9ihRET6P7J2evnYmGTjdud7rqzh/dqbQ+dfrW83367YuPOvuLahP2NrnTe4cF1l93E/YMupsYFrDNqKp/MzmUy2rR9b21n7YD1RjpeuytvnXelfCZjeK2uq6q+dj7E2q7JKD9P3XgTzZ/YViQvw3UEMm+9PtvKjXeftT9iXWxHY70dQFvt+49nvTBDs+x/8/kHsDafyWG/z2V2nd7YR3aE138myK8+eF9laeNarLnv1R54yybHyTx1x2+Z1Zd6C2qbCe4lEIpFIJBKJRCKR+HUiCe6JRCKRSCQSiQTAhmvOS7huNBeUnzHHsxQZxeSrZ6DoQU5o5cHL4WRDFQyPBPMZCW0J3rU5fReQXz5jEM8h1lgb2DUNXtp7XR8GVFtZy2Kw0QvyepE1FonbyUFdGHi1MlSwFq9VPs0YWnElkO2VvwobDH9rCMLit4yvQWqJEFm+FNllRwqKlo/UV/k/ZcOrfcPKR/y0tc3ax3z4I83xoybNkscYeR7zob24/ng+vZOTkbSG5DamyyOW4bqINiuyG7YDk9dMGrMP5TK7mE6WJypnV1buCxon4flzTIzLqstNfbs5apHtHbCfpn1H0+N6lIN12Nu7MBskoq4IbIyWi5Ivn7LpKp5wc67tZMPcSitnl8X8rR0HDIwIO8l5sb3UnpnZ8Yzs3Zql9tqKGIz5pjy10voo3Tvbjwtqx67dlB1qHVA2qXmuCNWeHJvPrj+4Fqm1ia1LTAfmZ0C7d76MtZUaX16afma99msIu3XHI00qW3G9Z7qYL/HWAmazl/+t5r61b01/e0Rs/Nafk74ZMAbuK8/CEX2sDH5voJ7nbf5nvx9gdfW+52DfT0TlWBlWdoN/pax1Y3W0Muz3Q6pdia3L3GgmH4N3j8kc2xV/vaO2TGbptclbKx7fQ3Y/2tPXcvYZa17vVhtK4cNgSYctHlqeSCQSiUQikUgkEolfJ5LgnkgkEolEIpFIzBhRk1ZaYae1l1Lg9FATgIH8c1ytmv+fylbijm+aR/DziAIqz6yhLuUUuYAF9qRsFhBE8hcppwiUNFDJ4l2RIDEGPjGahnJt8FUFQj07VFxO1cmL42G9d2XaJo8KjHtQwWsvwKt01rKvsyfbA5H5LAHlS+G97PvW693xVnYqPxfJ6xGjdzIixCAk/tn/pP8jupjfDBFERb1YOyARgpH8UA7V2ebPEbId9sOzpHEmxxtnZz90wgevH/abskWtb8+QVpgdUJiOfSa3231lzj32SP58GvUTe6kpb9VtwebJbm6wcRYdO1Hyo6tf3Jtkt/XeW+DN5LTmruWX9ZDsyq++Qqx8S1Km2tcqkq3Nx/z6VHba1mp/arEjSTMfLuWZ/a/yRazOuD5RuQGwvmZy0Tbm25WtjIwXhdITsWs3N7CMt0Z4duBYs+nemsn8trfuMuzaR+WNjE81d9g6u1vD2ee38hHemIrMZ1aG96XW/554q7XkF4FoVfF7gqjMyDNyKdf5u1F72H32TK6+/1Dfj+zqZb83afDPlvNI7ShH6Yp+D8I+L/fanK+jXp93fb+8yBoi6ZcU457nY3ZzlK1/6Fvtmj7pOr+yW+tD9M++ebPe8m3w0Os9NrRWyua92UQikUgkEolEIpFIfIdIgnsikUgkEolEIjGjR2weIRmMnohgzMhlTnfH+FqcLrXKPs3QJ8yu5TiZSxESFCHSI0BM96ovD/OPa9NQihyISbQlvQBvMwQ7G0RVwDxXA9RqgLCyPaAaIb6rfCoYbfWrILaSp+qvEGlXzN9tu6IHy1wpl/hy+Mp94pFun/HEzxBeI6SrKAnuiv5dXkXoVUQEJBbvyiL5EdchRciz+jw7UA5rS0YwjRLsFIm1lDIRtSv8h1DEjwixMAqXrN3m+jP7sExk7F62g9ynMGSeq0CSqNRd1zR2uvxVIqxFhGyE7czGaESWyqf2aa/2Kyh9uo2YrK7P892eXYq42sZmR6mO+WIl2/Ybs8H1E3Qry/fN01/R7BF/dHU8vNLHyidfya/yeP5fyeyfo+sOW3+Zr8H1junekaBRjtXbxxjrQ5s3su95Zm6hHLQnIveq77Hzate2EXjr/yt4S1lWZuIroBOwI/ns31LOZ2CUUQPXHtTyZdPVM34l16j/yrO7rbf3fQPagfZGyiHwuxDVxpi3Fm2v6o/RJsIorx7invSr7hbLX6e89VI9F7H1xt33t/13jt7+230W2PW5vH/UrW0lJBKJRCKRSCQSiUTiO0MS3BOJRCKRSCQSCYtaPtdS7qWSME97/G8bTRmnkOqYpL1GQhrLf3LqfO074ggjI0RJi9v77UxX9lBCyNFQk7y6bxfUtcALZrJiKjisVNigcDWfPQI6023LNPOP6cZ8Vq/CLliPQXL7t9/ftQMrs7NnF2y+glfqH81zBclNeb4vvyHsSK7efUXuZvCIf0zOM4RD5SuREBcmCm8+XyE2NvGfstMj1e0Ikh45cWcfqyeTzciQeB9tVCRMrOuOvMj6YEfcvAJVN8+mK/d3abt9CZZb2rC1Rd681XjdeW/tq6uutyCKR/dxaqy5JpB7u7l2xVaXBOXk88rM41S3wc6veqRa795urnq6tv6XPivE2kZd72Ts9HlEOpVH2Wn9U3TdUeRwpov1G8vLdEXHKq4H+N+VOR8do2j77mUHm++Kb/eI9JF9DLNLrZVd1yv7ny4r8Z3gSld+yW6PPG/3v94ztb3Xly+VjmDP8XhP2YrP5/Y7CbSvQRlPrmeHms5KjvMdy/K9EfsuQ7XLxXHSVCeq+jj19HwTW5fsGuKtex5CfnT5VUq+Zj/zXMJtGpmsEK9vfpZ3EolEIpFIJBKJRCLxXSIJ7olEIpFIJBKJhEEt5f6I6DAiSZs/FpJFwWR4xNecwBIJ5lQTbGSkDUass5+R9IDkCo/woqACatFAlgd7Sm6pmmBYS90GRye7PHO8YGqU+IXBYZSPgece2GxwX8lnMr3PvbyV7wV3Maho9WMA2Kvre8IPdq55I4Frpw50PrwgLywj8RTUCXPPYEcUYPctUewKEYvJUp+fqZsiITDCoSI9KgKglb0jfFoyBn6O2Gvvs2tMi9TPs5fp8vqFkS09Uqc3RnZrqUfEZHbbctjuOxKpTVd2KVKqqv/uhQCvv5CQqcg/mB/lrfU+EZ1nET8BCVv/cJ0YNM/Dnn/Xr9NYIOKHvMbrGSXEMnvZZ7Zn9cpJe0Vej4il5pga11ZeZGyhLM8v2PToXMI2tOPB2rcbr2iv5//Z3N35uGfGTKR9d/K9MeWtvZZEeMr210W0YzcWo3sN5tf6/QjJUdlxdU/B+lj5WFbO8yW7Mldt/VJ4lnj/KnZryXeJK9W92jSW3P1MObxmz+nsWTyi70pd7LPy1e8W0B7Ma+231w0LlvkZ3GvbVmablU3su4naLyvP3+Czvc/Avjeg7VXXvlQym708DYns6/q1XQPYnr7ns3+Zjt2aPPIHvhtR+6Y1vyerl1szV2jfqVatfHbEJhKJRCKRSCQSiUTiO0QS3BOJRCKRSCQSCYNWSm1HgK6WUgbXvbUzyrIJQlZ23wRnWkPyhLlNgp7V/N9TfiXIHSFIYNqOVFArD5hFgTZ5n0HRopORbhzFR7dSdteST9qAXYTBVxswNXJrA3JNJABsZWJdWEAX5TIZXv3QNqvL2qbsZjK8YLYXgN7Z+V7cFy/Y/yVlJFy8N/npCsESCVkREnKUfH0FURJ11xMlnyHpziPVYR6PfKdIjIyw6dVlR6LFa0UMQXIotkH/y+xjBFOmA9uP5bM2IAHTG3cMeH/3Wcnw9gesvZjsHRHY/p1JPnrMeAR9rz6l8LHH7IqSLVUbYXvjtbrv219M+2iCU0+LkOyv3IvY7Mm9StRUdVZ2ePNK2Wb9V8Tmh4y9f2N7bzXeMY3pRXi+kuVFOxixG/Wr+4qA5xGhcU6xebybQ6qfsF4ox9plr3Xbxcl9rN/UGsc1xZ+tPJ+l+nEny33+Aj3e+hR+liT9E7H31fyvlo/Ms/fCovvrmfJt4C3q/8zwYWXwuXn3/Grz2KXE+/6BLTnquwSWj31PgDqZDqUX62Fled8jMOzaVH2PsJOJ7bzrb9AxvvMy+pc1V3y3dOW5j62tam1X67jNq/YaTB+tuMkr0xZ35HvHK91nWyMdXSKRSCQSiUQikUj8+pAE90QikUgkEolEwqId/2smbNJPE29HFCtIApbZLgb02vH5EUvjgbArRJaezyOOnZo4sYIRUZbgHwTinkGbOkLUwemPHQFtyIfgJGTiAeQe2xzjQyo5/5mAKiWaqGA2Boob/LXpjPSOslEO2trLNScvs1Hd88AC1a/wUlRA/clhaAPVR8LzSFL7m+BLEp04t+I5eTsyXIQs94wtnh9EQmCEzMbyegRQb31iaxGS5VhZS75TRA1lR4X/rM4dmTRaZ9UOkbV6l08RXFUbsXZh9VHEU6aDEUUtkZHtIxjBxuszNRbPvcVqm0cI8vZO1n5F+GGy5nG0o/GsUP2g2ozZhbK8umA+zzd4RFycP1Y+y8+IWOyzsnGnw5uHV/wZ6kD5aAuXjX2l/QnKUuN9tuEsw/5TelgaK8Ps241Hew9lqjEY8dd2LfBg8zAfhPVg84PVE21htrOx6pVHfWg7m7c7nx+pj+eb2Jhg/bnDVf/3qgxvXLyFLe+FV/akQQVfB99Kk3/NZy37HB1pD/vM7T2/o2yGKvLg9xBMN/vuwebHv/CdxnkPKtHzMRt27YN2MdsjQBtZ2d33HeOWr3i630T6YpSWo/YEuBe3edU+mMlQ+47Tfr0nwbsjvZ6fw75ONKv3pESNSyQSiUQikUgkEonEd40kuCcSiUQikUgkEgy1x+l6lAb+llIeR7Ef/wymuKaKzFgxTjab6eRRr2SrU+yZ5hEwtgS9xskqtowigtg0LxCoyC3Kbnt/CvwZFR6phyGajwaeTbmlnrZTowHZJUhc5kAsBkqZfKZDxVS9ADwL9O4C0s/UF2WqwLtnn7qngtVvQcB4bxLHt0IS+UZxlbi0y++TpFZZzxKnIoH+Z+v2LGGKEQGvkNl2JEWrJ2ILyvc+R+x7VeYVoiMSTZTsHekQyc42jRE+7Zq8JawQW1EPprGy9q+tLxJvWL2sjYroy+RfsYXl6dfMbtxXMfsRKymVg5FQI+OSkYoj852NGaaH9cHVvVsEbM/pEaav3FNgdfLKqR5s8J/Xb+e9B4PvvKd9zq6drV1K3qp//YxjFccI5kXdTL6yWeVlzxQ7H+k9u2A+pRv1eX2NNik7IvB81m6tZGV3dby6B3h173BVz7P7plL0esrWmLfCK/Z+TdlfFc8SkN8Tu2fcq2Wv5LdLgrJj92zNvn+wS0F18rB7zfyzxPOdnR5QhicL5XlTFp/d/SXQl8NI7vR7hjbnG6ngL9uc3u95+9orzxtsn6TWL7VH2X2HZsHXOvassJac7Deid2udwpAovrsxl/fLwhOJRCKRSCQSiUQi8YtGEtwTiUQikUgkEgkLcyhoK6XMp7fXOTBYyoPwXkl0DoJmjLs85fMCgSNLLEiEBCKbZoHkpyl4V32CnrLNBtiulo3ItnZHCCc7Ulw0vwz4Nl1u6MCyx1ByiRgYeAUZoywLjNuA9i5QzYLvarBeCXqzct4YR1t3QWyP1K+aVRHlrxIdnuHPXI3vvi/f6KvivclUz+BLkY3eWs/OB14hJPbrq4TGiG1Kzo7k6+EKoW9HBt6Ru5EEbdMwvyLzeX3FCMlKNsqJkHLtHZTnkQ/xHq7BqE8RbNn+AEHT2N4K7NjJQHt3utU8sm0VIZejnWpeqT5Qc0Ol496LjQ1FDlfzDm2ze0slH+vKxg62pbLXs2+3t1MEMHevFsDOzqj/ZHK88WVtR9/kzbudrayPvfGhxtCVPbmag6w8608vzdON+mx+rOMra5PSo3T3v16/sTmDiKYxG6622Vvku4Jo+z/bT4l3QGQYvNpd7FkRZSrid0S2em6MYPO9Qag8q4t9bt+R4yP62DO/+h5BEeJfmfJvPWV332GwNpk+1zW9cr/9uOXvyRjaYcRuf8TkXgFb55U8vndidpg8jdj1Bu5/SBzju9Hvq2qtP7+uLZFIJBKJRCKRSCQSvyQkwT2RSCQSiUQikTCopdxbgxOBqomq2KCfIF8x0HARBg1dMvEakRsBqzan2b+n+JWs5yFCThz3WqF5d+Se/tcjTFk5nXjfy+2IRFGShQokLulek03x0LZ9QaC1i/IVVCDfCzov42yj2Aa8mT6lywu4R/Kp7mOEBqyTshPzKnLAjhSgXh5gslT6Wwf1fyG8nu+dgPQquestyGGKhHgV3jpytewVwqNHRkaZO/IrWys84gkjj+7aoeeJEq6ZfEZCYUQZpafn8duOk0t3faVIy8oGr76qvN0LoP0eSYdhRxBSJHQs7xHC0R6PoNtlocwdURnbZNcHVhbLh/KYnCh5/618DMrfkfB3+7Vn/Wek/dm888jlmM8bL6wuVl50j4tz1fNJVjarK/YHa2c1N/X+l/fV7plF1U3usTfjUo0XHGdXfA62mbKD+XCWV43l3Zrn3bs6b3d1idqX+Ir4Ws8a7zUM7DOgfT7d2bCzRz1PYx5viYk8X/a0iD6bN2J/t88j9XvP6vh8HenD/jwcei6+0CHPPgo5Ynd7w6hMu/bsnm20z+V7DrQV9/W4xkTWHJav18uv+7lzYXfUGJ+0RP2AO6/Md421mJdfW1R6IpFIJBKJRCKRSCS+EyTBPZFIJBKJRCKRMGjm/6UUE1SpJ6G9NZ+sak8a6veaiN2oAOiSuWqd1ebiBBwkWT2KcyJNa620dpI/doSiUsuko9/3UEuVp7N6RI1ODFfEGxa8pIG5aoODk3JuHzFp0mWChNX01RQAhDpO9bSBZxacVrABZRaQVsFuqwvtsIHqaGDd6mM6GnzueRlRISqbyUDdz9ioyuNcxTnu6WU6rgTvoyQDVSZDwF8Mr5K7rpR/ltzXcZUMekVuRLYiTUTXEaXbIwB6hENcGxVxFteZaD88QzSMkHEYYRKJtN4a2fN5a70nH+uEdYuOs0V/m+u2I6Pu5OE+xab1/NjPHgGJycBy2D5Mvxp79jMjMHkkWW8OYn2jJFZmE5uvjHylxjv7vOvP3Vi27RWRj3tk1h9qDDKgbmwXb+4jkY3p9MagmhPe3pi1V6QflL0oZy6rofoN/fMu/QrYHO9gvk3dtzar9nnGNk+fTXulDZTs98SX1vergvcs8xbPAleeT3d6vTxeGfXcp54lbfoz7aGeNfH6Svuq73/sfXx+ZzrUs7FC9NmQPa96uhjXmH2XpW9q/c8CZNTK9yK+PzobPeJnvfV/tx4wAjvTy54/VNl+j67plX9veAg+/hCbG9gE3+s0NnbKnGe5xjxY1Kq/OtcSiUQikUgkEolEIvHdIAnuiUQikUgkEokE4BE4aUfgpR1BFRvIqUswZy5s75kglJVZykwiLs0P1tTCT/326iECckvwq835e0BVkXKYDk8+I3/hPUa06nkVgYnpRTJfr44vYw7aUdg2OtrnQYKfDAiBBRinADEL3LHAvLJzR5L3Aos7EoJLlC8wpolNqNcjiasgvNXFdCOZvJl0ppPZYu95ZBG0TQFtiODV4O1b8YcyiPyLxY5EhuQ+RVZ8FTvSrFofopAEjY0NivQZkWfTIyTDK/WMtH907VXy8a/aL+zsZYRYu3fAetu2mtfpmVjc82Aa5lPkaUa4VQRarD+WZe2KZCIrlxF9mU6EauNu324vhXZ4+x7sN9s+uPeL2MjkMfmsbraONp3ZovrF5sd9pb2v7N7NYRwfrF6KnP0sdm3H5p7nN7y+9erN2tyzy8c6N3Y2q/m+1xTLx3y+tc8r5+V7q3HgyVC2l3JtPF5NZ3rw2sNbtMdb4S33Ot8E3qs6r3RZxCbM45Wxz3+b704Ke/Ziz31RfSjD06ue+5jeBv92evBZGOUy+ey7gUjfyLqa740i5UJjM/adD96/6lO8ee/vV/SehO2v8J6Vz/ZK/ZoR1r29wJX6476Z7XtLKcdhF63Y79Hqbtw787KWwr83Y9+12KSGCUeR+/fmvBOJRCKRSCQSiUQisUMS3BOJRCKRSCQSCYtWamvtQV9eAqKtDHL6uMZoZJ2jN5YMX/q1vT9/XAI8PXZYa/n506fS2kFmCJJlQ+SEWseJ7az80KnKG1JRKWWShcSxiRxECPsYFPSIZT0fJ7XbQB0hwI0/Tvu0fh9stCf4N0XsMPVoRqGop63hlEaCeosaFbgfQ7VNwzMU0Ff6FFQzWvuwKXdyMUjKSACeLSz4r8rtCAQ7OyN5WL5oPHqnYyfnlRBwho9/sYj4f0bA2JFR30LvW4IRR56RoUiuEYLps2Br3KukWJRr5UVIvsq+HZFyl8baEcnCaA8jcO7622tD7GcsvyNQKzvsZ2YT1gMJTozMhGW9cTHtrZz+3MEb5ywddUXIyliekdAje0N1bWXtCGZXSfxsvu7KIeGejdedDaqOqp3YZ2/8sBcMlIzo3EY5PScr69m/u69wxY/u2ikqC/vIG0tvhS+hI6o/qvNbIpV/6f3KV8XVZn+2ab5Uk+IzZv+Lz4n490o7eM+ujCyO973ndMxrn1ubyMds89rbu8eesS/IadMFF0C/07D6l2JY+b2/4Hsnz+D9elhlR+u9mPcSmaeTfa/Vr3GPtANbxyPrJu6xWmvl8/G943GjlFYeX3t531tqw/hQVd+PGJ3TOC2l1NpKaa3UW/kU1J5IJBKJRCKRSCQSie8ESXBPJBKJRCKRSCRm3Eup91LLefg6kr/pzzAf0RlGih95Cs8zEkWUqB0E958/lfv98ypDBZdobE+TuVaLjoBa1aewouxaaql1DsxhfkWIsuQfJJZFCC6M6K7qNF/PRDPM3+CzDFqSIPZp+xq4NIVFGQIb7BPlR9oYkrWYqvJg+w5t/jCT/MssvwOJ5UymLWunAAvaM5IB5qf2Ctigvmcns+eK/Cs22bxX+uhLkVYSvzpECJwMX5o0doUwdzXve5Hx2LqKJBN7byeLyY4QWWw6EoMj/YhrMKtbRI5XXuVnadb2iByLXRlGcld7Hfy8k7kjCO9eJHiGXOqNqxhhmedVRK+djbaMIlOjHI+8xdqWkcWuEJiRgGbl4me1f1X2R8jK3n7VA9bXq3+EwPcMWNtf8bGv6o/Y9hZ5f1Wk6SeQ7WPwLTcF4/hGvnNgXOML31W4YHr6M9OOLGttYTZdscXysJUcQs6VdnlQz9DWlpHenDZoc7mrz82AK/sbYowzLryOjFu3A+4VsZj9/maWvN+zRfZPak3e7d2jWPZQpr0nWTatPey6t3v58aefxnd6h8FK0fyX5WX+Aw9gYN/zlLaMkfOr1ZoE90QikUgkEolEIpH4lSEJ7olEIpFIJBKJhEUt91bapxEgpL+lK6I2/VT3ZiI9tWoCcDFpm4Onbrdb+fz55/LHP/7klp0CVkewKESKcuzbBdlcck4gFsfIQja4FyHxeKQhn6zWm/Ak3TDS4cjsxEtbaePnnM//+zIH+bwaGRCQHKdnLbpV+nx7uWafT8M0RuBRkJGa+IDBSmxHZgubdlHs8nvthXrRNjVPmUwV3MU0j/jxKt5T9hUbImmJbxJPE9G+wT5+5lTdqwTpV+DpeYbs3dOvEvSvtA/ef4aAsyuv1nJGJr6qc0fwZnsRr5523Y+ScVEHEv2Vzt0LfV76bi54tiIYSeuKXEbYVvs/qw/7PEICV/kUIkRs75TUKyT0yPhlBHGr74rsZ3zKq+MF+/XqOHzGF0eI/8+M2feC58sT3yGuduuVoec9B74FLLF1R+RWz32RZ1hPjvcMWcU/1NP/bb6LofesTCvHey5kbWXrwmyxBZT84xmd2y3Kq+fti8/S1/0TNhrDfm/Tpg7U+TwLprW9+d/f2L2Fuu+9mOd9ZxbZs4UwfQUDMiPfRdRSPn+6l59//rncbje/FXfvIrDvUdg4G/kOQ7BLoVwrpbTW7p5piUQikUgkEolEIpH4/pAE90QikUgkEolEwqCWeq+lfH5clzKf1t7mv7WeBPh2SjhPczfEaItmAjfNBHJGcG3VWWspt1stf//3/1Du97sk2dggXSdP7wg+Q02v1pPEpy5nKmeI254NEbKY/ayIXtgGeyLTSliaAp3WfgiAK5Jcg7RtYBLafrGn1ikYPmxZxh5aMAwZ5ZY2Z79GsBEnCQKgj5bzPis9KsC5I0iwmDeWrXBt72G6Ir/jX2YDAyNHoJ0KSq6yHfN8SZ4UI7UkT+v7xxfu4yiRWOFV8mD0VOwrcq5gR+Z9hvzNoMjF0fo/Q97ckdcjp4gqqPZRewmW3yMzefcRu9M7XwW+yIfpeB0FI2mxPnmrOnmk/ytz/CrBG19E6HnYfhTnSWRfHfVhXv/tZEfJ3rs8b4W3HOu7ebiz4Zl6vQfp/OoLKwxJhv8CeHsXHZcd1f3MMPBks69EmD7v+a85+VB21BaVhs9Ku+fZyHMjlmfPNVYG6mfPRAzLPfGdUml+e0+JwBDGsux6S0iOovt6tk9V8PeLjRip9hu41tSjTGQPYYnsleT11ne2t0Q8+/wiX/JT8159J9DvHf/avZV/+Md/LPf753K7qXHH5ex3EMSgPharNcQY1j/C8Gmt5QnuiUQikUgkEolEIvErQxLcE4lEIpFIJBIJg1rL53Zvn/xIDhLRScCutfnansJdbXSQ6JkIzef9jx8/lh9//GP5wx//8BABgUh7qtQjyQmYqUBtNPA6itTp7/nnBZLMFCTjxCBFsjtFxIOFNmi5kG2MLZimbJqv29JGW9sI8bs1okfYMYKBpA6rjaBsY9pE9Fe2t1LmXz4A2VESNtOjiAf92iMbePBkMhv71EWdnu07vbt8O8KF1yfe5y8J1o5vgfciGr0ngSnxboisP4hXSZaWIBmV9eza9Qqeld/b9JWXBLz7O+IvrrVI6mFEWaZvR+a+0ofP1icqY5fvKoHelnvlpQBmk2rLZY/4pHxPdhS2vXB/qfLviOTqZUtGwn8r0nGUkMfKRcne/TpCzvvauOp3FZ4p/97++ll8q3Z9V3jrqYB7fG9P791XeCt7mRxFYLdp22c+UqFdPcljrLQp8uyJMr16oJ4dydz2myKPRzHV4Ym1fGQLPCiz5/Dp4/4Bu68q9HuHzbq6rqVtfNI2xCfHlRfGuP3rXoyt+W+1ToHiMr6XEfdR/wIYArd6Kz/9/Kn84R//UG63W/z7jE6O7zVk34t4Ntrvjfp3pZOvewip1dSmlSS4JxKJRCKRSCQSicSvDElwTyQSiUQikUgkLGq9t1I+l9ImUvEMyyy20aMjCtPTLLG9R5BGkKcBCRiiPyQAe7vdysePt/JXf/U35dOn41QlQRiVxKPFnDZ9VmmI3UmYrTVOynbKjHzGNhV0nAKejZOJbJmKETxSl3jI8TztkZF/ZjvnUo88UwEmfsGuvRcxi4wnAqpDaBvXLrkJiQhTUJIYycjp7DqCKHFBxcDZ8LhCOlAkBSQ+MJK61cvyWflY3mtDlM2uVZ5d3rfCexJuotiRZxK/OLwVgeQqOfeq3i9FQowQW6/IQBIv3n+F3K3amhHad+TbCJnXy+u125U2Zbbu7FH3XiEYKzueIYtbm/C6f35mTFibrrz0cAVqvzjr1+V2sll7Ru39lgjkrA/8Nvs6tr/q276lNo/gLe39pdX9uwbb4+/ye4gSU7FMVCc+g3R9EcK51WUJrspmlq6euVj5Cv+UXFtePYehDiYj8ryLdkTJ7so+licKIMqv8vhe71FqfEEw5TkNUS+ToQz+fU8tuK6eDTW/qGb3p2XSaMurvYn6a8ujfbZe+jvD90EttbTawnNOrpPt/FdrLZ/vn8rf/M3flnv7VD58+HCWapAf00DW+BwZ0/hdyZBlEuqj34foh+wkuCcSiUQikUgkEonErwxJcE8kEolEIpFIJAxqKffS2md6h173pDr/7QG42v+VIxpjIj8joGnkoZqjzIMwXsoPP/xQPv38c/mLf/+X5fPne7nhSdmdHA7ByBAYCdYpuiU7m3jlOGFKEW1tPmqaDka6MVkaqFzlrsFKn/XKTulUOe39HpwdZUmxpV4h/okYQ36in6WpGyYZg5c2SMnKL4QGpk+onT6bOaQCqVaHtdUjIjDSgkesUPc9KDKFl28ny7MVoeqr2u4t8AzR5ksh+V3fJd6SPP6liOhfClcJzZG8UQL3+nLW/BKBuq/kXbXr2b702ozZHNX7Fi9FvCV5/D3HemTcRU453Z+wur+nXp6cc6+ENg9K/hWwcl677V6yfAW7OnwNcvR76HxlzH+NNsi17Q3wrVbbeyaKEJs9earss88g7HmeEVUxXT1T4TMbe8ZE/Z7t6jsN9gxo7WME9gpl2fPpro4sPfxsJDJB8lP+aPeVR8EmO78DUZlOO/ia2GjHrrb3fGxtRRvQxp7Wv+NRxPyJpF70i5OsPHvRE+0PveT3ij9i49WD8CP19qjPX//135U//OEfy29++Dh/RbLzJb1L4WtQqn+ZB43U4RDI5mQp/SAN8n1tIpFIJBKJRCKRSCS+ZyTBPZFIJBKJRCKRmHEvpX0qpZa6nLDOrk3SFLAxeTBw01HhQ9c3ToA/M1Vz9Sd/8tvyD//w9+Uv/v1fzSR3RVZVOlUAOgA8ASskE0jveK/2QNaraF1kjJDGTuntQVEveGnl8xieJpBhQBXv2XowMRVfbJgV8HYPR7BJxN0jRSjigJR/fLBzppH0XkYFSdU87MBytZT5NLAibACoAC3e88gPaBvmVX22I7TYskgKsbqwrgqtrLbs4BFMmK2vyEwkviC+V/Lf1dOvGanHyxMBIwepPFH5z9iF+4T5ZbTnSMtX2/etoE5nt2C2fSl7I3oi/fXMiw1X8+2Ia6oM5n2Ll0O8dlN9+ewLAlfyMN3vjW/NJ39r9nzXeKWpn3nefe+u9Z6d2FcOV7nLV/OjHrVnx+cEZZ9XJyTBMnnMBvVMtCPWX8Hm6x75HKW+52HtiDKQQD+yRRt3j2YbL9gueAiAxZy2W9utjN26ytdPawsjuSMRXRHhGUFfvViJ9WcnwI8y9fpLcSbzit1XNuz7DHuN36WgTFOmfngY8Nd/83flb//m78pvfvPx/E4SX9zoaWrOoQ3KxukdiDrnG4aNyp4CzfdFrbWfifZEIpFIJBKJRCKRSHzHSIJ7IpFIJBKJRCJhcPtw++neyh9aKRcDoxCM6ZGchtEdIrQd/xvBIGDNVktvL+V2q+VP/uR35e/+7m/Lv/1v/6L8/PPP5cOH24P0vCPE7u4BaIAuErTu6SwQLILmUQLPFpdiinOwkgVzWTC1LQ29kq6wXP98xgTXoGzk9NJJrZElSU0qGP8soH3fluBjAqr2RQ8MrKq5dBq1lm3BZniGRGL/db0qmBvVzeaZIuV7pI4q/uI1AxI9VCCblWGyo237DCnllwCP0JRIfEVET35+K38fIcd+TdI1kpW/FJH1LU6EfouTxL9VRAny0fH03uT+tyLsvyWefVnkWXyNU84T3wje8dnjkg2KZBzVh3u2V+rFiJ9YN+8l1+gLq0yvqpO9Z2UL4vVkk9rroy72fLOrQy/nke699sR6sXKRdlT3d9+5UNniOX1cnh8m31ltZsWI1obYU83PbM3k4GWv+u9Vzmnv+b0HX6sj67Yth9fjexTSnuwkdrb+IzkedarDGEIvxUXH2W68ReWxvGY+1FrLhw+38vnT5/IXf/FX5a//6q/Lb3/7oXz88OHsdzX3W+PfK+xsrHCzf9fTie3t+FBrmb9Dndv0fm+ltPJHXtlEIpFIJBKJRCKRSHyvSIJ7IpFIJBKJRCJh8OF2+/Sb33z84+dPnwPBb8Jq7YGZYoNdlZdbgsMYbW4jXyv3ca+VUj5++FD+9Pe/K3/4wz+Uf/3f/NvyN3/79+V+v5fb7VZu1Zw+3yA4acyxeZagWr9V50bAg5Ym+6PBdi/g7AXTSzzQGiWKs/veSWVr/pPwzoKnWO5BZirmWp8ytsdKah8ySEC9LVej0FInT9tafLV7Txrb9COSFex1tImIDJwLjQ02pVsRIdj8sddov0cwiZItFHZEEWZjJOCuAty7NBJQd8u8Erz/EnjVHksGuPJygbr/7FjBct9aOye+ON6b6Pte+F7Is+GX2xx8aTJ+IhFBjscD30szXKnHK6T0t2qv3UuYUdIpK8vyRfbhXYYkjwo9Xjrb27PnGfP1wnLPQ+T5R9lRzV/1sq3a/0cfJdEOTN+Vp4h+qXEFdfqz3hUDo505uG5VGfweZ2741vCl/bMB/ef7Nn3q97r9Zx6caPP3IAWktCmlmeGyfwmzmrZdp8j8vQwvP19Lwn19p72n51dOo+a8bPjh15PTrVpuB7G9tXv5u7//h/Jv/s2/K3/3t39Tfvfbj+XDxw9zvZWf6IdqqO8ErR1YnzHEzrHwILPb72jaIs+2+b3dSyntx7WGiUQikUgkEolEIpH4nvHxaxuQSCQSiUQikUh8S6i1fiq1/uX9fi+tffAzNxZVaiPogz/fjJettFIbeed0BLCqSboVG3RspZXbh1v509//vvz404/l3/7bf1t+97vfl3/2T/9J+d3vflt++OFDqfU2RNx6EBH4+I+fVD5iVNXoZvx7NG/OPspUk7EdzbFm5sKHHbJNjnatmLlBkO+RYQnkjgCnSa11tGppPSray5of1W7mpYBu7DDB9lU97SEvGtxMQ7ej0Uac8Oh3exr/OMTKBGynMO1o01Zqq6WJBryZ0hhHVLLnuCoP5lZo11GPWkx7HvbZYOaiZf0ZcRwzdqwp2LpNdTJ29A/1sI+N6TLqUU2FrAxToF8cL4QMG8b4t5ac+YgQ0NGFrPVYKQNEjPUlVmcfVBV6WbQzi2GXYrsX2ATjZLc6jc+HA5rtaK1NTTjVHvxVz3SSHub2Oes6qym1Tc1J/05KoX+WBiAD83RQvGwzH5c6Cfl2HvV6LI718CS2r6GNT/+IbWNsdjvY1rWttlp5aoJOA9V8aJgGsvlqYx2msaGtxRc59hIm05C7GLzWYRk/tm9UPdiAK0c7Mw+0A/iVBSp9d1/YWArxhW+Eqfp2HPV2Lec8Bn9TsR2wT5a+3H0u+6ajFRD9wZaPxV/OvxvzHEg9QmVYG3l5IW1yapjvmfFytYyamJi2K69MgbrFnLiQuyxOj/GLZK4x3xyzF5uwgJkPy97jhTFG5qCbf9Ln6J/WNchn5/+077d2wOdpj4N9aNY2LDM7l9OWyU8fN0e/qcZga53KasaA3SvRvQdXMeuAdRHbli1Jo5wpw7qsyx17SVK+12PqnzK31ZBt7nV7xlpQTVlrg20jYgdOv5tZR6yt1ei343rJW848bG73x/Sbk68WaFNjM47JpV2gfnZqVEic+sPMK9g7Tn1zfJ6beR7zcsgo2K62Q6Gu9xeBy+d6yDlJ1IvcI115mdPuQ1Zpy9RF72zl2vtdjiVhWx1LO4IW229t2vPM6N9FcOl4jEIlI7OO9sJpW2ox3w2cKlq1pUsprR7DtpX+bcLZDn2dMXVo5fi+xPpX05qj8GnbNP8PQ2qFerdSlm8nrJ5Dfd+mznvDMnRMa+5c9ekkOD3GHzqn7ymmW6DX3NuuwEYeXWpJwVYehjPPZN1Laa3c2718/vS5/PjTz+Vv//bvyh/+8Q/lw4db+f3vf1fqrY9q4qOFjashxfhvYi92HxVgk4i/LqX8/OlTaa38FbEikUgkEolEIpFIJBLfMZLgnkgkEolEIpFIAH768ad/db/fH4GouwlAFiRMe2ji+ozsTEE6G23sAehBTMBI8L2MkOKtlN/97jflNx8/lj/+9GP5d//+j+Xjx4/l48cfyscPt3L78LHcao//1SUQ3gOQtdZTrYmADs0T+93kGXL8pmhd3gg6nq1Qmg30VsNlsPKn8OzStHOot4ygaA9BnvkPO1BH64FuCOrVUwpCB9SPAHNrZuzM9va6jjF1BB5HtsEpIA2LkXRm4hLTncfuOIm9GnuHXUeeZgLXRuYjAFwXrjKpxhKvr6WUe7NGn3oHH2YQDuppB8avR9+tY2+MBTK16iGw2z7aHgvbz7buwA1B+0exhmlrlNfex/IjLjw3/XAP0/Q77sMUPV7caOUcA6seBFpZ61lG8S/QFi99bjs7gLofMunN2APl2lGJWzUvRXRxjdR1qAKd1fzyAjTMybM47TmHS53z93tTn57tb31ba6efud/POs9jpfswQkjppk/sAet9bP0Zu8AZAJiz93st08tQVkYrj/lYay136/PIfOgY43pad1a7mmm78f9J/jxBJ6LRaKPT0naMgVnfo2HrrRqZlcwV+4JOGy88oc/EOj7yzmtnHX63nf18dJrljzucp9LXjzE2RnOY8QN+ErmYve9snz7qdIxvsKWXtb569eNizBmSIr68dJZ4OPnzJM8x25axUEz+7vvsOGO+dcy/Q3+vv5oirQvq87ebXOc8tZRzze7zAMi1a3vZeQ7qWx/L3S+OCVPanc/feY08LsZCeC4k09rY/0f6eZI77GpjXJWpDc46TsYcWtrhF2aXOZeZXtCpZ3/jHOwykfe2tgf46FG3eZ9n/bECuvo+nKHpYDXDhiylllsp47TcetYb9XUZ7Zy7WNdRlz6WW+Pz+1B+1pP4t2r9wFwvPtqMXW3OU8G+U2IpZa65lDts6qnC36xzq5jPvX0e1/YFVdueKz0UfGmd70F1oH2mlhi6pjHW5px2HTLT3Mg+Zfb165Hn3Bv0tsI93zLhy0nGnarX/Ubr88bYcdiw+IWumixQ8xpBWmeac/NIa70t2vw6cj0G6JQbhsO5lna/WTjM4D9/SatM7VYPP/pI7x3TRnMuz0pk/RlrsJ1ch5obyfdQ9ch77g/OUb7skXB6ldm3z8RvWAuN35j2CsOOMtV1qnMfK12oSesdz54z1rk4Z7J6Witkfp35Rv1hrjyqcq5Rp685csD+ZFp2+p06N+3xdZB55j3H7zpXykgffWfncitzBY7PU2v0yps+sn5u3vvbhnmUPXMzGMOWVdg2qpFpksd2qJg2X0qf3xx04v6yAzJjvpckw/n0Vo0UsUqPgvhreaoVsKZsZSmjrbsJp/Zlz9B9qLGndnuGfcc8G21yYvJDpYwXALpPHy+C137iPtjbep5qW3me062Vdr+Xnz//XD79/Ln8/PPP5VZL+ZPf/aZ8/MgP9Jj0sMYUQ3Gk2YGNf6Uwq6zBvV7He/nHf/jjH/75P/+n/7WSlkgkEolEIpFIJBKJ7xNJcE8kEolEIpFIJACfPt//5eeDRLThvSx4BDMxIIN5zgDcmWgjRHPYC6NHtdweQc5xolYptw8fyu//5EO5t1bunz+Xn376sfx4/1wGYW5E0xqPWJmAWTuiy5bHZG1bguy1UJKYDdZOQdQpON5N8klG9fYgdvEWtTpJ28L923G83oi1mfqMoHUxvTfizIY8UmcdSzDUWDOf8GVCpCbWzehvD9u6XY9adXJKJ6FgMPcMBD/k3e/GjjqTySzp+xyxSGI1LIdDx60aMubRftWyvY7IPhKoRoD83g4580nc7XibpLY65e+R7daaGWfnOJzHjQnsQr+u+TG4D6Q60zAzCbVMOO1vcxrKgYB2sTa1Hro9+tqyI7r+eRiZtnsoq3Wu52gRM796f2G9z2A4eJ96tuWIV9uJW0y7DAnnfTt/OjGi/2JCzzHNme4bjqT7/QzqP3xTMW2C1s/1teagb7GEs4kc7DiY9QWnlR7RyWytPH4C/pxj2NbHmJ7Iqs3Y33/pwdr7aKDWWrndTuaAS0jtaWVeYuyvLvSMSCbt/TPISMYV2LHXpjZuw0YcVRMRzrqVUxkhCdmy1ipbnjqyUnob2vGAtRt+rY32tnOjWaLR0f+tllLubTDUJnLayF9KqX0MNDMOTpvtPJiMpraeZYrNZeZ2uzfia2a/1+2r9bbMETvGui85X8Aopd0PuTerq5Ex3v3fPH5PECdqs7ezBUa5c9iMdhs2m76fyZZmnen9bMhWfa6e8/Ysw7qgQsLZrueYGaew4rphq17gQ61La0zjeuhf17XJou4fTANORFk7Jnpincfv6svr0i9mmp+1aJjf/DJHb2czF/sU6v15OqCzrr0t+4sWMyHWVMjcs/sJSzS15dAP3tu93Or8S0p2jRvrieNnhz2QyY4llNnrjPaeNsNY7M6DjJfJ1nYvtZ57XPsSH65eaq2b1wK7MIKEsacw5Yypj/22ebG2FXgx0so27dCTzS1r7+hnuwlAb0r8yRBt93MTVuLqXHD1XPPwOlePkzBuxj8UaGUe3/PpuXafts7LSVjfy6Bdk282426q2CzzMTfNyxC2/cG32Ta+HzeWl0ZRZWmPxr2ZZw3TTut+xrycYcdGK8Xu4859UX9xsA7/MXxnOZ+fuh+0q1YnifaG6HnvfVM2Ve18/u72n8vi42Lew53tfK61tg/mfpieV3rVYfw3sKkVk1jsPTZ/sZ25T+ht3Ifw5MfKuS6d/qoZW9BvH31y7/ufc3Dxl2/m11am510cE6Zdup/pz8XnHmC2bW6Ac+z2Nut+H1/sss8C50uG8+BsNq0Pn+4LSp2fSWwfmnr3FzWml2BMmbOTTvk27WyTSofAPC/MuJv8nVk82tkj9oWLue5Ls45WNx5i2o8Oc1GnnQ/lJG/Xrt9UdPzf+KdT68MK+fxm1FnfPa8cczl8XrI4+/4cH3NjGBldb9/X2u8Rbqcx7JlrmD/1v/VQk7scrXErpfzww8fym9//ttxut1nWaO9zCZ6qbmHm3nLvnIRzvZcHbiv8zNzK3fSXVVSGD/mHf/jDX/7H//F/+P9DzYlEIpFIJBKJRCKR+L6RBPdEIpFIJBKJRALwz//ZP/mv/vCHH3/+/e9/90Mp5QzsjuCaOXkbUMnVjN0p8COCWjDgswT6ag8v9+tHIPd2+1g+/vBD6UFWatFBQCw9IGYJGJMdPX2K0KpKO/WeQ+KD7Yq6RzrKOgkGS7DwsMkN37PI72Jz47dH+bnvR1yvB3mNlLkK0GYQq7NWVXJvVPcgBPTTkpFMN/qmk46sBGvUEglfrFjqc96eg99rhVlFsG9n3f103n6PhcpplxQTjF90P/QhidSoOUlZoAObdBl3kMSaA+u7cPPK0jouqHyCU1aTn9Z6dj9CptbGVjnnBI9AjnsnO9ZC9aGdl65NDdK8jvAC+grDXRpfHymnZKEdi6zdiY1X9JvWUwNCyWH58X4pa3tj3awZzRljSs+SjqN8g93YXRyT0yjL2jgT0+ZBbOS4/W3vkfXYg+fsqM1YBOxltrOB4Olg/d/Tcb2YnPa5Jp9FiIPtogehbrOHYfsLtihjsjeeCex5rHyNJoV2bbUsXE9i5/fkokfyq7JMjtVfSYFn9NS+V1jvsRfCxn1my27tkP5CzAOFdTNR6IBQmxBlq7qP+VxbnPvsLalix7ojh5i4rfcVu9kYU2XHwEFf4WwWFn28LVCF7IdS/Dru1luiSoKsu1TCbvy4MDsi4qumF4jRtsDYe4ytkziNhGhRIy5TtUPQ3zzbT4t9MA5W8XMt3PrQEqvORU7AZm4PaJrI0Gd/2Rd2nNnlTu/d8I2474W0Tqpkicsca+uqJY7Zy2y3Lx7KFpqey+dJ0XVMv+5gviswFQMbYM0lz/T2VHGsL62P+T6JfX2BPTnkF5vJGyUmq5FkZeox2qB/H/fOlYsstpN/N5/t3mW83NfmfEueYvQRe5e1RI8sVsslDxSz32lNVUChHTs/1onsy4BmH5SlXemc3lopnz+38seffvpvfv8nv/tvN5YkEolEIpFIJBKJROI7QxLcE4lEIpFIJBIJwG9++8P/96/+6m//spY/+xdnLHCECY+fIQYahjlJbgcdksJ852mUcxC7jr82KDufyguBIoyHGjnF1qfOBVpZT97l5Og1NDvpWIgG9Sxyq2dw7YiJVYjt9ZOgRvx2iDkzrfx8CCpOwbT1LK+pKrY+o8NuU5keiqz1NgUfp+aq5ynOeL+3z0nCsBlOC+dAZR2N01+6eMgyuQZh5Kzr+L3r4/4ZtD0VnqVm0uDUsz0IPjfEPFarDVqfH/qJegtqnczr+s8arS+F9Pre+gl+5w3TWKYOvWlMrPgGPztgyex9hLRyRuHrrZMyVnm3cpIHTjlmjB9/Wz3v93Ewnfxr62Had2puFQOe0kwJY6/Ve/45+2hqA2N39wFj3Ng8xIzzlGUI+BNbR3sYIzmFoUL7ztUcftD04TmCjC2l3z/8pz1l0+TpLw7ZUwOncQ1t0VWMk0PxHnObpEnsXO/tbabRmPNdf/9Fj2GzIXmd8uZBtJxcSlq8ToOgnPO8MuLYQUiphiRUZ/1Dx+To2uiL0646tRkSj+yUYvWytrd25qm2TFnlnvVZTz5+JM+LUu8XK9nK5eQ65j/X+8tYqfNJpnY0nH6V7ywW0AG3OpXpZT7ro6dJZ+t5m9LLIXas2cq2W88HJ41C+sOOGxQGD4Evyo0m6T0/t++8R+lCbP/WJV9fE+hJxU41e9n5xPRz90aGCe8rkwbVA90wluwUZw7nyMN84kMHtpO4lvdnXzJk2zWcOf5axv7P2r34CmbHNFRNv5pya13hM5y0W2oZp0K3aaNaIC/OR7MulLnKi48s6/g6bTsWQWwrWnezsPfNS8/Yp1Iz+dSYHvWZhM+2jU0RGSdt1Gjy6Xgqb5mu+xp4zsWT8EjsrGWSM2yrc5+u+VdZ8352Xh9x92xqtuozm5Xlpeg+Fuoqw7bbpGkqbl9yXtfmM/u8F5h9GXcZxtmP9jhtPFqnwlhlgBepq81by9SuIwfvqvG/ueWP+/blpVLGr0ChXdO63OY6THl6erWpdpwf2rC9+3oBbdNwo8zQSln3bXP5OvIVu7DuYethnzVw72rzs70rriHVlDMLUS3lcfq49dnDPxx/WinNkNtp14OOsZ070ltrx1P5MaqNe1Tr3aJvPC+c2qt5djwG7doeMHkevuk2l+vybfOYxwK70lTbdqYJblMf2xK2Lsfz8s0WfjTU8jTf6z3GMZsrrUynb3fbjnUEn4PMjIB6zdf9u7NTvylnKj5WujrP2eF/j74/GwKJ4VY/77RzH1ZnG458j+cqK8O2+OM7n3qrptbn+Jx6seux+5xljaxTmdoba8jqdTY1Of5n31XAk90nTPOU4xyyZM1cXeVckN0f6eeIP09mxzaFfoPv1ebvOkv5+eefS7u3//J3v/vN3zqWJRKJRCKRSCQSiUTiO0QS3BOJRCKRSCQSCcDv/+R3//rf/+Xf/Fef7/d/cRsRwzn4twTOTbCOncE05RV6W7kf93sQp+s+pTzyVJNn/fuw4bAETvJEgpcl8Y4QfjUB3hFYPwJsxQYz5zohCexGck6k4UfDTeHHM/hYZruqJZ2seq0ca7cNJFr7EJVcnQHYOX5nSXijZxT5q5l6zUIeH5sNtPYiM9FvDRbPLTbZNDrWlOrBVTMYa6mTLZOthpw46bXxyNG8hriDhIcCOglJbapKmxNHDepcTxp8NUUXYrod63089wr1bE7Qd1SlEyEsqcUOl8KIMWVqtxvYVso5zlGfMGM0K6t3KSbw/xA+k7HLORSkvjGE5rk6jbre7xAxn2e8jcajAK2f+otix3gZ/mCkq7pMds0yGOHsUV2YV5OOua88giUS5M/ba50ePzHP5/3Ig41D7Tv7+9Q717GTM1Wde9uQCk1+gxG3EXN9rC9eiYiTTOtjTgcy1qU6F1r8Ufd53rS2usZ1W2t2dkTPs7a5zVsbtr80gPpg/rmOMYIOyxJ1FpvZBgTzmDpZu3BdeoizhNAHCWqaA0Sf3wsmH5742P1tqfP4idSNzcupbU/fv7Q1m1N4jfJwTROfp3WXmMym3SIP12X6Yc276FK37PpvxvPaTo5s2jarn172BNOYNOXt2rEjWtny0z3oV+riRN0LEKwqjEmc63ZgwViozfhlO0y7PKyz8W3LPMe6L+MO5NnPU7tW3QdzpYTquup3sLQj7PHGdeP5z/px6Z5t9iWTSva6aEP/rCntUHaRqdcLtYZYP+j5T7ruo982PvS0xqoi+2n7vNCw/mdjbn27eZlWP3ut6cvLZ5X0ab/H5I0uIM/q5dy7jj2hMp+NpaNeD/K+P+C9cYT7oSHaTPxGyvX+bObZfH0en/VMLzjgAChnm8l8kL+UsjwfWLTSx2MrbanXWd/lHSClr4/DOqdX2JOxMtbWWorwGeUc77bsOlmkvbeDpLyMiV5P+7lgFpxvax1QP7yDIl58hl364jMPUje031iXUR7Wx7axWgOgH3AN435xvrf4NLYfHJfn/NGDa7ZjteGUdPqQ0+fUh1FHntMwPP19mDs9B65PQrY11u8WDK272vLGZ/RnneWlo3M+d7/R05QlO59GwYqIvQN/biQCgNyOon/88efSWvkvL1qaSCQSiUQikUgkEonvAHj8USKRSCQSiUQi8avHx48f/vHTp8//xaefP5V+Cmyt5z9EKybQ3TAYwyI/Nop6BngeVLHb8ek+8swn8t2OINS9WLSpTCn9hKlTyxkgbEMXCzrV+fQye69ay+f/FkLCVLou+s47jKDg24jyVsmnFMSOjrAE91j8fgqokkDwXtEsG+PhVciMEAH6tSHIcNUBA+3wBNnTKdU7+5Qtldyv5J8V1WZBbFz1dJyG6uRHOAZ8lWPu0QCwkW3HpL3f242d9rjFRHRiM8ZmPU9SraWuL94MHgUPOI/2nLr1lDGdkgkdxEg2w4a6pqPuLl/5C8QjqB9sQ1aezF1mj7qPeSixxfaFaS/lD7G8UbT3KWRZGXVEn2XlRkHGBM8GBC6iA+fV4r8K+1zX+8TvhWXXs4zUbRHNZ9WzF588G+YtwXLfHSM721pZxxGQpJgs6w/muYzO2dFji+A/JJYxe9RaxPShPE+mtVusOUs63vfWNs/+yD0vn7JX2aXyYj5v+6o4Y5H54PXJVZnFzIVo23WwueaVs77Ulses+FIhyrDz2Fv7VfvjXEX7o+MQ05U8m+aNtV07ejxDllfpZ/dLmWQvazqxTa1dbP1G2VQ+F+briMiQotUAFLqFj7f7LUeZEV/pdcQ2um/Ck/Ur2TvYa5yH5Hq3H2Sk78WuXZsQ8GfbOmRetbPntDZjWSUTn5Ptntp7Tpnvrfe1lb7z3+2pw9itMeQ+9bNsHWU+Sq0Z9vN0vY4BKsuWu7qn9Gz0fMpuT1PgM2vPBn8jdiB23wMoOd6QkesP2x9EFn2UIvIPUfvNi/yuiryEq77bOufx/P1YT9Hlz//mbwQ9Gy8uSu7gwDy2w1ux33VqgE2tlL/527///Od//s/+7xcNTSQSiUQikUgkEonEd4AkuCcSiUQikUgkEgQfP374v/zxx59HUKW1B9G9tSYJe62UQbpsIs7TjoBOg+jmGXhqU95H6n7bjkGwTnTtISt+Qhz/bHV328apuMu9lZCwt/UMtvNmunbaH5dwnBy3EFT8IPtEpiB8l1bKGZiuJJ8XlFVleAUeZE34WXcagGZBdxU0tsOOxXqVrF0AW7UBC6SzPEqu0jElO40ZHZZAID3H5xxIRrKJ0sFe0PDstiTSUsr8kkk986v5Zm3Ts2oltzAyTCnl+Ol1LW89Uc3pgyf5LB211IWo0v2RZxslp18gXzBSFktX+YfMikngfxQhLUJYVNjJVDyPI10SMDdEkxA5YkfKsf7V6uxptg5IbGb5el7md1lbY9ugDiOHvuCD9u3GHLMXr9GeqE9m6wC2BSNAQl3sC3yujRE/jzYirJ2qHbA/vHW1lbmdGbAcGwPMJrZ2qTGG+ZgNrG/QbrVG23p6dcDPOEZwjuFeg7UV6lPjE+c42qLmsgeWB8e70mNtiaxTbI6jjiiwz9T8Ub4a8ygb0T42prz22LWN5zvRzuOv9Cc4PpgNam+rbFNlmf0qDyKwj5B7JM/X79YMb91WPgzXyXH7FLQ80wXmwvJsAjIRuH+NktHH52baz9rhyFHPtoz0vbMLX2TH5wLVnvYztjPasugR8qy9O9K4lWvLnMNx3ecyeaxd1DMRPo+4JOFpC/UMuVbbdxiw1GfoYXsfJVetreO26IfezuJXKpa8EZ/v+Wu2flso/4FyWR6Uy/YU3v5H6ce8nj8r0J9X1qeIDVIMf/nFfwblciKY/ck6j1UZ9v1cv67lmn9hoM88mFC71axt7ub6yKwOdTBSz/Wzlvv9c/nrv/mHf/3f+Q/+7L8IG55IJBKJRCKRSCQSie8GSXBPJBKJRCKRSCQI/uyf/ZP//O///h/+srV2xmxqKf1DJ7u3dga8zhjhGdjxTkl65L2Psjbwc4Z57yPffP9Ggrb99PceyGI4A29e0H22ez2BjpE9FXnBC/LRoF3dB/KYLIslgH3emO1jAVM0upJLFYzbmUyC3VJGJwKRrBMBGglSjNBTzH0FRZJiMXt8g8MLmtvPh50TaUCVZ/IgEO+SuW2/8Z9ekGOHyWNEFCS5sAD4OGl8R8ypZ3qrfC4x3Qo7grr9bylHSCdIiLeykSyEctlLAkiuZ75gR65H/6PumUz0s9IZIdu4ZBWikxGrjhueEiqL6ouke6SQHWHE833M30TmtvVhNs3TuWsLXARZ36M+RhbCv8bXLn2v/Bn6ZrzP7FU+FX2zIh0xHSiL3Ue5RYxx1r/KfraeoJ07ItKuPt5aosbPboyyMcT6Fq9Zn2BaRG9k/jDZSqb6zMbGlX5FexiYP9z5IZWH1RPtsn21m3eb/c7Uj6h7N6+x7awuNg5UH+7GgS0X2Z+qfeJOl3dP9RXorupXc9RahXk9n7Hzc2LuTb9OweRfXYOg3PRMspvXji/EX9ii+a3fctYy+wszSt+qamyapr8uafLQNe3XzLN1K/OztLUJ93XqmYgC+5gUVPv9SN6FNA73rBy1/+Vmz2U8cqt3z3sGqFW8sEvK2zysHjvybe/ffps9g3tQ36MoW6dxVNeyY0zVQstMcvs4jazFzB46Xdskb/quwlv3LDx/tPOprIyXf7euqPzs806f8tdTUmjQUODzraob9t857o/7x3iO+hSUvdgBeq3fW5ukTvmZ32TCz7wXBjKVhDeim4L+S3LW3lKOL1SlD0X8+OPP5Q9/+MN//s//7J/+y4j9iUQikUgkEolEIpH4vpAE90QikUgkEolEguDP/uyf/Jf/8I8//l8/ff48iO0NgjmPwOkj4HXEZ467D6JEJwH3+2fpORhly53k+B4w3gfEGZG0X61B6DP4xYLyNo86rcqmN5MOgqZLrgc+d7LDEVCmJFCCLcHUS7N9Zg1mpKNigo+9mxixbEdaajO5Y0HP28i/IaJxQpUC2jrHHP28mF/ltWkV0oEA1ubKxOwvpp+qSDfAIDDJsBACGOnbfRnDlOn29Pnhkcj7fUV2Zrarcf7wIfiT5auf2elC0rzKj/7GBuTRBtZeu+A/Ja+Qn8TwyDchsGx2fML8VWMMiVzWNs9/SXI0g5rrFf7ZvMwneeWYDR6JRtm5y4t+wepq0PZYpwjh5wp3AwlB2GaYT9nO7nWXIH71ZcLOZlXe+mdPFuvrUvwxcgXdBtZ2TKcdo2pd2ulTYxrXNjVuVF2xr1m7eH1/tQ1xDLL2YPMS2243XpmtKFPB8xFROdjvNl2NPaaXja2I34nYaO1hctg4YL45MraUDiYfy6AsNUZQvvL7rJxKY2Pd049lFNDXR2zw1jemG+eF5889eYH6DGLtbt8cXX/VWPPgjbM276uWfaaoo3ouW57pvJd4rX3l3LtRfRX2daT9cb+F+/GZLKr3prYur+xbsT64x6b5jHjVvlaOVy9PBn5WJFJmu5WNe39VbqrfZkigLard1AsI9v6Ve27fPrsnAvlbm9ievf/d+SbVttH1H32LV07t09TeL7pvR124n2P+MiJryVL1OlrnnNN9JmerS5Vb/V10HvOXO9a8+PxuCfrrdmXn27y8pIFaLyXktm7TajfatfiRVspf/+3fld/+9of/LLTGJBKJRCKRSCQSiUTiu0MS3BOJRCKRSCQSCYIPt9tPH271//CP//jHEojKjovHqe7HR1Os1h6jI4Gc2kzsrgd076W5Ub02/q8C9jxGeQa7zhginuSGctegWZdVSXopZSGkhsihhuxgr4N8kgVLe18hISGx6GisEWzDIC4L/u4CsqxS2OS7YC4GglGOkm3LRNtFEX4KkGKeJU718gjT9st4GWqvkVGsfi+4aq8ZmUS92BEifJQ5LyP5zPO10c8LGZuUV/VT7bQlBFnfZurFyPA8IL8Sq1CXkhEh0YcwuYZz/A7ZjedFndNYsD6sFErymkg8V8gaHjEFnSQjbTxDENk0q9vuDf7uQPw/tVmRexRRRcnw/N7OV1mZm3KDUMNIOxbwuTUYI14dr6wxXn+o9YDV3X5Wa89V/UwXrsO7eWBtYKQrBW+rhes7A+4DIrp6e6t6ee3h6VEELlXmyvh5FRGZu/1L/2vnFOb1+srzCZG+YZ/VWGPzdN1a+/D2itYHsvyRsYhrx5U+quTa24+yeWr7spRVP/YDlkPsfFz/6613aM/VueD1GeYjY9h7iVWuu1f8QTVrUzF7oAp7FCInsr9u9kRe035ddniPHgDurT2yucp35RkiWgell7Zv42WYfWrvrvR5cnfAF3HxhVZm0+6ZSj1feH3F9tveM4zVExqvTy52y7PCQ9h0n8qO+KhTyN4Hqb2+2gup9ZOtp7umQf/tlfW6AtdfzL/bJ7FnIIbdvoCZWXk661s1ls4xvEddOkznq+aa6W+iYdp2UK1Y66Ze3nhCLvt1kuNea6WUWsvn++fy3/67v/r3//F/9z/8P11SkEgkEolEIpFIJBKJ7wZJcE8kEolEIpFIJAT+gz//s//9X//N3//7Mk7bPgO7pTR6qvAIRpm4EY8r2mD1bYTbe8pM4uwlzsjfGdw9JC7EgzVw1cp9SStDMw+8NxO19M55s0FveqobC5pO9k7mLEnPhOYrk3/AklGp/l2gll0joccGXVnAmenF8jtilU3r+QWZZXxmhCuUF23wMdxhsHtkpSsBb6bDKaf62yV6GGIJI08Lc9Z8bU+KQXIGlUPur6ewzZ8ZKQTJ8Or+DpSAvnBzVvLJlB9whWwTIbJbcpaXDyGJ5ldIZWjDXGiR6b3IoMpKX6qa0SOKoO/C+zv/MN2uIV8RIsKjzp2fVP5FpbFy6I9bmduEkWyuYNdXjFzUhyS+HMH8sqo7rgmoU7VPZFyhblsH227MXpbXswdtiqyfXl9F1s8dmA1sk2fXfjX3mExv7qIOtvdQtkbG8G5tjrSPsontPWwbeX6A7SsiezSVl41jz9aepvrjmba1chTPjLWBkmXvXdm/7cayN4cjYL5A1VvZrvaxdgwpG5/13WhrJI/IOxG9bRnmD497aq+122eO9sD5xcaz09bRtX0uCvsUap6/v1b22PLPYLc39669/Yt8GeCJfFFZFox87snD5xCb3uUp2/B5I1IfZS/TFbGfwX9eiz/rPA1nfXFfRtmZ5e134bn18hqEvtP6CrSB5d2tv5ifySzOfZTH8jG9np4SfzaM6mBzAZ9Zm2yIVY6VZb8B5PKUmaseNRd3Wwl7tc7Px3eKyv9ENozqRZXxC5gwJv/4h5/K3//9H/7P/9G/+A/+X1vhiUQikUgkEolEIpH4LvHxaxuQSCQSiUQikUh8q/jzP/9n/4//5t/8xX/240+f/tPf/OaHUkzQ6QwSn0ymWmtBzvs4hHUK2LVS6hHAmeKSiuHSddlAGkQHUa8JF82B62oCSjb/HGTCkNxMrl8DyixgPZ3SBiczsVPVOul8R2DA2vMT2ghrrZ3XtdaCnTUdmLsNPNs2Nxa149rKbtYOEbltXSYLhIpxQXUcNlSTD4oNa1oppbZynppldB/jtN5qaffjegqGmnF/q6XdWym1zmprOcpOCufrRR587vOlizl01Vqnrn1U24zZ0TymU1spt1rKvRs1Mh0zubXlZP5bqeVuTqIcvVjb2qOtlNbupd6OOXR/tG81Y2XcP+5RgkHtt8arNMYuE75up1/pwWA7LOv428bfVh51aqU9bLjhKYzzWEPfZGX24XPa3UbWemQeXT3h8JXHp9vZgpP2k1PRRrvciu0gVqoMYvCO7/HwG+tU6aH8buNZ51HrUs18WD2PJTrYq7PDJu96jKXKhBndi/31tJMXWgdWq2a8g9Wl1XM9qiin1/Xsi2kd2DR219iWqzJc2TSf6tFWZH6c8+Eof7MFpxqd84bZB3Odyugmsvvo05ietaGP9GYmq5n0KKvrRDk3uFfK1E6j7tRmYaeVYdNMGdqmzE7Mw+Qy/SpNjS/mMHo62EJ3Lii3t2u/7nnEEjxds6U7cs1kqKNIIjJ2UH2hxpo3jsa1ycDmAhsbnr2sPVVZzNs/C78wtS2TqfoS7VPtpPKxMjYPswfzeXnU3OtgYxhlK/+AQsbGw5QbdTsu6nnd7MdJZ18JQKmxZ9rO4n3v2trFxnmkj5VcwKPafQ/GM88mwDMLrjvLuu52yihTeluOtbOv+Wf7P5ac06FX0z7jGayefdL3GeWQbs3AelRMrWfOscwV2/S9BOsivbt6yPCp2Jij2YFkt1/GhjL2hKa+gFpLKXdTU1PHepSyus7vC/pnOxHnwXjrRhkTh94hfS7Z27bW+d5tWNSMDQ8p93sr9danRh11P7+TqGfpZupmx9Iwoi12nO1xyul5y5B57oPnvUo7no9Kwak0nvFanx9nK3Vb1+k3lJV6rAlTvqPgkGY3o+Wcz0NTs9/1HOOxrym2Xm0e7PV21nuYeJQbz8+1X5fzufFIq6aDrZtttRnBdVRujIWxNne7wbd0u3o/L/Utpe9Np+fqqf1rGd8ltGLyHXmHwWc/nfPDyGxnkVLY9VyPqTWVP4eJFHlBBp9PlCyUy76LWv3jrEO9HD7LKNM9/4UONHf+LnAl0q8+eNVTSyv3yVc87uJG1V+nppfu7RcDvamrHa9lytPnxl/85V+Xf/5n/+R/dbvVe0kkEolEIpFIJBKJxK8SSXBPJBKJRCKRSCQEaq3tt7/7zf/yr/7qb//T/+g/+vNHmNbEZCzpewrSPUqff46AjQ0ez4HkWSYGo5CYXsp5YlspGBg7g9iWRDkH2fbEiTVIZwNhJkilaAa9bibgS22wAWBTJw8Q1z7IGJjnDLxZayd2U63l3u06gt9LTUYQ+Yy99xv3ci+fP9+PwH+v0xmpWwPultowvx7RDV1fm7AEhMmkR3DxjMqbu7ahzvtzvPkYfw3z9zIPhkFrZe6TfqqW1TPi620KTk7m3A/5gztgOvGIa98m1XVqt6HqfhIcRuwTg+XFBkkfN+53Y34nQPegex+m9WzKhSDfZ1QnHNhYfGvlVk82RmsHieC4HnH7Q0nn1x9NfDbAmPgHCWWMnXqWPx1N6f3zSDP2GQ/Sm360JLyE0+6ES1CN/ab+DzJP92VnvtHqnbTf9d/7ODuJDR33zqhodfpVcks2YiSI3vemgB1G5SRg1anenPli/Bl0QSmnXcs4GP3fTq3DjlN/b8Nu3dFyJqU82rO3ZXmMb9t7wxsQtvIYX9NUtHmmCpRBRILxO/1CSZvbvRgbWjlo/abN7zarnb/lePFlmqMzkWL0z9HZ7RjHlvQ0TYvxMsrDb08NucD0qel3SzDCX2CZfW5P6/1b58LWaZikMvmZY+GYpJfR3p2XdBKK7IsH7SDRGavs+F0m7YneW82Wr7PrwJnQbEdOS8nRiGYBbKbODRttsqXX3yZWYS+BnXfWr4FfWMrUPo7t+nfmnuYIriHd8QyfGoR1SVBd61u6D2hThgPd4Q/zsFX6+jK/NDU1AvqqqXIE5yKz2H/6h7Ovh/+3znXpPBgUdpBg/fq+AAXdS5lGxjHBamlHvxqjhs+FqnYZdk3CaXS81Db29svEwLo56TC3Ri/Y9rzbhL7HsfPkfFnwIcvMtybM6U2A93sTlZPmelT6XE9sWx42nXVgHrGeIoaarnjSYtbHR5/VVgcRdBAqDzvGOjb5zNNPN9uypg8fbXo2/Fj/W7eglmGGEbE0FB1ArUwk1XMhWuaMzTD899BZSykVVPb9VB3iJo6qUTVBqLXjZDxpHS9mDrdmBNRaB0m0uwzcG9+LNerRtvelHc7+n01t8ziz9loR5t5Uvp7tOD3NHja2YwCNYTR8wKxr9EWFcWCsGOVbK61CH9r15/Aj9/ux3+/NNfYsY+U9ylRolzrqNabftJc1xHjzUu3os2OSz/uEPn9Kqa0/zz7uHE9w58g0e//hi47c9pn+3nq7l6M92jlebXn0Ib1i7RwP1fqWUsr5bvE8x4YPaWdf157fjqHxxuHtLDO9KDiPY9PypVWzdth8rX/oFtXj/cPT101OZ/TT2b/tXgwh/RhR/SXe7quM7zfmnj6mmOcpsw/u5Hbkc9dinp3q2XYPJv3Zp/b1hv58ePrfo8gwp9opb2w1bdH9LB5acK9jKb5Pa9j8qspw14fv6c/mt9ut3PpLxWNtN/KHP+7fihH/Usrom+4O7nA/guW7LSailuMZr07lMM9SdrQ5L4d09LkH+Unp6mVr/NxhX3Z5nMKOr5nP30R1cnsxZebXpO3rN23SU8ydyUjrAvqzXS2QwQz6WsuPP/5U/ut/9W/+3//z/9n/6H8rqpZIJBKJRCKRSCQSiV8BkuCeSCQSiUQikUg4+B/89/97/5v/2//z//N//LM/+9P/5E9+99uDv2ZC1j0g0+OSJjB65DiDUcvJWIb0UE1aJWVHsJIF82abMfS1lgJYokI5g3tn6VVyE9c26zj5bZBYznr2+OWQP+7N0kacc4q2nvfqrZYf//hT+cd//LF8/OFD+fDhQ7nd6hl3L2forTV7AtUpw8TxpiYppcBJYbYdjjDffYoO69OUTVkMCU6RZpM2bO0B0UX0SQLHFybun1u5NzjpuHTuwX1UsNv7+fO91FrLhw/1eGHgVk5iWFvap1tt44/lILZ2IoUlN9gaFlNkFtHnR3uQoarzwsNgc3lSRV9UvFOnNranBH7+3AYZqON+b6WU+yA0tGNst3Y/x1+pY9z3UzSRgDa/zGLDwPMYaVM/nud0YhW8SW5P5pzaZmqmZvwXi8qvSUs7GvLX/X4v9/ujnertNupyb61MzPpq+72U24dH+91ut6nGwwfaMTeZ2cD/7uuwzu1OHGm0P84xAlKZI1mIcKYmky+skIPlWe1XLxidp4r2/ihjCrfWzAmRt1JqLffPn0sr/dcK7ma89TyPch8/3Eqtt+MkPaOr13oQguzaYTvLNOLSF2ffWp87+dNWykRWPSq19HKdfVMnzcynAa4zD8fCQjqcl/FSirHTTAY2pia9h0o7Wuz4OpkgXR7qLcs9a/MgIxXw/9DsowW6ezd+QOs+24qdMOzX/ZTZ25Ovl2ernGSrPidnHbbdbVHmN9iKw3RJ+0stpbZlWs9tVE3+qSWne3Ss2azcgHG/Wp8JdcRTL7uNzK+z9IfLqMWettvbf96HgN+Z32YRlZjrsy7j/kI27SWtGcQvTybiWGuTVx+y119VIkbTdWb1WYtvaH1OwpgEm88XfE5H9uBAos/CgnUq33XbNWK82GhyLGPRLDrT65bj8vG5r++94ZcXhvq8uN3Kh9uH0trn0kort3obBOFem7lec2vMqDAGYT9Qpi4frVENoXz1B1bW6td2fqGUee4PImKDE3olKf4YP+UkHZZC9r49ey3ry4TlXNuH/nGyc9+Pl/G/2828aTDWevqqMqhHu2Dsl4K813WksuELrtnaopv/9MXryDHtavYzpVSz9kD+9vh1p3u7P/ZI5XwJoBQzLpoZ0+X+OA29tlLrSdCdLCd7lMOSycdOZvcaLc/3rHHnwg0aY+pVxzVbAu2qDVrXtqHZP7RSyv3z4Rdaffxa1XjhbPaNP/zwQ6m1ls+fP5d2bCj7uLzdDOl9DIRzRNgT1PuYnpqiVxbHER2IeKO/xNkXllnuOQzMM/r0lor1n2yscXtqOcbfvZX7/V5aK+U23rrvs6+3dX++fDiDruPW3xJfNkXm02RqO/uP7o+wnUz1+npjH2yn8QsFJlnt3Ff0NanWIj1QLaXCwB5jDtbi+72Vdr+Xnz99LqW08k//yZ+W2+1W7PM2+le16zhf3qI3Rx5VHpvGW2/n+cdWMbM3AH3n/dU+u4QzWXytOb97Oqnz1dQWviM0fmp+JoV1fvoO1O5J5l2snfOtHr+89/le/tW//jfl44fb/+Kf/dM//bclkUgkEolEIpFIJBK/WiTBPZFIJBKJRCLxPWJEVVprN/O5muuR3lq5ldL60d611vrhLN7++l/8h3/+v/7Hf/jjf/K73/7WBKcqizKNwNAZT++BarTsDILy4PzDsPPE3DlKej/IEzPZqJXzN697flvlbmSZ0yCm2INPKmi3gkfNLSn3DJOZoFapk/xq/m8lz+2JWm/lH/7wx/Lv/uKvym9/+0P5+PFj+fjhQ6m3M8R2b0b2iDgeiW0O1A3Zh1IWbh0h2imwytqiiZSTuFB7m9QyCDH3w4Bay/hsfwi6n8w36lVPEkctjxPR7vd7+fnTz6WU2zgZrY4j0ku53z9PFn/69LmU1srHHz6Ujx8+lA8fPwwiLGl6kzLX8azrOnoYGbOTK9cSluBxah5VMEH6Rc7RljiGJ7LfrGW61w5hn+/38unz54P4//Egrxxk9vvncwrXWj59+lw+3z+Xj7cP5cOHW7l9+DAI2qc9RoepD7bBI88Z9LUtItkSHuyABb9lODvzRQ8qm5cWrCzmG6bTdVsrn++tfG6fy/1zKR8/fCi3Dx9KJ8Ld73cgHJTSyoNsXW+1fPz4odxuH0rtR0Y++DJkbK2T1JLUxinqlixYmL+FHsAkQ9rA+TzkPxQOXWf9hCOxMhqxqwJxbLZwKn920TwLhw3H0vDzz5/Lp58/lduHD+U3v/mh1FLKz58+l3Zv5YcfPpZ7a+X++ZMh0D58w60++uTDh9tZ1eX49nOcWLtNhazFax3K2b/nCxm8vbDQcpKi6Q40YSUxzsLxFSQY+udQME1tl2jrAy1BZtxrZSYBEhvZ6ruuld2XtXHyrLVjrnM52nNdm1Q7L5gGfjsO37YL8qoYqTOrP5sT+0n53XtP44gM/DYqDX9JdtMVI4NtZbu3G2tLMa6jnNsHTCulmBfqTleLlWR+s1h5ZCzYAT+Nclwe25xrPqVzFjckkbaaOHrN5DekQnyxYNR5GNLb8HE9bFk6BYlSc18jWdPqm9C3C6MdOskX+sO0k22rUuY+nWWTCWKXRBzgbZgzpdnxpsbBad/pTGopC2kY/Y4neLwUYMoxGVPzgL7pVNnDR376dC+fP396ENY/3Jb6ttL3a7dSb7fy6dNP5f75Xm4fP5SPH27lNv0CkRm30E7dqAbyZ798nmFu1+T5V1TWJlwWXeinM+Oqt99S6wl2xVIn80YGuFZauJqM08sUtZR27Pk/f/5cPn2+H+t0n/unwP6rTx8+fHi8oPD58Rxw+/Dh8XJrd27T4LYDzdoEDggemhb3JxabWcTZmxpzh81dODdclzbdOuqC/Vjag2z96dOn8unzvfzw8cOyXnZBHz5+LLXU8vPPP5f7/V4+HGO6Hm2HPuesvt0MRBdewFJOOMlh7VwDXA9QytTy1l6Tsd5mn9HLt/u9fPp8L58+fS6PlyI/jDFajRWf76387re/K6WW8tOPP5Z2b+X24XaM2/mn1CZ3xfzrkWn+bqEcBHEYwiN7Ndf8NerHyendf7LZfNaHrum9TY7uWkfSPM5be8zhR/t9Kq2Uxxgs5mT3Y+5//PDxQdpu7ZG33cvtw2MMlk4Un+r8+P8NaqteEDm7ffFa0z7JPsP1549BnD9K3srYMRifev5yypBi5iQuabZVVS/0sp8/fS6fPn0uf/zxp/KbH34of/qnf1o+kMV9IdP3fYMZ63w/UKybo/mY12jLXWVPnVLYvD3dGPOn68EGjnvQMH1x/j17pa97/Tz52Wpr0Kwf+7SWs2/GejHqUh4vNtxu5aeffyp//PHnf/k//Z/8D/939/v9Y73d/llp7fPxKFJKKff6+LqslfMHwlr/V2u1aYlEIpFIJBKJRCKR+AWjeicsJRKJRCKRSCS+HP7lv/yXpZRSWmu/b639WSn1YynlQbSu5aOJp3wspdT6iMJ8KLWHD6eXFz+UUur93uof/vDHH+7t/ggatvaxxyRbaz/UB0pr7YdyhjN+GCG9Wj/2iHitj7O4uj2ljbjVx1qOqHktH+v5I/SH/bU9ruvH8gg6fCy1/HCEND60Un44bL7VUn44wmH1kFX++NNP9acff/qhllrKrdZayg9H8KaWUn44TgKsrZQfHlaW2lr54RHvrKWW8kM56vmQcGirtw/lpI3caqnd1lpv9WPXcKsfPt3b/fe11v/xh9ut98cW9CQqmmQJPvEo1EniMB8Um0Jt+Z8Jem0wgrE24Dwdf3bW2T2FWtg9TmE0+X768afy408/lw+3YxgOst8c8O6p9OQujKgSzsBE1xP3TztX7kIb0e45vQ9KSxA7iRnH1RqfLdCs5ww+GNN3IFX3PON0RFPPx8mP5TwZboqm9kCm0WXrKeqLGaYx2+8VqJcNHDfTzZ5sU0cEic/PnA2moz16oDU4vbOXu+EpkL3/+kl6dWrrxT5LXrd9BoT2pcGHrSvBcOEe2XJd/rh3lmXTrM+H895pCLbZWnI29jyF8RzjtRr7TZE+bluxJxGe+hg5crKtPNpw7rOTAFBN641w/TL3lpYotiFrKeNgxznPmcO2WyeFVujDSUR9GEBcypJ3uT+NQdsW0Hcwz/sAHvL6vC99/D48dGv3cr+XcqvmZSusbT37rhuJRFUJU8FB1kOWA8k/udFqbuEaWGYSziIO3fE0vjvZhS0Is30nVenM9yjVROeZ/qKO0YzRsY7ZkmpRX9dXdiKk/fUJcju0NzhP3xwT+JyoSLzpJFDWv4bo2dvxJI2aUYzrnf3Aumdy/tBeR7Il0Zc652PzUbfEWWZ2WO0c24X1IfiW0W5kMi1jexE43zMVOU8nr5MeHHbLeHgCyz4I7SsPPXYMzqeem35D5nVgH8Ags0zjZK6D3Zer07Ttfvf0u3xuznLYygv5cY6egtY5u8wBMWDGWMf86MOsvWQeHXb1eXm71cczJvF/rfV+bdPUmPYAUBU2hkfLkTUI17raf8Xp6JvJHSEhu+fpZWfhxi6+loxy0PbLuKGDkLzKhH007Dj9pLVtrvq5Z33s5Y2Wx8QvrfUxe/4SQUX5csO9w+KEh7jT79e5C6a6or/ma+7UlGIOW5uQQO/1T7s/9v6PfT5rh3o8G5yn5dvx3MeKFXo2r7YR61iK8dvQjv0R7Q7L7JgnFVqO5Jv9Plhi+qMZwr71b9Mv7Ry2WFiC+Oii3n79lx/K2SZ2/3nWn9tv95fsHsJsMUopB/F9qhNB/x7j/8/ev/1Ks6T3nd/viaxaa72Hfeju3Wx2kxQP4skzkiWOxNGFhrBswRgIMzDmwoYMG5B9YXhgwIBv/AcY8LUvDRjwAYbmxicYwsCwLRiwMdYYmhnJljESPRppRFKkyGYfdu/ee7/vuw5VGY8vMiMzMjIyK2u96927dvP7IXe/qyozIyMjIyOzIp6KGj5TjHW3fKYvq+zw1sLlWt5zhzas/xyQBynP7tFFVPr0M1Vft/NI8dp+i3zn52fxexen2unJ8uk9pLzWJp9f1y6JWT2d1pX8i63pPpn+je4KIejZzbUsZL9i8YRmx1RZXuav/GW6cruhvDx7LtK0vyxfp3pDWjrQ2rJaHSnOZf1ePc/T6j5X9rP2eWZIJrqObfvJfrf7Jy5vjsfWrGt22r4NifLutzfkOvZ9OO7dwujRjy65SYf+Lnn0LkDe5X7oL4Oju/t+vz/eXF9FyaO7tV1N80OXYzuY1EoeJTv0B3HoAu29dXXrd++5m+zYH2mU1MYY3bt8upkdvbuZHNUdS5T7sb++D+o+OLXuHkMI8fmzm2MI5u6eZqho+3Rj/17s33P3lEe1kt2FYJ9Ian/+53/+ZFkDAAAAwKUjwB0AAOBC/N7v/Z4Oh+NvPByO/5PdrvmFJoQ2hBDMZBZCY/2QpdkkwD2UAe7D+6PGxgi4fDbz8u+z1YIql58ua0vWt5Cmg51Ly7+IZ9pH72dtsOnLUosd+CJ3vzSAurJ+OWCfG3+uO62/fJ4mA6Mbtym3LbdJdWMWzFo7kMr+l2aAXJxpuBhd78Y4+4HkhXS2HM8m/b4nA/dWWUVZNbP6e+MGZSuQDwpn71W+CNCnNsvmZLA+X6USzFFLJZ+Nt0tnHngyyXHtXGUBCDVrY75lDJZq9aWysRcHZykfRbaGY1uoXvM89sEdRRr5emtvnCq/tE71/bRNPlBenN8y4GIpyGXxNjTJR7FoKSCgL1zvK0t57mbbLOxnnq18tuR6dss6nAeqlO8VsVb9vk+3kfl6+RdclOV7HvQw3dGw6+LYU72cFEvWTiyV+dL6w/VaOaxxWcr49PiseK97f95GreVpclyav19bXg026v8e6pGPC8e2c/71MC/OSR6MVgYTTXZl0+sqrz/pixyz85EXTl4Gaf0srVldTXnrp7GfXrfjtTSkajbOkK7sFxGy/JXnpWsuiyAvW34U80q9mBx31o6faufy/dXeTstmVSnbpnpXdmW/YFF3sk0+YcifivNfaT+qr2sJLpVPbZXZPboorOKZo8zvsMXCPW3yfYdh2+mFXtbZYcb+/L2iDJbv4cVvA3m5fJpOWlhtanxaTuUz8bDN5AYwVy2H2UrdtSZZcc8sG8VtygDWWX6tyFcyLbbFa6f6fJOlNTnc4ti9sn31tlmpg1J2X6u0k5O080SzhqB6r8vTL8ql1s4O6W80+bJj9TmsUtc0fW927y5ZsZ/UZhfZrd4jtPRi3Kg8J5N0y3OVnxPPyr1cpdjX2i+9LNXp6k1/aAXG+5b5fNVqwHR2bcyCqlWUw5C37JiUXcuVY8zXn+QlW7d6bU6zcbpNme1zmlh+rx6OKb9OH9f0FPucl2M+M3q6hidtRZbf+TN5/TNfyv8QfF0t8/Vr8PSxLJTfyjrDepUP7ymvk+twkqSP7cKsMmq4IU0Ct4vnqbHd2NJPkeVm0r+yfk3WPpd/6WPeZ1wXWDf9IuR565X9J4vXh7bVm/o9I10Wb3XCh1no+zy0/esuMH58T+oD8rt1FbtVdHS5e/T22LbeB/2HH//483/n6197/3/8K7/yy21tpwAAAADwVbI7vQoAAAC+CK9f3+rN7f2//fLl8/9iCtg1M4UQprPZaj6YVc58NZ0Bq/53ruzIX+vYnw4YzJcvd+svLVmKxNA08GHYfzk4uZQ3m4wTL0c8LizLs+eVMim3XRgAHo7lElUCQ2zl9ZPu+twyqQQEjGl9MQW8pTy2rqNsvceU+5Zt1mJfhmsitRkb81q+ny87dRaWLpFanM4s+GND+mvrT9I9UcCzWKTK8lkeZydkOSLj5LFUotdq8exnqVaQYj8n19es0s3ylZ/IoRDHQIWa4TDL9dLJqkYsjlmv7n/IQxbVMttxtp8xE8VBZa/L85t2MhzjQoTScvhWvTKMN623j+rJ8zuUw6mCKzNTyddseV5uvvJ+tl15IVUvjKX8VtbJ97vWKA3RZbUWdOGKz89xrU7nUWCuaVnP8povL9LIM2/ZNrNsVY53UmelSfRlWSC1/M0ayTLh/DysPTPlaS9c06utbC2v+fKlCrNWobbkvShT1dYt6u0kzfxc1NqDtbzX8jL/s57/pSeBc++ii08KmtX7WZpbnwKW8rJ0DFmaeTvsC+e4um6528o1OMtD7ViWymBJfg6zNmexnduQzmybol7PrrMijZP5L4+xcsyzwMZsvUn2fFgk1drDhXtrmfXZglpdy/JZ3odW77GVfU/yXlk4/RA6Xydv+4ovAs2PoabSri9eurX7erlBrcw3nt88S7W8T5LOy17TdMtnreqzXpFmXqcXDmW6n5Vznecv3yy9P7xp2XFU6sDkHluktXZayy+Fze7X81/WKA953mTUynt+3Kda/WlaCxdjkad8UfUWsHQrWbrWltJfMDl3p+rQ2m2tTHTl7a2X8NrTQ75OeUnV7oBrd6entvZUcU4ab5vPLa1j8q7L5Mlsrdh/wuW/dDS0h92S4UsjW9TWy99bSudtv3hS9tXnauktTJqRJpxp+tf7Wd925XUKrHdJ3kZFk0IIao9tvzz8D//4+z/627/yK/q7Zx8YAAAAAFwYAtwBAAAuxP3DQe2x/ZkUCDB069tyR3steH0t2H3J28yCnrY7b/PK4ENttajpKF91UNLnI16z4I7a3irDqbO31obSXFJ2noot5gPUlm05z9tCyMY8t5XRv+lgqWky7WTtcGqZLXe+lLHawHFtkHtr+uW+lvJQ7q/MXy39peCQrSPpa/t9lC2BK1uGiJdObhF4cjqqQfUTtyU/a3lYikbZkqmtQ9tp3aUrbusJXkt3rQLVtqulcU6lX8v3ppCXt3BOeMlTbFemoRPpnGoctubpUWE0AAAAP6F+kp930jNmLN4754Pgl2Xpg+/bPMc+5jPE1mfwLR/kz3mWz537gfzUZ7dTaS11MNQ+I9bUPkeudZKspXGm2kfLk9VmS37Wtj23D2LBY7bd0o917vK17oyl5bW+scdYOhVndBEt92D0v/g3e7+WjPV/+2ydtZ4TZduZ1up+nupCn2ztJy+mmVx06gqd52Fljbx6b5g85tx115bVfsWg9ksicsnN5DH2X5iSYpTM7EXbtl9bzSgAAAAAfEUQ4A4AAHAxzGQKJim61OjxHeHvypYZcIotNryz9GZtWWWoptzW80EZn2yVr261vMVhYWWoo09rIa+zbGTZHHKxEsvqk79s8t5sosliZ17+lWZh83INKzbI11sYiC2X5bPCeiXNWgFVy6wy9ObSrGAmaVcGwbyyfrlssrgszBWT/T42uGAhUZ++rO94QzpL723O3mpGTiw7kYfaxbk5P1ss7WtrGqeOa6lsnvI4tub7Mcd3jresz+9834+tg4/Z12PWBQAA+Cr6SX7eOfc58THrvStvk/en2P7UNls/H536rLk1n29z7Od+lnvsZ8Rz131sPjZusiWbb7u/cru3uWxqfT1n7Prs9Mo+ovRmrY8r71H0bEHWT2SyvpvJs/drfbZlv1uZGVuoLmV/VD3p5R4MX3i/SNa7dW3hEIYcF9kfUh+KKZWLT7sUNfZ21krATvbBpR0U5Vh2YZZ5rKZSlsb8oMtfEM0DzZ+6T77sY8+D2/PA9nlffL2OW7c+MSAAAAAAfiKE06sAAADgi+FBCjuXK/+V00mX/pcQ1J5b2v88XthV62T3xRfVVCv/rW84/KJ4tl56Lx+bygdl0n9lQq7psvR3rQjm73Urd7PvZ+sMgxJFhlT+Pc2Qzwpu6b8hR8W6S9uW6+T/2sqyWprzfNeVQ1i1wRnTbCSquu9T+3zMQPKWdN5m5BYAAAAAAACdeh/iF5PeOf1mtf67Wp/dWj6W+tbK99b6zJbSWUtzOf/dS5/Gj1fWmvSfFptb2YVYpJOWlX2wZdeoz/5XcuUh+pUMeEq8cphZ+uslW68vk7zWZlB/IlvTNLPhvyxnxWzzfZlFJ8AdAAAAwE8EAtwBAAAuh5l5kOr98ef8HOoX6dRk2NWBg+rYy8pAy0rak7Bumy+XilmGijXKQYDuv27aH6sN7vg8f14Esw8h9tnAjWejQNu+ELA0+LT13KdA8cc6d3DxnMHDLesQRA4AAABg2dYfZgIA4N05NRnDWh9XbYKHvNPUinXL5bX9ndpnbfvp7PF5wPp8YpA+3HwhEH7rPBjp6EwaDi3NDZIf+fp8/L68izwfC/3FU+t7ymdw/7K4e3X/5VtmoT5DCwAAAAB8BRHgDgAAcCHcZZL62VVs7MifdVI/fQf1Yzvn65uNowez8YzVuOW1gYTpgI8X75Yzrc9S7PebgtDLwZn8vfVA9DJ/PgTEd4MMY3rTdZcGmrYGe59j40gSAAAAgK8MgrnniN0CAHy1nXNzf5cPAj75z/uO1Ol9dqUf08+7J5dh/bOJScq+8IUcj8ussqR4Wcn6lp7Z+cQlX5589vZhfCD1Ravo73btv/AMAgAAAMA7QIA7AADAhZh2yGdz1VzgoP34s6zDO6oFcVu+aDFYfMvM7cUMNbOg//xFMQdRtmwMYB/3Owam5+/1CRX5nA/s5IMH4/RG00GPpxgAyUdjvvwBFQDA+b6M8fALGIP/ifFlleV8xsTx/VN/r6X5lL4K9exSrr93mY+n2t/W+vQ2x/JFnY9z9vNF1pHH7uspg7m/rGviXe33q9AOAQBQt3YTe8wN7pz01vsZ5xN5lNutdfouT/qR+mJTP+3yfsYU8h7zSor9XO7lPn36ssza5O+vZp+rT74tkPqmhyUAAAAA8JW3+7IzAADAT5q/+Ft/Y/ZeCK62DfpP/+Of0evPn0mKlS2DpH8g6ecl/T/7f/8jSb/YL/9dSf+apL8t6Rck/X8lfUfS1yT9tqTflPRzkv6Pkr4h6X8g6Z9L+l9K+vOS/kafxv9M0qF//ZuS/l1J/7d+H/+1/j3176X3JelflvTfkHQl6W9J+n8V+f/Lkv4rkm4lPZf09yT97yvH+Tck/RlJb/rXzyX9I0l/U9Je0r8t6Wck3Ve2laRG0oOk/42kvyTpz/b7POW5pP+rpE8l/fUN26Q+4Bt15fg/lfRvSfotSa+1HnVeLNtJ+u+rOz21wwpBanb6//zVf90ksy44Osz62lf3+AVNXVfOVjO+nM6+vpjfNJ3MPOV5uqlP3ioz+dSStunAy3RwpNzQVI5mTH9q1odZ2af5Op13ADiHnznT2VfZOcf6VSqXU4Px5bq19co0HnP8tW2eugy35OtdnbtaurVfY1nbd768XDe9Xlpnbdljz1ee9zVlPmvHs7bsnDp6ylo9W6vHa38v5a12TvJl5XZLZboWsJ2nv7a/tWOoLa9tu7beOXW5Vn5r650qv1Pt0tb3l5afcw5r+T+ldt635HFLe3nudb7lWjtVz85Jf60dS04d16n9nbPe2rW95Ro41Q7k6ZX7eEz7trVt3HpvOaddX8rLY7f/IizVt8ds/5TPCl+1Z8avSl4B/KQr+0WX9P28G1Zdn+E8LbOiv3Xcxn3sm509p2lsQ/O/8+X1fdr071pnu9X6safvjPf6sb/4i+qLX+PD/6TO8y7fKWf75n80Wf+Y/uiPe1PibXrjmaTfkfS/VvdmXpg/K+m/I+la3bjT5twvZChqW/3c9Xn5X0n6vf69vyrpX9c49qQ+X38o6X8h6a5I4yN1eX9PXd6faz4uVvNLkv5b6sb0rtSNsZXjZblflfRfV1d+v19Z/hfUjc1J3Zja/ztb9p6k/666Mb+dlsfd0vhd7Nf736obQ8zH455J+s8k/c8l/Vq/LB/vK/Npkn5D0j+V9Hm/n/fVDXb9PyT93ZVjzv2bkr6r7jz899SVW7uwbtDNs3v9+p/7F9pftYrx8dfa3/87f/PR2wIAAOByEOAOAAC+osaO8dM9smk916T3enh/af30b/6jN626TsJNvcDdeqF/GVX/boO870y3YNI+pW0aZ7OxeU/7NIUvqWN9HMifdjoPwySTt11bJo9xZYMU+WBFtq9uMGF8XyrzYcXftb0U7xRleP5Pz24dHALwLmwJ0NsSWPzUedgSDHROUG7t/XcRdHxukFYZLHnO+kvLTgVJ1vZTC6w7NzBtS8Bsbf9Lx7QU5Ld0HGtBy2Vg2Fpa5wQP5pb2vfZe2q48d+cEza6lt2XbtXpTrncq+HktILqWxtJ6ZdD0qbzXrG1blnl6vZT/IShkIc2yTp0T4Jynu1Z+S+Wx9v45r9feL6+PPK/nnPvae7Vrc2sZ5mVXu47SOkv5zJdtLdd8u1qeTpXDlmXlOrXyz9+vBQif0z5tDaSvXTOltaD7Jfkmp8pl6V62FLxdvj51jeXp1V4vle2WOn9qvVP3uNo2p9Y9de+vlc2pcqulfyqvp55DTl2/a/ne2v5uSXPteWPruV/b5tT5KLcv83cq30vL87xuecZZq1+PfT5c2uZUWvl+t2xzTt6WzvfSdmV+tuYdwE+aDQ9x72Q/abb2sg+1+3vsi51OOjJOSrKwF5+3sSnge3x7THvpLZ8srax/pi+iv976ohzLpvsjRtf77z9Mdv6Zzghyd3Xz79yqjxVv1I2LvNQ4wOH9f8/6ZUctDH4s7GDc0XT8ZSlzXiwPxfvSOG6Tb2+V9fL1AQAAAFwyAtwBAMA7stZRnncyBo0diYf+dZp9I6WTd142/X+W/Zd1RNq8k9r6dVwvJN2Z9Ln03oP03Gf9se+Z9Fymw/GoGFulnlz/5m9IH97I4g8U451ie+hHorsu3O9Ytyf3qPv7+64T3rrXbq30zyT7bnZYk8jt7p+P/9Xfsg+ev/zSBxfPD+z24X+H7uLpiMBsXWXrVQNVbL48z1c+QNC9Xaabr7v1OB5z7JOt32JbfNl+0gb2H3M8a0EvX2Q+HrufU/s7FXBYC1Bc2s/WAJyl/ZZBKWvBf6eCaGvHvhR4dG7wz9J2SwFTS9tvyX9Kb0sgXO04lspxa8Bdfi7WBs23eJvt1+pC+f7S3+e+V+7nnAC4t9nfKVu3fZt8PSZ/p87R0rpbAhbX9rdl2ZZAwq3pnZvXx9bvrWm81SPaI9J7zPEvBc2fk5d3UTan0vwynn+21M3H1t9zynBLkNTm87httbPzs6Vctu5jrYze9h732PW2rnvuOuc8X5yb/pbns6Vtt3yRZ4u3ue8tfUmi/LLM0rPk1jyfUyZb1q89S2/Z79r5qj3rrKV16os4p45p6fwvfTljyxc7lurT2heCTr1fW6/22aRWr8vPOEtfRjj3HrRlu7V68VTWjg3AkjKYXZXXxdKsgUqTnOT9w7WJTyZ7PHl9upaiu5eWvMvr/tH90ZVi9f4A3LT7td/455Mc/1D9/OWu7ldmFw9Wapq99tfP5J9L+kTqxmxey/WvKgWWh5DGaHZy/b52zU5XV1cyd92rm6s7TvLZ/WEWFJq97LuSvTF1v7R7KynIZAq7D/VpuNFRcfiigmTdCYiSPmn7MZY0rvSepG9I9lzSN1xqJU+B7kHr0fwpuL7p97OvFGzNQ5ZuMT5VRSA9AAAA8FgEuAMAgAVlp1ursVPwOF9dR3WPFum/ff9fnk7/t3nfDxrVdau+0M5+xWK8l/RK8h9IOnS/HvmNINNO7q7oUR9a0EuPun/4ZcX4ucx+uwtcv97Jv+Nq/UEe267DM3Q/Mvk1mQ5tq4fDS3ncS/GPZB/u5S8Oerh9Y64o3XSH9oF385A8HA9qo8t0o+ZwkO1+TdpdS/6xDodbHQ63sp1JL6Vg0i52P53pCtrHVq73ZfZS8Xinw+Ggmz+UruO0c7R89frHt/bBi5ddp7arEja+7IuYvb3sbO9erh1T/Z20bT3L05ltuoHD1Pk9nb2ntv+FnG9YB38S5fWwFqzwmHSe2tYggnzZqbSW0izTT69PDeJv3e/a+mvl/9hjPieoq7bNUj5r+TqV7mPyU1u+tG4tMHtLIMuWwJe15Vv2d453FbS3FCD+Nvt/Cu8iSPBtnDqfX3T5bHUJ+XqKQD989TxFkOol+Krm+117qnLZ9mnuT54vst592XX83Oelp87vOW3VUz3bvc0z3db1Hntcj83LOc/CWwPK8+fTc57nt3jMOajNMF/L45YveKw9e2/5zPWYzya1fNfSPRV0n69f7mvt8+Bamlu+PFFLY2nZ1n2c2vaUtfICtnu7G1vqC+7+sezv8Smr1n5N08jf8+xfG/70Ph2fLpm9uhT5bPepIRiOzCW57z87fGZmpqbZS+rCwN/vv2/gD+pitEN5rJLLtd/deHOQeXDZT6U4873e6Kf0IFcIn2m3DzLbqZtY6OMu1DuYgjXam/SLZtLBpVd90sG0a64VQqNdc6XjtfQQTdIbNc29wq6V3LXbv9YnTaOH6NKdKVhQCDuF/TP3tpV++ANZe1AIV31+/7Sa+Cuy66/pu7azaL+rZncjxTvpj15L943M7iX7C3I/ahdudL/7mj6VZHYt04PcPpb8KH38SjrsJH1LksvshVrbaxowr2556z6Ofe01nZSpdK1uzOxh4YweNH4ZpC2W1cbiAAAAgD85CHAHAOBPFFfXWZb+Nk07zKLGTrpn/X/q13vR/30v2c+Yrv7s0Gu6k6vRzyj6x3L/TPrGTnrxXHb8NyS70gcKetHe6u7wsaRX0rf/ofzZQYovZHqhq2j6qfav6OHhU7XxY6n5kWRS3D3IP3gms49kHhUPd/a8Pej5tevBPlBs7xXb12qPkoVGV01UiEcdDvdqrx+kZ6bGTeZRTXzQjT6Q2p/Ss8OtQrxX/Mx1ODxYDEfZPsjddGyP+iS2Xae3XUnxWs+1lz1IftcqxlspyvZ2I79x6Sh5jLo9HvtSvZKpkbxRjLdyj3I1ivtGrULW0RzlMdpYvtIf/MEPmm9/55s2dM6n0s9nKlk6s/7uf/K020/+7zhAUbzsXvjCTDizQYUycH38Oz+m+Ww2ROP8JKoFQ6/NYrdW7dcGjWsD9fk6a/s9NfNibbtafsq8nRqkr+1vy+D9YwJV07aPnY32Mfs7tf7WYI93GcR0Tlmem4/HBnE8Zl9vu91Xzbs6znd9731s+k8x/P62x1Zufyq99Ms3a3vsnjXq6dTSf4rzszWN/Mt4b2vpOeirZkuZvM15m/6azxf1HLx9P29TJ76o43mMpbxNzofmbdC5x7RWfmX65bpb2pvJF2ezh6Vzzu/Sunn61qc9hB+ZTX/1Sue117Uv/k729Y6dqtfvIh+pjB5TVu/2Hv3Okv7S/CQe01fJJZR/Lai9XF57v7bO2+bjbdI+tX2tn2Dr57wt79UC47fkfe3z+5Y0av0lS30FW/KylPZSH8epvplzA/BTmkt9M4/xZW+Pp+Czf+vXxvh81D2/LM347sU20yVl//WmHH7hz/LZ58fsdfSo4M+CSbLYzUqeQrEtmHRlw7CQWxeULjtIijKZWkltPKoJwduj6ShXkOtBrqOk4FeKfpQsBV93wd0m62ZnN1djR9l908d0u8waNbudS1LUndpgOjQ7SS/Uhucy/UgKroMf9fJ4kLVSuNtpZ1du1urN3a0dw072wQvJPtHuqlVo9pLvpM+l0L7SL+53eghBoTlKfif90sfa7Xayh7384U9Jkq5217rbX+kzmXa7azd7LbfvK/it7Ed76fBM0l9WkHR19b6+v3uuh3Als1u5v5KCdef4u//E9KbV1e5Dvd7/uj7XT0t+7H7Nt5H0af+fJOm5pO8rhF+W66d0GH96uBuuiz8vqXXpql83H5d7qTF4vtHybPCH4nX+C8kAAADAVxcB7gAA/ERJnVapMyt1dh3VBa7vJX2jf33TLbeflZ79RZO79vqa9rpVtFeK3/y67PqvSdF0I+lb9lzHwz/X/f2PZd94Jn39N7qJK6L0bX2gZ9rp9e3v6eHwSvaeFJ+ZXDvJv6lnvtPV8bUd79+TN6+lF5+qbQ+Kx26Av4lH7eyh62tr9vL3XGqk431QfH0l11HX8aAbl+5bt8/9QXZjcmvU6j15MLkfZfdHXUsKcS/du2nXzR9yjEExBrlHmQ669aidXCaZmr3sZi/tgjyaglrtdJQ8yOPO2ninVlITGkVzWbhWo6BobmqiPEYpBu3Dc0WZ5LHvOG+7jlSzLhZLkmWdj+7ppzKDuo5L0yefft5I3n3DwJY66C/BNGNDPtMMMF3ZTtarB//65N/qni63EP7EWBrA2xIAvjaD0lrQ9lqwc1mXTg0CL6Wzlv7SgHTt/XPSe0zeTi0/d/D+nEvqT8rl95jBx0sOPjzlqQOXnyL9tUDVagCsloeWnyKodPg3208tePNkoPVKA5DvQ97fN4uAxbXA3zJvSb5cK4GoqeGs7UPFuTgVSFw959n6s/SX9Puu1oHq6n1ZaRrsOVknS1fFeV0KFJ1sl+9rIQg2L6el41s8D9lyH18sNsBl+inoM22XH9epm6NVztFQD5WV0cab7FCO2bEunZe1Y1p6b3Z82d+T81XJ71Kbkn+xYvsXLOdlbOqCQmpRM14sr5V72md+HLP6UTwALdXhSVp9erN9FteDNG9PtgRNz67vPP8bt1k8xsr6ZR2rti9F27l0Pfh0w8n6a8HblTerx1r7nFPeGybtk+r3tlP1Mi+32v0vvxfUzm3tPrfU5pfHuXQfGtrshfa0vI+V60+OsT9vk/axTy+/5qrXSKVtr6V9qq5vvSaq9xFNz+nkmE88p1TPZ+X+WDu+x+S/lv5JK885W/JT7vNdPGM+la/is3+tzdry5ZQNt/yfOE99zI9JL22zcKvZvK8t+17b19uuv/AIN+m7OZVmXk1r65Xb1Nav7a/cd/nIeOoSP/e8npN2bduvWJNzceZ1Z7gLS4vB7vl681dlfbq48+Tp+aP7rNAeY7MLVztZK8U4PlK5ugDtRtIzyVrrn50k074/KJPUynRQcPOjvAt4D6bg3fQ+ZteSgsKwft+PEXZDhoLt3cylvStY0FHSbZN9sT3I98FlupcsyuyZZKbgUXbvaqMp7nd+VGsy6WitPJjMriQ9U7yPMoUudD8GSY2rDWp9p9Yl041CeF+tHaU2yI4uC9JD2/rBD7oxUzg8mHSnsI8KxyuFsJNfS/vdtQ67Kx3U6kN9qmBXCs0bqflM1jba3e/l35SiBe2bT3W4+Zrf2c/K9T2FeCuzK9kbl16H/rm7lelf6MXzn5P2O/2Rd18i8EbSZy7//lFXV//U9vuXMv8lvdFP6wf96bIQFMJR9od3Oh4PetDXJP2FvhBNUpBuo6SfkRS8e2+nfs5+pbGnbhyqySrNIUujHFfMKhYAAADwJSPAHQCArxzX2OH0oLHT6aiu0+ojkz7s3/vIpb9san5aevGJpJ2eN/9l6VutFKLe02/rg2f3unv5y7L2St+0z/W+/bbePDR6s7s321+73LXzqJf+Rg9qdX8IpniU3z0oxFb2LKoNps+OpuO16+bqfdmbg9r7g/xlVPvwPbv1Rq/suZ55o8avFVuXt3u1rRSjy5qdYpB8dzDJFe+OMkXt7JnaqytFc7Vt1J27YmwU4pWFN0F+ZWr2R8ldsZX5znQXW0UPCu21rmJU2EXzvnM2xoPc7xRDozaarndu7ia3nbwNUmzlHmTWSG4W1Sg0QSFGRbXy0PX+eoyKirLWJTcpmlmQGotdh6qZ3E0h7NRYUHSZ5FmXYZR7kDR2GEtBdw8PV9EVrJj93Pve9Md2nL+bwdjlUbfJIL6PQwHTwaTzglsuzalzsba8NshVG2Art197/9RAXa4c/Cu3XXJqoHVtsHJtH2V5nHP6Tw20npteLU9b3n9sek/lsQHF0npAzJkJbmqgHhOYs7Z9uaysbLPgpko+y/drAV6T/dTy7tPZWSuZ62f/KmYRKyrpsGWZZrbfSb43yIOA8/dmeSnSnQWBZsvzNMugzUn6/bHnQX1Lx5EHIc4CwCrbaeX6zreZlGmlXErebzcEpS5sk59PFX9PAiolWcq/mWwyw9wwAj0PDF0o/0lA79pxVcpV+T7S8VXKIQ8orwVprgWhpjzP6qyZYpbusJ3mdTMvi3y9Wv7y+rKUntSdg8nxFAGgeZ1bSqN2fsr2oMzrmC8vFti0fLK0q/vO38tfpOu4T6OWZrldeW7zZa6srCrrrbU6ZTnl7w3lm2d9Ja0y3/nxlWVUpuW1elaWRXG/KEu5Wg80ryOTdCvv58dcu+YmdbdyvhaXbXxdy+fkHJd1oBKQvBbEPrPUrhbLZ/eBemqz+hKz67mcs3BII6sn6f3hmtW8PtX2XQZKqyyn4nhO5b22fq3uzO+PK/laMbSjWrjei7asdp9bWn92b1jKQ592vo4tvF+un+9r9XrO1h/qxrjS4v07e3N6LPn9cuU+d+o8VK+Z4nX+7FQL+F5L89TyU8rnm6X91p5vrN8wSuOXEpYfxmb3k6X0h/NV6QuYPWt1G0+fV8t9ZPmqPUMPq53YZ/mMPLsf5vfgohzz92rHXttmKI8inS1nd+0LHZN9S/N7W1637cSv6fjK587iulv8zKbKPfREvtfSyfOW0llq39N6S59xyvUem7el/T5VWu/KWrlt2v7E48HWgOAynVP9OitN/Gzfa9vV0ln4aH+2rWmXy87ZVxl8Xdu+7A9cyseW83T5fPh3bCPzNiy1ff3nV5tuM1wNrrGL3rv3x7J526vmKXT9C67xc3TKURtjCLKdvP9FWQ/jZtFdwaXGFM0kmWRt/+XxIMlc1h18jN1+rkyKClLsv0gol6txiy6FpstBlBRTe9f0Dw0PbnulDiQFlxRM0k6mowfvf0lXpqCdzKJidB0Vuv01cjOXWdA+SEH3smbnrd/Ib7tjVohq90HemMxav3KToss8SMer7td/TQrPd24umTW2C0HxGLr2wQ4K2nWzwe9MjQWp2XlUo6gHBd3JdafopsbelynocHDFZqdDs9ObeKvm9od2fXXj7gfZ51I4Rh2vTA/PWjVNIwvXsvBM9/ZjNffS1+Ne1gSpNdkzk39H2jc/0s3NDz3YMz3oWt+Qy90thJ3ee/k93//07+tVK31PO8n+TF/9HtTYQcdPr/XD+2vJf8/S6d7d/2kdv/8LuvX31U0l710g/LGboV76KY11+AN1E2N9pC5IPs3ML3Xjj/fZ63tte0IBAAAAngYB7gAAXLSorrPoqK7jKKrrUHpf0s9aF8j+5yT9oqQPpPe+I+3/DT3btbr+1j/X0aK9tD+tj67vdfvyH2rvO33t4VYP4WgxtLoyKdy+0d3rRuHqa2q90Y+OB+nYyOKH8oeDtfGgYxt19J3a68Zsb4rhoPYo7X2ncIgKz1opHBR0VOt7s6sr7fbP5NYqNA/aeVSM0u7qSmZmfjjKXdp5kMlNatXqKF27FEx+3MmiJA9msdVuf1S46jqdLQZ5a4qtmbfSrum6GqMFi27q5mU3+b5RlKk5yjz226qRPCq4zMzUmksmRUX5UTaESlj3iBQsduOtQToq9L3dB+t7PiWXgmQeTK6okDr2TOZNt9zdFdTlq58z3oKb1O87cUW9ub3dSW7d4G5RFb7kPnP3+YzyY5Yqg+zDssnw+crge7feJQa3nxrYqQ0YbQ2sLgeUiliXk9ss5e2cwb9z8vnY9ba+/9Sn/7HpPSZgfLK9pgFAVowiurT4Xi0AfBbokAVTeLZeqhRbZj6czO56Yt08n7Ii4KMPgiiDTZYszUKbV+ZaQE2Zr7S8fK8MjlItrVoQS7ntQuBDynOuDKqqBsksHMPs2MYV6u9vSKOUjn0pD2uBkieDrLK81gNIT+d1tqwIhlosq8o9SaoHc1Y3SOvngen99qlOl1vkQ+HlfsrgbVcfMGQ2BoK5j38vZCl/qxZAWAv0K4OfhmsqT7PIX5luvm01vcp7tfKJlfyoyE+5//zc5f+W61rxbyod8+n5ytvgpcCwSeBYUc5Lx1tLY/2pJq9/xfKVa3xSlzWvd2UeymVr+V56vJzcTzSXH89Smc6uj2JHXinEtVasTGOpjGqvy/W31snJxjYv81ke0m3Fpu+X53+prtfSXXt/KS9rqvW/kmbeTkyf3qfb1OpZaWmd1ePMr6daZT+RTu1aWaoDS/UqX3dYvtSmVbK5pT6X13Xarn59z9OeXRcnngXW2oZJIK7q57hctlgPKpV7qZ6fKv+1ZbXg/fT32n17zew4i3O+dP7zZbVrptzHJC2ffplOWj6X8cQ5XrtXTNvh+TOFF+/3n8jHtq3crqyTlbIqt5tkoVhvLY9luYxpzp/Py3OfvlhYu+5n+1551q0+B2t6Hof3PM+1hvMbymPcuO9JOpV8Lz0PLKVh48L1trm4xoa/0xcYT3wRdpZu7XOU++SLhtV8518CqaRj/Trl58LyGhs+q1Y+p279nDl5rl74Ukr1i71ZPmq/rJHSmH3GLz/jZsdWS2PYNh1/9ln91BcfhnTyDqzsSydLXxA/x7SuaPLv9jQevfu3TuMp9r0l7a19iFvTq73O30/9lvnrtXTLKrJ1vbesPk9mzFPZx7R2B197397ZsZ31pTXNn8W6+093Pz8eYyPX3lJgu1k/NJG2Cv1xdBd9/3X8/sR596u11rhbt0zm3dhHk/ZkMu1c1v2Waxgb4S4dxS4JNbKQ2iJp3x+mW8qrJA+y2CgqerAoD0FxF7q5yL11i03XlykpWKMY5VEmhW5ExoJpH4LMoqTG26Pk8dAF0jemJuylEF0eFQ9S9IMabxWCKVrj5teSR7XuXdB508glNX50jwfJgoLvZG3oAuHDzh9u7iR/0E2IQz9rG2Qx3kj7O/m1yXbB9zooHIOaY9QxHBTtmWSN7psHaRdkMShoL2uD/Oj+5mh2sJ2a0GjXNGr8Qf7mXp990pjd7GUh6COP8vtX8miSXmu/i9q9F/XR+7fqfl1YCiHqvevg9z+31/fiH8gs6OrqQZ+9Cvr01U4Kv6jwWaP7H/6O7ptGsp+WHv6a9Oprku5N+ouSXkt6IemZpM/VjU+apJfqBvLSJFwAAADAu0WAOwAAFyV1MN5r7CBqJX3busD2n5P01yR9S3r+r0jvfaaX+xe6+dZON3arjz78T3Ufgt5rGz1vXunN/bXpeNCVS9ef7HT0qNfXz3W4c9mN1O6e63h8ppt9K99dqW3dYnBdPTOFJup4PEpXUcHMdnEnOx4UWml31agNpthIbZRZK13pRlFRrR8U9wd5aKRjY97u5XZUCK0UTMfYmnuUbCdrdjI7WDfA5bIYJJN2+2CeZtqILj+a+slArJHkZopBikF2dJNi6vCUmTVS6DpSrQ3mLkVzSW5uQaa+H9b6GHo1fY902y81c9Pw/5LLzSwFT5l3van9j1+q6xjO+7T7oTaTXH0SMvXdrurmHOnfi11nbr+J3tze760YP5vWjdpQ5mmnAk7PnoWuCIaYry91ndk2GdyY72Yp1ORpnTsIk687CSzJBi/WBp8eM8jxmIGsRw8O6jG16ALkg+3lYHJlwPppd70+a/hs8L+oBL5QKVIwhOfrqX5N1oK+583E8vaWVdq8DtQCCWr7reUnDaQvzmxYCXqYlWMZZFGkVQ49DsuKdWf5q+Q3H55c2uem9GsBFiu8OMeTQKTaOamkXQ6tljlbCqZKQQ5l+ktDtymt2pEv7aO2XbffeZ6X0j7XpAwX8rR5X4vnf55QCmJdKr9ZvSvSL9dbOw9Lea+tU93viW2HN4oTlMdnpUP3yvq1fXix2to6m/KnynVfrucL+ykqyOYy0bxuDfW5KJfFBC2rQwsxE1vq5rlPSJN9ltvW8pUW5flcuLjya6IWqF4mOzv+SqEtpZMSKIPGa+W5dJ63XhO1/aa0F7c9dQHbtLxqlXhIc+GczNK12Z/LajeMlZvEqbJafZ3t61FP9SfalNmuTt3M8jws1fNyxdr5mT+qzNddyteCre3jZNlj2o6l67dYNruXLFxX1f2ldnfWUI77yJ8DzvrgUeR/Vh5bymJlvdmzSn2TafmsnN9anV/KbzXPRVuX2/ocs1TnV9ddyJOXb6ysu7R8qRyXthkCfVfSmuZ7nqppfj5P5fec591aWmU6Zd5SniZfbNT8mJbyUiuPPH+VW+Jk3dotaqn5rO1bfd7l3UfE2q/wSFrvS6otKzoxFqttvzztdzabfpH+sKz8PJt9Dl/7Ymq5vPpl2aV99n/XPhsvfXY7tc8yzbIvZLHOFP0BtfQnwfhaKct8H5X+EF96P71XfJav9d1U62+R5loe3taGZvPJLfUtPaZPcH0/5y0vu4XKbq3yssqt9bXWXm8Jpn965TUxvTrzL2FM9188EA3LutqT+r+39Ltvrb9LEz3UE+7+W7rfHQ+Hncn2bukxIZ0EdQ8gaQKe7HHE0g1MknnoW4p0N+sXBEnRu2mGzOSWvs4VvZv9vR9hUXQFyd26IHSPfRLuZv3YipmiTO7mClHpV2+tNW/MJXNZCG7ejT8purdBHqNbY3JrTBatPyz3KJMfu2O1XRfQr9A/nLZB3nbbNNYF8wdrZdHdtOufy45SExV1lDx4CMGCdooW5TFIauRuHtt7s+ao4E0X9B6uJJPHtpX8qNAEmZkaa7oxLpfMW5m3UrN3Na7nvlMbTO6tmijZ8yDt9vLjQaFtFRqTNabgreyZdC+Thys1zc6DPejh2OpWktlL7Zpnsnito9/LX93K2kb762f60et788ODPlDQ1dWV9rdHfdC4vvOhabdvfPdh0Ovv/ECvrqT9/kqf3L3Wmx+/lvZBOlwr/PH72sWvy3WvT/VberBGsvekw5X0yZ3J/2V145WNpO9J+oO+nvyxpNdF1Tz29YSgeAAAAJyPAHcAAC5KGl74U6bwDYXwb8k8qP3gm7IXv6yb9k5f/8435Dd/rG9dHdU8b3V9+GNd6Urt4Ur2+qU9PJjuYtAPjw/yneno14q7qKsXpng0XV9Jz5rG5FGNP6i56X4u0o/32tvOFKQ2uEI8qJFL3ii0bjFEad9FtB8fXL4zNaGbqtxjVFSUxaAmXFsbjvL2Xqa9tAtSDGYW1aqVmysEmftO8rY73tBYCN3s3d72Y2j9T0/275ti1w3bmixYUOj7KN3dYjfi1oWmB+tmTPfYdZeaZI11YzfRZTJZI4ve/4SnyYL1s6xHM7duNnbrg9rTafG+i9tkNk7P1XWGWj8jfLde32keg8nSLIg+jvJnyXr6q//n4XDY+fiu8qHS9GqpO3zLjM2Lte6czvM8Pz5/Pc4ClNK02WxNtbTehXJgojYIsxQkfu447WPWeZdW68rC+uWA4dIA5KkhmTKYeTaAmb8ugrarM3Lnee/XqwZ7Lw4UTvMzVAzvZ46r5GftuGrr1oIParNSTwILskH9yWqal/HaYPtaoEK+LJ8hshxszvOYqwUSTGZEPFHRV2f/LgLuq/svty2W1Qb1y/V8Yd1ZvtbWKwIlTqWV0llKz4t/19I9dcyT92sRAgt5WQ3WWli2pQzTzjzLmGcnxsvCWWtQVir4Uhnm61bLpExTmgcypj9SHivlWtz+lhvWSp6r+1qqzPmy8iTWKvxiA695mVfKoszHLM9L+aq8rt7yaxf1UiOWvVetk6fKotxHrRxX/vba3/luTtWtU8d1Srm9jy8X11+9MLK0yuOubXOqTi7UhWoQ8VI5n1M3rVgvvzZr69fyXmsMa/spbyK195f2VbPacBfrnSqr9OfCdTfZbuk4tuZvabvqTWXeli6uv9ZePuYGXuahqA/V8lrKZ+3vpXWWli3VMan7tYmifSnTXbuvreahdk2u5XNt+Vq5L+3Hpv8O5b7ULq3tIzve6r0k39/S63T/WNh8Ul/SW6euj1p7vrRubZva9ivPRV7+sdRerdX7vH2u5XXtvrx0DEt52ZLvlfKrnevJcWzdtqyXp87b1vyUy9J9eS1flXo4y6vVy2xLM7R0G5nkceFZdK1Jnqxr4z/lNvmv9qzdavMFa48T68fis+UlkxY/fy41owvN9eJxrD7eVfad/4pTtuIsjcn+Tnz2X/2MXb5fy/tCP0S5XZnvch9DQP+4wmTdyRfsF/61LqHZPiZ9OwsRz2v9RYu/GveWzglSTpMcpHOW/wpCvkx6dDP1KOf2Z76r9WunN+uq+wJmfS/aFJ9eLWMe5lfRWAfGM/euJ91YYyYNP0jbv049fm3bBpl27uoGQaxfa/zT0/F6n1jq8kzX5/Braf0P0w7bDilJ6adou4l+vNs2DpmRWT/dTz+ZkeRSSIMr3f91Azfqhl+C5NG9n69IoY9/V1C3D3k3J72bzL1f1k2O1AXeWz/5kUkWvFsgmQdXkFnoZxzyndxbBbUeg0neqFEjC6233TGYuyuEIJN5tCALktSaYitpJwtN13THqOitNSaZBwVrPFqrruhd3kgWGu3D3lvvB7miq3FTG/ZytZK3iu1OZkGNScFdh9gqRpeFXfffTu4Pt3aMrt3NM71sTTrcK+he5kEPUfIb037fqNm537audncl7YLeNPeKD8+0u2/U3B+l+9YsRDW79/Th627G+PfCTnpvr911dMVPdPXRUfvme3K5Pm9uFK/2au1Tfd+C2o+Puo8f6JPw0/IY5H/4benhL8oPjfTDT9XYGzPbKcY/lPyfK+qbLn1PckKTAAAAcD6eIgEA+AL56lSF0fT8T+u9P32jX/7Gb0m/eNB33hxln32qV9e/K3txJ7v9XC+i6f7hudrbRu0nL3V/NPv8bqej7nV/8yC7OujZjamJ3Qzp7ymoPT6oaaN5NLVvTDGY2kY6hGhN6DoTm+gyHeXBzNzUWtdjGRT62deDFGXadUHual3RZArqOuPMZXY0s6BGoe9hbWUKJguSuYJHizJ1P43pGuZC76aG6oLRFWTRzZV+trj7lUzr48pd3czr3eQgXddnkOTBuh7ZKCl0ex96Oz2o6+t0uczi2G3bnRd18fHpTJi6kZr+dFlXQv057Pt63fr49TQoaeN4XZq5fDjvwzzu0/Of71AytdGboWN3vtY7G/U4NWvUZLCi+Hdcr57Bc35adas8Pja9LmcVqs0ytJTOOfv8sgPXuzysD5x4UQinAserQe2VdfOB0GHw1YaLpBoAvmVG8sl7lbQW62flixnz2cjHzE4Gg7N/awPmtfzlg7yr1WClkiwNmi9c8cu7OLGsHG4rB+e9eK8ahCBNg+I1z39t29o65XpLA/Oz/Z9YXjuuLemUzVV6XbtFL9WPYWFlVHrWTi613Vva9Dzd2olb2qZfXm6yuo9afpb2VUs4L4vaurV0z2lTl/JZu4jSJd7dkecVdm37Mo+n3qvlsZbn0qkTs2Vfa+8tXSBbL5rHlsnWY1pqLIrXvqWulMvSsZ865lONRnZNW7ksW372fopzM9TT/P0t+azl+dz1ymujlq+t+1s6V8Wx5HfRyfW5dsyPuR7yZbWb4dp+3mb/J9btvhybPaOVz/qVv2fn4py25jF5rbWhS/VzLa0t7ci5aZ7Thp1qP4r7RfdW9ly8cg0sLvNi2eQ8bsz/khP1vHYM68ktH8OpPFTrZLntWjbOvabTNZyWnXsP3LKPLfeZ/Np7m3Z36f5x6nllKU+n9lumW+ZlqZ1came2lH/+71KbVUtj7fmldl63PGdV8ja8VeRl7Uugs3wuve+VLBXPFtU6tbaPcvuF5Cf5P9UG24lT6fV1TlW5LZfSWlqzS8y1/qsvlXVqRVc7BWu3ito5LH9dZsvn49ryxX0U6dZO56nj2HJ8p6pWbf/z8vDpv2WalUD+2npLfQOT94rA97VfmZttW0uvzKukWhB8fhyTXwKoTJQw6aPLy+bEr9pN+tlOBUh/MZHfT65W9LV+3KT2/tMGvuc3vnq9qO/H+3GdLy+YfZIbV9Zn392cUxx7v4ZkwSYz8Iwztg9PjbL+rjVtLPqeT5cFS59dXJ7KQFI/A3q332wIpQukz3IlWRoYSSHtJim6ormnX6VIM8nLTTFtZaZhLx7cLfZ76XIUfZr54N0cTv2s8d79rG82vZD1OYtdy2OK8iBZ/8vA/daKMfQTKMVuICq4TMEsSG5dobs13cTw5vIQ5X1fevAgyeShNQVzj65gjbw/qqPHbt6k0Mgak2KrnTfuHtR27Zup6crAQ1DjrYJ2Mpm3MSocox1Mavd7qXEd5XIFhcbdDgdZNDW6UrhrJDvai6ZRCN3090fbuz/ba/e8kcv05sEUdg9qgvT69Wt5jLKrKzWttPvRlYXwHR3CXrJXanbBr5tr7ZprNeFeH119Lr13o2OIen31x2qa19r97HOFcCV/MPnHL/Xi+bf08uVLPX/+q7oKUb+vaL+j9/VPf+eo+LFLvxNdr9bq+Jd/nQEAAOByEOAOAMAXxEwKYWGo51r27M9J/8pvfqjf/DnXy9c/1vd/+H29Ob6Svh713iHq1cevdffwTX3e/oweHlo9PNxbG4+K7b3a55/q8P69rq5u9PX2Pe2PprZ1tYeD2uMb88NOB7/W8crV3hy1s2jPfC9vTbqPcnNr90FHM0WPalwKbeiiykMrmRQVFCVrjt3M6gpmXeec6xi74PPQjNE5UVJU14fazQRv5vJ+Bo2gJnbB7jLJrTWLQSFKHqINM3x4q+Ch+6VJ824yD3eF0I0ldF23JgvRQj+ViPfDEv1cQtZNMeLdKeg7olOvbp+sun+6vJi7hb77tA9AyaI6+n0OnepuQzBw1zErM7OQd+N6F1QvD32OXGae9itJ1nXzmhS7X8VMM5+njuBhsORL79fLM61UrsOy6Uzta8OaK3uoDFgsDXyszRJ0CYHoUlZz+qGBLYMgtRnQc/lPSs/erwSDL804bsV6k+3MJvspf8J7HC/pRz7KAbqF4xxiIspjzNKb1Kq3+IbCEJw9jGRM/z0nxqKcbbzc81rsRm25L7wu05xtX8moV/6uvbf178mbRUDDqRiJalqVdGrLF00qa2U/SyP91cwsbFPur1/Ha2meslaZ1vJQy9OW6AepHvBhleVrFa7cT+3Eltueqhxb0j0lL5/84lu62AqzMIWli688lrW6Md1Bf6uvBzOu5e3UeUjBg7Mg/cVN+jZ/KR8ntptsu7B9HtC4FAw6S2d5x/P9+HQftf3WXs/2XT4TbNh+6ZyP5VM5B5M2ab6P3KkyyYOeH7P9Uh7GkADN/j51LKfqw9o+t+QxPWvn+VnLa3ktbK5vp9q9hbyVaW85x2t5KtPPy7g8V2Ua5wRSL17TxTpL11B5LMNyrx9bbbs8T7W6vRY0njt7vtWTDzdFHnx6LvL9p7/Xzk2tzpzc5yOXb70GN6e3sO5SHV67Jha3GQL8NFl+qt2Y5b32UDw/iPXXpxTPYeecj3PKetjuVP7Ozf/Wbdaeb7YsW7q/LrRHq+lveD5a/CKFNH823Kp8tkzvladw5blvcXnt/S3PrKfKplaeKS9bnsHzddae50sbPjAvFke+/ta6WVafMp+1D90L65y8xPp1fS29DZ81vPJi8deh1pIqytcXjmUpS2tVpPy7srvqfsrLo/Y4VU0/K9ulj8WT9PO+ocr6pfyXA6rbnOo8XJL12eWz/g/HsRBwP01ivp/axAm1/JjVl9X6805e9guTYpycLGND2k9pLfB9qY93KRj+zD1r7QOC+7h8Xl7dskmzMeT58YHvTzE5TPXWG/v51LvfyZVZmmFISr28Pkbt9/fcbh72dIQm86jYfadDqU66m6VZ0NM/3icTZGnq976nZJhKxYZQeaWRGPfUpWyyfvJ177JtFvv2x+Td0FO3fd9lLZN77PMVJJm5W5R1P9AbLQXnu0eP1v1qr5nL2i4zFrqxnDaYQpsC7bshr6NMbeMW3KU2yCwoWHSZW7Sg1k3WHj24zEKjEExBrZtFxTboGBuFKDM7qhsea7qhtIfWJOko6cGCmhC6vHrUPu66Be3OFaIOOugYTLZvZG7WmEketb9vvTkeZcdGbTBZc6Wg1vzqqPvmqHtJFuWhaRQsKNxK4Y2rCXe2b14phJ1Cs/dn+70sPFfTNGq/LilE3YdX+nH4TLdto2A7hc92aj59rua4szt1Y5tN80JXDx9501zLJL30W1n4rnb77+r65lbPnj1X+M6P5PpYu12j/f6ZvvnNb+mXP3xP/1r8Gf3jXzH9n/1eH3/PTX9b0j9WqkCZ/lzZ218bAAAA+MlAgDsAAF+AGE3NrtXXv/mZXn32XF23W0yLTf+S9Of/uvTXY9Snnz/oP/nP/kC3t7dqdjuFsNOrVz/W56/3appf17E96u7+uyaZ4uFWh6s38p+Lig+uj+6/rqv7qLv2Vsf23mL7oMNRatsPFF9GtS/uFQ8He3a40tXxWg/tg47tQe3zK7X7a8XDg0JsdROvpTbYcX9Qu2vl7V5t25jao668lV1fKQYptq1i28g9aLc7qmm6Y42ty6MrNkG7vku0+/XFrrcq2NiR7H1R2FAYaYmpn68iW9DFvvd/SimANaZ+sNRNOnTE5iOi3ieQ5itxNymo/zVLU3de+tlAugnlvVtzGGkYppnv3jAb+6D7t1Pq/THYmPnsrxR0Px50N6mI6SgpWlY+Za+5P9FP6yanZz7K3sveGAejuldrsyhN050PQFRn5cn2Ua7zNjaNAZ8a9FkJHE+sHw6YBLa7z9cdR7GqozhpYE3Kq8HyOauN+9bzl21XbCMp/VrC5L2lgdJqnoYgqPog6GR/xeBhmc+l99YGbGdlUNl+af1SyuPy8JcWA8/7KtBttzC6O0nTJouqf6+fCC0XWpnQZLS2kpaK5SqOc63wl0ab++2rgeMLhVsGxi0GM5xIZ0grH22vVc7SUjmt7XstnVp+lIb95oGBm9I71bB5NlaUHfswg3BZxgt5XCvbfD+zu9TaxVPbV61eVOpbHmx5VnBZStLr2yy9P8ljtm6ehzI/w1fqhuxX9pcVThlgWAZb1o613G8tiHYpaHQpuHjtvTIYNN9f/l5ZLueaBdeeeF17v8zXWnByjckWgkqm6awF/Jbr52mVdWUtT2vBtbWg3FNp5HWz3hyul09tv6fqnYZ9leVTubYWjqmWZnmdpfwNy7zeRiylder1WKuWy35L/SyvnTzv+bVVO76lNMtA7bUA7Fo9rbU9a6/S/tL79e3Xy22tnTinHm4NNK+lvVZOtfdOnetaPS/Xre1vLR9lO7aWh6XzUMvnqTTWjuHU61PtRMrDyTpQPLvMyzF9lli+by2pPYelfFXzounzU7mP5bZv/f5Tuy7KfC2uUznepfZ4/hwyLbv83bVr4lR9LPO/Zuka3rL/Mi+Ttn7YrH6MQ71Kf9ee6eeZPXksNvYdjXv3eh0Y3rP5uZay8qt91itu4PVjX8h/2l+lLuevJU0/I+RlVuZHG/+u5c2KdZZ4dpy1tNfyNCmrIi9rea19ns3zXaZTbleuXy4r8zV/IJv3EZT7qx2LTdf1cv08rcoxngrSlzT2DZTrl3lYOKzJi0rVHYomW750KcwzNl9/kmZFWjcWE0MUWViuNrVA9kr6Zf7HZaayb8z640kTSrg06aurH0j22aXvP17+1c55ibiU9e9aOrgh7aEcsn7RfJKTyez0mlevLc7p/632J9sky0tbrqbbpWHL/cML/fP5+o8NeN8e7D6/AkzdOejqjklmrSxEUz9beT9oEaNJJu8nUM8Kyn3sxOz2kd6wYMMq3T99a5yqidIzWZ+voQqNFaRbOaaEzRS8D4Tv7oH9BCjW1z/rl8VhHMXNvZsBybs89Hfd/rpw6yYW8tjNL28aa7L5kAsNW8kVpeBD3P2wJxtuTpKGjbvF3ZBRF4M/VoLuz9AH46e2MV1CZuZS0x9hmyL7uxEpkxQkD1EhNrKjKVjjbTzaQXILrULYWRsauQXZ8UH2EGUmNa15ULBgV266UtSdPTR30s5NzZXHEOVxL91fK8ade/jUzI/SsbUrczdrdHh40M3VC13vX/iL43O9Dn+oh/eOClem9uqg+OlBIb4naxrFeFDbvtbx+NqeP//Id7trHfyl3H9Nd/dv9Pnd7+vFwfX+++/L3XV/7/rxjz/Vp5/e61d/9Vd1s5d+06NuJf0f/pSkf1PSH0h6lTdIQWZRH/30p9pftWrbsPGaAAAAwE8yAtwBAPiCxNb00U9/JjPTH/3+13R4uJbUSnKpldqjdGykEEw3N1e6f7iTmSuYK5gU5HI/ysJOTfNMbXunrn/O5A+mYK7j7lPt4zPt1Mj8yg8xWhOOkt9Khyv5/U4y99umtdYPCmrUaC89uBSPsmCKzU531irI3Vqz5mEnDy5rutkuDrGRtVEhyoM1CsEtqlV0yY9ys6MsBAvWzVzh0ewok/Xxvk1r8sYtpl+RbE1BphhcFq3rcfR+5vXQyPvf27TYz6vu3s/x0XV0mrqfpLTQT7Xe/UilRe86vyx05df1QXYdsDK3ENJoS98d697Prh5k2RQk41wR3ZwjwfvXln5h06377UtZmjV+7AiV+pEI92w+k64zVWnKl67v2mW3t3fucoUQuhn/zWRBw2urdJ5v7SyvdayvdZoP6+aDGVkft7myzvw0emDjJvMc9OnW9lV/vXUYoAyaL/qr5+OM2bKU0b6K9Mu6Huih77s4oFQ24+CJjUWQrW6SNAwArJwry462PEfqvg6zNCBXDopZsV1NmVa+Xc2w/2Jgcci21wbnlqVzIGn4wsqkzIrjGo9/WsfSMhXb1NLI95nObZnZfBiuHoQ6L+Nhu6yu5eu56nU+pIs/X1aOck4KvF8/XUeT91NGssTyk5bPYDZWx2n9zNcb0ivypq51s7SvIa8+LfS8gN263wjOC2j40lD/b7rQ8i/2ZKXc/QZw5QoIyi5abTI9r9anUWkHy8q0cDHlq5Svh79nldn65d5/2Wuat8UgoL588jZn1tLa0t8pANHnRdzdEqvH048CVjfLj3nczUoI09KCocCsWpbjvGG1tCw7jHnbWb8XjUks5Xb1+i+ClsZb+fi3JIXsfNba4zx/ad1p+2Wz85EfrbLt82CmPFDKJumcPto8reklYAtbTPOeL5/ei2zxfAzV2GrLsv2WDWy+fWHpnIds7aX6km8/ez25XpWPlE/Sz8u7/PLT7Jxpvn1+vaXzuHSMY9nadMGsOV9uJK34t7Ys3/Hwi/RZutO6M68fedbKdMvTav1F35XfeG+q3SHW0s3zODkn2YZWPjxW6tZSfRjfK/Zae8gql2dN+FCew63QpOKZPb+G8qTXlGVf5nX5esyOtKjz022LC9fq7UHNUrsy7DkPyKrkt8z7EOhYtHsT1YOdrxOssm1NepQpklqrj/l7a21m/v58++V2bEigr1x5Oay3tZUyy+tp8Xa+/9qXL8p8nTqOJJR5yPI2eaN4r37vWq5f4zbTfKf9h0re0jZlHqfX5vIzSZnO9DxO8+nTFSdta37tLG6XH4MpC06u73P2fmqDZld9rY2tr3Oynmp7nam3Zdl6Vm5Vr3HjknHPPl+lslW9TavVp8m+JtV24ZnOtPC5oCzLLN/z0zk8Kw/rWvHQlH/WCRrfs+l+ltql6ucgV7avIZF0oUw/+6SGJ+VrcSbWfNn8XC1dX929s/KMkK826TTo0x6mvejTsWLbcvKBaqOeH1u2YuhyZi55/nk7ZXZ2Pst2LrsHW1l7xiMff3EvT6vfZvY52aZpDecoy/vYIXbiAshKO7/BZHmbpTFUyWmBZ5fB8nP+2KQVVSx96bZuqeTKlmvt0a28V0h93/xCu1juZ5Jmdkq8WEfDe1btD03tc3lall6n8h+DvBcaOZ9sNV3c95kPz6ealsXks9FwgPNdDOd5yzOyFq7nMwzlt7pxeUeYLJrkpdJ6Z/vK7v0LOywD3tfWPZeZKYTQ/6pBUJCrjUEhtJKCmibo9s2b4PH4vI8mVz9Ze5pW3bsBmODyOP2Ukn1rwdOTgcv76Xlk3s3sk758EbtRIcnSmI76n6ft66Jc7t1cQy5X95O+kiymL3N1Iesmmbui9w300GS5Wz+5UT+64jbU4C4cvvvsbT5MKOVBHt2lVrKgdD9y649elspDwV0KptZNwYNLrYKirBsd636U2KI8ZbR1b4Ir7EI/bBXN+zPcHoNM7rsQ1f0EcVCI5lFS9AdpF+QKMm+177uF7Rgl7eTuetBRdtXNmh+bne9cCh5kD+5BDzJ3Wdx53AXFYKZGai3qaAd5MB3b6OF4LQtB5o2aoxTuo0J4pSa0Ck3wEHaysJOFoNAEedPorjmoDVH3zYMOO6m5D9IbU/PZtcz3Uv9lFrOdmuZau90zD+FaHoPkUaZP1TR32jXPdHN91VeFKMm13zf64IP3dLUPujLTwYO+F/rZro4azmQ64TfP7vUzv/Cxvv7RK8X4NNcLAAAAvvoIcAcA4AvibgqN66d/7kd68d6tfvDdD/WjH75Ue9y5/qHbP/h3XMe/5PpLv7TXL/ziz+vjH/5IP/rkR3o43uv5h88Vru51fPP/Uzx+WzsFv7t/pjZcWzg+0/H379R+cKuPr1/pWXur51c7+f5a3j7zm9iqPbbWPtyr/Vxqm6CDzN80RwUza66kXSu344P2FuTBum68xqU2yjzIoqvpeh89Nt0wQmyPMoVuQMRM1gaTWRfq7tEaN1kTPCqYty5XHDoUPUYLahWtMVlweSv1gevdT2a6pcGXbvAiTQljpuAWzS1kEetpWo2ua6zrNTSPXcx7CkTvft/S3GOQe+h/gtOkENy96Xo2o3k3pUaQe1A/mUkaN3F59+OVXUR7UDe2Ya62PzBP44MhjXhkQz5pmfohnHw0SHK33/2dP9Dv/e53vxes0dV+p/2+0X63U9g12jVBTdOoCUEhBIVgZ3eKL8/83WUjRh/Wi951YQ8ziKdJXDwWARD1me6m66Q0sves6NwfZioqg3jzGYzSYGTq5K4cv0/+6dNXNoAyTLUyBhikZNM7lg1C9O9PB6HGwZ18mGdeuvmI0vT9cnio3HZxsKU81g1VYJZWvl35d75RvkllIG7yRyUAeRpak17nmcjWHwZ8sjWHpLJMroxeDvVmGIy2YQw5/WbttI6Ng4f57IJpm6HezopoHAwb35/W0mXTlMb00rWn8RiyNMtTU36poyiKyijtcKDZlzvGRCxbOW1fDdwqLqxyjsqhDLMRzHzocJKt7IXJJu1THpM/fVEWxPRfG8bhCkMa80Xel8lkwNjzTayy7/E85tW0HOqezRc5BC6Ocyzm6edl7uUfxQU4KcPiTHXBDt6/3V+JZSNQjhxXy61yGfpwGJP1VKxTS3NaPpUWcwgsHMttllR/TEMARpnh9F6eyTyQJVttchyWHUY57dvqVV1rRCvrp4CSsYHJzmHRmmQHOwYTZOFR+WEM9cMrRWrTP7N0i5qZJ3jieLvto6fvx4ztRj18MEveiuOdVuJBl3a9Uk2+X1BWzMkdxlWmMP1mW6X+DG8Vx2FSeuSczQNeu0/N0rdJfpatrzF51lq6ZjenNbZSy+svNArD9vN2fXk/lbzl1+Fkd+N+Y+xmCrRqGZYJdNuO+6zVByvWO3Vt93+lgOu+Dg/fzyrSnDXUZVrFeRvvNeV2s7vv5FaQr1dei9N9L50dr/y1dK7mZ3H+pdl6ueft8firBak8u1fDNrOGPr3vRdFMGsBh7fkRzs/uGGNTa/s02Vc9cC2/v5R5nSTUNffp+cLLcqzdfBfqzmSTPpixeu17vlqfzWma08eppfq2cn8YNq7nNcUzpdTzZtzrZ2SSRn6PqNxBFo936SqePivn95y8PcnbibFdG/dZu18s3evGcz9Wz+nJml4n2bbFPdzT+ZqV9zQP0/ZzWhrTZ7X69tN9r7QT+W07ey9Y/dcxpke7fgzTfc0DwdeugelzRdp+fMKu7684l7O2p7j+yn3NgsfLdWvPA7l5+14+n9Rn219Oa+06mKkVTblKVnfmnze7BKqflfLrrQgMnxzJ0M5ON8nzNfnoVrs3KHtvCLjLz0z9QL0o7slnr0naWe4m/Tnjcsv+tzzu8bNY5ezYQnlNCn6pFmX309pmsxNWXhHT+tufzcmRD/uZvFfbOvu3bCPSlweG1PKUxrKbPO4XxTPJVPbG9JcblFIa15+0pctHYtlz3UTRwJTlP75wlZ8t8yMcyqe8zU4zMj3OmoVqP69W+bPW2N81uw7yW0//v/mdsY/5VV7XKgeZvZu1u31lGLJc5GncqHJQRb5O77lu3kOVDqes4UXRzso3v8CydqNfdZgURaYQxo27ejUuk0nBxq9ErP0K6CR/ZtW/hyy6q21bta2rja2Ox1Yxuo5tq/bQ6nA8qo1R3/vejz7/R//J71qM7a9UCkWS3OTRYz9Lu5lnFSJVj3ymHu9zPwSXjxOfy9MdYXijC3OPGsPl47CudQ2hR7lMsQtfH7721c1tJEV1H3fSuXFJsZ863b2bAD26rFvTPLod3SSPZu4WuzD8LtXYZz1lr8tw/+nO5eMP2ZpZF8feSt6FbnfVIMi8dfOoaN2QUb8HqTVvrZU1YfjQGryRx270KSrKoyTrvvwUzD24+q8FBClGxRD7kaZWMlNzbHQVG3eP8ni0oC5I/rjby0Krg0V5lDfd2Jz7w0EWza/ilaw1KbQK4V7BTM1Oio3rGBo1zTOZudom6k00NYd7tYp6CAfZK5cdd5Jd6fr+SuG4lymo2e9loVHTXHsTGl3vHhTsTrKDtGtl+lj761e6eha1238oi0Heum5ununFi5d6+fIDvf/yAx0t6J/Ge/3jvfR33zTSfyjp70l63RX9zbN7ffTTn+obP/W5rp8dFds01AYAAABItv3nrgAAwBZ/8bf+xsl1ml2Uu/Tq02f6+Pvv6/NPnun2di/tpd3PNPYLe1eQ6e4u6v7DW9nXP5X8c//mN2717PAgP7T6ILzQw0OQHd7T4f7e2vZah9jqEO+k666TU9emq2B+OAbt962urLHDg7SPQeauQ2xNu71i2yo2O4Ug0/EoD3vtdy4/tl3otsuaKPNdo2iuEM08RvPgMjNrvJFHBZebN60kWfCdZGZRbh5bc3kwNRbMgnsMZjF0fYrB1I3qmLrfpgwmWdfn56GfDsTcPcgs9L9e2Zir6XtX+2k4FPq+0KAhXFFjILtZF3Te/a558NQvPQab9/+mmdmlLq1hgiDL/tPw7zg2lEa48p63+YRkNf1UKJL0L/36L3z9L/z5/9xf3TXhp1xuu2YXmn1ogoWmC263YN0U+WpMMguyJjRNCF14pvtk9qlu0pTp7sxMHruZNLzvho6KkkwxRplZkMxi1/va9wF3/7lL0eMwWOHu48w+/fqTkaJ+8G7tkbMcmJqGFeejN7ORrkkhp+3iMIgyHPCQF/duRvxJ3qRhxtBhH2m8yruZcFxx+ALAMFARxrmjuhlzurKN6bscqaz7PnTrBzliH2wd+/eHyhW6ghqDPMcS6sZWuiONHlPXejdQMgwcDUOFQ9r5GJyFfpQipgGZcdBOaZgiXQkaBzzzAdPJe8MPt3Y/sirrgtFCCON+ssGe4WD7HMVu1h8NM9ZZGpAahheGs2xZHhTS2JkP5y4OF1937O5R3czfUtdmWF8PfZyd05T9Qq33V0AamKsMpOVVJHT7TZMKpfOfj8ql/QyTlGV1y/ovqAw/39BXmDHQvjt50ftpjUIYjlnyYZAstj7sq42enaMhG8OxehoWyo5vqBM+1p2hXPvjjf11Mw7QZZUqK7smDdaZhnyl8hqDFPoG02zYl7JrYSzqbsA5xrFOdtWyq7MpoG+sK/3ESMXARwiSKfRtVr9++rJDv27TDJkby6K/9tPInbkN16z1BzUdGkv7s7588tnVXB7HPKfRvSGsz7L9alJhFCyMwY/mats8oL4fYjNTG2NfzvOgsGDdNZF+CWS8jaXxvaz9zAZP0zkZB1RdPrRtY9uTUksBoN7Xz6FupHtDVu+Hox8b6eH+Mfxmimf3jazepeusbePw9NCVo/XXf1QKRs4H2Icy3dnkWuib02HE1UI399lQcd3VZl/+GuqhJI/dzGjpHO6aZqgvrvSlsbGdl1xNE7r7aH+9jsH6Yx2SUlvYtWPuUbHt7+2WtzSpDQwKw3mJ3fENv1KjoU6O+ZfS7Tq/43oc24z0BYnJl42sy19qRzWUt4brOB1Juj96LIIMXApNf377a9HMFPviDhaGayAdh7sPs+SmAApLdaSvh+n+nA67y2d/fH3aMaa6kt43hW4sOQtcHgNS3aYhQWNwW1eIIW2TyrivI/n5TtfcMJZu6p7bhntEup+60tcH0xkOIQyNTPmFsba/N6QAw/QIO7S1XZDCcOJidyHKQvra6Nju5ed3/IWaPIDK+meEbl6+sUXoN+2rcfdjG+l89Gv0bWeqRumSGJ7S0/H2pz3GrA2zrFxTiU6bqf7+27d9nrcrKe0UwNTV1VQHUu5TWikQOG/Xu/M9NkKprg73aZPaYxwmA5wFOY2N9ZCHyTNIf0B9Tvr7rhdt3/QLSk0TFNs4POeG0NWT1Aane2JqY7s/x3qTym+4x2p8dkl1KQ9WTV9qTdfSUGbDrLfdv+Nzdf8ZoS+fsZ6Nd6b0tDUWUn+GY/ayvz7dvWsTh+fTMD6Lp7YjZp9Fovrf1bIxrfESHp9nx71k9Sm7htPzzvB2ukelJ+8uv6mdHFLI7rOpLRnqkJkaMx37+3Vqo5qQ6tJ4cQ2P6NIwAaVCd++aVK+syqU6lh3ueA6LL4Sl69T65PMf0hnOpaQY+/tJf0xmGib3tCYrT8/OpqXsTj+LdJ8PbHi/v+IUrJH6+S49HauNz8VDXvLnRCt+XUpdeXZfiEnrjz/SM2yWrq/h80kRzG/9bOFZIzMEpPV/p8/NaRPv2z55d/+Kill9n64/Pqf4kB+llr2/nwWl8jHZ8AtIqeEbr8HYn4fQ9PVesU+7r1v9l4PSM/Kk3dS0zUvtsUcfn03Goh7vcaEvK8/qvpncW3n2LDmZbLq/lw6XcZ92sNC3Wf0zW3bJpnZrCGQfjim1H1kbmZ2p9HwZLLt/e3e/VKor/bkJfa+RD5edjc9RLnmMUhhn6B+6NYZnI2Wf5eJwHtOxp2e5VP7pmNNBxjZOzsv42Nxdld5nLl2Xqc3uurPSM3/qbBjrT/rfYGF8DkhNtfLy748zfRZI94C8i6SvIzasm3/JrL9X+Hg9j/1B2VNfulWkOtE3FsN9Nm+rh1PpQ/+BK13rXX/MEERq6tuLbk9t/zyZfqGxewYfqkZWRt1zdQhjmxhjv8/+Osivs7FrK8ukSYrjnWx4vuzPk7urCVlgcJ9k1NjGWd+PkJ/7sc3rPu8pSz99EB56Yny8T8eYyseG+/3Yp2NjFvo6kw6xe94aej+G6zstdx+PcShHSaEJOh5bpeDw9LyUHpKtfyaJ6ZkxFelQB9TNMd0FZY7P3rLh/j3cR+XDOR1uMH1lGj5/pHqS2qhs3S4gVApN+qKk+jJLJyL75ZmhKmZh3n0DNDyfjLfz7kfqUnvh6Zm7e05LnzOt6Z7jva8g1th4Uxrup31a+eeIrC4NOx7KOrU1fduTLe6Kp2+jgk2el7KC6tvf4YF4mH1bGvM03Kv7ujd8AMjKPH/eDCHLb7qHm+RtVPoMqnS/TM8qY8M6HldfHvkx5VVw+AyYvZPya+ra+6G/It1XQxjOf7oWVKQ9pJkOoX8vFsvTsXbCULb5r5+mAPvQPZdF62bvyc6FKTTm+TGnz5jZZ00fGs6+P0XehV+7vE2fs2Ib1cbYHmOM3rZq2xije+utx2Ns26YJx48/+ezv/7v/p3//PyyON12V+SnNroHhcsl6KTzd6obPXGMOh7upD+3+uK1r8m+2W7OxInYpxiF3Sg8Uw0dkTymbpVNj6ZN3v2yyr+5OasPtPjV6fWB++uzVXaXdfsY0uu4kH9d1xf78eTorXZrm1v8WcVc03d03Be93s9y7d5/Bo8fobm6pkXeZovrP/BajTBajuWSxS7lrpTyGxls7Sq3L1Hh3w3a3cFSIJjs2XYx/PEiK2u2u+ufOo0e1urUrhXClVm/8PhzV2LWaN1Hyo9wb6c7VhMabZi/znRqZXA/aXz2TNSbTH+v6Kvhudy25KeyCPt/f6uD3erCdvr/fKYaj7HYn++Q9eWjMvx/kP36hZzdX2u33aprP1NjHuvVn+gP9Mz9++5Xe+/CvqPm/m7x1Nc+jvvaN13r5wa1unj8oRlNsl36X9nx//+/8zSdLCwAAAF8eAtwBAHhiWwLcJcnMFZruPnx/u9f93V6H22A//OP39RA/lYVgD3c7HR8+lsI31Lz33K6/+UZNeKVn79/bBz91kB0P9u2wkx8OJr+Wt9Giv1B7eG7H4xtza9V6tGN7tHAlC82VolvYNbIgM2+9G19xWdSuC1D31hRktpPJo7m7mYcQZKHvT7YsaNzUxROZUjC5mVkflN79TmEazvIgmZmZDTOmaxhfT/+FbtDGsvdS36SFrO899XLZ0D06xLd2Qw7DeM44wjYErmd95lk373hqir9TD2s2LLM05cwkzfwhy7J/aw9f+TZWvDcRzNIA4rC8aZqx1687B0OkTxOaMp2lh78hD7tdk8YIZs5+ciw3WCqBMhfT4YcygUk/+9nWztDS2Vk7a2v5yLc9dexb9/nYx/cyL3qLtGppp/Rqf2vhvVr92JKvtymHS1CWQfVq0/L5eqrz9y7KsTbqWFsn9xR1em0/a9fgluv4nPwsycaoNT+T29Lc1ibUy/3Unp6yHmxpT5fahmk5zdMs1685VSfK+lDu77H1c8t2KW5iaxpb81BrU2q1rGyja+lsKb9TbdBaOsPt3ebv1yzViTW1tE7Vx7e575zbJm/J36n25Nz0trJ84/Ixd2n9bJ3H3Fe2XPML2dr8VJ2HayzuYCVPb1vGS22f9HZ18FS7s7bNWjtaS2stX+U2W59zpvtZX7N2Tt71s2BZVrP9VQp3aUbsU+fi1Lprzw6PuccP+/Dpe9Vt7LzPEVvPzZbPWEv7WbqfS9uvqVP7rVk6V0/xTFrbZu3z6tozzdZ71pb711M9Q57zfPXY6/uc+/o0J7apLLbua60N3HLfOueZYM2p62upTV2qT0/1GbRu/a576jkx/9tnS6bpLOf/1B3rtHPaynybPAdLyx/btm3ZR1rnMdflOfXjMXXonOM/9fyx5Xl2bb18/cc8uz72HlLu4zHPQ0/5eaFMd+letb2+lt/nXd5Xud38L9kkpW4a8XKdPq3aPiffKLTpV/k2cju2Mbq8rS1ce92mb9ePy7pPZ9G7qdb7bJvMY4yKnn+Tq0x3cnF2K9jwTSTXGF5f7nOWv+y0evlVg355/tWi9G56KO73rfEbIdm64xsm9V/dG1/KpTxgPh2PuWTyMcBlmm+bBNmnzKbvUAzbmA1l4959iXzMa/etDJ9ukr7L5alc+vXTeukbCu7DN16H8u++EZPy5WO63ez5CuMXBrJ5CPo66P27HtMXTKz/GplFhe6PPuvWn/vobu795DJupmhd8bp5I3VfHnMP8nT6LARvZWp1cFP3hRg/3Hlog4dmN3zJ68fW6KjGXY0eotTGRv5Grk+brvDaoKBWsh/7m1ef6Or6oPc/vHL5XntFv7p60IsPv9NPWZW+qBYVfTGw/a1aKwLcAQAAfjLsvuwMAADwE2it13NY5m7WHrsw4qvro26ePci/Zvb1b78ydZ1sdri/tfvbzyW1tt+/lGIMkqn1xuL3G7PmPX3s9xZjY8H2MtuZ7LqbU2S3Vzcdi9muuQ56LskeFHS0KzNroqy1aOqmUDHXgyQP0s7cb+QxmmJj3YRgPulebL3t5hTrxrq7ecDd+0leXNqnAcI0PVZr3TKTyzyYhZ3c4jjdrqmfm1RdhHyaI8bMQ9/pqmwqkbE/0GRp6p30xb3u76Ej1KzvVA3pIPq0x5NhKe2uq9PGHfQB+nmHpIKn35Xse4u79IL6OYS72T/GyeV8TKc67DOUQf9HNn9vNu1fP41XnEy72f3RHtugebr93zEfUkh5yuchyvPXpfFwOObFky1b6/Tu18umJ8s7kieG/ul8yKP7z+WK5tkww2RyqGHuqzSJaxiOa5z2qpsnbm2Yxcfirg8eVGSTWA1TbJXlUqQ19NXX0myVl3mXn7yejFNLTfUDEMO2KV/jdPKTdSfHnU/ElU1IZOlnYvN6kAZiwlgPF+txNpAxXFrZvrMZfcY8NH12h7kpNa2Ped2x8VLzdMytJud8yFf5XmpXUplkeU2/+DArs7S9sr/zcms0Lfu0Tq2+5eepyNfs73x/eXprbUieLyvSKPeT5y2fkErFsrKu5NvneS3qoEtjvXFN81C7BvrlaY6tWX3Njy3Pb229cvsyDZ+v62UZN5qdh3LOy8X2oWzP0/WfX0v5evl+QrdvK+tJ/gsiZR5S3ttsP2U7379v5bZL+U9lsnA8i+1pKrdyWt6iXbFG03pVK9uyDGrtW1onv9b7f4c2t8xrpV5YXmZL9avWxsRsnex9T8vKc5vSaLO89cdkZZ1Lu4vZuvn9PbV9Ka993ZmlkbbNjytvt7Iysl1xPNI0Pc/ylKS2NX9dq6dry5P8fpqu9bTPfHmlHZjci4t70aTNTO+V9bZsH1st5zW/V6Q6kPJaHmso8pqd9+G+F6bvD21NXv/y6yFJeU9/l3nIz2Xtmijb/7R/ZWVSXqOp3qX7Zl4O6s9Dk21TXiNl/vN85f/m119e16XZc94wT2e+fZlGfoy1trXcNrv3en7eyvwnTVYHyzTy85Zfw7VyabOk8zra/ztERZR5Lu/jeZ7TPrN2eNhlWbblvTadz/welLdtqc7k11B2/NV2uCney+/ZtbRTHspruLyHZOd3cqqWzr+y9PN81JTXXn4vWmonyrRqdajMW17f83Odl1HtHmPT5ZN9Sl39LO9H+X5rx1Fev6XiWNw1f8bJ7p+W1/3yes73WT5zxOx4U3nk+S7btDK/5fWXt9np/qvKdmvnNq+Ha9NJNsW6ebqlsp3J2/NsH17Wo/KclZ+9a/pjHcq13Fd+rZTv521E2kdR/panUdm35/tMaaR9lO1VWid/fio/e5f5KPs2klp7n99/88+hKf20z/I48+f1vB4GTc9ZeV9ulU/rP69D/T7MNN5LY38faou0asdeq49epFe2v+nfWrvmxTbls6b357P8jFI8f1SfrWvtYdC0vMtyLZ8v8nXyci/vZfn9orgPZ1O1r7exabu2WL+8N6V/83Y83UfTsvw5tq+Xs3tRClLN27+yjVLxXnqrz68ry28qj7TPtK3194da2eVp5+1med+w4u98X3neUznky2r1Jt9f2lde79b2myvaSs/zVZSnpXpctit5nagFJ2f1wMr3yrq0dP5s/HPxnrKUp3RM5fWUn+vaMeXKdiDPkxXr5OcnayNc09czC+U+qUtWrFO7v6/dm0upXpfPcEuf2cpniPzaU/F+Ut5TyuPLrmW54uzXdcp2Pd+uvMbKOi8NfUauvq8/P/bZ+v3vc/Sx1/06niK6Pco9uqWhEkvpp3Lo61L30od9TOPjLZt3aHqoLplc5QRBluXVh+TCuLmZqYnu3v8gS0p+mCldkkVZK/dW41z4fWlbltDQ192tE4P5of+9vez0pp+19PH3hCW15jpEy8cMbPxFgO53A937m1T+2wDRU6bNGrNxjknvW8TJB2rrA9tNrUl3fWaDa1zNs0rmTQh9UH5MO/Qo02vby4Mp/Uxed5YbqZXpjdQP8jSpYex61l06XHt3ftssbP/BpVYeo0Jz5WZfk/u9/HCQ9TO9fxDHLzp0vyHUSi9d+vDYndj+rhRC4+7fkGkns72Pp94Ujw/D2I+7dDymW35eicaiWnh/q8dsAwAAgAtDgDsAAE9va6fJ0CcY3RRj15GTh93u9i+0v35fXcfSvYZJP+9vFeJeQc/1h7//H9mnP/p9uf6rkv2CTP++SW8k+zWXfknSgyx8V/r2nXT1TIrP9U2Len79SndfO5g8aC/p2zp4o6PJbvRwiLq9vZM9b6SX6vvNuj5I043eizcKirp/eGNte5DcFWPsugmbqNYe+t8z/cila7k/yBWtbVu53K8UrHFTPN5J11HayRSl2PWvKh4P3gWR7yV9oO6RpesfbCTdeEzjau7map8frA1RbTvpx847geXeKsZW1u3KdpK/VCprV4ytPL6Q9FxDf/RsllVzKZp7VDbpSP+rl8MY1tL5z37vNjv/fQ9t9zO0UW37UOtE744ldfu+kKnJszD0dUoyN5sE7g0/r1sMVtQGCWr7XrK07dZOx3L/XWm/kfQgyVzBdrJmN6wc26O5H7uF3pfBC6Xh1Wy/rUmWZu2ZDeZkX4Qo81hbfyHvNg99VSrrTWlWBzXSjz2PP2i+ng8zW8tz9Vy4j/+r6QBMPjhTCYA2K4+5SKs2CDbbf7HM+7KcDcB5+l31+XbVwZsFp+r0MHBUHNzS+tngy3RUZGXfS6rnLvuFrfOun211V/P2YbKrsnxPpZ2ntXXgcSHd6TVVKYeyfmXpWfp17cUy8PlPl5X1c0v++3UmY01b7/m1dfN6LE2O1Sy7LsYNxvO1VOfKc3hOPcrzlZbn6+X/Ssv7OPHevC1Z2K52jQ15OFEWtTTy17N7Q5mVhV8yyduocrNz76lleS4df63elPt4jLw9UzYgvLUd2mTxbGerDDubtvvntieTtIr3y/amdj+r3XMm61fu8Ut5WGs3V+8dC+U1O74sL+W+avWoXFZrh63ff75uKpctbWPadu3etpSvSTpF3mrt5FrbZlldXl0vLas8y2y9H5xoR1bqnSs9yG9pP9P7tf2sndOl+/OW56baduU9P09v6fXSvaO2XSUfk2eDKM++dr1+zGsm6/a/LraxTCb52XrNz9av7G7tnG89vpV6e7IlPpl+3xaUzwOTVbJ0Tl0bZb7cxy++l+nnf69dz2tM9eBNzZ8/1+4F9aSzZ9BzngtTO7B07teeBx5z7z/nGqnlofZe5dq2/n2vnb9z8rW1zc/XOfXeUn5q2y6tU7YH1br+yOeorc/XG87Dapu8JR+1upbe33qfXEqz9n6ev9pzTVqm7O+1+1W53tLx1NI6p51Ze95aY9M/q/eEtfpQK5OlZ6i1PHjeDg8bd3N+lOmX+0jtan4Qs3z2V4kXn9tqzykq3lvKti308+XPVnk6a3V5muj8kLfUha1t3VK66d6R+vamK7pvOZd5uuUzc/leuX9pXpbZg9bQfb10veTvnbqWS1uu4TK/j7n/rV2np+rj4+69JqmV69Yl2yn0/dpDBU33ji1Pj2XOXC61fRo2vruQWlAYe8uza6dpdh4s6M6C7mUyvTLpXpr9Ym2UdOiy0Y0tDMvNgpqwG8q00erhLLVj498m6Va2O1zHsEtzovTbmSlY0F0T9GDRzT9XaKKsuRqSDZa+O9TNCO5Hk1534wdmJu2uvE2llrYJu6EXXtZIoenK6RBN9z9QaKKC7eWSgjey/rtJTQhqG/PXtrdm95533SpHSR/3/5p1aTdpUnbTa0m345xG7ne6uXlf19fvy/2NugGRK+Xfe2kkfS7p+90J0P5qp93XXrr3jVaQ6dC0/t0/+Nza7/eNWKpfwV33V6bvfts97iTFYUp9pWbe/5Gkn5L08zIdJO3l+r/I9I8kC/rZX/ov+Yv3vm2xfSX3zxTsWvur98Y6MD3FLu2HEpZL7bEbHuy+JnCcnn/LP9bN6kRy6lkUAAAAf4IQ4A4AwBfrZCdMPsQZo0vx2L8K2Tp9J7NJx8Nrf3j4XOPkSv+Buu6vDyX95yV9IunvSP/sjyX9FUn/Bf0LHSX9jvTst4c0/1B/RkF/RtKDov9YMb6RPjx0yWRx4zs917f0ofZy3d23Oh4PMruSPtxJH0lqXX5I48fvSdpL9kLuUcfjnV6a6dnxTq8fXvXH0kpfbyUzxfYg99j158nVRzqre6PLRJTUeqvj8b5bx1ztPuqFud7bhdlULXnO29bUtt0kPI2kq77j8HC8l6mVmqiuI9LLIk8l3295k73uT8Rb9691M1g0cTZjxVyU9EzSdbFbM7UP92rbQ+rPNJf7bnelZn+l9diNL1HX+S99LlOj7tgkmQUPYezfjDHIfZe26A6mlemZXGOfdq0cMq791Y1Cs3t8eSyk73Lt9tdqdvvHpe2uw8OdJOnq6mbWVTzNgqk9HnQ83FWOcWUXclkI2u9n6Z+sxMfDvWJ7zMZiXCE02l3drG22zkzt4UHt8WFell9QvTUzxfao48OtNowuPTZIY6MnqJ9LzORtq+PDnboByu6ncxfqwxfu+HA3fAnprHJYvd6lNM63v7qRNY3qcUTbmZmOhwdJ0u5d1c+V6+JSztejnTxf2zxJ+7Nkofxn+2922u2v335//ZfshoHvL5qZPHZtg3s3HvoU18u59ymXq2n2aq6u3/o6PZGx2fl1uZr+njPbt5naw73a44P2V8/eTfus/F50p1PRDo983li9f9XO1+Z6Pr2/FHlPbfD1Oyu7PB+KUYeHO3U/Mb+t3q08bywF/IxlaSZvuznxTl0z6Tmq2yx0z3ohvNv6vt1bPr+8A8X9wuXWl5s/Sbll9XZT/XzC+9dbfV44e4euw+FOHrddE9Uk3kX7PJTng0zh3PvOk9XX/PnzMc8W5eejrbpoq4trB96K9fdXd3/39/IvzuK9c/rZJXnazx34Sjm/U9Bdx8O9mv2VLHwJ9aVyX3uyz5uTzxdRodk/yeem+nUndX3D/bV3TlmmfN7fKYTwbj5bnsxCrT/qC3x+XuKuw8Otmmb/7vo9Ls/bd+53QdrdcMZNd37zfu2nsVM3dlF+d6/i+CAdHrrreT+uvt8/VxOa4VIx3asLcK//qICZtNtlCaS/sm/5fd6nUG6qrWXarxl2UaHpvhkTwl675moYA2s/k+LDx5LfKTR7hTD+0ELbzTTfcykG6Zh+sC4qhIOeX32gYEFBrs8k/WC372e4965IU0YsSs9fSHbs7uevJf2LlHLU9e6lDrsP9H3dycJn4z6zUSnXUenLATJ1se+v0tIg6SMF+0Ah3Mj1gbpA8/9A0qeTIjmMqUj269L+5yQd+kPdS/aJ9OpvuY6vUiFm5f0Nl/6b6gZa8gDzdJ7/kbqxw19VV3GvJN2pO5tSjMc0eVCftuVns9YqeHm6F9qO2ptb6smfiIYIAAAAdQS4AwDwFWchD4iO6qPDNf4yZ1TXOfa5utkgorog7Y+l278/bHmnb0n6sxpnS/9b0vd/2E8TMexND/pL+l39uroOr+fqekj/ifRH/8CGXQ8dnvNfoP2Bmf7Q7xXj6269/W9IH/2aFB7SmES2vffpN5N0onsXCJ+l+zXvwumXAtzNuuD2w/Gg1Cnn+l1JnwydbWafjPt5IelbWTaGP74u6Zc1TpDyNLrhC9OpvmlJXTD4a3V9jxOm9nivNh7zZKxprhSavS66H9A1diaPp98m/a9lQLarK4tXsmkffLUcBs3uWiEMvwrwCMvpN7srhfDIsnbX4dgFuO93pwYUTTEe1B4fzt6NWdBud11Lf7X2HY8PXed2vkEI2u3eZhDQ1LYP/aDq1BdXb00xHtUeK0MxSxs8zTpVb18/l3S/ZHE83Odp20p9+EIdj13wVbK9HNav97TObn8ts+m95HG6Oit1dfTd1M/l6+JSztfjbTlfG1N66/ZnMeXF8k9c3Wxfu93Vwhrbubvc276+fxls+BKi+kkCn+Z6Oe8+5ZKasFOzK7+999Tm59elLnizek2n9R+02928o/a520/XRt9tWvuRzxurk+qV52t7Pa/eXyZ2+5snaoNP5SOvy9uc8bwxn2mwf4Yws5PHN3mOMtNud9PPAnhRz+cXdHOp3C+6crOnKbfxmtv2zPF096+3+rxwLncdj/fFZ+czk9C7aJ9TeR5kCo+977x1fc2fP7s2r+meszZvP/98tNnltgOPNE5Y8O7v5V+o6uk9Hu/7QNv56k/3uQNfMWc1Be6utn1Q01x9Se1A/b72NJ83x2cyj32A+xN8blq+7vTINrXP5+FWdmb7/3SW+6O+mOfnBX3/ZAi7d9jvcZHe/lm41Rh77iomrn5bjbrxmN9VP+P68qru0kcfSb/889IPo/TvKY+Uzv5X6n6+dzkWvfsS/F6znwTKQp9/pG6oorr5ViYpm2c8zdyeAtzth5LdPlf3dZw1e0nfl+zf0zg2FRTC+10b4V34eatfkPSbeXR75pv9v96d0zZf1qgrs9+W9L/L3g/Z4a7l8EbSf1tdUPudurG4e0n/saQfrGz3vqQ/12+T8nFUN7lVrR8h9BmfBt+P9pqOH0al4HezMD/fAAAAwJeIAHcAAP5ESLf8FAVczq6YpF7YVtKPVYmgVhcknzo9d+qC3D+X9I9dsximsvOs2+dD3rF2/A3pD39Ksjeq56kMkk9J2Xgokn7k+RwXFWZ9EFnqrGvk+nsm/TONHZBZ0PoraTieye5d0p/X2PH3lGz7GFIqlrJv2W9UC876SnRK9pOBJOVPBC9+AaBSFvVyyFJ6y/JYTv/t0nbvpq9PP3v6uDyctiX9+f6eVff3mLSm6b6bsjwvD67uWy2X4N0dd3dNPZ/v8S3P4VPo6kFuezlsuxbCk8WEp7y+y/q5dkyXcL7extu0XaV3VRbb8vh016q7f6n36e52+yx752mul/PP9RfT7p/7rDSu/27z192L5m103dPn5W2eIZfuL+em8xR8Upe3eNtnt1Q3Tq03fY76qrflX4RanXzKchuvua31/KnuX1/sZ7Pzr4mad93mPN1z2vl5yJ13nEufj7b6SWsHvohn5Euxfu6/nPqMrx7355K9ze+CvO3+6/e1p2ibpp8vnuYecrLNtXB2WY75/PL6TZf7o77cvlz/ksvlK6mLo57EOJ8KxT7PXl0n+O+rG59Zy4tL791IP//TLj90EehDDPQ4/jGGuq99vd/6L/Rq8RKshYifLWUj9fG7T0deWqm7Vk5NDP9M0meS/kjTyPT85Ejd54AbdQNAZXpr7WAqv4Oq89afdNtvG4v/Tv2q79Jx71UPcN8/Im8AAADAZbI/IT8tBgAAAAAAAAAAAAAAAAAAAAC4cD9Z04QAAAAAAAAAAAAAAAAAAAAAAL6yCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAAAAAAAAAAAF4EAdwAAAAAAAAAAAAAAAAAAAADARSDAHQAAAAAAAAAAAAAAAAAAAABwEQhwBwAAAAAAAAAAAAAAAAAAAABcBALcAQAAAAAAAAAAAAAAAAAAAAAXgQB3AAAAAAAAAAAAAAAAAAAAAMBFIMAdAAAAAAAAAAAAAAAAAAAAAHARCHAHAAAAAAAAAAAAAAAAAAAAAFwEAtwBAAAAAAAAAAAAAAAAAAAAABeBAHcAAAAAAAAAAAAAAAAAAAAAwEUgwB0AAAAAAAAAAAAAAAAAAAAAcBEIcAcAAAAAAAAAAAAAAAAAAAAAXAQC3AEAAAAAAAAAAAD8/9u1YwEAAACAQf7W09hRHAEAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAguAOAAAAAAAAAAAAAMCC4A4AAAAAAAAAAAAAwILgDgAAAAAAAAAAAADAQuJ7m1ejLDPxAAAAAElFTkSuQmCC\"}))));}var ForwardRef=/*#__PURE__*/React.forwardRef(SvgPc160X600);export default __webpack_public_path__+\"static/media/pc-160x600.081b4cad3b50c7c3993136fa37a4cf70.svg\";export{ForwardRef as ReactComponent};","var _rect, _rect2, _rect3, _rect4, _rect5, _rect6, _rect7, _rect8, _rect9, _rect10, _rect11, _rect12, _rect13, _rect14, _rect15, _rect16, _rect17, _rect18, _rect19, _rect20, _rect21, _rect22, _rect23, _defs;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgVideo300X250(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 417,\n height: 321,\n viewBox: \"0 0 417 321\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _rect || (_rect = /*#__PURE__*/React.createElement(\"rect\", {\n x: 417,\n width: 320.031,\n height: 417,\n transform: \"rotate(90 417 0)\",\n fill: \"url(#pattern0)\"\n })), _rect2 || (_rect2 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 269,\n y: 201,\n width: 99,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect3 || (_rect3 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 269,\n y: 238,\n width: 99,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect4 || (_rect4 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 269,\n y: 219,\n width: 89.76,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect5 || (_rect5 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 269,\n y: 256,\n width: 89.76,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect6 || (_rect6 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 269,\n y: 155,\n width: 99,\n height: 14,\n fill: \"#F0F0F0\"\n })), _rect7 || (_rect7 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 269,\n y: 176,\n width: 83.16,\n height: 14,\n fill: \"#F0F0F0\"\n })), _rect8 || (_rect8 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 269,\n y: 210,\n width: 76.56,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect9 || (_rect9 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 269,\n y: 247,\n width: 76.56,\n height: 6,\n fill: \"#F0F0F0\"\n })), _rect10 || (_rect10 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 34,\n width: 124.189,\n height: 13.5371,\n fill: \"#F0F0F0\"\n })), _rect11 || (_rect11 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 212.897,\n width: 181,\n height: 8.24,\n fill: \"#F0F0F0\"\n })), _rect12 || (_rect12 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 183.897,\n width: 181,\n height: 8.24,\n fill: \"#F0F0F0\"\n })), _rect13 || (_rect13 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 242.326,\n width: 181,\n height: 3.53143,\n fill: \"#F0F0F0\"\n })), _rect14 || (_rect14 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 270.577,\n width: 181,\n height: 3.53143,\n fill: \"#F0F0F0\"\n })), _rect15 || (_rect15 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 252.92,\n width: 181,\n height: 3.53143,\n fill: \"#F0F0F0\"\n })), _rect16 || (_rect16 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 281.171,\n width: 181,\n height: 3.53143,\n fill: \"#F0F0F0\"\n })), _rect17 || (_rect17 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 225.257,\n width: 156.687,\n height: 8.24,\n fill: \"#F0F0F0\"\n })), _rect18 || (_rect18 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 196.257,\n width: 156.687,\n height: 8.24,\n fill: \"#F0F0F0\"\n })), _rect19 || (_rect19 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 247.623,\n width: 156.687,\n height: 3.53143,\n fill: \"#F0F0F0\"\n })), _rect20 || (_rect20 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 275.874,\n width: 156.687,\n height: 3.53143,\n fill: \"#F0F0F0\"\n })), _rect21 || (_rect21 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 258.217,\n width: 156.687,\n height: 3.53143,\n fill: \"#F0F0F0\"\n })), _rect22 || (_rect22 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 34,\n y: 286.469,\n width: 156.687,\n height: 3.53143,\n fill: \"#F0F0F0\"\n })), _rect23 || (_rect23 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 261,\n y: 58,\n width: 114,\n height: 83,\n fill: \"#F0F0F0\"\n })), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern0\",\n patternContentUnits: \"objectBoundingBox\",\n width: 1,\n height: 1\n }, /*#__PURE__*/React.createElement(\"use\", {\n xlinkHref: \"#image0_616_383\",\n transform: \"matrix(0.00103413 0 0 0.000793651 -1.05067 -0.225397)\"\n })), /*#__PURE__*/React.createElement(\"image\", {\n id: \"image0_616_383\",\n width: 3000,\n height: 1846,\n xlinkHref: \"data:image/png;base64,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\"\n }))));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgVideo300X250);\nexport default __webpack_public_path__ + \"static/media/video_300x250.d2585fbfeca0281080a08af7a50b8ba2.svg\";\nexport { ForwardRef as ReactComponent };","var _rect, _rect2, _rect3, _defs;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgCtv(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 422,\n height: 325,\n viewBox: \"0 0 422 325\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _rect || (_rect = /*#__PURE__*/React.createElement(\"rect\", {\n x: 421.042,\n y: 0.812744,\n width: 323.556,\n height: 420.172,\n transform: \"rotate(90 421.042 0.812744)\",\n fill: \"url(#pattern0)\"\n })), _rect2 || (_rect2 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 40.166,\n y: 261.654,\n width: 157.187,\n height: 14.1542,\n fill: \"#F0F0F0\"\n })), _rect3 || (_rect3 = /*#__PURE__*/React.createElement(\"rect\", {\n x: 40.166,\n y: 286.93,\n width: 286.16,\n height: 23.2533,\n fill: \"#F0F0F0\"\n })), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern0\",\n patternContentUnits: \"objectBoundingBox\",\n width: 1,\n height: 1\n }, /*#__PURE__*/React.createElement(\"use\", {\n xlinkHref: \"#image0_644_455\",\n transform: \"matrix(0.00103413 0 0 0.000793651 -1.05067 -0.225397)\"\n })), /*#__PURE__*/React.createElement(\"image\", {\n id: \"image0_644_455\",\n width: 3000,\n height: 1846,\n xlinkHref: \"data:image/png;base64,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\"\n }))));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgCtv);\nexport default __webpack_public_path__ + \"static/media/ctv.9d407bf153e0998211780f2c91049007.svg\";\nexport { ForwardRef as ReactComponent };","var _path;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgExpandContent(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 24,\n height: 24,\n viewBox: \"0 0 24 24\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M3 21V13H5V17.6L17.6 5H13V3H21V11H19V6.4L6.4 19H11V21H3Z\",\n fill: \"black\"\n })));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgExpandContent);\nexport default __webpack_public_path__ + \"static/media/expand_content.f978811a635eeb5f4c834b705a0892d6.svg\";\nexport { ForwardRef as ReactComponent };","var _path;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgCollapseAll(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 24,\n height: 24,\n viewBox: \"0 0 24 24\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M3.4 22L2 20.6L8.6 14H4V12H12V20H10V15.4L3.4 22ZM12 12V4H14V8.6L20.6 2L22 3.4L15.4 10H20V12H12Z\",\n fill: \"black\"\n })));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgCollapseAll);\nexport default __webpack_public_path__ + \"static/media/collapse_all.d1f553d4816d7242753904c489c7d001.svg\";\nexport { ForwardRef as ReactComponent };","var _g;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgArrowUpRight(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 16,\n height: 16,\n viewBox: \"0 0 16 16\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n id: \"north_east_FILL0_wght400_GRAD0_opsz48 1\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n id: \"Vector\",\n d: \"M6.36675 13.3334L5.66675 12.6334L13.9667 4.33337H9.06675V3.33337H15.6667V9.93337H14.6667V5.03337L6.36675 13.3334Z\",\n fill: \"black\"\n }))));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgArrowUpRight);\nexport default __webpack_public_path__ + \"static/media/arrowUpRight.0f1c08bf9158bb91f6fc995114ac9f9f.svg\";\nexport { ForwardRef as ReactComponent };","import React, { useEffect, useRef } from 'react';\nimport { ReactComponent as Vtablet300250 } from '../../src/img/vipad-300x250.svg';\nimport { ReactComponent as Vtablet300600 } from '../../src/img/vipad-300x600.svg';\nimport { ReactComponent as Pc970250 } from '../../src/img/pc-970x250.svg';\nimport { ReactComponent as Pc160600 } from '../../src/img/pc-160x600.svg';\nimport { ReactComponent as Video300x250 } from '../../src/img/video_300x250.svg';\nimport { ReactComponent as Ctv } from '../../src/img/ctv.svg';\nimport { ReactComponent as Expand } from '../../src/img/expand_content.svg';\nimport { GetCopy } from '../util/GetCopy';\nimport { useAppState } from '../context/State';\nimport { ReactComponent as Collapse } from '../../src/img/collapse_all.svg';\n\nconst Device = ({ brandData, adSize, selected }) => {\n const sizeToUse = brandData['16:9'] ? brandData['16:9'] : brandData[adSize];\n const videoRef = useRef(null);\n const state = useAppState();\n\n useEffect(() => {\n const videoElement = videoRef.current;\n\n if (videoElement) {\n // Start playing the video\n videoElement.play();\n\n // Enable looping\n videoElement.loop = true;\n\n // Clean up on component unmount\n return () => {\n videoElement.pause();\n };\n }\n }, []);\n\n const getTablet = (adSize) => {\n switch (adSize) {\n case '300x250':\n return <Vtablet300250 />;\n case '300x600':\n return <Vtablet300600 />;\n case '970x250':\n return <Pc970250 />;\n case '160x600':\n return <Pc160600 />;\n case '16:9':\n return <Ctv />;\n default:\n return <Ctv />;\n }\n };\n\n if (sizeToUse) {\n return (\n <div className={`deviceDisplay x${adSize ? adSize : 'CTV'} d-flex justify-content-center`}>\n {getTablet(adSize)}\n <video\n ref={videoRef}\n autoPlay={true}\n playsInline\n controls={false}\n muted\n className={`deviceVideoFile ${'s' + (adSize || '169')}`}\n src={sizeToUse[0]['url']}\n />\n {selected !== 'Mobile' && (\n <div\n className=\"expandContract\"\n onClick={() => {\n state.setExpanded(!state.expaned);\n }}\n >\n {!state.expaned && (\n <>\n <Expand width={15} height={15} /> <GetCopy copy=\"expand\" />\n </>\n )}\n {state.expaned && (\n <>\n <Collapse width={15} height={15} /> <GetCopy copy=\"minimize\" />\n </>\n )}\n </div>\n )}\n </div>\n );\n }\n return null;\n};\n\nexport default Device;\n","var _g;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgBackButton(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 36,\n height: 36,\n viewBox: \"0 0 36 36\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n id: \"Back Button\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n id: \"Vector\",\n d: \"M13.4625 26.925L4.5 17.9625L13.4625 9L15.075 10.6125L8.85 16.8375H31.5V19.0875H8.85L15.075 25.3125L13.4625 26.925Z\",\n fill: \"black\"\n }))));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgBackButton);\nexport default __webpack_public_path__ + \"static/media/BackButton.bff6b598b550b230d51db5d5fb77c1c0.svg\";\nexport { ForwardRef as ReactComponent };","var _path;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgMobile(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 14,\n height: 20,\n viewBox: \"0 0 14 20\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M11 0H3C2.20435 0 1.44129 0.316071 0.87868 0.87868C0.316071 1.44129 0 2.20435 0 3V17C0 17.7956 0.316071 18.5587 0.87868 19.1213C1.44129 19.6839 2.20435 20 3 20H11C11.7956 20 12.5587 19.6839 13.1213 19.1213C13.6839 18.5587 14 17.7956 14 17V3C14 2.20435 13.6839 1.44129 13.1213 0.87868C12.5587 0.316071 11.7956 0 11 0ZM12 17C12 17.2652 11.8946 17.5196 11.7071 17.7071C11.5196 17.8946 11.2652 18 11 18H3C2.73478 18 2.48043 17.8946 2.29289 17.7071C2.10536 17.5196 2 17.2652 2 17V16H12V17ZM12 14H2V3C2 2.73478 2.10536 2.48043 2.29289 2.29289C2.48043 2.10536 2.73478 2 3 2H11C11.2652 2 11.5196 2.10536 11.7071 2.29289C11.8946 2.48043 12 2.73478 12 3V14Z\",\n fill: \"#006BD6\"\n })));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgMobile);\nexport default __webpack_public_path__ + \"static/media/mobile.4a9b38dec330b8ede3040af08a27b48c.svg\";\nexport { ForwardRef as ReactComponent };","import { useEffect, useState } from 'react';\nimport { useAppState } from '../context/State';\nimport { GetCopy } from '../util/GetCopy';\n\nexport const AdSize = ({ brandData, currentSize, setCurrentSize, selected, screenSizeHasAdSize }) => {\n const state = useAppState();\n const sizes = state.adSizes;\n const firstAvailableSize = state.adSizes.find((size) => {\n if (brandData[size] && screenSizeHasAdSize.includes(size)) {\n return true;\n }\n });\n\n const sizeToChoose = brandData['16:9']\n ? '16:9'\n : brandData['300x600']\n ? '300x600'\n : brandData['300x250']\n ? '300x250'\n : firstAvailableSize;\n\n const setSize = (e) => {\n setCurrentSize(e);\n };\n useEffect(() => {\n setCurrentSize(sizeToChoose);\n }, [selected, firstAvailableSize]);\n\n useEffect(() => {\n setSize(firstAvailableSize);\n }, [selected]);\n return (\n <div>\n <b>\n <GetCopy copy=\"ad size\" />\n </b>\n {!brandData['16:9'] && (\n <div className=\"adSizeHolder\">\n {sizes.map((size) => {\n const available = !!brandData[size];\n const activeOrNot = size === currentSize ? 'adSizeText active' : 'adSizeText';\n const mobile =\n selected === 'Mobile' && (currentSize === '300x600' || currentSize === '300x250') && 'mobileSize';\n if (available && screenSizeHasAdSize.includes(size)) {\n return (\n <span\n onClick={() => {\n setSize(size);\n }}\n className={`${activeOrNot} ${mobile}`}\n >\n {size}\n </span>\n );\n } else {\n return;\n }\n })}\n </div>\n )}\n {!!brandData['16:9'] && (\n <div className=\"adSizeHolder\">\n <span\n onClick={() => {\n // theres only one size for ctv\n // setSize(\"16:9\");\n }}\n className={'adSizeText active'}\n >\n 16:9\n </span>\n </div>\n )}\n </div>\n );\n};\n","var _path;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgPc(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 20,\n height: 18,\n viewBox: \"0 0 20 18\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M17 0H3C2.20435 0 1.44129 0.316071 0.87868 0.87868C0.316071 1.44129 0 2.20435 0 3V11C0 11.7956 0.316071 12.5587 0.87868 13.1213C1.44129 13.6839 2.20435 14 3 14H9V16H5C4.73478 16 4.48043 16.1054 4.29289 16.2929C4.10536 16.4804 4 16.7348 4 17C4 17.2652 4.10536 17.5196 4.29289 17.7071C4.48043 17.8946 4.73478 18 5 18H15C15.2652 18 15.5196 17.8946 15.7071 17.7071C15.8946 17.5196 16 17.2652 16 17C16 16.7348 15.8946 16.4804 15.7071 16.2929C15.5196 16.1054 15.2652 16 15 16H11V14H17C17.7956 14 18.5587 13.6839 19.1213 13.1213C19.6839 12.5587 20 11.7956 20 11V3C20 2.20435 19.6839 1.44129 19.1213 0.87868C18.5587 0.316071 17.7956 0 17 0ZM18 11C18 11.2652 17.8946 11.5196 17.7071 11.7071C17.5196 11.8946 17.2652 12 17 12H3C2.73478 12 2.48043 11.8946 2.29289 11.7071C2.10536 11.5196 2 11.2652 2 11V3C2 2.73478 2.10536 2.48043 2.29289 2.29289C2.48043 2.10536 2.73478 2 3 2H17C17.2652 2 17.5196 2.10536 17.7071 2.29289C17.8946 2.48043 18 2.73478 18 3V11Z\",\n fill: \"black\"\n })));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgPc);\nexport default __webpack_public_path__ + \"static/media/pc.128d4485f837e83dc27e7c3d142fffa2.svg\";\nexport { ForwardRef as ReactComponent };","var _path;\n\nvar _excluded = [\"title\", \"titleId\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nfunction SvgTv(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 18,\n height: 21,\n viewBox: \"0 0 18 21\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M15 5H11.41L13.71 2.71C13.8032 2.61676 13.8772 2.50607 13.9277 2.38425C13.9781 2.26243 14.0041 2.13186 14.0041 2C14.0041 1.86814 13.9781 1.73758 13.9277 1.61575C13.8772 1.49393 13.8032 1.38324 13.71 1.29C13.6168 1.19676 13.5061 1.1228 13.3842 1.07234C13.2624 1.02188 13.1319 0.995911 13 0.995911C12.7337 0.995911 12.4783 1.1017 12.29 1.29L9 4.54L7.83 2.54C7.76434 2.42575 7.67682 2.32555 7.57243 2.24513C7.46805 2.1647 7.34885 2.10562 7.22163 2.07127C7.09441 2.03691 6.96168 2.02794 6.83099 2.04489C6.70031 2.06183 6.57425 2.10434 6.46 2.17C6.34575 2.23566 6.24555 2.32318 6.16513 2.42757C6.0847 2.53195 6.02562 2.65116 5.99126 2.77837C5.95691 2.90559 5.94794 3.03833 5.96488 3.16901C5.98182 3.29969 6.02434 3.42575 6.09 3.54L7 5H3C2.20435 5 1.44129 5.31607 0.87868 5.87868C0.316071 6.44129 0 7.20435 0 8V16C0 16.7957 0.316071 17.5587 0.87868 18.1213C1.44129 18.6839 2.20435 19 3 19V20C3 20.2652 3.10536 20.5196 3.29289 20.7071C3.48043 20.8946 3.73478 21 4 21C4.26522 21 4.51957 20.8946 4.70711 20.7071C4.89464 20.5196 5 20.2652 5 20V19H13V20C13 20.2652 13.1054 20.5196 13.2929 20.7071C13.4804 20.8946 13.7348 21 14 21C14.2652 21 14.5196 20.8946 14.7071 20.7071C14.8946 20.5196 15 20.2652 15 20V19C15.7956 19 16.5587 18.6839 17.1213 18.1213C17.6839 17.5587 18 16.7957 18 16V8C18 7.20435 17.6839 6.44129 17.1213 5.87868C16.5587 5.31607 15.7956 5 15 5ZM16 16C16 16.2652 15.8946 16.5196 15.7071 16.7071C15.5196 16.8946 15.2652 17 15 17H3C2.73478 17 2.48043 16.8946 2.29289 16.7071C2.10536 16.5196 2 16.2652 2 16V8C2 7.73479 2.10536 7.48043 2.29289 7.2929C2.48043 7.10536 2.73478 7 3 7H15C15.2652 7 15.5196 7.10536 15.7071 7.2929C15.8946 7.48043 16 7.73479 16 8V16Z\",\n fill: \"black\"\n })));\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgTv);\nexport default __webpack_public_path__ + \"static/media/tv.caeeb7f3e52b761caaf22f41aee0833e.svg\";\nexport { ForwardRef as ReactComponent };","import { GetCopy } from '../util/GetCopy';\nimport { ReactComponent as Mobile } from '../../src/img/mobile.svg';\nimport { ReactComponent as PC } from '../../src/img/pc.svg';\nimport { ReactComponent as CTV } from '../../src/img/tv.svg';\n\nexport const ScreenSize = ({ brandData, ScreenSizes, selected, updateSelected }) => {\n const setActice = (e) => {\n updateSelected(e);\n };\n\n //change this to use the airtable config\n const hasDesktop = brandData.hasOwnProperty('160x600') || brandData.hasOwnProperty('970x250') || false;\n const hasCtv = brandData.hasOwnProperty('16:9') || false;\n const hasMobile = brandData.hasOwnProperty('300x600') || brandData.hasOwnProperty('300x250') || false;\n\n return (\n <div>\n <b>\n <GetCopy copy=\"screen size\" />\n </b>\n {/* display */}\n {!brandData['Video'] && (\n <div className=\"screenIcons\">\n {ScreenSizes.map((size) => {\n if (size === 'Mobile' && hasMobile) {\n return (\n <div\n onClick={() => {\n setActice(size);\n }}\n className={size === selected ? 'active' : 'inactive'}\n >\n <Mobile />\n </div>\n );\n } \n if (size === 'Desktop' && hasDesktop) {\n \n return (\n <div\n onClick={() => {\n setActice(size);\n }}\n className={size === selected ? 'active' : 'inactive'}\n >\n <PC />\n </div>\n );\n }\n if (size === 'CTV' && hasCtv) {\n return (\n <div\n onClick={() => {\n setActice('CTV');\n }}\n className={size === 'CTV' ? 'active' : 'inactive'}\n >\n {updateSelected(\"CTV\")}\n <CTV />\n </div>\n );\n }\n })}\n </div>\n )}\n {/* video */}\n {!!brandData['Video'] && (\n <div className=\"screenIcons\">\n {ScreenSizes.map((size, i) => {\n if (size === 'Mobile') {\n return (\n <div\n key={size}\n onClick={() => {\n setActice(size);\n }}\n className={size === selected ? 'active' : 'inactive'}\n >\n <Mobile />\n </div>\n );\n }\n if (size === 'Desktop') {\n return (\n <div\n onClick={() => {\n setActice(size);\n }}\n className={'unavailable inactive'}\n >\n <PC />\n </div>\n );\n }\n if (size === 'CTV') {\n return (\n <div\n onClick={() => {\n setActice('CTV');\n }}\n className={'unavailable inactive'}\n >\n <CTV />\n </div>\n );\n }\n return null;\n })}\n </div>\n )}\n </div>\n );\n};\n","import { useAppState } from '../context/State';\nimport { GetCopy } from '../util/GetCopy';\nimport Device from './Device';\nimport { ReactComponent as ArrowRight } from '../../src/img/arrowUpRight.svg';\nimport { ReactComponent as ArrowLeft } from '../../src/img/BackButton.svg';\nimport { AdSize } from './AdSize';\nimport { ScreenSize } from './ScreenSize';\nimport { useEffect, useState } from 'react';\nimport { useNavigate } from 'react-router-dom';\n\nconst BrandBody = ({ brandData }) => {\n const state = useAppState();\n const navigate = useNavigate();\n const locale = state.locale.toLowerCase();\n const linkLocale = locale === 'en' ? '' : locale;\n const [currentSize, setCurrentSize] = useState();\n const ScreenSizes = ['Mobile', 'Desktop', 'CTV'];\n const [selected, updateSelected] = useState('Mobile');\n const availableSizes = state.config.filter((item) => item.fields.Name === selected);\n const screenSizesWithData = state.config.filter(\n (item) => ScreenSizes.includes(item.fields.Name) && item.fields?.Sizes?.length,\n );\n const screenSizeHasAdSize = availableSizes?.[0]?.fields?.Sizes;\n const goBack = () => {\n navigate(-1);\n };\n const [dimensions, setDimensions] = useState({\n height: window.innerHeight,\n width: window.innerWidth,\n });\n useEffect(() => {\n function handleResize() {\n setDimensions({\n height: window.innerHeight,\n width: window.innerWidth,\n });\n }\n\n window.addEventListener('resize', handleResize);\n return () => {\n window.removeEventListener('resize', handleResize);\n };\n });\n const [deviceSize, updateDeviceSize] = useState(dimensions.width > 992 ? 'Desktop' : 'Mobile');\n useEffect(() => {\n updateDeviceSize(dimensions.width > 992 ? 'Desktop' : 'Mobile');\n }, [dimensions.width]);\n const expandedView = state.expaned && deviceSize === 'Desktop';\n return (\n <div className=\"boundingBox\">\n <div className={`brandBody container ${expandedView ? 'expanded' : null}`}>\n <div className=\"fullSizeDevice\">\n {expandedView && (\n <Device className=\"marginContainerDevice\" selected={selected} adSize={currentSize} brandData={brandData} />\n )}\n </div>\n <div className=\"deviceBackHolder\">\n <div className=\"backButton\">\n <span onClick={goBack} className=\"backbuttonholder\">\n <ArrowLeft />\n <span className=\"goBackCopy\">\n <GetCopy copy=\"back\" />\n </span>\n </span>\n </div>\n {!expandedView && (\n <Device className=\"marginContainerDevice\" selected={selected} adSize={currentSize} brandData={brandData} />\n )}\n </div>\n{console.log(locale)}\n <div className=\"brandCopy\">\n <div className=\"flex-me\">\n <div className=\"description\">\n <div className=\"holder mb-3\">\n <h1>{brandData.Brand}</h1>\n {console.log(brandData)}\n <p>{brandData[`${locale.toUpperCase()} Description`]}</p>\n {!brandData['16:9'] && (\n <a\n className=\"learnMoreAbout\"\n href={`/digital-ad-formats/#${brandData['Format'].toLowerCase().replace(/ /g, '-')}`}\n >\n <GetCopy copy=\"learn more\" />\n {brandData['Format']}\n \n <ArrowRight />\n </a>\n )}\n {!!brandData['16:9'] && (\n <a href={`/digital-ad-formats/#Video`} className=\"learnMoreAbout\">\n <GetCopy copy=\"learn more\" />\n {brandData['Format']}\n \n <ArrowRight />\n </a>\n )}\n </div>\n </div>\n <div className=\"settings\">\n <div className=\"holder mb-3\">\n <div>\n <ScreenSize\n brandData={brandData}\n ScreenSizes={ScreenSizes}\n selected={selected}\n updateSelected={updateSelected}\n screenSizesWithData={screenSizesWithData}\n />\n </div>\n <div>\n <AdSize\n brandData={brandData}\n currentSize={currentSize}\n setCurrentSize={setCurrentSize}\n selected={selected}\n screenSizeHasAdSize={screenSizeHasAdSize}\n />\n </div>\n {brandData['Success Story Path'] && (\n <div>\n <GetCopy copy=\"read the full success story\" />\n <a href={window.location.origin + linkLocale + brandData['Success Story Path']}>\n \n <GetCopy copy=\"here\" />\n </a>\n </div>\n )}\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n );\n};\n\nexport default BrandBody;\n","import React from 'react';\nimport Hero from './Hero';\nimport { useParams } from 'react-router-dom';\nimport { useAppState } from '../context/State';\nimport BrandBody from './BrandBody';\n\nconst BrandPage = () => {\n const state = useAppState();\n const adData = state.adData;\n const videoData = state.videoData;\n const { brand } = useParams();\n const modifiedStr = brand.toLowerCase().trim().replace(/ /g, '-');\n const dataToFilter = state.activeOption === 'Video' ? videoData : adData;\n\n const brandData = dataToFilter.filter(\n (brand) => brand.fields.Brand.toLowerCase().trim().replace(/ /g, '-') === modifiedStr,\n )[0];\n if (brandData === undefined) {\n state.setActiveOption('Video');\n }\n\n return (brandData && <BrandBody brandData={brandData.fields} />) || 'sorry, brand not found';\n};\n\nexport default BrandPage;\n","import { useEffect } from 'react';\nimport { useLocation } from 'react-router-dom';\n\nfunction ScrollToTop() {\n const { pathname } = useLocation();\n\n useEffect(() => {\n window.setTimeout(() => {\n window.scrollTo(-800, 0);\n }, 100);\n }, [pathname]);\n\n return null;\n}\n\nexport default ScrollToTop;\n","import type { WrappedFunction } from '@sentry/types';\n\nimport { getGlobalSingleton, GLOBAL_OBJ } from './worldwide';\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\nexport const CONSOLE_LEVELS = ['debug', 'info', 'warn', 'error', 'log', 'assert', 'trace'] as const;\nexport type ConsoleLevel = (typeof CONSOLE_LEVELS)[number];\n\ntype LoggerMethod = (...args: unknown[]) => void;\ntype LoggerConsoleMethods = Record<(typeof CONSOLE_LEVELS)[number], LoggerMethod>;\n\n/** JSDoc */\ninterface Logger extends LoggerConsoleMethods {\n disable(): void;\n enable(): void;\n}\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nexport function consoleSandbox<T>(callback: () => T): T {\n if (!('console' in GLOBAL_OBJ)) {\n return callback();\n }\n\n const originalConsole = GLOBAL_OBJ.console as Console & Record<string, unknown>;\n const wrappedLevels: Partial<LoggerConsoleMethods> = {};\n\n // Restore all wrapped console methods\n CONSOLE_LEVELS.forEach(level => {\n // TODO(v7): Remove this check as it's only needed for Node 6\n const originalWrappedFunc =\n originalConsole[level] && (originalConsole[level] as WrappedFunction).__sentry_original__;\n if (level in originalConsole && originalWrappedFunc) {\n wrappedLevels[level] = originalConsole[level] as LoggerConsoleMethods[typeof level];\n originalConsole[level] = originalWrappedFunc as Console[typeof level];\n }\n });\n\n try {\n return callback();\n } finally {\n // Revert restoration to wrapped state\n Object.keys(wrappedLevels).forEach(level => {\n originalConsole[level] = wrappedLevels[level as (typeof CONSOLE_LEVELS)[number]];\n });\n }\n}\n\nfunction makeLogger(): Logger {\n let enabled = false;\n const logger: Partial<Logger> = {\n enable: () => {\n enabled = true;\n },\n disable: () => {\n enabled = false;\n },\n };\n\n if (__DEBUG_BUILD__) {\n CONSOLE_LEVELS.forEach(name => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n logger[name] = (...args: any[]) => {\n if (enabled) {\n consoleSandbox(() => {\n GLOBAL_OBJ.console[name](`${PREFIX}[${name}]:`, ...args);\n });\n }\n };\n });\n } else {\n CONSOLE_LEVELS.forEach(name => {\n logger[name] = () => undefined;\n });\n }\n\n return logger as Logger;\n}\n\n// Ensure we only have a single logger instance, even if multiple versions of @sentry/utils are being used\nlet logger: Logger;\nif (__DEBUG_BUILD__) {\n logger = getGlobalSingleton('logger', makeLogger);\n} else {\n logger = makeLogger();\n}\n\nexport { logger };\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n\nimport type { PolymorphicEvent, Primitive } from '@sentry/types';\n\n// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isError(wat: unknown): wat is Error {\n switch (objectToString.call(wat)) {\n case '[object Error]':\n case '[object Exception]':\n case '[object DOMException]':\n return true;\n default:\n return isInstanceOf(wat, Error);\n }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat: unknown, className: string): boolean {\n return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isErrorEvent(wat: unknown): boolean {\n return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isDOMError(wat: unknown): boolean {\n return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isDOMException(wat: unknown): boolean {\n return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isString(wat: unknown): wat is string {\n return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isPrimitive(wat: unknown): wat is Primitive {\n return wat === null || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isPlainObject(wat: unknown): wat is Record<string, unknown> {\n return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isEvent(wat: unknown): wat is PolymorphicEvent {\n return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isElement(wat: unknown): boolean {\n return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isRegExp(wat: unknown): wat is RegExp {\n return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nexport function isThenable(wat: any): wat is PromiseLike<any> {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return Boolean(wat && wat.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isSyntheticEvent(wat: unknown): boolean {\n return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value is NaN\n * {@link isNaN}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isNaN(wat: unknown): boolean {\n return typeof wat === 'number' && wat !== wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nexport function isInstanceOf(wat: any, base: any): boolean {\n try {\n return wat instanceof base;\n } catch (_e) {\n return false;\n }\n}\n","import { isString } from './is';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nconst DEFAULT_MAX_STRING_LENGTH = 80;\n\n/**\n * Given a child DOM element, returns a query-selector statement describing that\n * and its ancestors\n * e.g. [HTMLElement] => body > div > input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nexport function htmlTreeAsString(\n elem: unknown,\n options: string[] | { keyAttrs?: string[]; maxStringLength?: number } = {},\n): string {\n type SimpleNode = {\n parentNode: SimpleNode;\n } | null;\n\n // try/catch both:\n // - accessing event.target (see getsentry/raven-js#838, #768)\n // - `htmlTreeAsString` because it's complex, and just accessing the DOM incorrectly\n // - can throw an exception in some circumstances.\n try {\n let currentElem = elem as SimpleNode;\n const MAX_TRAVERSE_HEIGHT = 5;\n const out = [];\n let height = 0;\n let len = 0;\n const separator = ' > ';\n const sepLength = separator.length;\n let nextStr;\n const keyAttrs = Array.isArray(options) ? options : options.keyAttrs;\n const maxStringLength = (!Array.isArray(options) && options.maxStringLength) || DEFAULT_MAX_STRING_LENGTH;\n\n while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) {\n nextStr = _htmlElementAsString(currentElem, keyAttrs);\n // bail out if\n // - nextStr is the 'html' element\n // - the length of the string that would be created exceeds maxStringLength\n // (ignore this limit if we are on the first iteration)\n if (nextStr === 'html' || (height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength)) {\n break;\n }\n\n out.push(nextStr);\n\n len += nextStr.length;\n currentElem = currentElem.parentNode;\n }\n\n return out.reverse().join(separator);\n } catch (_oO) {\n return '<unknown>';\n }\n}\n\n/**\n * Returns a simple, query-selector representation of a DOM element\n * e.g. [HTMLElement] => input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction _htmlElementAsString(el: unknown, keyAttrs?: string[]): string {\n const elem = el as {\n tagName?: string;\n id?: string;\n className?: string;\n getAttribute(key: string): string;\n };\n\n const out = [];\n let className;\n let classes;\n let key;\n let attr;\n let i;\n\n if (!elem || !elem.tagName) {\n return '';\n }\n\n out.push(elem.tagName.toLowerCase());\n\n // Pairs of attribute keys defined in `serializeAttribute` and their values on element.\n const keyAttrPairs =\n keyAttrs && keyAttrs.length\n ? keyAttrs.filter(keyAttr => elem.getAttribute(keyAttr)).map(keyAttr => [keyAttr, elem.getAttribute(keyAttr)])\n : null;\n\n if (keyAttrPairs && keyAttrPairs.length) {\n keyAttrPairs.forEach(keyAttrPair => {\n out.push(`[${keyAttrPair[0]}=\"${keyAttrPair[1]}\"]`);\n });\n } else {\n if (elem.id) {\n out.push(`#${elem.id}`);\n }\n\n // eslint-disable-next-line prefer-const\n className = elem.className;\n if (className && isString(className)) {\n classes = className.split(/\\s+/);\n for (i = 0; i < classes.length; i++) {\n out.push(`.${classes[i]}`);\n }\n }\n }\n const allowedAttrs = ['aria-label', 'type', 'name', 'title', 'alt'];\n for (i = 0; i < allowedAttrs.length; i++) {\n key = allowedAttrs[i];\n attr = elem.getAttribute(key);\n if (attr) {\n out.push(`[${key}=\"${attr}\"]`);\n }\n }\n return out.join('');\n}\n\n/**\n * A safe form of location.href\n */\nexport function getLocationHref(): string {\n try {\n return WINDOW.document.location.href;\n } catch (oO) {\n return '';\n }\n}\n\n/**\n * Gets a DOM element by using document.querySelector.\n *\n * This wrapper will first check for the existance of the function before\n * actually calling it so that we don't have to take care of this check,\n * every time we want to access the DOM.\n *\n * Reason: DOM/querySelector is not available in all environments.\n *\n * We have to cast to any because utils can be consumed by a variety of environments,\n * and we don't want to break TS users. If you know what element will be selected by\n * `document.querySelector`, specify it as part of the generic call. For example,\n * `const element = getDomElement<Element>('selector');`\n *\n * @param selector the selector string passed on to document.querySelector\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getDomElement<E = any>(selector: string): E | null {\n if (WINDOW.document && WINDOW.document.querySelector) {\n return WINDOW.document.querySelector(selector) as unknown as E;\n }\n return null;\n}\n","import { isRegExp, isString } from './is';\n\nexport { escapeStringForRegex } from './vendor/escapeStringForRegex';\n\n/**\n * Truncates given string to the maximum characters count\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string (0 = unlimited)\n * @returns string Encoded\n */\nexport function truncate(str: string, max: number = 0): string {\n if (typeof str !== 'string' || max === 0) {\n return str;\n }\n return str.length <= max ? str : `${str.slice(0, max)}...`;\n}\n\n/**\n * This is basically just `trim_line` from\n * https://github.com/getsentry/sentry/blob/master/src/sentry/lang/javascript/processor.py#L67\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string\n * @returns string Encoded\n */\nexport function snipLine(line: string, colno: number): string {\n let newLine = line;\n const lineLength = newLine.length;\n if (lineLength <= 150) {\n return newLine;\n }\n if (colno > lineLength) {\n // eslint-disable-next-line no-param-reassign\n colno = lineLength;\n }\n\n let start = Math.max(colno - 60, 0);\n if (start < 5) {\n start = 0;\n }\n\n let end = Math.min(start + 140, lineLength);\n if (end > lineLength - 5) {\n end = lineLength;\n }\n if (end === lineLength) {\n start = Math.max(end - 140, 0);\n }\n\n newLine = newLine.slice(start, end);\n if (start > 0) {\n newLine = `'{snip} ${newLine}`;\n }\n if (end < lineLength) {\n newLine += ' {snip}';\n }\n\n return newLine;\n}\n\n/**\n * Join values in array\n * @param input array of values to be joined together\n * @param delimiter string to be placed in-between values\n * @returns Joined values\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function safeJoin(input: any[], delimiter?: string): string {\n if (!Array.isArray(input)) {\n return '';\n }\n\n const output = [];\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < input.length; i++) {\n const value = input[i];\n try {\n output.push(String(value));\n } catch (e) {\n output.push('[value cannot be serialized]');\n }\n }\n\n return output.join(delimiter);\n}\n\n/**\n * Checks if the given value matches a regex or string\n *\n * @param value The string to test\n * @param pattern Either a regex or a string against which `value` will be matched\n * @param requireExactStringMatch If true, `value` must match `pattern` exactly. If false, `value` will match\n * `pattern` if it contains `pattern`. Only applies to string-type patterns.\n */\nexport function isMatchingPattern(\n value: string,\n pattern: RegExp | string,\n requireExactStringMatch: boolean = false,\n): boolean {\n if (!isString(value)) {\n return false;\n }\n\n if (isRegExp(pattern)) {\n return pattern.test(value);\n }\n if (isString(pattern)) {\n return requireExactStringMatch ? value === pattern : value.includes(pattern);\n }\n\n return false;\n}\n\n/**\n * Test the given string against an array of strings and regexes. By default, string matching is done on a\n * substring-inclusion basis rather than a strict equality basis\n *\n * @param testString The string to test\n * @param patterns The patterns against which to test the string\n * @param requireExactStringMatch If true, `testString` must match one of the given string patterns exactly in order to\n * count. If false, `testString` will match a string pattern if it contains that pattern.\n * @returns\n */\nexport function stringMatchesSomePattern(\n testString: string,\n patterns: Array<string | RegExp> = [],\n requireExactStringMatch: boolean = false,\n): boolean {\n return patterns.some(pattern => isMatchingPattern(testString, pattern, requireExactStringMatch));\n}\n","/* eslint-disable max-lines */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { WrappedFunction } from '@sentry/types';\n\nimport { htmlTreeAsString } from './browser';\nimport { isElement, isError, isEvent, isInstanceOf, isPlainObject, isPrimitive } from './is';\nimport { truncate } from './string';\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, <other\n * args>)` or `origMethod.apply(this, [<other args>])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nexport function fill(source: { [key: string]: any }, name: string, replacementFactory: (...args: any[]) => any): void {\n if (!(name in source)) {\n return;\n }\n\n const original = source[name] as () => any;\n const wrapped = replacementFactory(original) as WrappedFunction;\n\n // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n if (typeof wrapped === 'function') {\n try {\n markFunctionWrapped(wrapped, original);\n } catch (_Oo) {\n // This can throw if multiple fill happens on a global object like XMLHttpRequest\n // Fixes https://github.com/getsentry/sentry-javascript/issues/2043\n }\n }\n\n source[name] = wrapped;\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nexport function addNonEnumerableProperty(obj: { [key: string]: unknown }, name: string, value: unknown): void {\n Object.defineProperty(obj, name, {\n // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n value: value,\n writable: true,\n configurable: true,\n });\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nexport function markFunctionWrapped(wrapped: WrappedFunction, original: WrappedFunction): void {\n const proto = original.prototype || {};\n wrapped.prototype = original.prototype = proto;\n addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n}\n\n/**\n * This extracts the original function if available. See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\nexport function getOriginalFunction(func: WrappedFunction): WrappedFunction | undefined {\n return func.__sentry_original__;\n}\n\n/**\n * Encodes given object into url-friendly format\n *\n * @param object An object that contains serializable values\n * @returns string Encoded\n */\nexport function urlEncode(object: { [key: string]: any }): string {\n return Object.keys(object)\n .map(key => `${encodeURIComponent(key)}=${encodeURIComponent(object[key])}`)\n .join('&');\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argurment itself, when value is neither an Event nor\n * an Error.\n */\nexport function convertToPlainObject<V>(value: V):\n | {\n [ownProps: string]: unknown;\n type: string;\n target: string;\n currentTarget: string;\n detail?: unknown;\n }\n | {\n [ownProps: string]: unknown;\n message: string;\n name: string;\n stack?: string;\n }\n | V {\n if (isError(value)) {\n return {\n message: value.message,\n name: value.name,\n stack: value.stack,\n ...getOwnProperties(value),\n };\n } else if (isEvent(value)) {\n const newObj: {\n [ownProps: string]: unknown;\n type: string;\n target: string;\n currentTarget: string;\n detail?: unknown;\n } = {\n type: value.type,\n target: serializeEventTarget(value.target),\n currentTarget: serializeEventTarget(value.currentTarget),\n ...getOwnProperties(value),\n };\n\n if (typeof CustomEvent !== 'undefined' && isInstanceOf(value, CustomEvent)) {\n newObj.detail = value.detail;\n }\n\n return newObj;\n } else {\n return value;\n }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target: unknown): string {\n try {\n return isElement(target) ? htmlTreeAsString(target) : Object.prototype.toString.call(target);\n } catch (_oO) {\n return '<unknown>';\n }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj: unknown): { [key: string]: unknown } {\n if (typeof obj === 'object' && obj !== null) {\n const extractedProps: { [key: string]: unknown } = {};\n for (const property in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, property)) {\n extractedProps[property] = (obj as Record<string, unknown>)[property];\n }\n }\n return extractedProps;\n } else {\n return {};\n }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nexport function extractExceptionKeysForMessage(exception: Record<string, unknown>, maxLength: number = 40): string {\n const keys = Object.keys(convertToPlainObject(exception));\n keys.sort();\n\n if (!keys.length) {\n return '[object has no keys]';\n }\n\n if (keys[0].length >= maxLength) {\n return truncate(keys[0], maxLength);\n }\n\n for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n const serialized = keys.slice(0, includedKeys).join(', ');\n if (serialized.length > maxLength) {\n continue;\n }\n if (includedKeys === keys.length) {\n return serialized;\n }\n return truncate(serialized, maxLength);\n }\n\n return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n */\nexport function dropUndefinedKeys<T>(inputValue: T): T {\n // This map keeps track of what already visited nodes map to.\n // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n // references as the input object.\n const memoizationMap = new Map<unknown, unknown>();\n\n // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys<T>(inputValue: T, memoizationMap: Map<unknown, unknown>): T {\n if (isPlainObject(inputValue)) {\n // If this node has already been visited due to a circular reference, return the object it was mapped to in the new object\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal as T;\n }\n\n const returnValue: { [key: string]: any } = {};\n // Store the mapping of this value in case we visit it again, in case of circular data\n memoizationMap.set(inputValue, returnValue);\n\n for (const key of Object.keys(inputValue)) {\n if (typeof inputValue[key] !== 'undefined') {\n returnValue[key] = _dropUndefinedKeys(inputValue[key], memoizationMap);\n }\n }\n\n return returnValue as T;\n }\n\n if (Array.isArray(inputValue)) {\n // If this node has already been visited due to a circular reference, return the array it was mapped to in the new object\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal as T;\n }\n\n const returnValue: unknown[] = [];\n // Store the mapping of this value in case we visit it again, in case of circular data\n memoizationMap.set(inputValue, returnValue);\n\n inputValue.forEach((item: unknown) => {\n returnValue.push(_dropUndefinedKeys(item, memoizationMap));\n });\n\n return returnValue as unknown as T;\n }\n\n return inputValue;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nexport function objectify(wat: unknown): typeof Object {\n let objectified;\n switch (true) {\n case wat === undefined || wat === null:\n objectified = new String(wat);\n break;\n\n // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n // an object in order to wrap it.\n case typeof wat === 'symbol' || typeof wat === 'bigint':\n objectified = Object(wat);\n break;\n\n // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n case isPrimitive(wat):\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n objectified = new (wat as any).constructor(wat);\n break;\n\n // by process of elimination, at this point we know that `wat` must already be an object\n default:\n objectified = wat;\n break;\n }\n return objectified;\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { Event, Exception, Mechanism, StackFrame } from '@sentry/types';\n\nimport { addNonEnumerableProperty } from './object';\nimport { snipLine } from './string';\nimport { GLOBAL_OBJ } from './worldwide';\n\ninterface CryptoInternal {\n getRandomValues(array: Uint8Array): Uint8Array;\n randomUUID?(): string;\n}\n\n/** An interface for common properties on global */\ninterface CryptoGlobal {\n msCrypto?: CryptoInternal;\n crypto?: CryptoInternal;\n}\n\n/**\n * UUID4 generator\n *\n * @returns string Generated UUID4.\n */\nexport function uuid4(): string {\n const gbl = GLOBAL_OBJ as typeof GLOBAL_OBJ & CryptoGlobal;\n const crypto = gbl.crypto || gbl.msCrypto;\n\n if (crypto && crypto.randomUUID) {\n return crypto.randomUUID().replace(/-/g, '');\n }\n\n const getRandomByte =\n crypto && crypto.getRandomValues ? () => crypto.getRandomValues(new Uint8Array(1))[0] : () => Math.random() * 16;\n\n // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#2117523\n // Concatenating the following numbers as strings results in '10000000100040008000100000000000'\n return (([1e7] as unknown as string) + 1e3 + 4e3 + 8e3 + 1e11).replace(/[018]/g, c =>\n // eslint-disable-next-line no-bitwise\n ((c as unknown as number) ^ ((getRandomByte() & 15) >> ((c as unknown as number) / 4))).toString(16),\n );\n}\n\nfunction getFirstException(event: Event): Exception | undefined {\n return event.exception && event.exception.values ? event.exception.values[0] : undefined;\n}\n\n/**\n * Extracts either message or type+value from an event that can be used for user-facing logs\n * @returns event's description\n */\nexport function getEventDescription(event: Event): string {\n const { message, event_id: eventId } = event;\n if (message) {\n return message;\n }\n\n const firstException = getFirstException(event);\n if (firstException) {\n if (firstException.type && firstException.value) {\n return `${firstException.type}: ${firstException.value}`;\n }\n return firstException.type || firstException.value || eventId || '<unknown>';\n }\n return eventId || '<unknown>';\n}\n\n/**\n * Adds exception values, type and value to an synthetic Exception.\n * @param event The event to modify.\n * @param value Value of the exception.\n * @param type Type of the exception.\n * @hidden\n */\nexport function addExceptionTypeValue(event: Event, value?: string, type?: string): void {\n const exception = (event.exception = event.exception || {});\n const values = (exception.values = exception.values || []);\n const firstException = (values[0] = values[0] || {});\n if (!firstException.value) {\n firstException.value = value || '';\n }\n if (!firstException.type) {\n firstException.type = type || 'Error';\n }\n}\n\n/**\n * Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed.\n *\n * @param event The event to modify.\n * @param newMechanism Mechanism data to add to the event.\n * @hidden\n */\nexport function addExceptionMechanism(event: Event, newMechanism?: Partial<Mechanism>): void {\n const firstException = getFirstException(event);\n if (!firstException) {\n return;\n }\n\n const defaultMechanism = { type: 'generic', handled: true };\n const currentMechanism = firstException.mechanism;\n firstException.mechanism = { ...defaultMechanism, ...currentMechanism, ...newMechanism };\n\n if (newMechanism && 'data' in newMechanism) {\n const mergedData = { ...(currentMechanism && currentMechanism.data), ...newMechanism.data };\n firstException.mechanism.data = mergedData;\n }\n}\n\n// https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string\nconst SEMVER_REGEXP =\n /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/;\n\n/**\n * Represents Semantic Versioning object\n */\ninterface SemVer {\n major?: number;\n minor?: number;\n patch?: number;\n prerelease?: string;\n buildmetadata?: string;\n}\n\n/**\n * Parses input into a SemVer interface\n * @param input string representation of a semver version\n */\nexport function parseSemver(input: string): SemVer {\n const match = input.match(SEMVER_REGEXP) || [];\n const major = parseInt(match[1], 10);\n const minor = parseInt(match[2], 10);\n const patch = parseInt(match[3], 10);\n return {\n buildmetadata: match[5],\n major: isNaN(major) ? undefined : major,\n minor: isNaN(minor) ? undefined : minor,\n patch: isNaN(patch) ? undefined : patch,\n prerelease: match[4],\n };\n}\n\n/**\n * This function adds context (pre/post/line) lines to the provided frame\n *\n * @param lines string[] containing all lines\n * @param frame StackFrame that will be mutated\n * @param linesOfContext number of context lines we want to add pre/post\n */\nexport function addContextToFrame(lines: string[], frame: StackFrame, linesOfContext: number = 5): void {\n // When there is no line number in the frame, attaching context is nonsensical and will even break grouping\n if (frame.lineno === undefined) {\n return;\n }\n\n const maxLines = lines.length;\n const sourceLine = Math.max(Math.min(maxLines - 1, frame.lineno - 1), 0);\n\n frame.pre_context = lines\n .slice(Math.max(0, sourceLine - linesOfContext), sourceLine)\n .map((line: string) => snipLine(line, 0));\n\n frame.context_line = snipLine(lines[Math.min(maxLines - 1, sourceLine)], frame.colno || 0);\n\n frame.post_context = lines\n .slice(Math.min(sourceLine + 1, maxLines), sourceLine + 1 + linesOfContext)\n .map((line: string) => snipLine(line, 0));\n}\n\n/**\n * Checks whether or not we've already captured the given exception (note: not an identical exception - the very object\n * in question), and marks it captured if not.\n *\n * This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and\n * record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so\n * that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because\n * the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not\n * caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This\n * function helps us ensure that even if we encounter the same error more than once, we only record it the first time we\n * see it.\n *\n * Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on\n * them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent\n * object wrapper forms so that this check will always work. However, because we need to flag the exact object which\n * will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification\n * must be done before the exception captured.\n *\n * @param A thrown exception to check or flag as having been seen\n * @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen)\n */\nexport function checkOrSetAlreadyCaught(exception: unknown): boolean {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (exception && (exception as any).__sentry_captured__) {\n return true;\n }\n\n try {\n // set it this way rather than by assignment so that it's not ennumerable and therefore isn't recorded by the\n // `ExtraErrorData` integration\n addNonEnumerableProperty(exception as { [key: string]: unknown }, '__sentry_captured__', true);\n } catch (err) {\n // `exception` is a primitive, so we can't mark it seen\n }\n\n return false;\n}\n\n/**\n * Checks whether the given input is already an array, and if it isn't, wraps it in one.\n *\n * @param maybeArray Input to turn into an array, if necessary\n * @returns The input, if already an array, or an array with the input as the only element, if not\n */\nexport function arrayify<T = unknown>(maybeArray: T | T[]): T[] {\n return Array.isArray(maybeArray) ? maybeArray : [maybeArray];\n}\n","import type { Event, EventProcessor, Hub, Integration, StackFrame } from '@sentry/types';\nimport { getEventDescription, logger, stringMatchesSomePattern } from '@sentry/utils';\n\n// \"Script error.\" is hard coded into browsers for errors that it can't read.\n// this is the result of a script being pulled in from an external domain and CORS.\nconst DEFAULT_IGNORE_ERRORS = [/^Script error\\.?$/, /^Javascript error: Script error\\.? on line 0$/];\n\nconst DEFAULT_IGNORE_TRANSACTIONS = [\n /^.*healthcheck.*$/,\n /^.*healthy.*$/,\n /^.*live.*$/,\n /^.*ready.*$/,\n /^.*heartbeat.*$/,\n /^.*\\/health$/,\n /^.*\\/healthz$/,\n];\n\n/** Options for the InboundFilters integration */\nexport interface InboundFiltersOptions {\n allowUrls: Array<string | RegExp>;\n denyUrls: Array<string | RegExp>;\n ignoreErrors: Array<string | RegExp>;\n ignoreTransactions: Array<string | RegExp>;\n ignoreInternal: boolean;\n disableErrorDefaults: boolean;\n disableTransactionDefaults: boolean;\n}\n\n/** Inbound filters configurable by the user */\nexport class InboundFilters implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'InboundFilters';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n private readonly _options: Partial<InboundFiltersOptions>;\n\n public constructor(options: Partial<InboundFiltersOptions> = {}) {\n this.name = InboundFilters.id;\n this._options = options;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(addGlobalEventProcessor: (processor: EventProcessor) => void, getCurrentHub: () => Hub): void {\n const eventProcess: EventProcessor = (event: Event) => {\n const hub = getCurrentHub();\n if (hub) {\n const self = hub.getIntegration(InboundFilters);\n if (self) {\n const client = hub.getClient();\n const clientOptions = client ? client.getOptions() : {};\n const options = _mergeOptions(self._options, clientOptions);\n return _shouldDropEvent(event, options) ? null : event;\n }\n }\n return event;\n };\n\n eventProcess.id = this.name;\n addGlobalEventProcessor(eventProcess);\n }\n}\n\n/** JSDoc */\nexport function _mergeOptions(\n internalOptions: Partial<InboundFiltersOptions> = {},\n clientOptions: Partial<InboundFiltersOptions> = {},\n): Partial<InboundFiltersOptions> {\n return {\n allowUrls: [...(internalOptions.allowUrls || []), ...(clientOptions.allowUrls || [])],\n denyUrls: [...(internalOptions.denyUrls || []), ...(clientOptions.denyUrls || [])],\n ignoreErrors: [\n ...(internalOptions.ignoreErrors || []),\n ...(clientOptions.ignoreErrors || []),\n ...(internalOptions.disableErrorDefaults ? [] : DEFAULT_IGNORE_ERRORS),\n ],\n ignoreTransactions: [\n ...(internalOptions.ignoreTransactions || []),\n ...(clientOptions.ignoreTransactions || []),\n ...(internalOptions.disableTransactionDefaults ? [] : DEFAULT_IGNORE_TRANSACTIONS),\n ],\n ignoreInternal: internalOptions.ignoreInternal !== undefined ? internalOptions.ignoreInternal : true,\n };\n}\n\n/** JSDoc */\nexport function _shouldDropEvent(event: Event, options: Partial<InboundFiltersOptions>): boolean {\n if (options.ignoreInternal && _isSentryError(event)) {\n __DEBUG_BUILD__ &&\n logger.warn(`Event dropped due to being internal Sentry Error.\\nEvent: ${getEventDescription(event)}`);\n return true;\n }\n if (_isIgnoredError(event, options.ignoreErrors)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`ignoreErrors\\` option.\\nEvent: ${getEventDescription(event)}`,\n );\n return true;\n }\n if (_isIgnoredTransaction(event, options.ignoreTransactions)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`ignoreTransactions\\` option.\\nEvent: ${getEventDescription(event)}`,\n );\n return true;\n }\n if (_isDeniedUrl(event, options.denyUrls)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`denyUrls\\` option.\\nEvent: ${getEventDescription(\n event,\n )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n );\n return true;\n }\n if (!_isAllowedUrl(event, options.allowUrls)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to not being matched by \\`allowUrls\\` option.\\nEvent: ${getEventDescription(\n event,\n )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n );\n return true;\n }\n return false;\n}\n\nfunction _isIgnoredError(event: Event, ignoreErrors?: Array<string | RegExp>): boolean {\n // If event.type, this is not an error\n if (event.type || !ignoreErrors || !ignoreErrors.length) {\n return false;\n }\n\n return _getPossibleEventMessages(event).some(message => stringMatchesSomePattern(message, ignoreErrors));\n}\n\nfunction _isIgnoredTransaction(event: Event, ignoreTransactions?: Array<string | RegExp>): boolean {\n if (event.type !== 'transaction' || !ignoreTransactions || !ignoreTransactions.length) {\n return false;\n }\n\n const name = event.transaction;\n return name ? stringMatchesSomePattern(name, ignoreTransactions) : false;\n}\n\nfunction _isDeniedUrl(event: Event, denyUrls?: Array<string | RegExp>): boolean {\n // TODO: Use Glob instead?\n if (!denyUrls || !denyUrls.length) {\n return false;\n }\n const url = _getEventFilterUrl(event);\n return !url ? false : stringMatchesSomePattern(url, denyUrls);\n}\n\nfunction _isAllowedUrl(event: Event, allowUrls?: Array<string | RegExp>): boolean {\n // TODO: Use Glob instead?\n if (!allowUrls || !allowUrls.length) {\n return true;\n }\n const url = _getEventFilterUrl(event);\n return !url ? true : stringMatchesSomePattern(url, allowUrls);\n}\n\nfunction _getPossibleEventMessages(event: Event): string[] {\n if (event.message) {\n return [event.message];\n }\n if (event.exception) {\n const { values } = event.exception;\n try {\n const { type = '', value = '' } = (values && values[values.length - 1]) || {};\n return [`${value}`, `${type}: ${value}`];\n } catch (oO) {\n __DEBUG_BUILD__ && logger.error(`Cannot extract message for event ${getEventDescription(event)}`);\n return [];\n }\n }\n return [];\n}\n\nfunction _isSentryError(event: Event): boolean {\n try {\n // @ts-ignore can't be a sentry error if undefined\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return event.exception.values[0].type === 'SentryError';\n } catch (e) {\n // ignore\n }\n return false;\n}\n\nfunction _getLastValidUrl(frames: StackFrame[] = []): string | null {\n for (let i = frames.length - 1; i >= 0; i--) {\n const frame = frames[i];\n\n if (frame && frame.filename !== '<anonymous>' && frame.filename !== '[native code]') {\n return frame.filename || null;\n }\n }\n\n return null;\n}\n\nfunction _getEventFilterUrl(event: Event): string | null {\n try {\n let frames;\n try {\n // @ts-ignore we only care about frames if the whole thing here is defined\n frames = event.exception.values[0].stacktrace.frames;\n } catch (e) {\n // ignore\n }\n return frames ? _getLastValidUrl(frames) : null;\n } catch (oO) {\n __DEBUG_BUILD__ && logger.error(`Cannot extract url for event ${getEventDescription(event)}`);\n return null;\n }\n}\n","import type { Integration, WrappedFunction } from '@sentry/types';\nimport { getOriginalFunction } from '@sentry/utils';\n\nlet originalFunctionToString: () => void;\n\n/** Patch toString calls to return proper name for wrapped functions */\nexport class FunctionToString implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'FunctionToString';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n public constructor() {\n this.name = FunctionToString.id;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n originalFunctionToString = Function.prototype.toString;\n\n // intrinsics (like Function.prototype) might be immutable in some environments\n // e.g. Node with --frozen-intrinsics, XS (an embedded JavaScript engine) or SES (a JavaScript proposal)\n try {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Function.prototype.toString = function (this: WrappedFunction, ...args: any[]): string {\n const context = getOriginalFunction(this) || this;\n return originalFunctionToString.apply(context, args);\n };\n } catch {\n // ignore errors here, just don't patch this\n }\n }\n}\n","/* eslint-disable @typescript-eslint/explicit-function-return-type */\n/* eslint-disable @typescript-eslint/typedef */\n/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { isThenable } from './is';\n\n/** SyncPromise internal states */\nconst enum States {\n /** Pending */\n PENDING = 0,\n /** Resolved / OK */\n RESOLVED = 1,\n /** Rejected / Error */\n REJECTED = 2,\n}\n\n// Overloads so we can call resolvedSyncPromise without arguments and generic argument\nexport function resolvedSyncPromise(): PromiseLike<void>;\nexport function resolvedSyncPromise<T>(value: T | PromiseLike<T>): PromiseLike<T>;\n\n/**\n * Creates a resolved sync promise.\n *\n * @param value the value to resolve the promise with\n * @returns the resolved sync promise\n */\nexport function resolvedSyncPromise<T>(value?: T | PromiseLike<T>): PromiseLike<T> {\n return new SyncPromise(resolve => {\n resolve(value);\n });\n}\n\n/**\n * Creates a rejected sync promise.\n *\n * @param value the value to reject the promise with\n * @returns the rejected sync promise\n */\nexport function rejectedSyncPromise<T = never>(reason?: any): PromiseLike<T> {\n return new SyncPromise((_, reject) => {\n reject(reason);\n });\n}\n\n/**\n * Thenable class that behaves like a Promise and follows it's interface\n * but is not async internally\n */\nclass SyncPromise<T> implements PromiseLike<T> {\n private _state: States;\n private _handlers: Array<[boolean, (value: T) => void, (reason: any) => any]>;\n private _value: any;\n\n public constructor(\n executor: (resolve: (value?: T | PromiseLike<T> | null) => void, reject: (reason?: any) => void) => void,\n ) {\n this._state = States.PENDING;\n this._handlers = [];\n\n try {\n executor(this._resolve, this._reject);\n } catch (e) {\n this._reject(e);\n }\n }\n\n /** JSDoc */\n public then<TResult1 = T, TResult2 = never>(\n onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | null,\n onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null,\n ): PromiseLike<TResult1 | TResult2> {\n return new SyncPromise((resolve, reject) => {\n this._handlers.push([\n false,\n result => {\n if (!onfulfilled) {\n // TODO: ¯\\_(ツ)_/¯\n // TODO: FIXME\n resolve(result as any);\n } else {\n try {\n resolve(onfulfilled(result));\n } catch (e) {\n reject(e);\n }\n }\n },\n reason => {\n if (!onrejected) {\n reject(reason);\n } else {\n try {\n resolve(onrejected(reason));\n } catch (e) {\n reject(e);\n }\n }\n },\n ]);\n this._executeHandlers();\n });\n }\n\n /** JSDoc */\n public catch<TResult = never>(\n onrejected?: ((reason: any) => TResult | PromiseLike<TResult>) | null,\n ): PromiseLike<T | TResult> {\n return this.then(val => val, onrejected);\n }\n\n /** JSDoc */\n public finally<TResult>(onfinally?: (() => void) | null): PromiseLike<TResult> {\n return new SyncPromise<TResult>((resolve, reject) => {\n let val: TResult | any;\n let isRejected: boolean;\n\n return this.then(\n value => {\n isRejected = false;\n val = value;\n if (onfinally) {\n onfinally();\n }\n },\n reason => {\n isRejected = true;\n val = reason;\n if (onfinally) {\n onfinally();\n }\n },\n ).then(() => {\n if (isRejected) {\n reject(val);\n return;\n }\n\n resolve(val as unknown as any);\n });\n });\n }\n\n /** JSDoc */\n private readonly _resolve = (value?: T | PromiseLike<T> | null) => {\n this._setResult(States.RESOLVED, value);\n };\n\n /** JSDoc */\n private readonly _reject = (reason?: any) => {\n this._setResult(States.REJECTED, reason);\n };\n\n /** JSDoc */\n private readonly _setResult = (state: States, value?: T | PromiseLike<T> | any) => {\n if (this._state !== States.PENDING) {\n return;\n }\n\n if (isThenable(value)) {\n void (value as PromiseLike<T>).then(this._resolve, this._reject);\n return;\n }\n\n this._state = state;\n this._value = value;\n\n this._executeHandlers();\n };\n\n /** JSDoc */\n private readonly _executeHandlers = () => {\n if (this._state === States.PENDING) {\n return;\n }\n\n const cachedHandlers = this._handlers.slice();\n this._handlers = [];\n\n cachedHandlers.forEach(handler => {\n if (handler[0]) {\n return;\n }\n\n if (this._state === States.RESOLVED) {\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n handler[1](this._value as unknown as any);\n }\n\n if (this._state === States.REJECTED) {\n handler[2](this._value);\n }\n\n handler[0] = true;\n });\n };\n}\n\nexport { SyncPromise };\n","export const DEFAULT_ENVIRONMENT = 'production';\n","import type { SerializedSession, Session, SessionContext, SessionStatus } from '@sentry/types';\nimport { dropUndefinedKeys, timestampInSeconds, uuid4 } from '@sentry/utils';\n\n/**\n * Creates a new `Session` object by setting certain default parameters. If optional @param context\n * is passed, the passed properties are applied to the session object.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns a new `Session` object\n */\nexport function makeSession(context?: Omit<SessionContext, 'started' | 'status'>): Session {\n // Both timestamp and started are in seconds since the UNIX epoch.\n const startingTime = timestampInSeconds();\n\n const session: Session = {\n sid: uuid4(),\n init: true,\n timestamp: startingTime,\n started: startingTime,\n duration: 0,\n status: 'ok',\n errors: 0,\n ignoreDuration: false,\n toJSON: () => sessionToJSON(session),\n };\n\n if (context) {\n updateSession(session, context);\n }\n\n return session;\n}\n\n/**\n * Updates a session object with the properties passed in the context.\n *\n * Note that this function mutates the passed object and returns void.\n * (Had to do this instead of returning a new and updated session because closing and sending a session\n * makes an update to the session after it was passed to the sending logic.\n * @see BaseClient.captureSession )\n *\n * @param session the `Session` to update\n * @param context the `SessionContext` holding the properties that should be updated in @param session\n */\n// eslint-disable-next-line complexity\nexport function updateSession(session: Session, context: SessionContext = {}): void {\n if (context.user) {\n if (!session.ipAddress && context.user.ip_address) {\n session.ipAddress = context.user.ip_address;\n }\n\n if (!session.did && !context.did) {\n session.did = context.user.id || context.user.email || context.user.username;\n }\n }\n\n session.timestamp = context.timestamp || timestampInSeconds();\n\n if (context.ignoreDuration) {\n session.ignoreDuration = context.ignoreDuration;\n }\n if (context.sid) {\n // Good enough uuid validation. — Kamil\n session.sid = context.sid.length === 32 ? context.sid : uuid4();\n }\n if (context.init !== undefined) {\n session.init = context.init;\n }\n if (!session.did && context.did) {\n session.did = `${context.did}`;\n }\n if (typeof context.started === 'number') {\n session.started = context.started;\n }\n if (session.ignoreDuration) {\n session.duration = undefined;\n } else if (typeof context.duration === 'number') {\n session.duration = context.duration;\n } else {\n const duration = session.timestamp - session.started;\n session.duration = duration >= 0 ? duration : 0;\n }\n if (context.release) {\n session.release = context.release;\n }\n if (context.environment) {\n session.environment = context.environment;\n }\n if (!session.ipAddress && context.ipAddress) {\n session.ipAddress = context.ipAddress;\n }\n if (!session.userAgent && context.userAgent) {\n session.userAgent = context.userAgent;\n }\n if (typeof context.errors === 'number') {\n session.errors = context.errors;\n }\n if (context.status) {\n session.status = context.status;\n }\n}\n\n/**\n * Closes a session by setting its status and updating the session object with it.\n * Internally calls `updateSession` to update the passed session object.\n *\n * Note that this function mutates the passed session (@see updateSession for explanation).\n *\n * @param session the `Session` object to be closed\n * @param status the `SessionStatus` with which the session was closed. If you don't pass a status,\n * this function will keep the previously set status, unless it was `'ok'` in which case\n * it is changed to `'exited'`.\n */\nexport function closeSession(session: Session, status?: Exclude<SessionStatus, 'ok'>): void {\n let context = {};\n if (status) {\n context = { status };\n } else if (session.status === 'ok') {\n context = { status: 'exited' };\n }\n\n updateSession(session, context);\n}\n\n/**\n * Serializes a passed session object to a JSON object with a slightly different structure.\n * This is necessary because the Sentry backend requires a slightly different schema of a session\n * than the one the JS SDKs use internally.\n *\n * @param session the session to be converted\n *\n * @returns a JSON object of the passed session\n */\nfunction sessionToJSON(session: Session): SerializedSession {\n return dropUndefinedKeys({\n sid: `${session.sid}`,\n init: session.init,\n // Make sure that sec is converted to ms for date constructor\n started: new Date(session.started * 1000).toISOString(),\n timestamp: new Date(session.timestamp * 1000).toISOString(),\n status: session.status,\n errors: session.errors,\n did: typeof session.did === 'number' || typeof session.did === 'string' ? `${session.did}` : undefined,\n duration: session.duration,\n attrs: {\n release: session.release,\n environment: session.environment,\n ip_address: session.ipAddress,\n user_agent: session.userAgent,\n },\n });\n}\n","/* eslint-disable max-lines */\nimport type {\n Attachment,\n Breadcrumb,\n CaptureContext,\n Context,\n Contexts,\n Event,\n EventHint,\n EventProcessor,\n Extra,\n Extras,\n Primitive,\n PropagationContext,\n RequestSession,\n Scope as ScopeInterface,\n ScopeContext,\n Session,\n Severity,\n SeverityLevel,\n Span,\n Transaction,\n User,\n} from '@sentry/types';\nimport {\n arrayify,\n dateTimestampInSeconds,\n getGlobalSingleton,\n isPlainObject,\n isThenable,\n logger,\n SyncPromise,\n uuid4,\n} from '@sentry/utils';\n\nimport { updateSession } from './session';\n\n/**\n * Default value for maximum number of breadcrumbs added to an event.\n */\nconst DEFAULT_MAX_BREADCRUMBS = 100;\n\n/**\n * Holds additional event information. {@link Scope.applyToEvent} will be\n * called by the client before an event will be sent.\n */\nexport class Scope implements ScopeInterface {\n /** Flag if notifying is happening. */\n protected _notifyingListeners: boolean;\n\n /** Callback for client to receive scope changes. */\n protected _scopeListeners: Array<(scope: Scope) => void>;\n\n /** Callback list that will be called after {@link applyToEvent}. */\n protected _eventProcessors: EventProcessor[];\n\n /** Array of breadcrumbs. */\n protected _breadcrumbs: Breadcrumb[];\n\n /** User */\n protected _user: User;\n\n /** Tags */\n protected _tags: { [key: string]: Primitive };\n\n /** Extra */\n protected _extra: Extras;\n\n /** Contexts */\n protected _contexts: Contexts;\n\n /** Attachments */\n protected _attachments: Attachment[];\n\n /** Propagation Context for distributed tracing */\n protected _propagationContext: PropagationContext;\n\n /**\n * A place to stash data which is needed at some point in the SDK's event processing pipeline but which shouldn't get\n * sent to Sentry\n */\n protected _sdkProcessingMetadata: { [key: string]: unknown };\n\n /** Fingerprint */\n protected _fingerprint?: string[];\n\n /** Severity */\n // eslint-disable-next-line deprecation/deprecation\n protected _level?: Severity | SeverityLevel;\n\n /** Transaction Name */\n protected _transactionName?: string;\n\n /** Span */\n protected _span?: Span;\n\n /** Session */\n protected _session?: Session;\n\n /** Request Mode Session Status */\n protected _requestSession?: RequestSession;\n\n // NOTE: Any field which gets added here should get added not only to the constructor but also to the `clone` method.\n\n public constructor() {\n this._notifyingListeners = false;\n this._scopeListeners = [];\n this._eventProcessors = [];\n this._breadcrumbs = [];\n this._attachments = [];\n this._user = {};\n this._tags = {};\n this._extra = {};\n this._contexts = {};\n this._sdkProcessingMetadata = {};\n this._propagationContext = generatePropagationContext();\n }\n\n /**\n * Inherit values from the parent scope.\n * @param scope to clone.\n */\n public static clone(scope?: Scope): Scope {\n const newScope = new Scope();\n if (scope) {\n newScope._breadcrumbs = [...scope._breadcrumbs];\n newScope._tags = { ...scope._tags };\n newScope._extra = { ...scope._extra };\n newScope._contexts = { ...scope._contexts };\n newScope._user = scope._user;\n newScope._level = scope._level;\n newScope._span = scope._span;\n newScope._session = scope._session;\n newScope._transactionName = scope._transactionName;\n newScope._fingerprint = scope._fingerprint;\n newScope._eventProcessors = [...scope._eventProcessors];\n newScope._requestSession = scope._requestSession;\n newScope._attachments = [...scope._attachments];\n newScope._sdkProcessingMetadata = { ...scope._sdkProcessingMetadata };\n newScope._propagationContext = { ...scope._propagationContext };\n }\n return newScope;\n }\n\n /**\n * Add internal on change listener. Used for sub SDKs that need to store the scope.\n * @hidden\n */\n public addScopeListener(callback: (scope: Scope) => void): void {\n this._scopeListeners.push(callback);\n }\n\n /**\n * @inheritDoc\n */\n public addEventProcessor(callback: EventProcessor): this {\n this._eventProcessors.push(callback);\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setUser(user: User | null): this {\n this._user = user || {};\n if (this._session) {\n updateSession(this._session, { user });\n }\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getUser(): User | undefined {\n return this._user;\n }\n\n /**\n * @inheritDoc\n */\n public getRequestSession(): RequestSession | undefined {\n return this._requestSession;\n }\n\n /**\n * @inheritDoc\n */\n public setRequestSession(requestSession?: RequestSession): this {\n this._requestSession = requestSession;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTags(tags: { [key: string]: Primitive }): this {\n this._tags = {\n ...this._tags,\n ...tags,\n };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): this {\n this._tags = { ...this._tags, [key]: value };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setExtras(extras: Extras): this {\n this._extra = {\n ...this._extra,\n ...extras,\n };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setExtra(key: string, extra: Extra): this {\n this._extra = { ...this._extra, [key]: extra };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setFingerprint(fingerprint: string[]): this {\n this._fingerprint = fingerprint;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setLevel(\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel,\n ): this {\n this._level = level;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTransactionName(name?: string): this {\n this._transactionName = name;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setContext(key: string, context: Context | null): this {\n if (context === null) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this._contexts[key];\n } else {\n this._contexts[key] = context;\n }\n\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setSpan(span?: Span): this {\n this._span = span;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getSpan(): Span | undefined {\n return this._span;\n }\n\n /**\n * @inheritDoc\n */\n public getTransaction(): Transaction | undefined {\n // Often, this span (if it exists at all) will be a transaction, but it's not guaranteed to be. Regardless, it will\n // have a pointer to the currently-active transaction.\n const span = this.getSpan();\n return span && span.transaction;\n }\n\n /**\n * @inheritDoc\n */\n public setSession(session?: Session): this {\n if (!session) {\n delete this._session;\n } else {\n this._session = session;\n }\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getSession(): Session | undefined {\n return this._session;\n }\n\n /**\n * @inheritDoc\n */\n public update(captureContext?: CaptureContext): this {\n if (!captureContext) {\n return this;\n }\n\n if (typeof captureContext === 'function') {\n const updatedScope = (captureContext as <T>(scope: T) => T)(this);\n return updatedScope instanceof Scope ? updatedScope : this;\n }\n\n if (captureContext instanceof Scope) {\n this._tags = { ...this._tags, ...captureContext._tags };\n this._extra = { ...this._extra, ...captureContext._extra };\n this._contexts = { ...this._contexts, ...captureContext._contexts };\n if (captureContext._user && Object.keys(captureContext._user).length) {\n this._user = captureContext._user;\n }\n if (captureContext._level) {\n this._level = captureContext._level;\n }\n if (captureContext._fingerprint) {\n this._fingerprint = captureContext._fingerprint;\n }\n if (captureContext._requestSession) {\n this._requestSession = captureContext._requestSession;\n }\n if (captureContext._propagationContext) {\n this._propagationContext = captureContext._propagationContext;\n }\n } else if (isPlainObject(captureContext)) {\n // eslint-disable-next-line no-param-reassign\n captureContext = captureContext as ScopeContext;\n this._tags = { ...this._tags, ...captureContext.tags };\n this._extra = { ...this._extra, ...captureContext.extra };\n this._contexts = { ...this._contexts, ...captureContext.contexts };\n if (captureContext.user) {\n this._user = captureContext.user;\n }\n if (captureContext.level) {\n this._level = captureContext.level;\n }\n if (captureContext.fingerprint) {\n this._fingerprint = captureContext.fingerprint;\n }\n if (captureContext.requestSession) {\n this._requestSession = captureContext.requestSession;\n }\n if (captureContext.propagationContext) {\n this._propagationContext = captureContext.propagationContext;\n }\n }\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public clear(): this {\n this._breadcrumbs = [];\n this._tags = {};\n this._extra = {};\n this._user = {};\n this._contexts = {};\n this._level = undefined;\n this._transactionName = undefined;\n this._fingerprint = undefined;\n this._requestSession = undefined;\n this._span = undefined;\n this._session = undefined;\n this._notifyScopeListeners();\n this._attachments = [];\n this._propagationContext = generatePropagationContext();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public addBreadcrumb(breadcrumb: Breadcrumb, maxBreadcrumbs?: number): this {\n const maxCrumbs = typeof maxBreadcrumbs === 'number' ? maxBreadcrumbs : DEFAULT_MAX_BREADCRUMBS;\n\n // No data has been changed, so don't notify scope listeners\n if (maxCrumbs <= 0) {\n return this;\n }\n\n const mergedBreadcrumb = {\n timestamp: dateTimestampInSeconds(),\n ...breadcrumb,\n };\n this._breadcrumbs = [...this._breadcrumbs, mergedBreadcrumb].slice(-maxCrumbs);\n this._notifyScopeListeners();\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getLastBreadcrumb(): Breadcrumb | undefined {\n return this._breadcrumbs[this._breadcrumbs.length - 1];\n }\n\n /**\n * @inheritDoc\n */\n public clearBreadcrumbs(): this {\n this._breadcrumbs = [];\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public addAttachment(attachment: Attachment): this {\n this._attachments.push(attachment);\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getAttachments(): Attachment[] {\n return this._attachments;\n }\n\n /**\n * @inheritDoc\n */\n public clearAttachments(): this {\n this._attachments = [];\n return this;\n }\n\n /**\n * Applies data from the scope to the event and runs all event processors on it.\n *\n * @param event Event\n * @param hint Object containing additional information about the original exception, for use by the event processors.\n * @hidden\n */\n public applyToEvent(event: Event, hint: EventHint = {}): PromiseLike<Event | null> {\n if (this._extra && Object.keys(this._extra).length) {\n event.extra = { ...this._extra, ...event.extra };\n }\n if (this._tags && Object.keys(this._tags).length) {\n event.tags = { ...this._tags, ...event.tags };\n }\n if (this._user && Object.keys(this._user).length) {\n event.user = { ...this._user, ...event.user };\n }\n if (this._contexts && Object.keys(this._contexts).length) {\n event.contexts = { ...this._contexts, ...event.contexts };\n }\n if (this._level) {\n event.level = this._level;\n }\n if (this._transactionName) {\n event.transaction = this._transactionName;\n }\n\n // We want to set the trace context for normal events only if there isn't already\n // a trace context on the event. There is a product feature in place where we link\n // errors with transaction and it relies on that.\n if (this._span) {\n event.contexts = { trace: this._span.getTraceContext(), ...event.contexts };\n const transaction = this._span.transaction;\n if (transaction) {\n event.sdkProcessingMetadata = {\n dynamicSamplingContext: transaction.getDynamicSamplingContext(),\n ...event.sdkProcessingMetadata,\n };\n const transactionName = transaction.name;\n if (transactionName) {\n event.tags = { transaction: transactionName, ...event.tags };\n }\n }\n }\n\n this._applyFingerprint(event);\n\n event.breadcrumbs = [...(event.breadcrumbs || []), ...this._breadcrumbs];\n event.breadcrumbs = event.breadcrumbs.length > 0 ? event.breadcrumbs : undefined;\n\n event.sdkProcessingMetadata = {\n ...event.sdkProcessingMetadata,\n ...this._sdkProcessingMetadata,\n propagationContext: this._propagationContext,\n };\n\n return this._notifyEventProcessors([...getGlobalEventProcessors(), ...this._eventProcessors], event, hint);\n }\n\n /**\n * Add data which will be accessible during event processing but won't get sent to Sentry\n */\n public setSDKProcessingMetadata(newData: { [key: string]: unknown }): this {\n this._sdkProcessingMetadata = { ...this._sdkProcessingMetadata, ...newData };\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setPropagationContext(context: PropagationContext): this {\n this._propagationContext = context;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getPropagationContext(): PropagationContext {\n return this._propagationContext;\n }\n\n /**\n * This will be called after {@link applyToEvent} is finished.\n */\n protected _notifyEventProcessors(\n processors: EventProcessor[],\n event: Event | null,\n hint: EventHint,\n index: number = 0,\n ): PromiseLike<Event | null> {\n return new SyncPromise<Event | null>((resolve, reject) => {\n const processor = processors[index];\n if (event === null || typeof processor !== 'function') {\n resolve(event);\n } else {\n const result = processor({ ...event }, hint) as Event | null;\n\n __DEBUG_BUILD__ &&\n processor.id &&\n result === null &&\n logger.log(`Event processor \"${processor.id}\" dropped event`);\n\n if (isThenable(result)) {\n void result\n .then(final => this._notifyEventProcessors(processors, final, hint, index + 1).then(resolve))\n .then(null, reject);\n } else {\n void this._notifyEventProcessors(processors, result, hint, index + 1)\n .then(resolve)\n .then(null, reject);\n }\n }\n });\n }\n\n /**\n * This will be called on every set call.\n */\n protected _notifyScopeListeners(): void {\n // We need this check for this._notifyingListeners to be able to work on scope during updates\n // If this check is not here we'll produce endless recursion when something is done with the scope\n // during the callback.\n if (!this._notifyingListeners) {\n this._notifyingListeners = true;\n this._scopeListeners.forEach(callback => {\n callback(this);\n });\n this._notifyingListeners = false;\n }\n }\n\n /**\n * Applies fingerprint from the scope to the event if there's one,\n * uses message if there's one instead or get rid of empty fingerprint\n */\n private _applyFingerprint(event: Event): void {\n // Make sure it's an array first and we actually have something in place\n event.fingerprint = event.fingerprint ? arrayify(event.fingerprint) : [];\n\n // If we have something on the scope, then merge it with event\n if (this._fingerprint) {\n event.fingerprint = event.fingerprint.concat(this._fingerprint);\n }\n\n // If we have no data at all, remove empty array default\n if (event.fingerprint && !event.fingerprint.length) {\n delete event.fingerprint;\n }\n }\n}\n\n/**\n * Returns the global event processors.\n */\nfunction getGlobalEventProcessors(): EventProcessor[] {\n return getGlobalSingleton<EventProcessor[]>('globalEventProcessors', () => []);\n}\n\n/**\n * Add a EventProcessor to be kept globally.\n * @param callback EventProcessor to add\n */\nexport function addGlobalEventProcessor(callback: EventProcessor): void {\n getGlobalEventProcessors().push(callback);\n}\n\nfunction generatePropagationContext(): PropagationContext {\n return {\n traceId: uuid4(),\n spanId: uuid4().substring(16),\n sampled: false,\n };\n}\n","/* eslint-disable max-lines */\nimport type {\n Breadcrumb,\n BreadcrumbHint,\n Client,\n CustomSamplingContext,\n Event,\n EventHint,\n Extra,\n Extras,\n Hub as HubInterface,\n Integration,\n IntegrationClass,\n Primitive,\n Session,\n SessionContext,\n Severity,\n SeverityLevel,\n Transaction,\n TransactionContext,\n User,\n} from '@sentry/types';\nimport { consoleSandbox, dateTimestampInSeconds, getGlobalSingleton, GLOBAL_OBJ, logger, uuid4 } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from './constants';\nimport { Scope } from './scope';\nimport { closeSession, makeSession, updateSession } from './session';\n\n/**\n * API compatibility version of this hub.\n *\n * WARNING: This number should only be increased when the global interface\n * changes and new methods are introduced.\n *\n * @hidden\n */\nexport const API_VERSION = 4;\n\n/**\n * Default maximum number of breadcrumbs added to an event. Can be overwritten\n * with {@link Options.maxBreadcrumbs}.\n */\nconst DEFAULT_BREADCRUMBS = 100;\n\nexport interface RunWithAsyncContextOptions {\n /** Whether to reuse an existing async context if one exists. Defaults to false. */\n reuseExisting?: boolean;\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Strategy used to track async context.\n */\nexport interface AsyncContextStrategy {\n /**\n * Gets the current async context. Returns undefined if there is no current async context.\n */\n getCurrentHub: () => Hub | undefined;\n /**\n * Runs the supplied callback in its own async context.\n */\n runWithAsyncContext<T>(callback: () => T, options: RunWithAsyncContextOptions): T;\n}\n\n/**\n * A layer in the process stack.\n * @hidden\n */\nexport interface Layer {\n client?: Client;\n scope: Scope;\n}\n\n/**\n * An object that contains a hub and maintains a scope stack.\n * @hidden\n */\nexport interface Carrier {\n __SENTRY__?: {\n hub?: Hub;\n acs?: AsyncContextStrategy;\n /**\n * Extra Hub properties injected by various SDKs\n */\n integrations?: Integration[];\n extensions?: {\n /** Extension methods for the hub, which are bound to the current Hub instance */\n // eslint-disable-next-line @typescript-eslint/ban-types\n [key: string]: Function;\n };\n };\n}\n\n/**\n * @inheritDoc\n */\nexport class Hub implements HubInterface {\n /** Is a {@link Layer}[] containing the client and scope */\n private readonly _stack: Layer[];\n\n /** Contains the last event id of a captured event. */\n private _lastEventId?: string;\n\n /**\n * Creates a new instance of the hub, will push one {@link Layer} into the\n * internal stack on creation.\n *\n * @param client bound to the hub.\n * @param scope bound to the hub.\n * @param version number, higher number means higher priority.\n */\n public constructor(client?: Client, scope: Scope = new Scope(), private readonly _version: number = API_VERSION) {\n this._stack = [{ scope }];\n if (client) {\n this.bindClient(client);\n }\n }\n\n /**\n * @inheritDoc\n */\n public isOlderThan(version: number): boolean {\n return this._version < version;\n }\n\n /**\n * @inheritDoc\n */\n public bindClient(client?: Client): void {\n const top = this.getStackTop();\n top.client = client;\n if (client && client.setupIntegrations) {\n client.setupIntegrations();\n }\n }\n\n /**\n * @inheritDoc\n */\n public pushScope(): Scope {\n // We want to clone the content of prev scope\n const scope = Scope.clone(this.getScope());\n this.getStack().push({\n client: this.getClient(),\n scope,\n });\n return scope;\n }\n\n /**\n * @inheritDoc\n */\n public popScope(): boolean {\n if (this.getStack().length <= 1) return false;\n return !!this.getStack().pop();\n }\n\n /**\n * @inheritDoc\n */\n public withScope(callback: (scope: Scope) => void): void {\n const scope = this.pushScope();\n try {\n callback(scope);\n } finally {\n this.popScope();\n }\n }\n\n /**\n * @inheritDoc\n */\n public getClient<C extends Client>(): C | undefined {\n return this.getStackTop().client as C;\n }\n\n /** Returns the scope of the top stack. */\n public getScope(): Scope {\n return this.getStackTop().scope;\n }\n\n /** Returns the scope stack for domains or the process. */\n public getStack(): Layer[] {\n return this._stack;\n }\n\n /** Returns the topmost scope layer in the order domain > local > process. */\n public getStackTop(): Layer {\n return this._stack[this._stack.length - 1];\n }\n\n /**\n * @inheritDoc\n */\n public captureException(exception: unknown, hint?: EventHint): string {\n const eventId = (this._lastEventId = hint && hint.event_id ? hint.event_id : uuid4());\n const syntheticException = new Error('Sentry syntheticException');\n this._withClient((client, scope) => {\n client.captureException(\n exception,\n {\n originalException: exception,\n syntheticException,\n ...hint,\n event_id: eventId,\n },\n scope,\n );\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level?: Severity | SeverityLevel,\n hint?: EventHint,\n ): string {\n const eventId = (this._lastEventId = hint && hint.event_id ? hint.event_id : uuid4());\n const syntheticException = new Error(message);\n this._withClient((client, scope) => {\n client.captureMessage(\n message,\n level,\n {\n originalException: message,\n syntheticException,\n ...hint,\n event_id: eventId,\n },\n scope,\n );\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureEvent(event: Event, hint?: EventHint): string {\n const eventId = hint && hint.event_id ? hint.event_id : uuid4();\n if (!event.type) {\n this._lastEventId = eventId;\n }\n\n this._withClient((client, scope) => {\n client.captureEvent(event, { ...hint, event_id: eventId }, scope);\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public lastEventId(): string | undefined {\n return this._lastEventId;\n }\n\n /**\n * @inheritDoc\n */\n public addBreadcrumb(breadcrumb: Breadcrumb, hint?: BreadcrumbHint): void {\n const { scope, client } = this.getStackTop();\n\n if (!client) return;\n\n const { beforeBreadcrumb = null, maxBreadcrumbs = DEFAULT_BREADCRUMBS } =\n (client.getOptions && client.getOptions()) || {};\n\n if (maxBreadcrumbs <= 0) return;\n\n const timestamp = dateTimestampInSeconds();\n const mergedBreadcrumb = { timestamp, ...breadcrumb };\n const finalBreadcrumb = beforeBreadcrumb\n ? (consoleSandbox(() => beforeBreadcrumb(mergedBreadcrumb, hint)) as Breadcrumb | null)\n : mergedBreadcrumb;\n\n if (finalBreadcrumb === null) return;\n\n if (client.emit) {\n client.emit('beforeAddBreadcrumb', finalBreadcrumb, hint);\n }\n\n scope.addBreadcrumb(finalBreadcrumb, maxBreadcrumbs);\n }\n\n /**\n * @inheritDoc\n */\n public setUser(user: User | null): void {\n this.getScope().setUser(user);\n }\n\n /**\n * @inheritDoc\n */\n public setTags(tags: { [key: string]: Primitive }): void {\n this.getScope().setTags(tags);\n }\n\n /**\n * @inheritDoc\n */\n public setExtras(extras: Extras): void {\n this.getScope().setExtras(extras);\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): void {\n this.getScope().setTag(key, value);\n }\n\n /**\n * @inheritDoc\n */\n public setExtra(key: string, extra: Extra): void {\n this.getScope().setExtra(key, extra);\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public setContext(name: string, context: { [key: string]: any } | null): void {\n this.getScope().setContext(name, context);\n }\n\n /**\n * @inheritDoc\n */\n public configureScope(callback: (scope: Scope) => void): void {\n const { scope, client } = this.getStackTop();\n if (client) {\n callback(scope);\n }\n }\n\n /**\n * @inheritDoc\n */\n public run(callback: (hub: Hub) => void): void {\n const oldHub = makeMain(this);\n try {\n callback(this);\n } finally {\n makeMain(oldHub);\n }\n }\n\n /**\n * @inheritDoc\n */\n public getIntegration<T extends Integration>(integration: IntegrationClass<T>): T | null {\n const client = this.getClient();\n if (!client) return null;\n try {\n return client.getIntegration(integration);\n } catch (_oO) {\n __DEBUG_BUILD__ && logger.warn(`Cannot retrieve integration ${integration.id} from the current Hub`);\n return null;\n }\n }\n\n /**\n * @inheritDoc\n */\n public startTransaction(context: TransactionContext, customSamplingContext?: CustomSamplingContext): Transaction {\n const result = this._callExtensionMethod<Transaction>('startTransaction', context, customSamplingContext);\n\n if (__DEBUG_BUILD__ && !result) {\n // eslint-disable-next-line no-console\n console.warn(`Tracing extension 'startTransaction' has not been added. Call 'addTracingExtensions' before calling 'init':\nSentry.addTracingExtensions();\nSentry.init({...});\n`);\n }\n\n return result;\n }\n\n /**\n * @inheritDoc\n */\n public traceHeaders(): { [key: string]: string } {\n return this._callExtensionMethod<{ [key: string]: string }>('traceHeaders');\n }\n\n /**\n * @inheritDoc\n */\n public captureSession(endSession: boolean = false): void {\n // both send the update and pull the session from the scope\n if (endSession) {\n return this.endSession();\n }\n\n // only send the update\n this._sendSessionUpdate();\n }\n\n /**\n * @inheritDoc\n */\n public endSession(): void {\n const layer = this.getStackTop();\n const scope = layer.scope;\n const session = scope.getSession();\n if (session) {\n closeSession(session);\n }\n this._sendSessionUpdate();\n\n // the session is over; take it off of the scope\n scope.setSession();\n }\n\n /**\n * @inheritDoc\n */\n public startSession(context?: SessionContext): Session {\n const { scope, client } = this.getStackTop();\n const { release, environment = DEFAULT_ENVIRONMENT } = (client && client.getOptions()) || {};\n\n // Will fetch userAgent if called from browser sdk\n const { userAgent } = GLOBAL_OBJ.navigator || {};\n\n const session = makeSession({\n release,\n environment,\n user: scope.getUser(),\n ...(userAgent && { userAgent }),\n ...context,\n });\n\n // End existing session if there's one\n const currentSession = scope.getSession && scope.getSession();\n if (currentSession && currentSession.status === 'ok') {\n updateSession(currentSession, { status: 'exited' });\n }\n this.endSession();\n\n // Afterwards we set the new session on the scope\n scope.setSession(session);\n\n return session;\n }\n\n /**\n * Returns if default PII should be sent to Sentry and propagated in ourgoing requests\n * when Tracing is used.\n */\n public shouldSendDefaultPii(): boolean {\n const client = this.getClient();\n const options = client && client.getOptions();\n return Boolean(options && options.sendDefaultPii);\n }\n\n /**\n * Sends the current Session on the scope\n */\n private _sendSessionUpdate(): void {\n const { scope, client } = this.getStackTop();\n\n const session = scope.getSession();\n if (session && client && client.captureSession) {\n client.captureSession(session);\n }\n }\n\n /**\n * Internal helper function to call a method on the top client if it exists.\n *\n * @param method The method to call on the client.\n * @param args Arguments to pass to the client function.\n */\n private _withClient(callback: (client: Client, scope: Scope) => void): void {\n const { scope, client } = this.getStackTop();\n if (client) {\n callback(client, scope);\n }\n }\n\n /**\n * Calls global extension method and binding current instance to the function call\n */\n // @ts-ignore Function lacks ending return statement and return type does not include 'undefined'. ts(2366)\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private _callExtensionMethod<T>(method: string, ...args: any[]): T {\n const carrier = getMainCarrier();\n const sentry = carrier.__SENTRY__;\n if (sentry && sentry.extensions && typeof sentry.extensions[method] === 'function') {\n return sentry.extensions[method].apply(this, args);\n }\n __DEBUG_BUILD__ && logger.warn(`Extension method ${method} couldn't be found, doing nothing.`);\n }\n}\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nexport function getMainCarrier(): Carrier {\n GLOBAL_OBJ.__SENTRY__ = GLOBAL_OBJ.__SENTRY__ || {\n extensions: {},\n hub: undefined,\n };\n return GLOBAL_OBJ;\n}\n\n/**\n * Replaces the current main hub with the passed one on the global object\n *\n * @returns The old replaced hub\n */\nexport function makeMain(hub: Hub): Hub {\n const registry = getMainCarrier();\n const oldHub = getHubFromCarrier(registry);\n setHubOnCarrier(registry, hub);\n return oldHub;\n}\n\n/**\n * Returns the default hub instance.\n *\n * If a hub is already registered in the global carrier but this module\n * contains a more recent version, it replaces the registered version.\n * Otherwise, the currently registered hub will be returned.\n */\nexport function getCurrentHub(): Hub {\n // Get main carrier (global for every environment)\n const registry = getMainCarrier();\n\n if (registry.__SENTRY__ && registry.__SENTRY__.acs) {\n const hub = registry.__SENTRY__.acs.getCurrentHub();\n\n if (hub) {\n return hub;\n }\n }\n\n // Return hub that lives on a global object\n return getGlobalHub(registry);\n}\n\nfunction getGlobalHub(registry: Carrier = getMainCarrier()): Hub {\n // If there's no hub, or its an old API, assign a new one\n if (!hasHubOnCarrier(registry) || getHubFromCarrier(registry).isOlderThan(API_VERSION)) {\n setHubOnCarrier(registry, new Hub());\n }\n\n // Return hub that lives on a global object\n return getHubFromCarrier(registry);\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * If the carrier does not contain a hub, a new hub is created with the global hub client and scope.\n */\nexport function ensureHubOnCarrier(carrier: Carrier, parent: Hub = getGlobalHub()): void {\n // If there's no hub on current domain, or it's an old API, assign a new one\n if (!hasHubOnCarrier(carrier) || getHubFromCarrier(carrier).isOlderThan(API_VERSION)) {\n const globalHubTopStack = parent.getStackTop();\n setHubOnCarrier(carrier, new Hub(globalHubTopStack.client, Scope.clone(globalHubTopStack.scope)));\n }\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Sets the global async context strategy\n */\nexport function setAsyncContextStrategy(strategy: AsyncContextStrategy | undefined): void {\n // Get main carrier (global for every environment)\n const registry = getMainCarrier();\n registry.__SENTRY__ = registry.__SENTRY__ || {};\n registry.__SENTRY__.acs = strategy;\n}\n\n/**\n * Runs the supplied callback in its own async context. Async Context strategies are defined per SDK.\n *\n * @param callback The callback to run in its own async context\n * @param options Options to pass to the async context strategy\n * @returns The result of the callback\n */\nexport function runWithAsyncContext<T>(callback: () => T, options: RunWithAsyncContextOptions = {}): T {\n const registry = getMainCarrier();\n\n if (registry.__SENTRY__ && registry.__SENTRY__.acs) {\n return registry.__SENTRY__.acs.runWithAsyncContext(callback, options);\n }\n\n // if there was no strategy, fallback to just calling the callback\n return callback();\n}\n\n/**\n * This will tell whether a carrier has a hub on it or not\n * @param carrier object\n */\nfunction hasHubOnCarrier(carrier: Carrier): boolean {\n return !!(carrier && carrier.__SENTRY__ && carrier.__SENTRY__.hub);\n}\n\n/**\n * This will create a new {@link Hub} and add to the passed object on\n * __SENTRY__.hub.\n * @param carrier object\n * @hidden\n */\nexport function getHubFromCarrier(carrier: Carrier): Hub {\n return getGlobalSingleton<Hub>('hub', () => new Hub(), carrier);\n}\n\n/**\n * This will set passed {@link Hub} on the passed object's __SENTRY__.hub attribute\n * @param carrier object\n * @param hub Hub\n * @returns A boolean indicating success or failure\n */\nexport function setHubOnCarrier(carrier: Carrier, hub: Hub): boolean {\n if (!carrier) return false;\n const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n __SENTRY__.hub = hub;\n return true;\n}\n","import type { Integration, Options } from '@sentry/types';\nimport { arrayify, logger } from '@sentry/utils';\n\nimport { getCurrentHub } from './hub';\nimport { addGlobalEventProcessor } from './scope';\n\ndeclare module '@sentry/types' {\n interface Integration {\n isDefaultInstance?: boolean;\n }\n}\n\nexport const installedIntegrations: string[] = [];\n\n/** Map of integrations assigned to a client */\nexport type IntegrationIndex = {\n [key: string]: Integration;\n};\n\n/**\n * Remove duplicates from the given array, preferring the last instance of any duplicate. Not guaranteed to\n * preseve the order of integrations in the array.\n *\n * @private\n */\nfunction filterDuplicates(integrations: Integration[]): Integration[] {\n const integrationsByName: { [key: string]: Integration } = {};\n\n integrations.forEach(currentInstance => {\n const { name } = currentInstance;\n\n const existingInstance = integrationsByName[name];\n\n // We want integrations later in the array to overwrite earlier ones of the same type, except that we never want a\n // default instance to overwrite an existing user instance\n if (existingInstance && !existingInstance.isDefaultInstance && currentInstance.isDefaultInstance) {\n return;\n }\n\n integrationsByName[name] = currentInstance;\n });\n\n return Object.keys(integrationsByName).map(k => integrationsByName[k]);\n}\n\n/** Gets integrations to install */\nexport function getIntegrationsToSetup(options: Options): Integration[] {\n const defaultIntegrations = options.defaultIntegrations || [];\n const userIntegrations = options.integrations;\n\n // We flag default instances, so that later we can tell them apart from any user-created instances of the same class\n defaultIntegrations.forEach(integration => {\n integration.isDefaultInstance = true;\n });\n\n let integrations: Integration[];\n\n if (Array.isArray(userIntegrations)) {\n integrations = [...defaultIntegrations, ...userIntegrations];\n } else if (typeof userIntegrations === 'function') {\n integrations = arrayify(userIntegrations(defaultIntegrations));\n } else {\n integrations = defaultIntegrations;\n }\n\n const finalIntegrations = filterDuplicates(integrations);\n\n // The `Debug` integration prints copies of the `event` and `hint` which will be passed to `beforeSend` or\n // `beforeSendTransaction`. It therefore has to run after all other integrations, so that the changes of all event\n // processors will be reflected in the printed values. For lack of a more elegant way to guarantee that, we therefore\n // locate it and, assuming it exists, pop it out of its current spot and shove it onto the end of the array.\n const debugIndex = findIndex(finalIntegrations, integration => integration.name === 'Debug');\n if (debugIndex !== -1) {\n const [debugInstance] = finalIntegrations.splice(debugIndex, 1);\n finalIntegrations.push(debugInstance);\n }\n\n return finalIntegrations;\n}\n\n/**\n * Given a list of integration instances this installs them all. When `withDefaults` is set to `true` then all default\n * integrations are added unless they were already provided before.\n * @param integrations array of integration instances\n * @param withDefault should enable default integrations\n */\nexport function setupIntegrations(integrations: Integration[]): IntegrationIndex {\n const integrationIndex: IntegrationIndex = {};\n\n integrations.forEach(integration => {\n // guard against empty provided integrations\n if (integration) {\n setupIntegration(integration, integrationIndex);\n }\n });\n\n return integrationIndex;\n}\n\n/** Setup a single integration. */\nexport function setupIntegration(integration: Integration, integrationIndex: IntegrationIndex): void {\n integrationIndex[integration.name] = integration;\n\n if (installedIntegrations.indexOf(integration.name) === -1) {\n integration.setupOnce(addGlobalEventProcessor, getCurrentHub);\n installedIntegrations.push(integration.name);\n __DEBUG_BUILD__ && logger.log(`Integration installed: ${integration.name}`);\n }\n}\n\n// Polyfill for Array.findIndex(), which is not supported in ES5\nfunction findIndex<T>(arr: T[], callback: (item: T) => boolean): number {\n for (let i = 0; i < arr.length; i++) {\n if (callback(arr[i]) === true) {\n return i;\n }\n }\n\n return -1;\n}\n","import type { Client, ClientOptions } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport { getCurrentHub } from './hub';\n\n/** A class object that can instantiate Client objects. */\nexport type ClientClass<F extends Client, O extends ClientOptions> = new (options: O) => F;\n\n/**\n * Internal function to create a new SDK client instance. The client is\n * installed and then bound to the current scope.\n *\n * @param clientClass The client class to instantiate.\n * @param options Options to pass to the client.\n */\nexport function initAndBind<F extends Client, O extends ClientOptions>(\n clientClass: ClientClass<F, O>,\n options: O,\n): void {\n if (options.debug === true) {\n if (__DEBUG_BUILD__) {\n logger.enable();\n } else {\n // use `console.warn` rather than `logger.warn` since by non-debug bundles have all `logger.x` statements stripped\n // eslint-disable-next-line no-console\n console.warn('[Sentry] Cannot initialize SDK with `debug` option using a non-debug bundle.');\n }\n }\n const hub = getCurrentHub();\n const scope = hub.getScope();\n scope.update(options.initialScope);\n\n const client = new clientClass(options);\n hub.bindClient(client);\n}\n","import type { StackFrame, StackLineParser, StackParser } from '@sentry/types';\n\nimport type { GetModuleFn } from './node-stack-trace';\nimport { node } from './node-stack-trace';\n\nconst STACKTRACE_FRAME_LIMIT = 50;\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nexport function createStackParser(...parsers: StackLineParser[]): StackParser {\n const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n return (stack: string, skipFirst: number = 0): StackFrame[] => {\n const frames: StackFrame[] = [];\n const lines = stack.split('\\n');\n\n for (let i = skipFirst; i < lines.length; i++) {\n const line = lines[i];\n // Ignore lines over 1kb as they are unlikely to be stack frames.\n // Many of the regular expressions use backtracking which results in run time that increases exponentially with\n // input size. Huge strings can result in hangs/Denial of Service:\n // https://github.com/getsentry/sentry-javascript/issues/2286\n if (line.length > 1024) {\n continue;\n }\n\n // https://github.com/getsentry/sentry-javascript/issues/5459\n // Remove webpack (error: *) wrappers\n const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n // https://github.com/getsentry/sentry-javascript/issues/7813\n // Skip Error: lines\n if (cleanedLine.match(/\\S*Error: /)) {\n continue;\n }\n\n for (const parser of sortedParsers) {\n const frame = parser(cleanedLine);\n\n if (frame) {\n frames.push(frame);\n break;\n }\n }\n\n if (frames.length >= STACKTRACE_FRAME_LIMIT) {\n break;\n }\n }\n\n return stripSentryFramesAndReverse(frames);\n };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nexport function stackParserFromStackParserOptions(stackParser: StackParser | StackLineParser[]): StackParser {\n if (Array.isArray(stackParser)) {\n return createStackParser(...stackParser);\n }\n return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nexport function stripSentryFramesAndReverse(stack: ReadonlyArray<StackFrame>): StackFrame[] {\n if (!stack.length) {\n return [];\n }\n\n const localStack = Array.from(stack);\n\n // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n if (/sentryWrapped/.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n }\n\n // Reversing in the middle of the procedure allows us to just pop the values off the stack\n localStack.reverse();\n\n // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n if (STRIP_FRAME_REGEXP.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n\n // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n // is produced within the hub itself, making it:\n //\n // Sentry.captureException()\n // getCurrentHub().captureException()\n //\n // instead of just the top `Sentry` call itself.\n // This forces us to possibly strip an additional frame in the exact same was as above.\n if (STRIP_FRAME_REGEXP.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n }\n }\n\n return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n ...frame,\n filename: frame.filename || localStack[localStack.length - 1].filename,\n function: frame.function || '?',\n }));\n}\n\nconst defaultFunctionName = '<anonymous>';\n\n/**\n * Safely extract function name from itself\n */\nexport function getFunctionName(fn: unknown): string {\n try {\n if (!fn || typeof fn !== 'function') {\n return defaultFunctionName;\n }\n return fn.name || defaultFunctionName;\n } catch (e) {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n return defaultFunctionName;\n }\n}\n\n/**\n * Node.js stack line parser\n *\n * This is in @sentry/utils so it can be used from the Electron SDK in the browser for when `nodeIntegration == true`.\n * This allows it to be used without referencing or importing any node specific code which causes bundlers to complain\n */\nexport function nodeStackLineParser(getModule?: GetModuleFn): StackLineParser {\n return [90, node(getModule)];\n}\n","import { logger } from './logger';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nexport { supportsHistory } from './vendor/supportsHistory';\n\n/**\n * Tells whether current environment supports ErrorEvent objects\n * {@link supportsErrorEvent}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsErrorEvent(): boolean {\n try {\n new ErrorEvent('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMError objects\n * {@link supportsDOMError}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsDOMError(): boolean {\n try {\n // Chrome: VM89:1 Uncaught TypeError: Failed to construct 'DOMError':\n // 1 argument required, but only 0 present.\n // @ts-ignore It really needs 1 argument, not 0.\n new DOMError('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMException objects\n * {@link supportsDOMException}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsDOMException(): boolean {\n try {\n new DOMException('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports Fetch API\n * {@link supportsFetch}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsFetch(): boolean {\n if (!('fetch' in WINDOW)) {\n return false;\n }\n\n try {\n new Headers();\n new Request('http://www.example.com');\n new Response();\n return true;\n } catch (e) {\n return false;\n }\n}\n/**\n * isNativeFetch checks if the given function is a native implementation of fetch()\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function isNativeFetch(func: Function): boolean {\n return func && /^function fetch\\(\\)\\s+\\{\\s+\\[native code\\]\\s+\\}$/.test(func.toString());\n}\n\n/**\n * Tells whether current environment supports Fetch API natively\n * {@link supportsNativeFetch}.\n *\n * @returns true if `window.fetch` is natively implemented, false otherwise\n */\nexport function supportsNativeFetch(): boolean {\n if (!supportsFetch()) {\n return false;\n }\n\n // Fast path to avoid DOM I/O\n // eslint-disable-next-line @typescript-eslint/unbound-method\n if (isNativeFetch(WINDOW.fetch)) {\n return true;\n }\n\n // window.fetch is implemented, but is polyfilled or already wrapped (e.g: by a chrome extension)\n // so create a \"pure\" iframe to see if that has native fetch\n let result = false;\n const doc = WINDOW.document;\n // eslint-disable-next-line deprecation/deprecation\n if (doc && typeof (doc.createElement as unknown) === 'function') {\n try {\n const sandbox = doc.createElement('iframe');\n sandbox.hidden = true;\n doc.head.appendChild(sandbox);\n if (sandbox.contentWindow && sandbox.contentWindow.fetch) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n result = isNativeFetch(sandbox.contentWindow.fetch);\n }\n doc.head.removeChild(sandbox);\n } catch (err) {\n __DEBUG_BUILD__ &&\n logger.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', err);\n }\n }\n\n return result;\n}\n\n/**\n * Tells whether current environment supports ReportingObserver API\n * {@link supportsReportingObserver}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsReportingObserver(): boolean {\n return 'ReportingObserver' in WINDOW;\n}\n\n/**\n * Tells whether current environment supports Referrer Policy API\n * {@link supportsReferrerPolicy}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsReferrerPolicy(): boolean {\n // Despite all stars in the sky saying that Edge supports old draft syntax, aka 'never', 'always', 'origin' and 'default'\n // (see https://caniuse.com/#feat=referrer-policy),\n // it doesn't. And it throws an exception instead of ignoring this parameter...\n // REF: https://github.com/getsentry/raven-js/issues/1233\n\n if (!supportsFetch()) {\n return false;\n }\n\n try {\n new Request('_', {\n referrerPolicy: 'origin' as ReferrerPolicy,\n });\n return true;\n } catch (e) {\n return false;\n }\n}\n","// Based on https://github.com/angular/angular.js/pull/13945/files\n// The MIT License\n\n// Copyright (c) 2010-2016 Google, Inc. http://angularjs.org\n\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport { getGlobalObject } from '../worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\n/**\n * Tells whether current environment supports History API\n * {@link supportsHistory}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsHistory(): boolean {\n // NOTE: in Chrome App environment, touching history.pushState, *even inside\n // a try/catch block*, will cause Chrome to output an error to console.error\n // borrowed from: https://github.com/angular/angular.js/pull/13945/files\n /* eslint-disable @typescript-eslint/no-unsafe-member-access */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const chrome = (WINDOW as any).chrome;\n const isChromePackagedApp = chrome && chrome.app && chrome.app.runtime;\n /* eslint-enable @typescript-eslint/no-unsafe-member-access */\n const hasHistoryApi = 'history' in WINDOW && !!WINDOW.history.pushState && !!WINDOW.history.replaceState;\n\n return !isChromePackagedApp && hasHistoryApi;\n}\n","/* eslint-disable max-lines */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/ban-types */\nimport type {\n HandlerDataFetch,\n HandlerDataXhr,\n SentryWrappedXMLHttpRequest,\n SentryXhrData,\n WrappedFunction,\n} from '@sentry/types';\n\nimport { isString } from './is';\nimport { CONSOLE_LEVELS, logger } from './logger';\nimport { fill } from './object';\nimport { getFunctionName } from './stacktrace';\nimport { supportsHistory, supportsNativeFetch } from './supports';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nexport const SENTRY_XHR_DATA_KEY = '__sentry_xhr_v2__';\n\nexport type InstrumentHandlerType =\n | 'console'\n | 'dom'\n | 'fetch'\n | 'history'\n | 'sentry'\n | 'xhr'\n | 'error'\n | 'unhandledrejection';\nexport type InstrumentHandlerCallback = (data: any) => void;\n\n/**\n * Instrument native APIs to call handlers that can be used to create breadcrumbs, APM spans etc.\n * - Console API\n * - Fetch API\n * - XHR API\n * - History API\n * - DOM API (click/typing)\n * - Error API\n * - UnhandledRejection API\n */\n\nconst handlers: { [key in InstrumentHandlerType]?: InstrumentHandlerCallback[] } = {};\nconst instrumented: { [key in InstrumentHandlerType]?: boolean } = {};\n\n/** Instruments given API */\nfunction instrument(type: InstrumentHandlerType): void {\n if (instrumented[type]) {\n return;\n }\n\n instrumented[type] = true;\n\n switch (type) {\n case 'console':\n instrumentConsole();\n break;\n case 'dom':\n instrumentDOM();\n break;\n case 'xhr':\n instrumentXHR();\n break;\n case 'fetch':\n instrumentFetch();\n break;\n case 'history':\n instrumentHistory();\n break;\n case 'error':\n instrumentError();\n break;\n case 'unhandledrejection':\n instrumentUnhandledRejection();\n break;\n default:\n __DEBUG_BUILD__ && logger.warn('unknown instrumentation type:', type);\n return;\n }\n}\n\n/**\n * Add handler that will be called when given type of instrumentation triggers.\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nexport function addInstrumentationHandler(type: InstrumentHandlerType, callback: InstrumentHandlerCallback): void {\n handlers[type] = handlers[type] || [];\n (handlers[type] as InstrumentHandlerCallback[]).push(callback);\n instrument(type);\n}\n\n/** JSDoc */\nfunction triggerHandlers(type: InstrumentHandlerType, data: any): void {\n if (!type || !handlers[type]) {\n return;\n }\n\n for (const handler of handlers[type] || []) {\n try {\n handler(data);\n } catch (e) {\n __DEBUG_BUILD__ &&\n logger.error(\n `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${getFunctionName(handler)}\\nError:`,\n e,\n );\n }\n }\n}\n\n/** JSDoc */\nfunction instrumentConsole(): void {\n if (!('console' in WINDOW)) {\n return;\n }\n\n CONSOLE_LEVELS.forEach(function (level: string): void {\n if (!(level in WINDOW.console)) {\n return;\n }\n\n fill(WINDOW.console, level, function (originalConsoleMethod: () => any): Function {\n return function (...args: any[]): void {\n triggerHandlers('console', { args, level });\n\n // this fails for some browsers. :(\n if (originalConsoleMethod) {\n originalConsoleMethod.apply(WINDOW.console, args);\n }\n };\n });\n });\n}\n\n/** JSDoc */\nfunction instrumentFetch(): void {\n if (!supportsNativeFetch()) {\n return;\n }\n\n fill(WINDOW, 'fetch', function (originalFetch: () => void): () => void {\n return function (...args: any[]): void {\n const { method, url } = parseFetchArgs(args);\n\n const handlerData: HandlerDataFetch = {\n args,\n fetchData: {\n method,\n url,\n },\n startTimestamp: Date.now(),\n };\n\n triggerHandlers('fetch', {\n ...handlerData,\n });\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return originalFetch.apply(WINDOW, args).then(\n (response: Response) => {\n triggerHandlers('fetch', {\n ...handlerData,\n endTimestamp: Date.now(),\n response,\n });\n return response;\n },\n (error: Error) => {\n triggerHandlers('fetch', {\n ...handlerData,\n endTimestamp: Date.now(),\n error,\n });\n // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n // it means the sentry.javascript SDK caught an error invoking your application code.\n // This is expected behavior and NOT indicative of a bug with sentry.javascript.\n throw error;\n },\n );\n };\n });\n}\n\nfunction hasProp<T extends string>(obj: unknown, prop: T): obj is Record<string, string> {\n return !!obj && typeof obj === 'object' && !!(obj as Record<string, string>)[prop];\n}\n\ntype FetchResource = string | { toString(): string } | { url: string };\n\nfunction getUrlFromResource(resource: FetchResource): string {\n if (typeof resource === 'string') {\n return resource;\n }\n\n if (!resource) {\n return '';\n }\n\n if (hasProp(resource, 'url')) {\n return resource.url;\n }\n\n if (resource.toString) {\n return resource.toString();\n }\n\n return '';\n}\n\n/**\n * Parses the fetch arguments to find the used Http method and the url of the request\n */\nexport function parseFetchArgs(fetchArgs: unknown[]): { method: string; url: string } {\n if (fetchArgs.length === 0) {\n return { method: 'GET', url: '' };\n }\n\n if (fetchArgs.length === 2) {\n const [url, options] = fetchArgs as [FetchResource, object];\n\n return {\n url: getUrlFromResource(url),\n method: hasProp(options, 'method') ? String(options.method).toUpperCase() : 'GET',\n };\n }\n\n const arg = fetchArgs[0];\n return {\n url: getUrlFromResource(arg as FetchResource),\n method: hasProp(arg, 'method') ? String(arg.method).toUpperCase() : 'GET',\n };\n}\n\n/** JSDoc */\nfunction instrumentXHR(): void {\n if (!('XMLHttpRequest' in WINDOW)) {\n return;\n }\n\n const xhrproto = XMLHttpRequest.prototype;\n\n fill(xhrproto, 'open', function (originalOpen: () => void): () => void {\n return function (this: XMLHttpRequest & SentryWrappedXMLHttpRequest, ...args: any[]): void {\n const url = args[1];\n const xhrInfo: SentryXhrData = (this[SENTRY_XHR_DATA_KEY] = {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n method: isString(args[0]) ? args[0].toUpperCase() : args[0],\n url: args[1],\n request_headers: {},\n });\n\n // if Sentry key appears in URL, don't capture it as a request\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (isString(url) && xhrInfo.method === 'POST' && url.match(/sentry_key/)) {\n this.__sentry_own_request__ = true;\n }\n\n const onreadystatechangeHandler: () => void = () => {\n // For whatever reason, this is not the same instance here as from the outer method\n const xhrInfo = this[SENTRY_XHR_DATA_KEY];\n\n if (!xhrInfo) {\n return;\n }\n\n if (this.readyState === 4) {\n try {\n // touching statusCode in some platforms throws\n // an exception\n xhrInfo.status_code = this.status;\n } catch (e) {\n /* do nothing */\n }\n\n triggerHandlers('xhr', {\n args: args as [string, string],\n endTimestamp: Date.now(),\n startTimestamp: Date.now(),\n xhr: this,\n } as HandlerDataXhr);\n }\n };\n\n if ('onreadystatechange' in this && typeof this.onreadystatechange === 'function') {\n fill(this, 'onreadystatechange', function (original: WrappedFunction): Function {\n return function (this: SentryWrappedXMLHttpRequest, ...readyStateArgs: any[]): void {\n onreadystatechangeHandler();\n return original.apply(this, readyStateArgs);\n };\n });\n } else {\n this.addEventListener('readystatechange', onreadystatechangeHandler);\n }\n\n // Intercepting `setRequestHeader` to access the request headers of XHR instance.\n // This will only work for user/library defined headers, not for the default/browser-assigned headers.\n // Request cookies are also unavailable for XHR, as `Cookie` header can't be defined by `setRequestHeader`.\n fill(this, 'setRequestHeader', function (original: WrappedFunction): Function {\n return function (this: SentryWrappedXMLHttpRequest, ...setRequestHeaderArgs: unknown[]): void {\n const [header, value] = setRequestHeaderArgs as [string, string];\n\n const xhrInfo = this[SENTRY_XHR_DATA_KEY];\n\n if (xhrInfo) {\n xhrInfo.request_headers[header.toLowerCase()] = value;\n }\n\n return original.apply(this, setRequestHeaderArgs);\n };\n });\n\n return originalOpen.apply(this, args);\n };\n });\n\n fill(xhrproto, 'send', function (originalSend: () => void): () => void {\n return function (this: XMLHttpRequest & SentryWrappedXMLHttpRequest, ...args: any[]): void {\n const sentryXhrData = this[SENTRY_XHR_DATA_KEY];\n if (sentryXhrData && args[0] !== undefined) {\n sentryXhrData.body = args[0];\n }\n\n triggerHandlers('xhr', {\n args,\n startTimestamp: Date.now(),\n xhr: this,\n });\n\n return originalSend.apply(this, args);\n };\n });\n}\n\nlet lastHref: string;\n\n/** JSDoc */\nfunction instrumentHistory(): void {\n if (!supportsHistory()) {\n return;\n }\n\n const oldOnPopState = WINDOW.onpopstate;\n WINDOW.onpopstate = function (this: WindowEventHandlers, ...args: any[]): any {\n const to = WINDOW.location.href;\n // keep track of the current URL state, as we always receive only the updated state\n const from = lastHref;\n lastHref = to;\n triggerHandlers('history', {\n from,\n to,\n });\n if (oldOnPopState) {\n // Apparently this can throw in Firefox when incorrectly implemented plugin is installed.\n // https://github.com/getsentry/sentry-javascript/issues/3344\n // https://github.com/bugsnag/bugsnag-js/issues/469\n try {\n return oldOnPopState.apply(this, args);\n } catch (_oO) {\n // no-empty\n }\n }\n };\n\n /** @hidden */\n function historyReplacementFunction(originalHistoryFunction: () => void): () => void {\n return function (this: History, ...args: any[]): void {\n const url = args.length > 2 ? args[2] : undefined;\n if (url) {\n // coerce to string (this is what pushState does)\n const from = lastHref;\n const to = String(url);\n // keep track of the current URL state, as we always receive only the updated state\n lastHref = to;\n triggerHandlers('history', {\n from,\n to,\n });\n }\n return originalHistoryFunction.apply(this, args);\n };\n }\n\n fill(WINDOW.history, 'pushState', historyReplacementFunction);\n fill(WINDOW.history, 'replaceState', historyReplacementFunction);\n}\n\nconst debounceDuration = 1000;\nlet debounceTimerID: number | undefined;\nlet lastCapturedEvent: Event | undefined;\n\n/**\n * Decide whether the current event should finish the debounce of previously captured one.\n * @param previous previously captured event\n * @param current event to be captured\n */\nfunction shouldShortcircuitPreviousDebounce(previous: Event | undefined, current: Event): boolean {\n // If there was no previous event, it should always be swapped for the new one.\n if (!previous) {\n return true;\n }\n\n // If both events have different type, then user definitely performed two separate actions. e.g. click + keypress.\n if (previous.type !== current.type) {\n return true;\n }\n\n try {\n // If both events have the same type, it's still possible that actions were performed on different targets.\n // e.g. 2 clicks on different buttons.\n if (previous.target !== current.target) {\n return true;\n }\n } catch (e) {\n // just accessing `target` property can throw an exception in some rare circumstances\n // see: https://github.com/getsentry/sentry-javascript/issues/838\n }\n\n // If both events have the same type _and_ same `target` (an element which triggered an event, _not necessarily_\n // to which an event listener was attached), we treat them as the same action, as we want to capture\n // only one breadcrumb. e.g. multiple clicks on the same button, or typing inside a user input box.\n return false;\n}\n\n/**\n * Decide whether an event should be captured.\n * @param event event to be captured\n */\nfunction shouldSkipDOMEvent(event: Event): boolean {\n // We are only interested in filtering `keypress` events for now.\n if (event.type !== 'keypress') {\n return false;\n }\n\n try {\n const target = event.target as HTMLElement;\n\n if (!target || !target.tagName) {\n return true;\n }\n\n // Only consider keypress events on actual input elements. This will disregard keypresses targeting body\n // e.g.tabbing through elements, hotkeys, etc.\n if (target.tagName === 'INPUT' || target.tagName === 'TEXTAREA' || target.isContentEditable) {\n return false;\n }\n } catch (e) {\n // just accessing `target` property can throw an exception in some rare circumstances\n // see: https://github.com/getsentry/sentry-javascript/issues/838\n }\n\n return true;\n}\n\n/**\n * Wraps addEventListener to capture UI breadcrumbs\n * @param handler function that will be triggered\n * @param globalListener indicates whether event was captured by the global event listener\n * @returns wrapped breadcrumb events handler\n * @hidden\n */\nfunction makeDOMEventHandler(handler: Function, globalListener: boolean = false): (event: Event) => void {\n return (event: Event): void => {\n // It's possible this handler might trigger multiple times for the same\n // event (e.g. event propagation through node ancestors).\n // Ignore if we've already captured that event.\n if (!event || lastCapturedEvent === event) {\n return;\n }\n\n // We always want to skip _some_ events.\n if (shouldSkipDOMEvent(event)) {\n return;\n }\n\n const name = event.type === 'keypress' ? 'input' : event.type;\n\n // If there is no debounce timer, it means that we can safely capture the new event and store it for future comparisons.\n if (debounceTimerID === undefined) {\n handler({\n event: event,\n name,\n global: globalListener,\n });\n lastCapturedEvent = event;\n }\n // If there is a debounce awaiting, see if the new event is different enough to treat it as a unique one.\n // If that's the case, emit the previous event and store locally the newly-captured DOM event.\n else if (shouldShortcircuitPreviousDebounce(lastCapturedEvent, event)) {\n handler({\n event: event,\n name,\n global: globalListener,\n });\n lastCapturedEvent = event;\n }\n\n // Start a new debounce timer that will prevent us from capturing multiple events that should be grouped together.\n clearTimeout(debounceTimerID);\n debounceTimerID = WINDOW.setTimeout(() => {\n debounceTimerID = undefined;\n }, debounceDuration);\n };\n}\n\ntype AddEventListener = (\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | AddEventListenerOptions,\n) => void;\ntype RemoveEventListener = (\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | EventListenerOptions,\n) => void;\n\ntype InstrumentedElement = Element & {\n __sentry_instrumentation_handlers__?: {\n [key in 'click' | 'keypress']?: {\n handler?: Function;\n /** The number of custom listeners attached to this element */\n refCount: number;\n };\n };\n};\n\n/** JSDoc */\nfunction instrumentDOM(): void {\n if (!('document' in WINDOW)) {\n return;\n }\n\n // Make it so that any click or keypress that is unhandled / bubbled up all the way to the document triggers our dom\n // handlers. (Normally we have only one, which captures a breadcrumb for each click or keypress.) Do this before\n // we instrument `addEventListener` so that we don't end up attaching this handler twice.\n const triggerDOMHandler = triggerHandlers.bind(null, 'dom');\n const globalDOMEventHandler = makeDOMEventHandler(triggerDOMHandler, true);\n WINDOW.document.addEventListener('click', globalDOMEventHandler, false);\n WINDOW.document.addEventListener('keypress', globalDOMEventHandler, false);\n\n // After hooking into click and keypress events bubbled up to `document`, we also hook into user-handled\n // clicks & keypresses, by adding an event listener of our own to any element to which they add a listener. That\n // way, whenever one of their handlers is triggered, ours will be, too. (This is needed because their handler\n // could potentially prevent the event from bubbling up to our global listeners. This way, our handler are still\n // guaranteed to fire at least once.)\n ['EventTarget', 'Node'].forEach((target: string) => {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const proto = (WINDOW as any)[target] && (WINDOW as any)[target].prototype;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, no-prototype-builtins\n if (!proto || !proto.hasOwnProperty || !proto.hasOwnProperty('addEventListener')) {\n return;\n }\n\n fill(proto, 'addEventListener', function (originalAddEventListener: AddEventListener): AddEventListener {\n return function (\n this: Element,\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ): AddEventListener {\n if (type === 'click' || type == 'keypress') {\n try {\n const el = this as InstrumentedElement;\n const handlers = (el.__sentry_instrumentation_handlers__ = el.__sentry_instrumentation_handlers__ || {});\n const handlerForType = (handlers[type] = handlers[type] || { refCount: 0 });\n\n if (!handlerForType.handler) {\n const handler = makeDOMEventHandler(triggerDOMHandler);\n handlerForType.handler = handler;\n originalAddEventListener.call(this, type, handler, options);\n }\n\n handlerForType.refCount++;\n } catch (e) {\n // Accessing dom properties is always fragile.\n // Also allows us to skip `addEventListenrs` calls with no proper `this` context.\n }\n }\n\n return originalAddEventListener.call(this, type, listener, options);\n };\n });\n\n fill(\n proto,\n 'removeEventListener',\n function (originalRemoveEventListener: RemoveEventListener): RemoveEventListener {\n return function (\n this: Element,\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | EventListenerOptions,\n ): () => void {\n if (type === 'click' || type == 'keypress') {\n try {\n const el = this as InstrumentedElement;\n const handlers = el.__sentry_instrumentation_handlers__ || {};\n const handlerForType = handlers[type];\n\n if (handlerForType) {\n handlerForType.refCount--;\n // If there are no longer any custom handlers of the current type on this element, we can remove ours, too.\n if (handlerForType.refCount <= 0) {\n originalRemoveEventListener.call(this, type, handlerForType.handler, options);\n handlerForType.handler = undefined;\n delete handlers[type]; // eslint-disable-line @typescript-eslint/no-dynamic-delete\n }\n\n // If there are no longer any custom handlers of any type on this element, cleanup everything.\n if (Object.keys(handlers).length === 0) {\n delete el.__sentry_instrumentation_handlers__;\n }\n }\n } catch (e) {\n // Accessing dom properties is always fragile.\n // Also allows us to skip `addEventListenrs` calls with no proper `this` context.\n }\n }\n\n return originalRemoveEventListener.call(this, type, listener, options);\n };\n },\n );\n });\n}\n\nlet _oldOnErrorHandler: (typeof WINDOW)['onerror'] | null = null;\n/** JSDoc */\nfunction instrumentError(): void {\n _oldOnErrorHandler = WINDOW.onerror;\n\n WINDOW.onerror = function (msg: unknown, url: unknown, line: unknown, column: unknown, error: unknown): boolean {\n triggerHandlers('error', {\n column,\n error,\n line,\n msg,\n url,\n });\n\n if (_oldOnErrorHandler && !_oldOnErrorHandler.__SENTRY_LOADER__) {\n // eslint-disable-next-line prefer-rest-params\n return _oldOnErrorHandler.apply(this, arguments);\n }\n\n return false;\n };\n\n WINDOW.onerror.__SENTRY_INSTRUMENTED__ = true;\n}\n\nlet _oldOnUnhandledRejectionHandler: (typeof WINDOW)['onunhandledrejection'] | null = null;\n/** JSDoc */\nfunction instrumentUnhandledRejection(): void {\n _oldOnUnhandledRejectionHandler = WINDOW.onunhandledrejection;\n\n WINDOW.onunhandledrejection = function (e: any): boolean {\n triggerHandlers('unhandledrejection', e);\n\n if (_oldOnUnhandledRejectionHandler && !_oldOnUnhandledRejectionHandler.__SENTRY_LOADER__) {\n // eslint-disable-next-line prefer-rest-params\n return _oldOnUnhandledRejectionHandler.apply(this, arguments);\n }\n\n return true;\n };\n\n WINDOW.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true;\n}\n","import getPrototypeOf from \"./getPrototypeOf.js\";\nexport default function _superPropBase(object, property) {\n while (!Object.prototype.hasOwnProperty.call(object, property)) {\n object = getPrototypeOf(object);\n if (object === null) break;\n }\n\n return object;\n}","import superPropBase from \"./superPropBase.js\";\nexport default function _get() {\n if (typeof Reflect !== \"undefined\" && Reflect.get) {\n _get = Reflect.get.bind();\n } else {\n _get = function _get(target, property, receiver) {\n var base = superPropBase(target, property);\n if (!base) return;\n var desc = Object.getOwnPropertyDescriptor(base, property);\n\n if (desc.get) {\n return desc.get.call(arguments.length < 3 ? target : receiver);\n }\n\n return desc.value;\n };\n }\n\n return _get.apply(this, arguments);\n}","export const SDK_VERSION = '7.64.0';\n","import type { DsnComponents, DsnLike, DsnProtocol } from '@sentry/types';\n\nimport { logger } from './logger';\n\n/** Regular expression used to parse a Dsn. */\nconst DSN_REGEX = /^(?:(\\w+):)\\/\\/(?:(\\w+)(?::(\\w+)?)?@)([\\w.-]+)(?::(\\d+))?\\/(.+)/;\n\nfunction isValidProtocol(protocol?: string): protocol is DsnProtocol {\n return protocol === 'http' || protocol === 'https';\n}\n\n/**\n * Renders the string representation of this Dsn.\n *\n * By default, this will render the public representation without the password\n * component. To get the deprecated private representation, set `withPassword`\n * to true.\n *\n * @param withPassword When set to true, the password will be included.\n */\nexport function dsnToString(dsn: DsnComponents, withPassword: boolean = false): string {\n const { host, path, pass, port, projectId, protocol, publicKey } = dsn;\n return (\n `${protocol}://${publicKey}${withPassword && pass ? `:${pass}` : ''}` +\n `@${host}${port ? `:${port}` : ''}/${path ? `${path}/` : path}${projectId}`\n );\n}\n\n/**\n * Parses a Dsn from a given string.\n *\n * @param str A Dsn as string\n * @returns Dsn as DsnComponents or undefined if @param str is not a valid DSN string\n */\nexport function dsnFromString(str: string): DsnComponents | undefined {\n const match = DSN_REGEX.exec(str);\n\n if (!match) {\n // This should be logged to the console\n // eslint-disable-next-line no-console\n console.error(`Invalid Sentry Dsn: ${str}`);\n return undefined;\n }\n\n const [protocol, publicKey, pass = '', host, port = '', lastPath] = match.slice(1);\n let path = '';\n let projectId = lastPath;\n\n const split = projectId.split('/');\n if (split.length > 1) {\n path = split.slice(0, -1).join('/');\n projectId = split.pop() as string;\n }\n\n if (projectId) {\n const projectMatch = projectId.match(/^\\d+/);\n if (projectMatch) {\n projectId = projectMatch[0];\n }\n }\n\n return dsnFromComponents({ host, pass, path, projectId, port, protocol: protocol as DsnProtocol, publicKey });\n}\n\nfunction dsnFromComponents(components: DsnComponents): DsnComponents {\n return {\n protocol: components.protocol,\n publicKey: components.publicKey || '',\n pass: components.pass || '',\n host: components.host,\n port: components.port || '',\n path: components.path || '',\n projectId: components.projectId,\n };\n}\n\nfunction validateDsn(dsn: DsnComponents): boolean {\n if (!__DEBUG_BUILD__) {\n return true;\n }\n\n const { port, projectId, protocol } = dsn;\n\n const requiredComponents: ReadonlyArray<keyof DsnComponents> = ['protocol', 'publicKey', 'host', 'projectId'];\n const hasMissingRequiredComponent = requiredComponents.find(component => {\n if (!dsn[component]) {\n logger.error(`Invalid Sentry Dsn: ${component} missing`);\n return true;\n }\n return false;\n });\n\n if (hasMissingRequiredComponent) {\n return false;\n }\n\n if (!projectId.match(/^\\d+$/)) {\n logger.error(`Invalid Sentry Dsn: Invalid projectId ${projectId}`);\n return false;\n }\n\n if (!isValidProtocol(protocol)) {\n logger.error(`Invalid Sentry Dsn: Invalid protocol ${protocol}`);\n return false;\n }\n\n if (port && isNaN(parseInt(port, 10))) {\n logger.error(`Invalid Sentry Dsn: Invalid port ${port}`);\n return false;\n }\n\n return true;\n}\n\n/**\n * Creates a valid Sentry Dsn object, identifying a Sentry instance and project.\n * @returns a valid DsnComponents object or `undefined` if @param from is an invalid DSN source\n */\nexport function makeDsn(from: DsnLike): DsnComponents | undefined {\n const components = typeof from === 'string' ? dsnFromString(from) : dsnFromComponents(from);\n if (!components || !validateDsn(components)) {\n return undefined;\n }\n return components;\n}\n","/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport type MemoFunc = [\n // memoize\n (obj: any) => boolean,\n // unmemoize\n (obj: any) => void,\n];\n\n/**\n * Helper to decycle json objects\n */\nexport function memoBuilder(): MemoFunc {\n const hasWeakSet = typeof WeakSet === 'function';\n const inner: any = hasWeakSet ? new WeakSet() : [];\n function memoize(obj: any): boolean {\n if (hasWeakSet) {\n if (inner.has(obj)) {\n return true;\n }\n inner.add(obj);\n return false;\n }\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < inner.length; i++) {\n const value = inner[i];\n if (value === obj) {\n return true;\n }\n }\n inner.push(obj);\n return false;\n }\n\n function unmemoize(obj: any): void {\n if (hasWeakSet) {\n inner.delete(obj);\n } else {\n for (let i = 0; i < inner.length; i++) {\n if (inner[i] === obj) {\n inner.splice(i, 1);\n break;\n }\n }\n }\n }\n return [memoize, unmemoize];\n}\n","import type { Primitive } from '@sentry/types';\n\nimport { isNaN, isSyntheticEvent } from './is';\nimport type { MemoFunc } from './memo';\nimport { memoBuilder } from './memo';\nimport { convertToPlainObject } from './object';\nimport { getFunctionName } from './stacktrace';\n\ntype Prototype = { constructor: (...args: unknown[]) => unknown };\n// This is a hack to placate TS, relying on the fact that technically, arrays are objects with integer keys. Normally we\n// think of those keys as actual numbers, but `arr['0']` turns out to work just as well as `arr[0]`, and doing it this\n// way lets us use a single type in the places where behave as if we are only dealing with objects, even if some of them\n// might be arrays.\ntype ObjOrArray<T> = { [key: string]: T };\n\n/**\n * Recursively normalizes the given object.\n *\n * - Creates a copy to prevent original input mutation\n * - Skips non-enumerable properties\n * - When stringifying, calls `toJSON` if implemented\n * - Removes circular references\n * - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format\n * - Translates known global objects/classes to a string representations\n * - Takes care of `Error` object serialization\n * - Optionally limits depth of final output\n * - Optionally limits number of properties/elements included in any single object/array\n *\n * @param input The object to be normalized.\n * @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.)\n * @param maxProperties The max number of elements or properties to be included in any single array or\n * object in the normallized output.\n * @returns A normalized version of the object, or `\"**non-serializable**\"` if any errors are thrown during normalization.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function normalize(input: unknown, depth: number = 100, maxProperties: number = +Infinity): any {\n try {\n // since we're at the outermost level, we don't provide a key\n return visit('', input, depth, maxProperties);\n } catch (err) {\n return { ERROR: `**non-serializable** (${err})` };\n }\n}\n\n/** JSDoc */\nexport function normalizeToSize<T>(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n object: { [key: string]: any },\n // Default Node.js REPL depth\n depth: number = 3,\n // 100kB, as 200kB is max payload size, so half sounds reasonable\n maxSize: number = 100 * 1024,\n): T {\n const normalized = normalize(object, depth);\n\n if (jsonSize(normalized) > maxSize) {\n return normalizeToSize(object, depth - 1, maxSize);\n }\n\n return normalized as T;\n}\n\n/**\n * Visits a node to perform normalization on it\n *\n * @param key The key corresponding to the given node\n * @param value The node to be visited\n * @param depth Optional number indicating the maximum recursion depth\n * @param maxProperties Optional maximum number of properties/elements included in any single object/array\n * @param memo Optional Memo class handling decycling\n */\nfunction visit(\n key: string,\n value: unknown,\n depth: number = +Infinity,\n maxProperties: number = +Infinity,\n memo: MemoFunc = memoBuilder(),\n): Primitive | ObjOrArray<unknown> {\n const [memoize, unmemoize] = memo;\n\n // Get the simple cases out of the way first\n if (\n value == null || // this matches null and undefined -> eqeq not eqeqeq\n (['number', 'boolean', 'string'].includes(typeof value) && !isNaN(value))\n ) {\n return value as Primitive;\n }\n\n const stringified = stringifyValue(key, value);\n\n // Anything we could potentially dig into more (objects or arrays) will have come back as `\"[object XXXX]\"`.\n // Everything else will have already been serialized, so if we don't see that pattern, we're done.\n if (!stringified.startsWith('[object ')) {\n return stringified;\n }\n\n // From here on, we can assert that `value` is either an object or an array.\n\n // Do not normalize objects that we know have already been normalized. As a general rule, the\n // \"__sentry_skip_normalization__\" property should only be used sparingly and only should only be set on objects that\n // have already been normalized.\n if ((value as ObjOrArray<unknown>)['__sentry_skip_normalization__']) {\n return value as ObjOrArray<unknown>;\n }\n\n // We can set `__sentry_override_normalization_depth__` on an object to ensure that from there\n // We keep a certain amount of depth.\n // This should be used sparingly, e.g. we use it for the redux integration to ensure we get a certain amount of state.\n const remainingDepth =\n typeof (value as ObjOrArray<unknown>)['__sentry_override_normalization_depth__'] === 'number'\n ? ((value as ObjOrArray<unknown>)['__sentry_override_normalization_depth__'] as number)\n : depth;\n\n // We're also done if we've reached the max depth\n if (remainingDepth === 0) {\n // At this point we know `serialized` is a string of the form `\"[object XXXX]\"`. Clean it up so it's just `\"[XXXX]\"`.\n return stringified.replace('object ', '');\n }\n\n // If we've already visited this branch, bail out, as it's circular reference. If not, note that we're seeing it now.\n if (memoize(value)) {\n return '[Circular ~]';\n }\n\n // If the value has a `toJSON` method, we call it to extract more information\n const valueWithToJSON = value as unknown & { toJSON?: () => unknown };\n if (valueWithToJSON && typeof valueWithToJSON.toJSON === 'function') {\n try {\n const jsonValue = valueWithToJSON.toJSON();\n // We need to normalize the return value of `.toJSON()` in case it has circular references\n return visit('', jsonValue, remainingDepth - 1, maxProperties, memo);\n } catch (err) {\n // pass (The built-in `toJSON` failed, but we can still try to do it ourselves)\n }\n }\n\n // At this point we know we either have an object or an array, we haven't seen it before, and we're going to recurse\n // because we haven't yet reached the max depth. Create an accumulator to hold the results of visiting each\n // property/entry, and keep track of the number of items we add to it.\n const normalized = (Array.isArray(value) ? [] : {}) as ObjOrArray<unknown>;\n let numAdded = 0;\n\n // Before we begin, convert`Error` and`Event` instances into plain objects, since some of each of their relevant\n // properties are non-enumerable and otherwise would get missed.\n const visitable = convertToPlainObject(value as ObjOrArray<unknown>);\n\n for (const visitKey in visitable) {\n // Avoid iterating over fields in the prototype if they've somehow been exposed to enumeration.\n if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) {\n continue;\n }\n\n if (numAdded >= maxProperties) {\n normalized[visitKey] = '[MaxProperties ~]';\n break;\n }\n\n // Recursively visit all the child nodes\n const visitValue = visitable[visitKey];\n normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo);\n\n numAdded++;\n }\n\n // Once we've visited all the branches, remove the parent from memo storage\n unmemoize(value);\n\n // Return accumulated values\n return normalized;\n}\n\n// TODO remove this in v7 (this means the method will no longer be exported, under any name)\nexport { visit as walk };\n\n/* eslint-disable complexity */\n/**\n * Stringify the given value. Handles various known special values and types.\n *\n * Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn\n * the number 1231 into \"[Object Number]\", nor on `null`, as it will throw.\n *\n * @param value The value to stringify\n * @returns A stringified representation of the given value\n */\nfunction stringifyValue(\n key: unknown,\n // this type is a tiny bit of a cheat, since this function does handle NaN (which is technically a number), but for\n // our internal use, it'll do\n value: Exclude<unknown, string | number | boolean | null>,\n): string {\n try {\n if (key === 'domain' && value && typeof value === 'object' && (value as { _events: unknown })._events) {\n return '[Domain]';\n }\n\n if (key === 'domainEmitter') {\n return '[DomainEmitter]';\n }\n\n // It's safe to use `global`, `window`, and `document` here in this manner, as we are asserting using `typeof` first\n // which won't throw if they are not present.\n\n if (typeof global !== 'undefined' && value === global) {\n return '[Global]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof window !== 'undefined' && value === window) {\n return '[Window]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof document !== 'undefined' && value === document) {\n return '[Document]';\n }\n\n // React's SyntheticEvent thingy\n if (isSyntheticEvent(value)) {\n return '[SyntheticEvent]';\n }\n\n if (typeof value === 'number' && value !== value) {\n return '[NaN]';\n }\n\n if (typeof value === 'function') {\n return `[Function: ${getFunctionName(value)}]`;\n }\n\n if (typeof value === 'symbol') {\n return `[${String(value)}]`;\n }\n\n // stringified BigInts are indistinguishable from regular numbers, so we need to label them to avoid confusion\n if (typeof value === 'bigint') {\n return `[BigInt: ${String(value)}]`;\n }\n\n // Now that we've knocked out all the special cases and the primitives, all we have left are objects. Simply casting\n // them to strings means that instances of classes which haven't defined their `toStringTag` will just come out as\n // `\"[object Object]\"`. If we instead look at the constructor's name (which is the same as the name of the class),\n // we can make sure that only plain objects come out that way.\n const objName = getConstructorName(value);\n\n // Handle HTML Elements\n if (/^HTML(\\w*)Element$/.test(objName)) {\n return `[HTMLElement: ${objName}]`;\n }\n\n return `[object ${objName}]`;\n } catch (err) {\n return `**non-serializable** (${err})`;\n }\n}\n/* eslint-enable complexity */\n\nfunction getConstructorName(value: unknown): string {\n const prototype: Prototype | null = Object.getPrototypeOf(value);\n\n return prototype ? prototype.constructor.name : 'null prototype';\n}\n\n/** Calculates bytes size of input string */\nfunction utf8Length(value: string): number {\n // eslint-disable-next-line no-bitwise\n return ~-encodeURI(value).split(/%..|./).length;\n}\n\n/** Calculates bytes size of input object */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction jsonSize(value: any): number {\n return utf8Length(JSON.stringify(value));\n}\n","import type {\n Attachment,\n AttachmentItem,\n BaseEnvelopeHeaders,\n BaseEnvelopeItemHeaders,\n DataCategory,\n DsnComponents,\n Envelope,\n EnvelopeItemType,\n Event,\n EventEnvelopeHeaders,\n SdkInfo,\n SdkMetadata,\n TextEncoderInternal,\n} from '@sentry/types';\n\nimport { dsnToString } from './dsn';\nimport { normalize } from './normalize';\nimport { dropUndefinedKeys } from './object';\n\n/**\n * Creates an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nexport function createEnvelope<E extends Envelope>(headers: E[0], items: E[1] = []): E {\n return [headers, items] as E;\n}\n\n/**\n * Add an item to an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nexport function addItemToEnvelope<E extends Envelope>(envelope: E, newItem: E[1][number]): E {\n const [headers, items] = envelope;\n return [headers, [...items, newItem]] as unknown as E;\n}\n\n/**\n * Convenience function to loop through the items and item types of an envelope.\n * (This function was mostly created because working with envelope types is painful at the moment)\n *\n * If the callback returns true, the rest of the items will be skipped.\n */\nexport function forEachEnvelopeItem<E extends Envelope>(\n envelope: Envelope,\n callback: (envelopeItem: E[1][number], envelopeItemType: E[1][number][0]['type']) => boolean | void,\n): boolean {\n const envelopeItems = envelope[1];\n\n for (const envelopeItem of envelopeItems) {\n const envelopeItemType = envelopeItem[0].type;\n const result = callback(envelopeItem, envelopeItemType);\n\n if (result) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Returns true if the envelope contains any of the given envelope item types\n */\nexport function envelopeContainsItemType(envelope: Envelope, types: EnvelopeItemType[]): boolean {\n return forEachEnvelopeItem(envelope, (_, type) => types.includes(type));\n}\n\n/**\n * Encode a string to UTF8.\n */\nfunction encodeUTF8(input: string, textEncoder?: TextEncoderInternal): Uint8Array {\n const utf8 = textEncoder || new TextEncoder();\n return utf8.encode(input);\n}\n\n/**\n * Serializes an envelope.\n */\nexport function serializeEnvelope(envelope: Envelope, textEncoder?: TextEncoderInternal): string | Uint8Array {\n const [envHeaders, items] = envelope;\n\n // Initially we construct our envelope as a string and only convert to binary chunks if we encounter binary data\n let parts: string | Uint8Array[] = JSON.stringify(envHeaders);\n\n function append(next: string | Uint8Array): void {\n if (typeof parts === 'string') {\n parts = typeof next === 'string' ? parts + next : [encodeUTF8(parts, textEncoder), next];\n } else {\n parts.push(typeof next === 'string' ? encodeUTF8(next, textEncoder) : next);\n }\n }\n\n for (const item of items) {\n const [itemHeaders, payload] = item;\n\n append(`\\n${JSON.stringify(itemHeaders)}\\n`);\n\n if (typeof payload === 'string' || payload instanceof Uint8Array) {\n append(payload);\n } else {\n let stringifiedPayload: string;\n try {\n stringifiedPayload = JSON.stringify(payload);\n } catch (e) {\n // In case, despite all our efforts to keep `payload` circular-dependency-free, `JSON.strinify()` still\n // fails, we try again after normalizing it again with infinite normalization depth. This of course has a\n // performance impact but in this case a performance hit is better than throwing.\n stringifiedPayload = JSON.stringify(normalize(payload));\n }\n append(stringifiedPayload);\n }\n }\n\n return typeof parts === 'string' ? parts : concatBuffers(parts);\n}\n\nfunction concatBuffers(buffers: Uint8Array[]): Uint8Array {\n const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0);\n\n const merged = new Uint8Array(totalLength);\n let offset = 0;\n for (const buffer of buffers) {\n merged.set(buffer, offset);\n offset += buffer.length;\n }\n\n return merged;\n}\n\nexport interface TextDecoderInternal {\n decode(input?: Uint8Array): string;\n}\n\n/**\n * Parses an envelope\n */\nexport function parseEnvelope(\n env: string | Uint8Array,\n textEncoder: TextEncoderInternal,\n textDecoder: TextDecoderInternal,\n): Envelope {\n let buffer = typeof env === 'string' ? textEncoder.encode(env) : env;\n\n function readBinary(length: number): Uint8Array {\n const bin = buffer.subarray(0, length);\n // Replace the buffer with the remaining data excluding trailing newline\n buffer = buffer.subarray(length + 1);\n return bin;\n }\n\n function readJson<T>(): T {\n let i = buffer.indexOf(0xa);\n // If we couldn't find a newline, we must have found the end of the buffer\n if (i < 0) {\n i = buffer.length;\n }\n\n return JSON.parse(textDecoder.decode(readBinary(i))) as T;\n }\n\n const envelopeHeader = readJson<BaseEnvelopeHeaders>();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const items: [any, any][] = [];\n\n while (buffer.length) {\n const itemHeader = readJson<BaseEnvelopeItemHeaders>();\n const binaryLength = typeof itemHeader.length === 'number' ? itemHeader.length : undefined;\n\n items.push([itemHeader, binaryLength ? readBinary(binaryLength) : readJson()]);\n }\n\n return [envelopeHeader, items];\n}\n\n/**\n * Creates attachment envelope items\n */\nexport function createAttachmentEnvelopeItem(\n attachment: Attachment,\n textEncoder?: TextEncoderInternal,\n): AttachmentItem {\n const buffer = typeof attachment.data === 'string' ? encodeUTF8(attachment.data, textEncoder) : attachment.data;\n\n return [\n dropUndefinedKeys({\n type: 'attachment',\n length: buffer.length,\n filename: attachment.filename,\n content_type: attachment.contentType,\n attachment_type: attachment.attachmentType,\n }),\n buffer,\n ];\n}\n\nconst ITEM_TYPE_TO_DATA_CATEGORY_MAP: Record<EnvelopeItemType, DataCategory> = {\n session: 'session',\n sessions: 'session',\n attachment: 'attachment',\n transaction: 'transaction',\n event: 'error',\n client_report: 'internal',\n user_report: 'default',\n profile: 'profile',\n replay_event: 'replay',\n replay_recording: 'replay',\n check_in: 'monitor',\n};\n\n/**\n * Maps the type of an envelope item to a data category.\n */\nexport function envelopeItemTypeToDataCategory(type: EnvelopeItemType): DataCategory {\n return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type];\n}\n\n/** Extracts the minimal SDK info from from the metadata or an events */\nexport function getSdkMetadataForEnvelopeHeader(metadataOrEvent?: SdkMetadata | Event): SdkInfo | undefined {\n if (!metadataOrEvent || !metadataOrEvent.sdk) {\n return;\n }\n const { name, version } = metadataOrEvent.sdk;\n return { name, version };\n}\n\n/**\n * Creates event envelope headers, based on event, sdk info and tunnel\n * Note: This function was extracted from the core package to make it available in Replay\n */\nexport function createEventEnvelopeHeaders(\n event: Event,\n sdkInfo: SdkInfo | undefined,\n tunnel: string | undefined,\n dsn: DsnComponents,\n): EventEnvelopeHeaders {\n const dynamicSamplingContext = event.sdkProcessingMetadata && event.sdkProcessingMetadata.dynamicSamplingContext;\n return {\n event_id: event.event_id as string,\n sent_at: new Date().toISOString(),\n ...(sdkInfo && { sdk: sdkInfo }),\n ...(!!tunnel && { dsn: dsnToString(dsn) }),\n ...(dynamicSamplingContext && {\n trace: dropUndefinedKeys({ ...dynamicSamplingContext }),\n }),\n };\n}\n","import type { ConsoleLevel } from './logger';\n\n/** An error emitted by Sentry SDKs and related utilities. */\nexport class SentryError extends Error {\n /** Display name of this error instance. */\n public name: string;\n\n public logLevel: ConsoleLevel;\n\n public constructor(public message: string, logLevel: ConsoleLevel = 'warn') {\n super(message);\n\n this.name = new.target.prototype.constructor.name;\n // This sets the prototype to be `Error`, not `SentryError`. It's unclear why we do this, but commenting this line\n // out causes various (seemingly totally unrelated) playwright tests consistently time out. FYI, this makes\n // instances of `SentryError` fail `obj instanceof SentryError` checks.\n Object.setPrototypeOf(this, new.target.prototype);\n this.logLevel = logLevel;\n }\n}\n","import type { ClientOptions, DsnComponents, DsnLike, SdkInfo } from '@sentry/types';\nimport { dsnToString, makeDsn, urlEncode } from '@sentry/utils';\n\nconst SENTRY_API_VERSION = '7';\n\n/** Returns the prefix to construct Sentry ingestion API endpoints. */\nfunction getBaseApiEndpoint(dsn: DsnComponents): string {\n const protocol = dsn.protocol ? `${dsn.protocol}:` : '';\n const port = dsn.port ? `:${dsn.port}` : '';\n return `${protocol}//${dsn.host}${port}${dsn.path ? `/${dsn.path}` : ''}/api/`;\n}\n\n/** Returns the ingest API endpoint for target. */\nfunction _getIngestEndpoint(dsn: DsnComponents): string {\n return `${getBaseApiEndpoint(dsn)}${dsn.projectId}/envelope/`;\n}\n\n/** Returns a URL-encoded string with auth config suitable for a query string. */\nfunction _encodedAuth(dsn: DsnComponents, sdkInfo: SdkInfo | undefined): string {\n return urlEncode({\n // We send only the minimum set of required information. See\n // https://github.com/getsentry/sentry-javascript/issues/2572.\n sentry_key: dsn.publicKey,\n sentry_version: SENTRY_API_VERSION,\n ...(sdkInfo && { sentry_client: `${sdkInfo.name}/${sdkInfo.version}` }),\n });\n}\n\n/**\n * Returns the envelope endpoint URL with auth in the query string.\n *\n * Sending auth as part of the query string and not as custom HTTP headers avoids CORS preflight requests.\n */\nexport function getEnvelopeEndpointWithUrlEncodedAuth(\n dsn: DsnComponents,\n // TODO (v8): Remove `tunnelOrOptions` in favor of `options`, and use the substitute code below\n // options: ClientOptions = {} as ClientOptions,\n tunnelOrOptions: string | ClientOptions = {} as ClientOptions,\n): string {\n // TODO (v8): Use this code instead\n // const { tunnel, _metadata = {} } = options;\n // return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, _metadata.sdk)}`;\n\n const tunnel = typeof tunnelOrOptions === 'string' ? tunnelOrOptions : tunnelOrOptions.tunnel;\n const sdkInfo =\n typeof tunnelOrOptions === 'string' || !tunnelOrOptions._metadata ? undefined : tunnelOrOptions._metadata.sdk;\n\n return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, sdkInfo)}`;\n}\n\n/** Returns the url to the report dialog endpoint. */\nexport function getReportDialogEndpoint(\n dsnLike: DsnLike,\n dialogOptions: {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n user?: { name?: string; email?: string };\n },\n): string {\n const dsn = makeDsn(dsnLike);\n if (!dsn) {\n return '';\n }\n\n const endpoint = `${getBaseApiEndpoint(dsn)}embed/error-page/`;\n\n let encodedOptions = `dsn=${dsnToString(dsn)}`;\n for (const key in dialogOptions) {\n if (key === 'dsn') {\n continue;\n }\n\n if (key === 'user') {\n const user = dialogOptions.user;\n if (!user) {\n continue;\n }\n if (user.name) {\n encodedOptions += `&name=${encodeURIComponent(user.name)}`;\n }\n if (user.email) {\n encodedOptions += `&email=${encodeURIComponent(user.email)}`;\n }\n } else {\n encodedOptions += `&${encodeURIComponent(key)}=${encodeURIComponent(dialogOptions[key] as string)}`;\n }\n }\n\n return `${endpoint}?${encodedOptions}`;\n}\n","import type { Client, DynamicSamplingContext, Scope } from '@sentry/types';\nimport { dropUndefinedKeys } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from '../constants';\n\n/**\n * Creates a dynamic sampling context from a client.\n *\n * Dispatchs the `createDsc` lifecycle hook as a side effect.\n */\nexport function getDynamicSamplingContextFromClient(\n trace_id: string,\n client: Client,\n scope?: Scope,\n): DynamicSamplingContext {\n const options = client.getOptions();\n\n const { publicKey: public_key } = client.getDsn() || {};\n const { segment: user_segment } = (scope && scope.getUser()) || {};\n\n const dsc = dropUndefinedKeys({\n environment: options.environment || DEFAULT_ENVIRONMENT,\n release: options.release,\n user_segment,\n public_key,\n trace_id,\n }) as DynamicSamplingContext;\n\n client.emit && client.emit('createDsc', dsc);\n\n return dsc;\n}\n","import type { ClientOptions, Event, EventHint, StackFrame, StackParser } from '@sentry/types';\nimport { dateTimestampInSeconds, GLOBAL_OBJ, normalize, resolvedSyncPromise, truncate, uuid4 } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from '../constants';\nimport { Scope } from '../scope';\n\n/**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * Note: This also triggers callbacks for `addGlobalEventProcessor`, but not `beforeSend`.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n * @hidden\n */\nexport function prepareEvent(\n options: ClientOptions,\n event: Event,\n hint: EventHint,\n scope?: Scope,\n): PromiseLike<Event | null> {\n const { normalizeDepth = 3, normalizeMaxBreadth = 1_000 } = options;\n const prepared: Event = {\n ...event,\n event_id: event.event_id || hint.event_id || uuid4(),\n timestamp: event.timestamp || dateTimestampInSeconds(),\n };\n const integrations = hint.integrations || options.integrations.map(i => i.name);\n\n applyClientOptions(prepared, options);\n applyIntegrationsMetadata(prepared, integrations);\n\n // Only put debug IDs onto frames for error events.\n if (event.type === undefined) {\n applyDebugIds(prepared, options.stackParser);\n }\n\n // If we have scope given to us, use it as the base for further modifications.\n // This allows us to prevent unnecessary copying of data if `captureContext` is not provided.\n let finalScope = scope;\n if (hint.captureContext) {\n finalScope = Scope.clone(finalScope).update(hint.captureContext);\n }\n\n // We prepare the result here with a resolved Event.\n let result = resolvedSyncPromise<Event | null>(prepared);\n\n // This should be the last thing called, since we want that\n // {@link Hub.addEventProcessor} gets the finished prepared event.\n //\n // We need to check for the existence of `finalScope.getAttachments`\n // because `getAttachments` can be undefined if users are using an older version\n // of `@sentry/core` that does not have the `getAttachments` method.\n // See: https://github.com/getsentry/sentry-javascript/issues/5229\n if (finalScope) {\n // Collect attachments from the hint and scope\n if (finalScope.getAttachments) {\n const attachments = [...(hint.attachments || []), ...finalScope.getAttachments()];\n\n if (attachments.length) {\n hint.attachments = attachments;\n }\n }\n\n // In case we have a hub we reassign it.\n result = finalScope.applyToEvent(prepared, hint);\n }\n\n return result.then(evt => {\n if (evt) {\n // We apply the debug_meta field only after all event processors have ran, so that if any event processors modified\n // file names (e.g.the RewriteFrames integration) the filename -> debug ID relationship isn't destroyed.\n // This should not cause any PII issues, since we're only moving data that is already on the event and not adding\n // any new data\n applyDebugMeta(evt);\n }\n\n if (typeof normalizeDepth === 'number' && normalizeDepth > 0) {\n return normalizeEvent(evt, normalizeDepth, normalizeMaxBreadth);\n }\n return evt;\n });\n}\n\n/**\n * Enhances event using the client configuration.\n * It takes care of all \"static\" values like environment, release and `dist`,\n * as well as truncating overly long values.\n * @param event event instance to be enhanced\n */\nfunction applyClientOptions(event: Event, options: ClientOptions): void {\n const { environment, release, dist, maxValueLength = 250 } = options;\n\n if (!('environment' in event)) {\n event.environment = 'environment' in options ? environment : DEFAULT_ENVIRONMENT;\n }\n\n if (event.release === undefined && release !== undefined) {\n event.release = release;\n }\n\n if (event.dist === undefined && dist !== undefined) {\n event.dist = dist;\n }\n\n if (event.message) {\n event.message = truncate(event.message, maxValueLength);\n }\n\n const exception = event.exception && event.exception.values && event.exception.values[0];\n if (exception && exception.value) {\n exception.value = truncate(exception.value, maxValueLength);\n }\n\n const request = event.request;\n if (request && request.url) {\n request.url = truncate(request.url, maxValueLength);\n }\n}\n\nconst debugIdStackParserCache = new WeakMap<StackParser, Map<string, StackFrame[]>>();\n\n/**\n * Puts debug IDs into the stack frames of an error event.\n */\nexport function applyDebugIds(event: Event, stackParser: StackParser): void {\n const debugIdMap = GLOBAL_OBJ._sentryDebugIds;\n\n if (!debugIdMap) {\n return;\n }\n\n let debugIdStackFramesCache: Map<string, StackFrame[]>;\n const cachedDebugIdStackFrameCache = debugIdStackParserCache.get(stackParser);\n if (cachedDebugIdStackFrameCache) {\n debugIdStackFramesCache = cachedDebugIdStackFrameCache;\n } else {\n debugIdStackFramesCache = new Map<string, StackFrame[]>();\n debugIdStackParserCache.set(stackParser, debugIdStackFramesCache);\n }\n\n // Build a map of filename -> debug_id\n const filenameDebugIdMap = Object.keys(debugIdMap).reduce<Record<string, string>>((acc, debugIdStackTrace) => {\n let parsedStack: StackFrame[];\n const cachedParsedStack = debugIdStackFramesCache.get(debugIdStackTrace);\n if (cachedParsedStack) {\n parsedStack = cachedParsedStack;\n } else {\n parsedStack = stackParser(debugIdStackTrace);\n debugIdStackFramesCache.set(debugIdStackTrace, parsedStack);\n }\n\n for (let i = parsedStack.length - 1; i >= 0; i--) {\n const stackFrame = parsedStack[i];\n if (stackFrame.filename) {\n acc[stackFrame.filename] = debugIdMap[debugIdStackTrace];\n break;\n }\n }\n return acc;\n }, {});\n\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n event!.exception!.values!.forEach(exception => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n exception.stacktrace!.frames!.forEach(frame => {\n if (frame.filename) {\n frame.debug_id = filenameDebugIdMap[frame.filename];\n }\n });\n });\n } catch (e) {\n // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n }\n}\n\n/**\n * Moves debug IDs from the stack frames of an error event into the debug_meta field.\n */\nexport function applyDebugMeta(event: Event): void {\n // Extract debug IDs and filenames from the stack frames on the event.\n const filenameDebugIdMap: Record<string, string> = {};\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n event.exception!.values!.forEach(exception => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n exception.stacktrace!.frames!.forEach(frame => {\n if (frame.debug_id) {\n if (frame.abs_path) {\n filenameDebugIdMap[frame.abs_path] = frame.debug_id;\n } else if (frame.filename) {\n filenameDebugIdMap[frame.filename] = frame.debug_id;\n }\n delete frame.debug_id;\n }\n });\n });\n } catch (e) {\n // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n }\n\n if (Object.keys(filenameDebugIdMap).length === 0) {\n return;\n }\n\n // Fill debug_meta information\n event.debug_meta = event.debug_meta || {};\n event.debug_meta.images = event.debug_meta.images || [];\n const images = event.debug_meta.images;\n Object.keys(filenameDebugIdMap).forEach(filename => {\n images.push({\n type: 'sourcemap',\n code_file: filename,\n debug_id: filenameDebugIdMap[filename],\n });\n });\n}\n\n/**\n * This function adds all used integrations to the SDK info in the event.\n * @param event The event that will be filled with all integrations.\n */\nfunction applyIntegrationsMetadata(event: Event, integrationNames: string[]): void {\n if (integrationNames.length > 0) {\n event.sdk = event.sdk || {};\n event.sdk.integrations = [...(event.sdk.integrations || []), ...integrationNames];\n }\n}\n\n/**\n * Applies `normalize` function on necessary `Event` attributes to make them safe for serialization.\n * Normalized keys:\n * - `breadcrumbs.data`\n * - `user`\n * - `contexts`\n * - `extra`\n * @param event Event\n * @returns Normalized event\n */\nfunction normalizeEvent(event: Event | null, depth: number, maxBreadth: number): Event | null {\n if (!event) {\n return null;\n }\n\n const normalized: Event = {\n ...event,\n ...(event.breadcrumbs && {\n breadcrumbs: event.breadcrumbs.map(b => ({\n ...b,\n ...(b.data && {\n data: normalize(b.data, depth, maxBreadth),\n }),\n })),\n }),\n ...(event.user && {\n user: normalize(event.user, depth, maxBreadth),\n }),\n ...(event.contexts && {\n contexts: normalize(event.contexts, depth, maxBreadth),\n }),\n ...(event.extra && {\n extra: normalize(event.extra, depth, maxBreadth),\n }),\n };\n\n // event.contexts.trace stores information about a Transaction. Similarly,\n // event.spans[] stores information about child Spans. Given that a\n // Transaction is conceptually a Span, normalization should apply to both\n // Transactions and Spans consistently.\n // For now the decision is to skip normalization of Transactions and Spans,\n // so this block overwrites the normalized event to add back the original\n // Transaction information prior to normalization.\n if (event.contexts && event.contexts.trace && normalized.contexts) {\n normalized.contexts.trace = event.contexts.trace;\n\n // event.contexts.trace.data may contain circular/dangerous data so we need to normalize it\n if (event.contexts.trace.data) {\n normalized.contexts.trace.data = normalize(event.contexts.trace.data, depth, maxBreadth);\n }\n }\n\n // event.spans[].data may contain circular/dangerous data so we need to normalize it\n if (event.spans) {\n normalized.spans = event.spans.map(span => {\n // We cannot use the spread operator here because `toJSON` on `span` is non-enumerable\n if (span.data) {\n span.data = normalize(span.data, depth, maxBreadth);\n }\n return span;\n });\n }\n\n return normalized;\n}\n","/* eslint-disable max-lines */\nimport type {\n Breadcrumb,\n BreadcrumbHint,\n Client,\n ClientOptions,\n DataCategory,\n DsnComponents,\n DynamicSamplingContext,\n Envelope,\n ErrorEvent,\n Event,\n EventDropReason,\n EventHint,\n Integration,\n IntegrationClass,\n Outcome,\n PropagationContext,\n SdkMetadata,\n Session,\n SessionAggregates,\n Severity,\n SeverityLevel,\n Transaction,\n TransactionEvent,\n Transport,\n TransportMakeRequestResponse,\n} from '@sentry/types';\nimport {\n addItemToEnvelope,\n checkOrSetAlreadyCaught,\n createAttachmentEnvelopeItem,\n isPlainObject,\n isPrimitive,\n isThenable,\n logger,\n makeDsn,\n rejectedSyncPromise,\n resolvedSyncPromise,\n SentryError,\n SyncPromise,\n} from '@sentry/utils';\n\nimport { getEnvelopeEndpointWithUrlEncodedAuth } from './api';\nimport { createEventEnvelope, createSessionEnvelope } from './envelope';\nimport type { IntegrationIndex } from './integration';\nimport { setupIntegration, setupIntegrations } from './integration';\nimport type { Scope } from './scope';\nimport { updateSession } from './session';\nimport { getDynamicSamplingContextFromClient } from './tracing/dynamicSamplingContext';\nimport { prepareEvent } from './utils/prepareEvent';\n\nconst ALREADY_SEEN_ERROR = \"Not capturing exception because it's already been captured.\";\n\n/**\n * Base implementation for all JavaScript SDK clients.\n *\n * Call the constructor with the corresponding options\n * specific to the client subclass. To access these options later, use\n * {@link Client.getOptions}.\n *\n * If a Dsn is specified in the options, it will be parsed and stored. Use\n * {@link Client.getDsn} to retrieve the Dsn at any moment. In case the Dsn is\n * invalid, the constructor will throw a {@link SentryException}. Note that\n * without a valid Dsn, the SDK will not send any events to Sentry.\n *\n * Before sending an event, it is passed through\n * {@link BaseClient._prepareEvent} to add SDK information and scope data\n * (breadcrumbs and context). To add more custom information, override this\n * method and extend the resulting prepared event.\n *\n * To issue automatically created events (e.g. via instrumentation), use\n * {@link Client.captureEvent}. It will prepare the event and pass it through\n * the callback lifecycle. To issue auto-breadcrumbs, use\n * {@link Client.addBreadcrumb}.\n *\n * @example\n * class NodeClient extends BaseClient<NodeOptions> {\n * public constructor(options: NodeOptions) {\n * super(options);\n * }\n *\n * // ...\n * }\n */\nexport abstract class BaseClient<O extends ClientOptions> implements Client<O> {\n /** Options passed to the SDK. */\n protected readonly _options: O;\n\n /** The client Dsn, if specified in options. Without this Dsn, the SDK will be disabled. */\n protected readonly _dsn?: DsnComponents;\n\n protected readonly _transport?: Transport;\n\n /** Array of set up integrations. */\n protected _integrations: IntegrationIndex;\n\n /** Indicates whether this client's integrations have been set up. */\n protected _integrationsInitialized: boolean;\n\n /** Number of calls being processed */\n protected _numProcessing: number;\n\n /** Holds flushable */\n private _outcomes: { [key: string]: number };\n\n // eslint-disable-next-line @typescript-eslint/ban-types\n private _hooks: Record<string, Function[]>;\n\n /**\n * Initializes this client instance.\n *\n * @param options Options for the client.\n */\n protected constructor(options: O) {\n this._options = options;\n this._integrations = {};\n this._integrationsInitialized = false;\n this._numProcessing = 0;\n this._outcomes = {};\n this._hooks = {};\n\n if (options.dsn) {\n this._dsn = makeDsn(options.dsn);\n } else {\n __DEBUG_BUILD__ && logger.warn('No DSN provided, client will not do anything.');\n }\n\n if (this._dsn) {\n const url = getEnvelopeEndpointWithUrlEncodedAuth(this._dsn, options);\n this._transport = options.transport({\n recordDroppedEvent: this.recordDroppedEvent.bind(this),\n ...options.transportOptions,\n url,\n });\n }\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public captureException(exception: any, hint?: EventHint, scope?: Scope): string | undefined {\n // ensure we haven't captured this very object before\n if (checkOrSetAlreadyCaught(exception)) {\n __DEBUG_BUILD__ && logger.log(ALREADY_SEEN_ERROR);\n return;\n }\n\n let eventId: string | undefined = hint && hint.event_id;\n\n this._process(\n this.eventFromException(exception, hint)\n .then(event => this._captureEvent(event, hint, scope))\n .then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level?: Severity | SeverityLevel,\n hint?: EventHint,\n scope?: Scope,\n ): string | undefined {\n let eventId: string | undefined = hint && hint.event_id;\n\n const promisedEvent = isPrimitive(message)\n ? this.eventFromMessage(String(message), level, hint)\n : this.eventFromException(message, hint);\n\n this._process(\n promisedEvent\n .then(event => this._captureEvent(event, hint, scope))\n .then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureEvent(event: Event, hint?: EventHint, scope?: Scope): string | undefined {\n // ensure we haven't captured this very object before\n if (hint && hint.originalException && checkOrSetAlreadyCaught(hint.originalException)) {\n __DEBUG_BUILD__ && logger.log(ALREADY_SEEN_ERROR);\n return;\n }\n\n let eventId: string | undefined = hint && hint.event_id;\n\n this._process(\n this._captureEvent(event, hint, scope).then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureSession(session: Session): void {\n if (!this._isEnabled()) {\n __DEBUG_BUILD__ && logger.warn('SDK not enabled, will not capture session.');\n return;\n }\n\n if (!(typeof session.release === 'string')) {\n __DEBUG_BUILD__ && logger.warn('Discarded session because of missing or non-string release');\n } else {\n this.sendSession(session);\n // After sending, we set init false to indicate it's not the first occurrence\n updateSession(session, { init: false });\n }\n }\n\n /**\n * @inheritDoc\n */\n public getDsn(): DsnComponents | undefined {\n return this._dsn;\n }\n\n /**\n * @inheritDoc\n */\n public getOptions(): O {\n return this._options;\n }\n\n /**\n * @see SdkMetadata in @sentry/types\n *\n * @return The metadata of the SDK\n */\n public getSdkMetadata(): SdkMetadata | undefined {\n return this._options._metadata;\n }\n\n /**\n * @inheritDoc\n */\n public getTransport(): Transport | undefined {\n return this._transport;\n }\n\n /**\n * @inheritDoc\n */\n public flush(timeout?: number): PromiseLike<boolean> {\n const transport = this._transport;\n if (transport) {\n return this._isClientDoneProcessing(timeout).then(clientFinished => {\n return transport.flush(timeout).then(transportFlushed => clientFinished && transportFlushed);\n });\n } else {\n return resolvedSyncPromise(true);\n }\n }\n\n /**\n * @inheritDoc\n */\n public close(timeout?: number): PromiseLike<boolean> {\n return this.flush(timeout).then(result => {\n this.getOptions().enabled = false;\n return result;\n });\n }\n\n /**\n * Sets up the integrations\n */\n public setupIntegrations(): void {\n if (this._isEnabled() && !this._integrationsInitialized) {\n this._integrations = setupIntegrations(this._options.integrations);\n this._integrationsInitialized = true;\n }\n }\n\n /**\n * Gets an installed integration by its `id`.\n *\n * @returns The installed integration or `undefined` if no integration with that `id` was installed.\n */\n public getIntegrationById(integrationId: string): Integration | undefined {\n return this._integrations[integrationId];\n }\n\n /**\n * @inheritDoc\n */\n public getIntegration<T extends Integration>(integration: IntegrationClass<T>): T | null {\n try {\n return (this._integrations[integration.id] as T) || null;\n } catch (_oO) {\n __DEBUG_BUILD__ && logger.warn(`Cannot retrieve integration ${integration.id} from the current Client`);\n return null;\n }\n }\n\n /**\n * @inheritDoc\n */\n public addIntegration(integration: Integration): void {\n setupIntegration(integration, this._integrations);\n }\n\n /**\n * @inheritDoc\n */\n public sendEvent(event: Event, hint: EventHint = {}): void {\n if (this._dsn) {\n let env = createEventEnvelope(event, this._dsn, this._options._metadata, this._options.tunnel);\n\n for (const attachment of hint.attachments || []) {\n env = addItemToEnvelope(\n env,\n createAttachmentEnvelopeItem(\n attachment,\n this._options.transportOptions && this._options.transportOptions.textEncoder,\n ),\n );\n }\n\n const promise = this._sendEnvelope(env);\n if (promise) {\n promise.then(sendResponse => this.emit('afterSendEvent', event, sendResponse), null);\n }\n }\n }\n\n /**\n * @inheritDoc\n */\n public sendSession(session: Session | SessionAggregates): void {\n if (this._dsn) {\n const env = createSessionEnvelope(session, this._dsn, this._options._metadata, this._options.tunnel);\n void this._sendEnvelope(env);\n }\n }\n\n /**\n * @inheritDoc\n */\n public recordDroppedEvent(reason: EventDropReason, category: DataCategory, _event?: Event): void {\n // Note: we use `event` in replay, where we overwrite this hook.\n\n if (this._options.sendClientReports) {\n // We want to track each category (error, transaction, session, replay_event) separately\n // but still keep the distinction between different type of outcomes.\n // We could use nested maps, but it's much easier to read and type this way.\n // A correct type for map-based implementation if we want to go that route\n // would be `Partial<Record<SentryRequestType, Partial<Record<Outcome, number>>>>`\n // With typescript 4.1 we could even use template literal types\n const key = `${reason}:${category}`;\n __DEBUG_BUILD__ && logger.log(`Adding outcome: \"${key}\"`);\n\n // The following works because undefined + 1 === NaN and NaN is falsy\n this._outcomes[key] = this._outcomes[key] + 1 || 1;\n }\n }\n\n // Keep on() & emit() signatures in sync with types' client.ts interface\n\n /** @inheritdoc */\n public on(hook: 'startTransaction' | 'finishTransaction', callback: (transaction: Transaction) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'beforeEnvelope', callback: (envelope: Envelope) => void): void;\n\n /** @inheritdoc */\n public on(\n hook: 'afterSendEvent',\n callback: (event: Event, sendResponse: TransportMakeRequestResponse | void) => void,\n ): void;\n\n /** @inheritdoc */\n public on(hook: 'beforeAddBreadcrumb', callback: (breadcrumb: Breadcrumb, hint?: BreadcrumbHint) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'createDsc', callback: (dsc: DynamicSamplingContext) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'otelSpanEnd', callback: (otelSpan: unknown, mutableOptions: { drop: boolean }) => void): void;\n\n /** @inheritdoc */\n public on(hook: string, callback: unknown): void {\n if (!this._hooks[hook]) {\n this._hooks[hook] = [];\n }\n\n // @ts-ignore We assue the types are correct\n this._hooks[hook].push(callback);\n }\n\n /** @inheritdoc */\n public emit(hook: 'startTransaction' | 'finishTransaction', transaction: Transaction): void;\n\n /** @inheritdoc */\n public emit(hook: 'beforeEnvelope', envelope: Envelope): void;\n\n /** @inheritdoc */\n public emit(hook: 'afterSendEvent', event: Event, sendResponse: TransportMakeRequestResponse | void): void;\n\n /** @inheritdoc */\n public emit(hook: 'beforeAddBreadcrumb', breadcrumb: Breadcrumb, hint?: BreadcrumbHint): void;\n\n /** @inheritdoc */\n public emit(hook: 'createDsc', dsc: DynamicSamplingContext): void;\n\n /** @inheritdoc */\n public emit(hook: 'otelSpanEnd', otelSpan: unknown, mutableOptions: { drop: boolean }): void;\n\n /** @inheritdoc */\n public emit(hook: string, ...rest: unknown[]): void {\n if (this._hooks[hook]) {\n // @ts-ignore we cannot enforce the callback to match the hook\n this._hooks[hook].forEach(callback => callback(...rest));\n }\n }\n\n /** Updates existing session based on the provided event */\n protected _updateSessionFromEvent(session: Session, event: Event): void {\n let crashed = false;\n let errored = false;\n const exceptions = event.exception && event.exception.values;\n\n if (exceptions) {\n errored = true;\n\n for (const ex of exceptions) {\n const mechanism = ex.mechanism;\n if (mechanism && mechanism.handled === false) {\n crashed = true;\n break;\n }\n }\n }\n\n // A session is updated and that session update is sent in only one of the two following scenarios:\n // 1. Session with non terminal status and 0 errors + an error occurred -> Will set error count to 1 and send update\n // 2. Session with non terminal status and 1 error + a crash occurred -> Will set status crashed and send update\n const sessionNonTerminal = session.status === 'ok';\n const shouldUpdateAndSend = (sessionNonTerminal && session.errors === 0) || (sessionNonTerminal && crashed);\n\n if (shouldUpdateAndSend) {\n updateSession(session, {\n ...(crashed && { status: 'crashed' }),\n errors: session.errors || Number(errored || crashed),\n });\n this.captureSession(session);\n }\n }\n\n /**\n * Determine if the client is finished processing. Returns a promise because it will wait `timeout` ms before saying\n * \"no\" (resolving to `false`) in order to give the client a chance to potentially finish first.\n *\n * @param timeout The time, in ms, after which to resolve to `false` if the client is still busy. Passing `0` (or not\n * passing anything) will make the promise wait as long as it takes for processing to finish before resolving to\n * `true`.\n * @returns A promise which will resolve to `true` if processing is already done or finishes before the timeout, and\n * `false` otherwise\n */\n protected _isClientDoneProcessing(timeout?: number): PromiseLike<boolean> {\n return new SyncPromise(resolve => {\n let ticked: number = 0;\n const tick: number = 1;\n\n const interval = setInterval(() => {\n if (this._numProcessing == 0) {\n clearInterval(interval);\n resolve(true);\n } else {\n ticked += tick;\n if (timeout && ticked >= timeout) {\n clearInterval(interval);\n resolve(false);\n }\n }\n }, tick);\n });\n }\n\n /** Determines whether this SDK is enabled and a valid Dsn is present. */\n protected _isEnabled(): boolean {\n return this.getOptions().enabled !== false && this._dsn !== undefined;\n }\n\n /**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n */\n protected _prepareEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event | null> {\n const options = this.getOptions();\n const integrations = Object.keys(this._integrations);\n if (!hint.integrations && integrations.length > 0) {\n hint.integrations = integrations;\n }\n return prepareEvent(options, event, hint, scope).then(evt => {\n if (evt === null) {\n return evt;\n }\n\n // If a trace context is not set on the event, we use the propagationContext set on the event to\n // generate a trace context. If the propagationContext does not have a dynamic sampling context, we\n // also generate one for it.\n const { propagationContext } = evt.sdkProcessingMetadata || {};\n const trace = evt.contexts && evt.contexts.trace;\n if (!trace && propagationContext) {\n const { traceId: trace_id, spanId, parentSpanId, dsc } = propagationContext as PropagationContext;\n evt.contexts = {\n trace: {\n trace_id,\n span_id: spanId,\n parent_span_id: parentSpanId,\n },\n ...evt.contexts,\n };\n\n const dynamicSamplingContext = dsc ? dsc : getDynamicSamplingContextFromClient(trace_id, this, scope);\n\n evt.sdkProcessingMetadata = {\n dynamicSamplingContext,\n ...evt.sdkProcessingMetadata,\n };\n }\n return evt;\n });\n }\n\n /**\n * Processes the event and logs an error in case of rejection\n * @param event\n * @param hint\n * @param scope\n */\n protected _captureEvent(event: Event, hint: EventHint = {}, scope?: Scope): PromiseLike<string | undefined> {\n return this._processEvent(event, hint, scope).then(\n finalEvent => {\n return finalEvent.event_id;\n },\n reason => {\n if (__DEBUG_BUILD__) {\n // If something's gone wrong, log the error as a warning. If it's just us having used a `SentryError` for\n // control flow, log just the message (no stack) as a log-level log.\n const sentryError = reason as SentryError;\n if (sentryError.logLevel === 'log') {\n logger.log(sentryError.message);\n } else {\n logger.warn(sentryError);\n }\n }\n return undefined;\n },\n );\n }\n\n /**\n * Processes an event (either error or message) and sends it to Sentry.\n *\n * This also adds breadcrumbs and context information to the event. However,\n * platform specific meta data (such as the User's IP address) must be added\n * by the SDK implementor.\n *\n *\n * @param event The event to send to Sentry.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A SyncPromise that resolves with the event or rejects in case event was/will not be send.\n */\n protected _processEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event> {\n const options = this.getOptions();\n const { sampleRate } = options;\n\n if (!this._isEnabled()) {\n return rejectedSyncPromise(new SentryError('SDK not enabled, will not capture event.', 'log'));\n }\n\n const isTransaction = isTransactionEvent(event);\n const isError = isErrorEvent(event);\n const eventType = event.type || 'error';\n const beforeSendLabel = `before send for type \\`${eventType}\\``;\n\n // 1.0 === 100% events are sent\n // 0.0 === 0% events are sent\n // Sampling for transaction happens somewhere else\n if (isError && typeof sampleRate === 'number' && Math.random() > sampleRate) {\n this.recordDroppedEvent('sample_rate', 'error', event);\n return rejectedSyncPromise(\n new SentryError(\n `Discarding event because it's not included in the random sample (sampling rate = ${sampleRate})`,\n 'log',\n ),\n );\n }\n\n const dataCategory: DataCategory = eventType === 'replay_event' ? 'replay' : eventType;\n\n return this._prepareEvent(event, hint, scope)\n .then(prepared => {\n if (prepared === null) {\n this.recordDroppedEvent('event_processor', dataCategory, event);\n throw new SentryError('An event processor returned `null`, will not send event.', 'log');\n }\n\n const isInternalException = hint.data && (hint.data as { __sentry__: boolean }).__sentry__ === true;\n if (isInternalException) {\n return prepared;\n }\n\n const result = processBeforeSend(options, prepared, hint);\n return _validateBeforeSendResult(result, beforeSendLabel);\n })\n .then(processedEvent => {\n if (processedEvent === null) {\n this.recordDroppedEvent('before_send', dataCategory, event);\n throw new SentryError(`${beforeSendLabel} returned \\`null\\`, will not send event.`, 'log');\n }\n\n const session = scope && scope.getSession();\n if (!isTransaction && session) {\n this._updateSessionFromEvent(session, processedEvent);\n }\n\n // None of the Sentry built event processor will update transaction name,\n // so if the transaction name has been changed by an event processor, we know\n // it has to come from custom event processor added by a user\n const transactionInfo = processedEvent.transaction_info;\n if (isTransaction && transactionInfo && processedEvent.transaction !== event.transaction) {\n const source = 'custom';\n processedEvent.transaction_info = {\n ...transactionInfo,\n source,\n };\n }\n\n this.sendEvent(processedEvent, hint);\n return processedEvent;\n })\n .then(null, reason => {\n if (reason instanceof SentryError) {\n throw reason;\n }\n\n this.captureException(reason, {\n data: {\n __sentry__: true,\n },\n originalException: reason,\n });\n throw new SentryError(\n `Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\\nReason: ${reason}`,\n );\n });\n }\n\n /**\n * Occupies the client with processing and event\n */\n protected _process<T>(promise: PromiseLike<T>): void {\n this._numProcessing++;\n void promise.then(\n value => {\n this._numProcessing--;\n return value;\n },\n reason => {\n this._numProcessing--;\n return reason;\n },\n );\n }\n\n /**\n * @inheritdoc\n */\n protected _sendEnvelope(envelope: Envelope): PromiseLike<void | TransportMakeRequestResponse> | void {\n if (this._transport && this._dsn) {\n this.emit('beforeEnvelope', envelope);\n\n return this._transport.send(envelope).then(null, reason => {\n __DEBUG_BUILD__ && logger.error('Error while sending event:', reason);\n });\n } else {\n __DEBUG_BUILD__ && logger.error('Transport disabled');\n }\n }\n\n /**\n * Clears outcomes on this client and returns them.\n */\n protected _clearOutcomes(): Outcome[] {\n const outcomes = this._outcomes;\n this._outcomes = {};\n return Object.keys(outcomes).map(key => {\n const [reason, category] = key.split(':') as [EventDropReason, DataCategory];\n return {\n reason,\n category,\n quantity: outcomes[key],\n };\n });\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public abstract eventFromException(_exception: any, _hint?: EventHint): PromiseLike<Event>;\n\n /**\n * @inheritDoc\n */\n public abstract eventFromMessage(\n _message: string,\n // eslint-disable-next-line deprecation/deprecation\n _level?: Severity | SeverityLevel,\n _hint?: EventHint,\n ): PromiseLike<Event>;\n}\n\n/**\n * Verifies that return value of configured `beforeSend` or `beforeSendTransaction` is of expected type, and returns the value if so.\n */\nfunction _validateBeforeSendResult(\n beforeSendResult: PromiseLike<Event | null> | Event | null,\n beforeSendLabel: string,\n): PromiseLike<Event | null> | Event | null {\n const invalidValueError = `${beforeSendLabel} must return \\`null\\` or a valid event.`;\n if (isThenable(beforeSendResult)) {\n return beforeSendResult.then(\n event => {\n if (!isPlainObject(event) && event !== null) {\n throw new SentryError(invalidValueError);\n }\n return event;\n },\n e => {\n throw new SentryError(`${beforeSendLabel} rejected with ${e}`);\n },\n );\n } else if (!isPlainObject(beforeSendResult) && beforeSendResult !== null) {\n throw new SentryError(invalidValueError);\n }\n return beforeSendResult;\n}\n\n/**\n * Process the matching `beforeSendXXX` callback.\n */\nfunction processBeforeSend(\n options: ClientOptions,\n event: Event,\n hint: EventHint,\n): PromiseLike<Event | null> | Event | null {\n const { beforeSend, beforeSendTransaction } = options;\n\n if (isErrorEvent(event) && beforeSend) {\n return beforeSend(event, hint);\n }\n\n if (isTransactionEvent(event) && beforeSendTransaction) {\n return beforeSendTransaction(event, hint);\n }\n\n return event;\n}\n\nfunction isErrorEvent(event: Event): event is ErrorEvent {\n return event.type === undefined;\n}\n\nfunction isTransactionEvent(event: Event): event is TransactionEvent {\n return event.type === 'transaction';\n}\n","import { getCurrentHub } from '@sentry/core';\nimport type { Event, EventHint, Exception, Severity, SeverityLevel, StackFrame, StackParser } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addExceptionTypeValue,\n extractExceptionKeysForMessage,\n isDOMError,\n isDOMException,\n isError,\n isErrorEvent,\n isEvent,\n isPlainObject,\n normalizeToSize,\n resolvedSyncPromise,\n} from '@sentry/utils';\n\ntype Prototype = { constructor: (...args: unknown[]) => unknown };\n\n/**\n * This function creates an exception from a JavaScript Error\n */\nexport function exceptionFromError(stackParser: StackParser, ex: Error): Exception {\n // Get the frames first since Opera can lose the stack if we touch anything else first\n const frames = parseStackFrames(stackParser, ex);\n\n const exception: Exception = {\n type: ex && ex.name,\n value: extractMessage(ex),\n };\n\n if (frames.length) {\n exception.stacktrace = { frames };\n }\n\n if (exception.type === undefined && exception.value === '') {\n exception.value = 'Unrecoverable error caught';\n }\n\n return exception;\n}\n\n/**\n * @hidden\n */\nexport function eventFromPlainObject(\n stackParser: StackParser,\n exception: Record<string, unknown>,\n syntheticException?: Error,\n isUnhandledRejection?: boolean,\n): Event {\n const hub = getCurrentHub();\n const client = hub.getClient();\n const normalizeDepth = client && client.getOptions().normalizeDepth;\n\n const event: Event = {\n exception: {\n values: [\n {\n type: isEvent(exception) ? exception.constructor.name : isUnhandledRejection ? 'UnhandledRejection' : 'Error',\n value: getNonErrorObjectExceptionValue(exception, { isUnhandledRejection }),\n },\n ],\n },\n extra: {\n __serialized__: normalizeToSize(exception, normalizeDepth),\n },\n };\n\n if (syntheticException) {\n const frames = parseStackFrames(stackParser, syntheticException);\n if (frames.length) {\n // event.exception.values[0] has been set above\n (event.exception as { values: Exception[] }).values[0].stacktrace = { frames };\n }\n }\n\n return event;\n}\n\n/**\n * @hidden\n */\nexport function eventFromError(stackParser: StackParser, ex: Error): Event {\n return {\n exception: {\n values: [exceptionFromError(stackParser, ex)],\n },\n };\n}\n\n/** Parses stack frames from an error */\nexport function parseStackFrames(\n stackParser: StackParser,\n ex: Error & { framesToPop?: number; stacktrace?: string },\n): StackFrame[] {\n // Access and store the stacktrace property before doing ANYTHING\n // else to it because Opera is not very good at providing it\n // reliably in other circumstances.\n const stacktrace = ex.stacktrace || ex.stack || '';\n\n const popSize = getPopSize(ex);\n\n try {\n return stackParser(stacktrace, popSize);\n } catch (e) {\n // no-empty\n }\n\n return [];\n}\n\n// Based on our own mapping pattern - https://github.com/getsentry/sentry/blob/9f08305e09866c8bd6d0c24f5b0aabdd7dd6c59c/src/sentry/lang/javascript/errormapping.py#L83-L108\nconst reactMinifiedRegexp = /Minified React error #\\d+;/i;\n\nfunction getPopSize(ex: Error & { framesToPop?: number }): number {\n if (ex) {\n if (typeof ex.framesToPop === 'number') {\n return ex.framesToPop;\n }\n\n if (reactMinifiedRegexp.test(ex.message)) {\n return 1;\n }\n }\n\n return 0;\n}\n\n/**\n * There are cases where stacktrace.message is an Event object\n * https://github.com/getsentry/sentry-javascript/issues/1949\n * In this specific case we try to extract stacktrace.message.error.message\n */\nfunction extractMessage(ex: Error & { message: { error?: Error } }): string {\n const message = ex && ex.message;\n if (!message) {\n return 'No error message';\n }\n if (message.error && typeof message.error.message === 'string') {\n return message.error.message;\n }\n return message;\n}\n\n/**\n * Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`.\n * @hidden\n */\nexport function eventFromException(\n stackParser: StackParser,\n exception: unknown,\n hint?: EventHint,\n attachStacktrace?: boolean,\n): PromiseLike<Event> {\n const syntheticException = (hint && hint.syntheticException) || undefined;\n const event = eventFromUnknownInput(stackParser, exception, syntheticException, attachStacktrace);\n addExceptionMechanism(event); // defaults to { type: 'generic', handled: true }\n event.level = 'error';\n if (hint && hint.event_id) {\n event.event_id = hint.event_id;\n }\n return resolvedSyncPromise(event);\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nexport function eventFromMessage(\n stackParser: StackParser,\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel = 'info',\n hint?: EventHint,\n attachStacktrace?: boolean,\n): PromiseLike<Event> {\n const syntheticException = (hint && hint.syntheticException) || undefined;\n const event = eventFromString(stackParser, message, syntheticException, attachStacktrace);\n event.level = level;\n if (hint && hint.event_id) {\n event.event_id = hint.event_id;\n }\n return resolvedSyncPromise(event);\n}\n\n/**\n * @hidden\n */\nexport function eventFromUnknownInput(\n stackParser: StackParser,\n exception: unknown,\n syntheticException?: Error,\n attachStacktrace?: boolean,\n isUnhandledRejection?: boolean,\n): Event {\n let event: Event;\n\n if (isErrorEvent(exception as ErrorEvent) && (exception as ErrorEvent).error) {\n // If it is an ErrorEvent with `error` property, extract it to get actual Error\n const errorEvent = exception as ErrorEvent;\n return eventFromError(stackParser, errorEvent.error as Error);\n }\n\n // If it is a `DOMError` (which is a legacy API, but still supported in some browsers) then we just extract the name\n // and message, as it doesn't provide anything else. According to the spec, all `DOMExceptions` should also be\n // `Error`s, but that's not the case in IE11, so in that case we treat it the same as we do a `DOMError`.\n //\n // https://developer.mozilla.org/en-US/docs/Web/API/DOMError\n // https://developer.mozilla.org/en-US/docs/Web/API/DOMException\n // https://webidl.spec.whatwg.org/#es-DOMException-specialness\n if (isDOMError(exception) || isDOMException(exception as DOMException)) {\n const domException = exception as DOMException;\n\n if ('stack' in (exception as Error)) {\n event = eventFromError(stackParser, exception as Error);\n } else {\n const name = domException.name || (isDOMError(domException) ? 'DOMError' : 'DOMException');\n const message = domException.message ? `${name}: ${domException.message}` : name;\n event = eventFromString(stackParser, message, syntheticException, attachStacktrace);\n addExceptionTypeValue(event, message);\n }\n if ('code' in domException) {\n // eslint-disable-next-line deprecation/deprecation\n event.tags = { ...event.tags, 'DOMException.code': `${domException.code}` };\n }\n\n return event;\n }\n if (isError(exception)) {\n // we have a real Error object, do nothing\n return eventFromError(stackParser, exception);\n }\n if (isPlainObject(exception) || isEvent(exception)) {\n // If it's a plain object or an instance of `Event` (the built-in JS kind, not this SDK's `Event` type), serialize\n // it manually. This will allow us to group events based on top-level keys which is much better than creating a new\n // group on any key/value change.\n const objectException = exception as Record<string, unknown>;\n event = eventFromPlainObject(stackParser, objectException, syntheticException, isUnhandledRejection);\n addExceptionMechanism(event, {\n synthetic: true,\n });\n return event;\n }\n\n // If none of previous checks were valid, then it means that it's not:\n // - an instance of DOMError\n // - an instance of DOMException\n // - an instance of Event\n // - an instance of Error\n // - a valid ErrorEvent (one with an error property)\n // - a plain Object\n //\n // So bail out and capture it as a simple message:\n event = eventFromString(stackParser, exception as string, syntheticException, attachStacktrace);\n addExceptionTypeValue(event, `${exception}`, undefined);\n addExceptionMechanism(event, {\n synthetic: true,\n });\n\n return event;\n}\n\n/**\n * @hidden\n */\nexport function eventFromString(\n stackParser: StackParser,\n input: string,\n syntheticException?: Error,\n attachStacktrace?: boolean,\n): Event {\n const event: Event = {\n message: input,\n };\n\n if (attachStacktrace && syntheticException) {\n const frames = parseStackFrames(stackParser, syntheticException);\n if (frames.length) {\n event.exception = {\n values: [{ value: input, stacktrace: { frames } }],\n };\n }\n }\n\n return event;\n}\n\nfunction getNonErrorObjectExceptionValue(\n exception: Record<string, unknown>,\n { isUnhandledRejection }: { isUnhandledRejection?: boolean },\n): string {\n const keys = extractExceptionKeysForMessage(exception);\n const captureType = isUnhandledRejection ? 'promise rejection' : 'exception';\n\n // Some ErrorEvent instances do not have an `error` property, which is why they are not handled before\n // We still want to try to get a decent message for these cases\n if (isErrorEvent(exception)) {\n return `Event \\`ErrorEvent\\` captured as ${captureType} with message \\`${exception.message}\\``;\n }\n\n if (isEvent(exception)) {\n const className = getObjectClassName(exception);\n return `Event \\`${className}\\` (type=${exception.type}) captured as ${captureType}`;\n }\n\n return `Object captured as ${captureType} with keys: ${keys}`;\n}\n\nfunction getObjectClassName(obj: unknown): string | undefined | void {\n try {\n const prototype: Prototype | null = Object.getPrototypeOf(obj);\n return prototype ? prototype.constructor.name : undefined;\n } catch (e) {\n // ignore errors here\n }\n}\n","import type {\n Breadcrumb,\n CaptureContext,\n CheckIn,\n CustomSamplingContext,\n Event,\n EventHint,\n Extra,\n Extras,\n MonitorConfig,\n Primitive,\n Severity,\n SeverityLevel,\n TransactionContext,\n User,\n} from '@sentry/types';\nimport { logger, uuid4 } from '@sentry/utils';\n\nimport type { Hub } from './hub';\nimport { getCurrentHub } from './hub';\nimport type { Scope } from './scope';\n\n// Note: All functions in this file are typed with a return value of `ReturnType<Hub[HUB_FUNCTION]>`,\n// where HUB_FUNCTION is some method on the Hub class.\n//\n// This is done to make sure the top level SDK methods stay in sync with the hub methods.\n// Although every method here has an explicit return type, some of them (that map to void returns) do not\n// contain `return` keywords. This is done to save on bundle size, as `return` is not minifiable.\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception An exception-like object.\n * @param captureContext Additional scope data to apply to exception event.\n * @returns The generated eventId.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\nexport function captureException(exception: any, captureContext?: CaptureContext): ReturnType<Hub['captureException']> {\n return getCurrentHub().captureException(exception, { captureContext });\n}\n\n/**\n * Captures a message event and sends it to Sentry.\n *\n * @param message The message to send to Sentry.\n * @param Severity Define the level of the message.\n * @returns The generated eventId.\n */\nexport function captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n captureContext?: CaptureContext | Severity | SeverityLevel,\n): ReturnType<Hub['captureMessage']> {\n // This is necessary to provide explicit scopes upgrade, without changing the original\n // arity of the `captureMessage(message, level)` method.\n const level = typeof captureContext === 'string' ? captureContext : undefined;\n const context = typeof captureContext !== 'string' ? { captureContext } : undefined;\n return getCurrentHub().captureMessage(message, level, context);\n}\n\n/**\n * Captures a manually created event and sends it to Sentry.\n *\n * @param event The event to send to Sentry.\n * @returns The generated eventId.\n */\nexport function captureEvent(event: Event, hint?: EventHint): ReturnType<Hub['captureEvent']> {\n return getCurrentHub().captureEvent(event, hint);\n}\n\n/**\n * Callback to set context information onto the scope.\n * @param callback Callback function that receives Scope.\n */\nexport function configureScope(callback: (scope: Scope) => void): ReturnType<Hub['configureScope']> {\n getCurrentHub().configureScope(callback);\n}\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on\n * user's actions prior to an error or crash.\n *\n * @param breadcrumb The breadcrumb to record.\n */\nexport function addBreadcrumb(breadcrumb: Breadcrumb): ReturnType<Hub['addBreadcrumb']> {\n getCurrentHub().addBreadcrumb(breadcrumb);\n}\n\n/**\n * Sets context data with the given name.\n * @param name of the context\n * @param context Any kind of data. This data will be normalized.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function setContext(name: string, context: { [key: string]: any } | null): ReturnType<Hub['setContext']> {\n getCurrentHub().setContext(name, context);\n}\n\n/**\n * Set an object that will be merged sent as extra data with the event.\n * @param extras Extras object to merge into current context.\n */\nexport function setExtras(extras: Extras): ReturnType<Hub['setExtras']> {\n getCurrentHub().setExtras(extras);\n}\n\n/**\n * Set key:value that will be sent as extra data with the event.\n * @param key String of extra\n * @param extra Any kind of data. This data will be normalized.\n */\nexport function setExtra(key: string, extra: Extra): ReturnType<Hub['setExtra']> {\n getCurrentHub().setExtra(key, extra);\n}\n\n/**\n * Set an object that will be merged sent as tags data with the event.\n * @param tags Tags context object to merge into current context.\n */\nexport function setTags(tags: { [key: string]: Primitive }): ReturnType<Hub['setTags']> {\n getCurrentHub().setTags(tags);\n}\n\n/**\n * Set key:value that will be sent as tags data with the event.\n *\n * Can also be used to unset a tag, by passing `undefined`.\n *\n * @param key String key of tag\n * @param value Value of tag\n */\nexport function setTag(key: string, value: Primitive): ReturnType<Hub['setTag']> {\n getCurrentHub().setTag(key, value);\n}\n\n/**\n * Updates user context information for future events.\n *\n * @param user User context object to be set in the current context. Pass `null` to unset the user.\n */\nexport function setUser(user: User | null): ReturnType<Hub['setUser']> {\n getCurrentHub().setUser(user);\n}\n\n/**\n * Creates a new scope with and executes the given operation within.\n * The scope is automatically removed once the operation\n * finishes or throws.\n *\n * This is essentially a convenience function for:\n *\n * pushScope();\n * callback();\n * popScope();\n *\n * @param callback that will be enclosed into push/popScope.\n */\nexport function withScope(callback: (scope: Scope) => void): ReturnType<Hub['withScope']> {\n getCurrentHub().withScope(callback);\n}\n\n/**\n * Starts a new `Transaction` and returns it. This is the entry point to manual tracing instrumentation.\n *\n * A tree structure can be built by adding child spans to the transaction, and child spans to other spans. To start a\n * new child span within the transaction or any span, call the respective `.startChild()` method.\n *\n * Every child span must be finished before the transaction is finished, otherwise the unfinished spans are discarded.\n *\n * The transaction must be finished with a call to its `.finish()` method, at which point the transaction with all its\n * finished child spans will be sent to Sentry.\n *\n * NOTE: This function should only be used for *manual* instrumentation. Auto-instrumentation should call\n * `startTransaction` directly on the hub.\n *\n * @param context Properties of the new `Transaction`.\n * @param customSamplingContext Information given to the transaction sampling function (along with context-dependent\n * default values). See {@link Options.tracesSampler}.\n *\n * @returns The transaction which was just started\n */\nexport function startTransaction(\n context: TransactionContext,\n customSamplingContext?: CustomSamplingContext,\n): ReturnType<Hub['startTransaction']> {\n return getCurrentHub().startTransaction({ ...context }, customSamplingContext);\n}\n\n/**\n * Create a cron monitor check in and send it to Sentry.\n *\n * @param checkIn An object that describes a check in.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nexport function captureCheckIn(checkIn: CheckIn, upsertMonitorConfig?: MonitorConfig): string {\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const client = hub.getClient();\n if (!client) {\n __DEBUG_BUILD__ && logger.warn('Cannot capture check-in. No client defined.');\n } else if (!client.captureCheckIn) {\n __DEBUG_BUILD__ && logger.warn('Cannot capture check-in. Client does not support sending check-ins.');\n } else {\n return client.captureCheckIn(checkIn, upsertMonitorConfig, scope);\n }\n\n return uuid4();\n}\n\n/**\n * Call `flush()` on the current client, if there is one. See {@link Client.flush}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue. Omitting this parameter will cause\n * the client to wait until all events are sent before resolving the promise.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nexport async function flush(timeout?: number): Promise<boolean> {\n const client = getCurrentHub().getClient();\n if (client) {\n return client.flush(timeout);\n }\n __DEBUG_BUILD__ && logger.warn('Cannot flush events. No client defined.');\n return Promise.resolve(false);\n}\n\n/**\n * Call `close()` on the current client, if there is one. See {@link Client.close}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue before shutting down. Omitting this\n * parameter will cause the client to wait until all events are sent before disabling itself.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nexport async function close(timeout?: number): Promise<boolean> {\n const client = getCurrentHub().getClient();\n if (client) {\n return client.close(timeout);\n }\n __DEBUG_BUILD__ && logger.warn('Cannot flush events and disable SDK. No client defined.');\n return Promise.resolve(false);\n}\n\n/**\n * This is the getter for lastEventId.\n *\n * @returns The last event id of a captured event.\n */\nexport function lastEventId(): string | undefined {\n return getCurrentHub().lastEventId();\n}\n","import { captureException, withScope } from '@sentry/core';\nimport type { DsnLike, Event as SentryEvent, Mechanism, Scope, WrappedFunction } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addExceptionTypeValue,\n addNonEnumerableProperty,\n getOriginalFunction,\n GLOBAL_OBJ,\n markFunctionWrapped,\n} from '@sentry/utils';\n\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ & Window;\n\nlet ignoreOnError: number = 0;\n\n/**\n * @hidden\n */\nexport function shouldIgnoreOnError(): boolean {\n return ignoreOnError > 0;\n}\n\n/**\n * @hidden\n */\nexport function ignoreNextOnError(): void {\n // onerror should trigger before setTimeout\n ignoreOnError++;\n setTimeout(() => {\n ignoreOnError--;\n });\n}\n\n/**\n * Instruments the given function and sends an event to Sentry every time the\n * function throws an exception.\n *\n * @param fn A function to wrap. It is generally safe to pass an unbound function, because the returned wrapper always\n * has a correct `this` context.\n * @returns The wrapped function.\n * @hidden\n */\nexport function wrap(\n fn: WrappedFunction,\n options: {\n mechanism?: Mechanism;\n } = {},\n before?: WrappedFunction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): any {\n // for future readers what this does is wrap a function and then create\n // a bi-directional wrapping between them.\n //\n // example: wrapped = wrap(original);\n // original.__sentry_wrapped__ -> wrapped\n // wrapped.__sentry_original__ -> original\n\n if (typeof fn !== 'function') {\n return fn;\n }\n\n try {\n // if we're dealing with a function that was previously wrapped, return\n // the original wrapper.\n const wrapper = fn.__sentry_wrapped__;\n if (wrapper) {\n return wrapper;\n }\n\n // We don't wanna wrap it twice\n if (getOriginalFunction(fn)) {\n return fn;\n }\n } catch (e) {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n // Bail on wrapping and return the function as-is (defers to window.onerror).\n return fn;\n }\n\n /* eslint-disable prefer-rest-params */\n // It is important that `sentryWrapped` is not an arrow function to preserve the context of `this`\n const sentryWrapped: WrappedFunction = function (this: unknown): void {\n const args = Array.prototype.slice.call(arguments);\n\n try {\n if (before && typeof before === 'function') {\n before.apply(this, arguments);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n const wrappedArguments = args.map((arg: any) => wrap(arg, options));\n\n // Attempt to invoke user-land function\n // NOTE: If you are a Sentry user, and you are seeing this stack frame, it\n // means the sentry.javascript SDK caught an error invoking your application code. This\n // is expected behavior and NOT indicative of a bug with sentry.javascript.\n return fn.apply(this, wrappedArguments);\n } catch (ex) {\n ignoreNextOnError();\n\n withScope((scope: Scope) => {\n scope.addEventProcessor((event: SentryEvent) => {\n if (options.mechanism) {\n addExceptionTypeValue(event, undefined, undefined);\n addExceptionMechanism(event, options.mechanism);\n }\n\n event.extra = {\n ...event.extra,\n arguments: args,\n };\n\n return event;\n });\n\n captureException(ex);\n });\n\n throw ex;\n }\n };\n /* eslint-enable prefer-rest-params */\n\n // Accessing some objects may throw\n // ref: https://github.com/getsentry/sentry-javascript/issues/1168\n try {\n for (const property in fn) {\n if (Object.prototype.hasOwnProperty.call(fn, property)) {\n sentryWrapped[property] = fn[property];\n }\n }\n } catch (_oO) {} // eslint-disable-line no-empty\n\n // Signal that this function has been wrapped/filled already\n // for both debugging and to prevent it to being wrapped/filled twice\n markFunctionWrapped(sentryWrapped, fn);\n\n addNonEnumerableProperty(fn, '__sentry_wrapped__', sentryWrapped);\n\n // Restore original function name (not all browsers allow that)\n try {\n const descriptor = Object.getOwnPropertyDescriptor(sentryWrapped, 'name') as PropertyDescriptor;\n if (descriptor.configurable) {\n Object.defineProperty(sentryWrapped, 'name', {\n get(): string {\n return fn.name;\n },\n });\n }\n // eslint-disable-next-line no-empty\n } catch (_oO) {}\n\n return sentryWrapped;\n}\n\n/**\n * All properties the report dialog supports\n */\nexport interface ReportDialogOptions {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n eventId?: string;\n dsn?: DsnLike;\n user?: {\n email?: string;\n name?: string;\n };\n lang?: string;\n title?: string;\n subtitle?: string;\n subtitle2?: string;\n labelName?: string;\n labelEmail?: string;\n labelComments?: string;\n labelClose?: string;\n labelSubmit?: string;\n errorGeneric?: string;\n errorFormEntry?: string;\n successMessage?: string;\n /** Callback after reportDialog showed up */\n onLoad?(this: void): void;\n}\n","/* eslint-disable deprecation/deprecation */\nimport type { Severity, SeverityLevel } from '@sentry/types';\n\n// Note: Ideally the `SeverityLevel` type would be derived from `validSeverityLevels`, but that would mean either\n//\n// a) moving `validSeverityLevels` to `@sentry/types`,\n// b) moving the`SeverityLevel` type here, or\n// c) importing `validSeverityLevels` from here into `@sentry/types`.\n//\n// Option A would make `@sentry/types` a runtime dependency of `@sentry/utils` (not good), and options B and C would\n// create a circular dependency between `@sentry/types` and `@sentry/utils` (also not good). So a TODO accompanying the\n// type, reminding anyone who changes it to change this list also, will have to do.\n\nexport const validSeverityLevels = ['fatal', 'error', 'warning', 'log', 'info', 'debug'];\n\n/**\n * Converts a string-based level into a member of the deprecated {@link Severity} enum.\n *\n * @deprecated `severityFromString` is deprecated. Please use `severityLevelFromString` instead.\n *\n * @param level String representation of Severity\n * @returns Severity\n */\nexport function severityFromString(level: Severity | SeverityLevel | string): Severity {\n return severityLevelFromString(level) as Severity;\n}\n\n/**\n * Converts a string-based level into a `SeverityLevel`, normalizing it along the way.\n *\n * @param level String representation of desired `SeverityLevel`.\n * @returns The `SeverityLevel` corresponding to the given string, or 'log' if the string isn't a valid level.\n */\nexport function severityLevelFromString(level: SeverityLevel | string): SeverityLevel {\n return (level === 'warn' ? 'warning' : validSeverityLevels.includes(level) ? level : 'log') as SeverityLevel;\n}\n","type PartialURL = {\n host?: string;\n path?: string;\n protocol?: string;\n relative?: string;\n search?: string;\n hash?: string;\n};\n\n/**\n * Parses string form of URL into an object\n * // borrowed from https://tools.ietf.org/html/rfc3986#appendix-B\n * // intentionally using regex and not <a/> href parsing trick because React Native and other\n * // environments where DOM might not be available\n * @returns parsed URL object\n */\nexport function parseUrl(url: string): PartialURL {\n if (!url) {\n return {};\n }\n\n const match = url.match(/^(([^:/?#]+):)?(\\/\\/([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?$/);\n\n if (!match) {\n return {};\n }\n\n // coerce to undefined values to empty string so we don't get 'undefined'\n const query = match[6] || '';\n const fragment = match[8] || '';\n return {\n host: match[4],\n path: match[5],\n protocol: match[2],\n search: query,\n hash: fragment,\n relative: match[5] + query + fragment, // everything minus origin\n };\n}\n\n/**\n * Strip the query string and fragment off of a given URL or path (if present)\n *\n * @param urlPath Full URL or path, including possible query string and/or fragment\n * @returns URL or path without query string or fragment\n */\nexport function stripUrlQueryAndFragment(urlPath: string): string {\n // eslint-disable-next-line no-useless-escape\n return urlPath.split(/[\\?#]/, 1)[0];\n}\n\n/**\n * Returns number of URL segments of a passed string URL.\n */\nexport function getNumberOfUrlSegments(url: string): number {\n // split at '/' or at '\\/' to split regex urls correctly\n return url.split(/\\\\?\\//).filter(s => s.length > 0 && s !== ',').length;\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span description\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nexport function getSanitizedUrlString(url: PartialURL): string {\n const { protocol, host, path } = url;\n\n const filteredHost =\n (host &&\n host\n // Always filter out authority\n .replace(/^.*@/, '[filtered]:[filtered]@')\n // Don't show standard :80 (http) and :443 (https) ports to reduce the noise\n .replace(':80', '')\n .replace(':443', '')) ||\n '';\n\n return `${protocol ? `${protocol}://` : ''}${filteredHost}${path}`;\n}\n","/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable max-lines */\nimport { getCurrentHub } from '@sentry/core';\nimport type { Event as SentryEvent, HandlerDataFetch, HandlerDataXhr, Integration } from '@sentry/types';\nimport type {\n FetchBreadcrumbData,\n FetchBreadcrumbHint,\n XhrBreadcrumbData,\n XhrBreadcrumbHint,\n} from '@sentry/types/build/types/breadcrumb';\nimport {\n addInstrumentationHandler,\n getEventDescription,\n htmlTreeAsString,\n logger,\n parseUrl,\n safeJoin,\n SENTRY_XHR_DATA_KEY,\n severityLevelFromString,\n} from '@sentry/utils';\n\nimport { WINDOW } from '../helpers';\n\ntype HandlerData = Record<string, unknown>;\n\n/** JSDoc */\ninterface BreadcrumbsOptions {\n console: boolean;\n dom:\n | boolean\n | {\n serializeAttribute?: string | string[];\n maxStringLength?: number;\n };\n fetch: boolean;\n history: boolean;\n sentry: boolean;\n xhr: boolean;\n}\n\n/** maxStringLength gets capped to prevent 100 breadcrumbs exceeding 1MB event payload size */\nconst MAX_ALLOWED_STRING_LENGTH = 1024;\n\nexport const BREADCRUMB_INTEGRATION_ID = 'Breadcrumbs';\n\n/**\n * Default Breadcrumbs instrumentations\n * TODO: Deprecated - with v6, this will be renamed to `Instrument`\n */\nexport class Breadcrumbs implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = BREADCRUMB_INTEGRATION_ID;\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /**\n * Options of the breadcrumbs integration.\n */\n // This field is public, because we use it in the browser client to check if the `sentry` option is enabled.\n public readonly options: Readonly<BreadcrumbsOptions>;\n\n /**\n * @inheritDoc\n */\n public constructor(options?: Partial<BreadcrumbsOptions>) {\n this.name = Breadcrumbs.id;\n this.options = {\n console: true,\n dom: true,\n fetch: true,\n history: true,\n sentry: true,\n xhr: true,\n ...options,\n };\n }\n\n /**\n * Instrument browser built-ins w/ breadcrumb capturing\n * - Console API\n * - DOM API (click/typing)\n * - XMLHttpRequest API\n * - Fetch API\n * - History API\n */\n public setupOnce(): void {\n if (this.options.console) {\n addInstrumentationHandler('console', _consoleBreadcrumb);\n }\n if (this.options.dom) {\n addInstrumentationHandler('dom', _domBreadcrumb(this.options.dom));\n }\n if (this.options.xhr) {\n addInstrumentationHandler('xhr', _xhrBreadcrumb);\n }\n if (this.options.fetch) {\n addInstrumentationHandler('fetch', _fetchBreadcrumb);\n }\n if (this.options.history) {\n addInstrumentationHandler('history', _historyBreadcrumb);\n }\n }\n\n /**\n * Adds a breadcrumb for Sentry events or transactions if this option is enabled.\n */\n public addSentryBreadcrumb(event: SentryEvent): void {\n if (this.options.sentry) {\n getCurrentHub().addBreadcrumb(\n {\n category: `sentry.${event.type === 'transaction' ? 'transaction' : 'event'}`,\n event_id: event.event_id,\n level: event.level,\n message: getEventDescription(event),\n },\n {\n event,\n },\n );\n }\n }\n}\n\n/**\n * A HOC that creaes a function that creates breadcrumbs from DOM API calls.\n * This is a HOC so that we get access to dom options in the closure.\n */\nfunction _domBreadcrumb(dom: BreadcrumbsOptions['dom']): (handlerData: HandlerData) => void {\n function _innerDomBreadcrumb(handlerData: HandlerData): void {\n let target;\n let keyAttrs = typeof dom === 'object' ? dom.serializeAttribute : undefined;\n\n let maxStringLength =\n typeof dom === 'object' && typeof dom.maxStringLength === 'number' ? dom.maxStringLength : undefined;\n if (maxStringLength && maxStringLength > MAX_ALLOWED_STRING_LENGTH) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `\\`dom.maxStringLength\\` cannot exceed ${MAX_ALLOWED_STRING_LENGTH}, but a value of ${maxStringLength} was configured. Sentry will use ${MAX_ALLOWED_STRING_LENGTH} instead.`,\n );\n maxStringLength = MAX_ALLOWED_STRING_LENGTH;\n }\n\n if (typeof keyAttrs === 'string') {\n keyAttrs = [keyAttrs];\n }\n\n // Accessing event.target can throw (see getsentry/raven-js#838, #768)\n try {\n const event = handlerData.event as Event | Node;\n target = _isEvent(event)\n ? htmlTreeAsString(event.target, { keyAttrs, maxStringLength })\n : htmlTreeAsString(event, { keyAttrs, maxStringLength });\n } catch (e) {\n target = '<unknown>';\n }\n\n if (target.length === 0) {\n return;\n }\n\n getCurrentHub().addBreadcrumb(\n {\n category: `ui.${handlerData.name}`,\n message: target,\n },\n {\n event: handlerData.event,\n name: handlerData.name,\n global: handlerData.global,\n },\n );\n }\n\n return _innerDomBreadcrumb;\n}\n\n/**\n * Creates breadcrumbs from console API calls\n */\nfunction _consoleBreadcrumb(handlerData: HandlerData & { args: unknown[]; level: string }): void {\n // This is a hack to fix a Vue3-specific bug that causes an infinite loop of\n // console warnings. This happens when a Vue template is rendered with\n // an undeclared variable, which we try to stringify, ultimately causing\n // Vue to issue another warning which repeats indefinitely.\n // see: https://github.com/getsentry/sentry-javascript/pull/6010\n // see: https://github.com/getsentry/sentry-javascript/issues/5916\n for (let i = 0; i < handlerData.args.length; i++) {\n if (handlerData.args[i] === 'ref=Ref<') {\n handlerData.args[i + 1] = 'viewRef';\n break;\n }\n }\n const breadcrumb = {\n category: 'console',\n data: {\n arguments: handlerData.args,\n logger: 'console',\n },\n level: severityLevelFromString(handlerData.level),\n message: safeJoin(handlerData.args, ' '),\n };\n\n if (handlerData.level === 'assert') {\n if (handlerData.args[0] === false) {\n breadcrumb.message = `Assertion failed: ${safeJoin(handlerData.args.slice(1), ' ') || 'console.assert'}`;\n breadcrumb.data.arguments = handlerData.args.slice(1);\n } else {\n // Don't capture a breadcrumb for passed assertions\n return;\n }\n }\n\n getCurrentHub().addBreadcrumb(breadcrumb, {\n input: handlerData.args,\n level: handlerData.level,\n });\n}\n\n/**\n * Creates breadcrumbs from XHR API calls\n */\nfunction _xhrBreadcrumb(handlerData: HandlerData & HandlerDataXhr): void {\n const { startTimestamp, endTimestamp } = handlerData;\n\n const sentryXhrData = handlerData.xhr[SENTRY_XHR_DATA_KEY];\n\n // We only capture complete, non-sentry requests\n if (!startTimestamp || !endTimestamp || !sentryXhrData) {\n return;\n }\n\n const { method, url, status_code, body } = sentryXhrData;\n\n const data: XhrBreadcrumbData = {\n method,\n url,\n status_code,\n };\n\n const hint: XhrBreadcrumbHint = {\n xhr: handlerData.xhr,\n input: body,\n startTimestamp,\n endTimestamp,\n };\n\n getCurrentHub().addBreadcrumb(\n {\n category: 'xhr',\n data,\n type: 'http',\n },\n hint,\n );\n}\n\n/**\n * Creates breadcrumbs from fetch API calls\n */\nfunction _fetchBreadcrumb(handlerData: HandlerData & HandlerDataFetch & { response?: Response }): void {\n const { startTimestamp, endTimestamp } = handlerData;\n\n // We only capture complete fetch requests\n if (!endTimestamp) {\n return;\n }\n\n if (handlerData.fetchData.url.match(/sentry_key/) && handlerData.fetchData.method === 'POST') {\n // We will not create breadcrumbs for fetch requests that contain `sentry_key` (internal sentry requests)\n return;\n }\n\n if (handlerData.error) {\n const data: FetchBreadcrumbData = handlerData.fetchData;\n const hint: FetchBreadcrumbHint = {\n data: handlerData.error,\n input: handlerData.args,\n startTimestamp,\n endTimestamp,\n };\n\n getCurrentHub().addBreadcrumb(\n {\n category: 'fetch',\n data,\n level: 'error',\n type: 'http',\n },\n hint,\n );\n } else {\n const data: FetchBreadcrumbData = {\n ...handlerData.fetchData,\n status_code: handlerData.response && handlerData.response.status,\n };\n const hint: FetchBreadcrumbHint = {\n input: handlerData.args,\n response: handlerData.response,\n startTimestamp,\n endTimestamp,\n };\n getCurrentHub().addBreadcrumb(\n {\n category: 'fetch',\n data,\n type: 'http',\n },\n hint,\n );\n }\n}\n\n/**\n * Creates breadcrumbs from history API calls\n */\nfunction _historyBreadcrumb(handlerData: HandlerData & { from: string; to: string }): void {\n let from: string | undefined = handlerData.from;\n let to: string | undefined = handlerData.to;\n const parsedLoc = parseUrl(WINDOW.location.href);\n let parsedFrom = parseUrl(from);\n const parsedTo = parseUrl(to);\n\n // Initial pushState doesn't provide `from` information\n if (!parsedFrom.path) {\n parsedFrom = parsedLoc;\n }\n\n // Use only the path component of the URL if the URL matches the current\n // document (almost all the time when using pushState)\n if (parsedLoc.protocol === parsedTo.protocol && parsedLoc.host === parsedTo.host) {\n to = parsedTo.relative;\n }\n if (parsedLoc.protocol === parsedFrom.protocol && parsedLoc.host === parsedFrom.host) {\n from = parsedFrom.relative;\n }\n\n getCurrentHub().addBreadcrumb({\n category: 'navigation',\n data: {\n from,\n to,\n },\n });\n}\n\nfunction _isEvent(event: unknown): event is Event {\n return !!event && !!(event as Record<string, unknown>).target;\n}\n","import type { Scope } from '@sentry/core';\nimport { BaseClient, SDK_VERSION } from '@sentry/core';\nimport type {\n BrowserClientProfilingOptions,\n BrowserClientReplayOptions,\n ClientOptions,\n Event,\n EventHint,\n Options,\n Severity,\n SeverityLevel,\n UserFeedback,\n} from '@sentry/types';\nimport { createClientReportEnvelope, dsnToString, getSDKSource, logger } from '@sentry/utils';\n\nimport { eventFromException, eventFromMessage } from './eventbuilder';\nimport { WINDOW } from './helpers';\nimport type { Breadcrumbs } from './integrations';\nimport { BREADCRUMB_INTEGRATION_ID } from './integrations/breadcrumbs';\nimport type { BrowserTransportOptions } from './transports/types';\nimport { createUserFeedbackEnvelope } from './userfeedback';\n\n/**\n * Configuration options for the Sentry Browser SDK.\n * @see @sentry/types Options for more information.\n */\nexport type BrowserOptions = Options<BrowserTransportOptions> &\n BrowserClientReplayOptions &\n BrowserClientProfilingOptions;\n\n/**\n * Configuration options for the Sentry Browser SDK Client class\n * @see BrowserClient for more information.\n */\nexport type BrowserClientOptions = ClientOptions<BrowserTransportOptions>;\n\n/**\n * The Sentry Browser SDK Client.\n *\n * @see BrowserOptions for documentation on configuration options.\n * @see SentryClient for usage documentation.\n */\nexport class BrowserClient extends BaseClient<BrowserClientOptions> {\n /**\n * Creates a new Browser SDK instance.\n *\n * @param options Configuration options for this SDK.\n */\n public constructor(options: BrowserClientOptions) {\n const sdkSource = WINDOW.SENTRY_SDK_SOURCE || getSDKSource();\n\n options._metadata = options._metadata || {};\n options._metadata.sdk = options._metadata.sdk || {\n name: 'sentry.javascript.browser',\n packages: [\n {\n name: `${sdkSource}:@sentry/browser`,\n version: SDK_VERSION,\n },\n ],\n version: SDK_VERSION,\n };\n\n super(options);\n\n if (options.sendClientReports && WINDOW.document) {\n WINDOW.document.addEventListener('visibilitychange', () => {\n if (WINDOW.document.visibilityState === 'hidden') {\n this._flushOutcomes();\n }\n });\n }\n }\n\n /**\n * @inheritDoc\n */\n public eventFromException(exception: unknown, hint?: EventHint): PromiseLike<Event> {\n return eventFromException(this._options.stackParser, exception, hint, this._options.attachStacktrace);\n }\n\n /**\n * @inheritDoc\n */\n public eventFromMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel = 'info',\n hint?: EventHint,\n ): PromiseLike<Event> {\n return eventFromMessage(this._options.stackParser, message, level, hint, this._options.attachStacktrace);\n }\n\n /**\n * @inheritDoc\n */\n public sendEvent(event: Event, hint?: EventHint): void {\n // We only want to add the sentry event breadcrumb when the user has the breadcrumb integration installed and\n // activated its `sentry` option.\n // We also do not want to use the `Breadcrumbs` class here directly, because we do not want it to be included in\n // bundles, if it is not used by the SDK.\n // This all sadly is a bit ugly, but we currently don't have a \"pre-send\" hook on the integrations so we do it this\n // way for now.\n const breadcrumbIntegration = this.getIntegrationById(BREADCRUMB_INTEGRATION_ID) as Breadcrumbs | undefined;\n // We check for definedness of `addSentryBreadcrumb` in case users provided their own integration with id\n // \"Breadcrumbs\" that does not have this function.\n if (breadcrumbIntegration && breadcrumbIntegration.addSentryBreadcrumb) {\n breadcrumbIntegration.addSentryBreadcrumb(event);\n }\n\n super.sendEvent(event, hint);\n }\n\n /**\n * Sends user feedback to Sentry.\n */\n public captureUserFeedback(feedback: UserFeedback): void {\n if (!this._isEnabled()) {\n __DEBUG_BUILD__ && logger.warn('SDK not enabled, will not capture user feedback.');\n return;\n }\n\n const envelope = createUserFeedbackEnvelope(feedback, {\n metadata: this.getSdkMetadata(),\n dsn: this.getDsn(),\n tunnel: this.getOptions().tunnel,\n });\n void this._sendEnvelope(envelope);\n }\n\n /**\n * @inheritDoc\n */\n protected _prepareEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event | null> {\n event.platform = event.platform || 'javascript';\n return super._prepareEvent(event, hint, scope);\n }\n\n /**\n * Sends client reports as an envelope.\n */\n private _flushOutcomes(): void {\n const outcomes = this._clearOutcomes();\n\n if (outcomes.length === 0) {\n __DEBUG_BUILD__ && logger.log('No outcomes to send');\n return;\n }\n\n if (!this._dsn) {\n __DEBUG_BUILD__ && logger.log('No dsn provided, will not send outcomes');\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('Sending outcomes:', outcomes);\n\n const envelope = createClientReportEnvelope(outcomes, this._options.tunnel && dsnToString(this._dsn));\n void this._sendEnvelope(envelope);\n }\n}\n","import type { DsnComponents, EventEnvelope, SdkMetadata, UserFeedback, UserFeedbackItem } from '@sentry/types';\nimport { createEnvelope, dsnToString } from '@sentry/utils';\n\n/**\n * Creates an envelope from a user feedback.\n */\nexport function createUserFeedbackEnvelope(\n feedback: UserFeedback,\n {\n metadata,\n tunnel,\n dsn,\n }: {\n metadata: SdkMetadata | undefined;\n tunnel: string | undefined;\n dsn: DsnComponents | undefined;\n },\n): EventEnvelope {\n const headers: EventEnvelope[0] = {\n event_id: feedback.event_id,\n sent_at: new Date().toISOString(),\n ...(metadata &&\n metadata.sdk && {\n sdk: {\n name: metadata.sdk.name,\n version: metadata.sdk.version,\n },\n }),\n ...(!!tunnel && !!dsn && { dsn: dsnToString(dsn) }),\n };\n const item = createUserFeedbackEnvelopeItem(feedback);\n\n return createEnvelope(headers, [item]);\n}\n\nfunction createUserFeedbackEnvelopeItem(feedback: UserFeedback): UserFeedbackItem {\n const feedbackHeaders: UserFeedbackItem[0] = {\n type: 'user_report',\n };\n return [feedbackHeaders, feedback];\n}\n","import type { ClientReport, ClientReportEnvelope, ClientReportItem } from '@sentry/types';\n\nimport { createEnvelope } from './envelope';\nimport { dateTimestampInSeconds } from './time';\n\n/**\n * Creates client report envelope\n * @param discarded_events An array of discard events\n * @param dsn A DSN that can be set on the header. Optional.\n */\nexport function createClientReportEnvelope(\n discarded_events: ClientReport['discarded_events'],\n dsn?: string,\n timestamp?: number,\n): ClientReportEnvelope {\n const clientReportItem: ClientReportItem = [\n { type: 'client_report' },\n {\n timestamp: timestamp || dateTimestampInSeconds(),\n discarded_events,\n },\n ];\n return createEnvelope<ClientReportEnvelope>(dsn ? { dsn } : {}, [clientReportItem]);\n}\n","/* eslint-disable @typescript-eslint/no-unsafe-member-access */\nimport { getCurrentHub } from '@sentry/core';\nimport type { Event, EventHint, Hub, Integration, Primitive, StackParser } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addInstrumentationHandler,\n getLocationHref,\n isErrorEvent,\n isPrimitive,\n isString,\n logger,\n} from '@sentry/utils';\n\nimport type { BrowserClient } from '../client';\nimport { eventFromUnknownInput } from '../eventbuilder';\nimport { shouldIgnoreOnError } from '../helpers';\n\ntype GlobalHandlersIntegrationsOptionKeys = 'onerror' | 'onunhandledrejection';\n\n/** JSDoc */\ntype GlobalHandlersIntegrations = Record<GlobalHandlersIntegrationsOptionKeys, boolean>;\n\n/** Global handlers */\nexport class GlobalHandlers implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'GlobalHandlers';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /** JSDoc */\n private readonly _options: GlobalHandlersIntegrations;\n\n /**\n * Stores references functions to installing handlers. Will set to undefined\n * after they have been run so that they are not used twice.\n */\n private _installFunc: Record<GlobalHandlersIntegrationsOptionKeys, (() => void) | undefined>;\n\n /** JSDoc */\n public constructor(options?: GlobalHandlersIntegrations) {\n this.name = GlobalHandlers.id;\n this._options = {\n onerror: true,\n onunhandledrejection: true,\n ...options,\n };\n\n this._installFunc = {\n onerror: _installGlobalOnErrorHandler,\n onunhandledrejection: _installGlobalOnUnhandledRejectionHandler,\n };\n }\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n Error.stackTraceLimit = 50;\n const options = this._options;\n\n // We can disable guard-for-in as we construct the options object above + do checks against\n // `this._installFunc` for the property.\n // eslint-disable-next-line guard-for-in\n for (const key in options) {\n const installFunc = this._installFunc[key as GlobalHandlersIntegrationsOptionKeys];\n if (installFunc && options[key as GlobalHandlersIntegrationsOptionKeys]) {\n globalHandlerLog(key);\n installFunc();\n this._installFunc[key as GlobalHandlersIntegrationsOptionKeys] = undefined;\n }\n }\n }\n}\n\n/** JSDoc */\nfunction _installGlobalOnErrorHandler(): void {\n addInstrumentationHandler(\n 'error',\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (data: { msg: any; url: any; line: any; column: any; error: any }) => {\n const [hub, stackParser, attachStacktrace] = getHubAndOptions();\n if (!hub.getIntegration(GlobalHandlers)) {\n return;\n }\n const { msg, url, line, column, error } = data;\n if (shouldIgnoreOnError() || (error && error.__sentry_own_request__)) {\n return;\n }\n\n const event =\n error === undefined && isString(msg)\n ? _eventFromIncompleteOnError(msg, url, line, column)\n : _enhanceEventWithInitialFrame(\n eventFromUnknownInput(stackParser, error || msg, undefined, attachStacktrace, false),\n url,\n line,\n column,\n );\n\n event.level = 'error';\n\n addMechanismAndCapture(hub, error, event, 'onerror');\n },\n );\n}\n\n/** JSDoc */\nfunction _installGlobalOnUnhandledRejectionHandler(): void {\n addInstrumentationHandler(\n 'unhandledrejection',\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (e: any) => {\n const [hub, stackParser, attachStacktrace] = getHubAndOptions();\n if (!hub.getIntegration(GlobalHandlers)) {\n return;\n }\n let error = e;\n\n // dig the object of the rejection out of known event types\n try {\n // PromiseRejectionEvents store the object of the rejection under 'reason'\n // see https://developer.mozilla.org/en-US/docs/Web/API/PromiseRejectionEvent\n if ('reason' in e) {\n error = e.reason;\n }\n // something, somewhere, (likely a browser extension) effectively casts PromiseRejectionEvents\n // to CustomEvents, moving the `promise` and `reason` attributes of the PRE into\n // the CustomEvent's `detail` attribute, since they're not part of CustomEvent's spec\n // see https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent and\n // https://github.com/getsentry/sentry-javascript/issues/2380\n else if ('detail' in e && 'reason' in e.detail) {\n error = e.detail.reason;\n }\n } catch (_oO) {\n // no-empty\n }\n\n if (shouldIgnoreOnError() || (error && error.__sentry_own_request__)) {\n return true;\n }\n\n const event = isPrimitive(error)\n ? _eventFromRejectionWithPrimitive(error)\n : eventFromUnknownInput(stackParser, error, undefined, attachStacktrace, true);\n\n event.level = 'error';\n\n addMechanismAndCapture(hub, error, event, 'onunhandledrejection');\n return;\n },\n );\n}\n\n/**\n * Create an event from a promise rejection where the `reason` is a primitive.\n *\n * @param reason: The `reason` property of the promise rejection\n * @returns An Event object with an appropriate `exception` value\n */\nfunction _eventFromRejectionWithPrimitive(reason: Primitive): Event {\n return {\n exception: {\n values: [\n {\n type: 'UnhandledRejection',\n // String() is needed because the Primitive type includes symbols (which can't be automatically stringified)\n value: `Non-Error promise rejection captured with value: ${String(reason)}`,\n },\n ],\n },\n };\n}\n\n/**\n * This function creates a stack from an old, error-less onerror handler.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _eventFromIncompleteOnError(msg: any, url: any, line: any, column: any): Event {\n const ERROR_TYPES_RE =\n /^(?:[Uu]ncaught (?:exception: )?)?(?:((?:Eval|Internal|Range|Reference|Syntax|Type|URI|)Error): )?(.*)$/i;\n\n // If 'message' is ErrorEvent, get real message from inside\n let message = isErrorEvent(msg) ? msg.message : msg;\n let name = 'Error';\n\n const groups = message.match(ERROR_TYPES_RE);\n if (groups) {\n name = groups[1];\n message = groups[2];\n }\n\n const event = {\n exception: {\n values: [\n {\n type: name,\n value: message,\n },\n ],\n },\n };\n\n return _enhanceEventWithInitialFrame(event, url, line, column);\n}\n\n/** JSDoc */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _enhanceEventWithInitialFrame(event: Event, url: any, line: any, column: any): Event {\n // event.exception\n const e = (event.exception = event.exception || {});\n // event.exception.values\n const ev = (e.values = e.values || []);\n // event.exception.values[0]\n const ev0 = (ev[0] = ev[0] || {});\n // event.exception.values[0].stacktrace\n const ev0s = (ev0.stacktrace = ev0.stacktrace || {});\n // event.exception.values[0].stacktrace.frames\n const ev0sf = (ev0s.frames = ev0s.frames || []);\n\n const colno = isNaN(parseInt(column, 10)) ? undefined : column;\n const lineno = isNaN(parseInt(line, 10)) ? undefined : line;\n const filename = isString(url) && url.length > 0 ? url : getLocationHref();\n\n // event.exception.values[0].stacktrace.frames\n if (ev0sf.length === 0) {\n ev0sf.push({\n colno,\n filename,\n function: '?',\n in_app: true,\n lineno,\n });\n }\n\n return event;\n}\n\nfunction globalHandlerLog(type: string): void {\n __DEBUG_BUILD__ && logger.log(`Global Handler attached: ${type}`);\n}\n\nfunction addMechanismAndCapture(hub: Hub, error: EventHint['originalException'], event: Event, type: string): void {\n addExceptionMechanism(event, {\n handled: false,\n type,\n });\n hub.captureEvent(event, {\n originalException: error,\n });\n}\n\nfunction getHubAndOptions(): [Hub, StackParser, boolean | undefined] {\n const hub = getCurrentHub();\n const client = hub.getClient<BrowserClient>();\n const options = (client && client.getOptions()) || {\n stackParser: () => [],\n attachStacktrace: false,\n };\n return [hub, options.stackParser, options.attachStacktrace];\n}\n","import type { Integration, WrappedFunction } from '@sentry/types';\nimport { fill, getFunctionName, getOriginalFunction } from '@sentry/utils';\n\nimport { WINDOW, wrap } from '../helpers';\n\nconst DEFAULT_EVENT_TARGET = [\n 'EventTarget',\n 'Window',\n 'Node',\n 'ApplicationCache',\n 'AudioTrackList',\n 'ChannelMergerNode',\n 'CryptoOperation',\n 'EventSource',\n 'FileReader',\n 'HTMLUnknownElement',\n 'IDBDatabase',\n 'IDBRequest',\n 'IDBTransaction',\n 'KeyOperation',\n 'MediaController',\n 'MessagePort',\n 'ModalWindow',\n 'Notification',\n 'SVGElementInstance',\n 'Screen',\n 'TextTrack',\n 'TextTrackCue',\n 'TextTrackList',\n 'WebSocket',\n 'WebSocketWorker',\n 'Worker',\n 'XMLHttpRequest',\n 'XMLHttpRequestEventTarget',\n 'XMLHttpRequestUpload',\n];\n\ntype XMLHttpRequestProp = 'onload' | 'onerror' | 'onprogress' | 'onreadystatechange';\n\n/** JSDoc */\ninterface TryCatchOptions {\n setTimeout: boolean;\n setInterval: boolean;\n requestAnimationFrame: boolean;\n XMLHttpRequest: boolean;\n eventTarget: boolean | string[];\n}\n\n/** Wrap timer functions and event targets to catch errors and provide better meta data */\nexport class TryCatch implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'TryCatch';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /** JSDoc */\n private readonly _options: TryCatchOptions;\n\n /**\n * @inheritDoc\n */\n public constructor(options?: Partial<TryCatchOptions>) {\n this.name = TryCatch.id;\n this._options = {\n XMLHttpRequest: true,\n eventTarget: true,\n requestAnimationFrame: true,\n setInterval: true,\n setTimeout: true,\n ...options,\n };\n }\n\n /**\n * Wrap timer functions and event targets to catch errors\n * and provide better metadata.\n */\n public setupOnce(): void {\n if (this._options.setTimeout) {\n fill(WINDOW, 'setTimeout', _wrapTimeFunction);\n }\n\n if (this._options.setInterval) {\n fill(WINDOW, 'setInterval', _wrapTimeFunction);\n }\n\n if (this._options.requestAnimationFrame) {\n fill(WINDOW, 'requestAnimationFrame', _wrapRAF);\n }\n\n if (this._options.XMLHttpRequest && 'XMLHttpRequest' in WINDOW) {\n fill(XMLHttpRequest.prototype, 'send', _wrapXHR);\n }\n\n const eventTargetOption = this._options.eventTarget;\n if (eventTargetOption) {\n const eventTarget = Array.isArray(eventTargetOption) ? eventTargetOption : DEFAULT_EVENT_TARGET;\n eventTarget.forEach(_wrapEventTarget);\n }\n }\n}\n\n/** JSDoc */\nfunction _wrapTimeFunction(original: () => void): () => number {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: any, ...args: any[]): number {\n const originalCallback = args[0];\n args[0] = wrap(originalCallback, {\n mechanism: {\n data: { function: getFunctionName(original) },\n handled: true,\n type: 'instrument',\n },\n });\n return original.apply(this, args);\n };\n}\n\n/** JSDoc */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _wrapRAF(original: any): (callback: () => void) => any {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: any, callback: () => void): () => void {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return original.apply(this, [\n wrap(callback, {\n mechanism: {\n data: {\n function: 'requestAnimationFrame',\n handler: getFunctionName(original),\n },\n handled: true,\n type: 'instrument',\n },\n }),\n ]);\n };\n}\n\n/** JSDoc */\nfunction _wrapXHR(originalSend: () => void): () => void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: XMLHttpRequest, ...args: any[]): void {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const xhr = this;\n const xmlHttpRequestProps: XMLHttpRequestProp[] = ['onload', 'onerror', 'onprogress', 'onreadystatechange'];\n\n xmlHttpRequestProps.forEach(prop => {\n if (prop in xhr && typeof xhr[prop] === 'function') {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n fill(xhr, prop, function (original: WrappedFunction): () => any {\n const wrapOptions = {\n mechanism: {\n data: {\n function: prop,\n handler: getFunctionName(original),\n },\n handled: true,\n type: 'instrument',\n },\n };\n\n // If Instrument integration has been called before TryCatch, get the name of original function\n const originalFunction = getOriginalFunction(original);\n if (originalFunction) {\n wrapOptions.mechanism.data.handler = getFunctionName(originalFunction);\n }\n\n // Otherwise wrap directly\n return wrap(original, wrapOptions);\n });\n }\n });\n\n return originalSend.apply(this, args);\n };\n}\n\n/** JSDoc */\nfunction _wrapEventTarget(target: string): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const globalObject = WINDOW as { [key: string]: any };\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const proto = globalObject[target] && globalObject[target].prototype;\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, no-prototype-builtins\n if (!proto || !proto.hasOwnProperty || !proto.hasOwnProperty('addEventListener')) {\n return;\n }\n\n fill(proto, 'addEventListener', function (original: () => void): (\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ) => void {\n return function (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this: any,\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ): (eventName: string, fn: EventListenerObject, capture?: boolean, secure?: boolean) => void {\n try {\n if (typeof fn.handleEvent === 'function') {\n // ESlint disable explanation:\n // First, it is generally safe to call `wrap` with an unbound function. Furthermore, using `.bind()` would\n // introduce a bug here, because bind returns a new function that doesn't have our\n // flags(like __sentry_original__) attached. `wrap` checks for those flags to avoid unnecessary wrapping.\n // Without those flags, every call to addEventListener wraps the function again, causing a memory leak.\n // eslint-disable-next-line @typescript-eslint/unbound-method\n fn.handleEvent = wrap(fn.handleEvent, {\n mechanism: {\n data: {\n function: 'handleEvent',\n handler: getFunctionName(fn),\n target,\n },\n handled: true,\n type: 'instrument',\n },\n });\n }\n } catch (err) {\n // can sometimes get 'Permission denied to access property \"handle Event'\n }\n\n return original.apply(this, [\n eventName,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n wrap(fn as any as WrappedFunction, {\n mechanism: {\n data: {\n function: 'addEventListener',\n handler: getFunctionName(fn),\n target,\n },\n handled: true,\n type: 'instrument',\n },\n }),\n options,\n ]);\n };\n });\n\n fill(\n proto,\n 'removeEventListener',\n function (\n originalRemoveEventListener: () => void,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): (this: any, eventName: string, fn: EventListenerObject, options?: boolean | EventListenerOptions) => () => void {\n return function (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this: any,\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | EventListenerOptions,\n ): () => void {\n /**\n * There are 2 possible scenarios here:\n *\n * 1. Someone passes a callback, which was attached prior to Sentry initialization, or by using unmodified\n * method, eg. `document.addEventListener.call(el, name, handler). In this case, we treat this function\n * as a pass-through, and call original `removeEventListener` with it.\n *\n * 2. Someone passes a callback, which was attached after Sentry was initialized, which means that it was using\n * our wrapped version of `addEventListener`, which internally calls `wrap` helper.\n * This helper \"wraps\" whole callback inside a try/catch statement, and attached appropriate metadata to it,\n * in order for us to make a distinction between wrapped/non-wrapped functions possible.\n * If a function was wrapped, it has additional property of `__sentry_wrapped__`, holding the handler.\n *\n * When someone adds a handler prior to initialization, and then do it again, but after,\n * then we have to detach both of them. Otherwise, if we'd detach only wrapped one, it'd be impossible\n * to get rid of the initial handler and it'd stick there forever.\n */\n const wrappedEventHandler = fn as unknown as WrappedFunction;\n try {\n const originalEventHandler = wrappedEventHandler && wrappedEventHandler.__sentry_wrapped__;\n if (originalEventHandler) {\n originalRemoveEventListener.call(this, eventName, originalEventHandler, options);\n }\n } catch (e) {\n // ignore, accessing __sentry_wrapped__ will throw in some Selenium environments\n }\n return originalRemoveEventListener.call(this, eventName, wrappedEventHandler, options);\n };\n },\n );\n}\n","import type { Event, EventHint, Exception, ExtendedError, StackParser } from '@sentry/types';\n\nimport { isInstanceOf } from './is';\nimport { truncate } from './string';\n\n/**\n * Creates exceptions inside `event.exception.values` for errors that are nested on properties based on the `key` parameter.\n */\nexport function applyAggregateErrorsToEvent(\n exceptionFromErrorImplementation: (stackParser: StackParser, ex: Error) => Exception,\n parser: StackParser,\n maxValueLimit: number = 250,\n key: string,\n limit: number,\n event: Event,\n hint?: EventHint,\n): void {\n if (!event.exception || !event.exception.values || !hint || !isInstanceOf(hint.originalException, Error)) {\n return;\n }\n\n // Generally speaking the last item in `event.exception.values` is the exception originating from the original Error\n const originalException: Exception | undefined =\n event.exception.values.length > 0 ? event.exception.values[event.exception.values.length - 1] : undefined;\n\n // We only create exception grouping if there is an exception in the event.\n if (originalException) {\n event.exception.values = truncateAggregateExceptions(\n aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n hint.originalException as ExtendedError,\n key,\n event.exception.values,\n originalException,\n 0,\n ),\n maxValueLimit,\n );\n }\n}\n\nfunction aggregateExceptionsFromError(\n exceptionFromErrorImplementation: (stackParser: StackParser, ex: Error) => Exception,\n parser: StackParser,\n limit: number,\n error: ExtendedError,\n key: string,\n prevExceptions: Exception[],\n exception: Exception,\n exceptionId: number,\n): Exception[] {\n if (prevExceptions.length >= limit + 1) {\n return prevExceptions;\n }\n\n let newExceptions = [...prevExceptions];\n\n if (isInstanceOf(error[key], Error)) {\n applyExceptionGroupFieldsForParentException(exception, exceptionId);\n const newException = exceptionFromErrorImplementation(parser, error[key]);\n const newExceptionId = newExceptions.length;\n applyExceptionGroupFieldsForChildException(newException, key, newExceptionId, exceptionId);\n newExceptions = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n error[key],\n key,\n [newException, ...newExceptions],\n newException,\n newExceptionId,\n );\n }\n\n // This will create exception grouping for AggregateErrors\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AggregateError\n if (Array.isArray(error.errors)) {\n error.errors.forEach((childError, i) => {\n if (isInstanceOf(childError, Error)) {\n applyExceptionGroupFieldsForParentException(exception, exceptionId);\n const newException = exceptionFromErrorImplementation(parser, childError);\n const newExceptionId = newExceptions.length;\n applyExceptionGroupFieldsForChildException(newException, `errors[${i}]`, newExceptionId, exceptionId);\n newExceptions = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n childError,\n key,\n [newException, ...newExceptions],\n newException,\n newExceptionId,\n );\n }\n });\n }\n\n return newExceptions;\n}\n\nfunction applyExceptionGroupFieldsForParentException(exception: Exception, exceptionId: number): void {\n // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n exception.mechanism = {\n ...exception.mechanism,\n is_exception_group: true,\n exception_id: exceptionId,\n };\n}\n\nfunction applyExceptionGroupFieldsForChildException(\n exception: Exception,\n source: string,\n exceptionId: number,\n parentId: number | undefined,\n): void {\n // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n exception.mechanism = {\n ...exception.mechanism,\n type: 'chained',\n source,\n exception_id: exceptionId,\n parent_id: parentId,\n };\n}\n\n/**\n * Truncate the message (exception.value) of all exceptions in the event.\n * Because this event processor is ran after `applyClientOptions`,\n * we need to truncate the message of the added exceptions here.\n */\nfunction truncateAggregateExceptions(exceptions: Exception[], maxValueLength: number): Exception[] {\n return exceptions.map(exception => {\n if (exception.value) {\n exception.value = truncate(exception.value, maxValueLength);\n }\n return exception;\n });\n}\n","import type { Event, EventHint, EventProcessor, Hub, Integration } from '@sentry/types';\nimport { applyAggregateErrorsToEvent } from '@sentry/utils';\n\nimport { exceptionFromError } from '../eventbuilder';\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\ninterface LinkedErrorsOptions {\n key: string;\n limit: number;\n}\n\n/** Adds SDK info to an event. */\nexport class LinkedErrors implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'LinkedErrors';\n\n /**\n * @inheritDoc\n */\n public readonly name: string;\n\n /**\n * @inheritDoc\n */\n private readonly _key: LinkedErrorsOptions['key'];\n\n /**\n * @inheritDoc\n */\n private readonly _limit: LinkedErrorsOptions['limit'];\n\n /**\n * @inheritDoc\n */\n public constructor(options: Partial<LinkedErrorsOptions> = {}) {\n this.name = LinkedErrors.id;\n this._key = options.key || DEFAULT_KEY;\n this._limit = options.limit || DEFAULT_LIMIT;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(addGlobalEventProcessor: (callback: EventProcessor) => void, getCurrentHub: () => Hub): void {\n addGlobalEventProcessor((event: Event, hint?: EventHint) => {\n const hub = getCurrentHub();\n const client = hub.getClient();\n const self = hub.getIntegration(LinkedErrors);\n\n if (!client || !self) {\n return event;\n }\n\n const options = client.getOptions();\n applyAggregateErrorsToEvent(\n exceptionFromError,\n options.stackParser,\n options.maxValueLength,\n self._key,\n self._limit,\n event,\n hint,\n );\n\n return event;\n });\n }\n}\n","import { addGlobalEventProcessor, getCurrentHub } from '@sentry/core';\nimport type { Event, Integration } from '@sentry/types';\n\nimport { WINDOW } from '../helpers';\n\n/** HttpContext integration collects information about HTTP request headers */\nexport class HttpContext implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'HttpContext';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n public constructor() {\n this.name = HttpContext.id;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n addGlobalEventProcessor((event: Event) => {\n if (getCurrentHub().getIntegration(HttpContext)) {\n // if none of the information we want exists, don't bother\n if (!WINDOW.navigator && !WINDOW.location && !WINDOW.document) {\n return event;\n }\n\n // grab as much info as exists and add it to the event\n const url = (event.request && event.request.url) || (WINDOW.location && WINDOW.location.href);\n const { referrer } = WINDOW.document || {};\n const { userAgent } = WINDOW.navigator || {};\n\n const headers = {\n ...(event.request && event.request.headers),\n ...(referrer && { Referer: referrer }),\n ...(userAgent && { 'User-Agent': userAgent }),\n };\n const request = { ...event.request, ...(url && { url }), headers };\n\n return { ...event, request };\n }\n return event;\n });\n }\n}\n","import type { Event, EventProcessor, Exception, Hub, Integration, StackFrame } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\n/** Deduplication filter */\nexport class Dedupe implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'Dedupe';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /**\n * @inheritDoc\n */\n private _previousEvent?: Event;\n\n public constructor() {\n this.name = Dedupe.id;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(addGlobalEventProcessor: (callback: EventProcessor) => void, getCurrentHub: () => Hub): void {\n const eventProcessor: EventProcessor = currentEvent => {\n // We want to ignore any non-error type events, e.g. transactions or replays\n // These should never be deduped, and also not be compared against as _previousEvent.\n if (currentEvent.type) {\n return currentEvent;\n }\n\n const self = getCurrentHub().getIntegration(Dedupe);\n if (self) {\n // Juuust in case something goes wrong\n try {\n if (_shouldDropEvent(currentEvent, self._previousEvent)) {\n __DEBUG_BUILD__ && logger.warn('Event dropped due to being a duplicate of previously captured event.');\n return null;\n }\n } catch (_oO) {\n return (self._previousEvent = currentEvent);\n }\n\n return (self._previousEvent = currentEvent);\n }\n return currentEvent;\n };\n\n eventProcessor.id = this.name;\n addGlobalEventProcessor(eventProcessor);\n }\n}\n\n/** JSDoc */\nfunction _shouldDropEvent(currentEvent: Event, previousEvent?: Event): boolean {\n if (!previousEvent) {\n return false;\n }\n\n if (_isSameMessageEvent(currentEvent, previousEvent)) {\n return true;\n }\n\n if (_isSameExceptionEvent(currentEvent, previousEvent)) {\n return true;\n }\n\n return false;\n}\n\n/** JSDoc */\nfunction _isSameMessageEvent(currentEvent: Event, previousEvent: Event): boolean {\n const currentMessage = currentEvent.message;\n const previousMessage = previousEvent.message;\n\n // If neither event has a message property, they were both exceptions, so bail out\n if (!currentMessage && !previousMessage) {\n return false;\n }\n\n // If only one event has a stacktrace, but not the other one, they are not the same\n if ((currentMessage && !previousMessage) || (!currentMessage && previousMessage)) {\n return false;\n }\n\n if (currentMessage !== previousMessage) {\n return false;\n }\n\n if (!_isSameFingerprint(currentEvent, previousEvent)) {\n return false;\n }\n\n if (!_isSameStacktrace(currentEvent, previousEvent)) {\n return false;\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameExceptionEvent(currentEvent: Event, previousEvent: Event): boolean {\n const previousException = _getExceptionFromEvent(previousEvent);\n const currentException = _getExceptionFromEvent(currentEvent);\n\n if (!previousException || !currentException) {\n return false;\n }\n\n if (previousException.type !== currentException.type || previousException.value !== currentException.value) {\n return false;\n }\n\n if (!_isSameFingerprint(currentEvent, previousEvent)) {\n return false;\n }\n\n if (!_isSameStacktrace(currentEvent, previousEvent)) {\n return false;\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameStacktrace(currentEvent: Event, previousEvent: Event): boolean {\n let currentFrames = _getFramesFromEvent(currentEvent);\n let previousFrames = _getFramesFromEvent(previousEvent);\n\n // If neither event has a stacktrace, they are assumed to be the same\n if (!currentFrames && !previousFrames) {\n return true;\n }\n\n // If only one event has a stacktrace, but not the other one, they are not the same\n if ((currentFrames && !previousFrames) || (!currentFrames && previousFrames)) {\n return false;\n }\n\n currentFrames = currentFrames as StackFrame[];\n previousFrames = previousFrames as StackFrame[];\n\n // If number of frames differ, they are not the same\n if (previousFrames.length !== currentFrames.length) {\n return false;\n }\n\n // Otherwise, compare the two\n for (let i = 0; i < previousFrames.length; i++) {\n const frameA = previousFrames[i];\n const frameB = currentFrames[i];\n\n if (\n frameA.filename !== frameB.filename ||\n frameA.lineno !== frameB.lineno ||\n frameA.colno !== frameB.colno ||\n frameA.function !== frameB.function\n ) {\n return false;\n }\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameFingerprint(currentEvent: Event, previousEvent: Event): boolean {\n let currentFingerprint = currentEvent.fingerprint;\n let previousFingerprint = previousEvent.fingerprint;\n\n // If neither event has a fingerprint, they are assumed to be the same\n if (!currentFingerprint && !previousFingerprint) {\n return true;\n }\n\n // If only one event has a fingerprint, but not the other one, they are not the same\n if ((currentFingerprint && !previousFingerprint) || (!currentFingerprint && previousFingerprint)) {\n return false;\n }\n\n currentFingerprint = currentFingerprint as string[];\n previousFingerprint = previousFingerprint as string[];\n\n // Otherwise, compare the two\n try {\n return !!(currentFingerprint.join('') === previousFingerprint.join(''));\n } catch (_oO) {\n return false;\n }\n}\n\n/** JSDoc */\nfunction _getExceptionFromEvent(event: Event): Exception | undefined {\n return event.exception && event.exception.values && event.exception.values[0];\n}\n\n/** JSDoc */\nfunction _getFramesFromEvent(event: Event): StackFrame[] | undefined {\n const exception = event.exception;\n\n if (exception) {\n try {\n // @ts-ignore Object could be undefined\n return exception.values[0].stacktrace.frames;\n } catch (_oO) {\n return undefined;\n }\n }\n return undefined;\n}\n","// This was originally forked from https://github.com/csnover/TraceKit, and was largely\n// re - written as part of raven - js.\n//\n// This code was later copied to the JavaScript mono - repo and further modified and\n// refactored over the years.\n\n// Copyright (c) 2013 Onur Can Cakmak onur.cakmak@gmail.com and all TraceKit contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of this\n// software and associated documentation files(the 'Software'), to deal in the Software\n// without restriction, including without limitation the rights to use, copy, modify,\n// merge, publish, distribute, sublicense, and / or sell copies of the Software, and to\n// permit persons to whom the Software is furnished to do so, subject to the following\n// conditions:\n//\n// The above copyright notice and this permission notice shall be included in all copies\n// or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,\n// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A\n// PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\n// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF\n// CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE\n// OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nimport type { StackFrame, StackLineParser, StackLineParserFn } from '@sentry/types';\nimport { createStackParser } from '@sentry/utils';\n\n// global reference to slice\nconst UNKNOWN_FUNCTION = '?';\n\nconst OPERA10_PRIORITY = 10;\nconst OPERA11_PRIORITY = 20;\nconst CHROME_PRIORITY = 30;\nconst WINJS_PRIORITY = 40;\nconst GECKO_PRIORITY = 50;\n\nfunction createFrame(filename: string, func: string, lineno?: number, colno?: number): StackFrame {\n const frame: StackFrame = {\n filename,\n function: func,\n in_app: true, // All browser frames are considered in_app\n };\n\n if (lineno !== undefined) {\n frame.lineno = lineno;\n }\n\n if (colno !== undefined) {\n frame.colno = colno;\n }\n\n return frame;\n}\n\n// Chromium based browsers: Chrome, Brave, new Opera, new Edge\nconst chromeRegex =\n /^\\s*at (?:(.+?\\)(?: \\[.+\\])?|.*?) ?\\((?:address at )?)?(?:async )?((?:<anonymous>|[-a-z]+:|.*bundle|\\/)?.*?)(?::(\\d+))?(?::(\\d+))?\\)?\\s*$/i;\nconst chromeEvalRegex = /\\((\\S*)(?::(\\d+))(?::(\\d+))\\)/;\n\nconst chrome: StackLineParserFn = line => {\n const parts = chromeRegex.exec(line);\n\n if (parts) {\n const isEval = parts[2] && parts[2].indexOf('eval') === 0; // start of line\n\n if (isEval) {\n const subMatch = chromeEvalRegex.exec(parts[2]);\n\n if (subMatch) {\n // throw out eval line/column and use top-most line/column number\n parts[2] = subMatch[1]; // url\n parts[3] = subMatch[2]; // line\n parts[4] = subMatch[3]; // column\n }\n }\n\n // Kamil: One more hack won't hurt us right? Understanding and adding more rules on top of these regexps right now\n // would be way too time consuming. (TODO: Rewrite whole RegExp to be more readable)\n const [func, filename] = extractSafariExtensionDetails(parts[1] || UNKNOWN_FUNCTION, parts[2]);\n\n return createFrame(filename, func, parts[3] ? +parts[3] : undefined, parts[4] ? +parts[4] : undefined);\n }\n\n return;\n};\n\nexport const chromeStackLineParser: StackLineParser = [CHROME_PRIORITY, chrome];\n\n// gecko regex: `(?:bundle|\\d+\\.js)`: `bundle` is for react native, `\\d+\\.js` also but specifically for ram bundles because it\n// generates filenames without a prefix like `file://` the filenames in the stacktrace are just 42.js\n// We need this specific case for now because we want no other regex to match.\nconst geckoREgex =\n /^\\s*(.*?)(?:\\((.*?)\\))?(?:^|@)?((?:[-a-z]+)?:\\/.*?|\\[native code\\]|[^@]*(?:bundle|\\d+\\.js)|\\/[\\w\\-. /=]+)(?::(\\d+))?(?::(\\d+))?\\s*$/i;\nconst geckoEvalRegex = /(\\S+) line (\\d+)(?: > eval line \\d+)* > eval/i;\n\nconst gecko: StackLineParserFn = line => {\n const parts = geckoREgex.exec(line);\n\n if (parts) {\n const isEval = parts[3] && parts[3].indexOf(' > eval') > -1;\n if (isEval) {\n const subMatch = geckoEvalRegex.exec(parts[3]);\n\n if (subMatch) {\n // throw out eval line/column and use top-most line number\n parts[1] = parts[1] || 'eval';\n parts[3] = subMatch[1];\n parts[4] = subMatch[2];\n parts[5] = ''; // no column when eval\n }\n }\n\n let filename = parts[3];\n let func = parts[1] || UNKNOWN_FUNCTION;\n [func, filename] = extractSafariExtensionDetails(func, filename);\n\n return createFrame(filename, func, parts[4] ? +parts[4] : undefined, parts[5] ? +parts[5] : undefined);\n }\n\n return;\n};\n\nexport const geckoStackLineParser: StackLineParser = [GECKO_PRIORITY, gecko];\n\nconst winjsRegex = /^\\s*at (?:((?:\\[object object\\])?.+) )?\\(?((?:[-a-z]+):.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nconst winjs: StackLineParserFn = line => {\n const parts = winjsRegex.exec(line);\n\n return parts\n ? createFrame(parts[2], parts[1] || UNKNOWN_FUNCTION, +parts[3], parts[4] ? +parts[4] : undefined)\n : undefined;\n};\n\nexport const winjsStackLineParser: StackLineParser = [WINJS_PRIORITY, winjs];\n\nconst opera10Regex = / line (\\d+).*script (?:in )?(\\S+)(?:: in function (\\S+))?$/i;\n\nconst opera10: StackLineParserFn = line => {\n const parts = opera10Regex.exec(line);\n return parts ? createFrame(parts[2], parts[3] || UNKNOWN_FUNCTION, +parts[1]) : undefined;\n};\n\nexport const opera10StackLineParser: StackLineParser = [OPERA10_PRIORITY, opera10];\n\nconst opera11Regex =\n / line (\\d+), column (\\d+)\\s*(?:in (?:<anonymous function: ([^>]+)>|([^)]+))\\(.*\\))? in (.*):\\s*$/i;\n\nconst opera11: StackLineParserFn = line => {\n const parts = opera11Regex.exec(line);\n return parts ? createFrame(parts[5], parts[3] || parts[4] || UNKNOWN_FUNCTION, +parts[1], +parts[2]) : undefined;\n};\n\nexport const opera11StackLineParser: StackLineParser = [OPERA11_PRIORITY, opera11];\n\nexport const defaultStackLineParsers = [chromeStackLineParser, geckoStackLineParser, winjsStackLineParser];\n\nexport const defaultStackParser = createStackParser(...defaultStackLineParsers);\n\n/**\n * Safari web extensions, starting version unknown, can produce \"frames-only\" stacktraces.\n * What it means, is that instead of format like:\n *\n * Error: wat\n * at function@url:row:col\n * at function@url:row:col\n * at function@url:row:col\n *\n * it produces something like:\n *\n * function@url:row:col\n * function@url:row:col\n * function@url:row:col\n *\n * Because of that, it won't be captured by `chrome` RegExp and will fall into `Gecko` branch.\n * This function is extracted so that we can use it in both places without duplicating the logic.\n * Unfortunately \"just\" changing RegExp is too complicated now and making it pass all tests\n * and fix this case seems like an impossible, or at least way too time-consuming task.\n */\nconst extractSafariExtensionDetails = (func: string, filename: string): [string, string] => {\n const isSafariExtension = func.indexOf('safari-extension') !== -1;\n const isSafariWebExtension = func.indexOf('safari-web-extension') !== -1;\n\n return isSafariExtension || isSafariWebExtension\n ? [\n func.indexOf('@') !== -1 ? func.split('@')[0] : UNKNOWN_FUNCTION,\n isSafariExtension ? `safari-extension:${filename}` : `safari-web-extension:${filename}`,\n ]\n : [func, filename];\n};\n","import { SentryError } from './error';\nimport { rejectedSyncPromise, resolvedSyncPromise, SyncPromise } from './syncpromise';\n\nexport interface PromiseBuffer<T> {\n // exposes the internal array so tests can assert on the state of it.\n // XXX: this really should not be public api.\n $: Array<PromiseLike<T>>;\n add(taskProducer: () => PromiseLike<T>): PromiseLike<T>;\n drain(timeout?: number): PromiseLike<boolean>;\n}\n\n/**\n * Creates an new PromiseBuffer object with the specified limit\n * @param limit max number of promises that can be stored in the buffer\n */\nexport function makePromiseBuffer<T>(limit?: number): PromiseBuffer<T> {\n const buffer: Array<PromiseLike<T>> = [];\n\n function isReady(): boolean {\n return limit === undefined || buffer.length < limit;\n }\n\n /**\n * Remove a promise from the queue.\n *\n * @param task Can be any PromiseLike<T>\n * @returns Removed promise.\n */\n function remove(task: PromiseLike<T>): PromiseLike<T> {\n return buffer.splice(buffer.indexOf(task), 1)[0];\n }\n\n /**\n * Add a promise (representing an in-flight action) to the queue, and set it to remove itself on fulfillment.\n *\n * @param taskProducer A function producing any PromiseLike<T>; In previous versions this used to be `task:\n * PromiseLike<T>`, but under that model, Promises were instantly created on the call-site and their executor\n * functions therefore ran immediately. Thus, even if the buffer was full, the action still happened. By\n * requiring the promise to be wrapped in a function, we can defer promise creation until after the buffer\n * limit check.\n * @returns The original promise.\n */\n function add(taskProducer: () => PromiseLike<T>): PromiseLike<T> {\n if (!isReady()) {\n return rejectedSyncPromise(new SentryError('Not adding Promise because buffer limit was reached.'));\n }\n\n // start the task and add its promise to the queue\n const task = taskProducer();\n if (buffer.indexOf(task) === -1) {\n buffer.push(task);\n }\n void task\n .then(() => remove(task))\n // Use `then(null, rejectionHandler)` rather than `catch(rejectionHandler)` so that we can use `PromiseLike`\n // rather than `Promise`. `PromiseLike` doesn't have a `.catch` method, making its polyfill smaller. (ES5 didn't\n // have promises, so TS has to polyfill when down-compiling.)\n .then(null, () =>\n remove(task).then(null, () => {\n // We have to add another catch here because `remove()` starts a new promise chain.\n }),\n );\n return task;\n }\n\n /**\n * Wait for all promises in the queue to resolve or for timeout to expire, whichever comes first.\n *\n * @param timeout The time, in ms, after which to resolve to `false` if the queue is still non-empty. Passing `0` (or\n * not passing anything) will make the promise wait as long as it takes for the queue to drain before resolving to\n * `true`.\n * @returns A promise which will resolve to `true` if the queue is already empty or drains before the timeout, and\n * `false` otherwise\n */\n function drain(timeout?: number): PromiseLike<boolean> {\n return new SyncPromise<boolean>((resolve, reject) => {\n let counter = buffer.length;\n\n if (!counter) {\n return resolve(true);\n }\n\n // wait for `timeout` ms and then resolve to `false` (if not cancelled first)\n const capturedSetTimeout = setTimeout(() => {\n if (timeout && timeout > 0) {\n resolve(false);\n }\n }, timeout);\n\n // if all promises resolve in time, cancel the timer and resolve to `true`\n buffer.forEach(item => {\n void resolvedSyncPromise(item).then(() => {\n if (!--counter) {\n clearTimeout(capturedSetTimeout);\n resolve(true);\n }\n }, reject);\n });\n });\n }\n\n return {\n $: buffer,\n add,\n drain,\n };\n}\n","import type { TransportMakeRequestResponse } from '@sentry/types';\n\n// Intentionally keeping the key broad, as we don't know for sure what rate limit headers get returned from backend\nexport type RateLimits = Record<string, number>;\n\nexport const DEFAULT_RETRY_AFTER = 60 * 1000; // 60 seconds\n\n/**\n * Extracts Retry-After value from the request header or returns default value\n * @param header string representation of 'Retry-After' header\n * @param now current unix timestamp\n *\n */\nexport function parseRetryAfterHeader(header: string, now: number = Date.now()): number {\n const headerDelay = parseInt(`${header}`, 10);\n if (!isNaN(headerDelay)) {\n return headerDelay * 1000;\n }\n\n const headerDate = Date.parse(`${header}`);\n if (!isNaN(headerDate)) {\n return headerDate - now;\n }\n\n return DEFAULT_RETRY_AFTER;\n}\n\n/**\n * Gets the time that the given category is disabled until for rate limiting.\n * In case no category-specific limit is set but a general rate limit across all categories is active,\n * that time is returned.\n *\n * @return the time in ms that the category is disabled until or 0 if there's no active rate limit.\n */\nexport function disabledUntil(limits: RateLimits, category: string): number {\n return limits[category] || limits.all || 0;\n}\n\n/**\n * Checks if a category is rate limited\n */\nexport function isRateLimited(limits: RateLimits, category: string, now: number = Date.now()): boolean {\n return disabledUntil(limits, category) > now;\n}\n\n/**\n * Update ratelimits from incoming headers.\n *\n * @return the updated RateLimits object.\n */\nexport function updateRateLimits(\n limits: RateLimits,\n { statusCode, headers }: TransportMakeRequestResponse,\n now: number = Date.now(),\n): RateLimits {\n const updatedRateLimits: RateLimits = {\n ...limits,\n };\n\n // \"The name is case-insensitive.\"\n // https://developer.mozilla.org/en-US/docs/Web/API/Headers/get\n const rateLimitHeader = headers && headers['x-sentry-rate-limits'];\n const retryAfterHeader = headers && headers['retry-after'];\n\n if (rateLimitHeader) {\n /**\n * rate limit headers are of the form\n * <header>,<header>,..\n * where each <header> is of the form\n * <retry_after>: <categories>: <scope>: <reason_code>\n * where\n * <retry_after> is a delay in seconds\n * <categories> is the event type(s) (error, transaction, etc) being rate limited and is of the form\n * <category>;<category>;...\n * <scope> is what's being limited (org, project, or key) - ignored by SDK\n * <reason_code> is an arbitrary string like \"org_quota\" - ignored by SDK\n */\n for (const limit of rateLimitHeader.trim().split(',')) {\n const [retryAfter, categories] = limit.split(':', 2);\n const headerDelay = parseInt(retryAfter, 10);\n const delay = (!isNaN(headerDelay) ? headerDelay : 60) * 1000; // 60sec default\n if (!categories) {\n updatedRateLimits.all = now + delay;\n } else {\n for (const category of categories.split(';')) {\n updatedRateLimits[category] = now + delay;\n }\n }\n }\n } else if (retryAfterHeader) {\n updatedRateLimits.all = now + parseRetryAfterHeader(retryAfterHeader, now);\n } else if (statusCode === 429) {\n updatedRateLimits.all = now + 60 * 1000;\n }\n\n return updatedRateLimits;\n}\n","import type {\n Envelope,\n EnvelopeItem,\n EnvelopeItemType,\n Event,\n EventDropReason,\n EventItem,\n InternalBaseTransportOptions,\n Transport,\n TransportMakeRequestResponse,\n TransportRequestExecutor,\n} from '@sentry/types';\nimport type { PromiseBuffer, RateLimits } from '@sentry/utils';\nimport {\n createEnvelope,\n envelopeItemTypeToDataCategory,\n forEachEnvelopeItem,\n isRateLimited,\n logger,\n makePromiseBuffer,\n resolvedSyncPromise,\n SentryError,\n serializeEnvelope,\n updateRateLimits,\n} from '@sentry/utils';\n\nexport const DEFAULT_TRANSPORT_BUFFER_SIZE = 30;\n\n/**\n * Creates an instance of a Sentry `Transport`\n *\n * @param options\n * @param makeRequest\n */\nexport function createTransport(\n options: InternalBaseTransportOptions,\n makeRequest: TransportRequestExecutor,\n buffer: PromiseBuffer<void | TransportMakeRequestResponse> = makePromiseBuffer(\n options.bufferSize || DEFAULT_TRANSPORT_BUFFER_SIZE,\n ),\n): Transport {\n let rateLimits: RateLimits = {};\n const flush = (timeout?: number): PromiseLike<boolean> => buffer.drain(timeout);\n\n function send(envelope: Envelope): PromiseLike<void | TransportMakeRequestResponse> {\n const filteredEnvelopeItems: EnvelopeItem[] = [];\n\n // Drop rate limited items from envelope\n forEachEnvelopeItem(envelope, (item, type) => {\n const envelopeItemDataCategory = envelopeItemTypeToDataCategory(type);\n if (isRateLimited(rateLimits, envelopeItemDataCategory)) {\n const event: Event | undefined = getEventForEnvelopeItem(item, type);\n options.recordDroppedEvent('ratelimit_backoff', envelopeItemDataCategory, event);\n } else {\n filteredEnvelopeItems.push(item);\n }\n });\n\n // Skip sending if envelope is empty after filtering out rate limited events\n if (filteredEnvelopeItems.length === 0) {\n return resolvedSyncPromise();\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const filteredEnvelope: Envelope = createEnvelope(envelope[0], filteredEnvelopeItems as any);\n\n // Creates client report for each item in an envelope\n const recordEnvelopeLoss = (reason: EventDropReason): void => {\n forEachEnvelopeItem(filteredEnvelope, (item, type) => {\n const event: Event | undefined = getEventForEnvelopeItem(item, type);\n options.recordDroppedEvent(reason, envelopeItemTypeToDataCategory(type), event);\n });\n };\n\n const requestTask = (): PromiseLike<void | TransportMakeRequestResponse> =>\n makeRequest({ body: serializeEnvelope(filteredEnvelope, options.textEncoder) }).then(\n response => {\n // We don't want to throw on NOK responses, but we want to at least log them\n if (response.statusCode !== undefined && (response.statusCode < 200 || response.statusCode >= 300)) {\n __DEBUG_BUILD__ && logger.warn(`Sentry responded with status code ${response.statusCode} to sent event.`);\n }\n\n rateLimits = updateRateLimits(rateLimits, response);\n return response;\n },\n error => {\n recordEnvelopeLoss('network_error');\n throw error;\n },\n );\n\n return buffer.add(requestTask).then(\n result => result,\n error => {\n if (error instanceof SentryError) {\n __DEBUG_BUILD__ && logger.error('Skipped sending event because buffer is full.');\n recordEnvelopeLoss('queue_overflow');\n return resolvedSyncPromise();\n } else {\n throw error;\n }\n },\n );\n }\n\n // We use this to identifify if the transport is the base transport\n // TODO (v8): Remove this again as we'll no longer need it\n send.__sentry__baseTransport__ = true;\n\n return {\n send,\n flush,\n };\n}\n\nfunction getEventForEnvelopeItem(item: Envelope[1][number], type: EnvelopeItemType): Event | undefined {\n if (type !== 'event' && type !== 'transaction') {\n return undefined;\n }\n\n return Array.isArray(item) ? (item as EventItem)[1] : undefined;\n}\n","import { isNativeFetch, logger } from '@sentry/utils';\n\nimport { WINDOW } from '../helpers';\n\nlet cachedFetchImpl: FetchImpl | undefined = undefined;\n\nexport type FetchImpl = typeof fetch;\n\n/**\n * A special usecase for incorrectly wrapped Fetch APIs in conjunction with ad-blockers.\n * Whenever someone wraps the Fetch API and returns the wrong promise chain,\n * this chain becomes orphaned and there is no possible way to capture it's rejections\n * other than allowing it bubble up to this very handler. eg.\n *\n * const f = window.fetch;\n * window.fetch = function () {\n * const p = f.apply(this, arguments);\n *\n * p.then(function() {\n * console.log('hi.');\n * });\n *\n * return p;\n * }\n *\n * `p.then(function () { ... })` is producing a completely separate promise chain,\n * however, what's returned is `p` - the result of original `fetch` call.\n *\n * This mean, that whenever we use the Fetch API to send our own requests, _and_\n * some ad-blocker blocks it, this orphaned chain will _always_ reject,\n * effectively causing another event to be captured.\n * This makes a whole process become an infinite loop, which we need to somehow\n * deal with, and break it in one way or another.\n *\n * To deal with this issue, we are making sure that we _always_ use the real\n * browser Fetch API, instead of relying on what `window.fetch` exposes.\n * The only downside to this would be missing our own requests as breadcrumbs,\n * but because we are already not doing this, it should be just fine.\n *\n * Possible failed fetch error messages per-browser:\n *\n * Chrome: Failed to fetch\n * Edge: Failed to Fetch\n * Firefox: NetworkError when attempting to fetch resource\n * Safari: resource blocked by content blocker\n */\nexport function getNativeFetchImplementation(): FetchImpl {\n if (cachedFetchImpl) {\n return cachedFetchImpl;\n }\n\n /* eslint-disable @typescript-eslint/unbound-method */\n\n // Fast path to avoid DOM I/O\n if (isNativeFetch(WINDOW.fetch)) {\n return (cachedFetchImpl = WINDOW.fetch.bind(WINDOW));\n }\n\n const document = WINDOW.document;\n let fetchImpl = WINDOW.fetch;\n // eslint-disable-next-line deprecation/deprecation\n if (document && typeof document.createElement === 'function') {\n try {\n const sandbox = document.createElement('iframe');\n sandbox.hidden = true;\n document.head.appendChild(sandbox);\n const contentWindow = sandbox.contentWindow;\n if (contentWindow && contentWindow.fetch) {\n fetchImpl = contentWindow.fetch;\n }\n document.head.removeChild(sandbox);\n } catch (e) {\n __DEBUG_BUILD__ &&\n logger.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', e);\n }\n }\n\n return (cachedFetchImpl = fetchImpl.bind(WINDOW));\n /* eslint-enable @typescript-eslint/unbound-method */\n}\n\n/** Clears cached fetch impl */\nexport function clearCachedFetchImplementation(): void {\n cachedFetchImpl = undefined;\n}\n","import { createTransport } from '@sentry/core';\nimport type { Transport, TransportMakeRequestResponse, TransportRequest } from '@sentry/types';\nimport { rejectedSyncPromise } from '@sentry/utils';\n\nimport type { BrowserTransportOptions } from './types';\nimport type { FetchImpl } from './utils';\nimport { clearCachedFetchImplementation, getNativeFetchImplementation } from './utils';\n\n/**\n * Creates a Transport that uses the Fetch API to send events to Sentry.\n */\nexport function makeFetchTransport(\n options: BrowserTransportOptions,\n nativeFetch: FetchImpl = getNativeFetchImplementation(),\n): Transport {\n let pendingBodySize = 0;\n let pendingCount = 0;\n\n function makeRequest(request: TransportRequest): PromiseLike<TransportMakeRequestResponse> {\n const requestSize = request.body.length;\n pendingBodySize += requestSize;\n pendingCount++;\n\n const requestOptions: RequestInit = {\n body: request.body,\n method: 'POST',\n referrerPolicy: 'origin',\n headers: options.headers,\n // Outgoing requests are usually cancelled when navigating to a different page, causing a \"TypeError: Failed to\n // fetch\" error and sending a \"network_error\" client-outcome - in Chrome, the request status shows \"(cancelled)\".\n // The `keepalive` flag keeps outgoing requests alive, even when switching pages. We want this since we're\n // frequently sending events right before the user is switching pages (eg. whenfinishing navigation transactions).\n // Gotchas:\n // - `keepalive` isn't supported by Firefox\n // - As per spec (https://fetch.spec.whatwg.org/#http-network-or-cache-fetch):\n // If the sum of contentLength and inflightKeepaliveBytes is greater than 64 kibibytes, then return a network error.\n // We will therefore only activate the flag when we're below that limit.\n // There is also a limit of requests that can be open at the same time, so we also limit this to 15\n // See https://github.com/getsentry/sentry-javascript/pull/7553 for details\n keepalive: pendingBodySize <= 60_000 && pendingCount < 15,\n ...options.fetchOptions,\n };\n\n try {\n return nativeFetch(options.url, requestOptions).then(response => {\n pendingBodySize -= requestSize;\n pendingCount--;\n return {\n statusCode: response.status,\n headers: {\n 'x-sentry-rate-limits': response.headers.get('X-Sentry-Rate-Limits'),\n 'retry-after': response.headers.get('Retry-After'),\n },\n };\n });\n } catch (e) {\n clearCachedFetchImplementation();\n pendingBodySize -= requestSize;\n pendingCount--;\n return rejectedSyncPromise(e);\n }\n }\n\n return createTransport(options, makeRequest);\n}\n","import { createTransport } from '@sentry/core';\nimport type { Transport, TransportMakeRequestResponse, TransportRequest } from '@sentry/types';\nimport { SyncPromise } from '@sentry/utils';\n\nimport type { BrowserTransportOptions } from './types';\n\n/**\n * The DONE ready state for XmlHttpRequest\n *\n * Defining it here as a constant b/c XMLHttpRequest.DONE is not always defined\n * (e.g. during testing, it is `undefined`)\n *\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/readyState}\n */\nconst XHR_READYSTATE_DONE = 4;\n\n/**\n * Creates a Transport that uses the XMLHttpRequest API to send events to Sentry.\n */\nexport function makeXHRTransport(options: BrowserTransportOptions): Transport {\n function makeRequest(request: TransportRequest): PromiseLike<TransportMakeRequestResponse> {\n return new SyncPromise((resolve, reject) => {\n const xhr = new XMLHttpRequest();\n\n xhr.onerror = reject;\n\n xhr.onreadystatechange = (): void => {\n if (xhr.readyState === XHR_READYSTATE_DONE) {\n resolve({\n statusCode: xhr.status,\n headers: {\n 'x-sentry-rate-limits': xhr.getResponseHeader('X-Sentry-Rate-Limits'),\n 'retry-after': xhr.getResponseHeader('Retry-After'),\n },\n });\n }\n };\n\n xhr.open('POST', options.url);\n\n for (const header in options.headers) {\n if (Object.prototype.hasOwnProperty.call(options.headers, header)) {\n xhr.setRequestHeader(header, options.headers[header]);\n }\n }\n\n xhr.send(request.body);\n });\n }\n\n return createTransport(options, makeRequest);\n}\n","import type { Hub } from '@sentry/core';\nimport {\n getCurrentHub,\n getIntegrationsToSetup,\n getReportDialogEndpoint,\n initAndBind,\n Integrations as CoreIntegrations,\n} from '@sentry/core';\nimport type { UserFeedback } from '@sentry/types';\nimport { addInstrumentationHandler, logger, stackParserFromStackParserOptions, supportsFetch } from '@sentry/utils';\n\nimport type { BrowserClientOptions, BrowserOptions } from './client';\nimport { BrowserClient } from './client';\nimport type { ReportDialogOptions } from './helpers';\nimport { WINDOW, wrap as internalWrap } from './helpers';\nimport { Breadcrumbs, Dedupe, GlobalHandlers, HttpContext, LinkedErrors, TryCatch } from './integrations';\nimport { defaultStackParser } from './stack-parsers';\nimport { makeFetchTransport, makeXHRTransport } from './transports';\n\nexport const defaultIntegrations = [\n new CoreIntegrations.InboundFilters(),\n new CoreIntegrations.FunctionToString(),\n new TryCatch(),\n new Breadcrumbs(),\n new GlobalHandlers(),\n new LinkedErrors(),\n new Dedupe(),\n new HttpContext(),\n];\n\n/**\n * A magic string that build tooling can leverage in order to inject a release value into the SDK.\n */\ndeclare const __SENTRY_RELEASE__: string | undefined;\n\n/**\n * The Sentry Browser SDK Client.\n *\n * To use this SDK, call the {@link init} function as early as possible when\n * loading the web page. To set context information or send manual events, use\n * the provided methods.\n *\n * @example\n *\n * ```\n *\n * import { init } from '@sentry/browser';\n *\n * init({\n * dsn: '__DSN__',\n * // ...\n * });\n * ```\n *\n * @example\n * ```\n *\n * import { configureScope } from '@sentry/browser';\n * configureScope((scope: Scope) => {\n * scope.setExtra({ battery: 0.7 });\n * scope.setTag({ user_mode: 'admin' });\n * scope.setUser({ id: '4711' });\n * });\n * ```\n *\n * @example\n * ```\n *\n * import { addBreadcrumb } from '@sentry/browser';\n * addBreadcrumb({\n * message: 'My Breadcrumb',\n * // ...\n * });\n * ```\n *\n * @example\n *\n * ```\n *\n * import * as Sentry from '@sentry/browser';\n * Sentry.captureMessage('Hello, world!');\n * Sentry.captureException(new Error('Good bye'));\n * Sentry.captureEvent({\n * message: 'Manual',\n * stacktrace: [\n * // ...\n * ],\n * });\n * ```\n *\n * @see {@link BrowserOptions} for documentation on configuration options.\n */\nexport function init(options: BrowserOptions = {}): void {\n if (options.defaultIntegrations === undefined) {\n options.defaultIntegrations = defaultIntegrations;\n }\n if (options.release === undefined) {\n // This allows build tooling to find-and-replace __SENTRY_RELEASE__ to inject a release value\n if (typeof __SENTRY_RELEASE__ === 'string') {\n options.release = __SENTRY_RELEASE__;\n }\n\n // This supports the variable that sentry-webpack-plugin injects\n if (WINDOW.SENTRY_RELEASE && WINDOW.SENTRY_RELEASE.id) {\n options.release = WINDOW.SENTRY_RELEASE.id;\n }\n }\n if (options.autoSessionTracking === undefined) {\n options.autoSessionTracking = true;\n }\n if (options.sendClientReports === undefined) {\n options.sendClientReports = true;\n }\n\n const clientOptions: BrowserClientOptions = {\n ...options,\n stackParser: stackParserFromStackParserOptions(options.stackParser || defaultStackParser),\n integrations: getIntegrationsToSetup(options),\n transport: options.transport || (supportsFetch() ? makeFetchTransport : makeXHRTransport),\n };\n\n initAndBind(BrowserClient, clientOptions);\n\n if (options.autoSessionTracking) {\n startSessionTracking();\n }\n}\n\n/**\n * Present the user with a report dialog.\n *\n * @param options Everything is optional, we try to fetch all info need from the global scope.\n */\nexport function showReportDialog(options: ReportDialogOptions = {}, hub: Hub = getCurrentHub()): void {\n // doesn't work without a document (React Native)\n if (!WINDOW.document) {\n __DEBUG_BUILD__ && logger.error('Global document not defined in showReportDialog call');\n return;\n }\n\n const { client, scope } = hub.getStackTop();\n const dsn = options.dsn || (client && client.getDsn());\n if (!dsn) {\n __DEBUG_BUILD__ && logger.error('DSN not configured for showReportDialog call');\n return;\n }\n\n if (scope) {\n options.user = {\n ...scope.getUser(),\n ...options.user,\n };\n }\n\n if (!options.eventId) {\n options.eventId = hub.lastEventId();\n }\n\n const script = WINDOW.document.createElement('script');\n script.async = true;\n script.crossOrigin = 'anonymous';\n script.src = getReportDialogEndpoint(dsn, options);\n\n if (options.onLoad) {\n script.onload = options.onLoad;\n }\n\n const injectionPoint = WINDOW.document.head || WINDOW.document.body;\n if (injectionPoint) {\n injectionPoint.appendChild(script);\n } else {\n __DEBUG_BUILD__ && logger.error('Not injecting report dialog. No injection point found in HTML');\n }\n}\n\n/**\n * This function is here to be API compatible with the loader.\n * @hidden\n */\nexport function forceLoad(): void {\n // Noop\n}\n\n/**\n * This function is here to be API compatible with the loader.\n * @hidden\n */\nexport function onLoad(callback: () => void): void {\n callback();\n}\n\n/**\n * Wrap code within a try/catch block so the SDK is able to capture errors.\n *\n * @param fn A function to wrap.\n *\n * @returns The result of wrapped function call.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function wrap(fn: (...args: any) => any): any {\n return internalWrap(fn)();\n}\n\nfunction startSessionOnHub(hub: Hub): void {\n hub.startSession({ ignoreDuration: true });\n hub.captureSession();\n}\n\n/**\n * Enable automatic Session Tracking for the initial page load.\n */\nfunction startSessionTracking(): void {\n if (typeof WINDOW.document === 'undefined') {\n __DEBUG_BUILD__ &&\n logger.warn('Session tracking in non-browser environment with @sentry/browser is not supported.');\n return;\n }\n\n const hub = getCurrentHub();\n\n // The only way for this to be false is for there to be a version mismatch between @sentry/browser (>= 6.0.0) and\n // @sentry/hub (< 5.27.0). In the simple case, there won't ever be such a mismatch, because the two packages are\n // pinned at the same version in package.json, but there are edge cases where it's possible. See\n // https://github.com/getsentry/sentry-javascript/issues/3207 and\n // https://github.com/getsentry/sentry-javascript/issues/3234 and\n // https://github.com/getsentry/sentry-javascript/issues/3278.\n if (!hub.captureSession) {\n return;\n }\n\n // The session duration for browser sessions does not track a meaningful\n // concept that can be used as a metric.\n // Automatically captured sessions are akin to page views, and thus we\n // discard their duration.\n startSessionOnHub(hub);\n\n // We want to create a session for every navigation as well\n addInstrumentationHandler('history', ({ from, to }) => {\n // Don't create an additional session for the initial route or if the location did not change\n if (!(from === undefined || from === to)) {\n startSessionOnHub(getCurrentHub());\n }\n });\n}\n\n/**\n * Captures user feedback and sends it to Sentry.\n */\nexport function captureUserFeedback(feedback: UserFeedback): void {\n const client = getCurrentHub().getClient<BrowserClient>();\n if (client) {\n client.captureUserFeedback(feedback);\n }\n}\n","import type { DynamicSamplingContext } from '@sentry/types';\n\nimport { isString } from './is';\nimport { logger } from './logger';\n\nexport const BAGGAGE_HEADER_NAME = 'baggage';\n\nexport const SENTRY_BAGGAGE_KEY_PREFIX = 'sentry-';\n\nexport const SENTRY_BAGGAGE_KEY_PREFIX_REGEX = /^sentry-/;\n\n/**\n * Max length of a serialized baggage string\n *\n * https://www.w3.org/TR/baggage/#limits\n */\nexport const MAX_BAGGAGE_STRING_LENGTH = 8192;\n\n/**\n * Takes a baggage header and turns it into Dynamic Sampling Context, by extracting all the \"sentry-\" prefixed values\n * from it.\n *\n * @param baggageHeader A very bread definition of a baggage header as it might appear in various frameworks.\n * @returns The Dynamic Sampling Context that was found on `baggageHeader`, if there was any, `undefined` otherwise.\n */\nexport function baggageHeaderToDynamicSamplingContext(\n // Very liberal definition of what any incoming header might look like\n baggageHeader: string | string[] | number | null | undefined | boolean,\n): Partial<DynamicSamplingContext> | undefined {\n if (!isString(baggageHeader) && !Array.isArray(baggageHeader)) {\n return undefined;\n }\n\n // Intermediary object to store baggage key value pairs of incoming baggage headers on.\n // It is later used to read Sentry-DSC-values from.\n let baggageObject: Readonly<Record<string, string>> = {};\n\n if (Array.isArray(baggageHeader)) {\n // Combine all baggage headers into one object containing the baggage values so we can later read the Sentry-DSC-values from it\n baggageObject = baggageHeader.reduce<Record<string, string>>((acc, curr) => {\n const currBaggageObject = baggageHeaderToObject(curr);\n return {\n ...acc,\n ...currBaggageObject,\n };\n }, {});\n } else {\n // Return undefined if baggage header is an empty string (technically an empty baggage header is not spec conform but\n // this is how we choose to handle it)\n if (!baggageHeader) {\n return undefined;\n }\n\n baggageObject = baggageHeaderToObject(baggageHeader);\n }\n\n // Read all \"sentry-\" prefixed values out of the baggage object and put it onto a dynamic sampling context object.\n const dynamicSamplingContext = Object.entries(baggageObject).reduce<Record<string, string>>((acc, [key, value]) => {\n if (key.match(SENTRY_BAGGAGE_KEY_PREFIX_REGEX)) {\n const nonPrefixedKey = key.slice(SENTRY_BAGGAGE_KEY_PREFIX.length);\n acc[nonPrefixedKey] = value;\n }\n return acc;\n }, {});\n\n // Only return a dynamic sampling context object if there are keys in it.\n // A keyless object means there were no sentry values on the header, which means that there is no DSC.\n if (Object.keys(dynamicSamplingContext).length > 0) {\n return dynamicSamplingContext as Partial<DynamicSamplingContext>;\n } else {\n return undefined;\n }\n}\n\n/**\n * Turns a Dynamic Sampling Object into a baggage header by prefixing all the keys on the object with \"sentry-\".\n *\n * @param dynamicSamplingContext The Dynamic Sampling Context to turn into a header. For convenience and compatibility\n * with the `getDynamicSamplingContext` method on the Transaction class ,this argument can also be `undefined`. If it is\n * `undefined` the function will return `undefined`.\n * @returns a baggage header, created from `dynamicSamplingContext`, or `undefined` either if `dynamicSamplingContext`\n * was `undefined`, or if `dynamicSamplingContext` didn't contain any values.\n */\nexport function dynamicSamplingContextToSentryBaggageHeader(\n // this also takes undefined for convenience and bundle size in other places\n dynamicSamplingContext?: Partial<DynamicSamplingContext>,\n): string | undefined {\n if (!dynamicSamplingContext) {\n return undefined;\n }\n\n // Prefix all DSC keys with \"sentry-\" and put them into a new object\n const sentryPrefixedDSC = Object.entries(dynamicSamplingContext).reduce<Record<string, string>>(\n (acc, [dscKey, dscValue]) => {\n if (dscValue) {\n acc[`${SENTRY_BAGGAGE_KEY_PREFIX}${dscKey}`] = dscValue;\n }\n return acc;\n },\n {},\n );\n\n return objectToBaggageHeader(sentryPrefixedDSC);\n}\n\n/**\n * Will parse a baggage header, which is a simple key-value map, into a flat object.\n *\n * @param baggageHeader The baggage header to parse.\n * @returns a flat object containing all the key-value pairs from `baggageHeader`.\n */\nfunction baggageHeaderToObject(baggageHeader: string): Record<string, string> {\n return baggageHeader\n .split(',')\n .map(baggageEntry => baggageEntry.split('=').map(keyOrValue => decodeURIComponent(keyOrValue.trim())))\n .reduce<Record<string, string>>((acc, [key, value]) => {\n acc[key] = value;\n return acc;\n }, {});\n}\n\n/**\n * Turns a flat object (key-value pairs) into a baggage header, which is also just key-value pairs.\n *\n * @param object The object to turn into a baggage header.\n * @returns a baggage header string, or `undefined` if the object didn't have any values, since an empty baggage header\n * is not spec compliant.\n */\nfunction objectToBaggageHeader(object: Record<string, string>): string | undefined {\n if (Object.keys(object).length === 0) {\n // An empty baggage header is not spec compliant: We return undefined.\n return undefined;\n }\n\n return Object.entries(object).reduce((baggageHeader, [objectKey, objectValue], currentIndex) => {\n const baggageEntry = `${encodeURIComponent(objectKey)}=${encodeURIComponent(objectValue)}`;\n const newBaggageHeader = currentIndex === 0 ? baggageEntry : `${baggageHeader},${baggageEntry}`;\n if (newBaggageHeader.length > MAX_BAGGAGE_STRING_LENGTH) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Not adding key: ${objectKey} with val: ${objectValue} to baggage header due to exceeding baggage size limits.`,\n );\n return baggageHeader;\n } else {\n return newBaggageHeader;\n }\n }, '');\n}\n","import type { DynamicSamplingContext, PropagationContext, TraceparentData } from '@sentry/types';\n\nimport { baggageHeaderToDynamicSamplingContext } from './baggage';\nimport { uuid4 } from './misc';\n\nexport const TRACEPARENT_REGEXP = new RegExp(\n '^[ \\\\t]*' + // whitespace\n '([0-9a-f]{32})?' + // trace_id\n '-?([0-9a-f]{16})?' + // span_id\n '-?([01])?' + // sampled\n '[ \\\\t]*$', // whitespace\n);\n\n/**\n * Extract transaction context data from a `sentry-trace` header.\n *\n * @param traceparent Traceparent string\n *\n * @returns Object containing data from the header, or undefined if traceparent string is malformed\n */\nexport function extractTraceparentData(traceparent?: string): TraceparentData | undefined {\n if (!traceparent) {\n return undefined;\n }\n\n const matches = traceparent.match(TRACEPARENT_REGEXP);\n if (!matches) {\n return undefined;\n }\n\n let parentSampled: boolean | undefined;\n if (matches[3] === '1') {\n parentSampled = true;\n } else if (matches[3] === '0') {\n parentSampled = false;\n }\n\n return {\n traceId: matches[1],\n parentSampled,\n parentSpanId: matches[2],\n };\n}\n\n/**\n * Create tracing context from incoming headers.\n */\nexport function tracingContextFromHeaders(\n sentryTrace: Parameters<typeof extractTraceparentData>[0],\n baggage: Parameters<typeof baggageHeaderToDynamicSamplingContext>[0],\n): {\n traceparentData: ReturnType<typeof extractTraceparentData>;\n dynamicSamplingContext: ReturnType<typeof baggageHeaderToDynamicSamplingContext>;\n propagationContext: PropagationContext;\n} {\n const traceparentData = extractTraceparentData(sentryTrace);\n const dynamicSamplingContext = baggageHeaderToDynamicSamplingContext(baggage);\n\n const { traceId, parentSpanId, parentSampled } = traceparentData || {};\n\n const propagationContext: PropagationContext = {\n traceId: traceId || uuid4(),\n spanId: uuid4().substring(16),\n sampled: parentSampled === undefined ? false : parentSampled,\n };\n\n if (parentSpanId) {\n propagationContext.parentSpanId = parentSpanId;\n }\n\n if (dynamicSamplingContext) {\n propagationContext.dsc = dynamicSamplingContext as DynamicSamplingContext;\n }\n\n return {\n traceparentData,\n dynamicSamplingContext,\n propagationContext,\n };\n}\n\n/**\n * Create sentry-trace header from span context values.\n */\nexport function generateSentryTraceHeader(\n traceId: string = uuid4(),\n spanId: string = uuid4().substring(16),\n sampled?: boolean,\n): string {\n let sampledString = '';\n if (sampled !== undefined) {\n sampledString = sampled ? '-1' : '-0';\n }\n return `${traceId}-${spanId}${sampledString}`;\n}\n","/* eslint-disable max-lines */\nimport type {\n Instrumenter,\n Primitive,\n Span as SpanInterface,\n SpanContext,\n TraceContext,\n Transaction,\n} from '@sentry/types';\nimport { dropUndefinedKeys, generateSentryTraceHeader, logger, timestampInSeconds, uuid4 } from '@sentry/utils';\n\n/**\n * Keeps track of finished spans for a given transaction\n * @internal\n * @hideconstructor\n * @hidden\n */\nexport class SpanRecorder {\n public spans: Span[];\n\n private readonly _maxlen: number;\n\n public constructor(maxlen: number = 1000) {\n this._maxlen = maxlen;\n this.spans = [];\n }\n\n /**\n * This is just so that we don't run out of memory while recording a lot\n * of spans. At some point we just stop and flush out the start of the\n * trace tree (i.e.the first n spans with the smallest\n * start_timestamp).\n */\n public add(span: Span): void {\n if (this.spans.length > this._maxlen) {\n span.spanRecorder = undefined;\n } else {\n this.spans.push(span);\n }\n }\n}\n\n/**\n * Span contains all data about a span\n */\nexport class Span implements SpanInterface {\n /**\n * @inheritDoc\n */\n public traceId: string;\n\n /**\n * @inheritDoc\n */\n public spanId: string;\n\n /**\n * @inheritDoc\n */\n public parentSpanId?: string;\n\n /**\n * Internal keeper of the status\n */\n public status?: SpanStatusType | string;\n\n /**\n * @inheritDoc\n */\n public sampled?: boolean;\n\n /**\n * Timestamp in seconds when the span was created.\n */\n public startTimestamp: number;\n\n /**\n * Timestamp in seconds when the span ended.\n */\n public endTimestamp?: number;\n\n /**\n * @inheritDoc\n */\n public op?: string;\n\n /**\n * @inheritDoc\n */\n public description?: string;\n\n /**\n * @inheritDoc\n */\n public tags: { [key: string]: Primitive };\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public data: { [key: string]: any };\n\n /**\n * List of spans that were finalized\n */\n public spanRecorder?: SpanRecorder;\n\n /**\n * @inheritDoc\n */\n public transaction?: Transaction;\n\n /**\n * The instrumenter that created this span.\n */\n public instrumenter: Instrumenter;\n\n /**\n * You should never call the constructor manually, always use `Sentry.startTransaction()`\n * or call `startChild()` on an existing span.\n * @internal\n * @hideconstructor\n * @hidden\n */\n public constructor(spanContext?: SpanContext) {\n this.traceId = uuid4();\n this.spanId = uuid4().substring(16);\n this.startTimestamp = timestampInSeconds();\n this.tags = {};\n this.data = {};\n this.instrumenter = 'sentry';\n\n if (!spanContext) {\n return this;\n }\n if (spanContext.traceId) {\n this.traceId = spanContext.traceId;\n }\n if (spanContext.spanId) {\n this.spanId = spanContext.spanId;\n }\n if (spanContext.parentSpanId) {\n this.parentSpanId = spanContext.parentSpanId;\n }\n // We want to include booleans as well here\n if ('sampled' in spanContext) {\n this.sampled = spanContext.sampled;\n }\n if (spanContext.op) {\n this.op = spanContext.op;\n }\n if (spanContext.description) {\n this.description = spanContext.description;\n }\n if (spanContext.name) {\n this.description = spanContext.name;\n }\n if (spanContext.data) {\n this.data = spanContext.data;\n }\n if (spanContext.tags) {\n this.tags = spanContext.tags;\n }\n if (spanContext.status) {\n this.status = spanContext.status;\n }\n if (spanContext.startTimestamp) {\n this.startTimestamp = spanContext.startTimestamp;\n }\n if (spanContext.endTimestamp) {\n this.endTimestamp = spanContext.endTimestamp;\n }\n if (spanContext.instrumenter) {\n this.instrumenter = spanContext.instrumenter;\n }\n }\n\n /**\n * @inheritDoc\n */\n public startChild(\n spanContext?: Pick<SpanContext, Exclude<keyof SpanContext, 'sampled' | 'traceId' | 'parentSpanId'>>,\n ): Span {\n const childSpan = new Span({\n ...spanContext,\n parentSpanId: this.spanId,\n sampled: this.sampled,\n traceId: this.traceId,\n });\n\n childSpan.spanRecorder = this.spanRecorder;\n if (childSpan.spanRecorder) {\n childSpan.spanRecorder.add(childSpan);\n }\n\n childSpan.transaction = this.transaction;\n\n if (__DEBUG_BUILD__ && childSpan.transaction) {\n const opStr = (spanContext && spanContext.op) || '< unknown op >';\n const nameStr = childSpan.transaction.name || '< unknown name >';\n const idStr = childSpan.transaction.spanId;\n\n const logMessage = `[Tracing] Starting '${opStr}' span on transaction '${nameStr}' (${idStr}).`;\n childSpan.transaction.metadata.spanMetadata[childSpan.spanId] = { logMessage };\n logger.log(logMessage);\n }\n\n return childSpan;\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): this {\n this.tags = { ...this.tags, [key]: value };\n return this;\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public setData(key: string, value: any): this {\n this.data = { ...this.data, [key]: value };\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setStatus(value: SpanStatusType): this {\n this.status = value;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setHttpStatus(httpStatus: number): this {\n this.setTag('http.status_code', String(httpStatus));\n this.setData('http.response.status_code', httpStatus);\n const spanStatus = spanStatusfromHttpCode(httpStatus);\n if (spanStatus !== 'unknown_error') {\n this.setStatus(spanStatus);\n }\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setName(name: string): void {\n this.description = name;\n }\n\n /**\n * @inheritDoc\n */\n public isSuccess(): boolean {\n return this.status === 'ok';\n }\n\n /**\n * @inheritDoc\n */\n public finish(endTimestamp?: number): void {\n if (\n __DEBUG_BUILD__ &&\n // Don't call this for transactions\n this.transaction &&\n this.transaction.spanId !== this.spanId\n ) {\n const { logMessage } = this.transaction.metadata.spanMetadata[this.spanId];\n if (logMessage) {\n logger.log((logMessage as string).replace('Starting', 'Finishing'));\n }\n }\n\n this.endTimestamp = typeof endTimestamp === 'number' ? endTimestamp : timestampInSeconds();\n }\n\n /**\n * @inheritDoc\n */\n public toTraceparent(): string {\n return generateSentryTraceHeader(this.traceId, this.spanId, this.sampled);\n }\n\n /**\n * @inheritDoc\n */\n public toContext(): SpanContext {\n return dropUndefinedKeys({\n data: this.data,\n description: this.description,\n endTimestamp: this.endTimestamp,\n op: this.op,\n parentSpanId: this.parentSpanId,\n sampled: this.sampled,\n spanId: this.spanId,\n startTimestamp: this.startTimestamp,\n status: this.status,\n tags: this.tags,\n traceId: this.traceId,\n });\n }\n\n /**\n * @inheritDoc\n */\n public updateWithContext(spanContext: SpanContext): this {\n this.data = spanContext.data || {};\n this.description = spanContext.description;\n this.endTimestamp = spanContext.endTimestamp;\n this.op = spanContext.op;\n this.parentSpanId = spanContext.parentSpanId;\n this.sampled = spanContext.sampled;\n this.spanId = spanContext.spanId || this.spanId;\n this.startTimestamp = spanContext.startTimestamp || this.startTimestamp;\n this.status = spanContext.status;\n this.tags = spanContext.tags || {};\n this.traceId = spanContext.traceId || this.traceId;\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getTraceContext(): TraceContext {\n return dropUndefinedKeys({\n data: Object.keys(this.data).length > 0 ? this.data : undefined,\n description: this.description,\n op: this.op,\n parent_span_id: this.parentSpanId,\n span_id: this.spanId,\n status: this.status,\n tags: Object.keys(this.tags).length > 0 ? this.tags : undefined,\n trace_id: this.traceId,\n });\n }\n\n /**\n * @inheritDoc\n */\n public toJSON(): {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data?: { [key: string]: any };\n description?: string;\n op?: string;\n parent_span_id?: string;\n span_id: string;\n start_timestamp: number;\n status?: string;\n tags?: { [key: string]: Primitive };\n timestamp?: number;\n trace_id: string;\n } {\n return dropUndefinedKeys({\n data: Object.keys(this.data).length > 0 ? this.data : undefined,\n description: this.description,\n op: this.op,\n parent_span_id: this.parentSpanId,\n span_id: this.spanId,\n start_timestamp: this.startTimestamp,\n status: this.status,\n tags: Object.keys(this.tags).length > 0 ? this.tags : undefined,\n timestamp: this.endTimestamp,\n trace_id: this.traceId,\n });\n }\n}\n\nexport type SpanStatusType =\n /** The operation completed successfully. */\n | 'ok'\n /** Deadline expired before operation could complete. */\n | 'deadline_exceeded'\n /** 401 Unauthorized (actually does mean unauthenticated according to RFC 7235) */\n | 'unauthenticated'\n /** 403 Forbidden */\n | 'permission_denied'\n /** 404 Not Found. Some requested entity (file or directory) was not found. */\n | 'not_found'\n /** 429 Too Many Requests */\n | 'resource_exhausted'\n /** Client specified an invalid argument. 4xx. */\n | 'invalid_argument'\n /** 501 Not Implemented */\n | 'unimplemented'\n /** 503 Service Unavailable */\n | 'unavailable'\n /** Other/generic 5xx. */\n | 'internal_error'\n /** Unknown. Any non-standard HTTP status code. */\n | 'unknown_error'\n /** The operation was cancelled (typically by the user). */\n | 'cancelled'\n /** Already exists (409) */\n | 'already_exists'\n /** Operation was rejected because the system is not in a state required for the operation's */\n | 'failed_precondition'\n /** The operation was aborted, typically due to a concurrency issue. */\n | 'aborted'\n /** Operation was attempted past the valid range. */\n | 'out_of_range'\n /** Unrecoverable data loss or corruption */\n | 'data_loss';\n\n/**\n * Converts a HTTP status code into a {@link SpanStatusType}.\n *\n * @param httpStatus The HTTP response status code.\n * @returns The span status or unknown_error.\n */\nexport function spanStatusfromHttpCode(httpStatus: number): SpanStatusType {\n if (httpStatus < 400 && httpStatus >= 100) {\n return 'ok';\n }\n\n if (httpStatus >= 400 && httpStatus < 500) {\n switch (httpStatus) {\n case 401:\n return 'unauthenticated';\n case 403:\n return 'permission_denied';\n case 404:\n return 'not_found';\n case 409:\n return 'already_exists';\n case 413:\n return 'failed_precondition';\n case 429:\n return 'resource_exhausted';\n default:\n return 'invalid_argument';\n }\n }\n\n if (httpStatus >= 500 && httpStatus < 600) {\n switch (httpStatus) {\n case 501:\n return 'unimplemented';\n case 503:\n return 'unavailable';\n case 504:\n return 'deadline_exceeded';\n default:\n return 'internal_error';\n }\n }\n\n return 'unknown_error';\n}\n","import type {\n Context,\n Contexts,\n DynamicSamplingContext,\n Event,\n Measurements,\n MeasurementUnit,\n Transaction as TransactionInterface,\n TransactionContext,\n TransactionMetadata,\n} from '@sentry/types';\nimport { dropUndefinedKeys, logger } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport { getCurrentHub } from '../hub';\nimport { getDynamicSamplingContextFromClient } from './dynamicSamplingContext';\nimport { Span as SpanClass, SpanRecorder } from './span';\n\n/** JSDoc */\nexport class Transaction extends SpanClass implements TransactionInterface {\n public metadata: TransactionMetadata;\n\n /**\n * The reference to the current hub.\n */\n public _hub: Hub;\n\n private _name: string;\n\n private _measurements: Measurements;\n\n private _contexts: Contexts;\n\n private _trimEnd?: boolean;\n\n private _frozenDynamicSamplingContext: Readonly<Partial<DynamicSamplingContext>> | undefined;\n\n /**\n * This constructor should never be called manually. Those instrumenting tracing should use\n * `Sentry.startTransaction()`, and internal methods should use `hub.startTransaction()`.\n * @internal\n * @hideconstructor\n * @hidden\n */\n public constructor(transactionContext: TransactionContext, hub?: Hub) {\n super(transactionContext);\n // We need to delete description since it's set by the Span class constructor\n // but not needed for transactions.\n delete this.description;\n\n this._measurements = {};\n this._contexts = {};\n\n this._hub = hub || getCurrentHub();\n\n this._name = transactionContext.name || '';\n\n this.metadata = {\n source: 'custom',\n ...transactionContext.metadata,\n spanMetadata: {},\n };\n\n this._trimEnd = transactionContext.trimEnd;\n\n // this is because transactions are also spans, and spans have a transaction pointer\n this.transaction = this;\n\n // If Dynamic Sampling Context is provided during the creation of the transaction, we freeze it as it usually means\n // there is incoming Dynamic Sampling Context. (Either through an incoming request, a baggage meta-tag, or other means)\n const incomingDynamicSamplingContext = this.metadata.dynamicSamplingContext;\n if (incomingDynamicSamplingContext) {\n // We shallow copy this in case anything writes to the original reference of the passed in `dynamicSamplingContext`\n this._frozenDynamicSamplingContext = { ...incomingDynamicSamplingContext };\n }\n }\n\n /** Getter for `name` property */\n public get name(): string {\n return this._name;\n }\n\n /** Setter for `name` property, which also sets `source` as custom */\n public set name(newName: string) {\n this.setName(newName);\n }\n\n /**\n * JSDoc\n */\n public setName(name: string, source: TransactionMetadata['source'] = 'custom'): void {\n this._name = name;\n this.metadata.source = source;\n }\n\n /**\n * Attaches SpanRecorder to the span itself\n * @param maxlen maximum number of spans that can be recorded\n */\n public initSpanRecorder(maxlen: number = 1000): void {\n if (!this.spanRecorder) {\n this.spanRecorder = new SpanRecorder(maxlen);\n }\n this.spanRecorder.add(this);\n }\n\n /**\n * @inheritDoc\n */\n public setContext(key: string, context: Context | null): void {\n if (context === null) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this._contexts[key];\n } else {\n this._contexts[key] = context;\n }\n }\n\n /**\n * @inheritDoc\n */\n public setMeasurement(name: string, value: number, unit: MeasurementUnit = ''): void {\n this._measurements[name] = { value, unit };\n }\n\n /**\n * @inheritDoc\n */\n public setMetadata(newMetadata: Partial<TransactionMetadata>): void {\n this.metadata = { ...this.metadata, ...newMetadata };\n }\n\n /**\n * @inheritDoc\n */\n public finish(endTimestamp?: number): string | undefined {\n // This transaction is already finished, so we should not flush it again.\n if (this.endTimestamp !== undefined) {\n return undefined;\n }\n\n if (!this.name) {\n __DEBUG_BUILD__ && logger.warn('Transaction has no name, falling back to `<unlabeled transaction>`.');\n this.name = '<unlabeled transaction>';\n }\n\n // just sets the end timestamp\n super.finish(endTimestamp);\n\n const client = this._hub.getClient();\n if (client && client.emit) {\n client.emit('finishTransaction', this);\n }\n\n if (this.sampled !== true) {\n // At this point if `sampled !== true` we want to discard the transaction.\n __DEBUG_BUILD__ && logger.log('[Tracing] Discarding transaction because its trace was not chosen to be sampled.');\n\n if (client) {\n client.recordDroppedEvent('sample_rate', 'transaction');\n }\n\n return undefined;\n }\n\n const finishedSpans = this.spanRecorder ? this.spanRecorder.spans.filter(s => s !== this && s.endTimestamp) : [];\n\n if (this._trimEnd && finishedSpans.length > 0) {\n this.endTimestamp = finishedSpans.reduce((prev: SpanClass, current: SpanClass) => {\n if (prev.endTimestamp && current.endTimestamp) {\n return prev.endTimestamp > current.endTimestamp ? prev : current;\n }\n return prev;\n }).endTimestamp;\n }\n\n const metadata = this.metadata;\n\n const transaction: Event = {\n contexts: {\n ...this._contexts,\n // We don't want to override trace context\n trace: this.getTraceContext(),\n },\n spans: finishedSpans,\n start_timestamp: this.startTimestamp,\n tags: this.tags,\n timestamp: this.endTimestamp,\n transaction: this.name,\n type: 'transaction',\n sdkProcessingMetadata: {\n ...metadata,\n dynamicSamplingContext: this.getDynamicSamplingContext(),\n },\n ...(metadata.source && {\n transaction_info: {\n source: metadata.source,\n },\n }),\n };\n\n const hasMeasurements = Object.keys(this._measurements).length > 0;\n\n if (hasMeasurements) {\n __DEBUG_BUILD__ &&\n logger.log(\n '[Measurements] Adding measurements to transaction',\n JSON.stringify(this._measurements, undefined, 2),\n );\n transaction.measurements = this._measurements;\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] Finishing ${this.op} transaction: ${this.name}.`);\n\n return this._hub.captureEvent(transaction);\n }\n\n /**\n * @inheritDoc\n */\n public toContext(): TransactionContext {\n const spanContext = super.toContext();\n\n return dropUndefinedKeys({\n ...spanContext,\n name: this.name,\n trimEnd: this._trimEnd,\n });\n }\n\n /**\n * @inheritDoc\n */\n public updateWithContext(transactionContext: TransactionContext): this {\n super.updateWithContext(transactionContext);\n\n this.name = transactionContext.name || '';\n\n this._trimEnd = transactionContext.trimEnd;\n\n return this;\n }\n\n /**\n * @inheritdoc\n *\n * @experimental\n */\n public getDynamicSamplingContext(): Readonly<Partial<DynamicSamplingContext>> {\n if (this._frozenDynamicSamplingContext) {\n return this._frozenDynamicSamplingContext;\n }\n\n const hub = this._hub || getCurrentHub();\n const client = hub.getClient();\n\n if (!client) return {};\n\n const scope = hub.getScope();\n const dsc = getDynamicSamplingContextFromClient(this.traceId, client, scope);\n\n const maybeSampleRate = this.metadata.sampleRate;\n if (maybeSampleRate !== undefined) {\n dsc.sample_rate = `${maybeSampleRate}`;\n }\n\n // We don't want to have a transaction name in the DSC if the source is \"url\" because URLs might contain PII\n const source = this.metadata.source;\n if (source && source !== 'url') {\n dsc.transaction = this.name;\n }\n\n if (this.sampled !== undefined) {\n dsc.sampled = String(this.sampled);\n }\n\n // Uncomment if we want to make DSC immutable\n // this._frozenDynamicSamplingContext = dsc;\n\n return dsc;\n }\n\n /**\n * Override the current hub with a new one.\n * Used if you want another hub to finish the transaction.\n *\n * @internal\n */\n public setHub(hub: Hub): void {\n this._hub = hub;\n }\n}\n","/* eslint-disable max-lines */\nimport type { TransactionContext } from '@sentry/types';\nimport { logger, timestampInSeconds } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport type { Span } from './span';\nimport { SpanRecorder } from './span';\nimport { Transaction } from './transaction';\n\nexport const TRACING_DEFAULTS = {\n idleTimeout: 1000,\n finalTimeout: 30000,\n heartbeatInterval: 5000,\n};\n\nconst FINISH_REASON_TAG = 'finishReason';\n\nconst IDLE_TRANSACTION_FINISH_REASONS = [\n 'heartbeatFailed',\n 'idleTimeout',\n 'documentHidden',\n 'finalTimeout',\n 'externalFinish',\n 'cancelled',\n];\n\n/**\n * @inheritDoc\n */\nexport class IdleTransactionSpanRecorder extends SpanRecorder {\n public constructor(\n private readonly _pushActivity: (id: string) => void,\n private readonly _popActivity: (id: string) => void,\n public transactionSpanId: string,\n maxlen?: number,\n ) {\n super(maxlen);\n }\n\n /**\n * @inheritDoc\n */\n public add(span: Span): void {\n // We should make sure we do not push and pop activities for\n // the transaction that this span recorder belongs to.\n if (span.spanId !== this.transactionSpanId) {\n // We patch span.finish() to pop an activity after setting an endTimestamp.\n span.finish = (endTimestamp?: number) => {\n span.endTimestamp = typeof endTimestamp === 'number' ? endTimestamp : timestampInSeconds();\n this._popActivity(span.spanId);\n };\n\n // We should only push new activities if the span does not have an end timestamp.\n if (span.endTimestamp === undefined) {\n this._pushActivity(span.spanId);\n }\n }\n\n super.add(span);\n }\n}\n\nexport type BeforeFinishCallback = (transactionSpan: IdleTransaction, endTimestamp: number) => void;\n\n/**\n * An IdleTransaction is a transaction that automatically finishes. It does this by tracking child spans as activities.\n * You can have multiple IdleTransactions active, but if the `onScope` option is specified, the idle transaction will\n * put itself on the scope on creation.\n */\nexport class IdleTransaction extends Transaction {\n // Activities store a list of active spans\n public activities: Record<string, boolean>;\n // Track state of activities in previous heartbeat\n private _prevHeartbeatString: string | undefined;\n\n // Amount of times heartbeat has counted. Will cause transaction to finish after 3 beats.\n private _heartbeatCounter: number;\n\n // We should not use heartbeat if we finished a transaction\n private _finished: boolean;\n\n // Idle timeout was canceled and we should finish the transaction with the last span end.\n private _idleTimeoutCanceledPermanently: boolean;\n\n private readonly _beforeFinishCallbacks: BeforeFinishCallback[];\n\n /**\n * Timer that tracks Transaction idleTimeout\n */\n private _idleTimeoutID: ReturnType<typeof setTimeout> | undefined;\n\n private _finishReason: (typeof IDLE_TRANSACTION_FINISH_REASONS)[number];\n\n public constructor(\n transactionContext: TransactionContext,\n private readonly _idleHub: Hub,\n /**\n * The time to wait in ms until the idle transaction will be finished. This timer is started each time\n * there are no active spans on this transaction.\n */\n private readonly _idleTimeout: number = TRACING_DEFAULTS.idleTimeout,\n /**\n * The final value in ms that a transaction cannot exceed\n */\n private readonly _finalTimeout: number = TRACING_DEFAULTS.finalTimeout,\n private readonly _heartbeatInterval: number = TRACING_DEFAULTS.heartbeatInterval,\n // Whether or not the transaction should put itself on the scope when it starts and pop itself off when it ends\n private readonly _onScope: boolean = false,\n ) {\n super(transactionContext, _idleHub);\n\n this.activities = {};\n this._heartbeatCounter = 0;\n this._finished = false;\n this._idleTimeoutCanceledPermanently = false;\n this._beforeFinishCallbacks = [];\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[4];\n\n if (_onScope) {\n // We set the transaction here on the scope so error events pick up the trace\n // context and attach it to the error.\n __DEBUG_BUILD__ && logger.log(`Setting idle transaction on scope. Span ID: ${this.spanId}`);\n _idleHub.configureScope(scope => scope.setSpan(this));\n }\n\n this._restartIdleTimeout();\n setTimeout(() => {\n if (!this._finished) {\n this.setStatus('deadline_exceeded');\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[3];\n this.finish();\n }\n }, this._finalTimeout);\n }\n\n /** {@inheritDoc} */\n public finish(endTimestamp: number = timestampInSeconds()): string | undefined {\n this._finished = true;\n this.activities = {};\n\n if (this.op === 'ui.action.click') {\n this.setTag(FINISH_REASON_TAG, this._finishReason);\n }\n\n if (this.spanRecorder) {\n __DEBUG_BUILD__ &&\n logger.log('[Tracing] finishing IdleTransaction', new Date(endTimestamp * 1000).toISOString(), this.op);\n\n for (const callback of this._beforeFinishCallbacks) {\n callback(this, endTimestamp);\n }\n\n this.spanRecorder.spans = this.spanRecorder.spans.filter((span: Span) => {\n // If we are dealing with the transaction itself, we just return it\n if (span.spanId === this.spanId) {\n return true;\n }\n\n // We cancel all pending spans with status \"cancelled\" to indicate the idle transaction was finished early\n if (!span.endTimestamp) {\n span.endTimestamp = endTimestamp;\n span.setStatus('cancelled');\n __DEBUG_BUILD__ &&\n logger.log('[Tracing] cancelling span since transaction ended early', JSON.stringify(span, undefined, 2));\n }\n\n const spanStartedBeforeTransactionFinish = span.startTimestamp < endTimestamp;\n\n // Add a delta with idle timeout so that we prevent false positives\n const timeoutWithMarginOfError = (this._finalTimeout + this._idleTimeout) / 1000;\n const spanEndedBeforeFinalTimeout = span.endTimestamp - this.startTimestamp < timeoutWithMarginOfError;\n\n if (__DEBUG_BUILD__) {\n const stringifiedSpan = JSON.stringify(span, undefined, 2);\n if (!spanStartedBeforeTransactionFinish) {\n logger.log('[Tracing] discarding Span since it happened after Transaction was finished', stringifiedSpan);\n } else if (!spanEndedBeforeFinalTimeout) {\n logger.log('[Tracing] discarding Span since it finished after Transaction final timeout', stringifiedSpan);\n }\n }\n\n return spanStartedBeforeTransactionFinish && spanEndedBeforeFinalTimeout;\n });\n\n __DEBUG_BUILD__ && logger.log('[Tracing] flushing IdleTransaction');\n } else {\n __DEBUG_BUILD__ && logger.log('[Tracing] No active IdleTransaction');\n }\n\n // if `this._onScope` is `true`, the transaction put itself on the scope when it started\n if (this._onScope) {\n const scope = this._idleHub.getScope();\n if (scope.getTransaction() === this) {\n scope.setSpan(undefined);\n }\n }\n\n return super.finish(endTimestamp);\n }\n\n /**\n * Register a callback function that gets excecuted before the transaction finishes.\n * Useful for cleanup or if you want to add any additional spans based on current context.\n *\n * This is exposed because users have no other way of running something before an idle transaction\n * finishes.\n */\n public registerBeforeFinishCallback(callback: BeforeFinishCallback): void {\n this._beforeFinishCallbacks.push(callback);\n }\n\n /**\n * @inheritDoc\n */\n public initSpanRecorder(maxlen?: number): void {\n if (!this.spanRecorder) {\n const pushActivity = (id: string): void => {\n if (this._finished) {\n return;\n }\n this._pushActivity(id);\n };\n const popActivity = (id: string): void => {\n if (this._finished) {\n return;\n }\n this._popActivity(id);\n };\n\n this.spanRecorder = new IdleTransactionSpanRecorder(pushActivity, popActivity, this.spanId, maxlen);\n\n // Start heartbeat so that transactions do not run forever.\n __DEBUG_BUILD__ && logger.log('Starting heartbeat');\n this._pingHeartbeat();\n }\n this.spanRecorder.add(this);\n }\n\n /**\n * Cancels the existing idle timeout, if there is one.\n * @param restartOnChildSpanChange Default is `true`.\n * If set to false the transaction will end\n * with the last child span.\n */\n public cancelIdleTimeout(\n endTimestamp?: Parameters<IdleTransaction['finish']>[0],\n {\n restartOnChildSpanChange,\n }: {\n restartOnChildSpanChange?: boolean;\n } = {\n restartOnChildSpanChange: true,\n },\n ): void {\n this._idleTimeoutCanceledPermanently = restartOnChildSpanChange === false;\n if (this._idleTimeoutID) {\n clearTimeout(this._idleTimeoutID);\n this._idleTimeoutID = undefined;\n\n if (Object.keys(this.activities).length === 0 && this._idleTimeoutCanceledPermanently) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[5];\n this.finish(endTimestamp);\n }\n }\n }\n\n /**\n * Temporary method used to externally set the transaction's `finishReason`\n *\n * ** WARNING**\n * This is for the purpose of experimentation only and will be removed in the near future, do not use!\n *\n * @internal\n *\n */\n public setFinishReason(reason: string): void {\n this._finishReason = reason;\n }\n\n /**\n * Restarts idle timeout, if there is no running idle timeout it will start one.\n */\n private _restartIdleTimeout(endTimestamp?: Parameters<IdleTransaction['finish']>[0]): void {\n this.cancelIdleTimeout();\n this._idleTimeoutID = setTimeout(() => {\n if (!this._finished && Object.keys(this.activities).length === 0) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[1];\n this.finish(endTimestamp);\n }\n }, this._idleTimeout);\n }\n\n /**\n * Start tracking a specific activity.\n * @param spanId The span id that represents the activity\n */\n private _pushActivity(spanId: string): void {\n this.cancelIdleTimeout(undefined, { restartOnChildSpanChange: !this._idleTimeoutCanceledPermanently });\n __DEBUG_BUILD__ && logger.log(`[Tracing] pushActivity: ${spanId}`);\n this.activities[spanId] = true;\n __DEBUG_BUILD__ && logger.log('[Tracing] new activities count', Object.keys(this.activities).length);\n }\n\n /**\n * Remove an activity from usage\n * @param spanId The span id that represents the activity\n */\n private _popActivity(spanId: string): void {\n if (this.activities[spanId]) {\n __DEBUG_BUILD__ && logger.log(`[Tracing] popActivity ${spanId}`);\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this.activities[spanId];\n __DEBUG_BUILD__ && logger.log('[Tracing] new activities count', Object.keys(this.activities).length);\n }\n\n if (Object.keys(this.activities).length === 0) {\n const endTimestamp = timestampInSeconds();\n if (this._idleTimeoutCanceledPermanently) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[5];\n this.finish(endTimestamp);\n } else {\n // We need to add the timeout here to have the real endtimestamp of the transaction\n // Remember timestampInSeconds is in seconds, timeout is in ms\n this._restartIdleTimeout(endTimestamp + this._idleTimeout / 1000);\n }\n }\n }\n\n /**\n * Checks when entries of this.activities are not changing for 3 beats.\n * If this occurs we finish the transaction.\n */\n private _beat(): void {\n // We should not be running heartbeat if the idle transaction is finished.\n if (this._finished) {\n return;\n }\n\n const heartbeatString = Object.keys(this.activities).join('');\n\n if (heartbeatString === this._prevHeartbeatString) {\n this._heartbeatCounter++;\n } else {\n this._heartbeatCounter = 1;\n }\n\n this._prevHeartbeatString = heartbeatString;\n\n if (this._heartbeatCounter >= 3) {\n __DEBUG_BUILD__ && logger.log('[Tracing] Transaction finished because of no change for 3 heart beats');\n this.setStatus('deadline_exceeded');\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[0];\n this.finish();\n } else {\n this._pingHeartbeat();\n }\n }\n\n /**\n * Pings the heartbeat\n */\n private _pingHeartbeat(): void {\n __DEBUG_BUILD__ && logger.log(`pinging Heartbeat -> current counter: ${this._heartbeatCounter}`);\n setTimeout(() => {\n this._beat();\n }, this._heartbeatInterval);\n }\n}\n","import type { Options } from '@sentry/types';\n\nimport { getCurrentHub } from '../hub';\n\n// Treeshakable guard to remove all code related to tracing\ndeclare const __SENTRY_TRACING__: boolean | undefined;\n\n/**\n * Determines if tracing is currently enabled.\n *\n * Tracing is enabled when at least one of `tracesSampleRate` and `tracesSampler` is defined in the SDK config.\n */\nexport function hasTracingEnabled(\n maybeOptions?: Pick<Options, 'tracesSampleRate' | 'tracesSampler' | 'enableTracing'> | undefined,\n): boolean {\n if (typeof __SENTRY_TRACING__ === 'boolean' && !__SENTRY_TRACING__) {\n return false;\n }\n\n const client = getCurrentHub().getClient();\n const options = maybeOptions || (client && client.getOptions());\n return !!options && (options.enableTracing || 'tracesSampleRate' in options || 'tracesSampler' in options);\n}\n","import type { Transaction } from '@sentry/types';\n\nimport type { Hub } from '../hub';\nimport { getCurrentHub } from '../hub';\n\n/**\n * The `extractTraceparentData` function and `TRACEPARENT_REGEXP` constant used\n * to be declared in this file. It was later moved into `@sentry/utils` as part of a\n * move to remove `@sentry/tracing` dependencies from `@sentry/node` (`extractTraceparentData`\n * is the only tracing function used by `@sentry/node`).\n *\n * These exports are kept here for backwards compatability's sake.\n *\n * TODO(v7): Reorganize these exports\n *\n * See https://github.com/getsentry/sentry-javascript/issues/4642 for more details.\n */\nexport { TRACEPARENT_REGEXP, extractTraceparentData } from '@sentry/utils';\n\n/** Grabs active transaction off scope, if any */\nexport function getActiveTransaction<T extends Transaction>(maybeHub?: Hub): T | undefined {\n const hub = maybeHub || getCurrentHub();\n const scope = hub.getScope();\n return scope.getTransaction() as T | undefined;\n}\n\n// so it can be used in manual instrumentation without necessitating a hard dependency on @sentry/utils\nexport { stripUrlQueryAndFragment } from '@sentry/utils';\n","import { addInstrumentationHandler, logger } from '@sentry/utils';\n\nimport type { SpanStatusType } from './span';\nimport { getActiveTransaction } from './utils';\n\nlet errorsInstrumented = false;\n\n/**\n * Configures global error listeners\n */\nexport function registerErrorInstrumentation(): void {\n if (errorsInstrumented) {\n return;\n }\n\n errorsInstrumented = true;\n addInstrumentationHandler('error', errorCallback);\n addInstrumentationHandler('unhandledrejection', errorCallback);\n}\n\n/**\n * If an error or unhandled promise occurs, we mark the active transaction as failed\n */\nfunction errorCallback(): void {\n const activeTransaction = getActiveTransaction();\n if (activeTransaction) {\n const status: SpanStatusType = 'internal_error';\n __DEBUG_BUILD__ && logger.log(`[Tracing] Transaction: ${status} -> Global error occured`);\n activeTransaction.setStatus(status);\n }\n}\n\n// The function name will be lost when bundling but we need to be able to identify this listener later to maintain the\n// node.js default exit behaviour\nerrorCallback.tag = 'sentry_tracingErrorCallback';\n","import type { ClientOptions, CustomSamplingContext, Options, SamplingContext, TransactionContext } from '@sentry/types';\nimport { isNaN, logger } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport { getMainCarrier } from '../hub';\nimport { hasTracingEnabled } from '../utils/hasTracingEnabled';\nimport { registerErrorInstrumentation } from './errors';\nimport { IdleTransaction } from './idletransaction';\nimport { Transaction } from './transaction';\n\n/** Returns all trace headers that are currently on the top scope. */\nfunction traceHeaders(this: Hub): { [key: string]: string } {\n const scope = this.getScope();\n const span = scope.getSpan();\n\n return span\n ? {\n 'sentry-trace': span.toTraceparent(),\n }\n : {};\n}\n\n/**\n * Makes a sampling decision for the given transaction and stores it on the transaction.\n *\n * Called every time a transaction is created. Only transactions which emerge with a `sampled` value of `true` will be\n * sent to Sentry.\n *\n * @param transaction: The transaction needing a sampling decision\n * @param options: The current client's options, so we can access `tracesSampleRate` and/or `tracesSampler`\n * @param samplingContext: Default and user-provided data which may be used to help make the decision\n *\n * @returns The given transaction with its `sampled` value set\n */\nfunction sample<T extends Transaction>(\n transaction: T,\n options: Pick<Options, 'tracesSampleRate' | 'tracesSampler' | 'enableTracing'>,\n samplingContext: SamplingContext,\n): T {\n // nothing to do if tracing is not enabled\n if (!hasTracingEnabled(options)) {\n transaction.sampled = false;\n return transaction;\n }\n\n // if the user has forced a sampling decision by passing a `sampled` value in their transaction context, go with that\n if (transaction.sampled !== undefined) {\n transaction.setMetadata({\n sampleRate: Number(transaction.sampled),\n });\n return transaction;\n }\n\n // we would have bailed already if neither `tracesSampler` nor `tracesSampleRate` nor `enableTracing` were defined, so one of these should\n // work; prefer the hook if so\n let sampleRate;\n if (typeof options.tracesSampler === 'function') {\n sampleRate = options.tracesSampler(samplingContext);\n transaction.setMetadata({\n sampleRate: Number(sampleRate),\n });\n } else if (samplingContext.parentSampled !== undefined) {\n sampleRate = samplingContext.parentSampled;\n } else if (typeof options.tracesSampleRate !== 'undefined') {\n sampleRate = options.tracesSampleRate;\n transaction.setMetadata({\n sampleRate: Number(sampleRate),\n });\n } else {\n // When `enableTracing === true`, we use a sample rate of 100%\n sampleRate = 1;\n transaction.setMetadata({\n sampleRate,\n });\n }\n\n // Since this is coming from the user (or from a function provided by the user), who knows what we might get. (The\n // only valid values are booleans or numbers between 0 and 1.)\n if (!isValidSampleRate(sampleRate)) {\n __DEBUG_BUILD__ && logger.warn('[Tracing] Discarding transaction because of invalid sample rate.');\n transaction.sampled = false;\n return transaction;\n }\n\n // if the function returned 0 (or false), or if `tracesSampleRate` is 0, it's a sign the transaction should be dropped\n if (!sampleRate) {\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Discarding transaction because ${\n typeof options.tracesSampler === 'function'\n ? 'tracesSampler returned 0 or false'\n : 'a negative sampling decision was inherited or tracesSampleRate is set to 0'\n }`,\n );\n transaction.sampled = false;\n return transaction;\n }\n\n // Now we roll the dice. Math.random is inclusive of 0, but not of 1, so strict < is safe here. In case sampleRate is\n // a boolean, the < comparison will cause it to be automatically cast to 1 if it's true and 0 if it's false.\n transaction.sampled = Math.random() < (sampleRate as number | boolean);\n\n // if we're not going to keep it, we're done\n if (!transaction.sampled) {\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Discarding transaction because it's not included in the random sample (sampling rate = ${Number(\n sampleRate,\n )})`,\n );\n return transaction;\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] starting ${transaction.op} transaction - ${transaction.name}`);\n return transaction;\n}\n\n/**\n * Checks the given sample rate to make sure it is valid type and value (a boolean, or a number between 0 and 1).\n */\nfunction isValidSampleRate(rate: unknown): boolean {\n // we need to check NaN explicitly because it's of type 'number' and therefore wouldn't get caught by this typecheck\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (isNaN(rate) || !(typeof rate === 'number' || typeof rate === 'boolean')) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `[Tracing] Given sample rate is invalid. Sample rate must be a boolean or a number between 0 and 1. Got ${JSON.stringify(\n rate,\n )} of type ${JSON.stringify(typeof rate)}.`,\n );\n return false;\n }\n\n // in case sampleRate is a boolean, it will get automatically cast to 1 if it's true and 0 if it's false\n if (rate < 0 || rate > 1) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Given sample rate is invalid. Sample rate must be between 0 and 1. Got ${rate}.`);\n return false;\n }\n return true;\n}\n\n/**\n * Creates a new transaction and adds a sampling decision if it doesn't yet have one.\n *\n * The Hub.startTransaction method delegates to this method to do its work, passing the Hub instance in as `this`, as if\n * it had been called on the hub directly. Exists as a separate function so that it can be injected into the class as an\n * \"extension method.\"\n *\n * @param this: The Hub starting the transaction\n * @param transactionContext: Data used to configure the transaction\n * @param CustomSamplingContext: Optional data to be provided to the `tracesSampler` function (if any)\n *\n * @returns The new transaction\n *\n * @see {@link Hub.startTransaction}\n */\nfunction _startTransaction(\n this: Hub,\n transactionContext: TransactionContext,\n customSamplingContext?: CustomSamplingContext,\n): Transaction {\n const client = this.getClient();\n const options: Partial<ClientOptions> = (client && client.getOptions()) || {};\n\n const configInstrumenter = options.instrumenter || 'sentry';\n const transactionInstrumenter = transactionContext.instrumenter || 'sentry';\n\n if (configInstrumenter !== transactionInstrumenter) {\n __DEBUG_BUILD__ &&\n logger.error(\n `A transaction was started with instrumenter=\\`${transactionInstrumenter}\\`, but the SDK is configured with the \\`${configInstrumenter}\\` instrumenter.\nThe transaction will not be sampled. Please use the ${configInstrumenter} instrumentation to start transactions.`,\n );\n\n transactionContext.sampled = false;\n }\n\n let transaction = new Transaction(transactionContext, this);\n transaction = sample(transaction, options, {\n parentSampled: transactionContext.parentSampled,\n transactionContext,\n ...customSamplingContext,\n });\n if (transaction.sampled) {\n transaction.initSpanRecorder(options._experiments && (options._experiments.maxSpans as number));\n }\n if (client && client.emit) {\n client.emit('startTransaction', transaction);\n }\n return transaction;\n}\n\n/**\n * Create new idle transaction.\n */\nexport function startIdleTransaction(\n hub: Hub,\n transactionContext: TransactionContext,\n idleTimeout: number,\n finalTimeout: number,\n onScope?: boolean,\n customSamplingContext?: CustomSamplingContext,\n heartbeatInterval?: number,\n): IdleTransaction {\n const client = hub.getClient();\n const options: Partial<ClientOptions> = (client && client.getOptions()) || {};\n\n let transaction = new IdleTransaction(transactionContext, hub, idleTimeout, finalTimeout, heartbeatInterval, onScope);\n transaction = sample(transaction, options, {\n parentSampled: transactionContext.parentSampled,\n transactionContext,\n ...customSamplingContext,\n });\n if (transaction.sampled) {\n transaction.initSpanRecorder(options._experiments && (options._experiments.maxSpans as number));\n }\n if (client && client.emit) {\n client.emit('startTransaction', transaction);\n }\n return transaction;\n}\n\n/**\n * Adds tracing extensions to the global hub.\n */\nexport function addTracingExtensions(): void {\n const carrier = getMainCarrier();\n if (!carrier.__SENTRY__) {\n return;\n }\n carrier.__SENTRY__.extensions = carrier.__SENTRY__.extensions || {};\n if (!carrier.__SENTRY__.extensions.startTransaction) {\n carrier.__SENTRY__.extensions.startTransaction = _startTransaction;\n }\n if (!carrier.__SENTRY__.extensions.traceHeaders) {\n carrier.__SENTRY__.extensions.traceHeaders = traceHeaders;\n }\n\n registerErrorInstrumentation();\n}\n","import { GLOBAL_OBJ } from '@sentry/utils';\n\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ & Window;\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { Metric, ReportCallback } from '../types';\n\nexport const bindReporter = (\n callback: ReportCallback,\n metric: Metric,\n reportAllChanges?: boolean,\n): ((forceReport?: boolean) => void) => {\n let prevValue: number;\n let delta: number;\n return (forceReport?: boolean) => {\n if (metric.value >= 0) {\n if (forceReport || reportAllChanges) {\n delta = metric.value - (prevValue || 0);\n\n // Report the metric if there's a non-zero delta or if no previous\n // value exists (which can happen in the case of the document becoming\n // hidden when the metric value is 0).\n // See: https://github.com/GoogleChrome/web-vitals/issues/14\n if (delta || prevValue === undefined) {\n prevValue = metric.value;\n metric.delta = delta;\n callback(metric);\n }\n }\n }\n };\n};\n","/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport type { NavigationTimingPolyfillEntry } from '../types';\n\nconst getNavigationEntryFromPerformanceTiming = (): NavigationTimingPolyfillEntry => {\n // eslint-disable-next-line deprecation/deprecation\n const timing = WINDOW.performance.timing;\n // eslint-disable-next-line deprecation/deprecation\n const type = WINDOW.performance.navigation.type;\n\n const navigationEntry: { [key: string]: number | string } = {\n entryType: 'navigation',\n startTime: 0,\n type: type == 2 ? 'back_forward' : type === 1 ? 'reload' : 'navigate',\n };\n\n for (const key in timing) {\n if (key !== 'navigationStart' && key !== 'toJSON') {\n // eslint-disable-next-line deprecation/deprecation\n navigationEntry[key] = Math.max((timing[key as keyof PerformanceTiming] as number) - timing.navigationStart, 0);\n }\n }\n return navigationEntry as unknown as NavigationTimingPolyfillEntry;\n};\n\nexport const getNavigationEntry = (): PerformanceNavigationTiming | NavigationTimingPolyfillEntry | undefined => {\n if (WINDOW.__WEB_VITALS_POLYFILL__) {\n return (\n WINDOW.performance &&\n ((performance.getEntriesByType && performance.getEntriesByType('navigation')[0]) ||\n getNavigationEntryFromPerformanceTiming())\n );\n } else {\n return WINDOW.performance && performance.getEntriesByType && performance.getEntriesByType('navigation')[0];\n }\n};\n","/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getNavigationEntry } from './getNavigationEntry';\n\nexport const getActivationStart = (): number => {\n const navEntry = getNavigationEntry();\n return (navEntry && navEntry.activationStart) || 0;\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport type { Metric } from '../types';\nimport { generateUniqueID } from './generateUniqueID';\nimport { getActivationStart } from './getActivationStart';\nimport { getNavigationEntry } from './getNavigationEntry';\n\nexport const initMetric = (name: Metric['name'], value?: number): Metric => {\n const navEntry = getNavigationEntry();\n let navigationType: Metric['navigationType'] = 'navigate';\n\n if (navEntry) {\n if (WINDOW.document.prerendering || getActivationStart() > 0) {\n navigationType = 'prerender';\n } else {\n navigationType = navEntry.type.replace(/_/g, '-') as Metric['navigationType'];\n }\n }\n\n return {\n name,\n value: typeof value === 'undefined' ? -1 : value,\n rating: 'good', // Will be updated if the value changes.\n delta: 0,\n entries: [],\n id: generateUniqueID(),\n navigationType,\n };\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Performantly generate a unique, 30-char string by combining a version\n * number, the current timestamp with a 13-digit number integer.\n * @return {string}\n */\nexport const generateUniqueID = (): string => {\n return `v3-${Date.now()}-${Math.floor(Math.random() * (9e12 - 1)) + 1e12}`;\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { FirstInputPolyfillEntry, NavigationTimingPolyfillEntry, PerformancePaintTiming } from '../types';\n\nexport interface PerformanceEntryHandler {\n (entry: PerformanceEntry): void;\n}\n\ninterface PerformanceEntryMap {\n event: PerformanceEventTiming[];\n paint: PerformancePaintTiming[];\n 'layout-shift': LayoutShift[];\n 'largest-contentful-paint': LargestContentfulPaint[];\n 'first-input': PerformanceEventTiming[] | FirstInputPolyfillEntry[];\n navigation: PerformanceNavigationTiming[] | NavigationTimingPolyfillEntry[];\n resource: PerformanceResourceTiming[];\n longtask: PerformanceEntry[];\n}\n\n/**\n * Takes a performance entry type and a callback function, and creates a\n * `PerformanceObserver` instance that will observe the specified entry type\n * with buffering enabled and call the callback _for each entry_.\n *\n * This function also feature-detects entry support and wraps the logic in a\n * try/catch to avoid errors in unsupporting browsers.\n */\nexport const observe = <K extends keyof PerformanceEntryMap>(\n type: K,\n callback: (entries: PerformanceEntryMap[K]) => void,\n opts?: PerformanceObserverInit,\n): PerformanceObserver | undefined => {\n try {\n if (PerformanceObserver.supportedEntryTypes.includes(type)) {\n const po = new PerformanceObserver(list => {\n callback(list.getEntries() as PerformanceEntryMap[K]);\n });\n po.observe(\n Object.assign(\n {\n type,\n buffered: true,\n },\n opts || {},\n ) as PerformanceObserverInit,\n );\n return po;\n }\n } catch (e) {\n // Do nothing.\n }\n return;\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\n\nexport interface OnHiddenCallback {\n (event: Event): void;\n}\n\nexport const onHidden = (cb: OnHiddenCallback, once?: boolean): void => {\n const onHiddenOrPageHide = (event: Event): void => {\n if (event.type === 'pagehide' || WINDOW.document.visibilityState === 'hidden') {\n cb(event);\n if (once) {\n removeEventListener('visibilitychange', onHiddenOrPageHide, true);\n removeEventListener('pagehide', onHiddenOrPageHide, true);\n }\n }\n };\n addEventListener('visibilitychange', onHiddenOrPageHide, true);\n // Some browsers have buggy implementations of visibilitychange,\n // so we use pagehide in addition, just to be safe.\n addEventListener('pagehide', onHiddenOrPageHide, true);\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport { onHidden } from './onHidden';\n\nlet firstHiddenTime = -1;\n\nconst initHiddenTime = (): number => {\n // If the document is hidden and not prerendering, assume it was always\n // hidden and the page was loaded in the background.\n return WINDOW.document.visibilityState === 'hidden' && !WINDOW.document.prerendering ? 0 : Infinity;\n};\n\nconst trackChanges = (): void => {\n // Update the time if/when the document becomes hidden.\n onHidden(({ timeStamp }) => {\n firstHiddenTime = timeStamp;\n }, true);\n};\n\nexport const getVisibilityWatcher = (): {\n readonly firstHiddenTime: number;\n} => {\n if (firstHiddenTime < 0) {\n // If the document is hidden when this code runs, assume it was hidden\n // since navigation start. This isn't a perfect heuristic, but it's the\n // best we can do until an API is available to support querying past\n // visibilityState.\n firstHiddenTime = initHiddenTime();\n trackChanges();\n }\n return {\n get firstHiddenTime() {\n return firstHiddenTime;\n },\n };\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { getActivationStart } from './lib/getActivationStart';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { LCPMetric, ReportCallback, StopListening } from './types';\n\nconst reportedMetricIDs: Record<string, boolean> = {};\n\n/**\n * Calculates the [LCP](https://web.dev/lcp/) value for the current page and\n * calls the `callback` function once the value is ready (along with the\n * relevant `largest-contentful-paint` performance entry used to determine the\n * value). The reported value is a `DOMHighResTimeStamp`.\n */\nexport const onLCP = (onReport: ReportCallback): StopListening | undefined => {\n const visibilityWatcher = getVisibilityWatcher();\n const metric = initMetric('LCP');\n let report: ReturnType<typeof bindReporter>;\n\n const handleEntries = (entries: LCPMetric['entries']): void => {\n const lastEntry = entries[entries.length - 1] as LargestContentfulPaint;\n if (lastEntry) {\n // The startTime attribute returns the value of the renderTime if it is\n // not 0, and the value of the loadTime otherwise. The activationStart\n // reference is used because LCP should be relative to page activation\n // rather than navigation start if the page was prerendered.\n const value = Math.max(lastEntry.startTime - getActivationStart(), 0);\n\n // Only report if the page wasn't hidden prior to LCP.\n if (value < visibilityWatcher.firstHiddenTime) {\n metric.value = value;\n metric.entries = [lastEntry];\n report();\n }\n }\n };\n\n const po = observe('largest-contentful-paint', handleEntries);\n\n if (po) {\n report = bindReporter(onReport, metric);\n\n const stopListening = (): void => {\n if (!reportedMetricIDs[metric.id]) {\n handleEntries(po.takeRecords() as LCPMetric['entries']);\n po.disconnect();\n reportedMetricIDs[metric.id] = true;\n report(true);\n }\n };\n\n // Stop listening after input. Note: while scrolling is an input that\n // stop LCP observation, it's unreliable since it can be programmatically\n // generated. See: https://github.com/GoogleChrome/web-vitals/issues/75\n ['keydown', 'click'].forEach(type => {\n addEventListener(type, stopListening, { once: true, capture: true });\n });\n\n onHidden(stopListening, true);\n\n return stopListening;\n }\n\n return;\n};\n","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n\n return target;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}","import type { Transaction } from '@sentry/core';\nimport type { Span, SpanContext } from '@sentry/types';\n\n/**\n * Checks if a given value is a valid measurement value.\n */\nexport function isMeasurementValue(value: unknown): value is number {\n return typeof value === 'number' && isFinite(value);\n}\n\n/**\n * Helper function to start child on transactions. This function will make sure that the transaction will\n * use the start timestamp of the created child span if it is earlier than the transactions actual\n * start timestamp.\n */\nexport function _startChild(transaction: Transaction, { startTimestamp, ...ctx }: SpanContext): Span {\n if (startTimestamp && transaction.startTimestamp > startTimestamp) {\n transaction.startTimestamp = startTimestamp;\n }\n\n return transaction.startChild({\n startTimestamp,\n ...ctx,\n });\n}\n","/* eslint-disable max-lines */\nimport type { IdleTransaction, Transaction } from '@sentry/core';\nimport { getActiveTransaction } from '@sentry/core';\nimport type { Measurements } from '@sentry/types';\nimport { browserPerformanceTimeOrigin, htmlTreeAsString, logger } from '@sentry/utils';\n\nimport { WINDOW } from '../types';\nimport { onCLS } from '../web-vitals/getCLS';\nimport { onFID } from '../web-vitals/getFID';\nimport { onLCP } from '../web-vitals/getLCP';\nimport { getVisibilityWatcher } from '../web-vitals/lib/getVisibilityWatcher';\nimport { observe } from '../web-vitals/lib/observe';\nimport type { NavigatorDeviceMemory, NavigatorNetworkInformation } from '../web-vitals/types';\nimport { _startChild, isMeasurementValue } from './utils';\n\n/**\n * Converts from milliseconds to seconds\n * @param time time in ms\n */\nfunction msToSec(time: number): number {\n return time / 1000;\n}\n\nfunction getBrowserPerformanceAPI(): Performance | undefined {\n // @ts-ignore we want to make sure all of these are available, even if TS is sure they are\n return WINDOW && WINDOW.addEventListener && WINDOW.performance;\n}\n\nlet _performanceCursor: number = 0;\n\nlet _measurements: Measurements = {};\nlet _lcpEntry: LargestContentfulPaint | undefined;\nlet _clsEntry: LayoutShift | undefined;\n\n/**\n * Start tracking web vitals\n *\n * @returns A function that forces web vitals collection\n */\nexport function startTrackingWebVitals(): () => void {\n const performance = getBrowserPerformanceAPI();\n if (performance && browserPerformanceTimeOrigin) {\n // @ts-ignore we want to make sure all of these are available, even if TS is sure they are\n if (performance.mark) {\n WINDOW.performance.mark('sentry-tracing-init');\n }\n _trackFID();\n const clsCallback = _trackCLS();\n const lcpCallback = _trackLCP();\n\n return (): void => {\n if (clsCallback) {\n clsCallback();\n }\n if (lcpCallback) {\n lcpCallback();\n }\n };\n }\n\n return () => undefined;\n}\n\n/**\n * Start tracking long tasks.\n */\nexport function startTrackingLongTasks(): void {\n const entryHandler = (entries: PerformanceEntry[]): void => {\n for (const entry of entries) {\n const transaction = getActiveTransaction() as IdleTransaction | undefined;\n if (!transaction) {\n return;\n }\n const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n const duration = msToSec(entry.duration);\n\n transaction.startChild({\n description: 'Main UI thread blocked',\n op: 'ui.long-task',\n startTimestamp: startTime,\n endTimestamp: startTime + duration,\n });\n }\n };\n\n observe('longtask', entryHandler);\n}\n\n/**\n * Start tracking interaction events.\n */\nexport function startTrackingInteractions(): void {\n const entryHandler = (entries: PerformanceEventTiming[]): void => {\n for (const entry of entries) {\n const transaction = getActiveTransaction() as IdleTransaction | undefined;\n if (!transaction) {\n return;\n }\n\n if (entry.name === 'click') {\n const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n const duration = msToSec(entry.duration);\n\n transaction.startChild({\n description: htmlTreeAsString(entry.target),\n op: `ui.interaction.${entry.name}`,\n startTimestamp: startTime,\n endTimestamp: startTime + duration,\n });\n }\n }\n };\n\n observe('event', entryHandler, { durationThreshold: 0 });\n}\n\n/** Starts tracking the Cumulative Layout Shift on the current page. */\nfunction _trackCLS(): ReturnType<typeof onCLS> {\n // See:\n // https://web.dev/evolving-cls/\n // https://web.dev/cls-web-tooling/\n return onCLS(metric => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding CLS');\n _measurements['cls'] = { value: metric.value, unit: '' };\n _clsEntry = entry as LayoutShift;\n });\n}\n\n/** Starts tracking the Largest Contentful Paint on the current page. */\nfunction _trackLCP(): ReturnType<typeof onLCP> {\n return onLCP(metric => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding LCP');\n _measurements['lcp'] = { value: metric.value, unit: 'millisecond' };\n _lcpEntry = entry as LargestContentfulPaint;\n });\n}\n\n/** Starts tracking the First Input Delay on the current page. */\nfunction _trackFID(): void {\n onFID(metric => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n const timeOrigin = msToSec(browserPerformanceTimeOrigin as number);\n const startTime = msToSec(entry.startTime);\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FID');\n _measurements['fid'] = { value: metric.value, unit: 'millisecond' };\n _measurements['mark.fid'] = { value: timeOrigin + startTime, unit: 'second' };\n });\n}\n\n/** Add performance related spans to a transaction */\nexport function addPerformanceEntries(transaction: Transaction): void {\n const performance = getBrowserPerformanceAPI();\n if (!performance || !WINDOW.performance.getEntries || !browserPerformanceTimeOrigin) {\n // Gatekeeper if performance API not available\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Tracing] Adding & adjusting spans using Performance API');\n const timeOrigin = msToSec(browserPerformanceTimeOrigin);\n\n const performanceEntries = performance.getEntries();\n\n let responseStartTimestamp: number | undefined;\n let requestStartTimestamp: number | undefined;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n performanceEntries.slice(_performanceCursor).forEach((entry: Record<string, any>) => {\n const startTime = msToSec(entry.startTime);\n const duration = msToSec(entry.duration);\n\n if (transaction.op === 'navigation' && timeOrigin + startTime < transaction.startTimestamp) {\n return;\n }\n\n switch (entry.entryType) {\n case 'navigation': {\n _addNavigationSpans(transaction, entry, timeOrigin);\n responseStartTimestamp = timeOrigin + msToSec(entry.responseStart);\n requestStartTimestamp = timeOrigin + msToSec(entry.requestStart);\n break;\n }\n case 'mark':\n case 'paint':\n case 'measure': {\n _addMeasureSpans(transaction, entry, startTime, duration, timeOrigin);\n\n // capture web vitals\n const firstHidden = getVisibilityWatcher();\n // Only report if the page wasn't hidden prior to the web vital.\n const shouldRecord = entry.startTime < firstHidden.firstHiddenTime;\n\n if (entry.name === 'first-paint' && shouldRecord) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FP');\n _measurements['fp'] = { value: entry.startTime, unit: 'millisecond' };\n }\n if (entry.name === 'first-contentful-paint' && shouldRecord) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FCP');\n _measurements['fcp'] = { value: entry.startTime, unit: 'millisecond' };\n }\n break;\n }\n case 'resource': {\n const resourceName = (entry.name as string).replace(WINDOW.location.origin, '');\n _addResourceSpans(transaction, entry, resourceName, startTime, duration, timeOrigin);\n break;\n }\n default:\n // Ignore other entry types.\n }\n });\n\n _performanceCursor = Math.max(performanceEntries.length - 1, 0);\n\n _trackNavigator(transaction);\n\n // Measurements are only available for pageload transactions\n if (transaction.op === 'pageload') {\n // Generate TTFB (Time to First Byte), which measured as the time between the beginning of the transaction and the\n // start of the response in milliseconds\n if (typeof responseStartTimestamp === 'number') {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding TTFB');\n _measurements['ttfb'] = {\n value: (responseStartTimestamp - transaction.startTimestamp) * 1000,\n unit: 'millisecond',\n };\n\n if (typeof requestStartTimestamp === 'number' && requestStartTimestamp <= responseStartTimestamp) {\n // Capture the time spent making the request and receiving the first byte of the response.\n // This is the time between the start of the request and the start of the response in milliseconds.\n _measurements['ttfb.requestTime'] = {\n value: (responseStartTimestamp - requestStartTimestamp) * 1000,\n unit: 'millisecond',\n };\n }\n }\n\n ['fcp', 'fp', 'lcp'].forEach(name => {\n if (!_measurements[name] || timeOrigin >= transaction.startTimestamp) {\n return;\n }\n // The web vitals, fcp, fp, lcp, and ttfb, all measure relative to timeOrigin.\n // Unfortunately, timeOrigin is not captured within the transaction span data, so these web vitals will need\n // to be adjusted to be relative to transaction.startTimestamp.\n const oldValue = _measurements[name].value;\n const measurementTimestamp = timeOrigin + msToSec(oldValue);\n\n // normalizedValue should be in milliseconds\n const normalizedValue = Math.abs((measurementTimestamp - transaction.startTimestamp) * 1000);\n const delta = normalizedValue - oldValue;\n\n __DEBUG_BUILD__ &&\n logger.log(`[Measurements] Normalized ${name} from ${oldValue} to ${normalizedValue} (${delta})`);\n _measurements[name].value = normalizedValue;\n });\n\n const fidMark = _measurements['mark.fid'];\n if (fidMark && _measurements['fid']) {\n // create span for FID\n _startChild(transaction, {\n description: 'first input delay',\n endTimestamp: fidMark.value + msToSec(_measurements['fid'].value),\n op: 'ui.action',\n startTimestamp: fidMark.value,\n });\n\n // Delete mark.fid as we don't want it to be part of final payload\n delete _measurements['mark.fid'];\n }\n\n // If FCP is not recorded we should not record the cls value\n // according to the new definition of CLS.\n if (!('fcp' in _measurements)) {\n delete _measurements.cls;\n }\n\n Object.keys(_measurements).forEach(measurementName => {\n transaction.setMeasurement(\n measurementName,\n _measurements[measurementName].value,\n _measurements[measurementName].unit,\n );\n });\n\n _tagMetricInfo(transaction);\n }\n\n _lcpEntry = undefined;\n _clsEntry = undefined;\n _measurements = {};\n}\n\n/** Create measure related spans */\nexport function _addMeasureSpans(\n transaction: Transaction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n entry: Record<string, any>,\n startTime: number,\n duration: number,\n timeOrigin: number,\n): number {\n const measureStartTimestamp = timeOrigin + startTime;\n const measureEndTimestamp = measureStartTimestamp + duration;\n\n _startChild(transaction, {\n description: entry.name as string,\n endTimestamp: measureEndTimestamp,\n op: entry.entryType as string,\n startTimestamp: measureStartTimestamp,\n });\n\n return measureStartTimestamp;\n}\n\n/** Instrument navigation entries */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _addNavigationSpans(transaction: Transaction, entry: Record<string, any>, timeOrigin: number): void {\n ['unloadEvent', 'redirect', 'domContentLoadedEvent', 'loadEvent', 'connect'].forEach(event => {\n _addPerformanceNavigationTiming(transaction, entry, event, timeOrigin);\n });\n _addPerformanceNavigationTiming(transaction, entry, 'secureConnection', timeOrigin, 'TLS/SSL', 'connectEnd');\n _addPerformanceNavigationTiming(transaction, entry, 'fetch', timeOrigin, 'cache', 'domainLookupStart');\n _addPerformanceNavigationTiming(transaction, entry, 'domainLookup', timeOrigin, 'DNS');\n _addRequest(transaction, entry, timeOrigin);\n}\n\n/** Create performance navigation related spans */\nfunction _addPerformanceNavigationTiming(\n transaction: Transaction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n entry: Record<string, any>,\n event: string,\n timeOrigin: number,\n description?: string,\n eventEnd?: string,\n): void {\n const end = eventEnd ? (entry[eventEnd] as number | undefined) : (entry[`${event}End`] as number | undefined);\n const start = entry[`${event}Start`] as number | undefined;\n if (!start || !end) {\n return;\n }\n _startChild(transaction, {\n op: 'browser',\n description: description || event,\n startTimestamp: timeOrigin + msToSec(start),\n endTimestamp: timeOrigin + msToSec(end),\n });\n}\n\n/** Create request and response related spans */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _addRequest(transaction: Transaction, entry: Record<string, any>, timeOrigin: number): void {\n _startChild(transaction, {\n op: 'browser',\n description: 'request',\n startTimestamp: timeOrigin + msToSec(entry.requestStart as number),\n endTimestamp: timeOrigin + msToSec(entry.responseEnd as number),\n });\n\n _startChild(transaction, {\n op: 'browser',\n description: 'response',\n startTimestamp: timeOrigin + msToSec(entry.responseStart as number),\n endTimestamp: timeOrigin + msToSec(entry.responseEnd as number),\n });\n}\n\nexport interface ResourceEntry extends Record<string, unknown> {\n initiatorType?: string;\n transferSize?: number;\n encodedBodySize?: number;\n decodedBodySize?: number;\n renderBlockingStatus?: string;\n}\n\n/** Create resource-related spans */\nexport function _addResourceSpans(\n transaction: Transaction,\n entry: ResourceEntry,\n resourceName: string,\n startTime: number,\n duration: number,\n timeOrigin: number,\n): void {\n // we already instrument based on fetch and xhr, so we don't need to\n // duplicate spans here.\n if (entry.initiatorType === 'xmlhttprequest' || entry.initiatorType === 'fetch') {\n return;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const data: Record<string, any> = {};\n if ('transferSize' in entry) {\n data['http.response_transfer_size'] = entry.transferSize;\n }\n if ('encodedBodySize' in entry) {\n data['http.response_content_length'] = entry.encodedBodySize;\n }\n if ('decodedBodySize' in entry) {\n data['http.decoded_response_content_length'] = entry.decodedBodySize;\n }\n if ('renderBlockingStatus' in entry) {\n data['resource.render_blocking_status'] = entry.renderBlockingStatus;\n }\n\n const startTimestamp = timeOrigin + startTime;\n const endTimestamp = startTimestamp + duration;\n\n _startChild(transaction, {\n description: resourceName,\n endTimestamp,\n op: entry.initiatorType ? `resource.${entry.initiatorType}` : 'resource.other',\n startTimestamp,\n data,\n });\n}\n\n/**\n * Capture the information of the user agent.\n */\nfunction _trackNavigator(transaction: Transaction): void {\n const navigator = WINDOW.navigator as null | (Navigator & NavigatorNetworkInformation & NavigatorDeviceMemory);\n if (!navigator) {\n return;\n }\n\n // track network connectivity\n const connection = navigator.connection;\n if (connection) {\n if (connection.effectiveType) {\n transaction.setTag('effectiveConnectionType', connection.effectiveType);\n }\n\n if (connection.type) {\n transaction.setTag('connectionType', connection.type);\n }\n\n if (isMeasurementValue(connection.rtt)) {\n _measurements['connection.rtt'] = { value: connection.rtt, unit: 'millisecond' };\n }\n }\n\n if (isMeasurementValue(navigator.deviceMemory)) {\n transaction.setTag('deviceMemory', `${navigator.deviceMemory} GB`);\n }\n\n if (isMeasurementValue(navigator.hardwareConcurrency)) {\n transaction.setTag('hardwareConcurrency', String(navigator.hardwareConcurrency));\n }\n}\n\n/** Add LCP / CLS data to transaction to allow debugging */\nfunction _tagMetricInfo(transaction: Transaction): void {\n if (_lcpEntry) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding LCP Data');\n\n // Capture Properties of the LCP element that contributes to the LCP.\n\n if (_lcpEntry.element) {\n transaction.setTag('lcp.element', htmlTreeAsString(_lcpEntry.element));\n }\n\n if (_lcpEntry.id) {\n transaction.setTag('lcp.id', _lcpEntry.id);\n }\n\n if (_lcpEntry.url) {\n // Trim URL to the first 200 characters.\n transaction.setTag('lcp.url', _lcpEntry.url.trim().slice(0, 200));\n }\n\n transaction.setTag('lcp.size', _lcpEntry.size);\n }\n\n // See: https://developer.mozilla.org/en-US/docs/Web/API/LayoutShift\n if (_clsEntry && _clsEntry.sources) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding CLS Data');\n _clsEntry.sources.forEach((source, index) =>\n transaction.setTag(`cls.source.${index + 1}`, htmlTreeAsString(source.node)),\n );\n }\n}\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { FIDMetric, PerformanceEventTiming, ReportCallback } from './types';\n\n/**\n * Calculates the [FID](https://web.dev/fid/) value for the current page and\n * calls the `callback` function once the value is ready, along with the\n * relevant `first-input` performance entry used to determine the value. The\n * reported value is a `DOMHighResTimeStamp`.\n *\n * _**Important:** since FID is only reported after the user interacts with the\n * page, it's possible that it will not be reported for some page loads._\n */\nexport const onFID = (onReport: ReportCallback): void => {\n const visibilityWatcher = getVisibilityWatcher();\n const metric = initMetric('FID');\n // eslint-disable-next-line prefer-const\n let report: ReturnType<typeof bindReporter>;\n\n const handleEntry = (entry: PerformanceEventTiming): void => {\n // Only report if the page wasn't hidden prior to the first input.\n if (entry.startTime < visibilityWatcher.firstHiddenTime) {\n metric.value = entry.processingStart - entry.startTime;\n metric.entries.push(entry);\n report(true);\n }\n };\n\n const handleEntries = (entries: FIDMetric['entries']): void => {\n (entries as PerformanceEventTiming[]).forEach(handleEntry);\n };\n\n const po = observe('first-input', handleEntries);\n report = bindReporter(onReport, metric);\n\n if (po) {\n onHidden(() => {\n handleEntries(po.takeRecords() as FIDMetric['entries']);\n po.disconnect();\n }, true);\n }\n};\n","/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { CLSMetric, ReportCallback, StopListening } from './types';\n\n/**\n * Calculates the [CLS](https://web.dev/cls/) value for the current page and\n * calls the `callback` function once the value is ready to be reported, along\n * with all `layout-shift` performance entries that were used in the metric\n * value calculation. The reported value is a `double` (corresponding to a\n * [layout shift score](https://web.dev/cls/#layout-shift-score)).\n *\n * If the `reportAllChanges` configuration option is set to `true`, the\n * `callback` function will be called as soon as the value is initially\n * determined as well as any time the value changes throughout the page\n * lifespan.\n *\n * _**Important:** CLS should be continually monitored for changes throughout\n * the entire lifespan of a page—including if the user returns to the page after\n * it's been hidden/backgrounded. However, since browsers often [will not fire\n * additional callbacks once the user has backgrounded a\n * page](https://developer.chrome.com/blog/page-lifecycle-api/#advice-hidden),\n * `callback` is always called when the page's visibility state changes to\n * hidden. As a result, the `callback` function might be called multiple times\n * during the same page load._\n */\nexport const onCLS = (onReport: ReportCallback): StopListening | undefined => {\n const metric = initMetric('CLS', 0);\n let report: ReturnType<typeof bindReporter>;\n\n let sessionValue = 0;\n let sessionEntries: PerformanceEntry[] = [];\n\n // const handleEntries = (entries: Metric['entries']) => {\n const handleEntries = (entries: LayoutShift[]): void => {\n entries.forEach(entry => {\n // Only count layout shifts without recent user input.\n if (!entry.hadRecentInput) {\n const firstSessionEntry = sessionEntries[0];\n const lastSessionEntry = sessionEntries[sessionEntries.length - 1];\n\n // If the entry occurred less than 1 second after the previous entry and\n // less than 5 seconds after the first entry in the session, include the\n // entry in the current session. Otherwise, start a new session.\n if (\n sessionValue &&\n sessionEntries.length !== 0 &&\n entry.startTime - lastSessionEntry.startTime < 1000 &&\n entry.startTime - firstSessionEntry.startTime < 5000\n ) {\n sessionValue += entry.value;\n sessionEntries.push(entry);\n } else {\n sessionValue = entry.value;\n sessionEntries = [entry];\n }\n\n // If the current session value is larger than the current CLS value,\n // update CLS and the entries contributing to it.\n if (sessionValue > metric.value) {\n metric.value = sessionValue;\n metric.entries = sessionEntries;\n if (report) {\n report();\n }\n }\n }\n });\n };\n\n const po = observe('layout-shift', handleEntries);\n if (po) {\n report = bindReporter(onReport, metric);\n\n const stopListening = (): void => {\n handleEntries(po.takeRecords() as CLSMetric['entries']);\n report(true);\n };\n\n onHidden(stopListening);\n\n return stopListening;\n }\n\n return;\n};\n","/* eslint-disable max-lines */\nimport { getCurrentHub, getDynamicSamplingContextFromClient, hasTracingEnabled } from '@sentry/core';\nimport type { Client, Scope, Span } from '@sentry/types';\nimport {\n addInstrumentationHandler,\n BAGGAGE_HEADER_NAME,\n browserPerformanceTimeOrigin,\n dynamicSamplingContextToSentryBaggageHeader,\n generateSentryTraceHeader,\n isInstanceOf,\n SENTRY_XHR_DATA_KEY,\n stringMatchesSomePattern,\n} from '@sentry/utils';\n\nexport const DEFAULT_TRACE_PROPAGATION_TARGETS = ['localhost', /^\\/(?!\\/)/];\n\n/** Options for Request Instrumentation */\nexport interface RequestInstrumentationOptions {\n /**\n * @deprecated Will be removed in v8.\n * Use `shouldCreateSpanForRequest` to control span creation and `tracePropagationTargets` to control\n * trace header attachment.\n */\n tracingOrigins: Array<string | RegExp>;\n\n /**\n * List of strings and/or regexes used to determine which outgoing requests will have `sentry-trace` and `baggage`\n * headers attached.\n *\n * Default: ['localhost', /^\\//] {@see DEFAULT_TRACE_PROPAGATION_TARGETS}\n */\n tracePropagationTargets: Array<string | RegExp>;\n\n /**\n * Flag to disable patching all together for fetch requests.\n *\n * Default: true\n */\n traceFetch: boolean;\n\n /**\n * Flag to disable patching all together for xhr requests.\n *\n * Default: true\n */\n traceXHR: boolean;\n\n /**\n * If true, Sentry will capture http timings and add them to the corresponding http spans.\n *\n * Default: true\n */\n enableHTTPTimings: boolean;\n\n /**\n * This function will be called before creating a span for a request with the given url.\n * Return false if you don't want a span for the given url.\n *\n * Default: (url: string) => true\n */\n shouldCreateSpanForRequest?(this: void, url: string): boolean;\n}\n\n/** Data returned from fetch callback */\nexport interface FetchData {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n args: any[]; // the arguments passed to the fetch call itself\n fetchData?: {\n method: string;\n url: string;\n // span_id\n __span?: string;\n };\n\n // TODO Should this be unknown instead? If we vendor types, make it a Response\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n response?: any;\n error?: unknown;\n\n startTimestamp: number;\n endTimestamp?: number;\n}\n\n/** Data returned from XHR request */\nexport interface XHRData {\n xhr?: {\n [SENTRY_XHR_DATA_KEY]?: {\n method: string;\n url: string;\n status_code: number;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: Record<string, any>;\n };\n __sentry_xhr_span_id__?: string;\n setRequestHeader?: (key: string, val: string) => void;\n getRequestHeader?: (key: string) => string;\n __sentry_own_request__?: boolean;\n };\n startTimestamp: number;\n endTimestamp?: number;\n}\n\ntype PolymorphicRequestHeaders =\n | Record<string, string | undefined>\n | Array<[string, string]>\n // the below is not preicsely the Header type used in Request, but it'll pass duck-typing\n | {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n append: (key: string, value: string) => void;\n get: (key: string) => string | null | undefined;\n };\n\nexport const defaultRequestInstrumentationOptions: RequestInstrumentationOptions = {\n traceFetch: true,\n traceXHR: true,\n enableHTTPTimings: true,\n // TODO (v8): Remove this property\n tracingOrigins: DEFAULT_TRACE_PROPAGATION_TARGETS,\n tracePropagationTargets: DEFAULT_TRACE_PROPAGATION_TARGETS,\n};\n\n/** Registers span creators for xhr and fetch requests */\nexport function instrumentOutgoingRequests(_options?: Partial<RequestInstrumentationOptions>): void {\n const {\n traceFetch,\n traceXHR,\n tracePropagationTargets,\n // eslint-disable-next-line deprecation/deprecation\n tracingOrigins,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n } = {\n traceFetch: defaultRequestInstrumentationOptions.traceFetch,\n traceXHR: defaultRequestInstrumentationOptions.traceXHR,\n ..._options,\n };\n\n const shouldCreateSpan =\n typeof shouldCreateSpanForRequest === 'function' ? shouldCreateSpanForRequest : (_: string) => true;\n\n // TODO(v8) Remove tracingOrigins here\n // The only reason we're passing it in here is because this instrumentOutgoingRequests function is publicly exported\n // and we don't want to break the API. We can remove it in v8.\n const shouldAttachHeadersWithTargets = (url: string): boolean =>\n shouldAttachHeaders(url, tracePropagationTargets || tracingOrigins);\n\n const spans: Record<string, Span> = {};\n\n if (traceFetch) {\n addInstrumentationHandler('fetch', (handlerData: FetchData) => {\n const createdSpan = fetchCallback(handlerData, shouldCreateSpan, shouldAttachHeadersWithTargets, spans);\n if (enableHTTPTimings && createdSpan) {\n addHTTPTimings(createdSpan);\n }\n });\n }\n\n if (traceXHR) {\n addInstrumentationHandler('xhr', (handlerData: XHRData) => {\n const createdSpan = xhrCallback(handlerData, shouldCreateSpan, shouldAttachHeadersWithTargets, spans);\n if (enableHTTPTimings && createdSpan) {\n addHTTPTimings(createdSpan);\n }\n });\n }\n}\n\n/**\n * Creates a temporary observer to listen to the next fetch/xhr resourcing timings,\n * so that when timings hit their per-browser limit they don't need to be removed.\n *\n * @param span A span that has yet to be finished, must contain `url` on data.\n */\nfunction addHTTPTimings(span: Span): void {\n const url = span.data.url;\n const observer = new PerformanceObserver(list => {\n const entries = list.getEntries() as PerformanceResourceTiming[];\n entries.forEach(entry => {\n if ((entry.initiatorType === 'fetch' || entry.initiatorType === 'xmlhttprequest') && entry.name.endsWith(url)) {\n const spanData = resourceTimingEntryToSpanData(entry);\n spanData.forEach(data => span.setData(...data));\n observer.disconnect();\n }\n });\n });\n observer.observe({\n entryTypes: ['resource'],\n });\n}\n\n/**\n * Converts ALPN protocol ids to name and version.\n *\n * (https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids)\n * @param nextHopProtocol PerformanceResourceTiming.nextHopProtocol\n */\nexport function extractNetworkProtocol(nextHopProtocol: string): { name: string; version: string } {\n let name = 'unknown';\n let version = 'unknown';\n let _name = '';\n for (const char of nextHopProtocol) {\n // http/1.1 etc.\n if (char === '/') {\n [name, version] = nextHopProtocol.split('/');\n break;\n }\n // h2, h3 etc.\n if (!isNaN(Number(char))) {\n name = _name === 'h' ? 'http' : _name;\n version = nextHopProtocol.split(_name)[1];\n break;\n }\n _name += char;\n }\n if (_name === nextHopProtocol) {\n // webrtc, ftp, etc.\n name = _name;\n }\n return { name, version };\n}\n\nfunction getAbsoluteTime(time: number): number {\n return ((browserPerformanceTimeOrigin || performance.timeOrigin) + time) / 1000;\n}\n\nfunction resourceTimingEntryToSpanData(resourceTiming: PerformanceResourceTiming): [string, string | number][] {\n const { name, version } = extractNetworkProtocol(resourceTiming.nextHopProtocol);\n\n const timingSpanData: [string, string | number][] = [];\n\n timingSpanData.push(['network.protocol.version', version], ['network.protocol.name', name]);\n\n if (!browserPerformanceTimeOrigin) {\n return timingSpanData;\n }\n return [\n ...timingSpanData,\n ['http.request.redirect_start', getAbsoluteTime(resourceTiming.redirectStart)],\n ['http.request.fetch_start', getAbsoluteTime(resourceTiming.fetchStart)],\n ['http.request.domain_lookup_start', getAbsoluteTime(resourceTiming.domainLookupStart)],\n ['http.request.domain_lookup_end', getAbsoluteTime(resourceTiming.domainLookupEnd)],\n ['http.request.connect_start', getAbsoluteTime(resourceTiming.connectStart)],\n ['http.request.secure_connection_start', getAbsoluteTime(resourceTiming.secureConnectionStart)],\n ['http.request.connection_end', getAbsoluteTime(resourceTiming.connectEnd)],\n ['http.request.request_start', getAbsoluteTime(resourceTiming.requestStart)],\n ['http.request.response_start', getAbsoluteTime(resourceTiming.responseStart)],\n ['http.request.response_end', getAbsoluteTime(resourceTiming.responseEnd)],\n ];\n}\n\n/**\n * A function that determines whether to attach tracing headers to a request.\n * This was extracted from `instrumentOutgoingRequests` to make it easier to test shouldAttachHeaders.\n * We only export this fuction for testing purposes.\n */\nexport function shouldAttachHeaders(url: string, tracePropagationTargets: (string | RegExp)[] | undefined): boolean {\n return stringMatchesSomePattern(url, tracePropagationTargets || DEFAULT_TRACE_PROPAGATION_TARGETS);\n}\n\n/**\n * Create and track fetch request spans\n *\n * @returns Span if a span was created, otherwise void.\n */\nexport function fetchCallback(\n handlerData: FetchData,\n shouldCreateSpan: (url: string) => boolean,\n shouldAttachHeaders: (url: string) => boolean,\n spans: Record<string, Span>,\n): Span | undefined {\n if (!hasTracingEnabled() || !handlerData.fetchData) {\n return undefined;\n }\n\n const shouldCreateSpanResult = shouldCreateSpan(handlerData.fetchData.url);\n\n if (handlerData.endTimestamp && shouldCreateSpanResult) {\n const spanId = handlerData.fetchData.__span;\n if (!spanId) return;\n\n const span = spans[spanId];\n if (span) {\n if (handlerData.response) {\n // TODO (kmclb) remove this once types PR goes through\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n span.setHttpStatus(handlerData.response.status);\n\n const contentLength: string =\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n handlerData.response && handlerData.response.headers && handlerData.response.headers.get('content-length');\n\n const contentLengthNum = parseInt(contentLength);\n if (contentLengthNum > 0) {\n span.setData('http.response_content_length', contentLengthNum);\n }\n } else if (handlerData.error) {\n span.setStatus('internal_error');\n }\n span.finish();\n\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete spans[spanId];\n }\n return undefined;\n }\n\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const client = hub.getClient();\n const parentSpan = scope.getSpan();\n\n const { method, url } = handlerData.fetchData;\n\n const span =\n shouldCreateSpanResult && parentSpan\n ? parentSpan.startChild({\n data: {\n url,\n type: 'fetch',\n 'http.method': method,\n },\n description: `${method} ${url}`,\n op: 'http.client',\n })\n : undefined;\n\n if (span) {\n handlerData.fetchData.__span = span.spanId;\n spans[span.spanId] = span;\n }\n\n if (shouldAttachHeaders(handlerData.fetchData.url) && client) {\n const request: string | Request = handlerData.args[0];\n\n // In case the user hasn't set the second argument of a fetch call we default it to `{}`.\n handlerData.args[1] = handlerData.args[1] || {};\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const options: { [key: string]: any } = handlerData.args[1];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n options.headers = addTracingHeadersToFetchRequest(request, client, scope, options, span);\n }\n\n return span;\n}\n\n/**\n * Adds sentry-trace and baggage headers to the various forms of fetch headers\n */\nexport function addTracingHeadersToFetchRequest(\n request: string | unknown, // unknown is actually type Request but we can't export DOM types from this package,\n client: Client,\n scope: Scope,\n options: {\n headers?:\n | {\n [key: string]: string[] | string | undefined;\n }\n | PolymorphicRequestHeaders;\n },\n requestSpan?: Span,\n): PolymorphicRequestHeaders | undefined {\n const span = requestSpan || scope.getSpan();\n\n const transaction = span && span.transaction;\n\n const { traceId, sampled, dsc } = scope.getPropagationContext();\n\n const sentryTraceHeader = span ? span.toTraceparent() : generateSentryTraceHeader(traceId, undefined, sampled);\n const dynamicSamplingContext = transaction\n ? transaction.getDynamicSamplingContext()\n : dsc\n ? dsc\n : getDynamicSamplingContextFromClient(traceId, client, scope);\n\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n\n const headers =\n typeof Request !== 'undefined' && isInstanceOf(request, Request) ? (request as Request).headers : options.headers;\n\n if (!headers) {\n return { 'sentry-trace': sentryTraceHeader, baggage: sentryBaggageHeader };\n } else if (typeof Headers !== 'undefined' && isInstanceOf(headers, Headers)) {\n const newHeaders = new Headers(headers as Headers);\n\n newHeaders.append('sentry-trace', sentryTraceHeader);\n\n if (sentryBaggageHeader) {\n // If the same header is appended multiple times the browser will merge the values into a single request header.\n // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n newHeaders.append(BAGGAGE_HEADER_NAME, sentryBaggageHeader);\n }\n\n return newHeaders as PolymorphicRequestHeaders;\n } else if (Array.isArray(headers)) {\n const newHeaders = [...headers, ['sentry-trace', sentryTraceHeader]];\n\n if (sentryBaggageHeader) {\n // If there are multiple entries with the same key, the browser will merge the values into a single request header.\n // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n newHeaders.push([BAGGAGE_HEADER_NAME, sentryBaggageHeader]);\n }\n\n return newHeaders as PolymorphicRequestHeaders;\n } else {\n const existingBaggageHeader = 'baggage' in headers ? headers.baggage : undefined;\n const newBaggageHeaders: string[] = [];\n\n if (Array.isArray(existingBaggageHeader)) {\n newBaggageHeaders.push(...existingBaggageHeader);\n } else if (existingBaggageHeader) {\n newBaggageHeaders.push(existingBaggageHeader);\n }\n\n if (sentryBaggageHeader) {\n newBaggageHeaders.push(sentryBaggageHeader);\n }\n\n return {\n ...(headers as Exclude<typeof headers, Headers>),\n 'sentry-trace': sentryTraceHeader,\n baggage: newBaggageHeaders.length > 0 ? newBaggageHeaders.join(',') : undefined,\n };\n }\n}\n\n/**\n * Create and track xhr request spans\n *\n * @returns Span if a span was created, otherwise void.\n */\n// eslint-disable-next-line complexity\nexport function xhrCallback(\n handlerData: XHRData,\n shouldCreateSpan: (url: string) => boolean,\n shouldAttachHeaders: (url: string) => boolean,\n spans: Record<string, Span>,\n): Span | undefined {\n const xhr = handlerData.xhr;\n const sentryXhrData = xhr && xhr[SENTRY_XHR_DATA_KEY];\n\n if (!hasTracingEnabled() || (xhr && xhr.__sentry_own_request__) || !xhr || !sentryXhrData) {\n return undefined;\n }\n\n const shouldCreateSpanResult = shouldCreateSpan(sentryXhrData.url);\n\n // check first if the request has finished and is tracked by an existing span which should now end\n if (handlerData.endTimestamp && shouldCreateSpanResult) {\n const spanId = xhr.__sentry_xhr_span_id__;\n if (!spanId) return;\n\n const span = spans[spanId];\n if (span) {\n span.setHttpStatus(sentryXhrData.status_code);\n span.finish();\n\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete spans[spanId];\n }\n return undefined;\n }\n\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const parentSpan = scope.getSpan();\n\n const span =\n shouldCreateSpanResult && parentSpan\n ? parentSpan.startChild({\n data: {\n ...sentryXhrData.data,\n type: 'xhr',\n 'http.method': sentryXhrData.method,\n url: sentryXhrData.url,\n },\n description: `${sentryXhrData.method} ${sentryXhrData.url}`,\n op: 'http.client',\n })\n : undefined;\n\n if (span) {\n xhr.__sentry_xhr_span_id__ = span.spanId;\n spans[xhr.__sentry_xhr_span_id__] = span;\n }\n\n if (xhr.setRequestHeader && shouldAttachHeaders(sentryXhrData.url)) {\n if (span) {\n const transaction = span && span.transaction;\n const dynamicSamplingContext = transaction && transaction.getDynamicSamplingContext();\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n setHeaderOnXhr(xhr, span.toTraceparent(), sentryBaggageHeader);\n } else {\n const client = hub.getClient();\n const { traceId, sampled, dsc } = scope.getPropagationContext();\n const sentryTraceHeader = generateSentryTraceHeader(traceId, undefined, sampled);\n const dynamicSamplingContext =\n dsc || (client ? getDynamicSamplingContextFromClient(traceId, client, scope) : undefined);\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n setHeaderOnXhr(xhr, sentryTraceHeader, sentryBaggageHeader);\n }\n }\n\n return span;\n}\n\nfunction setHeaderOnXhr(\n xhr: NonNullable<XHRData['xhr']>,\n sentryTraceHeader: string,\n sentryBaggageHeader: string | undefined,\n): void {\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n xhr.setRequestHeader!('sentry-trace', sentryTraceHeader);\n if (sentryBaggageHeader) {\n // From MDN: \"If this method is called several times with the same header, the values are merged into one single request header.\"\n // We can therefore simply set a baggage header without checking what was there before\n // https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/setRequestHeader\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n xhr.setRequestHeader!(BAGGAGE_HEADER_NAME, sentryBaggageHeader);\n }\n } catch (_) {\n // Error: InvalidStateError: Failed to execute 'setRequestHeader' on 'XMLHttpRequest': The object's state must be OPENED.\n }\n}\n","/* eslint-disable max-lines */\nimport type { Hub, IdleTransaction } from '@sentry/core';\nimport { addTracingExtensions, getActiveTransaction, startIdleTransaction, TRACING_DEFAULTS } from '@sentry/core';\nimport type { EventProcessor, Integration, Transaction, TransactionContext, TransactionSource } from '@sentry/types';\nimport { getDomElement, logger, tracingContextFromHeaders } from '@sentry/utils';\n\nimport { registerBackgroundTabDetection } from './backgroundtab';\nimport {\n addPerformanceEntries,\n startTrackingInteractions,\n startTrackingLongTasks,\n startTrackingWebVitals,\n} from './metrics';\nimport type { RequestInstrumentationOptions } from './request';\nimport { defaultRequestInstrumentationOptions, instrumentOutgoingRequests } from './request';\nimport { instrumentRoutingWithDefaults } from './router';\nimport { WINDOW } from './types';\n\nexport const BROWSER_TRACING_INTEGRATION_ID = 'BrowserTracing';\n\n/** Options for Browser Tracing integration */\nexport interface BrowserTracingOptions extends RequestInstrumentationOptions {\n /**\n * The time to wait in ms until the transaction will be finished during an idle state. An idle state is defined\n * by a moment where there are no in-progress spans.\n *\n * The transaction will use the end timestamp of the last finished span as the endtime for the transaction.\n * If there are still active spans when this the `idleTimeout` is set, the `idleTimeout` will get reset.\n * Time is in ms.\n *\n * Default: 1000\n */\n idleTimeout: number;\n\n /**\n * The max duration for a transaction. If a transaction duration hits the `finalTimeout` value, it\n * will be finished.\n * Time is in ms.\n *\n * Default: 30000\n */\n finalTimeout: number;\n\n /**\n * The heartbeat interval. If no new spans are started or open spans are finished within 3 heartbeats,\n * the transaction will be finished.\n * Time is in ms.\n *\n * Default: 5000\n */\n heartbeatInterval: number;\n\n /**\n * Flag to enable/disable creation of `navigation` transaction on history changes.\n *\n * Default: true\n */\n startTransactionOnLocationChange: boolean;\n\n /**\n * Flag to enable/disable creation of `pageload` transaction on first pageload.\n *\n * Default: true\n */\n startTransactionOnPageLoad: boolean;\n\n /**\n * Flag Transactions where tabs moved to background with \"cancelled\". Browser background tab timing is\n * not suited towards doing precise measurements of operations. By default, we recommend that this option\n * be enabled as background transactions can mess up your statistics in nondeterministic ways.\n *\n * Default: true\n */\n markBackgroundTransactions: boolean;\n\n /**\n * If true, Sentry will capture long tasks and add them to the corresponding transaction.\n *\n * Default: true\n */\n enableLongTask: boolean;\n\n /**\n * _metricOptions allows the user to send options to change how metrics are collected.\n *\n * _metricOptions is currently experimental.\n *\n * Default: undefined\n */\n _metricOptions?: Partial<{\n /**\n * @deprecated This property no longer has any effect and will be removed in v8.\n */\n _reportAllChanges: boolean;\n }>;\n\n /**\n * _experiments allows the user to send options to define how this integration works.\n * Note that the `enableLongTask` options is deprecated in favor of the option at the top level, and will be removed in v8.\n *\n * TODO (v8): Remove enableLongTask\n *\n * Default: undefined\n */\n _experiments: Partial<{\n enableLongTask: boolean;\n enableInteractions: boolean;\n onStartRouteTransaction: (t: Transaction | undefined, ctx: TransactionContext, getCurrentHub: () => Hub) => void;\n }>;\n\n /**\n * beforeNavigate is called before a pageload/navigation transaction is created and allows users to modify transaction\n * context data, or drop the transaction entirely (by setting `sampled = false` in the context).\n *\n * Note: For legacy reasons, transactions can also be dropped by returning `undefined`.\n *\n * @param context: The context data which will be passed to `startTransaction` by default\n *\n * @returns A (potentially) modified context object, with `sampled = false` if the transaction should be dropped.\n */\n beforeNavigate?(this: void, context: TransactionContext): TransactionContext | undefined;\n\n /**\n * Instrumentation that creates routing change transactions. By default creates\n * pageload and navigation transactions.\n */\n routingInstrumentation<T extends Transaction>(\n this: void,\n customStartTransaction: (context: TransactionContext) => T | undefined,\n startTransactionOnPageLoad?: boolean,\n startTransactionOnLocationChange?: boolean,\n ): void;\n}\n\nconst DEFAULT_BROWSER_TRACING_OPTIONS: BrowserTracingOptions = {\n ...TRACING_DEFAULTS,\n markBackgroundTransactions: true,\n routingInstrumentation: instrumentRoutingWithDefaults,\n startTransactionOnLocationChange: true,\n startTransactionOnPageLoad: true,\n enableLongTask: true,\n _experiments: {},\n ...defaultRequestInstrumentationOptions,\n};\n\n/**\n * The Browser Tracing integration automatically instruments browser pageload/navigation\n * actions as transactions, and captures requests, metrics and errors as spans.\n *\n * The integration can be configured with a variety of options, and can be extended to use\n * any routing library. This integration uses {@see IdleTransaction} to create transactions.\n */\nexport class BrowserTracing implements Integration {\n // This class currently doesn't have a static `id` field like the other integration classes, because it prevented\n // @sentry/tracing from being treeshaken. Tree shakers do not like static fields, because they behave like side effects.\n // TODO: Come up with a better plan, than using static fields on integration classes, and use that plan on all\n // integrations.\n\n /** Browser Tracing integration options */\n public options: BrowserTracingOptions;\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n private _getCurrentHub?: () => Hub;\n\n private _latestRouteName?: string;\n private _latestRouteSource?: TransactionSource;\n\n private _collectWebVitals: () => void;\n\n private _hasSetTracePropagationTargets: boolean;\n\n public constructor(_options?: Partial<BrowserTracingOptions>) {\n this.name = BROWSER_TRACING_INTEGRATION_ID;\n this._hasSetTracePropagationTargets = false;\n\n addTracingExtensions();\n\n if (__DEBUG_BUILD__) {\n this._hasSetTracePropagationTargets = !!(\n _options &&\n // eslint-disable-next-line deprecation/deprecation\n (_options.tracePropagationTargets || _options.tracingOrigins)\n );\n }\n\n this.options = {\n ...DEFAULT_BROWSER_TRACING_OPTIONS,\n ..._options,\n };\n\n // Special case: enableLongTask can be set in _experiments\n // TODO (v8): Remove this in v8\n if (this.options._experiments.enableLongTask !== undefined) {\n this.options.enableLongTask = this.options._experiments.enableLongTask;\n }\n\n // TODO (v8): remove this block after tracingOrigins is removed\n // Set tracePropagationTargets to tracingOrigins if specified by the user\n // In case both are specified, tracePropagationTargets takes precedence\n // eslint-disable-next-line deprecation/deprecation\n if (_options && !_options.tracePropagationTargets && _options.tracingOrigins) {\n // eslint-disable-next-line deprecation/deprecation\n this.options.tracePropagationTargets = _options.tracingOrigins;\n }\n\n this._collectWebVitals = startTrackingWebVitals();\n if (this.options.enableLongTask) {\n startTrackingLongTasks();\n }\n if (this.options._experiments.enableInteractions) {\n startTrackingInteractions();\n }\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(_: (callback: EventProcessor) => void, getCurrentHub: () => Hub): void {\n this._getCurrentHub = getCurrentHub;\n const hub = getCurrentHub();\n const client = hub.getClient();\n const clientOptions = client && client.getOptions();\n\n const {\n routingInstrumentation: instrumentRouting,\n startTransactionOnLocationChange,\n startTransactionOnPageLoad,\n markBackgroundTransactions,\n traceFetch,\n traceXHR,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n _experiments,\n } = this.options;\n\n const clientOptionsTracePropagationTargets = clientOptions && clientOptions.tracePropagationTargets;\n // There are three ways to configure tracePropagationTargets:\n // 1. via top level client option `tracePropagationTargets`\n // 2. via BrowserTracing option `tracePropagationTargets`\n // 3. via BrowserTracing option `tracingOrigins` (deprecated)\n //\n // To avoid confusion, favour top level client option `tracePropagationTargets`, and fallback to\n // BrowserTracing option `tracePropagationTargets` and then `tracingOrigins` (deprecated).\n // This is done as it minimizes bundle size (we don't have to have undefined checks).\n //\n // If both 1 and either one of 2 or 3 are set (from above), we log out a warning.\n const tracePropagationTargets = clientOptionsTracePropagationTargets || this.options.tracePropagationTargets;\n if (__DEBUG_BUILD__ && this._hasSetTracePropagationTargets && clientOptionsTracePropagationTargets) {\n logger.warn(\n '[Tracing] The `tracePropagationTargets` option was set in the BrowserTracing integration and top level `Sentry.init`. The top level `Sentry.init` value is being used.',\n );\n }\n\n instrumentRouting(\n (context: TransactionContext) => {\n const transaction = this._createRouteTransaction(context);\n\n this.options._experiments.onStartRouteTransaction &&\n this.options._experiments.onStartRouteTransaction(transaction, context, getCurrentHub);\n\n return transaction;\n },\n startTransactionOnPageLoad,\n startTransactionOnLocationChange,\n );\n\n if (markBackgroundTransactions) {\n registerBackgroundTabDetection();\n }\n\n if (_experiments.enableInteractions) {\n this._registerInteractionListener();\n }\n\n instrumentOutgoingRequests({\n traceFetch,\n traceXHR,\n tracePropagationTargets,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n });\n }\n\n /** Create routing idle transaction. */\n private _createRouteTransaction(context: TransactionContext): Transaction | undefined {\n if (!this._getCurrentHub) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Did not create ${context.op} transaction because _getCurrentHub is invalid.`);\n return undefined;\n }\n\n const hub = this._getCurrentHub();\n\n const { beforeNavigate, idleTimeout, finalTimeout, heartbeatInterval } = this.options;\n\n const isPageloadTransaction = context.op === 'pageload';\n\n const sentryTrace = isPageloadTransaction ? getMetaContent('sentry-trace') : '';\n const baggage = isPageloadTransaction ? getMetaContent('baggage') : '';\n const { traceparentData, dynamicSamplingContext, propagationContext } = tracingContextFromHeaders(\n sentryTrace,\n baggage,\n );\n\n const expandedContext: TransactionContext = {\n ...context,\n ...traceparentData,\n metadata: {\n ...context.metadata,\n dynamicSamplingContext: traceparentData && !dynamicSamplingContext ? {} : dynamicSamplingContext,\n },\n trimEnd: true,\n };\n\n const modifiedContext = typeof beforeNavigate === 'function' ? beforeNavigate(expandedContext) : expandedContext;\n\n // For backwards compatibility reasons, beforeNavigate can return undefined to \"drop\" the transaction (prevent it\n // from being sent to Sentry).\n const finalContext = modifiedContext === undefined ? { ...expandedContext, sampled: false } : modifiedContext;\n\n // If `beforeNavigate` set a custom name, record that fact\n finalContext.metadata =\n finalContext.name !== expandedContext.name\n ? { ...finalContext.metadata, source: 'custom' }\n : finalContext.metadata;\n\n this._latestRouteName = finalContext.name;\n this._latestRouteSource = finalContext.metadata && finalContext.metadata.source;\n\n if (finalContext.sampled === false) {\n __DEBUG_BUILD__ &&\n logger.log(`[Tracing] Will not send ${finalContext.op} transaction because of beforeNavigate.`);\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] Starting ${finalContext.op} transaction on scope`);\n\n const { location } = WINDOW;\n\n const idleTransaction = startIdleTransaction(\n hub,\n finalContext,\n idleTimeout,\n finalTimeout,\n true,\n { location }, // for use in the tracesSampler\n heartbeatInterval,\n );\n\n const scope = hub.getScope();\n\n // If it's a pageload and there is a meta tag set\n // use the traceparentData as the propagation context\n if (isPageloadTransaction && traceparentData) {\n scope.setPropagationContext(propagationContext);\n } else {\n // Navigation transactions should set a new propagation context based on the\n // created idle transaction.\n scope.setPropagationContext({\n traceId: idleTransaction.traceId,\n spanId: idleTransaction.spanId,\n parentSpanId: idleTransaction.parentSpanId,\n sampled: !!idleTransaction.sampled,\n });\n }\n\n idleTransaction.registerBeforeFinishCallback(transaction => {\n this._collectWebVitals();\n addPerformanceEntries(transaction);\n });\n\n return idleTransaction as Transaction;\n }\n\n /** Start listener for interaction transactions */\n private _registerInteractionListener(): void {\n let inflightInteractionTransaction: IdleTransaction | undefined;\n const registerInteractionTransaction = (): void => {\n const { idleTimeout, finalTimeout, heartbeatInterval } = this.options;\n const op = 'ui.action.click';\n\n const currentTransaction = getActiveTransaction();\n if (currentTransaction && currentTransaction.op && ['navigation', 'pageload'].includes(currentTransaction.op)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `[Tracing] Did not create ${op} transaction because a pageload or navigation transaction is in progress.`,\n );\n return undefined;\n }\n\n if (inflightInteractionTransaction) {\n inflightInteractionTransaction.setFinishReason('interactionInterrupted');\n inflightInteractionTransaction.finish();\n inflightInteractionTransaction = undefined;\n }\n\n if (!this._getCurrentHub) {\n __DEBUG_BUILD__ && logger.warn(`[Tracing] Did not create ${op} transaction because _getCurrentHub is invalid.`);\n return undefined;\n }\n\n if (!this._latestRouteName) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Did not create ${op} transaction because _latestRouteName is missing.`);\n return undefined;\n }\n\n const hub = this._getCurrentHub();\n const { location } = WINDOW;\n\n const context: TransactionContext = {\n name: this._latestRouteName,\n op,\n trimEnd: true,\n metadata: {\n source: this._latestRouteSource || 'url',\n },\n };\n\n inflightInteractionTransaction = startIdleTransaction(\n hub,\n context,\n idleTimeout,\n finalTimeout,\n true,\n { location }, // for use in the tracesSampler\n heartbeatInterval,\n );\n };\n\n ['click'].forEach(type => {\n addEventListener(type, registerInteractionTransaction, { once: false, capture: true });\n });\n }\n}\n\n/** Returns the value of a meta tag */\nexport function getMetaContent(metaName: string): string | undefined {\n // Can't specify generic to `getDomElement` because tracing can be used\n // in a variety of environments, have to disable `no-unsafe-member-access`\n // as a result.\n const metaTag = getDomElement(`meta[name=${metaName}]`);\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return metaTag ? metaTag.getAttribute('content') : undefined;\n}\n","import type { Transaction, TransactionContext } from '@sentry/types';\nimport { addInstrumentationHandler, browserPerformanceTimeOrigin, logger } from '@sentry/utils';\n\nimport { WINDOW } from './types';\n\n/**\n * Default function implementing pageload and navigation transactions\n */\nexport function instrumentRoutingWithDefaults<T extends Transaction>(\n customStartTransaction: (context: TransactionContext) => T | undefined,\n startTransactionOnPageLoad: boolean = true,\n startTransactionOnLocationChange: boolean = true,\n): void {\n if (!WINDOW || !WINDOW.location) {\n __DEBUG_BUILD__ && logger.warn('Could not initialize routing instrumentation due to invalid location');\n return;\n }\n\n let startingUrl: string | undefined = WINDOW.location.href;\n\n let activeTransaction: T | undefined;\n if (startTransactionOnPageLoad) {\n activeTransaction = customStartTransaction({\n name: WINDOW.location.pathname,\n // pageload should always start at timeOrigin (and needs to be in s, not ms)\n startTimestamp: browserPerformanceTimeOrigin ? browserPerformanceTimeOrigin / 1000 : undefined,\n op: 'pageload',\n metadata: { source: 'url' },\n });\n }\n\n if (startTransactionOnLocationChange) {\n addInstrumentationHandler('history', ({ to, from }: { to: string; from?: string }) => {\n /**\n * This early return is there to account for some cases where a navigation transaction starts right after\n * long-running pageload. We make sure that if `from` is undefined and a valid `startingURL` exists, we don't\n * create an uneccessary navigation transaction.\n *\n * This was hard to duplicate, but this behavior stopped as soon as this fix was applied. This issue might also\n * only be caused in certain development environments where the usage of a hot module reloader is causing\n * errors.\n */\n if (from === undefined && startingUrl && startingUrl.indexOf(to) !== -1) {\n startingUrl = undefined;\n return;\n }\n\n if (from !== to) {\n startingUrl = undefined;\n if (activeTransaction) {\n __DEBUG_BUILD__ && logger.log(`[Tracing] Finishing current transaction with op: ${activeTransaction.op}`);\n // If there's an open transaction on the scope, we need to finish it before creating an new one.\n activeTransaction.finish();\n }\n activeTransaction = customStartTransaction({\n name: WINDOW.location.pathname,\n op: 'navigation',\n metadata: { source: 'url' },\n });\n }\n });\n }\n}\n","import type { IdleTransaction, SpanStatusType } from '@sentry/core';\nimport { getActiveTransaction } from '@sentry/core';\nimport { logger } from '@sentry/utils';\n\nimport { WINDOW } from './types';\n\n/**\n * Add a listener that cancels and finishes a transaction when the global\n * document is hidden.\n */\nexport function registerBackgroundTabDetection(): void {\n if (WINDOW && WINDOW.document) {\n WINDOW.document.addEventListener('visibilitychange', () => {\n const activeTransaction = getActiveTransaction() as IdleTransaction;\n if (WINDOW.document.hidden && activeTransaction) {\n const statusType: SpanStatusType = 'cancelled';\n\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Transaction: ${statusType} -> since tab moved to the background, op: ${activeTransaction.op}`,\n );\n // We should not set status if it is already set, this prevent important statuses like\n // error or data loss from being overwritten on transaction.\n if (!activeTransaction.status) {\n activeTransaction.setStatus(statusType);\n }\n activeTransaction.setTag('visibilitychange', 'document.hidden');\n activeTransaction.finish();\n }\n });\n } else {\n __DEBUG_BUILD__ &&\n logger.warn('[Tracing] Could not set up background tab detection due to lack of global document');\n }\n}\n","var NodeType;\n(function (NodeType) {\n NodeType[NodeType[\"Document\"] = 0] = \"Document\";\n NodeType[NodeType[\"DocumentType\"] = 1] = \"DocumentType\";\n NodeType[NodeType[\"Element\"] = 2] = \"Element\";\n NodeType[NodeType[\"Text\"] = 3] = \"Text\";\n NodeType[NodeType[\"CDATA\"] = 4] = \"CDATA\";\n NodeType[NodeType[\"Comment\"] = 5] = \"Comment\";\n})(NodeType || (NodeType = {}));\n\nfunction isElement(n) {\n return n.nodeType === n.ELEMENT_NODE;\n}\nfunction isShadowRoot(n) {\n const host = n === null || n === void 0 ? void 0 : n.host;\n return Boolean(host && host.shadowRoot && host.shadowRoot === n);\n}\nfunction isInputTypeMasked({ maskInputOptions, tagName, type, }) {\n if (tagName.toLowerCase() === 'option') {\n tagName = 'select';\n }\n const actualType = typeof type === 'string' ? type.toLowerCase() : undefined;\n return (maskInputOptions[tagName.toLowerCase()] ||\n (actualType && maskInputOptions[actualType]) ||\n actualType === 'password' ||\n (tagName === 'input' && !type && maskInputOptions['text']));\n}\nfunction hasInputMaskOptions({ tagName, type, maskInputOptions, maskInputSelector, }) {\n return (maskInputSelector || isInputTypeMasked({ maskInputOptions, tagName, type }));\n}\nfunction maskInputValue({ input, maskInputSelector, unmaskInputSelector, maskInputOptions, tagName, type, value, maskInputFn, }) {\n let text = value || '';\n if (unmaskInputSelector && input.matches(unmaskInputSelector)) {\n return text;\n }\n if (input.hasAttribute('data-rr-is-password')) {\n type = 'password';\n }\n if (isInputTypeMasked({ maskInputOptions, tagName, type }) ||\n (maskInputSelector && input.matches(maskInputSelector))) {\n if (maskInputFn) {\n text = maskInputFn(text);\n }\n else {\n text = '*'.repeat(text.length);\n }\n }\n return text;\n}\nconst ORIGINAL_ATTRIBUTE_NAME = '__rrweb_original__';\nfunction is2DCanvasBlank(canvas) {\n const ctx = canvas.getContext('2d');\n if (!ctx)\n return true;\n const chunkSize = 50;\n for (let x = 0; x < canvas.width; x += chunkSize) {\n for (let y = 0; y < canvas.height; y += chunkSize) {\n const getImageData = ctx.getImageData;\n const originalGetImageData = ORIGINAL_ATTRIBUTE_NAME in getImageData\n ? getImageData[ORIGINAL_ATTRIBUTE_NAME]\n : getImageData;\n const pixelBuffer = new Uint32Array(originalGetImageData.call(ctx, x, y, Math.min(chunkSize, canvas.width - x), Math.min(chunkSize, canvas.height - y)).data.buffer);\n if (pixelBuffer.some((pixel) => pixel !== 0))\n return false;\n }\n }\n return true;\n}\nfunction getInputType(element) {\n const type = element.type;\n return element.hasAttribute('data-rr-is-password')\n ? 'password'\n : type\n ? type.toLowerCase()\n : null;\n}\nfunction getInputValue(el, tagName, type) {\n typeof type === 'string' ? type.toLowerCase() : '';\n if (tagName === 'INPUT' && (type === 'radio' || type === 'checkbox')) {\n return el.getAttribute('value') || '';\n }\n return el.value;\n}\nfunction defineCustomElement(w, elementName) {\n try {\n if (!w.customElements.get(elementName)) {\n const CustomElement = w.HTMLElement;\n w.customElements.define(elementName, class extends CustomElement {\n });\n }\n }\n catch (_a) { }\n}\n\nlet _id = 1;\nconst tagNameRegex = new RegExp('[^a-z0-9-_:]');\nconst IGNORED_NODE = -2;\nfunction defaultMaskFn(str) {\n return str ? str.replace(/[\\S]/g, '*') : '';\n}\nfunction genId() {\n return _id++;\n}\nfunction getValidTagName(element) {\n if (element instanceof HTMLFormElement) {\n return 'form';\n }\n const processedTagName = element.tagName.toLowerCase().trim();\n if (tagNameRegex.test(processedTagName)) {\n return 'div';\n }\n return processedTagName;\n}\nfunction getCssRulesString(s) {\n try {\n const rules = s.rules || s.cssRules;\n return rules ? Array.from(rules).map(getCssRuleString).join('') : null;\n }\n catch (error) {\n return null;\n }\n}\nfunction getCssRuleString(rule) {\n let cssStringified = rule.cssText;\n if (isCSSImportRule(rule)) {\n try {\n cssStringified = getCssRulesString(rule.styleSheet) || cssStringified;\n }\n catch (_a) {\n }\n }\n return validateStringifiedCssRule(cssStringified);\n}\nfunction validateStringifiedCssRule(cssStringified) {\n if (cssStringified.indexOf(':') > -1) {\n const regex = /(\\[(?:[\\w-]+)[^\\\\])(:(?:[\\w-]+)\\])/gm;\n return cssStringified.replace(regex, '$1\\\\$2');\n }\n return cssStringified;\n}\nfunction isCSSImportRule(rule) {\n return 'styleSheet' in rule;\n}\nfunction stringifyStyleSheet(sheet) {\n return sheet.cssRules\n ? Array.from(sheet.cssRules)\n .map((rule) => rule.cssText ? validateStringifiedCssRule(rule.cssText) : '')\n .join('')\n : '';\n}\nfunction extractOrigin(url) {\n let origin = '';\n if (url.indexOf('//') > -1) {\n origin = url.split('/').slice(0, 3).join('/');\n }\n else {\n origin = url.split('/')[0];\n }\n origin = origin.split('?')[0];\n return origin;\n}\nlet canvasService;\nlet canvasCtx;\nconst URL_IN_CSS_REF = /url\\((?:(')([^']*)'|(\")(.*?)\"|([^)]*))\\)/gm;\nconst RELATIVE_PATH = /^(?!www\\.|(?:http|ftp)s?:\\/\\/|[A-Za-z]:\\\\|\\/\\/|#).*/;\nconst DATA_URI = /^(data:)([^,]*),(.*)/i;\nfunction absoluteToStylesheet(cssText, href) {\n return (cssText || '').replace(URL_IN_CSS_REF, (origin, quote1, path1, quote2, path2, path3) => {\n const filePath = path1 || path2 || path3;\n const maybeQuote = quote1 || quote2 || '';\n if (!filePath) {\n return origin;\n }\n if (!RELATIVE_PATH.test(filePath)) {\n return `url(${maybeQuote}${filePath}${maybeQuote})`;\n }\n if (DATA_URI.test(filePath)) {\n return `url(${maybeQuote}${filePath}${maybeQuote})`;\n }\n if (filePath[0] === '/') {\n return `url(${maybeQuote}${extractOrigin(href) + filePath}${maybeQuote})`;\n }\n const stack = href.split('/');\n const parts = filePath.split('/');\n stack.pop();\n for (const part of parts) {\n if (part === '.') {\n continue;\n }\n else if (part === '..') {\n stack.pop();\n }\n else {\n stack.push(part);\n }\n }\n return `url(${maybeQuote}${stack.join('/')}${maybeQuote})`;\n });\n}\nconst SRCSET_NOT_SPACES = /^[^ \\t\\n\\r\\u000c]+/;\nconst SRCSET_COMMAS_OR_SPACES = /^[, \\t\\n\\r\\u000c]+/;\nfunction getAbsoluteSrcsetString(doc, attributeValue) {\n if (attributeValue.trim() === '') {\n return attributeValue;\n }\n let pos = 0;\n function collectCharacters(regEx) {\n let chars;\n let match = regEx.exec(attributeValue.substring(pos));\n if (match) {\n chars = match[0];\n pos += chars.length;\n return chars;\n }\n return '';\n }\n let output = [];\n while (true) {\n collectCharacters(SRCSET_COMMAS_OR_SPACES);\n if (pos >= attributeValue.length) {\n break;\n }\n let url = collectCharacters(SRCSET_NOT_SPACES);\n if (url.slice(-1) === ',') {\n url = absoluteToDoc(doc, url.substring(0, url.length - 1));\n output.push(url);\n }\n else {\n let descriptorsStr = '';\n url = absoluteToDoc(doc, url);\n let inParens = false;\n while (true) {\n let c = attributeValue.charAt(pos);\n if (c === '') {\n output.push((url + descriptorsStr).trim());\n break;\n }\n else if (!inParens) {\n if (c === ',') {\n pos += 1;\n output.push((url + descriptorsStr).trim());\n break;\n }\n else if (c === '(') {\n inParens = true;\n }\n }\n else {\n if (c === ')') {\n inParens = false;\n }\n }\n descriptorsStr += c;\n pos += 1;\n }\n }\n }\n return output.join(', ');\n}\nfunction absoluteToDoc(doc, attributeValue) {\n if (!attributeValue || attributeValue.trim() === '') {\n return attributeValue;\n }\n const a = doc.createElement('a');\n a.href = attributeValue;\n return a.href;\n}\nfunction isSVGElement(el) {\n return Boolean(el.tagName === 'svg' || el.ownerSVGElement);\n}\nfunction getHref() {\n const a = document.createElement('a');\n a.href = '';\n return a.href;\n}\nfunction transformAttribute(doc, element, _tagName, _name, value, maskAllText, unmaskTextSelector, maskTextFn) {\n if (!value) {\n return value;\n }\n const name = _name.toLowerCase();\n const tagName = _tagName.toLowerCase();\n if (name === 'src' || name === 'href') {\n return absoluteToDoc(doc, value);\n }\n else if (name === 'xlink:href' && value[0] !== '#') {\n return absoluteToDoc(doc, value);\n }\n else if (name === 'background' &&\n (tagName === 'table' || tagName === 'td' || tagName === 'th')) {\n return absoluteToDoc(doc, value);\n }\n else if (name === 'srcset') {\n return getAbsoluteSrcsetString(doc, value);\n }\n else if (name === 'style') {\n return absoluteToStylesheet(value, getHref());\n }\n else if (tagName === 'object' && name === 'data') {\n return absoluteToDoc(doc, value);\n }\n else if (maskAllText &&\n _shouldMaskAttribute(element, name, tagName, unmaskTextSelector)) {\n return maskTextFn ? maskTextFn(value) : defaultMaskFn(value);\n }\n return value;\n}\nfunction _shouldMaskAttribute(element, attribute, tagName, unmaskTextSelector) {\n if (unmaskTextSelector && element.matches(unmaskTextSelector)) {\n return false;\n }\n return (['placeholder', 'title', 'aria-label'].indexOf(attribute) > -1 ||\n (tagName === 'input' &&\n attribute === 'value' &&\n element.hasAttribute('type') &&\n ['submit', 'button'].indexOf(element.getAttribute('type').toLowerCase()) > -1));\n}\nfunction _isBlockedElement(element, blockClass, blockSelector, unblockSelector) {\n if (unblockSelector && element.matches(unblockSelector)) {\n return false;\n }\n if (typeof blockClass === 'string') {\n if (element.classList.contains(blockClass)) {\n return true;\n }\n }\n else {\n for (let eIndex = 0; eIndex < element.classList.length; eIndex++) {\n const className = element.classList[eIndex];\n if (blockClass.test(className)) {\n return true;\n }\n }\n }\n if (blockSelector) {\n return element.matches(blockSelector);\n }\n return false;\n}\nfunction needMaskingText(node, maskTextClass, maskTextSelector, unmaskTextSelector, maskAllText) {\n if (!node) {\n return false;\n }\n if (node.nodeType !== node.ELEMENT_NODE) {\n return needMaskingText(node.parentNode, maskTextClass, maskTextSelector, unmaskTextSelector, maskAllText);\n }\n if (unmaskTextSelector) {\n if (node.matches(unmaskTextSelector) ||\n node.closest(unmaskTextSelector)) {\n return false;\n }\n }\n if (maskAllText) {\n return true;\n }\n if (typeof maskTextClass === 'string') {\n if (node.classList.contains(maskTextClass)) {\n return true;\n }\n }\n else {\n for (let eIndex = 0; eIndex < node.classList.length; eIndex++) {\n const className = node.classList[eIndex];\n if (maskTextClass.test(className)) {\n return true;\n }\n }\n }\n if (maskTextSelector) {\n if (node.matches(maskTextSelector)) {\n return true;\n }\n }\n return needMaskingText(node.parentNode, maskTextClass, maskTextSelector, unmaskTextSelector, maskAllText);\n}\nfunction onceIframeLoaded(iframeEl, listener, iframeLoadTimeout) {\n const win = iframeEl.contentWindow;\n if (!win) {\n return;\n }\n let fired = false;\n let readyState;\n try {\n readyState = win.document.readyState;\n }\n catch (error) {\n return;\n }\n if (readyState !== 'complete') {\n const timer = setTimeout(() => {\n if (!fired) {\n listener();\n fired = true;\n }\n }, iframeLoadTimeout);\n iframeEl.addEventListener('load', () => {\n clearTimeout(timer);\n fired = true;\n listener();\n });\n return;\n }\n const blankUrl = 'about:blank';\n if (win.location.href !== blankUrl ||\n iframeEl.src === blankUrl ||\n iframeEl.src === '') {\n setTimeout(listener, 0);\n return;\n }\n iframeEl.addEventListener('load', listener);\n}\nfunction serializeNode(n, options) {\n var _a;\n const { doc, blockClass, blockSelector, unblockSelector, maskTextClass, maskTextSelector, unmaskTextSelector, inlineStylesheet, maskInputSelector, unmaskInputSelector, maskAllText, maskInputOptions = {}, maskTextFn, maskInputFn, dataURLOptions = {}, inlineImages, recordCanvas, keepIframeSrcFn, } = options;\n let rootId;\n if (doc.__sn) {\n const docId = doc.__sn.id;\n rootId = docId === 1 ? undefined : docId;\n }\n switch (n.nodeType) {\n case n.DOCUMENT_NODE:\n if (n.compatMode !== 'CSS1Compat') {\n return {\n type: NodeType.Document,\n childNodes: [],\n compatMode: n.compatMode,\n rootId,\n };\n }\n else {\n return {\n type: NodeType.Document,\n childNodes: [],\n rootId,\n };\n }\n case n.DOCUMENT_TYPE_NODE:\n return {\n type: NodeType.DocumentType,\n name: n.name,\n publicId: n.publicId,\n systemId: n.systemId,\n rootId,\n };\n case n.ELEMENT_NODE:\n const needBlock = _isBlockedElement(n, blockClass, blockSelector, unblockSelector);\n const tagName = getValidTagName(n);\n let attributes = {};\n for (const { name, value } of Array.from(n.attributes)) {\n if (!skipAttribute(tagName, name)) {\n attributes[name] = transformAttribute(doc, n, tagName, name, value, maskAllText, unmaskTextSelector, maskTextFn);\n }\n }\n if (tagName === 'link' && inlineStylesheet) {\n const stylesheet = Array.from(doc.styleSheets).find((s) => {\n return s.href === n.href;\n });\n let cssText = null;\n if (stylesheet) {\n cssText = getCssRulesString(stylesheet);\n }\n if (cssText) {\n delete attributes.rel;\n delete attributes.href;\n attributes._cssText = absoluteToStylesheet(cssText, stylesheet.href);\n }\n }\n if (tagName === 'style' &&\n n.sheet &&\n !(n.innerText ||\n n.textContent ||\n '').trim().length) {\n const cssText = getCssRulesString(n.sheet);\n if (cssText) {\n attributes._cssText = absoluteToStylesheet(cssText, getHref());\n }\n }\n if (tagName === 'input' ||\n tagName === 'textarea' ||\n tagName === 'select' ||\n tagName === 'option') {\n const el = n;\n const type = getInputType(el);\n const value = getInputValue(el, tagName.toUpperCase(), type);\n const checked = n.checked;\n if (type !== 'submit' &&\n type !== 'button' &&\n value) {\n attributes.value = maskInputValue({\n input: el,\n type,\n tagName,\n value,\n maskInputSelector,\n unmaskInputSelector,\n maskInputOptions,\n maskInputFn,\n });\n }\n if (checked) {\n attributes.checked = checked;\n }\n }\n if (tagName === 'option') {\n if (n.selected && !maskInputOptions['select']) {\n attributes.selected = true;\n }\n else {\n delete attributes.selected;\n }\n }\n if (tagName === 'canvas' && recordCanvas) {\n if (n.__context === '2d') {\n if (!is2DCanvasBlank(n)) {\n attributes.rr_dataURL = n.toDataURL(dataURLOptions.type, dataURLOptions.quality);\n }\n }\n else if (!('__context' in n)) {\n const canvasDataURL = n.toDataURL(dataURLOptions.type, dataURLOptions.quality);\n const blankCanvas = document.createElement('canvas');\n blankCanvas.width = n.width;\n blankCanvas.height = n.height;\n const blankCanvasDataURL = blankCanvas.toDataURL(dataURLOptions.type, dataURLOptions.quality);\n if (canvasDataURL !== blankCanvasDataURL) {\n attributes.rr_dataURL = canvasDataURL;\n }\n }\n }\n if (tagName === 'img' && inlineImages) {\n if (!canvasService) {\n canvasService = doc.createElement('canvas');\n canvasCtx = canvasService.getContext('2d');\n }\n const image = n;\n const oldValue = image.crossOrigin;\n image.crossOrigin = 'anonymous';\n const recordInlineImage = () => {\n try {\n canvasService.width = image.naturalWidth;\n canvasService.height = image.naturalHeight;\n canvasCtx.drawImage(image, 0, 0);\n attributes.rr_dataURL = canvasService.toDataURL(dataURLOptions.type, dataURLOptions.quality);\n }\n catch (err) {\n console.warn(`Cannot inline img src=${image.currentSrc}! Error: ${err}`);\n }\n oldValue\n ? (attributes.crossOrigin = oldValue)\n : delete attributes.crossOrigin;\n };\n if (image.complete && image.naturalWidth !== 0)\n recordInlineImage();\n else\n image.onload = recordInlineImage;\n }\n if (tagName === 'audio' || tagName === 'video') {\n attributes.rr_mediaState = n.paused\n ? 'paused'\n : 'played';\n attributes.rr_mediaCurrentTime = n.currentTime;\n }\n if (n.scrollLeft) {\n attributes.rr_scrollLeft = n.scrollLeft;\n }\n if (n.scrollTop) {\n attributes.rr_scrollTop = n.scrollTop;\n }\n if (needBlock) {\n const { width, height } = n.getBoundingClientRect();\n attributes = {\n class: attributes.class,\n rr_width: `${width}px`,\n rr_height: `${height}px`,\n };\n }\n if (tagName === 'iframe' && !keepIframeSrcFn(attributes.src)) {\n if (!n.contentDocument) {\n attributes.rr_src = attributes.src;\n }\n delete attributes.src;\n }\n return {\n type: NodeType.Element,\n tagName,\n attributes,\n childNodes: [],\n isSVG: isSVGElement(n) || undefined,\n needBlock,\n rootId,\n };\n case n.TEXT_NODE:\n const parentTagName = n.parentNode && n.parentNode.tagName;\n let textContent = n.textContent;\n const isStyle = parentTagName === 'STYLE' ? true : undefined;\n const isScript = parentTagName === 'SCRIPT' ? true : undefined;\n if (isStyle && textContent) {\n try {\n if (n.nextSibling || n.previousSibling) {\n }\n else if ((_a = n.parentNode.sheet) === null || _a === void 0 ? void 0 : _a.cssRules) {\n textContent = stringifyStyleSheet(n.parentNode.sheet);\n }\n }\n catch (err) {\n console.warn(`Cannot get CSS styles from text's parentNode. Error: ${err}`, n);\n }\n textContent = absoluteToStylesheet(textContent, getHref());\n }\n if (isScript) {\n textContent = 'SCRIPT_PLACEHOLDER';\n }\n if (parentTagName === 'TEXTAREA' && textContent) {\n textContent = '';\n }\n else if (parentTagName === 'OPTION' && textContent) {\n const option = n.parentNode;\n textContent = maskInputValue({\n input: option,\n type: null,\n tagName: parentTagName,\n value: textContent,\n maskInputSelector,\n unmaskInputSelector,\n maskInputOptions,\n maskInputFn,\n });\n }\n else if (!isStyle &&\n !isScript &&\n needMaskingText(n, maskTextClass, maskTextSelector, unmaskTextSelector, maskAllText) &&\n textContent) {\n textContent = maskTextFn\n ? maskTextFn(textContent)\n : defaultMaskFn(textContent);\n }\n return {\n type: NodeType.Text,\n textContent: textContent || '',\n isStyle,\n rootId,\n };\n case n.CDATA_SECTION_NODE:\n return {\n type: NodeType.CDATA,\n textContent: '',\n rootId,\n };\n case n.COMMENT_NODE:\n return {\n type: NodeType.Comment,\n textContent: n.textContent || '',\n rootId,\n };\n default:\n return false;\n }\n}\nfunction lowerIfExists(maybeAttr) {\n if (maybeAttr === undefined || maybeAttr === null) {\n return '';\n }\n else {\n return maybeAttr.toLowerCase();\n }\n}\nfunction slimDOMExcluded(sn, slimDOMOptions) {\n if (slimDOMOptions.comment && sn.type === NodeType.Comment) {\n return true;\n }\n else if (sn.type === NodeType.Element) {\n if (slimDOMOptions.script &&\n (sn.tagName === 'script' ||\n (sn.tagName === 'link' &&\n (sn.attributes.rel === 'preload' ||\n sn.attributes.rel === 'modulepreload') &&\n sn.attributes.as === 'script') ||\n (sn.tagName === 'link' &&\n sn.attributes.rel === 'prefetch' &&\n typeof sn.attributes.href === 'string' &&\n sn.attributes.href.endsWith('.js')))) {\n return true;\n }\n else if (slimDOMOptions.headFavicon &&\n ((sn.tagName === 'link' && sn.attributes.rel === 'shortcut icon') ||\n (sn.tagName === 'meta' &&\n (lowerIfExists(sn.attributes.name).match(/^msapplication-tile(image|color)$/) ||\n lowerIfExists(sn.attributes.name) === 'application-name' ||\n lowerIfExists(sn.attributes.rel) === 'icon' ||\n lowerIfExists(sn.attributes.rel) === 'apple-touch-icon' ||\n lowerIfExists(sn.attributes.rel) === 'shortcut icon')))) {\n return true;\n }\n else if (sn.tagName === 'meta') {\n if (slimDOMOptions.headMetaDescKeywords &&\n lowerIfExists(sn.attributes.name).match(/^description|keywords$/)) {\n return true;\n }\n else if (slimDOMOptions.headMetaSocial &&\n (lowerIfExists(sn.attributes.property).match(/^(og|twitter|fb):/) ||\n lowerIfExists(sn.attributes.name).match(/^(og|twitter):/) ||\n lowerIfExists(sn.attributes.name) === 'pinterest')) {\n return true;\n }\n else if (slimDOMOptions.headMetaRobots &&\n (lowerIfExists(sn.attributes.name) === 'robots' ||\n lowerIfExists(sn.attributes.name) === 'googlebot' ||\n lowerIfExists(sn.attributes.name) === 'bingbot')) {\n return true;\n }\n else if (slimDOMOptions.headMetaHttpEquiv &&\n sn.attributes['http-equiv'] !== undefined) {\n return true;\n }\n else if (slimDOMOptions.headMetaAuthorship &&\n (lowerIfExists(sn.attributes.name) === 'author' ||\n lowerIfExists(sn.attributes.name) === 'generator' ||\n lowerIfExists(sn.attributes.name) === 'framework' ||\n lowerIfExists(sn.attributes.name) === 'publisher' ||\n lowerIfExists(sn.attributes.name) === 'progid' ||\n lowerIfExists(sn.attributes.property).match(/^article:/) ||\n lowerIfExists(sn.attributes.property).match(/^product:/))) {\n return true;\n }\n else if (slimDOMOptions.headMetaVerification &&\n (lowerIfExists(sn.attributes.name) === 'google-site-verification' ||\n lowerIfExists(sn.attributes.name) === 'yandex-verification' ||\n lowerIfExists(sn.attributes.name) === 'csrf-token' ||\n lowerIfExists(sn.attributes.name) === 'p:domain_verify' ||\n lowerIfExists(sn.attributes.name) === 'verify-v1' ||\n lowerIfExists(sn.attributes.name) === 'verification' ||\n lowerIfExists(sn.attributes.name) === 'shopify-checkout-api-token')) {\n return true;\n }\n }\n }\n return false;\n}\nfunction serializeNodeWithId(n, options) {\n const { doc, map, blockClass, blockSelector, unblockSelector, maskTextClass, maskTextSelector, unmaskTextSelector, skipChild = false, inlineStylesheet = true, maskInputSelector, unmaskInputSelector, maskAllText, maskInputOptions = {}, maskTextFn, maskInputFn, slimDOMOptions, dataURLOptions = {}, inlineImages = false, recordCanvas = false, onSerialize, onIframeLoad, iframeLoadTimeout = 5000, keepIframeSrcFn = () => false, } = options;\n let { preserveWhiteSpace = true } = options;\n const _serializedNode = serializeNode(n, {\n doc,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n inlineStylesheet,\n maskInputSelector,\n unmaskInputSelector,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n keepIframeSrcFn,\n });\n if (!_serializedNode) {\n console.warn(n, 'not serialized');\n return null;\n }\n let id;\n if ('__sn' in n) {\n id = n.__sn.id;\n }\n else if (slimDOMExcluded(_serializedNode, slimDOMOptions) ||\n (!preserveWhiteSpace &&\n _serializedNode.type === NodeType.Text &&\n !_serializedNode.isStyle &&\n !_serializedNode.textContent.replace(/^\\s+|\\s+$/gm, '').length)) {\n id = IGNORED_NODE;\n }\n else {\n id = genId();\n }\n const serializedNode = Object.assign(_serializedNode, { id });\n n.__sn = serializedNode;\n if (id === IGNORED_NODE) {\n return null;\n }\n map[id] = n;\n if (onSerialize) {\n onSerialize(n);\n }\n let recordChild = !skipChild;\n if (serializedNode.type === NodeType.Element) {\n recordChild = recordChild && !serializedNode.needBlock;\n delete serializedNode.needBlock;\n if (n.shadowRoot)\n serializedNode.isShadowHost = true;\n }\n if ((serializedNode.type === NodeType.Document ||\n serializedNode.type === NodeType.Element) &&\n recordChild) {\n if (slimDOMOptions.headWhitespace &&\n _serializedNode.type === NodeType.Element &&\n _serializedNode.tagName === 'head') {\n preserveWhiteSpace = false;\n }\n const bypassOptions = {\n doc,\n map,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n skipChild,\n inlineStylesheet,\n maskInputSelector,\n unmaskInputSelector,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n keepIframeSrcFn,\n };\n for (const childN of Array.from(n.childNodes)) {\n const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\n if (serializedChildNode) {\n serializedNode.childNodes.push(serializedChildNode);\n }\n }\n if (isElement(n) && n.shadowRoot) {\n for (const childN of Array.from(n.shadowRoot.childNodes)) {\n const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\n if (serializedChildNode) {\n serializedChildNode.isShadow = true;\n serializedNode.childNodes.push(serializedChildNode);\n }\n }\n }\n }\n if (n.parentNode && isShadowRoot(n.parentNode)) {\n serializedNode.isShadow = true;\n }\n if (serializedNode.type === NodeType.Element &&\n serializedNode.tagName === 'iframe') {\n onceIframeLoaded(n, () => {\n const iframeDoc = n.contentDocument;\n if (iframeDoc && onIframeLoad) {\n const serializedIframeNode = serializeNodeWithId(iframeDoc, {\n doc: iframeDoc,\n map,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n skipChild: false,\n inlineStylesheet,\n maskInputSelector,\n unmaskInputSelector,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n keepIframeSrcFn,\n });\n if (serializedIframeNode) {\n onIframeLoad(n, serializedIframeNode);\n }\n }\n }, iframeLoadTimeout);\n }\n return serializedNode;\n}\nfunction snapshot(n, options) {\n const { blockClass = 'rr-block', blockSelector = null, unblockSelector = null, maskTextClass = 'rr-mask', maskTextSelector = null, unmaskTextSelector = null, inlineStylesheet = true, inlineImages = false, recordCanvas = false, maskInputSelector = null, unmaskInputSelector = null, maskAllText = false, maskAllInputs = false, maskTextFn, maskInputFn, slimDOM = false, dataURLOptions, preserveWhiteSpace, onSerialize, onIframeLoad, iframeLoadTimeout, keepIframeSrcFn = () => false, } = options || {};\n const idNodeMap = {};\n const maskInputOptions = maskAllInputs === true\n ? {\n color: true,\n date: true,\n 'datetime-local': true,\n email: true,\n month: true,\n number: true,\n range: true,\n search: true,\n tel: true,\n text: true,\n time: true,\n url: true,\n week: true,\n textarea: true,\n select: true,\n }\n : maskAllInputs === false\n ? {}\n : maskAllInputs;\n const slimDOMOptions = slimDOM === true || slimDOM === 'all'\n ?\n {\n script: true,\n comment: true,\n headFavicon: true,\n headWhitespace: true,\n headMetaDescKeywords: slimDOM === 'all',\n headMetaSocial: true,\n headMetaRobots: true,\n headMetaHttpEquiv: true,\n headMetaAuthorship: true,\n headMetaVerification: true,\n }\n : slimDOM === false\n ? {}\n : slimDOM;\n return [\n serializeNodeWithId(n, {\n doc: n,\n map: idNodeMap,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n skipChild: false,\n inlineStylesheet,\n maskInputSelector,\n unmaskInputSelector,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n keepIframeSrcFn,\n }),\n idNodeMap,\n ];\n}\nfunction skipAttribute(tagName, attributeName, value) {\n return ((tagName === 'video' || tagName === 'audio') && attributeName === 'autoplay');\n}\n\nconst commentre = /\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\//g;\nfunction parse(css, options = {}) {\n let lineno = 1;\n let column = 1;\n function updatePosition(str) {\n const lines = str.match(/\\n/g);\n if (lines) {\n lineno += lines.length;\n }\n let i = str.lastIndexOf('\\n');\n column = i === -1 ? column + str.length : str.length - i;\n }\n function position() {\n const start = { line: lineno, column };\n return (node) => {\n node.position = new Position(start);\n whitespace();\n return node;\n };\n }\n class Position {\n constructor(start) {\n this.start = start;\n this.end = { line: lineno, column };\n this.source = options.source;\n }\n }\n Position.prototype.content = css;\n const errorsList = [];\n function error(msg) {\n const err = new Error(options.source + ':' + lineno + ':' + column + ': ' + msg);\n err.reason = msg;\n err.filename = options.source;\n err.line = lineno;\n err.column = column;\n err.source = css;\n if (options.silent) {\n errorsList.push(err);\n }\n else {\n throw err;\n }\n }\n function stylesheet() {\n const rulesList = rules();\n return {\n type: 'stylesheet',\n stylesheet: {\n source: options.source,\n rules: rulesList,\n parsingErrors: errorsList,\n },\n };\n }\n function open() {\n return match(/^{\\s*/);\n }\n function close() {\n return match(/^}/);\n }\n function rules() {\n let node;\n const rules = [];\n whitespace();\n comments(rules);\n while (css.length && css.charAt(0) !== '}' && (node = atrule() || rule())) {\n if (node !== false) {\n rules.push(node);\n comments(rules);\n }\n }\n return rules;\n }\n function match(re) {\n const m = re.exec(css);\n if (!m) {\n return;\n }\n const str = m[0];\n updatePosition(str);\n css = css.slice(str.length);\n return m;\n }\n function whitespace() {\n match(/^\\s*/);\n }\n function comments(rules = []) {\n let c;\n while ((c = comment())) {\n if (c !== false) {\n rules.push(c);\n }\n c = comment();\n }\n return rules;\n }\n function comment() {\n const pos = position();\n if ('/' !== css.charAt(0) || '*' !== css.charAt(1)) {\n return;\n }\n let i = 2;\n while ('' !== css.charAt(i) &&\n ('*' !== css.charAt(i) || '/' !== css.charAt(i + 1))) {\n ++i;\n }\n i += 2;\n if ('' === css.charAt(i - 1)) {\n return error('End of comment missing');\n }\n const str = css.slice(2, i - 2);\n column += 2;\n updatePosition(str);\n css = css.slice(i);\n column += 2;\n return pos({\n type: 'comment',\n comment: str,\n });\n }\n function selector() {\n const m = match(/^([^{]+)/);\n if (!m) {\n return;\n }\n return trim(m[0])\n .replace(/\\/\\*([^*]|[\\r\\n]|(\\*+([^*/]|[\\r\\n])))*\\*\\/+/g, '')\n .replace(/\"(?:\\\\\"|[^\"])*\"|'(?:\\\\'|[^'])*'/g, (m) => {\n return m.replace(/,/g, '\\u200C');\n })\n .split(/\\s*(?![^(]*\\)),\\s*/)\n .map((s) => {\n return s.replace(/\\u200C/g, ',');\n });\n }\n function declaration() {\n const pos = position();\n let propMatch = match(/^(\\*?[-#\\/\\*\\\\\\w]+(\\[[0-9a-z_-]+\\])?)\\s*/);\n if (!propMatch) {\n return;\n }\n const prop = trim(propMatch[0]);\n if (!match(/^:\\s*/)) {\n return error(`property missing ':'`);\n }\n const val = match(/^((?:'(?:\\\\'|.)*?'|\"(?:\\\\\"|.)*?\"|\\([^\\)]*?\\)|[^};])+)/);\n const ret = pos({\n type: 'declaration',\n property: prop.replace(commentre, ''),\n value: val ? trim(val[0]).replace(commentre, '') : '',\n });\n match(/^[;\\s]*/);\n return ret;\n }\n function declarations() {\n const decls = [];\n if (!open()) {\n return error(`missing '{'`);\n }\n comments(decls);\n let decl;\n while ((decl = declaration())) {\n if (decl !== false) {\n decls.push(decl);\n comments(decls);\n }\n decl = declaration();\n }\n if (!close()) {\n return error(`missing '}'`);\n }\n return decls;\n }\n function keyframe() {\n let m;\n const vals = [];\n const pos = position();\n while ((m = match(/^((\\d+\\.\\d+|\\.\\d+|\\d+)%?|[a-z]+)\\s*/))) {\n vals.push(m[1]);\n match(/^,\\s*/);\n }\n if (!vals.length) {\n return;\n }\n return pos({\n type: 'keyframe',\n values: vals,\n declarations: declarations(),\n });\n }\n function atkeyframes() {\n const pos = position();\n let m = match(/^@([-\\w]+)?keyframes\\s*/);\n if (!m) {\n return;\n }\n const vendor = m[1];\n m = match(/^([-\\w]+)\\s*/);\n if (!m) {\n return error('@keyframes missing name');\n }\n const name = m[1];\n if (!open()) {\n return error(`@keyframes missing '{'`);\n }\n let frame;\n let frames = comments();\n while ((frame = keyframe())) {\n frames.push(frame);\n frames = frames.concat(comments());\n }\n if (!close()) {\n return error(`@keyframes missing '}'`);\n }\n return pos({\n type: 'keyframes',\n name,\n vendor,\n keyframes: frames,\n });\n }\n function atsupports() {\n const pos = position();\n const m = match(/^@supports *([^{]+)/);\n if (!m) {\n return;\n }\n const supports = trim(m[1]);\n if (!open()) {\n return error(`@supports missing '{'`);\n }\n const style = comments().concat(rules());\n if (!close()) {\n return error(`@supports missing '}'`);\n }\n return pos({\n type: 'supports',\n supports,\n rules: style,\n });\n }\n function athost() {\n const pos = position();\n const m = match(/^@host\\s*/);\n if (!m) {\n return;\n }\n if (!open()) {\n return error(`@host missing '{'`);\n }\n const style = comments().concat(rules());\n if (!close()) {\n return error(`@host missing '}'`);\n }\n return pos({\n type: 'host',\n rules: style,\n });\n }\n function atmedia() {\n const pos = position();\n const m = match(/^@media *([^{]+)/);\n if (!m) {\n return;\n }\n const media = trim(m[1]);\n if (!open()) {\n return error(`@media missing '{'`);\n }\n const style = comments().concat(rules());\n if (!close()) {\n return error(`@media missing '}'`);\n }\n return pos({\n type: 'media',\n media,\n rules: style,\n });\n }\n function atcustommedia() {\n const pos = position();\n const m = match(/^@custom-media\\s+(--[^\\s]+)\\s*([^{;]+);/);\n if (!m) {\n return;\n }\n return pos({\n type: 'custom-media',\n name: trim(m[1]),\n media: trim(m[2]),\n });\n }\n function atpage() {\n const pos = position();\n const m = match(/^@page */);\n if (!m) {\n return;\n }\n const sel = selector() || [];\n if (!open()) {\n return error(`@page missing '{'`);\n }\n let decls = comments();\n let decl;\n while ((decl = declaration())) {\n decls.push(decl);\n decls = decls.concat(comments());\n }\n if (!close()) {\n return error(`@page missing '}'`);\n }\n return pos({\n type: 'page',\n selectors: sel,\n declarations: decls,\n });\n }\n function atdocument() {\n const pos = position();\n const m = match(/^@([-\\w]+)?document *([^{]+)/);\n if (!m) {\n return;\n }\n const vendor = trim(m[1]);\n const doc = trim(m[2]);\n if (!open()) {\n return error(`@document missing '{'`);\n }\n const style = comments().concat(rules());\n if (!close()) {\n return error(`@document missing '}'`);\n }\n return pos({\n type: 'document',\n document: doc,\n vendor,\n rules: style,\n });\n }\n function atfontface() {\n const pos = position();\n const m = match(/^@font-face\\s*/);\n if (!m) {\n return;\n }\n if (!open()) {\n return error(`@font-face missing '{'`);\n }\n let decls = comments();\n let decl;\n while ((decl = declaration())) {\n decls.push(decl);\n decls = decls.concat(comments());\n }\n if (!close()) {\n return error(`@font-face missing '}'`);\n }\n return pos({\n type: 'font-face',\n declarations: decls,\n });\n }\n const atimport = _compileAtrule('import');\n const atcharset = _compileAtrule('charset');\n const atnamespace = _compileAtrule('namespace');\n function _compileAtrule(name) {\n const re = new RegExp('^@' + name + '\\\\s*([^;]+);');\n return () => {\n const pos = position();\n const m = match(re);\n if (!m) {\n return;\n }\n const ret = { type: name };\n ret[name] = m[1].trim();\n return pos(ret);\n };\n }\n function atrule() {\n if (css[0] !== '@') {\n return;\n }\n return (atkeyframes() ||\n atmedia() ||\n atcustommedia() ||\n atsupports() ||\n atimport() ||\n atcharset() ||\n atnamespace() ||\n atdocument() ||\n atpage() ||\n athost() ||\n atfontface());\n }\n function rule() {\n const pos = position();\n const sel = selector();\n if (!sel) {\n return error('selector missing');\n }\n comments();\n return pos({\n type: 'rule',\n selectors: sel,\n declarations: declarations(),\n });\n }\n return addParent(stylesheet());\n}\nfunction trim(str) {\n return str ? str.replace(/^\\s+|\\s+$/g, '') : '';\n}\nfunction addParent(obj, parent) {\n const isNode = obj && typeof obj.type === 'string';\n const childParent = isNode ? obj : parent;\n for (const k of Object.keys(obj)) {\n const value = obj[k];\n if (Array.isArray(value)) {\n value.forEach((v) => {\n addParent(v, childParent);\n });\n }\n else if (value && typeof value === 'object') {\n addParent(value, childParent);\n }\n }\n if (isNode) {\n Object.defineProperty(obj, 'parent', {\n configurable: true,\n writable: true,\n enumerable: false,\n value: parent || null,\n });\n }\n return obj;\n}\n\nconst tagMap = {\n script: 'noscript',\n altglyph: 'altGlyph',\n altglyphdef: 'altGlyphDef',\n altglyphitem: 'altGlyphItem',\n animatecolor: 'animateColor',\n animatemotion: 'animateMotion',\n animatetransform: 'animateTransform',\n clippath: 'clipPath',\n feblend: 'feBlend',\n fecolormatrix: 'feColorMatrix',\n fecomponenttransfer: 'feComponentTransfer',\n fecomposite: 'feComposite',\n feconvolvematrix: 'feConvolveMatrix',\n fediffuselighting: 'feDiffuseLighting',\n fedisplacementmap: 'feDisplacementMap',\n fedistantlight: 'feDistantLight',\n fedropshadow: 'feDropShadow',\n feflood: 'feFlood',\n fefunca: 'feFuncA',\n fefuncb: 'feFuncB',\n fefuncg: 'feFuncG',\n fefuncr: 'feFuncR',\n fegaussianblur: 'feGaussianBlur',\n feimage: 'feImage',\n femerge: 'feMerge',\n femergenode: 'feMergeNode',\n femorphology: 'feMorphology',\n feoffset: 'feOffset',\n fepointlight: 'fePointLight',\n fespecularlighting: 'feSpecularLighting',\n fespotlight: 'feSpotLight',\n fetile: 'feTile',\n feturbulence: 'feTurbulence',\n foreignobject: 'foreignObject',\n glyphref: 'glyphRef',\n lineargradient: 'linearGradient',\n radialgradient: 'radialGradient',\n};\nfunction getTagName(n) {\n let tagName = tagMap[n.tagName] ? tagMap[n.tagName] : n.tagName;\n if (tagName === 'link' && n.attributes._cssText) {\n tagName = 'style';\n }\n return tagName;\n}\nfunction escapeRegExp(str) {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\nconst HOVER_SELECTOR = /([^\\\\]):hover/;\nconst HOVER_SELECTOR_GLOBAL = new RegExp(HOVER_SELECTOR.source, 'g');\nfunction addHoverClass(cssText, cache) {\n const cachedStyle = cache === null || cache === void 0 ? void 0 : cache.stylesWithHoverClass.get(cssText);\n if (cachedStyle)\n return cachedStyle;\n const ast = parse(cssText, {\n silent: true,\n });\n if (!ast.stylesheet) {\n return cssText;\n }\n const selectors = [];\n ast.stylesheet.rules.forEach((rule) => {\n if ('selectors' in rule) {\n (rule.selectors || []).forEach((selector) => {\n if (HOVER_SELECTOR.test(selector)) {\n selectors.push(selector);\n }\n });\n }\n });\n if (selectors.length === 0) {\n return cssText;\n }\n const selectorMatcher = new RegExp(selectors\n .filter((selector, index) => selectors.indexOf(selector) === index)\n .sort((a, b) => b.length - a.length)\n .map((selector) => {\n return escapeRegExp(selector);\n })\n .join('|'), 'g');\n const result = cssText.replace(selectorMatcher, (selector) => {\n const newSelector = selector.replace(HOVER_SELECTOR_GLOBAL, '$1.\\\\:hover');\n return `${selector}, ${newSelector}`;\n });\n cache === null || cache === void 0 ? void 0 : cache.stylesWithHoverClass.set(cssText, result);\n return result;\n}\nfunction createCache() {\n const stylesWithHoverClass = new Map();\n return {\n stylesWithHoverClass,\n };\n}\nfunction buildNode(n, options) {\n const { doc, hackCss, cache } = options;\n switch (n.type) {\n case NodeType.Document:\n return doc.implementation.createDocument(null, '', null);\n case NodeType.DocumentType:\n return doc.implementation.createDocumentType(n.name || 'html', n.publicId, n.systemId);\n case NodeType.Element:\n const tagName = getTagName(n);\n let node;\n if (n.isSVG) {\n node = doc.createElementNS('http://www.w3.org/2000/svg', tagName);\n }\n else {\n node = doc.createElement(tagName);\n }\n for (const name in n.attributes) {\n if (!n.attributes.hasOwnProperty(name)) {\n continue;\n }\n let value = n.attributes[name];\n if (tagName === 'option' && name === 'selected' && value === false) {\n continue;\n }\n value =\n typeof value === 'boolean' || typeof value === 'number' || value === null ? '' : value;\n if (!name.startsWith('rr_')) {\n const isTextarea = tagName === 'textarea' && name === 'value';\n const isRemoteOrDynamicCss = tagName === 'style' && name === '_cssText';\n if (isRemoteOrDynamicCss && hackCss) {\n value = addHoverClass(value, cache);\n }\n if (isTextarea || isRemoteOrDynamicCss) {\n const child = doc.createTextNode(value);\n for (const c of Array.from(node.childNodes)) {\n if (c.nodeType === node.TEXT_NODE) {\n node.removeChild(c);\n }\n }\n node.appendChild(child);\n continue;\n }\n try {\n if (n.isSVG && name === 'xlink:href') {\n node.setAttributeNS('http://www.w3.org/1999/xlink', name, value);\n }\n else if (name === 'onload' ||\n name === 'onclick' ||\n name.substring(0, 7) === 'onmouse') {\n node.setAttribute('_' + name, value);\n }\n else if (tagName === 'meta' &&\n n.attributes['http-equiv'] === 'Content-Security-Policy' &&\n name === 'content') {\n node.setAttribute('csp-content', value);\n continue;\n }\n else if (tagName === 'link' &&\n (n.attributes.rel === 'preload' || n.attributes.rel === 'modulepreload') &&\n n.attributes.as === 'script') {\n }\n else if (tagName === 'link' &&\n n.attributes.rel === 'prefetch' &&\n typeof n.attributes.href === 'string' &&\n n.attributes.href.endsWith('.js')) {\n }\n else if (tagName === 'img' &&\n n.attributes.srcset &&\n n.attributes.rr_dataURL) {\n node.setAttribute('rrweb-original-srcset', n.attributes.srcset);\n }\n else {\n node.setAttribute(name, value);\n }\n }\n catch (error) {\n }\n }\n else {\n if (tagName === 'canvas' && name === 'rr_dataURL') {\n const image = document.createElement('img');\n image.src = value;\n image.onload = () => {\n const ctx = node.getContext('2d');\n if (ctx) {\n ctx.drawImage(image, 0, 0, image.width, image.height);\n }\n };\n }\n else if (tagName === 'img' && name === 'rr_dataURL') {\n const image = node;\n if (!image.currentSrc.startsWith('data:')) {\n image.setAttribute('rrweb-original-src', n.attributes.src);\n image.src = value;\n }\n }\n if (name === 'rr_width') {\n node.style.width = value;\n }\n else if (name === 'rr_height') {\n node.style.height = value;\n }\n else if (name === 'rr_mediaCurrentTime') {\n node.currentTime = n.attributes\n .rr_mediaCurrentTime;\n }\n else if (name === 'rr_mediaState') {\n switch (value) {\n case 'played':\n node\n .play()\n .catch((e) => console.warn('media playback error', e));\n break;\n case 'paused':\n node.pause();\n break;\n }\n }\n }\n }\n if (n.isShadowHost) {\n if (!node.shadowRoot) {\n node.attachShadow({ mode: 'open' });\n if (doc.defaultView) {\n defineCustomElement(doc.defaultView, tagName);\n }\n }\n else {\n while (node.shadowRoot.firstChild) {\n node.shadowRoot.removeChild(node.shadowRoot.firstChild);\n }\n }\n }\n return node;\n case NodeType.Text:\n return doc.createTextNode(n.isStyle && hackCss\n ? addHoverClass(n.textContent, cache)\n : n.textContent);\n case NodeType.CDATA:\n return doc.createCDATASection(n.textContent);\n case NodeType.Comment:\n return doc.createComment(n.textContent);\n default:\n return null;\n }\n}\nfunction buildNodeWithSN(n, options) {\n const { doc, map, skipChild = false, hackCss = true, afterAppend, cache, } = options;\n let node = buildNode(n, { doc, hackCss, cache });\n if (!node) {\n return null;\n }\n if (n.rootId) {\n console.assert(map[n.rootId] === doc, 'Target document should has the same root id.');\n }\n if (n.type === NodeType.Document) {\n doc.close();\n doc.open();\n if (n.compatMode === 'BackCompat' &&\n n.childNodes &&\n n.childNodes[0].type !== NodeType.DocumentType) {\n if (n.childNodes[0].type === NodeType.Element &&\n 'xmlns' in n.childNodes[0].attributes &&\n n.childNodes[0].attributes.xmlns === 'http://www.w3.org/1999/xhtml') {\n doc.write('<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"\">');\n }\n else {\n doc.write('<!DOCTYPE html PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"\">');\n }\n }\n node = doc;\n }\n node.__sn = n;\n map[n.id] = node;\n if ((n.type === NodeType.Document || n.type === NodeType.Element) &&\n !skipChild) {\n for (const childN of n.childNodes) {\n const childNode = buildNodeWithSN(childN, {\n doc,\n map,\n skipChild: false,\n hackCss,\n afterAppend,\n cache,\n });\n if (!childNode) {\n console.warn('Failed to rebuild', childN);\n continue;\n }\n if (childN.isShadow && isElement(node) && node.shadowRoot) {\n node.shadowRoot.appendChild(childNode);\n }\n else {\n node.appendChild(childNode);\n }\n if (afterAppend) {\n afterAppend(childNode);\n }\n }\n }\n return node;\n}\nfunction visit(idNodeMap, onVisit) {\n function walk(node) {\n onVisit(node);\n }\n for (const key in idNodeMap) {\n if (idNodeMap[key]) {\n walk(idNodeMap[key]);\n }\n }\n}\nfunction handleScroll(node) {\n const n = node.__sn;\n if (n.type !== NodeType.Element) {\n return;\n }\n const el = node;\n for (const name in n.attributes) {\n if (!(n.attributes.hasOwnProperty(name) && name.startsWith('rr_'))) {\n continue;\n }\n const value = n.attributes[name];\n if (name === 'rr_scrollLeft') {\n el.scrollLeft = value;\n }\n if (name === 'rr_scrollTop') {\n el.scrollTop = value;\n }\n }\n}\nfunction rebuild(n, options) {\n const { doc, onVisit, hackCss = true, afterAppend, cache } = options;\n const idNodeMap = {};\n const node = buildNodeWithSN(n, {\n doc,\n map: idNodeMap,\n skipChild: false,\n hackCss,\n afterAppend,\n cache,\n });\n visit(idNodeMap, (visitedNode) => {\n if (onVisit) {\n onVisit(visitedNode);\n }\n handleScroll(visitedNode);\n });\n return [node, idNodeMap];\n}\n\nexport { IGNORED_NODE, NodeType, addHoverClass, buildNodeWithSN, createCache, defineCustomElement, getInputType, getInputValue, hasInputMaskOptions, is2DCanvasBlank, isElement, isShadowRoot, maskInputValue, needMaskingText, rebuild, serializeNodeWithId, snapshot, transformAttribute };\n","import { GLOBAL_OBJ } from '@sentry/utils';\n\n// exporting a separate copy of `WINDOW` rather than exporting the one from `@sentry/browser`\n// prevents the browser package from being bundled in the CDN bundle, and avoids a\n// circular dependency between the browser and replay packages should `@sentry/browser` import\n// from `@sentry/replay` in the future\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ & Window;\n\nexport const REPLAY_SESSION_KEY = 'sentryReplaySession';\nexport const REPLAY_EVENT_NAME = 'replay_event';\nexport const RECORDING_EVENT_NAME = 'replay_recording';\nexport const UNABLE_TO_SEND_REPLAY = 'Unable to send Replay';\n\n// The idle limit for a session after which recording is paused.\nexport const SESSION_IDLE_PAUSE_DURATION = 300_000; // 5 minutes in ms\n\n// The idle limit for a session after which the session expires.\nexport const SESSION_IDLE_EXPIRE_DURATION = 900_000; // 15 minutes in ms\n\n// The maximum length of a session\nexport const MAX_SESSION_LIFE = 3_600_000; // 60 minutes in ms\n\n/** Default flush delays */\nexport const DEFAULT_FLUSH_MIN_DELAY = 5_000;\n// XXX: Temp fix for our debounce logic where `maxWait` would never occur if it\n// was the same as `wait`\nexport const DEFAULT_FLUSH_MAX_DELAY = 5_500;\n\n/* How long to wait for error checkouts */\nexport const BUFFER_CHECKOUT_TIME = 60_000;\n\nexport const RETRY_BASE_INTERVAL = 5000;\nexport const RETRY_MAX_COUNT = 3;\n\n/* The max (uncompressed) size in bytes of a network body. Any body larger than this will be truncated. */\nexport const NETWORK_BODY_MAX_SIZE = 150_000;\n\n/* The max size of a single console arg that is captured. Any arg larger than this will be truncated. */\nexport const CONSOLE_ARG_MAX_SIZE = 5_000;\n\n/* Min. time to wait before we consider something a slow click. */\nexport const SLOW_CLICK_THRESHOLD = 3_000;\n/* For scroll actions after a click, we only look for a very short time period to detect programmatic scrolling. */\nexport const SLOW_CLICK_SCROLL_TIMEOUT = 300;\n\n/** When encountering a total segment size exceeding this size, stop the replay (as we cannot properly ingest it). */\nexport const REPLAY_MAX_EVENT_BUFFER_SIZE = 20_000_000; // ~20MB\n\n/** Replays must be min. 5s long before we send them. */\nexport const MIN_REPLAY_DURATION = 4_999;\n/* The max. allowed value that the minReplayDuration can be set to. */\nexport const MIN_REPLAY_DURATION_LIMIT = 15_000;\n","var EventType;\n(function (EventType) {\n EventType[EventType[\"DomContentLoaded\"] = 0] = \"DomContentLoaded\";\n EventType[EventType[\"Load\"] = 1] = \"Load\";\n EventType[EventType[\"FullSnapshot\"] = 2] = \"FullSnapshot\";\n EventType[EventType[\"IncrementalSnapshot\"] = 3] = \"IncrementalSnapshot\";\n EventType[EventType[\"Meta\"] = 4] = \"Meta\";\n EventType[EventType[\"Custom\"] = 5] = \"Custom\";\n EventType[EventType[\"Plugin\"] = 6] = \"Plugin\";\n})(EventType || (EventType = {}));\nvar IncrementalSource;\n(function (IncrementalSource) {\n IncrementalSource[IncrementalSource[\"Mutation\"] = 0] = \"Mutation\";\n IncrementalSource[IncrementalSource[\"MouseMove\"] = 1] = \"MouseMove\";\n IncrementalSource[IncrementalSource[\"MouseInteraction\"] = 2] = \"MouseInteraction\";\n IncrementalSource[IncrementalSource[\"Scroll\"] = 3] = \"Scroll\";\n IncrementalSource[IncrementalSource[\"ViewportResize\"] = 4] = \"ViewportResize\";\n IncrementalSource[IncrementalSource[\"Input\"] = 5] = \"Input\";\n IncrementalSource[IncrementalSource[\"TouchMove\"] = 6] = \"TouchMove\";\n IncrementalSource[IncrementalSource[\"MediaInteraction\"] = 7] = \"MediaInteraction\";\n IncrementalSource[IncrementalSource[\"StyleSheetRule\"] = 8] = \"StyleSheetRule\";\n IncrementalSource[IncrementalSource[\"CanvasMutation\"] = 9] = \"CanvasMutation\";\n IncrementalSource[IncrementalSource[\"Font\"] = 10] = \"Font\";\n IncrementalSource[IncrementalSource[\"Log\"] = 11] = \"Log\";\n IncrementalSource[IncrementalSource[\"Drag\"] = 12] = \"Drag\";\n IncrementalSource[IncrementalSource[\"StyleDeclaration\"] = 13] = \"StyleDeclaration\";\n})(IncrementalSource || (IncrementalSource = {}));\nvar MouseInteractions;\n(function (MouseInteractions) {\n MouseInteractions[MouseInteractions[\"MouseUp\"] = 0] = \"MouseUp\";\n MouseInteractions[MouseInteractions[\"MouseDown\"] = 1] = \"MouseDown\";\n MouseInteractions[MouseInteractions[\"Click\"] = 2] = \"Click\";\n MouseInteractions[MouseInteractions[\"ContextMenu\"] = 3] = \"ContextMenu\";\n MouseInteractions[MouseInteractions[\"DblClick\"] = 4] = \"DblClick\";\n MouseInteractions[MouseInteractions[\"Focus\"] = 5] = \"Focus\";\n MouseInteractions[MouseInteractions[\"Blur\"] = 6] = \"Blur\";\n MouseInteractions[MouseInteractions[\"TouchStart\"] = 7] = \"TouchStart\";\n MouseInteractions[MouseInteractions[\"TouchMove_Departed\"] = 8] = \"TouchMove_Departed\";\n MouseInteractions[MouseInteractions[\"TouchEnd\"] = 9] = \"TouchEnd\";\n MouseInteractions[MouseInteractions[\"TouchCancel\"] = 10] = \"TouchCancel\";\n})(MouseInteractions || (MouseInteractions = {}));\nvar CanvasContext;\n(function (CanvasContext) {\n CanvasContext[CanvasContext[\"2D\"] = 0] = \"2D\";\n CanvasContext[CanvasContext[\"WebGL\"] = 1] = \"WebGL\";\n CanvasContext[CanvasContext[\"WebGL2\"] = 2] = \"WebGL2\";\n})(CanvasContext || (CanvasContext = {}));\nvar MediaInteractions;\n(function (MediaInteractions) {\n MediaInteractions[MediaInteractions[\"Play\"] = 0] = \"Play\";\n MediaInteractions[MediaInteractions[\"Pause\"] = 1] = \"Pause\";\n MediaInteractions[MediaInteractions[\"Seeked\"] = 2] = \"Seeked\";\n MediaInteractions[MediaInteractions[\"VolumeChange\"] = 3] = \"VolumeChange\";\n})(MediaInteractions || (MediaInteractions = {}));\nvar ReplayerEvents;\n(function (ReplayerEvents) {\n ReplayerEvents[\"Start\"] = \"start\";\n ReplayerEvents[\"Pause\"] = \"pause\";\n ReplayerEvents[\"Resume\"] = \"resume\";\n ReplayerEvents[\"Resize\"] = \"resize\";\n ReplayerEvents[\"Finish\"] = \"finish\";\n ReplayerEvents[\"FullsnapshotRebuilded\"] = \"fullsnapshot-rebuilded\";\n ReplayerEvents[\"LoadStylesheetStart\"] = \"load-stylesheet-start\";\n ReplayerEvents[\"LoadStylesheetEnd\"] = \"load-stylesheet-end\";\n ReplayerEvents[\"SkipStart\"] = \"skip-start\";\n ReplayerEvents[\"SkipEnd\"] = \"skip-end\";\n ReplayerEvents[\"MouseInteraction\"] = \"mouse-interaction\";\n ReplayerEvents[\"EventCast\"] = \"event-cast\";\n ReplayerEvents[\"CustomEvent\"] = \"custom-event\";\n ReplayerEvents[\"Flush\"] = \"flush\";\n ReplayerEvents[\"StateChange\"] = \"state-change\";\n ReplayerEvents[\"PlayBack\"] = \"play-back\";\n})(ReplayerEvents || (ReplayerEvents = {}));\n\nexport { CanvasContext, EventType, IncrementalSource, MediaInteractions, MouseInteractions, ReplayerEvents };\n","import { IncrementalSource } from './types.js';\nimport { IGNORED_NODE, isShadowRoot, NodeType } from '../../rrweb-snapshot/es/rrweb-snapshot.js';\n\nfunction on(type, fn, target = document) {\n const options = { capture: true, passive: true };\n target.addEventListener(type, fn, options);\n return () => target.removeEventListener(type, fn, options);\n}\nfunction createMirror() {\n return {\n map: {},\n getId(n) {\n if (!n || !n.__sn) {\n return -1;\n }\n return n.__sn.id;\n },\n getNode(id) {\n return this.map[id] || null;\n },\n removeNodeFromMap(n) {\n const id = n.__sn && n.__sn.id;\n delete this.map[id];\n if (n.childNodes) {\n n.childNodes.forEach((child) => this.removeNodeFromMap(child));\n }\n },\n has(id) {\n return this.map.hasOwnProperty(id);\n },\n reset() {\n this.map = {};\n },\n };\n}\nconst DEPARTED_MIRROR_ACCESS_WARNING = 'Please stop import mirror directly. Instead of that,' +\n '\\r\\n' +\n 'now you can use replayer.getMirror() to access the mirror instance of a replayer,' +\n '\\r\\n' +\n 'or you can use record.mirror to access the mirror instance during recording.';\nlet _mirror = {\n map: {},\n getId() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return -1;\n },\n getNode() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return null;\n },\n removeNodeFromMap() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n },\n has() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n return false;\n },\n reset() {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n },\n};\nif (typeof window !== 'undefined' && window.Proxy && window.Reflect) {\n _mirror = new Proxy(_mirror, {\n get(target, prop, receiver) {\n if (prop === 'map') {\n console.error(DEPARTED_MIRROR_ACCESS_WARNING);\n }\n return Reflect.get(target, prop, receiver);\n },\n });\n}\nfunction throttle(func, wait, options = {}) {\n let timeout = null;\n let previous = 0;\n return function (arg) {\n let now = Date.now();\n if (!previous && options.leading === false) {\n previous = now;\n }\n let remaining = wait - (now - previous);\n let context = this;\n let args = arguments;\n if (remaining <= 0 || remaining > wait) {\n if (timeout) {\n clearTimeout(timeout);\n timeout = null;\n }\n previous = now;\n func.apply(context, args);\n }\n else if (!timeout && options.trailing !== false) {\n timeout = setTimeout(() => {\n previous = options.leading === false ? 0 : Date.now();\n timeout = null;\n func.apply(context, args);\n }, remaining);\n }\n };\n}\nfunction hookSetter(target, key, d, isRevoked, win = window) {\n const original = win.Object.getOwnPropertyDescriptor(target, key);\n win.Object.defineProperty(target, key, isRevoked\n ? d\n : {\n set(value) {\n setTimeout(() => {\n d.set.call(this, value);\n }, 0);\n if (original && original.set) {\n original.set.call(this, value);\n }\n },\n });\n return () => hookSetter(target, key, original || {}, true);\n}\nfunction patch(source, name, replacement) {\n try {\n if (!(name in source)) {\n return () => { };\n }\n const original = source[name];\n const wrapped = replacement(original);\n if (typeof wrapped === 'function') {\n wrapped.prototype = wrapped.prototype || {};\n Object.defineProperties(wrapped, {\n __rrweb_original__: {\n enumerable: false,\n value: original,\n },\n });\n }\n source[name] = wrapped;\n return () => {\n source[name] = original;\n };\n }\n catch (_a) {\n return () => { };\n }\n}\nfunction getWindowHeight() {\n return (window.innerHeight ||\n (document.documentElement && document.documentElement.clientHeight) ||\n (document.body && document.body.clientHeight));\n}\nfunction getWindowWidth() {\n return (window.innerWidth ||\n (document.documentElement && document.documentElement.clientWidth) ||\n (document.body && document.body.clientWidth));\n}\nfunction isBlocked(node, blockClass, blockSelector, unblockSelector) {\n if (!node) {\n return false;\n }\n if (node.nodeType === node.ELEMENT_NODE) {\n let needBlock = false;\n const needUnblock = unblockSelector && node.matches(unblockSelector);\n if (typeof blockClass === 'string') {\n if (node.closest !== undefined) {\n needBlock =\n !needUnblock &&\n node.closest('.' + blockClass) !== null;\n }\n else {\n needBlock =\n !needUnblock && node.classList.contains(blockClass);\n }\n }\n else {\n !needUnblock &&\n node.classList.forEach((className) => {\n if (blockClass.test(className)) {\n needBlock = true;\n }\n });\n }\n if (!needBlock && blockSelector) {\n needBlock = node.matches(blockSelector);\n }\n return ((!needUnblock && needBlock) ||\n isBlocked(node.parentNode, blockClass, blockSelector, unblockSelector));\n }\n if (node.nodeType === node.TEXT_NODE) {\n return isBlocked(node.parentNode, blockClass, blockSelector, unblockSelector);\n }\n return isBlocked(node.parentNode, blockClass, blockSelector, unblockSelector);\n}\nfunction isIgnored(n) {\n if ('__sn' in n) {\n return n.__sn.id === IGNORED_NODE;\n }\n return false;\n}\nfunction isAncestorRemoved(target, mirror) {\n if (isShadowRoot(target)) {\n return false;\n }\n const id = mirror.getId(target);\n if (!mirror.has(id)) {\n return true;\n }\n if (target.parentNode &&\n target.parentNode.nodeType === target.DOCUMENT_NODE) {\n return false;\n }\n if (!target.parentNode) {\n return true;\n }\n return isAncestorRemoved(target.parentNode, mirror);\n}\nfunction isTouchEvent(event) {\n return Boolean(event.changedTouches);\n}\nfunction polyfill(win = window) {\n if ('NodeList' in win && !win.NodeList.prototype.forEach) {\n win.NodeList.prototype.forEach = Array.prototype\n .forEach;\n }\n if ('DOMTokenList' in win && !win.DOMTokenList.prototype.forEach) {\n win.DOMTokenList.prototype.forEach = Array.prototype\n .forEach;\n }\n if (!Node.prototype.contains) {\n Node.prototype.contains = function contains(node) {\n if (!(0 in arguments)) {\n throw new TypeError('1 argument is required');\n }\n do {\n if (this === node) {\n return true;\n }\n } while ((node = node && node.parentNode));\n return false;\n };\n }\n}\nclass TreeIndex {\n constructor() {\n this.reset();\n }\n add(mutation) {\n const parentTreeNode = this.indexes.get(mutation.parentId);\n const treeNode = {\n id: mutation.node.id,\n mutation,\n children: [],\n texts: [],\n attributes: [],\n };\n if (!parentTreeNode) {\n this.tree[treeNode.id] = treeNode;\n }\n else {\n treeNode.parent = parentTreeNode;\n parentTreeNode.children[treeNode.id] = treeNode;\n }\n this.indexes.set(treeNode.id, treeNode);\n }\n remove(mutation, mirror) {\n const parentTreeNode = this.indexes.get(mutation.parentId);\n const treeNode = this.indexes.get(mutation.id);\n const deepRemoveFromMirror = (id) => {\n this.removeIdSet.add(id);\n const node = mirror.getNode(id);\n node === null || node === void 0 ? void 0 : node.childNodes.forEach((childNode) => {\n if ('__sn' in childNode) {\n deepRemoveFromMirror(childNode.__sn.id);\n }\n });\n };\n const deepRemoveFromTreeIndex = (node) => {\n this.removeIdSet.add(node.id);\n Object.values(node.children).forEach((n) => deepRemoveFromTreeIndex(n));\n const _treeNode = this.indexes.get(node.id);\n if (_treeNode) {\n const _parentTreeNode = _treeNode.parent;\n if (_parentTreeNode) {\n delete _treeNode.parent;\n delete _parentTreeNode.children[_treeNode.id];\n this.indexes.delete(mutation.id);\n }\n }\n };\n if (!treeNode) {\n this.removeNodeMutations.push(mutation);\n deepRemoveFromMirror(mutation.id);\n }\n else if (!parentTreeNode) {\n delete this.tree[treeNode.id];\n this.indexes.delete(treeNode.id);\n deepRemoveFromTreeIndex(treeNode);\n }\n else {\n delete treeNode.parent;\n delete parentTreeNode.children[treeNode.id];\n this.indexes.delete(mutation.id);\n deepRemoveFromTreeIndex(treeNode);\n }\n }\n text(mutation) {\n const treeNode = this.indexes.get(mutation.id);\n if (treeNode) {\n treeNode.texts.push(mutation);\n }\n else {\n this.textMutations.push(mutation);\n }\n }\n attribute(mutation) {\n const treeNode = this.indexes.get(mutation.id);\n if (treeNode) {\n treeNode.attributes.push(mutation);\n }\n else {\n this.attributeMutations.push(mutation);\n }\n }\n scroll(d) {\n this.scrollMap.set(d.id, d);\n }\n input(d) {\n this.inputMap.set(d.id, d);\n }\n flush() {\n const { tree, removeNodeMutations, textMutations, attributeMutations, } = this;\n const batchMutationData = {\n source: IncrementalSource.Mutation,\n removes: removeNodeMutations,\n texts: textMutations,\n attributes: attributeMutations,\n adds: [],\n };\n const walk = (treeNode, removed) => {\n if (removed) {\n this.removeIdSet.add(treeNode.id);\n }\n batchMutationData.texts = batchMutationData.texts\n .concat(removed ? [] : treeNode.texts)\n .filter((m) => !this.removeIdSet.has(m.id));\n batchMutationData.attributes = batchMutationData.attributes\n .concat(removed ? [] : treeNode.attributes)\n .filter((m) => !this.removeIdSet.has(m.id));\n if (!this.removeIdSet.has(treeNode.id) &&\n !this.removeIdSet.has(treeNode.mutation.parentId) &&\n !removed) {\n batchMutationData.adds.push(treeNode.mutation);\n if (treeNode.children) {\n Object.values(treeNode.children).forEach((n) => walk(n, false));\n }\n }\n else {\n Object.values(treeNode.children).forEach((n) => walk(n, true));\n }\n };\n Object.values(tree).forEach((n) => walk(n, false));\n for (const id of this.scrollMap.keys()) {\n if (this.removeIdSet.has(id)) {\n this.scrollMap.delete(id);\n }\n }\n for (const id of this.inputMap.keys()) {\n if (this.removeIdSet.has(id)) {\n this.inputMap.delete(id);\n }\n }\n const scrollMap = new Map(this.scrollMap);\n const inputMap = new Map(this.inputMap);\n this.reset();\n return {\n mutationData: batchMutationData,\n scrollMap,\n inputMap,\n };\n }\n reset() {\n this.tree = [];\n this.indexes = new Map();\n this.removeNodeMutations = [];\n this.textMutations = [];\n this.attributeMutations = [];\n this.removeIdSet = new Set();\n this.scrollMap = new Map();\n this.inputMap = new Map();\n }\n idRemoved(id) {\n return this.removeIdSet.has(id);\n }\n}\nfunction queueToResolveTrees(queue) {\n const queueNodeMap = {};\n const putIntoMap = (m, parent) => {\n const nodeInTree = {\n value: m,\n parent,\n children: [],\n };\n queueNodeMap[m.node.id] = nodeInTree;\n return nodeInTree;\n };\n const queueNodeTrees = [];\n for (const mutation of queue) {\n const { nextId, parentId } = mutation;\n if (nextId && nextId in queueNodeMap) {\n const nextInTree = queueNodeMap[nextId];\n if (nextInTree.parent) {\n const idx = nextInTree.parent.children.indexOf(nextInTree);\n nextInTree.parent.children.splice(idx, 0, putIntoMap(mutation, nextInTree.parent));\n }\n else {\n const idx = queueNodeTrees.indexOf(nextInTree);\n queueNodeTrees.splice(idx, 0, putIntoMap(mutation, null));\n }\n continue;\n }\n if (parentId in queueNodeMap) {\n const parentInTree = queueNodeMap[parentId];\n parentInTree.children.push(putIntoMap(mutation, parentInTree));\n continue;\n }\n queueNodeTrees.push(putIntoMap(mutation, null));\n }\n return queueNodeTrees;\n}\nfunction iterateResolveTree(tree, cb) {\n cb(tree.value);\n for (let i = tree.children.length - 1; i >= 0; i--) {\n iterateResolveTree(tree.children[i], cb);\n }\n}\nfunction isIframeINode(node) {\n if ('__sn' in node) {\n return (node.__sn.type === NodeType.Element && node.__sn.tagName === 'iframe');\n }\n return false;\n}\nfunction getBaseDimension(node, rootIframe) {\n var _a, _b;\n const frameElement = (_b = (_a = node.ownerDocument) === null || _a === void 0 ? void 0 : _a.defaultView) === null || _b === void 0 ? void 0 : _b.frameElement;\n if (!frameElement || frameElement === rootIframe) {\n return {\n x: 0,\n y: 0,\n relativeScale: 1,\n absoluteScale: 1,\n };\n }\n const frameDimension = frameElement.getBoundingClientRect();\n const frameBaseDimension = getBaseDimension(frameElement, rootIframe);\n const relativeScale = frameDimension.height / frameElement.clientHeight;\n return {\n x: frameDimension.x * frameBaseDimension.relativeScale +\n frameBaseDimension.x,\n y: frameDimension.y * frameBaseDimension.relativeScale +\n frameBaseDimension.y,\n relativeScale,\n absoluteScale: frameBaseDimension.absoluteScale * relativeScale,\n };\n}\nfunction hasShadowRoot(n) {\n return Boolean(n === null || n === void 0 ? void 0 : n.shadowRoot);\n}\n\nexport { TreeIndex, _mirror, createMirror, getBaseDimension, getWindowHeight, getWindowWidth, hasShadowRoot, hookSetter, isAncestorRemoved, isBlocked, isIframeINode, isIgnored, isTouchEvent, iterateResolveTree, on, patch, polyfill, queueToResolveTrees, throttle };\n","import { isShadowRoot, maskInputValue, transformAttribute, needMaskingText, IGNORED_NODE, serializeNodeWithId } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { isIgnored, isBlocked, isAncestorRemoved, isIframeINode, hasShadowRoot } from '../utils.js';\n\nfunction isNodeInLinkedList(n) {\n return '__ln' in n;\n}\nclass DoubleLinkedList {\n constructor() {\n this.length = 0;\n this.head = null;\n }\n get(position) {\n if (position >= this.length) {\n throw new Error('Position outside of list range');\n }\n let current = this.head;\n for (let index = 0; index < position; index++) {\n current = (current === null || current === void 0 ? void 0 : current.next) || null;\n }\n return current;\n }\n addNode(n) {\n const node = {\n value: n,\n previous: null,\n next: null,\n };\n n.__ln = node;\n if (n.previousSibling && isNodeInLinkedList(n.previousSibling)) {\n const current = n.previousSibling.__ln.next;\n node.next = current;\n node.previous = n.previousSibling.__ln;\n n.previousSibling.__ln.next = node;\n if (current) {\n current.previous = node;\n }\n }\n else if (n.nextSibling &&\n isNodeInLinkedList(n.nextSibling) &&\n n.nextSibling.__ln.previous) {\n const current = n.nextSibling.__ln.previous;\n node.previous = current;\n node.next = n.nextSibling.__ln;\n n.nextSibling.__ln.previous = node;\n if (current) {\n current.next = node;\n }\n }\n else {\n if (this.head) {\n this.head.previous = node;\n }\n node.next = this.head;\n this.head = node;\n }\n this.length++;\n }\n removeNode(n) {\n const current = n.__ln;\n if (!this.head) {\n return;\n }\n if (!current.previous) {\n this.head = current.next;\n if (this.head) {\n this.head.previous = null;\n }\n }\n else {\n current.previous.next = current.next;\n if (current.next) {\n current.next.previous = current.previous;\n }\n }\n if (n.__ln) {\n delete n.__ln;\n }\n this.length--;\n }\n}\nconst moveKey = (id, parentId) => `${id}@${parentId}`;\nfunction isINode(n) {\n return '__sn' in n;\n}\nclass MutationBuffer {\n constructor() {\n this.frozen = false;\n this.locked = false;\n this.texts = [];\n this.attributes = [];\n this.removes = [];\n this.mapRemoves = [];\n this.movedMap = {};\n this.addedSet = new Set();\n this.movedSet = new Set();\n this.droppedSet = new Set();\n this.processMutations = (mutations) => {\n mutations.forEach(this.processMutation);\n this.emit();\n };\n this.emit = () => {\n if (this.frozen || this.locked) {\n return;\n }\n const adds = [];\n const addList = new DoubleLinkedList();\n const getNextId = (n) => {\n let ns = n;\n let nextId = IGNORED_NODE;\n while (nextId === IGNORED_NODE) {\n ns = ns && ns.nextSibling;\n nextId = ns && this.mirror.getId(ns);\n }\n return nextId;\n };\n const pushAdd = (n) => {\n var _a, _b, _c, _d, _e;\n const shadowHost = n.getRootNode\n ? (_a = n.getRootNode()) === null || _a === void 0 ? void 0 : _a.host\n : null;\n let rootShadowHost = shadowHost;\n while ((_c = (_b = rootShadowHost === null || rootShadowHost === void 0 ? void 0 : rootShadowHost.getRootNode) === null || _b === void 0 ? void 0 : _b.call(rootShadowHost)) === null || _c === void 0 ? void 0 : _c.host)\n rootShadowHost =\n ((_e = (_d = rootShadowHost === null || rootShadowHost === void 0 ? void 0 : rootShadowHost.getRootNode) === null || _d === void 0 ? void 0 : _d.call(rootShadowHost)) === null || _e === void 0 ? void 0 : _e.host) ||\n null;\n const notInDoc = !this.doc.contains(n) &&\n (!rootShadowHost || !this.doc.contains(rootShadowHost));\n if (!n.parentNode || notInDoc) {\n return;\n }\n const parentId = isShadowRoot(n.parentNode)\n ? this.mirror.getId(shadowHost)\n : this.mirror.getId(n.parentNode);\n const nextId = getNextId(n);\n if (parentId === -1 || nextId === -1) {\n return addList.addNode(n);\n }\n let sn = serializeNodeWithId(n, {\n doc: this.doc,\n map: this.mirror.map,\n blockClass: this.blockClass,\n blockSelector: this.blockSelector,\n unblockSelector: this.unblockSelector,\n maskTextClass: this.maskTextClass,\n maskTextSelector: this.maskTextSelector,\n unmaskTextSelector: this.unmaskTextSelector,\n maskInputSelector: this.maskInputSelector,\n unmaskInputSelector: this.unmaskInputSelector,\n skipChild: true,\n inlineStylesheet: this.inlineStylesheet,\n maskAllText: this.maskAllText,\n maskInputOptions: this.maskInputOptions,\n maskTextFn: this.maskTextFn,\n maskInputFn: this.maskInputFn,\n slimDOMOptions: this.slimDOMOptions,\n recordCanvas: this.recordCanvas,\n inlineImages: this.inlineImages,\n onSerialize: (currentN) => {\n if (isIframeINode(currentN)) {\n this.iframeManager.addIframe(currentN);\n }\n if (hasShadowRoot(n)) {\n this.shadowDomManager.addShadowRoot(n.shadowRoot, document);\n }\n },\n onIframeLoad: (iframe, childSn) => {\n this.iframeManager.attachIframe(iframe, childSn);\n this.shadowDomManager.observeAttachShadow(iframe);\n },\n });\n if (sn) {\n adds.push({\n parentId,\n nextId,\n node: sn,\n });\n }\n };\n while (this.mapRemoves.length) {\n this.mirror.removeNodeFromMap(this.mapRemoves.shift());\n }\n for (const n of this.movedSet) {\n if (isParentRemoved(this.removes, n, this.mirror) &&\n !this.movedSet.has(n.parentNode)) {\n continue;\n }\n pushAdd(n);\n }\n for (const n of this.addedSet) {\n if (!isAncestorInSet(this.droppedSet, n) &&\n !isParentRemoved(this.removes, n, this.mirror)) {\n pushAdd(n);\n }\n else if (isAncestorInSet(this.movedSet, n)) {\n pushAdd(n);\n }\n else {\n this.droppedSet.add(n);\n }\n }\n let candidate = null;\n while (addList.length) {\n let node = null;\n if (candidate) {\n const parentId = this.mirror.getId(candidate.value.parentNode);\n const nextId = getNextId(candidate.value);\n if (parentId !== -1 && nextId !== -1) {\n node = candidate;\n }\n }\n if (!node) {\n for (let index = addList.length - 1; index >= 0; index--) {\n const _node = addList.get(index);\n if (_node) {\n const parentId = this.mirror.getId(_node.value.parentNode);\n const nextId = getNextId(_node.value);\n if (parentId !== -1 && nextId !== -1) {\n node = _node;\n break;\n }\n }\n }\n }\n if (!node) {\n while (addList.head) {\n addList.removeNode(addList.head.value);\n }\n break;\n }\n candidate = node.previous;\n addList.removeNode(node.value);\n pushAdd(node.value);\n }\n const payload = {\n texts: this.texts\n .map((text) => ({\n id: this.mirror.getId(text.node),\n value: text.value,\n }))\n .filter((text) => this.mirror.has(text.id)),\n attributes: this.attributes\n .map((attribute) => ({\n id: this.mirror.getId(attribute.node),\n attributes: attribute.attributes,\n }))\n .filter((attribute) => this.mirror.has(attribute.id)),\n removes: this.removes,\n adds,\n };\n if (!payload.texts.length &&\n !payload.attributes.length &&\n !payload.removes.length &&\n !payload.adds.length) {\n return;\n }\n this.texts = [];\n this.attributes = [];\n this.removes = [];\n this.addedSet = new Set();\n this.movedSet = new Set();\n this.droppedSet = new Set();\n this.movedMap = {};\n this.mutationCb(payload);\n };\n this.processMutation = (m) => {\n if (isIgnored(m.target)) {\n return;\n }\n switch (m.type) {\n case 'characterData': {\n const value = m.target.textContent;\n if (!isBlocked(m.target, this.blockClass, this.blockSelector, this.unblockSelector) && value !== m.oldValue) {\n this.texts.push({\n value: needMaskingText(m.target, this.maskTextClass, this.maskTextSelector, this.unmaskTextSelector, this.maskAllText) && value\n ? this.maskTextFn\n ? this.maskTextFn(value)\n : value.replace(/[\\S]/g, '*')\n : value,\n node: m.target,\n });\n }\n break;\n }\n case 'attributes': {\n const target = m.target;\n let value = target.getAttribute(m.attributeName);\n if (m.attributeName === 'value') {\n value = maskInputValue({\n input: target,\n maskInputSelector: this.maskInputSelector,\n unmaskInputSelector: this.unmaskInputSelector,\n maskInputOptions: this.maskInputOptions,\n tagName: target.tagName,\n type: target.getAttribute('type'),\n value,\n maskInputFn: this.maskInputFn,\n });\n }\n if (isBlocked(m.target, this.blockClass, this.blockSelector, this.unblockSelector) || value === m.oldValue) {\n return;\n }\n let item = this.attributes.find((a) => a.node === m.target);\n if (!item) {\n item = {\n node: m.target,\n attributes: {},\n };\n this.attributes.push(item);\n }\n if (m.attributeName === 'type' &&\n target.tagName === 'INPUT' &&\n (m.oldValue || '').toLowerCase() === 'password') {\n target.setAttribute('data-rr-is-password', 'true');\n }\n if (m.attributeName === 'style') {\n const old = this.doc.createElement('span');\n if (m.oldValue) {\n old.setAttribute('style', m.oldValue);\n }\n if (item.attributes.style === undefined ||\n item.attributes.style === null) {\n item.attributes.style = {};\n }\n try {\n const styleObj = item.attributes.style;\n for (const pname of Array.from(target.style)) {\n const newValue = target.style.getPropertyValue(pname);\n const newPriority = target.style.getPropertyPriority(pname);\n if (newValue !== old.style.getPropertyValue(pname) ||\n newPriority !== old.style.getPropertyPriority(pname)) {\n if (newPriority === '') {\n styleObj[pname] = newValue;\n }\n else {\n styleObj[pname] = [newValue, newPriority];\n }\n }\n }\n for (const pname of Array.from(old.style)) {\n if (target.style.getPropertyValue(pname) === '') {\n styleObj[pname] = false;\n }\n }\n }\n catch (error) {\n console.warn('[rrweb] Error when parsing update to style attribute:', error);\n }\n }\n else {\n const element = m.target;\n item.attributes[m.attributeName] = transformAttribute(this.doc, element, element.tagName, m.attributeName, value, this.maskAllText, this.unmaskTextSelector, this.maskTextFn);\n }\n break;\n }\n case 'childList': {\n m.addedNodes.forEach((n) => this.genAdds(n, m.target));\n m.removedNodes.forEach((n) => {\n const nodeId = this.mirror.getId(n);\n const parentId = isShadowRoot(m.target)\n ? this.mirror.getId(m.target.host)\n : this.mirror.getId(m.target);\n if (isBlocked(m.target, this.blockClass, this.blockSelector, this.unblockSelector) || isIgnored(n)) {\n return;\n }\n if (this.addedSet.has(n)) {\n deepDelete(this.addedSet, n);\n this.droppedSet.add(n);\n }\n else if (this.addedSet.has(m.target) && nodeId === -1) ;\n else if (isAncestorRemoved(m.target, this.mirror)) ;\n else if (this.movedSet.has(n) &&\n this.movedMap[moveKey(nodeId, parentId)]) {\n deepDelete(this.movedSet, n);\n }\n else {\n this.removes.push({\n parentId,\n id: nodeId,\n isShadow: isShadowRoot(m.target) ? true : undefined,\n });\n }\n this.mapRemoves.push(n);\n });\n break;\n }\n }\n };\n this.genAdds = (n, target) => {\n if (target && isBlocked(target, this.blockClass, this.blockSelector, this.unblockSelector)) {\n return;\n }\n if (isINode(n)) {\n if (isIgnored(n)) {\n return;\n }\n this.movedSet.add(n);\n let targetId = null;\n if (target && isINode(target)) {\n targetId = target.__sn.id;\n }\n if (targetId) {\n this.movedMap[moveKey(n.__sn.id, targetId)] = true;\n }\n }\n else {\n this.addedSet.add(n);\n this.droppedSet.delete(n);\n }\n if (!isBlocked(n, this.blockClass, this.blockSelector, this.unblockSelector))\n n.childNodes.forEach((childN) => this.genAdds(childN));\n };\n }\n init(options) {\n [\n 'mutationCb',\n 'blockClass',\n 'blockSelector',\n 'unblockSelector',\n 'maskTextClass',\n 'maskTextSelector',\n 'unmaskTextSelector',\n 'maskInputSelector',\n 'unmaskInputSelector',\n 'inlineStylesheet',\n 'maskAllText',\n 'maskInputOptions',\n 'maskTextFn',\n 'maskInputFn',\n 'recordCanvas',\n 'inlineImages',\n 'slimDOMOptions',\n 'doc',\n 'mirror',\n 'iframeManager',\n 'shadowDomManager',\n 'canvasManager',\n ].forEach((key) => {\n this[key] = options[key];\n });\n }\n freeze() {\n this.frozen = true;\n this.canvasManager.freeze();\n }\n unfreeze() {\n this.frozen = false;\n this.canvasManager.unfreeze();\n this.emit();\n }\n isFrozen() {\n return this.frozen;\n }\n lock() {\n this.locked = true;\n this.canvasManager.lock();\n }\n unlock() {\n this.locked = false;\n this.canvasManager.unlock();\n this.emit();\n }\n reset() {\n this.shadowDomManager.reset();\n this.canvasManager.reset();\n }\n}\nfunction deepDelete(addsSet, n) {\n addsSet.delete(n);\n n.childNodes.forEach((childN) => deepDelete(addsSet, childN));\n}\nfunction isParentRemoved(removes, n, mirror) {\n const { parentNode } = n;\n if (!parentNode) {\n return false;\n }\n const parentId = mirror.getId(parentNode);\n if (removes.some((r) => r.id === parentId)) {\n return true;\n }\n return isParentRemoved(removes, parentNode, mirror);\n}\nfunction isAncestorInSet(set, n) {\n const { parentNode } = n;\n if (!parentNode) {\n return false;\n }\n if (set.has(parentNode)) {\n return true;\n }\n return isAncestorInSet(set, parentNode);\n}\n\nexport { MutationBuffer as default };\n","const callbackWrapper = (cb) => {\n const rrwebWrapped = (...rest) => {\n try {\n return cb(...rest);\n }\n catch (error) {\n try {\n error.__rrweb__ = true;\n }\n catch (_a) {\n }\n throw error;\n }\n };\n return rrwebWrapped;\n};\n\nexport { callbackWrapper };\n","import { getInputType, getInputValue, hasInputMaskOptions, maskInputValue } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { on, throttle, isBlocked, hookSetter, patch, isTouchEvent, getWindowHeight, getWindowWidth } from '../utils.js';\nimport { MouseInteractions, IncrementalSource } from '../types.js';\nimport MutationBuffer from './mutation.js';\nimport { callbackWrapper } from '../sentry/callbackWrapper.js';\n\nconst mutationBuffers = [];\nfunction getEventTarget(event) {\n try {\n if ('composedPath' in event) {\n const path = event.composedPath();\n if (path.length) {\n return path[0];\n }\n }\n else if ('path' in event && event.path.length) {\n return event.path[0];\n }\n }\n catch (_a) { }\n return event && event.target;\n}\nfunction initMutationObserver(options, rootEl) {\n var _a, _b;\n const mutationBuffer = new MutationBuffer();\n mutationBuffers.push(mutationBuffer);\n mutationBuffer.init(options);\n let mutationObserverCtor = window.MutationObserver ||\n window.__rrMutationObserver;\n const angularZoneSymbol = (_b = (_a = window === null || window === void 0 ? void 0 : window.Zone) === null || _a === void 0 ? void 0 : _a.__symbol__) === null || _b === void 0 ? void 0 : _b.call(_a, 'MutationObserver');\n if (angularZoneSymbol &&\n window[angularZoneSymbol]) {\n mutationObserverCtor = window[angularZoneSymbol];\n }\n const observer = new mutationObserverCtor(callbackWrapper((mutations) => {\n if (options.onMutation && options.onMutation(mutations) === false) {\n return;\n }\n mutationBuffer.processMutations(mutations);\n }));\n observer.observe(rootEl, {\n attributes: true,\n attributeOldValue: true,\n characterData: true,\n characterDataOldValue: true,\n childList: true,\n subtree: true,\n });\n return observer;\n}\nfunction initMoveObserver({ mousemoveCb, sampling, doc, mirror, }) {\n if (sampling.mousemove === false) {\n return () => { };\n }\n const threshold = typeof sampling.mousemove === 'number' ? sampling.mousemove : 50;\n const callbackThreshold = typeof sampling.mousemoveCallback === 'number'\n ? sampling.mousemoveCallback\n : 500;\n let positions = [];\n let timeBaseline;\n const wrappedCb = throttle((source) => {\n const totalOffset = Date.now() - timeBaseline;\n callbackWrapper(mousemoveCb)(positions.map((p) => {\n p.timeOffset -= totalOffset;\n return p;\n }), source);\n positions = [];\n timeBaseline = null;\n }, callbackThreshold);\n const updatePosition = throttle((evt) => {\n const target = getEventTarget(evt);\n const { clientX, clientY } = isTouchEvent(evt)\n ? evt.changedTouches[0]\n : evt;\n if (!timeBaseline) {\n timeBaseline = Date.now();\n }\n positions.push({\n x: clientX,\n y: clientY,\n id: mirror.getId(target),\n timeOffset: Date.now() - timeBaseline,\n });\n wrappedCb(typeof DragEvent !== 'undefined' && evt instanceof DragEvent\n ? IncrementalSource.Drag\n : evt instanceof MouseEvent\n ? IncrementalSource.MouseMove\n : IncrementalSource.TouchMove);\n }, threshold, {\n trailing: false,\n });\n const handlers = [\n on('mousemove', callbackWrapper(updatePosition), doc),\n on('touchmove', callbackWrapper(updatePosition), doc),\n on('drag', callbackWrapper(updatePosition), doc),\n ];\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction initMouseInteractionObserver({ mouseInteractionCb, doc, mirror, blockClass, blockSelector, unblockSelector, sampling, }) {\n if (sampling.mouseInteraction === false) {\n return () => { };\n }\n const disableMap = sampling.mouseInteraction === true ||\n sampling.mouseInteraction === undefined\n ? {}\n : sampling.mouseInteraction;\n const handlers = [];\n const getHandler = (eventKey) => {\n return (event) => {\n const target = getEventTarget(event);\n if (isBlocked(target, blockClass, blockSelector, unblockSelector)) {\n return;\n }\n const e = isTouchEvent(event) ? event.changedTouches[0] : event;\n if (!e) {\n return;\n }\n const id = mirror.getId(target);\n const { clientX, clientY } = e;\n callbackWrapper(mouseInteractionCb)({\n type: MouseInteractions[eventKey],\n id,\n x: clientX,\n y: clientY,\n });\n };\n };\n Object.keys(MouseInteractions)\n .filter((key) => Number.isNaN(Number(key)) &&\n !key.endsWith('_Departed') &&\n disableMap[key] !== false)\n .forEach((eventKey) => {\n const eventName = eventKey.toLowerCase();\n const handler = callbackWrapper(getHandler(eventKey));\n handlers.push(on(eventName, handler, doc));\n });\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction initScrollObserver({ scrollCb, doc, mirror, blockClass, blockSelector, unblockSelector, sampling, }) {\n const updatePosition = throttle((evt) => {\n const target = getEventTarget(evt);\n if (!target ||\n isBlocked(target, blockClass, blockSelector, unblockSelector)) {\n return;\n }\n const id = mirror.getId(target);\n if (target === doc) {\n const scrollEl = (doc.scrollingElement || doc.documentElement);\n callbackWrapper(scrollCb)({\n id,\n x: scrollEl.scrollLeft,\n y: scrollEl.scrollTop,\n });\n }\n else {\n callbackWrapper(scrollCb)({\n id,\n x: target.scrollLeft,\n y: target.scrollTop,\n });\n }\n }, sampling.scroll || 100);\n return on('scroll', callbackWrapper(updatePosition), doc);\n}\nfunction initViewportResizeObserver({ viewportResizeCb, }) {\n let lastH = -1;\n let lastW = -1;\n const updateDimension = throttle(() => {\n const height = getWindowHeight();\n const width = getWindowWidth();\n if (lastH !== height || lastW !== width) {\n callbackWrapper(viewportResizeCb)({\n width: Number(width),\n height: Number(height),\n });\n lastH = height;\n lastW = width;\n }\n }, 200);\n return on('resize', callbackWrapper(updateDimension), window);\n}\nfunction wrapEventWithUserTriggeredFlag(v, enable) {\n const value = Object.assign({}, v);\n if (!enable)\n delete value.userTriggered;\n return value;\n}\nconst INPUT_TAGS = ['INPUT', 'TEXTAREA', 'SELECT'];\nconst lastInputValueMap = new WeakMap();\nfunction initInputObserver({ inputCb, doc, mirror, blockClass, blockSelector, unblockSelector, ignoreClass, ignoreSelector, maskInputSelector, unmaskInputSelector, maskInputOptions, maskInputFn, sampling, userTriggeredOnInput, }) {\n function eventHandler(event) {\n let target = getEventTarget(event);\n const tagName = target && target.tagName;\n const userTriggered = event.isTrusted;\n if (tagName === 'OPTION')\n target = target.parentElement;\n if (!target ||\n !tagName ||\n INPUT_TAGS.indexOf(tagName) < 0 ||\n isBlocked(target, blockClass, blockSelector, unblockSelector)) {\n return;\n }\n const el = target;\n const type = getInputType(el);\n if (el.classList.contains(ignoreClass) ||\n (ignoreSelector && el.matches(ignoreSelector))) {\n return;\n }\n let text = getInputValue(el, tagName, type);\n let isChecked = false;\n if (type === 'radio' || type === 'checkbox') {\n isChecked = target.checked;\n }\n if (hasInputMaskOptions({\n maskInputOptions,\n maskInputSelector,\n tagName,\n type,\n })) {\n text = maskInputValue({\n input: el,\n maskInputOptions,\n maskInputSelector,\n unmaskInputSelector,\n tagName,\n type,\n value: text,\n maskInputFn,\n });\n }\n cbWithDedup(target, callbackWrapper(wrapEventWithUserTriggeredFlag)({ text, isChecked, userTriggered }, userTriggeredOnInput));\n const name = target.name;\n if (type === 'radio' && name && isChecked) {\n doc\n .querySelectorAll(`input[type=\"radio\"][name=\"${name}\"]`)\n .forEach((el) => {\n if (el !== target) {\n const text = maskInputValue({\n input: el,\n maskInputOptions,\n maskInputSelector,\n unmaskInputSelector,\n tagName,\n type,\n value: getInputValue(el, tagName, type),\n maskInputFn,\n });\n cbWithDedup(el, callbackWrapper(wrapEventWithUserTriggeredFlag)({\n text,\n isChecked: !isChecked,\n userTriggered: false,\n }, userTriggeredOnInput));\n }\n });\n }\n }\n function cbWithDedup(target, v) {\n const lastInputValue = lastInputValueMap.get(target);\n if (!lastInputValue ||\n lastInputValue.text !== v.text ||\n lastInputValue.isChecked !== v.isChecked) {\n lastInputValueMap.set(target, v);\n const id = mirror.getId(target);\n inputCb(Object.assign(Object.assign({}, v), { id }));\n }\n }\n const events = sampling.input === 'last' ? ['change'] : ['input', 'change'];\n const handlers = events.map((eventName) => on(eventName, callbackWrapper(eventHandler), doc));\n const propertyDescriptor = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value');\n const hookProperties = [\n [HTMLInputElement.prototype, 'value'],\n [HTMLInputElement.prototype, 'checked'],\n [HTMLSelectElement.prototype, 'value'],\n [HTMLTextAreaElement.prototype, 'value'],\n [HTMLSelectElement.prototype, 'selectedIndex'],\n [HTMLOptionElement.prototype, 'selected'],\n ];\n if (propertyDescriptor && propertyDescriptor.set) {\n handlers.push(...hookProperties.map((p) => hookSetter(p[0], p[1], {\n set() {\n callbackWrapper(eventHandler)({ target: this });\n },\n })));\n }\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction getNestedCSSRulePositions(rule) {\n const positions = [];\n function recurse(childRule, pos) {\n if ((hasNestedCSSRule('CSSGroupingRule') &&\n childRule.parentRule instanceof CSSGroupingRule) ||\n (hasNestedCSSRule('CSSMediaRule') &&\n childRule.parentRule instanceof CSSMediaRule) ||\n (hasNestedCSSRule('CSSSupportsRule') &&\n childRule.parentRule instanceof CSSSupportsRule) ||\n (hasNestedCSSRule('CSSConditionRule') &&\n childRule.parentRule instanceof CSSConditionRule)) {\n const rules = Array.from(childRule.parentRule.cssRules);\n const index = rules.indexOf(childRule);\n pos.unshift(index);\n }\n else {\n const rules = Array.from(childRule.parentStyleSheet.cssRules);\n const index = rules.indexOf(childRule);\n pos.unshift(index);\n }\n return pos;\n }\n return recurse(rule, positions);\n}\nfunction initStyleSheetObserver({ styleSheetRuleCb, mirror }, { win }) {\n if (!win.CSSStyleSheet || !win.CSSStyleSheet.prototype) {\n return () => { };\n }\n const insertRule = win.CSSStyleSheet.prototype.insertRule;\n win.CSSStyleSheet.prototype.insertRule = new Proxy(insertRule, {\n apply: callbackWrapper((target, thisArg, argumentsList) => {\n const [rule, index] = argumentsList;\n const id = mirror.getId(thisArg.ownerNode);\n if (id !== -1) {\n styleSheetRuleCb({\n id,\n adds: [{ rule, index }],\n });\n }\n return target.apply(thisArg, argumentsList);\n }),\n });\n const deleteRule = win.CSSStyleSheet.prototype.deleteRule;\n win.CSSStyleSheet.prototype.deleteRule = new Proxy(deleteRule, {\n apply: callbackWrapper((target, thisArg, argumentsList) => {\n const [index] = argumentsList;\n const id = mirror.getId(thisArg.ownerNode);\n if (id !== -1) {\n styleSheetRuleCb({\n id,\n removes: [{ index }],\n });\n }\n return target.apply(thisArg, argumentsList);\n }),\n });\n const supportedNestedCSSRuleTypes = {};\n if (canMonkeyPatchNestedCSSRule('CSSGroupingRule')) {\n supportedNestedCSSRuleTypes.CSSGroupingRule = win.CSSGroupingRule;\n }\n else {\n if (canMonkeyPatchNestedCSSRule('CSSMediaRule')) {\n supportedNestedCSSRuleTypes.CSSMediaRule = win.CSSMediaRule;\n }\n if (canMonkeyPatchNestedCSSRule('CSSConditionRule')) {\n supportedNestedCSSRuleTypes.CSSConditionRule = win.CSSConditionRule;\n }\n if (canMonkeyPatchNestedCSSRule('CSSSupportsRule')) {\n supportedNestedCSSRuleTypes.CSSSupportsRule = win.CSSSupportsRule;\n }\n }\n const unmodifiedFunctions = {};\n Object.entries(supportedNestedCSSRuleTypes).forEach(([typeKey, type]) => {\n unmodifiedFunctions[typeKey] = {\n insertRule: type.prototype.insertRule,\n deleteRule: type.prototype.deleteRule,\n };\n type.prototype.insertRule = new Proxy(unmodifiedFunctions[typeKey].insertRule, {\n apply: callbackWrapper((target, thisArg, argumentsList) => {\n const [rule, index] = argumentsList;\n const id = mirror.getId(thisArg.parentStyleSheet.ownerNode);\n if (id !== -1) {\n styleSheetRuleCb({\n id,\n adds: [\n {\n rule,\n index: [\n ...getNestedCSSRulePositions(thisArg),\n index || 0,\n ],\n },\n ],\n });\n }\n return target.apply(thisArg, argumentsList);\n }),\n });\n type.prototype.deleteRule = new Proxy(unmodifiedFunctions[typeKey].deleteRule, {\n apply: callbackWrapper((target, thisArg, argumentsList) => {\n const [index] = argumentsList;\n const id = mirror.getId(thisArg.parentStyleSheet.ownerNode);\n if (id !== -1) {\n styleSheetRuleCb({\n id,\n removes: [\n { index: [...getNestedCSSRulePositions(thisArg), index] },\n ],\n });\n }\n return target.apply(thisArg, argumentsList);\n }),\n });\n });\n return callbackWrapper(() => {\n win.CSSStyleSheet.prototype.insertRule = insertRule;\n win.CSSStyleSheet.prototype.deleteRule = deleteRule;\n Object.entries(supportedNestedCSSRuleTypes).forEach(([typeKey, type]) => {\n type.prototype.insertRule = unmodifiedFunctions[typeKey].insertRule;\n type.prototype.deleteRule = unmodifiedFunctions[typeKey].deleteRule;\n });\n });\n}\nfunction initStyleDeclarationObserver({ styleDeclarationCb, mirror }, { win }) {\n const setProperty = win.CSSStyleDeclaration.prototype.setProperty;\n win.CSSStyleDeclaration.prototype.setProperty = new Proxy(setProperty, {\n apply: callbackWrapper((target, thisArg, argumentsList) => {\n var _a, _b;\n const [property, value, priority] = argumentsList;\n const id = mirror.getId((_b = (_a = thisArg.parentRule) === null || _a === void 0 ? void 0 : _a.parentStyleSheet) === null || _b === void 0 ? void 0 : _b.ownerNode);\n if (id !== -1) {\n styleDeclarationCb({\n id,\n set: {\n property,\n value,\n priority,\n },\n index: getNestedCSSRulePositions(thisArg.parentRule),\n });\n }\n return target.apply(thisArg, argumentsList);\n }),\n });\n const removeProperty = win.CSSStyleDeclaration.prototype.removeProperty;\n win.CSSStyleDeclaration.prototype.removeProperty = new Proxy(removeProperty, {\n apply: callbackWrapper((target, thisArg, argumentsList) => {\n var _a, _b;\n const [property] = argumentsList;\n const id = mirror.getId((_b = (_a = thisArg.parentRule) === null || _a === void 0 ? void 0 : _a.parentStyleSheet) === null || _b === void 0 ? void 0 : _b.ownerNode);\n if (id !== -1) {\n styleDeclarationCb({\n id,\n remove: {\n property,\n },\n index: getNestedCSSRulePositions(thisArg.parentRule),\n });\n }\n return target.apply(thisArg, argumentsList);\n }),\n });\n return callbackWrapper(() => {\n win.CSSStyleDeclaration.prototype.setProperty = setProperty;\n win.CSSStyleDeclaration.prototype.removeProperty = removeProperty;\n });\n}\nfunction initMediaInteractionObserver({ mediaInteractionCb, blockClass, blockSelector, unblockSelector, mirror, sampling, }) {\n const handler = (type) => throttle(callbackWrapper((event) => {\n const target = getEventTarget(event);\n if (!target ||\n isBlocked(target, blockClass, blockSelector, unblockSelector)) {\n return;\n }\n const { currentTime, volume, muted } = target;\n mediaInteractionCb({\n type,\n id: mirror.getId(target),\n currentTime,\n volume,\n muted,\n });\n }), sampling.media || 500);\n const handlers = [\n on('play', handler(0)),\n on('pause', handler(1)),\n on('seeked', handler(2)),\n on('volumechange', handler(3)),\n ];\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction initFontObserver({ fontCb, doc }) {\n const win = doc.defaultView;\n if (!win) {\n return () => { };\n }\n const handlers = [];\n const fontMap = new WeakMap();\n const originalFontFace = win.FontFace;\n win.FontFace = function FontFace(family, source, descriptors) {\n const fontFace = new originalFontFace(family, source, descriptors);\n fontMap.set(fontFace, {\n family,\n buffer: typeof source !== 'string',\n descriptors,\n fontSource: typeof source === 'string'\n ? source\n :\n JSON.stringify(Array.from(new Uint8Array(source))),\n });\n return fontFace;\n };\n const restoreHandler = patch(doc.fonts, 'add', function (original) {\n return function (fontFace) {\n setTimeout(() => {\n const p = fontMap.get(fontFace);\n if (p) {\n fontCb(p);\n fontMap.delete(fontFace);\n }\n }, 0);\n return original.apply(this, [fontFace]);\n };\n });\n handlers.push(() => {\n win.FontFace = originalFontFace;\n });\n handlers.push(restoreHandler);\n return callbackWrapper(() => {\n handlers.forEach((h) => h());\n });\n}\nfunction mergeHooks(o, hooks) {\n const { mutationCb, mousemoveCb, mouseInteractionCb, scrollCb, viewportResizeCb, inputCb, mediaInteractionCb, styleSheetRuleCb, styleDeclarationCb, canvasMutationCb, fontCb, } = o;\n o.mutationCb = (...p) => {\n if (hooks.mutation) {\n hooks.mutation(...p);\n }\n mutationCb(...p);\n };\n o.mousemoveCb = (...p) => {\n if (hooks.mousemove) {\n hooks.mousemove(...p);\n }\n mousemoveCb(...p);\n };\n o.mouseInteractionCb = (...p) => {\n if (hooks.mouseInteraction) {\n hooks.mouseInteraction(...p);\n }\n mouseInteractionCb(...p);\n };\n o.scrollCb = (...p) => {\n if (hooks.scroll) {\n hooks.scroll(...p);\n }\n scrollCb(...p);\n };\n o.viewportResizeCb = (...p) => {\n if (hooks.viewportResize) {\n hooks.viewportResize(...p);\n }\n viewportResizeCb(...p);\n };\n o.inputCb = (...p) => {\n if (hooks.input) {\n hooks.input(...p);\n }\n inputCb(...p);\n };\n o.mediaInteractionCb = (...p) => {\n if (hooks.mediaInteaction) {\n hooks.mediaInteaction(...p);\n }\n mediaInteractionCb(...p);\n };\n o.styleSheetRuleCb = (...p) => {\n if (hooks.styleSheetRule) {\n hooks.styleSheetRule(...p);\n }\n styleSheetRuleCb(...p);\n };\n o.styleDeclarationCb = (...p) => {\n if (hooks.styleDeclaration) {\n hooks.styleDeclaration(...p);\n }\n styleDeclarationCb(...p);\n };\n o.canvasMutationCb = (...p) => {\n if (hooks.canvasMutation) {\n hooks.canvasMutation(...p);\n }\n canvasMutationCb(...p);\n };\n o.fontCb = (...p) => {\n if (hooks.font) {\n hooks.font(...p);\n }\n fontCb(...p);\n };\n}\nfunction initObservers(o, hooks = {}) {\n const currentWindow = o.doc.defaultView;\n if (!currentWindow) {\n return () => { };\n }\n mergeHooks(o, hooks);\n const mutationObserver = initMutationObserver(o, o.doc);\n const mousemoveHandler = initMoveObserver(o);\n const mouseInteractionHandler = initMouseInteractionObserver(o);\n const scrollHandler = initScrollObserver(o);\n const viewportResizeHandler = initViewportResizeObserver(o);\n const inputHandler = initInputObserver(o);\n const mediaInteractionHandler = initMediaInteractionObserver(o);\n const styleSheetObserver = initStyleSheetObserver(o, { win: currentWindow });\n const styleDeclarationObserver = initStyleDeclarationObserver(o, {\n win: currentWindow,\n });\n const fontObserver = o.collectFonts ? initFontObserver(o) : () => { };\n const pluginHandlers = [];\n for (const plugin of o.plugins) {\n pluginHandlers.push(plugin.observer(plugin.callback, currentWindow, plugin.options));\n }\n return callbackWrapper(() => {\n mutationBuffers.forEach((b) => b.reset());\n mutationObserver.disconnect();\n mousemoveHandler();\n mouseInteractionHandler();\n scrollHandler();\n viewportResizeHandler();\n inputHandler();\n mediaInteractionHandler();\n try {\n styleSheetObserver();\n styleDeclarationObserver();\n }\n catch (e) {\n }\n fontObserver();\n pluginHandlers.forEach((h) => h());\n });\n}\nfunction hasNestedCSSRule(prop) {\n return typeof window[prop] !== 'undefined';\n}\nfunction canMonkeyPatchNestedCSSRule(prop) {\n return Boolean(typeof window[prop] !== 'undefined' &&\n window[prop].prototype &&\n 'insertRule' in window[prop].prototype &&\n 'deleteRule' in window[prop].prototype);\n}\n\nexport { INPUT_TAGS, initMutationObserver, initObservers, initScrollObserver, mutationBuffers };\n","class IframeManager {\n constructor(options) {\n this.iframes = new WeakMap();\n this.mutationCb = options.mutationCb;\n }\n addIframe(iframeEl) {\n this.iframes.set(iframeEl, true);\n }\n addLoadListener(cb) {\n this.loadListener = cb;\n }\n attachIframe(iframeEl, childSn) {\n var _a;\n this.mutationCb({\n adds: [\n {\n parentId: iframeEl.__sn.id,\n nextId: null,\n node: childSn,\n },\n ],\n removes: [],\n texts: [],\n attributes: [],\n isAttachIframe: true,\n });\n (_a = this.loadListener) === null || _a === void 0 ? void 0 : _a.call(this, iframeEl);\n }\n}\n\nexport { IframeManager };\n","import { initMutationObserver, initScrollObserver } from './observer.js';\nimport { patch } from '../utils.js';\n\nclass ShadowDomManager {\n constructor(options) {\n this.restorePatches = [];\n this.mutationCb = options.mutationCb;\n this.scrollCb = options.scrollCb;\n this.bypassOptions = options.bypassOptions;\n this.mirror = options.mirror;\n const manager = this;\n this.restorePatches.push(patch(HTMLElement.prototype, 'attachShadow', function (original) {\n return function () {\n const shadowRoot = original.apply(this, arguments);\n if (this.shadowRoot)\n manager.addShadowRoot(this.shadowRoot, this.ownerDocument);\n return shadowRoot;\n };\n }));\n }\n addShadowRoot(shadowRoot, doc) {\n initMutationObserver(Object.assign(Object.assign({}, this.bypassOptions), { doc, mutationCb: this.mutationCb, mirror: this.mirror, shadowDomManager: this }), shadowRoot);\n initScrollObserver(Object.assign(Object.assign({}, this.bypassOptions), { scrollCb: this.scrollCb, doc: shadowRoot, mirror: this.mirror }));\n }\n observeAttachShadow(iframeElement) {\n if (iframeElement.contentWindow) {\n const manager = this;\n this.restorePatches.push(patch(iframeElement.contentWindow.HTMLElement.prototype, 'attachShadow', function (original) {\n return function () {\n const shadowRoot = original.apply(this, arguments);\n if (this.shadowRoot)\n manager.addShadowRoot(this.shadowRoot, iframeElement.contentDocument);\n return shadowRoot;\n };\n }));\n }\n }\n reset() {\n this.restorePatches.forEach((restorePatch) => restorePatch());\n }\n}\n\nexport { ShadowDomManager };\n","/*\n * base64-arraybuffer 1.0.2 <https://github.com/niklasvh/base64-arraybuffer>\n * Copyright (c) 2022 Niklas von Hertzen <https://hertzen.com>\n * Released under MIT License\n */\nvar chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n// Use a lookup table to find the index.\nvar lookup = typeof Uint8Array === 'undefined' ? [] : new Uint8Array(256);\nfor (var i = 0; i < chars.length; i++) {\n lookup[chars.charCodeAt(i)] = i;\n}\nvar encode = function (arraybuffer) {\n var bytes = new Uint8Array(arraybuffer), i, len = bytes.length, base64 = '';\n for (i = 0; i < len; i += 3) {\n base64 += chars[bytes[i] >> 2];\n base64 += chars[((bytes[i] & 3) << 4) | (bytes[i + 1] >> 4)];\n base64 += chars[((bytes[i + 1] & 15) << 2) | (bytes[i + 2] >> 6)];\n base64 += chars[bytes[i + 2] & 63];\n }\n if (len % 3 === 2) {\n base64 = base64.substring(0, base64.length - 1) + '=';\n }\n else if (len % 3 === 1) {\n base64 = base64.substring(0, base64.length - 2) + '==';\n }\n return base64;\n};\nvar decode = function (base64) {\n var bufferLength = base64.length * 0.75, len = base64.length, i, p = 0, encoded1, encoded2, encoded3, encoded4;\n if (base64[base64.length - 1] === '=') {\n bufferLength--;\n if (base64[base64.length - 2] === '=') {\n bufferLength--;\n }\n }\n var arraybuffer = new ArrayBuffer(bufferLength), bytes = new Uint8Array(arraybuffer);\n for (i = 0; i < len; i += 4) {\n encoded1 = lookup[base64.charCodeAt(i)];\n encoded2 = lookup[base64.charCodeAt(i + 1)];\n encoded3 = lookup[base64.charCodeAt(i + 2)];\n encoded4 = lookup[base64.charCodeAt(i + 3)];\n bytes[p++] = (encoded1 << 2) | (encoded2 >> 4);\n bytes[p++] = ((encoded2 & 15) << 4) | (encoded3 >> 2);\n bytes[p++] = ((encoded3 & 3) << 6) | (encoded4 & 63);\n }\n return arraybuffer;\n};\n\nexport { decode, encode };\n","import { encode } from './../../../../../../ext/base64-arraybuffer/dist/base64-arraybuffer.es5.js';\n\nconst webGLVarMap = new Map();\nfunction variableListFor(ctx, ctor) {\n let contextMap = webGLVarMap.get(ctx);\n if (!contextMap) {\n contextMap = new Map();\n webGLVarMap.set(ctx, contextMap);\n }\n if (!contextMap.has(ctor)) {\n contextMap.set(ctor, []);\n }\n return contextMap.get(ctor);\n}\nconst saveWebGLVar = (value, win, ctx) => {\n if (!value ||\n !(isInstanceOfWebGLObject(value, win) || typeof value === 'object'))\n return;\n const name = value.constructor.name;\n const list = variableListFor(ctx, name);\n let index = list.indexOf(value);\n if (index === -1) {\n index = list.length;\n list.push(value);\n }\n return index;\n};\nfunction serializeArg(value, win, ctx) {\n if (value instanceof Array) {\n return value.map((arg) => serializeArg(arg, win, ctx));\n }\n else if (value === null) {\n return value;\n }\n else if (value instanceof Float32Array ||\n value instanceof Float64Array ||\n value instanceof Int32Array ||\n value instanceof Uint32Array ||\n value instanceof Uint8Array ||\n value instanceof Uint16Array ||\n value instanceof Int16Array ||\n value instanceof Int8Array ||\n value instanceof Uint8ClampedArray) {\n const name = value.constructor.name;\n return {\n rr_type: name,\n args: [Object.values(value)],\n };\n }\n else if (value instanceof ArrayBuffer) {\n const name = value.constructor.name;\n const base64 = encode(value);\n return {\n rr_type: name,\n base64,\n };\n }\n else if (value instanceof DataView) {\n const name = value.constructor.name;\n return {\n rr_type: name,\n args: [\n serializeArg(value.buffer, win, ctx),\n value.byteOffset,\n value.byteLength,\n ],\n };\n }\n else if (value instanceof HTMLImageElement) {\n const name = value.constructor.name;\n const { src } = value;\n return {\n rr_type: name,\n src,\n };\n }\n else if (value instanceof ImageData) {\n const name = value.constructor.name;\n return {\n rr_type: name,\n args: [serializeArg(value.data, win, ctx), value.width, value.height],\n };\n }\n else if (isInstanceOfWebGLObject(value, win) || typeof value === 'object') {\n const name = value.constructor.name;\n const index = saveWebGLVar(value, win, ctx);\n return {\n rr_type: name,\n index: index,\n };\n }\n return value;\n}\nconst serializeArgs = (args, win, ctx) => {\n return [...args].map((arg) => serializeArg(arg, win, ctx));\n};\nconst isInstanceOfWebGLObject = (value, win) => {\n const webGLConstructorNames = [\n 'WebGLActiveInfo',\n 'WebGLBuffer',\n 'WebGLFramebuffer',\n 'WebGLProgram',\n 'WebGLRenderbuffer',\n 'WebGLShader',\n 'WebGLShaderPrecisionFormat',\n 'WebGLTexture',\n 'WebGLUniformLocation',\n 'WebGLVertexArrayObject',\n 'WebGLVertexArrayObjectOES',\n ];\n const supportedWebGLConstructorNames = webGLConstructorNames.filter((name) => typeof win[name] === 'function');\n return Boolean(supportedWebGLConstructorNames.find((name) => value instanceof win[name]));\n};\n\nexport { isInstanceOfWebGLObject, saveWebGLVar, serializeArg, serializeArgs, variableListFor };\n","import { CanvasContext } from '../../../types.js';\nimport { patch, isBlocked, hookSetter } from '../../../utils.js';\nimport { saveWebGLVar, serializeArgs } from './serialize-args.js';\n\nfunction patchGLPrototype(prototype, type, cb, blockClass, unblockSelector, blockSelector, mirror, win) {\n const handlers = [];\n const props = Object.getOwnPropertyNames(prototype);\n for (const prop of props) {\n try {\n if (typeof prototype[prop] !== 'function') {\n continue;\n }\n const restoreHandler = patch(prototype, prop, function (original) {\n return function (...args) {\n const result = original.apply(this, args);\n saveWebGLVar(result, win, prototype);\n if (!isBlocked(this.canvas, blockClass, blockSelector, unblockSelector)) {\n const id = mirror.getId(this.canvas);\n const recordArgs = serializeArgs([...args], win, prototype);\n const mutation = {\n type,\n property: prop,\n args: recordArgs,\n };\n cb(this.canvas, mutation);\n }\n return result;\n };\n });\n handlers.push(restoreHandler);\n }\n catch (_a) {\n const hookHandler = hookSetter(prototype, prop, {\n set(v) {\n cb(this.canvas, {\n type,\n property: prop,\n args: [v],\n setter: true,\n });\n },\n });\n handlers.push(hookHandler);\n }\n }\n return handlers;\n}\nfunction initCanvasWebGLMutationObserver(cb, win, blockClass, blockSelector, unblockSelector, mirror) {\n const handlers = [];\n handlers.push(...patchGLPrototype(win.WebGLRenderingContext.prototype, CanvasContext.WebGL, cb, blockClass, blockSelector, unblockSelector, mirror, win));\n if (typeof win.WebGL2RenderingContext !== 'undefined') {\n handlers.push(...patchGLPrototype(win.WebGL2RenderingContext.prototype, CanvasContext.WebGL2, cb, blockClass, blockSelector, unblockSelector, mirror, win));\n }\n return () => {\n handlers.forEach((h) => h());\n };\n}\n\nexport { initCanvasWebGLMutationObserver as default };\n","import { snapshot } from '../../../rrweb-snapshot/es/rrweb-snapshot.js';\nimport { initObservers, mutationBuffers } from './observer.js';\nimport { polyfill, on, createMirror, getWindowWidth, getWindowHeight, isIframeINode, hasShadowRoot } from '../utils.js';\nimport { EventType, IncrementalSource } from '../types.js';\nimport { IframeManager } from './iframe-manager.js';\nimport { ShadowDomManager } from './shadow-dom-manager.js';\nimport { CanvasManager } from './observers/canvas/canvas-manager.js';\nimport { callbackWrapper } from '../sentry/callbackWrapper.js';\n\nfunction wrapEvent(e) {\n return Object.assign(Object.assign({}, e), { timestamp: Date.now() });\n}\nlet wrappedEmit;\nlet takeFullSnapshot;\nconst mirror = createMirror();\nfunction record(options = {}) {\n const { emit, checkoutEveryNms, checkoutEveryNth, blockClass = 'rr-block', blockSelector = null, unblockSelector = null, ignoreClass = 'rr-ignore', ignoreSelector = null, maskTextClass = 'rr-mask', maskTextSelector = null, maskInputSelector = null, unmaskTextSelector = null, unmaskInputSelector = null, inlineStylesheet = true, maskAllText = false, maskAllInputs, maskInputOptions: _maskInputOptions, slimDOMOptions: _slimDOMOptions, maskInputFn, maskTextFn, hooks, packFn, sampling = {}, mousemoveWait, recordCanvas = false, userTriggeredOnInput = false, collectFonts = false, inlineImages = false, plugins, keepIframeSrcFn = () => false, onMutation, } = options;\n if (!emit) {\n throw new Error('emit function is required');\n }\n if (mousemoveWait !== undefined && sampling.mousemove === undefined) {\n sampling.mousemove = mousemoveWait;\n }\n const maskInputOptions = maskAllInputs === true\n ? {\n color: true,\n date: true,\n 'datetime-local': true,\n email: true,\n month: true,\n number: true,\n range: true,\n search: true,\n tel: true,\n text: true,\n time: true,\n url: true,\n week: true,\n textarea: true,\n select: true,\n radio: true,\n checkbox: true,\n }\n : _maskInputOptions !== undefined\n ? _maskInputOptions\n : {};\n const slimDOMOptions = _slimDOMOptions === true || _slimDOMOptions === 'all'\n ? {\n script: true,\n comment: true,\n headFavicon: true,\n headWhitespace: true,\n headMetaSocial: true,\n headMetaRobots: true,\n headMetaHttpEquiv: true,\n headMetaVerification: true,\n headMetaAuthorship: _slimDOMOptions === 'all',\n headMetaDescKeywords: _slimDOMOptions === 'all',\n }\n : _slimDOMOptions\n ? _slimDOMOptions\n : {};\n polyfill();\n let lastFullSnapshotEvent;\n let incrementalSnapshotCount = 0;\n const eventProcessor = (e) => {\n for (const plugin of plugins || []) {\n if (plugin.eventProcessor) {\n e = plugin.eventProcessor(e);\n }\n }\n if (packFn) {\n e = packFn(e);\n }\n return e;\n };\n wrappedEmit = (e, isCheckout) => {\n var _a;\n if (((_a = mutationBuffers[0]) === null || _a === void 0 ? void 0 : _a.isFrozen()) &&\n e.type !== EventType.FullSnapshot &&\n !(e.type === EventType.IncrementalSnapshot &&\n e.data.source === IncrementalSource.Mutation)) {\n mutationBuffers.forEach((buf) => buf.unfreeze());\n }\n emit(eventProcessor(e), isCheckout);\n if (e.type === EventType.FullSnapshot) {\n lastFullSnapshotEvent = e;\n incrementalSnapshotCount = 0;\n }\n else if (e.type === EventType.IncrementalSnapshot) {\n if (e.data.source === IncrementalSource.Mutation &&\n e.data.isAttachIframe) {\n return;\n }\n incrementalSnapshotCount++;\n const exceedCount = checkoutEveryNth && incrementalSnapshotCount >= checkoutEveryNth;\n const exceedTime = checkoutEveryNms &&\n e.timestamp - lastFullSnapshotEvent.timestamp > checkoutEveryNms;\n if (exceedCount || exceedTime) {\n takeFullSnapshot(true);\n }\n }\n };\n const wrappedMutationEmit = (m) => {\n wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.Mutation }, m),\n }));\n };\n const wrappedScrollEmit = (p) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.Scroll }, p),\n }));\n const wrappedCanvasMutationEmit = (p) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.CanvasMutation }, p),\n }));\n const iframeManager = new IframeManager({\n mutationCb: wrappedMutationEmit,\n });\n const canvasManager = new CanvasManager({\n recordCanvas,\n mutationCb: wrappedCanvasMutationEmit,\n win: window,\n blockClass,\n blockSelector,\n unblockSelector,\n mirror,\n });\n const shadowDomManager = new ShadowDomManager({\n mutationCb: wrappedMutationEmit,\n scrollCb: wrappedScrollEmit,\n bypassOptions: {\n onMutation,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n maskInputSelector,\n unmaskInputSelector,\n inlineStylesheet,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n recordCanvas,\n inlineImages,\n sampling,\n slimDOMOptions,\n iframeManager,\n canvasManager,\n },\n mirror,\n });\n takeFullSnapshot = (isCheckout = false) => {\n var _a, _b, _c, _d;\n wrappedEmit(wrapEvent({\n type: EventType.Meta,\n data: {\n href: window.location.href,\n width: getWindowWidth(),\n height: getWindowHeight(),\n },\n }), isCheckout);\n mutationBuffers.forEach((buf) => buf.lock());\n const [node, idNodeMap] = snapshot(document, {\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n maskInputSelector,\n unmaskInputSelector,\n inlineStylesheet,\n maskAllText,\n maskAllInputs: maskInputOptions,\n maskTextFn,\n slimDOM: slimDOMOptions,\n recordCanvas,\n inlineImages,\n onSerialize: (n) => {\n if (isIframeINode(n)) {\n iframeManager.addIframe(n);\n }\n if (hasShadowRoot(n)) {\n shadowDomManager.addShadowRoot(n.shadowRoot, document);\n }\n },\n onIframeLoad: (iframe, childSn) => {\n iframeManager.attachIframe(iframe, childSn);\n shadowDomManager.observeAttachShadow(iframe);\n },\n keepIframeSrcFn,\n });\n if (!node) {\n return console.warn('Failed to snapshot the document');\n }\n mirror.map = idNodeMap;\n wrappedEmit(wrapEvent({\n type: EventType.FullSnapshot,\n data: {\n node,\n initialOffset: {\n left: window.pageXOffset !== undefined\n ? window.pageXOffset\n : (document === null || document === void 0 ? void 0 : document.documentElement.scrollLeft) ||\n ((_b = (_a = document === null || document === void 0 ? void 0 : document.body) === null || _a === void 0 ? void 0 : _a.parentElement) === null || _b === void 0 ? void 0 : _b.scrollLeft) ||\n (document === null || document === void 0 ? void 0 : document.body.scrollLeft) ||\n 0,\n top: window.pageYOffset !== undefined\n ? window.pageYOffset\n : (document === null || document === void 0 ? void 0 : document.documentElement.scrollTop) ||\n ((_d = (_c = document === null || document === void 0 ? void 0 : document.body) === null || _c === void 0 ? void 0 : _c.parentElement) === null || _d === void 0 ? void 0 : _d.scrollTop) ||\n (document === null || document === void 0 ? void 0 : document.body.scrollTop) ||\n 0,\n },\n },\n }));\n mutationBuffers.forEach((buf) => buf.unlock());\n };\n try {\n const handlers = [];\n handlers.push(on('DOMContentLoaded', () => {\n wrappedEmit(wrapEvent({\n type: EventType.DomContentLoaded,\n data: {},\n }));\n }));\n const observe = (doc) => {\n var _a;\n return callbackWrapper(initObservers)({\n onMutation,\n mutationCb: wrappedMutationEmit,\n mousemoveCb: (positions, source) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: {\n source,\n positions,\n },\n })),\n mouseInteractionCb: (d) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.MouseInteraction }, d),\n })),\n scrollCb: wrappedScrollEmit,\n viewportResizeCb: (d) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.ViewportResize }, d),\n })),\n inputCb: (v) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.Input }, v),\n })),\n mediaInteractionCb: (p) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.MediaInteraction }, p),\n })),\n styleSheetRuleCb: (r) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.StyleSheetRule }, r),\n })),\n styleDeclarationCb: (r) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.StyleDeclaration }, r),\n })),\n canvasMutationCb: wrappedCanvasMutationEmit,\n fontCb: (p) => wrappedEmit(wrapEvent({\n type: EventType.IncrementalSnapshot,\n data: Object.assign({ source: IncrementalSource.Font }, p),\n })),\n blockClass,\n ignoreClass,\n ignoreSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n maskInputSelector,\n unmaskInputSelector,\n maskInputOptions,\n inlineStylesheet,\n sampling,\n recordCanvas,\n inlineImages,\n userTriggeredOnInput,\n collectFonts,\n doc,\n maskAllText,\n maskInputFn,\n maskTextFn,\n blockSelector,\n unblockSelector,\n slimDOMOptions,\n mirror,\n iframeManager,\n shadowDomManager,\n canvasManager,\n plugins: ((_a = plugins === null || plugins === void 0 ? void 0 : plugins.filter((p) => p.observer)) === null || _a === void 0 ? void 0 : _a.map((p) => ({\n observer: p.observer,\n options: p.options,\n callback: (payload) => wrappedEmit(wrapEvent({\n type: EventType.Plugin,\n data: {\n plugin: p.name,\n payload,\n },\n })),\n }))) || [],\n }, hooks);\n };\n iframeManager.addLoadListener((iframeEl) => {\n try {\n handlers.push(observe(iframeEl.contentDocument));\n }\n catch (error) {\n console.warn(error);\n }\n });\n const init = () => {\n takeFullSnapshot();\n handlers.push(observe(document));\n };\n if (document.readyState === 'interactive' ||\n document.readyState === 'complete') {\n init();\n }\n else {\n handlers.push(on('load', () => {\n wrappedEmit(wrapEvent({\n type: EventType.Load,\n data: {},\n }));\n init();\n }, window));\n }\n return () => {\n handlers.forEach((h) => h());\n };\n }\n catch (error) {\n console.warn(error);\n }\n}\nrecord.addCustomEvent = (tag, payload) => {\n if (!wrappedEmit) {\n throw new Error('please add custom event after start recording');\n }\n wrappedEmit(wrapEvent({\n type: EventType.Custom,\n data: {\n tag,\n payload,\n },\n }));\n};\nrecord.freezePage = () => {\n mutationBuffers.forEach((buf) => buf.freeze());\n};\nrecord.takeFullSnapshot = (isCheckout) => {\n if (!takeFullSnapshot) {\n throw new Error('please take full snapshot after start recording');\n }\n takeFullSnapshot(isCheckout);\n};\nrecord.mirror = mirror;\n\nexport { record as default };\n","import { __rest } from './../../../../../../ext/tslib/tslib.es6.js';\nimport initCanvas2DMutationObserver from './2d.js';\nimport initCanvasContextObserver from './canvas.js';\nimport initCanvasWebGLMutationObserver from './webgl.js';\n\nclass CanvasManager {\n reset() {\n this.pendingCanvasMutations.clear();\n this.resetObservers && this.resetObservers();\n }\n freeze() {\n this.frozen = true;\n }\n unfreeze() {\n this.frozen = false;\n }\n lock() {\n this.locked = true;\n }\n unlock() {\n this.locked = false;\n }\n constructor(options) {\n this.pendingCanvasMutations = new Map();\n this.rafStamps = { latestId: 0, invokeId: null };\n this.frozen = false;\n this.locked = false;\n this.processMutation = function (target, mutation) {\n const newFrame = this.rafStamps.invokeId &&\n this.rafStamps.latestId !== this.rafStamps.invokeId;\n if (newFrame || !this.rafStamps.invokeId)\n this.rafStamps.invokeId = this.rafStamps.latestId;\n if (!this.pendingCanvasMutations.has(target)) {\n this.pendingCanvasMutations.set(target, []);\n }\n this.pendingCanvasMutations.get(target).push(mutation);\n };\n this.mutationCb = options.mutationCb;\n this.mirror = options.mirror;\n if (options.recordCanvas === true)\n this.initCanvasMutationObserver(options.win, options.blockClass, options.blockSelector, options.unblockSelector);\n }\n initCanvasMutationObserver(win, blockClass, unblockSelector, blockSelector) {\n this.startRAFTimestamping();\n this.startPendingCanvasMutationFlusher();\n const canvasContextReset = initCanvasContextObserver(win, blockClass, blockSelector, unblockSelector);\n const canvas2DReset = initCanvas2DMutationObserver(this.processMutation.bind(this), win, blockClass, blockSelector, unblockSelector, this.mirror);\n const canvasWebGL1and2Reset = initCanvasWebGLMutationObserver(this.processMutation.bind(this), win, blockClass, blockSelector, unblockSelector, this.mirror);\n this.resetObservers = () => {\n canvasContextReset();\n canvas2DReset();\n canvasWebGL1and2Reset();\n };\n }\n startPendingCanvasMutationFlusher() {\n requestAnimationFrame(() => this.flushPendingCanvasMutations());\n }\n startRAFTimestamping() {\n const setLatestRAFTimestamp = (timestamp) => {\n this.rafStamps.latestId = timestamp;\n requestAnimationFrame(setLatestRAFTimestamp);\n };\n requestAnimationFrame(setLatestRAFTimestamp);\n }\n flushPendingCanvasMutations() {\n this.pendingCanvasMutations.forEach((values, canvas) => {\n const id = this.mirror.getId(canvas);\n this.flushPendingCanvasMutationFor(canvas, id);\n });\n requestAnimationFrame(() => this.flushPendingCanvasMutations());\n }\n flushPendingCanvasMutationFor(canvas, id) {\n if (this.frozen || this.locked) {\n return;\n }\n const valuesWithType = this.pendingCanvasMutations.get(canvas);\n if (!valuesWithType || id === -1)\n return;\n const values = valuesWithType.map((value) => {\n const rest = __rest(value, [\"type\"]);\n return rest;\n });\n const { type } = valuesWithType[0];\n this.mutationCb({ id, type, commands: values });\n this.pendingCanvasMutations.delete(canvas);\n }\n}\n\nexport { CanvasManager };\n","import { patch, isBlocked } from '../../../utils.js';\n\nfunction initCanvasContextObserver(win, blockClass, blockSelector, unblockSelector) {\n const handlers = [];\n try {\n const restoreHandler = patch(win.HTMLCanvasElement.prototype, 'getContext', function (original) {\n return function (contextType, ...args) {\n if (!isBlocked(this, blockClass, blockSelector, unblockSelector)) {\n if (!('__context' in this))\n this.__context = contextType;\n }\n return original.apply(this, [contextType, ...args]);\n };\n });\n handlers.push(restoreHandler);\n }\n catch (_a) {\n console.error('failed to patch HTMLCanvasElement.prototype.getContext');\n }\n return () => {\n handlers.forEach((h) => h());\n };\n}\n\nexport { initCanvasContextObserver as default };\n","import { CanvasContext } from '../../../types.js';\nimport { patch, isBlocked, hookSetter } from '../../../utils.js';\n\nfunction initCanvas2DMutationObserver(cb, win, blockClass, unblockSelector, blockSelector, mirror) {\n const handlers = [];\n const props2D = Object.getOwnPropertyNames(win.CanvasRenderingContext2D.prototype);\n for (const prop of props2D) {\n try {\n if (typeof win.CanvasRenderingContext2D.prototype[prop] !== 'function') {\n continue;\n }\n const restoreHandler = patch(win.CanvasRenderingContext2D.prototype, prop, function (original) {\n return function (...args) {\n if (!isBlocked(this.canvas, blockClass, blockSelector, unblockSelector)) {\n setTimeout(() => {\n const recordArgs = [...args];\n if (prop === 'drawImage') {\n if (recordArgs[0] &&\n recordArgs[0] instanceof HTMLCanvasElement) {\n const canvas = recordArgs[0];\n const ctx = canvas.getContext('2d');\n let imgd = ctx === null || ctx === void 0 ? void 0 : ctx.getImageData(0, 0, canvas.width, canvas.height);\n let pix = imgd === null || imgd === void 0 ? void 0 : imgd.data;\n recordArgs[0] = JSON.stringify(pix);\n }\n }\n cb(this.canvas, {\n type: CanvasContext['2D'],\n property: prop,\n args: recordArgs,\n });\n }, 0);\n }\n return original.apply(this, args);\n };\n });\n handlers.push(restoreHandler);\n }\n catch (_a) {\n const hookHandler = hookSetter(win.CanvasRenderingContext2D.prototype, prop, {\n set(v) {\n cb(this.canvas, {\n type: CanvasContext['2D'],\n property: prop,\n args: [v],\n setter: true,\n });\n },\n });\n handlers.push(hookHandler);\n }\n }\n return () => {\n handlers.forEach((h) => h());\n };\n}\n\nexport { initCanvas2DMutationObserver as default };\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n\r\nfunction __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\n\nexport { __rest };\n","/**\n * Converts a timestamp to ms, if it was in s, or keeps it as ms.\n */\nexport function timestampToMs(timestamp: number): number {\n const isMs = timestamp > 9999999999;\n return isMs ? timestamp : timestamp * 1000;\n}\n\n/**\n * Converts a timestamp to s, if it was in ms, or keeps it as s.\n */\nexport function timestampToS(timestamp: number): number {\n const isMs = timestamp > 9999999999;\n return isMs ? timestamp / 1000 : timestamp;\n}\n","import { EventType } from '@sentry-internal/rrweb';\nimport type { Breadcrumb } from '@sentry/types';\nimport { normalize } from '@sentry/utils';\n\nimport type { ReplayContainer } from '../../types';\n\n/**\n * Add a breadcrumb event to replay.\n */\nexport function addBreadcrumbEvent(replay: ReplayContainer, breadcrumb: Breadcrumb): void {\n if (breadcrumb.category === 'sentry.transaction') {\n return;\n }\n\n if (['ui.click', 'ui.input'].includes(breadcrumb.category as string)) {\n replay.triggerUserActivity();\n } else {\n replay.checkAndHandleExpiredSession();\n }\n\n replay.addUpdate(() => {\n void replay.throttledAddEvent({\n type: EventType.Custom,\n // TODO: We were converting from ms to seconds for breadcrumbs, spans,\n // but maybe we should just keep them as milliseconds\n timestamp: (breadcrumb.timestamp || 0) * 1000,\n data: {\n tag: 'breadcrumb',\n // normalize to max. 10 depth and 1_000 properties per object\n payload: normalize(breadcrumb, 10, 1_000),\n },\n });\n\n // Do not flush after console log messages\n return breadcrumb.category === 'console';\n });\n}\n","import type { INode } from '@sentry-internal/rrweb-snapshot';\n\nexport interface DomHandlerData {\n name: string;\n event: Node | { target: EventTarget };\n}\n\nconst INTERACTIVE_SELECTOR = 'button,a';\n\n/**\n * For clicks, we check if the target is inside of a button or link\n * If so, we use this as the target instead\n * This is useful because if you click on the image in <button><img></button>,\n * The target will be the image, not the button, which we don't want here\n */\nexport function getClickTargetNode(event: DomHandlerData['event'] | MouseEvent): Node | INode | null {\n const target = getTargetNode(event);\n\n if (!target || !(target instanceof Element)) {\n return target;\n }\n\n const closestInteractive = target.closest(INTERACTIVE_SELECTOR);\n return closestInteractive || target;\n}\n\n/** Get the event target node. */\nexport function getTargetNode(event: Node | { target: EventTarget | null }): Node | INode | null {\n if (isEventWithTarget(event)) {\n return event.target as Node | null;\n }\n\n return event;\n}\n\nfunction isEventWithTarget(event: unknown): event is { target: EventTarget | null } {\n return typeof event === 'object' && !!event && 'target' in event;\n}\n","import { fill } from '@sentry/utils';\n\nimport { WINDOW } from '../../constants';\n\ntype WindowOpenHandler = () => void;\n\nlet handlers: undefined | WindowOpenHandler[];\n\n/**\n * Register a handler to be called when `window.open()` is called.\n * Returns a cleanup function.\n */\nexport function onWindowOpen(cb: WindowOpenHandler): () => void {\n // Ensure to only register this once\n if (!handlers) {\n handlers = [];\n monkeyPatchWindowOpen();\n }\n\n handlers.push(cb);\n\n return () => {\n const pos = handlers ? handlers.indexOf(cb) : -1;\n if (pos > -1) {\n (handlers as WindowOpenHandler[]).splice(pos, 1);\n }\n };\n}\n\nfunction monkeyPatchWindowOpen(): void {\n fill(WINDOW, 'open', function (originalWindowOpen: () => void): () => void {\n return function (...args: unknown[]): void {\n if (handlers) {\n try {\n handlers.forEach(handler => handler());\n } catch (e) {\n // ignore errors in here\n }\n }\n\n return originalWindowOpen.apply(WINDOW, args);\n };\n });\n}\n","var NodeType;\n(function (NodeType) {\n NodeType[NodeType[\"Document\"] = 0] = \"Document\";\n NodeType[NodeType[\"DocumentType\"] = 1] = \"DocumentType\";\n NodeType[NodeType[\"Element\"] = 2] = \"Element\";\n NodeType[NodeType[\"Text\"] = 3] = \"Text\";\n NodeType[NodeType[\"CDATA\"] = 4] = \"CDATA\";\n NodeType[NodeType[\"Comment\"] = 5] = \"Comment\";\n})(NodeType || (NodeType = {}));\n\nfunction isElement(n) {\n return n.nodeType === n.ELEMENT_NODE;\n}\nfunction isShadowRoot(n) {\n const host = n === null || n === void 0 ? void 0 : n.host;\n return Boolean(host && host.shadowRoot && host.shadowRoot === n);\n}\nfunction isInputTypeMasked({ maskInputOptions, tagName, type, }) {\n if (tagName.toLowerCase() === 'option') {\n tagName = 'select';\n }\n const actualType = typeof type === 'string' ? type.toLowerCase() : undefined;\n return (maskInputOptions[tagName.toLowerCase()] ||\n (actualType && maskInputOptions[actualType]) ||\n actualType === 'password' ||\n (tagName === 'input' && !type && maskInputOptions['text']));\n}\nfunction hasInputMaskOptions({ tagName, type, maskInputOptions, maskInputSelector, }) {\n return (maskInputSelector || isInputTypeMasked({ maskInputOptions, tagName, type }));\n}\nfunction maskInputValue({ input, maskInputSelector, unmaskInputSelector, maskInputOptions, tagName, type, value, maskInputFn, }) {\n let text = value || '';\n if (unmaskInputSelector && input.matches(unmaskInputSelector)) {\n return text;\n }\n if (input.hasAttribute('data-rr-is-password')) {\n type = 'password';\n }\n if (isInputTypeMasked({ maskInputOptions, tagName, type }) ||\n (maskInputSelector && input.matches(maskInputSelector))) {\n if (maskInputFn) {\n text = maskInputFn(text);\n }\n else {\n text = '*'.repeat(text.length);\n }\n }\n return text;\n}\nconst ORIGINAL_ATTRIBUTE_NAME = '__rrweb_original__';\nfunction is2DCanvasBlank(canvas) {\n const ctx = canvas.getContext('2d');\n if (!ctx)\n return true;\n const chunkSize = 50;\n for (let x = 0; x < canvas.width; x += chunkSize) {\n for (let y = 0; y < canvas.height; y += chunkSize) {\n const getImageData = ctx.getImageData;\n const originalGetImageData = ORIGINAL_ATTRIBUTE_NAME in getImageData\n ? getImageData[ORIGINAL_ATTRIBUTE_NAME]\n : getImageData;\n const pixelBuffer = new Uint32Array(originalGetImageData.call(ctx, x, y, Math.min(chunkSize, canvas.width - x), Math.min(chunkSize, canvas.height - y)).data.buffer);\n if (pixelBuffer.some((pixel) => pixel !== 0))\n return false;\n }\n }\n return true;\n}\nfunction getInputType(element) {\n const type = element.type;\n return element.hasAttribute('data-rr-is-password')\n ? 'password'\n : type\n ? type.toLowerCase()\n : null;\n}\nfunction getInputValue(el, tagName, type) {\n typeof type === 'string' ? type.toLowerCase() : '';\n if (tagName === 'INPUT' && (type === 'radio' || type === 'checkbox')) {\n return el.getAttribute('value') || '';\n }\n return el.value;\n}\nfunction defineCustomElement(w, elementName) {\n try {\n if (!w.customElements.get(elementName)) {\n const CustomElement = w.HTMLElement;\n w.customElements.define(elementName, class extends CustomElement {\n });\n }\n }\n catch (_a) { }\n}\n\nlet _id = 1;\nconst tagNameRegex = new RegExp('[^a-z0-9-_:]');\nconst IGNORED_NODE = -2;\nfunction defaultMaskFn(str) {\n return str ? str.replace(/[\\S]/g, '*') : '';\n}\nfunction genId() {\n return _id++;\n}\nfunction getValidTagName(element) {\n if (element instanceof HTMLFormElement) {\n return 'form';\n }\n const processedTagName = element.tagName.toLowerCase().trim();\n if (tagNameRegex.test(processedTagName)) {\n return 'div';\n }\n return processedTagName;\n}\nfunction getCssRulesString(s) {\n try {\n const rules = s.rules || s.cssRules;\n return rules ? Array.from(rules).map(getCssRuleString).join('') : null;\n }\n catch (error) {\n return null;\n }\n}\nfunction getCssRuleString(rule) {\n let cssStringified = rule.cssText;\n if (isCSSImportRule(rule)) {\n try {\n cssStringified = getCssRulesString(rule.styleSheet) || cssStringified;\n }\n catch (_a) {\n }\n }\n return validateStringifiedCssRule(cssStringified);\n}\nfunction validateStringifiedCssRule(cssStringified) {\n if (cssStringified.indexOf(':') > -1) {\n const regex = /(\\[(?:[\\w-]+)[^\\\\])(:(?:[\\w-]+)\\])/gm;\n return cssStringified.replace(regex, '$1\\\\$2');\n }\n return cssStringified;\n}\nfunction isCSSImportRule(rule) {\n return 'styleSheet' in rule;\n}\nfunction stringifyStyleSheet(sheet) {\n return sheet.cssRules\n ? Array.from(sheet.cssRules)\n .map((rule) => rule.cssText ? validateStringifiedCssRule(rule.cssText) : '')\n .join('')\n : '';\n}\nfunction extractOrigin(url) {\n let origin = '';\n if (url.indexOf('//') > -1) {\n origin = url.split('/').slice(0, 3).join('/');\n }\n else {\n origin = url.split('/')[0];\n }\n origin = origin.split('?')[0];\n return origin;\n}\nlet canvasService;\nlet canvasCtx;\nconst URL_IN_CSS_REF = /url\\((?:(')([^']*)'|(\")(.*?)\"|([^)]*))\\)/gm;\nconst RELATIVE_PATH = /^(?!www\\.|(?:http|ftp)s?:\\/\\/|[A-Za-z]:\\\\|\\/\\/|#).*/;\nconst DATA_URI = /^(data:)([^,]*),(.*)/i;\nfunction absoluteToStylesheet(cssText, href) {\n return (cssText || '').replace(URL_IN_CSS_REF, (origin, quote1, path1, quote2, path2, path3) => {\n const filePath = path1 || path2 || path3;\n const maybeQuote = quote1 || quote2 || '';\n if (!filePath) {\n return origin;\n }\n if (!RELATIVE_PATH.test(filePath)) {\n return `url(${maybeQuote}${filePath}${maybeQuote})`;\n }\n if (DATA_URI.test(filePath)) {\n return `url(${maybeQuote}${filePath}${maybeQuote})`;\n }\n if (filePath[0] === '/') {\n return `url(${maybeQuote}${extractOrigin(href) + filePath}${maybeQuote})`;\n }\n const stack = href.split('/');\n const parts = filePath.split('/');\n stack.pop();\n for (const part of parts) {\n if (part === '.') {\n continue;\n }\n else if (part === '..') {\n stack.pop();\n }\n else {\n stack.push(part);\n }\n }\n return `url(${maybeQuote}${stack.join('/')}${maybeQuote})`;\n });\n}\nconst SRCSET_NOT_SPACES = /^[^ \\t\\n\\r\\u000c]+/;\nconst SRCSET_COMMAS_OR_SPACES = /^[, \\t\\n\\r\\u000c]+/;\nfunction getAbsoluteSrcsetString(doc, attributeValue) {\n if (attributeValue.trim() === '') {\n return attributeValue;\n }\n let pos = 0;\n function collectCharacters(regEx) {\n let chars;\n let match = regEx.exec(attributeValue.substring(pos));\n if (match) {\n chars = match[0];\n pos += chars.length;\n return chars;\n }\n return '';\n }\n let output = [];\n while (true) {\n collectCharacters(SRCSET_COMMAS_OR_SPACES);\n if (pos >= attributeValue.length) {\n break;\n }\n let url = collectCharacters(SRCSET_NOT_SPACES);\n if (url.slice(-1) === ',') {\n url = absoluteToDoc(doc, url.substring(0, url.length - 1));\n output.push(url);\n }\n else {\n let descriptorsStr = '';\n url = absoluteToDoc(doc, url);\n let inParens = false;\n while (true) {\n let c = attributeValue.charAt(pos);\n if (c === '') {\n output.push((url + descriptorsStr).trim());\n break;\n }\n else if (!inParens) {\n if (c === ',') {\n pos += 1;\n output.push((url + descriptorsStr).trim());\n break;\n }\n else if (c === '(') {\n inParens = true;\n }\n }\n else {\n if (c === ')') {\n inParens = false;\n }\n }\n descriptorsStr += c;\n pos += 1;\n }\n }\n }\n return output.join(', ');\n}\nfunction absoluteToDoc(doc, attributeValue) {\n if (!attributeValue || attributeValue.trim() === '') {\n return attributeValue;\n }\n const a = doc.createElement('a');\n a.href = attributeValue;\n return a.href;\n}\nfunction isSVGElement(el) {\n return Boolean(el.tagName === 'svg' || el.ownerSVGElement);\n}\nfunction getHref() {\n const a = document.createElement('a');\n a.href = '';\n return a.href;\n}\nfunction transformAttribute(doc, element, _tagName, _name, value, maskAllText, unmaskTextSelector, maskTextFn) {\n if (!value) {\n return value;\n }\n const name = _name.toLowerCase();\n const tagName = _tagName.toLowerCase();\n if (name === 'src' || name === 'href') {\n return absoluteToDoc(doc, value);\n }\n else if (name === 'xlink:href' && value[0] !== '#') {\n return absoluteToDoc(doc, value);\n }\n else if (name === 'background' &&\n (tagName === 'table' || tagName === 'td' || tagName === 'th')) {\n return absoluteToDoc(doc, value);\n }\n else if (name === 'srcset') {\n return getAbsoluteSrcsetString(doc, value);\n }\n else if (name === 'style') {\n return absoluteToStylesheet(value, getHref());\n }\n else if (tagName === 'object' && name === 'data') {\n return absoluteToDoc(doc, value);\n }\n else if (maskAllText &&\n _shouldMaskAttribute(element, name, tagName, unmaskTextSelector)) {\n return maskTextFn ? maskTextFn(value) : defaultMaskFn(value);\n }\n return value;\n}\nfunction _shouldMaskAttribute(element, attribute, tagName, unmaskTextSelector) {\n if (unmaskTextSelector && element.matches(unmaskTextSelector)) {\n return false;\n }\n return (['placeholder', 'title', 'aria-label'].indexOf(attribute) > -1 ||\n (tagName === 'input' &&\n attribute === 'value' &&\n element.hasAttribute('type') &&\n ['submit', 'button'].indexOf(element.getAttribute('type').toLowerCase()) > -1));\n}\nfunction _isBlockedElement(element, blockClass, blockSelector, unblockSelector) {\n if (unblockSelector && element.matches(unblockSelector)) {\n return false;\n }\n if (typeof blockClass === 'string') {\n if (element.classList.contains(blockClass)) {\n return true;\n }\n }\n else {\n for (let eIndex = 0; eIndex < element.classList.length; eIndex++) {\n const className = element.classList[eIndex];\n if (blockClass.test(className)) {\n return true;\n }\n }\n }\n if (blockSelector) {\n return element.matches(blockSelector);\n }\n return false;\n}\nfunction needMaskingText(node, maskTextClass, maskTextSelector, unmaskTextSelector, maskAllText) {\n if (!node) {\n return false;\n }\n if (node.nodeType !== node.ELEMENT_NODE) {\n return needMaskingText(node.parentNode, maskTextClass, maskTextSelector, unmaskTextSelector, maskAllText);\n }\n if (unmaskTextSelector) {\n if (node.matches(unmaskTextSelector) ||\n node.closest(unmaskTextSelector)) {\n return false;\n }\n }\n if (maskAllText) {\n return true;\n }\n if (typeof maskTextClass === 'string') {\n if (node.classList.contains(maskTextClass)) {\n return true;\n }\n }\n else {\n for (let eIndex = 0; eIndex < node.classList.length; eIndex++) {\n const className = node.classList[eIndex];\n if (maskTextClass.test(className)) {\n return true;\n }\n }\n }\n if (maskTextSelector) {\n if (node.matches(maskTextSelector)) {\n return true;\n }\n }\n return needMaskingText(node.parentNode, maskTextClass, maskTextSelector, unmaskTextSelector, maskAllText);\n}\nfunction onceIframeLoaded(iframeEl, listener, iframeLoadTimeout) {\n const win = iframeEl.contentWindow;\n if (!win) {\n return;\n }\n let fired = false;\n let readyState;\n try {\n readyState = win.document.readyState;\n }\n catch (error) {\n return;\n }\n if (readyState !== 'complete') {\n const timer = setTimeout(() => {\n if (!fired) {\n listener();\n fired = true;\n }\n }, iframeLoadTimeout);\n iframeEl.addEventListener('load', () => {\n clearTimeout(timer);\n fired = true;\n listener();\n });\n return;\n }\n const blankUrl = 'about:blank';\n if (win.location.href !== blankUrl ||\n iframeEl.src === blankUrl ||\n iframeEl.src === '') {\n setTimeout(listener, 0);\n return;\n }\n iframeEl.addEventListener('load', listener);\n}\nfunction serializeNode(n, options) {\n var _a;\n const { doc, blockClass, blockSelector, unblockSelector, maskTextClass, maskTextSelector, unmaskTextSelector, inlineStylesheet, maskInputSelector, unmaskInputSelector, maskAllText, maskInputOptions = {}, maskTextFn, maskInputFn, dataURLOptions = {}, inlineImages, recordCanvas, keepIframeSrcFn, } = options;\n let rootId;\n if (doc.__sn) {\n const docId = doc.__sn.id;\n rootId = docId === 1 ? undefined : docId;\n }\n switch (n.nodeType) {\n case n.DOCUMENT_NODE:\n if (n.compatMode !== 'CSS1Compat') {\n return {\n type: NodeType.Document,\n childNodes: [],\n compatMode: n.compatMode,\n rootId,\n };\n }\n else {\n return {\n type: NodeType.Document,\n childNodes: [],\n rootId,\n };\n }\n case n.DOCUMENT_TYPE_NODE:\n return {\n type: NodeType.DocumentType,\n name: n.name,\n publicId: n.publicId,\n systemId: n.systemId,\n rootId,\n };\n case n.ELEMENT_NODE:\n const needBlock = _isBlockedElement(n, blockClass, blockSelector, unblockSelector);\n const tagName = getValidTagName(n);\n let attributes = {};\n for (const { name, value } of Array.from(n.attributes)) {\n if (!skipAttribute(tagName, name)) {\n attributes[name] = transformAttribute(doc, n, tagName, name, value, maskAllText, unmaskTextSelector, maskTextFn);\n }\n }\n if (tagName === 'link' && inlineStylesheet) {\n const stylesheet = Array.from(doc.styleSheets).find((s) => {\n return s.href === n.href;\n });\n let cssText = null;\n if (stylesheet) {\n cssText = getCssRulesString(stylesheet);\n }\n if (cssText) {\n delete attributes.rel;\n delete attributes.href;\n attributes._cssText = absoluteToStylesheet(cssText, stylesheet.href);\n }\n }\n if (tagName === 'style' &&\n n.sheet &&\n !(n.innerText ||\n n.textContent ||\n '').trim().length) {\n const cssText = getCssRulesString(n.sheet);\n if (cssText) {\n attributes._cssText = absoluteToStylesheet(cssText, getHref());\n }\n }\n if (tagName === 'input' ||\n tagName === 'textarea' ||\n tagName === 'select' ||\n tagName === 'option') {\n const el = n;\n const type = getInputType(el);\n const value = getInputValue(el, tagName.toUpperCase(), type);\n const checked = n.checked;\n if (type !== 'submit' &&\n type !== 'button' &&\n value) {\n attributes.value = maskInputValue({\n input: el,\n type,\n tagName,\n value,\n maskInputSelector,\n unmaskInputSelector,\n maskInputOptions,\n maskInputFn,\n });\n }\n if (checked) {\n attributes.checked = checked;\n }\n }\n if (tagName === 'option') {\n if (n.selected && !maskInputOptions['select']) {\n attributes.selected = true;\n }\n else {\n delete attributes.selected;\n }\n }\n if (tagName === 'canvas' && recordCanvas) {\n if (n.__context === '2d') {\n if (!is2DCanvasBlank(n)) {\n attributes.rr_dataURL = n.toDataURL(dataURLOptions.type, dataURLOptions.quality);\n }\n }\n else if (!('__context' in n)) {\n const canvasDataURL = n.toDataURL(dataURLOptions.type, dataURLOptions.quality);\n const blankCanvas = document.createElement('canvas');\n blankCanvas.width = n.width;\n blankCanvas.height = n.height;\n const blankCanvasDataURL = blankCanvas.toDataURL(dataURLOptions.type, dataURLOptions.quality);\n if (canvasDataURL !== blankCanvasDataURL) {\n attributes.rr_dataURL = canvasDataURL;\n }\n }\n }\n if (tagName === 'img' && inlineImages) {\n if (!canvasService) {\n canvasService = doc.createElement('canvas');\n canvasCtx = canvasService.getContext('2d');\n }\n const image = n;\n const oldValue = image.crossOrigin;\n image.crossOrigin = 'anonymous';\n const recordInlineImage = () => {\n try {\n canvasService.width = image.naturalWidth;\n canvasService.height = image.naturalHeight;\n canvasCtx.drawImage(image, 0, 0);\n attributes.rr_dataURL = canvasService.toDataURL(dataURLOptions.type, dataURLOptions.quality);\n }\n catch (err) {\n console.warn(`Cannot inline img src=${image.currentSrc}! Error: ${err}`);\n }\n oldValue\n ? (attributes.crossOrigin = oldValue)\n : delete attributes.crossOrigin;\n };\n if (image.complete && image.naturalWidth !== 0)\n recordInlineImage();\n else\n image.onload = recordInlineImage;\n }\n if (tagName === 'audio' || tagName === 'video') {\n attributes.rr_mediaState = n.paused\n ? 'paused'\n : 'played';\n attributes.rr_mediaCurrentTime = n.currentTime;\n }\n if (n.scrollLeft) {\n attributes.rr_scrollLeft = n.scrollLeft;\n }\n if (n.scrollTop) {\n attributes.rr_scrollTop = n.scrollTop;\n }\n if (needBlock) {\n const { width, height } = n.getBoundingClientRect();\n attributes = {\n class: attributes.class,\n rr_width: `${width}px`,\n rr_height: `${height}px`,\n };\n }\n if (tagName === 'iframe' && !keepIframeSrcFn(attributes.src)) {\n if (!n.contentDocument) {\n attributes.rr_src = attributes.src;\n }\n delete attributes.src;\n }\n return {\n type: NodeType.Element,\n tagName,\n attributes,\n childNodes: [],\n isSVG: isSVGElement(n) || undefined,\n needBlock,\n rootId,\n };\n case n.TEXT_NODE:\n const parentTagName = n.parentNode && n.parentNode.tagName;\n let textContent = n.textContent;\n const isStyle = parentTagName === 'STYLE' ? true : undefined;\n const isScript = parentTagName === 'SCRIPT' ? true : undefined;\n if (isStyle && textContent) {\n try {\n if (n.nextSibling || n.previousSibling) {\n }\n else if ((_a = n.parentNode.sheet) === null || _a === void 0 ? void 0 : _a.cssRules) {\n textContent = stringifyStyleSheet(n.parentNode.sheet);\n }\n }\n catch (err) {\n console.warn(`Cannot get CSS styles from text's parentNode. Error: ${err}`, n);\n }\n textContent = absoluteToStylesheet(textContent, getHref());\n }\n if (isScript) {\n textContent = 'SCRIPT_PLACEHOLDER';\n }\n if (parentTagName === 'TEXTAREA' && textContent) {\n textContent = '';\n }\n else if (parentTagName === 'OPTION' && textContent) {\n const option = n.parentNode;\n textContent = maskInputValue({\n input: option,\n type: null,\n tagName: parentTagName,\n value: textContent,\n maskInputSelector,\n unmaskInputSelector,\n maskInputOptions,\n maskInputFn,\n });\n }\n else if (!isStyle &&\n !isScript &&\n needMaskingText(n, maskTextClass, maskTextSelector, unmaskTextSelector, maskAllText) &&\n textContent) {\n textContent = maskTextFn\n ? maskTextFn(textContent)\n : defaultMaskFn(textContent);\n }\n return {\n type: NodeType.Text,\n textContent: textContent || '',\n isStyle,\n rootId,\n };\n case n.CDATA_SECTION_NODE:\n return {\n type: NodeType.CDATA,\n textContent: '',\n rootId,\n };\n case n.COMMENT_NODE:\n return {\n type: NodeType.Comment,\n textContent: n.textContent || '',\n rootId,\n };\n default:\n return false;\n }\n}\nfunction lowerIfExists(maybeAttr) {\n if (maybeAttr === undefined || maybeAttr === null) {\n return '';\n }\n else {\n return maybeAttr.toLowerCase();\n }\n}\nfunction slimDOMExcluded(sn, slimDOMOptions) {\n if (slimDOMOptions.comment && sn.type === NodeType.Comment) {\n return true;\n }\n else if (sn.type === NodeType.Element) {\n if (slimDOMOptions.script &&\n (sn.tagName === 'script' ||\n (sn.tagName === 'link' &&\n (sn.attributes.rel === 'preload' ||\n sn.attributes.rel === 'modulepreload') &&\n sn.attributes.as === 'script') ||\n (sn.tagName === 'link' &&\n sn.attributes.rel === 'prefetch' &&\n typeof sn.attributes.href === 'string' &&\n sn.attributes.href.endsWith('.js')))) {\n return true;\n }\n else if (slimDOMOptions.headFavicon &&\n ((sn.tagName === 'link' && sn.attributes.rel === 'shortcut icon') ||\n (sn.tagName === 'meta' &&\n (lowerIfExists(sn.attributes.name).match(/^msapplication-tile(image|color)$/) ||\n lowerIfExists(sn.attributes.name) === 'application-name' ||\n lowerIfExists(sn.attributes.rel) === 'icon' ||\n lowerIfExists(sn.attributes.rel) === 'apple-touch-icon' ||\n lowerIfExists(sn.attributes.rel) === 'shortcut icon')))) {\n return true;\n }\n else if (sn.tagName === 'meta') {\n if (slimDOMOptions.headMetaDescKeywords &&\n lowerIfExists(sn.attributes.name).match(/^description|keywords$/)) {\n return true;\n }\n else if (slimDOMOptions.headMetaSocial &&\n (lowerIfExists(sn.attributes.property).match(/^(og|twitter|fb):/) ||\n lowerIfExists(sn.attributes.name).match(/^(og|twitter):/) ||\n lowerIfExists(sn.attributes.name) === 'pinterest')) {\n return true;\n }\n else if (slimDOMOptions.headMetaRobots &&\n (lowerIfExists(sn.attributes.name) === 'robots' ||\n lowerIfExists(sn.attributes.name) === 'googlebot' ||\n lowerIfExists(sn.attributes.name) === 'bingbot')) {\n return true;\n }\n else if (slimDOMOptions.headMetaHttpEquiv &&\n sn.attributes['http-equiv'] !== undefined) {\n return true;\n }\n else if (slimDOMOptions.headMetaAuthorship &&\n (lowerIfExists(sn.attributes.name) === 'author' ||\n lowerIfExists(sn.attributes.name) === 'generator' ||\n lowerIfExists(sn.attributes.name) === 'framework' ||\n lowerIfExists(sn.attributes.name) === 'publisher' ||\n lowerIfExists(sn.attributes.name) === 'progid' ||\n lowerIfExists(sn.attributes.property).match(/^article:/) ||\n lowerIfExists(sn.attributes.property).match(/^product:/))) {\n return true;\n }\n else if (slimDOMOptions.headMetaVerification &&\n (lowerIfExists(sn.attributes.name) === 'google-site-verification' ||\n lowerIfExists(sn.attributes.name) === 'yandex-verification' ||\n lowerIfExists(sn.attributes.name) === 'csrf-token' ||\n lowerIfExists(sn.attributes.name) === 'p:domain_verify' ||\n lowerIfExists(sn.attributes.name) === 'verify-v1' ||\n lowerIfExists(sn.attributes.name) === 'verification' ||\n lowerIfExists(sn.attributes.name) === 'shopify-checkout-api-token')) {\n return true;\n }\n }\n }\n return false;\n}\nfunction serializeNodeWithId(n, options) {\n const { doc, map, blockClass, blockSelector, unblockSelector, maskTextClass, maskTextSelector, unmaskTextSelector, skipChild = false, inlineStylesheet = true, maskInputSelector, unmaskInputSelector, maskAllText, maskInputOptions = {}, maskTextFn, maskInputFn, slimDOMOptions, dataURLOptions = {}, inlineImages = false, recordCanvas = false, onSerialize, onIframeLoad, iframeLoadTimeout = 5000, keepIframeSrcFn = () => false, } = options;\n let { preserveWhiteSpace = true } = options;\n const _serializedNode = serializeNode(n, {\n doc,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n inlineStylesheet,\n maskInputSelector,\n unmaskInputSelector,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n keepIframeSrcFn,\n });\n if (!_serializedNode) {\n console.warn(n, 'not serialized');\n return null;\n }\n let id;\n if ('__sn' in n) {\n id = n.__sn.id;\n }\n else if (slimDOMExcluded(_serializedNode, slimDOMOptions) ||\n (!preserveWhiteSpace &&\n _serializedNode.type === NodeType.Text &&\n !_serializedNode.isStyle &&\n !_serializedNode.textContent.replace(/^\\s+|\\s+$/gm, '').length)) {\n id = IGNORED_NODE;\n }\n else {\n id = genId();\n }\n const serializedNode = Object.assign(_serializedNode, { id });\n n.__sn = serializedNode;\n if (id === IGNORED_NODE) {\n return null;\n }\n map[id] = n;\n if (onSerialize) {\n onSerialize(n);\n }\n let recordChild = !skipChild;\n if (serializedNode.type === NodeType.Element) {\n recordChild = recordChild && !serializedNode.needBlock;\n delete serializedNode.needBlock;\n if (n.shadowRoot)\n serializedNode.isShadowHost = true;\n }\n if ((serializedNode.type === NodeType.Document ||\n serializedNode.type === NodeType.Element) &&\n recordChild) {\n if (slimDOMOptions.headWhitespace &&\n _serializedNode.type === NodeType.Element &&\n _serializedNode.tagName === 'head') {\n preserveWhiteSpace = false;\n }\n const bypassOptions = {\n doc,\n map,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n skipChild,\n inlineStylesheet,\n maskInputSelector,\n unmaskInputSelector,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n keepIframeSrcFn,\n };\n for (const childN of Array.from(n.childNodes)) {\n const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\n if (serializedChildNode) {\n serializedNode.childNodes.push(serializedChildNode);\n }\n }\n if (isElement(n) && n.shadowRoot) {\n for (const childN of Array.from(n.shadowRoot.childNodes)) {\n const serializedChildNode = serializeNodeWithId(childN, bypassOptions);\n if (serializedChildNode) {\n serializedChildNode.isShadow = true;\n serializedNode.childNodes.push(serializedChildNode);\n }\n }\n }\n }\n if (n.parentNode && isShadowRoot(n.parentNode)) {\n serializedNode.isShadow = true;\n }\n if (serializedNode.type === NodeType.Element &&\n serializedNode.tagName === 'iframe') {\n onceIframeLoaded(n, () => {\n const iframeDoc = n.contentDocument;\n if (iframeDoc && onIframeLoad) {\n const serializedIframeNode = serializeNodeWithId(iframeDoc, {\n doc: iframeDoc,\n map,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n skipChild: false,\n inlineStylesheet,\n maskInputSelector,\n unmaskInputSelector,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n keepIframeSrcFn,\n });\n if (serializedIframeNode) {\n onIframeLoad(n, serializedIframeNode);\n }\n }\n }, iframeLoadTimeout);\n }\n return serializedNode;\n}\nfunction snapshot(n, options) {\n const { blockClass = 'rr-block', blockSelector = null, unblockSelector = null, maskTextClass = 'rr-mask', maskTextSelector = null, unmaskTextSelector = null, inlineStylesheet = true, inlineImages = false, recordCanvas = false, maskInputSelector = null, unmaskInputSelector = null, maskAllText = false, maskAllInputs = false, maskTextFn, maskInputFn, slimDOM = false, dataURLOptions, preserveWhiteSpace, onSerialize, onIframeLoad, iframeLoadTimeout, keepIframeSrcFn = () => false, } = options || {};\n const idNodeMap = {};\n const maskInputOptions = maskAllInputs === true\n ? {\n color: true,\n date: true,\n 'datetime-local': true,\n email: true,\n month: true,\n number: true,\n range: true,\n search: true,\n tel: true,\n text: true,\n time: true,\n url: true,\n week: true,\n textarea: true,\n select: true,\n }\n : maskAllInputs === false\n ? {}\n : maskAllInputs;\n const slimDOMOptions = slimDOM === true || slimDOM === 'all'\n ?\n {\n script: true,\n comment: true,\n headFavicon: true,\n headWhitespace: true,\n headMetaDescKeywords: slimDOM === 'all',\n headMetaSocial: true,\n headMetaRobots: true,\n headMetaHttpEquiv: true,\n headMetaAuthorship: true,\n headMetaVerification: true,\n }\n : slimDOM === false\n ? {}\n : slimDOM;\n return [\n serializeNodeWithId(n, {\n doc: n,\n map: idNodeMap,\n blockClass,\n blockSelector,\n unblockSelector,\n maskTextClass,\n maskTextSelector,\n unmaskTextSelector,\n skipChild: false,\n inlineStylesheet,\n maskInputSelector,\n unmaskInputSelector,\n maskAllText,\n maskInputOptions,\n maskTextFn,\n maskInputFn,\n slimDOMOptions,\n dataURLOptions,\n inlineImages,\n recordCanvas,\n preserveWhiteSpace,\n onSerialize,\n onIframeLoad,\n iframeLoadTimeout,\n keepIframeSrcFn,\n }),\n idNodeMap,\n ];\n}\nfunction visitSnapshot(node, onVisit) {\n function walk(current) {\n onVisit(current);\n if (current.type === NodeType.Document ||\n current.type === NodeType.Element) {\n current.childNodes.forEach(walk);\n }\n }\n walk(node);\n}\nfunction cleanupSnapshot() {\n _id = 1;\n}\nfunction skipAttribute(tagName, attributeName, value) {\n return ((tagName === 'video' || tagName === 'audio') && attributeName === 'autoplay');\n}\n\nconst commentre = /\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\//g;\nfunction parse(css, options = {}) {\n let lineno = 1;\n let column = 1;\n function updatePosition(str) {\n const lines = str.match(/\\n/g);\n if (lines) {\n lineno += lines.length;\n }\n let i = str.lastIndexOf('\\n');\n column = i === -1 ? column + str.length : str.length - i;\n }\n function position() {\n const start = { line: lineno, column };\n return (node) => {\n node.position = new Position(start);\n whitespace();\n return node;\n };\n }\n class Position {\n constructor(start) {\n this.start = start;\n this.end = { line: lineno, column };\n this.source = options.source;\n }\n }\n Position.prototype.content = css;\n const errorsList = [];\n function error(msg) {\n const err = new Error(options.source + ':' + lineno + ':' + column + ': ' + msg);\n err.reason = msg;\n err.filename = options.source;\n err.line = lineno;\n err.column = column;\n err.source = css;\n if (options.silent) {\n errorsList.push(err);\n }\n else {\n throw err;\n }\n }\n function stylesheet() {\n const rulesList = rules();\n return {\n type: 'stylesheet',\n stylesheet: {\n source: options.source,\n rules: rulesList,\n parsingErrors: errorsList,\n },\n };\n }\n function open() {\n return match(/^{\\s*/);\n }\n function close() {\n return match(/^}/);\n }\n function rules() {\n let node;\n const rules = [];\n whitespace();\n comments(rules);\n while (css.length && css.charAt(0) !== '}' && (node = atrule() || rule())) {\n if (node !== false) {\n rules.push(node);\n comments(rules);\n }\n }\n return rules;\n }\n function match(re) {\n const m = re.exec(css);\n if (!m) {\n return;\n }\n const str = m[0];\n updatePosition(str);\n css = css.slice(str.length);\n return m;\n }\n function whitespace() {\n match(/^\\s*/);\n }\n function comments(rules = []) {\n let c;\n while ((c = comment())) {\n if (c !== false) {\n rules.push(c);\n }\n c = comment();\n }\n return rules;\n }\n function comment() {\n const pos = position();\n if ('/' !== css.charAt(0) || '*' !== css.charAt(1)) {\n return;\n }\n let i = 2;\n while ('' !== css.charAt(i) &&\n ('*' !== css.charAt(i) || '/' !== css.charAt(i + 1))) {\n ++i;\n }\n i += 2;\n if ('' === css.charAt(i - 1)) {\n return error('End of comment missing');\n }\n const str = css.slice(2, i - 2);\n column += 2;\n updatePosition(str);\n css = css.slice(i);\n column += 2;\n return pos({\n type: 'comment',\n comment: str,\n });\n }\n function selector() {\n const m = match(/^([^{]+)/);\n if (!m) {\n return;\n }\n return trim(m[0])\n .replace(/\\/\\*([^*]|[\\r\\n]|(\\*+([^*/]|[\\r\\n])))*\\*\\/+/g, '')\n .replace(/\"(?:\\\\\"|[^\"])*\"|'(?:\\\\'|[^'])*'/g, (m) => {\n return m.replace(/,/g, '\\u200C');\n })\n .split(/\\s*(?![^(]*\\)),\\s*/)\n .map((s) => {\n return s.replace(/\\u200C/g, ',');\n });\n }\n function declaration() {\n const pos = position();\n let propMatch = match(/^(\\*?[-#\\/\\*\\\\\\w]+(\\[[0-9a-z_-]+\\])?)\\s*/);\n if (!propMatch) {\n return;\n }\n const prop = trim(propMatch[0]);\n if (!match(/^:\\s*/)) {\n return error(`property missing ':'`);\n }\n const val = match(/^((?:'(?:\\\\'|.)*?'|\"(?:\\\\\"|.)*?\"|\\([^\\)]*?\\)|[^};])+)/);\n const ret = pos({\n type: 'declaration',\n property: prop.replace(commentre, ''),\n value: val ? trim(val[0]).replace(commentre, '') : '',\n });\n match(/^[;\\s]*/);\n return ret;\n }\n function declarations() {\n const decls = [];\n if (!open()) {\n return error(`missing '{'`);\n }\n comments(decls);\n let decl;\n while ((decl = declaration())) {\n if (decl !== false) {\n decls.push(decl);\n comments(decls);\n }\n decl = declaration();\n }\n if (!close()) {\n return error(`missing '}'`);\n }\n return decls;\n }\n function keyframe() {\n let m;\n const vals = [];\n const pos = position();\n while ((m = match(/^((\\d+\\.\\d+|\\.\\d+|\\d+)%?|[a-z]+)\\s*/))) {\n vals.push(m[1]);\n match(/^,\\s*/);\n }\n if (!vals.length) {\n return;\n }\n return pos({\n type: 'keyframe',\n values: vals,\n declarations: declarations(),\n });\n }\n function atkeyframes() {\n const pos = position();\n let m = match(/^@([-\\w]+)?keyframes\\s*/);\n if (!m) {\n return;\n }\n const vendor = m[1];\n m = match(/^([-\\w]+)\\s*/);\n if (!m) {\n return error('@keyframes missing name');\n }\n const name = m[1];\n if (!open()) {\n return error(`@keyframes missing '{'`);\n }\n let frame;\n let frames = comments();\n while ((frame = keyframe())) {\n frames.push(frame);\n frames = frames.concat(comments());\n }\n if (!close()) {\n return error(`@keyframes missing '}'`);\n }\n return pos({\n type: 'keyframes',\n name,\n vendor,\n keyframes: frames,\n });\n }\n function atsupports() {\n const pos = position();\n const m = match(/^@supports *([^{]+)/);\n if (!m) {\n return;\n }\n const supports = trim(m[1]);\n if (!open()) {\n return error(`@supports missing '{'`);\n }\n const style = comments().concat(rules());\n if (!close()) {\n return error(`@supports missing '}'`);\n }\n return pos({\n type: 'supports',\n supports,\n rules: style,\n });\n }\n function athost() {\n const pos = position();\n const m = match(/^@host\\s*/);\n if (!m) {\n return;\n }\n if (!open()) {\n return error(`@host missing '{'`);\n }\n const style = comments().concat(rules());\n if (!close()) {\n return error(`@host missing '}'`);\n }\n return pos({\n type: 'host',\n rules: style,\n });\n }\n function atmedia() {\n const pos = position();\n const m = match(/^@media *([^{]+)/);\n if (!m) {\n return;\n }\n const media = trim(m[1]);\n if (!open()) {\n return error(`@media missing '{'`);\n }\n const style = comments().concat(rules());\n if (!close()) {\n return error(`@media missing '}'`);\n }\n return pos({\n type: 'media',\n media,\n rules: style,\n });\n }\n function atcustommedia() {\n const pos = position();\n const m = match(/^@custom-media\\s+(--[^\\s]+)\\s*([^{;]+);/);\n if (!m) {\n return;\n }\n return pos({\n type: 'custom-media',\n name: trim(m[1]),\n media: trim(m[2]),\n });\n }\n function atpage() {\n const pos = position();\n const m = match(/^@page */);\n if (!m) {\n return;\n }\n const sel = selector() || [];\n if (!open()) {\n return error(`@page missing '{'`);\n }\n let decls = comments();\n let decl;\n while ((decl = declaration())) {\n decls.push(decl);\n decls = decls.concat(comments());\n }\n if (!close()) {\n return error(`@page missing '}'`);\n }\n return pos({\n type: 'page',\n selectors: sel,\n declarations: decls,\n });\n }\n function atdocument() {\n const pos = position();\n const m = match(/^@([-\\w]+)?document *([^{]+)/);\n if (!m) {\n return;\n }\n const vendor = trim(m[1]);\n const doc = trim(m[2]);\n if (!open()) {\n return error(`@document missing '{'`);\n }\n const style = comments().concat(rules());\n if (!close()) {\n return error(`@document missing '}'`);\n }\n return pos({\n type: 'document',\n document: doc,\n vendor,\n rules: style,\n });\n }\n function atfontface() {\n const pos = position();\n const m = match(/^@font-face\\s*/);\n if (!m) {\n return;\n }\n if (!open()) {\n return error(`@font-face missing '{'`);\n }\n let decls = comments();\n let decl;\n while ((decl = declaration())) {\n decls.push(decl);\n decls = decls.concat(comments());\n }\n if (!close()) {\n return error(`@font-face missing '}'`);\n }\n return pos({\n type: 'font-face',\n declarations: decls,\n });\n }\n const atimport = _compileAtrule('import');\n const atcharset = _compileAtrule('charset');\n const atnamespace = _compileAtrule('namespace');\n function _compileAtrule(name) {\n const re = new RegExp('^@' + name + '\\\\s*([^;]+);');\n return () => {\n const pos = position();\n const m = match(re);\n if (!m) {\n return;\n }\n const ret = { type: name };\n ret[name] = m[1].trim();\n return pos(ret);\n };\n }\n function atrule() {\n if (css[0] !== '@') {\n return;\n }\n return (atkeyframes() ||\n atmedia() ||\n atcustommedia() ||\n atsupports() ||\n atimport() ||\n atcharset() ||\n atnamespace() ||\n atdocument() ||\n atpage() ||\n athost() ||\n atfontface());\n }\n function rule() {\n const pos = position();\n const sel = selector();\n if (!sel) {\n return error('selector missing');\n }\n comments();\n return pos({\n type: 'rule',\n selectors: sel,\n declarations: declarations(),\n });\n }\n return addParent(stylesheet());\n}\nfunction trim(str) {\n return str ? str.replace(/^\\s+|\\s+$/g, '') : '';\n}\nfunction addParent(obj, parent) {\n const isNode = obj && typeof obj.type === 'string';\n const childParent = isNode ? obj : parent;\n for (const k of Object.keys(obj)) {\n const value = obj[k];\n if (Array.isArray(value)) {\n value.forEach((v) => {\n addParent(v, childParent);\n });\n }\n else if (value && typeof value === 'object') {\n addParent(value, childParent);\n }\n }\n if (isNode) {\n Object.defineProperty(obj, 'parent', {\n configurable: true,\n writable: true,\n enumerable: false,\n value: parent || null,\n });\n }\n return obj;\n}\n\nconst tagMap = {\n script: 'noscript',\n altglyph: 'altGlyph',\n altglyphdef: 'altGlyphDef',\n altglyphitem: 'altGlyphItem',\n animatecolor: 'animateColor',\n animatemotion: 'animateMotion',\n animatetransform: 'animateTransform',\n clippath: 'clipPath',\n feblend: 'feBlend',\n fecolormatrix: 'feColorMatrix',\n fecomponenttransfer: 'feComponentTransfer',\n fecomposite: 'feComposite',\n feconvolvematrix: 'feConvolveMatrix',\n fediffuselighting: 'feDiffuseLighting',\n fedisplacementmap: 'feDisplacementMap',\n fedistantlight: 'feDistantLight',\n fedropshadow: 'feDropShadow',\n feflood: 'feFlood',\n fefunca: 'feFuncA',\n fefuncb: 'feFuncB',\n fefuncg: 'feFuncG',\n fefuncr: 'feFuncR',\n fegaussianblur: 'feGaussianBlur',\n feimage: 'feImage',\n femerge: 'feMerge',\n femergenode: 'feMergeNode',\n femorphology: 'feMorphology',\n feoffset: 'feOffset',\n fepointlight: 'fePointLight',\n fespecularlighting: 'feSpecularLighting',\n fespotlight: 'feSpotLight',\n fetile: 'feTile',\n feturbulence: 'feTurbulence',\n foreignobject: 'foreignObject',\n glyphref: 'glyphRef',\n lineargradient: 'linearGradient',\n radialgradient: 'radialGradient',\n};\nfunction getTagName(n) {\n let tagName = tagMap[n.tagName] ? tagMap[n.tagName] : n.tagName;\n if (tagName === 'link' && n.attributes._cssText) {\n tagName = 'style';\n }\n return tagName;\n}\nfunction escapeRegExp(str) {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\nconst HOVER_SELECTOR = /([^\\\\]):hover/;\nconst HOVER_SELECTOR_GLOBAL = new RegExp(HOVER_SELECTOR.source, 'g');\nfunction addHoverClass(cssText, cache) {\n const cachedStyle = cache === null || cache === void 0 ? void 0 : cache.stylesWithHoverClass.get(cssText);\n if (cachedStyle)\n return cachedStyle;\n const ast = parse(cssText, {\n silent: true,\n });\n if (!ast.stylesheet) {\n return cssText;\n }\n const selectors = [];\n ast.stylesheet.rules.forEach((rule) => {\n if ('selectors' in rule) {\n (rule.selectors || []).forEach((selector) => {\n if (HOVER_SELECTOR.test(selector)) {\n selectors.push(selector);\n }\n });\n }\n });\n if (selectors.length === 0) {\n return cssText;\n }\n const selectorMatcher = new RegExp(selectors\n .filter((selector, index) => selectors.indexOf(selector) === index)\n .sort((a, b) => b.length - a.length)\n .map((selector) => {\n return escapeRegExp(selector);\n })\n .join('|'), 'g');\n const result = cssText.replace(selectorMatcher, (selector) => {\n const newSelector = selector.replace(HOVER_SELECTOR_GLOBAL, '$1.\\\\:hover');\n return `${selector}, ${newSelector}`;\n });\n cache === null || cache === void 0 ? void 0 : cache.stylesWithHoverClass.set(cssText, result);\n return result;\n}\nfunction createCache() {\n const stylesWithHoverClass = new Map();\n return {\n stylesWithHoverClass,\n };\n}\nfunction buildNode(n, options) {\n const { doc, hackCss, cache } = options;\n switch (n.type) {\n case NodeType.Document:\n return doc.implementation.createDocument(null, '', null);\n case NodeType.DocumentType:\n return doc.implementation.createDocumentType(n.name || 'html', n.publicId, n.systemId);\n case NodeType.Element:\n const tagName = getTagName(n);\n let node;\n if (n.isSVG) {\n node = doc.createElementNS('http://www.w3.org/2000/svg', tagName);\n }\n else {\n node = doc.createElement(tagName);\n }\n for (const name in n.attributes) {\n if (!n.attributes.hasOwnProperty(name)) {\n continue;\n }\n let value = n.attributes[name];\n if (tagName === 'option' && name === 'selected' && value === false) {\n continue;\n }\n value =\n typeof value === 'boolean' || typeof value === 'number' || value === null ? '' : value;\n if (!name.startsWith('rr_')) {\n const isTextarea = tagName === 'textarea' && name === 'value';\n const isRemoteOrDynamicCss = tagName === 'style' && name === '_cssText';\n if (isRemoteOrDynamicCss && hackCss) {\n value = addHoverClass(value, cache);\n }\n if (isTextarea || isRemoteOrDynamicCss) {\n const child = doc.createTextNode(value);\n for (const c of Array.from(node.childNodes)) {\n if (c.nodeType === node.TEXT_NODE) {\n node.removeChild(c);\n }\n }\n node.appendChild(child);\n continue;\n }\n try {\n if (n.isSVG && name === 'xlink:href') {\n node.setAttributeNS('http://www.w3.org/1999/xlink', name, value);\n }\n else if (name === 'onload' ||\n name === 'onclick' ||\n name.substring(0, 7) === 'onmouse') {\n node.setAttribute('_' + name, value);\n }\n else if (tagName === 'meta' &&\n n.attributes['http-equiv'] === 'Content-Security-Policy' &&\n name === 'content') {\n node.setAttribute('csp-content', value);\n continue;\n }\n else if (tagName === 'link' &&\n (n.attributes.rel === 'preload' || n.attributes.rel === 'modulepreload') &&\n n.attributes.as === 'script') {\n }\n else if (tagName === 'link' &&\n n.attributes.rel === 'prefetch' &&\n typeof n.attributes.href === 'string' &&\n n.attributes.href.endsWith('.js')) {\n }\n else if (tagName === 'img' &&\n n.attributes.srcset &&\n n.attributes.rr_dataURL) {\n node.setAttribute('rrweb-original-srcset', n.attributes.srcset);\n }\n else {\n node.setAttribute(name, value);\n }\n }\n catch (error) {\n }\n }\n else {\n if (tagName === 'canvas' && name === 'rr_dataURL') {\n const image = document.createElement('img');\n image.src = value;\n image.onload = () => {\n const ctx = node.getContext('2d');\n if (ctx) {\n ctx.drawImage(image, 0, 0, image.width, image.height);\n }\n };\n }\n else if (tagName === 'img' && name === 'rr_dataURL') {\n const image = node;\n if (!image.currentSrc.startsWith('data:')) {\n image.setAttribute('rrweb-original-src', n.attributes.src);\n image.src = value;\n }\n }\n if (name === 'rr_width') {\n node.style.width = value;\n }\n else if (name === 'rr_height') {\n node.style.height = value;\n }\n else if (name === 'rr_mediaCurrentTime') {\n node.currentTime = n.attributes\n .rr_mediaCurrentTime;\n }\n else if (name === 'rr_mediaState') {\n switch (value) {\n case 'played':\n node\n .play()\n .catch((e) => console.warn('media playback error', e));\n break;\n case 'paused':\n node.pause();\n break;\n }\n }\n }\n }\n if (n.isShadowHost) {\n if (!node.shadowRoot) {\n node.attachShadow({ mode: 'open' });\n if (doc.defaultView) {\n defineCustomElement(doc.defaultView, tagName);\n }\n }\n else {\n while (node.shadowRoot.firstChild) {\n node.shadowRoot.removeChild(node.shadowRoot.firstChild);\n }\n }\n }\n return node;\n case NodeType.Text:\n return doc.createTextNode(n.isStyle && hackCss\n ? addHoverClass(n.textContent, cache)\n : n.textContent);\n case NodeType.CDATA:\n return doc.createCDATASection(n.textContent);\n case NodeType.Comment:\n return doc.createComment(n.textContent);\n default:\n return null;\n }\n}\nfunction buildNodeWithSN(n, options) {\n const { doc, map, skipChild = false, hackCss = true, afterAppend, cache, } = options;\n let node = buildNode(n, { doc, hackCss, cache });\n if (!node) {\n return null;\n }\n if (n.rootId) {\n console.assert(map[n.rootId] === doc, 'Target document should has the same root id.');\n }\n if (n.type === NodeType.Document) {\n doc.close();\n doc.open();\n if (n.compatMode === 'BackCompat' &&\n n.childNodes &&\n n.childNodes[0].type !== NodeType.DocumentType) {\n if (n.childNodes[0].type === NodeType.Element &&\n 'xmlns' in n.childNodes[0].attributes &&\n n.childNodes[0].attributes.xmlns === 'http://www.w3.org/1999/xhtml') {\n doc.write('<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"\">');\n }\n else {\n doc.write('<!DOCTYPE html PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"\">');\n }\n }\n node = doc;\n }\n node.__sn = n;\n map[n.id] = node;\n if ((n.type === NodeType.Document || n.type === NodeType.Element) &&\n !skipChild) {\n for (const childN of n.childNodes) {\n const childNode = buildNodeWithSN(childN, {\n doc,\n map,\n skipChild: false,\n hackCss,\n afterAppend,\n cache,\n });\n if (!childNode) {\n console.warn('Failed to rebuild', childN);\n continue;\n }\n if (childN.isShadow && isElement(node) && node.shadowRoot) {\n node.shadowRoot.appendChild(childNode);\n }\n else {\n node.appendChild(childNode);\n }\n if (afterAppend) {\n afterAppend(childNode);\n }\n }\n }\n return node;\n}\nfunction visit(idNodeMap, onVisit) {\n function walk(node) {\n onVisit(node);\n }\n for (const key in idNodeMap) {\n if (idNodeMap[key]) {\n walk(idNodeMap[key]);\n }\n }\n}\nfunction handleScroll(node) {\n const n = node.__sn;\n if (n.type !== NodeType.Element) {\n return;\n }\n const el = node;\n for (const name in n.attributes) {\n if (!(n.attributes.hasOwnProperty(name) && name.startsWith('rr_'))) {\n continue;\n }\n const value = n.attributes[name];\n if (name === 'rr_scrollLeft') {\n el.scrollLeft = value;\n }\n if (name === 'rr_scrollTop') {\n el.scrollTop = value;\n }\n }\n}\nfunction rebuild(n, options) {\n const { doc, onVisit, hackCss = true, afterAppend, cache } = options;\n const idNodeMap = {};\n const node = buildNodeWithSN(n, {\n doc,\n map: idNodeMap,\n skipChild: false,\n hackCss,\n afterAppend,\n cache,\n });\n visit(idNodeMap, (visitedNode) => {\n if (onVisit) {\n onVisit(visitedNode);\n }\n handleScroll(visitedNode);\n });\n return [node, idNodeMap];\n}\n\nexport { IGNORED_NODE, NodeType, addHoverClass, buildNodeWithSN, cleanupSnapshot, createCache, defineCustomElement, getInputType, getInputValue, hasInputMaskOptions, is2DCanvasBlank, isElement, isShadowRoot, maskInputValue, needMaskingText, rebuild, serializeNodeWithId, snapshot, transformAttribute, visitSnapshot };\n","import type { Breadcrumb } from '@sentry/types';\n\nimport { WINDOW } from '../constants';\nimport type { MultiClickFrame, ReplayClickDetector, ReplayContainer, SlowClickConfig, SlowClickFrame } from '../types';\nimport { timestampToS } from '../util/timestamp';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\nimport { getClickTargetNode } from './util/domUtils';\nimport { onWindowOpen } from './util/onWindowOpen';\n\ntype ClickBreadcrumb = Breadcrumb & {\n timestamp: number;\n};\n\ninterface Click {\n timestamp: number;\n mutationAfter?: number;\n scrollAfter?: number;\n clickBreadcrumb: ClickBreadcrumb;\n clickCount: number;\n node: HTMLElement;\n}\n\n/** Handle a click. */\nexport function handleClick(clickDetector: ReplayClickDetector, clickBreadcrumb: Breadcrumb, node: HTMLElement): void {\n clickDetector.handleClick(clickBreadcrumb, node);\n}\n\n/** A click detector class that can be used to detect slow or rage clicks on elements. */\nexport class ClickDetector implements ReplayClickDetector {\n // protected for testing\n protected _lastMutation: number;\n protected _lastScroll: number;\n\n private _clicks: Click[];\n private _teardown: undefined | (() => void);\n\n private _threshold: number;\n private _scollTimeout: number;\n private _timeout: number;\n private _ignoreSelector: string;\n\n private _replay: ReplayContainer;\n private _checkClickTimeout?: ReturnType<typeof setTimeout>;\n private _addBreadcrumbEvent: typeof addBreadcrumbEvent;\n\n public constructor(\n replay: ReplayContainer,\n slowClickConfig: SlowClickConfig,\n // Just for easier testing\n _addBreadcrumbEvent = addBreadcrumbEvent,\n ) {\n this._lastMutation = 0;\n this._lastScroll = 0;\n this._clicks = [];\n\n // We want everything in s, but options are in ms\n this._timeout = slowClickConfig.timeout / 1000;\n this._threshold = slowClickConfig.threshold / 1000;\n this._scollTimeout = slowClickConfig.scrollTimeout / 1000;\n this._replay = replay;\n this._ignoreSelector = slowClickConfig.ignoreSelector;\n this._addBreadcrumbEvent = _addBreadcrumbEvent;\n }\n\n /** Register click detection handlers on mutation or scroll. */\n public addListeners(): void {\n const mutationHandler = (): void => {\n this._lastMutation = nowInSeconds();\n };\n\n const scrollHandler = (): void => {\n this._lastScroll = nowInSeconds();\n };\n\n const cleanupWindowOpen = onWindowOpen(() => {\n // Treat window.open as mutation\n this._lastMutation = nowInSeconds();\n });\n\n const clickHandler = (event: MouseEvent): void => {\n if (!event.target) {\n return;\n }\n\n const node = getClickTargetNode(event);\n if (node) {\n this._handleMultiClick(node as HTMLElement);\n }\n };\n\n const obs = new MutationObserver(mutationHandler);\n\n obs.observe(WINDOW.document.documentElement, {\n attributes: true,\n characterData: true,\n childList: true,\n subtree: true,\n });\n\n WINDOW.addEventListener('scroll', scrollHandler, { passive: true });\n WINDOW.addEventListener('click', clickHandler, { passive: true });\n\n this._teardown = () => {\n WINDOW.removeEventListener('scroll', scrollHandler);\n WINDOW.removeEventListener('click', clickHandler);\n cleanupWindowOpen();\n\n obs.disconnect();\n this._clicks = [];\n this._lastMutation = 0;\n this._lastScroll = 0;\n };\n }\n\n /** Clean up listeners. */\n public removeListeners(): void {\n if (this._teardown) {\n this._teardown();\n }\n\n if (this._checkClickTimeout) {\n clearTimeout(this._checkClickTimeout);\n }\n }\n\n /** Handle a click */\n public handleClick(breadcrumb: Breadcrumb, node: HTMLElement): void {\n if (ignoreElement(node, this._ignoreSelector) || !isClickBreadcrumb(breadcrumb)) {\n return;\n }\n\n const newClick: Click = {\n timestamp: timestampToS(breadcrumb.timestamp),\n clickBreadcrumb: breadcrumb,\n // Set this to 0 so we know it originates from the click breadcrumb\n clickCount: 0,\n node,\n };\n\n // If there was a click in the last 1s on the same element, ignore it - only keep a single reference per second\n if (\n this._clicks.some(click => click.node === newClick.node && Math.abs(click.timestamp - newClick.timestamp) < 1)\n ) {\n return;\n }\n\n this._clicks.push(newClick);\n\n // If this is the first new click, set a timeout to check for multi clicks\n if (this._clicks.length === 1) {\n this._scheduleCheckClicks();\n }\n }\n\n /** Count multiple clicks on elements. */\n private _handleMultiClick(node: HTMLElement): void {\n this._getClicks(node).forEach(click => {\n click.clickCount++;\n });\n }\n\n /** Get all pending clicks for a given node. */\n private _getClicks(node: HTMLElement): Click[] {\n return this._clicks.filter(click => click.node === node);\n }\n\n /** Check the clicks that happened. */\n private _checkClicks(): void {\n const timedOutClicks: Click[] = [];\n\n const now = nowInSeconds();\n\n this._clicks.forEach(click => {\n if (!click.mutationAfter && this._lastMutation) {\n click.mutationAfter = click.timestamp <= this._lastMutation ? this._lastMutation - click.timestamp : undefined;\n }\n if (!click.scrollAfter && this._lastScroll) {\n click.scrollAfter = click.timestamp <= this._lastScroll ? this._lastScroll - click.timestamp : undefined;\n }\n\n // All of these are in seconds!\n if (click.timestamp + this._timeout <= now) {\n timedOutClicks.push(click);\n }\n });\n\n // Remove \"old\" clicks\n for (const click of timedOutClicks) {\n const pos = this._clicks.indexOf(click);\n\n if (pos > -1) {\n this._generateBreadcrumbs(click);\n this._clicks.splice(pos, 1);\n }\n }\n\n // Trigger new check, unless no clicks left\n if (this._clicks.length) {\n this._scheduleCheckClicks();\n }\n }\n\n /** Generate matching breadcrumb(s) for the click. */\n private _generateBreadcrumbs(click: Click): void {\n const replay = this._replay;\n const hadScroll = click.scrollAfter && click.scrollAfter <= this._scollTimeout;\n const hadMutation = click.mutationAfter && click.mutationAfter <= this._threshold;\n\n const isSlowClick = !hadScroll && !hadMutation;\n const { clickCount, clickBreadcrumb } = click;\n\n // Slow click\n if (isSlowClick) {\n // If `mutationAfter` is set, it means a mutation happened after the threshold, but before the timeout\n // If not, it means we just timed out without scroll & mutation\n const timeAfterClickMs = Math.min(click.mutationAfter || this._timeout, this._timeout) * 1000;\n const endReason = timeAfterClickMs < this._timeout * 1000 ? 'mutation' : 'timeout';\n\n const breadcrumb: SlowClickFrame = {\n type: 'default',\n message: clickBreadcrumb.message,\n timestamp: clickBreadcrumb.timestamp,\n category: 'ui.slowClickDetected',\n data: {\n ...clickBreadcrumb.data,\n url: WINDOW.location.href,\n route: replay.getCurrentRoute(),\n timeAfterClickMs,\n endReason,\n // If clickCount === 0, it means multiClick was not correctly captured here\n // - we still want to send 1 in this case\n clickCount: clickCount || 1,\n },\n };\n\n this._addBreadcrumbEvent(replay, breadcrumb);\n return;\n }\n\n // Multi click\n if (clickCount > 1) {\n const breadcrumb: MultiClickFrame = {\n type: 'default',\n message: clickBreadcrumb.message,\n timestamp: clickBreadcrumb.timestamp,\n category: 'ui.multiClick',\n data: {\n ...clickBreadcrumb.data,\n url: WINDOW.location.href,\n route: replay.getCurrentRoute(),\n clickCount,\n metric: true,\n },\n };\n\n this._addBreadcrumbEvent(replay, breadcrumb);\n }\n }\n\n /** Schedule to check current clicks. */\n private _scheduleCheckClicks(): void {\n if (this._checkClickTimeout) {\n clearTimeout(this._checkClickTimeout);\n }\n\n this._checkClickTimeout = setTimeout(() => this._checkClicks(), 1000);\n }\n}\n\nconst SLOW_CLICK_TAGS = ['A', 'BUTTON', 'INPUT'];\n\n/** exported for tests only */\nexport function ignoreElement(node: HTMLElement, ignoreSelector: string): boolean {\n if (!SLOW_CLICK_TAGS.includes(node.tagName)) {\n return true;\n }\n\n // If <input> tag, we only want to consider input[type='submit'] & input[type='button']\n if (node.tagName === 'INPUT' && !['submit', 'button'].includes(node.getAttribute('type') || '')) {\n return true;\n }\n\n // If <a> tag, detect special variants that may not lead to an action\n // If target !== _self, we may open the link somewhere else, which would lead to no action\n // Also, when downloading a file, we may not leave the page, but still not trigger an action\n if (\n node.tagName === 'A' &&\n (node.hasAttribute('download') || (node.hasAttribute('target') && node.getAttribute('target') !== '_self'))\n ) {\n return true;\n }\n\n if (ignoreSelector && node.matches(ignoreSelector)) {\n return true;\n }\n\n return false;\n}\n\nfunction isClickBreadcrumb(breadcrumb: Breadcrumb): breadcrumb is ClickBreadcrumb {\n return !!(breadcrumb.data && typeof breadcrumb.data.nodeId === 'number' && breadcrumb.timestamp);\n}\n\n// This is good enough for us, and is easier to test/mock than `timestampInSeconds`\nfunction nowInSeconds(): number {\n return Date.now() / 1000;\n}\n","import type { BreadcrumbFrame } from '../types/replayFrame';\n\n/**\n * Create a breadcrumb for a replay.\n */\nexport function createBreadcrumb(\n breadcrumb: Omit<BreadcrumbFrame, 'timestamp' | 'type'> & Partial<Pick<BreadcrumbFrame, 'timestamp'>>,\n): BreadcrumbFrame {\n return {\n timestamp: Date.now() / 1000,\n type: 'default',\n ...breadcrumb,\n };\n}\n","// Note that these are the serialized attributes and not attributes directly on\n// the DOM Node. Attributes we are interested in:\nconst ATTRIBUTES_TO_RECORD = new Set([\n 'id',\n 'class',\n 'aria-label',\n 'role',\n 'name',\n 'alt',\n 'title',\n 'data-test-id',\n 'data-testid',\n 'disabled',\n 'aria-disabled',\n]);\n\n/**\n * Inclusion list of attributes that we want to record from the DOM element\n */\nexport function getAttributesToRecord(attributes: Record<string, unknown>): Record<string, unknown> {\n const obj: Record<string, unknown> = {};\n for (const key in attributes) {\n if (ATTRIBUTES_TO_RECORD.has(key)) {\n let normalizedKey = key;\n\n if (key === 'data-testid' || key === 'data-test-id') {\n normalizedKey = 'testId';\n }\n\n obj[normalizedKey] = attributes[key];\n }\n }\n\n return obj;\n}\n","import type { INode } from '@sentry-internal/rrweb-snapshot';\nimport { NodeType } from '@sentry-internal/rrweb-snapshot';\nimport type { Breadcrumb } from '@sentry/types';\nimport { htmlTreeAsString } from '@sentry/utils';\n\nimport type { ReplayContainer } from '../types';\nimport { createBreadcrumb } from '../util/createBreadcrumb';\nimport { handleClick } from './handleClick';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\nimport type { DomHandlerData } from './util/domUtils';\nimport { getClickTargetNode, getTargetNode } from './util/domUtils';\nimport { getAttributesToRecord } from './util/getAttributesToRecord';\n\nexport const handleDomListener: (replay: ReplayContainer) => (handlerData: DomHandlerData) => void = (\n replay: ReplayContainer,\n) => {\n return (handlerData: DomHandlerData): void => {\n if (!replay.isEnabled()) {\n return;\n }\n\n const result = handleDom(handlerData);\n\n if (!result) {\n return;\n }\n\n const isClick = handlerData.name === 'click';\n const event = isClick && (handlerData.event as PointerEvent);\n // Ignore clicks if ctrl/alt/meta/shift keys are held down as they alter behavior of clicks (e.g. open in new tab)\n if (\n isClick &&\n replay.clickDetector &&\n event &&\n !event.altKey &&\n !event.metaKey &&\n !event.ctrlKey &&\n !event.shiftKey\n ) {\n handleClick(\n replay.clickDetector,\n result as Breadcrumb & { timestamp: number; data: { nodeId: number } },\n getClickTargetNode(handlerData.event) as HTMLElement,\n );\n }\n\n addBreadcrumbEvent(replay, result);\n };\n};\n\n/** Get the base DOM breadcrumb. */\nexport function getBaseDomBreadcrumb(target: Node | INode | null, message: string): Breadcrumb {\n // `__sn` property is the serialized node created by rrweb\n const serializedNode = target && isRrwebNode(target) && target.__sn.type === NodeType.Element ? target.__sn : null;\n\n return {\n message,\n data: serializedNode\n ? {\n nodeId: serializedNode.id,\n node: {\n id: serializedNode.id,\n tagName: serializedNode.tagName,\n textContent: target\n ? Array.from(target.childNodes)\n .map(\n (node: Node | INode) => '__sn' in node && node.__sn.type === NodeType.Text && node.__sn.textContent,\n )\n .filter(Boolean) // filter out empty values\n .map(text => (text as string).trim())\n .join('')\n : '',\n attributes: getAttributesToRecord(serializedNode.attributes),\n },\n }\n : {},\n };\n}\n\n/**\n * An event handler to react to DOM events.\n * Exported for tests.\n */\nexport function handleDom(handlerData: DomHandlerData): Breadcrumb | null {\n const { target, message } = getDomTarget(handlerData);\n\n return createBreadcrumb({\n category: `ui.${handlerData.name}`,\n ...getBaseDomBreadcrumb(target, message),\n });\n}\n\nfunction getDomTarget(handlerData: DomHandlerData): { target: Node | INode | null; message: string } {\n const isClick = handlerData.name === 'click';\n\n let message: string | undefined;\n let target: Node | INode | null = null;\n\n // Accessing event.target can throw (see getsentry/raven-js#838, #768)\n try {\n target = isClick ? getClickTargetNode(handlerData.event) : getTargetNode(handlerData.event);\n message = htmlTreeAsString(target, { maxStringLength: 200 }) || '<unknown>';\n } catch (e) {\n message = '<unknown>';\n }\n\n return { target, message };\n}\n\nfunction isRrwebNode(node: EventTarget): node is INode {\n return '__sn' in node;\n}\n","import type { Breadcrumb } from '@sentry/types';\nimport { htmlTreeAsString } from '@sentry/utils';\n\nimport type { ReplayContainer } from '../types';\nimport { createBreadcrumb } from '../util/createBreadcrumb';\nimport { getBaseDomBreadcrumb } from './handleDom';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\n\n/** Handle keyboard events & create breadcrumbs. */\nexport function handleKeyboardEvent(replay: ReplayContainer, event: KeyboardEvent): void {\n if (!replay.isEnabled()) {\n return;\n }\n\n // Update user activity, but do not restart recording as it can create\n // noisy/low-value replays (e.g. user comes back from idle, hits alt-tab, new\n // session with a single \"keydown\" breadcrumb is created)\n replay.updateUserActivity();\n\n const breadcrumb = getKeyboardBreadcrumb(event);\n\n if (!breadcrumb) {\n return;\n }\n\n addBreadcrumbEvent(replay, breadcrumb);\n}\n\n/** exported only for tests */\nexport function getKeyboardBreadcrumb(event: KeyboardEvent): Breadcrumb | null {\n const { metaKey, shiftKey, ctrlKey, altKey, key, target } = event;\n\n // never capture for input fields\n if (!target || isInputElement(target as HTMLElement) || !key) {\n return null;\n }\n\n // Note: We do not consider shift here, as that means \"uppercase\"\n const hasModifierKey = metaKey || ctrlKey || altKey;\n const isCharacterKey = key.length === 1; // other keys like Escape, Tab, etc have a longer length\n\n // Do not capture breadcrumb if only a word key is pressed\n // This could leak e.g. user input\n if (!hasModifierKey && isCharacterKey) {\n return null;\n }\n\n const message = htmlTreeAsString(target, { maxStringLength: 200 }) || '<unknown>';\n const baseBreadcrumb = getBaseDomBreadcrumb(target as Node, message);\n\n return createBreadcrumb({\n category: 'ui.keyDown',\n message,\n data: {\n ...baseBreadcrumb.data,\n metaKey,\n shiftKey,\n ctrlKey,\n altKey,\n key,\n },\n });\n}\n\nfunction isInputElement(target: HTMLElement): boolean {\n return target.tagName === 'INPUT' || target.tagName === 'TEXTAREA' || target.isContentEditable;\n}\n","const NAVIGATION_ENTRY_KEYS: Array<keyof PerformanceNavigationTiming> = [\n 'name',\n 'type',\n 'startTime',\n 'transferSize',\n 'duration',\n];\n\nfunction isNavigationEntryEqual(a: PerformanceNavigationTiming) {\n return function (b: PerformanceNavigationTiming) {\n return NAVIGATION_ENTRY_KEYS.every(key => a[key] === b[key]);\n };\n}\n\n/**\n * There are some difficulties diagnosing why there are duplicate navigation\n * entries. We've witnessed several intermittent results:\n * - duplicate entries have duration = 0\n * - duplicate entries are the same object reference\n * - none of the above\n *\n * Compare the values of several keys to determine if the entries are duplicates or not.\n */\n// TODO (high-prio): Figure out wth is returned here\n// eslint-disable-next-line @typescript-eslint/explicit-function-return-type\nexport function dedupePerformanceEntries(\n currentList: PerformanceEntryList,\n newList: PerformanceEntryList,\n): PerformanceEntryList {\n // Partition `currentList` into 3 different lists based on entryType\n const [existingNavigationEntries, existingLcpEntries, existingEntries] = currentList.reduce(\n (acc: [PerformanceNavigationTiming[], PerformancePaintTiming[], PerformanceEntryList], entry) => {\n if (entry.entryType === 'navigation') {\n acc[0].push(entry as PerformanceNavigationTiming);\n } else if (entry.entryType === 'largest-contentful-paint') {\n acc[1].push(entry as PerformancePaintTiming);\n } else {\n acc[2].push(entry);\n }\n return acc;\n },\n [[], [], []],\n );\n\n const newEntries: PerformanceEntryList = [];\n const newNavigationEntries: PerformanceNavigationTiming[] = [];\n let newLcpEntry: PerformancePaintTiming | undefined = existingLcpEntries.length\n ? existingLcpEntries[existingLcpEntries.length - 1] // Take the last element as list is sorted\n : undefined;\n\n newList.forEach(entry => {\n if (entry.entryType === 'largest-contentful-paint') {\n // We want the latest LCP event only\n if (!newLcpEntry || newLcpEntry.startTime < entry.startTime) {\n newLcpEntry = entry;\n }\n return;\n }\n\n if (entry.entryType === 'navigation') {\n const navigationEntry = entry as PerformanceNavigationTiming;\n\n // Check if the navigation entry is contained in currentList or newList\n if (\n // Ignore any navigation entries with duration 0, as they are likely duplicates\n entry.duration > 0 &&\n // Ensure new entry does not already exist in existing entries\n !existingNavigationEntries.find(isNavigationEntryEqual(navigationEntry)) &&\n // Ensure new entry does not already exist in new list of navigation entries\n !newNavigationEntries.find(isNavigationEntryEqual(navigationEntry))\n ) {\n newNavigationEntries.push(navigationEntry);\n }\n\n // Otherwise this navigation entry is considered a duplicate and is thrown away\n return;\n }\n\n newEntries.push(entry);\n });\n\n // Re-combine and sort by startTime\n return [\n ...(newLcpEntry ? [newLcpEntry] : []),\n ...existingNavigationEntries,\n ...existingEntries,\n ...newEntries,\n ...newNavigationEntries,\n ].sort((a, b) => a.startTime - b.startTime);\n}\n","import type { AllPerformanceEntry, ReplayContainer } from '../types';\nimport { dedupePerformanceEntries } from '../util/dedupePerformanceEntries';\n\n/**\n * Sets up a PerformanceObserver to listen to all performance entry types.\n */\nexport function setupPerformanceObserver(replay: ReplayContainer): PerformanceObserver {\n const performanceObserverHandler = (list: PerformanceObserverEntryList): void => {\n // For whatever reason the observer was returning duplicate navigation\n // entries (the other entry types were not duplicated).\n const newPerformanceEntries = dedupePerformanceEntries(\n replay.performanceEvents,\n list.getEntries() as AllPerformanceEntry[],\n );\n replay.performanceEvents = newPerformanceEntries;\n };\n\n const performanceObserver = new PerformanceObserver(performanceObserverHandler);\n\n [\n 'element',\n 'event',\n 'first-input',\n 'largest-contentful-paint',\n 'layout-shift',\n 'longtask',\n 'navigation',\n 'paint',\n 'resource',\n ].forEach(type => {\n try {\n performanceObserver.observe({\n type,\n buffered: true,\n });\n } catch {\n // This can throw if an entry type is not supported in the browser.\n // Ignore these errors.\n }\n });\n\n return performanceObserver;\n}\n","import { getCurrentHub } from '@sentry/core';\nimport { logger } from '@sentry/utils';\n\n/**\n * Log a message in debug mode, and add a breadcrumb when _experiment.traceInternals is enabled.\n */\nexport function logInfo(message: string, shouldAddBreadcrumb?: boolean): void {\n if (!__DEBUG_BUILD__) {\n return;\n }\n\n logger.info(message);\n\n if (shouldAddBreadcrumb) {\n addBreadcrumb(message);\n }\n}\n\n/**\n * Log a message, and add a breadcrumb in the next tick.\n * This is necessary when the breadcrumb may be added before the replay is initialized.\n */\nexport function logInfoNextTick(message: string, shouldAddBreadcrumb?: boolean): void {\n if (!__DEBUG_BUILD__) {\n return;\n }\n\n logger.info(message);\n\n if (shouldAddBreadcrumb) {\n // Wait a tick here to avoid race conditions for some initial logs\n // which may be added before replay is initialized\n setTimeout(() => {\n addBreadcrumb(message);\n }, 0);\n }\n}\n\nfunction addBreadcrumb(message: string): void {\n const hub = getCurrentHub();\n hub.addBreadcrumb(\n {\n category: 'console',\n data: {\n logger: 'replay',\n },\n level: 'info',\n message,\n },\n { level: 'info' },\n );\n}\n","import { REPLAY_MAX_EVENT_BUFFER_SIZE } from '../constants';\n\n/** This error indicates that the event buffer size exceeded the limit.. */\nexport class EventBufferSizeExceededError extends Error {\n public constructor() {\n super(`Event buffer exceeded maximum size of ${REPLAY_MAX_EVENT_BUFFER_SIZE}.`);\n }\n}\n","import { REPLAY_MAX_EVENT_BUFFER_SIZE } from '../constants';\nimport type { AddEventResult, EventBuffer, EventBufferType, RecordingEvent } from '../types';\nimport { timestampToMs } from '../util/timestamp';\nimport { EventBufferSizeExceededError } from './error';\n\n/**\n * A basic event buffer that does not do any compression.\n * Used as fallback if the compression worker cannot be loaded or is disabled.\n */\nexport class EventBufferArray implements EventBuffer {\n /** All the events that are buffered to be sent. */\n public events: RecordingEvent[];\n\n /** @inheritdoc */\n public hasCheckout: boolean;\n\n private _totalSize: number;\n\n public constructor() {\n this.events = [];\n this._totalSize = 0;\n this.hasCheckout = false;\n }\n\n /** @inheritdoc */\n public get hasEvents(): boolean {\n return this.events.length > 0;\n }\n\n /** @inheritdoc */\n public get type(): EventBufferType {\n return 'sync';\n }\n\n /** @inheritdoc */\n public destroy(): void {\n this.events = [];\n }\n\n /** @inheritdoc */\n public async addEvent(event: RecordingEvent): Promise<AddEventResult> {\n const eventSize = JSON.stringify(event).length;\n this._totalSize += eventSize;\n if (this._totalSize > REPLAY_MAX_EVENT_BUFFER_SIZE) {\n throw new EventBufferSizeExceededError();\n }\n\n this.events.push(event);\n }\n\n /** @inheritdoc */\n public finish(): Promise<string> {\n return new Promise<string>(resolve => {\n // Make a copy of the events array reference and immediately clear the\n // events member so that we do not lose new events while uploading\n // attachment.\n const eventsRet = this.events;\n this.clear();\n resolve(JSON.stringify(eventsRet));\n });\n }\n\n /** @inheritdoc */\n public clear(): void {\n this.events = [];\n this._totalSize = 0;\n this.hasCheckout = false;\n }\n\n /** @inheritdoc */\n public getEarliestTimestamp(): number | null {\n const timestamp = this.events.map(event => event.timestamp).sort()[0];\n\n if (!timestamp) {\n return null;\n }\n\n return timestampToMs(timestamp);\n }\n}\n","import { logger } from '@sentry/utils';\n\nimport type { WorkerRequest, WorkerResponse } from '../types';\nimport { logInfo } from '../util/log';\n\n/**\n * Event buffer that uses a web worker to compress events.\n * Exported only for testing.\n */\nexport class WorkerHandler {\n private _worker: Worker;\n private _id: number;\n private _ensureReadyPromise?: Promise<void>;\n\n public constructor(worker: Worker) {\n this._worker = worker;\n this._id = 0;\n }\n\n /**\n * Ensure the worker is ready (or not).\n * This will either resolve when the worker is ready, or reject if an error occured.\n */\n public ensureReady(): Promise<void> {\n // Ensure we only check once\n if (this._ensureReadyPromise) {\n return this._ensureReadyPromise;\n }\n\n this._ensureReadyPromise = new Promise((resolve, reject) => {\n this._worker.addEventListener(\n 'message',\n ({ data }: MessageEvent) => {\n if ((data as WorkerResponse).success) {\n resolve();\n } else {\n reject();\n }\n },\n { once: true },\n );\n\n this._worker.addEventListener(\n 'error',\n error => {\n reject(error);\n },\n { once: true },\n );\n });\n\n return this._ensureReadyPromise;\n }\n\n /**\n * Destroy the worker.\n */\n public destroy(): void {\n logInfo('[Replay] Destroying compression worker');\n this._worker.terminate();\n }\n\n /**\n * Post message to worker and wait for response before resolving promise.\n */\n public postMessage<T>(method: WorkerRequest['method'], arg?: WorkerRequest['arg']): Promise<T> {\n const id = this._getAndIncrementId();\n\n return new Promise((resolve, reject) => {\n const listener = ({ data }: MessageEvent): void => {\n const response = data as WorkerResponse;\n if (response.method !== method) {\n return;\n }\n\n // There can be multiple listeners for a single method, the id ensures\n // that the response matches the caller.\n if (response.id !== id) {\n return;\n }\n\n // At this point, we'll always want to remove listener regardless of result status\n this._worker.removeEventListener('message', listener);\n\n if (!response.success) {\n // TODO: Do some error handling, not sure what\n __DEBUG_BUILD__ && logger.error('[Replay]', response.response);\n\n reject(new Error('Error in compression worker'));\n return;\n }\n\n resolve(response.response as T);\n };\n\n // Note: we can't use `once` option because it's possible it needs to\n // listen to multiple messages\n this._worker.addEventListener('message', listener);\n this._worker.postMessage({ id, method, arg });\n });\n }\n\n /** Get the current ID and increment it for the next call. */\n private _getAndIncrementId(): number {\n return this._id++;\n }\n}\n","import type { ReplayRecordingData } from '@sentry/types';\n\nimport { REPLAY_MAX_EVENT_BUFFER_SIZE } from '../constants';\nimport type { AddEventResult, EventBuffer, EventBufferType, RecordingEvent } from '../types';\nimport { timestampToMs } from '../util/timestamp';\nimport { EventBufferSizeExceededError } from './error';\nimport { WorkerHandler } from './WorkerHandler';\n\n/**\n * Event buffer that uses a web worker to compress events.\n * Exported only for testing.\n */\nexport class EventBufferCompressionWorker implements EventBuffer {\n /** @inheritdoc */\n public hasCheckout: boolean;\n\n private _worker: WorkerHandler;\n private _earliestTimestamp: number | null;\n private _totalSize;\n\n public constructor(worker: Worker) {\n this._worker = new WorkerHandler(worker);\n this._earliestTimestamp = null;\n this._totalSize = 0;\n this.hasCheckout = false;\n }\n\n /** @inheritdoc */\n public get hasEvents(): boolean {\n return !!this._earliestTimestamp;\n }\n\n /** @inheritdoc */\n public get type(): EventBufferType {\n return 'worker';\n }\n\n /**\n * Ensure the worker is ready (or not).\n * This will either resolve when the worker is ready, or reject if an error occured.\n */\n public ensureReady(): Promise<void> {\n return this._worker.ensureReady();\n }\n\n /**\n * Destroy the event buffer.\n */\n public destroy(): void {\n this._worker.destroy();\n }\n\n /**\n * Add an event to the event buffer.\n *\n * Returns true if event was successfuly received and processed by worker.\n */\n public addEvent(event: RecordingEvent): Promise<AddEventResult> {\n const timestamp = timestampToMs(event.timestamp);\n if (!this._earliestTimestamp || timestamp < this._earliestTimestamp) {\n this._earliestTimestamp = timestamp;\n }\n\n const data = JSON.stringify(event);\n this._totalSize += data.length;\n\n if (this._totalSize > REPLAY_MAX_EVENT_BUFFER_SIZE) {\n return Promise.reject(new EventBufferSizeExceededError());\n }\n\n return this._sendEventToWorker(data);\n }\n\n /**\n * Finish the event buffer and return the compressed data.\n */\n public finish(): Promise<ReplayRecordingData> {\n return this._finishRequest();\n }\n\n /** @inheritdoc */\n public clear(): void {\n this._earliestTimestamp = null;\n this._totalSize = 0;\n this.hasCheckout = false;\n\n // We do not wait on this, as we assume the order of messages is consistent for the worker\n void this._worker.postMessage('clear');\n }\n\n /** @inheritdoc */\n public getEarliestTimestamp(): number | null {\n return this._earliestTimestamp;\n }\n\n /**\n * Send the event to the worker.\n */\n private _sendEventToWorker(data: string): Promise<AddEventResult> {\n return this._worker.postMessage<void>('addEvent', data);\n }\n\n /**\n * Finish the request and return the compressed data from the worker.\n */\n private async _finishRequest(): Promise<Uint8Array> {\n const response = await this._worker.postMessage<Uint8Array>('finish');\n\n this._earliestTimestamp = null;\n this._totalSize = 0;\n\n return response;\n }\n}\n","import type { ReplayRecordingData } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport type { AddEventResult, EventBuffer, EventBufferType, RecordingEvent } from '../types';\nimport { logInfo } from '../util/log';\nimport { EventBufferArray } from './EventBufferArray';\nimport { EventBufferCompressionWorker } from './EventBufferCompressionWorker';\n\n/**\n * This proxy will try to use the compression worker, and fall back to use the simple buffer if an error occurs there.\n * This can happen e.g. if the worker cannot be loaded.\n * Exported only for testing.\n */\nexport class EventBufferProxy implements EventBuffer {\n private _fallback: EventBufferArray;\n private _compression: EventBufferCompressionWorker;\n private _used: EventBuffer;\n private _ensureWorkerIsLoadedPromise: Promise<void>;\n\n public constructor(worker: Worker) {\n this._fallback = new EventBufferArray();\n this._compression = new EventBufferCompressionWorker(worker);\n this._used = this._fallback;\n\n this._ensureWorkerIsLoadedPromise = this._ensureWorkerIsLoaded();\n }\n\n /** @inheritdoc */\n public get type(): EventBufferType {\n return this._used.type;\n }\n\n /** @inheritDoc */\n public get hasEvents(): boolean {\n return this._used.hasEvents;\n }\n\n /** @inheritdoc */\n public get hasCheckout(): boolean {\n return this._used.hasCheckout;\n }\n /** @inheritdoc */\n public set hasCheckout(value: boolean) {\n this._used.hasCheckout = value;\n }\n\n /** @inheritDoc */\n public destroy(): void {\n this._fallback.destroy();\n this._compression.destroy();\n }\n\n /** @inheritdoc */\n public clear(): void {\n return this._used.clear();\n }\n\n /** @inheritdoc */\n public getEarliestTimestamp(): number | null {\n return this._used.getEarliestTimestamp();\n }\n\n /**\n * Add an event to the event buffer.\n *\n * Returns true if event was successfully added.\n */\n public addEvent(event: RecordingEvent): Promise<AddEventResult> {\n return this._used.addEvent(event);\n }\n\n /** @inheritDoc */\n public async finish(): Promise<ReplayRecordingData> {\n // Ensure the worker is loaded, so the sent event is compressed\n await this.ensureWorkerIsLoaded();\n\n return this._used.finish();\n }\n\n /** Ensure the worker has loaded. */\n public ensureWorkerIsLoaded(): Promise<void> {\n return this._ensureWorkerIsLoadedPromise;\n }\n\n /** Actually check if the worker has been loaded. */\n private async _ensureWorkerIsLoaded(): Promise<void> {\n try {\n await this._compression.ensureReady();\n } catch (error) {\n // If the worker fails to load, we fall back to the simple buffer.\n // Nothing more to do from our side here\n logInfo('[Replay] Failed to load the compression worker, falling back to simple buffer');\n return;\n }\n\n // Now we need to switch over the array buffer to the compression worker\n await this._switchToCompressionWorker();\n }\n\n /** Switch the used buffer to the compression worker. */\n private async _switchToCompressionWorker(): Promise<void> {\n const { events, hasCheckout } = this._fallback;\n\n const addEventPromises: Promise<void>[] = [];\n for (const event of events) {\n addEventPromises.push(this._compression.addEvent(event));\n }\n\n this._compression.hasCheckout = hasCheckout;\n\n // We switch over to the new buffer immediately - any further events will be added\n // after the previously buffered ones\n this._used = this._compression;\n\n // Wait for original events to be re-added before resolving\n try {\n await Promise.all(addEventPromises);\n } catch (error) {\n __DEBUG_BUILD__ && logger.warn('[Replay] Failed to add events when switching buffers.', error);\n }\n }\n}\n","import { getWorkerURL } from '@sentry-internal/replay-worker';\n\nimport type { EventBuffer } from '../types';\nimport { logInfo } from '../util/log';\nimport { EventBufferArray } from './EventBufferArray';\nimport { EventBufferProxy } from './EventBufferProxy';\n\ninterface CreateEventBufferParams {\n useCompression: boolean;\n}\n\n/**\n * Create an event buffer for replays.\n */\nexport function createEventBuffer({ useCompression }: CreateEventBufferParams): EventBuffer {\n // eslint-disable-next-line no-restricted-globals\n if (useCompression && window.Worker) {\n try {\n const workerUrl = getWorkerURL();\n\n logInfo('[Replay] Using compression worker');\n const worker = new Worker(workerUrl);\n return new EventBufferProxy(worker);\n } catch (error) {\n logInfo('[Replay] Failed to create compression worker');\n // Fall back to use simple event buffer array\n }\n }\n\n logInfo('[Replay] Using simple buffer');\n return new EventBufferArray();\n}\n","import r from\"./worker\";function e(){const e=new Blob([r]);return URL.createObjectURL(e)}export{e as getWorkerURL};\n","export default `/*! pako 2.1.0 https://github.com/nodeca/pako @license (MIT AND Zlib) */\nfunction t(t){let e=t.length;for(;--e>=0;)t[e]=0}const e=new Uint8Array([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0]),a=new Uint8Array([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13]),i=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),n=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),s=new Array(576);t(s);const r=new Array(60);t(r);const o=new Array(512);t(o);const l=new Array(256);t(l);const h=new Array(29);t(h);const d=new Array(30);function _(t,e,a,i,n){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=i,this.max_length=n,this.has_stree=t&&t.length}let f,c,u;function w(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}t(d);const m=t=>t<256?o[t]:o[256+(t>>>7)],b=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},g=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,b(t,t.bi_buf),t.bi_buf=e>>16-t.bi_valid,t.bi_valid+=a-16):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=a)},p=(t,e,a)=>{g(t,a[2*e],a[2*e+1])},k=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},v=(t,e,a)=>{const i=new Array(16);let n,s,r=0;for(n=1;n<=15;n++)r=r+a[n-1]<<1,i[n]=r;for(s=0;s<=e;s++){let e=t[2*s+1];0!==e&&(t[2*s]=k(i[e]++,e))}},y=t=>{let e;for(e=0;e<286;e++)t.dyn_ltree[2*e]=0;for(e=0;e<30;e++)t.dyn_dtree[2*e]=0;for(e=0;e<19;e++)t.bl_tree[2*e]=0;t.dyn_ltree[512]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},x=t=>{t.bi_valid>8?b(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},z=(t,e,a,i)=>{const n=2*e,s=2*a;return t[n]<t[s]||t[n]===t[s]&&i[e]<=i[a]},A=(t,e,a)=>{const i=t.heap[a];let n=a<<1;for(;n<=t.heap_len&&(n<t.heap_len&&z(e,t.heap[n+1],t.heap[n],t.depth)&&n++,!z(e,i,t.heap[n],t.depth));)t.heap[a]=t.heap[n],a=n,n<<=1;t.heap[a]=i},E=(t,i,n)=>{let s,r,o,_,f=0;if(0!==t.sym_next)do{s=255&t.pending_buf[t.sym_buf+f++],s+=(255&t.pending_buf[t.sym_buf+f++])<<8,r=t.pending_buf[t.sym_buf+f++],0===s?p(t,r,i):(o=l[r],p(t,o+256+1,i),_=e[o],0!==_&&(r-=h[o],g(t,r,_)),s--,o=m(s),p(t,o,n),_=a[o],0!==_&&(s-=d[o],g(t,s,_)))}while(f<t.sym_next);p(t,256,i)},R=(t,e)=>{const a=e.dyn_tree,i=e.stat_desc.static_tree,n=e.stat_desc.has_stree,s=e.stat_desc.elems;let r,o,l,h=-1;for(t.heap_len=0,t.heap_max=573,r=0;r<s;r++)0!==a[2*r]?(t.heap[++t.heap_len]=h=r,t.depth[r]=0):a[2*r+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=h<2?++h:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,n&&(t.static_len-=i[2*l+1]);for(e.max_code=h,r=t.heap_len>>1;r>=1;r--)A(t,a,r);l=s;do{r=t.heap[1],t.heap[1]=t.heap[t.heap_len--],A(t,a,1),o=t.heap[1],t.heap[--t.heap_max]=r,t.heap[--t.heap_max]=o,a[2*l]=a[2*r]+a[2*o],t.depth[l]=(t.depth[r]>=t.depth[o]?t.depth[r]:t.depth[o])+1,a[2*r+1]=a[2*o+1]=l,t.heap[1]=l++,A(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,i=e.max_code,n=e.stat_desc.static_tree,s=e.stat_desc.has_stree,r=e.stat_desc.extra_bits,o=e.stat_desc.extra_base,l=e.stat_desc.max_length;let h,d,_,f,c,u,w=0;for(f=0;f<=15;f++)t.bl_count[f]=0;for(a[2*t.heap[t.heap_max]+1]=0,h=t.heap_max+1;h<573;h++)d=t.heap[h],f=a[2*a[2*d+1]+1]+1,f>l&&(f=l,w++),a[2*d+1]=f,d>i||(t.bl_count[f]++,c=0,d>=o&&(c=r[d-o]),u=a[2*d],t.opt_len+=u*(f+c),s&&(t.static_len+=u*(n[2*d+1]+c)));if(0!==w){do{for(f=l-1;0===t.bl_count[f];)f--;t.bl_count[f]--,t.bl_count[f+1]+=2,t.bl_count[l]--,w-=2}while(w>0);for(f=l;0!==f;f--)for(d=t.bl_count[f];0!==d;)_=t.heap[--h],_>i||(a[2*_+1]!==f&&(t.opt_len+=(f-a[2*_+1])*a[2*_],a[2*_+1]=f),d--)}})(t,e),v(a,h,t.bl_count)},Z=(t,e,a)=>{let i,n,s=-1,r=e[1],o=0,l=7,h=4;for(0===r&&(l=138,h=3),e[2*(a+1)+1]=65535,i=0;i<=a;i++)n=r,r=e[2*(i+1)+1],++o<l&&n===r||(o<h?t.bl_tree[2*n]+=o:0!==n?(n!==s&&t.bl_tree[2*n]++,t.bl_tree[32]++):o<=10?t.bl_tree[34]++:t.bl_tree[36]++,o=0,s=n,0===r?(l=138,h=3):n===r?(l=6,h=3):(l=7,h=4))},U=(t,e,a)=>{let i,n,s=-1,r=e[1],o=0,l=7,h=4;for(0===r&&(l=138,h=3),i=0;i<=a;i++)if(n=r,r=e[2*(i+1)+1],!(++o<l&&n===r)){if(o<h)do{p(t,n,t.bl_tree)}while(0!=--o);else 0!==n?(n!==s&&(p(t,n,t.bl_tree),o--),p(t,16,t.bl_tree),g(t,o-3,2)):o<=10?(p(t,17,t.bl_tree),g(t,o-3,3)):(p(t,18,t.bl_tree),g(t,o-11,7));o=0,s=n,0===r?(l=138,h=3):n===r?(l=6,h=3):(l=7,h=4)}};let S=!1;const D=(t,e,a,i)=>{g(t,0+(i?1:0),3),x(t),b(t,a),b(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var T=(t,e,a,i)=>{let o,l,h=0;t.level>0?(2===t.strm.data_type&&(t.strm.data_type=(t=>{let e,a=4093624447;for(e=0;e<=31;e++,a>>>=1)if(1&a&&0!==t.dyn_ltree[2*e])return 0;if(0!==t.dyn_ltree[18]||0!==t.dyn_ltree[20]||0!==t.dyn_ltree[26])return 1;for(e=32;e<256;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),R(t,t.l_desc),R(t,t.d_desc),h=(t=>{let e;for(Z(t,t.dyn_ltree,t.l_desc.max_code),Z(t,t.dyn_dtree,t.d_desc.max_code),R(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*n[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),o=t.opt_len+3+7>>>3,l=t.static_len+3+7>>>3,l<=o&&(o=l)):o=l=a+5,a+4<=o&&-1!==e?D(t,e,a,i):4===t.strategy||l===o?(g(t,2+(i?1:0),3),E(t,s,r)):(g(t,4+(i?1:0),3),((t,e,a,i)=>{let s;for(g(t,e-257,5),g(t,a-1,5),g(t,i-4,4),s=0;s<i;s++)g(t,t.bl_tree[2*n[s]+1],3);U(t,t.dyn_ltree,e-1),U(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,h+1),E(t,t.dyn_ltree,t.dyn_dtree)),y(t),i&&x(t)},O={_tr_init:t=>{S||((()=>{let t,n,w,m,b;const g=new Array(16);for(w=0,m=0;m<28;m++)for(h[m]=w,t=0;t<1<<e[m];t++)l[w++]=m;for(l[w-1]=m,b=0,m=0;m<16;m++)for(d[m]=b,t=0;t<1<<a[m];t++)o[b++]=m;for(b>>=7;m<30;m++)for(d[m]=b<<7,t=0;t<1<<a[m]-7;t++)o[256+b++]=m;for(n=0;n<=15;n++)g[n]=0;for(t=0;t<=143;)s[2*t+1]=8,t++,g[8]++;for(;t<=255;)s[2*t+1]=9,t++,g[9]++;for(;t<=279;)s[2*t+1]=7,t++,g[7]++;for(;t<=287;)s[2*t+1]=8,t++,g[8]++;for(v(s,287,g),t=0;t<30;t++)r[2*t+1]=5,r[2*t]=k(t,5);f=new _(s,e,257,286,15),c=new _(r,a,0,30,15),u=new _(new Array(0),i,0,19,7)})(),S=!0),t.l_desc=new w(t.dyn_ltree,f),t.d_desc=new w(t.dyn_dtree,c),t.bl_desc=new w(t.bl_tree,u),t.bi_buf=0,t.bi_valid=0,y(t)},_tr_stored_block:D,_tr_flush_block:T,_tr_tally:(t,e,a)=>(t.pending_buf[t.sym_buf+t.sym_next++]=e,t.pending_buf[t.sym_buf+t.sym_next++]=e>>8,t.pending_buf[t.sym_buf+t.sym_next++]=a,0===e?t.dyn_ltree[2*a]++:(t.matches++,e--,t.dyn_ltree[2*(l[a]+256+1)]++,t.dyn_dtree[2*m(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{g(t,2,3),p(t,256,s),(t=>{16===t.bi_valid?(b(t,t.bi_buf),t.bi_buf=0,t.bi_valid=0):t.bi_valid>=8&&(t.pending_buf[t.pending++]=255&t.bi_buf,t.bi_buf>>=8,t.bi_valid-=8)})(t)}};var F=(t,e,a,i)=>{let n=65535&t|0,s=t>>>16&65535|0,r=0;for(;0!==a;){r=a>2e3?2e3:a,a-=r;do{n=n+e[i++]|0,s=s+n|0}while(--r);n%=65521,s%=65521}return n|s<<16|0};const L=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var i=0;i<8;i++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var N=(t,e,a,i)=>{const n=L,s=i+a;t^=-1;for(let a=i;a<s;a++)t=t>>>8^n[255&(t^e[a])];return-1^t},I={2:\"need dictionary\",1:\"stream end\",0:\"\",\"-1\":\"file error\",\"-2\":\"stream error\",\"-3\":\"data error\",\"-4\":\"insufficient memory\",\"-5\":\"buffer error\",\"-6\":\"incompatible version\"},B={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_TREES:6,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_MEM_ERROR:-4,Z_BUF_ERROR:-5,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:C,_tr_stored_block:H,_tr_flush_block:M,_tr_tally:j,_tr_align:K}=O,{Z_NO_FLUSH:P,Z_PARTIAL_FLUSH:Y,Z_FULL_FLUSH:G,Z_FINISH:X,Z_BLOCK:W,Z_OK:q,Z_STREAM_END:J,Z_STREAM_ERROR:Q,Z_DATA_ERROR:V,Z_BUF_ERROR:$,Z_DEFAULT_COMPRESSION:tt,Z_FILTERED:et,Z_HUFFMAN_ONLY:at,Z_RLE:it,Z_FIXED:nt,Z_DEFAULT_STRATEGY:st,Z_UNKNOWN:rt,Z_DEFLATED:ot}=B,lt=(t,e)=>(t.msg=I[e],e),ht=t=>2*t-(t>4?9:0),dt=t=>{let e=t.length;for(;--e>=0;)t[e]=0},_t=t=>{let e,a,i,n=t.w_size;e=t.hash_size,i=e;do{a=t.head[--i],t.head[i]=a>=n?a-n:0}while(--e);e=n,i=e;do{a=t.prev[--i],t.prev[i]=a>=n?a-n:0}while(--e)};let ft=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const ct=t=>{const e=t.state;let a=e.pending;a>t.avail_out&&(a=t.avail_out),0!==a&&(t.output.set(e.pending_buf.subarray(e.pending_out,e.pending_out+a),t.next_out),t.next_out+=a,e.pending_out+=a,t.total_out+=a,t.avail_out-=a,e.pending-=a,0===e.pending&&(e.pending_out=0))},ut=(t,e)=>{M(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,ct(t.strm)},wt=(t,e)=>{t.pending_buf[t.pending++]=e},mt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},bt=(t,e,a,i)=>{let n=t.avail_in;return n>i&&(n=i),0===n?0:(t.avail_in-=n,e.set(t.input.subarray(t.next_in,t.next_in+n),a),1===t.state.wrap?t.adler=F(t.adler,e,n,a):2===t.state.wrap&&(t.adler=N(t.adler,e,n,a)),t.next_in+=n,t.total_in+=n,n)},gt=(t,e)=>{let a,i,n=t.max_chain_length,s=t.strstart,r=t.prev_length,o=t.nice_match;const l=t.strstart>t.w_size-262?t.strstart-(t.w_size-262):0,h=t.window,d=t.w_mask,_=t.prev,f=t.strstart+258;let c=h[s+r-1],u=h[s+r];t.prev_length>=t.good_match&&(n>>=2),o>t.lookahead&&(o=t.lookahead);do{if(a=e,h[a+r]===u&&h[a+r-1]===c&&h[a]===h[s]&&h[++a]===h[s+1]){s+=2,a++;do{}while(h[++s]===h[++a]&&h[++s]===h[++a]&&h[++s]===h[++a]&&h[++s]===h[++a]&&h[++s]===h[++a]&&h[++s]===h[++a]&&h[++s]===h[++a]&&h[++s]===h[++a]&&s<f);if(i=258-(f-s),s=f-258,i>r){if(t.match_start=e,r=i,i>=o)break;c=h[s+r-1],u=h[s+r]}}}while((e=_[e&d])>l&&0!=--n);return r<=t.lookahead?r:t.lookahead},pt=t=>{const e=t.w_size;let a,i,n;do{if(i=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-262)&&(t.window.set(t.window.subarray(e,e+e-i),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),_t(t),i+=e),0===t.strm.avail_in)break;if(a=bt(t.strm,t.window,t.strstart+t.lookahead,i),t.lookahead+=a,t.lookahead+t.insert>=3)for(n=t.strstart-t.insert,t.ins_h=t.window[n],t.ins_h=ft(t,t.ins_h,t.window[n+1]);t.insert&&(t.ins_h=ft(t,t.ins_h,t.window[n+3-1]),t.prev[n&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=n,n++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<262&&0!==t.strm.avail_in)},kt=(t,e)=>{let a,i,n,s=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,r=0,o=t.strm.avail_in;do{if(a=65535,n=t.bi_valid+42>>3,t.strm.avail_out<n)break;if(n=t.strm.avail_out-n,i=t.strstart-t.block_start,a>i+t.strm.avail_in&&(a=i+t.strm.avail_in),a>n&&(a=n),a<s&&(0===a&&e!==X||e===P||a!==i+t.strm.avail_in))break;r=e===X&&a===i+t.strm.avail_in?1:0,H(t,0,0,r),t.pending_buf[t.pending-4]=a,t.pending_buf[t.pending-3]=a>>8,t.pending_buf[t.pending-2]=~a,t.pending_buf[t.pending-1]=~a>>8,ct(t.strm),i&&(i>a&&(i=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+i),t.strm.next_out),t.strm.next_out+=i,t.strm.avail_out-=i,t.strm.total_out+=i,t.block_start+=i,a-=i),a&&(bt(t.strm,t.strm.output,t.strm.next_out,a),t.strm.next_out+=a,t.strm.avail_out-=a,t.strm.total_out+=a)}while(0===r);return o-=t.strm.avail_in,o&&(o>=t.w_size?(t.matches=2,t.window.set(t.strm.input.subarray(t.strm.next_in-t.w_size,t.strm.next_in),0),t.strstart=t.w_size,t.insert=t.strstart):(t.window_size-t.strstart<=o&&(t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,t.insert>t.strstart&&(t.insert=t.strstart)),t.window.set(t.strm.input.subarray(t.strm.next_in-o,t.strm.next_in),t.strstart),t.strstart+=o,t.insert+=o>t.w_size-t.insert?t.w_size-t.insert:o),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),r?4:e!==P&&e!==X&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(n=t.window_size-t.strstart,t.strm.avail_in>n&&t.block_start>=t.w_size&&(t.block_start-=t.w_size,t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,n+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),n>t.strm.avail_in&&(n=t.strm.avail_in),n&&(bt(t.strm,t.window,t.strstart,n),t.strstart+=n,t.insert+=n>t.w_size-t.insert?t.w_size-t.insert:n),t.high_water<t.strstart&&(t.high_water=t.strstart),n=t.bi_valid+42>>3,n=t.pending_buf_size-n>65535?65535:t.pending_buf_size-n,s=n>t.w_size?t.w_size:n,i=t.strstart-t.block_start,(i>=s||(i||e===X)&&e!==P&&0===t.strm.avail_in&&i<=n)&&(a=i>n?n:i,r=e===X&&0===t.strm.avail_in&&a===i?1:0,H(t,t.block_start,a,r),t.block_start+=a,ct(t.strm)),r?3:1)},vt=(t,e)=>{let a,i;for(;;){if(t.lookahead<262){if(pt(t),t.lookahead<262&&e===P)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=ft(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),0!==a&&t.strstart-a<=t.w_size-262&&(t.match_length=gt(t,a)),t.match_length>=3)if(i=j(t,t.strstart-t.match_start,t.match_length-3),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=3){t.match_length--;do{t.strstart++,t.ins_h=ft(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart}while(0!=--t.match_length);t.strstart++}else t.strstart+=t.match_length,t.match_length=0,t.ins_h=t.window[t.strstart],t.ins_h=ft(t,t.ins_h,t.window[t.strstart+1]);else i=j(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(i&&(ut(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===X?(ut(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(ut(t,!1),0===t.strm.avail_out)?1:2},yt=(t,e)=>{let a,i,n;for(;;){if(t.lookahead<262){if(pt(t),t.lookahead<262&&e===P)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=ft(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),t.prev_length=t.match_length,t.prev_match=t.match_start,t.match_length=2,0!==a&&t.prev_length<t.max_lazy_match&&t.strstart-a<=t.w_size-262&&(t.match_length=gt(t,a),t.match_length<=5&&(t.strategy===et||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){n=t.strstart+t.lookahead-3,i=j(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=n&&(t.ins_h=ft(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart)}while(0!=--t.prev_length);if(t.match_available=0,t.match_length=2,t.strstart++,i&&(ut(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(i=j(t,0,t.window[t.strstart-1]),i&&ut(t,!1),t.strstart++,t.lookahead--,0===t.strm.avail_out)return 1}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(i=j(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===X?(ut(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(ut(t,!1),0===t.strm.avail_out)?1:2};function xt(t,e,a,i,n){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=i,this.func=n}const zt=[new xt(0,0,0,0,kt),new xt(4,4,8,4,vt),new xt(4,5,16,8,vt),new xt(4,6,32,32,vt),new xt(4,4,16,16,yt),new xt(8,16,32,32,yt),new xt(8,16,128,128,yt),new xt(8,32,128,256,yt),new xt(32,128,258,1024,yt),new xt(32,258,258,4096,yt)];function At(){this.strm=null,this.status=0,this.pending_buf=null,this.pending_buf_size=0,this.pending_out=0,this.pending=0,this.wrap=0,this.gzhead=null,this.gzindex=0,this.method=ot,this.last_flush=-1,this.w_size=0,this.w_bits=0,this.w_mask=0,this.window=null,this.window_size=0,this.prev=null,this.head=null,this.ins_h=0,this.hash_size=0,this.hash_bits=0,this.hash_mask=0,this.hash_shift=0,this.block_start=0,this.match_length=0,this.prev_match=0,this.match_available=0,this.strstart=0,this.match_start=0,this.lookahead=0,this.prev_length=0,this.max_chain_length=0,this.max_lazy_match=0,this.level=0,this.strategy=0,this.good_match=0,this.nice_match=0,this.dyn_ltree=new Uint16Array(1146),this.dyn_dtree=new Uint16Array(122),this.bl_tree=new Uint16Array(78),dt(this.dyn_ltree),dt(this.dyn_dtree),dt(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(16),this.heap=new Uint16Array(573),dt(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),dt(this.depth),this.sym_buf=0,this.lit_bufsize=0,this.sym_next=0,this.sym_end=0,this.opt_len=0,this.static_len=0,this.matches=0,this.insert=0,this.bi_buf=0,this.bi_valid=0}const Et=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||42!==e.status&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&113!==e.status&&666!==e.status?1:0},Rt=t=>{if(Et(t))return lt(t,Q);t.total_in=t.total_out=0,t.data_type=rt;const e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=2===e.wrap?57:e.wrap?42:113,t.adler=2===e.wrap?0:1,e.last_flush=-2,C(e),q},Zt=t=>{const e=Rt(t);var a;return e===q&&((a=t.state).window_size=2*a.w_size,dt(a.head),a.max_lazy_match=zt[a.level].max_lazy,a.good_match=zt[a.level].good_length,a.nice_match=zt[a.level].nice_length,a.max_chain_length=zt[a.level].max_chain,a.strstart=0,a.block_start=0,a.lookahead=0,a.insert=0,a.match_length=a.prev_length=2,a.match_available=0,a.ins_h=0),e},Ut=(t,e,a,i,n,s)=>{if(!t)return Q;let r=1;if(e===tt&&(e=6),i<0?(r=0,i=-i):i>15&&(r=2,i-=16),n<1||n>9||a!==ot||i<8||i>15||e<0||e>9||s<0||s>nt||8===i&&1!==r)return lt(t,Q);8===i&&(i=9);const o=new At;return t.state=o,o.strm=t,o.status=42,o.wrap=r,o.gzhead=null,o.w_bits=i,o.w_size=1<<o.w_bits,o.w_mask=o.w_size-1,o.hash_bits=n+7,o.hash_size=1<<o.hash_bits,o.hash_mask=o.hash_size-1,o.hash_shift=~~((o.hash_bits+3-1)/3),o.window=new Uint8Array(2*o.w_size),o.head=new Uint16Array(o.hash_size),o.prev=new Uint16Array(o.w_size),o.lit_bufsize=1<<n+6,o.pending_buf_size=4*o.lit_bufsize,o.pending_buf=new Uint8Array(o.pending_buf_size),o.sym_buf=o.lit_bufsize,o.sym_end=3*(o.lit_bufsize-1),o.level=e,o.strategy=s,o.method=a,Zt(t)};var St={deflateInit:(t,e)=>Ut(t,e,ot,15,8,st),deflateInit2:Ut,deflateReset:Zt,deflateResetKeep:Rt,deflateSetHeader:(t,e)=>Et(t)||2!==t.state.wrap?Q:(t.state.gzhead=e,q),deflate:(t,e)=>{if(Et(t)||e>W||e<0)return t?lt(t,Q):Q;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||666===a.status&&e!==X)return lt(t,0===t.avail_out?$:Q);const i=a.last_flush;if(a.last_flush=e,0!==a.pending){if(ct(t),0===t.avail_out)return a.last_flush=-1,q}else if(0===t.avail_in&&ht(e)<=ht(i)&&e!==X)return lt(t,$);if(666===a.status&&0!==t.avail_in)return lt(t,$);if(42===a.status&&0===a.wrap&&(a.status=113),42===a.status){let e=ot+(a.w_bits-8<<4)<<8,i=-1;if(i=a.strategy>=at||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=i<<6,0!==a.strstart&&(e|=32),e+=31-e%31,mt(a,e),0!==a.strstart&&(mt(a,t.adler>>>16),mt(a,65535&t.adler)),t.adler=1,a.status=113,ct(t),0!==a.pending)return a.last_flush=-1,q}if(57===a.status)if(t.adler=0,wt(a,31),wt(a,139),wt(a,8),a.gzhead)wt(a,(a.gzhead.text?1:0)+(a.gzhead.hcrc?2:0)+(a.gzhead.extra?4:0)+(a.gzhead.name?8:0)+(a.gzhead.comment?16:0)),wt(a,255&a.gzhead.time),wt(a,a.gzhead.time>>8&255),wt(a,a.gzhead.time>>16&255),wt(a,a.gzhead.time>>24&255),wt(a,9===a.level?2:a.strategy>=at||a.level<2?4:0),wt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(wt(a,255&a.gzhead.extra.length),wt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=N(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(wt(a,0),wt(a,0),wt(a,0),wt(a,0),wt(a,0),wt(a,9===a.level?2:a.strategy>=at||a.level<2?4:0),wt(a,3),a.status=113,ct(t),0!==a.pending)return a.last_flush=-1,q;if(69===a.status){if(a.gzhead.extra){let e=a.pending,i=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+i>a.pending_buf_size;){let n=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+n),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=N(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=n,ct(t),0!==a.pending)return a.last_flush=-1,q;e=0,i-=n}let n=new Uint8Array(a.gzhead.extra);a.pending_buf.set(n.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending+=i,a.gzhead.hcrc&&a.pending>e&&(t.adler=N(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex=0}a.status=73}if(73===a.status){if(a.gzhead.name){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=N(t.adler,a.pending_buf,a.pending-i,i)),ct(t),0!==a.pending)return a.last_flush=-1,q;i=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,wt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=N(t.adler,a.pending_buf,a.pending-i,i)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=N(t.adler,a.pending_buf,a.pending-i,i)),ct(t),0!==a.pending)return a.last_flush=-1,q;i=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,wt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=N(t.adler,a.pending_buf,a.pending-i,i))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(ct(t),0!==a.pending))return a.last_flush=-1,q;wt(a,255&t.adler),wt(a,t.adler>>8&255),t.adler=0}if(a.status=113,ct(t),0!==a.pending)return a.last_flush=-1,q}if(0!==t.avail_in||0!==a.lookahead||e!==P&&666!==a.status){let i=0===a.level?kt(a,e):a.strategy===at?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(pt(t),0===t.lookahead)){if(e===P)return 1;break}if(t.match_length=0,a=j(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(ut(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===X?(ut(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(ut(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===it?((t,e)=>{let a,i,n,s;const r=t.window;for(;;){if(t.lookahead<=258){if(pt(t),t.lookahead<=258&&e===P)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(n=t.strstart-1,i=r[n],i===r[++n]&&i===r[++n]&&i===r[++n])){s=t.strstart+258;do{}while(i===r[++n]&&i===r[++n]&&i===r[++n]&&i===r[++n]&&i===r[++n]&&i===r[++n]&&i===r[++n]&&i===r[++n]&&n<s);t.match_length=258-(s-n),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=j(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=j(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(ut(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===X?(ut(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(ut(t,!1),0===t.strm.avail_out)?1:2})(a,e):zt[a.level].func(a,e);if(3!==i&&4!==i||(a.status=666),1===i||3===i)return 0===t.avail_out&&(a.last_flush=-1),q;if(2===i&&(e===Y?K(a):e!==W&&(H(a,0,0,!1),e===G&&(dt(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),ct(t),0===t.avail_out))return a.last_flush=-1,q}return e!==X?q:a.wrap<=0?J:(2===a.wrap?(wt(a,255&t.adler),wt(a,t.adler>>8&255),wt(a,t.adler>>16&255),wt(a,t.adler>>24&255),wt(a,255&t.total_in),wt(a,t.total_in>>8&255),wt(a,t.total_in>>16&255),wt(a,t.total_in>>24&255)):(mt(a,t.adler>>>16),mt(a,65535&t.adler)),ct(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?q:J)},deflateEnd:t=>{if(Et(t))return Q;const e=t.state.status;return t.state=null,113===e?lt(t,V):q},deflateSetDictionary:(t,e)=>{let a=e.length;if(Et(t))return Q;const i=t.state,n=i.wrap;if(2===n||1===n&&42!==i.status||i.lookahead)return Q;if(1===n&&(t.adler=F(t.adler,e,a,0)),i.wrap=0,a>=i.w_size){0===n&&(dt(i.head),i.strstart=0,i.block_start=0,i.insert=0);let t=new Uint8Array(i.w_size);t.set(e.subarray(a-i.w_size,a),0),e=t,a=i.w_size}const s=t.avail_in,r=t.next_in,o=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,pt(i);i.lookahead>=3;){let t=i.strstart,e=i.lookahead-2;do{i.ins_h=ft(i,i.ins_h,i.window[t+3-1]),i.prev[t&i.w_mask]=i.head[i.ins_h],i.head[i.ins_h]=t,t++}while(--e);i.strstart=t,i.lookahead=2,pt(i)}return i.strstart+=i.lookahead,i.block_start=i.strstart,i.insert=i.lookahead,i.lookahead=0,i.match_length=i.prev_length=2,i.match_available=0,t.next_in=r,t.input=o,t.avail_in=s,i.wrap=n,q},deflateInfo:\"pako deflate (from Nodeca project)\"};const Dt=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var Tt=function(t){const e=Array.prototype.slice.call(arguments,1);for(;e.length;){const a=e.shift();if(a){if(\"object\"!=typeof a)throw new TypeError(a+\"must be non-object\");for(const e in a)Dt(a,e)&&(t[e]=a[e])}}return t},Ot=t=>{let e=0;for(let a=0,i=t.length;a<i;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,i=0,n=t.length;e<n;e++){let n=t[e];a.set(n,i),i+=n.length}return a};let Ft=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){Ft=!1}const Lt=new Uint8Array(256);for(let t=0;t<256;t++)Lt[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;Lt[254]=Lt[254]=1;var Nt=t=>{if(\"function\"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,i,n,s,r=t.length,o=0;for(n=0;n<r;n++)a=t.charCodeAt(n),55296==(64512&a)&&n+1<r&&(i=t.charCodeAt(n+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),n++)),o+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(o),s=0,n=0;s<o;n++)a=t.charCodeAt(n),55296==(64512&a)&&n+1<r&&(i=t.charCodeAt(n+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),n++)),a<128?e[s++]=a:a<2048?(e[s++]=192|a>>>6,e[s++]=128|63&a):a<65536?(e[s++]=224|a>>>12,e[s++]=128|a>>>6&63,e[s++]=128|63&a):(e[s++]=240|a>>>18,e[s++]=128|a>>>12&63,e[s++]=128|a>>>6&63,e[s++]=128|63&a);return e},It=(t,e)=>{const a=e||t.length;if(\"function\"==typeof TextDecoder&&TextDecoder.prototype.decode)return(new TextDecoder).decode(t.subarray(0,e));let i,n;const s=new Array(2*a);for(n=0,i=0;i<a;){let e=t[i++];if(e<128){s[n++]=e;continue}let r=Lt[e];if(r>4)s[n++]=65533,i+=r-1;else{for(e&=2===r?31:3===r?15:7;r>1&&i<a;)e=e<<6|63&t[i++],r--;r>1?s[n++]=65533:e<65536?s[n++]=e:(e-=65536,s[n++]=55296|e>>10&1023,s[n++]=56320|1023&e)}}return((t,e)=>{if(e<65534&&t.subarray&&Ft)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let a=\"\";for(let i=0;i<e;i++)a+=String.fromCharCode(t[i]);return a})(s,n)},Bt=(t,e)=>{(e=e||t.length)>t.length&&(e=t.length);let a=e-1;for(;a>=0&&128==(192&t[a]);)a--;return a<0||0===a?e:a+Lt[t[a]]>e?a:e};var Ct=function(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg=\"\",this.state=null,this.data_type=2,this.adler=0};const Ht=Object.prototype.toString,{Z_NO_FLUSH:Mt,Z_SYNC_FLUSH:jt,Z_FULL_FLUSH:Kt,Z_FINISH:Pt,Z_OK:Yt,Z_STREAM_END:Gt,Z_DEFAULT_COMPRESSION:Xt,Z_DEFAULT_STRATEGY:Wt,Z_DEFLATED:qt}=B;function Jt(t){this.options=Tt({level:Xt,method:qt,chunkSize:16384,windowBits:15,memLevel:8,strategy:Wt},t||{});let e=this.options;e.raw&&e.windowBits>0?e.windowBits=-e.windowBits:e.gzip&&e.windowBits>0&&e.windowBits<16&&(e.windowBits+=16),this.err=0,this.msg=\"\",this.ended=!1,this.chunks=[],this.strm=new Ct,this.strm.avail_out=0;let a=St.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==Yt)throw new Error(I[a]);if(e.header&&St.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t=\"string\"==typeof e.dictionary?Nt(e.dictionary):\"[object ArrayBuffer]\"===Ht.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=St.deflateSetDictionary(this.strm,t),a!==Yt)throw new Error(I[a]);this._dict_set=!0}}function Qt(t,e){const a=new Jt(e);if(a.push(t,!0),a.err)throw a.msg||I[a.err];return a.result}Jt.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize;let n,s;if(this.ended)return!1;for(s=e===~~e?e:!0===e?Pt:Mt,\"string\"==typeof t?a.input=Nt(t):\"[object ArrayBuffer]\"===Ht.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;)if(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),(s===jt||s===Kt)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(n=St.deflate(a,s),n===Gt)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),n=St.deflateEnd(this.strm),this.onEnd(n),this.ended=!0,n===Yt;if(0!==a.avail_out){if(s>0&&a.next_out>0)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else if(0===a.avail_in)break}else this.onData(a.output)}return!0},Jt.prototype.onData=function(t){this.chunks.push(t)},Jt.prototype.onEnd=function(t){t===Yt&&(this.result=Ot(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Vt={Deflate:Jt,deflate:Qt,deflateRaw:function(t,e){return(e=e||{}).raw=!0,Qt(t,e)},gzip:function(t,e){return(e=e||{}).gzip=!0,Qt(t,e)},constants:B};var $t=function(t,e){let a,i,n,s,r,o,l,h,d,_,f,c,u,w,m,b,g,p,k,v,y,x,z,A;const E=t.state;a=t.next_in,z=t.input,i=a+(t.avail_in-5),n=t.next_out,A=t.output,s=n-(e-t.avail_out),r=n+(t.avail_out-257),o=E.dmax,l=E.wsize,h=E.whave,d=E.wnext,_=E.window,f=E.hold,c=E.bits,u=E.lencode,w=E.distcode,m=(1<<E.lenbits)-1,b=(1<<E.distbits)-1;t:do{c<15&&(f+=z[a++]<<c,c+=8,f+=z[a++]<<c,c+=8),g=u[f&m];e:for(;;){if(p=g>>>24,f>>>=p,c-=p,p=g>>>16&255,0===p)A[n++]=65535&g;else{if(!(16&p)){if(0==(64&p)){g=u[(65535&g)+(f&(1<<p)-1)];continue e}if(32&p){E.mode=16191;break t}t.msg=\"invalid literal/length code\",E.mode=16209;break t}k=65535&g,p&=15,p&&(c<p&&(f+=z[a++]<<c,c+=8),k+=f&(1<<p)-1,f>>>=p,c-=p),c<15&&(f+=z[a++]<<c,c+=8,f+=z[a++]<<c,c+=8),g=w[f&b];a:for(;;){if(p=g>>>24,f>>>=p,c-=p,p=g>>>16&255,!(16&p)){if(0==(64&p)){g=w[(65535&g)+(f&(1<<p)-1)];continue a}t.msg=\"invalid distance code\",E.mode=16209;break t}if(v=65535&g,p&=15,c<p&&(f+=z[a++]<<c,c+=8,c<p&&(f+=z[a++]<<c,c+=8)),v+=f&(1<<p)-1,v>o){t.msg=\"invalid distance too far back\",E.mode=16209;break t}if(f>>>=p,c-=p,p=n-s,v>p){if(p=v-p,p>h&&E.sane){t.msg=\"invalid distance too far back\",E.mode=16209;break t}if(y=0,x=_,0===d){if(y+=l-p,p<k){k-=p;do{A[n++]=_[y++]}while(--p);y=n-v,x=A}}else if(d<p){if(y+=l+d-p,p-=d,p<k){k-=p;do{A[n++]=_[y++]}while(--p);if(y=0,d<k){p=d,k-=p;do{A[n++]=_[y++]}while(--p);y=n-v,x=A}}}else if(y+=d-p,p<k){k-=p;do{A[n++]=_[y++]}while(--p);y=n-v,x=A}for(;k>2;)A[n++]=x[y++],A[n++]=x[y++],A[n++]=x[y++],k-=3;k&&(A[n++]=x[y++],k>1&&(A[n++]=x[y++]))}else{y=n-v;do{A[n++]=A[y++],A[n++]=A[y++],A[n++]=A[y++],k-=3}while(k>2);k&&(A[n++]=A[y++],k>1&&(A[n++]=A[y++]))}break}}break}}while(a<i&&n<r);k=c>>3,a-=k,c-=k<<3,f&=(1<<c)-1,t.next_in=a,t.next_out=n,t.avail_in=a<i?i-a+5:5-(a-i),t.avail_out=n<r?r-n+257:257-(n-r),E.hold=f,E.bits=c};const te=new Uint16Array([3,4,5,6,7,8,9,10,11,13,15,17,19,23,27,31,35,43,51,59,67,83,99,115,131,163,195,227,258,0,0]),ee=new Uint8Array([16,16,16,16,16,16,16,16,17,17,17,17,18,18,18,18,19,19,19,19,20,20,20,20,21,21,21,21,16,72,78]),ae=new Uint16Array([1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193,257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0]),ie=new Uint8Array([16,16,16,16,17,17,18,18,19,19,20,20,21,21,22,22,23,23,24,24,25,25,26,26,27,27,28,28,29,29,64,64]);var ne=(t,e,a,i,n,s,r,o)=>{const l=o.bits;let h,d,_,f,c,u,w=0,m=0,b=0,g=0,p=0,k=0,v=0,y=0,x=0,z=0,A=null;const E=new Uint16Array(16),R=new Uint16Array(16);let Z,U,S,D=null;for(w=0;w<=15;w++)E[w]=0;for(m=0;m<i;m++)E[e[a+m]]++;for(p=l,g=15;g>=1&&0===E[g];g--);if(p>g&&(p=g),0===g)return n[s++]=20971520,n[s++]=20971520,o.bits=1,0;for(b=1;b<g&&0===E[b];b++);for(p<b&&(p=b),y=1,w=1;w<=15;w++)if(y<<=1,y-=E[w],y<0)return-1;if(y>0&&(0===t||1!==g))return-1;for(R[1]=0,w=1;w<15;w++)R[w+1]=R[w]+E[w];for(m=0;m<i;m++)0!==e[a+m]&&(r[R[e[a+m]]++]=m);if(0===t?(A=D=r,u=20):1===t?(A=te,D=ee,u=257):(A=ae,D=ie,u=0),z=0,m=0,w=b,c=s,k=p,v=0,_=-1,x=1<<p,f=x-1,1===t&&x>852||2===t&&x>592)return 1;for(;;){Z=w-v,r[m]+1<u?(U=0,S=r[m]):r[m]>=u?(U=D[r[m]-u],S=A[r[m]-u]):(U=96,S=0),h=1<<w-v,d=1<<k,b=d;do{d-=h,n[c+(z>>v)+d]=Z<<24|U<<16|S|0}while(0!==d);for(h=1<<w-1;z&h;)h>>=1;if(0!==h?(z&=h-1,z+=h):z=0,m++,0==--E[w]){if(w===g)break;w=e[a+r[m]]}if(w>p&&(z&f)!==_){for(0===v&&(v=p),c+=b,k=w-v,y=1<<k;k+v<g&&(y-=E[k+v],!(y<=0));)k++,y<<=1;if(x+=1<<k,1===t&&x>852||2===t&&x>592)return 1;_=z&f,n[_]=p<<24|k<<16|c-s|0}}return 0!==z&&(n[c+z]=w-v<<24|64<<16|0),o.bits=p,0};const{Z_FINISH:se,Z_BLOCK:re,Z_TREES:oe,Z_OK:le,Z_STREAM_END:he,Z_NEED_DICT:de,Z_STREAM_ERROR:_e,Z_DATA_ERROR:fe,Z_MEM_ERROR:ce,Z_BUF_ERROR:ue,Z_DEFLATED:we}=B,me=16209,be=t=>(t>>>24&255)+(t>>>8&65280)+((65280&t)<<8)+((255&t)<<24);function ge(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}const pe=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.mode<16180||e.mode>16211?1:0},ke=t=>{if(pe(t))return _e;const e=t.state;return t.total_in=t.total_out=e.total=0,t.msg=\"\",e.wrap&&(t.adler=1&e.wrap),e.mode=16180,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(852),e.distcode=e.distdyn=new Int32Array(592),e.sane=1,e.back=-1,le},ve=t=>{if(pe(t))return _e;const e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,ke(t)},ye=(t,e)=>{let a;if(pe(t))return _e;const i=t.state;return e<0?(a=0,e=-e):(a=5+(e>>4),e<48&&(e&=15)),e&&(e<8||e>15)?_e:(null!==i.window&&i.wbits!==e&&(i.window=null),i.wrap=a,i.wbits=e,ve(t))},xe=(t,e)=>{if(!t)return _e;const a=new ge;t.state=a,a.strm=t,a.window=null,a.mode=16180;const i=ye(t,e);return i!==le&&(t.state=null),i};let ze,Ae,Ee=!0;const Re=t=>{if(Ee){ze=new Int32Array(512),Ae=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(ne(1,t.lens,0,288,ze,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;ne(2,t.lens,0,32,Ae,0,t.work,{bits:5}),Ee=!1}t.lencode=ze,t.lenbits=9,t.distcode=Ae,t.distbits=5},Ze=(t,e,a,i)=>{let n;const s=t.state;return null===s.window&&(s.wsize=1<<s.wbits,s.wnext=0,s.whave=0,s.window=new Uint8Array(s.wsize)),i>=s.wsize?(s.window.set(e.subarray(a-s.wsize,a),0),s.wnext=0,s.whave=s.wsize):(n=s.wsize-s.wnext,n>i&&(n=i),s.window.set(e.subarray(a-i,a-i+n),s.wnext),(i-=n)?(s.window.set(e.subarray(a-i,a),0),s.wnext=i,s.whave=s.wsize):(s.wnext+=n,s.wnext===s.wsize&&(s.wnext=0),s.whave<s.wsize&&(s.whave+=n))),0};var Ue={inflateReset:ve,inflateReset2:ye,inflateResetKeep:ke,inflateInit:t=>xe(t,15),inflateInit2:xe,inflate:(t,e)=>{let a,i,n,s,r,o,l,h,d,_,f,c,u,w,m,b,g,p,k,v,y,x,z=0;const A=new Uint8Array(4);let E,R;const Z=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(pe(t)||!t.output||!t.input&&0!==t.avail_in)return _e;a=t.state,16191===a.mode&&(a.mode=16192),r=t.next_out,n=t.output,l=t.avail_out,s=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,_=o,f=l,x=le;t:for(;;)switch(a.mode){case 16180:if(0===a.wrap){a.mode=16192;break}for(;d<16;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(2&a.wrap&&35615===h){0===a.wbits&&(a.wbits=15),a.check=0,A[0]=255&h,A[1]=h>>>8&255,a.check=N(a.check,A,2,0),h=0,d=0,a.mode=16181;break}if(a.head&&(a.head.done=!1),!(1&a.wrap)||(((255&h)<<8)+(h>>8))%31){t.msg=\"incorrect header check\",a.mode=me;break}if((15&h)!==we){t.msg=\"unknown compression method\",a.mode=me;break}if(h>>>=4,d-=4,y=8+(15&h),0===a.wbits&&(a.wbits=y),y>15||y>a.wbits){t.msg=\"invalid window size\",a.mode=me;break}a.dmax=1<<a.wbits,a.flags=0,t.adler=a.check=1,a.mode=512&h?16189:16191,h=0,d=0;break;case 16181:for(;d<16;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(a.flags=h,(255&a.flags)!==we){t.msg=\"unknown compression method\",a.mode=me;break}if(57344&a.flags){t.msg=\"unknown header flags set\",a.mode=me;break}a.head&&(a.head.text=h>>8&1),512&a.flags&&4&a.wrap&&(A[0]=255&h,A[1]=h>>>8&255,a.check=N(a.check,A,2,0)),h=0,d=0,a.mode=16182;case 16182:for(;d<32;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}a.head&&(a.head.time=h),512&a.flags&&4&a.wrap&&(A[0]=255&h,A[1]=h>>>8&255,A[2]=h>>>16&255,A[3]=h>>>24&255,a.check=N(a.check,A,4,0)),h=0,d=0,a.mode=16183;case 16183:for(;d<16;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}a.head&&(a.head.xflags=255&h,a.head.os=h>>8),512&a.flags&&4&a.wrap&&(A[0]=255&h,A[1]=h>>>8&255,a.check=N(a.check,A,2,0)),h=0,d=0,a.mode=16184;case 16184:if(1024&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}a.length=h,a.head&&(a.head.extra_len=h),512&a.flags&&4&a.wrap&&(A[0]=255&h,A[1]=h>>>8&255,a.check=N(a.check,A,2,0)),h=0,d=0}else a.head&&(a.head.extra=null);a.mode=16185;case 16185:if(1024&a.flags&&(c=a.length,c>o&&(c=o),c&&(a.head&&(y=a.head.extra_len-a.length,a.head.extra||(a.head.extra=new Uint8Array(a.head.extra_len)),a.head.extra.set(i.subarray(s,s+c),y)),512&a.flags&&4&a.wrap&&(a.check=N(a.check,i,c,s)),o-=c,s+=c,a.length-=c),a.length))break t;a.length=0,a.mode=16186;case 16186:if(2048&a.flags){if(0===o)break t;c=0;do{y=i[s+c++],a.head&&y&&a.length<65536&&(a.head.name+=String.fromCharCode(y))}while(y&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=N(a.check,i,c,s)),o-=c,s+=c,y)break t}else a.head&&(a.head.name=null);a.length=0,a.mode=16187;case 16187:if(4096&a.flags){if(0===o)break t;c=0;do{y=i[s+c++],a.head&&y&&a.length<65536&&(a.head.comment+=String.fromCharCode(y))}while(y&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=N(a.check,i,c,s)),o-=c,s+=c,y)break t}else a.head&&(a.head.comment=null);a.mode=16188;case 16188:if(512&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(4&a.wrap&&h!==(65535&a.check)){t.msg=\"header crc mismatch\",a.mode=me;break}h=0,d=0}a.head&&(a.head.hcrc=a.flags>>9&1,a.head.done=!0),t.adler=a.check=0,a.mode=16191;break;case 16189:for(;d<32;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}t.adler=a.check=be(h),h=0,d=0,a.mode=16190;case 16190:if(0===a.havedict)return t.next_out=r,t.avail_out=l,t.next_in=s,t.avail_in=o,a.hold=h,a.bits=d,de;t.adler=a.check=1,a.mode=16191;case 16191:if(e===re||e===oe)break t;case 16192:if(a.last){h>>>=7&d,d-=7&d,a.mode=16206;break}for(;d<3;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}switch(a.last=1&h,h>>>=1,d-=1,3&h){case 0:a.mode=16193;break;case 1:if(Re(a),a.mode=16199,e===oe){h>>>=2,d-=2;break t}break;case 2:a.mode=16196;break;case 3:t.msg=\"invalid block type\",a.mode=me}h>>>=2,d-=2;break;case 16193:for(h>>>=7&d,d-=7&d;d<32;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if((65535&h)!=(h>>>16^65535)){t.msg=\"invalid stored block lengths\",a.mode=me;break}if(a.length=65535&h,h=0,d=0,a.mode=16194,e===oe)break t;case 16194:a.mode=16195;case 16195:if(c=a.length,c){if(c>o&&(c=o),c>l&&(c=l),0===c)break t;n.set(i.subarray(s,s+c),r),o-=c,s+=c,l-=c,r+=c,a.length-=c;break}a.mode=16191;break;case 16196:for(;d<14;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(a.nlen=257+(31&h),h>>>=5,d-=5,a.ndist=1+(31&h),h>>>=5,d-=5,a.ncode=4+(15&h),h>>>=4,d-=4,a.nlen>286||a.ndist>30){t.msg=\"too many length or distance symbols\",a.mode=me;break}a.have=0,a.mode=16197;case 16197:for(;a.have<a.ncode;){for(;d<3;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}a.lens[Z[a.have++]]=7&h,h>>>=3,d-=3}for(;a.have<19;)a.lens[Z[a.have++]]=0;if(a.lencode=a.lendyn,a.lenbits=7,E={bits:a.lenbits},x=ne(0,a.lens,0,19,a.lencode,0,a.work,E),a.lenbits=E.bits,x){t.msg=\"invalid code lengths set\",a.mode=me;break}a.have=0,a.mode=16198;case 16198:for(;a.have<a.nlen+a.ndist;){for(;z=a.lencode[h&(1<<a.lenbits)-1],m=z>>>24,b=z>>>16&255,g=65535&z,!(m<=d);){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(g<16)h>>>=m,d-=m,a.lens[a.have++]=g;else{if(16===g){for(R=m+2;d<R;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(h>>>=m,d-=m,0===a.have){t.msg=\"invalid bit length repeat\",a.mode=me;break}y=a.lens[a.have-1],c=3+(3&h),h>>>=2,d-=2}else if(17===g){for(R=m+3;d<R;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}h>>>=m,d-=m,y=0,c=3+(7&h),h>>>=3,d-=3}else{for(R=m+7;d<R;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}h>>>=m,d-=m,y=0,c=11+(127&h),h>>>=7,d-=7}if(a.have+c>a.nlen+a.ndist){t.msg=\"invalid bit length repeat\",a.mode=me;break}for(;c--;)a.lens[a.have++]=y}}if(a.mode===me)break;if(0===a.lens[256]){t.msg=\"invalid code -- missing end-of-block\",a.mode=me;break}if(a.lenbits=9,E={bits:a.lenbits},x=ne(1,a.lens,0,a.nlen,a.lencode,0,a.work,E),a.lenbits=E.bits,x){t.msg=\"invalid literal/lengths set\",a.mode=me;break}if(a.distbits=6,a.distcode=a.distdyn,E={bits:a.distbits},x=ne(2,a.lens,a.nlen,a.ndist,a.distcode,0,a.work,E),a.distbits=E.bits,x){t.msg=\"invalid distances set\",a.mode=me;break}if(a.mode=16199,e===oe)break t;case 16199:a.mode=16200;case 16200:if(o>=6&&l>=258){t.next_out=r,t.avail_out=l,t.next_in=s,t.avail_in=o,a.hold=h,a.bits=d,$t(t,f),r=t.next_out,n=t.output,l=t.avail_out,s=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,16191===a.mode&&(a.back=-1);break}for(a.back=0;z=a.lencode[h&(1<<a.lenbits)-1],m=z>>>24,b=z>>>16&255,g=65535&z,!(m<=d);){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(b&&0==(240&b)){for(p=m,k=b,v=g;z=a.lencode[v+((h&(1<<p+k)-1)>>p)],m=z>>>24,b=z>>>16&255,g=65535&z,!(p+m<=d);){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}h>>>=p,d-=p,a.back+=p}if(h>>>=m,d-=m,a.back+=m,a.length=g,0===b){a.mode=16205;break}if(32&b){a.back=-1,a.mode=16191;break}if(64&b){t.msg=\"invalid literal/length code\",a.mode=me;break}a.extra=15&b,a.mode=16201;case 16201:if(a.extra){for(R=a.extra;d<R;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}a.length+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}a.was=a.length,a.mode=16202;case 16202:for(;z=a.distcode[h&(1<<a.distbits)-1],m=z>>>24,b=z>>>16&255,g=65535&z,!(m<=d);){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(0==(240&b)){for(p=m,k=b,v=g;z=a.distcode[v+((h&(1<<p+k)-1)>>p)],m=z>>>24,b=z>>>16&255,g=65535&z,!(p+m<=d);){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}h>>>=p,d-=p,a.back+=p}if(h>>>=m,d-=m,a.back+=m,64&b){t.msg=\"invalid distance code\",a.mode=me;break}a.offset=g,a.extra=15&b,a.mode=16203;case 16203:if(a.extra){for(R=a.extra;d<R;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}a.offset+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}if(a.offset>a.dmax){t.msg=\"invalid distance too far back\",a.mode=me;break}a.mode=16204;case 16204:if(0===l)break t;if(c=f-l,a.offset>c){if(c=a.offset-c,c>a.whave&&a.sane){t.msg=\"invalid distance too far back\",a.mode=me;break}c>a.wnext?(c-=a.wnext,u=a.wsize-c):u=a.wnext-c,c>a.length&&(c=a.length),w=a.window}else w=n,u=r-a.offset,c=a.length;c>l&&(c=l),l-=c,a.length-=c;do{n[r++]=w[u++]}while(--c);0===a.length&&(a.mode=16200);break;case 16205:if(0===l)break t;n[r++]=a.length,l--,a.mode=16200;break;case 16206:if(a.wrap){for(;d<32;){if(0===o)break t;o--,h|=i[s++]<<d,d+=8}if(f-=l,t.total_out+=f,a.total+=f,4&a.wrap&&f&&(t.adler=a.check=a.flags?N(a.check,n,f,r-f):F(a.check,n,f,r-f)),f=l,4&a.wrap&&(a.flags?h:be(h))!==a.check){t.msg=\"incorrect data check\",a.mode=me;break}h=0,d=0}a.mode=16207;case 16207:if(a.wrap&&a.flags){for(;d<32;){if(0===o)break t;o--,h+=i[s++]<<d,d+=8}if(4&a.wrap&&h!==(4294967295&a.total)){t.msg=\"incorrect length check\",a.mode=me;break}h=0,d=0}a.mode=16208;case 16208:x=he;break t;case me:x=fe;break t;case 16210:return ce;default:return _e}return t.next_out=r,t.avail_out=l,t.next_in=s,t.avail_in=o,a.hold=h,a.bits=d,(a.wsize||f!==t.avail_out&&a.mode<me&&(a.mode<16206||e!==se))&&Ze(t,t.output,t.next_out,f-t.avail_out),_-=t.avail_in,f-=t.avail_out,t.total_in+=_,t.total_out+=f,a.total+=f,4&a.wrap&&f&&(t.adler=a.check=a.flags?N(a.check,n,f,t.next_out-f):F(a.check,n,f,t.next_out-f)),t.data_type=a.bits+(a.last?64:0)+(16191===a.mode?128:0)+(16199===a.mode||16194===a.mode?256:0),(0===_&&0===f||e===se)&&x===le&&(x=ue),x},inflateEnd:t=>{if(pe(t))return _e;let e=t.state;return e.window&&(e.window=null),t.state=null,le},inflateGetHeader:(t,e)=>{if(pe(t))return _e;const a=t.state;return 0==(2&a.wrap)?_e:(a.head=e,e.done=!1,le)},inflateSetDictionary:(t,e)=>{const a=e.length;let i,n,s;return pe(t)?_e:(i=t.state,0!==i.wrap&&16190!==i.mode?_e:16190===i.mode&&(n=1,n=F(n,e,a,0),n!==i.check)?fe:(s=Ze(t,e,a,a),s?(i.mode=16210,ce):(i.havedict=1,le)))},inflateInfo:\"pako inflate (from Nodeca project)\"};var Se=function(){this.text=0,this.time=0,this.xflags=0,this.os=0,this.extra=null,this.extra_len=0,this.name=\"\",this.comment=\"\",this.hcrc=0,this.done=!1};const De=Object.prototype.toString,{Z_NO_FLUSH:Te,Z_FINISH:Oe,Z_OK:Fe,Z_STREAM_END:Le,Z_NEED_DICT:Ne,Z_STREAM_ERROR:Ie,Z_DATA_ERROR:Be,Z_MEM_ERROR:Ce}=B;function He(t){this.options=Tt({chunkSize:65536,windowBits:15,to:\"\"},t||{});const e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,0===e.windowBits&&(e.windowBits=-15)),!(e.windowBits>=0&&e.windowBits<16)||t&&t.windowBits||(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&0==(15&e.windowBits)&&(e.windowBits|=15),this.err=0,this.msg=\"\",this.ended=!1,this.chunks=[],this.strm=new Ct,this.strm.avail_out=0;let a=Ue.inflateInit2(this.strm,e.windowBits);if(a!==Fe)throw new Error(I[a]);if(this.header=new Se,Ue.inflateGetHeader(this.strm,this.header),e.dictionary&&(\"string\"==typeof e.dictionary?e.dictionary=Nt(e.dictionary):\"[object ArrayBuffer]\"===De.call(e.dictionary)&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(a=Ue.inflateSetDictionary(this.strm,e.dictionary),a!==Fe)))throw new Error(I[a])}He.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize,n=this.options.dictionary;let s,r,o;if(this.ended)return!1;for(r=e===~~e?e:!0===e?Oe:Te,\"[object ArrayBuffer]\"===De.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;){for(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),s=Ue.inflate(a,r),s===Ne&&n&&(s=Ue.inflateSetDictionary(a,n),s===Fe?s=Ue.inflate(a,r):s===Be&&(s=Ne));a.avail_in>0&&s===Le&&a.state.wrap>0&&0!==t[a.next_in];)Ue.inflateReset(a),s=Ue.inflate(a,r);switch(s){case Ie:case Be:case Ne:case Ce:return this.onEnd(s),this.ended=!0,!1}if(o=a.avail_out,a.next_out&&(0===a.avail_out||s===Le))if(\"string\"===this.options.to){let t=Bt(a.output,a.next_out),e=a.next_out-t,n=It(a.output,t);a.next_out=e,a.avail_out=i-e,e&&a.output.set(a.output.subarray(t,t+e),0),this.onData(n)}else this.onData(a.output.length===a.next_out?a.output:a.output.subarray(0,a.next_out));if(s!==Fe||0!==o){if(s===Le)return s=Ue.inflateEnd(this.strm),this.onEnd(s),this.ended=!0,!0;if(0===a.avail_in)break}}return!0},He.prototype.onData=function(t){this.chunks.push(t)},He.prototype.onEnd=function(t){t===Fe&&(\"string\"===this.options.to?this.result=this.chunks.join(\"\"):this.result=Ot(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};const{Deflate:Me,deflate:je,deflateRaw:Ke,gzip:Pe}=Vt;var Ye=Me,Ge=je,Xe=B;const We=new class{constructor(){this._init()}clear(){this._init()}addEvent(t){if(!t)throw new Error(\"Adding invalid event\");const e=this._hasEvents?\",\":\"\";this.deflate.push(e+t,Xe.Z_SYNC_FLUSH),this._hasEvents=!0}finish(){if(this.deflate.push(\"]\",Xe.Z_FINISH),this.deflate.err)throw this.deflate.err;const t=this.deflate.result;return this._init(),t}_init(){this._hasEvents=!1,this.deflate=new Ye,this.deflate.push(\"[\",Xe.Z_NO_FLUSH)}},qe={clear:()=>{We.clear()},addEvent:t=>We.addEvent(t),finish:()=>We.finish(),compress:t=>function(t){return Ge(t)}(t)};addEventListener(\"message\",(function(t){const e=t.data.method,a=t.data.id,i=t.data.arg;if(e in qe&&\"function\"==typeof qe[e])try{const t=qe[e](i);postMessage({id:a,method:e,success:!0,response:t})}catch(t){postMessage({id:a,method:e,success:!1,response:t.message}),console.error(t)}})),postMessage({id:void 0,method:\"init\",success:!0,response:void 0});`;\n","import { WINDOW } from '../constants';\n\n/** If sessionStorage is available. */\nexport function hasSessionStorage(): boolean {\n try {\n // This can throw, e.g. when being accessed in a sandboxed iframe\n return 'sessionStorage' in WINDOW && !!WINDOW.sessionStorage;\n } catch {\n return false;\n }\n}\n","import { REPLAY_SESSION_KEY, WINDOW } from '../../src/constants';\nimport type { ReplayContainer } from '../../src/types';\nimport { hasSessionStorage } from '../util/hasSessionStorage';\n\n/**\n * Removes the session from Session Storage and unsets session in replay instance\n */\nexport function clearSession(replay: ReplayContainer): void {\n deleteSession();\n replay.session = undefined;\n}\n\n/**\n * Deletes a session from storage\n */\nfunction deleteSession(): void {\n if (!hasSessionStorage()) {\n return;\n }\n\n try {\n WINDOW.sessionStorage.removeItem(REPLAY_SESSION_KEY);\n } catch {\n // Ignore potential SecurityError exceptions\n }\n}\n","/**\n * Given an initial timestamp and an expiry duration, checks to see if current\n * time should be considered as expired.\n */\nexport function isExpired(\n initialTime: null | number,\n expiry: undefined | number,\n targetTime: number = +new Date(),\n): boolean {\n // Always expired if < 0\n if (initialTime === null || expiry === undefined || expiry < 0) {\n return true;\n }\n\n // Never expires if == 0\n if (expiry === 0) {\n return false;\n }\n\n return initialTime + expiry <= targetTime;\n}\n","import type { Session, Timeouts } from '../types';\nimport { isExpired } from './isExpired';\n\n/**\n * Checks to see if session is expired\n */\nexport function isSessionExpired(session: Session, timeouts: Timeouts, targetTime: number = +new Date()): boolean {\n return (\n // First, check that maximum session length has not been exceeded\n isExpired(session.started, timeouts.maxSessionLife, targetTime) ||\n // check that the idle timeout has not been exceeded (i.e. user has\n // performed an action within the last `sessionIdleExpire` ms)\n isExpired(session.lastActivity, timeouts.sessionIdleExpire, targetTime)\n );\n}\n","/**\n * Given a sample rate, returns true if replay should be sampled.\n *\n * 1.0 = 100% sampling\n * 0.0 = 0% sampling\n */\nexport function isSampled(sampleRate?: number): boolean {\n if (sampleRate === undefined) {\n return false;\n }\n\n // Math.random() returns a number in range of 0 to 1 (inclusive of 0, but not 1)\n return Math.random() < sampleRate;\n}\n","import { REPLAY_SESSION_KEY, WINDOW } from '../constants';\nimport type { Session } from '../types';\nimport { hasSessionStorage } from '../util/hasSessionStorage';\n\n/**\n * Save a session to session storage.\n */\nexport function saveSession(session: Session): void {\n if (!hasSessionStorage()) {\n return;\n }\n\n try {\n WINDOW.sessionStorage.setItem(REPLAY_SESSION_KEY, JSON.stringify(session));\n } catch {\n // Ignore potential SecurityError exceptions\n }\n}\n","import { uuid4 } from '@sentry/utils';\n\nimport type { Sampled, Session } from '../types';\n\n/**\n * Get a session with defaults & applied sampling.\n */\nexport function makeSession(session: Partial<Session> & { sampled: Sampled }): Session {\n const now = Date.now();\n const id = session.id || uuid4();\n // Note that this means we cannot set a started/lastActivity of `0`, but this should not be relevant outside of tests.\n const started = session.started || now;\n const lastActivity = session.lastActivity || now;\n const segmentId = session.segmentId || 0;\n const sampled = session.sampled;\n const shouldRefresh = typeof session.shouldRefresh === 'boolean' ? session.shouldRefresh : true;\n\n return {\n id,\n started,\n lastActivity,\n segmentId,\n sampled,\n shouldRefresh,\n };\n}\n","import type { Sampled, Session, SessionOptions } from '../types';\nimport { isSampled } from '../util/isSampled';\nimport { saveSession } from './saveSession';\nimport { makeSession } from './Session';\n\n/**\n * Get the sampled status for a session based on sample rates & current sampled status.\n */\nexport function getSessionSampleType(sessionSampleRate: number, allowBuffering: boolean): Sampled {\n return isSampled(sessionSampleRate) ? 'session' : allowBuffering ? 'buffer' : false;\n}\n\n/**\n * Create a new session, which in its current implementation is a Sentry event\n * that all replays will be saved to as attachments. Currently, we only expect\n * one of these Sentry events per \"replay session\".\n */\nexport function createSession({ sessionSampleRate, allowBuffering, stickySession = false }: SessionOptions): Session {\n const sampled = getSessionSampleType(sessionSampleRate, allowBuffering);\n const session = makeSession({\n sampled,\n });\n\n if (stickySession) {\n saveSession(session);\n }\n\n return session;\n}\n","import type { Session, SessionOptions, Timeouts } from '../types';\nimport { isSessionExpired } from '../util/isSessionExpired';\nimport { logInfoNextTick } from '../util/log';\nimport { createSession } from './createSession';\nimport { fetchSession } from './fetchSession';\nimport { makeSession } from './Session';\n\ninterface GetSessionParams extends SessionOptions {\n timeouts: Timeouts;\n\n /**\n * The current session (e.g. if stickySession is off)\n */\n currentSession?: Session;\n\n traceInternals?: boolean;\n}\n\n/**\n * Get or create a session\n */\nexport function getSession({\n timeouts,\n currentSession,\n stickySession,\n sessionSampleRate,\n allowBuffering,\n traceInternals,\n}: GetSessionParams): { type: 'new' | 'saved'; session: Session } {\n // If session exists and is passed, use it instead of always hitting session storage\n const session = currentSession || (stickySession && fetchSession(traceInternals));\n\n if (session) {\n // If there is a session, check if it is valid (e.g. \"last activity\" time\n // should be within the \"session idle time\", and \"session started\" time is\n // within \"max session time\").\n const isExpired = isSessionExpired(session, timeouts);\n\n if (!isExpired || (allowBuffering && session.shouldRefresh)) {\n return { type: 'saved', session };\n } else if (!session.shouldRefresh) {\n // This is the case if we have an error session that is completed\n // (=triggered an error). Session will continue as session-based replay,\n // and when this session is expired, it will not be renewed until user\n // reloads.\n const discardedSession = makeSession({ sampled: false });\n logInfoNextTick('[Replay] Session should not be refreshed', traceInternals);\n return { type: 'new', session: discardedSession };\n } else {\n logInfoNextTick('[Replay] Session has expired', traceInternals);\n }\n // Otherwise continue to create a new session\n }\n\n const newSession = createSession({\n stickySession,\n sessionSampleRate,\n allowBuffering,\n });\n logInfoNextTick('[Replay] Created new session', traceInternals);\n\n return { type: 'new', session: newSession };\n}\n","import { REPLAY_SESSION_KEY, WINDOW } from '../constants';\nimport type { Session } from '../types';\nimport { hasSessionStorage } from '../util/hasSessionStorage';\nimport { logInfoNextTick } from '../util/log';\nimport { makeSession } from './Session';\n\n/**\n * Fetches a session from storage\n */\nexport function fetchSession(traceInternals?: boolean): Session | null {\n if (!hasSessionStorage()) {\n return null;\n }\n\n try {\n // This can throw if cookies are disabled\n const sessionStringFromStorage = WINDOW.sessionStorage.getItem(REPLAY_SESSION_KEY);\n\n if (!sessionStringFromStorage) {\n return null;\n }\n\n const sessionObj = JSON.parse(sessionStringFromStorage) as Session;\n\n logInfoNextTick('[Replay] Loading existing session', traceInternals);\n\n return makeSession(sessionObj);\n } catch {\n return null;\n }\n}\n","import { EventType } from '@sentry-internal/rrweb';\nimport { getCurrentHub } from '@sentry/core';\nimport { logger } from '@sentry/utils';\n\nimport { EventBufferSizeExceededError } from '../eventBuffer/error';\nimport type { AddEventResult, RecordingEvent, ReplayContainer, ReplayFrameEvent, ReplayPluginOptions } from '../types';\nimport { logInfo } from './log';\nimport { timestampToMs } from './timestamp';\n\nfunction isCustomEvent(event: RecordingEvent): event is ReplayFrameEvent {\n return event.type === EventType.Custom;\n}\n\n/**\n * Add an event to the event buffer.\n * `isCheckout` is true if this is either the very first event, or an event triggered by `checkoutEveryNms`.\n */\nexport async function addEvent(\n replay: ReplayContainer,\n event: RecordingEvent,\n isCheckout?: boolean,\n): Promise<AddEventResult | null> {\n if (!replay.eventBuffer) {\n // This implies that `_isEnabled` is false\n return null;\n }\n\n if (replay.isPaused()) {\n // Do not add to event buffer when recording is paused\n return null;\n }\n\n const timestampInMs = timestampToMs(event.timestamp);\n\n // Throw out events that happen more than 5 minutes ago. This can happen if\n // page has been left open and idle for a long period of time and user\n // comes back to trigger a new session. The performance entries rely on\n // `performance.timeOrigin`, which is when the page first opened.\n if (timestampInMs + replay.timeouts.sessionIdlePause < Date.now()) {\n return null;\n }\n\n // Throw out events that are +60min from the initial timestamp\n if (timestampInMs > replay.getContext().initialTimestamp + replay.timeouts.maxSessionLife) {\n logInfo(\n `[Replay] Skipping event with timestamp ${timestampInMs} because it is after maxSessionLife`,\n replay.getOptions()._experiments.traceInternals,\n );\n return null;\n }\n\n try {\n if (isCheckout && replay.recordingMode === 'buffer') {\n replay.eventBuffer.clear();\n }\n\n if (isCheckout) {\n replay.eventBuffer.hasCheckout = true;\n }\n\n const replayOptions = replay.getOptions();\n\n const eventAfterPossibleCallback = maybeApplyCallback(event, replayOptions.beforeAddRecordingEvent);\n\n if (!eventAfterPossibleCallback) {\n return;\n }\n\n return await replay.eventBuffer.addEvent(eventAfterPossibleCallback);\n } catch (error) {\n const reason = error && error instanceof EventBufferSizeExceededError ? 'addEventSizeExceeded' : 'addEvent';\n\n __DEBUG_BUILD__ && logger.error(error);\n await replay.stop({ reason });\n\n const client = getCurrentHub().getClient();\n\n if (client) {\n client.recordDroppedEvent('internal_sdk_error', 'replay');\n }\n }\n}\n\nfunction maybeApplyCallback(\n event: RecordingEvent,\n callback: ReplayPluginOptions['beforeAddRecordingEvent'],\n): RecordingEvent | null | undefined {\n try {\n if (typeof callback === 'function' && isCustomEvent(event)) {\n return callback(event);\n }\n } catch (error) {\n __DEBUG_BUILD__ &&\n logger.error('[Replay] An error occured in the `beforeAddRecordingEvent` callback, skipping the event...', error);\n return null;\n }\n\n return event;\n}\n","import type { ErrorEvent, Event, ReplayEvent, TransactionEvent } from '@sentry/types';\n\n/** If the event is an error event */\nexport function isErrorEvent(event: Event): event is ErrorEvent {\n return !event.type;\n}\n\n/** If the event is a transaction event */\nexport function isTransactionEvent(event: Event): event is TransactionEvent {\n return event.type === 'transaction';\n}\n\n/** If the event is an replay event */\nexport function isReplayEvent(event: Event): event is ReplayEvent {\n return event.type === 'replay_event';\n}\n","import { getCurrentHub } from '@sentry/core';\nimport type { ErrorEvent, Event, TransactionEvent, Transport, TransportMakeRequestResponse } from '@sentry/types';\n\nimport type { ReplayContainer } from '../types';\nimport { isErrorEvent, isTransactionEvent } from '../util/eventUtils';\n\ntype AfterSendEventCallback = (event: Event, sendResponse: TransportMakeRequestResponse | void) => void;\n\n/**\n * Returns a listener to be added to `client.on('afterSendErrorEvent, listener)`.\n */\nexport function handleAfterSendEvent(replay: ReplayContainer): AfterSendEventCallback {\n // Custom transports may still be returning `Promise<void>`, which means we cannot expect the status code to be available there\n // TODO (v8): remove this check as it will no longer be necessary\n const enforceStatusCode = isBaseTransportSend();\n\n return (event: Event, sendResponse: TransportMakeRequestResponse | void) => {\n if (!replay.isEnabled() || (!isErrorEvent(event) && !isTransactionEvent(event))) {\n return;\n }\n\n const statusCode = sendResponse && sendResponse.statusCode;\n\n // We only want to do stuff on successful error sending, otherwise you get error replays without errors attached\n // If not using the base transport, we allow `undefined` response (as a custom transport may not implement this correctly yet)\n // If we do use the base transport, we skip if we encountered an non-OK status code\n if (enforceStatusCode && (!statusCode || statusCode < 200 || statusCode >= 300)) {\n return;\n }\n\n if (isTransactionEvent(event)) {\n handleTransactionEvent(replay, event);\n return;\n }\n\n handleErrorEvent(replay, event);\n };\n}\n\nfunction handleTransactionEvent(replay: ReplayContainer, event: TransactionEvent): void {\n const replayContext = replay.getContext();\n\n // Collect traceIds in _context regardless of `recordingMode`\n // In error mode, _context gets cleared on every checkout\n // We limit to max. 100 transactions linked\n if (event.contexts && event.contexts.trace && event.contexts.trace.trace_id && replayContext.traceIds.size < 100) {\n replayContext.traceIds.add(event.contexts.trace.trace_id as string);\n }\n}\n\nfunction handleErrorEvent(replay: ReplayContainer, event: ErrorEvent): void {\n const replayContext = replay.getContext();\n\n // Add error to list of errorIds of replay. This is ok to do even if not\n // sampled because context will get reset at next checkout.\n // XXX: There is also a race condition where it's possible to capture an\n // error to Sentry before Replay SDK has loaded, but response returns after\n // it was loaded, and this gets called.\n // We limit to max. 100 errors linked\n if (event.event_id && replayContext.errorIds.size < 100) {\n replayContext.errorIds.add(event.event_id);\n }\n\n // If error event is tagged with replay id it means it was sampled (when in buffer mode)\n // Need to be very careful that this does not cause an infinite loop\n if (replay.recordingMode === 'buffer' && event.tags && event.tags.replayId) {\n setTimeout(() => {\n // Capture current event buffer as new replay\n void replay.sendBufferedReplayOrFlush();\n });\n }\n}\n\nfunction isBaseTransportSend(): boolean {\n const client = getCurrentHub().getClient();\n if (!client) {\n return false;\n }\n\n const transport = client.getTransport();\n if (!transport) {\n return false;\n }\n\n return (\n (transport.send as Transport['send'] & { __sentry__baseTransport__?: true }).__sentry__baseTransport__ || false\n );\n}\n","import type { Event, EventHint } from '@sentry/types';\n\n/**\n * Returns true if we think the given event is an error originating inside of rrweb.\n */\nexport function isRrwebError(event: Event, hint: EventHint): boolean {\n if (event.type || !event.exception || !event.exception.values || !event.exception.values.length) {\n return false;\n }\n\n // @ts-ignore this may be set by rrweb when it finds errors\n if (hint.originalException && hint.originalException.__rrweb__) {\n return true;\n }\n\n // Check if any exception originates from rrweb\n return event.exception.values.some(exception => {\n if (!exception.stacktrace || !exception.stacktrace.frames || !exception.stacktrace.frames.length) {\n return false;\n }\n\n return exception.stacktrace.frames.some(frame => frame.filename && frame.filename.includes('/rrweb/src/'));\n });\n}\n","import type { Event } from '@sentry/types';\n\nimport { UNABLE_TO_SEND_REPLAY } from '../../constants';\nimport type { ReplayContainer } from '../../types';\nimport { isSampled } from '../../util/isSampled';\n\n/**\n * Determine if event should be sampled (only applies in buffer mode).\n * When an event is captured by `hanldleGlobalEvent`, when in buffer mode\n * we determine if we want to sample the error or not.\n */\nexport function shouldSampleForBufferEvent(replay: ReplayContainer, event: Event): boolean {\n if (replay.recordingMode !== 'buffer') {\n return false;\n }\n\n // ignore this error because otherwise we could loop indefinitely with\n // trying to capture replay and failing\n if (event.message === UNABLE_TO_SEND_REPLAY) {\n return false;\n }\n\n // Require the event to be an error event & to have an exception\n if (!event.exception || event.type) {\n return false;\n }\n\n return isSampled(replay.getOptions().errorSampleRate);\n}\n","import { EventType } from '@sentry-internal/rrweb';\n\nimport type { AddEventResult, AllEntryData, ReplayContainer, ReplayPerformanceEntry } from '../types';\n\n/**\n * Create a \"span\" for each performance entry.\n */\nexport function createPerformanceSpans(\n replay: ReplayContainer,\n entries: ReplayPerformanceEntry<AllEntryData>[],\n): Promise<AddEventResult | null>[] {\n return entries.map(({ type, start, end, name, data }) => {\n const response = replay.throttledAddEvent({\n type: EventType.Custom,\n timestamp: start,\n data: {\n tag: 'performanceSpan',\n payload: {\n op: type,\n description: name,\n startTimestamp: start,\n endTimestamp: end,\n data,\n },\n },\n });\n\n // If response is a string, it means its either THROTTLED or SKIPPED\n return typeof response === 'string' ? Promise.resolve(null) : response;\n });\n}\n","import type { HistoryData, ReplayContainer, ReplayPerformanceEntry } from '../types';\nimport { createPerformanceSpans } from '../util/createPerformanceSpans';\n\ninterface HistoryHandlerData {\n from: string;\n to: string;\n}\n\nfunction handleHistory(handlerData: HistoryHandlerData): ReplayPerformanceEntry<HistoryData> {\n const { from, to } = handlerData;\n\n const now = Date.now() / 1000;\n\n return {\n type: 'navigation.push',\n start: now,\n end: now,\n name: to,\n data: {\n previous: from,\n },\n };\n}\n\n/**\n * Returns a listener to be added to `addInstrumentationHandler('history', listener)`.\n */\nexport function handleHistorySpanListener(replay: ReplayContainer): (handlerData: HistoryHandlerData) => void {\n return (handlerData: HistoryHandlerData) => {\n if (!replay.isEnabled()) {\n return;\n }\n\n const result = handleHistory(handlerData);\n\n if (result === null) {\n return;\n }\n\n // Need to collect visited URLs\n replay.getContext().urls.push(result.name);\n replay.triggerUserActivity();\n\n replay.addUpdate(() => {\n createPerformanceSpans(replay, [result]);\n // Returning false to flush\n return false;\n });\n };\n}\n","import { getCurrentHub } from '@sentry/core';\n\nimport type { ReplayContainer } from '../types';\n\n/**\n * Check whether a given request URL should be filtered out. This is so we\n * don't log Sentry ingest requests.\n */\nexport function shouldFilterRequest(replay: ReplayContainer, url: string): boolean {\n // If we enabled the `traceInternals` experiment, we want to trace everything\n if (__DEBUG_BUILD__ && replay.getOptions()._experiments.traceInternals) {\n return false;\n }\n\n return _isSentryRequest(url);\n}\n\n/**\n * Checks wether a given URL belongs to the configured Sentry DSN.\n */\nfunction _isSentryRequest(url: string): boolean {\n const client = getCurrentHub().getClient();\n const dsn = client && client.getDsn();\n return dsn ? url.includes(dsn.host) : false;\n}\n","import type { NetworkRequestData, ReplayContainer, ReplayPerformanceEntry } from '../../types';\nimport { createPerformanceSpans } from '../../util/createPerformanceSpans';\nimport { shouldFilterRequest } from '../../util/shouldFilterRequest';\n\n/** Add a performance entry breadcrumb */\nexport function addNetworkBreadcrumb(\n replay: ReplayContainer,\n result: ReplayPerformanceEntry<NetworkRequestData> | null,\n): void {\n if (!replay.isEnabled()) {\n return;\n }\n\n if (result === null) {\n return;\n }\n\n if (shouldFilterRequest(replay, result.name)) {\n return;\n }\n\n replay.addUpdate(() => {\n createPerformanceSpans(replay, [result]);\n // Returning true will cause `addUpdate` to not flush\n // We do not want network requests to cause a flush. This will prevent\n // recurring/polling requests from keeping the replay session alive.\n return true;\n });\n}\n","export const OBJ = 10;\nexport const OBJ_KEY = 11;\nexport const OBJ_KEY_STR = 12;\nexport const OBJ_VAL = 13;\nexport const OBJ_VAL_STR = 14;\nexport const OBJ_VAL_COMPLETED = 15;\n\nexport const ARR = 20;\nexport const ARR_VAL = 21;\nexport const ARR_VAL_STR = 22;\nexport const ARR_VAL_COMPLETED = 23;\n\nexport type JsonToken =\n | typeof OBJ\n | typeof OBJ_KEY\n | typeof OBJ_KEY_STR\n | typeof OBJ_VAL\n | typeof OBJ_VAL_STR\n | typeof OBJ_VAL_COMPLETED\n | typeof ARR\n | typeof ARR_VAL\n | typeof ARR_VAL_STR\n | typeof ARR_VAL_COMPLETED;\n","import type { JsonToken } from './constants';\nimport {\n ARR,\n ARR_VAL,\n ARR_VAL_COMPLETED,\n ARR_VAL_STR,\n OBJ,\n OBJ_KEY,\n OBJ_KEY_STR,\n OBJ_VAL,\n OBJ_VAL_COMPLETED,\n OBJ_VAL_STR,\n} from './constants';\n\nconst ALLOWED_PRIMITIVES = ['true', 'false', 'null'];\n\n/**\n * Complete an incomplete JSON string.\n * This will ensure that the last element always has a `\"~~\"` to indicate it was truncated.\n * For example, `[1,2,` will be completed to `[1,2,\"~~\"]`\n * and `{\"aa\":\"b` will be completed to `{\"aa\":\"b~~\"}`\n */\nexport function completeJson(incompleteJson: string, stack: JsonToken[]): string {\n if (!stack.length) {\n return incompleteJson;\n }\n\n let json = incompleteJson;\n\n // Most checks are only needed for the last step in the stack\n const lastPos = stack.length - 1;\n const lastStep = stack[lastPos];\n\n json = _fixLastStep(json, lastStep);\n\n // Complete remaining steps - just add closing brackets\n for (let i = lastPos; i >= 0; i--) {\n const step = stack[i];\n\n switch (step) {\n case OBJ:\n json = `${json}}`;\n break;\n case ARR:\n json = `${json}]`;\n break;\n }\n }\n\n return json;\n}\n\nfunction _fixLastStep(json: string, lastStep: JsonToken): string {\n switch (lastStep) {\n // Object cases\n case OBJ:\n return `${json}\"~~\":\"~~\"`;\n case OBJ_KEY:\n return `${json}:\"~~\"`;\n case OBJ_KEY_STR:\n return `${json}~~\":\"~~\"`;\n case OBJ_VAL:\n return _maybeFixIncompleteObjValue(json);\n case OBJ_VAL_STR:\n return `${json}~~\"`;\n case OBJ_VAL_COMPLETED:\n return `${json},\"~~\":\"~~\"`;\n\n // Array cases\n case ARR:\n return `${json}\"~~\"`;\n case ARR_VAL:\n return _maybeFixIncompleteArrValue(json);\n case ARR_VAL_STR:\n return `${json}~~\"`;\n case ARR_VAL_COMPLETED:\n return `${json},\"~~\"`;\n }\n\n return json;\n}\n\nfunction _maybeFixIncompleteArrValue(json: string): string {\n const pos = _findLastArrayDelimiter(json);\n\n if (pos > -1) {\n const part = json.slice(pos + 1);\n\n if (ALLOWED_PRIMITIVES.includes(part.trim())) {\n return `${json},\"~~\"`;\n }\n\n // Everything else is replaced with `\"~~\"`\n return `${json.slice(0, pos + 1)}\"~~\"`;\n }\n\n // fallback, this shouldn't happen, to be save\n return json;\n}\n\nfunction _findLastArrayDelimiter(json: string): number {\n for (let i = json.length - 1; i >= 0; i--) {\n const char = json[i];\n\n if (char === ',' || char === '[') {\n return i;\n }\n }\n\n return -1;\n}\n\nfunction _maybeFixIncompleteObjValue(json: string): string {\n const startPos = json.lastIndexOf(':');\n\n const part = json.slice(startPos + 1);\n\n if (ALLOWED_PRIMITIVES.includes(part.trim())) {\n return `${json},\"~~\":\"~~\"`;\n }\n\n // Everything else is replaced with `\"~~\"`\n // This also means we do not have incomplete numbers, e.g `[1` is replaced with `[\"~~\"]`\n return `${json.slice(0, startPos + 1)}\"~~\"`;\n}\n","import type { JsonToken } from './constants';\nimport {\n ARR,\n ARR_VAL,\n ARR_VAL_COMPLETED,\n ARR_VAL_STR,\n OBJ,\n OBJ_KEY,\n OBJ_KEY_STR,\n OBJ_VAL,\n OBJ_VAL_COMPLETED,\n OBJ_VAL_STR,\n} from './constants';\n\n/**\n * Evaluate an (incomplete) JSON string.\n */\nexport function evaluateJson(json: string): JsonToken[] {\n const stack: JsonToken[] = [];\n\n for (let pos = 0; pos < json.length; pos++) {\n _evaluateJsonPos(stack, json, pos);\n }\n\n return stack;\n}\n\nfunction _evaluateJsonPos(stack: JsonToken[], json: string, pos: number): void {\n const curStep = stack[stack.length - 1];\n\n const char = json[pos];\n\n const whitespaceRegex = /\\s/;\n\n if (whitespaceRegex.test(char)) {\n return;\n }\n\n if (char === '\"' && !_isEscaped(json, pos)) {\n _handleQuote(stack, curStep);\n return;\n }\n\n switch (char) {\n case '{':\n _handleObj(stack, curStep);\n break;\n case '[':\n _handleArr(stack, curStep);\n break;\n case ':':\n _handleColon(stack, curStep);\n break;\n case ',':\n _handleComma(stack, curStep);\n break;\n case '}':\n _handleObjClose(stack, curStep);\n break;\n case ']':\n _handleArrClose(stack, curStep);\n break;\n }\n}\n\nfunction _handleQuote(stack: JsonToken[], curStep: JsonToken): void {\n // End of obj value\n if (curStep === OBJ_VAL_STR) {\n stack.pop();\n stack.push(OBJ_VAL_COMPLETED);\n return;\n }\n\n // End of arr value\n if (curStep === ARR_VAL_STR) {\n stack.pop();\n stack.push(ARR_VAL_COMPLETED);\n return;\n }\n\n // Start of obj value\n if (curStep === OBJ_VAL) {\n stack.push(OBJ_VAL_STR);\n return;\n }\n\n // Start of arr value\n if (curStep === ARR_VAL) {\n stack.push(ARR_VAL_STR);\n return;\n }\n\n // Start of obj key\n if (curStep === OBJ) {\n stack.push(OBJ_KEY_STR);\n return;\n }\n\n // End of obj key\n if (curStep === OBJ_KEY_STR) {\n stack.pop();\n stack.push(OBJ_KEY);\n return;\n }\n}\n\nfunction _handleObj(stack: JsonToken[], curStep: JsonToken): void {\n // Initial object\n if (!curStep) {\n stack.push(OBJ);\n return;\n }\n\n // New object as obj value\n if (curStep === OBJ_VAL) {\n stack.push(OBJ);\n return;\n }\n\n // New object as array element\n if (curStep === ARR_VAL) {\n stack.push(OBJ);\n }\n\n // New object as first array element\n if (curStep === ARR) {\n stack.push(OBJ);\n return;\n }\n}\n\nfunction _handleArr(stack: JsonToken[], curStep: JsonToken): void {\n // Initial array\n if (!curStep) {\n stack.push(ARR);\n stack.push(ARR_VAL);\n return;\n }\n\n // New array as obj value\n if (curStep === OBJ_VAL) {\n stack.push(ARR);\n stack.push(ARR_VAL);\n return;\n }\n\n // New array as array element\n if (curStep === ARR_VAL) {\n stack.push(ARR);\n stack.push(ARR_VAL);\n }\n\n // New array as first array element\n if (curStep === ARR) {\n stack.push(ARR);\n stack.push(ARR_VAL);\n return;\n }\n}\n\nfunction _handleColon(stack: JsonToken[], curStep: JsonToken): void {\n if (curStep === OBJ_KEY) {\n stack.pop();\n stack.push(OBJ_VAL);\n }\n}\n\nfunction _handleComma(stack: JsonToken[], curStep: JsonToken): void {\n // Comma after obj value\n if (curStep === OBJ_VAL) {\n stack.pop();\n return;\n }\n if (curStep === OBJ_VAL_COMPLETED) {\n // Pop OBJ_VAL_COMPLETED & OBJ_VAL\n stack.pop();\n stack.pop();\n return;\n }\n\n // Comma after arr value\n if (curStep === ARR_VAL) {\n // do nothing - basically we'd pop ARR_VAL but add it right back\n return;\n }\n\n if (curStep === ARR_VAL_COMPLETED) {\n // Pop ARR_VAL_COMPLETED\n stack.pop();\n\n // basically we'd pop ARR_VAL but add it right back\n return;\n }\n}\n\nfunction _handleObjClose(stack: JsonToken[], curStep: JsonToken): void {\n // Empty object {}\n if (curStep === OBJ) {\n stack.pop();\n }\n\n // Object with element\n if (curStep === OBJ_VAL) {\n // Pop OBJ_VAL, OBJ\n stack.pop();\n stack.pop();\n }\n\n // Obj with element\n if (curStep === OBJ_VAL_COMPLETED) {\n // Pop OBJ_VAL_COMPLETED, OBJ_VAL, OBJ\n stack.pop();\n stack.pop();\n stack.pop();\n }\n\n // if was obj value, complete it\n if (stack[stack.length - 1] === OBJ_VAL) {\n stack.push(OBJ_VAL_COMPLETED);\n }\n\n // if was arr value, complete it\n if (stack[stack.length - 1] === ARR_VAL) {\n stack.push(ARR_VAL_COMPLETED);\n }\n}\n\nfunction _handleArrClose(stack: JsonToken[], curStep: JsonToken): void {\n // Empty array []\n if (curStep === ARR) {\n stack.pop();\n }\n\n // Array with element\n if (curStep === ARR_VAL) {\n // Pop ARR_VAL, ARR\n stack.pop();\n stack.pop();\n }\n\n // Array with element\n if (curStep === ARR_VAL_COMPLETED) {\n // Pop ARR_VAL_COMPLETED, ARR_VAL, ARR\n stack.pop();\n stack.pop();\n stack.pop();\n }\n\n // if was obj value, complete it\n if (stack[stack.length - 1] === OBJ_VAL) {\n stack.push(OBJ_VAL_COMPLETED);\n }\n\n // if was arr value, complete it\n if (stack[stack.length - 1] === ARR_VAL) {\n stack.push(ARR_VAL_COMPLETED);\n }\n}\n\nfunction _isEscaped(str: string, pos: number): boolean {\n const previousChar = str[pos - 1];\n\n return previousChar === '\\\\' && !_isEscaped(str, pos - 1);\n}\n","/* eslint-disable max-lines */\n\nimport { completeJson } from './completeJson';\nimport { evaluateJson } from './evaluateJson';\n\n/**\n * Takes an incomplete JSON string, and returns a hopefully valid JSON string.\n * Note that this _can_ fail, so you should check the return value is valid JSON.\n */\nexport function fixJson(incompleteJson: string): string {\n const stack = evaluateJson(incompleteJson);\n\n return completeJson(incompleteJson, stack);\n}\n","import type { TextEncoderInternal } from '@sentry/types';\nimport { dropUndefinedKeys, stringMatchesSomePattern } from '@sentry/utils';\n\nimport { NETWORK_BODY_MAX_SIZE, WINDOW } from '../../constants';\nimport type {\n NetworkBody,\n NetworkMetaWarning,\n NetworkRequestData,\n ReplayNetworkRequestData,\n ReplayNetworkRequestOrResponse,\n ReplayPerformanceEntry,\n} from '../../types';\nimport { fixJson } from '../../util/truncateJson/fixJson';\n\n/** Get the size of a body. */\nexport function getBodySize(\n body: RequestInit['body'],\n textEncoder: TextEncoder | TextEncoderInternal,\n): number | undefined {\n if (!body) {\n return undefined;\n }\n\n try {\n if (typeof body === 'string') {\n return textEncoder.encode(body).length;\n }\n\n if (body instanceof URLSearchParams) {\n return textEncoder.encode(body.toString()).length;\n }\n\n if (body instanceof FormData) {\n const formDataStr = _serializeFormData(body);\n return textEncoder.encode(formDataStr).length;\n }\n\n if (body instanceof Blob) {\n return body.size;\n }\n\n if (body instanceof ArrayBuffer) {\n return body.byteLength;\n }\n\n // Currently unhandled types: ArrayBufferView, ReadableStream\n } catch {\n // just return undefined\n }\n\n return undefined;\n}\n\n/** Convert a Content-Length header to number/undefined. */\nexport function parseContentLengthHeader(header: string | null | undefined): number | undefined {\n if (!header) {\n return undefined;\n }\n\n const size = parseInt(header, 10);\n return isNaN(size) ? undefined : size;\n}\n\n/** Get the string representation of a body. */\nexport function getBodyString(body: unknown): string | undefined {\n if (typeof body === 'string') {\n return body;\n }\n\n if (body instanceof URLSearchParams) {\n return body.toString();\n }\n\n if (body instanceof FormData) {\n return _serializeFormData(body);\n }\n\n return undefined;\n}\n\n/** Convert ReplayNetworkRequestData to a PerformanceEntry. */\nexport function makeNetworkReplayBreadcrumb(\n type: string,\n data: ReplayNetworkRequestData | null,\n): ReplayPerformanceEntry<NetworkRequestData> | null {\n if (!data) {\n return null;\n }\n\n const { startTimestamp, endTimestamp, url, method, statusCode, request, response } = data;\n\n const result: ReplayPerformanceEntry<NetworkRequestData> = {\n type,\n start: startTimestamp / 1000,\n end: endTimestamp / 1000,\n name: url,\n data: dropUndefinedKeys({\n method,\n statusCode,\n request,\n response,\n }),\n };\n\n return result;\n}\n\n/** Get either a JSON network body, or a text representation. */\nexport function getNetworkBody(bodyText: string | undefined): NetworkBody | undefined {\n if (!bodyText) {\n return;\n }\n\n try {\n return JSON.parse(bodyText);\n } catch {\n // return text\n }\n\n return bodyText;\n}\n\n/** Build the request or response part of a replay network breadcrumb that was skipped. */\nexport function buildSkippedNetworkRequestOrResponse(bodySize: number | undefined): ReplayNetworkRequestOrResponse {\n return {\n headers: {},\n size: bodySize,\n _meta: {\n warnings: ['URL_SKIPPED'],\n },\n };\n}\n\n/** Build the request or response part of a replay network breadcrumb. */\nexport function buildNetworkRequestOrResponse(\n headers: Record<string, string>,\n bodySize: number | undefined,\n body: string | undefined,\n): ReplayNetworkRequestOrResponse | undefined {\n if (!bodySize && Object.keys(headers).length === 0) {\n return undefined;\n }\n\n if (!bodySize) {\n return {\n headers,\n };\n }\n\n if (!body) {\n return {\n headers,\n size: bodySize,\n };\n }\n\n const info: ReplayNetworkRequestOrResponse = {\n headers,\n size: bodySize,\n };\n\n const { body: normalizedBody, warnings } = normalizeNetworkBody(body);\n info.body = normalizedBody;\n if (warnings.length > 0) {\n info._meta = {\n warnings,\n };\n }\n\n return info;\n}\n\n/** Filter a set of headers */\nexport function getAllowedHeaders(headers: Record<string, string>, allowedHeaders: string[]): Record<string, string> {\n return Object.keys(headers).reduce((filteredHeaders: Record<string, string>, key: string) => {\n const normalizedKey = key.toLowerCase();\n // Avoid putting empty strings into the headers\n if (allowedHeaders.includes(normalizedKey) && headers[key]) {\n filteredHeaders[normalizedKey] = headers[key];\n }\n return filteredHeaders;\n }, {});\n}\n\nfunction _serializeFormData(formData: FormData): string {\n // This is a bit simplified, but gives us a decent estimate\n // This converts e.g. { name: 'Anne Smith', age: 13 } to 'name=Anne+Smith&age=13'\n // @ts-ignore passing FormData to URLSearchParams actually works\n return new URLSearchParams(formData).toString();\n}\n\nfunction normalizeNetworkBody(body: string | undefined): {\n body: NetworkBody | undefined;\n warnings: NetworkMetaWarning[];\n} {\n if (!body || typeof body !== 'string') {\n return {\n body,\n warnings: [],\n };\n }\n\n const exceedsSizeLimit = body.length > NETWORK_BODY_MAX_SIZE;\n\n if (_strIsProbablyJson(body)) {\n try {\n const json = exceedsSizeLimit ? fixJson(body.slice(0, NETWORK_BODY_MAX_SIZE)) : body;\n const normalizedBody = JSON.parse(json);\n return {\n body: normalizedBody,\n warnings: exceedsSizeLimit ? ['JSON_TRUNCATED'] : [],\n };\n } catch {\n return {\n body: exceedsSizeLimit ? `${body.slice(0, NETWORK_BODY_MAX_SIZE)}…` : body,\n warnings: exceedsSizeLimit ? ['INVALID_JSON', 'TEXT_TRUNCATED'] : ['INVALID_JSON'],\n };\n }\n }\n\n return {\n body: exceedsSizeLimit ? `${body.slice(0, NETWORK_BODY_MAX_SIZE)}…` : body,\n warnings: exceedsSizeLimit ? ['TEXT_TRUNCATED'] : [],\n };\n}\n\nfunction _strIsProbablyJson(str: string): boolean {\n const first = str[0];\n const last = str[str.length - 1];\n\n // Simple check: If this does not start & end with {} or [], it's not JSON\n return (first === '[' && last === ']') || (first === '{' && last === '}');\n}\n\n/** Match an URL against a list of strings/Regex. */\nexport function urlMatches(url: string, urls: (string | RegExp)[]): boolean {\n const fullUrl = getFullUrl(url);\n\n return stringMatchesSomePattern(fullUrl, urls);\n}\n\n/** exported for tests */\nexport function getFullUrl(url: string, baseURI = WINDOW.document.baseURI): string {\n // Short circuit for common cases:\n if (url.startsWith('http://') || url.startsWith('https://') || url.startsWith(WINDOW.location.origin)) {\n return url;\n }\n const fixedUrl = new URL(url, baseURI);\n\n // If these do not match, we are not dealing with a relative URL, so just return it\n if (fixedUrl.origin !== new URL(baseURI).origin) {\n return url;\n }\n\n const fullUrl = fixedUrl.href;\n\n // Remove trailing slashes, if they don't match the original URL\n if (!url.endsWith('/') && fullUrl.endsWith('/')) {\n return fullUrl.slice(0, -1);\n }\n\n return fullUrl;\n}\n","import type { Breadcrumb, FetchBreadcrumbData, TextEncoderInternal } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport type {\n FetchHint,\n ReplayContainer,\n ReplayNetworkOptions,\n ReplayNetworkRequestData,\n ReplayNetworkRequestOrResponse,\n} from '../../types';\nimport { addNetworkBreadcrumb } from './addNetworkBreadcrumb';\nimport {\n buildNetworkRequestOrResponse,\n buildSkippedNetworkRequestOrResponse,\n getAllowedHeaders,\n getBodySize,\n getBodyString,\n makeNetworkReplayBreadcrumb,\n parseContentLengthHeader,\n urlMatches,\n} from './networkUtils';\n\n/**\n * Capture a fetch breadcrumb to a replay.\n * This adds additional data (where approriate).\n */\nexport async function captureFetchBreadcrumbToReplay(\n breadcrumb: Breadcrumb & { data: FetchBreadcrumbData },\n hint: FetchHint,\n options: ReplayNetworkOptions & {\n textEncoder: TextEncoderInternal;\n replay: ReplayContainer;\n },\n): Promise<void> {\n try {\n const data = await _prepareFetchData(breadcrumb, hint, options);\n\n // Create a replay performance entry from this breadcrumb\n const result = makeNetworkReplayBreadcrumb('resource.fetch', data);\n addNetworkBreadcrumb(options.replay, result);\n } catch (error) {\n __DEBUG_BUILD__ && logger.error('[Replay] Failed to capture fetch breadcrumb', error);\n }\n}\n\n/**\n * Enrich a breadcrumb with additional data.\n * This has to be sync & mutate the given breadcrumb,\n * as the breadcrumb is afterwards consumed by other handlers.\n */\nexport function enrichFetchBreadcrumb(\n breadcrumb: Breadcrumb & { data: FetchBreadcrumbData },\n hint: FetchHint,\n options: { textEncoder: TextEncoderInternal },\n): void {\n const { input, response } = hint;\n\n const body = _getFetchRequestArgBody(input);\n const reqSize = getBodySize(body, options.textEncoder);\n\n const resSize = response ? parseContentLengthHeader(response.headers.get('content-length')) : undefined;\n\n if (reqSize !== undefined) {\n breadcrumb.data.request_body_size = reqSize;\n }\n if (resSize !== undefined) {\n breadcrumb.data.response_body_size = resSize;\n }\n}\n\nasync function _prepareFetchData(\n breadcrumb: Breadcrumb & { data: FetchBreadcrumbData },\n hint: FetchHint,\n options: ReplayNetworkOptions & {\n textEncoder: TextEncoderInternal;\n },\n): Promise<ReplayNetworkRequestData> {\n const { startTimestamp, endTimestamp } = hint;\n\n const {\n url,\n method,\n status_code: statusCode = 0,\n request_body_size: requestBodySize,\n response_body_size: responseBodySize,\n } = breadcrumb.data;\n\n const captureDetails =\n urlMatches(url, options.networkDetailAllowUrls) && !urlMatches(url, options.networkDetailDenyUrls);\n\n const request = captureDetails\n ? _getRequestInfo(options, hint.input, requestBodySize)\n : buildSkippedNetworkRequestOrResponse(requestBodySize);\n const response = await _getResponseInfo(captureDetails, options, hint.response, responseBodySize);\n\n return {\n startTimestamp,\n endTimestamp,\n url,\n method,\n statusCode,\n request,\n response,\n };\n}\n\nfunction _getRequestInfo(\n { networkCaptureBodies, networkRequestHeaders }: ReplayNetworkOptions,\n input: FetchHint['input'],\n requestBodySize?: number,\n): ReplayNetworkRequestOrResponse | undefined {\n const headers = getRequestHeaders(input, networkRequestHeaders);\n\n if (!networkCaptureBodies) {\n return buildNetworkRequestOrResponse(headers, requestBodySize, undefined);\n }\n\n // We only want to transmit string or string-like bodies\n const requestBody = _getFetchRequestArgBody(input);\n const bodyStr = getBodyString(requestBody);\n return buildNetworkRequestOrResponse(headers, requestBodySize, bodyStr);\n}\n\nasync function _getResponseInfo(\n captureDetails: boolean,\n {\n networkCaptureBodies,\n textEncoder,\n networkResponseHeaders,\n }: ReplayNetworkOptions & {\n textEncoder: TextEncoderInternal;\n },\n response: Response,\n responseBodySize?: number,\n): Promise<ReplayNetworkRequestOrResponse | undefined> {\n if (!captureDetails && responseBodySize !== undefined) {\n return buildSkippedNetworkRequestOrResponse(responseBodySize);\n }\n\n const headers = getAllHeaders(response.headers, networkResponseHeaders);\n\n if (!networkCaptureBodies && responseBodySize !== undefined) {\n return buildNetworkRequestOrResponse(headers, responseBodySize, undefined);\n }\n\n // Only clone the response if we need to\n try {\n // We have to clone this, as the body can only be read once\n const res = response.clone();\n const bodyText = await _parseFetchBody(res);\n\n const size =\n bodyText && bodyText.length && responseBodySize === undefined\n ? getBodySize(bodyText, textEncoder)\n : responseBodySize;\n\n if (!captureDetails) {\n return buildSkippedNetworkRequestOrResponse(size);\n }\n\n if (networkCaptureBodies) {\n return buildNetworkRequestOrResponse(headers, size, bodyText);\n }\n\n return buildNetworkRequestOrResponse(headers, size, undefined);\n } catch {\n // fallback\n return buildNetworkRequestOrResponse(headers, responseBodySize, undefined);\n }\n}\n\nasync function _parseFetchBody(response: Response): Promise<string | undefined> {\n try {\n return await response.text();\n } catch {\n return undefined;\n }\n}\n\nfunction _getFetchRequestArgBody(fetchArgs: unknown[] = []): RequestInit['body'] | undefined {\n // We only support getting the body from the fetch options\n if (fetchArgs.length !== 2 || typeof fetchArgs[1] !== 'object') {\n return undefined;\n }\n\n return (fetchArgs[1] as RequestInit).body;\n}\n\nfunction getAllHeaders(headers: Headers, allowedHeaders: string[]): Record<string, string> {\n const allHeaders: Record<string, string> = {};\n\n allowedHeaders.forEach(header => {\n if (headers.get(header)) {\n allHeaders[header] = headers.get(header) as string;\n }\n });\n\n return allHeaders;\n}\n\nfunction getRequestHeaders(fetchArgs: unknown[], allowedHeaders: string[]): Record<string, string> {\n if (fetchArgs.length === 1 && typeof fetchArgs[0] !== 'string') {\n return getHeadersFromOptions(fetchArgs[0] as Request | RequestInit, allowedHeaders);\n }\n\n if (fetchArgs.length === 2) {\n return getHeadersFromOptions(fetchArgs[1] as Request | RequestInit, allowedHeaders);\n }\n\n return {};\n}\n\nfunction getHeadersFromOptions(\n input: Request | RequestInit | undefined,\n allowedHeaders: string[],\n): Record<string, string> {\n if (!input) {\n return {};\n }\n\n const headers = input.headers;\n\n if (!headers) {\n return {};\n }\n\n if (headers instanceof Headers) {\n return getAllHeaders(headers, allowedHeaders);\n }\n\n // We do not support this, as it is not really documented (anymore?)\n if (Array.isArray(headers)) {\n return {};\n }\n\n return getAllowedHeaders(headers, allowedHeaders);\n}\n","import type { Breadcrumb, TextEncoderInternal, XhrBreadcrumbData } from '@sentry/types';\nimport { logger, SENTRY_XHR_DATA_KEY } from '@sentry/utils';\n\nimport type { ReplayContainer, ReplayNetworkOptions, ReplayNetworkRequestData, XhrHint } from '../../types';\nimport { addNetworkBreadcrumb } from './addNetworkBreadcrumb';\nimport {\n buildNetworkRequestOrResponse,\n buildSkippedNetworkRequestOrResponse,\n getAllowedHeaders,\n getBodySize,\n getBodyString,\n makeNetworkReplayBreadcrumb,\n parseContentLengthHeader,\n urlMatches,\n} from './networkUtils';\n\n/**\n * Capture an XHR breadcrumb to a replay.\n * This adds additional data (where approriate).\n */\nexport async function captureXhrBreadcrumbToReplay(\n breadcrumb: Breadcrumb & { data: XhrBreadcrumbData },\n hint: XhrHint,\n options: ReplayNetworkOptions & { replay: ReplayContainer },\n): Promise<void> {\n try {\n const data = _prepareXhrData(breadcrumb, hint, options);\n\n // Create a replay performance entry from this breadcrumb\n const result = makeNetworkReplayBreadcrumb('resource.xhr', data);\n addNetworkBreadcrumb(options.replay, result);\n } catch (error) {\n __DEBUG_BUILD__ && logger.error('[Replay] Failed to capture fetch breadcrumb', error);\n }\n}\n\n/**\n * Enrich a breadcrumb with additional data.\n * This has to be sync & mutate the given breadcrumb,\n * as the breadcrumb is afterwards consumed by other handlers.\n */\nexport function enrichXhrBreadcrumb(\n breadcrumb: Breadcrumb & { data: XhrBreadcrumbData },\n hint: XhrHint,\n options: { textEncoder: TextEncoderInternal },\n): void {\n const { xhr, input } = hint;\n\n const reqSize = getBodySize(input, options.textEncoder);\n const resSize = xhr.getResponseHeader('content-length')\n ? parseContentLengthHeader(xhr.getResponseHeader('content-length'))\n : getBodySize(xhr.response, options.textEncoder);\n\n if (reqSize !== undefined) {\n breadcrumb.data.request_body_size = reqSize;\n }\n if (resSize !== undefined) {\n breadcrumb.data.response_body_size = resSize;\n }\n}\n\nfunction _prepareXhrData(\n breadcrumb: Breadcrumb & { data: XhrBreadcrumbData },\n hint: XhrHint,\n options: ReplayNetworkOptions,\n): ReplayNetworkRequestData | null {\n const { startTimestamp, endTimestamp, input, xhr } = hint;\n\n const {\n url,\n method,\n status_code: statusCode = 0,\n request_body_size: requestBodySize,\n response_body_size: responseBodySize,\n } = breadcrumb.data;\n\n if (!url) {\n return null;\n }\n\n if (!urlMatches(url, options.networkDetailAllowUrls) || urlMatches(url, options.networkDetailDenyUrls)) {\n const request = buildSkippedNetworkRequestOrResponse(requestBodySize);\n const response = buildSkippedNetworkRequestOrResponse(responseBodySize);\n return {\n startTimestamp,\n endTimestamp,\n url,\n method,\n statusCode,\n request,\n response,\n };\n }\n\n const xhrInfo = xhr[SENTRY_XHR_DATA_KEY];\n const networkRequestHeaders = xhrInfo\n ? getAllowedHeaders(xhrInfo.request_headers, options.networkRequestHeaders)\n : {};\n const networkResponseHeaders = getAllowedHeaders(getResponseHeaders(xhr), options.networkResponseHeaders);\n\n const request = buildNetworkRequestOrResponse(\n networkRequestHeaders,\n requestBodySize,\n options.networkCaptureBodies ? getBodyString(input) : undefined,\n );\n const response = buildNetworkRequestOrResponse(\n networkResponseHeaders,\n responseBodySize,\n options.networkCaptureBodies ? hint.xhr.responseText : undefined,\n );\n\n return {\n startTimestamp,\n endTimestamp,\n url,\n method,\n statusCode,\n request,\n response,\n };\n}\n\nfunction getResponseHeaders(xhr: XMLHttpRequest): Record<string, string> {\n const headers = xhr.getAllResponseHeaders();\n\n if (!headers) {\n return {};\n }\n\n return headers.split('\\r\\n').reduce((acc: Record<string, string>, line: string) => {\n const [key, value] = line.split(': ');\n acc[key.toLowerCase()] = value;\n return acc;\n }, {});\n}\n","import { getCurrentHub } from '@sentry/core';\nimport type {\n Breadcrumb,\n BreadcrumbHint,\n FetchBreadcrumbData,\n TextEncoderInternal,\n XhrBreadcrumbData,\n} from '@sentry/types';\nimport { addInstrumentationHandler, logger } from '@sentry/utils';\n\nimport type { FetchHint, ReplayContainer, ReplayNetworkOptions, XhrHint } from '../types';\nimport { handleFetchSpanListener } from './handleFetch';\nimport { handleXhrSpanListener } from './handleXhr';\nimport { captureFetchBreadcrumbToReplay, enrichFetchBreadcrumb } from './util/fetchUtils';\nimport { captureXhrBreadcrumbToReplay, enrichXhrBreadcrumb } from './util/xhrUtils';\n\ninterface ExtendedNetworkBreadcrumbsOptions extends ReplayNetworkOptions {\n replay: ReplayContainer;\n textEncoder: TextEncoderInternal;\n}\n\n/**\n * This method does two things:\n * - It enriches the regular XHR/fetch breadcrumbs with request/response size data\n * - It captures the XHR/fetch breadcrumbs to the replay\n * (enriching it with further data that is _not_ added to the regular breadcrumbs)\n */\nexport function handleNetworkBreadcrumbs(replay: ReplayContainer): void {\n const client = getCurrentHub().getClient();\n\n try {\n const textEncoder = new TextEncoder();\n\n const {\n networkDetailAllowUrls,\n networkDetailDenyUrls,\n networkCaptureBodies,\n networkRequestHeaders,\n networkResponseHeaders,\n } = replay.getOptions();\n\n const options: ExtendedNetworkBreadcrumbsOptions = {\n replay,\n textEncoder,\n networkDetailAllowUrls,\n networkDetailDenyUrls,\n networkCaptureBodies,\n networkRequestHeaders,\n networkResponseHeaders,\n };\n\n if (client && client.on) {\n client.on('beforeAddBreadcrumb', (breadcrumb, hint) => beforeAddNetworkBreadcrumb(options, breadcrumb, hint));\n } else {\n // Fallback behavior\n addInstrumentationHandler('fetch', handleFetchSpanListener(replay));\n addInstrumentationHandler('xhr', handleXhrSpanListener(replay));\n }\n } catch {\n // Do nothing\n }\n}\n\n/** just exported for tests */\nexport function beforeAddNetworkBreadcrumb(\n options: ExtendedNetworkBreadcrumbsOptions,\n breadcrumb: Breadcrumb,\n hint?: BreadcrumbHint,\n): void {\n if (!breadcrumb.data) {\n return;\n }\n\n try {\n if (_isXhrBreadcrumb(breadcrumb) && _isXhrHint(hint)) {\n // This has to be sync, as we need to ensure the breadcrumb is enriched in the same tick\n // Because the hook runs synchronously, and the breadcrumb is afterwards passed on\n // So any async mutations to it will not be reflected in the final breadcrumb\n enrichXhrBreadcrumb(breadcrumb, hint, options);\n\n void captureXhrBreadcrumbToReplay(breadcrumb, hint, options);\n }\n\n if (_isFetchBreadcrumb(breadcrumb) && _isFetchHint(hint)) {\n // This has to be sync, as we need to ensure the breadcrumb is enriched in the same tick\n // Because the hook runs synchronously, and the breadcrumb is afterwards passed on\n // So any async mutations to it will not be reflected in the final breadcrumb\n enrichFetchBreadcrumb(breadcrumb, hint, options);\n\n void captureFetchBreadcrumbToReplay(breadcrumb, hint, options);\n }\n } catch (e) {\n __DEBUG_BUILD__ && logger.warn('Error when enriching network breadcrumb');\n }\n}\n\nfunction _isXhrBreadcrumb(breadcrumb: Breadcrumb): breadcrumb is Breadcrumb & { data: XhrBreadcrumbData } {\n return breadcrumb.category === 'xhr';\n}\n\nfunction _isFetchBreadcrumb(breadcrumb: Breadcrumb): breadcrumb is Breadcrumb & { data: FetchBreadcrumbData } {\n return breadcrumb.category === 'fetch';\n}\n\nfunction _isXhrHint(hint?: BreadcrumbHint): hint is XhrHint {\n return hint && hint.xhr;\n}\n\nfunction _isFetchHint(hint?: BreadcrumbHint): hint is FetchHint {\n return hint && hint.response;\n}\n","import type { HandlerDataFetch } from '@sentry/types';\n\nimport type { NetworkRequestData, ReplayContainer, ReplayPerformanceEntry } from '../types';\nimport { addNetworkBreadcrumb } from './util/addNetworkBreadcrumb';\n\n/** only exported for tests */\nexport function handleFetch(handlerData: HandlerDataFetch): null | ReplayPerformanceEntry<NetworkRequestData> {\n const { startTimestamp, endTimestamp, fetchData, response } = handlerData;\n\n if (!endTimestamp) {\n return null;\n }\n\n // This is only used as a fallback, so we know the body sizes are never set here\n const { method, url } = fetchData;\n\n return {\n type: 'resource.fetch',\n start: startTimestamp / 1000,\n end: endTimestamp / 1000,\n name: url,\n data: {\n method,\n statusCode: response ? (response as Response).status : undefined,\n },\n };\n}\n\n/**\n * Returns a listener to be added to `addInstrumentationHandler('fetch', listener)`.\n */\nexport function handleFetchSpanListener(replay: ReplayContainer): (handlerData: HandlerDataFetch) => void {\n return (handlerData: HandlerDataFetch) => {\n if (!replay.isEnabled()) {\n return;\n }\n\n const result = handleFetch(handlerData);\n\n addNetworkBreadcrumb(replay, result);\n };\n}\n","import type { HandlerDataXhr } from '@sentry/types';\nimport { SENTRY_XHR_DATA_KEY } from '@sentry/utils';\n\nimport type { NetworkRequestData, ReplayContainer, ReplayPerformanceEntry } from '../types';\nimport { addNetworkBreadcrumb } from './util/addNetworkBreadcrumb';\n\n/** only exported for tests */\nexport function handleXhr(handlerData: HandlerDataXhr): ReplayPerformanceEntry<NetworkRequestData> | null {\n const { startTimestamp, endTimestamp, xhr } = handlerData;\n\n const sentryXhrData = xhr[SENTRY_XHR_DATA_KEY];\n\n if (!startTimestamp || !endTimestamp || !sentryXhrData) {\n return null;\n }\n\n // This is only used as a fallback, so we know the body sizes are never set here\n const { method, url, status_code: statusCode } = sentryXhrData;\n\n if (url === undefined) {\n return null;\n }\n\n return {\n type: 'resource.xhr',\n name: url,\n start: startTimestamp / 1000,\n end: endTimestamp / 1000,\n data: {\n method,\n statusCode,\n },\n };\n}\n\n/**\n * Returns a listener to be added to `addInstrumentationHandler('xhr', listener)`.\n */\nexport function handleXhrSpanListener(replay: ReplayContainer): (handlerData: HandlerDataXhr) => void {\n return (handlerData: HandlerDataXhr) => {\n if (!replay.isEnabled()) {\n return;\n }\n\n const result = handleXhr(handlerData);\n\n addNetworkBreadcrumb(replay, result);\n };\n}\n","import type { Breadcrumb, Scope } from '@sentry/types';\nimport { normalize } from '@sentry/utils';\n\nimport { CONSOLE_ARG_MAX_SIZE } from '../constants';\nimport type { ReplayContainer } from '../types';\nimport type { ReplayFrame } from '../types/replayFrame';\nimport { createBreadcrumb } from '../util/createBreadcrumb';\nimport { fixJson } from '../util/truncateJson/fixJson';\nimport { addBreadcrumbEvent } from './util/addBreadcrumbEvent';\n\nlet _LAST_BREADCRUMB: null | Breadcrumb = null;\n\ntype BreadcrumbWithCategory = Required<Pick<Breadcrumb, 'category'>>;\n\nfunction isBreadcrumbWithCategory(breadcrumb: Breadcrumb): breadcrumb is BreadcrumbWithCategory {\n return !!breadcrumb.category;\n}\n\nexport const handleScopeListener: (replay: ReplayContainer) => (scope: Scope) => void =\n (replay: ReplayContainer) =>\n (scope: Scope): void => {\n if (!replay.isEnabled()) {\n return;\n }\n\n const result = handleScope(scope);\n\n if (!result) {\n return;\n }\n\n addBreadcrumbEvent(replay, result);\n };\n\n/**\n * An event handler to handle scope changes.\n */\nexport function handleScope(scope: Scope): Breadcrumb | null {\n // TODO (v8): Remove this guard. This was put in place because we introduced\n // Scope.getLastBreadcrumb mid-v7 which caused incompatibilities with older SDKs.\n // For now, we'll just return null if the method doesn't exist but we should eventually\n // get rid of this guard.\n const newBreadcrumb = scope.getLastBreadcrumb && scope.getLastBreadcrumb();\n\n // Listener can be called when breadcrumbs have not changed, so we store the\n // reference to the last crumb and only return a crumb if it has changed\n if (_LAST_BREADCRUMB === newBreadcrumb || !newBreadcrumb) {\n return null;\n }\n\n _LAST_BREADCRUMB = newBreadcrumb;\n\n if (\n !isBreadcrumbWithCategory(newBreadcrumb) ||\n ['fetch', 'xhr', 'sentry.event', 'sentry.transaction'].includes(newBreadcrumb.category) ||\n newBreadcrumb.category.startsWith('ui.')\n ) {\n return null;\n }\n\n if (newBreadcrumb.category === 'console') {\n return normalizeConsoleBreadcrumb(newBreadcrumb);\n }\n\n return createBreadcrumb(newBreadcrumb);\n}\n\n/** exported for tests only */\nexport function normalizeConsoleBreadcrumb(\n breadcrumb: Omit<Breadcrumb, 'category'> & BreadcrumbWithCategory,\n): ReplayFrame {\n const args = breadcrumb.data && breadcrumb.data.arguments;\n\n if (!Array.isArray(args) || args.length === 0) {\n return createBreadcrumb(breadcrumb);\n }\n\n let isTruncated = false;\n\n // Avoid giant args captures\n const normalizedArgs = args.map(arg => {\n if (!arg) {\n return arg;\n }\n if (typeof arg === 'string') {\n if (arg.length > CONSOLE_ARG_MAX_SIZE) {\n isTruncated = true;\n return `${arg.slice(0, CONSOLE_ARG_MAX_SIZE)}…`;\n }\n\n return arg;\n }\n if (typeof arg === 'object') {\n try {\n const normalizedArg = normalize(arg, 7);\n const stringified = JSON.stringify(normalizedArg);\n if (stringified.length > CONSOLE_ARG_MAX_SIZE) {\n const fixedJson = fixJson(stringified.slice(0, CONSOLE_ARG_MAX_SIZE));\n const json = JSON.parse(fixedJson);\n // We only set this after JSON.parse() was successfull, so we know we didn't run into `catch`\n isTruncated = true;\n return json;\n }\n return normalizedArg;\n } catch {\n // fall back to default\n }\n }\n\n return arg;\n });\n\n return createBreadcrumb({\n ...breadcrumb,\n data: {\n ...breadcrumb.data,\n arguments: normalizedArgs,\n ...(isTruncated ? { _meta: { warnings: ['CONSOLE_ARG_TRUNCATED'] } } : {}),\n },\n });\n}\n","import type { BaseClient } from '@sentry/core';\nimport { addGlobalEventProcessor, getCurrentHub } from '@sentry/core';\nimport type { Client, DynamicSamplingContext } from '@sentry/types';\nimport { addInstrumentationHandler } from '@sentry/utils';\n\nimport { handleAfterSendEvent } from '../coreHandlers/handleAfterSendEvent';\nimport { handleDomListener } from '../coreHandlers/handleDom';\nimport { handleGlobalEventListener } from '../coreHandlers/handleGlobalEvent';\nimport { handleHistorySpanListener } from '../coreHandlers/handleHistory';\nimport { handleNetworkBreadcrumbs } from '../coreHandlers/handleNetworkBreadcrumbs';\nimport { handleScopeListener } from '../coreHandlers/handleScope';\nimport type { ReplayContainer } from '../types';\n\n/**\n * Add global listeners that cannot be removed.\n */\nexport function addGlobalListeners(replay: ReplayContainer): void {\n // Listeners from core SDK //\n const scope = getCurrentHub().getScope();\n const client = getCurrentHub().getClient();\n\n if (scope) {\n scope.addScopeListener(handleScopeListener(replay));\n }\n addInstrumentationHandler('dom', handleDomListener(replay));\n addInstrumentationHandler('history', handleHistorySpanListener(replay));\n handleNetworkBreadcrumbs(replay);\n\n // Tag all (non replay) events that get sent to Sentry with the current\n // replay ID so that we can reference them later in the UI\n addGlobalEventProcessor(handleGlobalEventListener(replay, !hasHooks(client)));\n\n // If a custom client has no hooks yet, we continue to use the \"old\" implementation\n if (hasHooks(client)) {\n client.on('afterSendEvent', handleAfterSendEvent(replay));\n client.on('createDsc', (dsc: DynamicSamplingContext) => {\n const replayId = replay.getSessionId();\n // We do not want to set the DSC when in buffer mode, as that means the replay has not been sent (yet)\n if (replayId && replay.isEnabled() && replay.recordingMode === 'session') {\n dsc.replay_id = replayId;\n }\n });\n\n client.on('startTransaction', transaction => {\n replay.lastTransaction = transaction;\n });\n\n // We may be missing the initial startTransaction due to timing issues,\n // so we capture it on finish again.\n client.on('finishTransaction', transaction => {\n replay.lastTransaction = transaction;\n });\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction hasHooks(client: Client | undefined): client is BaseClient<any> {\n return !!(client && client.on);\n}\n","import type { Event, EventHint } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport type { ReplayContainer } from '../types';\nimport { isErrorEvent, isReplayEvent, isTransactionEvent } from '../util/eventUtils';\nimport { isRrwebError } from '../util/isRrwebError';\nimport { handleAfterSendEvent } from './handleAfterSendEvent';\nimport { shouldSampleForBufferEvent } from './util/shouldSampleForBufferEvent';\n\n/**\n * Returns a listener to be added to `addGlobalEventProcessor(listener)`.\n */\nexport function handleGlobalEventListener(\n replay: ReplayContainer,\n includeAfterSendEventHandling = false,\n): (event: Event, hint: EventHint) => Event | null {\n const afterSendHandler = includeAfterSendEventHandling ? handleAfterSendEvent(replay) : undefined;\n\n return (event: Event, hint: EventHint) => {\n // Do nothing if replay has been disabled\n if (!replay.isEnabled()) {\n return event;\n }\n\n if (isReplayEvent(event)) {\n // Replays have separate set of breadcrumbs, do not include breadcrumbs\n // from core SDK\n delete event.breadcrumbs;\n return event;\n }\n\n // We only want to handle errors & transactions, nothing else\n if (!isErrorEvent(event) && !isTransactionEvent(event)) {\n return event;\n }\n\n // Unless `captureExceptions` is enabled, we want to ignore errors coming from rrweb\n // As there can be a bunch of stuff going wrong in internals there, that we don't want to bubble up to users\n if (isRrwebError(event, hint) && !replay.getOptions()._experiments.captureExceptions) {\n __DEBUG_BUILD__ && logger.log('[Replay] Ignoring error from rrweb internals', event);\n return null;\n }\n\n // When in buffer mode, we decide to sample here.\n // Later, in `handleAfterSendEvent`, if the replayId is set, we know that we sampled\n // And convert the buffer session to a full session\n const isErrorEventSampled = shouldSampleForBufferEvent(replay, event);\n\n // Tag errors if it has been sampled in buffer mode, or if it is session mode\n // Only tag transactions if in session mode\n const shouldTagReplayId = isErrorEventSampled || replay.recordingMode === 'session';\n\n if (shouldTagReplayId) {\n event.tags = { ...event.tags, replayId: replay.getSessionId() };\n }\n\n // In cases where a custom client is used that does not support the new hooks (yet),\n // we manually call this hook method here\n if (afterSendHandler) {\n // Pretend the error had a 200 response so we always capture it\n afterSendHandler(event, { statusCode: 200 });\n }\n\n return event;\n };\n}\n","import { WINDOW } from '../constants';\nimport type { AddEventResult, MemoryData, ReplayContainer, ReplayPerformanceEntry } from '../types';\nimport { createPerformanceSpans } from './createPerformanceSpans';\n\ntype ReplayMemoryEntry = ReplayPerformanceEntry<MemoryData> & { data: { memory: MemoryInfo } };\n\ninterface MemoryInfo {\n jsHeapSizeLimit: number;\n totalJSHeapSize: number;\n usedJSHeapSize: number;\n}\n\n/**\n * Create a \"span\" for the total amount of memory being used by JS objects\n * (including v8 internal objects).\n */\nexport async function addMemoryEntry(replay: ReplayContainer): Promise<Array<AddEventResult | null>> {\n // window.performance.memory is a non-standard API and doesn't work on all browsers, so we try-catch this\n try {\n return Promise.all(\n createPerformanceSpans(replay, [\n // @ts-ignore memory doesn't exist on type Performance as the API is non-standard (we check that it exists above)\n createMemoryEntry(WINDOW.performance.memory),\n ]),\n );\n } catch (error) {\n // Do nothing\n return [];\n }\n}\n\nfunction createMemoryEntry(memoryEntry: MemoryInfo): ReplayMemoryEntry {\n const { jsHeapSizeLimit, totalJSHeapSize, usedJSHeapSize } = memoryEntry;\n // we don't want to use `getAbsoluteTime` because it adds the event time to the\n // time origin, so we get the current timestamp instead\n const time = Date.now() / 1000;\n return {\n type: 'memory',\n name: 'memory',\n start: time,\n end: time,\n data: {\n memory: {\n jsHeapSizeLimit,\n totalJSHeapSize,\n usedJSHeapSize,\n },\n },\n };\n}\n","import { record } from '@sentry-internal/rrweb';\nimport { browserPerformanceTimeOrigin } from '@sentry/utils';\n\nimport { WINDOW } from '../constants';\nimport type {\n AllPerformanceEntry,\n AllPerformanceEntryData,\n ExperimentalPerformanceResourceTiming,\n LargestContentfulPaintData,\n NavigationData,\n PaintData,\n ReplayPerformanceEntry,\n ResourceData,\n} from '../types';\n\n// Map entryType -> function to normalize data for event\n// @ts-ignore TODO: entry type does not fit the create* functions entry type\nconst ENTRY_TYPES: Record<\n string,\n (entry: AllPerformanceEntry) => null | ReplayPerformanceEntry<AllPerformanceEntryData>\n> = {\n // @ts-ignore TODO: entry type does not fit the create* functions entry type\n resource: createResourceEntry,\n paint: createPaintEntry,\n // @ts-ignore TODO: entry type does not fit the create* functions entry type\n navigation: createNavigationEntry,\n // @ts-ignore TODO: entry type does not fit the create* functions entry type\n ['largest-contentful-paint']: createLargestContentfulPaint,\n};\n\n/**\n * Create replay performance entries from the browser performance entries.\n */\nexport function createPerformanceEntries(\n entries: AllPerformanceEntry[],\n): ReplayPerformanceEntry<AllPerformanceEntryData>[] {\n return entries.map(createPerformanceEntry).filter(Boolean) as ReplayPerformanceEntry<AllPerformanceEntryData>[];\n}\n\nfunction createPerformanceEntry(entry: AllPerformanceEntry): ReplayPerformanceEntry<AllPerformanceEntryData> | null {\n if (ENTRY_TYPES[entry.entryType] === undefined) {\n return null;\n }\n\n return ENTRY_TYPES[entry.entryType](entry);\n}\n\nfunction getAbsoluteTime(time: number): number {\n // browserPerformanceTimeOrigin can be undefined if `performance` or\n // `performance.now` doesn't exist, but this is already checked by this integration\n return ((browserPerformanceTimeOrigin || WINDOW.performance.timeOrigin) + time) / 1000;\n}\n\nfunction createPaintEntry(entry: PerformancePaintTiming): ReplayPerformanceEntry<PaintData> {\n const { duration, entryType, name, startTime } = entry;\n\n const start = getAbsoluteTime(startTime);\n return {\n type: entryType,\n name,\n start,\n end: start + duration,\n data: undefined,\n };\n}\n\nfunction createNavigationEntry(entry: PerformanceNavigationTiming): ReplayPerformanceEntry<NavigationData> | null {\n const {\n entryType,\n name,\n decodedBodySize,\n duration,\n domComplete,\n encodedBodySize,\n domContentLoadedEventStart,\n domContentLoadedEventEnd,\n domInteractive,\n loadEventStart,\n loadEventEnd,\n redirectCount,\n startTime,\n transferSize,\n type,\n } = entry;\n\n // Ignore entries with no duration, they do not seem to be useful and cause dupes\n if (duration === 0) {\n return null;\n }\n\n return {\n type: `${entryType}.${type}`,\n start: getAbsoluteTime(startTime),\n end: getAbsoluteTime(domComplete),\n name,\n data: {\n size: transferSize,\n decodedBodySize,\n encodedBodySize,\n duration,\n domInteractive,\n domContentLoadedEventStart,\n domContentLoadedEventEnd,\n loadEventStart,\n loadEventEnd,\n domComplete,\n redirectCount,\n },\n };\n}\n\nfunction createResourceEntry(\n entry: ExperimentalPerformanceResourceTiming,\n): ReplayPerformanceEntry<ResourceData> | null {\n const {\n entryType,\n initiatorType,\n name,\n responseEnd,\n startTime,\n decodedBodySize,\n encodedBodySize,\n responseStatus,\n transferSize,\n } = entry;\n\n // Core SDK handles these\n if (['fetch', 'xmlhttprequest'].includes(initiatorType)) {\n return null;\n }\n\n return {\n type: `${entryType}.${initiatorType}`,\n start: getAbsoluteTime(startTime),\n end: getAbsoluteTime(responseEnd),\n name,\n data: {\n size: transferSize,\n statusCode: responseStatus,\n decodedBodySize,\n encodedBodySize,\n },\n };\n}\n\nfunction createLargestContentfulPaint(\n entry: PerformanceEntry & { size: number; element: Node },\n): ReplayPerformanceEntry<LargestContentfulPaintData> {\n const { entryType, startTime, size } = entry;\n\n let startTimeOrNavigationActivation = 0;\n\n if (WINDOW.performance) {\n const navEntry = WINDOW.performance.getEntriesByType('navigation')[0] as PerformanceNavigationTiming & {\n activationStart: number;\n };\n\n // See https://github.com/GoogleChrome/web-vitals/blob/9f11c4c6578fb4c5ee6fa4e32b9d1d756475f135/src/lib/getActivationStart.ts#L21\n startTimeOrNavigationActivation = (navEntry && navEntry.activationStart) || 0;\n }\n\n // value is in ms\n const value = Math.max(startTime - startTimeOrNavigationActivation, 0);\n // LCP doesn't have a \"duration\", it just happens at a single point in time.\n // But the UI expects both, so use end (in seconds) for both timestamps.\n const end = getAbsoluteTime(startTimeOrNavigationActivation) + value / 1000;\n\n return {\n type: entryType,\n name: entryType,\n start: end,\n end,\n data: {\n value, // LCP \"duration\" in ms\n size,\n // Not sure why this errors, Node should be correct (Argument of type 'Node' is not assignable to parameter of type 'INode')\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n nodeId: record.mirror.getId(entry.element as any),\n },\n };\n}\n","import { EventType } from '@sentry-internal/rrweb';\nimport { logger } from '@sentry/utils';\n\nimport { saveSession } from '../session/saveSession';\nimport type { AddEventResult, OptionFrameEvent, RecordingEvent, ReplayContainer } from '../types';\nimport { addEvent } from './addEvent';\nimport { logInfo } from './log';\n\ntype RecordingEmitCallback = (event: RecordingEvent, isCheckout?: boolean) => void;\n\n/**\n * Handler for recording events.\n *\n * Adds to event buffer, and has varying flushing behaviors if the event was a checkout.\n */\nexport function getHandleRecordingEmit(replay: ReplayContainer): RecordingEmitCallback {\n let hadFirstEvent = false;\n\n return (event: RecordingEvent, _isCheckout?: boolean) => {\n // If this is false, it means session is expired, create and a new session and wait for checkout\n if (!replay.checkAndHandleExpiredSession()) {\n __DEBUG_BUILD__ && logger.warn('[Replay] Received replay event after session expired.');\n\n return;\n }\n\n // `_isCheckout` is only set when the checkout is due to `checkoutEveryNms`\n // We also want to treat the first event as a checkout, so we handle this specifically here\n const isCheckout = _isCheckout || !hadFirstEvent;\n hadFirstEvent = true;\n\n // The handler returns `true` if we do not want to trigger debounced flush, `false` if we want to debounce flush.\n replay.addUpdate(() => {\n // The session is always started immediately on pageload/init, but for\n // error-only replays, it should reflect the most recent checkout\n // when an error occurs. Clear any state that happens before this current\n // checkout. This needs to happen before `addEvent()` which updates state\n // dependent on this reset.\n if (replay.recordingMode === 'buffer' && isCheckout) {\n replay.setInitialState();\n }\n\n // We need to clear existing events on a checkout, otherwise they are\n // incremental event updates and should be appended\n void addEvent(replay, event, isCheckout);\n\n // Different behavior for full snapshots (type=2), ignore other event types\n // See https://github.com/rrweb-io/rrweb/blob/d8f9290ca496712aa1e7d472549480c4e7876594/packages/rrweb/src/types.ts#L16\n if (!isCheckout) {\n return false;\n }\n\n // Additionally, create a meta event that will capture certain SDK settings.\n // In order to handle buffer mode, this needs to either be done when we\n // receive checkout events or at flush time.\n //\n // `isCheckout` is always true, but want to be explicit that it should\n // only be added for checkouts\n void addSettingsEvent(replay, isCheckout);\n\n // If there is a previousSessionId after a full snapshot occurs, then\n // the replay session was started due to session expiration. The new session\n // is started before triggering a new checkout and contains the id\n // of the previous session. Do not immediately flush in this case\n // to avoid capturing only the checkout and instead the replay will\n // be captured if they perform any follow-up actions.\n if (replay.session && replay.session.previousSessionId) {\n return true;\n }\n\n // When in buffer mode, make sure we adjust the session started date to the current earliest event of the buffer\n // this should usually be the timestamp of the checkout event, but to be safe...\n if (replay.recordingMode === 'buffer' && replay.session && replay.eventBuffer) {\n const earliestEvent = replay.eventBuffer.getEarliestTimestamp();\n if (earliestEvent) {\n logInfo(\n `[Replay] Updating session start time to earliest event in buffer to ${new Date(earliestEvent)}`,\n replay.getOptions()._experiments.traceInternals,\n );\n\n replay.session.started = earliestEvent;\n\n if (replay.getOptions().stickySession) {\n saveSession(replay.session);\n }\n }\n }\n\n if (replay.recordingMode === 'session') {\n // If the full snapshot is due to an initial load, we will not have\n // a previous session ID. In this case, we want to buffer events\n // for a set amount of time before flushing. This can help avoid\n // capturing replays of users that immediately close the window.\n void replay.flush();\n }\n\n return true;\n });\n };\n}\n\n/**\n * Exported for tests\n */\nexport function createOptionsEvent(replay: ReplayContainer): OptionFrameEvent {\n const options = replay.getOptions();\n return {\n type: EventType.Custom,\n timestamp: Date.now(),\n data: {\n tag: 'options',\n payload: {\n sessionSampleRate: options.sessionSampleRate,\n errorSampleRate: options.errorSampleRate,\n useCompressionOption: options.useCompression,\n blockAllMedia: options.blockAllMedia,\n maskAllText: options.maskAllText,\n maskAllInputs: options.maskAllInputs,\n useCompression: replay.eventBuffer ? replay.eventBuffer.type === 'worker' : false,\n networkDetailHasUrls: options.networkDetailAllowUrls.length > 0,\n networkCaptureBodies: options.networkCaptureBodies,\n networkRequestHasHeaders: options.networkRequestHeaders.length > 0,\n networkResponseHasHeaders: options.networkResponseHeaders.length > 0,\n },\n },\n };\n}\n\n/**\n * Add a \"meta\" event that contains a simplified view on current configuration\n * options. This should only be included on the first segment of a recording.\n */\nfunction addSettingsEvent(replay: ReplayContainer, isCheckout?: boolean): Promise<AddEventResult | null> {\n // Only need to add this event when sending the first segment\n if (!isCheckout || !replay.session || replay.session.segmentId !== 0) {\n return Promise.resolve(null);\n }\n\n return addEvent(replay, createOptionsEvent(replay), false);\n}\n","import type { DsnComponents, ReplayEnvelope, ReplayEvent, ReplayRecordingData } from '@sentry/types';\nimport { createEnvelope, createEventEnvelopeHeaders, getSdkMetadataForEnvelopeHeader } from '@sentry/utils';\n\n/**\n * Create a replay envelope ready to be sent.\n * This includes both the replay event, as well as the recording data.\n */\nexport function createReplayEnvelope(\n replayEvent: ReplayEvent,\n recordingData: ReplayRecordingData,\n dsn: DsnComponents,\n tunnel?: string,\n): ReplayEnvelope {\n return createEnvelope<ReplayEnvelope>(\n createEventEnvelopeHeaders(replayEvent, getSdkMetadataForEnvelopeHeader(replayEvent), tunnel, dsn),\n [\n [{ type: 'replay_event' }, replayEvent],\n [\n {\n type: 'replay_recording',\n // If string then we need to encode to UTF8, otherwise will have\n // wrong size. TextEncoder has similar browser support to\n // MutationObserver, although it does not accept IE11.\n length:\n typeof recordingData === 'string' ? new TextEncoder().encode(recordingData).length : recordingData.length,\n },\n recordingData,\n ],\n ],\n );\n}\n","import type { ReplayRecordingData } from '@sentry/types';\n\n/**\n * Prepare the recording data ready to be sent.\n */\nexport function prepareRecordingData({\n recordingData,\n headers,\n}: {\n recordingData: ReplayRecordingData;\n headers: Record<string, unknown>;\n}): ReplayRecordingData {\n let payloadWithSequence;\n\n // XXX: newline is needed to separate sequence id from events\n const replayHeaders = `${JSON.stringify(headers)}\n`;\n\n if (typeof recordingData === 'string') {\n payloadWithSequence = `${replayHeaders}${recordingData}`;\n } else {\n const enc = new TextEncoder();\n // XXX: newline is needed to separate sequence id from events\n const sequence = enc.encode(replayHeaders);\n // Merge the two Uint8Arrays\n payloadWithSequence = new Uint8Array(sequence.length + recordingData.length);\n payloadWithSequence.set(sequence);\n payloadWithSequence.set(recordingData, sequence.length);\n }\n\n return payloadWithSequence;\n}\n","import type { Scope } from '@sentry/core';\nimport { prepareEvent } from '@sentry/core';\nimport type { IntegrationIndex } from '@sentry/core/build/types/integration';\nimport type { Client, ReplayEvent } from '@sentry/types';\n\n/**\n * Prepare a replay event & enrich it with the SDK metadata.\n */\nexport async function prepareReplayEvent({\n client,\n scope,\n replayId: event_id,\n event,\n}: {\n client: Client & { _integrations?: IntegrationIndex };\n scope: Scope;\n replayId: string;\n event: ReplayEvent;\n}): Promise<ReplayEvent | null> {\n const integrations =\n typeof client._integrations === 'object' && client._integrations !== null && !Array.isArray(client._integrations)\n ? Object.keys(client._integrations)\n : undefined;\n const preparedEvent = (await prepareEvent(\n client.getOptions(),\n event,\n { event_id, integrations },\n scope,\n )) as ReplayEvent | null;\n\n // If e.g. a global event processor returned null\n if (!preparedEvent) {\n return null;\n }\n\n // This normally happens in browser client \"_prepareEvent\"\n // but since we do not use this private method from the client, but rather the plain import\n // we need to do this manually.\n preparedEvent.platform = preparedEvent.platform || 'javascript';\n\n // extract the SDK name because `client._prepareEvent` doesn't add it to the event\n const metadata = client.getSdkMetadata && client.getSdkMetadata();\n const { name, version } = (metadata && metadata.sdk) || {};\n\n preparedEvent.sdk = {\n ...preparedEvent.sdk,\n name: name || 'sentry.javascript.unknown',\n version: version || '0.0.0',\n };\n\n return preparedEvent;\n}\n","import { getCurrentHub } from '@sentry/core';\nimport type { ReplayEvent, TransportMakeRequestResponse } from '@sentry/types';\n\nimport { REPLAY_EVENT_NAME, UNABLE_TO_SEND_REPLAY } from '../constants';\nimport type { SendReplayData } from '../types';\nimport { createReplayEnvelope } from './createReplayEnvelope';\nimport { logInfo } from './log';\nimport { prepareRecordingData } from './prepareRecordingData';\nimport { prepareReplayEvent } from './prepareReplayEvent';\n\n/**\n * Send replay attachment using `fetch()`\n */\nexport async function sendReplayRequest({\n recordingData,\n replayId,\n segmentId: segment_id,\n eventContext,\n timestamp,\n session,\n}: SendReplayData): Promise<void | TransportMakeRequestResponse> {\n const preparedRecordingData = prepareRecordingData({\n recordingData,\n headers: {\n segment_id,\n },\n });\n\n const { urls, errorIds, traceIds, initialTimestamp } = eventContext;\n\n const hub = getCurrentHub();\n const client = hub.getClient();\n const scope = hub.getScope();\n const transport = client && client.getTransport();\n const dsn = client && client.getDsn();\n\n if (!client || !transport || !dsn || !session.sampled) {\n return;\n }\n\n const baseEvent: ReplayEvent = {\n type: REPLAY_EVENT_NAME,\n replay_start_timestamp: initialTimestamp / 1000,\n timestamp: timestamp / 1000,\n error_ids: errorIds,\n trace_ids: traceIds,\n urls,\n replay_id: replayId,\n segment_id,\n replay_type: session.sampled,\n };\n\n const replayEvent = await prepareReplayEvent({ scope, client, replayId, event: baseEvent });\n\n if (!replayEvent) {\n // Taken from baseclient's `_processEvent` method, where this is handled for errors/transactions\n client.recordDroppedEvent('event_processor', 'replay', baseEvent);\n logInfo('An event processor returned `null`, will not send event.');\n return;\n }\n\n /*\n For reference, the fully built event looks something like this:\n {\n \"type\": \"replay_event\",\n \"timestamp\": 1670837008.634,\n \"error_ids\": [\n \"errorId\"\n ],\n \"trace_ids\": [\n \"traceId\"\n ],\n \"urls\": [\n \"https://example.com\"\n ],\n \"replay_id\": \"eventId\",\n \"segment_id\": 3,\n \"replay_type\": \"error\",\n \"platform\": \"javascript\",\n \"event_id\": \"eventId\",\n \"environment\": \"production\",\n \"sdk\": {\n \"integrations\": [\n \"BrowserTracing\",\n \"Replay\"\n ],\n \"name\": \"sentry.javascript.browser\",\n \"version\": \"7.25.0\"\n },\n \"sdkProcessingMetadata\": {},\n \"contexts\": {\n },\n }\n */\n\n // Prevent this data (which, if it exists, was used in earlier steps in the processing pipeline) from being sent to\n // sentry. (Note: Our use of this property comes and goes with whatever we might be debugging, whatever hacks we may\n // have temporarily added, etc. Even if we don't happen to be using it at some point in the future, let's not get rid\n // of this `delete`, lest we miss putting it back in the next time the property is in use.)\n delete replayEvent.sdkProcessingMetadata;\n\n const envelope = createReplayEnvelope(replayEvent, preparedRecordingData, dsn, client.getOptions().tunnel);\n\n let response: void | TransportMakeRequestResponse;\n\n try {\n response = await transport.send(envelope);\n } catch (err) {\n const error = new Error(UNABLE_TO_SEND_REPLAY);\n\n try {\n // In case browsers don't allow this property to be writable\n // @ts-ignore This needs lib es2022 and newer\n error.cause = err;\n } catch {\n // nothing to do\n }\n throw error;\n }\n\n // TODO (v8): we can remove this guard once transport.send's type signature doesn't include void anymore\n if (!response) {\n return response;\n }\n\n // If the status code is invalid, we want to immediately stop & not retry\n if (typeof response.statusCode === 'number' && (response.statusCode < 200 || response.statusCode >= 300)) {\n throw new TransportStatusCodeError(response.statusCode);\n }\n\n return response;\n}\n\n/**\n * This error indicates that the transport returned an invalid status code.\n */\nexport class TransportStatusCodeError extends Error {\n public constructor(statusCode: number) {\n super(`Transport returned status code ${statusCode}`);\n }\n}\n","import { captureException, setContext } from '@sentry/core';\n\nimport { RETRY_BASE_INTERVAL, RETRY_MAX_COUNT, UNABLE_TO_SEND_REPLAY } from '../constants';\nimport type { SendReplayData } from '../types';\nimport { sendReplayRequest, TransportStatusCodeError } from './sendReplayRequest';\n\n/**\n * Finalize and send the current replay event to Sentry\n */\nexport async function sendReplay(\n replayData: SendReplayData,\n retryConfig = {\n count: 0,\n interval: RETRY_BASE_INTERVAL,\n },\n): Promise<unknown> {\n const { recordingData, options } = replayData;\n\n // short circuit if there's no events to upload (this shouldn't happen as _runFlush makes this check)\n if (!recordingData.length) {\n return;\n }\n\n try {\n await sendReplayRequest(replayData);\n return true;\n } catch (err) {\n if (err instanceof TransportStatusCodeError) {\n throw err;\n }\n\n // Capture error for every failed replay\n setContext('Replays', {\n _retryCount: retryConfig.count,\n });\n\n if (__DEBUG_BUILD__ && options._experiments && options._experiments.captureExceptions) {\n captureException(err);\n }\n\n // If an error happened here, it's likely that uploading the attachment\n // failed, we'll can retry with the same events payload\n if (retryConfig.count >= RETRY_MAX_COUNT) {\n const error = new Error(`${UNABLE_TO_SEND_REPLAY} - max retries exceeded`);\n\n try {\n // In case browsers don't allow this property to be writable\n // @ts-ignore This needs lib es2022 and newer\n error.cause = err;\n } catch {\n // nothing to do\n }\n\n throw error;\n }\n\n // will retry in intervals of 5, 10, 30\n retryConfig.interval *= ++retryConfig.count;\n\n return new Promise((resolve, reject) => {\n setTimeout(async () => {\n try {\n await sendReplay(replayData, retryConfig);\n resolve(true);\n } catch (err) {\n reject(err);\n }\n }, retryConfig.interval);\n });\n }\n}\n","export const THROTTLED = '__THROTTLED';\nexport const SKIPPED = '__SKIPPED';\n\n/**\n * Create a throttled function off a given function.\n * When calling the throttled function, it will call the original function only\n * if it hasn't been called more than `maxCount` times in the last `durationSeconds`.\n *\n * Returns `THROTTLED` if throttled for the first time, after that `SKIPPED`,\n * or else the return value of the original function.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function throttle<T extends (...rest: any[]) => any>(\n fn: T,\n maxCount: number,\n durationSeconds: number,\n): (...rest: Parameters<T>) => ReturnType<T> | typeof THROTTLED | typeof SKIPPED {\n const counter = new Map<number, number>();\n\n const _cleanup = (now: number): void => {\n const threshold = now - durationSeconds;\n counter.forEach((_value, key) => {\n if (key < threshold) {\n counter.delete(key);\n }\n });\n };\n\n const _getTotalCount = (): number => {\n return [...counter.values()].reduce((a, b) => a + b, 0);\n };\n\n let isThrottled = false;\n\n return (...rest: Parameters<T>): ReturnType<T> | typeof THROTTLED | typeof SKIPPED => {\n // Date in second-precision, which we use as basis for the throttling\n const now = Math.floor(Date.now() / 1000);\n\n // First, make sure to delete any old entries\n _cleanup(now);\n\n // If already over limit, do nothing\n if (_getTotalCount() >= maxCount) {\n const wasThrottled = isThrottled;\n isThrottled = true;\n return wasThrottled ? SKIPPED : THROTTLED;\n }\n\n isThrottled = false;\n const count = counter.get(now) || 0;\n counter.set(now, count + 1);\n\n return fn(...rest);\n };\n}\n","/* eslint-disable max-lines */ // TODO: We might want to split this file up\nimport { EventType, record } from '@sentry-internal/rrweb';\nimport { captureException, getCurrentHub } from '@sentry/core';\nimport type { ReplayRecordingMode, Transaction } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport {\n BUFFER_CHECKOUT_TIME,\n MAX_SESSION_LIFE,\n SESSION_IDLE_EXPIRE_DURATION,\n SESSION_IDLE_PAUSE_DURATION,\n SLOW_CLICK_SCROLL_TIMEOUT,\n SLOW_CLICK_THRESHOLD,\n WINDOW,\n} from './constants';\nimport { ClickDetector } from './coreHandlers/handleClick';\nimport { handleKeyboardEvent } from './coreHandlers/handleKeyboardEvent';\nimport { setupPerformanceObserver } from './coreHandlers/performanceObserver';\nimport { createEventBuffer } from './eventBuffer';\nimport { clearSession } from './session/clearSession';\nimport { getSession } from './session/getSession';\nimport { saveSession } from './session/saveSession';\nimport type {\n AddEventResult,\n AddUpdateCallback,\n AllPerformanceEntry,\n BreadcrumbFrame,\n EventBuffer,\n InternalEventContext,\n PopEventContext,\n RecordingEvent,\n RecordingOptions,\n ReplayContainer as ReplayContainerInterface,\n ReplayPluginOptions,\n SendBufferedReplayOptions,\n Session,\n SlowClickConfig,\n Timeouts,\n} from './types';\nimport { addEvent } from './util/addEvent';\nimport { addGlobalListeners } from './util/addGlobalListeners';\nimport { addMemoryEntry } from './util/addMemoryEntry';\nimport { createBreadcrumb } from './util/createBreadcrumb';\nimport { createPerformanceEntries } from './util/createPerformanceEntries';\nimport { createPerformanceSpans } from './util/createPerformanceSpans';\nimport { debounce } from './util/debounce';\nimport { getHandleRecordingEmit } from './util/handleRecordingEmit';\nimport { isExpired } from './util/isExpired';\nimport { isSessionExpired } from './util/isSessionExpired';\nimport { logInfo, logInfoNextTick } from './util/log';\nimport { sendReplay } from './util/sendReplay';\nimport type { SKIPPED } from './util/throttle';\nimport { throttle, THROTTLED } from './util/throttle';\n\n/**\n * The main replay container class, which holds all the state and methods for recording and sending replays.\n */\nexport class ReplayContainer implements ReplayContainerInterface {\n public eventBuffer: EventBuffer | null;\n\n /**\n * List of PerformanceEntry from PerformanceObserver\n */\n public performanceEvents: AllPerformanceEntry[];\n\n public session: Session | undefined;\n\n public clickDetector: ClickDetector | undefined;\n\n /**\n * Recording can happen in one of three modes:\n * - session: Record the whole session, sending it continuously\n * - buffer: Always keep the last 60s of recording, requires:\n * - having replaysOnErrorSampleRate > 0 to capture replay when an error occurs\n * - or calling `flush()` to send the replay\n */\n public recordingMode: ReplayRecordingMode;\n\n /**\n * The current or last active transcation.\n * This is only available when performance is enabled.\n */\n public lastTransaction?: Transaction;\n\n /**\n * These are here so we can overwrite them in tests etc.\n * @hidden\n */\n public readonly timeouts: Timeouts;\n\n private _throttledAddEvent: (\n event: RecordingEvent,\n isCheckout?: boolean,\n ) => typeof THROTTLED | typeof SKIPPED | Promise<AddEventResult | null>;\n\n /**\n * Options to pass to `rrweb.record()`\n */\n private readonly _recordingOptions: RecordingOptions;\n\n private readonly _options: ReplayPluginOptions;\n\n private _performanceObserver: PerformanceObserver | undefined;\n\n private _debouncedFlush: ReturnType<typeof debounce>;\n private _flushLock: Promise<unknown> | undefined;\n\n /**\n * Timestamp of the last user activity. This lives across sessions.\n */\n private _lastActivity: number;\n\n /**\n * Is the integration currently active?\n */\n private _isEnabled: boolean;\n\n /**\n * Paused is a state where:\n * - DOM Recording is not listening at all\n * - Nothing will be added to event buffer (e.g. core SDK events)\n */\n private _isPaused: boolean;\n\n /**\n * Have we attached listeners to the core SDK?\n * Note we have to track this as there is no way to remove instrumentation handlers.\n */\n private _hasInitializedCoreListeners: boolean;\n\n /**\n * Function to stop recording\n */\n private _stopRecording: ReturnType<typeof record> | undefined;\n\n private _context: InternalEventContext;\n\n public constructor({\n options,\n recordingOptions,\n }: {\n options: ReplayPluginOptions;\n recordingOptions: RecordingOptions;\n }) {\n this.eventBuffer = null;\n this.performanceEvents = [];\n this.recordingMode = 'session';\n this.timeouts = {\n sessionIdlePause: SESSION_IDLE_PAUSE_DURATION,\n sessionIdleExpire: SESSION_IDLE_EXPIRE_DURATION,\n maxSessionLife: MAX_SESSION_LIFE,\n } as const;\n this._lastActivity = Date.now();\n this._isEnabled = false;\n this._isPaused = false;\n this._hasInitializedCoreListeners = false;\n this._context = {\n errorIds: new Set(),\n traceIds: new Set(),\n urls: [],\n initialTimestamp: Date.now(),\n initialUrl: '',\n };\n\n this._recordingOptions = recordingOptions;\n this._options = options;\n\n this._debouncedFlush = debounce(() => this._flush(), this._options.flushMinDelay, {\n maxWait: this._options.flushMaxDelay,\n });\n\n this._throttledAddEvent = throttle(\n (event: RecordingEvent, isCheckout?: boolean) => addEvent(this, event, isCheckout),\n // Max 300 events...\n 300,\n // ... per 5s\n 5,\n );\n\n const { slowClickTimeout, slowClickIgnoreSelectors } = this.getOptions();\n\n const slowClickConfig: SlowClickConfig | undefined = slowClickTimeout\n ? {\n threshold: Math.min(SLOW_CLICK_THRESHOLD, slowClickTimeout),\n timeout: slowClickTimeout,\n scrollTimeout: SLOW_CLICK_SCROLL_TIMEOUT,\n ignoreSelector: slowClickIgnoreSelectors ? slowClickIgnoreSelectors.join(',') : '',\n }\n : undefined;\n\n if (slowClickConfig) {\n this.clickDetector = new ClickDetector(this, slowClickConfig);\n }\n }\n\n /** Get the event context. */\n public getContext(): InternalEventContext {\n return this._context;\n }\n\n /** If recording is currently enabled. */\n public isEnabled(): boolean {\n return this._isEnabled;\n }\n\n /** If recording is currently paused. */\n public isPaused(): boolean {\n return this._isPaused;\n }\n\n /** Get the replay integration options. */\n public getOptions(): ReplayPluginOptions {\n return this._options;\n }\n\n /**\n * Initializes the plugin based on sampling configuration. Should not be\n * called outside of constructor.\n */\n public initializeSampling(): void {\n const { errorSampleRate, sessionSampleRate } = this._options;\n\n // If neither sample rate is > 0, then do nothing - user will need to call one of\n // `start()` or `startBuffering` themselves.\n if (errorSampleRate <= 0 && sessionSampleRate <= 0) {\n return;\n }\n\n // Otherwise if there is _any_ sample rate set, try to load an existing\n // session, or create a new one.\n const isSessionSampled = this._loadAndCheckSession();\n\n if (!isSessionSampled) {\n // This should only occur if `errorSampleRate` is 0 and was unsampled for\n // session-based replay. In this case there is nothing to do.\n return;\n }\n\n if (!this.session) {\n // This should not happen, something wrong has occurred\n this._handleException(new Error('Unable to initialize and create session'));\n return;\n }\n\n if (this.session.sampled && this.session.sampled !== 'session') {\n // If not sampled as session-based, then recording mode will be `buffer`\n // Note that we don't explicitly check if `sampled === 'buffer'` because we\n // could have sessions from Session storage that are still `error` from\n // prior SDK version.\n this.recordingMode = 'buffer';\n }\n\n logInfoNextTick(\n `[Replay] Starting replay in ${this.recordingMode} mode`,\n this._options._experiments.traceInternals,\n );\n\n this._initializeRecording();\n }\n\n /**\n * Start a replay regardless of sampling rate. Calling this will always\n * create a new session. Will throw an error if replay is already in progress.\n *\n * Creates or loads a session, attaches listeners to varying events (DOM,\n * _performanceObserver, Recording, Sentry SDK, etc)\n */\n public start(): void {\n if (this._isEnabled && this.recordingMode === 'session') {\n throw new Error('Replay recording is already in progress');\n }\n\n if (this._isEnabled && this.recordingMode === 'buffer') {\n throw new Error('Replay buffering is in progress, call `flush()` to save the replay');\n }\n\n logInfoNextTick('[Replay] Starting replay in session mode', this._options._experiments.traceInternals);\n\n const previousSessionId = this.session && this.session.id;\n\n const { session } = getSession({\n timeouts: this.timeouts,\n stickySession: Boolean(this._options.stickySession),\n currentSession: this.session,\n // This is intentional: create a new session-based replay when calling `start()`\n sessionSampleRate: 1,\n allowBuffering: false,\n traceInternals: this._options._experiments.traceInternals,\n });\n\n session.previousSessionId = previousSessionId;\n this.session = session;\n\n this._initializeRecording();\n }\n\n /**\n * Start replay buffering. Buffers until `flush()` is called or, if\n * `replaysOnErrorSampleRate` > 0, an error occurs.\n */\n public startBuffering(): void {\n if (this._isEnabled) {\n throw new Error('Replay recording is already in progress');\n }\n\n logInfoNextTick('[Replay] Starting replay in buffer mode', this._options._experiments.traceInternals);\n\n const previousSessionId = this.session && this.session.id;\n\n const { session } = getSession({\n timeouts: this.timeouts,\n stickySession: Boolean(this._options.stickySession),\n currentSession: this.session,\n sessionSampleRate: 0,\n allowBuffering: true,\n traceInternals: this._options._experiments.traceInternals,\n });\n\n session.previousSessionId = previousSessionId;\n this.session = session;\n\n this.recordingMode = 'buffer';\n this._initializeRecording();\n }\n\n /**\n * Start recording.\n *\n * Note that this will cause a new DOM checkout\n */\n public startRecording(): void {\n try {\n this._stopRecording = record({\n ...this._recordingOptions,\n // When running in error sampling mode, we need to overwrite `checkoutEveryNms`\n // Without this, it would record forever, until an error happens, which we don't want\n // instead, we'll always keep the last 60 seconds of replay before an error happened\n ...(this.recordingMode === 'buffer' && { checkoutEveryNms: BUFFER_CHECKOUT_TIME }),\n emit: getHandleRecordingEmit(this),\n onMutation: this._onMutationHandler,\n });\n } catch (err) {\n this._handleException(err);\n }\n }\n\n /**\n * Stops the recording, if it was running.\n *\n * Returns true if it was previously stopped, or is now stopped,\n * otherwise false.\n */\n public stopRecording(): boolean {\n try {\n if (this._stopRecording) {\n this._stopRecording();\n this._stopRecording = undefined;\n }\n\n return true;\n } catch (err) {\n this._handleException(err);\n return false;\n }\n }\n\n /**\n * Currently, this needs to be manually called (e.g. for tests). Sentry SDK\n * does not support a teardown\n */\n public async stop({ forceFlush = false, reason }: { forceFlush?: boolean; reason?: string } = {}): Promise<void> {\n if (!this._isEnabled) {\n return;\n }\n\n try {\n logInfo(\n `[Replay] Stopping Replay${reason ? ` triggered by ${reason}` : ''}`,\n this._options._experiments.traceInternals,\n );\n\n // We can't move `_isEnabled` after awaiting a flush, otherwise we can\n // enter into an infinite loop when `stop()` is called while flushing.\n this._isEnabled = false;\n this._removeListeners();\n this.stopRecording();\n\n this._debouncedFlush.cancel();\n // See comment above re: `_isEnabled`, we \"force\" a flush, ignoring the\n // `_isEnabled` state of the plugin since it was disabled above.\n if (forceFlush) {\n await this._flush({ force: true });\n }\n\n // After flush, destroy event buffer\n this.eventBuffer && this.eventBuffer.destroy();\n this.eventBuffer = null;\n\n // Clear session from session storage, note this means if a new session\n // is started after, it will not have `previousSessionId`\n clearSession(this);\n } catch (err) {\n this._handleException(err);\n }\n }\n\n /**\n * Pause some replay functionality. See comments for `_isPaused`.\n * This differs from stop as this only stops DOM recording, it is\n * not as thorough of a shutdown as `stop()`.\n */\n public pause(): void {\n if (this._isPaused) {\n return;\n }\n\n this._isPaused = true;\n this.stopRecording();\n\n logInfo('[Replay] Pausing replay', this._options._experiments.traceInternals);\n }\n\n /**\n * Resumes recording, see notes for `pause().\n *\n * Note that calling `startRecording()` here will cause a\n * new DOM checkout.`\n */\n public resume(): void {\n if (!this._isPaused || !this._loadAndCheckSession()) {\n return;\n }\n\n this._isPaused = false;\n this.startRecording();\n\n logInfo('[Replay] Resuming replay', this._options._experiments.traceInternals);\n }\n\n /**\n * If not in \"session\" recording mode, flush event buffer which will create a new replay.\n * Unless `continueRecording` is false, the replay will continue to record and\n * behave as a \"session\"-based replay.\n *\n * Otherwise, queue up a flush.\n */\n public async sendBufferedReplayOrFlush({ continueRecording = true }: SendBufferedReplayOptions = {}): Promise<void> {\n if (this.recordingMode === 'session') {\n return this.flushImmediate();\n }\n\n const activityTime = Date.now();\n\n logInfo('[Replay] Converting buffer to session', this._options._experiments.traceInternals);\n\n // Allow flush to complete before resuming as a session recording, otherwise\n // the checkout from `startRecording` may be included in the payload.\n // Prefer to keep the error replay as a separate (and smaller) segment\n // than the session replay.\n await this.flushImmediate();\n\n const hasStoppedRecording = this.stopRecording();\n\n if (!continueRecording || !hasStoppedRecording) {\n return;\n }\n\n // To avoid race conditions where this is called multiple times, we check here again that we are still buffering\n if ((this.recordingMode as ReplayRecordingMode) === 'session') {\n return;\n }\n\n // Re-start recording in session-mode\n this.recordingMode = 'session';\n\n // Once this session ends, we do not want to refresh it\n if (this.session) {\n this.session.shouldRefresh = false;\n\n // It's possible that the session lifespan is > max session lifespan\n // because we have been buffering beyond max session lifespan (we ignore\n // expiration given that `shouldRefresh` is true). Since we flip\n // `shouldRefresh`, the session could be considered expired due to\n // lifespan, which is not what we want. Update session start date to be\n // the current timestamp, so that session is not considered to be\n // expired. This means that max replay duration can be MAX_SESSION_LIFE +\n // (length of buffer), which we are ok with.\n this._updateUserActivity(activityTime);\n this._updateSessionActivity(activityTime);\n this._maybeSaveSession();\n }\n\n this.startRecording();\n }\n\n /**\n * We want to batch uploads of replay events. Save events only if\n * `<flushMinDelay>` milliseconds have elapsed since the last event\n * *OR* if `<flushMaxDelay>` milliseconds have elapsed.\n *\n * Accepts a callback to perform side-effects and returns true to stop batch\n * processing and hand back control to caller.\n */\n public addUpdate(cb: AddUpdateCallback): void {\n // We need to always run `cb` (e.g. in the case of `this.recordingMode == 'buffer'`)\n const cbResult = cb();\n\n // If this option is turned on then we will only want to call `flush`\n // explicitly\n if (this.recordingMode === 'buffer') {\n return;\n }\n\n // If callback is true, we do not want to continue with flushing -- the\n // caller will need to handle it.\n if (cbResult === true) {\n return;\n }\n\n // addUpdate is called quite frequently - use _debouncedFlush so that it\n // respects the flush delays and does not flush immediately\n this._debouncedFlush();\n }\n\n /**\n * Updates the user activity timestamp and resumes recording. This should be\n * called in an event handler for a user action that we consider as the user\n * being \"active\" (e.g. a mouse click).\n */\n public triggerUserActivity(): void {\n this._updateUserActivity();\n\n // This case means that recording was once stopped due to inactivity.\n // Ensure that recording is resumed.\n if (!this._stopRecording) {\n // Create a new session, otherwise when the user action is flushed, it\n // will get rejected due to an expired session.\n if (!this._loadAndCheckSession()) {\n return;\n }\n\n // Note: This will cause a new DOM checkout\n this.resume();\n return;\n }\n\n // Otherwise... recording was never suspended, continue as normalish\n this.checkAndHandleExpiredSession();\n\n this._updateSessionActivity();\n }\n\n /**\n * Updates the user activity timestamp *without* resuming\n * recording. Some user events (e.g. keydown) can be create\n * low-value replays that only contain the keypress as a\n * breadcrumb. Instead this would require other events to\n * create a new replay after a session has expired.\n */\n public updateUserActivity(): void {\n this._updateUserActivity();\n this._updateSessionActivity();\n }\n\n /**\n * Only flush if `this.recordingMode === 'session'`\n */\n public conditionalFlush(): Promise<void> {\n if (this.recordingMode === 'buffer') {\n return Promise.resolve();\n }\n\n return this.flushImmediate();\n }\n\n /**\n * Flush using debounce flush\n */\n public flush(): Promise<void> {\n return this._debouncedFlush() as Promise<void>;\n }\n\n /**\n * Always flush via `_debouncedFlush` so that we do not have flushes triggered\n * from calling both `flush` and `_debouncedFlush`. Otherwise, there could be\n * cases of mulitple flushes happening closely together.\n */\n public flushImmediate(): Promise<void> {\n this._debouncedFlush();\n // `.flush` is provided by the debounced function, analogously to lodash.debounce\n return this._debouncedFlush.flush() as Promise<void>;\n }\n\n /**\n * Cancels queued up flushes.\n */\n public cancelFlush(): void {\n this._debouncedFlush.cancel();\n }\n\n /** Get the current sesion (=replay) ID */\n public getSessionId(): string | undefined {\n return this.session && this.session.id;\n }\n\n /**\n * Checks if recording should be stopped due to user inactivity. Otherwise\n * check if session is expired and create a new session if so. Triggers a new\n * full snapshot on new session.\n *\n * Returns true if session is not expired, false otherwise.\n * @hidden\n */\n public checkAndHandleExpiredSession(): boolean | void {\n const oldSessionId = this.getSessionId();\n\n // Prevent starting a new session if the last user activity is older than\n // SESSION_IDLE_PAUSE_DURATION. Otherwise non-user activity can trigger a new\n // session+recording. This creates noisy replays that do not have much\n // content in them.\n if (\n this._lastActivity &&\n isExpired(this._lastActivity, this.timeouts.sessionIdlePause) &&\n this.session &&\n this.session.sampled === 'session'\n ) {\n // Pause recording only for session-based replays. Otherwise, resuming\n // will create a new replay and will conflict with users who only choose\n // to record error-based replays only. (e.g. the resumed replay will not\n // contain a reference to an error)\n this.pause();\n return;\n }\n\n // --- There is recent user activity --- //\n // This will create a new session if expired, based on expiry length\n if (!this._loadAndCheckSession()) {\n return;\n }\n\n // Session was expired if session ids do not match\n const expired = oldSessionId !== this.getSessionId();\n\n if (!expired) {\n return true;\n }\n\n // Session is expired, trigger a full snapshot (which will create a new session)\n this._triggerFullSnapshot();\n\n return false;\n }\n\n /**\n * Capture some initial state that can change throughout the lifespan of the\n * replay. This is required because otherwise they would be captured at the\n * first flush.\n */\n public setInitialState(): void {\n const urlPath = `${WINDOW.location.pathname}${WINDOW.location.hash}${WINDOW.location.search}`;\n const url = `${WINDOW.location.origin}${urlPath}`;\n\n this.performanceEvents = [];\n\n // Reset _context as well\n this._clearContext();\n\n this._context.initialUrl = url;\n this._context.initialTimestamp = Date.now();\n this._context.urls.push(url);\n }\n\n /**\n * Add a breadcrumb event, that may be throttled.\n * If it was throttled, we add a custom breadcrumb to indicate that.\n */\n public throttledAddEvent(\n event: RecordingEvent,\n isCheckout?: boolean,\n ): typeof THROTTLED | typeof SKIPPED | Promise<AddEventResult | null> {\n const res = this._throttledAddEvent(event, isCheckout);\n\n // If this is THROTTLED, it means we have throttled the event for the first time\n // In this case, we want to add a breadcrumb indicating that something was skipped\n if (res === THROTTLED) {\n const breadcrumb = createBreadcrumb({\n category: 'replay.throttled',\n });\n\n this.addUpdate(() => {\n void addEvent(this, {\n type: EventType.Custom,\n timestamp: breadcrumb.timestamp || 0,\n data: {\n tag: 'breadcrumb',\n payload: breadcrumb,\n metric: true,\n },\n });\n });\n }\n\n return res;\n }\n\n /**\n * This will get the parametrized route name of the current page.\n * This is only available if performance is enabled, and if an instrumented router is used.\n */\n public getCurrentRoute(): string | undefined {\n const lastTransaction = this.lastTransaction || getCurrentHub().getScope().getTransaction();\n if (!lastTransaction || !['route', 'custom'].includes(lastTransaction.metadata.source)) {\n return undefined;\n }\n\n return lastTransaction.name;\n }\n\n /**\n * Initialize and start all listeners to varying events (DOM,\n * Performance Observer, Recording, Sentry SDK, etc)\n */\n private _initializeRecording(): void {\n this.setInitialState();\n\n // this method is generally called on page load or manually - in both cases\n // we should treat it as an activity\n this._updateSessionActivity();\n\n this.eventBuffer = createEventBuffer({\n useCompression: this._options.useCompression,\n });\n\n this._removeListeners();\n this._addListeners();\n\n // Need to set as enabled before we start recording, as `record()` can trigger a flush with a new checkout\n this._isEnabled = true;\n\n this.startRecording();\n }\n\n /** A wrapper to conditionally capture exceptions. */\n private _handleException(error: unknown): void {\n __DEBUG_BUILD__ && logger.error('[Replay]', error);\n\n if (__DEBUG_BUILD__ && this._options._experiments && this._options._experiments.captureExceptions) {\n captureException(error);\n }\n }\n\n /**\n * Loads (or refreshes) the current session.\n * Returns false if session is not recorded.\n */\n private _loadAndCheckSession(): boolean {\n const { type, session } = getSession({\n timeouts: this.timeouts,\n stickySession: Boolean(this._options.stickySession),\n currentSession: this.session,\n sessionSampleRate: this._options.sessionSampleRate,\n allowBuffering: this._options.errorSampleRate > 0 || this.recordingMode === 'buffer',\n traceInternals: this._options._experiments.traceInternals,\n });\n\n // If session was newly created (i.e. was not loaded from storage), then\n // enable flag to create the root replay\n if (type === 'new') {\n this.setInitialState();\n }\n\n const currentSessionId = this.getSessionId();\n if (session.id !== currentSessionId) {\n session.previousSessionId = currentSessionId;\n }\n\n this.session = session;\n\n if (!this.session.sampled) {\n void this.stop({ reason: 'session not refreshed' });\n return false;\n }\n\n return true;\n }\n\n /**\n * Adds listeners to record events for the replay\n */\n private _addListeners(): void {\n try {\n WINDOW.document.addEventListener('visibilitychange', this._handleVisibilityChange);\n WINDOW.addEventListener('blur', this._handleWindowBlur);\n WINDOW.addEventListener('focus', this._handleWindowFocus);\n WINDOW.addEventListener('keydown', this._handleKeyboardEvent);\n\n if (this.clickDetector) {\n this.clickDetector.addListeners();\n }\n\n // There is no way to remove these listeners, so ensure they are only added once\n if (!this._hasInitializedCoreListeners) {\n addGlobalListeners(this);\n\n this._hasInitializedCoreListeners = true;\n }\n } catch (err) {\n this._handleException(err);\n }\n\n // PerformanceObserver //\n if (!('PerformanceObserver' in WINDOW)) {\n return;\n }\n\n this._performanceObserver = setupPerformanceObserver(this);\n }\n\n /**\n * Cleans up listeners that were created in `_addListeners`\n */\n private _removeListeners(): void {\n try {\n WINDOW.document.removeEventListener('visibilitychange', this._handleVisibilityChange);\n\n WINDOW.removeEventListener('blur', this._handleWindowBlur);\n WINDOW.removeEventListener('focus', this._handleWindowFocus);\n WINDOW.removeEventListener('keydown', this._handleKeyboardEvent);\n\n if (this.clickDetector) {\n this.clickDetector.removeListeners();\n }\n\n if (this._performanceObserver) {\n this._performanceObserver.disconnect();\n this._performanceObserver = undefined;\n }\n } catch (err) {\n this._handleException(err);\n }\n }\n\n /**\n * Handle when visibility of the page content changes. Opening a new tab will\n * cause the state to change to hidden because of content of current page will\n * be hidden. Likewise, moving a different window to cover the contents of the\n * page will also trigger a change to a hidden state.\n */\n private _handleVisibilityChange: () => void = () => {\n if (WINDOW.document.visibilityState === 'visible') {\n this._doChangeToForegroundTasks();\n } else {\n this._doChangeToBackgroundTasks();\n }\n };\n\n /**\n * Handle when page is blurred\n */\n private _handleWindowBlur: () => void = () => {\n const breadcrumb = createBreadcrumb({\n category: 'ui.blur',\n });\n\n // Do not count blur as a user action -- it's part of the process of them\n // leaving the page\n this._doChangeToBackgroundTasks(breadcrumb);\n };\n\n /**\n * Handle when page is focused\n */\n private _handleWindowFocus: () => void = () => {\n const breadcrumb = createBreadcrumb({\n category: 'ui.focus',\n });\n\n // Do not count focus as a user action -- instead wait until they focus and\n // interactive with page\n this._doChangeToForegroundTasks(breadcrumb);\n };\n\n /** Ensure page remains active when a key is pressed. */\n private _handleKeyboardEvent: (event: KeyboardEvent) => void = (event: KeyboardEvent) => {\n handleKeyboardEvent(this, event);\n };\n\n /**\n * Tasks to run when we consider a page to be hidden (via blurring and/or visibility)\n */\n private _doChangeToBackgroundTasks(breadcrumb?: BreadcrumbFrame): void {\n if (!this.session) {\n return;\n }\n\n const expired = isSessionExpired(this.session, this.timeouts);\n\n if (breadcrumb && !expired) {\n this._createCustomBreadcrumb(breadcrumb);\n }\n\n // Send replay when the page/tab becomes hidden. There is no reason to send\n // replay if it becomes visible, since no actions we care about were done\n // while it was hidden\n void this.conditionalFlush();\n }\n\n /**\n * Tasks to run when we consider a page to be visible (via focus and/or visibility)\n */\n private _doChangeToForegroundTasks(breadcrumb?: BreadcrumbFrame): void {\n if (!this.session) {\n return;\n }\n\n const isSessionActive = this.checkAndHandleExpiredSession();\n\n if (!isSessionActive) {\n // If the user has come back to the page within SESSION_IDLE_PAUSE_DURATION\n // ms, we will re-use the existing session, otherwise create a new\n // session\n logInfo('[Replay] Document has become active, but session has expired');\n return;\n }\n\n if (breadcrumb) {\n this._createCustomBreadcrumb(breadcrumb);\n }\n }\n\n /**\n * Trigger rrweb to take a full snapshot which will cause this plugin to\n * create a new Replay event.\n */\n private _triggerFullSnapshot(checkout = true): void {\n try {\n logInfo('[Replay] Taking full rrweb snapshot');\n record.takeFullSnapshot(checkout);\n } catch (err) {\n this._handleException(err);\n }\n }\n\n /**\n * Update user activity (across session lifespans)\n */\n private _updateUserActivity(_lastActivity: number = Date.now()): void {\n this._lastActivity = _lastActivity;\n }\n\n /**\n * Updates the session's last activity timestamp\n */\n private _updateSessionActivity(_lastActivity: number = Date.now()): void {\n if (this.session) {\n this.session.lastActivity = _lastActivity;\n this._maybeSaveSession();\n }\n }\n\n /**\n * Helper to create (and buffer) a replay breadcrumb from a core SDK breadcrumb\n */\n private _createCustomBreadcrumb(breadcrumb: BreadcrumbFrame): void {\n this.addUpdate(() => {\n void this.throttledAddEvent({\n type: EventType.Custom,\n timestamp: breadcrumb.timestamp || 0,\n data: {\n tag: 'breadcrumb',\n payload: breadcrumb,\n },\n });\n });\n }\n\n /**\n * Observed performance events are added to `this.performanceEvents`. These\n * are included in the replay event before it is finished and sent to Sentry.\n */\n private _addPerformanceEntries(): Promise<Array<AddEventResult | null>> {\n // Copy and reset entries before processing\n const entries = [...this.performanceEvents];\n this.performanceEvents = [];\n\n return Promise.all(createPerformanceSpans(this, createPerformanceEntries(entries)));\n }\n\n /**\n * Clear _context\n */\n private _clearContext(): void {\n // XXX: `initialTimestamp` and `initialUrl` do not get cleared\n this._context.errorIds.clear();\n this._context.traceIds.clear();\n this._context.urls = [];\n }\n\n /** Update the initial timestamp based on the buffer content. */\n private _updateInitialTimestampFromEventBuffer(): void {\n const { session, eventBuffer } = this;\n if (!session || !eventBuffer) {\n return;\n }\n\n // we only ever update this on the initial segment\n if (session.segmentId) {\n return;\n }\n\n const earliestEvent = eventBuffer.getEarliestTimestamp();\n if (earliestEvent && earliestEvent < this._context.initialTimestamp) {\n this._context.initialTimestamp = earliestEvent;\n }\n }\n\n /**\n * Return and clear _context\n */\n private _popEventContext(): PopEventContext {\n const _context = {\n initialTimestamp: this._context.initialTimestamp,\n initialUrl: this._context.initialUrl,\n errorIds: Array.from(this._context.errorIds),\n traceIds: Array.from(this._context.traceIds),\n urls: this._context.urls,\n };\n\n this._clearContext();\n\n return _context;\n }\n\n /**\n * Flushes replay event buffer to Sentry.\n *\n * Performance events are only added right before flushing - this is\n * due to the buffered performance observer events.\n *\n * Should never be called directly, only by `flush`\n */\n private async _runFlush(): Promise<void> {\n if (!this.session || !this.eventBuffer) {\n __DEBUG_BUILD__ && logger.error('[Replay] No session or eventBuffer found to flush.');\n return;\n }\n\n await this._addPerformanceEntries();\n\n // Check eventBuffer again, as it could have been stopped in the meanwhile\n if (!this.eventBuffer || !this.eventBuffer.hasEvents) {\n return;\n }\n\n // Only attach memory event if eventBuffer is not empty\n await addMemoryEntry(this);\n\n // Check eventBuffer again, as it could have been stopped in the meanwhile\n if (!this.eventBuffer) {\n return;\n }\n\n try {\n // This uses the data from the eventBuffer, so we need to call this before `finish()\n this._updateInitialTimestampFromEventBuffer();\n\n // Note this empties the event buffer regardless of outcome of sending replay\n const recordingData = await this.eventBuffer.finish();\n\n const timestamp = Date.now();\n\n // Check total duration again, to avoid sending outdated stuff\n // We leave 30s wiggle room to accomodate late flushing etc.\n // This _could_ happen when the browser is suspended during flushing, in which case we just want to stop\n if (timestamp - this._context.initialTimestamp > this.timeouts.maxSessionLife + 30_000) {\n throw new Error('Session is too long, not sending replay');\n }\n\n // NOTE: Copy values from instance members, as it's possible they could\n // change before the flush finishes.\n const replayId = this.session.id;\n const eventContext = this._popEventContext();\n // Always increment segmentId regardless of outcome of sending replay\n const segmentId = this.session.segmentId++;\n this._maybeSaveSession();\n\n await sendReplay({\n replayId,\n recordingData,\n segmentId,\n eventContext,\n session: this.session,\n options: this.getOptions(),\n timestamp,\n });\n } catch (err) {\n this._handleException(err);\n\n // This means we retried 3 times and all of them failed,\n // or we ran into a problem we don't want to retry, like rate limiting.\n // In this case, we want to completely stop the replay - otherwise, we may get inconsistent segments\n void this.stop({ reason: 'sendReplay' });\n\n const client = getCurrentHub().getClient();\n\n if (client) {\n client.recordDroppedEvent('send_error', 'replay');\n }\n }\n }\n\n /**\n * Flush recording data to Sentry. Creates a lock so that only a single flush\n * can be active at a time. Do not call this directly.\n */\n private _flush = async ({\n force = false,\n }: {\n /**\n * If true, flush while ignoring the `_isEnabled` state of\n * Replay integration. (By default, flush is noop if integration\n * is stopped).\n */\n force?: boolean;\n } = {}): Promise<void> => {\n if (!this._isEnabled && !force) {\n // This can happen if e.g. the replay was stopped because of exceeding the retry limit\n return;\n }\n\n if (!this.checkAndHandleExpiredSession()) {\n __DEBUG_BUILD__ && logger.error('[Replay] Attempting to finish replay event after session expired.');\n return;\n }\n\n if (!this.session) {\n __DEBUG_BUILD__ && logger.error('[Replay] No session found to flush.');\n return;\n }\n\n const start = this.session.started;\n const now = Date.now();\n const duration = now - start;\n\n // A flush is about to happen, cancel any queued flushes\n this._debouncedFlush.cancel();\n\n // If session is too short, or too long (allow some wiggle room over maxSessionLife), do not send it\n // This _should_ not happen, but it may happen if flush is triggered due to a page activity change or similar\n const tooShort = duration < this._options.minReplayDuration;\n const tooLong = duration > this.timeouts.maxSessionLife + 5_000;\n if (tooShort || tooLong) {\n logInfo(\n `[Replay] Session duration (${Math.floor(duration / 1000)}s) is too ${\n tooShort ? 'short' : 'long'\n }, not sending replay.`,\n this._options._experiments.traceInternals,\n );\n\n if (tooShort) {\n this._debouncedFlush();\n }\n return;\n }\n\n const eventBuffer = this.eventBuffer;\n if (eventBuffer && this.session.segmentId === 0 && !eventBuffer.hasCheckout) {\n logInfo('[Replay] Flushing initial segment without checkout.', this._options._experiments.traceInternals);\n // TODO FN: Evaluate if we want to stop here, or remove this again?\n }\n\n // this._flushLock acts as a lock so that future calls to `_flush()`\n // will be blocked until this promise resolves\n if (!this._flushLock) {\n this._flushLock = this._runFlush();\n await this._flushLock;\n this._flushLock = undefined;\n return;\n }\n\n // Wait for previous flush to finish, then call the debounced `_flush()`.\n // It's possible there are other flush requests queued and waiting for it\n // to resolve. We want to reduce all outstanding requests (as well as any\n // new flush requests that occur within a second of the locked flush\n // completing) into a single flush.\n\n try {\n await this._flushLock;\n } catch (err) {\n __DEBUG_BUILD__ && logger.error(err);\n } finally {\n this._debouncedFlush();\n }\n };\n\n /** Save the session, if it is sticky */\n private _maybeSaveSession(): void {\n if (this.session && this._options.stickySession) {\n saveSession(this.session);\n }\n }\n\n /** Handler for rrweb.record.onMutation */\n private _onMutationHandler = (mutations: unknown[]): boolean => {\n const count = mutations.length;\n\n const mutationLimit = this._options.mutationLimit;\n const mutationBreadcrumbLimit = this._options.mutationBreadcrumbLimit;\n const overMutationLimit = mutationLimit && count > mutationLimit;\n\n // Create a breadcrumb if a lot of mutations happen at the same time\n // We can show this in the UI as an information with potential performance improvements\n if (count > mutationBreadcrumbLimit || overMutationLimit) {\n const breadcrumb = createBreadcrumb({\n category: 'replay.mutations',\n data: {\n count,\n limit: overMutationLimit,\n },\n });\n this._createCustomBreadcrumb(breadcrumb);\n }\n\n // Stop replay if over the mutation limit\n if (overMutationLimit) {\n void this.stop({ reason: 'mutationLimit', forceFlush: this.recordingMode === 'session' });\n return false;\n }\n\n // `true` means we use the regular mutation handling by rrweb\n return true;\n };\n}\n","type DebouncedCallback = {\n (): void | unknown;\n flush: () => void | unknown;\n cancel: () => void;\n};\ntype CallbackFunction = () => unknown;\ntype DebounceOptions = { maxWait?: number };\n\n/**\n * Heavily simplified debounce function based on lodash.debounce.\n *\n * This function takes a callback function (@param fun) and delays its invocation\n * by @param wait milliseconds. Optionally, a maxWait can be specified in @param options,\n * which ensures that the callback is invoked at least once after the specified max. wait time.\n *\n * @param func the function whose invocation is to be debounced\n * @param wait the minimum time until the function is invoked after it was called once\n * @param options the options object, which can contain the `maxWait` property\n *\n * @returns the debounced version of the function, which needs to be called at least once to start the\n * debouncing process. Subsequent calls will reset the debouncing timer and, in case @paramfunc\n * was already invoked in the meantime, return @param func's return value.\n * The debounced function has two additional properties:\n * - `flush`: Invokes the debounced function immediately and returns its return value\n * - `cancel`: Cancels the debouncing process and resets the debouncing timer\n */\nexport function debounce(func: CallbackFunction, wait: number, options?: DebounceOptions): DebouncedCallback {\n let callbackReturnValue: unknown;\n\n let timerId: ReturnType<typeof setTimeout> | undefined;\n let maxTimerId: ReturnType<typeof setTimeout> | undefined;\n\n const maxWait = options && options.maxWait ? Math.max(options.maxWait, wait) : 0;\n\n function invokeFunc(): unknown {\n cancelTimers();\n callbackReturnValue = func();\n return callbackReturnValue;\n }\n\n function cancelTimers(): void {\n timerId !== undefined && clearTimeout(timerId);\n maxTimerId !== undefined && clearTimeout(maxTimerId);\n timerId = maxTimerId = undefined;\n }\n\n function flush(): unknown {\n if (timerId !== undefined || maxTimerId !== undefined) {\n return invokeFunc();\n }\n return callbackReturnValue;\n }\n\n function debounced(): unknown {\n if (timerId) {\n clearTimeout(timerId);\n }\n timerId = setTimeout(invokeFunc, wait);\n\n if (maxWait && maxTimerId === undefined) {\n maxTimerId = setTimeout(invokeFunc, maxWait);\n }\n\n return callbackReturnValue;\n }\n\n debounced.cancel = cancelTimers;\n debounced.flush = flush;\n return debounced;\n}\n","import type { DeprecatedPrivacyOptions, ReplayIntegrationPrivacyOptions } from '../types';\n\ntype GetPrivacyOptions = Required<Omit<ReplayIntegrationPrivacyOptions, 'maskFn'>> &\n Omit<DeprecatedPrivacyOptions, 'maskInputOptions'>;\ninterface GetPrivacyReturn {\n maskTextSelector: string;\n unmaskTextSelector: string;\n maskInputSelector: string;\n unmaskInputSelector: string;\n blockSelector: string;\n unblockSelector: string;\n ignoreSelector: string;\n\n blockClass?: RegExp;\n maskTextClass?: RegExp;\n}\n\nfunction getOption(\n selectors: string[],\n defaultSelectors: string[],\n deprecatedClassOption?: string | RegExp,\n deprecatedSelectorOption?: string,\n): string {\n const deprecatedSelectors = typeof deprecatedSelectorOption === 'string' ? deprecatedSelectorOption.split(',') : [];\n\n const allSelectors = [\n ...selectors,\n // @deprecated\n ...deprecatedSelectors,\n\n // sentry defaults\n ...defaultSelectors,\n ];\n\n // @deprecated\n if (typeof deprecatedClassOption !== 'undefined') {\n // NOTE: No support for RegExp\n if (typeof deprecatedClassOption === 'string') {\n allSelectors.push(`.${deprecatedClassOption}`);\n }\n\n // eslint-disable-next-line no-console\n console.warn(\n '[Replay] You are using a deprecated configuration item for privacy. Read the documentation on how to use the new privacy configuration.',\n );\n }\n\n return allSelectors.join(',');\n}\n\n/**\n * Returns privacy related configuration for use in rrweb\n */\nexport function getPrivacyOptions({\n mask,\n unmask,\n block,\n unblock,\n ignore,\n\n // eslint-disable-next-line deprecation/deprecation\n blockClass,\n // eslint-disable-next-line deprecation/deprecation\n blockSelector,\n // eslint-disable-next-line deprecation/deprecation\n maskTextClass,\n // eslint-disable-next-line deprecation/deprecation\n maskTextSelector,\n // eslint-disable-next-line deprecation/deprecation\n ignoreClass,\n}: GetPrivacyOptions): GetPrivacyReturn {\n const defaultBlockedElements = ['base[href=\"/\"]'];\n\n const maskSelector = getOption(mask, ['.sentry-mask', '[data-sentry-mask]'], maskTextClass, maskTextSelector);\n const unmaskSelector = getOption(unmask, ['.sentry-unmask', '[data-sentry-unmask]']);\n\n const options: GetPrivacyReturn = {\n // We are making the decision to make text and input selectors the same\n maskTextSelector: maskSelector,\n unmaskTextSelector: unmaskSelector,\n maskInputSelector: maskSelector,\n unmaskInputSelector: unmaskSelector,\n\n blockSelector: getOption(\n block,\n ['.sentry-block', '[data-sentry-block]', ...defaultBlockedElements],\n blockClass,\n blockSelector,\n ),\n unblockSelector: getOption(unblock, ['.sentry-unblock', '[data-sentry-unblock]']),\n ignoreSelector: getOption(ignore, ['.sentry-ignore', '[data-sentry-ignore]', 'input[type=\"file\"]'], ignoreClass),\n };\n\n if (blockClass instanceof RegExp) {\n options.blockClass = blockClass;\n }\n\n if (maskTextClass instanceof RegExp) {\n options.maskTextClass = maskTextClass;\n }\n\n return options;\n}\n","import { isNodeEnv } from '@sentry/utils';\n\n/**\n * Returns true if we are in the browser.\n */\nexport function isBrowser(): boolean {\n // eslint-disable-next-line no-restricted-globals\n return typeof window !== 'undefined' && (!isNodeEnv() || isElectronNodeRenderer());\n}\n\ntype ElectronProcess = { type?: string };\n\n// Electron renderers with nodeIntegration enabled are detected as Node.js so we specifically test for them\nfunction isElectronNodeRenderer(): boolean {\n return typeof process !== 'undefined' && (process as ElectronProcess).type === 'renderer';\n}\n","import { getCurrentHub } from '@sentry/core';\nimport type { BrowserClientReplayOptions, Integration } from '@sentry/types';\nimport { dropUndefinedKeys } from '@sentry/utils';\n\nimport {\n DEFAULT_FLUSH_MAX_DELAY,\n DEFAULT_FLUSH_MIN_DELAY,\n MIN_REPLAY_DURATION,\n MIN_REPLAY_DURATION_LIMIT,\n} from './constants';\nimport { ReplayContainer } from './replay';\nimport type { RecordingOptions, ReplayConfiguration, ReplayPluginOptions, SendBufferedReplayOptions } from './types';\nimport { getPrivacyOptions } from './util/getPrivacyOptions';\nimport { isBrowser } from './util/isBrowser';\n\nconst MEDIA_SELECTORS =\n 'img,image,svg,video,object,picture,embed,map,audio,link[rel=\"icon\"],link[rel=\"apple-touch-icon\"]';\n\nconst DEFAULT_NETWORK_HEADERS = ['content-length', 'content-type', 'accept'];\n\nlet _initialized = false;\n\ntype InitialReplayPluginOptions = Omit<ReplayPluginOptions, 'sessionSampleRate' | 'errorSampleRate'> &\n Partial<Pick<ReplayPluginOptions, 'sessionSampleRate' | 'errorSampleRate'>>;\n\n/**\n * The main replay integration class, to be passed to `init({ integrations: [] })`.\n */\nexport class Replay implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'Replay';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /**\n * Options to pass to `rrweb.record()`\n */\n private readonly _recordingOptions: RecordingOptions;\n\n /**\n * Initial options passed to the replay integration, merged with default values.\n * Note: `sessionSampleRate` and `errorSampleRate` are not required here, as they\n * can only be finally set when setupOnce() is called.\n *\n * @private\n */\n private readonly _initialOptions: InitialReplayPluginOptions;\n\n private _replay?: ReplayContainer;\n\n public constructor({\n flushMinDelay = DEFAULT_FLUSH_MIN_DELAY,\n flushMaxDelay = DEFAULT_FLUSH_MAX_DELAY,\n minReplayDuration = MIN_REPLAY_DURATION,\n stickySession = true,\n useCompression = true,\n _experiments = {},\n sessionSampleRate,\n errorSampleRate,\n maskAllText = true,\n maskAllInputs = true,\n blockAllMedia = true,\n\n mutationBreadcrumbLimit = 750,\n mutationLimit = 10_000,\n\n slowClickTimeout = 7_000,\n slowClickIgnoreSelectors = [],\n\n networkDetailAllowUrls = [],\n networkDetailDenyUrls = [],\n networkCaptureBodies = true,\n networkRequestHeaders = [],\n networkResponseHeaders = [],\n\n mask = [],\n unmask = [],\n block = [],\n unblock = [],\n ignore = [],\n maskFn,\n\n beforeAddRecordingEvent,\n\n // eslint-disable-next-line deprecation/deprecation\n blockClass,\n // eslint-disable-next-line deprecation/deprecation\n blockSelector,\n // eslint-disable-next-line deprecation/deprecation\n maskInputOptions,\n // eslint-disable-next-line deprecation/deprecation\n maskTextClass,\n // eslint-disable-next-line deprecation/deprecation\n maskTextSelector,\n // eslint-disable-next-line deprecation/deprecation\n ignoreClass,\n }: ReplayConfiguration = {}) {\n this.name = Replay.id;\n\n this._recordingOptions = {\n maskAllInputs,\n maskAllText,\n maskInputOptions: { ...(maskInputOptions || {}), password: true },\n maskTextFn: maskFn,\n maskInputFn: maskFn,\n\n ...getPrivacyOptions({\n mask,\n unmask,\n block,\n unblock,\n ignore,\n blockClass,\n blockSelector,\n maskTextClass,\n maskTextSelector,\n ignoreClass,\n }),\n\n // Our defaults\n slimDOMOptions: 'all',\n inlineStylesheet: true,\n // Disable inline images as it will increase segment/replay size\n inlineImages: false,\n // collect fonts, but be aware that `sentry.io` needs to be an allowed\n // origin for playback\n collectFonts: true,\n };\n\n this._initialOptions = {\n flushMinDelay,\n flushMaxDelay,\n minReplayDuration: Math.min(minReplayDuration, MIN_REPLAY_DURATION_LIMIT),\n stickySession,\n sessionSampleRate,\n errorSampleRate,\n useCompression,\n blockAllMedia,\n maskAllInputs,\n maskAllText,\n mutationBreadcrumbLimit,\n mutationLimit,\n slowClickTimeout,\n slowClickIgnoreSelectors,\n networkDetailAllowUrls,\n networkDetailDenyUrls,\n networkCaptureBodies,\n networkRequestHeaders: _getMergedNetworkHeaders(networkRequestHeaders),\n networkResponseHeaders: _getMergedNetworkHeaders(networkResponseHeaders),\n beforeAddRecordingEvent,\n\n _experiments,\n };\n\n if (typeof sessionSampleRate === 'number') {\n // eslint-disable-next-line\n console.warn(\n `[Replay] You are passing \\`sessionSampleRate\\` to the Replay integration.\nThis option is deprecated and will be removed soon.\nInstead, configure \\`replaysSessionSampleRate\\` directly in the SDK init options, e.g.:\nSentry.init({ replaysSessionSampleRate: ${sessionSampleRate} })`,\n );\n\n this._initialOptions.sessionSampleRate = sessionSampleRate;\n }\n\n if (typeof errorSampleRate === 'number') {\n // eslint-disable-next-line\n console.warn(\n `[Replay] You are passing \\`errorSampleRate\\` to the Replay integration.\nThis option is deprecated and will be removed soon.\nInstead, configure \\`replaysOnErrorSampleRate\\` directly in the SDK init options, e.g.:\nSentry.init({ replaysOnErrorSampleRate: ${errorSampleRate} })`,\n );\n\n this._initialOptions.errorSampleRate = errorSampleRate;\n }\n\n if (this._initialOptions.blockAllMedia) {\n // `blockAllMedia` is a more user friendly option to configure blocking\n // embedded media elements\n this._recordingOptions.blockSelector = !this._recordingOptions.blockSelector\n ? MEDIA_SELECTORS\n : `${this._recordingOptions.blockSelector},${MEDIA_SELECTORS}`;\n }\n\n if (this._isInitialized && isBrowser()) {\n throw new Error('Multiple Sentry Session Replay instances are not supported');\n }\n\n this._isInitialized = true;\n }\n\n /** If replay has already been initialized */\n protected get _isInitialized(): boolean {\n return _initialized;\n }\n\n /** Update _isInitialized */\n protected set _isInitialized(value: boolean) {\n _initialized = value;\n }\n\n /**\n * Setup and initialize replay container\n */\n public setupOnce(): void {\n if (!isBrowser()) {\n return;\n }\n\n this._setup();\n\n // Once upon a time, we tried to create a transaction in `setupOnce` and it would\n // potentially create a transaction before some native SDK integrations have run\n // and applied their own global event processor. An example is:\n // https://github.com/getsentry/sentry-javascript/blob/b47ceafbdac7f8b99093ce6023726ad4687edc48/packages/browser/src/integrations/useragent.ts\n //\n // So we call `this._initialize()` in next event loop as a workaround to wait for other\n // global event processors to finish. This is no longer needed, but keeping it\n // here to avoid any future issues.\n setTimeout(() => this._initialize());\n }\n\n /**\n * Start a replay regardless of sampling rate. Calling this will always\n * create a new session. Will throw an error if replay is already in progress.\n *\n * Creates or loads a session, attaches listeners to varying events (DOM,\n * PerformanceObserver, Recording, Sentry SDK, etc)\n */\n public start(): void {\n if (!this._replay) {\n return;\n }\n\n this._replay.start();\n }\n\n /**\n * Start replay buffering. Buffers until `flush()` is called or, if\n * `replaysOnErrorSampleRate` > 0, until an error occurs.\n */\n public startBuffering(): void {\n if (!this._replay) {\n return;\n }\n\n this._replay.startBuffering();\n }\n\n /**\n * Currently, this needs to be manually called (e.g. for tests). Sentry SDK\n * does not support a teardown\n */\n public stop(): Promise<void> {\n if (!this._replay) {\n return Promise.resolve();\n }\n\n return this._replay.stop({ forceFlush: this._replay.recordingMode === 'session' });\n }\n\n /**\n * If not in \"session\" recording mode, flush event buffer which will create a new replay.\n * Unless `continueRecording` is false, the replay will continue to record and\n * behave as a \"session\"-based replay.\n *\n * Otherwise, queue up a flush.\n */\n public flush(options?: SendBufferedReplayOptions): Promise<void> {\n if (!this._replay || !this._replay.isEnabled()) {\n return Promise.resolve();\n }\n\n return this._replay.sendBufferedReplayOrFlush(options);\n }\n\n /**\n * Get the current session ID.\n */\n public getReplayId(): string | undefined {\n if (!this._replay || !this._replay.isEnabled()) {\n return;\n }\n\n return this._replay.getSessionId();\n }\n /**\n * Initializes replay.\n */\n protected _initialize(): void {\n if (!this._replay) {\n return;\n }\n\n this._replay.initializeSampling();\n }\n\n /** Setup the integration. */\n private _setup(): void {\n // Client is not available in constructor, so we need to wait until setupOnce\n const finalOptions = loadReplayOptionsFromClient(this._initialOptions);\n\n this._replay = new ReplayContainer({\n options: finalOptions,\n recordingOptions: this._recordingOptions,\n });\n }\n}\n\n/** Parse Replay-related options from SDK options */\nfunction loadReplayOptionsFromClient(initialOptions: InitialReplayPluginOptions): ReplayPluginOptions {\n const client = getCurrentHub().getClient();\n const opt = client && (client.getOptions() as BrowserClientReplayOptions);\n\n const finalOptions = { sessionSampleRate: 0, errorSampleRate: 0, ...dropUndefinedKeys(initialOptions) };\n\n if (!opt) {\n // eslint-disable-next-line no-console\n console.warn('SDK client is not available.');\n return finalOptions;\n }\n\n if (\n initialOptions.sessionSampleRate == null && // TODO remove once deprecated rates are removed\n initialOptions.errorSampleRate == null && // TODO remove once deprecated rates are removed\n opt.replaysSessionSampleRate == null &&\n opt.replaysOnErrorSampleRate == null\n ) {\n // eslint-disable-next-line no-console\n console.warn(\n 'Replay is disabled because neither `replaysSessionSampleRate` nor `replaysOnErrorSampleRate` are set.',\n );\n }\n\n if (typeof opt.replaysSessionSampleRate === 'number') {\n finalOptions.sessionSampleRate = opt.replaysSessionSampleRate;\n }\n\n if (typeof opt.replaysOnErrorSampleRate === 'number') {\n finalOptions.errorSampleRate = opt.replaysOnErrorSampleRate;\n }\n\n return finalOptions;\n}\n\nfunction _getMergedNetworkHeaders(headers: string[]): string[] {\n return [...DEFAULT_NETWORK_HEADERS, ...headers.map(header => header.toLowerCase())];\n}\n","import { useAppState } from './context/State';\nimport Loader from './components/Loader';\nimport { BrowserRouter as Router, Routes, Route, Navigate } from 'react-router-dom';\nimport FilteredVideoCarousel from './components/FilteredVideoCarousel';\nimport BrandPage from './components/BrandPage';\nimport './App.scss';\nimport ScrollToTop from './hooks/scrollToTop';\nimport * as Sentry from '@sentry/browser';\nimport { useEffect, useState } from 'react';\n\nSentry.init({\n dsn: 'https://4db026b9d53aec750f8960410faa9ead@o4504488188903424.ingest.sentry.io/4505705728507904',\n integrations: [\n new Sentry.BrowserTracing({\n // Set 'tracePropagationTargets' to control for which URLs distributed tracing should be enabled\n tracePropagationTargets: ['localhost', 'https:yourserver.io/api/'],\n }),\n new Sentry.Replay(),\n ],\n // Performance Monitoring\n tracesSampleRate: 1.0, // Capture 100% of the transactions, reduce in production!\n // Session Replay\n replaysSessionSampleRate: 0.1, // This sets the sample rate at 10%. You may want to change it to 100% while in development and then sample at a lower rate in production.\n replaysOnErrorSampleRate: 1.0, // If you're not already sampling the entire session, change the sample rate to 100% when sampling sessions where errors occur.\n});\n\nfunction App() {\n const state = useAppState();\n const { hasError, ready } = state;\n const [scrollPosition, setScrollPosition] = useState(0);\n const handleScroll = () => {\n const position = window.scrollY;\n setScrollPosition(position);\n };\n\n useEffect(() => {\n window.addEventListener('scroll', handleScroll, { passive: true });\n const header = document.getElementsByClassName('header-main-nav')[0];\n if (scrollPosition === 0) {\n header?.classList.remove('scrolled');\n } else {\n header?.classList.add('scrolled');\n }\n return () => {\n window.removeEventListener('scroll', handleScroll);\n };\n }, [scrollPosition]);\n\n if (hasError) {\n return <div>Error occurred. Please try again later.</div>;\n }\n\n if (!ready || !state || !state.adData) {\n return (\n <div className=\"appContainer\">\n <Loader />\n </div>\n );\n }\n const home = [\n '/wp-content/themes/criteo2017/react/ad-gallery/build/ad-gallery/',\n '/',\n '/ad-gallery/',\n '/es/ad-gallery/',\n '/es/',\n '/kr/ad-gallery/',\n '/de/ad-gallery/',\n '/fr/ad-gallery/',\n '/es/ad-gallery/',\n '/br/ad-gallery/',\n '/jp/ad-gallery/',\n '/it/ad-gallery/',\n '/ru/ad-gallery/',\n '/es/ad-gallery/',\n '/ru/ad-gallery/',\n '/pl/ad-gallery/',\n '/cn/ad-gallery/',\n ];\n\n return (\n <div className=\"appContainer\">\n <ScrollToTop />\n <Routes>\n {home.map((path) => (\n <Route key={path} path={path} element={<FilteredVideoCarousel />} />\n ))}\n {home.map((path) => (\n <Route key={path} path={`${path}display/:brand`} element={<BrandPage />} />\n ))}\n {home.map((path) => (\n <Route key={path} path={`${path}video/:brand`} element={<BrandPage />} />\n ))}\n {home.map((path) => (\n <Route key={path} path={`${path}video`} element={<Navigate to=\"/\" />} />\n ))}\n {home.map((path) => (\n <Route key={path} path={`${path}display`} element={<Navigate to=\"/\" />} />\n ))}\n </Routes>\n </div>\n );\n}\n\nexport default App;\n","import React from 'react';\nimport ReactDOM from 'react-dom/client';\nimport { BrowserRouter as Router } from 'react-router-dom';\nimport App from './App';\nimport AppState from './context/State';\n\nconst root = ReactDOM.createRoot(document.getElementById('root'));\nroot.render(\n <React.StrictMode>\n <AppState>\n <Router>\n <App />\n </Router>\n </AppState>\n </React.StrictMode>,\n);\n"],"names":["Object","nowSeconds","now","timeOrigin","platformPerformance","dateTimestampSource","Math","threshold","_browserPerformanceTimeOriginMode","isGlobalObj","obj","reactIs","require","REACT_STATICS","childContextTypes","contextType","contextTypes","defaultProps","displayName","getDefaultProps","getDerivedStateFromError","getDerivedStateFromProps","mixins","propTypes","type","KNOWN_STATICS","name","length","prototype","caller","callee","arguments","arity","MEMO_STATICS","compare","TYPE_STATICS","getStatics","component","isMemo","ForwardRef","render","Memo","defineProperty","getOwnPropertyNames","getOwnPropertySymbols","getOwnPropertyDescriptor","getPrototypeOf","objectPrototype","module","exports","hoistNonReactStatics","targetComponent","sourceComponent","blacklist","inheritedComponent","keys","concat","targetStatics","sourceStatics","i","key","descriptor","e","aa","ca","p","a","b","c","encodeURIComponent","da","Set","ea","fa","ha","add","ia","window","document","createElement","ja","hasOwnProperty","ka","la","ma","v","d","f","g","this","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","removeEmptyString","z","split","forEach","toLowerCase","ra","sa","toUpperCase","ta","slice","pa","isNaN","qa","call","test","oa","removeAttribute","setAttribute","setAttributeNS","replace","xlinkHref","ua","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","va","Symbol","for","wa","ya","za","Aa","Ba","Ca","Da","Ea","Fa","Ga","Ha","Ia","Ja","iterator","Ka","La","A","assign","Ma","Error","stack","trim","match","Na","Oa","prepareStackTrace","set","Reflect","construct","l","h","k","includes","Pa","tag","Qa","$$typeof","_context","_payload","_init","Ra","Sa","Ta","nodeName","Va","_valueTracker","constructor","get","configurable","enumerable","getValue","setValue","stopTracking","Ua","Wa","checked","value","Xa","activeElement","body","Ya","defaultChecked","defaultValue","_wrapperState","initialChecked","Za","initialValue","controlled","ab","bb","cb","db","ownerDocument","eb","Array","isArray","fb","options","selected","defaultSelected","disabled","gb","dangerouslySetInnerHTML","children","hb","ib","jb","textContent","kb","lb","mb","nb","namespaceURI","innerHTML","valueOf","toString","firstChild","removeChild","appendChild","MSApp","execUnsafeLocalFunction","ob","lastChild","nodeType","nodeValue","pb","animationIterationCount","aspectRatio","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","fontWeight","lineClamp","lineHeight","opacity","order","orphans","tabSize","widows","zIndex","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","qb","rb","sb","style","indexOf","setProperty","charAt","substring","tb","menuitem","area","base","br","col","embed","hr","img","input","keygen","link","meta","param","source","track","wbr","ub","vb","is","wb","xb","target","srcElement","correspondingUseElement","parentNode","yb","zb","Ab","Bb","Cb","stateNode","Db","Eb","push","Fb","Gb","Hb","Ib","Jb","Kb","Lb","Mb","addEventListener","removeEventListener","Nb","apply","m","onError","Ob","Pb","Qb","Rb","Sb","Tb","Vb","alternate","return","flags","Wb","memoizedState","dehydrated","Xb","Zb","child","sibling","current","Yb","$b","ac","unstable_scheduleCallback","bc","unstable_cancelCallback","cc","unstable_shouldYield","dc","unstable_requestPaint","B","unstable_now","ec","unstable_getCurrentPriorityLevel","fc","unstable_ImmediatePriority","gc","unstable_UserBlockingPriority","hc","unstable_NormalPriority","ic","unstable_LowPriority","jc","unstable_IdlePriority","kc","lc","oc","clz32","pc","qc","log","LN2","rc","sc","tc","uc","pendingLanes","suspendedLanes","pingedLanes","entangledLanes","entanglements","vc","xc","yc","zc","Ac","eventTimes","Cc","C","Dc","Ec","Fc","Gc","Hc","Ic","Jc","Kc","Lc","Mc","Nc","Oc","Map","Pc","Qc","Rc","Sc","delete","pointerId","Tc","nativeEvent","blockedOn","domEventName","eventSystemFlags","targetContainers","Vc","Wc","priority","isDehydrated","containerInfo","Xc","Yc","dispatchEvent","shift","Zc","$c","ad","bd","cd","ReactCurrentBatchConfig","dd","ed","transition","fd","gd","hd","id","Uc","stopPropagation","jd","kd","ld","md","nd","od","keyCode","charCode","pd","qd","rd","_reactName","_targetInst","currentTarget","isDefaultPrevented","defaultPrevented","returnValue","isPropagationStopped","preventDefault","cancelBubble","persist","isPersistent","wd","xd","yd","sd","eventPhase","bubbles","cancelable","timeStamp","Date","isTrusted","td","ud","view","detail","vd","Ad","screenX","screenY","clientX","clientY","pageX","pageY","ctrlKey","shiftKey","altKey","metaKey","getModifierState","zd","button","buttons","relatedTarget","fromElement","toElement","movementX","movementY","Bd","Dd","dataTransfer","Fd","Hd","animationName","elapsedTime","pseudoElement","Id","clipboardData","Jd","Ld","data","Md","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","Nd","Od","Alt","Control","Meta","Shift","Pd","Qd","String","fromCharCode","code","location","repeat","locale","which","Rd","Td","width","height","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","Vd","touches","targetTouches","changedTouches","Xd","Yd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","Zd","$d","ae","be","documentMode","ce","de","ee","fe","ge","he","ie","le","color","date","datetime","email","month","number","password","range","search","tel","text","time","url","week","me","ne","oe","event","listeners","pe","qe","re","se","te","ue","ve","we","xe","ye","ze","oninput","Ae","detachEvent","Be","Ce","attachEvent","De","Ee","Fe","He","Ie","Je","Ke","node","offset","nextSibling","Le","contains","compareDocumentPosition","Me","HTMLIFrameElement","contentWindow","href","Ne","contentEditable","Oe","focusedElem","selectionRange","documentElement","start","end","selectionStart","selectionEnd","min","defaultView","getSelection","extend","rangeCount","anchorNode","anchorOffset","focusNode","focusOffset","createRange","setStart","removeAllRanges","addRange","setEnd","element","left","scrollLeft","top","scrollTop","focus","Pe","Qe","Re","Se","Te","Ue","Ve","We","animationend","animationiteration","animationstart","transitionend","Xe","Ye","Ze","animation","$e","af","bf","cf","df","ef","ff","gf","hf","lf","mf","nf","Ub","instance","listener","D","of","has","pf","qf","rf","random","sf","bind","capture","passive","n","t","J","x","u","w","F","tf","uf","parentWindow","vf","wf","na","xa","$a","ba","je","char","ke","unshift","xf","yf","zf","Af","Bf","Cf","Df","Ef","__html","Ff","setTimeout","Gf","clearTimeout","Hf","Promise","Jf","queueMicrotask","resolve","then","catch","If","Kf","Lf","Mf","previousSibling","Nf","Of","Pf","Qf","Rf","Sf","Tf","Uf","E","G","Vf","H","Wf","Xf","Yf","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Zf","$f","ag","bg","getChildContext","cg","__reactInternalMemoizedMergedChildContext","dg","eg","fg","gg","hg","jg","kg","lg","mg","ng","og","pg","qg","rg","sg","tg","ug","vg","wg","xg","yg","I","zg","Ag","Bg","elementType","deletions","Cg","pendingProps","overflow","treeContext","retryLane","Dg","mode","Eg","Fg","Gg","memoizedProps","Hg","Ig","Jg","Kg","Lg","Mg","Ng","Og","Pg","Qg","Rg","_currentValue","Sg","childLanes","Tg","dependencies","firstContext","lanes","Ug","Vg","context","memoizedValue","next","Wg","Xg","Yg","interleaved","Zg","$g","ah","updateQueue","baseState","firstBaseUpdate","lastBaseUpdate","shared","pending","effects","bh","ch","eventTime","lane","payload","callback","dh","K","eh","fh","gh","q","r","y","hh","ih","jh","Component","refs","kh","nh","isMounted","_reactInternals","enqueueSetState","L","lh","mh","enqueueReplaceState","enqueueForceUpdate","oh","shouldComponentUpdate","isPureReactComponent","ph","state","updater","qh","componentWillReceiveProps","UNSAFE_componentWillReceiveProps","rh","props","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","componentDidMount","sh","ref","_owner","_stringRef","th","join","uh","vh","index","wh","xh","yh","implementation","zh","Ah","done","Bh","Ch","Dh","Eh","Fh","Gh","Hh","Ih","tagName","Jh","Kh","Lh","M","Mh","revealOrder","Nh","Oh","_workInProgressVersionPrimary","Ph","ReactCurrentDispatcher","Qh","Rh","N","O","P","Sh","Th","Uh","Vh","Q","Wh","Xh","Yh","Zh","$h","ai","bi","ci","baseQueue","queue","di","ei","fi","lastRenderedReducer","action","hasEagerState","eagerState","lastRenderedState","dispatch","gi","hi","ii","ji","ki","getSnapshot","li","mi","R","ni","lastEffect","stores","oi","pi","qi","ri","create","destroy","deps","si","ti","ui","vi","wi","xi","yi","zi","Ai","Bi","Ci","Di","Ei","Fi","Gi","Hi","Ii","Ji","readContext","useCallback","useContext","useEffect","useImperativeHandle","useInsertionEffect","useLayoutEffect","useMemo","useReducer","useRef","useState","useDebugValue","useDeferredValue","useTransition","useMutableSource","useSyncExternalStore","useId","unstable_isNewReconciler","identifierPrefix","Ki","message","digest","Li","Mi","console","error","Ni","WeakMap","Oi","Pi","Qi","Ri","componentDidCatch","Si","componentStack","Ti","pingCache","Ui","Vi","Wi","Xi","ReactCurrentOwner","Yi","Zi","$i","aj","bj","cj","dj","ej","baseLanes","cachePool","transitions","fj","gj","hj","ij","jj","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","kj","lj","pendingContext","mj","Aj","Cj","Dj","nj","oj","pj","fallback","qj","rj","tj","dataset","dgst","uj","vj","_reactRetry","sj","subtreeFlags","wj","xj","isBackwards","rendering","renderingStartTime","last","tail","tailMode","yj","Ej","S","Fj","Gj","wasMultiple","multiple","suppressHydrationWarning","onClick","onclick","size","createElementNS","autoFocus","createTextNode","T","Hj","Ij","Jj","Kj","U","Lj","WeakSet","V","Mj","W","Nj","Oj","Qj","Rj","Sj","Tj","Uj","Vj","Wj","insertBefore","_reactRootContainer","Xj","X","Yj","Zj","ak","onCommitFiberUnmount","componentWillUnmount","bk","ck","dk","ek","fk","isHidden","gk","hk","display","ik","jk","kk","lk","__reactInternalSnapshotBeforeUpdate","src","Wk","mk","ceil","nk","ok","pk","Y","Z","qk","rk","sk","tk","uk","Infinity","vk","wk","xk","yk","zk","Ak","Bk","Ck","Dk","Ek","callbackNode","expirationTimes","expiredLanes","wc","callbackPriority","ig","Fk","Gk","Hk","Ik","Jk","Kk","Lk","Mk","Nk","Ok","Pk","finishedWork","finishedLanes","Qk","timeoutHandle","Rk","Sk","Tk","Uk","Vk","mutableReadLanes","Bc","Pj","onCommitFiberRoot","mc","onRecoverableError","Xk","onPostCommitFiberRoot","Yk","Zk","al","isReactComponent","pendingChildren","bl","mutableSourceEagerHydrationData","cl","cache","pendingSuspenseBoundaries","dl","el","fl","gl","hl","il","jl","zj","$k","ll","reportError","ml","_internalRoot","nl","ol","pl","ql","sl","rl","unmount","unstable_scheduleHydration","splice","querySelectorAll","JSON","stringify","form","tl","usingClientEntryPoint","Events","ul","findFiberByHostInstance","bundleType","version","rendererPackageName","vl","rendererConfig","overrideHookState","overrideHookStateDeletePath","overrideHookStateRenamePath","overrideProps","overridePropsDeletePath","overridePropsRenamePath","setErrorHandler","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","reconcilerVersion","__REACT_DEVTOOLS_GLOBAL_HOOK__","wl","isDisabled","supportsFiber","inject","createPortal","createRoot","unstable_strictMode","findDOMNode","flushSync","hydrate","hydrateRoot","hydratedSources","_getVersion","_source","unmountComponentAtNode","unstable_batchedUpdates","unstable_renderSubtreeIntoContainer","checkDCE","err","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Element","Fragment","Lazy","Portal","Profiler","StrictMode","Suspense","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isElement","isForwardRef","isFragment","isLazy","isPortal","isProfiler","isStrictMode","isSuspense","isValidElementType","typeOf","__self","__source","jsx","jsxs","setState","forceUpdate","escape","_status","_result","default","Children","map","count","toArray","only","PureComponent","cloneElement","createContext","_currentValue2","_threadCount","Provider","Consumer","_defaultValue","_globalName","createFactory","createRef","forwardRef","isValidElement","lazy","memo","startTransition","unstable_act","pop","sortIndex","performance","setImmediate","startTime","expirationTime","priorityLevel","navigator","scheduling","isInputPending","MessageChannel","port2","port1","onmessage","postMessage","unstable_Profiling","unstable_continueExecution","unstable_forceFrameRate","floor","unstable_getFirstCallbackNode","unstable_next","unstable_pauseExecution","unstable_runWithPriority","delay","unstable_wrapCallback","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","loaded","__webpack_modules__","leafPrototypes","getProto","__proto__","__esModule","ns","def","definition","o","globalThis","Function","hmd","prop","toStringTag","Action","_arrayWithHoles","arr","_arrayLikeToArray","len","arr2","_unsupportedIterableToArray","minLen","from","_nonIterableRest","TypeError","_i","_s","_e","_arr","_n","_d","_iterableToArray","iter","Constructor","_defineProperties","writable","protoProps","staticProps","_setPrototypeOf","setPrototypeOf","_inherits","subClass","superClass","_getPrototypeOf","_isNativeReflectConstruct","sham","Proxy","Boolean","_typeof","_assertThisInitialized","self","ReferenceError","_possibleConstructorReturn","_createSuper","Derived","hasNativeReflectConstruct","result","Super","NewTarget","_construct","Parent","args","Class","_wrapNativeSuper","_cache","fn","Wrapper","allowArrayLike","it","s","normalCompletion","didErr","step","_e2","ResultType","PopStateEventType","invariant","warning","cond","warn","getHistoryState","usr","idx","createLocation","to","pathname","hash","parsePath","substr","_ref","path","parsedPath","hashIndex","searchIndex","getUrlBasedHistory","getLocation","createHref","validateLocation","v5Compat","globalHistory","history","Pop","getIndex","handlePop","nextIndex","delta","createURL","origin","createPath","URL","replaceState","listen","encodeLocation","Push","historyState","pushState","Replace","go","matchRoutes","routes","locationArg","basename","stripBasename","branches","flattenRoutes","sort","score","siblings","every","compareIndexes","routesMeta","childrenIndex","rankRouteBranches","matches","matchRouteBranch","safelyDecodeURI","parentsMeta","parentPath","flattenRoute","route","relativePath","caseSensitive","startsWith","joinPaths","computeScore","explodeOptionalSegments","exploded","segments","first","rest","isOptional","endsWith","required","restExploded","subpath","paramRe","isSplat","initialScore","some","filter","reduce","segment","branch","matchedParams","matchedPathname","remainingPathname","matchPath","params","pathnameBase","normalizePathname","pattern","paramNames","regexpSource","_","paramName","RegExp","compilePath","matcher","captureGroups","splatValue","decodeURIComponent","safelyDecodeURIComponent","decodeURI","startIndex","nextChar","getInvalidPathError","field","dest","getPathContributingMatches","resolveTo","toArg","routePathnames","locationPathname","isPathRelative","isEmptyPath","toPathname","routePathnameIndex","toSegments","fromPathname","resolvePathname","normalizeSearch","normalizeHash","resolvePath","hasExplicitTrailingSlash","hasCurrentTrailingSlash","paths","AbortedDeferredError","isRouteErrorResponse","status","statusText","internal","validMutationMethodsArr","validRequestMethodsArr","DataRouterContext","React","DataRouterStateContext","AwaitContext","NavigationContext","LocationContext","RouteContext","outlet","isDataRoute","RouteErrorContext","useInRouterContext","useLocation","useIsomorphicLayoutEffect","static","useNavigate","router","useDataRouterContext","DataRouterHook","UseNavigateStable","useCurrentRouteId","DataRouterStateHook","activeRef","navigate","fromRouteId","useNavigateStable","routePathnamesJson","parse","relative","useNavigateUnstable","useResolvedPath","_temp2","useRoutesImpl","dataRouterState","parentMatches","routeMatch","parentParams","parentPathnameBase","locationFromContext","parsedLocationArg","renderedMatches","_renderMatches","navigationType","NavigationType","DefaultErrorComponent","useDataRouterState","UseRouteError","routeId","errors","_state$errors","useRouteError","lightgrey","preStyles","padding","backgroundColor","fontStyle","defaultErrorElement","RenderErrorBoundary","revalidation","errorInfo","routeContext","RenderedRoute","dataRouterContext","staticContext","errorElement","ErrorBoundary","_deepestRenderedBoundaryId","_dataRouterState","_dataRouterState2","errorIndex","findIndex","reduceRight","getChildren","hookName","ctx","useRouteContext","thisRoute","AwaitRenderStatus","Navigate","_ref4","jsonPath","Route","_props","Router","_ref5","basenameProp","locationProp","staticProp","navigationContext","locationContext","trailingPathname","Routes","_ref6","createRoutesFromChildren","neverSettledPromise","treePath","loader","hasErrorBoundary","shouldRevalidate","handle","BrowserRouter","historyRef","createBrowserHistory","isBrowser","ABSOLUTE_URL_REGEX","Link","absoluteHref","reloadDocument","preventScrollReset","isExternal","currentUrl","targetUrl","protocol","_temp","joinedPathname","useHref","internalOnClick","replaceProp","isModifiedEvent","shouldProcessLinkClick","useLinkClickHandler","StateContext","shuffleArray","array","j","_defs","_g","useAppState","largeDataSet","setDisplay","video","setVideo","config","setConfig","ready","updateReady","copy","setCopy","adSizes","setAdSizes","updateLocale","activeOption","setActiveOption","expaned","setExpanded","langCode","lang","retryCount","fetchData","fetch","response","json","fields","ads","conf","item","primaryLang","otherLangs","entries","langs","convertCopy","adData","videoData","_objectWithoutProperties","excluded","sourceKeys","sourceSymbolKeys","propertyIsEnumerable","SvgTailSpin","svgRef","title","titleId","viewBox","xmlns","x1","y1","x2","y2","stopColor","fill","fillRule","transform","stroke","dur","repeatCount","cx","cy","hasError","className","ownKeys","object","enumerableOnly","symbols","sym","_objectSpread2","getOwnPropertyDescriptors","defineProperties","GetCopy","_toPropertyKey","arg","hint","prim","toPrimitive","res","Number","_x","_r","_excluded","StyleSheet","_this","_insertTag","before","tags","insertionPoint","prepend","container","isSpeedy","speedy","ctr","nonce","_proto","nodes","insert","rule","createStyleElement","sheet","styleSheets","ownerNode","sheetForTag","insertRule","cssRules","process","flush","abs","replacement","indexof","charat","charCodeAt","begin","strlen","sizeof","append","line","column","position","character","characters","root","parent","prev","peek","caret","token","alloc","dealloc","delimit","delimiter","whitespace","escaping","commenter","identifier","MS","MOZ","WEBKIT","COMMENT","RULESET","DECLARATION","KEYFRAMES","serialize","output","compile","rules","rulesets","pseudo","points","declarations","atrule","property","previous","variable","scanning","ampersand","reference","comment","declaration","ruleset","post","identifierWithPointTracking","getRules","parsed","toRules","fixedElements","compat","isImplicitRule","parentRules","removeLabel","prefix","defaultStylisPlugins","combine","exec","createCache","ssrStyles","getAttribute","head","stylisPlugins","_insert","inserted","nodesToHydrate","attrib","currentSheet","finalizingPlugins","serializer","collection","middleware","selector","serialized","shouldCache","styles","registered","registerStyles","isStringTag","unitlessKeys","msGridRow","msGridRowSpan","msGridColumn","msGridColumnSpan","WebkitLineClamp","memoize","hyphenateRegex","animationRegex","isCustomProperty","isProcessableValue","processStyleName","styleName","processStyleValue","p1","p2","cursor","unitless","handleInterpolation","mergedProps","interpolation","__emotion_styles","anim","string","_key","interpolated","createStringFromObject","previousCursor","cached","labelPattern","serializeStyles","stringMode","strings","raw","lastIndex","identifierName","str","hashString","useInsertionEffectAlwaysWithSyncFallback","EmotionCacheContext","HTMLElement","withEmotionCache","func","ThemeContext","typePropName","createEmotionProps","newProps","Insertion","insertStyles","Emotion","cssProp","css","WrappedComponent","registeredStyles","classNames","rawClassName","getRegisteredStyles","Emotion$1","argsLength","createElementArgArray","_len","Op","hasOwn","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","define","wrap","innerFn","outerFn","tryLocsList","protoGenerator","Generator","generator","Context","_invoke","method","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","sent","_sent","dispatchException","abrupt","record","tryCatch","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","NativeIteratorPrototype","values","Gp","defineIteratorMethods","AsyncIterator","PromiseImpl","invoke","reject","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","info","resultName","nextLoc","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","reset","iterable","iteratorMethod","isGeneratorFunction","genFun","ctor","mark","awrap","async","reverse","skipTempReset","stop","rootRecord","rval","exception","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","asyncGeneratorStep","gen","_next","_throw","max","round","createCoords","rectToClientRect","rect","right","bottom","getNodeName","isNode","getWindow","_node$ownerDocument","getDocumentElement","Node","isHTMLElement","isShadowRoot","ShadowRoot","isOverflowElement","getComputedStyle","overflowX","overflowY","isWebKit","CSS","supports","isLastTraversableNode","getParentNode","assignedSlot","host","getNearestOverflowAncestor","getOverflowAncestors","list","_node$ownerDocument2","scrollableAncestor","isBody","win","visualViewport","getCssDimensions","parseFloat","hasOffset","offsetWidth","offsetHeight","shouldFallback","$","unwrapElement","contextElement","getScale","domElement","getBoundingClientRect","isFinite","noOffsets","getVisualOffsets","offsetLeft","offsetTop","includeScale","isFixedStrategy","offsetParent","clientRect","scale","visualOffsets","isFixed","floatingOffsetParent","shouldAddVisualOffsets","offsetWin","currentIFrame","frameElement","iframeScale","iframeRect","clientLeft","paddingLeft","clientTop","paddingTop","autoUpdate","floating","update","ancestorScroll","ancestorResize","elementResize","ResizeObserver","layoutShift","IntersectionObserver","animationFrame","referenceEl","ancestors","ancestor","frameId","cleanupIo","onMove","timeoutId","io","cleanup","disconnect","refresh","skip","rootMargin","clientWidth","clientHeight","isFirstUpdate","handleObserve","observe","ratio","intersectionRatio","observeMove","reobserveFrame","resizeObserver","firstEntry","unobserve","cancelAnimationFrame","requestAnimationFrame","prevRefRect","frameLoop","nextRefRect","insertable","freeze","safeIsNaN","areInputsEqual","newInputs","lastInputs","second","resultFn","isEqual","memoized","newArgs","lastThis","lastArgs","lastResult","clear","StateManagedSelect","baseSelectProps","_ref$defaultInputValu","defaultInputValue","_ref$defaultMenuIsOpe","defaultMenuIsOpen","_ref$defaultValue","propsInputValue","inputValue","propsMenuIsOpen","menuIsOpen","propsOnChange","onChange","propsOnInputChange","onInputChange","propsOnMenuClose","onMenuClose","propsOnMenuOpen","onMenuOpen","propsValue","restSelectProps","_useState2","_slicedToArray","stateInputValue","setStateInputValue","_useState4","stateMenuIsOpen","setStateMenuIsOpen","_useState6","stateValue","setStateValue","actionMeta","newValue","_objectSpread","useStateManager","Select","_extends","StateManagedSelect$1","selectedFormat","setSelectedFormat","setNextAdIndex","uniqueFormats","setUniqueFormats","selectedLabel","updateSelectedLabel","handleSelectChange","label","Format","formats","format","colourStyles","control","borderColor","border","boxShadow","maxWidth","menu","indicatorSeparator","option","isFocused","isSelected","MyComponent","isSearchable","components","DropdownIndicator","IndicatorSeparator","observerMap","RootIds","rootId","unsupportedValue","optionsToId","getRootId","createObserver","thresholds","elements","observer","inView","isIntersecting","trackVisibility","isVisible","fallbackInView","bounds","boundingClientRect","intersectionRect","rootBounds","callbacks","isPlainChildren","useInView","triggerOnce","initialInView","setRef","entryTarget","previousEntryTarget","_path","videoRef","inViewRef","combinedRef","brandSlug","Brand","playState","updatePlayState","handleMouseEnter","play","handleMouseLeave","pause","currentTime","userAgent","videoUrlVideo","muted","controls","playsInline","autoPlay","onMouseEnter","onMouseLeave","videoUrl300x250","selectedOption","filteredData","setFilteredData","visibleAdData","setVisibleAdData","loadMoreAds","prevData","newIndex","LoadMoreButtonComponent","handleInView","timer","debounce","dt","dataToPreview","Live","SvgCheck","_rect","_rect2","_rect3","_rect4","_rect5","_rect6","_rect7","_rect8","_rect9","_rect10","_rect11","_rect12","prevOption","toLocaleLowerCase","showCopy","brand","goBack","textAlign","nextAdIndex","SvgVipad300X250","xmlnsXlink","patternContentUnits","_rect13","_rect14","SvgVipad300X600","SvgPc970X250","rx","_rect15","_rect16","_rect17","_rect18","_rect19","_rect20","_rect21","_rect22","_rect23","_rect24","_rect25","_rect26","_rect27","_rect28","_rect29","_rect30","SvgPc160X600","SvgCtv","SvgExpandContent","SvgCollapseAll","brandData","adSize","sizeToUse","videoElement","loop","getTablet","SvgArrowUpRight","SvgBackButton","AdSize","currentSize","setCurrentSize","screenSizeHasAdSize","sizes","firstAvailableSize","find","sizeToChoose","setSize","available","activeOrNot","mobile","SvgMobile","SvgPc","SvgTv","ScreenSize","ScreenSizes","updateSelected","setActice","hasDesktop","hasCtv","hasMobile","linkLocale","availableSizes","Name","screenSizesWithData","Sizes","innerHeight","innerWidth","dimensions","setDimensions","handleResize","deviceSize","updateDeviceSize","expandedView","modifiedStr","useParams","scrollTo","CONSOLE_LEVELS","originalConsole","wrappedLevels","makeLogger","enable","enabled","disable","logger","consoleSandbox","isBuiltin","wat","elem","nextStr","out","currentElem","_htmlElementAsString","keyAttrs","keyAttrPairs","classes","attr","requireExactStringMatch","testString","patterns","markFunctionWrapped","wrapped","addNonEnumerableProperty","getOwnProperties","newObj","serializeEventTarget","extractedProps","_dropUndefinedKeys","memoizationMap","crypto","getFirstException","firstException","handled","InboundFilters","internalOptions","clientOptions","allowUrls","denyUrls","ignoreErrors","ignoreTransactions","ignoreInternal","getEventDescription","_getEventFilterUrl","eventProcess","addGlobalEventProcessor","frames","FunctionToString","originalFunctionToString","States","SyncPromise","executor","onfulfilled","onrejected","isRejected","val","onfinally","cachedHandlers","handler","sid","init","timestamp","started","duration","ignoreDuration","toJSON","session","did","attrs","release","environment","ip_address","user_agent","updateSession","Scope","user","extras","level","breadcrumb","trace","dynamicSamplingContext","transaction","propagationContext","processors","processor","newScope","getGlobalEventProcessors","generatePropagationContext","traceId","spanId","sampled","Hub","scope","client","originalException","syntheticException","event_id","mergedBreadcrumb","makeMain","closeSession","GLOBAL_OBJ","extensions","hub","setHubOnCarrier","getGlobalHub","hasHubOnCarrier","carrier","__SENTRY__","defaultIntegrations","integration","integrations","integrationsByName","finalIntegrations","integrationIndex","installedIntegrations","clientClass","parsers","sortedParsers","localStack","frame","filename","function","instrument","instrumented","triggerHandlers","originalConsoleMethod","instrumentConsole","WINDOW","refCount","handlerForType","originalAddEventListener","proto","originalRemoveEventListener","instrumentDOM","request_headers","xhrInfo","endTimestamp","startTimestamp","xhr","onreadystatechangeHandler","readyStateArgs","setRequestHeaderArgs","sentryXhrData","instrumentXHR","sandbox","doc","handlerData","instrumentFetch","lastHref","instrumentHistory","_oldOnErrorHandler","msg","_oldOnUnhandledRejectionHandler","handlers","getFunctionName","hasProp","getUrlFromResource","resource","shouldShortcircuitPreviousDebounce","shouldSkipDOMEvent","makeDOMEventHandler","global","lastCapturedEvent","debounceTimerID","_superPropBase","_get","receiver","desc","port","projectId","dsnFromComponents","publicKey","pass","dsn","inner","ERROR","depth","maxSize","visit","maxProperties","memoBuilder","normalized","numAdded","unmemoize","stringifyValue","jsonSize","envelope","encodeUTF8","parts","items","stringifiedPayload","buffers","merged","attachment","textEncoder","dropUndefinedKeys","content_type","attachment_type","buffer","sessions","client_report","user_report","profile","replay_event","replay_recording","check_in","sdkInfo","tunnel","sent_at","sdk","SentryError","getBaseApiEndpoint","_getIngestEndpoint","_encodedAuth","sentry_key","sentry_version","sentry_client","metadata","enhanceEventWithSdkInfo","trace_id","user_segment","public_key","request","applyClientOptions","applyIntegrationsMetadata","debugIdStackFramesCache","debugIdStackParserCache","parsedStack","acc","applyDebugIds","finalScope","filenameDebugIdMap","images","code_file","debug_id","applyDebugMeta","breadcrumbs","contexts","extra","span","BaseClient","tunnelOrOptions","recordDroppedEvent","eventId","promisedEvent","setupIntegration","env","createAttachmentEnvelopeItem","promise","errored","exceptions","crashed","clearInterval","ticked","evt","span_id","parent_span_id","sampleRate","beforeSendResult","beforeSendLabel","processedEvent","transactionInfo","__sentry__","reason","category","quantity","isTransactionEvent","ex","stackParser","extractMessage","attachStacktrace","isUnhandledRejection","addExceptionTypeValue","__serialized__","addExceptionMechanism","synthetic","stacktrace","getNonErrorObjectExceptionValue","captureContext","getCurrentHub","ignoreOnError","ignoreNextOnError","withScope","captureException","sentryWrapped","Breadcrumbs","dom","sentry","addInstrumentationHandler","MAX_ALLOWED_STRING_LENGTH","maxStringLength","htmlTreeAsString","_consoleBreadcrumb","_xhrBreadcrumb","status_code","_fetchBreadcrumb","_historyBreadcrumb","parsedFrom","BrowserClient","packages","breadcrumbIntegration","feedback","discarded_events","GlobalHandlers","onerror","onunhandledrejection","globalHandlerLog","installFunc","_installGlobalOnErrorHandler","_eventFromIncompleteOnError","_enhanceEventWithInitialFrame","eventFromUnknownInput","addMechanismAndCapture","_installGlobalOnUnhandledRejectionHandler","_eventFromRejectionWithPrimitive","ev0sf","colno","in_app","lineno","getHubAndOptions","TryCatch","XMLHttpRequest","eventTarget","setInterval","_wrapTimeFunction","original","mechanism","_wrapRAF","_wrapXHR","originalSend","xmlHttpRequestProps","wrapOptions","_wrapEventTarget","eventName","aggregateExceptionsFromError","exceptionFromErrorImplementation","parser","limit","prevExceptions","exceptionId","applyExceptionGroupFieldsForParentException","applyExceptionGroupFieldsForChildException","newExceptions","newException","newExceptionId","childError","is_exception_group","exception_id","parentId","parent_id","truncateAggregateExceptions","LinkedErrors","maxValueLimit","applyAggregateErrorsToEvent","exceptionFromError","HttpContext","referrer","Referer","headers","Dedupe","currentEvent","eventProcessor","_isSameStacktrace","frameA","_isSameFingerprint","_getExceptionFromEvent","_getFramesFromEvent","createFrame","extractSafariExtensionDetails","isSafariExtension","remove","drain","timeout","limits","statusCode","rateLimitHeader","categories","updatedRateLimits","makeRequest","makePromiseBuffer","forEachEnvelopeItem","filteredEnvelopeItems","rateLimits","recordEnvelopeLoss","send","getEventForEnvelopeItem","fetchImpl","cachedFetchImpl","nativeFetch","getNativeFetchImplementation","pendingBodySize","pendingCount","referrerPolicy","keepalive","clearCachedFetchImplementation","startSessionOnHub","startSessionTracking","objectKey","objectValue","baggageHeaderToObject","baggageHeader","sentryTrace","baggage","parentSampled","parentSpanId","baggageObject","currBaggageObject","traceparentData","uuid4","sampledString","SpanRecorder","Transaction","transactionContext","spanMetadata","unit","spans","start_timestamp","sdkProcessingMetadata","transaction_info","trimEnd","dsc","Span","spanContext","childSpan","logMessage","description","op","idleTimeout","finalTimeout","heartbeatInterval","IdleTransactionSpanRecorder","_pushActivity","_popActivity","transactionSpanId","maxlen","IdleTransaction","_idleHub","_idleTimeout","TRACING_DEFAULTS","_finalTimeout","_heartbeatInterval","_onScope","restartOnChildSpanChange","maybeOptions","errorCallback","activeTransaction","traceHeaders","sample","samplingContext","rate","_startTransaction","customSamplingContext","transactionInstrumenter","configInstrumenter","onScope","errorsInstrumented","metric","reportAllChanges","prevValue","entryType","navigationEntry","getNavigationEntryFromPerformanceTiming","rating","opts","po","buffered","firstHiddenTime","onHidden","msToSec","getBrowserPerformanceAPI","report","handleEntries","onFID","_measurements","sessionValue","sessionEntries","_clsEntry","reportedMetricIDs","once","_lcpEntry","clsCallback","lcpCallback","performanceEntries","_addPerformanceNavigationTiming","_startChild","_addRequest","_addNavigationSpans","responseStartTimestamp","requestStartTimestamp","_addMeasureSpans","resourceName","_addResourceSpans","_performanceCursor","_trackNavigator","measurementName","_tagMetricInfo","eventEnd","traceFetch","traceXHR","enableHTTPTimings","tracingOrigins","tracePropagationTargets","_options","shouldCreateSpanForRequest","shouldAttachHeaders","shouldCreateSpan","shouldCreateSpanResult","parentSpan","requestSpan","getDynamicSamplingContextFromClient","newHeaders","newBaggageHeaders","addHTTPTimings","setHeaderOnXhr","resourceTiming","nextHopProtocol","_name","timingSpanData","spanData","entryTypes","getAbsoluteTime","sentryTraceHeader","sentryBaggageHeader","markBackgroundTransactions","routingInstrumentation","customStartTransaction","startTransactionOnPageLoad","startTransactionOnLocationChange","startingUrl","enableLongTask","_experiments","defaultRequestInstrumentationOptions","BrowserTracing","addTracingExtensions","DEFAULT_BROWSER_TRACING_OPTIONS","durationThreshold","instrumentRouting","statusType","instrumentOutgoingRequests","finalContext","idleTransaction","addPerformanceEntries","inflightInteractionTransaction","isInputTypeMasked","actualType","maskInputValue","maskInputOptions","maskInputSelector","NodeType","getInputType","getInputValue","defaultMaskFn","getCssRulesString","getCssRuleString","cssStringified","validateStringifiedCssRule","absoluteToStylesheet","cssText","EventType","IncrementalSource","MouseInteractions","CanvasContext","MediaInteractions","ReplayerEvents","absoluteToDoc","attributeValue","isSVGElement","getHref","transformAttribute","_tagName","maskAllText","unmaskTextSelector","maskTextFn","chars","pos","collectCharacters","inParens","descriptorsStr","attribute","_shouldMaskAttribute","needMaskingText","maskTextClass","maskTextSelector","serializeNode","childNodes","compatMode","publicId","systemId","blockClass","blockSelector","unblockSelector","attributes","unmaskInputSelector","maskInputFn","canvas","getImageData","blankCanvas","canvasService","canvasCtx","image","oldValue","recordInlineImage","class","rr_width","rr_height","isSVG","needBlock","isStyle","lowerIfExists","maybeAttr","serializeNodeWithId","inlineStylesheet","dataURLOptions","inlineImages","recordCanvas","keepIframeSrcFn","sn","slimDOMOptions","_serializedNode","onSerialize","recordChild","serializedNode","preserveWhiteSpace","skipChild","onIframeLoad","iframeLoadTimeout","serializedChildNode","iframeEl","readyState","fired","onceIframeLoaded","snapshot","textarea","select","maskAllInputs","script","headFavicon","headWhitespace","headMetaDescKeywords","headMetaSocial","headMetaRobots","headMetaHttpEquiv","headMetaAuthorship","headMetaVerification","slimDOM","idNodeMap","skipAttribute","on","getId","getNode","removeNodeFromMap","remaining","hookSetter","isRevoked","patch","__rrweb_original__","getWindowHeight","getWindowWidth","isBlocked","isIgnored","isAncestorRemoved","mirror","isTouchEvent","polyfill","isIframeINode","hasShadowRoot","isNodeInLinkedList","_mirror","DoubleLinkedList","isINode","MutationBuffer","mutations","nextId","rootShadowHost","adds","pushAdd","addList","candidate","texts","removes","old","newPriority","styleObj","deepDelete","isShadow","targetId","addsSet","isParentRemoved","isAncestorInSet","getEventTarget","initMutationObserver","rootEl","mutationBuffers","mutationBuffer","mutationObserverCtor","attributeOldValue","characterData","characterDataOldValue","childList","subtree","initMoveObserver","sampling","callbackWrapper","positions","timeBaseline","callbackThreshold","timeOffset","wrappedCb","trailing","initMouseInteractionObserver","disableMap","initScrollObserver","initViewportResizeObserver","lastH","lastW","wrapEventWithUserTriggeredFlag","initInputObserver","INPUT_TAGS","ignoreSelector","isChecked","cbWithDedup","userTriggered","userTriggeredOnInput","lastInputValue","lastInputValueMap","inputCb","getNestedCSSRulePositions","childRule","hasNestedCSSRule","initStyleSheetObserver","styleSheetRuleCb","supportedNestedCSSRuleTypes","unmodifiedFunctions","deleteRule","initStyleDeclarationObserver","styleDeclarationCb","initMediaInteractionObserver","mediaInteractionCb","volume","initFontObserver","fontMap","family","descriptors","fontSource","fontCb","mergeHooks","hooks","mutationCb","mousemoveCb","mouseInteractionCb","scrollCb","viewportResizeCb","canvasMutationCb","initObservers","pluginHandlers","mutationObserver","mousemoveHandler","mouseInteractionHandler","scrollHandler","viewportResizeHandler","inputHandler","mediaInteractionHandler","styleSheetObserver","styleDeclarationObserver","fontObserver","canMonkeyPatchNestedCSSRule","IframeManager","isAttachIframe","ShadowDomManager","manager","shadowDomManager","lookup","Uint8Array","contextMap","webGLVarMap","serializeArg","rr_type","base64","patchGLPrototype","saveWebGLVar","setter","CanvasManager","latestId","invokeId","recordArgs","canvasContextReset","canvas2DReset","canvasWebGL1and2Reset","commands","wrapEvent","radio","checkbox","_maskInputOptions","_slimDOMOptions","plugins","wrappedEmit","emit","lastFullSnapshotEvent","incrementalSnapshotCount","takeFullSnapshot","bypassOptions","onMutation","iframeManager","canvasManager","isCheckout","initialOffset","ignoreClass","collectFonts","plugin","replay","addCustomEvent","freezePage","ClickDetector","slowClickConfig","_addBreadcrumbEvent","addBreadcrumbEvent","obs","cleanupWindowOpen","clickBreadcrumb","clickCount","click","timedOutClicks","timeAfterClickMs","endReason","nowInSeconds","normalizedKey","getBaseDomBreadcrumb","isClick","clickDetector","handleClick","getClickTargetNode","nodeId","baseBreadcrumb","isNavigationEntryEqual","currentList","newList","existingLcpEntries","newEntries","newNavigationEntries","newLcpEntry","existingNavigationEntries","existingEntries","performanceObserver","addBreadcrumb","EventBufferSizeExceededError","REPLAY_MAX_EVENT_BUFFER_SIZE","EventBufferArray","eventSize","WorkerHandler","logInfo","EventBufferCompressionWorker","EventBufferProxy","events","hasCheckout","addEventPromises","deleteSession","initialTime","expiry","targetTime","isExpired","lastActivity","segmentId","shouldRefresh","saveSession","timeouts","currentSession","stickySession","sessionSampleRate","allowBuffering","traceInternals","logInfoNextTick","addEvent","timestampInMs","timestampToMs","replayOptions","eventAfterPossibleCallback","maybeApplyCallback","transport","replayContext","handleTransactionEvent","handleErrorEvent","createPerformanceSpans","_evaluateJsonPos","_handleObj","_handleArr","_handleColon","_handleComma","_handleObjClose","_handleArrClose","_handleQuote","_isEscaped","_meta","warnings","bodySize","filteredHeaders","_serializeFormData","formData","_prepareFetchData","makeNetworkReplayBreadcrumb","addNetworkBreadcrumb","requestBodySize","request_body_size","responseBodySize","response_body_size","captureDetails","urlMatches","_getRequestInfo","buildSkippedNetworkRequestOrResponse","_getResponseInfo","networkCaptureBodies","fetchArgs","networkRequestHeaders","networkResponseHeaders","getAllHeaders","buildNetworkRequestOrResponse","_parseFetchBody","bodyText","getBodySize","_getFetchRequestArgBody","allowedHeaders","allHeaders","getHeadersFromOptions","_prepareXhrData","getAllowedHeaders","networkDetailAllowUrls","networkDetailDenyUrls","parseContentLengthHeader","enrichXhrBreadcrumb","captureXhrBreadcrumbToReplay","enrichFetchBreadcrumb","captureFetchBreadcrumbToReplay","_LAST_BREADCRUMB","newBreadcrumb","isTruncated","handleNetworkBreadcrumbs","replayId","afterSendHandler","hasHooks","addMemoryEntry","createMemoryEntry","memoryEntry","memory","jsHeapSizeLimit","totalJSHeapSize","usedJSHeapSize","initiatorType","responseEnd","decodedBodySize","encodedBodySize","responseStatus","transferSize","paint","navigation","domComplete","domContentLoadedEventStart","domContentLoadedEventEnd","domInteractive","loadEventStart","loadEventEnd","redirectCount","startTimeOrNavigationActivation","createPerformanceEntry","hadFirstEvent","errorSampleRate","useCompressionOption","blockAllMedia","useCompression","networkDetailHasUrls","networkRequestHasHeaders","networkResponseHasHeaders","replayEvent","recordingData","createEventEnvelopeHeaders","payloadWithSequence","prepareReplayEvent","prepareEvent","preparedEvent","sendReplayRequest","segment_id","eventContext","preparedRecordingData","prepareRecordingData","urls","errorIds","traceIds","initialTimestamp","baseEvent","replay_start_timestamp","error_ids","trace_ids","replay_id","replay_type","createReplayEnvelope","TransportStatusCodeError","sendReplay","replayData","retryConfig","interval","setContext","_retryCount","ReplayContainer","recordingOptions","sessionIdlePause","sessionIdleExpire","maxSessionLife","initialUrl","cancelTimers","callbackReturnValue","timerId","maxTimerId","debounced","maxWait","maxCount","durationSeconds","counter","_cleanup","isThrottled","scrollTimeout","checkoutEveryNms","forceFlush","force","clearSession","activityTime","hasStoppedRecording","addGlobalListeners","handleKeyboardEvent","tooShort","tooLong","eventBuffer","getOption","selectors","defaultSelectors","deprecatedClassOption","deprecatedSelectorOption","deprecatedSelectors","allSelectors","mask","unmask","block","unblock","ignore","Replay","flushMinDelay","flushMaxDelay","minReplayDuration","mutationBreadcrumbLimit","mutationLimit","slowClickTimeout","slowClickIgnoreSelectors","maskFn","beforeAddRecordingEvent","getPrivacyOptions","MEDIA_SELECTORS","_initialized","initialOptions","opt","finalOptions","_getMergedNetworkHeaders","initAndBind","Sentry","tracesSampleRate","replaysSessionSampleRate","replaysOnErrorSampleRate","scrollPosition","setScrollPosition","handleScroll","scrollY","header","getElementsByClassName","classList","home","ReactDOM","getElementById"],"sourceRoot":""}