/* Global Font Styles */
@font-face {
    font-display: swap;
    font-family: 'DIN';
    font-weight: 300;
    font-style: normal;
    font-display: swap;
    src: url(/wp-content/themes/checkpoint-theme-v2/fonts/34CA47_4_0.woff2) format("woff2")
}

@font-face {
    font-display: swap;
    font-family: 'DIN';
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    src: url(/wp-content/themes/checkpoint-theme-v2/fonts/34CA47_6_0.woff2) format("woff2")
}

@font-face {
    font-display: swap;
    font-family: 'DIN';
    font-weight: 500;
    font-style: normal;
    font-display: swap;
    src: url(/wp-content/themes/checkpoint-theme-v2/fonts/34CA47_8_0.woff2) format("woff2")
}

@font-face {
    font-display: swap;
    font-family: 'DIN';
    font-weight: 700;
    font-style: normal;
    font-display: swap;
    src: url(/wp-content/themes/checkpoint-theme-v2/fonts/34CA47_A_0.woff2) format("woff2")
}
/* Defaults */
:root {
    /* Spacing */
    --container-max-width: 1600px;
    --section-spacing-vert: 8rem;
    --section-spacing-hor: 5%;
    --section-spacing: var(--section-spacing-vert) var(--section-spacing-hor) var(--section-spacing-vert) var(--section-spacing-hor);
    --col-gutter: 2.5%;
    --row-gutter: 2rem;
    --row-break: 6rem;
    /* Colors */
    --primary-color: #ee0c5d;    /* Brand Berry color */
    --btn-bgcolor: #e40c5b;
    --btn-secondary-bgcolor: #fff;    /* Brand Berry color for button */
    --primary-darker-color: #b70d4e;    /* Berry Dark color */
    --primary-darker-color-rgb: 183,13,78;    /* Berry Dark color RGB values */
    --clay-color: #f2f2f2;    /* Brand Clay color */
    --gravitas-grey: #41273c;    /* Gravitas Gray color */
    --purple-color: #741984;    /* Secondary purple color */
    --purple-gradient: linear-gradient(45deg, var(--purple-color), #421f42);
    --primary-gradient: linear-gradient(45deg, var(--primary-color), var(--primary-darker-color));
    --bg-light-grey-color: #F5F5F5;
    --bg-lighter-grey-color: #FCFCFC;
    --bg-darker-grey-color: #EBEBEB;
    --text-color: #333;
    --text-light: #A7A9AC;
    --text-reverse: #FFF;
    --border-color: #CACACA;
    --card-border-color: rgba(48, 36, 47, 0.14);
    /* Font weights */
/*  --font-lt: 'DIN-Light', 'Helvetica', Arial, sans-serif;
    --font-reg: 'DIN', 'Helvetica Neue', Arial, sans-serif;
    --font-bold: 'DIN-Bold', 'Helvetica Neue', Arial, sans-serif;
    --font-semibold: 'DIN-Medium', 'Helvetica Neue', Arial, sans-serif; */
    --font-lt: 300;
    --font-reg: 400;
    --font-semibold: 500;
    --font-bold: 700;
    /* Default overrides for carousels */
    --bullet-active: #a39f9f;
    --swiper-pagination-color: #a39f9f;
    --swiper-pagination-bullet-horizontal-gap: 10px;
    --swiper-navigation-color: var(--gravitas-grey);
    --swiper-navigation-size: 20px;
    --swiper-navigation-sides-offset: 20px;
}
html {
    font-size: 16px;
    overflow-x: hidden;
}
body {
    max-width: 100%;
    overflow: hidden auto;
    font-family: 'DIN', 'Helvetica Neue', Arial, sans-serif;
    font-weight: var(--font-lt);
    font-size: 19px;
    line-height: 1.5;
    color: var(--text-color);
}
body #ChatShare-container,
#ChatShare-container {
    z-index: 1 !important;
  }
a {
    color: var(--btn-bgcolor);
    font-weight: var(--font-reg);
}

a:focus,
a:hover {
    color: var(--primary-darker-color);
}

/* override bootstrap 4 defaults 

.row.swiper-wrapper {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
}*/

.btn-group-vertical > .btn-group::after, .btn-group-vertical > .btn-group::before, .btn-toolbar::after, .btn-toolbar::before, .clearfix::after, .clearfix::before, .container-fluid::after, .container-fluid::before, .container::after, .container::before, .dl-horizontal dd::after, .dl-horizontal dd::before, .form-horizontal .form-group::after, .form-horizontal .form-group::before, .modal-footer::after, .modal-footer::before, .modal-header::after, .modal-header::before, .nav::after, .nav::before, .navbar-collapse::after, .navbar-collapse::before, .navbar-header::after, .navbar-header::before, .navbar::after, .navbar::before, .pager::after, .pager::before, .panel-body::after, .panel-body::before, .row::after, .row::before {
    display: none!important;
 }
/* Max width container */

.section {
    clear: both;
}
.container {
    box-sizing: border-box;
    background: transparent;
    width: 100%;
    max-width: var(--container-max-width);
    margin: 0 auto;
}
section .container {
    padding: var(--section-spacing);
}
section .container + .container {
    padding-top: 0;
}
section .container .container,
section.logo-garden-section .container,
section.stats-section .container {
    padding-top: calc(var(--section-spacing-vert) / 3);
    padding-bottom: calc(var(--section-spacing-vert) / 3);
}
.row .row,
.tab-content .row,
.row {
    margin-left: 0;
    margin-right: 0;
}
.row-spotlight .row:after,
.card-deck:before,
.flex.row:before {
    display: none;
}
.card-deck {
    margin-left: 0;
    margin-right: 0;
}
.row:not(.card-deck)>[class^="col-"]:first-of-type {
    padding-left: 0;
}

.row:not(.card-deck)>[class^="col-"]:last-of-type {
    padding-right: 0;
}

.tabs-row-vert,
.flex {
    display: flex;
}

.flex [class^="col-"] {
    float: none;
}
.text-uc {
    text-transform: uppercase;
}
.dark-bg-reverse {
    color: var(--text-reverse);
    /*  font-weight: var(--font-reg); */
}

.red-component {
    background: var(--primary-gradient);
    color: var(--text-reverse);
    font-weight: var(--font-reg);
}

.purple-component {
    background: var(--purple-gradient);
    color: var(--text-reverse);
    font-weight: var(--font-reg);
}

.grey-component,
.bg-grey {
    background-color: var(--clay-color);
}

.bg-light-grey {
    background-color: var(--bg-light-grey-color);
}

.bg-lighter-grey {
    background-color: var(--bg-lighter-grey-color);
}

.bg-darker-grey {
    background-color: var(--bg-darker-grey-color);
}
.bg-primary-red {
    background: var(--primary-darker-color) url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-primary-red.png') no-repeat top left /cover;
}
.dark-bg-reverse h1,
.dark-bg-reverse h2 {
    font-weight: var(--font-lt);
}

b,
strong,
.semibold {
    font-weight: var(--font-semibold);
}

.bold {
    font-weight: var(--font-bold);
}

.breadcrumb {
    background: transparent;
    padding: 0;
}

.dark-bg-reverse .breadcrumb-item a,
.dark-bg-reverse .breadcrumb-item+.breadcrumb-item::before,
.dark-bg-reverse .breadcrumb-item.active {
    color: var(--text-reverse);
}

.breadcrumb-item+.breadcrumb-item::before {
    content: var(--bs-breadcrumb-divider, ">");
}
.jump-nav.navbar {
    padding-top: 0;
    padding-bottom: 0;
    min-height: 0;
}
.jump-nav.navbar:not(.affix) {
    position: static;
}
.jump-nav.navbar,
.jump-nav.navbar-inverse {
    background-color: var(--gravitas-grey);
    border-color: var(--gravitas-grey);
    color: var(--text-reverse);
}
.navbar-inverse .navbar-nav>li>a:focus,
.navbar-inverse .navbar-nav>li>a:hover {
    background-color: rgba(var(--primary-darker-color-rgb),0.43);
}
.navbar.affix {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 30;
}
.jump-nav .navbar-nav {
    position: relative;
    margin: 0 auto;
    justify-content: center;
    padding: 0;
    flex-wrap: nowrap;
}
.jump-nav.navbar-expand-md .navbar-nav .nav-link,
.jump-nav .navbar-nav a {
    font-weight: var(--font-semibold);
    padding-left: 1rem;
    padding-right: 1rem;
}
.navbar-nav > li {
    margin-bottom: 0;
}
.jump-nav .navbar-inverse .navbar-nav>.active>a {
  
}
/* Text Styles based on the provided designs */
h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: var(--font-semibold);
    margin-top: 0;
    margin-bottom: 1rem;
}

h1 {
    font-size: 64px;
    font-weight: var(--font-lt);
}

h2 {
    font-weight: var(--font-reg);
    font-size: 40px;
    line-height: 1.25;
    margin-bottom: 1.25rem;
}

h3 {
    font-size: 46px;
    line-height: 1.2;
    color: inherit;
}

