/* ----------------------------------
        SHOWCASE STYLES
---------------------------------- */

:root {
    --default-width: calc(100% - 10vw);
    --blue: #007eff;
    --navy: #0b3256;
    --dk-navy: #072744;
    --ultramarine: #4060fd;
    --gray-3: #E2E2EA;
    --purple-lt: #C7C7E8;
    --purple-med: #6A6A9F;
    --purple-dk: #383874;
    --bs: 6px 8px 20px 0px rgba(0, 0, 0, 0.35);
}

* {
    margin: 0px;
    padding: 0px;
}

html {
    background: #fff;
}

body {
    overflow-x: hidden;
    color: #fff;
}

.wrapper {
    margin-inline: auto;
    position: relative;
}


/* ----------------------------------
        MARK: Font Styles
---------------------------------- */

p {margin-block: 0;} /* reset from global-default.css */

p.title {
    --max-font-size: 75;
    --min-font-size: 48;
    line-height: 1.1em;
    color: var(--blue);
    font-family: "Archivo Black", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 400;
}

p.header1 {
    --max-font-size: 40;
    --min-font-size: 30;
    font-weight: 500;
    line-height: 1.3em;
}

p.header2 {
    --max-font-size: 28;
    --min-font-size: 22;
    font-weight: 400;
    line-height: 1.3em;
}

p.body {
    margin-block: 1em;
}



p.title + p.header1 {
    margin-top: 0.3em;
}
p.header1 + p.header2 {
    margin-top: 0.5em;
}
p.header1 + p.body {
    margin-top: 0.5em;
}


/* ----------------------------------
        MARK: Colors
---------------------------------- */
.white { color:#fff; }
.black { color:#000000; }

.white_bg { background-color: #fff; }

.nomargin { margin: 0 !important; }
.notopmargin, .nomargintop {margin-top: 0 !important;}
.nobottommargin, .nomarginbottom {margin-bottom: 0 !important;}


/* ----------------------------------
    MARK: Misc Default Styles
---------------------------------- */
.left {text-align: left;}
.center {text-align: center;}
.right {text-align: right;}

.section {
    position: relative;
}

.vc {
    display: flex;
    align-items: center;
}

.hc {
    display: flex;
    justify-content: center;
}

.vhc {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Wrap all tables in a div with this class so they display correctly on mobile */
.chart {overflow-x: auto;}

.touchandswipe {
    display: flex;
    align-items: center;
    margin-top: min(40px, 6vw);
    margin-bottom: -3vw;
}
.touchandswipe img {margin-inline-end: 0.5em;}
.touchandswipe.hide {display: none;}


/* ----------------------------------
        MARK: Custom Code
---------------------------------- */
section {
    position: relative;
    width: 100%;
    overflow-x: hidden;
}


svg {
    display: block;
}

video {
    border: 0;
    outline: 0;
    display: block;
}

.outer_card {
    border-radius: 28px;
    scrollbar-width:  thin;
    scrollbar-color: var(--purple-dk) transparent;
}


/* ---------------
    MARK: Panel 1
   --------------- */


#panel_1 .wrapper {
    width: min(1000px, var(--default-width));
    padding-block: min(220px, 30vw);
}

#panel_1 {
    color: var(--navy);
}



/* ---------------
    MARK: Panel 2
   --------------- */
#panel_2 {
    background: url(../images/2-Background_HD.jpg) 22% 33% / cover no-repeat;
}

#panel_2 .wrapper {
    width: min(1200px, var(--default-width));
    padding-block: min(120px, 20vw);
    display: grid;
    grid-template-columns: 1fr min(max(50%, 500px), 100%);
}

#panel_2 .text {
    padding-left: min(60px, 8vw);
    min-height: min(650px, 80vw);
    position: relative;
}

#panel_2 .border {
    width: 2px;
    height: 100%;
    position: absolute;
    top: 0px;
    left: 0px;
    background: var(--ultramarine);
}


