{"allowedRenditionsWidth":["320","480","640","768","960","1200","1440","1920"],"cssClassNames":"page basicpage summit-page","designPath":"/libs/settings/wcm/designs/default","brandSlug":"","componentsResourceTypes":["snowflake-site/components/quickstart/quickstart-button","snowflake-site/components/nav/nav-column/nav-column-container","snowflake-site/components/structure/page","snowflake-site/components/button","snowflake-site/components/quickstart/quickstart-hero","snowflake-site/components/quickstart/quickstart-table-of-content","snowflake-site/components/experiencefragment","snowflake-site/components/mega-header","snowflake-site/components/modal/modal-container","snowflake-site/components/image","snowflake-site/components/nav/nav-dropdown-header","snowflake-site/components/wistia-video/cta","nt:folder","snowflake-site/components/container","snowflake-site/components/nav/nav-dropdown-menu","snowflake-site/components/nav/nav-column","snowflake-site/components/flexible-column-container","snowflake-site/components/quickstart/quickstart-table-of-content/quickstart-table-of-content-container","snowflake-site/components/button/embedded","snowflake-site/components/icon","snowflake-site/components/nav/nav-mega","cq:LiveCopy","snowflake-site/components/quickstart/quickstart-last-modified","snowflake-site/components/nav/nav-promo-section","snowflake-site/components/markup-editor","snowflake-site/components/text","snowflake-site/components/title-v2","snowflake-site/components/nav/nav-dropdown-footer","nt:unstructured","nt:file","snowflake-site/components/contentfragment","snowflake-site/components/nav/nav-item","snowflake-site/components/nav/nav-promo-card","snowflake-site/components/form/marketo-v2","snowflake-site/components/nav/language-navigation","snowflake-site/components/title","wcm/foundation/components/responsivegrid","nt:resource","snowflake-site/components/structure/xfpage","snowflake-site/components/flexible-column-container/flexible-column-content-container","snowflake-site/components/pushdown-banner"],"clientlibsAsync":false,"dataLayerClientlibIncluded":true,"dataLayerName":"adobeDataLayer","lastModifiedDate":1766234494388,"language":"en","description":"explore Horizon Collaboration pillar features for sharing of data and apps","title":"Explore Cross-Cloud Sharing of Data and Applications with Private Listings","tags":["snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/product/applications-and-collaboration"],"templateName":"quickstart-page-template","analyticsPageType":"quickstart-page-template","analyticsCategory":"general","analyticsSubCategory":"","excludeFromAnalytics":false,"isPasswordProtected":false,"analyticsContentTags":["snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/product/applications-and-collaboration"],"analyticsEnabled":true,"coveoConfig":{"pipeline":"snowflake.com","apiKey":"xx335921a6-2a0a-40f2-a167-e390b4766c3d","organizationId":"snowflakecomputingproduction8neljofn","searchHub":"snowflake.com"},"analyticsDebugMode":false,"analyticsData":{"excludeFromAnalytics":false,"subCategory":"","pageType":"quickstart-page-template","templateName":"quickstart-page-template","siteName":"snowflake","pageUrl":"/content/snowflake-site/global/en/developers/guides/horizon-intra-org-sharing","language":"en","category":"general","pageName":"Explore Cross-Cloud Sharing of Data and Applications with Private Listings","contentTags":["snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/product/applications-and-collaboration"]},":type":"snowflake-site/components/structure/page",":items":{"root":{"columnClassNames":{"markup_editor_1950346551":"aem-GridColumn aem-GridColumn--default--12","experiencefragment-banner":"aem-GridColumn aem-GridColumn--default--12","experiencefragment-header":"aem-GridColumn aem-GridColumn--default--12","responsivegrid":"aem-GridColumn aem-GridColumn--default--12","experiencefragment-footer":"aem-GridColumn aem-GridColumn--default--12","modal_container":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnCount":12,":items":{"experiencefragment-banner":{"id":"experiencefragment-a1f8ae5acb","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/pushdown-banner/master/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"columnClassNames":{"pushdown_banner_copy":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-a26b9505b4",":type":"snowflake-site/components/container",":items":{"pushdown_banner_copy":{"id":"pushdown-banner-a2ef7c2c65","contentHeadline":"Summit Builder Keynote Debut","contentDescription":"Broadcast live on June 23","contentJustifyContent":"center","linkStyle":"text-white","linkCTA":{"id":"link-cta","heapButtonClasses":["pushdown_banner"],"showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://reg.snowflake.com/flow/snowflake/summit26/digitalreg/page/main"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Register now"},":type":"snowflake-site/components/pushdown-banner","appliedCssClassNames":"snowflake-pushdown-banner-text-white snowflake-pushdown-banner-background-black"}},":itemsOrder":["pushdown_banner_copy"]},"image":{":type":"nt:unstructured"},"cq:metadata":{":type":"nt:unstructured"}},":itemsOrder":["root","image","cq:metadata"],"classNames":"aem-xf"},"experiencefragment-header":{"id":"experiencefragment-43d107dffc","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"columnClassNames":{"mega_header":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-249561fa06",":type":"snowflake-site/components/container",":items":{"markup_editor":{"id":"markup-editor-5c654249a8","title":" ","cssContent":".footer-nav__link-group .snowflake-button-container,.subnav__item--button,.snowflake-card-v2-advanced-button .snowflake-button-container{justify-content:flex-start}.mega-nav__sign-in.snowflake-button-container{display:none}@media screen and (min-width:768px){.mega-nav__sign-in.snowflake-button-container{display:inline-block;font-family:'Texta',sans-serif;font-weight:800 !important}}@media screen and (min-width:1024px) and (max-width:1199px){.snowflake-mega-nav-header-buttons-container .snowflake-button-blue .snowflake-button-container{font-size:13px !important}.snowflake-language-navigation .language-icon{width:18px !important;height:18px !important;margin-right:4px !important}}.mega-nav__sign-in svg{display:none}.nav-item__platform-parent-why-sf.snowflake-mega-nav-nav-item\u003Ea:hover,.nav-item__platform-parent.snowflake-mega-nav-nav-item\u003Ea:hover{background-color:transparent !important}.nav-platform-sidebar .snowflake-mega-nav-nav-item:hover.blue-icon .snowflake-mega-nav-nav-item-icon__inner{background-color:var(--ui-01) !important}@media screen and (min-width:1024px){.snowflake-mega-nav-navigation-dropdown{overflow:hidden}.meganav-platform-features{padding-left:64px}.meganav-platform-features::before{content:'';transform:translateX(-64px);display:block;z-index:0;width:100%;height:100%;position:absolute;top:0;background:#f7f9fa}.nav-item--si.snowflake-mega-nav-nav-item\u003Ea:hover{background-color:transparent}.nav-item--si{border-bottom:1px solid #ccc;padding-bottom:16px;margin-bottom:8px}.nav-item__platform-parent{border-bottom:1px solid #ccc;margin-bottom:8px;padding-bottom:16px}.nav-item__platform-parent-why-sf .snowflake-mega-nav-nav-item-description::after{content:'What Snowflake can do for you \u003E';display:block;color:var(--ui-01);margin-top:16px}.nav-item__platform-parent .snowflake-mega-nav-nav-item-description::after{content:'View the platform \u003E';display:block;color:var(--ui-01);margin-top:16px}}@media screen and (min-width:1367px){.snowflake-mega-nav-nav-item-description{font-size:13px !important;line-height:20px !important}.snowflake-mega-nav-nav-item-title-wrapper\u003E.snowflake-mega-nav-nav-item-title{font-size:17px !important}.nav-item__platform-parent-why-sf .snowflake-mega-nav-nav-item-title,.nav-item__platform-parent .snowflake-mega-nav-nav-item-title{font-size:24px !important;line-height:32px !important;margin-bottom:8px !important}.nav-item__platform-parent-why-sf .snowflake-mega-nav-nav-item-description,.nav-item__platform-parent .snowflake-mega-nav-nav-item-description{font-size:14px !important;line-height:20px !important}}html.wf-texta-n9-loading .display-1-v2{font-size:48px!important;line-height:50px!important;letter-spacing:-.5px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .heading-4-v2{font-size:18px!important;line-height:24px!important;font-family:sans-serif!important}@media screen and (min-width:768px){html.wf-texta-n9-loading .display-2-v2{font-size:48px!important;line-height:50px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .display-1-v2{font-size:55.5px!important;line-height:54px!important;letter-spacing:-.5px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-2,html.wf-lato-n4-loading .heading-5-v2,html.wf-lato-n4-loading .snowflake-card-v2-advanced-text .snowflake-text p{font-size:15.5px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .heading-2,html.wf-texta-n9-loading .heading-2-v2{font-size:34px!important;line-height:38px!important;letter-spacing:-.75px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .heading-6-v2.snowflake-mega-nav-navigation-title{font-size:13.5px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .heading-4,html.wf-texta-n8-loading .snowflake-button-container,html.wf-texta-n8-loading .snowflake-button-regular .snowflake-button-container{font-size:13px!important;line-height:20px!important;letter-spacing:.25px!important;font-family:sans-serif!important}}@media screen and (min-width:1024px){html.wf-lato-n4-loading .snowflake-mega-nav-nav-item-description{font-size:11.5px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-2,html.wf-lato-n4-loading .text-size-regular .snowflake-text li,html.wf-lato-n4-loading .text-size-regular .snowflake-text p,html.wf-lato-n4-loading .text-size-regular .snowflake-text span[data-testid=text-content],html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom li,html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom p,html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom span[data-testid=text-content]{font-size:13.5px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .snowflake-button-compact .snowflake-button-container{font-size:12px!important;letter-spacing:0!important;line-height:18px!important}}@media screen and (min-width:1367px){html.wf-lato-n4-loading .hp-hero__eyebrow a\u003Eb:first-child{font-size:11px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .hp-hero__eyebrow a{font-size:13px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .display-2-v2{font-size:61px!important;line-height:60px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .display-1-v2{font-size:74.5px!important;line-height:74px!important;letter-spacing:-.75px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .heading-2,html.wf-texta-n9-loading .heading-2-v2{font-size:41px!important;letter-spacing:-.75px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .heading-3-v2{font-family:sans-serif!important;letter-spacing:-.75px!important;font-size:33.75px!important}html.wf-texta-n9-loading .heading-4-v2{font-size:19.5px!important;line-height:26px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .heading-6-v2{font-size:12px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .heading-6-v2.snowflake-mega-nav-navigation-title{font-size:14px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-1,html.wf-lato-n4-loading .cq-Editable-dom[data-cq-data-path*=text] ol\u003Eli,html.wf-lato-n4-loading .snowflake-text li,html.wf-lato-n4-loading .snowflake-text p,html.wf-lato-n4-loading .text-size-large .snowflake-text li,html.wf-lato-n4-loading .text-size-large .snowflake-text p,html.wf-lato-n4-loading .text-size-large .snowflake-text span[data-testid=text-content],html.wf-lato-n4-loading .text-size-large.cq-Editable-dom li,html.wf-lato-n4-loading .text-size-large.cq-Editable-dom p,html.wf-lato-n4-loading .text-size-large.cq-Editable-dom span[data-testid=text-content],html.wf-lato-n4-loading.cq-Editable-dom[data-cq-data-path*=text]\u003Ep,html.wf-lato-n4-loading.cq-Editable-dom[data-cq-data-path*=text]\u003Eul\u003Eli{font-size:17.5px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-2,html.wf-lato-n4-loading .text-size-regular .snowflake-text li,html.wf-lato-n4-loading .text-size-regular .snowflake-text p,html.wf-lato-n4-loading .text-size-regular .snowflake-text span[data-testid=text-content],html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom li,html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom p,html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom span[data-testid=text-content],html.wf-texta-n8-loading .snowflake-button-link .snowflake-button-container,html.wf-texta-n8-loading .snowflake-button-link-back .snowflake-button-container{font-size:15.5px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-3,html.wf-lato-n4-loading .text-size-small .snowflake-text li,html.wf-lato-n4-loading .text-size-small .snowflake-text p,html.wf-lato-n4-loading .text-size-small .snowflake-text span[data-testid=text-content],html.wf-lato-n4-loading .text-size-small.cq-Editable-dom li,html.wf-lato-n4-loading .text-size-small.cq-Editable-dom p,html.wf-lato-n4-loading .text-size-small.cq-Editable-dom span[data-testid=text-content]{font-size:13.5px!important;font-family:sans-serif!important}}#industryPlatformSection,.sc-hero{background-position:top left;background-size:20% auto}.bwalignc,.bwalignr{list-style-position:inside}.snowflake-text p sup{font-size:10px}#industryPlatformSection .industry-platform__row .snowflake-flexible-column-container-items,.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container,.snowflake-hero-system-content-container{gap:16px}.agenda-item p,.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.partner-details p{margin:0!important}.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container::after,.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container::before,.hide-logo .snowflake-case-study-card-logo,.partner-page__powered-by-logo,.sc-hero div.code-toolbar\u003E.toolbar,.snowflake-card-v2-advanced.no-link .snowflake-card-v2-advanced-button,.snowflake-partner-hero-card-badge-container{display:none!important}.section--card-mobile-carousel .snowflake-flexible-column-container-items-with-carousel{max-width:100%!important}@media screen and (min-width:768px){.button-group-pair .snowflake-button-container.inline-button--desktop,.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto!important;display:inline-block!important}.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container{align-items:center;justify-content:flex-start!important}.button-group-pair.center\u003E.container\u003E.cmp-container\u003E.aem-container{justify-content:center!important}.section--card-mobile-carousel{margin-left:var(--tablet-portrait-margin,48px)!important;margin-right:var(--tablet-portrait-margin,48px);width:calc(100% - 96px)!important;width:calc(100% - var(--tablet-portrait-margin) * 2)!important}}@media screen and (min-width:1024px){.section--card-mobile-carousel{margin-left:var(--tablet-horizontal-margin,48px)!important;margin-right:var(--tablet-horizontal-margin,48px);width:calc(100% - 96px)!important;width:calc(100% - var(--tablet-horizontal-margin) * 2)!important}.snowflake-mega-nav-header-mobile-icon{display:none!important}}@media screen and (min-width:1367px){.section--card-mobile-carousel{margin-left:var(--desktop-margin,6.5%)!important;margin-right:var(--desktop-margin,6.5%);width:87%!important;width:calc(100% - var(--desktop-margin) * 2)!important}.logo-container{min-width:143px}.sc-hero__headline .heading-1-v2{font-size:60px}.snowflake-mega-nav-navigation-title{font-size:17px}.snowflake-mega-nav-dropdown-footer-wrapper .snowflake-title-v2 .snowflake-title-v2-line:first-child{font-size:16px!important;line-height:24px!important}}.hero--home{overflow:hidden;background-color:var(--ui-01);z-index:2}.hp-hero__subheadline{width:90%}.hero--home .snowflake-button-container{transition:.3s}.hero--home .snowflake-button-primary a:hover,.hero--home .snowflake-button-secondary a:hover,.hero--home .snowflake-button-white a:hover{transition:.3s;background-color:var(--ui-02)!important;color:var(--ui-05)!important}.hero--home .snowflake-button-secondary a:hover{border-color:var(--ui-05)!important}.hero--home .snowflake-button-primary a:hover,.hero--home .snowflake-button-white a:hover{border-color:var(--ui-02)!important}.bwalignc,.hp-hero__eyebrow{text-align:center}.hp-hero__eyebrow a{display:inline-flex;flex-direction:column;justify-content:center;cursor:pointer;padding:8px;border-radius:var(--spacing-01);gap:8px;align-items:center;background-color:#45aee3;color:var(--ui-03);font-family:Texta,sans-serif;font-weight:800;font-size:16px;line-height:22px;transition:background-color .3s}.hp-hero__eyebrow a:hover{background-color:#7fc6ea;text-decoration:none;transition:background-color .3s}.hp-hero__eyebrow a\u003Eb:first-child{text-transform:uppercase;white-space:nowrap;display:inline-block;background-color:var(--ui-02);color:var(--ui-05);font-size:12px!important;line-height:16px!important;font-family:Lato,sans-serif;font-weight:500!important;padding:3px 6px;border-radius:2px;letter-spacing:1px}@media screen and (min-width:767px){.hp-hero__eyebrow{text-align:left}.hp-hero__eyebrow a{flex-direction:row;text-align:left}}.hero--home__inner .offset-video,.hero--home__inner .snowflake-experience-fragment,.offset-video__bg-image{max-height:200px;overflow:hidden}.hero--home__inner .offset-video .wistia-responsive-padding{padding-top:100%}.hero--home__inner .snowflake-experience-fragment,.offset-video__bg-image{position:absolute!important;top:0;left:0;width:100%}.offset-video__bg-image{z-index:-1}@media screen and (min-width:768px){.hero--home__inner .snowflake-experience-fragment,.offset-video,.offset-video__bg-image{position:absolute!important;max-height:none;top:0;left:0;width:250%;padding-bottom:250%;transform:translate(0,-50%);height:0}.workloads_7.unistore{max-width:317px}}.promo-banner--homepage{z-index:2}.homepage-banner-offset-container::after{content:\"\";display:block;position:absolute;bottom:0;z-index:1;left:0;width:100%;height:80%;background:#fff}.section--quicklinks .snowflake-button-full-width a{padding-left:24px!important;padding-right:24px!important;transition:box-shadow .25s cubic-bezier(.4,0,.2,1);text-align:left;display:flex;justify-content:center;align-items:center}.section--quicklinks .snowflake-button-full-width a:hover{box-shadow:0 16px 16px 0 rgb(0 0 0 / .16);transition:box-shadow .25s cubic-bezier(.4,0,.2,1)}.section--quicklinks .snowflake-button-container:focus-visible a::before,.section--quicklinks .snowflake-button-full-width a::before{content:\"\";width:23px;height:23px;flex-shrink:0;margin-right:12px;display:inline-block;background-size:cover;background-repeat:no-repeat;background-position:center}#industryPartnerSlider .snowflake-navigation-icon.swiper-button-disabled,#partnerResources .section--resource-hub a svg,.button-tabs span.snowflake-tabs-navigation-item:after,.customer-card--hide-cta .snowflake-case-study-card-button,.dot-tabs span.snowflake-tabs-navigation-item::after,.partner-sidebar__mobile-expand,html:not(.aem-AuthorLayer-initial):not(.aem-AuthorLayer-Edit) .tab-content:not(.is-active){display:none}.section--quicklinks .snowflake-button-full-width a.pricing::before{background-image:url(https://www.snowflake.com/content/dam/snowflake-site/general/icons/decorative-icons/pricing-icon.svg)}.section--quicklinks .snowflake-button-full-width a.snowflake_on_snowflake::before{background-image:url(https://www.snowflake.com/content/dam/snowflake-site/general/icons/navigation/nav-icon_snowflake-bug.svg)}.section--quicklinks .snowflake-button-full-width a.virtual_hands_on_labs::before{background-image:url(https://www.snowflake.com/content/dam/snowflake-site/general/icons/navigation/nav-icon__training.svg)}.section--quicklinks .snowflake-button-full-width a.weekly_demo::before{background-image:url(https://www.snowflake.com/content/dam/snowflake-site/general/icons/navigation/nav-icon__webinars.svg)}@media screen and (min-width:1024px){.hero--home__inner .snowflake-experience-fragment,.offset-video,.offset-video__bg-image{left:-50%}.section--quicklinks .snowflake-flexible-column-container-items{gap:24px}.snowflake-quote-item-inner{padding:32px 24px 24px!important}}#communitiesOuter_overflowBottomGray::after{max-height:100px}#caseStudyOuter_overflowBottomMidBlue::after{max-height:180px}#caseStudyInner .snowflake-case-study-card .snowflake-wistia-video{border-radius:0!important}#caseStudyInner .snowflake-case-study-card{box-shadow:none!important;border-radius:0}#caseStudyInner{max-width:1200px;margin:0 auto;box-shadow:rgb(152 162 179 / .1) 0 10px 20px 0,rgb(152 162 179 / .25) 0 2px 6px 0;border-radius:8px;overflow:hidden;position:relative;z-index:1}.case-study__logo-bar\u003E.snowflake-flexible-column-container-items{background:#f7f9fa;padding:32px 16px 40px}.case-study__logo-bar .cmp-image__image{width:90%;margin:0 auto;max-width:240px}.hp-platform__text-group\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:first-child),.sc-sidebar__group .snowflake-button-link{margin-top:8px}.workloads_7.unistore{margin-left:auto;margin-right:auto}#homepageFootnotesInner .snowflake-simple-stat-disclaimer .snowflake-text p{color:#fff!important}.snowflake-simple-stat-disclaimer .snowflake-text p\u003Ea{border-bottom:1px solid var(--ui-03);color:var(--text-03)}.snowflake-card-v2-advanced{color:inherit}#workloadCardGridOuter .snowflake-card-v2-base-front{gap:0}.video-modal.snowflake-modal-window-open-inner{background-color:#fff0;padding:8px;border:none}.snowflake-container-arrow-dotted-faded .snowflake-container-arrow-dotted-faded-image{width:40%!important;max-width:420px;top:4%!important}.list--blue-bullets ul{margin:0!important;padding:0!important;list-style-type:none}.list--blue-bullets li{margin:0;padding:0 0 0 32px;position:relative}.list--blue-bullets li::before{content:\"\";display:block;border-radius:100%;background:#29b5e8;width:18px;height:18px;position:absolute;top:4px;left:0;border:5px solid #e5f2f7;box-sizing:border-box}.list--blue-bullets li:not(:last-child){margin-bottom:1rem}.logo-tabs .snowflake-navigation-container,.snowflake-simple-stat-content:empty,.summit-speaker-card .snowflake-card-v2-advanced-text{margin-bottom:0}#techResourceInner,#techResourceOuter,div.overflow-bottom--blue,div.overflow-bottom--gray,div.overflow-bottom--mid-blue,div.overflow-bottom--white,div.overflow-top--blue,div.overflow-top--gray,div.overflow-top--mid-blue,div.overflow-top--white,div[id$=overflowBottomGray],div[id$=overflowBottomMidBlue],div[id$=overflowTopBlue],div[id$=overflowTopGray]{position:relative}div.overflow-bottom--blue::after,div.overflow-bottom--gray::after,div.overflow-bottom--mid-blue::after,div.overflow-bottom--white::after,div.overflow-top--blue::after,div.overflow-top--gray::after,div.overflow-top--mid-blue::after,div.overflow-top--white::after,div[id$=overflowBottomGray]::after,div[id$=overflowBottomMidBlue]::after,div[id$=overflowBottomWhite]::after,div[id$=overflowTopBlue]::after,div[id$=overflowTopGray]::after,div[id$=overflowTopWhite]::after{content:\"\";display:block;position:absolute;left:0;width:100%;height:40%}div.overflow-top--blue::after,div.overflow-top--gray::after,div.overflow-top--mid-blue::after,div.overflow-top--white::after,div[id$=overflowTopBlue]::after,div[id$=overflowTopGray]::after,div[id$=overflowTopWhite]::after{top:0}div.overflow-bottom--blue::after,div.overflow-bottom--gray::after,div.overflow-bottom--mid-blue::after,div.overflow-bottom--white::after,div[id$=overflowBottomGray]::after,div[id$=overflowBottomMidBlue]::after,div[id$=overflowBottomWhite]::after{bottom:0}div.overflow-bottom--white::after,div.overflow-top--white::after,div[id$=overflowBottomWhite]::after,div[id$=overflowTopWhite]::after{background:#fff!important}div.overflow-bottom--gray::after,div.overflow-top--gray::after,div[id$=overflowBottomGray]::after,div[id$=overflowTopGray]::after{background:#f6f9fa!important}div.overflow-bottom--mid-blue::after,div.overflow-top--mid-blue::after,div[id$=overflowBottomMidBlue]::after,div[id$=overflowTopMidBlue]::after{background:#11567f!important}div.overflow-bottom--blue::after,div.overflow-top--blue::after,div[id$=overflowBottomBlue]::after,div[id$=overflowTopBlue]::after{background:#259edc!important}.snowflake-premium-content-banner.promo-banner--no-shadow{box-shadow:none!important}#industryPartnerSlider .cmp-image__image,#industryPartnerSlider .section--partner-tabs .snowflake-image-container .cmp-image__image,#partnerSidebar,.has-shadow .cmp-image__image{box-shadow:0 10px 20px 0 rgb(152 162 179 / .1),0 2px 6px 0 rgb(152 162 179 / .25)}.content-chip--has-desc{align-items:flex-start;padding:20px!important}.content-chip--has-desc .snowflake-content-chip-image{max-width:100px}.content-chip--has-desc .snowflake-content-chip-image__image{aspect-ratio:1}.content-chip--has-desc .snowflake-title-v2-line:first-child{font-size:18px!important}.content-chip--has-desc .snowflake-title-v2-line:nth-child(2){color:#000!important;font-weight:500!important;font-size:16px!important;line-height:22px!important;margin-top:2px!important}.content-chip--has-desc .snowflake-content-chip-button{margin-top:6px!important;font-size:18px!important;display:none}.square-image .snowflake-content-chip-image{aspect-ratio:1;max-width:120px}.section--logo-bar.smaller-logos .snowflake-image-container .cmp-image__image{max-width:200px;margin:0 auto}.snowflake-card-v2-advanced-tag,.snowflake-content-chip-tag{padding:3px 6px!important}.sc-overview__webinar-promo-banner .snowflake-content-chip-button,.snowflake-card-v2-advanced-title:first-child,.summit-pricing-block__aside ul{margin-top:0}.dot-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item{width:40px;height:40px;display:flex;justify-content:center;align-items:center;margin:0!important}.dot-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item p{width:12px;height:12px;background:var(--ui-12);border-radius:100%}.dot-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item p,.logo-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item p{font-size:0!important}.dot-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item.active p{background:var(--ui-01)}.button-tabs .snowflake-navigation-container .swiper-wrapper{padding:8px 0}.button-tabs .snowflake-navigation-container .swiper-slide{margin:0 6px}.button-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item{padding:8px 24px;background-color:#f6f9fa;border-radius:48px;margin:0}.button-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item p{text-transform:uppercase;font-family:Texta,sans-serif;font-weight:700}.button-tabs .border-top{border-top:1px solid #ccc}.button-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item.active{background-color:var(--ui-01);box-shadow:0 2px 6px 0 rgb(152 162 179 / .25),0 10px 20px 0 rgb(152 162 179 / .1)}.button-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item.active p{color:#fff}.button-tabs.has-icons .snowflake-navigation-container .snowflake-tabs-navigation-item p::before{content:\"\";display:inline-block;width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-position:center center;margin-right:12px;vertical-align:middle;margin-top:-3px}.logo-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item{width:220px;padding-bottom:50%;height:0;margin:0 8px!important;background-size:cover;background-repeat:no-repeat;opacity:.5;transition:opacity .3s}.logo-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item:hover{opacity:.75;transition:opacity .3s}.logo-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item.active{opacity:1;transition:opacity .3s}.dot-tabs .aem-container.cmp-tabs,.logo-tabs .aem-container.cmp-tabs{display:flex;flex-direction:column-reverse}.snowflake-icon.is-center{margin:0 auto;display:block}#industryPartnerSlider .snowflake-flexible-column-container-items,#partnerLogoSquare .snowflake-flexible-column-container-items{gap:24px}#techResourceOuter::after{content:\"\";display:block;position:absolute;top:0;left:0;width:100%;height:40%;background:#f6f9fa}#techResourceInner{z-index:1}.partner-tier-tag h6{display:inline-block!important;padding:2px 6px;border-radius:2px;color:#666}.partner-tier-tag.registered h6{background-color:#f6f9fa}.partner-tier-tag.elite h6{background-color:#11567f;color:#fff}.partner-tier-tag.premier h6{background-color:#b14c77;color:#fff}.partner-tier-tag.select h6{background-color:#5094a0;color:#fff}.partner-details\u003Espan{display:flex;gap:24px}.partner-details a{color:inherit!important;font-weight:400!important}.partner-details p::before{content:\"\";display:inline-block;vertical-align:middle;width:16px;height:16px;background-repeat:no-repeat;background-position:center;transform:translateY(-1px);background-size:auto 90%;margin-right:6px}.partner-details__location::before{background-image:url(\"data:image/svg+xml,%3Csvg width='13' height='18' viewBox='0 0 13 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M6.25 17.7531C6.4375 17.7531 6.6 17.6844 6.7375 17.5531C6.875 17.4219 6.95 17.2531 6.95 17.0531C6.95 16.8531 7.075 16.4281 7.3 15.7969C7.5875 15.0281 7.925 14.3156 8.30625 13.6406C8.8 12.7781 9.3125 12.1031 9.85 11.6094C10.75 10.7969 11.4125 9.96563 11.85 9.12188C12.2875 8.27813 12.5063 7.40313 12.5063 6.49063C12.5063 5.36563 12.2187 4.31563 11.6437 3.33438C11.0937 2.40313 10.3438 1.65938 9.4 1.10938C8.43125 .534376 7.375 .246876 6.24375 .246876C5.1125 .246876 4.06875 .534376 3.0875 1.10938C2.15625 1.65938 1.4125 2.40313 .862498 3.33438C.287498 4.31563 0 5.36563 0 6.49063C0 7.47188 .262499 8.42813 .787499 9.35938C1.14375 10.0031 1.65625 10.6656 2.3125 11.3344C2.75625 11.8031 3.24375 12.4781 3.78125 13.3656C4.225 14.0969 4.63125 14.8594 5 15.6656C5.35 16.3844 5.53125 16.8531 5.55625 17.0656C5.55625 17.2594 5.625 17.4156 5.7625 17.5531C5.9 17.6844 6.0625 17.7531 6.25 17.7531ZM6.16875 14.9156C5.775 14.0656 5.325 13.2469 4.825 12.4594C4.275 11.5594 3.7625 10.8719 3.28125 10.3969C2.625 9.71563 2.1375 9.05938 1.825 8.43438C1.5125 7.80313 1.35625 7.16563 1.35625 6.50313C1.35625 5.61563 1.575 4.80313 2.0125 4.05313C2.45 3.30313 3.04375 2.71563 3.7875 2.27813C4.5375 1.84063 5.35 1.62188 6.2375 1.62188C7.125 1.62188 7.9375 1.84063 8.6875 2.27813C9.4375 2.71563 10.0312 3.30313 10.475 4.04688C10.9187 4.80313 11.1375 5.62188 11.1375 6.50313C11.1375 7.90313 10.3937 9.26563 8.9125 10.5969C8.35 11.1094 7.8125 11.7906 7.3 12.6406C6.88125 13.3344 6.50625 14.0969 6.16875 14.9219V14.9156ZM6.26875 8.36563C6.65625 8.36563 7.01875 8.26563 7.35625 8.07188C7.69375 7.87813 7.95625 7.60938 8.14375 7.28438C8.3375 6.95313 8.43125 6.59063 8.43125 6.19688C8.43125 5.80313 8.33125 5.43438 8.1375 5.10313C7.9375 4.76563 7.675 4.50313 7.3375 4.31563C7 4.12813 6.6375 4.02813 6.24375 4.02813C5.85 4.02813 5.4875 4.12813 5.15625 4.32188C4.825 4.52188 4.56875 4.78438 4.375 5.12188C4.18125 5.45938 4.0875 5.82188 4.0875 6.20938C4.0875 6.59688 4.1875 6.95938 4.38125 7.29688C4.58125 7.63438 4.84375 7.89688 5.18125 8.08438C5.51875 8.27813 5.88125 8.37188 6.26875 8.37188V8.36563ZM6.24375 7.50313C5.8875 7.50313 5.575 7.37188 5.31875 7.11563C5.0625 6.85938 4.93125 6.55313 4.93125 6.19063C4.93125 5.82813 5.0625 5.52188 5.31875 5.26563C5.575 5.00938 5.88125 4.87813 6.24375 4.87813C6.60625 4.87813 6.9125 5.00938 7.16875 5.26563C7.425 5.52188 7.55625 5.82813 7.55625 6.19063C7.55625 6.55313 7.425 6.85938 7.16875 7.11563C6.9125 7.37188 6.60625 7.50313 6.24375 7.50313Z' fill='%2329B5E8'/%3E%3C/svg%3E%0A\")}.partner-details__website::before{background-image:url(\"data:image/svg+xml,%3Csvg width='18' height='16' viewBox='0 0 18 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2.61587 2.96889C2.61587 2.75109 2.79633 2.57062 3.01413 2.57062C3.23192 2.57062 3.41238 2.75109 3.41238 2.96889C3.41238 3.18669 3.23192 3.36716 3.01413 3.36716C2.79633 3.36716 2.61587 3.18669 2.61587 2.96889ZM4.21512 2.96889C4.21512 2.75109 4.39558 2.57062 4.61338 2.57062C4.83117 2.57062 5.01163 2.75109 5.01163 2.96889C5.01163 3.18669 4.83117 3.36716 4.61338 3.36716C4.39558 3.36716 4.21512 3.18669 4.21512 2.96889ZM5.81438 2.96889C5.81438 2.75109 5.99484 2.57062 6.21264 2.57062C6.43043 2.57062 6.61089 2.75109 6.61089 2.96889C6.61089 3.18669 6.43043 3.36716 6.21264 3.36716C5.99484 3.36716 5.81438 3.18669 5.81438 2.96889ZM17.2518 .697559H1.19085C.811258 .697559 .506348 1.0025 .506348 1.38209V14.6179C.506348 14.9975 .811258 15.3024 1.19085 15.3024H17.2518C17.6314 15.3024 17.9363 14.9975 17.9363 14.6179V1.38209C17.9363 1.0025 17.6314 .697559 17.2518 .697559ZM16.5673 2.06035V3.90853H1.86914V2.06035H16.5673ZM1.86914 13.9334V4.78593H16.5673V13.9334H1.86914Z' fill='%2329B5E8'/%3E%3C/svg%3E%0A\")}#partnerSidebar{border-radius:4px;background-color:#fff;padding:24px 24px 32px;border-bottom:6px solid #29b5e8}#partnerSidebar h5,.newsletter-disclaimer p{font-size:14px!important}#partnerSidebar ul{margin-top:0;list-style-type:none;padding:0;display:flex;flex-wrap:wrap;gap:8px}#partnerSidebar li{border:1px solid;border-radius:2px;padding:0 4px!important;font-size:11px!important;letter-spacing:.25px;text-transform:uppercase}div.snowflake-partner-hero-card{width:100%;margin:0}.partner-details__logo{max-width:380px;margin:0 auto}@media screen and (max-width:767px){.left-alignment .hp-hero__subheadline{margin-left:auto;margin-right:auto}.left-alignment .hp-hero__headline .snowflake-title-v2-line,.left-alignment .hp-hero__subheadline .snowflake-title-v2-line{text-align:center}.hero--home__inner .snowflake-flexible-column-container-items-top-padding-large{padding-top:var(--spacing-02)}.section--logo-bar\u003E.snowflake-flexible-column-container-items{display:flex;flex-wrap:wrap;flex-direction:row;justify-content:center;gap:8px}.section--logo-bar\u003E.snowflake-flexible-column-container-items\u003Ediv{width:calc(33.33% - 8px)}.partner-sidebar__mobile-expand{display:inline-block;color:#249edc;border-color:#249edc!important}#partnerSidebar li:nth-child(n+6),.summit-nav__links .snowflake-button-tertiary{display:none}.sc-body__sidebar{background-color:#f6f9fa;padding:24px}.sc-body__content{padding:0 24px 24px}.summit-speaker-card .snowflake-card-v2-advanced-content{padding:24px}}#partnerResources h6,.snowflake-tabs-navigation-item p.body-1{font-size:16px!important}#partnerResources .section--resource-hub{padding:0 16px}#partnerResources .section--resource-hub a,.bwalignl{text-align:left}@media screen and (max-width:1023px){.hero--workload .snowflake-hero-system-media-container{width:100%}}.section--timely-content .snowflake-content-chip,.snowflake-mega-nav-dropdown-footer-wrapper{align-items:center}.section--timely-content .snowflake-content-chip-image{max-width:94px}.section--timely-content .snowflake-content-chip-image__inner{line-height:0}.section--timely-content .snowflake-content-chip-image__image{aspect-ratio:1;height:auto}.section--workload-overview .workload-overview__headline{max-width:280px;margin:0 auto}#industryPartnerSlider .swiper-slide{margin-top:0!important;padding:0 12px}#industryPartnerSlider .snowflake-tabs-navigation-item{margin-left:0!important;margin-right:0!important}#industryPartnerSlider .snowflake-premium-content-banner-background-grad-white .snowflake-premium-content-banner{box-shadow:none}#industryPartnerSlider .logo-slider__slide .aem-container{display:flex;padding:0 8px!important;flex-wrap:wrap;gap:16px!important;justify-content:center}#industryPartnerSlider .logo-slider__slide .aem-container\u003Ediv{width:48%;max-width:200px}#useCaseTabs{padding-top:24px;padding-bottom:24px;padding-right:24px}#useCaseTabs .tab-content.is-active{display:block}#useCaseTabs .vert-tab{border-bottom:1px solid #a0bbcc;padding-bottom:16px}#useCaseTabs .vert-tab p{display:inline-block}#useCaseTabs .vert-tab p:hover{cursor:pointer}#useCaseTabs .vert-tab p,#useCaseTabs .vert-tab.is-active p.not-active{color:#249edc}#useCaseTabs .vert-tab p.is-active,#useCaseTabs .vert-tab.is-active p{color:#000}#industryPlatformSection{background-image:url(/adobe/dynamicmedia/deliver/dm-aid--db074ad5-7122-4c51-87a3-76c3aa466182/double-arrow-bg%403x.png);background-repeat:no-repeat}.snowflake-text p.featured-quote__source{font-weight:900!important;text-transform:uppercase;font-size:16px!important;margin-top:2rem!important}.snowflake-text p.featured-quote__title{margin-top:0!important;font-size:16px!important}.snowflake-case-study-card-logo img{width:auto!important;height:100px!important;transform:translateX(-15%)}.snowflake-quote-item-quote-text{font-weight:600!important}#customerStoryStatsInner\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row}#customerStoryStat1,#customerStoryStat2{max-width:240px}#storyHighlights{border-radius:4px;padding:1rem}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .snowflake-title-v2-line,.summit-pricing-block__tile .black-blue-text-color .snowflake-title-v2-line{color:#000!important}.snowflake-youtube-embedded-wrapper{border-radius:var(--small-border-radius)}#arcticNavItem::before,#offset::before,#open-source::before{color:var(--text-05);font-family:Texta,sans-serif!important}#offset,.sc-architecture-caption{margin-top:16px}.hero--press .snowflake-title-v2-line{text-transform:none!important}@media screen and (min-width:768px){.subpage-timely-content__inner\u003E.snowflake-flexible-column-container-items{box-shadow:0 10px 20px 0 rgb(152 162 179 / .1),0 2px 6px 0 rgb(152 162 179 / .25);padding:var(--spacing-04);border-radius:4px;overflow:hidden}#partnerLogoSquare{padding:0 0 0 48px}.hero--workload .snowflake-container{max-width:1440px;margin:0 auto!important;align-items:center}#industryPartnerSlider.snowflake-flexible-column-container-2-column-40-60\u003E.snowflake-flexible-column-container-items{grid-template-columns:minmax(40%,4fr) minmax(0,6fr)}#industryPartnerSlider .swiper-slide{padding:0 24px}.sc-body{padding:48px}.sc-body\u003E.snowflake-flexible-column-container-items{grid-template-columns:7fr 3fr;gap:124px}}.snowflake-button-container.has-icon{display:inline-flex;justify-content:center;align-items:center;text-align:left}.snowflake-button-container.has-icon::before{content:\"\";display:inline-block;width:20px;height:20px;margin-right:12px;background-size:contain;background-repeat:no-repeat;background-position:center}.snowflake-button-container.is-video::before{background-image:url(\"data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 1.28663C13.2523 1.28663 16.7134 4.74768 16.7134 9C16.7134 13.2523 13.2523 16.7134 9 16.7134C4.74768 16.7198 1.28663 13.2588 1.28663 9C1.28663 4.74124 4.74768 1.28663 9 1.28663ZM9 0C4.0336 0 0 4.0336 0 9C0 13.9664 4.0336 18 9 18C13.9728 18 18 13.9664 18 9C18 4.0336 13.9728 0 9 0Z' fill='white'/%3E%3Cpath d='M7.75106 6.18211C7.42941 6.16925 7.16565 6.42658 7.16565 6.74823V11.2772C7.16565 11.7082 7.65457 11.9848 8.02126 11.7597L11.7975 9.4952C12.1578 9.27647 12.1578 8.74252 11.7975 8.52379L8.02126 6.25931C7.93763 6.21428 7.84756 6.18211 7.75106 6.18211Z' fill='white'/%3E%3C/svg%3E%0A\")}.snowflake-button-container.is-github::before{background-image:url(\"data:image/svg+xml,%3Csvg width='20' height='21' viewBox='0 0 20 21' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M10 .651794C4.475 .651794 0 5.12679 0 10.6518C0 15.0768 2.8625 18.8143 6.8375 20.1393C7.3375 20.2268 7.525 19.9268 7.525 19.6643C7.525 19.4268 7.5125 18.6393 7.5125 17.8018C5 18.2643 4.35 17.1893 4.15 16.6268C4.0375 16.3393 3.55 15.4518 3.125 15.2143C2.775 15.0268 2.275 14.5643 3.1125 14.5518C3.9 14.5393 4.4625 15.2768 4.65 15.5768C5.55 17.0893 6.9875 16.6643 7.5625 16.4018C7.65 15.7518 7.9125 15.3143 8.2 15.0643C5.975 14.8143 3.65 13.9518 3.65 10.1268C3.65 9.03929 4.0375 8.13929 4.675 7.43929C4.575 7.18929 4.225 6.16429 4.775 4.78929C4.775 4.78929 5.6125 4.52679 7.525 5.81429C8.325 5.58929 9.175 5.47679 10.025 5.47679C10.875 5.47679 11.725 5.58929 12.525 5.81429C14.4375 4.51429 15.275 4.78929 15.275 4.78929C15.825 6.16429 15.475 7.18929 15.375 7.43929C16.0125 8.13929 16.4 9.02679 16.4 10.1268C16.4 13.9643 14.0625 14.8143 11.8375 15.0643C12.2 15.3768 12.5125 15.9768 12.5125 16.9143C12.5125 18.2518 12.5 19.3268 12.5 19.6643C12.5 19.9268 12.6875 20.2393 13.1875 20.1393C17.1375 18.8143 20 15.0643 20 10.6518C20 5.12679 15.525 .651794 10 .651794Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\")}.snowflake-button-container.is-quickstart::before{background-image:url(\"data:image/svg+xml,%3Csvg width='15' height='21' viewBox='0 0 15 21' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.8489 2.79368H11.6439V2.38493C11.6439 1.71368 11.1451 .967427 10.4251 .967427H8.94762C8.80887 .359927 8.37387 .299927 7.89762 .299927H7.23012C6.85512 .299927 6.26637 .299927 6.08637 .967427H4.68387C3.94887 .967427 3.35637 1.74368 3.35637 2.38493V2.79368H1.15137C.738867 2.79368 .401367 3.13118 .401367 3.54368V20.2537C.401367 20.6662 .738867 21.0037 1.15137 21.0037H13.8489C14.2614 21.0037 14.5989 20.6662 14.5989 20.2537V3.54368C14.5989 3.13118 14.2614 2.79368 13.8489 2.79368ZM4.29387 2.38493C4.29387 2.18243 4.54137 1.90493 4.68387 1.90493H6.50262C6.76137 1.90493 6.97137 1.69493 6.97137 1.43618C6.97137 1.33868 6.97887 1.27868 6.98637 1.24118C7.05012 1.23368 7.15512 1.23368 7.23387 1.23368H7.90137C7.95012 1.23368 8.00637 1.23368 8.05137 1.23368C8.05512 1.27868 8.05887 1.34243 8.05887 1.43243C8.05887 1.69118 8.26887 1.90118 8.52762 1.90118H10.4289C10.5301 1.90118 10.7101 2.14493 10.7101 2.38118V2.78993H4.29762V2.38118L4.29387 2.38493ZM13.0989 19.4999H1.90137V4.29368H13.0989V19.5037V19.4999Z' fill='%23249EDC'/%3E%3Cpath d='M3.82512 16.0424H11.1751C11.4339 16.0424 11.6439 15.8324 11.6439 15.5736V6.88486C11.6439 6.62611 11.4339 6.41611 11.1751 6.41611H3.82512C3.56637 6.41611 3.35637 6.62611 3.35637 6.88486V15.5736C3.35637 15.8324 3.56637 16.0424 3.82512 16.0424ZM4.29387 15.1049V13.3686H10.7064V15.1049H4.29387ZM10.7101 7.35361V12.4311H4.29762V7.35361H10.7101Z' fill='%23249EDC'/%3E%3Cpath d='M6.16512 9.35989H8.83887C9.09762 9.35989 9.30762 9.14989 9.30762 8.89114C9.30762 8.63239 9.09762 8.42239 8.83887 8.42239H6.16512C5.90637 8.42239 5.69637 8.63239 5.69637 8.89114C5.69637 9.14989 5.90637 9.35989 6.16512 9.35989Z' fill='%23249EDC'/%3E%3Cpath d='M6.16512 11.3624H8.83887C9.09762 11.3624 9.30762 11.1524 9.30762 10.8937C9.30762 10.6349 9.09762 10.4249 8.83887 10.4249H6.16512C5.90637 10.4249 5.69637 10.6349 5.69637 10.8937C5.69637 11.1524 5.90637 11.3624 6.16512 11.3624Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\")}.snowflake-button-container.is-download::before{background-image:url(\"data:image/svg+xml,%3Csvg width='16' height='18' viewBox='0 0 16 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M15.2017 17.1637H.798265C.364425 17.1637 0 16.7993 0 16.3655V12.3568C0 11.923 .364425 11.5585 .798265 11.5585C1.2321 11.5585 1.59653 11.923 1.59653 12.3568V15.5498H14.4035V12.3568C14.4035 11.923 14.7679 11.5585 15.2017 11.5585C15.6356 11.5585 16 11.923 16 12.3568V16.3655C16 16.7993 15.6529 17.1637 15.2017 17.1637Z' fill='%23249EDC'/%3E%3Cpath d='M7.94793 12.9642C7.84381 12.9642 7.73969 12.9468 7.63557 12.8947C7.34056 12.7733 7.14967 12.4783 7.14967 12.1485L7.18437 .938127C7.18437 .504287 7.5488 .139862 7.98264 .139862C8.41648 .139862 8.7809 .504287 8.7809 .938127L8.7462 10.257L12.8416 6.33509C13.154 6.02273 13.6746 6.04008 13.9696 6.35244C14.282 6.66481 14.2646 7.18542 13.9523 7.48043L8.50325 12.7386C8.36442 12.8774 8.15617 12.9642 7.94793 12.9642Z' fill='%23249EDC'/%3E%3Cpath d='M7.94793 12.9642C7.73969 12.9642 7.54881 12.8947 7.39262 12.7386L2.03037 7.53249C1.718 7.22012 1.70065 6.71687 2.01301 6.40451C2.32538 6.09214 2.82863 6.07479 3.141 6.38715L8.50325 11.5932C8.81562 11.9056 8.83297 12.4088 8.52061 12.7212C8.36442 12.8774 8.15617 12.9642 7.94793 12.9642Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\")}.snowflake-button-container.is-expand::before{background-image:url(\"data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.64375 10.9125C6.9375 11.2062 6.93125 11.6812 6.64375 11.9687L2.57502 16H3.79375C4.20625 16 4.54376 16.3375 4.54376 16.75C4.54376 17.1625 4.20625 17.5 3.79375 17.5H.756264C.556264 17.5 .36876 17.4187 .22501 17.2812C.22501 17.2812 .206248 17.25 .193748 17.2375C.143748 17.1812 .100004 17.1125 .0625038 17.0437C.0375038 16.9687 .0187492 16.8937 .0187492 16.8187C.0187492 16.8 .0062561 16.7813 .0062561 16.7625V13.725C.0187561 13.3125 .356257 12.9875 .768757 12.9937C1.16876 13 1.48752 13.325 1.50002 13.725V14.9688L5.5875 10.9187C5.88125 10.6312 6.35 10.6312 6.64375 10.9187V10.9125ZM17.5063 .743732C17.5063 .543732 17.425 .356235 17.2875 .218735C17.2875 .218735 17.2562 .199998 17.2437 .193748C17.1875 .137498 17.1188 .0937347 17.0438 .0624847C16.9688 .0374847 16.8938 .0187492 16.8188 .0187492C16.8 .0187492 16.7813 .00623703 16.7625 .00623703H13.725C13.3125 .00623703 12.975 .343745 12.975 .756245C12.975 1.16874 13.3125 1.50623 13.725 1.50623H14.9688L11.1312 5.37498C10.8437 5.67498 10.8563 6.14999 11.1563 6.43124C11.45 6.71249 11.9063 6.70624 12.1938 6.43124L16.0125 2.575V3.79375C16.0125 4.20625 16.35 4.54372 16.7625 4.54372C17.175 4.54372 17.5125 4.20625 17.5125 3.79375V.756245L17.5063 .743732ZM16.7562 12.9688C16.3437 12.9688 16.0063 13.3063 16.0063 13.7188V14.8937L12.1938 10.925C11.9063 10.625 11.4375 10.6188 11.1375 10.9063C10.8375 11.1938 10.8313 11.6625 11.1188 11.9625L15 16.0062H13.7188C13.3063 16.0062 12.9688 16.3437 12.9688 16.7562C12.9688 17.1687 13.3063 17.5063 13.7188 17.5063H16.7562C16.85 17.5063 16.95 17.4875 17.0375 17.45C17.0875 17.425 17.1313 17.3937 17.175 17.3625C17.2063 17.3437 17.2438 17.325 17.275 17.3C17.3313 17.2375 17.375 17.1687 17.4125 17.1C17.4188 17.0875 17.4375 17.075 17.4438 17.0562C17.45 17.025 17.4563 16.9938 17.4625 16.9625C17.4813 16.9 17.5 16.8375 17.5 16.7687V13.725C17.5 13.3125 17.1687 12.975 16.7562 12.975V12.9688ZM.750008 4.53125C1.16251 4.53125 1.50002 4.19374 1.50002 3.78124V2.5L5.59376 6.43124C5.89376 6.71874 6.36251 6.70626 6.65001 6.41251C6.93751 6.11876 6.92501 5.64375 6.63126 5.35625L2.61251 1.49998H3.7875C4.2 1.49998 4.53751 1.16249 4.53751 .749989C4.53751 .337489 4.2 0 3.7875 0H.743752C.668752 0 .600004 .0187355 .531254 .0437355C.506254 .0499855 .481263 .0437477 .462513 .0562477C.443763 .0687477 .425015 .0812462 .406265 .0937462C.337515 .124996 .275004 .168741 .218754 .224991H.212498C.212498 .224991 .175 .28125 .15625 .3125C.11875 .3625 .0812477 .4125 .0562477 .46875C.0374977 .525 .0249992 .587499 .0187492 .643749C.0124992 .674999 0 .712482 0 .743732V3.78124C0 4.19374 .337508 4.53125 .750008 4.53125Z' fill='white'/%3E%3C/svg%3E%0A\")}@keyframes slow-scroll{100%{transform:translateY(-50%)}}.sc-hero{overflow:hidden;background-color:#212d35;background-repeat:repeat-y;background-image:url(\"data:image/svg+xml,%3Csvg width='389' height='17' viewBox='0 0 389 17' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M.638672 7.80824L.638672 9.2566C.638672 9.52364 .85538 9.74024 1.12262 9.74024H2.57204C2.83928 9.74024 3.05598 9.52364 3.05598 9.2566V7.80824C3.05598 7.54119 2.83928 7.32472 2.57204 7.32472L1.12262 7.32472C.85538 7.32472 .638672 7.54119 .638672 7.80824Z' fill='url(%23paint0_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M10.9639 7.80824V9.2566C10.9639 9.52364 11.1806 9.74024 11.4478 9.74024L12.8972 9.74024C13.1645 9.74024 13.3812 9.52364 13.3812 9.2566V7.80824C13.3812 7.54119 13.1645 7.32471 12.8972 7.32471L11.4478 7.32471C11.1806 7.32471 10.9639 7.54119 10.9639 7.80824Z' fill='url(%23paint1_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M21.2891 7.80823V9.2566C21.2891 9.52364 21.5058 9.74024 21.773 9.74024L23.2224 9.74024C23.4897 9.74024 23.7064 9.52364 23.7064 9.2566V7.80823C23.7064 7.54119 23.4897 7.32471 23.2224 7.32471L21.773 7.32471C21.5058 7.32471 21.2891 7.54119 21.2891 7.80823Z' fill='url(%23paint2_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M31.6143 7.80823V9.2566C31.6143 9.52364 31.831 9.74024 32.0982 9.74024H33.5476C33.8149 9.74024 34.0316 9.52364 34.0316 9.2566V7.80823C34.0316 7.54119 33.8149 7.32471 33.5476 7.32471L32.0982 7.32471C31.831 7.32471 31.6143 7.54119 31.6143 7.80823Z' fill='url(%23paint3_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M41.9395 7.80823V9.2566C41.9395 9.52364 42.1562 9.74024 42.4234 9.74024H43.8728C44.1401 9.74024 44.3568 9.52364 44.3568 9.2566V7.80823C44.3568 7.54119 44.1401 7.32471 43.8728 7.32471L42.4234 7.32471C42.1562 7.32471 41.9395 7.54119 41.9395 7.80823Z' fill='url(%23paint4_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M52.5076 7.80823V9.2566C52.5076 9.52364 52.7243 9.74024 52.9916 9.74024H54.441C54.7082 9.74024 54.9249 9.52364 54.9249 9.2566V7.80823C54.9249 7.54119 54.7082 7.32471 54.441 7.32471L52.9916 7.32471C52.7243 7.32471 52.5076 7.54119 52.5076 7.80823Z' fill='url(%23paint5_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M62.8331 7.80823V9.2566C62.8331 9.52364 63.0493 9.74024 63.3165 9.74024H64.7664C65.0332 9.74024 65.2504 9.52364 65.2504 9.2566V7.80823C65.2504 7.54119 65.0332 7.32471 64.7664 7.32471L63.3165 7.32471C63.0493 7.32471 62.8331 7.54119 62.8331 7.80823Z' fill='url(%23paint6_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M73.1583 7.80823V9.2566C73.1583 9.52364 73.3745 9.74024 73.6417 9.74024H75.0916C75.3584 9.74024 75.5756 9.52364 75.5756 9.2566V7.80823C75.5756 7.54119 75.3584 7.32471 75.0916 7.32471L73.6417 7.32471C73.3745 7.32471 73.1583 7.54119 73.1583 7.80823Z' fill='url(%23paint7_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M83.4835 7.80823V9.2566C83.4835 9.52364 83.6997 9.74024 83.9669 9.74024H85.4168C85.6836 9.74024 85.9008 9.52364 85.9008 9.2566V7.80823C85.9008 7.54119 85.6836 7.32471 85.4168 7.32471L83.9669 7.32471C83.6997 7.32471 83.4835 7.54119 83.4835 7.80823Z' fill='url(%23paint8_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M93.8087 7.80823V9.2566C93.8087 9.52364 94.0249 9.74024 94.2921 9.74024H95.742C96.0088 9.74024 96.226 9.52364 96.226 9.2566V7.80823C96.226 7.54119 96.0088 7.32471 95.742 7.32471L94.2921 7.32471C94.0249 7.32471 93.8087 7.54119 93.8087 7.80823Z' fill='url(%23paint9_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M104.134 7.80823V9.2566C104.134 9.52364 104.35 9.74024 104.617 9.74024H106.067C106.334 9.74024 106.551 9.52364 106.551 9.2566V7.80823C106.551 7.54119 106.334 7.32471 106.067 7.32471L104.617 7.32471C104.35 7.32471 104.134 7.54119 104.134 7.80823Z' fill='url(%23paint10_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M114.702 7.80823V9.2566C114.702 9.52364 114.918 9.74024 115.185 9.74024L116.635 9.74024C116.902 9.74024 117.119 9.52364 117.119 9.25659V7.80823C117.119 7.54119 116.902 7.32471 116.635 7.32471L115.185 7.32471C114.918 7.32471 114.702 7.54119 114.702 7.80823Z' fill='url(%23paint11_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M125.027 7.80823V9.25659C125.027 9.52364 125.243 9.74024 125.511 9.74024L126.961 9.74024C127.227 9.74024 127.445 9.52364 127.445 9.25659V7.80823C127.445 7.54119 127.227 7.32471 126.961 7.32471L125.511 7.32471C125.243 7.32471 125.027 7.54119 125.027 7.80823Z' fill='url(%23paint12_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M135.352 7.80823V9.25659C135.352 9.52364 135.569 9.74024 135.836 9.74024H137.286C137.553 9.74024 137.77 9.52364 137.77 9.25659V7.80823C137.77 7.54119 137.553 7.32471 137.286 7.32471L135.836 7.32471C135.569 7.32471 135.352 7.54119 135.352 7.80823Z' fill='url(%23paint13_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M145.678 7.80823V9.25659C145.678 9.52364 145.894 9.74024 146.161 9.74024H147.611C147.878 9.74024 148.095 9.52364 148.095 9.25659V7.80823C148.095 7.54119 147.878 7.32471 147.611 7.32471L146.161 7.32471C145.894 7.32471 145.678 7.54119 145.678 7.80823Z' fill='url(%23paint14_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M156.003 7.80823V9.25659C156.003 9.52364 156.219 9.74024 156.486 9.74024H157.936C158.203 9.74024 158.42 9.52364 158.42 9.25659V7.80823C158.42 7.54119 158.203 7.32471 157.936 7.32471L156.486 7.32471C156.219 7.32471 156.003 7.54119 156.003 7.80823Z' fill='url(%23paint15_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M166.328 7.80823V9.25659C166.328 9.52363 166.544 9.74024 166.811 9.74024H168.261C168.528 9.74024 168.745 9.52363 168.745 9.25659V7.80823C168.745 7.54119 168.528 7.32471 168.261 7.32471L166.811 7.32471C166.544 7.32471 166.328 7.54119 166.328 7.80823Z' fill='url(%23paint16_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M176.896 7.80823V9.25659C176.896 9.52363 177.112 9.74023 177.38 9.74023H178.83C179.096 9.74023 179.313 9.52363 179.313 9.25659V7.80823C179.313 7.54119 179.096 7.32471 178.83 7.32471L177.38 7.32471C177.112 7.32471 176.896 7.54119 176.896 7.80823Z' fill='url(%23paint17_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M187.221 7.80823V9.25659C187.221 9.52363 187.438 9.74023 187.705 9.74023H189.155C189.421 9.74023 189.639 9.52363 189.639 9.25659V7.80823C189.639 7.54119 189.421 7.32471 189.155 7.32471L187.705 7.32471C187.438 7.32471 187.221 7.54119 187.221 7.80823Z' fill='url(%23paint18_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M199.639 7.80824V9.2566C199.639 9.52364 199.855 9.74024 200.123 9.74024H201.572C201.839 9.74024 202.056 9.52364 202.056 9.2566V7.80824C202.056 7.54119 201.839 7.32472 201.572 7.32472L200.123 7.32472C199.855 7.32472 199.639 7.54119 199.639 7.80824Z' fill='url(%23paint19_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M209.964 7.80824V9.2566C209.964 9.52364 210.181 9.74024 210.448 9.74024L211.897 9.74024C212.164 9.74024 212.381 9.52364 212.381 9.2566V7.80824C212.381 7.54119 212.164 7.32471 211.897 7.32471L210.448 7.32471C210.181 7.32471 209.964 7.54119 209.964 7.80824Z' fill='url(%23paint20_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M220.289 7.80823V9.2566C220.289 9.52364 220.506 9.74024 220.773 9.74024L222.222 9.74024C222.49 9.74024 222.706 9.52364 222.706 9.2566V7.80823C222.706 7.54119 222.49 7.32471 222.222 7.32471L220.773 7.32471C220.506 7.32471 220.289 7.54119 220.289 7.80823Z' fill='url(%23paint21_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M230.614 7.80823V9.2566C230.614 9.52364 230.831 9.74024 231.098 9.74024H232.548C232.815 9.74024 233.032 9.52364 233.032 9.2566V7.80823C233.032 7.54119 232.815 7.32471 232.548 7.32471L231.098 7.32471C230.831 7.32471 230.614 7.54119 230.614 7.80823Z' fill='url(%23paint22_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M240.939 7.80823V9.2566C240.939 9.52364 241.156 9.74024 241.423 9.74024H242.873C243.14 9.74024 243.357 9.52364 243.357 9.2566V7.80823C243.357 7.54119 243.14 7.32471 242.873 7.32471L241.423 7.32471C241.156 7.32471 240.939 7.54119 240.939 7.80823Z' fill='url(%23paint23_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M251.508 7.80823V9.2566C251.508 9.52364 251.724 9.74024 251.992 9.74024H253.441C253.708 9.74024 253.925 9.52364 253.925 9.2566V7.80823C253.925 7.54119 253.708 7.32471 253.441 7.32471L251.992 7.32471C251.724 7.32471 251.508 7.54119 251.508 7.80823Z' fill='url(%23paint24_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M261.833 7.80823V9.2566C261.833 9.52364 262.049 9.74024 262.317 9.74024H263.766C264.033 9.74024 264.25 9.52364 264.25 9.2566V7.80823C264.25 7.54119 264.033 7.32471 263.766 7.32471L262.317 7.32471C262.049 7.32471 261.833 7.54119 261.833 7.80823Z' fill='url(%23paint25_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M272.158 7.80823V9.2566C272.158 9.52364 272.374 9.74024 272.642 9.74024H274.092C274.358 9.74024 274.576 9.52364 274.576 9.2566L274.576 7.80823C274.576 7.54119 274.358 7.32471 274.092 7.32471L272.642 7.32471C272.374 7.32471 272.158 7.54119 272.158 7.80823Z' fill='url(%23paint26_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M282.483 7.80823V9.2566C282.483 9.52364 282.7 9.74024 282.967 9.74024H284.417C284.684 9.74024 284.901 9.52364 284.901 9.2566V7.80823C284.901 7.54119 284.684 7.32471 284.417 7.32471L282.967 7.32471C282.7 7.32471 282.483 7.54119 282.483 7.80823Z' fill='url(%23paint27_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M292.809 7.80823L292.809 9.2566C292.809 9.52364 293.025 9.74024 293.292 9.74024H294.742C295.009 9.74024 295.226 9.52364 295.226 9.2566V7.80823C295.226 7.54119 295.009 7.32471 294.742 7.32471L293.292 7.32471C293.025 7.32471 292.809 7.54119 292.809 7.80823Z' fill='url(%23paint28_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M303.134 7.80823L303.134 9.2566C303.134 9.52364 303.35 9.74024 303.617 9.74024H305.067C305.334 9.74024 305.551 9.52364 305.551 9.2566V7.80823C305.551 7.54119 305.334 7.32471 305.067 7.32471L303.617 7.32471C303.35 7.32471 303.134 7.54119 303.134 7.80823Z' fill='url(%23paint29_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M313.702 7.80823L313.702 9.2566C313.702 9.52364 313.918 9.74024 314.185 9.74024L315.635 9.74024C315.902 9.74024 316.119 9.52364 316.119 9.25659V7.80823C316.119 7.54119 315.902 7.32471 315.635 7.32471L314.185 7.32471C313.918 7.32471 313.702 7.54119 313.702 7.80823Z' fill='url(%23paint30_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M324.027 7.80823V9.25659C324.027 9.52364 324.243 9.74024 324.511 9.74024L325.961 9.74024C326.227 9.74024 326.445 9.52364 326.445 9.25659V7.80823C326.445 7.54119 326.227 7.32471 325.961 7.32471L324.511 7.32471C324.243 7.32471 324.027 7.54119 324.027 7.80823Z' fill='url(%23paint31_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M334.352 7.80823V9.25659C334.352 9.52364 334.569 9.74024 334.836 9.74024H336.286C336.553 9.74024 336.77 9.52364 336.77 9.25659L336.77 7.80823C336.77 7.54119 336.553 7.32471 336.286 7.32471L334.836 7.32471C334.569 7.32471 334.352 7.54119 334.352 7.80823Z' fill='url(%23paint32_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M344.678 7.80823V9.25659C344.678 9.52364 344.894 9.74024 345.161 9.74024H346.611C346.878 9.74024 347.095 9.52364 347.095 9.25659L347.095 7.80823C347.095 7.54119 346.878 7.32471 346.611 7.32471L345.161 7.32471C344.894 7.32471 344.678 7.54119 344.678 7.80823Z' fill='url(%23paint33_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M355.003 7.80823V9.25659C355.003 9.52364 355.219 9.74024 355.486 9.74024H356.936C357.203 9.74024 357.42 9.52364 357.42 9.25659L357.42 7.80823C357.42 7.54119 357.203 7.32471 356.936 7.32471L355.486 7.32471C355.219 7.32471 355.003 7.54119 355.003 7.80823Z' fill='url(%23paint34_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M365.328 7.80823V9.25659C365.328 9.52363 365.544 9.74024 365.811 9.74024H367.261C367.528 9.74024 367.745 9.52363 367.745 9.25659V7.80823C367.745 7.54119 367.528 7.32471 367.261 7.32471L365.811 7.32471C365.544 7.32471 365.328 7.54119 365.328 7.80823Z' fill='url(%23paint35_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M375.896 7.80823V9.25659C375.896 9.52363 376.112 9.74023 376.38 9.74023H377.83C378.096 9.74023 378.313 9.52363 378.313 9.25659V7.80823C378.313 7.54119 378.096 7.32471 377.829 7.32471L376.38 7.32471C376.112 7.32471 375.896 7.54119 375.896 7.80823Z' fill='url(%23paint36_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M386.221 7.80823V9.25659C386.221 9.52363 386.438 9.74023 386.705 9.74023H388.155C388.421 9.74023 388.639 9.52363 388.639 9.25659V7.80823C388.639 7.54119 388.421 7.32471 388.155 7.32471L386.705 7.32471C386.438 7.32471 386.221 7.54119 386.221 7.80823Z' fill='url(%23paint37_linear_8295_70635)'/%3E%3Cdefs%3E%3ClinearGradient id='paint0_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint1_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint2_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint3_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint4_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint5_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint6_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint7_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint8_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint9_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint10_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint11_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint12_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint13_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint14_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint15_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint16_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint17_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint18_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint19_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint20_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint21_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint22_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint23_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint24_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint25_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint26_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint27_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint28_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint29_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint30_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint31_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint32_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint33_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint34_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint35_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint36_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint37_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3C/defs%3E%3C/svg%3E%0A\")}.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:first-child{position:relative;z-index:3}.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child{position:absolute;height:100%;width:100%;top:0;left:-24px}.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child::before{content:\"\";display:block;z-index:1;position:absolute;top:-64px;left:0;width:150%;height:calc(100% + 160px);background-color:rgb(32 44 53 / .9)}.sc-body__content .heading-3-v2,.sc-hero__headline .heading-1-v2{text-transform:none}.sc-body__content span.snowflake-image-caption{display:block!important;font-style:italic}.sc-body__content .snowflake-text p+ul{margin-top:24px!important;padding-left:16px!important}.white-blue-text-color .snowflake-title-v2.solution-center-hero__certification .snowflake-typographyv2\u003Espan.snowflake-title-v2-line{color:#e9eaeb!important;font-size:16px}.white-blue-text-color .snowflake-title-v2.solution-center-hero__certification.is-large .snowflake-typographyv2\u003Espan.snowflake-title-v2-line{color:#fff!important;font-size:18px}.solution-center-hero__certification\u003E.snowflake-title-v2-line\u003Espan:first-child{display:flex;justify-content:flex-start;align-items:center;gap:8px}.solution-center-hero__certification\u003E.snowflake-title-v2-line\u003Espan:first-child::before{content:\"\";display:inline-block;width:16px;height:16px;background-image:url(\"data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 0C3.58146 0 0 3.58146 0 8C0 12.4185 3.58146 16 8 16C12.4185 16 16 12.4185 16 8C16 3.58146 12.4185 0 8 0ZM12.7184 5.91984L7.33471 11.3026C7.31293 11.3244 7.31293 11.3454 7.29198 11.3454L7.20653 11.4308C6.94933 11.688 6.54132 11.7525 6.21962 11.6235C6.11238 11.5808 6.00514 11.5163 5.9197 11.4308L5.83425 11.3454C5.83425 11.3454 5.83425 11.3236 5.81246 11.3236L3.28149 8.79347C2.93799 8.44997 2.93799 7.87107 3.28149 7.50664L3.36694 7.42119C3.71044 7.07769 4.28934 7.07769 4.65377 7.42119L6.58401 9.35143L11.3877 4.5477C11.7312 4.2042 12.3101 4.2042 12.6746 4.5477L12.76 4.63315C13.0826 4.99758 13.0828 5.55541 12.7184 5.91984Z' fill='%230E8A16'/%3E%3C/svg%3E%0A\");background-size:contain;background-repeat:no-repeat;background-color:#fff;border-radius:100%}.sc-hero__byline{padding-top:8px}.sc-hero__byline p{color:#e2e2e2;margin-top:0!important}.sc-hero pre[class*=language-]{overflow:visible}.snowflake-code-snippet,.snowflake-code-snippet code,.snowflake-code-snippet pre{font-size:16px}.sc-hero__code-snippet:not(pre)\u003Ecode[class*=language-],.sc-hero__code-snippet pre[class*=language-]{background:0 0}.sc-hero__code-snippet{opacity:.8;background-color:transparent!important;position:absolute;top:0;right:0;width:100%;animation:240s linear 1s forwards slow-scroll}.sc-hero__button-container .snowflake-flexible-column-container-items{padding:0 0 24px;margin-top:-8px;margin-left:24px}.sc-sidebar__partner-logo{width:100%;max-width:140px;margin-top:8px}.sc-sidebar__partner-logo .cmp-image__image{border-radius:0}.sc-tag-cluster.snowflake-text ul{list-style-type:none;padding:0;display:flex;flex-wrap:wrap;gap:8px;margin:0}.sc-tag-cluster.snowflake-text li{color:#373f41;border-radius:4px;display:inline-block;padding:6px;text-transform:uppercase;letter-spacing:1px;font-size:12px!important;line-height:12px!important;margin:0!important;background-color:#f3f3f3}.sc-body .share-icon svg{height:24px;cursor:pointer}.sc-body .share-icon svg:hover path{fill:var(--ui-02)}.sc-overview__webinar-promo-banner{align-items:center;border:1px solid #ccc;padding:var(--spacing-02)}.sc-overview__webinar-promo-banner .snowflake-content-chip-image{max-width:32px;margin-right:var(--spacing-02);line-height:0}.sc-overview__webinar-promo-banner .snowflake-content-chip-image__image,.summit-speaker-card .snowflake-card-v2-advanced-image__image{aspect-ratio:1}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .heading-5-v2{font-size:14px;font-family:Lato,sans-serif}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .snowflake-title-v2-line:not(:first-child){font-weight:400}.sc-overview__webinar-promo-banner .snowflake-content-chip-button .snowflake-button-container{font-size:14px!important}.diagram-group__button{position:absolute;bottom:24px;right:24px;background-color:#212c35!important}.section--mountains-bottom,.summit-hp-hero{position:relative}.sc-cert-banner{background-color:#212d35;border-radius:8px;padding:24px;overflow:hidden}.sc-cert-banner\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row;align-items:center}:root{--text-secondary:#706f6f;--summit-bg-ltblue:#eaf8fd;--summit-bg-blue:#249edc;--summit-border:#d2d1d4;--summit-border-radius:8px;--summit-card-padding:32px;--summit-card-padding-sm:28px}.section--mountains-bottom::after,.section--mountains-bottom::before{content:\"\";display:block;position:absolute;bottom:-1px;max-width:400px;background-size:100% auto;height:100%;width:30%;line-height:0;background-repeat:no-repeat}.button-group\u003E.container\u003E.cmp-container\u003E.aem-container{justify-content:center;align-items:center}.button-group\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto!important;margin:0 8px!important}.button-group .snowflake-button-container{font-family:Texta,sans-serif}.section--summit-bg-ltblue{background-color:var(--summit-bg-ltblue)}.section--summit-bg-blue,.summit-hero-secondary{background-color:var(--summit-bg-blue)}.section--mountains-bottom::before{left:0;background-image:url(\"data:image/svg+xml,%3Csvg width='402' height='309' viewBox='0 0 402 309' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M401.523 308.761H0V0L181.63 182.431L228.479 135.531L401.523 308.761Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\");background-position:bottom left}.section--mountains-bottom::after{right:0;background-image:url(\"data:image/svg+xml,%3Csvg width='402' height='309' viewBox='0 0 402 309' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 308.761H401.523V0L219.893 182.431L173.044 135.531L0 308.761Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\");background-position:bottom right}.summit-hp-hero{overflow:hidden}.summit-hero__bg-video{position:absolute;top:50%;left:50%;width:120%;height:100%;opacity:.3;transform:translate(-50%,-50%)}.summit-hero__bg-svg,.summit-prefooter__bg-image,.summit-secondary-hero__bg-image{position:absolute;bottom:0;left:0;width:100%}.summit-hp-promo-banner__headline .heading-4-v2{font-weight:900}.summit-hero-secondary .hero-lottie__left{position:absolute;bottom:0;left:0;width:30%;line-height:0}.summit-timeline__card::after,.summit-timeline__card::before{bottom:0;left:50%;position:absolute;display:block;background-color:var(--ui-01);content:\"\"}.summit-hero-secondary .snowflake-text p{font-size:24px!important;line-height:32px!important;max-width:720px;margin:0 auto}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;justify-content:center}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto!important;max-width:25%}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:last-child){border-right:1px solid #fff}.summit-timeline__card{border:1px solid var(--summit-border);border-radius:var(--summit-border-radius);padding:var(--summit-card-padding);position:relative;background-color:#fff}.summit-timeline__card::before{width:20px;height:20px;border-radius:100%;transform:translate(-50%,50%)}.summit-timeline__card::after{width:3px;height:50px;transform:translate(-50%,100%)}.summit-timeline-card__icon{width:48px;height:48px}.summit-timeline-card__headline .heading-3-v2{font-size:32px}.faq-group{border:1px solid var(--ui-12);border-radius:4px;background-color:#fff}.faq-group__question{padding:24px}.faq-group__question:hover{color:var(--ui-01);cursor:pointer}.faq-group__question .heading-4-v2,.faq-group__question .heading-5-v2{position:relative;padding-right:64px}.faq-group__question .heading-4-v2::after,.faq-group__question .heading-5-v2::after{content:\"\";display:block;width:32px;height:32px;background-image:url(\"data:image/svg+xml,%3Csvg width='29' height='16' viewBox='0 0 29 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M14.16 14.6807C14.2537 14.7957 14.3719 14.8884 14.506 14.952C14.64 15.0157 14.7866 15.0487 14.935 15.0487C15.0834 15.0487 15.2299 15.0157 15.3639 14.952C15.498 14.8884 15.6162 14.7957 15.71 14.6807V14.6807L28.51 2.00068C29.07 1.43068 29.07 .92068 28.51 .44068C27.95 -.0393204 27.43 -.11932 26.96 .44068L14.94 12.0007L2.99996 .45068C2.90725 .322624 2.7855 .218374 2.6447 .146483C2.50389 .0745926 2.34805 .0371094 2.18996 .0371094C2.03187 .0371094 1.87603 .0745926 1.73522 .146483C1.59442 .218374 1.47267 .322624 1.37996 .45068C.819961 .93068 .819961 1.45068 1.37996 2.01068L14.16 14.6807Z' fill='black'/%3E%3C/svg%3E%0A\");background-size:80% auto;background-repeat:no-repeat;background-position:center;position:absolute;top:-2px;right:0;transition:.3s 150ms}.faq-group__question .heading-5-v2::after{top:-4px}.faq-group__answer{max-height:0;overflow:hidden;width:95%;padding:0 24px;transition:.5s}.faq-group__answer\u003Espan{display:block;padding-bottom:24px}.is-open .faq-group__answer{max-height:600px;transition:1s}.is-open .faq-group__question .heading-4-v2::after,.is-open .faq-group__question .heading-5-v2::after{transform:rotate(180deg);transition:.3s}.summit-agenda{box-shadow:2px 4px 10px 0 rgb(156 156 156 / .52);border-radius:8px;background-color:#fff;max-width:980px;margin-left:auto;margin-right:auto;padding:40px;width:90%}.agenda-item{border-radius:8px;background-color:#d4f0fa;padding:16px;border-left:4px solid var(--ui-01);position:relative}.summit-pricing-block__tile.is-past,.summit-pricing-block__tile.is-upcoming{pointer-events:none;border-color:#d2d1d4}p.agenda-item__time{width:25%;font-family:Texta!important;font-size:32px!important;font-weight:900!important;text-transform:uppercase!important;max-width:140px}@media screen and (max-width:991px){#partnerResources .section--resource-hub .snowflake-button-link .snowflake-button-container{font-size:14px!important;line-height:20px!important;margin-top:4px}#industryPartnerSlider\u003E.snowflake-flexible-column-container-items{display:flex;flex-direction:column}#industryPartnerSlider\u003E.snowflake-flexible-column-container-items\u003Ediv{width:100%}.sc-cert-banner__left{text-align:center}.sc-cert-banner__left .solution-center-hero__certification .snowflake-title-v2-line{justify-content:center}.summit-hero__bg-video{width:200%}.summit-leadership-grid .snowflake-flexible-column-container-items{grid-template-columns:repeat(2,1fr)}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:50%!important;max-width:50%!important}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:last-child){border-right:none!important}.summit-agenda{padding:24px}p.agenda-item__time{font-size:24px!important;width:auto;white-space:nowrap;padding-right:24px}}.agenda-item\u003Espan{display:flex;align-items:center}.summit-add-on-block,.summit-pricing-block{border:1px solid #d2d1d4;border-radius:8px;overflow:hidden;box-shadow:2px 4px 10px 0 rgb(156 156 156 / .52);background-color:#fff}.summit-add-on-block__content,.summit-pricing-block__content{padding:0 20px 20px}.summit-pricing-block__tile{padding:24px 20px;border-radius:4px;background:#fff;border:1px solid var(--ui-01);position:relative;transition:background-color .3s}.summit-pricing-block__tile:hover{background-color:var(--ui-01);transition:background-color .3s}.summit-pricing-block__tile.is-past{background-color:#d4f0fa}.summit-pricing-block__tile:hover .black-blue-text-color .snowflake-title-v2-line{color:#fff!important;transition:color .3s}.partner-card__logo-grid\u003E.container\u003E.cmp-container\u003E.aem-container::after,.partner-card__logo-grid\u003E.container\u003E.cmp-container\u003E.aem-container::before,.summit-add-on-block__content\u003E.container\u003E.cmp-container\u003E.aem-container::after,.summit-add-on-block__content\u003E.container\u003E.cmp-container\u003E.aem-container::before,.summit-pricing-block__tile.is-past .snowflake-content-chip-button,.summit-pricing-block__tile.is-upcoming .snowflake-content-chip-button,.summit-speaker-card .snowflake-card-v2-advanced-tag-indicator{display:none}.summit-pricing-block__tile.is-past .black-blue-text-color .snowflake-title-v2-line{color:#7cc7eb!important}.summit-pricing-block__tile.is-upcoming .black-blue-text-color .snowflake-title-v2-line{color:#8c8c8c!important}.summit-pricing-block__aside{background-color:#d4f0fa;border:1px solid #d2d1d4;border-radius:8px;padding:24px;width:100%}.summit-pricing-block__aside li::marker{color:var(--ui-01)}.summit-pricing-block__aside-headline .heading-5-v2{font-weight:900;margin-bottom:12px}.summit-pricing-block__header{background:#000;padding:24px 40px}.summit-pricing-block__header .heading-4-v2{font-weight:900;letter-spacing:.5px}.bwwidth100,.snowflake-mega-nav-dropdown-footer-content,.summit-pricing-block__tile .black-blue-text-color{width:100%}.summit-pricing-block__tile .heading-5-v2{position:static}.summit-pricing-block__tile .heading-5-v2 span.snowflake-title-v2-line:first-child{text-transform:uppercase;font-weight:900!important;letter-spacing:.25px;font-size:24px!important}.summit-pricing-block__tile .heading-5-v2 span.snowflake-title-v2-line:nth-child(2){margin-top:8px;font-family:Lato,sans-serif;font-size:14px;font-style:normal;font-weight:400;line-height:16px}.summit-pricing-block__tile .heading-5-v2 span.snowflake-title-v2-line:last-child{font-weight:900!important;font-size:40px!important}.snowflake-mega-nav-nav-item\u003Ea:hover .snowflake-mega-nav-nav-item-title-wrapper\u003E.snowflake-mega-nav-nav-item-title,.summit-pricing-block__tile:not(.is-upcoming):not(.is-past) .heading-5-v2 span.snowflake-title-v2-line:last-child{color:var(--ui-01)!important}.summit-pricing-block__tile:hover:not(.is-upcoming):not(.is-past) .heading-5-v2 span.snowflake-title-v2-line:last-child{color:#fff!important}.summit-pricing-block__tile.is-past .heading-5-v2 span.snowflake-title-v2-line:last-child{text-decoration:line-through}.summit-pricing-block__tile .snowflake-content-chip-button{margin-top:0;white-space:nowrap;display:none}.snowflake-card-v2-advanced.no-link{pointer-events:none!important}.snowpro-card{border:1px solid var(--summit-border);border-radius:var(--summit-border-radius);padding:var(--summit-card-padding-sm);display:flex;height:100%}.snowpro-card__headline{margin:24px 0 12px}.snowpro-card__pricing{margin-top:48px}.snowpro-card .snowflake-text .snowpro-card__price{color:var(--ui-01);font-weight:900;font-size:40px!important;font-family:Texta,sans-serif}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row;flex-wrap:wrap}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:last-child){border-right:1px solid var(--summit-border)}.summit-stat-card{padding:0 40px}.summit-stat .heading-2-v2 .snowflake-title-v2-line:first-child{font-size:64px;line-height:52px;margin-bottom:8px}.summit-stat .heading-2-v2 .snowflake-title-v2-line:last-child{font-size:32px;line-height:30px;margin-bottom:16px}.summit-speaker-card .snowflake-card-v2-advanced-title{margin-bottom:var(--spacing-01)}.summit-add-on-card{padding:24px;border:1px solid #d2d1d4;border-radius:8px}.summit-add-on__subhead{padding-left:40px;padding-right:40px}.partner-card__logo-grid,.partner-card__logo-single{padding:40px}.partner-card__logo-grid .snowflake-image-container .cmp-image__image,.partner-card__logo-single .snowflake-image-container .cmp-image__image{border-radius:0;max-width:240px;margin:0 auto}.partner-card\u003E.container,.partner-card\u003E.container\u003E.aem-container,.partner-card\u003E.container\u003E.cmp-container{height:100%}.summit-add-on-block__content\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row;gap:24px;align-items:stretch}.partner-card__logo-grid\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row;flex-wrap:wrap;gap:40px 24px;justify-content:center;align-items:center}.partner-card__logo-grid\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(33.3333% - 24px);margin:0!important}.partner-card{border-radius:8px;border:1px solid #d2d1d4;overflow:hidden;height:100%;background-color:#fff}.partner-card__header{padding:16px 24px;border-bottom:1px solid #d2d1d4}.partner-card__header.is-purple{background-color:#7d44cf}.partner-card__header h4{display:flex;flex-direction:row!important;align-items:center;gap:12px}.partner-card__header h4::before{vertical-align:middle;content:\"\";display:inline-block;width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-image:url(\"data:image/svg+xml,%3Csvg width='21' height='23' viewBox='0 0 21 23' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M20.0375 12.8374C20.1644 12.439 20.2172 12.0289 20.2077 11.6237C20.193 11.3305 20.1548 11.0373 20.0712 10.7441C19.8196 9.83306 19.223 9.01989 18.3294 8.50724L5.61817 1.2017C3.82388 .173815 1.53618 .784335 .506483 2.56804C-.533615 4.34915 .0797871 6.62351 1.87408 7.65398L8.97715 11.7427L1.87408 15.8201C.0797871 16.8527 -.531016 19.1271 .506483 20.9156C1.53618 22.6941 3.82388 23.302 5.61817 22.2746L18.3294 14.9643C19.1871 14.4728 19.7693 13.7027 20.0375 12.8374Z' fill='black'/%3E%3C/svg%3E%0A\")}.partner-card__header.is-purple h4::before{background-image:url(\"data:image/svg+xml,%3Csvg width='21' height='23' viewBox='0 0 21 23' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M20.0375 12.8374C20.1644 12.439 20.2172 12.0289 20.2077 11.6237C20.193 11.3305 20.1548 11.0373 20.0712 10.7441C19.8196 9.83306 19.223 9.01989 18.3294 8.50724L5.61817 1.2017C3.82388 .173815 1.53618 .784335 .506483 2.56804C-.533615 4.34915 .0797871 6.62351 1.87408 7.65398L8.97715 11.7427L1.87408 15.8201C.0797871 16.8527 -.531016 19.1271 .506483 20.9156C1.53618 22.6941 3.82388 23.302 5.61817 22.2746L18.3294 14.9643C19.1871 14.4728 19.7693 13.7027 20.0375 12.8374Z' fill='white'/%3E%3C/svg%3E%0A\")}.sf-blue-mountains{background-size:90% auto;background-repeat:no-repeat;background-position:center bottom;background-image:url(\"data:image/svg+xml,%3Csvg width='1361' height='410' viewBox='0 0 1361 410' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1360.25 410L1065.53 114.309L976.256 203.875L773.049 0L364.393 410H1360.25Z' fill='%233AA8DF'/%3E%3Cpath d='M274.778 410L137.467 272.238L.15625 410H274.778Z' fill='%233AA8DF'/%3E%3C/svg%3E%0A\")}.bwalignr,.main-pr-body .bwalignr{text-align:right}.bwblockalignl{margin-left:0;margin-right:auto}.bwcellpmargin{margin-top:0;margin-bottom:0}.bwlistdisc{list-style-type:disc}.bwpadb3{padding-bottom:4px}.bwpadb4{padding-bottom:5px}.bwpadl0{padding-left:0}.bwpadl3{padding-left:15px}.bwpadl6{padding-left:30px}.bwpadl9{padding-left:45px}.bwpadl12{padding-left:60px}.bwpadr0{padding-right:0}.bwtablemarginb{margin-bottom:10px}.bwvertalignb{vertical-align:bottom}.bwvertalignt{vertical-align:top}.bwsinglebottom{border-bottom:1pt solid #000}.bwdoublebottom{border-bottom:2.25pt double #000}.bwwidth1{width:1%}.bwwidth2{width:2%}.bwwidth6{width:6%}.bwwidth7{width:7%}.bwwidth8{width:8%}.bwwidth10{width:10%}.bwwidth12{width:12%}.bwwidth32{width:32%}.bwwidth44{width:44%}.bwwidth72{width:72%}.bwwidth97{width:97%}.main-pr-body{font-size:18px;line-height:26px}.main-pr-body img{display:block;width:100%;height:auto!important;border-radius:var(--small-border-radius)}.main-pr-body table{width:100%;display:block}.main-pr-body tbody{background-color:#f7f7f7}.main-pr-body .bwsinglebottom{border-bottom:1pt solid #000!important}.main-pr-body td.bwwidth44{padding-right:40px}.main-pr-body .bw-release-story{font-family:Lato,sans-serif}.main-pr-body .bw-release-story sup,.snowflake-mega-nav-dropdown-header-content-right a{white-space:nowrap}.main-pr-body .bw-release-story\u003E*,.main-pr-body\u003Espan\u003E*{margin-bottom:2rem!important}.snowflake-text.main-pr-body tbody,.snowflake-text.main-pr-body tbody p{font-size:14px!important;line-height:20px!important;width:100%;display:block}.press-body .snowflake-flexible-column-container-items{gap:var(--spacing-08)}.about-snowflake{border:1px solid #ccc;background-color:var(--ui-background-05);padding:24px;border-radius:8px;margin-top:0}.about-snowflake__logo{max-width:140px;margin-top:16px}.hero--press .snowflake-hero-system-inner{max-width:1408px;margin:0 auto!important}#arcticNavItem{flex-direction:column}#arcticNavItem::before{content:\"Featured Open Source Technologies\";display:block;margin-top:48px;margin-bottom:24px;font-size:16px!important;line-height:16px!important;font-weight:800!important;text-transform:uppercase}@media screen and (min-width:768px){.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child{position:relative;height:100%;top:auto;left:auto;width:auto}.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child::before{background:linear-gradient(180deg,#202c35 -7.5%,#fff0 51.25%,#202c35 107.69%)}.sc-hero__byline\u003Espan{display:flex;flex-wrap:wrap}.sc-hero__byline p:not(:last-child)::after{content:\"|\";margin:0 12px;opacity:.5}.sc-hero__button-container .snowflake-flexible-column-container-items{position:absolute;bottom:0;padding:0;margin:0 24px 0 0}.sc-hero__button-container .hero-watch-the-demo{padding:12px 16px!important;float:right;margin-bottom:48px;background-color:rgb(35 45 54 / .8)}.summit-overview-stat{padding:0 40px}.summit-timeline{border-bottom:3px solid var(--ui-01);margin-bottom:64px}.summit-add-on-block__content,.summit-pricing-block__content{padding:0 40px 40px}#arcticNavItem::before{font-size:12px!important;margin-bottom:8px;margin-top:16px}.snowflake-mega-nav-nav-item-title-wrapper\u003E.snowflake-mega-nav-nav-item-title{line-height:20px!important}.snowflake-card .heading-2.snowflake-title-line{font-size:24px!important;line-height:28px!important}}@media screen and (min-width:992px){.hp-hero__eyebrow a{gap:12px;margin-left:0;margin-right:0}.hp-hero__eyebrow a::after{content:\"\";background-image:url(\"data:image/svg+xml,%3Csvg width='6' height='11' viewBox='0 0 6 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M5.49134 5.79438C5.53447 5.75922 5.56923 5.71489 5.5931 5.66463C5.61697 5.61436 5.62935 5.55941 5.62935 5.50376C5.62935 5.44811 5.61697 5.39316 5.5931 5.34289C5.56923 5.29263 5.53447 5.2483 5.49134 5.21314L.736339 .413136C.522589 .203135 .331339 .203135 .151339 .413136C-.0286612 .623135 -.0586612 .818135 .151339 .994386L4.48634 5.50188L.155089 9.97938C.107068 10.0142 .0679743 10.0598 .0410153 10.1126C.0140562 10.1654 0 10.2238 0 10.2831C0 10.3424 .0140562 10.4009 .0410153 10.4537C.0679743 10.5065 .107068 10.5521 .155089 10.5869C.335089 10.7969 .530089 10.7969 .740089 10.5869L5.49134 5.79438Z' fill='black'/%3E%3C/svg%3E%0A\");display:inline-block;width:12px;height:12px;background-repeat:no-repeat;background-size:auto 100%;background-position:left center}.promo-banner--homepage{padding-top:32px}.homepage-banner-offset-container::after{height:50%}#storyHighlights{padding:2rem}.body-display-v2.snowflake-quote-item-quote-text{line-height:28px!important}.snowflake-hero-system-headline .heading-1-v2{line-height:48px;font-size:54px!important}.sc-overview__webinar-promo-banner .snowflake-content-chip-content{flex-direction:row;justify-content:space-between;align-items:center;width:100%}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .heading-5-v2{flex-direction:row}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .snowflake-title-v2-line:not(:first-child)::before{content:\"|\";margin:0 6px}.sc-cert-banner{padding:40px}.sc-cert-banner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{margin:0!important;width:50%}.sc-cert-banner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{flex-grow:1;padding-right:24px}.sc-cert-banner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:last-child{max-width:240px}.summit-pricing-block__content\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:last-child{width:70%;padding-left:40px}.summit-pricing-block__content\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{width:30%}.summit-add-on-block__content\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(33.3333% - 24px);margin:0!important;display:flex}.summit-pricing-block__tile .snowflake-content-chip-content{display:flex;flex-direction:row;align-items:center;width:calc(100% - 200px)}.summit-pricing-block__tile .heading-5-v2 span.snowflake-title-v2-line:last-child{position:absolute;top:50%;transform:translate(0,-50%);right:40px}.press-body\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child{position:sticky;top:120px}.snowflake-mega-nav-navigation-title:hover{color:var(--ui-01)}}@media screen and (min-width:1024px){.about-snowflake{padding:28px}.about-snowflake__logo{max-width:none;padding:0 0 0 48px;margin-bottom:0}.hero--press .snowflake-hero-system-layout-70-30 .snowflake-hero-system-content-container{width:85%}.snowflake-hero-system{padding-bottom:var(--spacing-04);padding-top:var(--spacing-07)}.hero--press .display-2-v2{font-size:64px;line-height:56px}.about-snowflake\u003E.container\u003E.cmp-container\u003E.aem-container{flex-direction:row;flex-wrap:nowrap;align-items:center}.about-snowflake\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:last-child{max-width:280px}.about-snowflake\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{flex-grow:1;margin-bottom:0!important}#polarisNavItem{margin-top:40px}.snowflake-mega-nav-nav-item-description{line-height:18px!important}.snowflake-mega-nav-column-items{gap:var(--spacing-01);grid-gap:var(--spacing-01)}.snowflake-mega-nav-navigation-title{text-transform:none}}div[id*=blueIcon] .snowflake-mega-nav-nav-item-icon__inner{background:var(--ui-01);padding:8px}div[id*=blueIcon]:hover .snowflake-mega-nav-nav-item-icon__inner{background:var(--ui-01)!important}.snowflake-mega-nav-nav-item-icon__inner{border-radius:4px;background:var(--ui-background-05);padding:6px}.snowflake-mega-nav-nav-item:hover .snowflake-mega-nav-nav-item-icon__inner{background:#fff!important}.snowflake-mega-nav-nav-item-icon.snowflake-image-container{height:40px;width:40px}.snowflake-mega-nav-dropdown-footer-links\u003E.snowflake-button-link\u003E.snowflake-button-container{font-size:16px!important;font-family:Texta!important;font-weight:800!important}.snowflake-mega-nav-dropdown-footer-icon.snowflake-image-container{margin-right:8px;width:40px!important;height:40px!important}#viewAllCapabilities a:hover{background:0 0!important}#platformFooter .snowflake-title-v2 .snowflake-title-v2-line:last-child{font-family:Lato;font-size:14px;font-weight:500}#platformFooter .snowflake-mega-nav-dropdown-footer-links{flex-grow:1;justify-content:flex-end;align-items:center}#platformFooter .snowflake-mega-nav-dropdown-footer-content{flex-direction:row}#offset,#open-source{flex-direction:column;border-top:1px solid #ccc}#offset::before,#open-source::before{content:\" \";display:block;width:100%;font-weight:800!important;font-size:12px!important;line-height:14px;text-transform:uppercase;white-space:nowrap;margin-top:16px;margin-bottom:8px}#open-source::before{content:\"Open Source Technologies\"}.snowflake-mega-nav-dropdown-menu-close-button{margin:var(--spacing-04) 0 var(--spacing-03)}.snowflake-mega-nav-column{gap:var(--spacing-02)!important}.snowflake-mega-nav-nav-item\u003Ea{width:100%;margin-left:-8px;padding:8px;border-radius:4px}.snowflake-mega-nav-nav-item\u003Ea:hover{background-color:var(--ui-background-05)}.snowflake-mega-nav-nav-item-description{margin-top:2px;display:block}#promobanner_overflowBottomDarkBlue::before{content:'';display:block;position:absolute;bottom:0;left:0;width:100%;height:50%;background:#212d35}#promobanner_overflowTopDarkBlue::before{content:'';display:block;position:absolute;top:0;left:0;width:100%;height:50%;background:#212d35}.overview-card\u003Ediv{box-shadow:0 0 14px 0 rgba(0,0,0,.10);background-color:#fff;border-radius:16px;overflow:hidden}.overview-card-text{padding:40px}.overview-card-image img{border-radius:0 !important}.overview-card-text h3,.overview-card-text .heading-3-v2{font-size:18px;line-height:1.1;margin-top:0}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"},"mega_header":{"additionalClasses":"heap-nav-header","layout":"SIMPLE","id":"container-c97ef8caf3",":type":"snowflake-site/components/mega-header",":items":{"nav_mega":{"activeItem":"item_1719963657751_c_663444255","id":"tabs-c2e54c75c0",":type":"snowflake-site/components/nav/nav-mega",":items":{"item_1719963657751_c_663444255":{"id":"nav-dropdown-menu-b7a51ccac7","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-0c7d6e8172",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"additionalClasses":"nav-platform-sidebar","numberOfSubColumns":"one-column","minWidth":"230","maxWidth":"350","layout":"SIMPLE","id":"container-382ba8d5d1",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_copy_2_793631646":{"id":"nav-item-af2629703e","additionalClasses":"nav-item__platform-parent is-platform","linkDescription":"Develop AI products, apps and more on a fully managed platform that securely connects businesses globally — across any type or scale of data.","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/platform/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"The Snowflake Platform"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-2aa9744803","additionalClasses":"nav-item nav-item--si is-si","linkDescription":"All your knowledge. One trusted enterprise agent.","flag":"NOW GA","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/snowflake-cowork/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake CoWork"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2_836345186":{"id":"nav-item-af40d52321","additionalClasses":"blue-icon is-analytics","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/analytics/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Analytics"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2":{"id":"nav-item-59ba546a43","additionalClasses":"blue-icon is-ai","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/ai/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"AI"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2_1314771042":{"id":"nav-item-1d4cd8cdb4","additionalClasses":"blue-icon is-data-eng","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/data-engineering/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Data Engineering"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634":{"id":"nav-item-cdba267ca7","additionalClasses":"blue-icon is-apps-collab","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/applications-and-collaboration/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Applications & Collaboration"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634_2013333117":{"id":"nav-item-4f53380cd5","additionalClasses":"blue-icon is-transactions","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/transactions/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Transactions"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_copy_2_793631646","nav_item","nav_item_copy_copy_2_836345186","nav_item_copy_copy_2","nav_item_copy_copy_2_1314771042","nav_item_copy_144634","nav_item_copy_144634_2013333117"]},"nav_column_copy_copy":{"additionalClasses":"meganav-platform-features","navColumnTitle":"Featured Capabilities","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-5b936e120b",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_212715":{"id":"nav-item-59022628d0","additionalClasses":"is-cortex-code","linkDescription":"Snowflake-native AI coding agent ","flag":"New","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/snowflake-coco/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake CoCo"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-4cad2b46ef","additionalClasses":"is-cortex-ai","linkDescription":"Instant access to industry-leading LLMs","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/cortex/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Cortex AI"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590635":{"id":"nav-item-650060cfa5","additionalClasses":"is-marketplace","linkDescription":"Third-party data sources connected within minutes","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/marketplace/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Marketplace"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590":{"id":"nav-item-22abee16c8","additionalClasses":"is-snowpark","linkDescription":"Libraries and code execution environments that run Python and more","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/snowpark/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Snowpark"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590_983061516":{"id":"nav-item-15394ec0ba","additionalClasses":"is-streamlit","linkDescription":"Framework for transforming Python scripts into web apps","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/streamlit-in-snowflake/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Streamlit"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_212715","nav_item","nav_item_copy_660590635","nav_item_copy_660590","nav_item_copy_660590_983061516"]},"nav_column_692142673":{"navColumnTitle":" ","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-933c5b23b8",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_660590_1739526127":{"id":"nav-item-0f59d07bb2","additionalClasses":"is-postgres","linkDescription":"Fully compatible open source Postgres running on Snowflake","flag":"Now GA","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/postgres/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Postgres"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565":{"id":"nav-item-e5a5a09213","additionalClasses":"is-dcr","linkDescription":"Streamlined model development and MLOps from a centralized UI","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/end-to-end-ml-workflows/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake ML"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_212715":{"id":"nav-item-4c75081681","additionalClasses":"is-openflow","linkDescription":"Effortless data movement for integrations","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/openflow/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Openflow"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590":{"id":"nav-item-383cb94576","additionalClasses":"is-notebooks","linkDescription":"Interactive dev environment for data and AI teams","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/notebooks/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Notebooks"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_258535199":{"id":"nav-item-eec5912ba9","propertiesId":"workload-nav-1","additionalClasses":"is-native-apps","linkDescription":"End-to-end, Snowflake-native app creation and distribution","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/native-apps/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Native Apps"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_660590_1739526127","nav_item_copy_185565","nav_item_copy_212715","nav_item_copy_660590","nav_item_258535199"]},"nav_column_782221091":{"navColumnTitle":" ","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-77603605ed",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy":{"id":"nav-item-5fbee8d3b6","additionalClasses":"is-light-gray-icon is-horizon-catalog","linkDescription":"Universal AI catalog","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/horizon/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Horizon Catalog"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590_1293798742":{"id":"nav-item-1b4eba8afd","additionalClasses":"is-snowflake-ml","linkDescription":"Governed context layer that keeps AI, BI and data apps working from one truth","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/horizon-context/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Horizon Context"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c":{"id":"nav-item-b1c4a9eddf","additionalClasses":"is-unistore","linkDescription":"Unify transactional and analytical workloads in Snowflake for enhanced simplicity","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/unistore/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Unistore"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c_1443811525":{"id":"nav-item-9b93c3739f","additionalClasses":"is-observe","linkDescription":"AI-powered observability for faster production troubleshooting","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/observe/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Observe"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c_1006104884":{"id":"nav-item-da2738d796","additionalClasses":"is-observe","linkDescription":"Use any engine on a single governed data copy","flag":"Now GA","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/use-cases/interoperable-lakehouse/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Interoperable Lakehouse"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy","nav_item_copy_660590_1293798742","nav_item_511717659_c","nav_item_511717659_c_1443811525","nav_item_511717659_c_1006104884"]}},":itemsOrder":["nav_column","nav_column_copy_copy","nav_column_692142673","nav_column_782221091"]},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Product"},"nav_dropdown_menu_2":{"id":"nav-dropdown-menu-e67636d1cd","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-e3be504697",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"navColumnTitle":"INDUSTRIES","numberOfSubColumns":"one-column","minWidth":"280","layout":"SIMPLE","id":"container-ca86f4a376",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_361384_2056203141":{"id":"nav-item-c805e45a50","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"All Industries"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-1a3b27ff3b","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/advertising-media-entertainment/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Advertising, Media & Entertainment"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-0fbc4bf8a7","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/financial-services/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Financial Services"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-739bffb620","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/healthcare-and-life-sciences/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Healthcare & Life Sciences"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1533429516":{"id":"nav-item-8ba509d4b6","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/manufacturing/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Manufacturing"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1444458226":{"id":"nav-item-05d7a29fd0","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/public-sector/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Public Sector"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1149488919":{"id":"nav-item-dda40a7f22","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/retail-consumer-goods/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Retail & Consumer Goods"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_57417040":{"id":"nav-item-8be63d204b","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/technology/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Technology"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_361384674":{"id":"nav-item-910670a1ed","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/telecom/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Telecom"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_361384":{"id":"nav-item-eaf21969c1","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/travel-hospitality/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Travel & Hospitality"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_361384_2056203141","nav_item","nav_item_copy","nav_item_copy_1970515619","nav_item_copy_1533429516","nav_item_copy_1444458226","nav_item_copy_1149488919","nav_item_copy_57417040","nav_item_copy_361384674","nav_item_copy_361384"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-extra-small"},"nav_column_copy":{"navColumnTitle":"DEPARTMENTS","numberOfSubColumns":"one-column","minWidth":"160","layout":"SIMPLE","id":"container-4e9da44961",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-e21fb90aa9","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/finance/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Finance"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-45848938b2","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/information-technology/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"IT"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-3e3f5cd78c","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/marketing/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Marketing"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy","nav_item_copy_1970515619"]},"nav_column_833417450":{"navColumnTitle":"Enablement Solutions","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-89a4a32ee2",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_107772":{"id":"nav-item-98aee4af7c","linkDescription":"Confident migration to a unified platform","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/migrate-to-the-cloud/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Migrate to the AI Data Cloud"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_833417450/nav_item_copy_107772/icon.coreimg.svg/1723828484100/nav-icon-cloud.svg","alt":"Cloud icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy":{"id":"nav-item-d742aef03e","linkDescription":"Snowflake experts to help you accelerate and achieve business goals","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/services-delivery/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Services Delivery"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_833417450/nav_item_copy_copy/icon.coreimg.svg/1768354429188/nav-icon--migrate.svg","alt":"Migrate icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_107772","nav_item_copy_copy"]},"nav_column_copy_copy":{"navColumnTitle":"PARTNER SOLUTIONS","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-e0ede5842f",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-3ea1b783a7","linkDescription":"Programs with product, solutions and cloud partners","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/partners/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake Partner Network"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_copy_copy/nav_item/icon.coreimg.svg/1723828498700/nav-icon--partner-network.svg","alt":"Partner Network icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-02342810ee","linkDescription":"Partners, apps and solutions for enhanced deployment","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/partners/all-partners/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Partner Finder"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_copy_copy/nav_item_copy/icon.coreimg.svg/1726173927645/nav-icon--partner-finder.svg","alt":"Partner Finder icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-a7ab1a6027","linkDescription":"Live and virtual events","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/partners/event-partnership-opportunities/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Event Partnership Opportunities"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_copy_copy/nav_item_copy_1970515619/icon.coreimg.svg/1726173935655/nav-icon--events.svg","alt":"Calendar icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy","nav_item_copy_1970515619"]}},":itemsOrder":["nav_column","nav_column_copy","nav_column_833417450","nav_column_copy_copy"]},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Solutions"},"item_1719963657751_c":{"id":"nav-dropdown-menu-bae6ee5d15","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-662d2c73cf",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"numberOfSubColumns":"one-column","minWidth":"230","maxWidth":"350","layout":"SIMPLE","id":"container-7ad055a706",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_copy_2_793631646":{"id":"nav-item-c46172fc7c","additionalClasses":"nav-item__platform-parent-why-sf","linkDescription":"Collaborate locally and globally to reveal new insights, create previously unforeseen business opportunities, and identify your customers with seamless experiences.","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Why Snowflake"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_copy_2_793631646"]},"nav_column_copy_copy":{"additionalClasses":"meganav-platform-features","numberOfSubColumns":"two-columns","maxWidth":"1200","layout":"SIMPLE","id":"container-249472e762",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-8d6b94d01c","propertiesId":"testID","linkDescription":"Case studies and videos showcasing how global organizations use Snowflake","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/customers/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Customers"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item/icon.coreimg.svg/1739839279367/nav-icon--partner-network.svg","alt":"Customer icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_258535199":{"id":"nav-item-6852f485b1","propertiesId":"workload-nav-1","linkDescription":"Learn how to connect, share and integrate the data and apps on the AI Data Cloud","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/what-is-data-cloud/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"The AI Data Cloud Explained"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item_258535199/icon.coreimg.svg/1739840490955/nav-icon-cloud.svg","alt":"Cloud icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565":{"id":"nav-item-62c095244e","linkDescription":"Comprehensive security through built-in features, robust cloud infrastructure protection, and more","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/snowflake-security-hub/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Security Hub"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item_copy_185565/icon.coreimg.svg/1758909528089/user-security-admins-ciso-icon.svg","alt":"User with security lock icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-9c1836f7e2","additionalClasses":"is-light-gray-icon","linkDescription":"Maximize economic value through minimizing TCO and continuously optimizing price for performance","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/pricing-options/cost-and-performance-optimization/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Cost and Performance Optimization"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item_copy/icon.coreimg.svg/1758909542267/nav-icon-cost-optimization-performance.svg","alt":"Cost Optimization icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565_903555964":{"id":"nav-item-a6cdc77700","linkDescription":"Startups building applications in the AI Data Cloud","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/startup-program/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake for Startups"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item_copy_185565_903555964/icon.coreimg.svg/1758732224323/launch.svg","alt":"Launch","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_258535199","nav_item_copy_185565","nav_item_copy","nav_item_copy_185565_903555964"]}},":itemsOrder":["nav_column","nav_column_copy_copy"]},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Why Snowflake"},"item_1719961362824":{"id":"nav-dropdown-menu-75ce91b8c2","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-182097f19c",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column_copy":{"navColumnTitle":"Connect","numberOfSubColumns":"one-column","minWidth":"124","layout":"SIMPLE","id":"container-efe0c531e8",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-533a437f26","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/blog/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Blog"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_180298689":{"id":"nav-item-2336fbf7e0","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/events/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Events"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_1639361946":{"id":"nav-item-c9a8c5c252","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/support/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Support"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_680912746":{"id":"nav-item-d6e065c6e5","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/contact/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Contact us"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_180298689","nav_item_1639361946","nav_item_680912746"]},"nav_column_44600420__826130542":{"navColumnTitle":"Learn","numberOfSubColumns":"two-columns","layout":"SIMPLE","id":"container-c40390face",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy":{"id":"nav-item-7e028a3787","linkDescription":"Ebooks, videos, white papers and more","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/resources/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Resource Library"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy/icon.coreimg.svg/1736877128196/nav-icon--notebooks.svg","alt":"Notebooks icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-8bd0f12150","linkDescription":"Overview of Snowflake's educational offerings","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/resources/learn/training/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Training"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item/icon.coreimg.svg/1722385094416/nav-icon--training.svg","alt":"Training icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634_1984107859":{"id":"nav-item-b216ff5744","linkDescription":"Expert-led discussions and demos across industries and use cases","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/webinars/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Webinars"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_144634_1984107859/icon.coreimg.svg/1759424691990/nav-icon--webinars.svg","alt":"Webinars icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1438098918":{"id":"nav-item-8316bc20e4","linkDescription":"Snowflake's technical industry professional certifications","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/resources/learn/certifications/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Certifications"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_1438098918/icon.coreimg.svg/1722382780833/nav-icon--cert.svg","alt":"Certification icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_143809":{"id":"nav-item-4fd33bd98a","linkDescription":"Weekly product demos showcasing key features and live Q&A ","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/webinars/demo/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Live Demos"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_143809/icon.coreimg.svg/1759424359543/nav-icon--live-demo.svg","alt":"Live Demo icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890638":{"id":"nav-item-e14f1930b5","linkDescription":"Training courses for all levels, on-demand or instructor-led","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://learn.snowflake.com/en/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Snowflake University"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_333890638/icon.coreimg.svg/1722382769808/nav-icon--education.svg","alt":"Education icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_189945":{"id":"nav-item-21599e3a17","linkDescription":"Instructor-led virtual workshops for exploring key Snowflake features","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/webinars/virtual-hands-on-lab/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Hands-On Labs"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_189945/icon.coreimg.svg/1759388182903/nav-icon--labs.svg","alt":"Hands-on Labs icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890":{"id":"nav-item-042d46befd","linkDescription":"Academic papers written by Snowflake researchers","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/resources/publications/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake Research Publications"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_333890/icon.coreimg.svg/1756326371387/copy.svg","alt":"Copy","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890_930852828":{"id":"nav-item-9b69017f41","linkDescription":"Informative articles about AI and data topics","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/fundamentals/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Fundamentals"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_333890_930852828/icon.coreimg.svg/1756853637155/data-sheet.svg","alt":"Document with list","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy","nav_item","nav_item_copy_144634_1984107859","nav_item_copy_1438098918","nav_item_copy_143809","nav_item_copy_333890638","nav_item_copy_189945","nav_item_copy_333890","nav_item_copy_333890_930852828"]}},":itemsOrder":["nav_column_copy","nav_column_44600420__826130542"]},"nav_promo_section":{"id":"nav-promo-section-6c42fe73b4","experience_fragment_1":{"id":"experiencefragment-be9d5b10a4","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/master1/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-e64776eb43",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-b1cfdccddd","openInNewWindow":true,"layout":"horizontal","headline":"Dev Day Virtual - June 25","description":"Don’t just hear about AI — build it. Luminary talks and hands-on labs","linkTitle":"Learn more","linkUrl":"/en/dev-day/americas-virtual/","image":{"id":"image","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--de231e36-6645-4550-abd9-0f8de758ac66/web-dev-day-26-960x540-1x.png?preferwebp=true&quality=85","alt":"dev day","lazyEnabled":true,"height":"540","width":"960",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:metadata":{":type":"nt:unstructured"}},":itemsOrder":["root","cq:metadata"],"classNames":"aem-xf"},"experience_fragment_2":{"id":"experiencefragment-58c8b68c5e","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/navigation-promo-card-2/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-aa889b07fd",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-8d3d69e43d","openInNewWindow":true,"layout":"horizontal","headline":"The ROI of Gen AI and Agents 2026","description":"Discover how 92% of early adopters are achieving positive ROI with gen AI.","linkTitle":"Learn More","linkUrl":"/en/lp/radical-roi-generative-ai/","image":{"id":"image","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--0c15edae-1a97-4739-8b16-c7f3941a6d9e/web-roi-of-gen-ai-and-agents-2026-r02-960x540.png?preferwebp=true&quality=85","alt":"roi of gen ai and agents","lazyEnabled":true,"height":"540","width":"960",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:metadata":{":type":"nt:unstructured"}},":itemsOrder":["root","cq:metadata"],"classNames":"aem-xf"},"experience_fragment_3":{"id":"experiencefragment-6905e0f5d4","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/navigation-promo-card-3/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-df6ee3debd",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-7a257f764b","openInNewWindow":true,"layout":"horizontal","headline":"Startup 2026: AI Agents Mean Business","description":"Venture leaders weigh in on agentic AI. ","linkTitle":"Learn more","linkUrl":"/en/lp/building-startup-ai-age/","image":{"id":"image","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--a320b404-dca1-4477-b033-c79708538657/web-startup-2026-960x540.png?preferwebp=true&quality=85","alt":"alt","lazyEnabled":true,"height":"540","width":"960",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:metadata":{":type":"nt:unstructured"}},":itemsOrder":["root","cq:metadata"],"classNames":"aem-xf"},":type":"snowflake-site/components/nav/nav-promo-section"},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Resources"},"item_1719963657751":{"id":"nav-dropdown-menu-09a2c9908e","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-5a65b9b6ed",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column_copy_copy":{"navColumnTitle":"Build","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-9ece4431e9",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-e43ede0ee4","propertiesId":"testID","linkDescription":"Overview of the dev resources you need to build and scale","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake for Developers"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy/nav_item/icon.coreimg.svg/1731362494574/nav-icon--devs.svg","alt":"Developers icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1855651246":{"id":"nav-item-36fbbbbad3","linkDescription":"Reference architectures, use cases and best practices","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/guides/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Developer Guides"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy/nav_item_copy_1855651246/icon.coreimg.svg/1761677891705/nav-icon--solution-center.svg","alt":"Solution Center icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-b4dff8d109","additionalClasses":"is-light-gray-icon","linkDescription":"The latest software versions, drivers, libraries and relevant docs","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/downloads/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Downloads"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy/nav_item_copy/icon.coreimg.svg/1731362660050/nav-icon-download.svg","alt":"Download icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy_1855651246","nav_item_copy"]},"nav_column_copy_copy_1367930678":{"navColumnTitle":"Learn","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-0e995d9677",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-371a2db705","propertiesId":"testID","linkDescription":"Reference docs, guides, tutorials and announcements","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://docs.snowflake.com/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Documentation"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1367930678/nav_item/icon.coreimg.svg/1731361950527/nav-icon--docs.svg","alt":"Docs icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-16df91efbf","additionalClasses":"is-light-gray-icon","linkDescription":"Key projects Snowflake engineers maintain and support","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/open-source/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Open Source"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1367930678/nav_item_copy/icon.coreimg.svg/1731365437016/nav-icon-open-source.svg","alt":"Open Source icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy":{"id":"nav-item-036ba0d7a5","additionalClasses":"is-light-gray-icon","linkDescription":"Online and in-person classes and workshops to upskill on Snowflake","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/northstar/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Builder Education"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1367930678/nav_item_copy_copy/icon.coreimg.svg/1731362475640/nav-icon--northstar.svg","alt":"Northstar logo","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy","nav_item_copy_copy"]},"nav_column_copy_copy_1101894776":{"navColumnTitle":"Connect","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-bb34535bf0",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-874db05e92","propertiesId":"testID","linkDescription":"Snowflake’s technical leaders on what, why and how they build features","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/engineering-blog/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Engineering Blog"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1101894776/nav_item/icon.coreimg.svg/1757101368571/nav-icon--developer-center.svg","alt":"Developers icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1855651246":{"id":"nav-item-3178865ce2","linkDescription":"Tips, tricks and discussion with fellow Snowflake developers","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://community.snowflake.com/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Community"},"icon":{"id":"icon","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1101894776/nav_item_copy_1855651246/icon.coreimg.svg/1731362644348/nav-icon--partner-network.svg","alt":"Partner Network icon","lazyEnabled":true,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy_1855651246"]}},":itemsOrder":["nav_column_copy_copy","nav_column_copy_copy_1367930678","nav_column_copy_copy_1101894776"]},"nav_promo_section":{"id":"nav-promo-section-96317bb589","experience_fragment_1":{"id":"experiencefragment-114f719b3d","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/nav-promo-5/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-0aa9f742fa",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-eee62e25ea","openInNewWindow":false,"layout":"horizontal","headline":"Get started with your first Snowflake Notebook","description":"Write and execute code, visualize results, and tell the story of your analysis all in one place.","linkTitle":"Learn More","linkUrl":"/en/developers/solutions-center/getting-started-with-your-first-snowflake-notebook-project/","image":{"id":"image","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--dc7e334a-c38b-4283-b1de-fcf829952eef/nav-promo-first-notebook.jpg?preferwebp=true&quality=85","alt":"alt","lazyEnabled":true,"height":"210","width":"415",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:LiveSyncConfig":{"cq:isDeep":true,"cq:rolloutConfigs":[],"cq:master":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/nav-promo-card-4",":type":"cq:LiveCopy"}},":itemsOrder":["root","cq:LiveSyncConfig"],"classNames":"aem-xf"},"experience_fragment_2":{"id":"experiencefragment-2ed797ec6d","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/nav-promo-card-4/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-db336422b1",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-33e7dc220c","openInNewWindow":true,"layout":"horizontal","headline":"Northstar Builder Workshops","description":"Join other developers as you roll up your sleeves and explore the possibilities of Snowflake.","linkTitle":"Learn More","linkUrl":"/en/nav-promos/northstar-builders-workshop/","image":{"id":"image","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--14341ced-bc5e-4a29-9762-b7857f6cadfc/nav-promo-northstar.jpg?preferwebp=true&quality=85","alt":"Snowflake Northstar logo","lazyEnabled":true,"height":"700","width":"1440",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:LiveSyncConfig":{"cq:isDeep":true,"cq:rolloutConfigs":[],"cq:master":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/master",":type":"cq:LiveCopy"}},":itemsOrder":["root","cq:LiveSyncConfig"],"classNames":"aem-xf"},":type":"snowflake-site/components/nav/nav-promo-section"},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Developers"},"item_1718247180324":{"id":"nav-dropdown-menu-a929984df8","enableDropdown":false,"link_url":"/en/pricing-options/",":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Pricing"}},":itemsOrder":["item_1719963657751_c_663444255","nav_dropdown_menu_2","item_1719963657751_c","item_1719961362824","item_1719963657751","item_1718247180324"]},"languagenavigation":{"id":"language-navigation-e7cfe34c56","languageNavItems":[{"title":"English","path":"/en/developers/guides/horizon-intra-org-sharing/","locale":"en","active":true},{"title":"日本語","path":"/ja/","locale":"ja","active":false},{"title":"한국어","path":"/ko/","locale":"ko","active":false},{"title":"中文（简体）","path":"/zh_cn/","locale":"zh-cn","active":false},{"title":"Português","path":"/pt_br/","locale":"pt-br","active":false},{"title":"Deutsch","path":"/de/","locale":"de","active":false},{"title":"Français","path":"/fr/","locale":"fr","active":false},{"title":"Español","path":"/es/","locale":"es","active":false},{"title":"Italiano","path":"/it/","locale":"it","active":false}],":type":"snowflake-site/components/nav/language-navigation"},"button_1177328691":{"id":"button-ca6f8896da","heapButtonClasses":["mega-nav__sign-in"],"showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://app.snowflake.com/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-link snowflake-button-black snowflake-button-compact","linkType":"SNOWFLAKE_EXTERNAL","text":"Sign in"},"button":{"id":"button-0fc66fb83f","heapButtonClasses":["contact_nav","heap-nav-contact"],"showOutboundIcon":true,"buttonLink":{"valid":true,"url":"/en/contact-sales/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-secondary snowflake-button-blue snowflake-button-compact","linkType":"SNOWFLAKE_INTERNAL","text":"CONTACT SALES"},"button_288358396":{"id":"button-5fb4b5b515","heapButtonClasses":["start_for_free_nav","heap-nav-start-for-free"],"showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://signup.snowflake.com/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-primary snowflake-button-blue snowflake-button-compact","linkType":"SNOWFLAKE_EXTERNAL","text":"start for free"}},":itemsOrder":["nav_mega","languagenavigation","button_1177328691","button","button_288358396"],"appliedCssClassNames":"snowflake-header-container white"}},":itemsOrder":["markup_editor","mega_header"]},"image":{":type":"nt:unstructured"},"cq:targetMetadata":{"cq:targetStatus":"OUT_OF_SYNC","cq:exportTime":1781280015540,"cq:targetOfferId":860250,":type":"nt:unstructured"}},":itemsOrder":["root","image","cq:targetMetadata"],"classNames":"aem-xf"},"markup_editor_1950346551":{"id":"markup-editor-30268a1094","title":" ","cssContent":".snowflake-markdown-table code[class*=language-],.snowflake-markdown-table code[class*=language-],.snowflake-markdown .snowflake-text code[class*=language-],.snowflake-markdown .snowflake-text pre[class*=language-]{background-color:rgba(var(--ui-12-rgb),.5);color:var(--text-01);text-shadow:none;padding:var(--spacing-00);border-radius:var(--spacing-00);font-size:smaller}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"},"responsivegrid":{"columnClassNames":{"quickstart_hero":"aem-GridColumn aem-GridColumn--default--12","flexible_column_cont":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnCount":12,":items":{"quickstart_hero":{"id":"quickstart-hero-27f3139624","isDeveloperGuidesPage":false,"quickstartHeroFirstCertifiedTag":{"tagText":"Quickstart","tagColor":"#29B5E8","tagPath":"/content/cq:tags/snowflake-site/taxonomy/solution-center/certification/quickstart","tagIcon":""},"quickstartHeroTitle":{"lines":["Explore Cross-Cloud Sharing of Data and Applications with Private Listings"],"type":"heading2",":type":"snowflake-site/components/title-v2"},"quickstartHeroAuthor":"Matthias Nicola, Vinay Srihari","quickstartHeroForkRepoLink":{"id":"button-8390a176be","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://github.com/Snowflake-Labs/sfquickstarts/tree/master/site/sfguides/src/horizon-intra-org-sharing"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Fork Repo"},"quickstartHeroBreadcrumbs":[{"title":"Explore Cross-Cloud Sharing of Data and Applications with Private Listings","url":"https://www.snowflake.com/content/snowflake-site/global/en/developers/guides/horizon-intra-org-sharing","currentPage":true},{"title":"Guides","url":"https://www.snowflake.com/content/snowflake-site/global/en/developers/guides","currentPage":false},{"title":"Snowflake for Developers","url":"https://www.snowflake.com/content/snowflake-site/global/en/developers","currentPage":false}],"fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/horizon-intra-org-sharing",":type":"snowflake-site/components/quickstart/quickstart-hero"},"flexible_column_cont":{"id":"flexible-column-container-aafb9818fa","propertiesId":"quickstart-template-main-flexible-container","type":"2-column-75-25","alignColumns":"top","containerMaxWidth":"extra-large","topPadding":"none","bottomPadding":"none","spaceBetween":"small","reverseOnMobile":false,"carouselOnMobile":false,"backgroundImageOption":"none","flexible_column_content_container_1":{"layout":"SIMPLE","id":"container-9d3f2c8ea1",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"contentfragment":{"id":"contentfragment-52cd91f052","paragraphs":["&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EOverview\u003C/h2\u003E\n","\u003Cp\u003ESharing information between departments, business units and subsidiaries of a company is critical for success, particularly when there are organizational silos in place. A modern data platform must provide decentralized ownership, universal discovery, access control, federated governance, and observability.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnowflake Horizon Catalog\u003C/strong\u003E is a connected catalog for your entire data estate. It allows customers to interoperate more easily across table formats, engines &amp; catalogs. Horizon allows you to manage metadata for all your data &amp; AI assets in one place for easy data discovery and collaboration.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/horizon-catalog.jpg\" alt=\"Snowflake Horizon Diagram\"\u003E\u003C/p\u003E\n","\u003Cp\u003EThis Quickstart is focused on the \u003Ccode\u003EHorizon Collaboration\u003C/code\u003E and \u003Ccode\u003EHorizon Discovery\u003C/code\u003E pillars.\u003C/p\u003E\n","\u003Cp\u003EThe objective of the Collaboration and Discovery pillars are to make it simple to share, discover, understand/build trust and access listings across any boundary, internal or external to the organization, and to make loose objects discoverable across account boundaries within an organization, supported by the tools necessary to ensure policy compliance, security, and data quality.\u003C/p\u003E\n","\u003Cp\u003EIn this lab you will experience the latest Snowflake Horizon Collaboration and Discovery features for sharing data and native apps intra-company: private listings, unified search &amp; discovery, data quality monitoring, role-based governance policies and programmatic management of data products. We will cover structured and unstructured data that is stored on-platform or on external storage.\u003C/p\u003E\n","\u003Ch3\u003EWhat You&rsquo;ll Learn\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003EHow to blend TastyBytes Point-of-Sale and Marketplace Weather data to build analytics data products, then publish Listings targeted at accounts in your company\u003C/li\u003E\u003Cli\u003EHow to configure data privacy polices that are preserved in the consumer accounts that install the listings. Tag-based column masking, row-access, aggregation and projection policies will be created with database roles.\u003C/li\u003E\u003Cli\u003EHow to setup Data Metrics Functions to monitor data quality of the shared data products\u003C/li\u003E\u003Cli\u003EHow to share Iceberg Tables within a cloud region\u003C/li\u003E\u003Cli\u003EHow to share a native application with Streamlit visualization\u003C/li\u003E\u003Cli\u003EHow to share unstructured text files cross-cloud and process with Cortex LLM functions\u003C/li\u003E\u003C/ul\u003E\n&lt;!--\n- How to use Universal Search and Snowflake Copilot to explore data from all sources\n--&gt;\n","\u003Ch3\u003EWhat You&rsquo;ll Need\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003EBasic knowledge of SQL, Database Concepts, Snowflake \u003Ca href=\"https://other-docs.snowflake.com/en/collaboration/collaboration-listings-about\"\u003EListings\u003C/a\u003E\u003C/li\u003E\u003Cli\u003EFamiliarity with \u003Ca href=\"https://docs.snowflake.com/en/user-guide/ui-snowsight-worksheets-gs\"\u003ESnowsight Worksheets\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EWhat You&rsquo;ll Build\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003EAnalytics data products for TastyBytes, that models a global food truck network with localized menu options in 15 countries, 30 major cities and 15 core brands\u003C/li\u003E\u003Cli\u003EListings comprised of metadata, data and application code, targeted at accounts in the same organization but in different cloud regions\u003C/li\u003E\u003Cli\u003EGovernance policies based on shared role-based-access-controls that are enforced at the target account consuming the listing\u003C/li\u003E\u003Cli\u003EInstall listings containing Iceberg Tables, then blend with local datasets to derive insights\u003C/li\u003E\u003C/ul\u003E\n&lt;!--\n- Exploration of all shared and local data with Universal Search and Copilot\n--&gt;\n","\u003Ch3\u003EPrerequisites\u003C/h3\u003E\n","\u003Ch4\u003ECreate 3 Snowflake Trial Accounts in the same Snowflake Organization\u003C/h4\u003E\n","\u003Cp\u003ESignup for an AWS trial account \u003Ca href=\"https://signup.snowflake.com/?utm_source=snowflake-devrel&amp;utm_medium=developer-guides&amp;utm_cta=developer-guides\"\u003Ehere\u003C/a\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EChoose \u003Cstrong\u003EAWS\u003C/strong\u003E as cloud provider, \u003Cstrong\u003EBusiness Critical\u003C/strong\u003E edition, \u003Cstrong\u003EAWS_US_WEST_2 (Oregon)\u003C/strong\u003E region\u003C/li\u003E\u003Cli\u003EActivate trial account with admin user \u003Ccode\u003Ehorizonadmin\u003C/code\u003E\n\u003Cul\u003E\u003Cli\u003Eadmin user has system roles: ACCOUNTADMIN, ORGADMIN, SYSADMIN\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003ELogin and create a SQL Worksheet named \u003Cem\u003E\u003Cstrong\u003EAccount Setup\u003C/strong\u003E\u003C/em\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E&lt;ins&gt;Note:&lt;/ins&gt; alternatively you \u003Cem\u003Ecan\u003C/em\u003E use an existing account instead of a trial account, provided that account has the \u003Ccode\u003EORGADMIN\u003C/code\u003E system role enabled.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ECreate user \u003Ccode\u003Ehorizonadmin\u003C/code\u003E, grant it ACCOUNTADMIN and ORGADMIN roles.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EExecute the following SQL commands in the \u003Cem\u003E\u003Cstrong\u003EAccount Setup\u003C/strong\u003E\u003C/em\u003E worksheet to bootstrap:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE accountadmin;\nSET my_user_var = CURRENT_USER();\nALTER USER identifier($my_user_var) SET DEFAULT_ROLE = accountadmin;\nCREATE OR REPLACE WAREHOUSE compute_wh WAREHOUSE_SIZE=small INITIALLY_SUSPENDED=TRUE;\nGRANT ALL ON WAREHOUSE compute_wh TO ROLE public;\nCREATE DATABASE IF NOT EXISTS snowflake_sample_data FROM SHARE sfc_samples.sample_data;\nGRANT IMPORTED PRIVILEGES ON DATABASE snowflake_sample_data TO public;\n\n-- Create an AWS Consumer account\nUSE ROLE orgadmin;\nCREATE ACCOUNT horizon_lab_aws_consumer\n  admin_name = horizonadmin\n  admin_password = 'FILL_IN_PASSWORD'\n  email = 'FILL_IN_EMAIL'\n  must_change_password = false\n  edition = business_critical\n  region = AWS_US_WEST_2;\n \n-- Create an Azure Consumer account\nCREATE ACCOUNT horizon_lab_azure_consumer\n  admin_name = horizonadmin\n  admin_password = 'FILL_IN_PASSWORD'\n  email = 'FILL_IN_EMAIL'\n  must_change_password = false\n  edition = business_critical\n  region = AZURE_WESTEUROPE;\n\n-- Verify that all three accounts are now created. Also, get the URLs\n-- from the column account_url to log in to your consumer accounts later\nSHOW ORGANIZATION ACCOUNTS;\n\n-- Enable the ACCOUNTADMIN role on this account to enable global auto-fulfillment\nUSE ROLE orgadmin;\nSELECT current_account_name();\nSELECT SYSTEM$ENABLE_GLOBAL_DATA_SHARING_FOR_ACCOUNT('!FILL IN CURRENT_ACCOUNT_NAME()!');\n\n-- PLEASE NOTE DOWN: &quot;orgname-accountname&quot; is the account format needed to add a connection to the Snowflake CLI\nSELECT current_organization_name() || '-' || current_account_name();\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ELogin to the \u003Cstrong\u003EHORIZON_LAB_AWS_CONSUMER\u003C/strong\u003E and \u003Cstrong\u003EHORIZON_LAB_AZURE_CONSUMER\u003C/strong\u003E accounts as \u003Ccode\u003Ehorizonadmin\u003C/code\u003E and run the following in a worksheet in each of the two accounts:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE accountadmin;\nSET my_user_var = CURRENT_USER();\nALTER USER identifier($my_user_var) SET DEFAULT_ROLE = accountadmin;\nCREATE OR REPLACE WAREHOUSE compute_wh WAREHOUSE_SIZE=medium INITIALLY_SUSPENDED=TRUE;\nGRANT ALL ON WAREHOUSE compute_wh TO ROLE public;\nCREATE DATABASE IF NOT EXISTS snowflake_sample_data FROM SHARE sfc_samples.sample_data;\nGRANT IMPORTED PRIVILEGES ON DATABASE snowflake_sample_data TO public;\n \nUSE ROLE useradmin;\nCREATE OR REPLACE ROLE sales_emea_role\n      COMMENT = 'EMEA Sales role for Tasty Bytes';\n\nCREATE OR REPLACE ROLE sales_americas_role\n      COMMENT = 'Americas Sales role for Tasty Bytes';\n\nCREATE OR REPLACE ROLE sales_apj_role\n      COMMENT = 'APJ Sales role for Tasty Bytes';\n\nCREATE OR REPLACE ROLE sales_manager_role\n      COMMENT = 'Sales Manager (all-access) role for Tasty Bytes';\n\n-- grant all these roles to the login user\nGRANT ROLE sales_emea_role TO USER identifier($my_user_var);\nGRANT ROLE sales_americas_role TO USER identifier($my_user_var);\nGRANT ROLE sales_apj_role TO USER identifier($my_user_var);\nGRANT ROLE sales_manager_role TO USER identifier($my_user_var);\n\nSHOW ROLES;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EInstall Snowflake CLI and configure Connections to Snowflake accounts\u003C/h4\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EInstall Python (3.8 or higher): \u003Ccode\u003Epython --version\u003C/code\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://brew.sh/\"\u003EHomebrew\u003C/a\u003E makes it simple to install python\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003E% brew install python\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E(optional): \u003Ccode\u003E% sudo ln -s /usr/bin/python3 /usr/local/bin/python\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EInstall \u003Ca href=\"https://pipx.pypa.io/stable/installation/\"\u003Epipx\u003C/a\u003E or \u003Ca href=\"https://macpaw.com/how-to/install-pip-mac\"\u003Epip\u003C/a\u003E\n(MacOS)\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003E% brew install pipx\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003E% pipx ensurepath\u003C/code\u003E\u003C/li\u003E\u003Cli\u003Eexit and open a new Terminal so path takes effect\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EInstall \u003Ca href=\"https://docs.snowflake.com/en/developer-guide/snowflake-cli-v2/installation/installation#label-snowcli-install-pipx\"\u003ESnowflake CLI\u003C/a\u003E\u003C/p\u003E\n","\u003Cp\u003ECreate CLI connections to the 3 accounts using \u003Ca href=\"https://docs.snowflake.com/en/developer-guide/snowflake-cli-v2/connecting/specify-credentials#how-to-add-credentials-using-a-sf-cli-connection-command\"\u003Esnow connection add\u003C/a\u003E:\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003Euse connection names: \u003Ccode\u003Ehorizon-aws-provider, horizon-aws-consumer, horizon-azure-consumer\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESnowflake CLI expects the account format \u003Cstrong\u003Eorgname-accountname\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003ESELECT current_organization_name() || '-' || current_account_name();\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003Eenter password when prompted, just hit \u003Cem\u003E\u003Cstrong\u003Ereturn\u003C/strong\u003E\u003C/em\u003E for the remaining prompts\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Esnow connection add -n horizon-aws-provider -a [orgname]-[provider_accountname] -u horizonadmin -r accountadmin -w compute_wh\nsnow connection add -n horizon-aws-consumer -a [orgname]-horizon_lab_aws_consumer -u horizonadmin -r accountadmin -w compute_wh\nsnow connection add -n horizon-azure-consumer -a [orgname]-horizon_lab_azure_consumer -u horizonadmin -r accountadmin -w compute_wh\nsnow connection set-default &quot;horizon-aws-provider&quot;\nsnow connection test --connection horizon-aws-provider\nsnow connection test --connection horizon-aws-consumer\nsnow connection test --connection horizon-azure-consumer\n\n# list all connections and check that default is horizon-aws-provider\nsnow connection list\n\n# you can also manually edit the config.toml file to remove or modify connections\nsnow --info\n\u003C/code\u003E\u003C/pre\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003ECitations and Terms of Use\u003C/h2\u003E\n","\u003Cp\u003ERaw text data provided for this lab is an extract from the \u003Ca href=\"https://ai.stanford.edu/~amaas/data/sentiment/\"\u003EIMDB Large Movie Review Dataset\u003C/a\u003E\u003C/p\u003E\n","\u003Cp\u003EUse of this dataset requires that we cite this ACL 2011 paper by Andrew Maas, et al:\n@InProceedings{maas-EtAl:2011:ACL-HLT2011,\nauthor    = {Maas, Andrew L.  and  Daly, Raymond E.  and  Pham, Peter T.  and  Huang, Dan  and  Ng, Andrew Y.  and  Potts, Christopher},\ntitle     = {Learning Word Vectors for Sentiment Analysis},\nbooktitle = {Proceedings of the 49th Annual Meeting of the Association for Computational Linguistics: Human Language Technologies},\nmonth     = {June},\nyear      = {2011},\naddress   = {Portland, Oregon, USA},\npublisher = {Association for Computational Linguistics},\npages     = {142--150},\nurl       = {\u003Ca href=\"http://www.aclweb.org/anthology/P11-1015}\"\u003Ehttp://www.aclweb.org/anthology/P11-1015}\u003C/a\u003E\n}\u003C/p\u003E\n","\u003Cp\u003E\u003Ca href=\"https://app.snowflake.com/marketplace/listing/GZSOZ1LLEL/weather-source-llc-weather-source-llc-frostbyte\"\u003EWeather Source LLC: frostbyte\u003C/a\u003E Marketplace listing requires accepting terms of use by the Provider and Snowflake.\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EHorizon AWS Provider Account Setup\u003C/h2\u003E\n","\u003Cp\u003EClone our \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-horizon-intra-organization-sharing\"\u003EHorizon Quickstart Scripts\u003C/a\u003E repository to your local machine with \u003Ccode\u003Egit\u003C/code\u003E:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Emkdir ~/snowflakelabs\ncd ~/snowflakelabs\ngit clone git@github.com:Snowflake-Labs/sfguide-horizon-intra-organization-sharing.git horizon-intra-org-scripts\ncd horizon-intra-org-scripts\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EIf you prefer not to use git, \u003Ccode\u003EDownload ZIP\u003C/code\u003E from the Lab Scripts \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-horizon-intra-organization-sharing\"\u003Egithub site\u003C/a\u003E\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/code-download.jpg\" alt=\"assets/code-download.jpg\"\u003E\u003C/p\u003E\n","\u003Cp\u003ELoad the SQL scripts in the \u003Ccode\u003Ecode/sql\u003C/code\u003E directory into \u003Ca href=\"https://docs.snowflake.com/en/user-guide/ui-snowsight-worksheets-gs#create-worksheets-in-sf-web-interface\"\u003ESnowsight Worksheets\u003C/a\u003E - one script per worksheet\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/002_load_SQL_scripts_to_worksheets.png\" alt=\"Create Worksheet\"\u003E\u003C/p\u003E\n","\u003Ch3\u003EExecute Setup SQL Scripts\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\u003Ccode\u003E100_Setup_Data_Model\u003C/code\u003E: create the TastyBytes foundational data model.\n\u003Ca href=\"/en/developers/guides/tasty-bytes-introduction/\"\u003ETastyBytes\u003C/a\u003E is a fictitious global food truck network that operates in 30 major cities located in 15 countries with localized menu options and brands. The single \u003Ccode\u003EFrostbytes_Tasty_Bytes\u003C/code\u003E is organized in the following schemas:\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003ERAW_CUSTOMER\u003C/code\u003E: raw customer loyalty data with personally identifiable information (PII)\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003ERAW_POS\u003C/code\u003E: raw point-of-sale data denormalized by orders, menu, franchise and country\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003EHARMONIZED\u003C/code\u003E: blended metrics for customers and orders\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003EANALYTICS\u003C/code\u003E: analytic data that delivers insights for aggregate trends and drill down\nb\nUse the \u003Cstrong\u003ERun All\u003C/strong\u003E pulldown command to run \u003Ccode\u003E100_Setup_Data_Model\u003C/code\u003E:\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/003_Run_All.png\" alt=\"Run All in Worksheet\"\u003E\u003C/p\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003E\u003Ccode\u003E200_Setup_Data_Products\u003C/code\u003E: build data assets to share in a Listing.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EIn step 1(a) of thescript \u003Ccode\u003E200_Setup_Data_Products\u003C/code\u003E you will acquire the \u003Cstrong\u003EWeather Source LLC\u003C/strong\u003E listing from the Marketplace and install it as a shared database \u003Ccode\u003EFROSTBYTE_WEATHERSOURCE\u003C/code\u003E.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Step 1(a) - Acquire &quot;Weather Source LLC: frostbyte&quot; Snowflake Marketplace Listing\n\n/*--- \n    1. Click -&gt; Data Products (Cloud Icon in left sidebar)\n    2. Click -&gt; Marketplace\n    3. Search -&gt; frostbyte\n    4. Click -&gt; Weather Source LLC: frostbyte\n    5. Click -&gt; Get\n    6. Click -&gt; Options\n    6. Database Name -&gt; FROSTBYTE_WEATHERSOURCE (all capital letters)\n    7. &quot;Which roles, in addition to ACCOUNTADMIN, can access this database?&quot; -&gt; PUBLIC\n    8. Click -&gt; Get\n---*/\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/006_WeatherSource.png\" alt=\"006_WeatherSource\"\u003E\u003C/p\u003E\n","\u003Cp\u003EThen proceed to execute all remaining steps in this script. This will create secure views, materialized views, functions and dynamic tables in the ANALYTICS schema, and an internal stage for sharing text data.\u003C/p\u003E\n","\u003Cp\u003ECheck out all the new objects created in the ANALYTICS and HARMONIZED schemas in the Snowsight Object Explorer panel. You will later create a Listing to share all of these objects.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/004_Database_Explorer.png\" alt=\"Database-Explorer\"\u003E\u003C/p\u003E\n","\u003Ch3\u003EUpload Unstructured Data into an Internal Stage\u003C/h3\u003E\n","\u003Cp\u003EWe have extracted 100 text files from the IMDB Large Movie Review dataset into the repo, that was cloned to your local machine earlier.\u003C/p\u003E\n","\u003Cp\u003ENow we can copy those text files into the internal stage \u003Ccode\u003Emovie_stage\u003C/code\u003E that was created by the SQL setup scripts.\nRun the snow CLI commands at the root of your repo, where the \u003Ccode\u003Egit clone\u003C/code\u003E was done.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Ecd ~/git_repos/sfguide-horizon-intra-org\nsnow stage copy data/imdb_reviews @frostbyte_tasty_bytes.movie_reviews.movie_stage\n\n# verify that there are now 100 files in the stage\nsnow stage list-files @frostbyte_tasty_bytes.movie_reviews.movie_stage\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ESetup is now complete!\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EPublish a Data Listing\u003C/h2\u003E\n","\u003Cp\u003EIn this section you will create, publish, consume, alter, and monitor a \u003Ca href=\"https://other-docs.snowflake.com/en/collaboration/collaboration-listings-about\"\u003Elisting\u003C/a\u003E.\u003C/p\u003E\n","\u003Ch3\u003EBuild and Publish a Listing in the Provider Studio UI\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003ENavigate to the Provider Studio and click the +Listing button in the top right:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/101_ProviderStudio+Listing.png\" alt=\"ProviderStudio\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EGive your listing a meaningful title. Let's use TASTY_BYTES_ANALYTICS in this lab. Then select the option that &quot;Only Specified Consumers&quot; can discover the listing, and click &quot;Next&quot;.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/102_CreateListing.png\" alt=\"102_CreateListing\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick &quot;+ Select&quot; and add the secure functions, the dynamic table, and all the secure views in the ANALYTICS and HARMONIZED schemas to this listing.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/103_CreateListing_SelectObjects.png\" alt=\"103_CreateListing_SelectObjects\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EContinue the listing specification:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EAdd a description to document your listing.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EFor example: &quot;This listing shares the Tasty Bytes Analytics and Harmonized data objects, including views, functions, and a dynamic table that provide a wealth of useful information.&quot;\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EAdd your two secondary accounts for this lab (one on AWS and one on Azure) as consumer accounts for this listing. Specify each consumer account as \u003Ccode\u003Eorg-name.account-name\u003C/code\u003E, which you can obtain as follows:\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Eselect current_organization_name() ||'.'||  current_account_name();\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cul\u003E\u003Cli\u003EFurther down in the same dialog, enter your email address to receive notifications about this listing.\u003C/li\u003E\u003Cli\u003EClick &quot;SAVE &amp; ADD MORE INFORMATION&quot; to add even more metdata to your listing.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/104_CreateListing_AddConsumers.png\" alt=\"104_CreateListing_AddConsumers\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EYou are now looking at your draft listing. Scroll down and add all optional information items to your listing.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/105_CreateListing_OptionalInformation.png\" alt=\"105_CreateListing_OptionalInformation\"\u003E\u003C/p\u003E\n","\u003Cp\u003EThis will add additional sections to your listing.\u003C/p\u003E\n","\u003Cp\u003EClick the ADD button in each of these sections to configure the data dictionary and to add business needs, sample queries, and attributes:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EConfiguring the data dictionary allows you to select &quot;featured&quot; objects that consumers will see first in the dictionary.\u003C/li\u003E\u003Cli\u003ESelect the views CUSTOMER_LOYALTY_METRICS_V and ORDERS_BY_POSTAL_CODE_V as well as the function FAHRENHEIT_TO_CELSIUS as featured objects.\u003C/li\u003E\u003Cli\u003EYou can grab some sample queries from the script 1000_Consumer_Queries.sql\u003C/li\u003E\u003Cli\u003EAttributes allow you to specify service level objectives such as how often you intend to update the data product or other properties.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/106_CreateListing_OptionalInfo_Part2.png\" alt=\"106_CreateListing_OptionalInfo_Part2\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIn your draft listing, navigate to the section &quot;Consumer Accounts&quot;. Click the three dots on the right to update the refresh frequency of the replica that Snowflake will automatiucally create to share the data product with your Azure account.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EFor the purpose of this lab, set the replication frequency to 1 minute.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/107_CreateListing_ReplicationFrequency.png\" alt=\"107_CreateListing_ReplicationFrequency\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EPublish your listing.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EYou can preview your draft listing at any time.\u003C/li\u003E\u003Cli\u003EWhen done, click the blue &quot;Publish Listing&quot; button in the top right corner.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003EInstall the Listing in your Consumer Accounts\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003ESwitch to Consumer Account: Horizon_Lab_Azure_Consumer\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EIn a different tab of your web browser login to your account &quot;horizon_lab_azure_consumer&quot; that you created in the Azure West Europe Region.\u003C/li\u003E\u003Cli\u003EUse the menu in the bottom left of the UI to switch to the ACCOUNTADMIN role.\u003C/li\u003E\u003Cli\u003ENavigate to &quot;Data Products&quot; and then &quot;Private Sharing&quot; in the left hand menu panel.\u003C/li\u003E\u003Cli\u003EYou will now see the listing that has been shared with this account.\u003C/li\u003E\u003Cli\u003EClick the listing name (not the Get button) to open and examine the listing details. For example, explore the data dictionary for the views and functions.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/201_Consumer_DiscoverListing.png\" alt=\"201_Consumer_DiscoverListing\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EAfter reviewing the listing, click the GET button.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EYou may be asked for your name &amp; email address if this is the first time a listing is being consumed in this Snowflake  account. Do provide this information, then go to your Email Inbox and validate the email that was sent.\u003C/li\u003E\u003Cli\u003EAfter you click the GET button Snowflake performs a one-time setup of the replication process (\u003Ca href=\"https://other-docs.snowflake.com/en/collaboration/provider-listings-auto-fulfillment\"\u003Eauto-fulfillment\u003C/a\u003E) to the local region.\u003C/li\u003E\u003Cli\u003EYou may have to wait for several minutes for this one-time setup to complete. Click OK. We will check back later.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/202_Consumer_WaitForReplica.png\" alt=\"202_Consumer_WaitForReplica\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESwitch to Consumer Account: Horizon_Lab_AWS_Consumer\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EIn yet another tab of your web browser login to your account &quot;horizon_lab_aws_consumer&quot;.\u003C/li\u003E\u003Cli\u003EUse the menu in the bottom left to switch to the ACCOUNTADMIN role.\u003C/li\u003E\u003Cli\u003ENavigate to &quot;Data Products&quot; and then &quot;Private Sharing&quot;.\u003C/li\u003E\u003Cli\u003EClick the listing name (not the Get button) to open and examine the listing details.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EAfter reviewing the listing, click the GET button.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EAgain, you may be asked to provide and validate your email address.\u003C/li\u003E\u003Cli\u003EAfter you click the GET button you can immediately mount the shared data product. There is no replication setup in this case since the provider account is in the same cloud region as this consumer account.\u003C/li\u003E\u003Cli\u003EUnder &quot;Options&quot; leave the local database name as is (it should be TASTY_BYTES_ANALYTICS), and select SALES_MANAGER_ROLE as an additional role to have immediate access to the data product.\u003C/li\u003E\u003Cli\u003EClick GET to confirm\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/203_Consumer_GET.png\" alt=\"203_Consumer_GET\"\u003E\u003C/p\u003E\n","\u003Cp\u003EYou can now use a worksheet or the database explorer to examine the shared data as a consumer.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EObserve live data sharing in action\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ESwitch to the \u003Cstrong\u003EAWS Provider\u003C/strong\u003E account where you published the listing\u003C/li\u003E\u003Cli\u003EInsert or update some of the source data. You can use the following statement which uses \u003Ca href=\"https://docs.snowflake.com/en/sql-reference/sql/select#label-select-cmd-examples-select-all-in-table-replace\"\u003Ea very cool SQL feature\u003C/a\u003E to modify the columns produced by \u003Ccode\u003ESELECT *\u003C/code\u003E.\n\u003Cul\u003E\u003Cli\u003EThe syntax \u003Ccode\u003ESELECT * REPLACE (&lt;expression&gt; AS &lt;column_name&gt;)\u003C/code\u003E returns all columns but replaces the column \u003Ccode\u003E&lt;column_name&gt;\u003C/code\u003E with the \u003Ccode\u003E&lt;expression&gt;\u003C/code\u003E.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- re-insert existing data for Berlin but give it today's date as the valid date \nINSERT INTO FROSTBYTE_TASTY_BYTES.WEATHER.HISTORY_DAY\n  SELECT * REPLACE  (current_date AS DATE_VALID_STD) \n  FROM FROSTBYTE_TASTY_BYTES.WEATHER.HISTORY_DAY\n  WHERE city_name = 'Berlin'\n  ORDER BY date_valid_std DESC;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cul\u003E\u003Cli\u003ESwitch back to your \u003Cstrong\u003EHorizon_Lab_AWS_Consumer\u003C/strong\u003E account to see that the data changes are instantly visible. For example:\u003C/li\u003E\u003C/ul\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT *\nFROM tasty_bytes_analytics.HARMONIZED.DAILY_WEATHER_V\nWHERE city_name = 'Berlin'\nORDER BY date_valid_std DESC;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch2\u003EListing Management and Monitoring\u003C/h2\u003E\n","\u003Ch3\u003EUse the Listing API to modify listing properties programmatically\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://other-docs.snowflake.com/en/sql-reference/sql/show-listings\"\u003ESHOW LISTINGS\u003C/a\u003E in the AWS Provider account where you published the listing.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/301_Provider_API_Show.png\" alt=\"301_Provider_API_Show\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ECopy the Snowflake object name of your listing and use it in the subsequent \u003Ca href=\"https://other-docs.snowflake.com/en/sql-reference/sql/desc-listing\"\u003EDESCRIBE LISTING\u003C/a\u003E command.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ENote: If that listing name contains special characters other than the underscore, then the name must be in double quotes and is case-sensitive.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIn the result of DESCRIBE LISTING, scroll to the right to the column \u003Ca href=\"https://other-docs.snowflake.com/en/progaccess/listing-manifest-reference\"\u003EMANIFEST_YAML\u003C/a\u003E and copy its column value. This YAML file is a complete representation of the listing and enables programmatic management of listings.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/302_Provider_API_Describe.png\" alt=\"302_Provider_API_Describe\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EPaste the copied YAML into an \u003Ca href=\"https://other-docs.snowflake.com/en/sql-reference/sql/alter-listing\"\u003EALTER LISTING\u003C/a\u003E statement using the listing name obtained in step 2 above (Show Listing).\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EMake some changes in the YAML that you can easily verify in the UI and on the consumer side. For example, update the title and the first line of the description.\u003C/li\u003E\u003Cli\u003EExecute the ALTER LISTING statement.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/303_Provider_API_AlterListing.png\" alt=\"303_Provider_API_AlterListing\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EVerify the immediate effect of the ALTER LISTING statement\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EIn the provider account, navigate to the Provider Studio, select &quot;Listings&quot; from the horizontal menu at the top, and open your listing.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/304_Provider_Studio.png\" alt=\"304_Provider_Studio\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ESwitch to your consumer account Horizon_Lab_AWS_Consumer.\u003C/li\u003E\u003Cli\u003ENavigate to &quot;Data Products&quot;, then &quot;Private Sharing&quot;, and open the listing page again. Refresh if needed to see the changes from the ALTER LISTING statement.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003EMonitor Auto Fulfillment status and cost\u003C/h3\u003E\n","\u003Cp\u003ETime to revisit the second consumer account (&quot;horizon_lab_azure_consumer&quot;) and the replication into that Azure region. By now, the one-time replication setup has been completed in the background and the data product is now ready to use.\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003ESwitch to the account &quot;horizon_lab_azure_consumer&quot; as ACCOUNTADMIN, and navigate to &quot;Private Sharing&quot; to open the listing that has been shared.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick the GET button to mount the data product locally, as you did in the &quot;horizon_lab_aws_consumer&quot; account.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESwitch to the AWS Provider account and take the following steps to monitor replication status and cost.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENavigate to the &quot;Provider Studio&quot;, select &quot;Listings&quot; from the horizontal menu at the top, and open your listing.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EOn the listings page, scoll down to &quot;Consumer Account&quot;, click on the 3 dots, and select &quot;Manage Regions &amp; Replication&quot;\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESelect the &quot;Azure West Europe Region&quot; to see the timestamp of the latest refresh to that region.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/400_MonitorReplicationStatus.png\" alt=\"400_MonitorReplicationStatus\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EGo back to the Provider Studio, select &quot;Analytics&quot; from the horizontal menu at the top. This is where summarized and detailed statistics about the usage of the listings will be displayed eventually. There is some delay in populating these statistics, but the following screenshots give you an idea of what you will see.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/401_Provider_Dashboard.png\" alt=\"401_Provider_Dashboard\"\u003E\u003C/p\u003E\n","\u003Cp\u003EThe same information as well as replication details can also be obtained from various views in the schema \u003Ca href=\"https://docs.snowflake.com/en/sql-reference/data-sharing-usage\"\u003ESNOWFLAKE.DATA_SHARING_USAGE\u003C/a\u003E and \u003Ca href=\"https://docs.snowflake.com/en/sql-reference/organization-usage\"\u003ESNOWFLAKE.ORGANIZATION_USAGE\u003C/a\u003E:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Euse database SNOWFLAKE;\n\nselect * from DATA_SHARING_USAGE.LISTING_ACCESS_HISTORY;\n\nselect * from DATA_SHARING_USAGE.LISTING_AUTO_FULFILLMENT_DATABASE_STORAGE_DAILY;\n\nselect * from DATA_SHARING_USAGE.LISTING_AUTO_FULFILLMENT_REFRESH_DAILY;\n\nselect * from DATA_SHARING_USAGE.LISTING_EVENTS_DAILY;\n\nselect * from DATA_SHARING_USAGE.LISTING_TELEMETRY_DAILY;\n\nselect * from ORGANIZATION_USAGE.LISTING_AUTO_FULFILLMENT_USAGE_HISTORY;\n\nselect * from ORGANIZATION_USAGE.REPLICATION_USAGE_HISTORY;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe \u003Ca href=\"https://other-docs.snowflake.com/en/collaboration/provider-understand-cost-auto-fulfillment\"\u003Ereplication cost\u003C/a\u003E can also be monitored in the UI. Navigate to the &quot;Admin&quot; menu in the left-hand panel, then to &quot;Cost Management&quot; and &quot;Consumption&quot;. Switch the filter from &quot;All Services&quot; to &quot;Cross-Cloud Auto-Fulfillment&quot;. Here is an example from a different test replicating a listing to the region Azure UK South:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/402_Provider_LAF_Cost_Compute.png\" alt=\"402_Provider_LAF_Cost_Compute\"\u003E\u003C/p\u003E\n","\u003Cp\u003EAdditional filters enable you to select a time period, pick a specific target region, or toggle between compute cost, storage cost, and data transfer volume incurred by the listing auto-fulfillment.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/403_Provider_LAF_DataTransfer.png\" alt=\"403_Provider_LAF_DataTransfer\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/404_Provider_LAF_DataTransfer_Details.png\" alt=\"404_Provider_LAF_DataTransfer_Details\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003EEnable and Consume Change Tracking\u003C/h3\u003E\n","\u003Cp\u003EThe provider of a listing can choose to enable \u003Ca href=\"https://docs.snowflake.com/en/user-guide/streams\"\u003Echange tracking\u003C/a\u003E on the some or all of the tables or views that are shared in a listing. This enables the consumer to track the data changes. Let's do that with the view DAILY_WEATHER_V:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- in the provider account:\nALTER VIEW FROSTBYTE_TASTY_BYTES.HARMONIZED.DAILY_WEATHER_V \n      SET CHANGE_TRACKING = TRUE;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThe consumer can now \u003Ca href=\"https://docs.snowflake.com/en/sql-reference/sql/create-stream\"\u003Edefine a Stream\u003C/a\u003E to capture the data changes in this view:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- in the consumer account:\nCREATE DATABASE tasty_bytes_local;\nUSE DATABASE tasty_bytes_local;\n\nCREATE STREAM stream_daily_weather_changes ON VIEW tasty_bytes_analytics.HARMONIZED.DAILY_WEATHER_V;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ETo see the change tracking in action you can now insert, update, or delete some of the weather related data in the AWS Provider account. For example:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- in the provider account:\nINSERT INTO FROSTBYTE_TASTY_BYTES.WEATHER.HISTORY_DAY\n  SELECT * REPLACE  (current_date AS DATE_VALID_STD) \n  FROM FROSTBYTE_TASTY_BYTES.WEATHER.HISTORY_DAY\n  WHERE city_name = 'San Mateo'\n  ORDER BY date_valid_std DESC;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow switch to the consumer account and query the stream:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- in the consumer account:\nUSE DATABASE tasty_bytes_local;\n\nSELECT METADATA$ACTION, METADATA$ISUPDATE, * \nFROM stream_daily_weather_changes;\n\u003C/code\u003E\u003C/pre\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EProtect Data with Governance Policies\u003C/h2\u003E\n","\u003Cp\u003EThis section of the lab introduces several capabilities for data providers to restrict the usage of their products by consumers.\u003C/p\u003E\n","\u003Ch3\u003ECross-Account Row-Level Access Policies\u003C/h3\u003E\n","\u003Cp\u003EFrosty the data steward is concerned that our listing that we have shared includes the view ANALYTICS.CUSTOMER_LOYALTY_METRICS_V which contains sensitive information that must not be accessible to all data consumers. He requests the following restrictions:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/500_DataSteward_1.png\" alt=\"500_DataSteward_1\"\u003E\u003C/p\u003E\n","\u003Cp\u003ELet's implement a \u003Ca href=\"https://docs.snowflake.com/en/user-guide/security-row-intro\"\u003Erow-level access policy\u003C/a\u003E to implement the required access control. Note the usage of the context function \u003Cstrong\u003Ecurrent_account_name()\u003C/strong\u003E to detect which consumer account is accessing the shared view.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFill in AWS Provider Account Name below\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Euse database frostbyte_tasty_bytes;\nuse schema analytics;\n\nCREATE OR REPLACE ROW ACCESS POLICY country_filter AS (country string) \nRETURNS boolean -&gt;\n  CASE\n    WHEN current_account_name() IN ('HORIZON_LAB_AWS_CONSUMER') \n      AND country               IN ('United States', 'Canada') \n      THEN true\n    WHEN current_account_name() IN ('HORIZON_LAB_AZURE_CONSUMER')        \n      AND country               IN ('France', 'Germany', 'Poland', 'Sweden', 'Spain') \n      THEN true\n    WHEN current_account_name() IN ('*** FILL IN AWS Provider Account Name ***')\n      THEN true\n      ELSE false\n  END;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThen apply the policy to the shared view:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER VIEW CUSTOMER_LOYALTY_METRICS_V ADD ROW ACCESS POLICY country_filter ON (country);\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow switch to the consumer account HORIZON_LAB_AWS_CONSUMER to confirm that only US and Canadian client data is visible in the view ANALYTICS.CUSTOMER_LOYALTY_METRICS_V.\u003C/p\u003E\n","\u003Cp\u003EAfter the replication interval of 1 minute you will also see that the consumer account HORIZON_LAB_AZURE_CONSUMER can only see the Eurpean clients.\u003C/p\u003E\n","\u003Ch3\u003ECross-Account Column Masking\u003C/h3\u003E\n","\u003Cp\u003EBut, Frosty the data steward is not yet satisfied:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/501_DataSteward_2.png\" alt=\"501_DataSteward_2\"\u003E\u003C/p\u003E\n","\u003Cp\u003EOk, let's get to work.\u003C/p\u003E\n","\u003Cp\u003ETo make things easy, let's first create a tag that you can use to indicate which columns contain PII data.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ECREATE SCHEMA IF NOT EXISTS tags;\n\nCREATE OR REPLACE TAG tags.tasty_pii\n    ALLOWED_VALUES 'NAME', 'PHONE_NUMBER', 'EMAIL', 'BIRTHDAY'\n    COMMENT = 'Tag for PII, allowed values are: NAME, PHONE_NUMBER, EMAIL, BIRTHDAY';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EWith the tag created, let's assign it to the relevant columns in the Customer Loyalty view:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER VIEW ANALYTICS.CUSTOMER_LOYALTY_METRICS_V\n    MODIFY COLUMN \n    first_name    SET TAG tags.tasty_pii = 'NAME',\n    last_name     SET TAG tags.tasty_pii = 'NAME',\n    phone_number  SET TAG tags.tasty_pii = 'PHONE_NUMBER',\n    e_mail        SET TAG tags.tasty_pii = 'EMAIL';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EOptionally, you can also use the UI to add or see the tags on these columns:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/502_AddTags.png\" alt=\"502_AddTags\"\u003E\u003C/p\u003E\n","\u003Cp\u003ENow let's create a slightly more advanced \u003Ca href=\"https://docs.snowflake.com/en/user-guide/tag-based-masking-policies\"\u003Epolicy to mask the PII columns depending on their tag\u003C/a\u003E value and the consmer account:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFill in AWS Provider Account Name below\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ECREATE OR REPLACE MASKING POLICY pii_string_mask AS (value STRING) RETURNS STRING -&gt;\n  CASE\n    -- two roles in the provider account have access to unmasked values \n    WHEN CURRENT_ACCOUNT_NAME() IN ('*** FILL IN AWS Provider Account Name ***') \n    AND CURRENT_ROLE()          IN ('ACCOUNTADMIN','SYSADMIN')\n    THEN value\n\n    -- For consumers in the 2nd AWS account: if a column is tagged with \n    -- TASTY_PII=PHONE_NUMBER then mask everything except the first 3 digits   \n    WHEN CURRENT_ACCOUNT_NAME() IN ('HORIZON_LAB_AWS_CONSUMER') \n    AND SYSTEM$GET_TAG_ON_CURRENT_COLUMN('TAGS.TASTY_PII') = 'PHONE_NUMBER'\n    THEN CONCAT(LEFT(value,3), '-***-****')\n        \n    -- For consumers in the Azure account: if a column is tagged with  \n    -- TASTY_PII=EMAIL then mask everything before the @ sign  \n    WHEN CURRENT_ACCOUNT_NAME() IN ('HORIZON_LAB_AZURE_CONSUMER') \n    AND SYSTEM$GET_TAG_ON_CURRENT_COLUMN('TAGS.TASTY_PII') = 'EMAIL'\n    THEN CONCAT('**~MASKED~**','@', SPLIT_PART(value, '@', -1))\n        \n    -- all other cases and columns, such as first and last name, should be fully masked   \n    ELSE '**~MASKED~**' \n  END;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENext, apply the policy to the tag so that the policy takes effect on all tages columns:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER TAG tags.tasty_pii SET MASKING POLICY pii_string_mask;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow switch to the consumer account HORIZON_LAB_AWS_CONSUMER and look at the view CUSTOMER_LOYALTY_METRICS_V to confirm that phone numbers are partially masked while the other PII columns are fully masked.\u003C/p\u003E\n","\u003Cp\u003EAfter the replication interval of 1 minute you will see in the account HORIZON_LAB_AZURE_CONSUMER that emails are partially masked while phone numbers and names are fully masked.\u003C/p\u003E\n","\u003Ch3\u003EDatabase Roles - Provider Side\u003C/h3\u003E\n","\u003Cp\u003EJust when we thought we had all the necessary governance controls in place, Frosty has a new requirement for us.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/503_DataSteward_3.png\" alt=\"503_DataSteward_3\"\u003E\u003C/p\u003E\n","\u003Cp\u003ESo far we have been using the context function \u003Cstrong\u003ECURRENT_ACCOUNT_NAME()\u003C/strong\u003E in our governance policies to control which consumer account can see which data. Now Frosty is telling us, that this needs to be more fine-grained down to indivudal roles on the consumer side.\u003C/p\u003E\n","\u003Cp\u003EWe will be using roles and \u003Ca href=\"https://docs.snowflake.com/en/sql-reference/sql/create-database-role\"\u003Edatabase roles\u003C/a\u003E for 3 different continents. Let's check that we have the correct roles in place.\u003C/p\u003E\n","\u003Cp\u003EOn the AWS Provider account, use \u003Cstrong\u003Eshow database roles\u003C/strong\u003E to confirm that you have 4 database roles in place. Else create them now.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Eshow database roles in database FROSTBYTE_TASTY_BYTES;\n\nUSE DATABASE frostbyte_tasty_bytes;\nCREATE OR REPLACE DATABASE ROLE tastybytes_emea_role;\nCREATE OR REPLACE DATABASE ROLE tastybytes_americas_role;\nCREATE OR REPLACE DATABASE ROLE tastybytes_apj_role;\nCREATE OR REPLACE DATABASE ROLE tastybytes_manager_role;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EWe can use these roles to define more granular and role-based access control for the data consumers. First, we need to give these roles access to the providers's schema and objects that we want to govern, in this case ANALYTICS.CUSTOMER_LOYALTY_METRICS_V:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Euse database FROSTBYTE_TASTY_BYTES;\n\ngrant usage  on schema ANALYTICS to database role tastybytes_emea_role;\ngrant usage  on schema ANALYTICS to database role tastybytes_americas_role;\ngrant usage  on schema ANALYTICS to database role tastybytes_apj_role;\ngrant usage  on schema ANALYTICS to database role tastybytes_manager_role;\n\ngrant select on view ANALYTICS.CUSTOMER_LOYALTY_METRICS_V \n             to database role tastybytes_emea_role; \ngrant select on view  ANALYTICS.CUSTOMER_LOYALTY_METRICS_V \n             to database role tastybytes_americas_role; \ngrant select on view  ANALYTICS.CUSTOMER_LOYALTY_METRICS_V \n             to database role tastybytes_apj_role; \ngrant select on view  ANALYTICS.CUSTOMER_LOYALTY_METRICS_V \n             to database role tastybytes_manager_role; \n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENext, use the context function \u003Ca href=\"https://docs.snowflake.com/en/sql-reference/functions/is_database_role_in_session\"\u003E\u003Cstrong\u003EIS_DATABASE_ROLE_IN_SESSION()\u003C/strong\u003E\u003C/a\u003E to recreate our row-level access policy to define which role can see customer loyality data from which country.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFill in Provider Account Name in the last WHEN clause of the policy below\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Euse database frostbyte_tasty_bytes;\nuse schema analytics;\n\nALTER VIEW CUSTOMER_LOYALTY_METRICS_V DROP ROW ACCESS POLICY country_filter;\n\n-- Fill in Provider Account Name below\n\nCREATE OR REPLACE ROW ACCESS POLICY country_filter AS (country string) \nRETURNS boolean -&gt;\n  CASE\n    -- users with the AMERICAS role can see data from the US, Canada, and Brazil\n    WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_AMERICAS_ROLE') \n     AND country IN ('United States', 'Canada', 'Brazil') \n    THEN true\n    -- users with the EMEA role can see data from these EMEA countries\n    WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_EMEA_ROLE')         \n     AND country IN ('France', 'Germany', 'Poland', 'Sweden', \n                     'Spain' , 'South Africa', 'Egypt') \n    THEN true\n    -- users with the APJ role can see data from these APJ countries\n    WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_APJ_ROLE')         \n     AND country IN ('Japan', 'Australia', 'India', 'South Korea') \n    THEN true\n    -- users with the manager role can see all data\n    WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_MANAGER_ROLE')         \n    THEN true\n    -- the account admin in the provider account can see all data\n    WHEN current_account_name() IN ('*** FILL IN AWS Provider Account Name ***') \n     AND current_role() = 'ACCOUNTADMIN'\n    THEN true\n    ELSE false\n  END;\n\nALTER VIEW CUSTOMER_LOYALTY_METRICS_V \n      ADD ROW ACCESS POLICY country_filter ON (country);\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EFor a larger number of roles and countries you can certainly use a mapping table from role to country so that the policy simply performs a lookup in the mapping table.\u003C/p\u003E\n","\u003Cp\u003EThe final step in the provider account is to share the database roles to the consumer accounts along with the data product.  This is achieved by \u003Ca href=\"https://docs.snowflake.com/en/sql-reference/sql/grant-database-role-share\"\u003Egranting the database roles to the share\u003C/a\u003E:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Use your share name in these commands.\n-- See below for hints on how to find your share name.\nGRANT DATABASE ROLE tastybytes_emea_role     TO SHARE &lt;share_name&gt;;\nGRANT DATABASE ROLE tastybytes_americas_role TO SHARE &lt;share_name&gt;;\nGRANT DATABASE ROLE tastybytes_apj_role      TO SHARE &lt;share_name&gt;;\nGRANT DATABASE ROLE tastybytes_manager_role  TO SHARE &lt;share_name&gt;;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EHere are two options how to find the share name for your listing:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOption 1:\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EIn the provider account, navigate to the Provider Studio, select &quot;Listings&quot; from the horizontal menu at the top, and open your listing. In the section &quot;Data Product&quot; you find the name of the Secure Share that bundles the shared data objects.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/602_DMF_AddTableToShare_1.png\" alt=\"602_DMF_AddTableToShare_1\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOption 2:\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EUse the SHOW SHARES command:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/504_ShowShares.png\" alt=\"504_ShowShares\"\u003E\u003C/p\u003E\n","\u003Cp\u003ECopy the share name to a text file or worksheet because you will need it again later.\u003C/p\u003E\n","\u003Ch3\u003EDatabase Roles - Consumer Side\u003C/h3\u003E\n","\u003Cp\u003ETo complete the configuration of cross-account role-based access control you need to assign the shared database roles to local account roles in the consumer roles.\u003C/p\u003E\n","\u003Cp\u003ESwitch to your consumer accounts.\u003C/p\u003E\n","\u003Cp\u003EIn each of your consumer accounts you should already have the following 4 roles that you created during the account setup. Verify that these roles are in place. Else, create them now.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESHOW ROLES LIKE 'SALES%';\n\nCREATE OR REPLACE ROLE sales_emea_role     COMMENT = 'EMEA Sales role';\nCREATE OR REPLACE ROLE sales_americas_role COMMENT = 'Americas Sales role ';\nCREATE OR REPLACE ROLE sales_apj_role      COMMENT = 'APJ Sales role ';\nCREATE OR REPLACE ROLE sales_manager_role  COMMENT = 'Manager (all-access) role';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EIn a real-world scenario you would now assign each of these roles to different users. For simplicity in this lab, grant all of these roles to yourself:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESET my_user_var  = CURRENT_USER();\nGRANT ROLE sales_emea_role     TO USER identifier($my_user_var);\nGRANT ROLE sales_americas_role TO USER identifier($my_user_var);\nGRANT ROLE sales_apj_role      TO USER identifier($my_user_var);\nGRANT ROLE sales_manager_role  TO USER identifier($my_user_var);\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EAnd finally, grant the shared database roles to the local account roles. This connects these local consumers roles to the row-access policy that you create on the provider side.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Euse database TASTY_BYTES_ANALYTICS;\ngrant database role tastybytes_emea_role     to role sales_emea_role; \ngrant database role tastybytes_americas_role to role sales_americas_role;\ngrant database role tastybytes_apj_role      to role sales_apj_role; \ngrant database role tastybytes_manager_role  to role sales_manager_role;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThe following picture illustrates the use of our database roles in this data sharing scenario.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/505_Database_Roles_Sharing.png\" alt=\"505_Database_Roles_Sharing\"\u003E\u003C/p\u003E\n","\u003Cp\u003ENow switch to the different local roles (sales_emea_role, sales_apj_role, etc) in each of your consumer accounts to verify that each local role can only see those rows in the CUSTOMER_LOYALTY_METRICS_V view that are permitted by the row-level access policy in the provider account.\u003C/p\u003E\n","\u003Ch3\u003EAggregation and Projection Policies\u003C/h3\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/550_DataSteward_4.png\" alt=\"550_DataSteward_4\"\u003E\u003C/p\u003E\n","\u003Cp\u003EFrosty the data steward has a new requirement for us. In the consumer accounts, only admins and managers may see the detailed per-customer loyalty data. Anyone else may see aggregated data only.\u003C/p\u003E\n","\u003Cp\u003ECreate the following \u003Ca href=\"https://docs.snowflake.com/en/user-guide/aggregation-policies\"\u003Eaggregation policy\u003C/a\u003E to implement this requirement:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFill in AWS Provider Account Name below\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ECREATE OR REPLACE AGGREGATION POLICY tasty_aggregation_policy\n  AS () RETURNS AGGREGATION_CONSTRAINT -&gt;\n  CASE\n      WHEN current_account_name() IN ('*** FILL IN AWS Provider Account Name ***') \n       AND current_role() = 'ACCOUNTADMIN'\n      THEN NO_AGGREGATION_CONSTRAINT()\n\n      WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_MANAGER_ROLE')\n      THEN NO_AGGREGATION_CONSTRAINT()\n\n      ELSE AGGREGATION_CONSTRAINT(MIN_GROUP_SIZE =&gt; 50) -- at least 50 rows in aggregate\n    END;\n\nALTER VIEW analytics.CUSTOMER_LOYALTY_METRICS_V\n  SET AGGREGATION POLICY tasty_aggregation_policy;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow switch to your consumer account \u003Cstrong\u003Ehorizon_lab_aws_consumer\u003C/strong\u003E to verify the effect of the aggregation policy:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Euse role sales_apj_role;\n-- sales_apj_role gets blocked from accessing any individual records:\nSELECT * FROM analytics.CUSTOMER_LOYALTY_METRICS_V;\n\n-- sales_apj_role can execute aggregation queries:\nSELECT city, count(*) as num_cust_per_city\nFROM analytics.CUSTOMER_LOYALTY_METRICS_V\nGROUP BY city;\n\n-- sales_manager_role is permitted to access  individual records:\nuse role sales_manager_role;\nSELECT * FROM analytics.CUSTOMER_LOYALTY_METRICS_V LIMIT 100;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ESwitch back to your AWS Provider account and issue the following command to deactivate the aggregation policy.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER TABLE analytics.CUSTOMER_LOYALTY_METRICS_V UNSET AGGREGATION POLICY;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENext, let's also create a \u003Ca href=\"https://docs.snowflake.com/en/user-guide/projection-policies\"\u003Eprojection policy\u003C/a\u003E that prevents the \u003Cstrong\u003Ecity\u003C/strong\u003E column from appearing in a result set but allows its usage in predicates to the restrict a query result:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFill in AWS Provider Account Name below\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ECREATE OR REPLACE PROJECTION POLICY tasty_projection_policy\n  AS () RETURNS PROJECTION_CONSTRAINT -&gt;\n  CASE\n      WHEN current_account_name() IN ('*** FILL IN AWS Provider Account Name ***') \n       AND current_role() = 'ACCOUNTADMIN'\n      THEN PROJECTION_CONSTRAINT(ALLOW =&gt; true)\n\n      WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_MANAGER_ROLE')\n      THEN PROJECTION_CONSTRAINT(ALLOW =&gt; true)\n\n      ELSE PROJECTION_CONSTRAINT(ALLOW =&gt; false)\n    END;\n\nALTER VIEW analytics.CUSTOMER_LOYALTY_METRICS_V\n  MODIFY COLUMN city \n  SET PROJECTION POLICY tasty_projection_policy;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ESwitch to your consumer account \u003Cstrong\u003Ehorizon_lab_aws_consumer\u003C/strong\u003E again to explore the effect of the projection policy on the results or the following queries:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Euse role sales_apj_role;\n\nSELECT *              FROM analytics.CUSTOMER_LOYALTY_METRICS_V;\n\nSELECT * EXCLUDE city FROM analytics.CUSTOMER_LOYALTY_METRICS_V;\n\nSELECT * EXCLUDE city \nFROM analytics.CUSTOMER_LOYALTY_METRICS_V\nWHERE city IN ('Delhi','Tokyo','Seoul','Melbourne','Sydney','Mumbai');\n\nSELECT city, count(*) as num_cust_per_city\nFROM analytics.CUSTOMER_LOYALTY_METRICS_V\nGROUP BY city;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENote that a projection policy by itself does not prevent users from detecting information about individuals. For example, the following query is permitted (and returns customer details if you remove the masking policy \u003Cstrong\u003Epii_string_mask\u003C/strong\u003E):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT * EXCLUDE city\nFROM analytics.CUSTOMER_LOYALTY_METRICS_V\nWHERE city = 'Melbourne' AND last_name = 'Arellano';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch2\u003EPublish Listing with Data Quality Metrics\u003C/h2\u003E\n","\u003Cp\u003EIn this section the data provider will capture \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-quality-intro\"\u003Edata quality metrics\u003C/a\u003E and share them with the data consumers. In particular, we want to monitor the data quality in the view ANALYTICS.ORDERS_BY_POSTAL_CODE_V.\u003C/p\u003E\n","\u003Ch3\u003EAssign Built-in and Custom Data Quality Metrics to Shared Data\u003C/h3\u003E\n","\u003Cp\u003EOn AWS Provider account, execute the following commands to create a database where we will define any custom quality functions.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003Euse role accountadmin;\ncreate or replace database tasty_bytes_quality;\nuse database tasty_bytes_quality;\ncreate schema dq_functions;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENext, let's define how often the quality of ORDERS_BY_POSTAL_CODE_V should be checked. For a table, the quality checks can be triggered by data changes or executed on a schedule. For views, the quality metrics can (currently) be evaluated on a schedule.\u003C/p\u003E\n","\u003Cp\u003ELet's set the schedule to the shortest possible interval, which is 5 minutes:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  SET DATA_METRIC_SCHEDULE = '5 MINUTE';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow, let's use two of \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-quality-system-dmfs\"\u003ESnowflake's built-in data quality functions\u003C/a\u003E to count the number of NULL valuse in the column POSTAL_CODE as well as the number of distinct cities reported in this view:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  ADD DATA METRIC FUNCTION SNOWFLAKE.CORE.NULL_COUNT ON (POSTAL_CODE);\n\nALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  ADD DATA METRIC FUNCTION SNOWFLAKE.CORE.UNIQUE_COUNT ON (CITY);\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EAdditionally, let's create a \u003Ca href=\"https://docs.snowflake.com/user-guide/data-quality-working#create-your-own-dmf\"\u003Ecustom data quality function\u003C/a\u003E that counts the number of outliers, i.e. postal areas with an exceptionally high or low number of orders:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ECREATE OR REPLACE DATA METRIC FUNCTION tasty_bytes_quality.dq_functions.postal_code_order_outliers (t TABLE  (count_order INTEGER) )\nRETURNS INTEGER\nAS\n$$\n  select count(*) \n  from t\n  where count_order &gt; 300000\n     or count_order &lt; 30\n$$;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThe owner of the object that is being monitored needs to have the privilege to execute the custom data metric function and use the database and schema where that function resides. Additional privileges are required to execute the built-in metric functions or view their results. To keep it simple, let's grant the following privileges to all users:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EGRANT ALL ON FUNCTION tasty_bytes_quality.dq_functions.postal_code_order_outliers(TABLE(INTEGER)) to role public;\nGRANT USAGE ON DATABASE tasty_bytes_quality              to role public;\nGRANT USAGE ON SCHEMA   tasty_bytes_quality.dq_functions to role public;\n\nGRANT EXECUTE DATA METRIC FUNCTION ON ACCOUNT            to role public;\nGRANT DATABASE ROLE SNOWFLAKE.DATA_METRIC_USER           to role public;\nGRANT DATABASE ROLE SNOWFLAKE.USAGE_VIEWER               to role public;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow we can apply our customer quality function to the view ORDERS_BY_POSTAL_CODE_V:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  ADD DATA METRIC FUNCTION tasty_bytes_quality.dq_functions.postal_code_order_outliers \n  ON (count_order);\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EUse the following command to verify that all three quality metrics have been scheduled correctly. Any permission problems would be reflected in the column &quot;schedule_status&quot;. Possible status values are \u003Ca href=\"https://docs.snowflake.com/sql-reference/functions/data_metric_function_references#returns\"\u003Edocumented here\u003C/a\u003E.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E  SELECT schedule_status, *\n  FROM TABLE(\n    INFORMATION_SCHEMA.DATA_METRIC_FUNCTION_REFERENCES(\n      REF_ENTITY_NAME =&gt; 'FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V',\n      REF_ENTITY_DOMAIN =&gt; 'VIEW'  )\n  );\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/600_DMF_Status.png\" alt=\"600_DMF_Status\"\u003E\u003C/p\u003E\n","\u003Cp\u003EAfter 5 minutes you can start observing quality metrics in the \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-quality-working#view-the-dmf-results\"\u003Edefault event table\u003C/a\u003E where all quality results are recorded:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EUnfortunately, accessing \u003Ccode\u003Esnowflake.local.data_quality_monitoring_results\u003C/code\u003E is not yet available in Snowflake trial accounts!\u003C/strong\u003E Please skip ahead to the next section \u003Cem\u003ESharing Data Quality Metrics\u003C/em\u003E if you are using a trial account.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT scheduled_time, measurement_time, metric_name, metric_schema,\n       value, table_name, table_schema, table_database \nFROM snowflake.local.data_quality_monitoring_results  /* not yet available in trial accounts! */\nORDER BY measurement_time DESC;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/601_DMF_Results.png\" alt=\"601_DMF_Results\"\u003E\u003C/p\u003E\n","\u003Cp\u003EAdditionally, you could define \u003Ca href=\"https://docs.snowflake.com/en/user-guide/alerts\"\u003EAlerts\u003C/a\u003E to watch the data quality metrics and take action automatically if acceptable thresholds are exceeded. For example, if the number of outliers reported by our custom quality function exceeds a certain value an alert could copy the offending rows into an exception table for review and send an \u003Ca href=\"https://docs.snowflake.com/en/user-guide/email-stored-procedures\"\u003Eemail notification\u003C/a\u003E.\u003C/p\u003E\n","\u003Ch3\u003ESharing Data Quality Metrics\u003C/h3\u003E\n","\u003Cp\u003EHow to share quality metrics from the event table with data consumers? At the time of authoring this lab (May 2024) event tables cannot be shared in a Listing directly. Similarly, views, streams, and dynamic tables are not yet an option for sharing data quality events.\u003C/p\u003E\n","\u003Cp\u003EAnd since Snowflake trial accounts cannot access the event table (yet!), let's setup a task that regularly inserts data quality metrics into a table for sharing:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE DATABASE FROSTBYTE_TASTY_BYTES;\nCREATE SCHEMA FROSTBYTE_TASTY_BYTES.dq;\n\n-- this table will hold and share 7 days worth of quality metrics:\nCREATE OR REPLACE TABLE FROSTBYTE_TASTY_BYTES.dq.shared_quality_events \n  (measurement_time TIMESTAMP, \n   table_name       VARCHAR, \n   table_schema     VARCHAR, \n   table_database   VARCHAR, \n   metric_name      VARCHAR, \n   metric_schema    VARCHAR,\n   value            INTEGER  );  \n \n\n-- this task will maintain the table above:\nCREATE OR REPLACE TASK FROSTBYTE_TASTY_BYTES.dq.subset_quality_events\n   SCHEDULE = '3 MINUTE'\n   AS BEGIN\n        DELETE FROM dq.shared_quality_events\n        WHERE measurement_time &lt; current_date - 7;   \n\n        INSERT INTO dq.shared_quality_events\n           SELECT current_timestamp, 'ORDERS_BY_POSTAL_CODE_V',\n                  'ANALYTICS', 'FROSTBYTE_TASTY_BYTES',\n                  'NULL_COUNT', 'SNOWFLAKE.CORE',\n                   SNOWFLAKE.CORE.NULL_COUNT(\n                       SELECT POSTAL_CODE\n                       FROM ANALYTICS.ORDERS_BY_POSTAL_CODE_V);\n                       \n        INSERT INTO FROSTBYTE_TASTY_BYTES.dq.shared_quality_events\n           SELECT current_timestamp, 'ORDERS_BY_POSTAL_CODE_V',\n                  'ANALYTICS', 'FROSTBYTE_TASTY_BYTES',\n                  'UNIQUE_COUNT', 'SNOWFLAKE.CORE',\n                   SNOWFLAKE.CORE.UNIQUE_COUNT(\n                       SELECT city\n                       FROM ANALYTICS.ORDERS_BY_POSTAL_CODE_V);               \n                       \n        INSERT INTO FROSTBYTE_TASTY_BYTES.dq.shared_quality_events\n           SELECT current_timestamp, 'ORDERS_BY_POSTAL_CODE_V',\n                  'ANALYTICS', 'FROSTBYTE_TASTY_BYTES',\n                  'postal_code_order_outliers', 'dq_functions',\n                   tasty_bytes_quality.dq_functions.postal_code_order_outliers(\n                       SELECT count_order\n                       FROM ANALYTICS.ORDERS_BY_POSTAL_CODE_V);                     \n   END;\n\nALTER TASK subset_quality_events RESUME;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow you can add the table &quot;shared_quality_events&quot; to the shared data product. Here are 2 options how you can so this.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOption 1: Programmatically\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EGrant the share the necessary access to the &quot;shared_quality_events&quot; table. You should already have the share name from the early section on Database Roles. Else, get the share name as in the first step of option 2 below.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EGRANT USAGE ON SCHEMA FROSTBYTE_TASTY_BYTES.dq TO SHARE &lt;share_name&gt;;\n \nGRANT SELECT ON FROSTBYTE_TASTY_BYTES.dq.shared_quality_events TO SHARE &lt;share_name&gt;;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOption 2: In the UI\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003ETake the following 3 steps in the UI:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EIn the provider account, navigate to the Provider Studio, select &quot;Listings&quot; from the horizontal menu at the top, and open your listing. In the section &quot;Data Product&quot; click on the name of the Secure Share that bundles the shared data objects.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/602_DMF_AddTableToShare_1.png\" alt=\"602_DMF_AddTableToShare_1\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EYou are now looking at a page detailing the underlying share. In the section &quot;Data&quot;, click the &quot;Edit&quot; button:\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/603_DMF_AddTableToShare_2.png\" alt=\"603_DMF_AddTableToShare_2\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow you can open the data explorer to find and select the table &quot;dq.shared_quality_events&quot;. Click &quot;Done&quot; and &quot;Save&quot; to finalize the update of your data product.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/604_DMF_AddTableToShare_3.png\" alt=\"604_DMF_AddTableToShare_3\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESwitch to your consumer account &quot;horizon_lab_aws_consumer&quot; to verify that the data quality metrics are immediately visible as a new table in the data product. In the second consumer account &quot;horizon_lab_azure_consumer&quot; you will see the same after the 1 minute replication interval.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EGo back to your provider account and suspend the task, to save credits in your trial account.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E  ALTER TASK subset_quality_events SUSPEND;\n  \n  ALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  UNSET DATA_METRIC_SCHEDULE;\n\u003C/code\u003E\u003C/pre\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EPublish a Native Application Listing\u003C/h2\u003E\n","\u003Cp\u003EThe \u003Ca href=\"https://docs.snowflake.com/en/developer-guide/snowflake-cli-v2/native-apps/overview\"\u003ESnowflake Native Application Framework\u003C/a\u003E provides developers the ability to create data intensive applications that run \u003Cem\u003Ewithin\u003C/em\u003E the Snowflake platform with versioning controls.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ENative Apps allow sharing of data and related business logic with other Snowflake accounts.\u003C/li\u003E\u003Cli\u003ENative Apps are shared with Consumer accounts using a Listing.\n\u003Cul\u003E\u003Cli\u003EA listing can be free or paid, published on Marketplace or to specific accounts\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003ERich visualizations can be include in the application with Streamlit.\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003ENative App Workflow\u003C/h3\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/native-app-framework.jpg\" alt=\"High Level View of Snowflake Native App Framework\"\u003E\u003C/p\u003E\n","\u003Cp\u003EYou will build a native app that visualizes Tasty Bytes food truck Sales over Time by City.\u003C/p\u003E\n","\u003Cp\u003EThe app will allow filtering on Year and City, while displaying the underlying raw data and associated SQL query.\nConsumer account admins responsible for installing the application will supply a country lookup table that restricts what is shown by Country using a row-access policy.\u003C/p\u003E\n","\u003Ch3\u003EOverview of Project Structure\u003C/h3\u003E\n","\u003Cp\u003EHere is the directory structure of the code repository that was cloned or downloaded from GitHub earlier, relevant to \u003Ccode\u003Eapp\u003C/code\u003E artifacts for the native app:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-plaintext\"\u003E|-- app\n|   |-- src\n|       |-- libraries\n|       |   |-- environment.yml\n|       |   |-- frosty_bytes_sis.py\n|       |   |-- procs.py\n|       |   |-- udf.py\n|       |-- manifest.yml\n|       |-- setup_script.sql\n|       |-- readme.md\n|-- scripts\n|   |-- setup_package_script.sql\n|-- snowflake.yml\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Ccode\u003Esrc\u003C/code\u003E - stores all source code including stored procedures, user-defined functions (UDFs), streamlit application and installation script \u003Ccode\u003Esetup_script.sql\u003C/code\u003E.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Ccode\u003Esetup_script.sql\u003C/code\u003E - defines all Snowflake objects used within the application. Runs every time a user installs the application, such as when a Consumer account installs the listing.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EHere is a snippet from \u003Ccode\u003Esetup_script.sql\u003C/code\u003E that shows how a row-access policy limits country sales based on consumer region and role.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Create Row-Access Policy to limit access by Consumer region using a local mapping table\nCREATE OR REPLACE TABLE app_instance_schema.region_country_map(region STRING, country STRING);\n\nINSERT INTO app_instance_schema.region_country_map\n    VALUES  ('PUBLIC.AZURE_WESTEUROPE','Germany'),\n            ('PUBLIC.AZURE_WESTEUROPE','Spain'),\n            (......);\n\nCREATE OR REPLACE ROW ACCESS POLICY app_instance_schema.country_row_policy\n    AS (country STRING) RETURNS BOOLEAN -&gt; \n    country = 'Canada' \n    OR current_role() IN ('ACCOUNTADMIN','SYSADMIN','SALES_MANAGER_ROLE')\n    OR EXISTS \n    (\n        SELECT 1\n        FROM app_instance_schema.region_country_map map\n        WHERE 1=1\n        AND map.region = current_region()\n        AND map.country = country\n    )\nCOMMENT = 'Policy to limit rows returned based on region';\n\nALTER VIEW app_instance_schema.orders_v\n  ADD ROW ACCESS POLICY app_instance_schema.country_row_policy ON (country);\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Ccode\u003Emanifest.yml\u003C/code\u003E - defines version metadata, location of artifacts (setup script, streamlit), configuration of logging/tracing.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Ccode\u003Esetup_package_script.sql\u003C/code\u003E - shares provider data that is needed by the application, executed when the application package is deployed or upgraded.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Ccode\u003Esnowflake.yml\u003C/code\u003E - Snowflake CLI configuration file that contains native app name, location of source code directory, location of package setup script \u003Ccode\u003Esetup_package_script.sql\u003C/code\u003E\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Ccode\u003Efrosty_bytes_sis.py\u003C/code\u003E - Streamlit visualization python script that accesses the shared data within the application package.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003ERefer to the \u003Ca href=\"/en/developers/guides/getting-started-with-native-apps/\"\u003EGetting Started with Native Apps\u003C/a\u003E Quickstart for more details.\u003C/p\u003E\n","\u003Ch3\u003ECreate Application Package using Snowflake CLI\u003C/h3\u003E\n","\u003Cp\u003ENow let's create the Snowflake Application Package from the project files in our repo!\u003C/p\u003E\n","\u003Cp\u003EOpen a new terminal at the root of the repository cloned/downloaded from Github and execute the following commands:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003E# verify that 3 account connections exist, with AWS Provider Account as DEFAULT\nsnow connection list\n+-------------------------------------------------------------------------------------------------------------------------------+\n| connection_name        | parameters                                                                              | is_default |\n|------------------------+-----------------------------------------------------------------------------------------+------------|\n| horizon-aws-provider   | {'account': '***orgname-accountname***', 'user': 'horizonadmin', 'password':            | True       |\n|                        | '****', 'warehouse': 'compute_wh', 'role': 'accountadmin'}                              |            |\n| horizon-aws-consumer   | {'account': '**orgname**-horizon_lab_aws_consumer', 'user': 'horizonadmin',             | False      |\n|                        | 'password': '****', 'warehouse': 'compute_wh', 'role': 'accountadmin'}                  |            |\n| horizon-azure-consumer | {'account': '***orgname***-horizon_lab_azure_consumer', 'user': 'horizonadmin',         | False      |\n|                        | 'password': '****', 'warehouse': 'compute_wh', 'role': 'accountadmin'}                  |            |\n+-------------------------------------------------------------------------------------------------------------------------------+\n\nsnow app version create --skip-git-check\n\nsnow sql -q 'ALTER APPLICATION PACKAGE horizon_quickstart_package SET DEFAULT RELEASE DIRECTIVE version=V1 patch=0'\n+---------------------------------------------------------+\n| status                                                  |\n|---------------------------------------------------------|\n| Default release directive set to version 'V1', patch 0. |\n+---------------------------------------------------------+\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThe \u003Ccode\u003Eapp version create\u003C/code\u003E command will upload source files to a stage and create the application package.\nSetting the default release version and patch is a required step before the application package can be published in a listing.\nDocumentation for publishing native applications is \u003Ca href=\"https://other-docs.snowflake.com/en/native-apps/provider-publishing-app-package#workflow-for-publishing-an-application-package\"\u003Ehere\u003C/a\u003E\u003C/p\u003E\n","\u003Cp\u003EYou should now see the \u003Cstrong\u003EHORIZON_QUICKSTART_PACKAGE\u003C/strong\u003E listed under the \u003Ccode\u003EDatabases\u003C/code\u003E panel in Snowsight.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/horizon_quickstart_app_pkg.jpg\" alt=\"HORIZON_QUICKSTART_APP\"\u003E\u003C/p\u003E\n","\u003Ch3\u003EPublish App Package as a Listing targeted at our AWS, Azure Consumer Accounts\u003C/h3\u003E\n","\u003Cp\u003EReturn to Snowsight and ensure your role is \u003Ccode\u003EACCOUNTADMIN\u003C/code\u003E (check and set if necessary at the bottom left corner)\u003C/p\u003E\n","\u003Cp\u003ENavigate to \u003Cstrong\u003EProvider Studio\u003C/strong\u003E (under Data Products) and click on \u003Ccode\u003E+ Listing\u003C/code\u003E to author a native app listing.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/create-native-app-listing.jpg\" alt=\"Create Listing\"\u003E\u003C/p\u003E\n","\u003Cp\u003ENow select the \u003Ccode\u003EHORIZON_QUICKSTART_PACKAGE\u003C/code\u003E and fill in a brief description using the rich text editor.\nYou can use this text to get started, but feel free to get creative!\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cem\u003E\u003Ca href=\"/en/developers/guides/tasty-bytes-introduction/\"\u003ETasty Bytes\u003C/a\u003E is a fictitious global food truck network\u003C/em\u003E\n\u003Cem\u003Ethat is on a mission to serve unique food options with high quality items in a safe, convenient and cost effective way.\u003C/em\u003E\n\u003Cem\u003EIn order to drive forward on their mission, Tasty Bytes is beginning to leverage the Snowflake Data Cloud.\u003C/em\u003E\u003C/p\u003E\n","\u003Cp\u003EThis application provides \u003Cstrong\u003ETotal Sales (USD) by Year\u003C/strong\u003E for selected cities in an interactive graphical visualization.\nThe cities available are dependent upon the Consumer account region: only sales for regional cities are shown.\nAlso displayed are the underlying raw sales data and associated SQL query.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EAdd 2 Consumer Accounts: \u003Ccode\u003E&lt;YOUR-ORGNAME&gt;.HORIZON_LAB_AWS_CONSUMER\u003C/code\u003E and \u003Ccode\u003E&lt;YOUR-ORGNAME&gt;.HORIZON_LAB_AZURE_CONSUMER\u003C/code\u003E\u003C/p\u003E\n","\u003Cp\u003EThe addition of a consumer account in a different cloud (or region) will reveal the auto-fulfillment panel.\nProvide your email to receive notifications and \u003Cstrong\u003EPublish\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/create-native-app-listing-detail.jpg\" alt=\"Publish Listing\"\u003E\u003C/p\u003E\n","\u003Cp\u003EInitially the auto-fulfillment frequency is set to 1 Day, you can change it to 15 minutes after the listing is published.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/manage-regions-replication.jpg\" alt=\"Update Refresh Frequency\"\u003E\u003C/p\u003E\n","\u003Ch3\u003EInstall the Tasty Bytes Sales App on Azure Consumer (HORIZON_LAB_AZURE_CONSUMER)\u003C/h3\u003E\n","\u003Cp\u003EWe are now at the moment of truth! \u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/snowflake-icon.jpg\" alt=\"snowflake\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESwitch to the HORIZON_LAB_AZURE_CONSUMER account\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EWith listing auto-fulfillment, replication will only be initiated from Provider AWS region to Consumer Azure region when there is a request.\nNavigate to Snowsight \u003Ccode\u003EData Products -&gt; Private Sharing\u003C/code\u003E to acquire the Tasty Bytes Global Sales application:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/azure-consumer-listing.jpg\" alt=\"Azure Consumer Listing\"\u003E\u003C/p\u003E\n","\u003Cp\u003EWhile the application objects are being delivered cross-cloud, we can now switch to the local AWS region consumer and install immediately.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESwitch to the HORIZON_LAB_AWS_CONSUMER account\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/aws-install-app.jpg\" alt=\"Application Install on AWS\"\u003E\u003C/p\u003E\n","\u003Cp\u003EOpen the application and while it is spinning up, click on the \u003Ccode\u003EManage Access\u003C/code\u003E button at top-right and give \u003Cstrong\u003EPUBLIC\u003C/strong\u003E access.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/native-app-access.jpg\" alt=\"Manage Access\"\u003E\u003C/p\u003E\n","\u003Cp\u003ENow try adding a few cities in addition to \u003Cem\u003EVancouver\u003C/em\u003E:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/global-sales-aws-uswest.jpg\" alt=\"Global Sales AWS-USWEST\"\u003E\u003C/p\u003E\n","\u003Cp\u003ETasty Bytes is sold in 15 countries and 30 cities worldwide.\nConsider these questions and see if you can come up with convincing answers:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EWhat is the query that generates the city list in the Streamlit graph? [Hint: see \u003Ccode\u003Efrosty_bytes_sis.py\u003C/code\u003E]\u003C/li\u003E\u003Cli\u003EHow many cities can be selected? If not all, why not? [Hint: see \u003Ccode\u003Esetup_script.sql\u003C/code\u003E]\u003C/li\u003E\u003Cli\u003ETry different roles [\u003Ccode\u003EACCOUNTADMIN\u003C/code\u003E,\u003Ccode\u003ESALES_MANAGER_ROLE\u003C/code\u003E,\u003Ccode\u003EPUBLIC\u003C/code\u003E] - does the city list change?\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003ENow it is time to return to \u003Cstrong\u003EHORIZON_LAB_AZURE_CONSUMER\u003C/strong\u003E and check if auto-fulfillment has completed...\u003C/p\u003E\n","\u003Cp\u003EOpen the application and again while it is spinning up, click on the \u003Ccode\u003EManage Access\u003C/code\u003E button to give \u003Cstrong\u003EPUBLIC\u003C/strong\u003E access.\u003C/p\u003E\n","\u003Cp\u003ETry adding a few cities in addition to \u003Cem\u003EVancouver\u003C/em\u003E as we did with the AWS US West consumer account\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/global-sales-azure-westeurope.jpg\" alt=\"Global Sales Azure-WestEurope\"\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EWhy is the country list different in the Azure West-Europe region (except Vancouver!)?\u003C/li\u003E\u003Cli\u003EAgain, does it make any difference with different roles?\u003C/li\u003E\u003C/ol\u003E\n\u003Cpre\u003E\u003Ccode\u003EStreamlit does not currently allow role-based policies because of security concerns, so only the region mapping in the policy will apply.\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ETo observe how the row-access policy evaluation of \u003Ccode\u003Ecurrent_role()\u003C/code\u003E works in an application instance, outside of Streamlit, step through this SQL snippet in a \u003Ccode\u003EWorksheet\u003C/code\u003E on the \u003Cstrong\u003EHORIZON_LAB_AWS_CONSUMER\u003C/strong\u003E and \u003Cstrong\u003EHORIZON_LAB_AZURE_CONSUMER\u003C/strong\u003E accounts:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE APPLICATION TASTY_BYTES_GLOBAL_SALES;\n\nUSE ROLE ACCOUNTADMIN;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\nUSE ROLE SALES_AMERICAS_ROLE;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\nUSE ROLE SALES_APJ_ROLE;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\nUSE ROLE SALES_EMEA_ROLE;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\nUSE ROLE SALES_MANAGER_ROLE;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\u003C/code\u003E\u003C/pre\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EShare Snowflake-Managed Iceberg Tables\u003C/h2\u003E\n","\u003Cp\u003EIceberg tables in Snowflake combine the performance and query semantics of regular Snowflake tables with external cloud storage managed by the customer. Snowflake supports Iceberg tables that use the Apache Parquet file format.\u003C/p\u003E\n","\u003Cp\u003ECreating and writing data into a Snowflake Iceberg table is beyond the scope of this lab; we will focus only on the Consumer side of Iceberg table sharing.\u003C/p\u003E\n","\u003Cp\u003EUsing the method outlined in \u003Ca href=\"/en/developers/guides/getting-started-iceberg-tables/\"\u003EGetting Started with Iceberg Tables\u003C/a\u003E Quickstart, create Iceberg Tables and policies based on what we created in the previous lab section.\u003C/p\u003E\n","\u003Cp\u003EOn the \u003Ccode\u003EProvider AWS Account\u003C/code\u003E execute the steps listed in \u003Ccode\u003Ecode/sql/reference/iceberg_provider.sql\u003C/code\u003E cloned from \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-horizon-intra-organization-sharing\"\u003EHorizon Quickstart Scripts\u003C/a\u003E repository earlier:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ECreate External Volume in Snowflake, after configuring an external volume with your cloud service provider (AWS, Azure, GCP).\u003C/li\u003E\u003Cli\u003ECreate a \u003Ccode\u003EFROSTBYTE_ICEBERG\u003C/code\u003E database with schemas for ANALYTICS, RAW_POS, RAW_CUSTOMER, GOVERNANCE, TPCH.\u003C/li\u003E\u003Cli\u003ECreate Iceberg Tables \u003Ccode\u003ECUSTOMER_LOYALTY_ICEBERG\u003C/code\u003E, \u003Ccode\u003EORDER_HEADER_ICEBERG\u003C/code\u003E, \u003Ccode\u003ECUSTOMER_TPCH_ICEBERG\u003C/code\u003E, \u003Ccode\u003ENATION_TPCH_ICEBERG\u003C/code\u003E.\u003C/li\u003E\u003Cli\u003ECreate Secure View \u003Ccode\u003ECUSTOMER_LOYALTY_METRICS_V\u003C/code\u003E that joins multiple iceberg tables.\u003C/li\u003E\u003Cli\u003ECreate Database Roles \u003Ccode\u003ETASTYBYTES_MANAGER_ROLE\u003C/code\u003E and \u003Ccode\u003ETASTYBYTES_ANALYST_ROLE\u003C/code\u003E to restrict access for consumers.\u003C/li\u003E\u003Cli\u003ECreate and apply row-access policy \u003Ccode\u003ECUSTOMER_COUNTRY_ROW_POLICY\u003C/code\u003E to \u003Ccode\u003ECUSTOMER_LOYALTY_ICEBERG.COUNTRY\u003C/code\u003E column that filters based on database role using the \u003Ccode\u003Eis_database_role_in_session()\u003C/code\u003E context function.\u003C/li\u003E\u003Cli\u003ECreate a listing called \u003Ccode\u003EICEBERG_LAB_ANALYTICS\u003C/code\u003E, attach iceberg tables and secure view.\u003C/li\u003E\u003Cli\u003EIn the \u003Cstrong\u003EListing Description\u003C/strong\u003E section: enter instructions on post-installation steps (see below)\u003C/li\u003E\u003Cli\u003EIn the \u003Cstrong\u003ESample Queries\u003C/strong\u003E section: enter queries for the consumer to run\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003ENow switch to the \u003Cstrong\u003EHORIZON_LAB_AWS_CONSUMER\u003C/strong\u003E account.\u003C/p\u003E\n","\u003Cp\u003ENavigate to \u003Ccode\u003EPrivate Sharing\u003C/code\u003E in Snowsight and install the \u003Ccode\u003EICEBERG_LAB_ANALYTICS\u003C/code\u003E listing that was shared by the AWS Provider.\nRun these post-installation steps in a worksheet.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE accountadmin;\nSHOW DATABASE ROLES IN DATABASE iceberg_lab_analytics;\nGRANT DATABASE ROLE iceberg_lab_analytics.tastybytes_manager_role to ROLE sales_manager_role;\nGRANT DATABASE ROLE iceberg_lab_analytics.tastybytes_analyst_role to ROLE public;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ECreate two users to test access controls on the incoming Iceberg Analytics listing.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE ACCOUNTADMIN;\n\nCREATE OR REPLACE USER horizonengineer\nPASSWORD='' \nDEFAULT_ROLE = PUBLIC \nMUST_CHANGE_PASSWORD = FALSE \nDEFAULT_WAREHOUSE = COMPUTE_WH;\n\nCREATE OR REPLACE USER horizonmanager\nPASSWORD='' \nDEFAULT_ROLE = SALES_MANAGER_ROLE \nMUST_CHANGE_PASSWORD = FALSE \nDEFAULT_WAREHOUSE = COMPUTE_WH;\n\nGRANT ROLE SALES_MANAGER_ROLE TO USER horizonmanager;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow run these queries that were entered as \u003Cstrong\u003ESample Queries\u003C/strong\u003E in the Iceberg listing.\nCompare results as a \u003Ccode\u003Ehorizonengineer\u003C/code\u003E and \u003Ccode\u003Ehorizonmanager\u003C/code\u003E user that leverages the row-access policy to limit sales analytics.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E// Customer Sales by City\n/*\nTotal food truck sales in USD by city\n*/\nSELECT\n    clm.city,\n    ROUND(SUM(clm.total_sales), 0) AS total_sales_usd\nFROM analytics.customer_loyalty_metrics_v clm\nGROUP BY clm.city\nORDER BY total_sales_usd DESC;\n\n// Total Orders by Gender\n/*\nWhat are the total order amounts in each city by gender?\n*/\nSELECT \n    cl.gender,\n    cl.city,\n    COUNT(oh.order_id) AS count_order,\n    ROUND(SUM(oh.order_amount),0) AS order_total,\n    current_time()\nFROM raw_pos.order_header_iceberg oh\nJOIN raw_customer.customer_loyalty_iceberg cl\n    ON oh.customer_id = cl.customer_id\nGROUP BY ALL\nORDER BY order_total DESC;\n\n// Visible Countries and Cities\n/*\nHow many cities in what countries can I view analytics data for?\n*/\nSELECT DISTINCT COUNTRY, CITY FROM analytics.customer_loyalty_metrics_v ORDER BY COUNTRY;\n;\n\n// TPCH Benchmark - Returned Item Reporting Query (Q10)\n/*\nThe Returned Item Reporting Query finds the top 10 customers, in terms of their effect on lost revenue for a given quarter, who have returned parts. The customers are listed in descending order of lost revenue.\n*/\nSELECT\n     c_custkey,\n     c_name,\n     TRUNCATE(SUM(l_extendedprice * (1 - l_discount))) AS lost_revenue,\n     c_acctbal,\n     n_name,\n     c_address,\n     c_phone,\n     c_comment\nFROM\n     tpch.customer_tpch_iceberg,\n     SNOWFLAKE_SAMPLE_DATA.TPCH_SF100.ORDERS,\n     SNOWFLAKE_SAMPLE_DATA.TPCH_SF100.LINEITEM,\n     tpch.nation_tpch_iceberg\nWHERE\n     c_custkey = o_custkey\n     AND l_orderkey = o_orderkey\n     AND o_orderdate &gt;= to_date('1993-10-01')\n     AND o_orderdate &lt; dateadd(month, 3, to_date('1993-10-01'))\n     AND l_returnflag = 'R'\n     AND c_nationkey = n_nationkey\nGROUP BY\n     c_custkey,\n     c_name,\n     c_acctbal,\n     c_phone,\n     n_name,\n     c_address,\n     c_comment\nORDER BY\n     lost_revenue DESC\nLIMIT 10\n;\n\u003C/code\u003E\u003C/pre\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EShare Unstructured Data\u003C/h2\u003E\n","\u003Cp\u003EWe have previously staged 100 movie reviews extracted from the \u003Ca href=\"https://ai.stanford.edu/~amaas/data/sentiment/\"\u003EIMDB Large Movie Review Dataset\u003C/a\u003E.\u003C/p\u003E\n","\u003Cp\u003EDirectory Tables are built-in Snowflake objects that provide an updated, tabular file catalog for staged data that makes it easy to search and lookup files.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE sysadmin;\nUSE WAREHOUSE tasty_de_wh;\nUSE SCHEMA frostbyte_tasty_bytes.movie_reviews;\n\nALTER STAGE movie_stage refresh;\nSELECT * FROM DIRECTORY(@movie_stage);\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ESnowflake offers access to unstructured data through three types of URLs based on the access policy that is required:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/sql-reference/functions/build_scoped_file_url.html?_fsi=A9hUbkt2&amp;_fsi=A9hUbkt2\"\u003EScoped URL\u003C/a\u003E: encoded URL to give a user temporary access (currently 24 hours) to a file without giving access to the stage.\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/sql-reference/functions/build_stage_file_url.html\"\u003EFile URL\u003C/a\u003E: requires user authentication with Snowflake and read privileges on the stage.\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/sql-reference/functions/get_presigned_url.html\"\u003EPre-signed URL\u003C/a\u003E: pre-authenticated URL that allows download directly from a browser.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EWe will use \u003Cstrong\u003E\u003Cem\u003EScoped URL\u003C/em\u003E\u003C/strong\u003E to share these text files within and across cloud regions. Unlike with data and app sharing, the unstructured data will not be physically replicated cross-cloud.\u003C/p\u003E\n","\u003Cp\u003EOn the \u003Cstrong\u003EAWS Provider Account\u003C/strong\u003E open a SQL Worksheet called \u003Ccode\u003EUnstructured Data\u003C/code\u003E and execute these commands sequentially:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE sysadmin;\nUSE WAREHOUSE tasty_de_wh;\nUSE SCHEMA frostbyte_tasty_bytes.movie_reviews;\n\n-- Here are the 100 review text files: click on any scoped URL to download and view\nSELECT relative_path\n , build_scoped_file_url(@movie_stage, relative_path) as scoped_url\nfrom directory(@movie_stage);\n\n-- Snowpark Python UDF to extract review contents from each file URL\nCREATE FUNCTION extract_review(file_path string)\nRETURNS STRING\nLANGUAGE PYTHON\nRUNTIME_VERSION = '3.8'\nPACKAGES = ('snowflake-snowpark-python')\nHANDLER = 'parse_text_file'\nAS\n$$\n\ndef parse_text_file(file_path):\n    from snowflake.snowpark.files import SnowflakeFile\n    with SnowflakeFile.open(file_path, 'r') as f:\n        lines = [ line.strip() for line in f ]\n        return lines\n$$\n;\n\n-- Share secure view that extracts review contents for the Consumer\nCREATE OR REPLACE SECURE VIEW movie_reviews_v\n    AS\nSELECT relative_path as review_file_name, \n    extract_review(build_scoped_file_url(@movie_stage, relative_path)) as review_content,\n    build_scoped_file_url(@movie_stage, relative_path) as scoped_url\nFROM DIRECTORY(@movie_stage);\n\nSELECT * FROM movie_reviews_v limit 10;\n\n-- Use the SUMMARIZE and SENTIMENT in-built Cortex LLM functions to derive insights from these reviews\nSELECT review_file_name, \nSNOWFLAKE.CORTEX.SUMMARIZE(review_content) as Summary, \nTO_DECIMAL(SNOWFLAKE.CORTEX.SENTIMENT(review_content),3,2) as Sentiment,\nscoped_url\nFROM movie_reviews_v\nORDER BY Sentiment DESC\nLIMIT 10;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENow this secure view can be shared in a private listing targeted at \u003Ccode\u003Ehorizon_lab_aws_consumer\u003C/code\u003E and \u003Ccode\u003Ehorizon_lab_azure_consumer\u003C/code\u003E just as we did in earlier sections with data and apps.\u003C/p\u003E\n","\u003Cp\u003ECreate a new listing called \u003Ccode\u003EIMDB Movie Reviews\u003C/code\u003E in Provider Studio to publish the review files and content:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003Eshare the \u003Ccode\u003EMOVIE_REVIEWS_V\u003C/code\u003E view\u003C/li\u003E\u003Cli\u003Eadd a description that includes a link to the highest grossing film of all time: \u003Ca href=\"https://www.youtube.com/watch?v=5PSNL1qE6VY\"\u003EAvatar\u003C/a\u003E and this link that documents the reference dataset \u003Ca href=\"https://ai.stanford.edu/~amaas/data/sentiment/\"\u003EIMDB Large Movie Review Dataset\u003C/a\u003E\u003C/li\u003E\u003Cli\u003Etarget the two Consumer accounts in AWS and Azure regions\u003C/li\u003E\u003Cli\u003Einclude the query that calls \u003Ccode\u003ESUMMARIZE\u003C/code\u003E and \u003Ccode\u003ESENTIMENT\u003C/code\u003E Cortex LLM functions in the Sample Queries section to make it easy for Consumers\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/error-publishing-python-function.jpg\" alt=\"Listing publish failure\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPublishing Fails\u003C/strong\u003E - do you understand why?\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003EHint: \u003Ccode\u003EMOVIE_REVIEWS_V\u003C/code\u003E uses a Python UDF for review content extraction, \u003Cem\u003Ewhich can only be shared in a Native App!\u003C/em\u003E\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EReturn to the \u003Ccode\u003EHORIZON_QUICKSTART_PACKAGE\u003C/code\u003E we created in the previous section and publish an update after adding \u003Ccode\u003EMOVIE_REVIEWS_V\u003C/code\u003E. Here are the steps:\u003C/p\u003E\n\u003Cblockquote\u003E\n\u003Col\u003E\u003Cli\u003EModify \u003Ccode\u003Escripts/setup_package_script.sql\u003C/code\u003E:\nshare the \u003Ccode\u003Emovie_reviews_v\u003C/code\u003E view similar to how \u003Ccode\u003Eorders_v\u003C/code\u003E view was handled\u003C/li\u003E\u003Cli\u003EModify \u003Ccode\u003Eapp/src/setup_script.sql\u003C/code\u003E:\ncreate a proxy view \u003Ccode\u003Emovie_reviews_v\u003C/code\u003E similar to \u003Ccode\u003Eorders_v\u003C/code\u003E in \u003Ccode\u003Eapp_instance_schema\u003C/code\u003E\ngrant select on \u003Ccode\u003Emovie_reviews_v\u003C/code\u003E to the application role \u003Ccode\u003Eapp_instance_role\u003C/code\u003E to make it visible\u003C/li\u003E\u003Cli\u003ECreate a new app version V2 by issuing:\n\u003Ccode\u003Esnow app version create V2 --skip-git-check\u003C/code\u003E\u003C/li\u003E\u003Cli\u003ESet the DEFAULT RELEASE DIRECTIVE to version V2 patch 0\n\u003Ccode\u003Esnow sql -q 'ALTER APPLICATION PACKAGE horizon_quickstart_package SET DEFAULT RELEASE DIRECTIVE version=V2 patch=0'\u003C/code\u003E\u003C/li\u003E\u003C/ol\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EAnd that is all it takes to upgrade a native app!\n\u003Cem\u003E(here is the \u003Ca href=\"https://docs.snowflake.com/en/developer-guide/native-apps/versioning#workflow-for-upgrading-an-native-app\"\u003EApp Upgrade Workflow doc\u003C/a\u003E)\u003C/em\u003E\u003C/p\u003E\n","\u003Cp\u003EOn the \u003Cstrong\u003EAWS Consumer Account\u003C/strong\u003E run this in a SQL Worksheet:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE ACCOUNTADMIN;\n\n-- install the app upgrade\nALTER APPLICATION TASTY_BYTES_GLOBAL_SALES UPGRADE;\n\nUSE APPLICATION TASTY_BYTES_GLOBAL_SALES;\n\nSELECT * FROM app_instance_schema.movie_reviews_v limit 10;\n\nSELECT review_file_name, \nSNOWFLAKE.CORTEX.SUMMARIZE(review_content) as Summary, \nTO_DECIMAL(SNOWFLAKE.CORTEX.SENTIMENT(review_content),3,2) as Sentiment,\nscoped_url\nFROM app_instance_schema.movie_reviews_v\nORDER BY Sentiment DESC\nLIMIT 10; \n\n-- Use this query to monitor usage of AI Services\n-- Note: this will only populate on a daily basis\nSELECT *\n  FROM snowflake.account_usage.metering_daily_history\n  WHERE SERVICE_TYPE='AI_SERVICES';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ETry the same steps on the \u003Cstrong\u003EAzure Consumer Account\u003C/strong\u003E:\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003EHow do you expect the refresh frequency for cross-cloud fulfillment to impact the application upgrade?\n(documentation on cross-region application upgrades \u003Ca href=\"https://docs.snowflake.com/en/developer-guide/native-apps/versioning#upgrade-an-installed-app-across-multiple-regions\"\u003Ehere\u003C/a\u003E)\u003C/p\u003E\n\u003C/blockquote\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EConclusion &amp; Resources\u003C/h2\u003E\n","\u003Cp\u003ECongratulations, you made it through our Horizon Collaboration journey! You have exercised a broad range of data sharing and governance capabilities. You have worked with different types of data products including structured data, unstructured data, and native applications. And you have deployed different types of governance policies to implement data access and data privacy restrictions.\u003C/p\u003E\n","\u003Ch3\u003EWhat you Learned\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to blend local Point-of-Sale data with Marketplace Weather data to build analytics data products.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to publish data products as Listings targeted at accounts in your company\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to configure data access and privacy polices as a data provider to restrict data access by data consumers.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to use tag-based column masking, row-access, aggregation and projection policies with database roles in a collaboration scenario.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to manage Listings via the Listings API.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to setup data quality monitoring of shared data products\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to share Iceberg Tables within a cloud region\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to share a native application with Streamlit visualization\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EHow to share unstructured text files and process with Cortex LLM functions\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003ERelated Resources\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-horizon-intra-organization-sharing\"\u003ELab Source Code on Github\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://other-docs.snowflake.com/en/collaboration/collaboration-listings-about\"\u003ESnowflake Listings\u003C/a\u003E and \u003Ca href=\"https://docs.snowflake.com/en/sql-reference/commands-listings\"\u003EManaging Listings via API\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://other-docs.snowflake.com/en/collaboration/provider-listings-auto-fulfillment\"\u003ECross-cloud Auto-Fulfillment\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://docs.snowflake.com/en/guides-overview-govern\"\u003EData Governance Policies\u003C/a\u003E and  \u003Ca href=\"https://docs.snowflake.com/en/guides-overview-privacy\"\u003EData Privacy Policies\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-quality-intro\"\u003EData Quality Metrics\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-sharing-policy-protected-data\"\u003ESharing  Data Protected by a Policy\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg\"\u003EIceberg Tables in Snowflake\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://docs.snowflake.com/en/developer-guide/native-apps/publish-guidelines#best-practices-when-publishing-a-native-app\"\u003EBest Practices publishing a Snowflake Native App\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/unstructured-data-sharing\"\u003ESharing Unstructured Data\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E"],"description":"explore Horizon Collaboration pillar features for sharing of data and apps","title":"Explore Cross-Cloud Sharing of Data and Applications with Private Listings","isDeveloperGuidesPage":false,":type":"snowflake-site/components/contentfragment",":items":{},":itemsOrder":[],"elements":{"quickstartArticleBody":{"dataType":"string","title":"Quickstart Article Body","value":"\u003C!-- ------------------------ --\u003E\n## Overview\n\n\nSharing information between departments, business units and subsidiaries of a company is critical for success, particularly when there are organizational silos in place. A modern data platform must provide decentralized ownership, universal discovery, access control, federated governance, and observability.\n\n**Snowflake Horizon Catalog** is a connected catalog for your entire data estate. It allows customers to interoperate more easily across table formats, engines & catalogs. Horizon allows you to manage metadata for all your data & AI assets in one place for easy data discovery and collaboration. \n\n![Snowflake Horizon Diagram](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/horizon-catalog.jpg)\n\nThis Quickstart is focused on the `Horizon Collaboration` and `Horizon Discovery` pillars.\n\nThe objective of the Collaboration and Discovery pillars are to make it simple to share, discover, understand/build trust and access listings across any boundary, internal or external to the organization, and to make loose objects discoverable across account boundaries within an organization, supported by the tools necessary to ensure policy compliance, security, and data quality.\n\nIn this lab you will experience the latest Snowflake Horizon Collaboration and Discovery features for sharing data and native apps intra-company: private listings, unified search & discovery, data quality monitoring, role-based governance policies and programmatic management of data products. We will cover structured and unstructured data that is stored on-platform or on external storage.\n\n\n### What You’ll Learn\n\n- How to blend TastyBytes Point-of-Sale and Marketplace Weather data to build analytics data products, then publish Listings targeted at accounts in your company\n- How to configure data privacy polices that are preserved in the consumer accounts that install the listings. Tag-based column masking, row-access, aggregation and projection policies will be created with database roles.\n- How to setup Data Metrics Functions to monitor data quality of the shared data products\n- How to share Iceberg Tables within a cloud region\n- How to share a native application with Streamlit visualization\n- How to share unstructured text files cross-cloud and process with Cortex LLM functions\n\u003C!--\n- How to use Universal Search and Snowflake Copilot to explore data from all sources\n--\u003E\n\n### What You’ll Need\n\n- Basic knowledge of SQL, Database Concepts, Snowflake [Listings](https://other-docs.snowflake.com/en/collaboration/collaboration-listings-about)\n- Familiarity with [Snowsight Worksheets](https://docs.snowflake.com/en/user-guide/ui-snowsight-worksheets-gs)\n\n### What You’ll Build\n\n- Analytics data products for TastyBytes, that models a global food truck network with localized menu options in 15 countries, 30 major cities and 15 core brands\n- Listings comprised of metadata, data and application code, targeted at accounts in the same organization but in different cloud regions\n- Governance policies based on shared role-based-access-controls that are enforced at the target account consuming the listing\n- Install listings containing Iceberg Tables, then blend with local datasets to derive insights\n\u003C!--\n- Exploration of all shared and local data with Universal Search and Copilot\n--\u003E\n\n### Prerequisites\n\n#### Create 3 Snowflake Trial Accounts in the same Snowflake Organization\n\nSignup for an AWS trial account [here](https://signup.snowflake.com/?utm_source=snowflake-devrel&utm_medium=developer-guides&utm_cta=developer-guides)\n\n- Choose **AWS** as cloud provider, **Business Critical** edition, **AWS_US_WEST_2 (Oregon)** region\n- Activate trial account with admin user `horizonadmin`\n  - admin user has system roles: ACCOUNTADMIN, ORGADMIN, SYSADMIN\n- Login and create a SQL Worksheet named _**Account Setup**_\n\n\u003Cins\u003ENote:\u003C/ins\u003E alternatively you _can_ use an existing account instead of a trial account, provided that account has the `ORGADMIN` system role enabled.\n\n- Create user `horizonadmin`, grant it ACCOUNTADMIN and ORGADMIN roles.\n\nExecute the following SQL commands in the _**Account Setup**_ worksheet to bootstrap:\n\n```sql\nUSE ROLE accountadmin;\nSET my_user_var = CURRENT_USER();\nALTER USER identifier($my_user_var) SET DEFAULT_ROLE = accountadmin;\nCREATE OR REPLACE WAREHOUSE compute_wh WAREHOUSE_SIZE=small INITIALLY_SUSPENDED=TRUE;\nGRANT ALL ON WAREHOUSE compute_wh TO ROLE public;\nCREATE DATABASE IF NOT EXISTS snowflake_sample_data FROM SHARE sfc_samples.sample_data;\nGRANT IMPORTED PRIVILEGES ON DATABASE snowflake_sample_data TO public;\n\n-- Create an AWS Consumer account\nUSE ROLE orgadmin;\nCREATE ACCOUNT horizon_lab_aws_consumer\n  admin_name = horizonadmin\n  admin_password = 'FILL_IN_PASSWORD'\n  email = 'FILL_IN_EMAIL'\n  must_change_password = false\n  edition = business_critical\n  region = AWS_US_WEST_2;\n \n-- Create an Azure Consumer account\nCREATE ACCOUNT horizon_lab_azure_consumer\n  admin_name = horizonadmin\n  admin_password = 'FILL_IN_PASSWORD'\n  email = 'FILL_IN_EMAIL'\n  must_change_password = false\n  edition = business_critical\n  region = AZURE_WESTEUROPE;\n\n-- Verify that all three accounts are now created. Also, get the URLs\n-- from the column account_url to log in to your consumer accounts later\nSHOW ORGANIZATION ACCOUNTS;\n\n-- Enable the ACCOUNTADMIN role on this account to enable global auto-fulfillment\nUSE ROLE orgadmin;\nSELECT current_account_name();\nSELECT SYSTEM$ENABLE_GLOBAL_DATA_SHARING_FOR_ACCOUNT('!FILL IN CURRENT_ACCOUNT_NAME()!');\n\n-- PLEASE NOTE DOWN: \"orgname-accountname\" is the account format needed to add a connection to the Snowflake CLI\nSELECT current_organization_name() || '-' || current_account_name();\n```\n\nLogin to the **HORIZON_LAB_AWS_CONSUMER** and **HORIZON_LAB_AZURE_CONSUMER** accounts as `horizonadmin` and run the following in a worksheet in each of the two accounts:\n\n```sql\nUSE ROLE accountadmin;\nSET my_user_var = CURRENT_USER();\nALTER USER identifier($my_user_var) SET DEFAULT_ROLE = accountadmin;\nCREATE OR REPLACE WAREHOUSE compute_wh WAREHOUSE_SIZE=medium INITIALLY_SUSPENDED=TRUE;\nGRANT ALL ON WAREHOUSE compute_wh TO ROLE public;\nCREATE DATABASE IF NOT EXISTS snowflake_sample_data FROM SHARE sfc_samples.sample_data;\nGRANT IMPORTED PRIVILEGES ON DATABASE snowflake_sample_data TO public;\n \nUSE ROLE useradmin;\nCREATE OR REPLACE ROLE sales_emea_role\n      COMMENT = 'EMEA Sales role for Tasty Bytes';\n\nCREATE OR REPLACE ROLE sales_americas_role\n      COMMENT = 'Americas Sales role for Tasty Bytes';\n\nCREATE OR REPLACE ROLE sales_apj_role\n      COMMENT = 'APJ Sales role for Tasty Bytes';\n\nCREATE OR REPLACE ROLE sales_manager_role\n      COMMENT = 'Sales Manager (all-access) role for Tasty Bytes';\n\n-- grant all these roles to the login user\nGRANT ROLE sales_emea_role TO USER identifier($my_user_var);\nGRANT ROLE sales_americas_role TO USER identifier($my_user_var);\nGRANT ROLE sales_apj_role TO USER identifier($my_user_var);\nGRANT ROLE sales_manager_role TO USER identifier($my_user_var);\n\nSHOW ROLES;\n```\n\n#### Install Snowflake CLI and configure Connections to Snowflake accounts\n\n- Install Python (3.8 or higher): `python --version`\n  - [Homebrew](https://brew.sh/) makes it simple to install python\n    - `% brew install python`\n    - (optional): `% sudo ln -s /usr/bin/python3 /usr/local/bin/python`\n- Install [pipx](https://pipx.pypa.io/stable/installation/) or [pip](https://macpaw.com/how-to/install-pip-mac)\n  (MacOS)\n  - `% brew install pipx`\n  - `% pipx ensurepath`\n  - exit and open a new Terminal so path takes effect\n- Install [Snowflake CLI](https://docs.snowflake.com/en/developer-guide/snowflake-cli-v2/installation/installation#label-snowcli-install-pipx)\n\n  Create CLI connections to the 3 accounts using [snow connection add](https://docs.snowflake.com/en/developer-guide/snowflake-cli-v2/connecting/specify-credentials#how-to-add-credentials-using-a-sf-cli-connection-command):\n\n- use connection names: `horizon-aws-provider, horizon-aws-consumer, horizon-azure-consumer`\n- Snowflake CLI expects the account format **orgname-accountname**\n  - `SELECT current_organization_name() || '-' || current_account_name();`\n- enter password when prompted, just hit _**return**_ for the remaining prompts\n  \n```bash\nsnow connection add -n horizon-aws-provider -a [orgname]-[provider_accountname] -u horizonadmin -r accountadmin -w compute_wh\nsnow connection add -n horizon-aws-consumer -a [orgname]-horizon_lab_aws_consumer -u horizonadmin -r accountadmin -w compute_wh\nsnow connection add -n horizon-azure-consumer -a [orgname]-horizon_lab_azure_consumer -u horizonadmin -r accountadmin -w compute_wh\nsnow connection set-default \"horizon-aws-provider\"\nsnow connection test --connection horizon-aws-provider\nsnow connection test --connection horizon-aws-consumer\nsnow connection test --connection horizon-azure-consumer\n\n# list all connections and check that default is horizon-aws-provider\nsnow connection list\n\n# you can also manually edit the config.toml file to remove or modify connections\nsnow --info\n```\n\n\u003C!-- ------------------------ --\u003E\n## Citations and Terms of Use\n\n\nRaw text data provided for this lab is an extract from the [IMDB Large Movie Review Dataset](https://ai.stanford.edu/~amaas/data/sentiment/)\n\nUse of this dataset requires that we cite this ACL 2011 paper by Andrew Maas, et al:\n@InProceedings{maas-EtAl:2011:ACL-HLT2011,\n  author    = {Maas, Andrew L.  and  Daly, Raymond E.  and  Pham, Peter T.  and  Huang, Dan  and  Ng, Andrew Y.  and  Potts, Christopher},\n  title     = {Learning Word Vectors for Sentiment Analysis},\n  booktitle = {Proceedings of the 49th Annual Meeting of the Association for Computational Linguistics: Human Language Technologies},\n  month     = {June},\n  year      = {2011},\n  address   = {Portland, Oregon, USA},\n  publisher = {Association for Computational Linguistics},\n  pages     = {142--150},\n  url       = {\u003Chttp://www.aclweb.org/anthology/P11-1015}\u003E\n}\n\n[Weather Source LLC: frostbyte](https://app.snowflake.com/marketplace/listing/GZSOZ1LLEL/weather-source-llc-weather-source-llc-frostbyte) Marketplace listing requires accepting terms of use by the Provider and Snowflake.\n\n\u003C!-- ------------------------ --\u003E\n## Horizon AWS Provider Account Setup\n\n\nClone our [Horizon Quickstart Scripts](https://github.com/Snowflake-Labs/sfguide-horizon-intra-organization-sharing) repository to your local machine with `git`:\n\n```bash\nmkdir ~/snowflakelabs\ncd ~/snowflakelabs\ngit clone git@github.com:Snowflake-Labs/sfguide-horizon-intra-organization-sharing.git horizon-intra-org-scripts\ncd horizon-intra-org-scripts\n```\n\nIf you prefer not to use git, `Download ZIP` from the Lab Scripts [github site](https://github.com/Snowflake-Labs/sfguide-horizon-intra-organization-sharing)\n![assets/code-download.jpg](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/code-download.jpg)\n\nLoad the SQL scripts in the `code/sql` directory into [Snowsight Worksheets](https://docs.snowflake.com/en/user-guide/ui-snowsight-worksheets-gs#create-worksheets-in-sf-web-interface) - one script per worksheet\n\n![Create Worksheet](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/002_load_SQL_scripts_to_worksheets.png)\n\n### Execute Setup SQL Scripts\n\n1. `100_Setup_Data_Model`: create the TastyBytes foundational data model.\n[TastyBytes](/en/developers/guides/tasty-bytes-introduction/) is a fictitious global food truck network that operates in 30 major cities located in 15 countries with localized menu options and brands. The single `Frostbytes_Tasty_Bytes` is organized in the following schemas:\n\n- `RAW_CUSTOMER`: raw customer loyalty data with personally identifiable information (PII)\n- `RAW_POS`: raw point-of-sale data denormalized by orders, menu, franchise and country\n- `HARMONIZED`: blended metrics for customers and orders\n- `ANALYTICS`: analytic data that delivers insights for aggregate trends and drill down\nb\nUse the **Run All** pulldown command to run `100_Setup_Data_Model`:\n\n![Run All in Worksheet](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/003_Run_All.png)\n\n2. `200_Setup_Data_Products`: build data assets to share in a Listing.\n\nIn step 1(a) of thescript `200_Setup_Data_Products` you will acquire the **Weather Source LLC** listing from the Marketplace and install it as a shared database `FROSTBYTE_WEATHERSOURCE`.\n\n```sql\n-- Step 1(a) - Acquire \"Weather Source LLC: frostbyte\" Snowflake Marketplace Listing\n\n/*--- \n    1. Click -\u003E Data Products (Cloud Icon in left sidebar)\n    2. Click -\u003E Marketplace\n    3. Search -\u003E frostbyte\n    4. Click -\u003E Weather Source LLC: frostbyte\n    5. Click -\u003E Get\n    6. Click -\u003E Options\n    6. Database Name -\u003E FROSTBYTE_WEATHERSOURCE (all capital letters)\n    7. \"Which roles, in addition to ACCOUNTADMIN, can access this database?\" -\u003E PUBLIC\n    8. Click -\u003E Get\n---*/\n```\n\n![006_WeatherSource](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/006_WeatherSource.png)\n\nThen proceed to execute all remaining steps in this script. This will create secure views, materialized views, functions and dynamic tables in the ANALYTICS schema, and an internal stage for sharing text data.\n\nCheck out all the new objects created in the ANALYTICS and HARMONIZED schemas in the Snowsight Object Explorer panel. You will later create a Listing to share all of these objects.\n\n![Database-Explorer](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/004_Database_Explorer.png)\n\n### Upload Unstructured Data into an Internal Stage\n\nWe have extracted 100 text files from the IMDB Large Movie Review dataset into the repo, that was cloned to your local machine earlier.\n\nNow we can copy those text files into the internal stage `movie_stage` that was created by the SQL setup scripts.\nRun the snow CLI commands at the root of your repo, where the `git clone` was done.\n\n```bash\ncd ~/git_repos/sfguide-horizon-intra-org\nsnow stage copy data/imdb_reviews @frostbyte_tasty_bytes.movie_reviews.movie_stage\n\n# verify that there are now 100 files in the stage\nsnow stage list-files @frostbyte_tasty_bytes.movie_reviews.movie_stage\n```\n\nSetup is now complete!\n\n\u003C!-- ------------------------ --\u003E\n## Publish a Data Listing\n\n\nIn this section you will create, publish, consume, alter, and monitor a [listing](https://other-docs.snowflake.com/en/collaboration/collaboration-listings-about).\n\n### Build and Publish a Listing in the Provider Studio UI\n1. Navigate to the Provider Studio and click the +Listing button in the top right:\n\n    ![ProviderStudio](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/101_ProviderStudio+Listing.png)\n\n2. Give your listing a meaningful title. Let's use TASTY_BYTES_ANALYTICS in this lab. Then select the option that \"Only Specified Consumers\" can discover the listing, and click \"Next\".\n\n    ![102_CreateListing](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/102_CreateListing.png)\n\n3. Click \"+ Select\" and add the secure functions, the dynamic table, and all the secure views in the ANALYTICS and HARMONIZED schemas to this listing.\n\n    ![103_CreateListing_SelectObjects](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/103_CreateListing_SelectObjects.png)\n\n4. Continue the listing specification:\n\n    - Add a description to document your listing.\n      - For example: \"This listing shares the Tasty Bytes Analytics and Harmonized data objects, including views, functions, and a dynamic table that provide a wealth of useful information.\"\n\n    - Add your two secondary accounts for this lab (one on AWS and one on Azure) as consumer accounts for this listing. Specify each consumer account as ```org-name.account-name```, which you can obtain as follows:\n\n    ```sql\n    select current_organization_name() ||'.'||  current_account_name();\n    ```\n\n    - Further down in the same dialog, enter your email address to receive notifications about this listing.\n    - Click \"SAVE & ADD MORE INFORMATION\" to add even more metdata to your listing.\n\n    ![104_CreateListing_AddConsumers](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/104_CreateListing_AddConsumers.png)\n\n5. You are now looking at your draft listing. Scroll down and add all optional information items to your listing.\n\n    ![105_CreateListing_OptionalInformation](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/105_CreateListing_OptionalInformation.png)\n\n    This will add additional sections to your listing.\n\n    Click the ADD button in each of these sections to configure the data dictionary and to add business needs, sample queries, and attributes:\n\n    - Configuring the data dictionary allows you to select \"featured\" objects that consumers will see first in the dictionary.\n    - Select the views CUSTOMER_LOYALTY_METRICS_V and ORDERS_BY_POSTAL_CODE_V as well as the function FAHRENHEIT_TO_CELSIUS as featured objects.\n    - You can grab some sample queries from the script 1000_Consumer_Queries.sql\n    - Attributes allow you to specify service level objectives such as how often you intend to update the data product or other properties.\n\n    ![106_CreateListing_OptionalInfo_Part2](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/106_CreateListing_OptionalInfo_Part2.png)\n\n6. In your draft listing, navigate to the section \"Consumer Accounts\". Click the three dots on the right to update the refresh frequency of the replica that Snowflake will automatiucally create to share the data product with your Azure account.\n\n    - For the purpose of this lab, set the replication frequency to 1 minute.\n\n    ![107_CreateListing_ReplicationFrequency](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/107_CreateListing_ReplicationFrequency.png)\n\n7. Publish your listing.\n\n    - You can preview your draft listing at any time.\n    - When done, click the blue \"Publish Listing\" button in the top right corner.\n\n### Install the Listing in your Consumer Accounts\n\n1. Switch to Consumer Account: Horizon_Lab_Azure_Consumer\n\n    - In a different tab of your web browser login to your account \"horizon_lab_azure_consumer\" that you created in the Azure West Europe Region.\n    - Use the menu in the bottom left of the UI to switch to the ACCOUNTADMIN role.\n    - Navigate to \"Data Products\" and then \"Private Sharing\" in the left hand menu panel.\n    - You will now see the listing that has been shared with this account.\n    - Click the listing name (not the Get button) to open and examine the listing details. For example, explore the data dictionary for the views and functions.\n\n    ![201_Consumer_DiscoverListing](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/201_Consumer_DiscoverListing.png)\n\n2. After reviewing the listing, click the GET button.\n\n    - You may be asked for your name & email address if this is the first time a listing is being consumed in this Snowflake  account. Do provide this information, then go to your Email Inbox and validate the email that was sent.\n    - After you click the GET button Snowflake performs a one-time setup of the replication process ([auto-fulfillment](https://other-docs.snowflake.com/en/collaboration/provider-listings-auto-fulfillment)) to the local region.\n    - You may have to wait for several minutes for this one-time setup to complete. Click OK. We will check back later.\n\n    ![202_Consumer_WaitForReplica](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/202_Consumer_WaitForReplica.png)\n\n3. Switch to Consumer Account: Horizon_Lab_AWS_Consumer\n\n    - In yet another tab of your web browser login to your account \"horizon_lab_aws_consumer\".\n    - Use the menu in the bottom left to switch to the ACCOUNTADMIN role.\n    - Navigate to \"Data Products\" and then \"Private Sharing\".\n    - Click the listing name (not the Get button) to open and examine the listing details.\n\n4. After reviewing the listing, click the GET button.\n\n    - Again, you may be asked to provide and validate your email address.\n    - After you click the GET button you can immediately mount the shared data product. There is no replication setup in this case since the provider account is in the same cloud region as this consumer account.\n    - Under \"Options\" leave the local database name as is (it should be TASTY_BYTES_ANALYTICS), and select SALES_MANAGER_ROLE as an additional role to have immediate access to the data product.\n    - Click GET to confirm\n\n    ![203_Consumer_GET](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/203_Consumer_GET.png)\n\n    You can now use a worksheet or the database explorer to examine the shared data as a consumer.\n\n5. Observe live data sharing in action\n\n    - Switch to the **AWS Provider** account where you published the listing\n    - Insert or update some of the source data. You can use the following statement which uses [a very cool SQL feature](https://docs.snowflake.com/en/sql-reference/sql/select#label-select-cmd-examples-select-all-in-table-replace) to modify the columns produced by ```SELECT *```.  \n      - The syntax ```SELECT * REPLACE (\u003Cexpression\u003E AS \u003Ccolumn_name\u003E)``` returns all columns but replaces the column ```\u003Ccolumn_name\u003E``` with the ```\u003Cexpression\u003E```.\n\n    ```sql\n    -- re-insert existing data for Berlin but give it today's date as the valid date \n    INSERT INTO FROSTBYTE_TASTY_BYTES.WEATHER.HISTORY_DAY\n      SELECT * REPLACE  (current_date AS DATE_VALID_STD) \n      FROM FROSTBYTE_TASTY_BYTES.WEATHER.HISTORY_DAY\n      WHERE city_name = 'Berlin'\n      ORDER BY date_valid_std DESC;\n      ```\n\n    - Switch back to your **Horizon_Lab_AWS_Consumer** account to see that the data changes are instantly visible. For example:\n\n    ```sql\n    SELECT *\n    FROM tasty_bytes_analytics.HARMONIZED.DAILY_WEATHER_V\n    WHERE city_name = 'Berlin'\n    ORDER BY date_valid_std DESC;\n    ```\n\n## Listing Management and Monitoring\n\n\n### Use the Listing API to modify listing properties programmatically\n\n1. [SHOW LISTINGS](https://other-docs.snowflake.com/en/sql-reference/sql/show-listings) in the AWS Provider account where you published the listing.\n\n    ![301_Provider_API_Show](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/301_Provider_API_Show.png)\n\n2. Copy the Snowflake object name of your listing and use it in the subsequent [DESCRIBE LISTING](https://other-docs.snowflake.com/en/sql-reference/sql/desc-listing) command.\n\n    - Note: If that listing name contains special characters other than the underscore, then the name must be in double quotes and is case-sensitive.\n\n3. In the result of DESCRIBE LISTING, scroll to the right to the column [MANIFEST_YAML](https://other-docs.snowflake.com/en/progaccess/listing-manifest-reference) and copy its column value. This YAML file is a complete representation of the listing and enables programmatic management of listings.\n\n    ![302_Provider_API_Describe](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/302_Provider_API_Describe.png)\n\n4. Paste the copied YAML into an [ALTER LISTING](https://other-docs.snowflake.com/en/sql-reference/sql/alter-listing) statement using the listing name obtained in step 2 above (Show Listing).\n\n    - Make some changes in the YAML that you can easily verify in the UI and on the consumer side. For example, update the title and the first line of the description.\n    - Execute the ALTER LISTING statement.\n\n    ![303_Provider_API_AlterListing](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/303_Provider_API_AlterListing.png)\n\n5. Verify the immediate effect of the ALTER LISTING statement\n\n    - In the provider account, navigate to the Provider Studio, select \"Listings\" from the horizontal menu at the top, and open your listing.\n\n    ![304_Provider_Studio](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/304_Provider_Studio.png)\n\n    - Switch to your consumer account Horizon_Lab_AWS_Consumer.\n    - Navigate to \"Data Products\", then \"Private Sharing\", and open the listing page again. Refresh if needed to see the changes from the ALTER LISTING statement.\n\n### Monitor Auto Fulfillment status and cost\n\nTime to revisit the second consumer account (\"horizon_lab_azure_consumer\") and the replication into that Azure region. By now, the one-time replication setup has been completed in the background and the data product is now ready to use.\n\n1. Switch to the account \"horizon_lab_azure_consumer\" as ACCOUNTADMIN, and navigate to \"Private Sharing\" to open the listing that has been shared.\n\n2. Click the GET button to mount the data product locally, as you did in the \"horizon_lab_aws_consumer\" account.\n\n3. Switch to the AWS Provider account and take the following steps to monitor replication status and cost.\n\n4. Navigate to the \"Provider Studio\", select \"Listings\" from the horizontal menu at the top, and open your listing.\n\n5. On the listings page, scoll down to \"Consumer Account\", click on the 3 dots, and select \"Manage Regions & Replication\"\n\n6. Select the \"Azure West Europe Region\" to see the timestamp of the latest refresh to that region.\n\n    ![400_MonitorReplicationStatus](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/400_MonitorReplicationStatus.png)\n\n7. Go back to the Provider Studio, select \"Analytics\" from the horizontal menu at the top. This is where summarized and detailed statistics about the usage of the listings will be displayed eventually. There is some delay in populating these statistics, but the following screenshots give you an idea of what you will see.\n\n    ![401_Provider_Dashboard](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/401_Provider_Dashboard.png)\n\n    The same information as well as replication details can also be obtained from various views in the schema [SNOWFLAKE.DATA_SHARING_USAGE](https://docs.snowflake.com/en/sql-reference/data-sharing-usage) and [SNOWFLAKE.ORGANIZATION_USAGE](https://docs.snowflake.com/en/sql-reference/organization-usage):\n\n    ```sql\n    use database SNOWFLAKE;\n\n    select * from DATA_SHARING_USAGE.LISTING_ACCESS_HISTORY;\n\n    select * from DATA_SHARING_USAGE.LISTING_AUTO_FULFILLMENT_DATABASE_STORAGE_DAILY;\n\n    select * from DATA_SHARING_USAGE.LISTING_AUTO_FULFILLMENT_REFRESH_DAILY;\n\n    select * from DATA_SHARING_USAGE.LISTING_EVENTS_DAILY;\n\n    select * from DATA_SHARING_USAGE.LISTING_TELEMETRY_DAILY;\n\n    select * from ORGANIZATION_USAGE.LISTING_AUTO_FULFILLMENT_USAGE_HISTORY;\n\n    select * from ORGANIZATION_USAGE.REPLICATION_USAGE_HISTORY;\n    ```\n\n8. The [replication cost](https://other-docs.snowflake.com/en/collaboration/provider-understand-cost-auto-fulfillment) can also be monitored in the UI. Navigate to the \"Admin\" menu in the left-hand panel, then to \"Cost Management\" and \"Consumption\". Switch the filter from \"All Services\" to \"Cross-Cloud Auto-Fulfillment\". Here is an example from a different test replicating a listing to the region Azure UK South:\n\n    ![402_Provider_LAF_Cost_Compute](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/402_Provider_LAF_Cost_Compute.png)\n\n    Additional filters enable you to select a time period, pick a specific target region, or toggle between compute cost, storage cost, and data transfer volume incurred by the listing auto-fulfillment.\n\n    ![403_Provider_LAF_DataTransfer](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/403_Provider_LAF_DataTransfer.png)\n\n    ![404_Provider_LAF_DataTransfer_Details](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/404_Provider_LAF_DataTransfer_Details.png)\n\n### Enable and Consume Change Tracking\n\nThe provider of a listing can choose to enable [change tracking](https://docs.snowflake.com/en/user-guide/streams) on the some or all of the tables or views that are shared in a listing. This enables the consumer to track the data changes. Let's do that with the view DAILY_WEATHER_V:\n\n```sql\n-- in the provider account:\nALTER VIEW FROSTBYTE_TASTY_BYTES.HARMONIZED.DAILY_WEATHER_V \n      SET CHANGE_TRACKING = TRUE;\n```\n\nThe consumer can now [define a Stream](https://docs.snowflake.com/en/sql-reference/sql/create-stream) to capture the data changes in this view:\n\n```sql\n-- in the consumer account:\nCREATE DATABASE tasty_bytes_local;\nUSE DATABASE tasty_bytes_local;\n\nCREATE STREAM stream_daily_weather_changes ON VIEW tasty_bytes_analytics.HARMONIZED.DAILY_WEATHER_V;\n```\n\nTo see the change tracking in action you can now insert, update, or delete some of the weather related data in the AWS Provider account. For example:\n\n```sql\n-- in the provider account:\nINSERT INTO FROSTBYTE_TASTY_BYTES.WEATHER.HISTORY_DAY\n  SELECT * REPLACE  (current_date AS DATE_VALID_STD) \n  FROM FROSTBYTE_TASTY_BYTES.WEATHER.HISTORY_DAY\n  WHERE city_name = 'San Mateo'\n  ORDER BY date_valid_std DESC;\n  ```\n\nNow switch to the consumer account and query the stream:\n\n```sql\n-- in the consumer account:\nUSE DATABASE tasty_bytes_local;\n\nSELECT METADATA$ACTION, METADATA$ISUPDATE, * \nFROM stream_daily_weather_changes;\n```\n\n\u003C!-- ------------------------ --\u003E\n## Protect Data with Governance Policies\n\n\nThis section of the lab introduces several capabilities for data providers to restrict the usage of their products by consumers.\n\n### Cross-Account Row-Level Access Policies\n\nFrosty the data steward is concerned that our listing that we have shared includes the view ANALYTICS.CUSTOMER_LOYALTY_METRICS_V which contains sensitive information that must not be accessible to all data consumers. He requests the following restrictions:\n\n![500_DataSteward_1](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/500_DataSteward_1.png)\n\nLet's implement a [row-level access policy](https://docs.snowflake.com/en/user-guide/security-row-intro) to implement the required access control. Note the usage of the context function **current_account_name()** to detect which consumer account is accessing the shared view.\n\n**Fill in AWS Provider Account Name below**\n\n```sql\nuse database frostbyte_tasty_bytes;\nuse schema analytics;\n\nCREATE OR REPLACE ROW ACCESS POLICY country_filter AS (country string) \nRETURNS boolean -\u003E\n  CASE\n    WHEN current_account_name() IN ('HORIZON_LAB_AWS_CONSUMER') \n      AND country               IN ('United States', 'Canada') \n      THEN true\n    WHEN current_account_name() IN ('HORIZON_LAB_AZURE_CONSUMER')        \n      AND country               IN ('France', 'Germany', 'Poland', 'Sweden', 'Spain') \n      THEN true\n    WHEN current_account_name() IN ('*** FILL IN AWS Provider Account Name ***')\n      THEN true\n      ELSE false\n  END;\n  ```\n\nThen apply the policy to the shared view:\n\n```sql\nALTER VIEW CUSTOMER_LOYALTY_METRICS_V ADD ROW ACCESS POLICY country_filter ON (country);\n```\n\nNow switch to the consumer account HORIZON_LAB_AWS_CONSUMER to confirm that only US and Canadian client data is visible in the view ANALYTICS.CUSTOMER_LOYALTY_METRICS_V.\n\nAfter the replication interval of 1 minute you will also see that the consumer account HORIZON_LAB_AZURE_CONSUMER can only see the Eurpean clients.\n\n### Cross-Account Column Masking\n\nBut, Frosty the data steward is not yet satisfied:\n\n![501_DataSteward_2](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/501_DataSteward_2.png)\n\nOk, let's get to work.\n\nTo make things easy, let's first create a tag that you can use to indicate which columns contain PII data.\n\n```sql\nCREATE SCHEMA IF NOT EXISTS tags;\n\nCREATE OR REPLACE TAG tags.tasty_pii\n    ALLOWED_VALUES 'NAME', 'PHONE_NUMBER', 'EMAIL', 'BIRTHDAY'\n    COMMENT = 'Tag for PII, allowed values are: NAME, PHONE_NUMBER, EMAIL, BIRTHDAY';\n```\n\nWith the tag created, let's assign it to the relevant columns in the Customer Loyalty view:\n\n```sql\nALTER VIEW ANALYTICS.CUSTOMER_LOYALTY_METRICS_V\n    MODIFY COLUMN \n    first_name    SET TAG tags.tasty_pii = 'NAME',\n    last_name     SET TAG tags.tasty_pii = 'NAME',\n    phone_number  SET TAG tags.tasty_pii = 'PHONE_NUMBER',\n    e_mail        SET TAG tags.tasty_pii = 'EMAIL';\n```\n\nOptionally, you can also use the UI to add or see the tags on these columns:\n\n![502_AddTags](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/502_AddTags.png)\n\nNow let's create a slightly more advanced [policy to mask the PII columns depending on their tag](https://docs.snowflake.com/en/user-guide/tag-based-masking-policies) value and the consmer account:\n\n**Fill in AWS Provider Account Name below**\n\n```sql\nCREATE OR REPLACE MASKING POLICY pii_string_mask AS (value STRING) RETURNS STRING -\u003E\n  CASE\n    -- two roles in the provider account have access to unmasked values \n    WHEN CURRENT_ACCOUNT_NAME() IN ('*** FILL IN AWS Provider Account Name ***') \n    AND CURRENT_ROLE()          IN ('ACCOUNTADMIN','SYSADMIN')\n    THEN value\n\n    -- For consumers in the 2nd AWS account: if a column is tagged with \n    -- TASTY_PII=PHONE_NUMBER then mask everything except the first 3 digits   \n    WHEN CURRENT_ACCOUNT_NAME() IN ('HORIZON_LAB_AWS_CONSUMER') \n    AND SYSTEM$GET_TAG_ON_CURRENT_COLUMN('TAGS.TASTY_PII') = 'PHONE_NUMBER'\n    THEN CONCAT(LEFT(value,3), '-***-****')\n        \n    -- For consumers in the Azure account: if a column is tagged with  \n    -- TASTY_PII=EMAIL then mask everything before the @ sign  \n    WHEN CURRENT_ACCOUNT_NAME() IN ('HORIZON_LAB_AZURE_CONSUMER') \n    AND SYSTEM$GET_TAG_ON_CURRENT_COLUMN('TAGS.TASTY_PII') = 'EMAIL'\n    THEN CONCAT('**~MASKED~**','@', SPLIT_PART(value, '@', -1))\n        \n    -- all other cases and columns, such as first and last name, should be fully masked   \n    ELSE '**~MASKED~**' \n  END;\n```\n\nNext, apply the policy to the tag so that the policy takes effect on all tages columns:\n\n```sql\nALTER TAG tags.tasty_pii SET MASKING POLICY pii_string_mask;\n```\n\nNow switch to the consumer account HORIZON_LAB_AWS_CONSUMER and look at the view CUSTOMER_LOYALTY_METRICS_V to confirm that phone numbers are partially masked while the other PII columns are fully masked.\n\nAfter the replication interval of 1 minute you will see in the account HORIZON_LAB_AZURE_CONSUMER that emails are partially masked while phone numbers and names are fully masked.  \n\n### Database Roles - Provider Side\n\nJust when we thought we had all the necessary governance controls in place, Frosty has a new requirement for us.\n\n![503_DataSteward_3](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/503_DataSteward_3.png)\n\nSo far we have been using the context function **CURRENT_ACCOUNT_NAME()** in our governance policies to control which consumer account can see which data. Now Frosty is telling us, that this needs to be more fine-grained down to indivudal roles on the consumer side.\n\nWe will be using roles and [database roles](https://docs.snowflake.com/en/sql-reference/sql/create-database-role) for 3 different continents. Let's check that we have the correct roles in place.\n\nOn the AWS Provider account, use **show database roles** to confirm that you have 4 database roles in place. Else create them now.\n\n```sql\nshow database roles in database FROSTBYTE_TASTY_BYTES;\n\nUSE DATABASE frostbyte_tasty_bytes;\nCREATE OR REPLACE DATABASE ROLE tastybytes_emea_role;\nCREATE OR REPLACE DATABASE ROLE tastybytes_americas_role;\nCREATE OR REPLACE DATABASE ROLE tastybytes_apj_role;\nCREATE OR REPLACE DATABASE ROLE tastybytes_manager_role;\n```\n\nWe can use these roles to define more granular and role-based access control for the data consumers. First, we need to give these roles access to the providers's schema and objects that we want to govern, in this case ANALYTICS.CUSTOMER_LOYALTY_METRICS_V:\n\n```sql\nuse database FROSTBYTE_TASTY_BYTES;\n\ngrant usage  on schema ANALYTICS to database role tastybytes_emea_role;\ngrant usage  on schema ANALYTICS to database role tastybytes_americas_role;\ngrant usage  on schema ANALYTICS to database role tastybytes_apj_role;\ngrant usage  on schema ANALYTICS to database role tastybytes_manager_role;\n\ngrant select on view ANALYTICS.CUSTOMER_LOYALTY_METRICS_V \n             to database role tastybytes_emea_role; \ngrant select on view  ANALYTICS.CUSTOMER_LOYALTY_METRICS_V \n             to database role tastybytes_americas_role; \ngrant select on view  ANALYTICS.CUSTOMER_LOYALTY_METRICS_V \n             to database role tastybytes_apj_role; \ngrant select on view  ANALYTICS.CUSTOMER_LOYALTY_METRICS_V \n             to database role tastybytes_manager_role; \n```\n\nNext, use the context function [**IS_DATABASE_ROLE_IN_SESSION()**](https://docs.snowflake.com/en/sql-reference/functions/is_database_role_in_session) to recreate our row-level access policy to define which role can see customer loyality data from which country.\n\n**Fill in Provider Account Name in the last WHEN clause of the policy below**\n\n```sql\nuse database frostbyte_tasty_bytes;\nuse schema analytics;\n\nALTER VIEW CUSTOMER_LOYALTY_METRICS_V DROP ROW ACCESS POLICY country_filter;\n\n-- Fill in Provider Account Name below\n\nCREATE OR REPLACE ROW ACCESS POLICY country_filter AS (country string) \nRETURNS boolean -\u003E\n  CASE\n    -- users with the AMERICAS role can see data from the US, Canada, and Brazil\n    WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_AMERICAS_ROLE') \n     AND country IN ('United States', 'Canada', 'Brazil') \n    THEN true\n    -- users with the EMEA role can see data from these EMEA countries\n    WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_EMEA_ROLE')         \n     AND country IN ('France', 'Germany', 'Poland', 'Sweden', \n                     'Spain' , 'South Africa', 'Egypt') \n    THEN true\n    -- users with the APJ role can see data from these APJ countries\n    WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_APJ_ROLE')         \n     AND country IN ('Japan', 'Australia', 'India', 'South Korea') \n    THEN true\n    -- users with the manager role can see all data\n    WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_MANAGER_ROLE')         \n    THEN true\n    -- the account admin in the provider account can see all data\n    WHEN current_account_name() IN ('*** FILL IN AWS Provider Account Name ***') \n     AND current_role() = 'ACCOUNTADMIN'\n    THEN true\n    ELSE false\n  END;\n\nALTER VIEW CUSTOMER_LOYALTY_METRICS_V \n      ADD ROW ACCESS POLICY country_filter ON (country);\n```\n\nFor a larger number of roles and countries you can certainly use a mapping table from role to country so that the policy simply performs a lookup in the mapping table.\n\nThe final step in the provider account is to share the database roles to the consumer accounts along with the data product.  This is achieved by [granting the database roles to the share](https://docs.snowflake.com/en/sql-reference/sql/grant-database-role-share):\n\n```sql\n-- Use your share name in these commands.\n-- See below for hints on how to find your share name.\nGRANT DATABASE ROLE tastybytes_emea_role     TO SHARE \u003Cshare_name\u003E;\nGRANT DATABASE ROLE tastybytes_americas_role TO SHARE \u003Cshare_name\u003E;\nGRANT DATABASE ROLE tastybytes_apj_role      TO SHARE \u003Cshare_name\u003E;\nGRANT DATABASE ROLE tastybytes_manager_role  TO SHARE \u003Cshare_name\u003E;\n```\n\nHere are two options how to find the share name for your listing:\n\n**Option 1:**\n\nIn the provider account, navigate to the Provider Studio, select \"Listings\" from the horizontal menu at the top, and open your listing. In the section \"Data Product\" you find the name of the Secure Share that bundles the shared data objects.\n![602_DMF_AddTableToShare_1](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/602_DMF_AddTableToShare_1.png)\n\n**Option 2:**\n\nUse the SHOW SHARES command:\n\n![504_ShowShares](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/504_ShowShares.png)\n\nCopy the share name to a text file or worksheet because you will need it again later.\n\n### Database Roles - Consumer Side\n\nTo complete the configuration of cross-account role-based access control you need to assign the shared database roles to local account roles in the consumer roles.\n\nSwitch to your consumer accounts.  \n\nIn each of your consumer accounts you should already have the following 4 roles that you created during the account setup. Verify that these roles are in place. Else, create them now.\n\n```sql\nSHOW ROLES LIKE 'SALES%';\n\nCREATE OR REPLACE ROLE sales_emea_role     COMMENT = 'EMEA Sales role';\nCREATE OR REPLACE ROLE sales_americas_role COMMENT = 'Americas Sales role ';\nCREATE OR REPLACE ROLE sales_apj_role      COMMENT = 'APJ Sales role ';\nCREATE OR REPLACE ROLE sales_manager_role  COMMENT = 'Manager (all-access) role';\n```\n\nIn a real-world scenario you would now assign each of these roles to different users. For simplicity in this lab, grant all of these roles to yourself:\n\n```sql\nSET my_user_var  = CURRENT_USER();\nGRANT ROLE sales_emea_role     TO USER identifier($my_user_var);\nGRANT ROLE sales_americas_role TO USER identifier($my_user_var);\nGRANT ROLE sales_apj_role      TO USER identifier($my_user_var);\nGRANT ROLE sales_manager_role  TO USER identifier($my_user_var);\n```\n\nAnd finally, grant the shared database roles to the local account roles. This connects these local consumers roles to the row-access policy that you create on the provider side.\n\n```sql\nuse database TASTY_BYTES_ANALYTICS;\ngrant database role tastybytes_emea_role     to role sales_emea_role; \ngrant database role tastybytes_americas_role to role sales_americas_role;\ngrant database role tastybytes_apj_role      to role sales_apj_role; \ngrant database role tastybytes_manager_role  to role sales_manager_role;\n```\n\nThe following picture illustrates the use of our database roles in this data sharing scenario.\n\n![505_Database_Roles_Sharing](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/505_Database_Roles_Sharing.png)\n\nNow switch to the different local roles (sales_emea_role, sales_apj_role, etc) in each of your consumer accounts to verify that each local role can only see those rows in the CUSTOMER_LOYALTY_METRICS_V view that are permitted by the row-level access policy in the provider account.\n\n### Aggregation and Projection Policies\n\n![550_DataSteward_4](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/550_DataSteward_4.png)\n\nFrosty the data steward has a new requirement for us. In the consumer accounts, only admins and managers may see the detailed per-customer loyalty data. Anyone else may see aggregated data only.\n\nCreate the following [aggregation policy](https://docs.snowflake.com/en/user-guide/aggregation-policies) to implement this requirement:\n\n**Fill in AWS Provider Account Name below**\n\n```sql\nCREATE OR REPLACE AGGREGATION POLICY tasty_aggregation_policy\n  AS () RETURNS AGGREGATION_CONSTRAINT -\u003E\n  CASE\n      WHEN current_account_name() IN ('*** FILL IN AWS Provider Account Name ***') \n       AND current_role() = 'ACCOUNTADMIN'\n      THEN NO_AGGREGATION_CONSTRAINT()\n\n      WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_MANAGER_ROLE')\n      THEN NO_AGGREGATION_CONSTRAINT()\n\n      ELSE AGGREGATION_CONSTRAINT(MIN_GROUP_SIZE =\u003E 50) -- at least 50 rows in aggregate\n    END;\n\nALTER VIEW analytics.CUSTOMER_LOYALTY_METRICS_V\n  SET AGGREGATION POLICY tasty_aggregation_policy;\n```\n\nNow switch to your consumer account **horizon_lab_aws_consumer** to verify the effect of the aggregation policy:\n\n```sql\nuse role sales_apj_role;\n-- sales_apj_role gets blocked from accessing any individual records:\nSELECT * FROM analytics.CUSTOMER_LOYALTY_METRICS_V;\n\n-- sales_apj_role can execute aggregation queries:\nSELECT city, count(*) as num_cust_per_city\nFROM analytics.CUSTOMER_LOYALTY_METRICS_V\nGROUP BY city;\n\n-- sales_manager_role is permitted to access  individual records:\nuse role sales_manager_role;\nSELECT * FROM analytics.CUSTOMER_LOYALTY_METRICS_V LIMIT 100;\n```\n\nSwitch back to your AWS Provider account and issue the following command to deactivate the aggregation policy.\n\n```sql\nALTER TABLE analytics.CUSTOMER_LOYALTY_METRICS_V UNSET AGGREGATION POLICY;\n```\n\nNext, let's also create a [projection policy](https://docs.snowflake.com/en/user-guide/projection-policies) that prevents the **city** column from appearing in a result set but allows its usage in predicates to the restrict a query result:\n\n**Fill in AWS Provider Account Name below**\n\n```sql\nCREATE OR REPLACE PROJECTION POLICY tasty_projection_policy\n  AS () RETURNS PROJECTION_CONSTRAINT -\u003E\n  CASE\n      WHEN current_account_name() IN ('*** FILL IN AWS Provider Account Name ***') \n       AND current_role() = 'ACCOUNTADMIN'\n      THEN PROJECTION_CONSTRAINT(ALLOW =\u003E true)\n\n      WHEN IS_DATABASE_ROLE_IN_SESSION('TASTYBYTES_MANAGER_ROLE')\n      THEN PROJECTION_CONSTRAINT(ALLOW =\u003E true)\n\n      ELSE PROJECTION_CONSTRAINT(ALLOW =\u003E false)\n    END;\n\nALTER VIEW analytics.CUSTOMER_LOYALTY_METRICS_V\n  MODIFY COLUMN city \n  SET PROJECTION POLICY tasty_projection_policy;\n```\n\n Switch to your consumer account **horizon_lab_aws_consumer** again to explore the effect of the projection policy on the results or the following queries:\n\n ```sql\nuse role sales_apj_role;\n\nSELECT *              FROM analytics.CUSTOMER_LOYALTY_METRICS_V;\n\nSELECT * EXCLUDE city FROM analytics.CUSTOMER_LOYALTY_METRICS_V;\n\nSELECT * EXCLUDE city \nFROM analytics.CUSTOMER_LOYALTY_METRICS_V\nWHERE city IN ('Delhi','Tokyo','Seoul','Melbourne','Sydney','Mumbai');\n\nSELECT city, count(*) as num_cust_per_city\nFROM analytics.CUSTOMER_LOYALTY_METRICS_V\nGROUP BY city;\n```\n\nNote that a projection policy by itself does not prevent users from detecting information about individuals. For example, the following query is permitted (and returns customer details if you remove the masking policy **pii_string_mask**):\n\n ```sql\nSELECT * EXCLUDE city\nFROM analytics.CUSTOMER_LOYALTY_METRICS_V\nWHERE city = 'Melbourne' AND last_name = 'Arellano';\n```\n\n## Publish Listing with Data Quality Metrics\n\n\nIn this section the data provider will capture [data quality metrics](https://docs.snowflake.com/en/user-guide/data-quality-intro) and share them with the data consumers. In particular, we want to monitor the data quality in the view ANALYTICS.ORDERS_BY_POSTAL_CODE_V.\n\n### Assign Built-in and Custom Data Quality Metrics to Shared Data\n\nOn AWS Provider account, execute the following commands to create a database where we will define any custom quality functions.\n\n```sql\nuse role accountadmin;\ncreate or replace database tasty_bytes_quality;\nuse database tasty_bytes_quality;\ncreate schema dq_functions;\n```\n\nNext, let's define how often the quality of ORDERS_BY_POSTAL_CODE_V should be checked. For a table, the quality checks can be triggered by data changes or executed on a schedule. For views, the quality metrics can (currently) be evaluated on a schedule.\n\nLet's set the schedule to the shortest possible interval, which is 5 minutes:\n\n```sql\nALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  SET DATA_METRIC_SCHEDULE = '5 MINUTE';\n```\n\nNow, let's use two of [Snowflake's built-in data quality functions](https://docs.snowflake.com/en/user-guide/data-quality-system-dmfs) to count the number of NULL valuse in the column POSTAL_CODE as well as the number of distinct cities reported in this view:\n\n```sql\nALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  ADD DATA METRIC FUNCTION SNOWFLAKE.CORE.NULL_COUNT ON (POSTAL_CODE);\n\nALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  ADD DATA METRIC FUNCTION SNOWFLAKE.CORE.UNIQUE_COUNT ON (CITY);\n```\n\nAdditionally, let's create a [custom data quality function](https://docs.snowflake.com/user-guide/data-quality-working#create-your-own-dmf) that counts the number of outliers, i.e. postal areas with an exceptionally high or low number of orders:\n\n```sql\nCREATE OR REPLACE DATA METRIC FUNCTION tasty_bytes_quality.dq_functions.postal_code_order_outliers (t TABLE  (count_order INTEGER) )\nRETURNS INTEGER\nAS\n$$\n  select count(*) \n  from t\n  where count_order \u003E 300000\n     or count_order \u003C 30\n$$;\n```\n\nThe owner of the object that is being monitored needs to have the privilege to execute the custom data metric function and use the database and schema where that function resides. Additional privileges are required to execute the built-in metric functions or view their results. To keep it simple, let's grant the following privileges to all users:\n\n```sql\nGRANT ALL ON FUNCTION tasty_bytes_quality.dq_functions.postal_code_order_outliers(TABLE(INTEGER)) to role public;\nGRANT USAGE ON DATABASE tasty_bytes_quality              to role public;\nGRANT USAGE ON SCHEMA   tasty_bytes_quality.dq_functions to role public;\n\nGRANT EXECUTE DATA METRIC FUNCTION ON ACCOUNT            to role public;\nGRANT DATABASE ROLE SNOWFLAKE.DATA_METRIC_USER           to role public;\nGRANT DATABASE ROLE SNOWFLAKE.USAGE_VIEWER               to role public;\n```\n\nNow we can apply our customer quality function to the view ORDERS_BY_POSTAL_CODE_V:\n\n```sql\nALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  ADD DATA METRIC FUNCTION tasty_bytes_quality.dq_functions.postal_code_order_outliers \n  ON (count_order);\n```\n\nUse the following command to verify that all three quality metrics have been scheduled correctly. Any permission problems would be reflected in the column \"schedule_status\". Possible status values are [documented here](https://docs.snowflake.com/sql-reference/functions/data_metric_function_references#returns).\n\n```sql\n  SELECT schedule_status, *\n  FROM TABLE(\n    INFORMATION_SCHEMA.DATA_METRIC_FUNCTION_REFERENCES(\n      REF_ENTITY_NAME =\u003E 'FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V',\n      REF_ENTITY_DOMAIN =\u003E 'VIEW'  )\n  );\n```  \n\n![600_DMF_Status](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/600_DMF_Status.png)\n\nAfter 5 minutes you can start observing quality metrics in the [default event table](https://docs.snowflake.com/en/user-guide/data-quality-working#view-the-dmf-results) where all quality results are recorded:\n\n**Unfortunately, accessing `snowflake.local.data_quality_monitoring_results` is not yet available in Snowflake trial accounts!** Please skip ahead to the next section _Sharing Data Quality Metrics_ if you are using a trial account.\n\n```sql\nSELECT scheduled_time, measurement_time, metric_name, metric_schema,\n       value, table_name, table_schema, table_database \nFROM snowflake.local.data_quality_monitoring_results  /* not yet available in trial accounts! */\nORDER BY measurement_time DESC;\n```\n\n![601_DMF_Results](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/601_DMF_Results.png)\n\nAdditionally, you could define [Alerts](https://docs.snowflake.com/en/user-guide/alerts) to watch the data quality metrics and take action automatically if acceptable thresholds are exceeded. For example, if the number of outliers reported by our custom quality function exceeds a certain value an alert could copy the offending rows into an exception table for review and send an [email notification](https://docs.snowflake.com/en/user-guide/email-stored-procedures).\n\n### Sharing Data Quality Metrics\n\nHow to share quality metrics from the event table with data consumers? At the time of authoring this lab (May 2024) event tables cannot be shared in a Listing directly. Similarly, views, streams, and dynamic tables are not yet an option for sharing data quality events.\n\nAnd since Snowflake trial accounts cannot access the event table (yet!), let's setup a task that regularly inserts data quality metrics into a table for sharing:\n\n```sql\nUSE DATABASE FROSTBYTE_TASTY_BYTES;\nCREATE SCHEMA FROSTBYTE_TASTY_BYTES.dq;\n\n-- this table will hold and share 7 days worth of quality metrics:\nCREATE OR REPLACE TABLE FROSTBYTE_TASTY_BYTES.dq.shared_quality_events \n  (measurement_time TIMESTAMP, \n   table_name       VARCHAR, \n   table_schema     VARCHAR, \n   table_database   VARCHAR, \n   metric_name      VARCHAR, \n   metric_schema    VARCHAR,\n   value            INTEGER  );  \n \n\n-- this task will maintain the table above:\nCREATE OR REPLACE TASK FROSTBYTE_TASTY_BYTES.dq.subset_quality_events\n   SCHEDULE = '3 MINUTE'\n   AS BEGIN\n        DELETE FROM dq.shared_quality_events\n        WHERE measurement_time \u003C current_date - 7;   \n\n        INSERT INTO dq.shared_quality_events\n           SELECT current_timestamp, 'ORDERS_BY_POSTAL_CODE_V',\n                  'ANALYTICS', 'FROSTBYTE_TASTY_BYTES',\n                  'NULL_COUNT', 'SNOWFLAKE.CORE',\n                   SNOWFLAKE.CORE.NULL_COUNT(\n                       SELECT POSTAL_CODE\n                       FROM ANALYTICS.ORDERS_BY_POSTAL_CODE_V);\n                       \n        INSERT INTO FROSTBYTE_TASTY_BYTES.dq.shared_quality_events\n           SELECT current_timestamp, 'ORDERS_BY_POSTAL_CODE_V',\n                  'ANALYTICS', 'FROSTBYTE_TASTY_BYTES',\n                  'UNIQUE_COUNT', 'SNOWFLAKE.CORE',\n                   SNOWFLAKE.CORE.UNIQUE_COUNT(\n                       SELECT city\n                       FROM ANALYTICS.ORDERS_BY_POSTAL_CODE_V);               \n                       \n        INSERT INTO FROSTBYTE_TASTY_BYTES.dq.shared_quality_events\n           SELECT current_timestamp, 'ORDERS_BY_POSTAL_CODE_V',\n                  'ANALYTICS', 'FROSTBYTE_TASTY_BYTES',\n                  'postal_code_order_outliers', 'dq_functions',\n                   tasty_bytes_quality.dq_functions.postal_code_order_outliers(\n                       SELECT count_order\n                       FROM ANALYTICS.ORDERS_BY_POSTAL_CODE_V);                     \n   END;\n\nALTER TASK subset_quality_events RESUME;\n```\n\nNow you can add the table \"shared_quality_events\" to the shared data product. Here are 2 options how you can so this.\n\n**Option 1: Programmatically**\n\nGrant the share the necessary access to the \"shared_quality_events\" table. You should already have the share name from the early section on Database Roles. Else, get the share name as in the first step of option 2 below.\n\n```sql\nGRANT USAGE ON SCHEMA FROSTBYTE_TASTY_BYTES.dq TO SHARE \u003Cshare_name\u003E;\n \nGRANT SELECT ON FROSTBYTE_TASTY_BYTES.dq.shared_quality_events TO SHARE \u003Cshare_name\u003E;\n```\n\n**Option 2: In the UI**\n\nTake the following 3 steps in the UI:\n\n1. In the provider account, navigate to the Provider Studio, select \"Listings\" from the horizontal menu at the top, and open your listing. In the section \"Data Product\" click on the name of the Secure Share that bundles the shared data objects.\n![602_DMF_AddTableToShare_1](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/602_DMF_AddTableToShare_1.png)\n\n2. You are now looking at a page detailing the underlying share. In the section \"Data\", click the \"Edit\" button:\n![603_DMF_AddTableToShare_2](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/603_DMF_AddTableToShare_2.png)\n\n3. Now you can open the data explorer to find and select the table \"dq.shared_quality_events\". Click \"Done\" and \"Save\" to finalize the update of your data product.\n![604_DMF_AddTableToShare_3](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/604_DMF_AddTableToShare_3.png)\n\n4. Switch to your consumer account \"horizon_lab_aws_consumer\" to verify that the data quality metrics are immediately visible as a new table in the data product. In the second consumer account \"horizon_lab_azure_consumer\" you will see the same after the 1 minute replication interval.\n\n5. Go back to your provider account and suspend the task, to save credits in your trial account.\n\n```sql\n  ALTER TASK subset_quality_events SUSPEND;\n  \n  ALTER VIEW FROSTBYTE_TASTY_BYTES.ANALYTICS.ORDERS_BY_POSTAL_CODE_V\n  UNSET DATA_METRIC_SCHEDULE;\n```\n\n\u003C!-- ------------------------ --\u003E\n## Publish a Native Application Listing\n\n\nThe [Snowflake Native Application Framework](https://docs.snowflake.com/en/developer-guide/snowflake-cli-v2/native-apps/overview) provides developers the ability to create data intensive applications that run _within_ the Snowflake platform with versioning controls.\n\n- Native Apps allow sharing of data and related business logic with other Snowflake accounts.\n- Native Apps are shared with Consumer accounts using a Listing.\n  - A listing can be free or paid, published on Marketplace or to specific accounts\n- Rich visualizations can be include in the application with Streamlit.\n\n### Native App Workflow\n\n![High Level View of Snowflake Native App Framework](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/native-app-framework.jpg)\n\nYou will build a native app that visualizes Tasty Bytes food truck Sales over Time by City.\n\nThe app will allow filtering on Year and City, while displaying the underlying raw data and associated SQL query.\nConsumer account admins responsible for installing the application will supply a country lookup table that restricts what is shown by Country using a row-access policy.\n\n### Overview of Project Structure\n\nHere is the directory structure of the code repository that was cloned or downloaded from GitHub earlier, relevant to `app` artifacts for the native app:\n\n```plaintext\n|-- app\n|   |-- src\n|       |-- libraries\n|       |   |-- environment.yml\n|       |   |-- frosty_bytes_sis.py\n|       |   |-- procs.py\n|       |   |-- udf.py\n|       |-- manifest.yml\n|       |-- setup_script.sql\n|       |-- readme.md\n|-- scripts\n|   |-- setup_package_script.sql\n|-- snowflake.yml\n```\n\n\u003E`src` - stores all source code including stored procedures, user-defined functions (UDFs), streamlit application and installation script `setup_script.sql`.\n\n\u003E`setup_script.sql` - defines all Snowflake objects used within the application. Runs every time a user installs the application, such as when a Consumer account installs the listing.\n\nHere is a snippet from `setup_script.sql` that shows how a row-access policy limits country sales based on consumer region and role.\n\n```sql\n-- Create Row-Access Policy to limit access by Consumer region using a local mapping table\nCREATE OR REPLACE TABLE app_instance_schema.region_country_map(region STRING, country STRING);\n\nINSERT INTO app_instance_schema.region_country_map\n    VALUES  ('PUBLIC.AZURE_WESTEUROPE','Germany'),\n            ('PUBLIC.AZURE_WESTEUROPE','Spain'),\n            (......);\n\nCREATE OR REPLACE ROW ACCESS POLICY app_instance_schema.country_row_policy\n    AS (country STRING) RETURNS BOOLEAN -\u003E \n    country = 'Canada' \n    OR current_role() IN ('ACCOUNTADMIN','SYSADMIN','SALES_MANAGER_ROLE')\n    OR EXISTS \n    (\n        SELECT 1\n        FROM app_instance_schema.region_country_map map\n        WHERE 1=1\n        AND map.region = current_region()\n        AND map.country = country\n    )\nCOMMENT = 'Policy to limit rows returned based on region';\n\nALTER VIEW app_instance_schema.orders_v\n  ADD ROW ACCESS POLICY app_instance_schema.country_row_policy ON (country);\n```\n\n\u003E`manifest.yml` - defines version metadata, location of artifacts (setup script, streamlit), configuration of logging/tracing.\n\n\u003E`setup_package_script.sql` - shares provider data that is needed by the application, executed when the application package is deployed or upgraded.\n\n\u003E`snowflake.yml` - Snowflake CLI configuration file that contains native app name, location of source code directory, location of package setup script `setup_package_script.sql`\n\n\u003E`frosty_bytes_sis.py` - Streamlit visualization python script that accesses the shared data within the application package.\n\nRefer to the [Getting Started with Native Apps](/en/developers/guides/getting-started-with-native-apps/) Quickstart for more details.\n\n### Create Application Package using Snowflake CLI\n\nNow let's create the Snowflake Application Package from the project files in our repo!\n\nOpen a new terminal at the root of the repository cloned/downloaded from Github and execute the following commands:\n\n```bash\n# verify that 3 account connections exist, with AWS Provider Account as DEFAULT\nsnow connection list\n+-------------------------------------------------------------------------------------------------------------------------------+\n| connection_name        | parameters                                                                              | is_default |\n|------------------------+-----------------------------------------------------------------------------------------+------------|\n| horizon-aws-provider   | {'account': '***orgname-accountname***', 'user': 'horizonadmin', 'password':            | True       |\n|                        | '****', 'warehouse': 'compute_wh', 'role': 'accountadmin'}                              |            |\n| horizon-aws-consumer   | {'account': '**orgname**-horizon_lab_aws_consumer', 'user': 'horizonadmin',             | False      |\n|                        | 'password': '****', 'warehouse': 'compute_wh', 'role': 'accountadmin'}                  |            |\n| horizon-azure-consumer | {'account': '***orgname***-horizon_lab_azure_consumer', 'user': 'horizonadmin',         | False      |\n|                        | 'password': '****', 'warehouse': 'compute_wh', 'role': 'accountadmin'}                  |            |\n+-------------------------------------------------------------------------------------------------------------------------------+\n\nsnow app version create --skip-git-check\n\nsnow sql -q 'ALTER APPLICATION PACKAGE horizon_quickstart_package SET DEFAULT RELEASE DIRECTIVE version=V1 patch=0'\n+---------------------------------------------------------+\n| status                                                  |\n|---------------------------------------------------------|\n| Default release directive set to version 'V1', patch 0. |\n+---------------------------------------------------------+\n```\n\nThe `app version create` command will upload source files to a stage and create the application package.\nSetting the default release version and patch is a required step before the application package can be published in a listing.\nDocumentation for publishing native applications is [here](https://other-docs.snowflake.com/en/native-apps/provider-publishing-app-package#workflow-for-publishing-an-application-package)\n\nYou should now see the **HORIZON_QUICKSTART_PACKAGE** listed under the `Databases` panel in Snowsight.\n\n![HORIZON_QUICKSTART_APP](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/horizon_quickstart_app_pkg.jpg)\n\n### Publish App Package as a Listing targeted at our AWS, Azure Consumer Accounts\n\nReturn to Snowsight and ensure your role is `ACCOUNTADMIN` (check and set if necessary at the bottom left corner)\n\nNavigate to **Provider Studio** (under Data Products) and click on `+ Listing` to author a native app listing.\n\n![Create Listing](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/create-native-app-listing.jpg)\n\nNow select the `HORIZON_QUICKSTART_PACKAGE` and fill in a brief description using the rich text editor.\nYou can use this text to get started, but feel free to get creative!\n\n\u003E _[Tasty Bytes](/en/developers/guides/tasty-bytes-introduction/) is a fictitious global food truck network_\n\u003E _that is on a mission to serve unique food options with high quality items in a safe, convenient and cost effective way._\n\u003E _In order to drive forward on their mission, Tasty Bytes is beginning to leverage the Snowflake Data Cloud._\n\u003E\n\u003E This application provides **Total Sales (USD) by Year** for selected cities in an interactive graphical visualization.\n\u003E The cities available are dependent upon the Consumer account region: only sales for regional cities are shown.\n\u003E Also displayed are the underlying raw sales data and associated SQL query.\n\nAdd 2 Consumer Accounts: `\u003CYOUR-ORGNAME\u003E.HORIZON_LAB_AWS_CONSUMER` and `\u003CYOUR-ORGNAME\u003E.HORIZON_LAB_AZURE_CONSUMER`\n\nThe addition of a consumer account in a different cloud (or region) will reveal the auto-fulfillment panel.\nProvide your email to receive notifications and **Publish**\n\n![Publish Listing](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/create-native-app-listing-detail.jpg)\n\nInitially the auto-fulfillment frequency is set to 1 Day, you can change it to 15 minutes after the listing is published.\n\n![Update Refresh Frequency](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/manage-regions-replication.jpg)\n\n### Install the Tasty Bytes Sales App on Azure Consumer (HORIZON_LAB_AZURE_CONSUMER)\n\nWe are now at the moment of truth! ![snowflake](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/snowflake-icon.jpg)\n\n**Switch to the HORIZON_LAB_AZURE_CONSUMER account**\n\nWith listing auto-fulfillment, replication will only be initiated from Provider AWS region to Consumer Azure region when there is a request.\nNavigate to Snowsight `Data Products -\u003E Private Sharing` to acquire the Tasty Bytes Global Sales application:\n\n![Azure Consumer Listing](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/azure-consumer-listing.jpg)\n\nWhile the application objects are being delivered cross-cloud, we can now switch to the local AWS region consumer and install immediately.\n\n**Switch to the HORIZON_LAB_AWS_CONSUMER account**\n\n![Application Install on AWS](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/aws-install-app.jpg)\n\nOpen the application and while it is spinning up, click on the `Manage Access` button at top-right and give **PUBLIC** access.\n\n![Manage Access](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/native-app-access.jpg)\n\nNow try adding a few cities in addition to _Vancouver_:\n\n![Global Sales AWS-USWEST](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/global-sales-aws-uswest.jpg)\n\nTasty Bytes is sold in 15 countries and 30 cities worldwide.\nConsider these questions and see if you can come up with convincing answers:\n\n  1. What is the query that generates the city list in the Streamlit graph? [Hint: see `frosty_bytes_sis.py`]\n  2. How many cities can be selected? If not all, why not? [Hint: see `setup_script.sql`]\n  3. Try different roles [`ACCOUNTADMIN`,`SALES_MANAGER_ROLE`,`PUBLIC`] - does the city list change?\n\nNow it is time to return to **HORIZON_LAB_AZURE_CONSUMER** and check if auto-fulfillment has completed...\n\nOpen the application and again while it is spinning up, click on the `Manage Access` button to give **PUBLIC** access.\n\nTry adding a few cities in addition to _Vancouver_ as we did with the AWS US West consumer account\n\n![Global Sales Azure-WestEurope](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/global-sales-azure-westeurope.jpg)\n\n  1. Why is the country list different in the Azure West-Europe region (except Vancouver!)?\n  2. Again, does it make any difference with different roles?\n\n```\nStreamlit does not currently allow role-based policies because of security concerns, so only the region mapping in the policy will apply.\n```\n\nTo observe how the row-access policy evaluation of `current_role()` works in an application instance, outside of Streamlit, step through this SQL snippet in a `Worksheet` on the **HORIZON_LAB_AWS_CONSUMER** and **HORIZON_LAB_AZURE_CONSUMER** accounts:\n\n```sql\nUSE APPLICATION TASTY_BYTES_GLOBAL_SALES;\n\nUSE ROLE ACCOUNTADMIN;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\nUSE ROLE SALES_AMERICAS_ROLE;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\nUSE ROLE SALES_APJ_ROLE;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\nUSE ROLE SALES_EMEA_ROLE;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n\nUSE ROLE SALES_MANAGER_ROLE;\nselect distinct primary_city from tasty_bytes_global_sales.app_instance_schema.orders_v;\n```\n\n\u003C!-- ------------------------ --\u003E\n## Share Snowflake-Managed Iceberg Tables\n\n\nIceberg tables in Snowflake combine the performance and query semantics of regular Snowflake tables with external cloud storage managed by the customer. Snowflake supports Iceberg tables that use the Apache Parquet file format.\n\nCreating and writing data into a Snowflake Iceberg table is beyond the scope of this lab; we will focus only on the Consumer side of Iceberg table sharing.\n\nUsing the method outlined in [Getting Started with Iceberg Tables](/en/developers/guides/getting-started-iceberg-tables/) Quickstart, create Iceberg Tables and policies based on what we created in the previous lab section.\n\nOn the `Provider AWS Account` execute the steps listed in `code/sql/reference/iceberg_provider.sql` cloned from [Horizon Quickstart Scripts](https://github.com/Snowflake-Labs/sfguide-horizon-intra-organization-sharing) repository earlier:\n\n1. Create External Volume in Snowflake, after configuring an external volume with your cloud service provider (AWS, Azure, GCP).\n2. Create a `FROSTBYTE_ICEBERG` database with schemas for ANALYTICS, RAW_POS, RAW_CUSTOMER, GOVERNANCE, TPCH.\n3. Create Iceberg Tables `CUSTOMER_LOYALTY_ICEBERG`, `ORDER_HEADER_ICEBERG`, `CUSTOMER_TPCH_ICEBERG`, `NATION_TPCH_ICEBERG`.\n4. Create Secure View `CUSTOMER_LOYALTY_METRICS_V` that joins multiple iceberg tables.\n5. Create Database Roles `TASTYBYTES_MANAGER_ROLE` and `TASTYBYTES_ANALYST_ROLE` to restrict access for consumers.\n6. Create and apply row-access policy `CUSTOMER_COUNTRY_ROW_POLICY` to `CUSTOMER_LOYALTY_ICEBERG.COUNTRY` column that filters based on database role using the `is_database_role_in_session()` context function.\n7. Create a listing called `ICEBERG_LAB_ANALYTICS`, attach iceberg tables and secure view.\n8. In the **Listing Description** section: enter instructions on post-installation steps (see below)\n9. In the **Sample Queries** section: enter queries for the consumer to run\n\nNow switch to the **HORIZON_LAB_AWS_CONSUMER** account.\n\nNavigate to `Private Sharing` in Snowsight and install the `ICEBERG_LAB_ANALYTICS` listing that was shared by the AWS Provider.\nRun these post-installation steps in a worksheet.\n\n```sql\nUSE ROLE accountadmin;\nSHOW DATABASE ROLES IN DATABASE iceberg_lab_analytics;\nGRANT DATABASE ROLE iceberg_lab_analytics.tastybytes_manager_role to ROLE sales_manager_role;\nGRANT DATABASE ROLE iceberg_lab_analytics.tastybytes_analyst_role to ROLE public;\n```\n\nCreate two users to test access controls on the incoming Iceberg Analytics listing.\n\n```sql\nUSE ROLE ACCOUNTADMIN;\n\nCREATE OR REPLACE USER horizonengineer\nPASSWORD='' \nDEFAULT_ROLE = PUBLIC \nMUST_CHANGE_PASSWORD = FALSE \nDEFAULT_WAREHOUSE = COMPUTE_WH;\n\nCREATE OR REPLACE USER horizonmanager\nPASSWORD='' \nDEFAULT_ROLE = SALES_MANAGER_ROLE \nMUST_CHANGE_PASSWORD = FALSE \nDEFAULT_WAREHOUSE = COMPUTE_WH;\n\nGRANT ROLE SALES_MANAGER_ROLE TO USER horizonmanager;\n```\n\nNow run these queries that were entered as **Sample Queries** in the Iceberg listing.\nCompare results as a `horizonengineer` and `horizonmanager` user that leverages the row-access policy to limit sales analytics.\n\n```sql\n// Customer Sales by City\n/*\nTotal food truck sales in USD by city\n*/\nSELECT\n    clm.city,\n    ROUND(SUM(clm.total_sales), 0) AS total_sales_usd\nFROM analytics.customer_loyalty_metrics_v clm\nGROUP BY clm.city\nORDER BY total_sales_usd DESC;\n\n// Total Orders by Gender\n/*\nWhat are the total order amounts in each city by gender?\n*/\nSELECT \n    cl.gender,\n    cl.city,\n    COUNT(oh.order_id) AS count_order,\n    ROUND(SUM(oh.order_amount),0) AS order_total,\n    current_time()\nFROM raw_pos.order_header_iceberg oh\nJOIN raw_customer.customer_loyalty_iceberg cl\n    ON oh.customer_id = cl.customer_id\nGROUP BY ALL\nORDER BY order_total DESC;\n\n// Visible Countries and Cities\n/*\nHow many cities in what countries can I view analytics data for?\n*/\nSELECT DISTINCT COUNTRY, CITY FROM analytics.customer_loyalty_metrics_v ORDER BY COUNTRY;\n;\n\n// TPCH Benchmark - Returned Item Reporting Query (Q10)\n/*\nThe Returned Item Reporting Query finds the top 10 customers, in terms of their effect on lost revenue for a given quarter, who have returned parts. The customers are listed in descending order of lost revenue.\n*/\nSELECT\n     c_custkey,\n     c_name,\n     TRUNCATE(SUM(l_extendedprice * (1 - l_discount))) AS lost_revenue,\n     c_acctbal,\n     n_name,\n     c_address,\n     c_phone,\n     c_comment\nFROM\n     tpch.customer_tpch_iceberg,\n     SNOWFLAKE_SAMPLE_DATA.TPCH_SF100.ORDERS,\n     SNOWFLAKE_SAMPLE_DATA.TPCH_SF100.LINEITEM,\n     tpch.nation_tpch_iceberg\nWHERE\n     c_custkey = o_custkey\n     AND l_orderkey = o_orderkey\n     AND o_orderdate \u003E= to_date('1993-10-01')\n     AND o_orderdate \u003C dateadd(month, 3, to_date('1993-10-01'))\n     AND l_returnflag = 'R'\n     AND c_nationkey = n_nationkey\nGROUP BY\n     c_custkey,\n     c_name,\n     c_acctbal,\n     c_phone,\n     n_name,\n     c_address,\n     c_comment\nORDER BY\n     lost_revenue DESC\nLIMIT 10\n;\n```\n\n\u003C!-- ------------------------ --\u003E\n## Share Unstructured Data\n\n\nWe have previously staged 100 movie reviews extracted from the [IMDB Large Movie Review Dataset](https://ai.stanford.edu/~amaas/data/sentiment/).\n\nDirectory Tables are built-in Snowflake objects that provide an updated, tabular file catalog for staged data that makes it easy to search and lookup files.\n\n```sql\nUSE ROLE sysadmin;\nUSE WAREHOUSE tasty_de_wh;\nUSE SCHEMA frostbyte_tasty_bytes.movie_reviews;\n\nALTER STAGE movie_stage refresh;\nSELECT * FROM DIRECTORY(@movie_stage);\n```\n\nSnowflake offers access to unstructured data through three types of URLs based on the access policy that is required:\n\n1. [Scoped URL](https://docs.snowflake.com/en/sql-reference/functions/build_scoped_file_url.html?_fsi=A9hUbkt2&_fsi=A9hUbkt2): encoded URL to give a user temporary access (currently 24 hours) to a file without giving access to the stage.\n2. [File URL](https://docs.snowflake.com/en/sql-reference/functions/build_stage_file_url.html): requires user authentication with Snowflake and read privileges on the stage.\n3. [Pre-signed URL](https://docs.snowflake.com/en/sql-reference/functions/get_presigned_url.html): pre-authenticated URL that allows download directly from a browser.\n\nWe will use **_Scoped URL_** to share these text files within and across cloud regions. Unlike with data and app sharing, the unstructured data will not be physically replicated cross-cloud.\n\nOn the **AWS Provider Account** open a SQL Worksheet called `Unstructured Data` and execute these commands sequentially:\n\n```sql\nUSE ROLE sysadmin;\nUSE WAREHOUSE tasty_de_wh;\nUSE SCHEMA frostbyte_tasty_bytes.movie_reviews;\n\n-- Here are the 100 review text files: click on any scoped URL to download and view\nSELECT relative_path\n , build_scoped_file_url(@movie_stage, relative_path) as scoped_url\nfrom directory(@movie_stage);\n\n-- Snowpark Python UDF to extract review contents from each file URL\nCREATE FUNCTION extract_review(file_path string)\nRETURNS STRING\nLANGUAGE PYTHON\nRUNTIME_VERSION = '3.8'\nPACKAGES = ('snowflake-snowpark-python')\nHANDLER = 'parse_text_file'\nAS\n$$\n\ndef parse_text_file(file_path):\n    from snowflake.snowpark.files import SnowflakeFile\n    with SnowflakeFile.open(file_path, 'r') as f:\n        lines = [ line.strip() for line in f ]\n        return lines\n$$\n;\n\n-- Share secure view that extracts review contents for the Consumer\nCREATE OR REPLACE SECURE VIEW movie_reviews_v\n    AS\nSELECT relative_path as review_file_name, \n    extract_review(build_scoped_file_url(@movie_stage, relative_path)) as review_content,\n    build_scoped_file_url(@movie_stage, relative_path) as scoped_url\nFROM DIRECTORY(@movie_stage);\n\nSELECT * FROM movie_reviews_v limit 10;\n\n-- Use the SUMMARIZE and SENTIMENT in-built Cortex LLM functions to derive insights from these reviews\nSELECT review_file_name, \nSNOWFLAKE.CORTEX.SUMMARIZE(review_content) as Summary, \nTO_DECIMAL(SNOWFLAKE.CORTEX.SENTIMENT(review_content),3,2) as Sentiment,\nscoped_url\nFROM movie_reviews_v\nORDER BY Sentiment DESC\nLIMIT 10;\n```\n\nNow this secure view can be shared in a private listing targeted at `horizon_lab_aws_consumer` and `horizon_lab_azure_consumer` just as we did in earlier sections with data and apps.\n\nCreate a new listing called `IMDB Movie Reviews` in Provider Studio to publish the review files and content:\n\n- share the `MOVIE_REVIEWS_V` view\n- add a description that includes a link to the highest grossing film of all time: [Avatar](https://www.youtube.com/watch?v=5PSNL1qE6VY) and this link that documents the reference dataset [IMDB Large Movie Review Dataset](https://ai.stanford.edu/~amaas/data/sentiment/)\n- target the two Consumer accounts in AWS and Azure regions\n- include the query that calls `SUMMARIZE` and `SENTIMENT` Cortex LLM functions in the Sample Queries section to make it easy for Consumers\n\n![Listing publish failure](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/horizon-intra-org-sharing/error-publishing-python-function.jpg)\n\n**Publishing Fails** - do you understand why?\n\u003E Hint: `MOVIE_REVIEWS_V` uses a Python UDF for review content extraction, _which can only be shared in a Native App!_\n\nReturn to the `HORIZON_QUICKSTART_PACKAGE` we created in the previous section and publish an update after adding `MOVIE_REVIEWS_V`. Here are the steps:\n\u003E\n\u003E 1. Modify `scripts/setup_package_script.sql`:\n\u003E share the `movie_reviews_v` view similar to how `orders_v` view was handled\n\u003E 2. Modify `app/src/setup_script.sql`:\n\u003E create a proxy view `movie_reviews_v` similar to `orders_v` in `app_instance_schema`\n\u003E grant select on `movie_reviews_v` to the application role `app_instance_role` to make it visible\n\u003E 3. Create a new app version V2 by issuing:\n\u003E `snow app version create V2 --skip-git-check`\n\u003E 4. Set the DEFAULT RELEASE DIRECTIVE to version V2 patch 0\n\u003E `snow sql -q 'ALTER APPLICATION PACKAGE horizon_quickstart_package SET DEFAULT RELEASE DIRECTIVE version=V2 patch=0'`\n\nAnd that is all it takes to upgrade a native app!\n_(here is the [App Upgrade Workflow doc](https://docs.snowflake.com/en/developer-guide/native-apps/versioning#workflow-for-upgrading-an-native-app))_\n\nOn the **AWS Consumer Account** run this in a SQL Worksheet:\n\n```sql\nUSE ROLE ACCOUNTADMIN;\n\n-- install the app upgrade\nALTER APPLICATION TASTY_BYTES_GLOBAL_SALES UPGRADE;\n\nUSE APPLICATION TASTY_BYTES_GLOBAL_SALES;\n\nSELECT * FROM app_instance_schema.movie_reviews_v limit 10;\n\nSELECT review_file_name, \nSNOWFLAKE.CORTEX.SUMMARIZE(review_content) as Summary, \nTO_DECIMAL(SNOWFLAKE.CORTEX.SENTIMENT(review_content),3,2) as Sentiment,\nscoped_url\nFROM app_instance_schema.movie_reviews_v\nORDER BY Sentiment DESC\nLIMIT 10; \n\n-- Use this query to monitor usage of AI Services\n-- Note: this will only populate on a daily basis\nSELECT *\n  FROM snowflake.account_usage.metering_daily_history\n  WHERE SERVICE_TYPE='AI_SERVICES';\n```\n\nTry the same steps on the **Azure Consumer Account**:\n\n\u003E How do you expect the refresh frequency for cross-cloud fulfillment to impact the application upgrade?\n\u003E (documentation on cross-region application upgrades [here](https://docs.snowflake.com/en/developer-guide/native-apps/versioning#upgrade-an-installed-app-across-multiple-regions))\n\n\u003C!-- ------------------------ --\u003E\n## Conclusion & Resources\n\n\nCongratulations, you made it through our Horizon Collaboration journey! You have exercised a broad range of data sharing and governance capabilities. You have worked with different types of data products including structured data, unstructured data, and native applications. And you have deployed different types of governance policies to implement data access and data privacy restrictions.\n\n### What you Learned\n\n- How to blend local Point-of-Sale data with Marketplace Weather data to build analytics data products.\n\n- How to publish data products as Listings targeted at accounts in your company\n- How to configure data access and privacy polices as a data provider to restrict data access by data consumers.\n- How to use tag-based column masking, row-access, aggregation and projection policies with database roles in a collaboration scenario.\n- How to manage Listings via the Listings API.\n- How to setup data quality monitoring of shared data products\n- How to share Iceberg Tables within a cloud region\n- How to share a native application with Streamlit visualization\n- How to share unstructured text files and process with Cortex LLM functions\n\n### Related Resources\n\n- [Lab Source Code on Github](https://github.com/Snowflake-Labs/sfguide-horizon-intra-organization-sharing)\n\n- [Snowflake Listings](https://other-docs.snowflake.com/en/collaboration/collaboration-listings-about) and [Managing Listings via API](https://docs.snowflake.com/en/sql-reference/commands-listings)\n\n- [Cross-cloud Auto-Fulfillment](https://other-docs.snowflake.com/en/collaboration/provider-listings-auto-fulfillment)\n\n- [Data Governance Policies](https://docs.snowflake.com/en/guides-overview-govern) and  [Data Privacy Policies](https://docs.snowflake.com/en/guides-overview-privacy)\n\n- [Data Quality Metrics](https://docs.snowflake.com/en/user-guide/data-quality-intro)\n\n- [Sharing  Data Protected by a Policy](https://docs.snowflake.com/en/user-guide/data-sharing-policy-protected-data)\n- [Iceberg Tables in Snowflake](https://docs.snowflake.com/en/user-guide/tables-iceberg)\n- [Best Practices publishing a Snowflake Native App](https://docs.snowflake.com/en/developer-guide/native-apps/publish-guidelines#best-practices-when-publishing-a-native-app)\n- [Sharing Unstructured Data](https://docs.snowflake.com/en/user-guide/unstructured-data-sharing)\n","multiValue":false,":type":"text/x-markdown"},"quickstartArticleLogoImage":{"dataType":"string","title":"Quickstart Article Logo Image","multiValue":false,":type":"text/plain"}},"elementsOrder":["quickstartArticleBody","quickstartArticleLogoImage"],"model":"snowflake-site/models/quickstart-article"},"flexible_column_cont":{"id":"flexible-column-container-8a4290792d","type":"2-column-75-25","alignColumns":"top","containerMaxWidth":"extra-large","topPadding":"none","bottomPadding":"none","spaceBetween":"none","reverseOnMobile":false,"carouselOnMobile":false,"backgroundImageOption":"none","flexible_column_content_container_1":{"layout":"SIMPLE","id":"container-e6382736d2",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"quickstart_last_modi":{"id":"quickstart-last-modified-10fbda2c45","icon":{"id":"icon","icon":"calendar",":type":"snowflake-site/components/icon","appliedCssClassNames":"snowflake-icon-blue"},"lastModifiedDatePrefix":"Updated","lastModifiedDate":"2025-12-20",":type":"snowflake-site/components/quickstart/quickstart-last-modified","appliedCssClassNames":"snowflake-responsive-component-top-padding-small"},"text":{"id":"text-320ca3ba0d","additionalClasses":"qs-disclaimer-text","text":"\u003Cp\u003E\u003Cspan style=\"color: #666;\"\u003EThis content is provided as is, and is not maintained on an ongoing basis. It may be out of date with current Snowflake instances\u003C/span\u003E\u003C/p\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"snowflake-responsive-component-top-padding-small"}},":itemsOrder":["quickstart_last_modi","text"]},"flexible_column_content_container_2":{"layout":"SIMPLE","id":"container-d16b273d06",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{},":itemsOrder":[]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"}},":itemsOrder":["contentfragment","flexible_column_cont"]},"flexible_column_content_container_2":{"layout":"SIMPLE","id":"container-e36b251ecd",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"quickstart_table_of_":{"layout":"SIMPLE","id":"container-e137fd7e7c","isDeveloperGuidesPage":false,":type":"snowflake-site/components/quickstart/quickstart-table-of-content/quickstart-table-of-content-container",":items":{"quickstart_table_of_":{"id":"quickstart-table-of-content-b725af5a53","fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/horizon-intra-org-sharing",":type":"snowflake-site/components/quickstart/quickstart-table-of-content","headings":["\u003Ch2\u003EOverview\u003C/h2\u003E","\u003Ch2\u003ECitations and Terms of Use\u003C/h2\u003E","\u003Ch2\u003EHorizon AWS Provider Account Setup\u003C/h2\u003E","\u003Ch2\u003EPublish a Data Listing\u003C/h2\u003E","\u003Ch2\u003EListing Management and Monitoring\u003C/h2\u003E","\u003Ch2\u003EProtect Data with Governance Policies\u003C/h2\u003E","\u003Ch2\u003EPublish Listing with Data Quality Metrics\u003C/h2\u003E","\u003Ch2\u003EPublish a Native Application Listing\u003C/h2\u003E","\u003Ch2\u003EShare Snowflake-Managed Iceberg Tables\u003C/h2\u003E","\u003Ch2\u003EShare Unstructured Data\u003C/h2\u003E","\u003Ch2\u003EConclusion & Resources\u003C/h2\u003E"]},"quickstart_button":{"id":"quickstart-button-2fe3df3885","fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/horizon-intra-org-sharing",":type":"snowflake-site/components/quickstart/quickstart-button","appliedCssClassNames":"snowflake-responsive-component-top-padding-none"}},":itemsOrder":["quickstart_table_of_","quickstart_button"]}},":itemsOrder":["quickstart_table_of_"]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"},"markup_editor":{"id":"markup-editor-4eb860bf09","title":"Page CSS","cssContent":"#quickstart-template-main-flexible-container{padding:24px}#quickstart-template-main-flexible-container \u003E .snowflake-flexible-column-container-items{grid-template-columns:1fr 0}.qs-disclaimer-text p \u003E span{font-size:15px !important}@media (min-width:768px){#quickstart-template-main-flexible-container{padding:24px 32px}#quickstart-template-main-flexible-container \u003E .snowflake-flexible-column-container-items{grid-template-columns:7fr 3fr;gap:48px}}@media (max-width:767px){#quickstart-template-main-flexible-container \u003E .snowflake-flexible-column-container-items{gap:0}}@media (min-width:1024px){#quickstart-template-main-flexible-container{padding:0 92px 48px 92px}#quickstart-template-main-flexible-container \u003E .snowflake-flexible-column-container-items{gap:117px}}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"}},":itemsOrder":["quickstart_hero","flexible_column_cont","markup_editor"],":type":"wcm/foundation/components/responsivegrid"},"modal_container":{"layout":"SIMPLE","id":"container-60f774a83d",":type":"snowflake-site/components/modal/modal-container",":items":{},":itemsOrder":[]},"experiencefragment-footer":{"id":"experiencefragment-92c234ea14","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/footer/master/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"additionalClasses":"sf-footer","layout":"SIMPLE","id":"container-0b18b7d77a",":type":"snowflake-site/components/container",":items":{"container_copy":{"additionalClasses":"sf-footer__inner","columnClassNames":{"flexible_column_cont":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-5a9cdc413f",":type":"snowflake-site/components/container",":items":{"flexible_column_cont":{"id":"flexible-column-container-db89050f2c","type":"1-column","alignColumns":"top","containerMaxWidth":"extra-large","topPadding":"medium","bottomPadding":"extra-small","spaceBetween":"small","reverseOnMobile":false,"carouselOnMobile":false,"propertiesCSSClasses":"sf-footer-grid","backgroundImageOption":"none","flexible_column_content_container_1":{"layout":"SIMPLE","id":"container-070c6076b2",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"container":{"additionalClasses":"sf-footer-grid__inner","columnClassNames":{"container":"aem-GridColumn aem-GridColumn--default--12","container_1622723482":"aem-GridColumn aem-GridColumn--default--12","container_copy_copy_":"aem-GridColumn aem-GridColumn--default--12","container_copy_copy":"aem-GridColumn aem-GridColumn--default--12","container_copy":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-3598b6a485",":type":"snowflake-site/components/container",":items":{"container_1622723482":{"additionalClasses":"sf-footer__column","columnClassNames":{"container":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-c64db18be6",":type":"snowflake-site/components/container",":items":{"container":{"additionalClasses":"sf-footer__newsletter-group","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12","marketo_v2":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-986a2986d7",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-dd7bbfadee","additionalClasses":"sf-footer__newsletter-title","text":"\u003Cp\u003E\u003Cb\u003ESubscribe to our monthly newsletter\u003C/b\u003E\u003C/p\u003E\r\n\u003Cp\u003EStay up to date on Snowflake’s latest products, expert insights and resources—right in your inbox!\u003C/p\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-regular text-color-text-04"},"marketo_v2":{"id":"marketo-v2-53cf7f97a1","marketoForm":{"formId":"45871","edit":false,"successUrl":null,"hidden":null,"script":null,"values":null},"formConfigured":true,"marketoConfigured":true,"munchkinId":"252-RFO-227","serverInstance":"252-RFO-227.mktoweb.com",":type":"snowflake-site/components/form/marketo-v2"}},":itemsOrder":["text","marketo_v2"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"}},":itemsOrder":["container"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"},"container":{"columnClassNames":{"text_copy":"aem-GridColumn aem-GridColumn--default--12","text":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-3e37c515b0",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-ece7c2b539","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003EProduct\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/platform/\"\u003EPlatform\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/product/snowflake-cowork/\"\u003ESnowflake CoWork\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/data-engineering/\"\u003EData Engineering\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/analytics/\"\u003EAnalytics\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/ai/\"\u003EAI\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/applications-and-collaboration/\"\u003EApplications &amp; Collaboration\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/pricing-options/\"\u003EPricing\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"},"text_copy":{"id":"text-022236a078","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003ESupport\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/support/\"\u003ESupport\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/legal/addenda/priority-support-services-description/\"\u003EPriority Support\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://status.snowflake.com/\" target=\"_blank\" rel=\"noopener noreferrer\"\u003EStatus\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"}},":itemsOrder":["text","text_copy"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-medium"},"container_copy_copy":{"columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-70c7478a74",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-e9b4882c0c","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003E\u003Ca href=\"/en/solutions/industries/\"\u003EIndustries\u003C/a\u003E\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/advertising-media-entertainment/\"\u003EAdvertising, Media &amp; Entertainment\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/financial-services/\"\u003EFinancial Services\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/healthcare-and-life-sciences/\"\u003EHealthcare &amp; Life Sciences\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/manufacturing/\"\u003EManufacturing\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/public-sector/\"\u003EPublic Sector\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/retail-consumer-goods/\"\u003ERetail &amp; Consumer Goods\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/telecom/\"\u003ETelecom\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/solutions/industries/technology/\"\u003ETechnology\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"}},":itemsOrder":["text"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"},"container_copy":{"columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-fb6a8693e2",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-2a3f2e163d","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003ECompany\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/about-snowflake/\"\u003EAbout Snowflake\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/leadership-and-board/\"\u003ELeadership &amp; Board\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://careers.snowflake.com/us/en\" target=\"_blank\" rel=\"noopener noreferrer\"\u003ECareers\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://investors.snowflake.com/overview/default.aspx\" target=\"_blank\" rel=\"noopener noreferrer\"\u003EInvestor Relations\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://trust.snowflake.com/\" target=\"_blank\" rel=\"noopener noreferrer\"\u003ETrust Center\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/brand-guidelines/\" target=\"_blank\" rel=\"noopener noreferrer\"\u003EBrand Guidelines\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/contact/\"\u003EContact\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/news/\"\u003ENewsroom\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/esg/\"\u003EEnvironmental, Social &amp; Governance\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/snowflake-ventures/\"\u003ESnowflake Ventures\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/end-data-disparity/\"\u003EEnd Data Disparity\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/summit/\"\u003ESnowflake Summit 26\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"}},":itemsOrder":["text"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"},"container_copy_copy_":{"columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-3613233208",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-59e5cdc208","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003ELearn\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://snowflake.com/en/resources/\"\u003EResource Library\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/webinars/demo/\"\u003ELive Demos\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/fundamentals/\"\u003EFundamentals\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/resources/learn/training/\"\u003ETraining\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/resources/learn/certifications/\"\u003ECertifications\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca rel=\"noopener noreferrer\" target=\"_blank\" href=\"https://learn.snowflake.com/en/\"\u003ESnowflake University\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/developers/guides\"\u003EDeveloper Guides\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca rel=\"noopener noreferrer\" target=\"_blank\" href=\"https://docs.snowflake.com/\"\u003EDocumentation\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/data-governance/\"\u003EData Governance\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"}},":itemsOrder":["text"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"}},":itemsOrder":["container_1622723482","container","container_copy_copy","container_copy","container_copy_copy_"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"}},":itemsOrder":["container"]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"}},":itemsOrder":["flexible_column_cont"],"appliedCssClassNames":"snowflake-container snowflake-responsive-container-inner-padding-small"},"container_573483281_":{"additionalClasses":"sf-footer__bottom","columnClassNames":{"container_112062425":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-7b6f1b8706",":type":"snowflake-site/components/container",":items":{"container_112062425":{"columnClassNames":{"flexible_column_cont":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-111693e3eb",":type":"snowflake-site/components/container",":items":{"flexible_column_cont":{"id":"flexible-column-container-ecca099c16","type":"1-column","alignColumns":"top","containerMaxWidth":"extra-large","topPadding":"none","bottomPadding":"none","spaceBetween":"small","reverseOnMobile":false,"carouselOnMobile":false,"backgroundImageOption":"none","flexible_column_content_container_1":{"layout":"SIMPLE","id":"container-5b3ba282f8",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"container":{"additionalClasses":"sf-footer__legal-container","columnClassNames":{"container":"aem-GridColumn aem-GridColumn--default--12","text_copy_copy_16360":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-c373956ebf",":type":"snowflake-site/components/container",":items":{"container":{"columnClassNames":{"image":"aem-GridColumn aem-GridColumn--default--12"},"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-8da3424cf1",":type":"snowflake-site/components/container",":items":{"image":{"id":"image-891be88bef","additionalClasses":"sf-footer__logo","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/footer/master/_jcr_content/root/container_573483281_/container_112062425/flexible_column_cont/flexible_column_content_container_1/container/container/image.coreimg.svg/1747882370694/nav-icon-snowflake-bug.svg","alt":"Snowflake logo","imageLink":{"valid":true,"url":"/en/"},"lazyEnabled":true,":type":"snowflake-site/components/image"}},":itemsOrder":["image"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-extra-small"},"text_copy_copy_16360":{"id":"text-a0fcdf3bff","additionalClasses":"sf-footer__legal-links","text":"\u003Cul\u003E\r\n\u003Cli\u003E© 2026 Snowflake Inc. All Rights Reserved\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/legal/privacy/privacy-policy/\"\u003EPrivacy Policy\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://snowflake.com/en/legal/snowflake-site-terms/\"\u003ESite Terms\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://info.snowflake.com/Preference-center.html\"\u003ECommunication Preferences\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Cbutton id=\"ot-sdk-btn\" class=\"ot-sdk-show-settings\"\u003ECookie Settings\u003C/button\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/legal/privacy/privacy-policy/#12\"\u003EDo Not Share My Personal Information\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/legal/\"\u003ELegal\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"},"markup_editor":{"id":"markup-editor-b51c1cefb0","title":" ","htmlContent":"\u003Cdiv class=\"sf-footer__social\"\u003E\r\n\u003Cdiv data-testid=\"snowflake-footer-twitter\" class=\"snowflake-button-icon snowflake-button-white snowflake-footer-social-item\"\u003E\u003Cdiv class=\"snowflake-button-icon \"\u003E\u003Ca href=\"https://x.com/Snowflake\" data-testid=\"button-external\" aria-label=\"X (Twitter)\" role=\"button\" class=\"snowflake-button-container\" title=\"X (Twitter)\" tabindex=\"0\" target=\"_blank\" rel=\"noreferrer\"\u003E\u003Cdiv data-testid=\"button-icon-wrapper\"\u003E\u003Csvg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 59 53\" class=\"button-icon\"\u003E\u003Cpath fill=\"currentColor\" d=\"M46.614 0h9.044L35.8 22.49 59 53H40.795L26.54 34.46 10.223 53H1.18l21.036-24.055L0 0h18.657l12.878 16.937zM43.45 47.72h5.013L16.023 5.085h-5.387z\"\u003E\u003C/path\u003E\u003C/svg\u003E\u003C/div\u003E\u003C/a\u003E\u003Cdiv\u003E\u003C/div\u003E\u003C/div\u003E\u003C/div\u003E\u003Cdiv data-testid=\"snowflake-footer-linkedin\" class=\"snowflake-button-icon snowflake-button-white snowflake-footer-social-item\"\u003E\u003Cdiv class=\"snowflake-button-icon \"\u003E\u003Ca href=\"https://www.linkedin.com/company/3653845\" data-testid=\"button-external\" aria-label=\"LinkedIn\" role=\"button\" class=\"snowflake-button-container\" title=\"LinkedIn\" tabindex=\"0\" target=\"_blank\" rel=\"noreferrer\"\u003E\u003Cdiv data-testid=\"button-icon-wrapper\"\u003E\u003Csvg xmlns=\"http://www.w3.org/2000/svg\" fill=\"currentColor\" viewBox=\"0 0 24 24\" class=\"button-icon\"\u003E\u003Cpath d=\"M22.223 0H1.772C.792 0 0 .773 0 1.73v20.536C0 23.222.792 24 1.772 24h20.451c.98 0 1.777-.778 1.777-1.73V1.73C24 .773 23.203 0 22.223 0ZM7.12 20.452H3.558V8.995H7.12v11.457ZM5.34 7.434a2.064 2.064 0 1 1 0-4.125 2.063 2.063 0 0 1 0 4.125Zm15.112 13.018h-3.558v-5.57c0-1.326-.024-3.037-1.852-3.037-1.851 0-2.133 1.449-2.133 2.944v5.663H9.356V8.995h3.413v1.566h.047c.473-.9 1.636-1.852 3.365-1.852 3.605 0 4.27 2.372 4.27 5.457v6.286Z\"\u003E\u003C/path\u003E\u003C/svg\u003E\u003C/div\u003E\u003C/a\u003E\u003Cdiv\u003E\u003C/div\u003E\u003C/div\u003E\u003C/div\u003E\u003Cdiv data-testid=\"snowflake-footer-facebook\" class=\"snowflake-button-icon snowflake-button-white snowflake-footer-social-item\"\u003E\u003Cdiv class=\"snowflake-button-icon \"\u003E\u003Ca href=\"https://www.facebook.com/snowflakedb/\" data-testid=\"button-external\" aria-label=\"Facebook\" role=\"button\" class=\"snowflake-button-container\" title=\"Facebook\" tabindex=\"0\" target=\"_blank\" rel=\"noreferrer\"\u003E\u003Cdiv data-testid=\"button-icon-wrapper\"\u003E\u003Csvg xmlns=\"http://www.w3.org/2000/svg\" fill=\"currentColor\" viewBox=\"0 0 24 24\" class=\"button-icon\"\u003E\u003Cpath d=\"M24 12c0-6.627-5.373-12-12-12S0 5.373 0 12c0 5.99 4.388 10.954 10.125 11.854V15.47H7.078V12h3.047V9.356c0-3.007 1.792-4.668 4.533-4.668 1.312 0 2.686.234 2.686.234v2.953H15.83c-1.491 0-1.956.925-1.956 1.875V12h3.328l-.532 3.469h-2.796v8.385C19.612 22.954 24 17.99 24 12Z\"\u003E\u003C/path\u003E\u003C/svg\u003E\u003C/div\u003E\u003C/a\u003E\u003Cdiv\u003E\u003C/div\u003E\u003C/div\u003E\u003C/div\u003E\u003Cdiv data-testid=\"snowflake-footer-youtube\" class=\"snowflake-button-icon snowflake-button-white snowflake-footer-social-item\"\u003E\u003Cdiv class=\"snowflake-button-icon \"\u003E\u003Ca href=\"https://www.youtube.com/user/snowflakecomputing\" data-testid=\"button-external\" aria-label=\"YouTube\" role=\"button\" class=\"snowflake-button-container\" title=\"YouTube\" tabindex=\"0\" target=\"_blank\" rel=\"noreferrer\"\u003E\u003Cdiv data-testid=\"button-icon-wrapper\"\u003E\u003Csvg xmlns=\"http://www.w3.org/2000/svg\" fill=\"currentColor\" viewBox=\"0 0 24 24\" class=\"button-icon\"\u003E\u003Cpath d=\"M23.76 7.2s-.233-1.655-.955-2.381c-.914-.956-1.936-.961-2.405-1.017-3.356-.244-8.395-.244-8.395-.244h-.01s-5.039 0-8.395.244c-.469.056-1.49.06-2.405 1.017C.473 5.545.244 7.2.244 7.2S0 9.145 0 11.086v1.819c0 1.94.24 3.886.24 3.886s.233 1.654.95 2.38c.915.957 2.115.924 2.65 1.027 1.92.183 8.16.24 8.16.24s5.044-.01 8.4-.249c.469-.056 1.49-.06 2.405-1.017.722-.727.956-2.381.956-2.381S24 14.85 24 12.905v-1.819c0-1.94-.24-3.886-.24-3.886ZM9.52 15.113V8.367l6.483 3.385-6.483 3.36Z\"\u003E\u003C/path\u003E\u003C/svg\u003E\u003C/div\u003E\u003C/a\u003E\u003Cdiv\u003E\u003C/div\u003E\u003C/div\u003E\u003C/div\u003E\r\n\u003C/div\u003E","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"}},":itemsOrder":["container","text_copy_copy_16360","markup_editor"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-none"}},":itemsOrder":["container"]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"}},":itemsOrder":["flexible_column_cont"],"appliedCssClassNames":"snowflake-container snowflake-responsive-container-inner-padding-small"}},":itemsOrder":["container_112062425"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-none"},"markup_editor_copy":{"id":"markup-editor-62053b673f","title":"New css","cssContent":".snowflake-image-container img{background-color:transparent}div.snowflake-person-chip-avatar{width:80px !important}#snowflake-blog-template-main-container .aem-GridColumn:has(.vertical-video){background-color:#000;border-radius:16px;overflow:hidden}#snowflake-blog-template-main-container .vertical-video{max-width:240px;margin-left:auto;margin-right:auto}@media screen and (min-width:1367px){.dynamic .heading-1-v2 .snowflake-title-v2-line{font-size:72px !important;line-height:60px !important}}.snowflake-flexible-column-container-items-alignment-match-height .download-card,.snowflake-flexible-column-container-items-alignment-match-height .download-card\u003E.container{height:100%}.download-card div.code-toolbar\u003E.toolbar .copy-to-clipboard-button{background-color:white;border:1px solid #a9e1f6;margin-right:4px;top:6px;border-radius:16px;height:26px;width:40px}.download-card .snowflake-code-snippet\u003Ediv.code-toolbar\u003E.toolbar\u003E.toolbar-item\u003Ebutton:before{content:'';background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='9' y='9' width='13' height='13' rx='2' ry='2' style='stroke:%23249EDC;'%3E%3C/rect%3E%3Cpath d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1' style='stroke:%23249EDC;'%3E%3C/path%3E%3C/svg%3E\");background-size:auto 65%;background-position:center;background-repeat:no-repeat;top:0;left:0;width:100%;height:100%}.download-card .snowflake-code-snippet\u003Ediv.code-toolbar\u003E.toolbar\u003E.toolbar-item\u003Ebutton:hover:before{background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='9' y='9' width='13' height='13' rx='2' ry='2' style='stroke:%23fff;'%3E%3C/rect%3E%3Cpath d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1' style='stroke:%23fff;'%3E%3C/path%3E%3C/svg%3E\")}.download-card\u003Ediv{background-color:#fff;border:1px solid #ccc;border-radius:8px;padding:24px}.download-chip__headline{border-bottom:1px solid #ccc;padding-bottom:16px;margin-bottom:16px}.download-chip{padding:8px 12px !important;border-radius:4px;transition:300ms ease background-color}.download-chip .black-blue-text-color .snowflake-title-v2-line{color:#000 !important;padding-right:24px;font-family:'Lato',sans-serif;font-size:14px !important;font-weight:500 !important}.download-chip .black-blue-text-color .snowflake-title-v2-line:not(:first-child){opacity:.6;font-style:italic !important}.download-chip .snowflake-content-chip-button{display:none}.download-chip.is-external-link{background-size:16px 16px;background-image:url(\"data:image/svg+xml,%3Csvg width='15' height='15' viewBox='0 0 15 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.06055 13.0607L11.8605 2.26067M13.0605 10.6607V1.06067H3.46055' stroke='%23249EDC' stroke-width='2.12132' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A\")}.download-chip{background-image:url(\"data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clip-path='url(%23clip0_883_7979)'%3E%3Cpath d='M3.375 16.875H14.625' stroke='%23249EDC' stroke-width='1.40625' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M9 1.125V11.25' stroke='%23249EDC' stroke-width='1.40625' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M4.5 7.875L9 12.375L13.5 7.875' stroke='%23249EDC' stroke-width='1.40625' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0_883_7979'%3E%3Crect width='18' height='18' fill='white'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A\");background-size:24px auto;background-repeat:no-repeat;background-position:calc(100% - 12px) center}.download-chip__headline{display:flex;gap:16px;flex-direction:row !important;flex-wrap:nowrap}.download-chip__headline::before{content:'';display:inline-block;width:24px;height:24px;background-position:center;background-image:url(\"data:image/svg+xml,%3Csvg width='21' height='21' viewBox='0 0 21 21' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M7.50005 9.89999C8.13657 9.89999 8.74702 9.64713 9.19711 9.19704C9.64719 8.74696 9.90005 8.13651 9.90005 7.49999V2.69999C9.90005 2.06347 9.64719 1.45302 9.19711 1.00293C8.74702 .552844 8.13657 .299988 7.50005 .299988H2.70005C2.06353 .299988 1.45308 .552844 1.00299 1.00293C.552905 1.45302 .300049 2.06347 .300049 2.69999V7.49999C.300049 8.13651 .552905 8.74696 1.00299 9.19704C1.45308 9.64713 2.06353 9.89999 2.70005 9.89999H7.50005ZM7.50005 7.49999H2.70005V2.69999H7.50005V7.49999Z' fill='%23249EDC' stroke='white' stroke-width='.6'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M7.50005 20.3C8.13657 20.3 8.74702 20.0472 9.19711 19.5971C9.64719 19.147 9.90005 18.5365 9.90005 17.9V13.1C9.90005 12.4635 9.64719 11.853 9.19711 11.403C8.74702 10.9529 8.13657 10.7 7.50005 10.7H2.70005C2.06353 10.7 1.45308 10.9529 1.00299 11.403C.552905 11.853 .300049 12.4635 .300049 13.1V17.9C.300049 18.5365 .552905 19.147 1.00299 19.5971C1.45308 20.0472 2.06353 20.3 2.70005 20.3H7.50005ZM7.50005 17.9H2.70005V13.1H7.50005V17.9Z' fill='%23249EDC' stroke='white' stroke-width='.6'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M17.9001 9.89999C18.5366 9.89999 19.147 9.64713 19.5971 9.19704C20.0472 8.74696 20.3001 8.13651 20.3001 7.49999V2.69999C20.3001 2.06347 20.0472 1.45302 19.5971 1.00293C19.147 .552844 18.5366 .299988 17.9001 .299988H13.1001C12.4636 .299988 11.8531 .552844 11.403 1.00293C10.9529 1.45302 10.7001 2.06347 10.7001 2.69999V7.49999C10.7001 8.13651 10.9529 8.74696 11.403 9.19704C11.8531 9.64713 12.4636 9.89999 13.1001 9.89999H17.9001ZM17.9001 7.49999H13.1001V2.69999H17.9001V7.49999Z' fill='%23249EDC' stroke='white' stroke-width='.6'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M17.9001 20.3C18.5366 20.3 19.147 20.0472 19.5971 19.5971C20.0472 19.147 20.3001 18.5365 20.3001 17.9V13.1C20.3001 12.4635 20.0472 11.853 19.5971 11.403C19.147 10.9529 18.5366 10.7 17.9001 10.7H13.1001C12.4636 10.7 11.8531 10.9529 11.403 11.403C10.9529 11.853 10.7001 12.4635 10.7001 13.1V17.9C10.7001 18.5365 10.9529 19.147 11.403 19.5971C11.8531 20.0472 12.4636 20.3 13.1001 20.3H17.9001ZM17.9001 17.9H13.1001V13.1H17.9001V17.9Z' fill='%23249EDC' stroke='white' stroke-width='.6'/%3E%3C/svg%3E%0A\");background-size:contain;background-repeat:no-repeat}.download-chip__headline.is-cli::before{background-image:url(\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 17L10 11L4 5' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M12 19H20' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A\")}.download-card pre[class*=language-]{padding:8px 12px;background-color:var(--ui-background-05);overflow:hidden}.download-chip__headline.is-windows,.download-chip__headline.is-mac{gap:12px}.download-chip__headline.is-windows::before{width:16px;height:20px;background-image:url(\"data:image/svg+xml,%3Csvg width='4875' height='4875' viewBox='0 0 4875 4875' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clip-path='url(%23clip0_122_201)'%3E%3Cpath d='M0 0H2311V2310H0V0ZM2564 0H4875V2310H2564V0ZM0 2564H2311V4875H0V2564ZM2564 2564H4875V4875H2564' fill='%23000'/%3E%3C/g%3E%3C/svg%3E\")}.download-chip__headline.is-mac::before{width:16px;height:20px;background-image:url(\"data:image/svg+xml,%3Csvg version='1.1' id='Layer_1' xmlns:x='ns_extend;' xmlns:i='ns_ai;' xmlns:graph='ns_graphs;' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0' y='0' viewBox='0 0 41.5 51' style='enable-background:new 0 0 41.5 51;' xml:space='preserve'%3E%3Cmetadata%3E%3Csfw xmlns='ns_sfw;'%3E%3Cslices%3E%3C/slices%3E%3CsliceSourceBounds bottomLeftOrigin='true' height='51' width='41.5' x='166.1' y='-208.1'%3E%3C/sliceSourceBounds%3E%3C/sfw%3E%3C/metadata%3E%3Cg%3E%3Cpath d='M40.2,17.4c-3.4,2.1-5.5,5.7-5.5,9.7c0,4.5,2.7,8.6,6.8,10.3c-.8,2.6-2,5-3.5,7.2c-2.2,3.1-4.5,6.3-7.9,6.3s-4.4-2-8.4-2 c-3.9,0-5.3,2.1-8.5,2.1s-5.4-2.9-7.9-6.5C2,39.5,.1,33.7,0,27.6c0-9.9,6.4-15.2,12.8-15.2c3.4,0,6.2,2.2,8.3,2.2 c2,0,5.2-2.3,9-2.3C34.1,12.2,37.9,14.1,40.2,17.4z M28.3,8.1C30,6.1,30.9,3.6,31,1c0-.3,0-.7-.1-1c-2.9,.3-5.6,1.7-7.5,3.9 c-1.7,1.9-2.7,4.3-2.8,6.9c0,.3,0,.6,.1,.9c.2,0,.5,.1,.7,.1C24.1,11.6,26.6,10.2,28.3,8.1z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E\")}.download-chip__headline.is-desktop::before{background-image:url(\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg opacity='.8'%3E%3Cpath d='M1.5 21H22.5V18H1.5V21Z' fill='%23000' stroke='white' stroke-width='.75'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M19.5 15C20.2956 15 21.0587 14.6839 21.6213 14.1213C22.1839 13.5587 22.5 12.7956 22.5 12V6C22.5 5.20435 22.1839 4.44129 21.6213 3.87868C21.0587 3.31607 20.2956 3 19.5 3H4.5C3.70435 3 2.94129 3.31607 2.37868 3.87868C1.81607 4.44129 1.5 5.20435 1.5 6V12C1.5 12.7956 1.81607 13.5587 2.37868 14.1213C2.94129 14.6839 3.70435 15 4.5 15H19.5ZM19.5 12H4.5V6H19.5V12Z' fill='%23000' stroke='white' stroke-width='.75'/%3E%3C/g%3E%3C/svg%3E%0A\")}.download-card .snowflake-code-snippet,.download-card .snowflake-code-snippet code,.download-card .snowflake-code-snippet pre{font-size:14px;color:#000;text-shadow:none !important}.download-chip:hover{background-color:var(--ui-background-05) !important;transition:300ms ease background-color}body:has(.snowflake-skip-to-content[style]) #subNav,.pushdown-banner-dismissed #subNav{top:var(--scroll-padding-top) !important;transition:300ms ease top}body:has(.snowflake-skip-to-content[style*=\"58\"]) #subNav{top:34px !important}body:has(.snowflake-skip-to-content[style*=\"82\"]) #subNav{top:58px !important}body:has(.snowflake-skip-to-content[style*=\"130\"]) #subNav{top:106px !important}body:has(.snowflake-skip-to-content[style*=\"138\"]) #subNav{top:114px !important}body:has(.snowflake-skip-to-content[style*=\"146\"]) #subNav{top:122px !important}.is-hidden .snowflake-person-chip-avatar{display:none}.is-small .snowflake-person-chip-avatar{width:56px;height:56px}.ai-summary ul{margin:16px 0 0 0 !important;padding:0 !important;list-style-type:none}.ai-summary li{margin:0;padding:0 0 0 32px;position:relative}.ai-summary li::before{content:\"\";display:block;border-radius:100%;background:#29b5e8;width:18px;height:18px;position:absolute;top:4px;left:0;border:5px solid #e5f2f7;box-sizing:border-box}.ai-summary li:not(:last-child){margin-bottom:1rem}.snowflake-content-chip-image__image{aspect-ratio:5 / 3 !important}.content-chip-new .snowflake-content-chip-image__image{height:100% !important;aspect-ratio:unset !important}.snapshot-card .snowflake-text p:not(:first-child){margin-top:var(--spacing-01)}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(2) p:has(b){font-family:'Texta',sans-serif;margin-top:24px}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(2) p b{font-weight:700 !important}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(2){border-bottom:1px solid #ccc;padding-bottom:24px}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(3) p:first-child:has(b){font-family:'Texta',sans-serif;font-size:20px !important;margin-bottom:1rem !important}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(3) li{display:inline-block}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(3) li a{display:inline-block;text-decoration:none;padding:4px 16px !important;border:1px solid #ccc;border-radius:24px;color:#666 !important}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(3) ul{list-style-type:none;display:flex;padding:0 !important;margin:0 !important;gap:12px}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container img{width:90%;max-width:240px;margin:0 auto}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container{padding:40px;max-width:450px;margin:0 0 0 auto;background-color:#fff;box-shadow:0 2px 6px 0 rgba(152,162,179,.25),0 10px 20px 0 rgba(152,162,179,.10);border-radius:8px;border-top:4px solid var(--ui-01)}.ai-summary{background-color:#f3fbfe;border-left:2px solid var(--ui-01);padding:40px}.ai-summary\u003Espan p:last-child:has(i){color:#666;font-size:14px !important}.ai-summary\u003Espan p:last-child:has(i) a{color:#666 !important;text-decoration:underline !important}.ai-summary\u003Espan p:last-child:has(i) a:hover{color:var(--ui-01) !Important}.ai-summary\u003Espan p:first-child:has(b)::after{content:'';display:inline-block;width:20px;height:20px;background-image:url(\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M9.3158 3.15226C8.6475 6.2258 6.22698 8.64545 3.15232 9.31587C2.94923 9.36072 2.94923 9.63928 3.15232 9.68413C6.22698 10.3522 8.6475 12.7742 9.3158 15.8477C9.36067 16.0508 9.63933 16.0508 9.6842 15.8477C10.3525 12.7742 12.773 10.3545 15.8477 9.68413C16.0508 9.63928 16.0508 9.36072 15.8477 9.31587C12.773 8.64781 10.3525 6.2258 9.6842 3.15226C9.63933 2.94925 9.36067 2.94925 9.3158 3.15226Z' fill='%23249EDC'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M17.3725 11.5461C16.9098 13.6739 15.2341 15.3491 13.1054 15.8132C12.9649 15.8443 12.9649 16.0371 13.1054 16.0681C15.2341 16.5307 16.9098 18.2074 17.3725 20.3353C17.4035 20.4758 17.5965 20.4758 17.6275 20.3353C18.0902 18.2074 19.7659 16.5323 21.8946 16.0681C22.0352 16.0371 22.0352 15.8443 21.8946 15.8132C19.7659 15.3507 18.0902 13.6739 17.6275 11.5461C17.5965 11.4055 17.4035 11.4055 17.3725 11.5461Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\");background-repeat:no-repeat;background-size:contain;background-position:center;vertical-align:middle;margin-left:8px}.ai-summary\u003Espan p:first-child:has(b){color:var(--ui-01) !important;text-transform:uppercase}.border-top{border-top:1px solid rgba(0,0,0,.2)}.border-top\u003Espan{display:block;padding-top:32px}body .snowflake-card-v2-advanced-image__image{aspect-ratio:16 / 9 !important}.content-chip-new .snowflake-content-chip-image__image{border-radius:0;object-fit:cover;height:100%}.sf-footer #ot-sdk-btn.ot-sdk-show-settings,.sf-footer #ot-sdk-btn.optanon-show-settings{color:rgba(255,255,255,.7) !important;text-underline-offset:4px;border-top:none;border-left:none;border-right:none;border-bottom:1px dotted transparent;background-color:transparent !important;background-image:none !important;transition:300ms ease text-decoration-color;padding:0 !important;font-size:12px;font-family:'Lato',sans-serif}.sf-footer #ot-sdk-btn.ot-sdk-show-settings:hover,.sf-footer #ot-sdk-btn.optanon-show-settings:hover{color:rgba(255,255,255,1) !important;border-bottom:1px dotted var(--ui-01);transition:300ms ease text-decoration-color}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:last-child{flex-shrink:0}.sf-footer__disclaimers{background-color:#042130}.sf-footer__disclaimers .snowflake-simple-stat-disclaimer p a{color:inherit;text-decoration:none !important}.sf-footer__disclaimers .snowflake-simple-stat-disclaimer p sup{margin-right:2px}.sf-footer__disclaimers .snowflake-simple-stat-disclaimer p{text-indent:-5px;padding-left:5px}.sf-footer__disclaimers-inner{border-top:1px solid rgba(255,255,255,.25);padding:40px 0}.sf-footer__disclaimers .snowflake-simple-stat{align-items:flex-start;text-align:left;color:rgba(255,255,255,.7);margin-bottom:10px}.sf-footer__social{display:flex;justify-content:center;gap:12px}.sf-footer .snowflake-footer-social-item{margin:0 !important}.sf-footer .snowflake-footer-social-item a{line-height:0;background-color:rgba(3,24,35,.8);display:inline-block;width:48px !important;height:48px;border-radius:8px;display:inline-flex;justify-content:center;align-items:center;transition:300ms ease background-color}.sf-footer .snowflake-footer-social-item a:hover{background-color:var(--ui-01) !important;transition:300ms ease background-color}.sf-footer__bottom{padding-bottom:40px}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoError .mktoErrorMsg{max-width:100%;color:#fff}.sf-footer .mktoForm .mktoError .mktoErrorMsg .mktoErrorDetail{display:inline-block}.sf-footer .mktoFormRow:has(.mktoHtmlText:empty){display:none}.sf-footer .mktoFormRow .mktoHtmlText span{color:#fff !important}.sf-footer{background-color:#042130}.sf-footer .optanon-toggle-display:hover{text-decoration-color:var(--ui-01) !important;cursor:pointer !important;text-underline-offset:4px;text-decoration-style:dotted !important;text-decoration-color:var(--ui-01);color:#fff !important;transition:300ms ease text-decoration-color;text-decoration:underline;opacity:1}.sf-footer__logo{width:40px}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container{row-gap:32px}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;justify-content:space-between;align-items:center;text-align:center;row-gap:16px}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(2){text-align:center;flex-grow:1}.sf-footer__legal-links li button,.sf-footer__legal-links li a,.sf-footer__legal-links li{margin:0;color:rgba(255,255,255,.7) !important;font-weight:500}.sf-footer__legal-links li a:hover{color:rgba(255,255,255,1) !important}.sf-footer div.sf-footer__copyright p,.sf-footer div.sf-footer__legal-links li,.sf-footer div.sf-footer__legal-links a,.sf-footer div.sf-footer__legal-links p{font-size:12px !important}.sf-footer__legal-links ul{list-style-type:none;margin:0;padding:0;display:flex;gap:20px;row-gap:4px;justify-content:center;flex-wrap:wrap;text-align:center}.sf-footer__legal-links li:last-child{width:100%}.sf-footer .mktoFormRow:has(.mktoPlaceholder),.sf-footer .mktoFormRow:has(input[type=\"hidden\"]){display:none !important}.sf-footer .mktoFormCol{margin-bottom:0 !important}.sf-footer label[for=\"adhoc1\"]{width:auto !important;flex-grow:1;margin-left:16px}.sf-footer .mktoFieldWrap:has(label[for=\"adhoc1\"]){display:flex;flex-direction:row-reverse;margin-top:22px}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoCheckboxList input[type=checkbox]{background-color:transparent !important;border:1px solid rgba(255,255,255,.4) !important;border-radius:4px !important}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoEmailField,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoTelField,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoTextField,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap select{background-color:transparent !important;color:#fff !important;height:auto !important;border:1px solid rgba(255,255,255,.4) !important;border-radius:4px !important;padding:12px 18px !important}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoEmailField:focus,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoTelField:focus,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoTextField:focus,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap select:focus{border-color:var(--ui-01) !important}.sf-footer .mktoForm *{padding:0 !important}.sf-footer .mktoForm,.sf-footer .snowflake-marketo-form-container{padding:0 !important;background:transparent;margin-bottom:0;box-shadow:none}.sf-footer .mktoHtmlText.mktoHasWidth{width:100% !important;margin:24px 0}.sf-footer .mktoFormRow{flex-direction:column}.sf-footer .mktoForm .mktoButtonWrap{margin:0 !important}.sf-footer select{background-image:url(\"data:image/svg+xml,%3Csvg width='14' height='8' viewBox='0 0 14 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M.981445 1.43496L6.90897 7.32496L12.9314 1.33496' stroke='white' stroke-width='1.33333' stroke-miterlimit='10' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A\") !important}.sf-footer .snowflake-marketo-form .mktoButtonWrap.mktoNative{justify-content:flex-start}.sf-footer *::placeholder{color:#fff !important;opacity:.8}.sf-footer .mktoForm .mktoButtonWrap.mktoSimple .mktoButton{background-color:var(--ui-01) !important;color:#fff !important;width:100% !important;padding:12px 16px !important;border:1px solid var(--ui-01) !important;background-image:none !important;border-radius:48px;text-transform:uppercase;font-weight:800 !important;font-family:'Texta',sans-serif !important;font-size:16px !important;line-height:1.2}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoHtmlText\u003Espan,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoLabel\u003Espan,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap label.mktoLabel{color:#fff !important}.sf-footer__newsletter-title p:not(:first-child){margin-top:8px !important}.sf-footer__newsletter-title p b{font-weight:800 !important;font-family:'Texta',sans-serif !important;font-size:22px !important;line-height:1.2}.sf-footer__newsletter-title p:last-child{font-size:14px !important;opacity:.8}.sf-footer__link-group li a[target=\"_blank\"]::after{content:'';display:inline-block;width:10px;height:10px;margin-left:5px;background-image:url(\"data:image/svg+xml,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.72222 1.22222C6.38471 1.22222 6.11111 .948616 6.11111 .611111C6.11111 .273607 6.38471 0 6.72222 0H10.3889C10.551 0 10.7064 .0643867 10.821 .178988C10.9356 .293596 11 .449032 11 .611111V4.27778C11 4.61529 10.7264 4.88889 10.3889 4.88889C10.0514 4.88889 9.77778 4.61529 9.77778 4.27778V2.08647L4.09879 7.76545C3.86013 8.00409 3.4732 8.00409 3.23454 7.76545C2.99589 7.52681 2.99589 7.13986 3.23454 6.90122L8.91355 1.22222H6.72222ZM0 2.44444C0 1.76943 .547207 1.22222 1.22222 1.22222H4.27778C4.61529 1.22222 4.88889 1.49583 4.88889 1.83333C4.88889 2.17084 4.61529 2.44444 4.27778 2.44444H1.22222V9.77778H8.55556V6.72222C8.55556 6.38471 8.82915 6.11111 9.16667 6.11111C9.50418 6.11111 9.77778 6.38471 9.77778 6.72222V9.77778C9.77778 10.4528 9.23059 11 8.55556 11H1.22222C.547207 11 0 10.4528 0 9.77778V2.44444Z' fill='white'/%3E%3C/svg%3E%0A\");background-size:contain;background-repeat:no-repeat;background-position:center}.sf-footer__link-group ul,.sf-footer__link-group li{margin:0;padding:0;list-style-type:none}.sf-footer__link-group ul{margin-top:20px !important}.sf-footer__link-group li{margin-top:15px}.sf-footer div.sf-footer__link-group\u003Espan\u003Ep\u003Ea,.sf-footer div.sf-footer__link-group\u003Espan\u003Ep{color:var(--ui-01) !important;font-weight:800 !important;font-family:'Texta',sans-serif !important;font-size:20px !important;line-height:1.2}.sf-footer__link-group li a{opacity:.9;color:#fff !important;font-weight:500 !important;font-size:15px !important;line-height:1.3}.sf-footer__link-group li a:hover{opacity:1}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container::before,.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container::after{display:none}.sf-footer__column{flex-grow:1}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:first-child){width:50%}@media (min-width:800px){.sf-footer__legal-links ul{justify-content:flex-start;text-align:left}.sf-footer__social{justify-content:flex-end}.sf-footer__legal-links ul{padding-left:24px}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container{text-align:right;flex-wrap:nowrap}.sf-footer__legal-links.align-left ul{justify-content:flex-start}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;justify-content:space-between;flex-direction:row}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto !important;max-width:200px}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{flex-grow:1;order:2;width:100% !important;max-width:none}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto}}@media screen and (min-width:1380px){.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container{flex-wrap:nowrap}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{padding-right:48px;max-width:380px;background-color:rgba(3,24,35,.4);padding:32px;margin-left:48px;border-radius:16px}.sf-footer__link-group li,.sf-footer__link-group li a{font-size:14px !important;line-height:1.3}}@media screen and (max-width:991px){.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{order:2;margin-top:24px !important}}@media screen and (max-width:420px){.is-reduced-mobile .heading-1-v2,.is-reduced-mobile .heading-1-v2-sm{font-size:32px;line-height:28px}}.quote-content-chip{background-color:var(--ui-background-05);padding:24px;border-radius:12px;position:relative}.quote-content-chip .black-blue-text-color .snowflake-title-v2-line\u003Espan{color:rgba(0,0,0,.8) !important;font-size:15px !important;line-height:1.5 !important;font-family:'Lato',sans-serif;font-weight:400 !important}.quote-content-chip .black-blue-text-color .snowflake-title-v2-line\u003Espan:not(:first-child){max-width:calc(100% - 200px)}.quote-content-chip .black-blue-text-color .snowflake-title-v2-line\u003Espan:nth-child(2){font-family:'Texta',sans-serif;color:#000 !important;font-size:20px !important;font-weight:800 !important;margin-top:24px}.quote-content-chip .snowflake-content-chip-image{width:140px !important}@media screen and (min-width:992px){.quote-content-chip .snowflake-content-chip-image{position:absolute !important;bottom:24px;right:16px}}@media screen and (max-width:991px){.quote-content-chip .snowflake-content-chip-image{margin-bottom:40px}.quote-content-chip{flex-direction:column}}#spa-root{background-color:#fff}.lowercase .snowflake-title-v2-line{text-transform:none !important}.centered .snowflake-logo-content-container-inner{justify-content:center}div.snowflake-linklist-dropdown-menu{max-height:380px}.first-line-blue .snowflake-typographyv2 .snowflake-title-v2-line:first-child{color:var(--ui-01) !important}.is-front{position:relative;z-index:2}.use-case-body .snowflake-text h1,.use-case-body .snowflake-text h2,.use-case-body .snowflake-text h3,.use-case-body .snowflake-text h4,.use-case-body .snowflake-text h5,.use-case-body .snowflake-text h6{font-family:'Texta',sans-serif;color:#000;margin:.25rem 0 0 0}.pc-hero .button-group\u003E.container\u003E.cmp-container\u003E.aem-container{justify-content:flex-start}.sf-footer .mktoFormRow .mktoHtmlText span{font-family:'Lato',sans-serif !important}.snowflake-button-primary.snowflake-button-blue .snowflake-button-container{justify-content:center}.related-chip-25{background-color:#fff;border:1px solid rgba(204,204,204,.5);border-radius:8px;padding:20px;position:relative}.related-chip-25:hover{box-shadow:rgba(152,162,179,.1) 0 10px 20px 0}.related-chip-25:hover::after{right:24px;transition:300ms ease right}.related-chip-25::after{content:'';display:block;transition:300ms ease right;background-image:url(\"data:image/svg+xml,%3Csvg width='8' height='14' viewBox='0 0 8 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M7.66699 7C7.66699 6.6571 7.53559 6.32825 7.30169 6.08578L2.34446 .947072C1.84529 .429617 1.0164 .429617 .517219 .947072C.0427878 1.43887 .042788 2.21798 .517219 2.70978L4.65591 7L.51722 11.2902C.0427889 11.782 .0427887 12.5611 .51722 13.0529C1.0164 13.5704 1.84529 13.5704 2.34447 13.0529L7.30169 7.91421C7.53559 7.67175 7.66699 7.34289 7.66699 7Z' fill='%2329B5E8'/%3E%3C/svg%3E%0A\");width:8px;height:14px;display:block;position:absolute;right:30px;top:50%;transform:translateY(-50%);background-size:contain;background-position:center;background-repeat:no-repeat}.related-chip-25 .heading-5-v2{font-size:22px;line-height:1.1}.related-chip-25 .snowflake-content-chip-image{width:48px;flex-shrink:0}.related-chip-25 .snowflake-content-chip-image__image{aspect-ratio:1;height:auto;object-fit:contain}.related-chip-25 .snowflake-content-chip-button{display:none}.related-chip-25 .snowflake-content-chip-content-without-tag{flex-grow:1;padding-right:24px}.case-study-25.small-logo .snowflake-case-study-card-logo img{width:60px !important}.swiper-slide .case-study-25{width:95%;margin-left:auto;margin-right:auto}.case-study-25 .snowflake-case-study-card-logo img{width:140px !important;height:auto !important;transform:none !important;margin:24px 0 8px 0}.case-study-25 .snowflake-case-study-card-image__image{object-position:left center}.case-study-25 .snowflake-case-study-card-information-container{padding-right:24px}.case-study-25 ul{list-style-type:none;padding:0;margin:8px 0 0 0}.case-study-25 li{font-size:15px !important;line-height:1.3 !important;display:flex;flex-direction:column;border-left:4px solid var(--ui-01);padding-left:24px;margin-top:24px;color:#535862;gap:4px}.case-study-25 li b{display:block;font-family:'Texta',sans-serif;font-weight:900 !important;font-size:48px !important;line-height:.9 !important;color:var(--ui-01)}.case-study-25 .snowflake-case-study-card-description p{color:#535862}.case-study-25 .snowflake-case-study-card-description p:nth-child(2):not(:has(a)){color:#000;font-family:Texta;font-size:30px !important;line-height:1 !important;font-style:normal;font-weight:700;text-indent:-8px}.case-study-25.is-story .snowflake-case-study-card-description p:nth-child(2):not(:has(a)){text-indent:0}.case-study-25 .snowflake-case-study-card-key-card{background-color:transparent}.case-study-25 .snowflake-case-study-card-button{display:none}.case-study-25{border-radius:24px;overflow:hidden}@media screen and (min-width:1024px){.case-study-25 .snowflake-case-study-card-left-container{position:static;width:60%;min-height:0}.case-study-25 .snowflake-case-study-card-right-container::after{content:'';display:block;width:60%;max-width:340px;padding-bottom:50%;background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 22 16' class='snowflake-pushdown-banner-placeholder-arrow'%3E%3Cpath fill='%2329B5E8' fill-rule='evenodd' d='M17.865 8.756c.088-.274.124-.555.118-.834a2.551 2.551 0 0 0-1.3-2.142L7.887.76C6.645.055 5.063.475 4.35 1.7a2.535 2.535 0 0 0 .947 3.494l4.916 2.809-4.916 2.801a2.543 2.543 0 0 0-.947 3.502c.713 1.222 2.295 1.64 3.537.934l8.796-5.024a2.541 2.541 0 0 0 1.182-1.46Z' clip-rule='evenodd'%3E%3C/path%3E%3C/svg%3E\");background-size:contain;background-repeat:no-repeat;position:absolute;top:-10%;left:-20%}.case-study-25 .snowflake-case-study-card-right-container{max-width:none;width:40%;position:absolute;top:-5%;right:-5%;z-index:0;height:110%}}@media screen and (min-width:768px){.case-study-25 li{max-width:50%}.case-study-25 ul{display:flex;gap:48px}}.snowflake-text.section-eyebrow p{margin-left:auto;margin-right:auto;margin-bottom:16px !important}.snowflake-text.section-eyebrow p,.snowflake-text.eyebrow-text p{text-transform:uppercase;font-family:'Texta',sans-serif !important;font-weight:800 !important;letter-spacing:.025em;margin-bottom:12px;line-height:1.1 !important}.snowflake-title-v2.dynamic .heading-2-v2 span.snowflake-title-v2-line{font-size:clamp(2.5rem,4.5vw,4rem) !important;line-height:.82 !important}.checklist ul{padding:0;margin:0}.checklist ul li{list-style-type:none;padding-left:32px;position:relative}.checklist ul li:not(:last-child){margin-bottom:1em}.checklist ul li::before{content:'';display:inline-block;width:20px;height:20px;background-image:url(\"data:image/svg+xml,%3Csvg width='24' height='25' viewBox='0 0 24 25' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect y='.985352' width='24' height='24' rx='12' fill='%23D4F0FA'/%3E%3Cpath d='M7.28613 13.2967L10.7147 16.7253L17.5718 9.86816' stroke='%2329B5E8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A\");background-size:contain;background-repeat:no-repeat;position:absolute;top:3px;left:0}.last-line-blue .snowflake-typographyv2 .snowflake-title-v2-line:last-child{color:var(--ui-01)}.snowflake-text p sup{line-height:0}.snowflake-title-v2.lowercase .heading-3-v2{font-size:28px;line-height:1;text-transform:none;font-weight:700}.snowflake-title-v2.lowercase .heading-2-v2{font-size:32px;line-height:1;text-transform:none;font-weight:700}.content-chip-new{border:1px solid rgba(204,204,204,.5);border-radius:16px;overflow:hidden}.content-chip-new .snowflake-image-container{border-radius:0;display:none}.content-chip-new .snowflake-content-chip-image{margin-right:0;max-width:180px;flex-shrink:0}.content-chip-new .snowflake-content-chip-content{padding:24px}.content-chip-new .black-blue-text-color .snowflake-title-v2-line:first-child{font-size:24px;line-height:1.1}.content-chip-new .black-blue-text-color .snowflake-title-v2-line:not(:first-child){font-family:'Lato',sans-serif;font-size:17px;color:#535862 !important;font-weight:500;line-height:1.45;margin-top:8px;display:none}div.snowflake-text a{font-weight:normal;color:var(--ui-01);text-decoration:underline;text-underline-offset:4px;text-decoration-style:dotted !important;text-decoration-color:transparent;transition:300ms ease text-decoration-color}div.snowflake-text a:hover{text-decoration-color:var(--ui-01);transition:300ms ease text-decoration-color}.footer-nav__link-group .snowflake-button-container,.subnav__item--button,.snowflake-card-v2-advanced-button .snowflake-button-container{justify-content:flex-start}.button-container\u003E.container\u003E.cmp-container\u003E.aem-container{align-items:center}.button-container\u003E.container\u003E.cmp-container\u003E.aem-container .snowflake-button-primary+.snowflake-button-link{margin-left:12px !important}.snowflake-button-regular.snowflake-button-link .snowflake-button-container{font-size:18px !important;text-align:left;justify-content:flex-start;line-height:1.4 !important}body .snowflake-card-v2-advanced{border:1px solid rgba(204,204,204,.5);border-radius:var(--spacing-02);transition:300ms ease all}body .snowflake-card-v2-advanced:hover{transform:translateY(-10px);box-shadow:rgba(152,162,179,.1) 0 10px 20px 0;transition:300ms ease all}body .snowflake-card-v2-advanced-inner{border-bottom:none}body .snowflake-card-v2-advanced-image{line-height:0}body .snowflake-card-v2-advanced-image__image{aspect-ratio:16 / 9}body .snowflake-card-v2-advanced-content{position:relative}body .snowflake-card-v2-advanced-content::after{content:'';display:block;position:absolute;bottom:0;left:0;transition:300ms ease all;width:20%;height:4px;background-color:var(--ui-01);opacity:0}body .snowflake-card-v2-advanced:hover .snowflake-card-v2-advanced-content::after{width:100%;opacity:1;transition:300ms ease all}body .snowflake-card-v2-advanced .snowflake-button-link.snowflake-button-blue .snowflake-button-container\u003E.link-icon{transition:300ms ease transform}body .snowflake-card-v2-advanced:hover .snowflake-button-link.snowflake-button-blue .snowflake-button-container\u003E.link-icon{transform:translateX(4px);transition:300ms ease transform}.six-columns\u003E.container\u003E.cmp-container\u003E.aem-container,.three-columns\u003E.container\u003E.cmp-container\u003E.aem-container,.four-columns\u003E.container\u003E.cmp-container\u003E.aem-container,.five-columns\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-wrap:wrap;gap:24px}.six-columns.align-center\u003E.container\u003E.cmp-container\u003E.aem-container,.three-columns.align-center\u003E.container\u003E.cmp-container\u003E.aem-container,.four-columns.align-center\u003E.container\u003E.cmp-container\u003E.aem-container,.five-columns.align-center\u003E.container\u003E.cmp-container\u003E.aem-container{justify-content:center}.three-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:100%;margin:0 !important}.six-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.four-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.five-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(50% - 12px);margin:0 !important}@media screen and (min-width:768px){.three-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(50% - 12px)}.six-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.four-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.five-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(33.333% - 16px)}}@media screen and (min-width:1024px){.snowflake-title-v2.lowercase .heading-3-v2{font-size:34px}.snowflake-title-v2.lowercase.larger .heading-2-v2{font-size:44px;line-height:.95}.three-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(33.333% - 16px)}.four-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(25% - 18px)}.five-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(20% - 19.2px)}.six-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(16.6666% - 20px)}.snowflake-title-v2.lowercase .heading-3-v2{font-size:28px !important}}@media screen and (min-width:1200px){.snowflake-title-v2.lowercase .heading-2-v2{font-size:40px}.content-chip-new .snowflake-content-chip-content{padding:32px}.content-chip-new .snowflake-image-container,.content-chip-new .black-blue-text-color .snowflake-title-v2-line:not(:first-child){display:block}}.promo-banner-25{border-radius:16px;overflow:hidden}.promo-banner-25 .snowflake-premium-content-banner-image-container{position:relative;max-width:380px}.promo-banner-25 .snowflake-text{color:#535862}.promo-banner-25 .snowflake-premium-content-banner-image__image{transform:translateY(8px);transition:300ms ease transform;border-radius:0;width:85%;margin:0 auto;display:block;position:relative;z-index:1}.promo-banner-25 .snowflake-premium-content-banner-image__link:hover .snowflake-premium-content-banner-image__image{transform:translateY(0);transition:300ms ease transform}.promo-banner-25 .snowflake-premium-content-banner-image__inner{height:auto;padding-top:24px}.promo-banner-25 .snowflake-premium-content-banner-image__link{position:relative;z-index:1;height:auto}.promo-banner-25 .snowflake-premium-content-banner-image__link::after{content:'';display:block;position:absolute;clip-path:polygon(0 0,66% 0,100% 100%,0 100%);bottom:0;left:0;width:100%;height:100%;background:var(--ui-01);transition:300ms ease width}.promo-banner-25 .snowflake-premium-content-banner-image__link:hover::after{width:110%;transition:300ms ease width}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap select{background-position:95% 50%}.sf-footer__disclaimers .text-size-small .snowflake-text p{color:#fff !important;font-size:10px !important;opacity:.8}@media screen and (min-width:768px){.sf-footer__disclaimers .text-size-small .snowflake-text p{font-size:12px !important}}@media screen and (max-width:1023px){.mobile-top-padding{padding-top:64px}}@media (max-width:799px){.sf-footer .snowflake-marketo-form .mktoButtonWrap.mktoNative .mktoButton{width:100% !important}.sf-footer__logo{text-align:center;display:block;margin:0 auto}}.customer-card .snowflake-card-v2-advanced-image{aspect-ratio:4.35 / 1}.customer-card .snowflake-card-v2-advanced-image__image{width:100%;height:100%;padding-left:8px;object-fit:contain;object-position:left center;margin:0 !important;aspect-ratio:initial}.customer-card .snowflake-card-v2-advanced-image__inner{height:110px}.customer-card .snowflake-card-v2-advanced-tag-indicator{display:none}.pc-hero .snowflake-container-arrow-small-gray-image{top:-34% !important;width:18% !important}.pc-hero .snowflake-container-arrow-small-gray-image path{fill:var(--ui-01);opacity:1}@media screen and (max-width:767px){.mobile-padding-top{padding-top:64px}.hide-mobile{display:none !important}.pc-hero{padding-top:52px}.pc-hero .snowflake-text p,.pc-hero .left-alignment .snowflake-title-v2-line,.pc-hero h1 span{text-align:center !important}}div.snowflake-pushdown-banner-button{margin-top:0}.button-group.align-center\u003E.container\u003E.cmp-container\u003E.aem-container{align-items:center;justify-content:center !important}.text-center .snowflake-breadcrumb-swiper .swiper-wrapper{justify-content:center}div.snowflake-breadcrumb a.snowflake-breadcrumb-item,.snowflake-breadcrumb div.snowflake-breadcrumb-item{text-transform:none;font-weight:500}.snowflake-breadcrumb svg{display:none !important}.snowflake-breadcrumb a:has(svg)::after{content:'/';margin:0 12px;color:#666}.hide-filters .snowflake-filterable-and-searchable-grid-top-part{display:none !important}.page-section{padding-left:24px;padding-right:24px}@media screen and (min-width:768px){.page-section{padding-left:48px;padding-right:48px}}.download-card pre[class*=language-]{overflow-x:scroll !important}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"}},":itemsOrder":["container_copy","container_573483281_","markup_editor_copy"]}},":itemsOrder":["root"],"classNames":"aem-xf"},"markup_editor":{"id":"markup-editor-3acd8dd2ba","title":"Quickstarts Overrides","cssContent":".snowflake-markdown blockquote{padding:24px 32px;background:#f6f9fa;border:1px solid #29b5e8;border-radius:16px}.snowflake-markdown .snowflake-image-container img{width:auto !important;max-width:100%}.snowflake-markdown .snowflake-text ol{padding-left:20px !important}.snowflake-markdown .snowflake-text li{margin:0 0 12px 0 !important}.snowflake-markdown h3.snowflake-markdown-h3{font-size:20px !important;font-family:Texta,sans-serif !important}@media (min-width:768px){.snowflake-markdown h3.snowflake-markdown-h3{font-size:28px !important}}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"}},":itemsOrder":["experiencefragment-banner","experiencefragment-header","markup_editor_1950346551","responsivegrid","modal_container","experiencefragment-footer","markup_editor"],":type":"wcm/foundation/components/responsivegrid"}},":itemsOrder":["root"],":hierarchyType":"page",":path":"/content/snowflake-site/global/en/developers/guides/horizon-intra-org-sharing","locale":"en",":mappedPath":"/en/developers/guides/horizon-intra-org-sharing/"}
  