h4 {
    font-size: 40px;
    line-height: 1.3;
}

.subhead {
    font-size: 32px;
    font-weight: 400;
}

p {
    font-size: 24px;
    margin: 0 0 2rem;
}
h2.title-compact {
    font-size: 1rem;
    font-weight: 500;
}
canvas {
    max-width: 100%;
}
/* Button Styles */
.btn {
    font-size: 20px;
    transition: all 0.3s ease;
}

.btn-primary,
.btn-secondary {
    border-color: var(--btn-bgcolor);
    border-width: 1px;
    border-radius: 0;
    padding: 0.5rem 1.5rem 0.9rem;
    font-weight: var(--font-semibold);
    letter-spacing: 0.03ch;
    box-shadow: none;
}

.btn-primary {
    background-color: var(--btn-bgcolor);
}

.btn-secondary {
    background-color: var(--btn-secondary-bgcolor);
    color: var(--btn-bgcolor);
}

.dark-bg-reverse .btn-link.btn-link-cta {
    color: var(--text-reverse);
}

.dark-bg-reverse .btn-secondary {
    background-color: transparent;
    color: var(--text-reverse);
    border-color: var(--text-reverse);
}

.red-component .btn-primary:not(:hover):not(:active):not(:focus) {
    background-color: var(--gravitas-grey);
    border-color: var(--gravitas-grey);
}

.red-component .btn-primary:hover,
.red-component .btn-primary:active,
.red-component .btn-primary:focus {
    background-color: var(--purple-color);
    border-color: var(--purple-color);
}