/* ---------------
    MARK: Panel 3
   --------------- */
#panel_3 {
    background: var(--ultramarine);
}
#panel_3 .wrapper {
    width: min(1400px, var(--default-width));
    padding-block: min(120px, 12vw);
}

#panel_3 .outer_card {
    background: #fff;
    padding: min(45px, 9vw) min(100px, 5vw);
    color: var(--blue);
    margin-top: 30px;
}

#panel_3 .device_wrapper {
    width: 100%;
    border-bottom: 2px solid #e3e3e8;
}
#panel_3 .device_wrapper .base {
    display: block;
    max-width: 100%;
}

#panel_3 .device_inner {
    position: relative;
}

#panel_3 .screen_wrapper {
    position: absolute;
    bottom: 0;
    left: 18.6%;
    width: 62.7%;
    /* height: 77.4%; */
    /* outline: 1px solid red; */
}

#panel_3 .screen_wrapper img {
    position: absolute;
    bottom: 0px;
    left: 0px;
    width: 100%;
}


.swiper {
    --swiper-theme-color: var(--royal);
    --swiper-navigation-size: min(65px, 6vw);
    --swiper-navigation-sides-offset: 0;
    --swiper-pagination-bullet-size: 8px;
    --swiper-pagination-bullet-height: 8px;
    --swiper-pagination-bullet-active-width: 45px;
    --swiper-pagination-bullet-inactive-color: #6e6e72;
    --swiper-pagination-bullet-horizontal-gap: 5px;
    /* --swiper-pagination-bottom: 0; */
    --swiper-pagination-color: #29292a;
    --swiper-pagination-bullet-border-radius: 6px;
    /* --swiper-pagination-top: 100%; */
}
#carousel_3 {
    width: 100%;
    /* padding-bottom: min(60px, 7vw); */
    /* box-sizing: border-box; */
}
.swiper-pagination {
    position: relative;
    display: inline-block;
    /* margin-top: 40px; */
    width: fit-content !important;
    background: #ecf0f9;
    padding: 15px 20px;
    border-radius: 25px;
}
.swiper-button-prev, .swiper-button-next {
    /* height: auto !important; */
    /* margin-top: unset !important; */
    /* top: unset !important; */
    /* margin-left: unset !important; */
}
.swiper-button-prev {
    /* left: var(--swiper-navigation-sides-offset)!important; */
    /* right: unset!important; */
}
.swiper-button-next {
    right: var(--swiper-navigation-sides-offset) !important;
    left: unset !important;
}
.swiper-button-prev img, .swiper-button-next img {
    width: 100%;
    height: auto;
}
.swiper-pagination-bullet {
    opacity: 1;
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
    transition: width 0.4s ease-in-out;
    transform-origin: left center;
}
.swiper-pagination-bullet.swiper-pagination-bullet-active {
    width: var(--swiper-pagination-bullet-active-width);
    transition: width 0.4s ease-in-out;
    transform-origin: left center;
}
.swiper-slide {align-self: center;min-height: 175px;display: flex;align-items: center;justify-content: center;box-sizing: border-box;padding-block: 20px;}
.slide_inner {
    width: min(800px, calc(100% - var(--swiper-navigation-size)*2 - 8vw));
}

#carousel_3 p.header2 {
    font-weight: 500;
}


/* ---------------
    MARK: Panel 4
   --------------- */
#panel_4 {
    background: var(--dk-navy);
}

#panel_4 .wrapper {
    width: min(985px, var(--default-width));
    padding-block: min(100px, 10vw);
}
#panel_4 p span {
    color: var(--blue);
}

/* ---------------
    MARK: Panel 5
   --------------- */
#panel_5 {
    color: var(--navy);
}

#panel_5 .wrapper {
    width: min(1400px, var(--default-width));
    padding-block: min(85px, 13vw);
}

#panel_5 .outer_card {
    background: #ecf0f9;
    padding: min(85px, 9vw) min(40px, 5vw);
    overflow-x: auto;
    margin-top: 30px;
}


