{"allowedRenditionsWidth":["320","480","640","768","960","1200","1440","1920"],"templateName":"quickstart-page-template","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"],"cssClassNames":"page basicpage summit-page","clientlibsAsync":false,"dataLayerClientlibIncluded":true,"dataLayerName":"adobeDataLayer","description":"Build an end-to-end enterprise lakehouse platform using Iceberg V3 tables with streaming, variant data, time-series, geospatial analytics, governance, and AI.","lastModifiedDate":1776889791983,"language":"en","title":"Enterprise Lakehouse Platform for Iceberg V3","tags":["snowflake-site:taxonomy/snowflake-feature/snowpipe-streaming","snowflake-site:taxonomy/snowflake-feature/horizon","snowflake-site:taxonomy/product/platform","snowflake-site:taxonomy/snowflake-feature/time-series-functions","snowflake-site:taxonomy/snowflake-feature/interoperable-storage","snowflake-site:taxonomy/snowflake-feature/snowflake-ml-functions","snowflake-site:taxonomy/snowflake-feature/data-lake","snowflake-site:taxonomy/snowflake-feature/geospatial","snowflake-site:taxonomy/snowflake-feature/dynamic-tables","snowflake-site:taxonomy/product/analytics","snowflake-site:taxonomy/product/data-engineering","snowflake-site:taxonomy/snowflake-feature/ingestion","snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/snowflake-feature/transformation","snowflake-site:taxonomy/snowflake-feature/cortex-analyst","snowflake-site:taxonomy/snowflake-feature/lakehouse-analytics","snowflake-site:taxonomy/snowflake-feature/apache-iceberg"],"analyticsPageType":"quickstart-page-template","analyticsCategory":"general","analyticsSubCategory":"","excludeFromAnalytics":false,":hierarchyType":"page",":path":"/content/snowflake-site/global/en/developers/guides/iceberg-v3-tables-comprehensive-guide","analyticsContentTags":["snowflake-site:taxonomy/snowflake-feature/snowpipe-streaming","snowflake-site:taxonomy/snowflake-feature/horizon","snowflake-site:taxonomy/product/platform","snowflake-site:taxonomy/snowflake-feature/time-series-functions","snowflake-site:taxonomy/snowflake-feature/interoperable-storage","snowflake-site:taxonomy/snowflake-feature/snowflake-ml-functions","snowflake-site:taxonomy/snowflake-feature/data-lake","snowflake-site:taxonomy/snowflake-feature/geospatial","snowflake-site:taxonomy/snowflake-feature/dynamic-tables","snowflake-site:taxonomy/product/analytics","snowflake-site:taxonomy/product/data-engineering","snowflake-site:taxonomy/snowflake-feature/ingestion","snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/snowflake-feature/transformation","snowflake-site:taxonomy/snowflake-feature/cortex-analyst","snowflake-site:taxonomy/snowflake-feature/lakehouse-analytics","snowflake-site:taxonomy/snowflake-feature/apache-iceberg"],"analyticsEnabled":true,"isPasswordProtected":false,"coveoConfig":{"pipeline":"snowflake.com","searchHub":"snowflake.com","organizationId":"snowflakecomputingproduction8neljofn","apiKey":"xx335921a6-2a0a-40f2-a167-e390b4766c3d"},"analyticsDebugMode":false,"analyticsData":{"excludeFromAnalytics":false,"subCategory":"","pageType":"quickstart-page-template","templateName":"quickstart-page-template","siteName":"snowflake","pageUrl":"/content/snowflake-site/global/en/developers/guides/iceberg-v3-tables-comprehensive-guide","language":"en","category":"general","pageName":"Enterprise Lakehouse Platform for Iceberg V3","contentTags":["snowflake-site:taxonomy/snowflake-feature/snowpipe-streaming","snowflake-site:taxonomy/snowflake-feature/horizon","snowflake-site:taxonomy/product/platform","snowflake-site:taxonomy/snowflake-feature/time-series-functions","snowflake-site:taxonomy/snowflake-feature/interoperable-storage","snowflake-site:taxonomy/snowflake-feature/snowflake-ml-functions","snowflake-site:taxonomy/snowflake-feature/data-lake","snowflake-site:taxonomy/snowflake-feature/geospatial","snowflake-site:taxonomy/snowflake-feature/dynamic-tables","snowflake-site:taxonomy/product/analytics","snowflake-site:taxonomy/product/data-engineering","snowflake-site:taxonomy/snowflake-feature/ingestion","snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/snowflake-feature/transformation","snowflake-site:taxonomy/snowflake-feature/cortex-analyst","snowflake-site:taxonomy/snowflake-feature/lakehouse-analytics","snowflake-site:taxonomy/snowflake-feature/apache-iceberg"]},":type":"snowflake-site/components/structure/page",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","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"},"columnCount":12,":items":{"experiencefragment-banner":{"id":"experiencefragment-c65d987cec","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/pushdown-banner/master/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"pushdown_banner_copy":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-926c8d09b9",":type":"snowflake-site/components/container",":items":{"pushdown_banner_copy":{"id":"pushdown-banner-2d2463856e","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-64280f8412","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":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"mega_header":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-d0698f01c7",":type":"snowflake-site/components/container",":items":{"markup_editor":{"id":"markup-editor-b0f20b2e7a","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}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false},"mega_header":{"additionalClasses":"heap-nav-header","layout":"SIMPLE","id":"container-dbf4042cdc",":type":"snowflake-site/components/mega-header","appliedCssClassNames":"snowflake-header-container white",":items":{"nav_mega":{"activeItem":"item_1719963657751_c_663444255","id":"tabs-b00ad8cc5c",":type":"snowflake-site/components/nav/nav-mega",":items":{"item_1719963657751_c_663444255":{"id":"nav-dropdown-menu-94ac5ffa0b","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-9883e7ffa5",":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-2e723c9104",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_copy_2_793631646":{"id":"nav-item-efdf18d702","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-6aefd56ab2","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-0d71411fb9","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-8db890506f","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-4610b5ac0d","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-63d1c7437e","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-b1f1741b3e","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-bb0584d636",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_212715":{"id":"nav-item-f56f74ffad","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-5847661b46","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-9a59251c0c","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-cc69f21f38","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-e49b1ca0cf","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-e21a199197",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_660590_1739526127":{"id":"nav-item-1df2038dc3","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-6a8c8842a3","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-035fcb09dd","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-e44eaf851a","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-5e8613c71b","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-6fb423a701",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy":{"id":"nav-item-d3f572f221","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-05ba589571","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-052de48e18","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-b1860345d1","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-3d7b9cbcf7","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-1cc8e8e7e3","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-1e069acaa7",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"navColumnTitle":"INDUSTRIES","numberOfSubColumns":"one-column","minWidth":"280","layout":"SIMPLE","id":"container-8f75618cb3",":type":"snowflake-site/components/nav/nav-column","appliedCssClassNames":"snowflake-responsive-container-inner-padding-extra-small",":items":{"nav_item_copy_361384_2056203141":{"id":"nav-item-cf60fdf6dd","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-61fb46b627","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-a39bab0114","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-2a62f3c55a","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-dd95f0a0d3","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-727103cf29","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-7f3e74a428","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-b8f26bf19c","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-ad5c96efaa","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-09843d5777","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"]},"nav_column_copy":{"navColumnTitle":"DEPARTMENTS","numberOfSubColumns":"one-column","minWidth":"160","layout":"SIMPLE","id":"container-5914ebd4b0",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-9144822a6d","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-722f088730","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-9aed93bd28","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-bde782aeca",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_107772":{"id":"nav-item-877f3d36a7","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy":{"id":"nav-item-69f6a47b26","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","lazyEnabled":true,"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",":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-193dba0b7b",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-3be2350a53","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-01a066084a","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-5b18ff5314","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","lazyEnabled":true,"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",":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-ee6297445c","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-7bae89604b",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"numberOfSubColumns":"one-column","minWidth":"230","maxWidth":"350","layout":"SIMPLE","id":"container-b6ac1f37c0",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_copy_2_793631646":{"id":"nav-item-375a493914","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-4e913a39f7",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-ef0b8d3e42","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_258535199":{"id":"nav-item-d314550a97","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565":{"id":"nav-item-bde8f96f31","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-59802069d8","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565_903555964":{"id":"nav-item-a852d28171","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","lazyEnabled":true,"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",":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-f23672f993","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-624f2d3044",":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-e7bf152bb9",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-8e2613e8fc","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-58688474c1","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-e7f2a0d8f9","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-0610506574","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-bd479f866f",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy":{"id":"nav-item-8238186b55","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-8d45dad6cf","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634_1984107859":{"id":"nav-item-72dbbb15e2","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1438098918":{"id":"nav-item-3eebe03419","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_143809":{"id":"nav-item-6d3a4d5775","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890638":{"id":"nav-item-b621edb654","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_189945":{"id":"nav-item-795f81e35d","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890":{"id":"nav-item-f8b3302a53","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890_930852828":{"id":"nav-item-befe1ff5c7","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","lazyEnabled":true,"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",":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-c79378ff5a","experience_fragment_1":{"id":"experiencefragment-bf7816fbc6","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":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-88142760a9",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-2547e56cbb","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","lazyEnabled":true,"src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--de231e36-6645-4550-abd9-0f8de758ac66/web-dev-day-26-960x540-1x.png?quality=85&preferwebp=true","alt":"dev day","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-9a2e2deff4","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":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-e77a398b1d",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-ff9a5cb9b2","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","lazyEnabled":true,"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?quality=85&preferwebp=true","alt":"roi of gen ai and agents","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-3b511c9140","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":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-1d2969c936",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-abc8538718","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","lazyEnabled":true,"src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--a320b404-dca1-4477-b033-c79708538657/web-startup-2026-960x540.png?quality=85&preferwebp=true","alt":"alt","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-1923a4afcd","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-f120f2e346",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column_copy_copy":{"navColumnTitle":"Build","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-d013fc8554",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-665541a419","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1855651246":{"id":"nav-item-f7f187d7f0","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-a4fbe90585","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","lazyEnabled":true,"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",":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-87963d7097",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-5d4bd120ff","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-e602b46f3d","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy":{"id":"nav-item-bdbf42d4dc","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","lazyEnabled":true,"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",":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-18162a6229",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-32270cf2d8","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","lazyEnabled":true,"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",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1855651246":{"id":"nav-item-20e0c5e1c2","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","lazyEnabled":true,"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",":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-7af3a7f806","experience_fragment_1":{"id":"experiencefragment-d6d27739cc","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":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-0d899cf1d1",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-197446fcbe","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","lazyEnabled":true,"src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--dc7e334a-c38b-4283-b1de-fcf829952eef/nav-promo-first-notebook.jpg?quality=85&preferwebp=true","alt":"alt","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-1160f994eb","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":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-ab762e434c",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-997ad57e49","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","lazyEnabled":true,"src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--14341ced-bc5e-4a29-9762-b7857f6cadfc/nav-promo-northstar.jpg?quality=85&preferwebp=true","alt":"Snowflake Northstar logo","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-08d2b8f456","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-f1fe86d0a8","languageNavItems":[{"title":"English","path":"/en/developers/guides/iceberg-v3-tables-comprehensive-guide/","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-3111423a32","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-8b7b0f395d","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-72b08cf42c","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"]}},":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-308741c132","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}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false},"responsivegrid":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","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"},"columnCount":12,":items":{"quickstart_hero":{"id":"quickstart-hero-dcd2c9049d","quickstartHeroAuthor":"Scott Teal (scottteal)","quickstartHeroFirstSnowflakeFeatureTag":{"tagText":"Apache Iceberg","tagColor":"#29B5E8","tagPath":"/content/cq:tags/snowflake-site/taxonomy/snowflake-feature/apache-iceberg","tagIcon":""},"quickstartHeroForkRepoLink":{"id":"button-8c37d693b3","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://github.com/Snowflake-Labs/sfquickstarts/tree/master/site/sfguides/src/iceberg-v3-tables-comprehensive-guide"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Fork Repo"},"quickstartHeroBreadcrumbs":[{"title":"Enterprise Lakehouse Platform for Iceberg V3","url":"https://www.snowflake.com/content/snowflake-site/global/en/developers/guides/iceberg-v3-tables-comprehensive-guide","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}],"quickstartHeroFirstCertifiedTag":{"tagText":"Quickstart","tagColor":"#29B5E8","tagPath":"/content/cq:tags/snowflake-site/taxonomy/solution-center/certification/quickstart","tagIcon":""},"quickstartHeroTitle":{"lines":["Enterprise Lakehouse Platform for Iceberg V3"],"type":"heading2",":type":"snowflake-site/components/title-v2"},"isDeveloperGuidesPage":false,"fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/iceberg-v3-tables-comprehensive-guide",":type":"snowflake-site/components/quickstart/quickstart-hero"},"flexible_column_cont":{"id":"flexible-column-container-af653b5bbd","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-a69c23db9d",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"contentfragment":{"id":"contentfragment-3198549782","description":"Build an end-to-end enterprise lakehouse platform using Iceberg V3 tables with streaming, variant data, time-series, geospatial analytics, governance, and AI.","paragraphs":["&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EOverview\u003C/h2\u003E\n","\u003Cp\u003EThis comprehensive guide demonstrates how to build a complete data engineering, analytics, and AI platform using Snowflake's Iceberg V3 tables. You'll work with a realistic Smart Fleet IoT Analytics use case that encompasses streaming semi-structured data, JSON log analysis, time-series analytics with nanosecond precision, and geospatial intelligence.\u003C/p\u003E\n","\u003Cp\u003EApache Iceberg V3 tables in Snowflake support the VARIANT data type, enabling efficient storage and querying of semi-structured data while maintaining the open table format's interoperability benefits. Combined with Snowflake's enterprise features for governance, AI/ML, and business continuity, you can build a truly modern lakehouse architecture.\u003C/p\u003E\n","\u003Ch3\u003EUse Case: Smart Fleet IoT Analytics\u003C/h3\u003E\n","\u003Cp\u003EYou'll build an analytics platform for a fleet management company that:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EStreams real-time vehicle telemetry\u003C/strong\u003E - Speed, location, engine diagnostics, fuel consumption as semi-structured VARIANT data\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EIngests maintenance logs\u003C/strong\u003E - JSON-formatted diagnostic reports and service records from cloud storage\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAnalyzes time-series sensor data\u003C/strong\u003E - High-precision timestamp data for trend analysis and forecasting\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EPerforms geospatial analytics\u003C/strong\u003E - Route optimization, geofencing, location-based insights\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EPowers AI agents\u003C/strong\u003E - Natural language querying of fleet analytics via Snowflake CoWork\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EWhat You Will Learn\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003ECreating and managing Iceberg V3 tables with Snowflake Horizon Catalog\u003C/li\u003E\u003Cli\u003EStreaming semi-structured data into VARIANT columns in Iceberg tables using Snowpipe Streaming\u003C/li\u003E\u003Cli\u003EIngesting data from web APIs and batch loading JSON logs\u003C/li\u003E\u003Cli\u003EBuilding declarative transformation pipelines with Dynamic Iceberg Tables, powered by row lineage\u003C/li\u003E\u003Cli\u003EApplying enterprise governance: PII detection, masking policies, data quality\u003C/li\u003E\u003Cli\u003EPerforming time-series analysis, forecasting, and geospatial analytics with Iceberg v3 data types\u003C/li\u003E\u003Cli\u003EEnabling AI agents on Iceberg data with Snowflake CoWork\u003C/li\u003E\u003Cli\u003ESetting up cross-region replication for business continuity on v3 Iceberg tables\u003C/li\u003E\u003Cli\u003EQuerying Iceberg tables from Apache Spark via Iceberg REST API with vended storage credentials and Horizon fine-grained access controls\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EWhat You Will Build\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003E6+ Iceberg V3 tables\u003C/strong\u003E covering streaming events, logs, time-series, and geospatial data\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EDynamic Iceberg Tables\u003C/strong\u003E for automated incremental transformations\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EStreaming pipeline\u003C/strong\u003E using Snowpipe Streaming with Python SDK\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EGovernance framework\u003C/strong\u003E with masking policies and data quality functions\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EML forecasting model\u003C/strong\u003E for predictive maintenance\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESnowflake CoWork agent\u003C/strong\u003E for natural language analytics\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESpark notebooks\u003C/strong\u003E demonstrating interoperability with enforced access controls\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EPrerequisites\u003C/h3\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnowflake Requirements:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ESnowflake account with \u003Ccode\u003EACCOUNTADMIN\u003C/code\u003E role access\u003C/li\u003E\u003Cli\u003EStandard Edition or higher (Enterprise features noted where applicable)\u003C/li\u003E\u003Cli\u003EAbility to create databases, schemas, warehouses, and Iceberg tables\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003ERequired Tools:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/developer-guide/snowflake-cli/installation/installation\"\u003ESnowflake CLI\u003C/a\u003E installed with a \u003Ca href=\"https://docs.snowflake.com/en/developer-guide/snowflake-cli/connecting/specify-credentials\"\u003Econfigured connection\u003C/a\u003E\u003C/li\u003E\u003Cli\u003EPython 3.9+ with pip\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnowflake CLI Connection\u003C/strong\u003E: Before running the setup, configure a connection named \u003Ccode\u003Edefault\u003C/code\u003E:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Esnow connection add --connection-name default --account &lt;your-account&gt; --user &lt;your-user&gt;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFor Snowflake-managed Iceberg storage (default in this lab):\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ENo customer-owned bucket or external volume is required. Snowflake stores Iceberg files using the reserved volume \u003Ccode\u003ESNOWFLAKE_MANAGED\u003C/code\u003E; see \u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage\"\u003ESnowflake storage for Apache Iceberg tables\u003C/a\u003E.\u003C/li\u003E\u003Cli\u003EThis storage option is available on accounts hosted on \u003Cstrong\u003EAWS\u003C/strong\u003E or \u003Cstrong\u003EAzure\u003C/strong\u003E (not Google Cloud).\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOptional &mdash; customer-managed object storage:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EIf you set \u003Ccode\u003EUSE_SNOWFLAKE_STORAGE=false\u003C/code\u003E in \u003Ccode\u003Econfig.env\u003C/code\u003E, you need AWS S3, Google Cloud Storage, or Azure Storage (Blob, ADLS Gen2, or OneLake) and the appropriate IAM roles or service principals.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFor Spark Interoperability Section:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EConda package manager installed (for isolated PySpark environment)\u003C/li\u003E\u003Cli\u003EApache Spark 4.0+ (required for VARIANT support in Iceberg V3)\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: At the time of writing, Spark does not support nanosecond timestamps or geospatial data types in Iceberg tables.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EObjects Created in This Guide\u003C/h3\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EObject Type\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EName\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EPurpose\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EDatabase\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EFLEET_ANALYTICS_DB\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EContains all demo objects\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EWarehouse\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EFLEET_ANALYTICS_WH\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ECompute for all operations\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EIceberg table storage\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ESnowflake-managed (\u003Ccode\u003ESNOWFLAKE_MANAGED\u003C/code\u003E)\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EDefault: Snowflake stores Iceberg files; no external volume object. Optional: customer volume \u003Ccode\u003EFLEET_ICEBERG_VOL\u003C/code\u003E if \u003Ccode\u003EUSE_SNOWFLAKE_STORAGE=false\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EIceberg Table\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EVEHICLE_TELEMETRY_STREAM\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EReal-time streaming events (VARIANT)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EIceberg Table\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EMAINTENANCE_LOGS\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EBatch-loaded JSON logs (VARIANT)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EIceberg Table\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ESENSOR_READINGS\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ETime-series sensor data\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EIceberg Table\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EVEHICLE_LOCATIONS\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EGeospatial vehicle positions\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EIceberg Table\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EVEHICLE_REGISTRY\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EVehicle master data\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EIceberg Table\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EAPI_WEATHER_DATA\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EWeather data from public API (VARIANT)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EDynamic Table\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ETELEMETRY_ENRICHED\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EJoined and enriched telemetry\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EDynamic Table\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EDAILY_FLEET_SUMMARY\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EAggregated fleet analytics\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EMasking Policy\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EPII_MASK\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EMasks sensitive driver information\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EData Metric Function\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ECHECK_VALID_COORDINATES\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EValidates geospatial data\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EStage\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ELOGS_STAGE\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EInternal stage for JSON files\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EExternal Access Integration\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EOPEN_METEO_ACCESS\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EAllows notebook API calls\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENetwork Policy (optional)\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EFLEET_STREAMING_POLICY\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EAllows streaming script connections\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ECortex Agent\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EFLEET_ANALYTICS_AGENT\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENatural language querying of fleet data\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EEnvironment Setup\u003C/h2\u003E\n","\u003Cp\u003EThis section guides you through setting up your environment. The setup is designed to be as simple as possible: clone the repo, configure a few variables, and run the setup script.\u003C/p\u003E\n","\u003Ch3\u003EStep 1: Download the Assets\u003C/h3\u003E\n","\u003Cp\u003EDownload or clone the guide assets from the \u003Ca href=\"https://github.com/Snowflake-Labs/sfquickstarts/tree/master/site/sfguides/src/iceberg-v3-tables-comprehensive-guide/assets\"\u003Eassets folder\u003C/a\u003E:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003E# Clone the sfquickstarts repo and navigate to the assets\ngit clone https://github.com/Snowflake-Labs/sfquickstarts.git\ncd sfquickstarts/site/sfguides/src/iceberg-v3-tables-comprehensive-guide/assets\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003EStep 2: Configure Variables\u003C/h3\u003E\n","\u003Cp\u003EEdit the \u003Ccode\u003Econfig.env\u003C/code\u003E file in the repository root:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003E# Required: Snowflake Account Information\nSNOWFLAKE_ACCOUNT=&quot;your_account_identifier&quot;\nSNOWFLAKE_USER=&quot;your_username&quot;\nSNOWFLAKE_ROLE=&quot;ACCOUNTADMIN&quot;\nSNOWFLAKE_WAREHOUSE=&quot;FLEET_ANALYTICS_WH&quot;\nSNOWFLAKE_DATABASE=&quot;FLEET_ANALYTICS_DB&quot;\n\n# Iceberg storage &mdash; default is Snowflake-managed (no bucket or external volume).\n# See: https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage\nUSE_SNOWFLAKE_STORAGE=true\n\n# --- Only if USE_SNOWFLAKE_STORAGE=false (customer-managed storage) ---\n# OPTION A: Use an existing external volume\nUSE_EXISTING_VOLUME=false\nEXISTING_VOLUME_NAME=&quot;&quot;\n\n# OPTION B: Create a new external volume named FLEET_ICEBERG_VOL\nSTORAGE_PROVIDER=&quot;S3&quot;  # Options: S3, GCS, AZURE\n\n# --- AWS S3 ---\nS3_BUCKET_NAME=&quot;your-bucket-name&quot;\nS3_PATH=&quot;iceberg/fleet-analytics/&quot;\nAWS_ROLE_ARN=&quot;&quot;  # Your IAM role ARN (see AWS S3 Setup below)\n\n# --- Google Cloud Storage ---\nGCS_BUCKET_NAME=&quot;your-bucket-name&quot;\nGCS_PATH=&quot;iceberg/fleet-analytics/&quot;\n\n# --- Azure Storage (Blob, ADLS Gen2, or OneLake) ---\n# See: https://docs.snowflake.com/en/user-guide/tables-iceberg-configure-external-volume-azure\nAZURE_TENANT_ID=&quot;your-tenant-id&quot;\nAZURE_STORAGE_ACCOUNT=&quot;your-storage-account&quot;\nAZURE_CONTAINER=&quot;your-container&quot;\nAZURE_PATH=&quot;iceberg/fleet-analytics/&quot;\n# For OneLake, set USE_ONELAKE=true and provide workspace/lakehouse GUIDs\nUSE_ONELAKE=false\nONELAKE_WORKSPACE_GUID=&quot;&quot;\nONELAKE_LAKEHOUSE_GUID=&quot;&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003EStep 3: Run Setup Script\u003C/h3\u003E\n","\u003Cp\u003EThe setup script will create all necessary Snowflake objects.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003E# Make the script executable\nchmod +x setup.sh\n\n# Run the setup\n./setup.sh\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EWhat the setup script does:\u003C/strong\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ECreates the database, schema, and warehouse\u003C/li\u003E\u003Cli\u003ESets Iceberg storage to Snowflake-managed by default (\u003Ccode\u003ESNOWFLAKE_MANAGED\u003C/code\u003E), or creates/uses a customer external volume when \u003Ccode\u003EUSE_SNOWFLAKE_STORAGE=false\u003C/code\u003E\u003C/li\u003E\u003Cli\u003ECreates all Iceberg V3 tables with appropriate schemas\u003C/li\u003E\u003Cli\u003ECreates Dynamic Iceberg Tables for transformation pipelines\u003C/li\u003E\u003Cli\u003ECreates governance objects (masking policies, data quality functions) - \u003Cem\u003EEnterprise edition only\u003C/em\u003E\u003C/li\u003E\u003Cli\u003EUploads sample JSON log files to the internal stage\u003C/li\u003E\u003Cli\u003ECreates the Snowflake CoWork agent configuration\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003EStep 4: Import the Snowflake Notebook\u003C/h3\u003E\n","\u003Cp\u003EImport the pre-populated notebook into Snowflake to follow along with the live demo:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ESign in to \u003Ca href=\"https://app.snowflake.com\"\u003ESnowsight\u003C/a\u003E\u003C/li\u003E\u003Cli\u003EIn the navigation menu, select \u003Cstrong\u003EProjects &raquo; Notebooks\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EClick the down arrow next to \u003Cstrong\u003E+ Notebook\u003C/strong\u003E and select \u003Cstrong\u003EImport .ipynb file\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003ENavigate to the cloned repository and select \u003Ccode\u003Eassets/fleet_analytics_notebook.ipynb\u003C/code\u003E\u003C/li\u003E\u003Cli\u003EIn the import dialog:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ENotebook location\u003C/strong\u003E: Select \u003Ccode\u003EFLEET_ANALYTICS_DB\u003C/code\u003E and \u003Ccode\u003ERAW\u003C/code\u003E schema\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EQuery warehouse\u003C/strong\u003E: Select \u003Ccode\u003EFLEET_ANALYTICS_WH\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003ECreate\u003C/strong\u003E to import the notebook\u003C/li\u003E\u003C/ol\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: The notebook is pre-configured with SQL and Python cells that should import with the correct cell types.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EAfter importing\u003C/strong\u003E, enable external API access for the weather data section:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EClick \u003Cstrong\u003ENotebook settings\u003C/strong\u003E (⋮ icon, top right)\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EExternal access\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EToggle ON \u003Cstrong\u003EOPEN_METEO_ACCESS\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003ESave\u003C/strong\u003E\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EFor more details on creating notebooks, see \u003Ca href=\"https://docs.snowflake.com/en/user-guide/ui-snowsight/notebooks-create#create-a-new-notebook\"\u003ECreate a notebook\u003C/a\u003E.\u003C/p\u003E\n","\u003Ch3\u003EExternal volume setup (customer-managed storage only)\u003C/h3\u003E\n","\u003Cp\u003EWith the default \u003Ccode\u003EUSE_SNOWFLAKE_STORAGE=true\u003C/code\u003E, Iceberg tables use \u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage\"\u003ESnowflake storage for Apache Iceberg tables\u003C/a\u003E (\u003Ccode\u003EEXTERNAL_VOLUME = 'SNOWFLAKE_MANAGED'\u003C/code\u003E). You can skip this entire subsection.\u003C/p\u003E\n","\u003Cp\u003EIf you set \u003Ccode\u003EUSE_SNOWFLAKE_STORAGE=false\u003C/code\u003E, Iceberg tables use a \u003Cstrong\u003Ecustomer-managed external volume\u003C/strong\u003E pointing to your object storage. Configure \u003Ccode\u003Econfig.env\u003C/code\u003E (existing volume or new \u003Ccode\u003EFLEET_ICEBERG_VOL\u003C/code\u003E via \u003Ccode\u003ESTORAGE_PROVIDER\u003C/code\u003E) and complete provider-specific setup before running \u003Ccode\u003Esetup.sh\u003C/code\u003E.\u003C/p\u003E\n","\u003Cp\u003EYou can also create external volumes from Snowflake's web UI by navigating to \u003Cstrong\u003ECatalog &gt; External data &gt; External volumes tab\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/create_external_volume.png?v=8cbd55b6\" alt=\"Create External Volume\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EAWS S3 Setup:\u003C/strong\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ECreate an IAM policy granting Snowflake access to your S3 bucket:\u003C/li\u003E\u003C/ol\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-json\"\u003E{\n    &quot;Version&quot;: &quot;2012-10-17&quot;,\n    &quot;Statement&quot;: [\n        {\n            &quot;Effect&quot;: &quot;Allow&quot;,\n            &quot;Action&quot;: [\n                &quot;s3:GetObject&quot;,\n                &quot;s3:GetObjectVersion&quot;,\n                &quot;s3:PutObject&quot;,\n                &quot;s3:DeleteObject&quot;,\n                &quot;s3:ListBucket&quot;,\n                &quot;s3:GetBucketLocation&quot;\n            ],\n            &quot;Resource&quot;: [\n                &quot;arn:aws:s3:::your-bucket-name/*&quot;,\n                &quot;arn:aws:s3:::your-bucket-name&quot;\n            ]\n        }\n    ]\n}\n\u003C/code\u003E\u003C/pre\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003ECreate an IAM role with this policy and update the trust relationship after running \u003Ccode\u003EDESCRIBE EXTERNAL VOLUME\u003C/code\u003E to get the Snowflake AWS IAM user ARN.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cstrong\u003EGCS Setup:\u003C/strong\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ECreate a Cloud Storage service account\u003C/li\u003E\u003Cli\u003EGrant \u003Ccode\u003Estorage.objectAdmin\u003C/code\u003E role on your bucket\u003C/li\u003E\u003Cli\u003EAfter running \u003Ccode\u003EDESCRIBE EXTERNAL VOLUME\u003C/code\u003E, grant the Snowflake service account access\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cstrong\u003EAzure Setup:\u003C/strong\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ECreate an Azure AD application registration\u003C/li\u003E\u003Cli\u003EGrant \u003Ccode\u003EStorage Blob Data Contributor\u003C/code\u003E role on your container\u003C/li\u003E\u003Cli\u003EConfigure the application for Snowflake access\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EThe setup script will provide specific instructions for your chosen provider.\u003C/p\u003E\n","\u003Ch3\u003EVerify Setup\u003C/h3\u003E\n","\u003Cp\u003EAfter running the setup script, verify everything was created:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Connect to Snowflake and run:\nUSE DATABASE FLEET_ANALYTICS_DB;\nSHOW ICEBERG TABLES;\nSHOW DYNAMIC TABLES;\nSHOW MASKING POLICIES;\nSHOW DATA METRIC FUNCTIONS;\nLIST @LOGS_STAGE;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EYou should see all the Iceberg tables, dynamic tables, and governance objects listed.\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EStreaming and Ingest\u003C/h2\u003E\n","\u003Cp\u003EThis section demonstrates various methods Snowflake supports for loading semi-structured data into Iceberg V3 tables with the VARIANT data type.\u003C/p\u003E\n","\u003Ch3\u003ESnowpipe Streaming: Real-Time Vehicle Telemetry\u003C/h3\u003E\n","\u003Cp\u003ESnowpipe Streaming enables low-latency ingestion of streaming data directly into Iceberg tables. The high-performance architecture provides sub-second latency for getting data queryable in Snowflake.\u003C/p\u003E\n","\u003Ch4\u003EReview the Streaming Target Table\u003C/h4\u003E\n","\u003Cp\u003EThe setup script created an Iceberg table designed to receive streaming telemetry:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE DATABASE FLEET_ANALYTICS_DB;\n\n-- View the table structure\nDESCRIBE TABLE VEHICLE_TELEMETRY_STREAM;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Confirm the table exists but is empty\nSELECT COUNT(*) FROM VEHICLE_TELEMETRY_STREAM;\n-- Returns: 0\n\n-- View the table properties showing it's an Iceberg V3 table with VARIANT column\nSELECT \n    GET_DDL('TABLE', 'VEHICLE_TELEMETRY_STREAM');\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EYou'll see a VARIANT column called \u003Ccode\u003ETELEMETRY_DATA\u003C/code\u003E designed to hold the flexible schema vehicle telemetry payload.\u003C/p\u003E\n","\u003Ch4\u003EStart the Streaming Simulation\u003C/h4\u003E\n","\u003Cp\u003EOpen a terminal and navigate to the cloned repository:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Ecd iceberg-v3-tables-comprehensive-guide/assets\n\n# Activate the Python environment (created by setup.sh)\nsource iceberg_v3_demo_venv/bin/activate\n\n# Start the streaming simulation (runs for 5 minutes max)\npython stream_telemetry.py\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETroubleshooting Connection Issues\u003C/strong\u003E: If you're on a VPN or corporate network and get connection errors, you may need a network policy to allow inbound connections. Set \u003Ccode\u003EENABLE_NETWORK_POLICY=true\u003C/code\u003E in \u003Ccode\u003Econfig.env\u003C/code\u003E and re-run setup, or manually run \u003Ccode\u003E08_network_policy.sql\u003C/code\u003E in Snowsight, then apply the policy to your user:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER USER &lt;your_username&gt; SET NETWORK_POLICY = FLEET_STREAMING_POLICY;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EThe Python script uses the Snowpipe Streaming SDK to simulate vehicle telemetry events:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003E# Example of what the streaming script sends\n{\n    &quot;vehicle_id&quot;: &quot;VH-2847&quot;,\n    &quot;event_timestamp&quot;: &quot;2026-02-03T14:32:15.847293847&quot;,  # Nanosecond precision\n    &quot;telemetry_data&quot;: {\n        &quot;location&quot;: {&quot;lat&quot;: 37.7749, &quot;lon&quot;: -122.4194},\n        &quot;speed_mph&quot;: 65.3,\n        &quot;heading&quot;: 285,\n        &quot;engine&quot;: {\n            &quot;rpm&quot;: 3200,\n            &quot;temperature_f&quot;: 195,\n            &quot;oil_pressure_psi&quot;: 42,\n            &quot;fuel_level_pct&quot;: 67.5\n        },\n        &quot;diagnostics&quot;: {\n            &quot;check_engine&quot;: false,\n            &quot;tire_pressure_warning&quot;: false,\n            &quot;codes&quot;: []\n        },\n        &quot;driver_behavior&quot;: {\n            &quot;hard_acceleration_count&quot;: 2,\n            &quot;hard_brake_count&quot;: 1,\n            &quot;sharp_turn_count&quot;: 0\n        }\n    }\n}\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EObserve Data Flowing In\u003C/h4\u003E\n","\u003Cp\u003EWhile the streaming script runs, watch data appear in Snowflake:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Check current count of streaming events\nSELECT COUNT(*) AS event_count FROM VEHICLE_TELEMETRY_STREAM;\n\n-- View the latest streaming events with VARIANT extraction\nSELECT \n    VEHICLE_ID,\n    EVENT_TIMESTAMP,\n    TELEMETRY_DATA:location:lat::FLOAT AS latitude,\n    TELEMETRY_DATA:location:lon::FLOAT AS longitude,\n    TELEMETRY_DATA:speed_mph::FLOAT AS speed_mph,\n    TELEMETRY_DATA:engine:temperature_f::INT AS engine_temp,\n    TELEMETRY_DATA:engine:fuel_level_pct::FLOAT AS fuel_level\nFROM VEHICLE_TELEMETRY_STREAM\nORDER BY EVENT_TIMESTAMP DESC\nLIMIT 10;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThe streaming data is immediately queryable with full SQL capabilities on the VARIANT column!\u003C/p\u003E\n","\u003Ch3\u003EPull from a Web API: Weather Data\u003C/h3\u003E\n","\u003Cp\u003EInstead of multi-step file-based ingestion, Snowflake can connect directly to web APIs and ingest semi-structured responses into Iceberg tables with VARIANT.\u003C/p\u003E\n","\u003Ch4\u003EEnable External Access in Your Notebook\u003C/h4\u003E\n","\u003Cp\u003ESnowflake Notebooks require an \u003Cstrong\u003EExternal Access Integration\u003C/strong\u003E to call external APIs. The setup script created an integration for the Open-Meteo weather API.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EBefore running the Python cell:\u003C/strong\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EIn your Snowflake Notebook, click the \u003Cstrong\u003ENotebook settings\u003C/strong\u003E (⋮ icon, top right)\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EExternal access\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EToggle ON \u003Cstrong\u003EOPEN_METEO_ACCESS\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003ESave\u003C/strong\u003E\u003C/li\u003E\u003C/ol\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: If you don't see \u003Ccode\u003EOPEN_METEO_ACCESS\u003C/code\u003E, run this SQL first:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ECREATE OR REPLACE NETWORK RULE FLEET_ANALYTICS_DB.RAW.OPEN_METEO_NETWORK_RULE\n    MODE = EGRESS TYPE = HOST_PORT VALUE_LIST = ('api.open-meteo.com:443');\nCREATE OR REPLACE EXTERNAL ACCESS INTEGRATION OPEN_METEO_ACCESS\n    ALLOWED_NETWORK_RULES = (FLEET_ANALYTICS_DB.RAW.OPEN_METEO_NETWORK_RULE) ENABLED = TRUE;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EView the Target Table\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- The table was created during setup\nDESCRIBE TABLE API_WEATHER_DATA;\n\n-- Confirm it's empty\nSELECT COUNT(*) AS current_count FROM API_WEATHER_DATA;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003ECreate and Run the API Ingestion Function\u003C/h4\u003E\n","\u003Cp\u003EIn your Snowflake Notebook (or worksheet), create a Python function to fetch weather data:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003E# This is pre-populated in the Snowflake Notebook\nimport snowflake.snowpark as snowpark\nfrom snowflake.snowpark.functions import col, parse_json, current_timestamp\nimport requests\n\ndef fetch_weather_data(session: snowpark.Session, cities: list) -&gt; str:\n    &quot;&quot;&quot;\n    Fetches weather data from Open-Meteo API and loads into Iceberg table.\n    Open-Meteo is a free, open-source weather API requiring no API key.\n    &quot;&quot;&quot;\n    \n    weather_records = []\n    \n    for city in cities:\n        # Using Open-Meteo free API\n        url = f&quot;https://api.open-meteo.com/v1/forecast&quot;\n        params = {\n            &quot;latitude&quot;: city[&quot;lat&quot;],\n            &quot;longitude&quot;: city[&quot;lon&quot;],\n            &quot;current&quot;: &quot;temperature_2m,wind_speed_10m,precipitation&quot;,\n            &quot;hourly&quot;: &quot;temperature_2m,precipitation_probability&quot;\n        }\n        \n        response = requests.get(url, params=params)\n        if response.status_code == 200:\n            weather_records.append({\n                &quot;city_name&quot;: city[&quot;name&quot;],\n                &quot;latitude&quot;: city[&quot;lat&quot;],\n                &quot;longitude&quot;: city[&quot;lon&quot;],\n                &quot;api_response&quot;: response.text,\n                &quot;fetched_at&quot;: datetime.now().isoformat()\n            })\n    \n    # Create DataFrame and write to Iceberg table\n    df = session.create_dataframe(weather_records)\n    df = df.with_column(&quot;WEATHER_DATA&quot;, parse_json(col(&quot;API_RESPONSE&quot;)))\n    df.select(\n        col(&quot;CITY_NAME&quot;),\n        col(&quot;LATITUDE&quot;),\n        col(&quot;LONGITUDE&quot;), \n        col(&quot;WEATHER_DATA&quot;),\n        current_timestamp().alias(&quot;INGESTED_AT&quot;)\n    ).write.mode(&quot;append&quot;).save_as_table(&quot;API_WEATHER_DATA&quot;)\n    \n    return f&quot;Loaded weather data for {len(weather_records)} cities&quot;\n\n# Define cities for fleet operations\nfleet_cities = [\n    {&quot;name&quot;: &quot;San Francisco&quot;, &quot;lat&quot;: 37.7749, &quot;lon&quot;: -122.4194},\n    {&quot;name&quot;: &quot;Los Angeles&quot;, &quot;lat&quot;: 34.0522, &quot;lon&quot;: -118.2437},\n    {&quot;name&quot;: &quot;Seattle&quot;, &quot;lat&quot;: 47.6062, &quot;lon&quot;: -122.3321},\n    {&quot;name&quot;: &quot;Denver&quot;, &quot;lat&quot;: 39.7392, &quot;lon&quot;: -104.9903},\n    {&quot;name&quot;: &quot;Chicago&quot;, &quot;lat&quot;: 41.8781, &quot;lon&quot;: -87.6298}\n]\n\n# Execute the function\nresult = fetch_weather_data(session, fleet_cities)\nprint(result)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EQuery the Weather Data\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- View the loaded weather data\nSELECT \n    CITY_NAME,\n    WEATHER_DATA:current:temperature_2m::FLOAT AS current_temp_c,\n    WEATHER_DATA:current:wind_speed_10m::FLOAT AS wind_speed_kmh,\n    WEATHER_DATA:current:precipitation::FLOAT AS precipitation_mm,\n    INGESTED_AT\nFROM API_WEATHER_DATA;\n\n-- Extract hourly forecast for a city\nSELECT \n    CITY_NAME,\n    f.value::FLOAT AS hourly_temp\nFROM API_WEATHER_DATA,\nLATERAL FLATTEN(input =&gt; WEATHER_DATA:hourly:temperature_2m) f\nWHERE CITY_NAME = 'San Francisco'\nLIMIT 24;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETip\u003C/strong\u003E: This ingestion pattern can be orchestrated natively in Snowflake using \u003Ca href=\"https://docs.snowflake.com/en/user-guide/tasks-intro\"\u003ETasks\u003C/a\u003E or \u003Ca href=\"https://docs.snowflake.com/en/user-guide/tasks-serverless\"\u003EServerless Tasks\u003C/a\u003E for scheduled API pulls.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EBatch Ingest JSON Logs\u003C/h3\u003E\n","\u003Cp\u003ESnowflake handles batch or continuous ingestion of semi-structured data stored in files, such as JSON diagnostic logs.\u003C/p\u003E\n","\u003Ch4\u003EView the Staged Files\u003C/h4\u003E\n","\u003Cp\u003EThe setup script uploaded 10 sample JSON files mimicking maintenance diagnostic logs:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- List the staged JSON files\nLIST @LOGS_STAGE;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EYou should see files like:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003Emaintenance_log_001.json\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003Emaintenance_log_002.json\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E... through \u003Ccode\u003Emaintenance_log_010.json\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch4\u003ELoad JSON Logs into Iceberg Table\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Load JSON files into Iceberg table\nCOPY INTO MAINTENANCE_LOGS (LOG_ID, VEHICLE_ID, LOG_TIMESTAMP, LOG_DATA, SOURCE_FILE)\nFROM (\n    SELECT \n        $1:log_id::VARCHAR,\n        $1:vehicle_id::VARCHAR,\n        $1:log_timestamp::TIMESTAMP_NTZ,\n        $1,\n        METADATA$FILENAME\n    FROM @LOGS_STAGE\n)\nFILE_FORMAT = (TYPE = 'JSON' STRIP_OUTER_ARRAY = TRUE)\nPATTERN = '.*maintenance_log.*\\.json';\n\n-- View the loaded maintenance logs with VARIANT data\nSELECT \n    LOG_ID,\n    VEHICLE_ID,\n    LOG_TIMESTAMP,\n    LOG_DATA:event_type::STRING AS event_type,\n    LOG_DATA:severity::STRING AS severity,\n    LOG_DATA:description::STRING AS description,\n    LOG_DATA:total_cost::FLOAT AS total_cost\nFROM MAINTENANCE_LOGS\nORDER BY LOG_TIMESTAMP DESC\nLIMIT 10;\n\u003C/code\u003E\u003C/pre\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003ETransformation\u003C/h2\u003E\n","\u003Cp\u003EThis section demonstrates how Snowflake powers transformation pipelines on Iceberg tables using Dynamic Tables. Dynamic Tables provide a declarative approach to data transformation&mdash;you define what the output should look like, and Snowflake handles the incremental refresh automatically.\u003C/p\u003E\n","\u003Cp\u003ERow lineage is used under the hood of Dynamic Iceberg V3 Tables to power change data capture (CDC) and incremental processing.\u003C/p\u003E\n","\u003Ch3\u003EDynamic Iceberg Tables Overview\u003C/h3\u003E\n","\u003Cp\u003EThe setup script created several Dynamic Iceberg Tables that form a transformation pipeline:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- View all dynamic tables in the pipeline\nSHOW DYNAMIC TABLES IN DATABASE FLEET_ANALYTICS_DB;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThese tables automatically refresh based on their TARGET_LAG setting, processing only incremental changes from source tables.\u003C/p\u003E\n","\u003Ch4\u003EExplore the Pipeline in the UI\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003ETransformation\u003C/strong\u003E &rarr; \u003Cstrong\u003EDynamic Tables\u003C/strong\u003E in the left pane\u003C/li\u003E\u003Cli\u003EFilter by database: \u003Cstrong\u003EFLEET_ANALYTICS_DB\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EClick on any dynamic table (e.g., \u003Ccode\u003ETELEMETRY_ENRICHED\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003EExplore the tabs:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EGraph\u003C/strong\u003E: Visualize the full pipeline and dependencies\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ERefresh History\u003C/strong\u003E: See incremental refresh operations\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EDefinition\u003C/strong\u003E: Review the declarative SQL that defines the transformation\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch4\u003EView the Dynamic Table Graph\u003C/h4\u003E\n","\u003Cp\u003EThe transformation pipeline looks like this:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/dit_graph.png?v=8cbd55b6\" alt=\"Dynamic Iceberg Table Graph\"\u003E\u003C/p\u003E\n","\u003Ch4\u003EMonitor Incremental Refreshes\u003C/h4\u003E\n","\u003Cp\u003EAs streaming data flows in, watch the dynamic tables refresh:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/dit_incremental_refresh.png?v=8cbd55b6\" alt=\"Dynamic Iceberg Table Incremental Refresh\"\u003E\u003C/p\u003E\n","\u003Cp\u003EThe \u003Ccode\u003EREFRESH_MODE = INCREMENTAL\u003C/code\u003E setting ensures only new or changed data is processed, making the pipeline highly efficient.\u003C/p\u003E\n","\u003Ch4\u003EQuery Transformed Data\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Query enriched telemetry with vehicle details\nSELECT \n    VEHICLE_ID,\n    MAKE,\n    MODEL,\n    DRIVER_NAME,\n    FLEET_REGION,\n    speed_mph,\n    engine_temp_f,\n    engine_health_status,\n    driving_behavior,\n    EVENT_TIMESTAMP\nFROM CURATED.TELEMETRY_ENRICHED\nWHERE engine_health_status != 'NORMAL' OR driving_behavior = 'AGGRESSIVE'\nORDER BY EVENT_TIMESTAMP DESC\nLIMIT 20;\n\u003C/code\u003E\u003C/pre\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003ESecurity and Governance\u003C/h2\u003E\n","\u003Cp\u003EThis section highlights Horizon Catalog as the central, unified, interoperable catalog with enterprise-grade security features. All governance capabilities work seamlessly with Iceberg V3 tables.\u003C/p\u003E\n","\u003Ch3\u003EPII Detection with Classification\u003C/h3\u003E\n","\u003Cp\u003ESnowflake can automatically detect and classify sensitive data across your entire database, including Iceberg tables.\u003C/p\u003E\n","\u003Ch4\u003EClassify the Schema\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003EData\u003C/strong\u003E &rarr; \u003Cstrong\u003EDatabases\u003C/strong\u003E &rarr; \u003Cstrong\u003EFLEET_ANALYTICS_DB\u003C/strong\u003E &rarr; \u003Cstrong\u003ERAW\u003C/strong\u003E (the schema)\u003C/li\u003E\u003Cli\u003EClick the \u003Cstrong\u003Ethree dots menu\u003C/strong\u003E (⋮) in the top right corner\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EClassify and Tag Sensitive Data\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003ESelect all Iceberg tables in the schema\u003C/li\u003E\u003Cli\u003EToggle \u003Cstrong\u003EAutomatically tag data\u003C/strong\u003E ON\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003EClassify and Tag Sensitive Data\u003C/strong\u003E\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/classify_sensitive_data.png?v=8cbd55b6\" alt=\"Classify and Tag Sensitive Data\"\u003E\u003C/p\u003E\n","\u003Ch4\u003EView Applied Tags\u003C/h4\u003E\n","\u003Cp\u003EAfter classification completes:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to any table (e.g., \u003Ccode\u003EVEHICLE_REGISTRY\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003EClick the \u003Cstrong\u003EColumns\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003ENotice tags applied to sensitive columns like \u003Ccode\u003EDRIVER_NAME\u003C/code\u003E, \u003Ccode\u003EDRIVER_EMAIL\u003C/code\u003E, \u003Ccode\u003EDRIVER_PHONE\u003C/code\u003E\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/classification_tag.png?v=8cbd55b6\" alt=\"Tagged Sensitive Data\"\u003E\u003C/p\u003E\n","\u003Cp\u003ECommon tags that may be applied:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003ESEMANTIC_CATEGORY:NAME\u003C/code\u003E - Personal names\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003ESEMANTIC_CATEGORY:EMAIL\u003C/code\u003E - Email addresses\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003ESEMANTIC_CATEGORY:PHONE_NUMBER\u003C/code\u003E - Phone numbers\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003ESEMANTIC_CATEGORY:US_SSN\u003C/code\u003E - Social Security Numbers\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETip\u003C/strong\u003E: You can also create \u003Ca href=\"https://docs.snowflake.com/en/user-guide/object-tagging/work#define-a-tag-that-will-automatically-propagate\"\u003Ecustom tags that automatically propagate\u003C/a\u003E to existing and new downstream objects.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EFine-Grained Access Control with Masking Policies\u003C/h3\u003E\n","\u003Cp\u003EThe setup script created masking policies to protect sensitive information. Now apply them to your Iceberg tables.\u003C/p\u003E\n","\u003Ch4\u003EView Created Masking Policies\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- View all masking policies in the database\nSHOW MASKING POLICIES IN DATABASE FLEET_ANALYTICS_DB;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThe \u003Ccode\u003EPII_MASK\u003C/code\u003E policy was created:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- View the policy definition\nSELECT GET_DDL('MASKING_POLICY', 'PII_MASK');\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ECREATE OR REPLACE MASKING POLICY PII_MASK AS (val STRING) \nRETURNS STRING -&gt;\n    CASE\n        WHEN CURRENT_ROLE() IN ('FLEET_ADMIN', 'ACCOUNTADMIN') THEN val\n        WHEN CURRENT_ROLE() = 'FLEET_ANALYST' THEN \n            CONCAT(LEFT(val, 2), '****', RIGHT(val, 2))\n        ELSE '********'\n    END;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EApply Masking Policies via UI\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003EData\u003C/strong\u003E &rarr; \u003Cstrong\u003EDatabases\u003C/strong\u003E &rarr; \u003Cstrong\u003EFLEET_ANALYTICS_DB\u003C/strong\u003E &rarr; \u003Cstrong\u003ERAW\u003C/strong\u003E &rarr; \u003Cstrong\u003EVEHICLE_REGISTRY\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EClick the \u003Cstrong\u003EColumns\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003EFind the \u003Ccode\u003EDRIVER_NAME\u003C/code\u003E column\u003C/li\u003E\u003Cli\u003EIn the \u003Cstrong\u003EPolicies\u003C/strong\u003E column, click the \u003Cstrong\u003E+\u003C/strong\u003E button\u003C/li\u003E\u003Cli\u003ESelect \u003Ccode\u003EPII_NAME_MASK\u003C/code\u003E and click \u003Cstrong\u003EDone\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003ERepeat for \u003Ccode\u003EDRIVER_EMAIL\u003C/code\u003E and \u003Ccode\u003EDRIVER_PHONE\u003C/code\u003E with \u003Ccode\u003EPII_EMAIL_MASK\u003C/code\u003E and \u003Ccode\u003EPII_PHONE_MASK\u003C/code\u003E\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/tag_mask.png?v=8cbd55b6\" alt=\"Mask Tagged Columns\"\u003E\u003C/p\u003E\n","\u003Ch4\u003ETest Masking Behavior\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- As ACCOUNTADMIN, see full PII values (unmasked)\nSELECT VEHICLE_ID, DRIVER_NAME, DRIVER_EMAIL, DRIVER_PHONE\nFROM VEHICLE_REGISTRY LIMIT 5;\n\n-- Create a test analyst role and grant it to the current user\nCREATE ROLE IF NOT EXISTS FLEET_ANALYST;\nGRANT USAGE ON DATABASE FLEET_ANALYTICS_DB TO ROLE FLEET_ANALYST;\nGRANT USAGE ON SCHEMA FLEET_ANALYTICS_DB.RAW TO ROLE FLEET_ANALYST;\nGRANT SELECT ON ALL TABLES IN SCHEMA FLEET_ANALYTICS_DB.RAW TO ROLE FLEET_ANALYST;\nGRANT USAGE ON WAREHOUSE FLEET_ANALYTICS_WH TO ROLE FLEET_ANALYST;\n\n-- Grant the role to the current user so we can switch to it\nSET MY_USER = CURRENT_USER();\nGRANT ROLE FLEET_ANALYST TO USER IDENTIFIER($MY_USER);\n\n-- Switch to analyst role and observe MASKED values\nUSE ROLE FLEET_ANALYST;\nSELECT VEHICLE_ID, DRIVER_NAME, DRIVER_EMAIL, DRIVER_PHONE\nFROM VEHICLE_REGISTRY LIMIT 5;\n-- Results show masked values: &quot;Jo****hn&quot;, &quot;jo****om&quot;\n\n-- Switch back to ACCOUNTADMIN for remaining operations\nUSE ROLE ACCOUNTADMIN;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003EData Quality Monitoring\u003C/h3\u003E\n","\u003Cp\u003EThe setup script created Data Metric Functions (DMFs) to monitor data quality on Iceberg tables.\u003C/p\u003E\n","\u003Ch4\u003EView Data Quality Setup\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Show data metric functions\nSHOW DATA METRIC FUNCTIONS IN DATABASE FLEET_ANALYTICS_DB;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExample DMF for validating geospatial coordinates:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ECREATE OR REPLACE DATA METRIC FUNCTION CHECK_VALID_COORDINATES(\n    arg_t TABLE(lat FLOAT, lon FLOAT)\n)\nRETURNS NUMBER\nAS\n$$\n    SELECT COUNT(*) \n    FROM arg_t\n    WHERE lat &lt; -90 OR lat &gt; 90 \n       OR lon &lt; -180 OR lon &gt; 180\n$$;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EReview Data Quality Results\u003C/h4\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: The Data Quality dashboard will initially be empty. DMFs run on a schedule (default: when triggered by Snowflake). To see results sooner, set a shorter schedule and insert new data to trigger the DMF.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003ETo configure DMF scheduling and verify results:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Set DMFs to trigger when data changes\nALTER ICEBERG TABLE RAW.VEHICLE_LOCATIONS SET DATA_METRIC_SCHEDULE = 'TRIGGER_ON_CHANGES';\nALTER ICEBERG TABLE RAW.SENSOR_READINGS SET DATA_METRIC_SCHEDULE = 'TRIGGER_ON_CHANGES';\n\n-- Or set a specific schedule (e.g., every 5 minutes)\n-- ALTER ICEBERG TABLE RAW.VEHICLE_LOCATIONS SET DATA_METRIC_SCHEDULE = '5 MINUTE';\n\n-- Check which DMFs are attached to VEHICLE_LOCATIONS\nSELECT * FROM TABLE(INFORMATION_SCHEMA.DATA_METRIC_FUNCTION_REFERENCES(\n    REF_ENTITY_NAME =&gt; 'FLEET_ANALYTICS_DB.RAW.VEHICLE_LOCATIONS',\n    REF_ENTITY_DOMAIN =&gt; 'TABLE'\n));\n\n-- Insert a row to trigger the DMF (if using TRIGGER_ON_CHANGES)\nINSERT INTO RAW.VEHICLE_LOCATIONS (LOCATION_ID, VEHICLE_ID, LOCATION_TIMESTAMP, LATITUDE, LONGITUDE, LOCATION_POINT, SPEED_MPH, HEADING_DEGREES, FLEET_REGION)\nSELECT UUID_STRING(), VEHICLE_ID, CURRENT_TIMESTAMP(), LATITUDE, LONGITUDE, LOCATION_POINT, SPEED_MPH, HEADING_DEGREES, FLEET_REGION\nFROM RAW.VEHICLE_LOCATIONS LIMIT 1;\n\n-- Check DMF results (may take a minute to populate after data insert)\nSELECT \n    TABLE_NAME,\n    METRIC_NAME,\n    VALUE,\n    MEASUREMENT_TIME\nFROM SNOWFLAKE.LOCAL.DATA_QUALITY_MONITORING_RESULTS\nWHERE TABLE_DATABASE = 'FLEET_ANALYTICS_DB'\nORDER BY MEASUREMENT_TIME DESC\nLIMIT 20;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETip\u003C/strong\u003E: Insert or modify data in the table to trigger the DMF if using \u003Ccode\u003ETRIGGER_ON_CHANGES\u003C/code\u003E. The Data Quality tab will populate after the next scheduled run.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003ETo view the Data Quality dashboard:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003EData\u003C/strong\u003E &rarr; \u003Cstrong\u003EDatabases\u003C/strong\u003E &rarr; \u003Cstrong\u003EFLEET_ANALYTICS_DB\u003C/strong\u003E &rarr; \u003Cstrong\u003ERAW\u003C/strong\u003E &rarr; \u003Cstrong\u003EVEHICLE_LOCATIONS\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EClick on the \u003Cstrong\u003EData Quality\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003EAfter DMFs have run, you'll see:\n\u003Cul\u003E\u003Cli\u003EQuality check results over time\u003C/li\u003E\u003Cli\u003EFailed record counts\u003C/li\u003E\u003Cli\u003EData quality trends by dimension (Freshness, Volume, Accuracy, etc.)\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EFor more details, see \u003Ca href=\"https://www.snowflake.com/en/developers/guides/getting-started-with-data-quality-in-snowflake/#review\"\u003EGetting Started with Data Quality in Snowflake\u003C/a\u003E.\u003C/p\u003E\n","\u003Ch3\u003EData Lineage\u003C/h3\u003E\n","\u003Cp\u003ESnowflake automatically tracks lineage for all objects, including Iceberg tables and Dynamic Tables.\u003C/p\u003E\n","\u003Ch4\u003EView Lineage Graph\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003EData\u003C/strong\u003E &rarr; \u003Cstrong\u003EDatabases\u003C/strong\u003E &rarr; \u003Cstrong\u003EFLEET_ANALYTICS_DB\u003C/strong\u003E &rarr; \u003Cstrong\u003ERAW\u003C/strong\u003E &rarr; \u003Cstrong\u003EMAINTENANCE_LOGS\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EClick on the \u003Cstrong\u003ELineage\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003EExplore the lineage graph showing both upstream and downstream tables, including upstream lineage from an external telemetry messaging service\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EThe lineage graph is valuable for:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EImpact analysis\u003C/strong\u003E: Understanding what's affected when source data changes\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EData quality investigation\u003C/strong\u003E: Tracing issues back to their source\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESecurity auditing\u003C/strong\u003E: Understanding data flow for sensitive information\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/lineage.png?v=8cbd55b6\" alt=\"Data Lineage\"\u003E\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EAnalytics and AI\u003C/h2\u003E\n","\u003Cp\u003EThis section demonstrates Snowflake's analytical capabilities on Iceberg V3 tables, including semi-structured data querying, time-series analysis, geospatial functions, and AI agents.\u003C/p\u003E\n","\u003Ch3\u003ESemi-Structured Data Analytics\u003C/h3\u003E\n","\u003Cp\u003ESnowflake efficiently queries VARIANT data in Iceberg tables with automatic pruning and optimization.\u003C/p\u003E\n","\u003Ch4\u003EQuery Nested Variant Data\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Extract nested fields from VARIANT with dot notation\nSELECT \n    VEHICLE_ID,\n    TELEMETRY_DATA:speed_mph::FLOAT AS speed,\n    TELEMETRY_DATA:engine:rpm::INT AS engine_rpm,\n    TELEMETRY_DATA:engine:temperature_f::INT AS engine_temp,\n    TELEMETRY_DATA:diagnostics:check_engine::BOOLEAN AS check_engine_light,\n    TELEMETRY_DATA:driver_behavior:hard_brake_count::INT AS hard_brakes\nFROM RAW.VEHICLE_TELEMETRY_STREAM\nWHERE TELEMETRY_DATA:speed_mph::FLOAT &gt; 50\nLIMIT 20;\n\n-- Aggregate on variant fields - find vehicles with check engine warnings\nSELECT \n    TELEMETRY_DATA:diagnostics:check_engine::BOOLEAN AS check_engine,\n    COUNT(*) AS event_count,\n    ROUND(AVG(TELEMETRY_DATA:speed_mph::FLOAT), 1) AS avg_speed,\n    COUNT(DISTINCT VEHICLE_ID) AS vehicle_count\nFROM RAW.VEHICLE_TELEMETRY_STREAM\nGROUP BY 1\nORDER BY event_count DESC;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EObserve Query Pruning\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Run with profile to see pruning efficiency\nSELECT \n    VEHICLE_ID,\n    EVENT_TIMESTAMP,\n    TELEMETRY_DATA:speed_mph::FLOAT AS speed\nFROM VEHICLE_TELEMETRY_STREAM\nWHERE VEHICLE_ID = 'VH-1234'\n  AND TELEMETRY_DATA:engine:temperature_f::INT &gt; 200;\n\n-- Check query profile in History tab to see partition pruning statistics\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003ETime-Series Analytics and Forecasting\u003C/h3\u003E\n","\u003Cp\u003EThe \u003Ccode\u003ESENSOR_READINGS\u003C/code\u003E table contains high-precision time-series data for analysis.\u003C/p\u003E\n","\u003Ch4\u003EAS OF Join for Point-in-Time Analysis\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- AS OF join: Find closest sensor reading before each maintenance event\nSELECT \n    m.VEHICLE_ID,\n    m.LOG_TIMESTAMP AS maintenance_time,\n    m.LOG_DATA:event_type::STRING AS maintenance_type,\n    s.READING_TIMESTAMP AS closest_reading_time,\n    s.ENGINE_TEMP_F,\n    s.OIL_PRESSURE_PSI\nFROM RAW.MAINTENANCE_LOGS m\nASOF JOIN RAW.SENSOR_READINGS s\n    MATCH_CONDITION (m.LOG_TIMESTAMP &gt;= s.READING_TIMESTAMP)\n    ON m.VEHICLE_ID = s.VEHICLE_ID\nWHERE m.LOG_DATA:severity::STRING IN ('CRITICAL', 'HIGH')\nORDER BY m.LOG_TIMESTAMP DESC\nLIMIT 15;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003ETime-Series Aggregation with\u003C/h4\u003E\n","\u003Cp\u003EWindow functions enable powerful time-series analysis directly in SQL:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ERolling averages\u003C/strong\u003E to smooth out noise\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ERunning totals\u003C/strong\u003E for cumulative metrics\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ELag/Lead\u003C/strong\u003E for period-over-period comparisons\u003C/li\u003E\u003C/ul\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Calculate rolling averages for engine temperature\nSELECT \n    VEHICLE_ID,\n    READING_TIMESTAMP,\n    ENGINE_TEMP_F,\n    AVG(ENGINE_TEMP_F) OVER (\n        PARTITION BY VEHICLE_ID \n        ORDER BY READING_TIMESTAMP \n        RANGE BETWEEN INTERVAL '1 HOUR' PRECEDING AND CURRENT ROW\n    ) AS rolling_avg_temp,\n    MAX(ENGINE_TEMP_F) OVER (\n        PARTITION BY VEHICLE_ID \n        ORDER BY READING_TIMESTAMP \n        RANGE BETWEEN INTERVAL '1 HOUR' PRECEDING AND CURRENT ROW\n    ) AS rolling_max_temp\nFROM RAW.SENSOR_READINGS\nORDER BY VEHICLE_ID, READING_TIMESTAMP\nLIMIT 50;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EML Forecasting for Predictive Maintenance\u003C/h4\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E⏱️ \u003Cstrong\u003ETraining Time\u003C/strong\u003E: Model training may take \u003Cstrong\u003E2-5 minutes\u003C/strong\u003E depending on data volume and warehouse size. To speed up training:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EUse a \u003Cstrong\u003Elarger warehouse\u003C/strong\u003E (e.g., MEDIUM or LARGE) - training scales with compute\u003C/li\u003E\u003Cli\u003EReduce the number of time series by filtering to specific vehicles\u003C/li\u003E\u003Cli\u003ELimit historical data range (e.g., 14 days instead of 30)\u003C/li\u003E\u003C/ul\u003E\n\u003C/blockquote\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Create a forecast model for fuel consumption\n-- For Iceberg tables, we must use SYSTEM$QUERY_REFERENCE instead of TABLE reference\nCREATE OR REPLACE SNOWFLAKE.ML.FORECAST fuel_consumption_forecast(\n    INPUT_DATA =&gt; SYSTEM$QUERY_REFERENCE('\n        SELECT \n            VEHICLE_ID,\n            READING_TIMESTAMP,\n            FUEL_CONSUMPTION_GPH\n        FROM RAW.SENSOR_READINGS\n        WHERE READING_TIMESTAMP &gt; DATEADD(''day'', -30, CURRENT_TIMESTAMP())\n    '),\n    TIMESTAMP_COLNAME =&gt; 'READING_TIMESTAMP',\n    TARGET_COLNAME =&gt; 'FUEL_CONSUMPTION_GPH',\n    SERIES_COLNAME =&gt; 'VEHICLE_ID'\n);\n\n-- Generate 7-day forecast and save results\nCALL fuel_consumption_forecast!FORECAST(\n    FORECASTING_PERIODS =&gt; 168,  -- 7 days * 24 hours\n    CONFIG_OBJECT =&gt; {'prediction_interval': 0.95}\n);\n\n-- FORECAST: Generate a 7-day forecast (168 hours) and save to a table for visualization\nCALL fuel_consumption_forecast!FORECAST(\n    FORECASTING_PERIODS =&gt; 168,\n    CONFIG_OBJECT =&gt; {'prediction_interval': 0.95}\n);\n\n-- Save forecast results to a table for visualization\nCREATE OR REPLACE TEMPORARY TABLE FUEL_FORECAST_RESULTS AS\nSELECT * FROM TABLE(RESULT_SCAN(LAST_QUERY_ID()));\n\n-- Preview forecast results\nSELECT * FROM FUEL_FORECAST_RESULTS ORDER BY SERIES, TS LIMIT 20;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EVisualize Historical + Forecast Data\u003C/h4\u003E\n","\u003Cp\u003EUse Streamlit in a Snowflake Notebook to plot historical data alongside the forecast:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003E# 📈 Visualize Historical + Forecast Fuel Consumption\nimport streamlit as st\nimport pandas as pd\nfrom snowflake.snowpark.context import get_active_session\n\nsession = get_active_session()\n\n# Get historical data (last 30 days for one vehicle)\nhistorical_df = session.sql(&quot;&quot;&quot;\n    SELECT \n        READING_TIMESTAMP AS ts,\n        FUEL_CONSUMPTION_GPH AS value,\n        'Historical' AS data_type\n    FROM RAW.SENSOR_READINGS\n    WHERE VEHICLE_ID = (SELECT SERIES FROM FUEL_FORECAST_RESULTS LIMIT 1)\n      AND READING_TIMESTAMP &gt; DATEADD('day', -30, CURRENT_TIMESTAMP())\n    ORDER BY READING_TIMESTAMP\n&quot;&quot;&quot;).to_pandas()\n\n# Get forecast data (column names vary - check with DESCRIBE first if needed)\nforecast_df = session.sql(&quot;&quot;&quot;\n    SELECT \n        TS AS ts,\n        FORECAST AS value,\n        'Forecast' AS data_type\n    FROM FUEL_FORECAST_RESULTS\n    WHERE SERIES = (SELECT SERIES FROM FUEL_FORECAST_RESULTS LIMIT 1)\n    ORDER BY TS\n&quot;&quot;&quot;).to_pandas()\n\n# Get the vehicle ID for the title\nvehicle_id = session.sql(&quot;SELECT SERIES FROM FUEL_FORECAST_RESULTS LIMIT 1&quot;).collect()[0][0]\n\nst.subheader(f&quot;📈 Fuel Consumption Forecast: {vehicle_id}&quot;)\nst.caption(&quot;Historical data (30 days) + 7-day forecast&quot;)\n\n# Normalize column names to lowercase\nhistorical_df.columns = historical_df.columns.str.lower()\nforecast_df.columns = forecast_df.columns.str.lower()\n\n# Combine for plotting\ncombined_df = pd.concat([historical_df, forecast_df], ignore_index=True)\ncombined_df['ts'] = pd.to_datetime(combined_df['ts'])\ncombined_df = combined_df.sort_values('ts')\n\n# Create the chart using Streamlit's native line chart\n# Pivot data for multi-line chart\nchart_data = combined_df.pivot_table(index='ts', columns='data_type', values='value', aggfunc='first')\nst.line_chart(chart_data, use_container_width=True)\n\n# Display metrics\ncol1, col2, col3 = st.columns(3)\ncol1.metric(&quot;Avg Historical (GPH)&quot;, f&quot;{historical_df['value'].mean():.2f}&quot;)\ncol2.metric(&quot;Avg Forecast (GPH)&quot;, f&quot;{forecast_df['value'].mean():.2f}&quot;)\nchange = ((forecast_df['value'].mean() - historical_df['value'].mean()) / historical_df['value'].mean()) * 100\ncol3.metric(&quot;Projected Change&quot;, f&quot;{change:+.1f}%&quot;)\n\nst.caption(&quot;💡 The forecast helps identify vehicles likely to have higher fuel consumption, enabling proactive maintenance scheduling.&quot;)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003EGeospatial Analytics\u003C/h3\u003E\n","\u003Cp\u003EH3 is Uber's hierarchical geospatial indexing system. Snowflake's H3 functions enable:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EAggregating vehicles by geographic cell\u003C/li\u003E\u003Cli\u003EEfficient spatial joins and clustering\u003C/li\u003E\u003Cli\u003EMulti-resolution analysis (cells at different zoom levels)\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThe \u003Ccode\u003EVEHICLE_LOCATIONS\u003C/code\u003E table contains GEOGRAPHY data for spatial analysis.\u003C/p\u003E\n","\u003Ch4\u003EBasic Geospatial Queries\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Calculate distance between consecutive positions\nSELECT \n    VEHICLE_ID,\n    LOCATION_TIMESTAMP,\n    LAG(LOCATION_POINT) OVER (\n        PARTITION BY VEHICLE_ID ORDER BY LOCATION_TIMESTAMP\n    ) AS prev_location,\n    LOCATION_POINT AS current_location,\n    ST_DISTANCE(\n        LOCATION_POINT,\n        LAG(LOCATION_POINT) OVER (PARTITION BY VEHICLE_ID ORDER BY LOCATION_TIMESTAMP)\n    ) / 1609.34 AS distance_miles  -- Convert meters to miles\nFROM VEHICLE_LOCATIONS\nORDER BY VEHICLE_ID, LOCATION_TIMESTAMP\nLIMIT 50;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EGeofencing Analysis\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Define a geofence (San Francisco downtown)\nSET sf_downtown = ST_MAKEPOLYGON(TO_GEOGRAPHY(\n    'LINESTRING(-122.42 37.78, -122.42 37.79, -122.40 37.79, -122.40 37.78, -122.42 37.78)'\n));\n\n-- Find vehicles inside the geofence\nSELECT \n    VEHICLE_ID,\n    LOCATION_TIMESTAMP,\n    ST_X(LOCATION_POINT) AS longitude,\n    ST_Y(LOCATION_POINT) AS latitude\nFROM VEHICLE_LOCATIONS\nWHERE ST_WITHIN(LOCATION_POINT, $sf_downtown)\nORDER BY LOCATION_TIMESTAMP DESC\nLIMIT 20;\n\n-- Geospatial: Aggregate vehicles by H3 cell (resolution 6)\nSELECT \n    H3_POINT_TO_CELL_STRING(LOCATION_POINT, 6) AS h3_cell,\n    FLEET_REGION,\n    COUNT(DISTINCT VEHICLE_ID) AS vehicle_count,\n    ROUND(AVG(SPEED_MPH), 1) AS avg_speed\nFROM RAW.VEHICLE_LOCATIONS\nWHERE LOCATION_TIMESTAMP &gt; DATEADD('hour', -24, CURRENT_TIMESTAMP())\nGROUP BY 1, 2\nORDER BY vehicle_count DESC\nLIMIT 20;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EInteractive Map Visualization with Streamlit\u003C/h4\u003E\n","\u003Cp\u003EIn the Snowflake Notebook, you can visualize the H3 geospatial data on an interactive map using Streamlit (built into Snowflake Notebooks):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003E# Visualize fleet locations on an interactive map using Streamlit\nimport streamlit as st\nfrom snowflake.snowpark.context import get_active_session\n\nsession = get_active_session()\n\n# Query location data with H3 cell centers (use ST_X/ST_Y for GEOGRAPHY type)\ndf = session.sql(&quot;&quot;&quot;\n    SELECT \n        H3_POINT_TO_CELL_STRING(LOCATION_POINT, 6) AS h3_cell,\n        ST_X(H3_CELL_TO_POINT(H3_POINT_TO_CELL_STRING(LOCATION_POINT, 6))) AS longitude,\n        ST_Y(H3_CELL_TO_POINT(H3_POINT_TO_CELL_STRING(LOCATION_POINT, 6))) AS latitude,\n        FLEET_REGION,\n        COUNT(DISTINCT VEHICLE_ID) AS vehicle_count,\n        ROUND(AVG(SPEED_MPH), 1) AS avg_speed\n    FROM RAW.VEHICLE_LOCATIONS\n    WHERE LOCATION_TIMESTAMP &gt; DATEADD('hour', -24, CURRENT_TIMESTAMP())\n    GROUP BY 1, 2, 3, 4\n    ORDER BY vehicle_count DESC\n    LIMIT 100\n&quot;&quot;&quot;).to_pandas()\n\nst.subheader(&quot;🗺️ Fleet Vehicle Distribution&quot;)\nst.caption(&quot;Each point represents an H3 cell with vehicle activity in the last 24 hours&quot;)\n\n# Display metrics\ncol1, col2, col3 = st.columns(3)\ncol1.metric(&quot;Total H3 Cells&quot;, len(df))\ncol2.metric(&quot;Total Vehicles&quot;, int(df['VEHICLE_COUNT'].sum()))\ncol3.metric(&quot;Avg Speed&quot;, f&quot;{df['AVG_SPEED'].mean():.1f} mph&quot;)\n\n# Interactive map visualization - point size scales with vehicle count\nst.map(df, latitude='LATITUDE', longitude='LONGITUDE', size='VEHICLE_COUNT')\n\n# Show data table\nst.dataframe(df[['FLEET_REGION', 'VEHICLE_COUNT', 'AVG_SPEED']].head(10))\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThis produces an interactive map showing vehicle distribution across the US, with:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EPoints sized by vehicle count per H3 cell\u003C/li\u003E\u003Cli\u003ESummary metrics for cells, vehicles, and average speed\u003C/li\u003E\u003Cli\u003EData table with regional breakdown\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EAI Agents with Snowflake CoWork\u003C/h3\u003E\n","\u003Cp\u003EThe setup script creates a Cortex Agent (\u003Ccode\u003EFLEET_ANALYTICS_AGENT\u003C/code\u003E) that enables natural language querying of your fleet data.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: Cortex Agents require Enterprise Edition or higher.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003ERegion Availability and Cross-Region Inference\u003C/h4\u003E\n","\u003Cp\u003ECortex Agents and Cortex Analyst rely on LLMs that may not be available in all Snowflake regions. If you see an error like:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode\u003ENone of the preferred models are authorized or available in your region...\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EYou have two options:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003EEnable Cross-Region Inference\u003C/strong\u003E (recommended): This allows Snowflake to route AI requests to regions where models are available, while keeping your data secure.\u003C/li\u003E\u003C/ol\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Enable cross-region inference for your account\nUSE ROLE ACCOUNTADMIN;\nALTER ACCOUNT SET CORTEX_ENABLED_CROSS_REGION = 'ANY_REGION';\n\u003C/code\u003E\u003C/pre\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003E\u003Cstrong\u003EUse a supported region\u003C/strong\u003E: Deploy your Snowflake account in a region with native LLM support.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EFor more details, see:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/snowflake-cortex/cortex-analyst#region-availability\"\u003ECortex Analyst Region Availability\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/snowflake-cortex/cross-region-inference\"\u003ECross-Region Inference\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPrivacy Note\u003C/strong\u003E: With cross-region inference, only the AI inference is routed cross-region. Your underlying data remains in your account's region and is protected by Snowflake's governance controls.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EAgent Configuration\u003C/h4\u003E\n","\u003Cp\u003EThe setup script creates the agent with a complete YAML specification including:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ESample questions\u003C/strong\u003E to help users get started\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EOrchestration instructions\u003C/strong\u003E explaining the data schema\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECortex Analyst tool\u003C/strong\u003E linked to a semantic model describing all tables\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThe semantic model (\u003Ccode\u003Efleet_semantic_model.yaml\u003C/code\u003E) is uploaded to the stage and defines:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ETable structures for SENSOR_READINGS, VEHICLE_TELEMETRY_STREAM, VEHICLE_LOCATIONS, etc.\u003C/li\u003E\u003Cli\u003EVARIANT column extraction patterns\u003C/li\u003E\u003Cli\u003EDimension and measure definitions\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: If the agent creation fails due to syntax issues, you can configure it manually through \u003Cstrong\u003ECortex AI\u003C/strong\u003E &rarr; \u003Cstrong\u003EAgents\u003C/strong\u003E &rarr; \u003Cstrong\u003EFLEET_ANALYTICS_AGENT\u003C/strong\u003E.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EUsing the Fleet Analytics Agent\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003ECortex AI\u003C/strong\u003E &rarr; \u003Cstrong\u003EAgents\u003C/strong\u003E in the left sidebar\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EFLEET_ANALYTICS_AGENT\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EStart asking questions in natural language:\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExample queries:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E&quot;Which vehicles had the highest fuel consumption last week?&quot;\u003C/li\u003E\u003Cli\u003E&quot;Show me all critical maintenance events&quot;\u003C/li\u003E\u003Cli\u003E&quot;What's the average speed by fleet region?&quot;\u003C/li\u003E\u003Cli\u003E&quot;Find vehicles with check engine warnings&quot;\u003C/li\u003E\u003Cli\u003E&quot;Which drivers have the most hard braking events?&quot;\u003C/li\u003E\u003Cli\u003E&quot;Show vehicle health scores below 60&quot;\u003C/li\u003E\u003Cli\u003E&quot;How many vehicles are in each H3 cell in California?&quot;\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThe agent understands your Iceberg table schema including:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EVARIANT columns\u003C/strong\u003E: Extracts nested JSON fields using colon notation\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EGEOGRAPHY columns\u003C/strong\u003E: Uses H3 and ST_* functions for geospatial analysis\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ETime-series data\u003C/strong\u003E: Performs ASOF joins and window functions\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch4\u003EAgent Configuration\u003C/h4\u003E\n","\u003Cp\u003EThe agent was created with access to these tables:\u003C/p\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003ETable\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EDescription\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ERAW.VEHICLE_TELEMETRY_STREAM\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EReal-time streaming telemetry (VARIANT)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ERAW.VEHICLE_LOCATIONS\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EGeospatial positions (GEOGRAPHY)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ERAW.SENSOR_READINGS\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EHigh-precision time-series sensor data\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ERAW.MAINTENANCE_LOGS\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EMaintenance events (VARIANT)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ERAW.VEHICLE_REGISTRY\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EVehicle and driver master data\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003EANALYTICS.DAILY_FLEET_SUMMARY\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EDaily aggregated metrics\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003EANALYTICS.VEHICLE_HEALTH_SCORE\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ECalculated health scores\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n","\u003Cp\u003ETo view or modify the agent configuration:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- View agent details\nSHOW AGENTS IN SCHEMA FLEET_ANALYTICS_DB.RAW;\n\n-- Describe the agent\nDESCRIBE AGENT FLEET_ANALYTICS_DB.RAW.FLEET_ANALYTICS_AGENT;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EFor more on building agents, see \u003Ca href=\"https://docs.snowflake.com/en/user-guide/snowflake-cortex/snowflake-intelligence\"\u003ESnowflake CoWork documentation\u003C/a\u003E.\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EBusiness Continuity and Disaster Recovery\u003C/h2\u003E\n","\u003Cp\u003EThis section highlights Snowflake's enterprise-grade, out-of-the-box business continuity and disaster recovery capabilities that extend to Iceberg V3 tables.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: Replication features require Business Critical Edition or higher.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EIceberg Table Replication Overview\u003C/h3\u003E\n","\u003Cp\u003ESnowflake supports replicating Iceberg tables across regions and clouds, ensuring your data lakehouse is protected against regional outages. See \u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-replication\"\u003EIceberg Table Replication documentation\u003C/a\u003E for details.\u003C/p\u003E\n","\u003Ch3\u003ESetting Up Replication via UI\u003C/h3\u003E\n","\u003Cp\u003EFollow these steps to set up cross-region replication for your Iceberg tables:\u003C/p\u003E\n","\u003Ch4\u003EStep 1: Create a Replication Group\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003EAdmin\u003C/strong\u003E &rarr; \u003Cstrong\u003EAccounts\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EClick on the \u003Cstrong\u003EReplication\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003E+ Group\u003C/strong\u003E (or \u003Cstrong\u003E+ Failover Group\u003C/strong\u003E for automatic failover)\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch4\u003EStep 2: Select Target Account\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003EChoose the target Snowflake account in a different cloud or region\u003C/li\u003E\u003Cli\u003EIf no secondary accounts exist, you'll need to create one first\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch4\u003EStep 3: Configure Objects\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003ESelect all objects to replicate:\n\u003Cul\u003E\u003Cli\u003EDatabases (includes all Iceberg tables)\u003C/li\u003E\u003Cli\u003EWarehouses (optional)\u003C/li\u003E\u003Cli\u003ERoles and privileges (recommended for consistent access)\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003EWith \u003Cstrong\u003ESnowflake-managed\u003C/strong\u003E Iceberg storage (\u003Ccode\u003ESNOWFLAKE_MANAGED\u003C/code\u003E, the lab default), you do not add customer external volumes for table files, and failover/replication groups can use \u003Ccode\u003EOBJECT_TYPES = DATABASES\u003C/code\u003E without listing external volumes. See \u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage#replication\"\u003EReplication\u003C/a\u003E under \u003Cem\u003ESnowflake storage for Apache Iceberg tables\u003C/em\u003E.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EStep 4: Enable and Monitor\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003EClick \u003Cstrong\u003ECreate\u003C/strong\u003E to enable replication\u003C/li\u003E\u003Cli\u003EMonitor replication status in the Replication tab\u003C/li\u003E\u003Cli\u003EView replication lag and sync history\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003EVerify Replication\u003C/h3\u003E\n","\u003Cp\u003EIn the secondary account:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Check that Iceberg tables exist\nUSE DATABASE FLEET_ANALYTICS_DB;\nSHOW ICEBERG TABLES;\n\n-- Query replicated data\nSELECT COUNT(*) FROM VEHICLE_TELEMETRY_STREAM;\nSELECT COUNT(*) FROM MAINTENANCE_LOGS;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003EFailover Testing\u003C/h3\u003E\n","\u003Cp\u003EFor Failover Groups (automatic failover):\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EIn the Replication tab, select your failover group\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003EFailover\u003C/strong\u003E to initiate failover to secondary\u003C/li\u003E\u003Cli\u003EVerify applications can connect to secondary account\u003C/li\u003E\u003Cli\u003EUse \u003Cstrong\u003EFailback\u003C/strong\u003E when primary is restored\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EFor detailed steps, see \u003Ca href=\"https://docs.snowflake.com/en/user-guide/account-replication-config#create-a-replication-or-failover-group-using-snowsight\"\u003ECreating Replication/Failover Groups via Snowsight\u003C/a\u003E.\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EInteroperability\u003C/h2\u003E\n","\u003Cp\u003EThis section demonstrates that external engines like Apache Spark can access Iceberg V3 tables managed by Snowflake. Horizon provides temporary, scoped storage credentials and enforces centralized row/column-level access controls for any engine.\u003C/p\u003E\n","\u003Ch3\u003EPrerequisites for Spark\u003C/h3\u003E\n","\u003Cp\u003EEnsure you have:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EConda installed\u003C/li\u003E\u003Cli\u003EThe repository cloned (\u003Ccode\u003Esfguide-iceberg-v3-comprehensive-guide\u003C/code\u003E)\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003EExternal engines still read Iceberg tables that use \u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage\"\u003ESnowflake-managed storage\u003C/a\u003E through Horizon Catalog. The Spark notebook includes a \u003Cstrong\u003ECloud Storage Bundles\u003C/strong\u003E section&mdash;use the bundle that matches your account&rsquo;s cloud if you adjust storage or see file I/O errors.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EStart the Spark Environment\u003C/h3\u003E\n","\u003Cp\u003EThe setup script created a Conda environment with Spark 4.0+ and all necessary dependencies:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Ecd sfquickstarts/site/sfguides/src/iceberg-v3-comprehensive-guide/assets\n\n# Activate the Spark environment\nconda activate fleet-spark\n\n# Start Jupyter notebook\njupyter notebook spark_iceberg_interop.ipynb\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003ESpark Notebook Walkthrough\u003C/h3\u003E\n","\u003Cp\u003EThe pre-configured Jupyter notebook contains all the code needed. Here's what you'll do:\u003C/p\u003E\n","\u003Ch4\u003ECell 1: Setup and Imports\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003Efrom pyspark.sql import SparkSession\nimport os\n\n# Load configuration (from the same config.env used during setup)\nfrom dotenv import load_dotenv\nload_dotenv('../config.env')\n\nSNOWFLAKE_ACCOUNT = os.getenv('SNOWFLAKE_ACCOUNT')\nSNOWFLAKE_USER = os.getenv('SNOWFLAKE_USER')\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003ECell 2: Create Spark Session with Horizon Catalog\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003Efrom pyspark.sql import SparkSession\n\n# Configuration\nSNOWFLAKE_PASSWORD = os.getenv('SNOWFLAKE_PASSWORD')\nSNOWFLAKE_ROLE = 'ACCOUNTADMIN'\nSNOWFLAKE_SCHEMA = 'RAW'\nSNOWFLAKE_WAREHOUSE = os.getenv('SNOWFLAKE_WAREHOUSE', 'FLEET_ANALYTICS_WH')\nSF_URL = f&quot;{SNOWFLAKE_ACCOUNT_URL}.snowflakecomputing.com&quot;\n\n# Versions - Note: Spark 3.5 required for Snowflake Connector masking support\nSNOWFLAKE_JDBC_VERSION = &quot;3.24.0&quot;\nSNOWFLAKE_SPARK_CONNECTOR_VERSION = &quot;3.1.6&quot;\n\n# Create Spark session with Iceberg and Snowflake catalog configuration\n# Note: \n# - driver.host and bindAddress ensure Spark uses localhost (avoids VPN issues)\n# - Using Spark 4.0 + Iceberg 1.10.1 for native VARIANT support\nspark = SparkSession.builder \\\n    .appName(&quot;Fleet Analytics - Iceberg V3 Interop&quot;) \\\n    .master(&quot;local[*]&quot;) \\\n    .config(&quot;spark.driver.host&quot;, &quot;127.0.0.1&quot;) \\\n    .config(&quot;spark.driver.bindAddress&quot;, &quot;127.0.0.1&quot;) \\\n    .config(&quot;spark.jars.packages&quot;, \n            f&quot;org.apache.iceberg:iceberg-spark-runtime-4.0_{SCALA_VERSION}:{ICEBERG_VERSION},&quot;\n            f&quot;org.apache.iceberg:iceberg-aws-bundle:{ICEBERG_VERSION},&quot;\n            f&quot;net.snowflake:snowflake-jdbc:{SNOWFLAKE_JDBC_VERSION},&quot;\n            f&quot;net.snowflake:spark-snowflake_{SCALA_VERSION}:{SNOWFLAKE_SPARK_CONNECTOR_VERSION}&quot;) \\\n    .config(&quot;spark.sql.extensions&quot;, &quot;org.apache.iceberg.spark.extensions.IcebergSparkSessionExtensions&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon&quot;, &quot;org.apache.iceberg.spark.SparkCatalog&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.type&quot;, &quot;rest&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.uri&quot;, f&quot;https://{SNOWFLAKE_ACCOUNT_URL}.snowflakecomputing.com/polaris/api/catalog&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.credential&quot;, SNOWFLAKE_ACCOUNTADMIN_TOKEN) \\\n    .config(&quot;spark.sql.catalog.horizon.warehouse&quot;, SNOWFLAKE_DATABASE) \\\n    .config(&quot;spark.sql.catalog.horizon.scope&quot;, f&quot;session:role:{SNOWFLAKE_ROLE}&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.header.X-Iceberg-Access-Delegation&quot;,&quot;vended-credentials&quot;) \\\n    .config(&quot;spark.snowflake.sfURL&quot;, SF_URL) \\\n    .config(&quot;spark.snowflake.sfUser&quot;, os.getenv('SNOWFLAKE_USER')) \\\n    .config(&quot;spark.snowflake.sfPassword&quot;, SNOWFLAKE_FLEET_ANALYST_TOKEN) \\\n    .config(&quot;spark.snowflake.sfDatabase&quot;, SNOWFLAKE_DATABASE) \\\n    .config(&quot;spark.snowflake.sfSchema&quot;, SNOWFLAKE_SCHEMA) \\\n    .config(&quot;spark.snowflake.sfRole&quot;, SNOWFLAKE_ROLE) \\\n    .config(&quot;spark.snowflake.sfWarehouse&quot;, SNOWFLAKE_WAREHOUSE) \\\n    .config(&quot;spark.sql.iceberg.vectorization.enabled&quot;, &quot;false&quot;) \\\n    .getOrCreate()\n\nprint(&quot;Spark session created successfully!&quot;)\nprint(f&quot;Spark version: {spark.version}&quot;)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003ECell 3: List Available Tables\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003E# Show all tables visible to Spark\nspark.sql(&quot;SHOW TABLES IN horizon.RAW&quot;).show(truncate=False)\nspark.sql(&quot;SHOW TABLES IN horizon.CURATED&quot;).show(truncate=False)\nspark.sql(&quot;SHOW TABLES IN horizon.ANALYTICS&quot;).show(truncate=False)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EOutput:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode\u003E+---------+------------------------+-----------+\n|namespace|tableName               |isTemporary|\n+---------+------------------------+-----------+\n|RAW      |API_WEATHER_DATA        |false      |\n|RAW      |MAINTENANCE_LOGS        |false      |\n|RAW      |SENSOR_READINGS         |false      |\n|RAW      |VEHICLE_LOCATIONS       |false      |\n|RAW      |VEHICLE_REGISTRY        |false      |\n|RAW      |VEHICLE_TELEMETRY_STREAM|false      |\n+---------+------------------------+-----------+\n\n+---------+--------------------+-----------+\n|namespace|tableName           |isTemporary|\n+---------+--------------------+-----------+\n|CURATED  |MAINTENANCE_ANALYSIS|false      |\n|CURATED  |TELEMETRY_ENRICHED  |false      |\n+---------+--------------------+-----------+\n\n+---------+--------------------+-----------+\n|namespace|tableName           |isTemporary|\n+---------+--------------------+-----------+\n|ANALYTICS|DAILY_FLEET_SUMMARY |false      |\n|ANALYTICS|VEHICLE_HEALTH_SCORE|false      |\n+---------+--------------------+-----------+\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ENote that Dynamic Iceberg Tables are also visible!\u003C/p\u003E\n","\u003Ch4\u003ECell 4: Describe Table with Variant Column\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003E# See variant column in Iceberg table\nspark.sql(&quot;DESCRIBE TABLE snowflake.RAW.VEHICLE_TELEMETRY_STREAM&quot;).show(truncate=False)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EOutput:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode\u003E+-------------------+---------------+-------+\n|col_name           |data_type      |comment|\n+-------------------+---------------+-------+\n|VEHICLE_ID         |string         |null   |\n|EVENT_TIMESTAMP    |timestamp      |null   |\n|TELEMETRY_DATA     |variant        |null   |\n+-------------------+---------------+-------+\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003ECell 5: Query Data with Variant\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003E# Use Spark's variant_get() function to extract nested fields from VARIANT\n# This query succeeds, and no Snowflake compute is used, since there's no masking policy on the Iceberg table.\ndf = spark.sql(f&quot;&quot;&quot;\n    SELECT \n        VEHICLE_ID,\n        EVENT_TIMESTAMP,\n        variant_get(TELEMETRY_DATA, '$.speed_mph', 'float') AS speed_mph,\n        variant_get(TELEMETRY_DATA, '$.engine.temperature_f', 'int') AS engine_temp,\n        variant_get(TELEMETRY_DATA, '$.location.lat', 'float') AS latitude,\n        variant_get(TELEMETRY_DATA, '$.location.lon', 'float') AS longitude\n    FROM snowflake.RAW.VEHICLE_TELEMETRY_STREAM\n    WHERE variant_get(TELEMETRY_DATA, '$.speed_mph', 'float') &gt; 60\n    LIMIT 10\n&quot;&quot;&quot;)\ndf.show()\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003ECell 6: Demonstrate Access Control (Masking Enforcement)\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003E# To enforce masking policies from Spark, we need the Snowflake Connector for Spark\n# which routes queries through Snowflake for policy evaluation\n# See: https://docs.snowflake.com/en/user-guide/tables-iceberg-query-using-external-query-engine-snowflake-horizon-enforce-access-policies\n\n# Stop the previous Spark session first\nspark.stop()\nfrom pyspark.sql import SparkSession\n\n# Configuration\nSNOWFLAKE_PASSWORD = os.getenv('SNOWFLAKE_PASSWORD')\nSNOWFLAKE_ROLE = 'FLEET_ANALYST'\nSNOWFLAKE_SCHEMA = 'RAW'\nSNOWFLAKE_WAREHOUSE = os.getenv('SNOWFLAKE_WAREHOUSE', 'FLEET_ANALYTICS_WH')\nSF_URL = f&quot;{SNOWFLAKE_ACCOUNT_URL}.snowflakecomputing.com&quot;\n\n# Versions - Note: Spark 3.5 required for Snowflake Connector masking support\nSNOWFLAKE_JDBC_VERSION = &quot;3.24.0&quot;\nSNOWFLAKE_SPARK_CONNECTOR_VERSION = &quot;3.1.6&quot;\n\nspark_analyst = SparkSession.builder \\\n    .appName(&quot;Fleet Analytics - Analyst View&quot;) \\\n    .master(&quot;local[*]&quot;) \\\n    .config(&quot;spark.driver.host&quot;, &quot;127.0.0.1&quot;) \\\n    .config(&quot;spark.driver.bindAddress&quot;, &quot;127.0.0.1&quot;) \\\n    .config(&quot;spark.jars.packages&quot;, \n            f&quot;org.apache.iceberg:iceberg-spark-runtime-4.0_{SCALA_VERSION}:{ICEBERG_VERSION},&quot;\n            f&quot;org.apache.iceberg:iceberg-aws-bundle:{ICEBERG_VERSION},&quot;\n            f&quot;net.snowflake:snowflake-jdbc:{SNOWFLAKE_JDBC_VERSION},&quot;\n            f&quot;net.snowflake:spark-snowflake_{SCALA_VERSION}:{SNOWFLAKE_SPARK_CONNECTOR_VERSION}&quot;) \\\n    .config(&quot;spark.sql.extensions&quot;, &quot;org.apache.iceberg.spark.extensions.IcebergSparkSessionExtensions&quot;) \\\n    .config(&quot;spark.sql.defaultCatalog&quot;, &quot;horizon&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon&quot;, &quot;org.apache.spark.sql.snowflake.catalog.SnowflakeFallbackCatalog&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.catalog-impl&quot;, &quot;org.apache.iceberg.spark.SparkCatalog&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.type&quot;, &quot;rest&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.uri&quot;, f&quot;https://{SNOWFLAKE_ACCOUNT_URL}.snowflakecomputing.com/polaris/api/catalog&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.warehouse&quot;, SNOWFLAKE_DATABASE) \\\n    .config(&quot;spark.sql.catalog.horizon.scope&quot;, f&quot;session:role:{SNOWFLAKE_ROLE}&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.credential&quot;, SNOWFLAKE_FLEET_ANALYST_TOKEN) \\\n    .config(&quot;spark.sql.catalog.horizon.io-impl&quot;, &quot;org.apache.iceberg.aws.s3.S3FileIO&quot;) \\\n    .config(&quot;spark.sql.catalog.horizon.header.X-Iceberg-Access-Delegation&quot;, &quot;vended-credentials&quot;) \\\n    .config(&quot;spark.snowflake.sfURL&quot;, SF_URL) \\\n    .config(&quot;spark.snowflake.sfUser&quot;, os.getenv('SNOWFLAKE_USER')) \\\n    .config(&quot;spark.snowflake.sfPassword&quot;, SNOWFLAKE_FLEET_ANALYST_TOKEN) \\\n    .config(&quot;spark.snowflake.sfDatabase&quot;, SNOWFLAKE_DATABASE) \\\n    .config(&quot;spark.snowflake.sfSchema&quot;, SNOWFLAKE_SCHEMA) \\\n    .config(&quot;spark.snowflake.sfRole&quot;, SNOWFLAKE_ROLE) \\\n    .config(&quot;spark.snowflake.sfWarehouse&quot;, SNOWFLAKE_WAREHOUSE) \\\n    .config(&quot;spark.sql.iceberg.vectorization.enabled&quot;, &quot;false&quot;) \\\n    .getOrCreate()\n\nspark_analyst.sparkContext.setLogLevel(&quot;ERROR&quot;)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EIceberg tables are still accessible via Iceberg REST API\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003Espark_analyst.sql(&quot;SHOW TABLES in horizon.RAW&quot;).show(truncate=False)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EWhen reading an Iceberg table with a maskign policy, Snowflake returns masked results\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-python\"\u003Espark_analyst.sql(&quot;&quot;&quot;\n    SELECT\n        VEHICLE_ID,\n        MAKE,\n        MODEL,\n        YEAR,\n        LICENSE_PLATE,\n        DRIVER_NAME,\n        DRIVER_EMAIL,\n        DRIVER_PHONE,\n        FLEET_REGION\n    FROM horizon.RAW.VEHICLE_REGISTRY\n&quot;&quot;&quot;).show(truncate=True)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/spark_masked.png?v=8cbd55b6\" alt=\"Interoperable Masking\"\u003E\u003C/p\u003E\n","\u003Cp\u003EThe masking policies defined in Snowflake are enforced even when accessing data through Spark!\u003C/p\u003E\n","\u003Cp\u003EFor more details on Spark integration, see:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-query-using-external-query-engine-snowflake-horizon\"\u003EQuery Iceberg Tables Using External Engines\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-query-using-external-query-engine-snowflake-horizon-enforce-access-policies\"\u003EEnforce Access Policies for External Engines\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003ECleanup\u003C/h2\u003E\n","\u003Cp\u003ETo remove all objects created by this guide:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE ACCOUNTADMIN;\n\n-- Drop the database (this removes all tables, schemas, and objects)\nDROP DATABASE IF EXISTS FLEET_ANALYTICS_DB;\n\n-- Drop the external volume only if you used customer-managed storage (USE_SNOWFLAKE_STORAGE=false)\nDROP EXTERNAL VOLUME IF EXISTS FLEET_ICEBERG_VOL;\n\n-- Drop the warehouse\nDROP WAREHOUSE IF EXISTS FLEET_ANALYTICS_WH;\n\n-- Drop roles\nDROP ROLE IF EXISTS FLEET_ANALYST;\nDROP ROLE IF EXISTS FLEET_ENGINEER;\nDROP ROLE IF EXISTS FLEET_ADMIN;\n\n-- If you created replication groups, remove them\nDROP REPLICATION GROUP IF EXISTS FLEET_ANALYTICS_REPLICATION;\n\n-- Remove network policy from user (if applied)\nALTER USER &lt;your_username&gt; UNSET NETWORK_POLICY;\nDROP NETWORK POLICY IF EXISTS FLEET_STREAMING_POLICY;\n\n-- External access integration\nDROP INTEGRATION IF EXISTS OPEN_METEO_ACCESS;\n\nSELECT 'Uncomment the commands above to cleanup' AS NOTE;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EIf you used customer-managed cloud storage, you may also want to clean up the Iceberg data files in your bucket or container.\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EConclusion and Resources\u003C/h2\u003E\n","\u003Cp\u003ECongratulations! You've built a comprehensive analytics platform using Snowflake Iceberg V3 tables, demonstrating the full power of Snowflake's modern lakehouse architecture.\u003C/p\u003E\n","\u003Ch3\u003EWhat You Learned\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EIceberg V3 Tables\u003C/strong\u003E: Created tables with VARIANT columns for semi-structured data, supporting flexible schemas\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EStreaming Ingestion\u003C/strong\u003E: Used Snowpipe Streaming to ingest real-time vehicle telemetry with sub-second latency\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EMulti-Source Ingestion\u003C/strong\u003E: Loaded data from web APIs and batch JSON files into Iceberg tables\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EDeclarative Pipelines\u003C/strong\u003E: Built incremental transformation pipelines with Dynamic Iceberg Tables\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EEnterprise Governance\u003C/strong\u003E: Applied PII detection, masking policies, and data quality monitoring\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAdvanced Analytics\u003C/strong\u003E: Performed time-series analysis, forecasting, and geospatial queries\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAI Integration\u003C/strong\u003E: Connected Iceberg data to Snowflake CoWork for natural language analytics\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EBusiness Continuity\u003C/strong\u003E: Configured cross-region replication for disaster recovery\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EInteroperability\u003C/strong\u003E: Queried Iceberg tables from Spark with enforced access controls\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EKey Benefits of Iceberg V3 Tables in Snowflake\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003EOpen Format\u003C/strong\u003E: Data stored in open Apache Iceberg format, accessible by any compatible engine\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EVARIANT Support\u003C/strong\u003E: Full semi-structured data capabilities with V3 table format\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EUnified Governance\u003C/strong\u003E: Single place to manage security, quality, and lineage across all engines\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EIncremental Processing\u003C/strong\u003E: Dynamic Tables automatically handle incremental transformations\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EEnterprise Features\u003C/strong\u003E: Time travel, cloning, replication all work with Iceberg tables\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EPerformance\u003C/strong\u003E: Snowflake's query optimization applies to Iceberg tables\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003ERelated Resources\u003C/h3\u003E\n","\u003Cp\u003E\u003Cstrong\u003EDocumentation:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage\"\u003ESnowflake storage for Apache Iceberg tables\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/LIMITEDACCESS/iceberg/tables-iceberg-v3-specification-support\"\u003EIceberg V3 Support in Snowflake\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/snowpipe-streaming/snowpipe-streaming-high-performance-overview\"\u003ESnowpipe Streaming\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/dynamic-tables-create-iceberg\"\u003EDynamic Iceberg Tables\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/snowflake-cortex/snowflake-intelligence\"\u003ESnowflake CoWork\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/tables-iceberg-replication\"\u003EIceberg Table Replication\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EGuides:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"/en/developers/guides/declarative-pipelines-using-dynamic-iceberg-tables/\"\u003EBuild Declarative Pipelines with Dynamic Iceberg Tables\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"/en/developers/guides/getting-started-with-data-quality-in-snowflake/\"\u003EGetting Started with Data Quality in Snowflake\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EAssets:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://github.com/Snowflake-Labs/sfquickstarts/tree/master/site/sfguides/src/iceberg-v3-tables-comprehensive-guide/assets\"\u003EGuide Assets Folder\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E"],"title":"Enterprise Lakehouse Platform for Iceberg V3","isDeveloperGuidesPage":false,":type":"snowflake-site/components/contentfragment",":items":{},":itemsOrder":[],"elements":{"quickstartArticleBody":{"dataType":"string","title":"Quickstart Article Body","value":"\u003C!-- ------------------------ --\u003E\n## Overview\n\nThis comprehensive guide demonstrates how to build a complete data engineering, analytics, and AI platform using Snowflake's Iceberg V3 tables. You'll work with a realistic Smart Fleet IoT Analytics use case that encompasses streaming semi-structured data, JSON log analysis, time-series analytics with nanosecond precision, and geospatial intelligence.\n\nApache Iceberg V3 tables in Snowflake support the VARIANT data type, enabling efficient storage and querying of semi-structured data while maintaining the open table format's interoperability benefits. Combined with Snowflake's enterprise features for governance, AI/ML, and business continuity, you can build a truly modern lakehouse architecture.\n\n### Use Case: Smart Fleet IoT Analytics\n\nYou'll build an analytics platform for a fleet management company that:\n\n- **Streams real-time vehicle telemetry** - Speed, location, engine diagnostics, fuel consumption as semi-structured VARIANT data\n- **Ingests maintenance logs** - JSON-formatted diagnostic reports and service records from cloud storage\n- **Analyzes time-series sensor data** - High-precision timestamp data for trend analysis and forecasting\n- **Performs geospatial analytics** - Route optimization, geofencing, location-based insights\n- **Powers AI agents** - Natural language querying of fleet analytics via Snowflake CoWork\n\n### What You Will Learn\n\n- Creating and managing Iceberg V3 tables with Snowflake Horizon Catalog\n- Streaming semi-structured data into VARIANT columns in Iceberg tables using Snowpipe Streaming\n- Ingesting data from web APIs and batch loading JSON logs\n- Building declarative transformation pipelines with Dynamic Iceberg Tables, powered by row lineage\n- Applying enterprise governance: PII detection, masking policies, data quality\n- Performing time-series analysis, forecasting, and geospatial analytics with Iceberg v3 data types\n- Enabling AI agents on Iceberg data with Snowflake CoWork\n- Setting up cross-region replication for business continuity on v3 Iceberg tables\n- Querying Iceberg tables from Apache Spark via Iceberg REST API with vended storage credentials and Horizon fine-grained access controls\n\n### What You Will Build\n\n- **6+ Iceberg V3 tables** covering streaming events, logs, time-series, and geospatial data\n- **Dynamic Iceberg Tables** for automated incremental transformations\n- **Streaming pipeline** using Snowpipe Streaming with Python SDK\n- **Governance framework** with masking policies and data quality functions\n- **ML forecasting model** for predictive maintenance\n- **Snowflake CoWork agent** for natural language analytics\n- **Spark notebooks** demonstrating interoperability with enforced access controls\n\n### Prerequisites\n\n**Snowflake Requirements:**\n- Snowflake account with `ACCOUNTADMIN` role access\n- Standard Edition or higher (Enterprise features noted where applicable)\n- Ability to create databases, schemas, warehouses, and Iceberg tables\n\n**Required Tools:**\n- [Snowflake CLI](https://docs.snowflake.com/en/developer-guide/snowflake-cli/installation/installation) installed with a [configured connection](https://docs.snowflake.com/en/developer-guide/snowflake-cli/connecting/specify-credentials)\n- Python 3.9+ with pip\n\n\u003E **Snowflake CLI Connection**: Before running the setup, configure a connection named `default`:\n\u003E ```bash\n\u003E snow connection add --connection-name default --account \u003Cyour-account\u003E --user \u003Cyour-user\u003E\n\u003E ```\n\n**For Snowflake-managed Iceberg storage (default in this lab):**\n- No customer-owned bucket or external volume is required. Snowflake stores Iceberg files using the reserved volume `SNOWFLAKE_MANAGED`; see [Snowflake storage for Apache Iceberg tables](https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage).\n- This storage option is available on accounts hosted on **AWS** or **Azure** (not Google Cloud).\n\n**Optional — customer-managed object storage:**\n- If you set `USE_SNOWFLAKE_STORAGE=false` in `config.env`, you need AWS S3, Google Cloud Storage, or Azure Storage (Blob, ADLS Gen2, or OneLake) and the appropriate IAM roles or service principals.\n\n**For Spark Interoperability Section:**\n- Conda package manager installed (for isolated PySpark environment)\n- Apache Spark 4.0+ (required for VARIANT support in Iceberg V3)\n\n\u003E **Note**: At the time of writing, Spark does not support nanosecond timestamps or geospatial data types in Iceberg tables.\n\n### Objects Created in This Guide\n\n| Object Type | Name | Purpose |\n|------------|------|---------|\n| Database | FLEET_ANALYTICS_DB | Contains all demo objects |\n| Warehouse | FLEET_ANALYTICS_WH | Compute for all operations |\n| Iceberg table storage | Snowflake-managed (`SNOWFLAKE_MANAGED`) | Default: Snowflake stores Iceberg files; no external volume object. Optional: customer volume `FLEET_ICEBERG_VOL` if `USE_SNOWFLAKE_STORAGE=false` |\n| Iceberg Table | VEHICLE_TELEMETRY_STREAM | Real-time streaming events (VARIANT) |\n| Iceberg Table | MAINTENANCE_LOGS | Batch-loaded JSON logs (VARIANT) |\n| Iceberg Table | SENSOR_READINGS | Time-series sensor data |\n| Iceberg Table | VEHICLE_LOCATIONS | Geospatial vehicle positions |\n| Iceberg Table | VEHICLE_REGISTRY | Vehicle master data |\n| Iceberg Table | API_WEATHER_DATA | Weather data from public API (VARIANT) |\n| Dynamic Table | TELEMETRY_ENRICHED | Joined and enriched telemetry |\n| Dynamic Table | DAILY_FLEET_SUMMARY | Aggregated fleet analytics |\n| Masking Policy | PII_MASK | Masks sensitive driver information |\n| Data Metric Function | CHECK_VALID_COORDINATES | Validates geospatial data |\n| Stage | LOGS_STAGE | Internal stage for JSON files |\n| External Access Integration | OPEN_METEO_ACCESS | Allows notebook API calls |\n| Network Policy (optional) | FLEET_STREAMING_POLICY | Allows streaming script connections |\n| Cortex Agent | FLEET_ANALYTICS_AGENT | Natural language querying of fleet data |\n\n\u003C!-- ------------------------ --\u003E\n## Environment Setup\n\nThis section guides you through setting up your environment. The setup is designed to be as simple as possible: clone the repo, configure a few variables, and run the setup script.\n\n### Step 1: Download the Assets\n\nDownload or clone the guide assets from the [assets folder](https://github.com/Snowflake-Labs/sfquickstarts/tree/master/site/sfguides/src/iceberg-v3-tables-comprehensive-guide/assets):\n\n```bash\n# Clone the sfquickstarts repo and navigate to the assets\ngit clone https://github.com/Snowflake-Labs/sfquickstarts.git\ncd sfquickstarts/site/sfguides/src/iceberg-v3-tables-comprehensive-guide/assets\n```\n\n### Step 2: Configure Variables\n\nEdit the `config.env` file in the repository root:\n\n```bash\n# Required: Snowflake Account Information\nSNOWFLAKE_ACCOUNT=\"your_account_identifier\"\nSNOWFLAKE_USER=\"your_username\"\nSNOWFLAKE_ROLE=\"ACCOUNTADMIN\"\nSNOWFLAKE_WAREHOUSE=\"FLEET_ANALYTICS_WH\"\nSNOWFLAKE_DATABASE=\"FLEET_ANALYTICS_DB\"\n\n# Iceberg storage — default is Snowflake-managed (no bucket or external volume).\n# See: https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage\nUSE_SNOWFLAKE_STORAGE=true\n\n# --- Only if USE_SNOWFLAKE_STORAGE=false (customer-managed storage) ---\n# OPTION A: Use an existing external volume\nUSE_EXISTING_VOLUME=false\nEXISTING_VOLUME_NAME=\"\"\n\n# OPTION B: Create a new external volume named FLEET_ICEBERG_VOL\nSTORAGE_PROVIDER=\"S3\"  # Options: S3, GCS, AZURE\n\n# --- AWS S3 ---\nS3_BUCKET_NAME=\"your-bucket-name\"\nS3_PATH=\"iceberg/fleet-analytics/\"\nAWS_ROLE_ARN=\"\"  # Your IAM role ARN (see AWS S3 Setup below)\n\n# --- Google Cloud Storage ---\nGCS_BUCKET_NAME=\"your-bucket-name\"\nGCS_PATH=\"iceberg/fleet-analytics/\"\n\n# --- Azure Storage (Blob, ADLS Gen2, or OneLake) ---\n# See: https://docs.snowflake.com/en/user-guide/tables-iceberg-configure-external-volume-azure\nAZURE_TENANT_ID=\"your-tenant-id\"\nAZURE_STORAGE_ACCOUNT=\"your-storage-account\"\nAZURE_CONTAINER=\"your-container\"\nAZURE_PATH=\"iceberg/fleet-analytics/\"\n# For OneLake, set USE_ONELAKE=true and provide workspace/lakehouse GUIDs\nUSE_ONELAKE=false\nONELAKE_WORKSPACE_GUID=\"\"\nONELAKE_LAKEHOUSE_GUID=\"\"\n```\n\n### Step 3: Run Setup Script\n\nThe setup script will create all necessary Snowflake objects.\n\n```bash\n# Make the script executable\nchmod +x setup.sh\n\n# Run the setup\n./setup.sh\n```\n\n**What the setup script does:**\n\n1. Creates the database, schema, and warehouse\n2. Sets Iceberg storage to Snowflake-managed by default (`SNOWFLAKE_MANAGED`), or creates/uses a customer external volume when `USE_SNOWFLAKE_STORAGE=false`\n3. Creates all Iceberg V3 tables with appropriate schemas\n4. Creates Dynamic Iceberg Tables for transformation pipelines\n5. Creates governance objects (masking policies, data quality functions) - *Enterprise edition only*\n6. Uploads sample JSON log files to the internal stage\n7. Creates the Snowflake CoWork agent configuration\n\n### Step 4: Import the Snowflake Notebook\n\nImport the pre-populated notebook into Snowflake to follow along with the live demo:\n\n1. Sign in to [Snowsight](https://app.snowflake.com)\n2. In the navigation menu, select **Projects » Notebooks**\n3. Click the down arrow next to **+ Notebook** and select **Import .ipynb file**\n4. Navigate to the cloned repository and select `assets/fleet_analytics_notebook.ipynb`\n5. In the import dialog:\n   - **Notebook location**: Select `FLEET_ANALYTICS_DB` and `RAW` schema\n   - **Query warehouse**: Select `FLEET_ANALYTICS_WH`\n6. Click **Create** to import the notebook\n\n\u003E **Note**: The notebook is pre-configured with SQL and Python cells that should import with the correct cell types.\n\n**After importing**, enable external API access for the weather data section:\n1. Click **Notebook settings** (⋮ icon, top right)\n2. Select **External access**\n3. Toggle ON **OPEN_METEO_ACCESS**\n4. Click **Save**\n\nFor more details on creating notebooks, see [Create a notebook](https://docs.snowflake.com/en/user-guide/ui-snowsight/notebooks-create#create-a-new-notebook).\n\n### External volume setup (customer-managed storage only)\n\nWith the default `USE_SNOWFLAKE_STORAGE=true`, Iceberg tables use [Snowflake storage for Apache Iceberg tables](https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage) (`EXTERNAL_VOLUME = 'SNOWFLAKE_MANAGED'`). You can skip this entire subsection.\n\nIf you set `USE_SNOWFLAKE_STORAGE=false`, Iceberg tables use a **customer-managed external volume** pointing to your object storage. Configure `config.env` (existing volume or new `FLEET_ICEBERG_VOL` via `STORAGE_PROVIDER`) and complete provider-specific setup before running `setup.sh`.\n\nYou can also create external volumes from Snowflake's web UI by navigating to **Catalog \u003E External data \u003E External volumes tab**.\n\n![Create External Volume](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/create_external_volume.png?v=8cbd55b6)\n\n**AWS S3 Setup:**\n\n1. Create an IAM policy granting Snowflake access to your S3 bucket:\n\n```json\n{\n    \"Version\": \"2012-10-17\",\n    \"Statement\": [\n        {\n            \"Effect\": \"Allow\",\n            \"Action\": [\n                \"s3:GetObject\",\n                \"s3:GetObjectVersion\",\n                \"s3:PutObject\",\n                \"s3:DeleteObject\",\n                \"s3:ListBucket\",\n                \"s3:GetBucketLocation\"\n            ],\n            \"Resource\": [\n                \"arn:aws:s3:::your-bucket-name/*\",\n                \"arn:aws:s3:::your-bucket-name\"\n            ]\n        }\n    ]\n}\n```\n\n2. Create an IAM role with this policy and update the trust relationship after running `DESCRIBE EXTERNAL VOLUME` to get the Snowflake AWS IAM user ARN.\n\n**GCS Setup:**\n\n1. Create a Cloud Storage service account\n2. Grant `storage.objectAdmin` role on your bucket\n3. After running `DESCRIBE EXTERNAL VOLUME`, grant the Snowflake service account access\n\n**Azure Setup:**\n\n1. Create an Azure AD application registration\n2. Grant `Storage Blob Data Contributor` role on your container\n3. Configure the application for Snowflake access\n\nThe setup script will provide specific instructions for your chosen provider.\n\n### Verify Setup\n\nAfter running the setup script, verify everything was created:\n\n```sql\n-- Connect to Snowflake and run:\nUSE DATABASE FLEET_ANALYTICS_DB;\nSHOW ICEBERG TABLES;\nSHOW DYNAMIC TABLES;\nSHOW MASKING POLICIES;\nSHOW DATA METRIC FUNCTIONS;\nLIST @LOGS_STAGE;\n```\n\nYou should see all the Iceberg tables, dynamic tables, and governance objects listed.\n\n\u003C!-- ------------------------ --\u003E\n## Streaming and Ingest\n\nThis section demonstrates various methods Snowflake supports for loading semi-structured data into Iceberg V3 tables with the VARIANT data type.\n\n### Snowpipe Streaming: Real-Time Vehicle Telemetry\n\nSnowpipe Streaming enables low-latency ingestion of streaming data directly into Iceberg tables. The high-performance architecture provides sub-second latency for getting data queryable in Snowflake.\n\n#### Review the Streaming Target Table\n\nThe setup script created an Iceberg table designed to receive streaming telemetry:\n\n```sql\nUSE DATABASE FLEET_ANALYTICS_DB;\n\n-- View the table structure\nDESCRIBE TABLE VEHICLE_TELEMETRY_STREAM;\n```\n\n```sql\n-- Confirm the table exists but is empty\nSELECT COUNT(*) FROM VEHICLE_TELEMETRY_STREAM;\n-- Returns: 0\n\n-- View the table properties showing it's an Iceberg V3 table with VARIANT column\nSELECT \n    GET_DDL('TABLE', 'VEHICLE_TELEMETRY_STREAM');\n```\n\nYou'll see a VARIANT column called `TELEMETRY_DATA` designed to hold the flexible schema vehicle telemetry payload.\n\n#### Start the Streaming Simulation\n\nOpen a terminal and navigate to the cloned repository:\n\n```bash\ncd iceberg-v3-tables-comprehensive-guide/assets\n\n# Activate the Python environment (created by setup.sh)\nsource iceberg_v3_demo_venv/bin/activate\n\n# Start the streaming simulation (runs for 5 minutes max)\npython stream_telemetry.py\n```\n\n\u003E **Troubleshooting Connection Issues**: If you're on a VPN or corporate network and get connection errors, you may need a network policy to allow inbound connections. Set `ENABLE_NETWORK_POLICY=true` in `config.env` and re-run setup, or manually run `08_network_policy.sql` in Snowsight, then apply the policy to your user:\n\u003E ```sql\n\u003E ALTER USER \u003Cyour_username\u003E SET NETWORK_POLICY = FLEET_STREAMING_POLICY;\n\u003E ```\n\nThe Python script uses the Snowpipe Streaming SDK to simulate vehicle telemetry events:\n\n```python\n# Example of what the streaming script sends\n{\n    \"vehicle_id\": \"VH-2847\",\n    \"event_timestamp\": \"2026-02-03T14:32:15.847293847\",  # Nanosecond precision\n    \"telemetry_data\": {\n        \"location\": {\"lat\": 37.7749, \"lon\": -122.4194},\n        \"speed_mph\": 65.3,\n        \"heading\": 285,\n        \"engine\": {\n            \"rpm\": 3200,\n            \"temperature_f\": 195,\n            \"oil_pressure_psi\": 42,\n            \"fuel_level_pct\": 67.5\n        },\n        \"diagnostics\": {\n            \"check_engine\": false,\n            \"tire_pressure_warning\": false,\n            \"codes\": []\n        },\n        \"driver_behavior\": {\n            \"hard_acceleration_count\": 2,\n            \"hard_brake_count\": 1,\n            \"sharp_turn_count\": 0\n        }\n    }\n}\n```\n\n#### Observe Data Flowing In\n\nWhile the streaming script runs, watch data appear in Snowflake:\n\n```sql\n-- Check current count of streaming events\nSELECT COUNT(*) AS event_count FROM VEHICLE_TELEMETRY_STREAM;\n\n-- View the latest streaming events with VARIANT extraction\nSELECT \n    VEHICLE_ID,\n    EVENT_TIMESTAMP,\n    TELEMETRY_DATA:location:lat::FLOAT AS latitude,\n    TELEMETRY_DATA:location:lon::FLOAT AS longitude,\n    TELEMETRY_DATA:speed_mph::FLOAT AS speed_mph,\n    TELEMETRY_DATA:engine:temperature_f::INT AS engine_temp,\n    TELEMETRY_DATA:engine:fuel_level_pct::FLOAT AS fuel_level\nFROM VEHICLE_TELEMETRY_STREAM\nORDER BY EVENT_TIMESTAMP DESC\nLIMIT 10;\n```\n\nThe streaming data is immediately queryable with full SQL capabilities on the VARIANT column!\n\n### Pull from a Web API: Weather Data\n\nInstead of multi-step file-based ingestion, Snowflake can connect directly to web APIs and ingest semi-structured responses into Iceberg tables with VARIANT.\n\n#### Enable External Access in Your Notebook\n\nSnowflake Notebooks require an **External Access Integration** to call external APIs. The setup script created an integration for the Open-Meteo weather API.\n\n**Before running the Python cell:**\n\n1. In your Snowflake Notebook, click the **Notebook settings** (⋮ icon, top right)\n2. Select **External access**\n3. Toggle ON **OPEN_METEO_ACCESS**\n4. Click **Save**\n\n\u003E **Note**: If you don't see `OPEN_METEO_ACCESS`, run this SQL first:\n\u003E ```sql\n\u003E CREATE OR REPLACE NETWORK RULE FLEET_ANALYTICS_DB.RAW.OPEN_METEO_NETWORK_RULE\n\u003E     MODE = EGRESS TYPE = HOST_PORT VALUE_LIST = ('api.open-meteo.com:443');\n\u003E CREATE OR REPLACE EXTERNAL ACCESS INTEGRATION OPEN_METEO_ACCESS\n\u003E     ALLOWED_NETWORK_RULES = (FLEET_ANALYTICS_DB.RAW.OPEN_METEO_NETWORK_RULE) ENABLED = TRUE;\n\u003E ```\n\n#### View the Target Table\n\n```sql\n-- The table was created during setup\nDESCRIBE TABLE API_WEATHER_DATA;\n\n-- Confirm it's empty\nSELECT COUNT(*) AS current_count FROM API_WEATHER_DATA;\n```\n\n#### Create and Run the API Ingestion Function\n\nIn your Snowflake Notebook (or worksheet), create a Python function to fetch weather data:\n\n```python\n# This is pre-populated in the Snowflake Notebook\nimport snowflake.snowpark as snowpark\nfrom snowflake.snowpark.functions import col, parse_json, current_timestamp\nimport requests\n\ndef fetch_weather_data(session: snowpark.Session, cities: list) -\u003E str:\n    \"\"\"\n    Fetches weather data from Open-Meteo API and loads into Iceberg table.\n    Open-Meteo is a free, open-source weather API requiring no API key.\n    \"\"\"\n    \n    weather_records = []\n    \n    for city in cities:\n        # Using Open-Meteo free API\n        url = f\"https://api.open-meteo.com/v1/forecast\"\n        params = {\n            \"latitude\": city[\"lat\"],\n            \"longitude\": city[\"lon\"],\n            \"current\": \"temperature_2m,wind_speed_10m,precipitation\",\n            \"hourly\": \"temperature_2m,precipitation_probability\"\n        }\n        \n        response = requests.get(url, params=params)\n        if response.status_code == 200:\n            weather_records.append({\n                \"city_name\": city[\"name\"],\n                \"latitude\": city[\"lat\"],\n                \"longitude\": city[\"lon\"],\n                \"api_response\": response.text,\n                \"fetched_at\": datetime.now().isoformat()\n            })\n    \n    # Create DataFrame and write to Iceberg table\n    df = session.create_dataframe(weather_records)\n    df = df.with_column(\"WEATHER_DATA\", parse_json(col(\"API_RESPONSE\")))\n    df.select(\n        col(\"CITY_NAME\"),\n        col(\"LATITUDE\"),\n        col(\"LONGITUDE\"), \n        col(\"WEATHER_DATA\"),\n        current_timestamp().alias(\"INGESTED_AT\")\n    ).write.mode(\"append\").save_as_table(\"API_WEATHER_DATA\")\n    \n    return f\"Loaded weather data for {len(weather_records)} cities\"\n\n# Define cities for fleet operations\nfleet_cities = [\n    {\"name\": \"San Francisco\", \"lat\": 37.7749, \"lon\": -122.4194},\n    {\"name\": \"Los Angeles\", \"lat\": 34.0522, \"lon\": -118.2437},\n    {\"name\": \"Seattle\", \"lat\": 47.6062, \"lon\": -122.3321},\n    {\"name\": \"Denver\", \"lat\": 39.7392, \"lon\": -104.9903},\n    {\"name\": \"Chicago\", \"lat\": 41.8781, \"lon\": -87.6298}\n]\n\n# Execute the function\nresult = fetch_weather_data(session, fleet_cities)\nprint(result)\n```\n\n#### Query the Weather Data\n\n```sql\n-- View the loaded weather data\nSELECT \n    CITY_NAME,\n    WEATHER_DATA:current:temperature_2m::FLOAT AS current_temp_c,\n    WEATHER_DATA:current:wind_speed_10m::FLOAT AS wind_speed_kmh,\n    WEATHER_DATA:current:precipitation::FLOAT AS precipitation_mm,\n    INGESTED_AT\nFROM API_WEATHER_DATA;\n\n-- Extract hourly forecast for a city\nSELECT \n    CITY_NAME,\n    f.value::FLOAT AS hourly_temp\nFROM API_WEATHER_DATA,\nLATERAL FLATTEN(input =\u003E WEATHER_DATA:hourly:temperature_2m) f\nWHERE CITY_NAME = 'San Francisco'\nLIMIT 24;\n```\n\n\u003E **Tip**: This ingestion pattern can be orchestrated natively in Snowflake using [Tasks](https://docs.snowflake.com/en/user-guide/tasks-intro) or [Serverless Tasks](https://docs.snowflake.com/en/user-guide/tasks-serverless) for scheduled API pulls.\n\n### Batch Ingest JSON Logs\n\nSnowflake handles batch or continuous ingestion of semi-structured data stored in files, such as JSON diagnostic logs.\n\n#### View the Staged Files\n\nThe setup script uploaded 10 sample JSON files mimicking maintenance diagnostic logs:\n\n```sql\n-- List the staged JSON files\nLIST @LOGS_STAGE;\n```\n\nYou should see files like:\n- `maintenance_log_001.json`\n- `maintenance_log_002.json`\n- ... through `maintenance_log_010.json`\n\n#### Load JSON Logs into Iceberg Table\n\n```sql\n-- Load JSON files into Iceberg table\nCOPY INTO MAINTENANCE_LOGS (LOG_ID, VEHICLE_ID, LOG_TIMESTAMP, LOG_DATA, SOURCE_FILE)\nFROM (\n    SELECT \n        $1:log_id::VARCHAR,\n        $1:vehicle_id::VARCHAR,\n        $1:log_timestamp::TIMESTAMP_NTZ,\n        $1,\n        METADATA$FILENAME\n    FROM @LOGS_STAGE\n)\nFILE_FORMAT = (TYPE = 'JSON' STRIP_OUTER_ARRAY = TRUE)\nPATTERN = '.*maintenance_log.*\\.json';\n\n-- View the loaded maintenance logs with VARIANT data\nSELECT \n    LOG_ID,\n    VEHICLE_ID,\n    LOG_TIMESTAMP,\n    LOG_DATA:event_type::STRING AS event_type,\n    LOG_DATA:severity::STRING AS severity,\n    LOG_DATA:description::STRING AS description,\n    LOG_DATA:total_cost::FLOAT AS total_cost\nFROM MAINTENANCE_LOGS\nORDER BY LOG_TIMESTAMP DESC\nLIMIT 10;\n```\n\n\u003C!-- ------------------------ --\u003E\n## Transformation\n\nThis section demonstrates how Snowflake powers transformation pipelines on Iceberg tables using Dynamic Tables. Dynamic Tables provide a declarative approach to data transformation—you define what the output should look like, and Snowflake handles the incremental refresh automatically.\n\nRow lineage is used under the hood of Dynamic Iceberg V3 Tables to power change data capture (CDC) and incremental processing.\n\n### Dynamic Iceberg Tables Overview\n\nThe setup script created several Dynamic Iceberg Tables that form a transformation pipeline:\n\n```sql\n-- View all dynamic tables in the pipeline\nSHOW DYNAMIC TABLES IN DATABASE FLEET_ANALYTICS_DB;\n```\n\nThese tables automatically refresh based on their TARGET_LAG setting, processing only incremental changes from source tables.\n\n#### Explore the Pipeline in the UI\n\n1. Navigate to **Transformation** → **Dynamic Tables** in the left pane\n2. Filter by database: **FLEET_ANALYTICS_DB**\n3. Click on any dynamic table (e.g., `TELEMETRY_ENRICHED`)\n4. Explore the tabs:\n   - **Graph**: Visualize the full pipeline and dependencies\n   - **Refresh History**: See incremental refresh operations\n   - **Definition**: Review the declarative SQL that defines the transformation\n\n#### View the Dynamic Table Graph\n\nThe transformation pipeline looks like this:\n\n![Dynamic Iceberg Table Graph](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/dit_graph.png?v=8cbd55b6)\n\n#### Monitor Incremental Refreshes\n\nAs streaming data flows in, watch the dynamic tables refresh:\n\n![Dynamic Iceberg Table Incremental Refresh](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/dit_incremental_refresh.png?v=8cbd55b6)\n\nThe `REFRESH_MODE = INCREMENTAL` setting ensures only new or changed data is processed, making the pipeline highly efficient.\n\n#### Query Transformed Data\n\n```sql\n-- Query enriched telemetry with vehicle details\nSELECT \n    VEHICLE_ID,\n    MAKE,\n    MODEL,\n    DRIVER_NAME,\n    FLEET_REGION,\n    speed_mph,\n    engine_temp_f,\n    engine_health_status,\n    driving_behavior,\n    EVENT_TIMESTAMP\nFROM CURATED.TELEMETRY_ENRICHED\nWHERE engine_health_status != 'NORMAL' OR driving_behavior = 'AGGRESSIVE'\nORDER BY EVENT_TIMESTAMP DESC\nLIMIT 20;\n```\n\n\u003C!-- ------------------------ --\u003E\n## Security and Governance\n\nThis section highlights Horizon Catalog as the central, unified, interoperable catalog with enterprise-grade security features. All governance capabilities work seamlessly with Iceberg V3 tables.\n\n### PII Detection with Classification\n\nSnowflake can automatically detect and classify sensitive data across your entire database, including Iceberg tables.\n\n#### Classify the Schema\n\n1. Navigate to **Data** → **Databases** → **FLEET_ANALYTICS_DB** → **RAW** (the schema)\n2. Click the **three dots menu** (⋮) in the top right corner\n3. Select **Classify and Tag Sensitive Data**\n4. Select all Iceberg tables in the schema\n5. Toggle **Automatically tag data** ON\n6. Click **Classify and Tag Sensitive Data**\n\n![Classify and Tag Sensitive Data](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/classify_sensitive_data.png?v=8cbd55b6)\n\n#### View Applied Tags\n\nAfter classification completes:\n\n1. Navigate to any table (e.g., `VEHICLE_REGISTRY`)\n2. Click the **Columns** tab\n3. Notice tags applied to sensitive columns like `DRIVER_NAME`, `DRIVER_EMAIL`, `DRIVER_PHONE`\n\n![Tagged Sensitive Data](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/classification_tag.png?v=8cbd55b6)\n\nCommon tags that may be applied:\n- `SEMANTIC_CATEGORY:NAME` - Personal names\n- `SEMANTIC_CATEGORY:EMAIL` - Email addresses\n- `SEMANTIC_CATEGORY:PHONE_NUMBER` - Phone numbers\n- `SEMANTIC_CATEGORY:US_SSN` - Social Security Numbers\n\n\u003E **Tip**: You can also create [custom tags that automatically propagate](https://docs.snowflake.com/en/user-guide/object-tagging/work#define-a-tag-that-will-automatically-propagate) to existing and new downstream objects.\n\n### Fine-Grained Access Control with Masking Policies\n\nThe setup script created masking policies to protect sensitive information. Now apply them to your Iceberg tables.\n\n#### View Created Masking Policies\n\n```sql\n-- View all masking policies in the database\nSHOW MASKING POLICIES IN DATABASE FLEET_ANALYTICS_DB;\n```\n\nThe `PII_MASK` policy was created:\n\n```sql\n-- View the policy definition\nSELECT GET_DDL('MASKING_POLICY', 'PII_MASK');\n```\n\n```sql\nCREATE OR REPLACE MASKING POLICY PII_MASK AS (val STRING) \nRETURNS STRING -\u003E\n    CASE\n        WHEN CURRENT_ROLE() IN ('FLEET_ADMIN', 'ACCOUNTADMIN') THEN val\n        WHEN CURRENT_ROLE() = 'FLEET_ANALYST' THEN \n            CONCAT(LEFT(val, 2), '****', RIGHT(val, 2))\n        ELSE '********'\n    END;\n```\n\n#### Apply Masking Policies via UI\n\n1. Navigate to **Data** → **Databases** → **FLEET_ANALYTICS_DB** → **RAW** → **VEHICLE_REGISTRY**\n2. Click the **Columns** tab\n3. Find the `DRIVER_NAME` column\n4. In the **Policies** column, click the **+** button\n5. Select `PII_NAME_MASK` and click **Done**\n6. Repeat for `DRIVER_EMAIL` and `DRIVER_PHONE` with `PII_EMAIL_MASK` and `PII_PHONE_MASK`\n\n![Mask Tagged Columns](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/tag_mask.png?v=8cbd55b6)\n\n#### Test Masking Behavior\n\n```sql\n-- As ACCOUNTADMIN, see full PII values (unmasked)\nSELECT VEHICLE_ID, DRIVER_NAME, DRIVER_EMAIL, DRIVER_PHONE\nFROM VEHICLE_REGISTRY LIMIT 5;\n\n-- Create a test analyst role and grant it to the current user\nCREATE ROLE IF NOT EXISTS FLEET_ANALYST;\nGRANT USAGE ON DATABASE FLEET_ANALYTICS_DB TO ROLE FLEET_ANALYST;\nGRANT USAGE ON SCHEMA FLEET_ANALYTICS_DB.RAW TO ROLE FLEET_ANALYST;\nGRANT SELECT ON ALL TABLES IN SCHEMA FLEET_ANALYTICS_DB.RAW TO ROLE FLEET_ANALYST;\nGRANT USAGE ON WAREHOUSE FLEET_ANALYTICS_WH TO ROLE FLEET_ANALYST;\n\n-- Grant the role to the current user so we can switch to it\nSET MY_USER = CURRENT_USER();\nGRANT ROLE FLEET_ANALYST TO USER IDENTIFIER($MY_USER);\n\n-- Switch to analyst role and observe MASKED values\nUSE ROLE FLEET_ANALYST;\nSELECT VEHICLE_ID, DRIVER_NAME, DRIVER_EMAIL, DRIVER_PHONE\nFROM VEHICLE_REGISTRY LIMIT 5;\n-- Results show masked values: \"Jo****hn\", \"jo****om\"\n\n-- Switch back to ACCOUNTADMIN for remaining operations\nUSE ROLE ACCOUNTADMIN;\n```\n\n### Data Quality Monitoring\n\nThe setup script created Data Metric Functions (DMFs) to monitor data quality on Iceberg tables.\n\n#### View Data Quality Setup\n\n```sql\n-- Show data metric functions\nSHOW DATA METRIC FUNCTIONS IN DATABASE FLEET_ANALYTICS_DB;\n```\n\nExample DMF for validating geospatial coordinates:\n\n```sql\nCREATE OR REPLACE DATA METRIC FUNCTION CHECK_VALID_COORDINATES(\n    arg_t TABLE(lat FLOAT, lon FLOAT)\n)\nRETURNS NUMBER\nAS\n$$\n    SELECT COUNT(*) \n    FROM arg_t\n    WHERE lat \u003C -90 OR lat \u003E 90 \n       OR lon \u003C -180 OR lon \u003E 180\n$$;\n```\n\n#### Review Data Quality Results\n\n\u003E **Note**: The Data Quality dashboard will initially be empty. DMFs run on a schedule (default: when triggered by Snowflake). To see results sooner, set a shorter schedule and insert new data to trigger the DMF.\n\nTo configure DMF scheduling and verify results:\n\n```sql\n-- Set DMFs to trigger when data changes\nALTER ICEBERG TABLE RAW.VEHICLE_LOCATIONS SET DATA_METRIC_SCHEDULE = 'TRIGGER_ON_CHANGES';\nALTER ICEBERG TABLE RAW.SENSOR_READINGS SET DATA_METRIC_SCHEDULE = 'TRIGGER_ON_CHANGES';\n\n-- Or set a specific schedule (e.g., every 5 minutes)\n-- ALTER ICEBERG TABLE RAW.VEHICLE_LOCATIONS SET DATA_METRIC_SCHEDULE = '5 MINUTE';\n\n-- Check which DMFs are attached to VEHICLE_LOCATIONS\nSELECT * FROM TABLE(INFORMATION_SCHEMA.DATA_METRIC_FUNCTION_REFERENCES(\n    REF_ENTITY_NAME =\u003E 'FLEET_ANALYTICS_DB.RAW.VEHICLE_LOCATIONS',\n    REF_ENTITY_DOMAIN =\u003E 'TABLE'\n));\n\n-- Insert a row to trigger the DMF (if using TRIGGER_ON_CHANGES)\nINSERT INTO RAW.VEHICLE_LOCATIONS (LOCATION_ID, VEHICLE_ID, LOCATION_TIMESTAMP, LATITUDE, LONGITUDE, LOCATION_POINT, SPEED_MPH, HEADING_DEGREES, FLEET_REGION)\nSELECT UUID_STRING(), VEHICLE_ID, CURRENT_TIMESTAMP(), LATITUDE, LONGITUDE, LOCATION_POINT, SPEED_MPH, HEADING_DEGREES, FLEET_REGION\nFROM RAW.VEHICLE_LOCATIONS LIMIT 1;\n\n-- Check DMF results (may take a minute to populate after data insert)\nSELECT \n    TABLE_NAME,\n    METRIC_NAME,\n    VALUE,\n    MEASUREMENT_TIME\nFROM SNOWFLAKE.LOCAL.DATA_QUALITY_MONITORING_RESULTS\nWHERE TABLE_DATABASE = 'FLEET_ANALYTICS_DB'\nORDER BY MEASUREMENT_TIME DESC\nLIMIT 20;\n```\n\n\u003E **Tip**: Insert or modify data in the table to trigger the DMF if using `TRIGGER_ON_CHANGES`. The Data Quality tab will populate after the next scheduled run.\n\nTo view the Data Quality dashboard:\n\n1. Navigate to **Data** → **Databases** → **FLEET_ANALYTICS_DB** → **RAW** → **VEHICLE_LOCATIONS**\n2. Click on the **Data Quality** tab\n3. After DMFs have run, you'll see:\n   - Quality check results over time\n   - Failed record counts  \n   - Data quality trends by dimension (Freshness, Volume, Accuracy, etc.)\n\nFor more details, see [Getting Started with Data Quality in Snowflake](https://www.snowflake.com/en/developers/guides/getting-started-with-data-quality-in-snowflake/#review).\n\n### Data Lineage\n\nSnowflake automatically tracks lineage for all objects, including Iceberg tables and Dynamic Tables.\n\n#### View Lineage Graph\n\n1. Navigate to **Data** → **Databases** → **FLEET_ANALYTICS_DB** → **RAW** → **MAINTENANCE_LOGS**\n2. Click on the **Lineage** tab\n3. Explore the lineage graph showing both upstream and downstream tables, including upstream lineage from an external telemetry messaging service\n\nThe lineage graph is valuable for:\n- **Impact analysis**: Understanding what's affected when source data changes\n- **Data quality investigation**: Tracing issues back to their source\n- **Security auditing**: Understanding data flow for sensitive information\n\n![Data Lineage](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/lineage.png?v=8cbd55b6)\n\n\u003C!-- ------------------------ --\u003E\n## Analytics and AI\n\nThis section demonstrates Snowflake's analytical capabilities on Iceberg V3 tables, including semi-structured data querying, time-series analysis, geospatial functions, and AI agents.\n\n### Semi-Structured Data Analytics\n\nSnowflake efficiently queries VARIANT data in Iceberg tables with automatic pruning and optimization.\n\n#### Query Nested Variant Data\n\n```sql\n-- Extract nested fields from VARIANT with dot notation\nSELECT \n    VEHICLE_ID,\n    TELEMETRY_DATA:speed_mph::FLOAT AS speed,\n    TELEMETRY_DATA:engine:rpm::INT AS engine_rpm,\n    TELEMETRY_DATA:engine:temperature_f::INT AS engine_temp,\n    TELEMETRY_DATA:diagnostics:check_engine::BOOLEAN AS check_engine_light,\n    TELEMETRY_DATA:driver_behavior:hard_brake_count::INT AS hard_brakes\nFROM RAW.VEHICLE_TELEMETRY_STREAM\nWHERE TELEMETRY_DATA:speed_mph::FLOAT \u003E 50\nLIMIT 20;\n\n-- Aggregate on variant fields - find vehicles with check engine warnings\nSELECT \n    TELEMETRY_DATA:diagnostics:check_engine::BOOLEAN AS check_engine,\n    COUNT(*) AS event_count,\n    ROUND(AVG(TELEMETRY_DATA:speed_mph::FLOAT), 1) AS avg_speed,\n    COUNT(DISTINCT VEHICLE_ID) AS vehicle_count\nFROM RAW.VEHICLE_TELEMETRY_STREAM\nGROUP BY 1\nORDER BY event_count DESC;\n```\n\n#### Observe Query Pruning\n\n```sql\n-- Run with profile to see pruning efficiency\nSELECT \n    VEHICLE_ID,\n    EVENT_TIMESTAMP,\n    TELEMETRY_DATA:speed_mph::FLOAT AS speed\nFROM VEHICLE_TELEMETRY_STREAM\nWHERE VEHICLE_ID = 'VH-1234'\n  AND TELEMETRY_DATA:engine:temperature_f::INT \u003E 200;\n\n-- Check query profile in History tab to see partition pruning statistics\n```\n\n### Time-Series Analytics and Forecasting\n\nThe `SENSOR_READINGS` table contains high-precision time-series data for analysis.\n\n#### AS OF Join for Point-in-Time Analysis\n\n```sql\n-- AS OF join: Find closest sensor reading before each maintenance event\nSELECT \n    m.VEHICLE_ID,\n    m.LOG_TIMESTAMP AS maintenance_time,\n    m.LOG_DATA:event_type::STRING AS maintenance_type,\n    s.READING_TIMESTAMP AS closest_reading_time,\n    s.ENGINE_TEMP_F,\n    s.OIL_PRESSURE_PSI\nFROM RAW.MAINTENANCE_LOGS m\nASOF JOIN RAW.SENSOR_READINGS s\n    MATCH_CONDITION (m.LOG_TIMESTAMP \u003E= s.READING_TIMESTAMP)\n    ON m.VEHICLE_ID = s.VEHICLE_ID\nWHERE m.LOG_DATA:severity::STRING IN ('CRITICAL', 'HIGH')\nORDER BY m.LOG_TIMESTAMP DESC\nLIMIT 15;\n```\n\n#### Time-Series Aggregation with \n\nWindow functions enable powerful time-series analysis directly in SQL:\n- **Rolling averages** to smooth out noise\n- **Running totals** for cumulative metrics\n- **Lag/Lead** for period-over-period comparisons\n\n```sql\n-- Calculate rolling averages for engine temperature\nSELECT \n    VEHICLE_ID,\n    READING_TIMESTAMP,\n    ENGINE_TEMP_F,\n    AVG(ENGINE_TEMP_F) OVER (\n        PARTITION BY VEHICLE_ID \n        ORDER BY READING_TIMESTAMP \n        RANGE BETWEEN INTERVAL '1 HOUR' PRECEDING AND CURRENT ROW\n    ) AS rolling_avg_temp,\n    MAX(ENGINE_TEMP_F) OVER (\n        PARTITION BY VEHICLE_ID \n        ORDER BY READING_TIMESTAMP \n        RANGE BETWEEN INTERVAL '1 HOUR' PRECEDING AND CURRENT ROW\n    ) AS rolling_max_temp\nFROM RAW.SENSOR_READINGS\nORDER BY VEHICLE_ID, READING_TIMESTAMP\nLIMIT 50;\n```\n\n#### ML Forecasting for Predictive Maintenance\n\n\u003E ⏱️ **Training Time**: Model training may take **2-5 minutes** depending on data volume and warehouse size. To speed up training:\n\u003E - Use a **larger warehouse** (e.g., MEDIUM or LARGE) - training scales with compute\n\u003E - Reduce the number of time series by filtering to specific vehicles  \n\u003E - Limit historical data range (e.g., 14 days instead of 30)\n\n```sql\n-- Create a forecast model for fuel consumption\n-- For Iceberg tables, we must use SYSTEM$QUERY_REFERENCE instead of TABLE reference\nCREATE OR REPLACE SNOWFLAKE.ML.FORECAST fuel_consumption_forecast(\n    INPUT_DATA =\u003E SYSTEM$QUERY_REFERENCE('\n        SELECT \n            VEHICLE_ID,\n            READING_TIMESTAMP,\n            FUEL_CONSUMPTION_GPH\n        FROM RAW.SENSOR_READINGS\n        WHERE READING_TIMESTAMP \u003E DATEADD(''day'', -30, CURRENT_TIMESTAMP())\n    '),\n    TIMESTAMP_COLNAME =\u003E 'READING_TIMESTAMP',\n    TARGET_COLNAME =\u003E 'FUEL_CONSUMPTION_GPH',\n    SERIES_COLNAME =\u003E 'VEHICLE_ID'\n);\n\n-- Generate 7-day forecast and save results\nCALL fuel_consumption_forecast!FORECAST(\n    FORECASTING_PERIODS =\u003E 168,  -- 7 days * 24 hours\n    CONFIG_OBJECT =\u003E {'prediction_interval': 0.95}\n);\n\n-- FORECAST: Generate a 7-day forecast (168 hours) and save to a table for visualization\nCALL fuel_consumption_forecast!FORECAST(\n    FORECASTING_PERIODS =\u003E 168,\n    CONFIG_OBJECT =\u003E {'prediction_interval': 0.95}\n);\n\n-- Save forecast results to a table for visualization\nCREATE OR REPLACE TEMPORARY TABLE FUEL_FORECAST_RESULTS AS\nSELECT * FROM TABLE(RESULT_SCAN(LAST_QUERY_ID()));\n\n-- Preview forecast results\nSELECT * FROM FUEL_FORECAST_RESULTS ORDER BY SERIES, TS LIMIT 20;\n```\n\n#### Visualize Historical + Forecast Data\n\nUse Streamlit in a Snowflake Notebook to plot historical data alongside the forecast:\n\n```python\n# 📈 Visualize Historical + Forecast Fuel Consumption\nimport streamlit as st\nimport pandas as pd\nfrom snowflake.snowpark.context import get_active_session\n\nsession = get_active_session()\n\n# Get historical data (last 30 days for one vehicle)\nhistorical_df = session.sql(\"\"\"\n    SELECT \n        READING_TIMESTAMP AS ts,\n        FUEL_CONSUMPTION_GPH AS value,\n        'Historical' AS data_type\n    FROM RAW.SENSOR_READINGS\n    WHERE VEHICLE_ID = (SELECT SERIES FROM FUEL_FORECAST_RESULTS LIMIT 1)\n      AND READING_TIMESTAMP \u003E DATEADD('day', -30, CURRENT_TIMESTAMP())\n    ORDER BY READING_TIMESTAMP\n\"\"\").to_pandas()\n\n# Get forecast data (column names vary - check with DESCRIBE first if needed)\nforecast_df = session.sql(\"\"\"\n    SELECT \n        TS AS ts,\n        FORECAST AS value,\n        'Forecast' AS data_type\n    FROM FUEL_FORECAST_RESULTS\n    WHERE SERIES = (SELECT SERIES FROM FUEL_FORECAST_RESULTS LIMIT 1)\n    ORDER BY TS\n\"\"\").to_pandas()\n\n# Get the vehicle ID for the title\nvehicle_id = session.sql(\"SELECT SERIES FROM FUEL_FORECAST_RESULTS LIMIT 1\").collect()[0][0]\n\nst.subheader(f\"📈 Fuel Consumption Forecast: {vehicle_id}\")\nst.caption(\"Historical data (30 days) + 7-day forecast\")\n\n# Normalize column names to lowercase\nhistorical_df.columns = historical_df.columns.str.lower()\nforecast_df.columns = forecast_df.columns.str.lower()\n\n# Combine for plotting\ncombined_df = pd.concat([historical_df, forecast_df], ignore_index=True)\ncombined_df['ts'] = pd.to_datetime(combined_df['ts'])\ncombined_df = combined_df.sort_values('ts')\n\n# Create the chart using Streamlit's native line chart\n# Pivot data for multi-line chart\nchart_data = combined_df.pivot_table(index='ts', columns='data_type', values='value', aggfunc='first')\nst.line_chart(chart_data, use_container_width=True)\n\n# Display metrics\ncol1, col2, col3 = st.columns(3)\ncol1.metric(\"Avg Historical (GPH)\", f\"{historical_df['value'].mean():.2f}\")\ncol2.metric(\"Avg Forecast (GPH)\", f\"{forecast_df['value'].mean():.2f}\")\nchange = ((forecast_df['value'].mean() - historical_df['value'].mean()) / historical_df['value'].mean()) * 100\ncol3.metric(\"Projected Change\", f\"{change:+.1f}%\")\n\nst.caption(\"💡 The forecast helps identify vehicles likely to have higher fuel consumption, enabling proactive maintenance scheduling.\")\n```\n\n### Geospatial Analytics\n\nH3 is Uber's hierarchical geospatial indexing system. Snowflake's H3 functions enable:\n- Aggregating vehicles by geographic cell\n- Efficient spatial joins and clustering\n- Multi-resolution analysis (cells at different zoom levels)\n\nThe `VEHICLE_LOCATIONS` table contains GEOGRAPHY data for spatial analysis.\n\n#### Basic Geospatial Queries\n\n```sql\n-- Calculate distance between consecutive positions\nSELECT \n    VEHICLE_ID,\n    LOCATION_TIMESTAMP,\n    LAG(LOCATION_POINT) OVER (\n        PARTITION BY VEHICLE_ID ORDER BY LOCATION_TIMESTAMP\n    ) AS prev_location,\n    LOCATION_POINT AS current_location,\n    ST_DISTANCE(\n        LOCATION_POINT,\n        LAG(LOCATION_POINT) OVER (PARTITION BY VEHICLE_ID ORDER BY LOCATION_TIMESTAMP)\n    ) / 1609.34 AS distance_miles  -- Convert meters to miles\nFROM VEHICLE_LOCATIONS\nORDER BY VEHICLE_ID, LOCATION_TIMESTAMP\nLIMIT 50;\n```\n\n#### Geofencing Analysis\n\n```sql\n-- Define a geofence (San Francisco downtown)\nSET sf_downtown = ST_MAKEPOLYGON(TO_GEOGRAPHY(\n    'LINESTRING(-122.42 37.78, -122.42 37.79, -122.40 37.79, -122.40 37.78, -122.42 37.78)'\n));\n\n-- Find vehicles inside the geofence\nSELECT \n    VEHICLE_ID,\n    LOCATION_TIMESTAMP,\n    ST_X(LOCATION_POINT) AS longitude,\n    ST_Y(LOCATION_POINT) AS latitude\nFROM VEHICLE_LOCATIONS\nWHERE ST_WITHIN(LOCATION_POINT, $sf_downtown)\nORDER BY LOCATION_TIMESTAMP DESC\nLIMIT 20;\n\n-- Geospatial: Aggregate vehicles by H3 cell (resolution 6)\nSELECT \n    H3_POINT_TO_CELL_STRING(LOCATION_POINT, 6) AS h3_cell,\n    FLEET_REGION,\n    COUNT(DISTINCT VEHICLE_ID) AS vehicle_count,\n    ROUND(AVG(SPEED_MPH), 1) AS avg_speed\nFROM RAW.VEHICLE_LOCATIONS\nWHERE LOCATION_TIMESTAMP \u003E DATEADD('hour', -24, CURRENT_TIMESTAMP())\nGROUP BY 1, 2\nORDER BY vehicle_count DESC\nLIMIT 20;\n```\n\n#### Interactive Map Visualization with Streamlit\n\nIn the Snowflake Notebook, you can visualize the H3 geospatial data on an interactive map using Streamlit (built into Snowflake Notebooks):\n\n```python\n# Visualize fleet locations on an interactive map using Streamlit\nimport streamlit as st\nfrom snowflake.snowpark.context import get_active_session\n\nsession = get_active_session()\n\n# Query location data with H3 cell centers (use ST_X/ST_Y for GEOGRAPHY type)\ndf = session.sql(\"\"\"\n    SELECT \n        H3_POINT_TO_CELL_STRING(LOCATION_POINT, 6) AS h3_cell,\n        ST_X(H3_CELL_TO_POINT(H3_POINT_TO_CELL_STRING(LOCATION_POINT, 6))) AS longitude,\n        ST_Y(H3_CELL_TO_POINT(H3_POINT_TO_CELL_STRING(LOCATION_POINT, 6))) AS latitude,\n        FLEET_REGION,\n        COUNT(DISTINCT VEHICLE_ID) AS vehicle_count,\n        ROUND(AVG(SPEED_MPH), 1) AS avg_speed\n    FROM RAW.VEHICLE_LOCATIONS\n    WHERE LOCATION_TIMESTAMP \u003E DATEADD('hour', -24, CURRENT_TIMESTAMP())\n    GROUP BY 1, 2, 3, 4\n    ORDER BY vehicle_count DESC\n    LIMIT 100\n\"\"\").to_pandas()\n\nst.subheader(\"🗺️ Fleet Vehicle Distribution\")\nst.caption(\"Each point represents an H3 cell with vehicle activity in the last 24 hours\")\n\n# Display metrics\ncol1, col2, col3 = st.columns(3)\ncol1.metric(\"Total H3 Cells\", len(df))\ncol2.metric(\"Total Vehicles\", int(df['VEHICLE_COUNT'].sum()))\ncol3.metric(\"Avg Speed\", f\"{df['AVG_SPEED'].mean():.1f} mph\")\n\n# Interactive map visualization - point size scales with vehicle count\nst.map(df, latitude='LATITUDE', longitude='LONGITUDE', size='VEHICLE_COUNT')\n\n# Show data table\nst.dataframe(df[['FLEET_REGION', 'VEHICLE_COUNT', 'AVG_SPEED']].head(10))\n```\n\nThis produces an interactive map showing vehicle distribution across the US, with:\n- Points sized by vehicle count per H3 cell\n- Summary metrics for cells, vehicles, and average speed\n- Data table with regional breakdown\n\n### AI Agents with Snowflake CoWork\n\nThe setup script creates a Cortex Agent (`FLEET_ANALYTICS_AGENT`) that enables natural language querying of your fleet data.\n\n\u003E **Note**: Cortex Agents require Enterprise Edition or higher.\n\n#### Region Availability and Cross-Region Inference\n\nCortex Agents and Cortex Analyst rely on LLMs that may not be available in all Snowflake regions. If you see an error like:\n\n```\nNone of the preferred models are authorized or available in your region...\n```\n\nYou have two options:\n\n1. **Enable Cross-Region Inference** (recommended): This allows Snowflake to route AI requests to regions where models are available, while keeping your data secure.\n\n```sql\n-- Enable cross-region inference for your account\nUSE ROLE ACCOUNTADMIN;\nALTER ACCOUNT SET CORTEX_ENABLED_CROSS_REGION = 'ANY_REGION';\n```\n\n2. **Use a supported region**: Deploy your Snowflake account in a region with native LLM support.\n\nFor more details, see:\n- [Cortex Analyst Region Availability](https://docs.snowflake.com/en/user-guide/snowflake-cortex/cortex-analyst#region-availability)\n- [Cross-Region Inference](https://docs.snowflake.com/en/user-guide/snowflake-cortex/cross-region-inference)\n\n\u003E **Privacy Note**: With cross-region inference, only the AI inference is routed cross-region. Your underlying data remains in your account's region and is protected by Snowflake's governance controls.\n\n#### Agent Configuration\n\nThe setup script creates the agent with a complete YAML specification including:\n- **Sample questions** to help users get started\n- **Orchestration instructions** explaining the data schema\n- **Cortex Analyst tool** linked to a semantic model describing all tables\n\nThe semantic model (`fleet_semantic_model.yaml`) is uploaded to the stage and defines:\n- Table structures for SENSOR_READINGS, VEHICLE_TELEMETRY_STREAM, VEHICLE_LOCATIONS, etc.\n- VARIANT column extraction patterns\n- Dimension and measure definitions\n\n\u003E **Note**: If the agent creation fails due to syntax issues, you can configure it manually through **Cortex AI** → **Agents** → **FLEET_ANALYTICS_AGENT**.\n\n#### Using the Fleet Analytics Agent\n\n1. Navigate to **Cortex AI** → **Agents** in the left sidebar\n2. Select **FLEET_ANALYTICS_AGENT**\n3. Start asking questions in natural language:\n\n**Example queries:**\n\n- \"Which vehicles had the highest fuel consumption last week?\"\n- \"Show me all critical maintenance events\"\n- \"What's the average speed by fleet region?\"\n- \"Find vehicles with check engine warnings\"\n- \"Which drivers have the most hard braking events?\"\n- \"Show vehicle health scores below 60\"\n- \"How many vehicles are in each H3 cell in California?\"\n\nThe agent understands your Iceberg table schema including:\n- **VARIANT columns**: Extracts nested JSON fields using colon notation\n- **GEOGRAPHY columns**: Uses H3 and ST_* functions for geospatial analysis\n- **Time-series data**: Performs ASOF joins and window functions\n\n#### Agent Configuration\n\nThe agent was created with access to these tables:\n\n| Table | Description |\n|-------|-------------|\n| `RAW.VEHICLE_TELEMETRY_STREAM` | Real-time streaming telemetry (VARIANT) |\n| `RAW.VEHICLE_LOCATIONS` | Geospatial positions (GEOGRAPHY) |\n| `RAW.SENSOR_READINGS` | High-precision time-series sensor data |\n| `RAW.MAINTENANCE_LOGS` | Maintenance events (VARIANT) |\n| `RAW.VEHICLE_REGISTRY` | Vehicle and driver master data |\n| `ANALYTICS.DAILY_FLEET_SUMMARY` | Daily aggregated metrics |\n| `ANALYTICS.VEHICLE_HEALTH_SCORE` | Calculated health scores |\n\nTo view or modify the agent configuration:\n\n```sql\n-- View agent details\nSHOW AGENTS IN SCHEMA FLEET_ANALYTICS_DB.RAW;\n\n-- Describe the agent\nDESCRIBE AGENT FLEET_ANALYTICS_DB.RAW.FLEET_ANALYTICS_AGENT;\n```\n\nFor more on building agents, see [Snowflake CoWork documentation](https://docs.snowflake.com/en/user-guide/snowflake-cortex/snowflake-intelligence).\n\n\u003C!-- ------------------------ --\u003E\n## Business Continuity and Disaster Recovery\n\nThis section highlights Snowflake's enterprise-grade, out-of-the-box business continuity and disaster recovery capabilities that extend to Iceberg V3 tables.\n\n\u003E **Note**: Replication features require Business Critical Edition or higher.\n\n### Iceberg Table Replication Overview\n\nSnowflake supports replicating Iceberg tables across regions and clouds, ensuring your data lakehouse is protected against regional outages. See [Iceberg Table Replication documentation](https://docs.snowflake.com/en/user-guide/tables-iceberg-replication) for details.\n\n### Setting Up Replication via UI\n\nFollow these steps to set up cross-region replication for your Iceberg tables:\n\n#### Step 1: Create a Replication Group\n\n1. Navigate to **Admin** → **Accounts**\n2. Click on the **Replication** tab\n3. Click **+ Group** (or **+ Failover Group** for automatic failover)\n\n#### Step 2: Select Target Account\n\n1. Choose the target Snowflake account in a different cloud or region\n2. If no secondary accounts exist, you'll need to create one first\n\n#### Step 3: Configure Objects\n\n1. Select all objects to replicate:\n   - Databases (includes all Iceberg tables)\n   - Warehouses (optional)\n   - Roles and privileges (recommended for consistent access)\n\n\u003E With **Snowflake-managed** Iceberg storage (`SNOWFLAKE_MANAGED`, the lab default), you do not add customer external volumes for table files, and failover/replication groups can use `OBJECT_TYPES = DATABASES` without listing external volumes. See [Replication](https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage#replication) under *Snowflake storage for Apache Iceberg tables*.\n\n#### Step 4: Enable and Monitor\n\n1. Click **Create** to enable replication\n2. Monitor replication status in the Replication tab\n3. View replication lag and sync history\n\n### Verify Replication\n\nIn the secondary account:\n\n```sql\n-- Check that Iceberg tables exist\nUSE DATABASE FLEET_ANALYTICS_DB;\nSHOW ICEBERG TABLES;\n\n-- Query replicated data\nSELECT COUNT(*) FROM VEHICLE_TELEMETRY_STREAM;\nSELECT COUNT(*) FROM MAINTENANCE_LOGS;\n```\n\n### Failover Testing\n\nFor Failover Groups (automatic failover):\n\n1. In the Replication tab, select your failover group\n2. Click **Failover** to initiate failover to secondary\n3. Verify applications can connect to secondary account\n4. Use **Failback** when primary is restored\n\nFor detailed steps, see [Creating Replication/Failover Groups via Snowsight](https://docs.snowflake.com/en/user-guide/account-replication-config#create-a-replication-or-failover-group-using-snowsight).\n\n\u003C!-- ------------------------ --\u003E\n## Interoperability\n\nThis section demonstrates that external engines like Apache Spark can access Iceberg V3 tables managed by Snowflake. Horizon provides temporary, scoped storage credentials and enforces centralized row/column-level access controls for any engine.\n\n### Prerequisites for Spark\n\nEnsure you have:\n- Conda installed\n- The repository cloned (`sfguide-iceberg-v3-comprehensive-guide`)\n\n\u003E External engines still read Iceberg tables that use [Snowflake-managed storage](https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage) through Horizon Catalog. The Spark notebook includes a **Cloud Storage Bundles** section—use the bundle that matches your account’s cloud if you adjust storage or see file I/O errors.\n\n### Start the Spark Environment\n\nThe setup script created a Conda environment with Spark 4.0+ and all necessary dependencies:\n\n```bash\ncd sfquickstarts/site/sfguides/src/iceberg-v3-comprehensive-guide/assets\n\n# Activate the Spark environment\nconda activate fleet-spark\n\n# Start Jupyter notebook\njupyter notebook spark_iceberg_interop.ipynb\n```\n\n### Spark Notebook Walkthrough\n\nThe pre-configured Jupyter notebook contains all the code needed. Here's what you'll do:\n\n#### Cell 1: Setup and Imports\n\n```python\nfrom pyspark.sql import SparkSession\nimport os\n\n# Load configuration (from the same config.env used during setup)\nfrom dotenv import load_dotenv\nload_dotenv('../config.env')\n\nSNOWFLAKE_ACCOUNT = os.getenv('SNOWFLAKE_ACCOUNT')\nSNOWFLAKE_USER = os.getenv('SNOWFLAKE_USER')\n```\n\n#### Cell 2: Create Spark Session with Horizon Catalog\n\n```python\nfrom pyspark.sql import SparkSession\n\n# Configuration\nSNOWFLAKE_PASSWORD = os.getenv('SNOWFLAKE_PASSWORD')\nSNOWFLAKE_ROLE = 'ACCOUNTADMIN'\nSNOWFLAKE_SCHEMA = 'RAW'\nSNOWFLAKE_WAREHOUSE = os.getenv('SNOWFLAKE_WAREHOUSE', 'FLEET_ANALYTICS_WH')\nSF_URL = f\"{SNOWFLAKE_ACCOUNT_URL}.snowflakecomputing.com\"\n\n# Versions - Note: Spark 3.5 required for Snowflake Connector masking support\nSNOWFLAKE_JDBC_VERSION = \"3.24.0\"\nSNOWFLAKE_SPARK_CONNECTOR_VERSION = \"3.1.6\"\n\n# Create Spark session with Iceberg and Snowflake catalog configuration\n# Note: \n# - driver.host and bindAddress ensure Spark uses localhost (avoids VPN issues)\n# - Using Spark 4.0 + Iceberg 1.10.1 for native VARIANT support\nspark = SparkSession.builder \\\n    .appName(\"Fleet Analytics - Iceberg V3 Interop\") \\\n    .master(\"local[*]\") \\\n    .config(\"spark.driver.host\", \"127.0.0.1\") \\\n    .config(\"spark.driver.bindAddress\", \"127.0.0.1\") \\\n    .config(\"spark.jars.packages\", \n            f\"org.apache.iceberg:iceberg-spark-runtime-4.0_{SCALA_VERSION}:{ICEBERG_VERSION},\"\n            f\"org.apache.iceberg:iceberg-aws-bundle:{ICEBERG_VERSION},\"\n            f\"net.snowflake:snowflake-jdbc:{SNOWFLAKE_JDBC_VERSION},\"\n            f\"net.snowflake:spark-snowflake_{SCALA_VERSION}:{SNOWFLAKE_SPARK_CONNECTOR_VERSION}\") \\\n    .config(\"spark.sql.extensions\", \"org.apache.iceberg.spark.extensions.IcebergSparkSessionExtensions\") \\\n    .config(\"spark.sql.catalog.horizon\", \"org.apache.iceberg.spark.SparkCatalog\") \\\n    .config(\"spark.sql.catalog.horizon.type\", \"rest\") \\\n    .config(\"spark.sql.catalog.horizon.uri\", f\"https://{SNOWFLAKE_ACCOUNT_URL}.snowflakecomputing.com/polaris/api/catalog\") \\\n    .config(\"spark.sql.catalog.horizon.credential\", SNOWFLAKE_ACCOUNTADMIN_TOKEN) \\\n    .config(\"spark.sql.catalog.horizon.warehouse\", SNOWFLAKE_DATABASE) \\\n    .config(\"spark.sql.catalog.horizon.scope\", f\"session:role:{SNOWFLAKE_ROLE}\") \\\n    .config(\"spark.sql.catalog.horizon.header.X-Iceberg-Access-Delegation\",\"vended-credentials\") \\\n    .config(\"spark.snowflake.sfURL\", SF_URL) \\\n    .config(\"spark.snowflake.sfUser\", os.getenv('SNOWFLAKE_USER')) \\\n    .config(\"spark.snowflake.sfPassword\", SNOWFLAKE_FLEET_ANALYST_TOKEN) \\\n    .config(\"spark.snowflake.sfDatabase\", SNOWFLAKE_DATABASE) \\\n    .config(\"spark.snowflake.sfSchema\", SNOWFLAKE_SCHEMA) \\\n    .config(\"spark.snowflake.sfRole\", SNOWFLAKE_ROLE) \\\n    .config(\"spark.snowflake.sfWarehouse\", SNOWFLAKE_WAREHOUSE) \\\n    .config(\"spark.sql.iceberg.vectorization.enabled\", \"false\") \\\n    .getOrCreate()\n\nprint(\"Spark session created successfully!\")\nprint(f\"Spark version: {spark.version}\")\n```\n\n#### Cell 3: List Available Tables\n\n```python\n# Show all tables visible to Spark\nspark.sql(\"SHOW TABLES IN horizon.RAW\").show(truncate=False)\nspark.sql(\"SHOW TABLES IN horizon.CURATED\").show(truncate=False)\nspark.sql(\"SHOW TABLES IN horizon.ANALYTICS\").show(truncate=False)\n```\n\nOutput:\n```\n+---------+------------------------+-----------+\n|namespace|tableName               |isTemporary|\n+---------+------------------------+-----------+\n|RAW      |API_WEATHER_DATA        |false      |\n|RAW      |MAINTENANCE_LOGS        |false      |\n|RAW      |SENSOR_READINGS         |false      |\n|RAW      |VEHICLE_LOCATIONS       |false      |\n|RAW      |VEHICLE_REGISTRY        |false      |\n|RAW      |VEHICLE_TELEMETRY_STREAM|false      |\n+---------+------------------------+-----------+\n\n+---------+--------------------+-----------+\n|namespace|tableName           |isTemporary|\n+---------+--------------------+-----------+\n|CURATED  |MAINTENANCE_ANALYSIS|false      |\n|CURATED  |TELEMETRY_ENRICHED  |false      |\n+---------+--------------------+-----------+\n\n+---------+--------------------+-----------+\n|namespace|tableName           |isTemporary|\n+---------+--------------------+-----------+\n|ANALYTICS|DAILY_FLEET_SUMMARY |false      |\n|ANALYTICS|VEHICLE_HEALTH_SCORE|false      |\n+---------+--------------------+-----------+\n```\n\nNote that Dynamic Iceberg Tables are also visible!\n\n#### Cell 4: Describe Table with Variant Column\n\n```python\n# See variant column in Iceberg table\nspark.sql(\"DESCRIBE TABLE snowflake.RAW.VEHICLE_TELEMETRY_STREAM\").show(truncate=False)\n```\n\nOutput:\n```\n+-------------------+---------------+-------+\n|col_name           |data_type      |comment|\n+-------------------+---------------+-------+\n|VEHICLE_ID         |string         |null   |\n|EVENT_TIMESTAMP    |timestamp      |null   |\n|TELEMETRY_DATA     |variant        |null   |\n+-------------------+---------------+-------+\n```\n\n#### Cell 5: Query Data with Variant\n\n```python\n# Use Spark's variant_get() function to extract nested fields from VARIANT\n# This query succeeds, and no Snowflake compute is used, since there's no masking policy on the Iceberg table.\ndf = spark.sql(f\"\"\"\n    SELECT \n        VEHICLE_ID,\n        EVENT_TIMESTAMP,\n        variant_get(TELEMETRY_DATA, '$.speed_mph', 'float') AS speed_mph,\n        variant_get(TELEMETRY_DATA, '$.engine.temperature_f', 'int') AS engine_temp,\n        variant_get(TELEMETRY_DATA, '$.location.lat', 'float') AS latitude,\n        variant_get(TELEMETRY_DATA, '$.location.lon', 'float') AS longitude\n    FROM snowflake.RAW.VEHICLE_TELEMETRY_STREAM\n    WHERE variant_get(TELEMETRY_DATA, '$.speed_mph', 'float') \u003E 60\n    LIMIT 10\n\"\"\")\ndf.show()\n```\n\n#### Cell 6: Demonstrate Access Control (Masking Enforcement)\n\n```python\n# To enforce masking policies from Spark, we need the Snowflake Connector for Spark\n# which routes queries through Snowflake for policy evaluation\n# See: https://docs.snowflake.com/en/user-guide/tables-iceberg-query-using-external-query-engine-snowflake-horizon-enforce-access-policies\n\n# Stop the previous Spark session first\nspark.stop()\nfrom pyspark.sql import SparkSession\n\n# Configuration\nSNOWFLAKE_PASSWORD = os.getenv('SNOWFLAKE_PASSWORD')\nSNOWFLAKE_ROLE = 'FLEET_ANALYST'\nSNOWFLAKE_SCHEMA = 'RAW'\nSNOWFLAKE_WAREHOUSE = os.getenv('SNOWFLAKE_WAREHOUSE', 'FLEET_ANALYTICS_WH')\nSF_URL = f\"{SNOWFLAKE_ACCOUNT_URL}.snowflakecomputing.com\"\n\n# Versions - Note: Spark 3.5 required for Snowflake Connector masking support\nSNOWFLAKE_JDBC_VERSION = \"3.24.0\"\nSNOWFLAKE_SPARK_CONNECTOR_VERSION = \"3.1.6\"\n\nspark_analyst = SparkSession.builder \\\n    .appName(\"Fleet Analytics - Analyst View\") \\\n    .master(\"local[*]\") \\\n    .config(\"spark.driver.host\", \"127.0.0.1\") \\\n    .config(\"spark.driver.bindAddress\", \"127.0.0.1\") \\\n    .config(\"spark.jars.packages\", \n            f\"org.apache.iceberg:iceberg-spark-runtime-4.0_{SCALA_VERSION}:{ICEBERG_VERSION},\"\n            f\"org.apache.iceberg:iceberg-aws-bundle:{ICEBERG_VERSION},\"\n            f\"net.snowflake:snowflake-jdbc:{SNOWFLAKE_JDBC_VERSION},\"\n            f\"net.snowflake:spark-snowflake_{SCALA_VERSION}:{SNOWFLAKE_SPARK_CONNECTOR_VERSION}\") \\\n    .config(\"spark.sql.extensions\", \"org.apache.iceberg.spark.extensions.IcebergSparkSessionExtensions\") \\\n    .config(\"spark.sql.defaultCatalog\", \"horizon\") \\\n    .config(\"spark.sql.catalog.horizon\", \"org.apache.spark.sql.snowflake.catalog.SnowflakeFallbackCatalog\") \\\n    .config(\"spark.sql.catalog.horizon.catalog-impl\", \"org.apache.iceberg.spark.SparkCatalog\") \\\n    .config(\"spark.sql.catalog.horizon.type\", \"rest\") \\\n    .config(\"spark.sql.catalog.horizon.uri\", f\"https://{SNOWFLAKE_ACCOUNT_URL}.snowflakecomputing.com/polaris/api/catalog\") \\\n    .config(\"spark.sql.catalog.horizon.warehouse\", SNOWFLAKE_DATABASE) \\\n    .config(\"spark.sql.catalog.horizon.scope\", f\"session:role:{SNOWFLAKE_ROLE}\") \\\n    .config(\"spark.sql.catalog.horizon.credential\", SNOWFLAKE_FLEET_ANALYST_TOKEN) \\\n    .config(\"spark.sql.catalog.horizon.io-impl\", \"org.apache.iceberg.aws.s3.S3FileIO\") \\\n    .config(\"spark.sql.catalog.horizon.header.X-Iceberg-Access-Delegation\", \"vended-credentials\") \\\n    .config(\"spark.snowflake.sfURL\", SF_URL) \\\n    .config(\"spark.snowflake.sfUser\", os.getenv('SNOWFLAKE_USER')) \\\n    .config(\"spark.snowflake.sfPassword\", SNOWFLAKE_FLEET_ANALYST_TOKEN) \\\n    .config(\"spark.snowflake.sfDatabase\", SNOWFLAKE_DATABASE) \\\n    .config(\"spark.snowflake.sfSchema\", SNOWFLAKE_SCHEMA) \\\n    .config(\"spark.snowflake.sfRole\", SNOWFLAKE_ROLE) \\\n    .config(\"spark.snowflake.sfWarehouse\", SNOWFLAKE_WAREHOUSE) \\\n    .config(\"spark.sql.iceberg.vectorization.enabled\", \"false\") \\\n    .getOrCreate()\n\nspark_analyst.sparkContext.setLogLevel(\"ERROR\")\n```\n\nIceberg tables are still accessible via Iceberg REST API\n```python\nspark_analyst.sql(\"SHOW TABLES in horizon.RAW\").show(truncate=False)\n```\n\nWhen reading an Iceberg table with a maskign policy, Snowflake returns masked results\n```python\nspark_analyst.sql(\"\"\"\n    SELECT\n        VEHICLE_ID,\n        MAKE,\n        MODEL,\n        YEAR,\n        LICENSE_PLATE,\n        DRIVER_NAME,\n        DRIVER_EMAIL,\n        DRIVER_PHONE,\n        FLEET_REGION\n    FROM horizon.RAW.VEHICLE_REGISTRY\n\"\"\").show(truncate=True)\n```\n\n![Interoperable Masking](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/iceberg-v3-tables-comprehensive-guide/spark_masked.png?v=8cbd55b6)\n\n\nThe masking policies defined in Snowflake are enforced even when accessing data through Spark!\n\nFor more details on Spark integration, see:\n- [Query Iceberg Tables Using External Engines](https://docs.snowflake.com/en/user-guide/tables-iceberg-query-using-external-query-engine-snowflake-horizon)\n- [Enforce Access Policies for External Engines](https://docs.snowflake.com/en/user-guide/tables-iceberg-query-using-external-query-engine-snowflake-horizon-enforce-access-policies)\n\n\u003C!-- ------------------------ --\u003E\n## Cleanup\n\nTo remove all objects created by this guide:\n\n```sql\nUSE ROLE ACCOUNTADMIN;\n\n-- Drop the database (this removes all tables, schemas, and objects)\nDROP DATABASE IF EXISTS FLEET_ANALYTICS_DB;\n\n-- Drop the external volume only if you used customer-managed storage (USE_SNOWFLAKE_STORAGE=false)\nDROP EXTERNAL VOLUME IF EXISTS FLEET_ICEBERG_VOL;\n\n-- Drop the warehouse\nDROP WAREHOUSE IF EXISTS FLEET_ANALYTICS_WH;\n\n-- Drop roles\nDROP ROLE IF EXISTS FLEET_ANALYST;\nDROP ROLE IF EXISTS FLEET_ENGINEER;\nDROP ROLE IF EXISTS FLEET_ADMIN;\n\n-- If you created replication groups, remove them\nDROP REPLICATION GROUP IF EXISTS FLEET_ANALYTICS_REPLICATION;\n\n-- Remove network policy from user (if applied)\nALTER USER \u003Cyour_username\u003E UNSET NETWORK_POLICY;\nDROP NETWORK POLICY IF EXISTS FLEET_STREAMING_POLICY;\n\n-- External access integration\nDROP INTEGRATION IF EXISTS OPEN_METEO_ACCESS;\n\nSELECT 'Uncomment the commands above to cleanup' AS NOTE;\n```\n\nIf you used customer-managed cloud storage, you may also want to clean up the Iceberg data files in your bucket or container.\n\n\u003C!-- ------------------------ --\u003E\n## Conclusion and Resources\n\nCongratulations! You've built a comprehensive analytics platform using Snowflake Iceberg V3 tables, demonstrating the full power of Snowflake's modern lakehouse architecture.\n\n### What You Learned\n\n- **Iceberg V3 Tables**: Created tables with VARIANT columns for semi-structured data, supporting flexible schemas\n- **Streaming Ingestion**: Used Snowpipe Streaming to ingest real-time vehicle telemetry with sub-second latency\n- **Multi-Source Ingestion**: Loaded data from web APIs and batch JSON files into Iceberg tables\n- **Declarative Pipelines**: Built incremental transformation pipelines with Dynamic Iceberg Tables\n- **Enterprise Governance**: Applied PII detection, masking policies, and data quality monitoring\n- **Advanced Analytics**: Performed time-series analysis, forecasting, and geospatial queries\n- **AI Integration**: Connected Iceberg data to Snowflake CoWork for natural language analytics\n- **Business Continuity**: Configured cross-region replication for disaster recovery\n- **Interoperability**: Queried Iceberg tables from Spark with enforced access controls\n\n### Key Benefits of Iceberg V3 Tables in Snowflake\n\n1. **Open Format**: Data stored in open Apache Iceberg format, accessible by any compatible engine\n2. **VARIANT Support**: Full semi-structured data capabilities with V3 table format\n3. **Unified Governance**: Single place to manage security, quality, and lineage across all engines\n4. **Incremental Processing**: Dynamic Tables automatically handle incremental transformations\n5. **Enterprise Features**: Time travel, cloning, replication all work with Iceberg tables\n6. **Performance**: Snowflake's query optimization applies to Iceberg tables\n\n### Related Resources\n\n**Documentation:**\n- [Snowflake storage for Apache Iceberg tables](https://docs.snowflake.com/en/user-guide/tables-iceberg-internal-storage)\n- [Iceberg V3 Support in Snowflake](https://docs.snowflake.com/en/LIMITEDACCESS/iceberg/tables-iceberg-v3-specification-support)\n- [Snowpipe Streaming](https://docs.snowflake.com/en/user-guide/snowpipe-streaming/snowpipe-streaming-high-performance-overview)\n- [Dynamic Iceberg Tables](https://docs.snowflake.com/en/user-guide/dynamic-tables-create-iceberg)\n- [Snowflake CoWork](https://docs.snowflake.com/en/user-guide/snowflake-cortex/snowflake-intelligence)\n- [Iceberg Table Replication](https://docs.snowflake.com/en/user-guide/tables-iceberg-replication)\n\n**Guides:**\n- [Build Declarative Pipelines with Dynamic Iceberg Tables](/en/developers/guides/declarative-pipelines-using-dynamic-iceberg-tables/)\n- [Getting Started with Data Quality in Snowflake](/en/developers/guides/getting-started-with-data-quality-in-snowflake/)\n\n**Assets:**\n- [Guide Assets Folder](https://github.com/Snowflake-Labs/sfquickstarts/tree/master/site/sfguides/src/iceberg-v3-tables-comprehensive-guide/assets)\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-b310b4e00a","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-f3f3df898c",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"quickstart_last_modi":{"id":"quickstart-last-modified-2b067271eb","icon":{"id":"icon","icon":"calendar",":type":"snowflake-site/components/icon","appliedCssClassNames":"snowflake-icon-blue"},"lastModifiedDatePrefix":"Updated","lastModifiedDate":"2026-04-22",":type":"snowflake-site/components/quickstart/quickstart-last-modified","appliedCssClassNames":"snowflake-responsive-component-top-padding-small"},"text":{"id":"text-eec628f1a8","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-d0d134ee44",":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-137e5a3c3b",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"quickstart_table_of_":{"layout":"SIMPLE","id":"container-960de50253","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-7e1fd73968","fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/iceberg-v3-tables-comprehensive-guide",":type":"snowflake-site/components/quickstart/quickstart-table-of-content","headings":["\u003Ch2\u003EOverview\u003C/h2\u003E","\u003Ch2\u003EEnvironment Setup\u003C/h2\u003E","\u003Ch2\u003EStreaming and Ingest\u003C/h2\u003E","\u003Ch2\u003ETransformation\u003C/h2\u003E","\u003Ch2\u003ESecurity and Governance\u003C/h2\u003E","\u003Ch2\u003EAnalytics and AI\u003C/h2\u003E","\u003Ch2\u003EBusiness Continuity and Disaster Recovery\u003C/h2\u003E","\u003Ch2\u003EInteroperability\u003C/h2\u003E","\u003Ch2\u003ECleanup\u003C/h2\u003E","\u003Ch2\u003EConclusion and Resources\u003C/h2\u003E"]},"quickstart_button":{"id":"quickstart-button-e415f4fa31","fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/iceberg-v3-tables-comprehensive-guide",":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-af846a3962","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}}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false}},":itemsOrder":["quickstart_hero","flexible_column_cont","markup_editor"],":type":"wcm/foundation/components/responsivegrid"},"modal_container":{"layout":"SIMPLE","id":"container-8975c1a917",":type":"snowflake-site/components/modal/modal-container",":items":{},":itemsOrder":[]},"experiencefragment-footer":{"id":"experiencefragment-f2ff3fec33","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-db22f95c75",":type":"snowflake-site/components/container",":items":{"container_copy":{"additionalClasses":"sf-footer__inner","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"flexible_column_cont":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-95dbb8d91f",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-container snowflake-responsive-container-inner-padding-small",":items":{"flexible_column_cont":{"id":"flexible-column-container-aa997aea9a","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-6c16882248",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"container":{"additionalClasses":"sf-footer-grid__inner","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-dc7568aed8",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-small",":items":{"container_1622723482":{"additionalClasses":"sf-footer__column","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"container":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-af3a3da579",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-small",":items":{"container":{"additionalClasses":"sf-footer__newsletter-group","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12","marketo_v2":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-7ada876d81",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-small",":items":{"text":{"id":"text-ea2fb9c4a0","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-c315af6c5f","marketoForm":{"successUrl":null,"formId":"45871","edit":false,"script":null,"hidden":null,"values":null},"marketoConfigured":true,"formConfigured":true,"munchkinId":"252-RFO-227","serverInstance":"252-RFO-227.mktoweb.com",":type":"snowflake-site/components/form/marketo-v2"}},":itemsOrder":["text","marketo_v2"]}},":itemsOrder":["container"]},"container":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text_copy":"aem-GridColumn aem-GridColumn--default--12","text":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-b1b914571d",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-medium",":items":{"text":{"id":"text-24b7539c34","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-e09da57113","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"]},"container_copy_copy":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-e9df4bd200",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-small",":items":{"text":{"id":"text-967880b5d4","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"]},"container_copy":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-d9162a9775",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-small",":items":{"text":{"id":"text-c0ba672e21","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"]},"container_copy_copy_":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-89c973b6bd",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-small",":items":{"text":{"id":"text-acf6044cf6","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"]}},":itemsOrder":["container_1622723482","container","container_copy_copy","container_copy","container_copy_copy_"]}},":itemsOrder":["container"]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"}},":itemsOrder":["flexible_column_cont"]},"container_573483281_":{"additionalClasses":"sf-footer__bottom","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"container_112062425":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-df6424828b",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-none",":items":{"container_112062425":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"flexible_column_cont":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-136e8d77c8",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-container snowflake-responsive-container-inner-padding-small",":items":{"flexible_column_cont":{"id":"flexible-column-container-4c5cf24c01","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-44ccf0fd22",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"container":{"additionalClasses":"sf-footer__legal-container","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-2a21fcf684",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-none",":items":{"container":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"image":"aem-GridColumn aem-GridColumn--default--12"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-62e7859e8b",":type":"snowflake-site/components/container","appliedCssClassNames":"snowflake-responsive-container-inner-padding-extra-small",":items":{"image":{"id":"image-b384103f27","additionalClasses":"sf-footer__logo","lazyEnabled":true,"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/"},":type":"snowflake-site/components/image"}},":itemsOrder":["image"]},"text_copy_copy_16360":{"id":"text-09aa4e2029","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-51fd4641f4","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",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false}},":itemsOrder":["container","text_copy_copy_16360","markup_editor"]}},":itemsOrder":["container"]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"}},":itemsOrder":["flexible_column_cont"]}},":itemsOrder":["container_112062425"]},"markup_editor_copy":{"id":"markup-editor-6b523f6245","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}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false}},":itemsOrder":["container_copy","container_573483281_","markup_editor_copy"]}},":itemsOrder":["root"],"classNames":"aem-xf"},"markup_editor":{"id":"markup-editor-14351f5b7a","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}}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false}},":itemsOrder":["experiencefragment-banner","experiencefragment-header","markup_editor_1950346551","responsivegrid","modal_container","experiencefragment-footer","markup_editor"],":type":"wcm/foundation/components/responsivegrid"}},":itemsOrder":["root"],":mappedPath":"/en/developers/guides/iceberg-v3-tables-comprehensive-guide/","locale":"en"}
  