.dark-bg-reverse .cta-banner h3,
.dark-bg-reverse .cta-banner p {
    font-weight: var(--font-reg);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary.active,
.btn-primary.active:hover,
.btn-primary:active,
.btn-primary:active:hover,
.btn-primary:active:focus,
.btn-secondary.focus,
.btn-secondary:focus,
.btn-secondary:hover,
.dark-bg-reverse .btn-secondary:hover,
.dark-bg-reverse .btn-secondary:active,
.dark-bg-reverse .btn-secondary:focus {
    color: #fff;
    background-color: var(--primary-darker-color);
    background-image: none;
    border-color: var(--primary-darker-color);
    outline: none;
    box-shadow: none;
}

.btn-link,
.btn-link-cta,
.btn-link.btn-link-cta {
    color: var(--btn-bgcolor);
    font-weight: var(--font-bold);
    text-decoration: none;
    text-wrap-mode: wrap;
    word-wrap: normal;
    line-height: 1.5;
    text-align: inherit;
    padding: initial;
    padding-right: 30px;
}

.btn-link-cta:after {
    content: "";
    width: 20px;
    height: 20px;
    display: inline-block;
    vertical-align: middle;
    box-sizing: content-box;
    padding-left: 10px;
    margin-right: -30px;
    background: no-repeat center center transparent url('data:image/svg+xml,%3Csvg width="16" height="13" viewBox="0 0 16 13" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M15.1797 6.64062C15.1797 6.9375 15.0729 7.1875 14.8594 7.39062L10.0312 12.2109C9.81771 12.4193 9.58333 12.5234 9.32812 12.5234C9.03125 12.5234 8.78906 12.4323 8.60156 12.25C8.41927 12.0677 8.32812 11.8411 8.32812 11.5703C8.32812 11.4193 8.35677 11.2839 8.41406 11.1641C8.47656 11.0391 8.55208 10.9323 8.64062 10.8438L10.2969 9.17969L12.8125 6.875L13.2266 7.5L10.4297 7.65625H1.92969C1.61719 7.65625 1.36458 7.5625 1.17188 7.375C0.979167 7.1875 0.882812 6.94271 0.882812 6.64062C0.882812 6.34375 0.979167 6.10417 1.17188 5.92188C1.36458 5.73438 1.61719 5.64062 1.92969 5.64062H10.4297L13.2266 5.78906L12.8125 6.41406L10.2969 4.10938L8.64062 2.4375C8.55208 2.34896 8.47656 2.24479 8.41406 2.125C8.35677 2.00521 8.32812 1.86979 8.32812 1.71875C8.32812 1.44271 8.41927 1.21354 8.60156 1.03125C8.78906 0.848958 9.03125 0.757812 9.32812 0.757812C9.45312 0.757812 9.57552 0.786458 9.69531 0.84375C9.8151 0.895833 9.93229 0.973958 10.0469 1.07812L14.8594 5.89844C15.0729 6.10156 15.1797 6.34896 15.1797 6.64062Z" fill="%23EE0C5D"/%3E%3C/svg%3E');
}

.dark-bg-reverse .btn-link-cta:after,
.dark-bg-reverse .btn-link-cta:hover:after,
.dark-bg-reverse .btn-link-cta:active:after,
.dark-bg-reverse .btn-link-cta:focus:after {
    color: #fff;
    background-image: url('data:image/svg+xml,%3Csvg width="16" height="13" viewBox="0 0 16 13" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M15.1797 6.64062C15.1797 6.9375 15.0729 7.1875 14.8594 7.39062L10.0312 12.2109C9.81771 12.4193 9.58333 12.5234 9.32812 12.5234C9.03125 12.5234 8.78906 12.4323 8.60156 12.25C8.41927 12.0677 8.32812 11.8411 8.32812 11.5703C8.32812 11.4193 8.35677 11.2839 8.41406 11.1641C8.47656 11.0391 8.55208 10.9323 8.64062 10.8438L10.2969 9.17969L12.8125 6.875L13.2266 7.5L10.4297 7.65625H1.92969C1.61719 7.65625 1.36458 7.5625 1.17188 7.375C0.979167 7.1875 0.882812 6.94271 0.882812 6.64062C0.882812 6.34375 0.979167 6.10417 1.17188 5.92188C1.36458 5.73438 1.61719 5.64062 1.92969 5.64062H10.4297L13.2266 5.78906L12.8125 6.41406L10.2969 4.10938L8.64062 2.4375C8.55208 2.34896 8.47656 2.24479 8.41406 2.125C8.35677 2.00521 8.32812 1.86979 8.32812 1.71875C8.32812 1.44271 8.41927 1.21354 8.60156 1.03125C8.78906 0.848958 9.03125 0.757812 9.32812 0.757812C9.45312 0.757812 9.57552 0.786458 9.69531 0.84375C9.8151 0.895833 9.93229 0.973958 10.0469 1.07812L14.8594 5.89844C15.0729 6.10156 15.1797 6.34896 15.1797 6.64062Z" fill="%23ffffff"/%3E%3C/svg%3E');

}
.btn-link-cta:hover,
.btn-link-cta:active,
.btn-link-cta:focus,
.btn-link.btn-link-cta:hover,
.btn-link.btn-link-cta:focus,
.btn-link.btn-link-cta:active {
    color: var(--primary-darker-color);
    text-decoration: none;
}

.btn-link-cta:hover:after,
.btn-link-cta:active:after,
.btn-link-cta:focus:after {
    background-image: url('data:image/svg+xml,%3Csvg width="16" height="13" viewBox="0 0 16 13" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M15.1797 6.64062C15.1797 6.9375 15.0729 7.1875 14.8594 7.39062L10.0312 12.2109C9.81771 12.4193 9.58333 12.5234 9.32812 12.5234C9.03125 12.5234 8.78906 12.4323 8.60156 12.25C8.41927 12.0677 8.32812 11.8411 8.32812 11.5703C8.32812 11.4193 8.35677 11.2839 8.41406 11.1641C8.47656 11.0391 8.55208 10.9323 8.64062 10.8438L10.2969 9.17969L12.8125 6.875L13.2266 7.5L10.4297 7.65625H1.92969C1.61719 7.65625 1.36458 7.5625 1.17188 7.375C0.979167 7.1875 0.882812 6.94271 0.882812 6.64062C0.882812 6.34375 0.979167 6.10417 1.17188 5.92188C1.36458 5.73438 1.61719 5.64062 1.92969 5.64062H10.4297L13.2266 5.78906L12.8125 6.41406L10.2969 4.10938L8.64062 2.4375C8.55208 2.34896 8.47656 2.24479 8.41406 2.125C8.35677 2.00521 8.32812 1.86979 8.32812 1.71875C8.32812 1.44271 8.41927 1.21354 8.60156 1.03125C8.78906 0.848958 9.03125 0.757812 9.32812 0.757812C9.45312 0.757812 9.57552 0.786458 9.69531 0.84375C9.8151 0.895833 9.93229 0.973958 10.0469 1.07812L14.8594 5.89844C15.0729 6.10156 15.1797 6.34896 15.1797 6.64062Z" fill="%23b70d4e"/%3E%3C/svg%3E');
}

.dark-bg-reverse .btn-link.btn-link-cta:hover,
.dark-bg-reverse .btn-link-cta:hover {
    color: var(--primary-color);
}
.dark-bg-reverse .btn-link-cta:hover::after {
    background-image: url('data:image/svg+xml,%3Csvg width="16" height="13" viewBox="0 0 16 13" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M15.1797 6.64062C15.1797 6.9375 15.0729 7.1875 14.8594 7.39062L10.0312 12.2109C9.81771 12.4193 9.58333 12.5234 9.32812 12.5234C9.03125 12.5234 8.78906 12.4323 8.60156 12.25C8.41927 12.0677 8.32812 11.8411 8.32812 11.5703C8.32812 11.4193 8.35677 11.2839 8.41406 11.1641C8.47656 11.0391 8.55208 10.9323 8.64062 10.8438L10.2969 9.17969L12.8125 6.875L13.2266 7.5L10.4297 7.65625H1.92969C1.61719 7.65625 1.36458 7.5625 1.17188 7.375C0.979167 7.1875 0.882812 6.94271 0.882812 6.64062C0.882812 6.34375 0.979167 6.10417 1.17188 5.92188C1.36458 5.73438 1.61719 5.64062 1.92969 5.64062H10.4297L13.2266 5.78906L12.8125 6.41406L10.2969 4.10938L8.64062 2.4375C8.55208 2.34896 8.47656 2.24479 8.41406 2.125C8.35677 2.00521 8.32812 1.86979 8.32812 1.71875C8.32812 1.44271 8.41927 1.21354 8.60156 1.03125C8.78906 0.848958 9.03125 0.757812 9.32812 0.757812C9.45312 0.757812 9.57552 0.786458 9.69531 0.84375C9.8151 0.895833 9.93229 0.973958 10.0469 1.07812L14.8594 5.89844C15.0729 6.10156 15.1797 6.34896 15.1797 6.64062Z" fill="%23ee0c5d"/%3E%3C/svg%3E');
}

.card .btn-link-cta {
    font-size: 16px;
}

.arrow {
    margin-left: 5px;
}

hr {
    border-width: 2px;
    border-color: var(--border-color);
}

.img-full-width {
    width: 100%;
    height: auto;
}

/* Component A: Hero Section */
.hero-section {
    display: flex;
    flex-direction: column;
}
.hero-wrapper {
    overflow-y: hidden;
    position: relative;
}

.hero-section .row {
    display: flex;
    align-content: center;
    flex-wrap: wrap;
}

.hero-section .intro-text,
.hero-section p {
    font-weight: var(--font-lt);
}

.hero-img {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}
.hero-img wistia-player,
.hero-img img {
    height: 100%;
    width: auto;
    position: absolute;
    right: 0;
    object-fit: cover;
}
.hero-img wistia-player {
    
}
.hero-img:after {
    content: "";
    position: absolute;
    width: 100%;
    left: 0;
    top: 0;
    bottom: 0;
    background: linear-gradient(90deg, var(--gravitas-grey) 50%, transparent 70%);
}
@media (min-width: 2100px) {
    .hero-img:after {
        content: "";
        position: absolute;
        width: 60%;
        max-width: 1185px;
        right: 0;
        top: 0;
        bottom: 0;
        margin-left: auto;
        background: linear-gradient(90deg, var(--gravitas-grey) 15%, transparent 35%);
    }
}
.hero-img > .video-poster {
    display: block;
    filter: blur(1px);
}
.hero-section .container.under-hero-promo {
    padding-top: 0;
    margin-top: -2rem;
}
.hero-section .container.under-hero-promo .promo-box {
    margin-top: 0;
}
.breadcrumb {
    margin-bottom: 4rem;
    margin-top: -2rem;
    font-size: 13px;
}

.breadcrumb,
.breadcrumb a {
    text-transform: uppercase;
    letter-spacing: 0.1rem;
    font-weight: var(--font-reg);
    line-height: 1.6;
}

.breadcrumb a:hover,
.breadcrumb a:active {
    text-decoration: underline;
    text-underline-offset: 0.2em;
}

h1 {
    margin-bottom: 2rem;
}

.cta-wrapper,
.hero-buttons {
    display: flex;
    gap: 1rem 2.5rem;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 0rem;
}
.promo-box .cta-wrapper {
    justify-content: end;
    margin-top: 0;
}

.text-center.cta-wrapper,
.text-center .cta-wrapper,
.text-center .hero-buttons {
    justify-content: center;
}

.section-text+.hero-buttons {
    margin-top: 3rem;
}

/* Component B: Dark CTA Block (formerly Conversion CTA) */
.cta-block-dark {
    background: var(--gravitas-grey) url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-footer.svg') no-repeat center center / auto 100%;
    position: relative;
}
.cta-block-light {
    background: var(--bg-light-grey-color) url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-footer-light.svg') no-repeat center center / 100%;
}
.bg-dark-red-grey {
    background: #30242f url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-dark-red-grey.svg') no-repeat top left / 100%;
}
.section-intro p:last-child,
.section-intro .section-text:last-child,
.section-intro .section-title:last-child {
    margin-bottom: 0;
}

.intro-text,
.section-text {
    font-size: 26px;
    line-height: 1.4;
}

.action-group {
    display: flex;
    gap: 15px;
}

.content-list {
    margin-top: 30px;
}

.list-item h4 {
    font-size: 18px;
    margin: 15px 0 10px;
    font-weight: var(--font-bold);
}

.spotlights-section>.container {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
}

.row-spotlight {
    justify-content: space-between;
    align-items: flex-start;
    column-gap: calc(var(--col-gutter)*2);
}

.row-spotlight .row {
    flex-wrap: nowrap;
    column-gap: 1rem;
}

.row-spotlight>[class^="col-"] {
    display: flex;
}
.card {
    background-color: transparent;
}
.row-spotlight .card-img {
    text-align: right;
}
.row-spotlight .card-img img {
    aspect-ratio: 1/1;
    max-width: 100%;
  height: auto;
}

.row-spotlight h3 {
    font-weight: var(--font-bold);
    font-size: 16px;
}

.row-spotlight .btn-link-cta {
    font-size: 16px;
    line-height: 1;
}
.row-spotlight .card-text {
    font-size: 16px;
    line-height: 1.25;
}

.card-spotlight {
    display: flex;
    flex-direction: column;
}

.col-md-6.card-spotlight {
    padding-left: 0;
}
/* Background circles */

.bg-section-circles-1 {
    background-color: var(--bg-light-grey-color);
    background-image: url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-circles-1.svg'), linear-gradient(180deg, #ECECEC 1.38%, #F9F9F9 100%);
    background-size: auto 100%;
    background-position: left top;
    background-repeat: no-repeat;
}
.bg-section-circles-2 {
    background-color: #F8F8F8;
    background-image: url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-circles-2.svg'), linear-gradient(180deg, #F9F9F9 -1.54%, #ECECEC 56.57%);
    background-size: auto 100%;
    background-position: right bottom;
    background-repeat: no-repeat;
}
.bg-section-circles-3 {
    background-color: var(--bg-light-grey-color);
    background-image: url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-circles-3.svg'), linear-gradient(180deg, #F9F9F9 -1.54%, #ECECEC 56.57%);
    background-size: auto 100%;
    background-position: right center;
    background-repeat: no-repeat;
}
.bg-section-circles-4 {
    background-color: var(--bg-darker-grey-color);
    background-image: url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-circles-4.svg'), linear-gradient(180deg, #ECECEC -1.54%, #F9F9F9 56.57%);
    background-size: auto 100%;
    background-position: left center;
    background-repeat: no-repeat;
}
/* Component E: Dark Content Section (formerly Check Point Healthcare IoT Security) */
.bg-gravitas-grey {
    background-color: var(--gravitas-grey);
    color: var(--text-reverse);
}
h4.subheading {
    font-size: 30px;
    font-weight: var(--font-reg);
}

.nav-tabs {
    background-image: none;
    list-style-image: none;
    border-color: var(--border-color);
}

.nav-tabs > li > a:after {
    content: "";
    display: block;
    position: absolute;
    width: 5px;
    height: 5px;
    background: transparent;
}

.nav-tabs > li:not(.active) > a:after {
    border-radius: 100%;
}

.nav-tabs.tabs-top > li > a:after {
    bottom: -5px;
}

.nav-tabs.tabs-left > li > a:after {
    right: -5px;
}

.nav-tabs > li.active > a,
.nav-tabs > li.active > a:hover,
.nav-tabs > li.active > a:focus,
.nav-tabs > li > a,
.nav-tabs > li > a:hover,
.nav-tabs > li > a:focus {
    position: relative;
    font-weight: var(--font-bold);
    font-size: 20px;
    color: var(--text-color);
    background-color: transparent;
    border: none;
    border-radius: 0;
    z-index: 1;
}

.nav-tabs.tabs-top > li.active > a,
.nav-tabs.tabs-top > li.active > a:hover,
.nav-tabs.tabs-top > li.active > a:focus,
.nav-tabs.tabs-top > li > a,
.nav-tabs.tabs-top > li > a:hover,
.nav-tabs.tabs-top > li > a:focus {
    padding: 10px 20px;
}

.nav-tabs > li.active > a,
.nav-tabs > li.active > a:hover,
.nav-tabs > li.active > a:focus {
    color: var(--btn-bgcolor);
}

.nav-tabs > li.active:after { /* override cp_base */
    display: none;
}
.nav-tabs > li > a:hover,
.nav-tabs > li > a:focus {
    color: var(--purple-color);
}

.nav-tabs > li.active > a:after {
    background: var(--btn-bgcolor);
}

.nav-tabs.tabs-top > li:not(.active) > a:after {
    left: calc(50% - 5px);
}

.nav-tabs.tabs-top > li:not(.active) > a:hover:after {
    bottom: -5px;
}

.nav-tabs.tabs-top > li.active > a:after {
    width: calc(100% - 40px);
    height: 5px;
    left: 20px;
    transition: width 0.3s ease-in, left 0.3s ease-in, right 0.3s ease-in;
}

.nav-tabs.tabs-left > li:not(.active) > a:after {
    top: calc(50% - 5px);
    bottom: auto;
    right: -7px;
}

.nav-tabs.tabs-left > li:not(.active) > a:hover:after {
    right: -9px;
}

.nav-tabs > li:not(.active) > a:hover:after {
    width: 10px;
    height: 10px;
    background: var(--purple-color);
}

.nav-tabs.tabs-left > li.active > a:after {
    height: auto;
    top: -1px;
    bottom: -1px;
    transition: height 0.3s ease-in, top 0.3s ease-in, bottom 0.3s ease-in;
}

.side-nav {
    padding-right: 0;
    border-right: 5px solid var(--border-color);
    margin-right: -5px;
}

.tabs-left {
    flex-direction: column;
    border-bottom-color: var(--border-color);
}

.tabs-left > li {
    float: none;
    margin-bottom: 0;
    border-top: 1px solid var(--border-color);
}

.nav-tabs.tabs-left > li > a {
    padding: 20px 10px 20px 0;
}

.tab-content {
    padding: 5%;
    border-radius: 0 3px 3px 3px;
}

.row .side-nav+.tab-content[class^="col-"] {
    padding-right: 3%;
}

.side-nav+.tab-content {
    border-left: 5px solid var(--border-color);
}

.tab-content h3 {
    margin-bottom: 20px;
}

ul.no-bullets,
.no-bullets li {
    list-style: none;
    list-style-image: none;
    padding-left: 0;
}
ul.checks,
ul.checks li {
    list-style: none;
    list-style-image: none;
}
ul.checks li {
    position: relative;
    padding-left: 30px;
}
ul.checks li:before { /* black checkmark */
    content: "";
    position: absolute;
    top: calc((1em / 2) - 3px);
    border-radius: 100%;
    left: -0.5ch;
    width: 20px;
    height: 20px;
    background-image: url(/wp-content/uploads/cp-check-5.png);
    background: no-repeat center center transparent url('data:image/svg+xml,%3Csvg width="32"  height="32" viewBox="0 0 32 32" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M16 2C13.2311 2 10.5243 2.82109 8.22202 4.35943C5.91973 5.89777 4.12532 8.08427 3.06569 10.6424C2.00607 13.2006 1.72882 16.0155 2.26901 18.7313C2.80921 21.447 4.14258 23.9416 6.10051 25.8995C8.05845 27.8574 10.553 29.1908 13.2687 29.731C15.9845 30.2712 18.7994 29.9939 21.3576 28.9343C23.9157 27.8747 26.1022 26.0803 27.6406 23.778C29.1789 21.4757 30 18.7689 30 16C30 12.287 28.525 8.72601 25.8995 6.1005C23.274 3.475 19.713 2 16 2ZM14 21.59L9.00001 16.59L10.59 15L14 18.41L21.41 11L23.006 12.586L14 21.59Z" fill="%2330242F"/%3E%3C/svg%3E');
}
.row-break,
.row + .row-break {
    margin-top: calc(var(--row-break)/2);
}
.row.hr {
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
}
.bg-white {
    background-color: #FFF;
}

.bg-grey {
    background-color: var(--clay-color);
}

.txt-purple {
    color: var(--purple-color);
}

.promo-box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--row-gutter) var(--col-gutter);
    padding: 2rem;
    margin-top: 30px;
    border-radius: 2px;
    border-left: 3px solid var(--border-color);
}
.promo-box > div {
    flex-shrink: 1;
    flex-grow: 1;
}
.promo-box.full-width {
    border: none;
    padding: 0;
}