/* ---------------
    MARK: Tech Diagram
--------------- */

#tech_diagram {
    display: grid;
    grid-template-columns: auto auto 1fr;
    grid-template-rows: 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
    gap: min(40px, 3vw) 0px;
    grid-auto-flow: row;
    grid-template-areas:
        "stats_col line_col row_account"
        "stats_col line_col row_auth"
        "stats_col line_col row_event"
        "stats_col line_col row_data"
        "stats_col line_col row_training"
        "stats_col line_col row_part"
        "stats_col line_col row_report";
    min-width: 1025px;
}

.stats_col {
    grid-area: stats_col;
}

.stats_card {
    background: #fff;
    border-radius: 20px;
    border: 1px solid var(--purple-lt);
    padding-block: 14px;
    padding-inline: 25px;
    box-shadow: 0px 2.77px 2.21px 0px #6C49AC05,
            0px 6.65px 5.32px 0px #6C49AC07,
            0px 12.52px 10.02px 0px #6C49AC09,
            0px 22.34px 17.87px 0px #6C49AC0B,
            0px 41.78px 33.42px 0px #6C49AC0D,
            0px 100px 80px 0px #6C49AC12;
}

.divider {
    width: 100%;
    height: 1px;
    background: var(--purple-lt);
    margin-block: 40px 23px;
}

.stats_card p.num {
    --max-font-size: 22;
    --min-font-size: 22;
    font-weight: bold;
}
.stats_card .bar_wrapper {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: space-between;
}
.stats_card .bar_track {
    width: min(125px, 12vw);
    height: 5px;
    background: var(--gray-3);
    border-radius: 10px;
    position: relative;
}

.stats_card .bar {
    height: 135%;
    position: absolute;
    top: -15%;
    left: 0;
    border-radius: inherit;
}
.users_2025_box .bar {
    width: 8%;
    background: #8676FF;
}
.users_all_box .bar {
    width: 100%;
    background: #4EB4F9;
}

.users_all_box {
    margin-top: 30px;
}


.line_col { grid-area: line_col; }

.line_col .align {
    width: min(100px, 9vw);
    position: relative;
    height: 94%;
    z-index: 1;
}

.line_col .align .line_img {
    width: 114%;
    height: 100%;
    left: -6%;
    position: relative;
    top: 0%;
}

.row_account { grid-area: row_account; }

.row_auth { grid-area: row_auth; }

.row_event { grid-area: row_event; }

.row_data { grid-area: row_data; }

.row_training { grid-area: row_training; }

.row_part { grid-area: row_part; }

.row_report { grid-area: row_report; }


.row_style {
    display: flex;
    align-items: center;
}

.pill_style {
    background: #fff;
    border-radius: 15px;
    border-width: 1px;
    border-style: solid;
    border-color: rgb(var(--row-color-rgb) / 70%);
    padding: 10px 20px;
    box-shadow: 0px 2.77px 2.21px 0px rgb(var(--row-color-rgb) / 2%),
                0px 6.65px 5.32px 0px rgb(var(--row-color-rgb) / 3%),
                0px 12.52px 10.02px 0px rgb(var(--row-color-rgb) / 3.5%),
                0px 22.34px 17.87px 0px rgb(var(--row-color-rgb) / 4%),
                0px 41.78px 33.42px 0px rgb(var(--row-color-rgb) / 5%),
                0px 100px 80px 0px rgb(var(--row-color-rgb) / 7%);
}

.row_style .pill_style:first-child {
    border-width: 2px;
    border-color: rgb(var(--row-color-rgb) / 100%);
    box-shadow: 15px 8px 40px 0px rgb(var(--row-color-rgb) / 25%);
}

.row_style .pill_style p {
    font-weight: bold;
    --max-font-size: 16;
    --min-font-size: 14;
}

.row_account {
    --row-color: #9D30DD;
    --row-color-rgb: 157 48 221;
}

.row_auth {
    --row-color: #4060FD;
    --row-color-rgb: 64 96 253;
}

.row_event {
    --row-color: #31ACFF;
    --row-color-rgb: 49 172 255;
}

.row_data {
    --row-color: #7161EB;
    --row-color-rgb: 113 97 235;
}

.row_training {
    --row-color: #FF5C21;
    --row-color-rgb: 255 92 33;
}

.row_part {
    --row-color: #D530B7;
    --row-color-rgb: 213 48 183;
}

.row_report {
    --row-color: #F4AE16;
    --row-color-rgb: 244 174 22;
}


.connector {
    width: 21px;
    height: 10px;
    position: relative;
    flex-shrink: 0;
    z-index: 1;
}
.connector img {
    width: 31px;
    height: 10px;
    position: absolute;
    top: 0px;
    left: -5px;
}


/* ---------------
    MARK: Panel 6
   --------------- */
#panel_6 {
    background: url(../images/6-Background_HD.jpg) 50% 50% / cover no-repeat;
    overflow: hidden;
}

#panel_6 .wrapper {
    padding-block: min(140px, 15vw) min(80px, 5vw);
    width: 100%;
}

#panel_6 .video_wrapper {
    position: relative;
}

#phone_6 {
    width: min(546px, 100%);
    display: block;
}


#panel_6 video {
    width: 65.5%;
    aspect-ratio: 360 / 640;
    display: block;
    position: absolute;
    top: 11.1%;
    left: 17.3%;
}



/* ---------------
    MARK: Panel 7
   --------------- */
#panel_7 {
    color: var(--navy);
}
#panel_7 .wrapper {
    width: min(1400px, var(--default-width));
    padding-block: min(85px, 13vw);
}
#panel_7 .outer_card {
    background: #ecf0f9;
    padding: min(40px, 7vw) min(60px, 5vw);
    margin-top: 30px;
    overflow: hidden;
}

/* ---------------
    MARK: Map Diagram
   --------------- */
#map_diagram {
    --map-yellow: #f4ae16;
    --map-blue: #4060fd;
    --map-green: #40b06d;
    --map-purple: #7161eb;
    --map-sky-blue: #31acff;
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto auto auto;
    gap: 10px 10px;
    grid-auto-flow: row;
    grid-template-areas:
        "users map map"
        "stats1 map map"
        "geos geos stats2";
}

#map_diagram > div {
    /* outline:1px solid red; */
    z-index: 1;
}

.users {
    grid-area: users;
    min-width: min(250px, 15vw);
    display: flex;
    align-items: flex-end;
}

.users p:nth-child(1) {
    --max-font-size: 24;
    --min-font-size: calc(var(--max-font-size) * 0.8);
    margin-bottom: 10px;
}

.users p:nth-child(3) {
    --max-font-size: 50;
    --min-font-size: 36;
    font-weight: 500;
    line-height: 100%;
}

.map {
    grid-area: map;
    position: relative;
    aspect-ratio: 1.8;
}

.map_container {
    /* aspect-ratio: 1.6; */
    z-index: 0;
    width: 107%;
    position: absolute;
    top: 0px;
    left: 0%;
}

.map_img {
    width: 100%;
    height: auto;
    display: block;
}
.map_lines {
    position: absolute;
    top: 9%;
    left: -2%;
    width: 92%;
    height: auto;
    display: block;
}

.dot_style {
    width: 14px;
    aspect-ratio: 1;
    border-radius: 50%;
    position: absolute;
}

.dot_canada {
    anchor-name: --canada-anchor;
    background: var(--map-yellow);
    top: 17%;
    left: 9.9%;
}

.dot_us {
    anchor-name: --us-anchor;
    background: var(--map-blue);
    top: 36%;
    left: 14.6%;
}

.dot_latam {
    anchor-name: --latam-anchor;
    background: var(--map-green);
    top: 67%;
    left: 23.3%;
}