.promo-box.border-red,
.border-red {
    border-color: var(--primary-color);
}

.promo-box.border-purple,
.border-purple {
    border-color: var(--purple-color)
}

.border-grey {
    border-color: var(--border-color)
}

.promo-box h3 {
    margin-bottom: 0;
}

.promo-box h3 .em {
    font-weight: var(--font-semibold);
}
.promo-box .em-larger {
    display: block;
    font-size: 1.5em;
}
.promo-box p {
    margin: 0;
    font-size: 20px;
    font-weight: var(--font-reg);
}

.promo-box h3 + p {
    margin-top: 0.5rem;
}

.full-width video,
.full-width .vimeo-video {
    width: 100%;
    height: auto;
}

.video-wrapper {
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.video-wrapper .video-poster {
    position: absolute;
    left: 0;
    right: 0;
    height: 100%;
    z-index: 1;
    width: 100%;
    top: 0;
    bottom: 0;
}

.video-wrapper.youtube {
    width: 100%;
}

.video-wrapper.play-button {
    --play-button-width: 85px;
    position: relative;
}

.video-wrapper.full-width iframe,
.video-wrapper.full-width>div {
    width: 100%;
    height: 100%;
}

.video-wrapper.play-button video,
.video-wrapper.play-button .vimeo-video {
    cursor: pointer;
}

.video-wrapper.play-button:before {
    content: "";
    position: absolute;
    display: block;
    left: calc(50% - var(--play-button-width)/2);
    top: calc(50% - var(--play-button-width)/2);
    width: var(--play-button-width);
    height: var(--play-button-width);
    cursor: pointer;
    z-index: 2;
    background: no-repeat center center transparent url('data:image/svg+xml,%3Csvg width="71" height="71" viewBox="0 0 71 71" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M35.8867 70.4336C31.0586 70.4336 26.5352 69.5312 22.3164 67.7266C18.0977 65.9219 14.3828 63.4141 11.1719 60.2031C7.98438 56.9922 5.47656 53.2773 3.64844 49.0586C1.84375 44.8398 0.941406 40.3164 0.941406 35.4883C0.941406 30.6602 1.84375 26.1367 3.64844 21.918C5.47656 17.6758 7.98438 13.9609 11.1719 10.7734C14.3828 7.5625 18.0977 5.05469 22.3164 3.25C26.5352 1.44531 31.0586 0.542969 35.8867 0.542969C40.7148 0.542969 45.2383 1.44531 49.457 3.25C53.6992 5.05469 57.4141 7.5625 60.6016 10.7734C63.8125 13.9609 66.3203 17.6758 68.125 21.918C69.9297 26.1367 70.832 30.6602 70.832 35.4883C70.832 40.3164 69.9297 44.8398 68.125 49.0586C66.3203 53.2773 63.8125 56.9922 60.6016 60.2031C57.4141 63.4141 53.6992 65.9219 49.457 67.7266C45.2383 69.5312 40.7148 70.4336 35.8867 70.4336ZM35.8867 62.1367C39.5898 62.1367 43.0469 61.4453 46.2578 60.0625C49.4688 58.6797 52.293 56.7695 54.7305 54.332C57.1914 51.8945 59.1016 49.0703 60.4609 45.8594C61.8438 42.625 62.5352 39.168 62.5352 35.4883C62.5352 31.8086 61.8438 28.3633 60.4609 25.1523C59.1016 21.918 57.1914 19.082 54.7305 16.6445C52.293 14.207 49.4688 12.2969 46.2578 10.9141C43.0469 9.53125 39.5898 8.83984 35.8867 8.83984C32.207 8.83984 28.7617 9.53125 25.5508 10.9141C22.3398 12.2969 19.5039 14.207 17.043 16.6445C14.6055 19.082 12.6953 21.918 11.3125 25.1523C9.92969 28.3633 9.23828 31.8086 9.23828 35.4883C9.23828 39.168 9.92969 42.625 11.3125 45.8594C12.6953 49.0703 14.6055 51.8945 17.043 54.332C19.5039 56.7695 22.3398 58.6797 25.5508 60.0625C28.7617 61.4453 32.207 62.1367 35.8867 62.1367ZM30.5078 48.5664C29.8047 48.9883 29.1016 49.1641 28.3984 49.0938C27.6953 49.0234 27.1094 48.7422 26.6406 48.25C26.1719 47.7578 25.9375 47.125 25.9375 46.3516V24.625C25.9375 23.8281 26.1719 23.1953 26.6406 22.7266C27.1094 22.2344 27.6953 21.9531 28.3984 21.8828C29.125 21.8125 29.8281 21.9766 30.5078 22.375L48.332 32.9219C49.0117 33.3203 49.457 33.8477 49.668 34.5039C49.9023 35.1602 49.9023 35.8164 49.668 36.4727C49.457 37.1289 49.0117 37.6562 48.332 38.0547L30.5078 48.5664Z" fill="%23FFFFFF"/%3E%3C/svg%3E');
}

.video-wrapper:not(.started)>div {
    display: none;
}

.video-wrapper.play-button.started .video-poster,
.video-wrapper.play-button.started:before {
    display: none;
}
.logo-highlight-section {
    overflow: hidden;
}
.logo-highlight-section .row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--row-gutter) var(--col-gutter);
    justify-content: space-between;
}

.red-component .logo-container {
    box-shadow: -2rem -1rem 0px 3rem rgba(var(--primary-darker-color-rgb),0.43);
}

.logo-container {
    margin: -1em 0;
    aspect-ratio: 1 / 1;
    background: #fff;
    border-radius: 100%;
    padding: 20%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.logo-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.logo-garden-section .row {
    align-items: center;
}
.row.logo-garden-vert {
    row-gap: var(--row-gutter);
}
.logo-garden {
    display: grid;
    width: 100%;
    margin: 0;
    list-style: none;
    grid-auto-flow: column;
    grid-template-rows: 1fr 1fr;
    grid-auto-columns: 1fr;
    align-items: center;
    justify-items: center;
    gap: 20px;
}
.logo-garden-single-row {
    grid-template-rows: auto;
}
.logo-garden li img {
    max-height: 100%;
    width: auto;
    max-width: 100%;
}
.logo-garden li {
    max-width: 150px;
    margin: 0;
}
.stats-hor h2 + .cta-wrapper,
.logo-garden-section h2 + .cta-wrapper {
    margin-top: 2rem;
}
/* Component I: Metrics Showcase (formerly Security Stats Section) */
.container .row.stats-hor .container {
    display: flex;
}
.container .row.stats-hor .container > div   {
    align-self: center;
}
.row.stats-hor {
    justify-content: space-between;
    align-items: center;
    height: 100%;
    row-gap: var(--row-gutter);
}

.row.stats-hor:before {
    display: none;
}

.stats-vert {
    padding: var(--row-gutter);
    row-gap: 1rem;
}

.stats-item {
    text-align: center;
    position: relative;
}

/* .stats-item:not(:last-of-type):after {
    content: "";
    position: absolute;
    top: 25%;
    right: 0;
    width: 1px;
    height: 50%;
    border-right: 1px solid var(--purple-color);
} */
.stats-number {
    margin-bottom: 0;
    font-weight: var(--font-reg);
    font-size: 60px;
    color: var(--purple-color);
}
.red-component .stats-number,
.purple-component .stats-number,
.dark-bg-reverse .stats-number {
    color: inherit;
}

.stats-number .pct {
    font-size: 40px;
}

.stats-number .curr {
    font-size: 75%;
    margin-right: 0.2ch;
}

.stats-item p {
    line-height: 1.2;
    font-weight: var(--font-reg);
    font-size: 20px;
}

/* Component J: Content Columns Section (formerly Common Challenges) */
.content-columns-section {}

h2 + .cta-wrapper,
.section-title + .cta-wrapper {
    margin-top: 3rem;
}

ul + .cta-wrapper {
    margin-top: 5%;
}


/* Component K: Content Showcase (formerly Featured Use Cases) */
.content-showcase {}


.card-deck {
    display: flex;
    flex-wrap: wrap;
    gap: var(--row-gutter) var(--col-gutter);
    justify-content: space-between;
}
.row.card-deck + .card-deck {
    margin-top: var(--col-gutter);
}
.swiper .card-deck {
    flex-wrap: nowrap;
    margin-top: -10px;
    padding-top: 10px;
    padding-bottom: 10px;
}

.row.swiper-wrapper {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
}

.card-deck .swiper-slide,
.row-spotlight .swiper-slide {
    width: auto;
    height: auto;
    flex-shrink: 1;
    flex-grow: 1;
    flex-basis: auto;
    max-width: none;
}

.carousel-paginated .swiper-pagination:not(.swiper-pagination-lock) {
    position: relative;
    bottom: 0;
    padding-top: 1rem;
}

.carousel-paginated .swiper-pagination-bullet-active {
    background: var(--bullet-active);
}

.card-deck .card {
    display: flex;
    flex-direction: column;
    padding: 2% 2% 3%;
    margin: 0;
    transition: all 0.3s ease;
    border-radius: 3px;
    border: none;
    transition: all 0.3s ease;
}
.card.dark-bg-reverse {
    padding: 5%;
}
.swiper-wrapper:before,
.row-spotlight:before,
.card-deck.row:after {
    display: none;
}

.columns-row {
    gap: calc(var(--row-gutter) * 1.25) calc(var(--col-gutter) * 1.6);
}

.icons-row {
    row-gap: calc(var(--row-gutter) * 1.5);
}

.columns-row .card-image {
    margin-bottom: 2rem;
}
.icon-anim .card-image {
  aspect-ratio: 1.23;
  align-content: center;
  text-align: center;
}
.icon-anim .card-image img {
  height: 100px;
}
.icon-anim .lottie-anim {
  margin: auto;
}
.card-deck.swiper-wrapper .card.col-lg-6 {
    min-width: calc(50% - var(--col-gutter)/2);
}
.card-deck .card.col-lg-6,
.card-deck .card.col-md-6,
.col-md-6.flex.flex-rows {
    width: calc(50% - var(--col-gutter)/2);
}
.card-deck .card.col-lg-4 {
    width: calc(25% - var(--col-gutter)*3);
}
.col-lg-12.card.card-hor {
    grid-auto-columns: 30% auto;
}
.card-deck .card[class^="col-"] {
    box-sizing: border-box;
    flex-basis: auto;
}

.card-deck .card.col-md-4 {
    width: calc((90% - var(--col-gutter)*2) / 3);
}
.columns-row .card.col-md-3 {
    width: calc((90% - (var(--col-gutter) * 3)) / 4);
}
.columns-row .card[class^="col-"] {
    padding-left: 0;
    padding-right: 0;
}
section .columns-row:last-of-type .card {
    padding-bottom: 0;
}
.card-deck .flex-rows {
    row-gap: 3rem;
    padding-left: 0;
    padding-right: 0;
}

.card-hor,
.card-deck .card-hor {
    display: grid;
    align-items: center;
    column-gap: 5%;
    padding: 2%;
    flex-basis: auto;
    grid-template-columns: 30% auto;
}
.card-hor.img-right {
    grid-template-columns: auto 30%;
}
.card-hor.card-hor-bleed,
.card-deck .card-hor.card-hor-bleed {
    padding: 0;
}
.card-hor.card-hor-bleed .card-body,
.card-deck .card-hor.card-hor-bleed .card-body {
    padding: 3% 3% 0 0;
}
.card-deck .card-hor.card-hor-bleed .card-cta {
    padding: 0 3% 3% 0;
}
.card-hor .card-body {
    padding: 0;
    grid-row: 1/2;
}
.card-hor .card-image {
    margin-bottom: 0;
    padding: 0;
    grid-row: 1/ span 2;
}
.card-hor.img-right .card-image {
    grid-column: 2;
}
.col-md-6 .card-hor {
    padding: 4%;
}
.cards-grey .card {
    background-color: var(--bg-darker-grey-color);
}
.cards-white .card {
    background-color: #FFF;
    border: 1px solid var(--card-border-color);
}
.cards-white .card:hover {
    box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.1);
    transform: translateY(-5px);
}
.cards-grey .card:hover {
    box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.3);
    transform: translateY(-5px);
}

.cards-centered {
    justify-content: center;
}

.cards-centered .card {
    align-items: center;
    text-align: center;
}

.card-image {
    margin-bottom: 1.5rem;
}

.card-body+.card-image {
    margin-top: 2.5rem;
    margin-bottom: 0;
}

.card-image:not([class^="col-"]) {
    width: 100%;
}
.card-image:not(.icon) img {
    width: 100%;
    height: auto;
}

.card-image.product-icon img {
    max-height: 58px;
    width: auto;
}
.card .card-body + .card-cta,
.card.card-hor .card-body + .card-cta,
.card-deck .card.card-hor .card-body + .card-cta,
.card-deck .card:not([class^="col-"]) .card-body + .card-cta {
    margin-top: 1rem;
}
.card-hor .card-body + .card-cta {
    align-self: flex-end;
}
.card-deck .card .card-body+.card-cta,
.card-deck .card.card-no-img .card-body+.card-cta {
    margin-top: 1.25rem;
}
.card.card-no-img .card-title {
    margin-top: 1rem;
}
h2.card-title {
    margin-bottom: 1rem;
    margin-top: 2rem;
}
.card-eyebrow {
    font-weight: var(--font-semibold);
    font-size: 0.75em;
    text-transform: uppercase;
}
.accordion .panel-body p,
.icons-row p,
.card-body p,
.card-text {
    font-size: 18px;
    margin-bottom: 1rem;
}