.dot_emea {
    anchor-name: --emea-anchor;
    background: var(--map-purple);
    top: 18.3%;
    left: 59.7%;
}

.dot_apj {
    anchor-name: --apj-anchor;
    background: var(--map-sky-blue);
    top: 65%;
    left: 82.4%;
}

.callout_box {
    --row-color-rgb: 41 52 149;
    background:#fff;
    padding: 4px 10px;
    border-radius: 10px;
    position: absolute;
    /* Anchor bottom center of callout to top center of anchor dot */
    position-area: top;
    display: flex;
    gap: min(10px, 1.5vw);
    align-items: center;
    box-shadow: 0px 3.9px 3.12px 0px #2934950F,
            0px 9.37px 7.49px 0px #29349516,
            0px 17.63px 14.11px 0px #2934951B,
            0px 31.46px 25.17px 0px #29349520,
            0px 58.84px 47.07px 0px #29349526,
            0px 140.83px 112.66px 0px #29349536;
    z-index: 1;
}

.callout_box .swatch {
    width: min(30px, 5vw);
    aspect-ratio: 1;
    border-radius: 4px;
    flex-shrink: 0;
    background: var(--region-color);
}

.callout_canada {
    --region-color: var(--map-yellow);
    position-anchor: --canada-anchor;
}

.callout_us {
    --region-color: var(--map-blue);
    position-anchor: --us-anchor;
}

.callout_latam {
    --region-color: var(--map-green);
    position-anchor: --latam-anchor;
}

.callout_emea {
    --region-color: var(--map-purple);
    position-anchor: --emea-anchor;
}

.callout_apj {
    --region-color: var(--map-sky-blue);
    position-anchor: --apj-anchor;
}

.callout_box .arrow {
    width: 15px;
    position: absolute;
    top: calc(100% - 1px);
    left: calc(50% - 8px);
}


.callout_box .text p:nth-child(1) {
    --max-font-size: 14;
    --min-font-size: calc(var(--max-font-size) * 0.8);
}
.callout_box .text p:nth-child(2) {
    --max-font-size: 15;
    --min-font-size: calc(var(--max-font-size) * 0.8);
    font-weight: bold;
}


.stats1 { grid-area: stats1; }
.stats2 {
    grid-area: stats2;
    display: flex;
    gap: min(50px, 3vw);
    align-items: center;
}

.stats1 .stat_box + .stat_box {
    margin-top: 15px;
}

.stat_box p:nth-child(1) {
    --max-font-size: 16;
    --min-font-size: 14;
}
.stat_box p:nth-child(2) {
    --max-font-size: 24;
    --min-font-size: calc(var(--max-font-size) * 0.8);
    line-height: 100%;
}

.geos {
    grid-area: geos;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.geo_box {
    padding: 22px 17px;
    border-radius: 25px;
}

.geo_box p {
    color: #fff;
    --max-font-size: 16;
    --min-font-size: calc(var(--max-font-size) * 0.8);
}
.geo_box p:first-child {
    --max-font-size: 22;
    --min-font-size: calc(var(--max-font-size) * 0.8);
    font-weight: bold;
}

.geo_box:nth-child(1) {background: var(--map-yellow);}
.geo_box:nth-child(2) {background: var(--map-blue);}
.geo_box:nth-child(3) {background: var(--map-green);}
.geo_box:nth-child(4) {background: var(--map-purple);}
.geo_box:nth-child(5) {background: var(--map-sky-blue);}



/* ---------------
    MARK: Panel 8
   --------------- */
#panel_8 {
    background: var(--ultramarine);
}
#panel_8 .wrapper {
    width: min(1200px, var(--default-width));
    min-height: 290px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 20px 50px;
}