.card-body p:last-of-type {
    margin-bottom: 0;
}

.card-body {
    flex-grow: 1;
    padding: 0;
}

.card-link,
.card-link:hover,
.card-link:active {
    color: var(--btn-bgcolor);
    text-decoration: none;
}

.additional-items {
    margin-top: 30px;
}

.cta-banner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 2rem 5%;
    padding: var(--row-gutter) 3%;
    margin-top: 6rem;
    border-radius: 3px;
}

.cta-banner .cta-wrapper {
    margin-top: 0;
}

.cta-banner h3 {
    font-size: 24px;
}

.cta-banner h3,
.cta-banner p {
    margin: 0;
}

.feature-icon {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: var(--gravitas-grey);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 2rem;
    transition: all 0.3s ease;
}

.icon-box {
    width: 30px;
    height: 30px;
    background-color: #FFF;
    border-radius: 3px;
}

.icons-row .btn-link.btn-link-cta {
    /*  font-size: 25px; */
}

.text-center.col-sm-12[class^="col-"],
.text-center.col-xs-12[class^="col-"] {
    float: none;
    margin-left: auto;
    margin-right: auto;
}

.section-intro {
    margin-bottom: 5rem;
}
.custom-list,
.bordered-list {
    list-style-image: none;
    margin: 0;
}

.custom-list > li,
.bordered-list > li {
    margin: 0 0 1rem;
    background-color: transparent;
    box-shadow: none;
}
.custom-list {
    padding: 0 0 0 1.5rem;
}
.custom-list li::marker {
    color: var(--btn-bgcolor);
}
.bordered-list {
    padding: 0 0 0 3rem;
    list-style: none;
    border-left: 3px solid var(--purple-color);
}

.bordered-list-2 li {
    padding-left: 20px;
}

.custom-list > li:last-child,
.bordered-list > li:last-child {
    margin-bottom: 0;
}

.highlight-box p,
.bordered-list p {
    margin-bottom: 1rem;
}

.accordion .panel-heading,
.icons-row h3,
.card-title,
.highlight-box h3 {
    font-weight: var(--font-bold);
    font-size: 20px;
    margin-bottom: 1rem;
}

.bordered-list h3,
.list-item h3 {
    font-weight: var(--font-reg);
    font-size: 26px;
}

.highlight-box h3 {
    font-size: 30px;
}

.highlight-box {
    padding: 8%;
    height: 100%;
    border-radius: 3px;
}

.tag-label {
    display: inline-block;
    padding: 5px 10px;
    background-color: var(--purple-color);
    color: var(--text-reverse);
    font-size: 14px;
    font-weight: var(--font-semibold);
    margin-bottom: 3rem;
    text-transform: uppercase;
}

.accordion .panel-heading > a {
    position: relative;
    display: block;
    color: var(--text-color);
    font-weight: var(--font-bold);
}

.accordion .panel-heading > a:hover,
.accordion .panel-heading > a:focus {
    text-decoration: none;
    outline: none;
}

.accordion .panel-heading {
    margin-bottom: 0;
    clear: both;
    float: none;
}

.accordion.plus .panel-body,
.accordion.plus .panel-heading {
    padding-left: 20px;
}

.accordion .panel-group .panel-heading+.panel-collapse>.panel-body {
    border-top: none;
}

.accordion.plus .panel-heading > a {
    display: flex;
    align-items: center;
}

.accordion.plus .panel-heading a:after,
.accordion.plus .panel-heading a.collapsed:after {
    text-align: center;
    position: absolute;
    left: -20px;
    top: 10px;
    font-size: 22px;
    line-height: 0;
    border: none;
    transition: all 0.3s ease 0s;
}

.accordion.plus .panel-heading a:not(.collapsed):after {
    content: "-";
}

.accordion.plus .panel-heading a.collapsed:after {
    content: "+";
    top: 15px;
    transform: rotate(180deg);
}

.accordion.panel-group .panel-heading+.panel-collapse>.list-group,
.accordion.panel-group .panel-heading+.panel-collapse>.panel-body {
    border-top: none;
}

/* .accordion.plus .panel-heading:hover a.collapsed:after {
    transform: rotate(360deg);
} */

.accordion .panel-body {
    padding-top: 0;
}

.accordion.panel-group .panel {
    margin-top: 0;
    box-shadow: none;
    border-radius: 0;
    background-color: transparent;
    border-bottom: 1px solid var(--border-color);
}


.accordion-row[class^="col-"] {
    float: none;
    padding-left: 0;
}

.collapse.in .panel-img {
    right: 0%;
}

.accordion .collapse.in {
    display: block;
}

/* Component P: Platform Overview (formerly AI Platform Section) */
.content-block {
    margin-bottom: 40px;
    background-color: #fff;
    padding: 25px;
    border-radius: 3px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    height: 100%;
}

.content-block h3 {
    font-size: 24px;
    font-weight: var(--font-bold);
    margin-bottom: 15px;
}

.content-block p {
    margin-bottom: 20px;
}

.content-block .feature-list li:before {
    color: var(--gravitas-grey);
}


/* Component: Customer carousel */
.customer-carousel .swiper-wrapper {
    /* align-items: stretch;
    justify-content: center; */
}

.carousel-container {
    position: relative;
}

.carousel-container .swiper-button {
    width: 20px;
    height: 20px;
    box-sizing: content-box;
    padding: 4px;
    border-radius: 100%;
    border: 1px solid var(--gravitas-grey);
    z-index: 1;
}

.swiper-button-next:after,
.swiper-button-prev:after {
    content: "";
    width: 20px;
    height: 20px;
    background-repeat: no-repeat;
    background-position: center;
}
.swiper-button-prev:after {
    background-image: url('data:image/svg+xml,<svg width="10" height="16" viewBox="0 0 10 16" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M9.27344 2.2625L3.53594 8L9.27344 13.7375L7.49844 15.5L-0.00156212 8L7.49844 0.5L9.27344 2.2625Z" fill="%23341E30"/></svg>')
}
.swiper-button-next:after {
    background-image: url('data:image/svg+xml,<svg width="10" height="16" viewBox="0 0 10 16" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M0.724609 13.7375L6.46211 8L0.724609 2.2625L2.49961 0.5L9.99961 8L2.49961 15.5L0.724609 13.7375Z" fill="%23341E30"/></svg>')
}
section.customer-carousel .container {
    padding-bottom: 4rem;
}

.customer-quote-wrapper {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex-grow: 1;
    padding: 2rem;
}

.customer-carousel .swiper-slide {
    max-width: var(--container-max-width);
    height: auto;
    box-sizing: border-box;
    padding: 2rem var(--col-gutter);
    background-color: #2c202a;
    background-position: top right;
    background-size: cover;
    background-repeat: no-repeat;
}
.customer-mobile-bg::before,
.customer-carousel .swiper-slide::before {
  content: "";
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  position: absolute;
}
.customer-carousel .swiper-slide::before {
  background: linear-gradient(90deg, rgba(65, 39, 60, 0.86) 50%, transparent 80%);
}
.customer-mobile-bg::before {
    background: rgba(65, 39, 60, 0.86);
}
.customer-mobile-bg {
    display: none;
}

.customer-carousel .customer-logo {
    margin-bottom: 1.5rem;
}

.customer-carousel .customer-logo img {
    max-height: 100px;
}

.customer-carousel h3.customer-quote-text {
    font-size: 24px;
    line-height: 1.4;
}

/* .customer-carousel .swiper-pagination {
    display: none;
} */
.customer-mobile-pagination {
    position: relative;
    display: none;
}

.customer-quote-author {
    margin-top: 2rem;
    font-weight: var(--font-reg);
    font-size: 100%;
}

.customer-carousel .btn,
.customer-quote-author {
    font-size: 16px;
}

.customer-quote-name {
    display: inline-block;
    margin-bottom: -2ch;
    font-weight: var(--font-bold);
}

.carousel-tabs .swiper-wrapper {
    justify-content: center;
    column-gap: 10px;
    padding-top: 3rem;
}

.carousel-tabs {
    position: relative;
    left: calc(-1 * (100vw - 100%) / 2);
    width: 100vw;
}

.carousel-tabs .container {
    padding: 3rem 6rem 0;
}

.carousel-tabs .swiper-slide {
    width: auto !important;
    flex-shrink: 1;
    padding: 1rem;
    font-size: 20px;
    font-weight: var(--font-semibold);
    line-height: 1.2;
    color: #666;
}

.carousel-tabs .swiper-slide:not(.active) {
    cursor: pointer;
}

.carousel-tabs .swiper-slide:not(.active):hover {
    border-bottom: 3px solid var(--primary-darker-color);
}

.carousel-tabs .swiper-slide.active {
    color: var(--primary-darker-color);
    border-bottom: 3px solid var(--primary-darker-color);
}
.swiper-pagination-bullet::after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  padding: 10px;
  margin-left: -5px;
  margin-top: -5px;
}

@media (min-width: 1200px) {
    .navbar-expand-xl .navbar-nav .nav-link {
        padding-right: 1rem;
        padding-left: 1rem;
    }
}
@media (max-width: 1200px) {
    .hero-wrapper .container {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }
    .customer-carousel .swiper-slide {
        background-position: right 50% top;
    }
    .col-lg-6 .logo-garden {
        grid-template-rows: 1fr 1fr 1fr;
    }
}
/* Allow for header on smaller screens */
@media (max-width: 1023px) {
    body {
        padding-top: 62px;
    }
    .hero-video {
        display: flex;
        flex-direction: column-reverse;
    }
    .hero-video .hero-img {
        position: relative;
    }
    .hero-video .hero-img img {
        position: static;
    }
    .hero-video .hero-img > .video-poster {
        filter: none;
    }
    .hero-video .hero-img > wistia-player {
        display: none;
    }
    .hero-video .hero-img:after {
        height: 40%;
        width: 100%;
        right: 0;
        background: linear-gradient(180deg, var(--gravitas-grey) 20%, transparent);
    }
    .hero-video .col-md-6 {
        max-width: 100%;
        flex-basis: 80%;
    }
    .hero-video.hero-wrapper .container {
        padding-bottom: 0;
    }
}
/* For laptop text sizes */
@media (min-width: 992px) {
    h1 {
        font-size: 50px;
    }

    h2 {
        /* font-size: 40px; */
    }

    h3 {
        font-size: 36px;
    }

    h4 {
        font-size: 40px;
    }

    .subhead {
        font-size: 24px;
    }
    .navbar-expand-lg .navbar-nav .nav-link {
        padding-right: 1rem;
        padding-left: 1rem;
    }
    
}

@media (max-width: 991.98px) {
    :root {
        --section-spacing-vert: 4rem;
        --swiper-navigation-sides-offset: 5px;
    }
    .max-width-container,
    section .container {
        margin: 0;
    }
    h1 {
        font-size: 46px;
    }

    h2 {
        font-size: 36px;
    }

    h3 {
        font-size: 22px;
    }

    h4 {
        font-size: 22px;
    }

    .subhead {
        font-size: 18px;
    }

    p {
        font-size: 20px;
    }

    .flex.row {
        flex-direction: column;
        row-gap: var(--row-gutter);
    }

    .row-spotlight {
        column-gap: var(--col-gutter);
    }
    .row-spotlight .flex.row {
        width: 100%;
        flex-direction: row;
        flex-wrap: nowrap;
    }

    .row-spotlight .card-text {
        display: none;
    }

    .row-spotlight .card-img img {
        height: 80px;
        width: 80px;
        padding-right: 0;
    }

    .flex [class^="col-"] {
        padding-left: 0;
    }

    .row.stacked [class^="col-"]+[class^="col-"] {
        margin-top: 6rem;
        padding-left: 0;
    }
    .col-sm-12.col-md-8.section-intro {
        flex-basis: 100%;
        max-width: none;
    }
    .cards-white .card.col-md-3,
    .card-deck .card.col-md-3,
    .card-deck .card.col-sm-6 {
        width: calc((95% -(var(--col-gutter)* 3)) / 3);
    }
    .card-deck .card.col-md-3.swiper-slide {
        min-width: calc((100% -(var(--col-gutter)* 3)) / 3);
    }

    .columns-row.card-deck .card.col-md-3,
    .card-deck .card.col-md-3.col-sm-6,
    .card-deck .card.col-sm-6,
    .card-deck .card.col-lg-4.col-md-6  {
        width: calc((95% - var(--col-gutter)) / 2);
    }
    .card-deck .card.col-md-3.col-sm-6.swiper-slide {
        min-width: calc((100% - var(--col-gutter)) / 2);
    }

    .action-group {
        flex-direction: column;
        gap: 10px;
    }

    .card[class^="col-"] {
        max-width: none;
    }

    .cta-banner,
    .promo-box,
    .highlight-banner,
    .logo-garden-section .row > .col-lg-6 {
        flex-direction: column;
        justify-items: center;
        row-gap: var(--row-gutter);
        text-align: center;
    }

    .promo-box.bg-white {
        border-left: none;
        border-top-width: 3px;
        border-top-style: solid;
    }

    [class^="col-"].card-hor:not(.card-hor-bleed),
    .card-deck [class^="col-"].card-hor:not(.card-hor-bleed) {
        padding-left: 4%;
    }

    .card-deck [class^="col-"].card.card-hor {
        flex-direction: column;
    }

    .stats-hor .row > [class^="col-"] {
        padding-right: 0;
    }
    .customer-quote-wrapper {
        padding: 0;
    }

    .carousel-tabs .container {
        padding: 3rem 0 0;
    }

    .swiper-wrapper.col-md-6 {
        width: 100%;
    }
    .logo-garden {
        grid-template-rows: 1fr 1fr 1fr;
    }
    
    .row > .col-lg-6.col-sm-12[class^="col-"] + .col-lg-6.col-sm-12[class^="col-"]:not(.card),
    .row > .col-lg-6.col-xs-12[class^="col-"] + .col-lg-6.col-xs-12[class^="col-"]:not(.card) {
        margin-top: var(--row-gutter);
        padding-left: 0;
    }

}