/* section .wrapper:after {
    position: absolute;
    top: 10%;
    right: 0;
    color: black;
    background: white;
    padding: 0.7em 1em;
    border-radius: 20px;
    font-size: 13px;
    border: 1px solid black;
}

#panel_1 .wrapper:after {content: "Panel 1";}
#panel_2 .wrapper:after {content: "Panel 2";}
#panel_3 .wrapper:after {content: "Panel 3";}
#panel_4 .wrapper:after {content: "Panel 4";}
#panel_5 .wrapper:after {content: "Panel 5";}
#panel_6 .wrapper:after {content: "Panel 6";}
#panel_7 .wrapper:after {content: "Panel 7";}
#panel_8 .wrapper:after {content: "Panel 8";} */



/* ----------------------------------
        MARK: MEDIA QUERIES
---------------------------------- */


@media only screen and (max-width: 1024px) {
	p, ul, li {line-height: 140%;}

    #map_diagram {
        --gap: min(30px, 3vw);
        grid-template-columns: auto 1fr 1fr;
        grid-template-rows: auto auto auto;
        gap: 0px var(--gap);
        grid-auto-flow: row;
        grid-template-areas:
            "users stats1 stats2"
            "map map map"
            "geos geos geos";
    }
    .users {
        display: unset;
    }
    .stats1, .stats2 {
        display: grid;
        grid-template-columns: auto auto;
        gap: 10px var(--gap);
        /* align-content: flex-start; */
        align-items: flex-start;
    }
    .stats1 .stat_box + .stat_box {
        margin-top: 0px;
    }

}


/* MARK: 768 */
/* MOBILE */
@media only screen and (max-width: 768px) {

    #panel_2 {
        background: #092845 url(../images/2-Background_MOB.jpg) 50% 0% / 100% auto no-repeat;
    }

    #panel_2 .wrapper {
        padding-top: 50vw;
        grid-template-columns: 1fr;
    }

    #panel_2 .empty {display: none;}

    #panel_6 {
        background: #092845 url(../images/6-Background_MOB.jpg) 50% 0% / 100% auto no-repeat;
    }

    #panel_6 .wrapper {
        padding-top: 50vw;
    }


    #panel_8 .wrapper {
        min-height: unset;
        grid-template-columns: 1fr;
        padding-block: 6vw 12vw;
        text-align: center;
    }
}

/* MARK: 600 */
@media only screen and (max-width: 600px) {
    #panel_5 .wrapper, #panel_7 .wrapper {
        width: 100%;
    }
    .outer_card {
        border-radius: 0px;
    }

    #panel_5 .header1 , #panel_7 .header1  {
        padding-inline: 10vw;
    }

    #map_diagram {
        --gap: 15px;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto auto auto;
        gap: var(--gap) var(--gap);
        grid-template-areas:
            "users users"
            "stats1 stats2"
            "map map"
            "geos geos";
    }

    .map {
        aspect-ratio: 1.4;
        margin-top: 25px;
    }

    .map_container {
        width: 114.6%;
        left: -5.3%;
    }
}



/* MARK: 450 */
@media only screen and (max-width: 450px) {
    .stats1, .stats2 {
        grid-template-columns: 1fr;
        align-content: flex-start;
    }
    .callout_box {
        padding: 2px 5px;
    }


#tech_diagram {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: repeat(8, auto);
    gap: min(40px, 3vw) 0px;
    grid-auto-flow: row;
    grid-template-areas:
        "stats_col"
        "row_account"
        "row_auth"
        "row_event"
        "row_data"
        "row_training"
        "row_part"
        "row_report";
    min-width: 850px;
}

.stats_card {
    width: calc(100vw - (5vw * 2));
    box-sizing: border-box;
    position: sticky;
    left: 0;
    margin-bottom: 25px;
}

.divider {
    margin-block: 14px;
}

.users_all_box {
    margin-top: 0px;
}

.stats_card .bar_track {
    width: 100%;
}

.line_col {display: none;}

.user_box_container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-content: flex-start;
    gap: 20px;
}

}



@media only screen and (max-width: 400px) {
    .geos {
        display: grid;
        grid-template-columns: auto auto;
    }
}