@media (max-width: 768px) {
    :root {
        --row-gutter: 2rem;
        --section-spacing-vert: 3rem;
        --section-spacing-hor: 1.5rem;
    }

    h1 {
        font-size: 36px;
        margin-bottom: 1.5rem;
    }

    h2 {
        font-size: 26px;
    }

    .bg-none-mobile {
        background-image: none!important;
    }
    .intro-text,
    .section-text,
    p {
        font-size: 18px;
    }
    .hero-wrapper {
    display: flex;
    flex-direction: column-reverse;
    }
    .hero-wrapper .container {
    padding-bottom: 0;
    }
    .hero-img {
        position: relative;
    }

    .hero-img img {
        position: static;
    }
    .hero-img > .video-poster {
        filter: none;
    }
    .hero-img > wistia-player {
        display: none;
    }
    .hero-img:after {
        height: 40%;
        width: 100%;
        right: 0;
        background: linear-gradient(180deg, var(--gravitas-grey) 20%, transparent);
    }
    .hero-section .container.under-hero-promo {
        margin-top: 0;
        padding: 0;
    }
    .bg-section-circles-1,
    .bg-section-circles-2,
    .bg-section-circles-3,
    .bg-section-circles-4 {
        background-image: none;
    }
    .section-intro {
        margin-bottom: 3rem;
    }
    .card-deck:not(.swiper-wrapper) {
        flex-direction: row;
        gap: var(--row-gutter) 2rem;
    }
    .row-spotlight {
        column-gap: normal;
    }
    
    .spotlights-section>.container {
        padding-top: 2rem;
        padding-bottom: 1.75rem;
    }
    .card-deck .swiper-slide,
    .card-deck .swiper-slide.card,
    .row-spotlight .swiper-slide {
        flex-shrink: 0;
    }

    .row-spotlight .col-md-6.card-img {
        flex-basis: 40%;
        flex-shrink: 1;
    }
    .col-md-6.card-spotlight {
        max-width: 70%;
        flex-basis: 70%;
    }
    .row-spotlight .card-img {
        text-align: left;
    }
    .card-deck .card.col-md-6.col-xs-12,
    .card-deck .card.col-sm-6,
    .col-md-6.flex.flex-rows,
    .card-deck.columns-row .card.col-md-3,
    .card-deck.cards-white .card.col-md-3 {
        width: 100%;
        max-width: 100%;
        flex-basis: auto;
    }
    .card-deck.swiper-wrapper .card.col-lg-6 {
        min-width: 0;
    }
    .card-deck .card.col-md-4.swiper-slide,
    .card-deck .card.col-md-4 {
        width: calc((90% - var(--col-gutter)*2) / 2);
      }
    .columns-row .card.col-md-3.col-sm-6 {
        width: calc((95% - var(--col-gutter)) / 2);
    }
     .card-deck [class^="col-"].card.card-hor {
        width: 100%;;
    }
    .col-lg-12.card.card-hor {
        grid-auto-columns: auto auto;
    }
    .row > .col-sm-12[class^="col-"]+.col-sm-12[class^="col-"]:not(.card),
    .row > .col-xs-12[class^="col-"]+.col-xs-12[class^="col-"]:not(.card) {
        padding-left: 0;
    }
    .row > .col-sm-12[class^="col-"]+.col-sm-12[class^="col-"]:not(.card):not(.swiper-slide),
    .row > .col-xs-12[class^="col-"]+.col-xs-12[class^="col-"]:not(.card):not(.swiper-slide) {
        margin-top: var(--row-gutter);
    }

    .center-on-mobile {
        text-align: center;
        justify-items: center;
    }
    section .container {
        --section-spacing-vert: 3rem;
    }
    .stats-panel {
        position: relative;
        width: 100%;
        margin-top: 20px;
    }
    .container .row.stats-hor .container,
    .stats-row {
        flex-direction: column;
    }
    .stats-item {
        margin-bottom: 20px;
    }
    .card-deck .card,
    .flex [class^="col-"].card {
        padding: 5% 5% 8%;
    }
    .card-hor.card-hor-bleed .card-image
    .card-deck .card-hor.card-hor-bleed .card-image {
        height: 100%;
        aspect-ratio: 1 / 1;
    }
    .card-hor.card-hor-bleed .card-body,
    .card-deck .card-hor.card-hor-bleed .card-body {
        padding: 9% 9% 0 0;
    }
    .card-hor.card-hor-bleed .card-cta,
    .card-deck .card-hor.card-hor-bleed .card-cta {
        padding:  0 9% 9% 0;
    }
    .nav-tabs {
        border-top: 1px solid var(--border-color);
    }
    .nav-tabs.active > li:not(:first-of-type) {
        border-top: 1px solid var(--border-color);
    }
    .jump-nav .navbar-nav {
        width: 100%;
    }
    ul.nav.nav-tabs.tabs-top,
    .jump-nav .navbar-nav {
        /* max-height: 50px; */
        overflow: hidden;
        display: flex;
        flex-direction: column;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        transition: max-height 3s ease-in-out;
    }
    .nav-tabs > li,
    .jump-nav .navbar-nav > li {
        opacity: 0;
        visibility: hidden;
        width: 100%;
        max-height: 0;
        overflow-y: hidden;
        background: inherit;
        transition: opacity .3s ease-in-out;
        margin: 0;
        text-align: left;
        -webkit-box-shadow: 0 0 0;
        -moz-box-shadow: 0 0 0;
        box-shadow: 0 0 0;
    }

    .nav-tabs.active > li,
    .nav-tabs > li.active,
    .jump-nav .navbar-nav > li:first-of-type,
    .jump-nav .navbar-nav.active > li,
    .jump-nav .navbar-nav > li.active {
        opacity: 1;
        visibility: visible;
        max-height: none;
    }
    .jump-nav .navbar-nav>.active>a,
    .jump-nav .navbar-nav>.active>a:focus,
    .jump-nav .navbar-nav>.active>a:hover,
    .jump-nav .navbar-inverse .navbar-nav>.active>a,
    .jump-nav .navbar-inverse .navbar-nav>.active>a:focus,
    .jump-nav .navbar-inverse .navbar-nav>.active>a:hover {
        background: transparent;
    }
    .jump-nav .navbar-nav > li > a {
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
    .nav-tabs > li.active {
        background: #fff;
    }
    .nav-tabs::after,
    .jump-nav .navbar-nav::after {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 19' xml:space='preserve'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='2' d='M1.6,17.7l8-8l-8-8'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        line-height: 1;
        content: '';
        transform: rotate(90deg);
        position: absolute;
        top: 50%;
        right: .5rem;
        margin-top: -.75ex;
        width: 16px;
        height: 16px;
        -webkit-transition: transform .2s ease-in;
        -moz-transition: transform .2s ease-in;
        transition: transform .2s ease-in;
    }
    .jump-nav.navbar-inverse .navbar-nav::after {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 19' xml:space='preserve'%3E%3Cpath fill='none' stroke='%23FFFFFF' stroke-width='2' d='M1.6,17.7l8-8l-8-8'/%3E%3C/svg%3E");
    }
    .nav-tabs.active::after,
    .jump-nav .navbar-nav.active::after {
        transform: rotate(270deg);
        top: 2.75ex;
    }
    .nav-tabs.tabs-left > li:not(.active) > a:after,
    .nav-tabs.tabs-left > li.active > a:after,
    .nav-tabs.tabs-top > li > a:after,
    .nav-tabs.tabs-top > li.active > a:after {
        display: none;
    }
    .tabs-left > li {
        border-top: none;
    }
    .nav-tabs.tabs-left > li > a {
        padding: 10px 20px;
    }
    .tabs-row-vert {
        flex-direction: column;
    }
    .side-nav {
        flex-basis: 100%;
        max-width: 100%;
        border-right: none;
        margin-right: 0;
    }
    .side-nav + .tab-content {
        flex-basis: 100%;
        max-width: 100%;
        border-left: none;
    }
    .container.carousel-container {
        padding: 0;
    }
    .carousel-tabs {
        display: none;
    }
    .customer-carousel .swiper-slide {
        position: relative;
        overflow: hidden;
        padding-left: 5%;
        padding-right: 5%;
        padding-bottom: 4rem;
    }
    .customer-mobile-bg {
        position: absolute;
        top: 0;
        left: 0;
        display: block;
        width: 100%;
    }
    .customer-carousel .swiper-slide::before {
        background: var(--gravitas-grey);
    }
    .customer-mobile-bg::before {
        background: linear-gradient(0deg, var(--gravitas-grey) 2%, rgba(65, 39, 60, 0.7) 30%);
    }
    .customer-mobile-bg img {
        height: auto;
        width: 100%;
    }
    .customer-carousel .swiper-pagination {
        display: block;
        bottom: 0;
        padding-top: 1.5rem;
    }
    .customer-carousel .swiper-button-next,
    .customer-carousel .swiper-rtl .swiper-button-prev {
        display: none;
    }
        
    .customer-mobile-pagination {
        display: block;
    }
    .col-md-6.col-sm-12 {
        width: auto;
        flex-basis: auto;
        max-width: 100%;
    }
    .active .panel-img,
    .active .panel-img img {
        position: static;
    }
    .active .panel-img img {
        margin-bottom: var(--row-gutter);
    }
    .row:not(.swiper-wrapper) > li .col-md-6.col-sm-12 + .col-md-6.col-sm-12 {
        margin-top: 3rem;
        padding-left: 0;
    }
    .cta-block-dark {
        background-image: url('/wp-content/uploads/bg-footer-mobile.png');
        background-size: cover;
    }
    .cta-block-light {
        background-image: url('/wp-content/themes/checkpoint-theme-v2/images/bg/bg-footer-light-mobile.svg');
        background-position: top left;
        background-size: cover;
    }
    .lottie-anim {
        width: 100%;
        height: auto;
    }
    .card-image.icon .lottie-anim {
        width: inherit;
    }
    .icon-anim .card-image {
        aspect-ratio: 2;
    }
    .icon-anim .card-image img,
    .icon-anim .card-image canvas {
        height: 125px;
    }
    .col-lg-6 .logo-garden,
    .logo-garden {
        grid-template-columns: 1fr 1fr;
        grid-auto-flow: row;
    }
}

@media (max-width: 576px) {
    .cta-wrapper .btn-primary, 
    .cta-wrapper .btn-secondary {
        display: block;
        max-width: 100%;
        width: 90%;
    }
}

@media (max-width: 480px) {

    /* override bootstrap 4 defaults */
    .row:not(.swiper-wrapper) {
        flex-direction: column;
        row-gap: var(--row-gutter);
    }
    .tab-content-section .row {
        row-gap: 0;
    }
    .row-spotlight .swiper-slide .flex.row {
        flex-basis: 100%;
        column-gap: 2rem;
    }
    .row-spotlight .col-md-6.card-img {
        flex-basis: 40%;
        text-align: right;
    }
    .row-spotlight h3 {
        margin-bottom: 0;
    }
    .col-md-6.card-spotlight {
        flex-basis: 60%;
    }
    .row:not(.card-deck)>[class^="col-"]:not(.tab-content) {
        padding-left: 0;
        padding-right: 0;
    }
    .col-sm-6.card,
    .card-deck .card.col-sm-6,
    .card-deck .card.col-md-4,
    .card.col-md-4,
    .card-deck [class^="col-"].card.card-hor {
        width: 100%;
        padding: 2rem 2rem 3rem;
    }

    .card-hor.card-hor-bleed .card-image,
    .card-hor.card-hor-bleed .card-body,
    .card-hor.card-hor-bleed .card-cta,
    .card-deck .card-hor.card-hor-bleed .card-image,
    .card-deck .card-hor.card-hor-bleed .card-body,
    .card-deck .card-hor.card-hor-bleed .card-cta {
        padding: 0;
    }
    .card-hor .card-image {
        margin-bottom: 1.5rem;
    }
    .card-hor .card-body + .card-cta {
        align-self: flex-start;
    }
    .card-deck.columns-row .card.col-md-3.col-sm-6 {
        width: 100%;
        padding-top: 0;
        padding-left: 0;
        padding-right: 0;
    }
    .row.card-deck + .card-deck {
        margin-top: var(--row-gutter);
    }
    .card-deck:not(.swiper-wrapper),
    .card-hor {
        flex-direction: column;
    }

    .card-deck .flex-rows {
        row-gap: 6rem;
    }
    .card.card-hor {
        display: flex;
    }
    .icons-row.card-deck .card {
        text-align: center;
    }

    .icons-row .feature-icon {
        margin-left: auto;
        margin-right: auto;
    }
    .btn {
        text-wrap-mode: wrap;
    }
    .cta-block-dark {
        background-size: auto;
    }
}

/* Add placeholder image styles */
img {
    max-width: 100%;
    height: auto;
}