/*
 * Landing page (Index.aspx) styles.
 * Extracted verbatim from inline <style> blocks for browser caching.
 * See docs/landing-page-asset-extraction-plan.md
 */

        h1, .h1 {
            font-family: "Times Sans Serif";
            font-size: 50px;
            line-height: 1.3em;
            letter-spacing: .0125em;
            text-align: center;
            margin: .375em auto;
            text-transform: uppercase
        }

            h1 span {
                font-family: "Lato Bold";
                color: #ca9851
            }

        h2, .h2 {
            font-family: "Times Sans Serif";
            font-size: 30px;
            line-height: 34px;
            margin: 10px 0;
            text-align: left;
            text-transform: uppercase;
            margin-left: -2px
        }

        h3 {
            font-family: "Times Sans Serif";
            font-size: 12px;
            text-transform: uppercase;
            line-height: 15px;
            letter-spacing: 1.83px;
            text-align: left;
            width: fit-content;
            width: -moz-fit-content
        }

        .SubHeader {
            font-family: "Lato Bold";
            font-size: 14px !important;
            line-height: 17px !important;
            letter-spacing: 3.2px !important;
            text-align: left
        }

            .SubHeader sup {
                font-size: 50%;
                line-height: 0;
                vertical-align: super
            }

        .BodyText {
            font-size: 18px;
            line-height: 30px;
            letter-spacing: .68px;
            text-align: left;
            padding-top: 15px
        }

        .ButtonContainer {
            padding-top: 25px;
            text-align: center
        }

        .TopBannerContainer {
            max-width: 1920px;
            margin: 0 auto;
            margin-bottom: 55px;
            position: relative
        }

        .box_margin_no_padding a span {
            font-size: 16px;
            line-height: 19px;
            letter-spacing: 2.44px;
            padding: 0 3px 6px;
            border-bottom: 1px solid #000;
            text-transform: uppercase;
            font-family: "Lato Bold"
        }

        .box_margin_no_padding a h3 {
            font-size: 12px;
            line-height: 15px;
            letter-spacing: 1.83px;
            padding: 0 0 6px;
            border-bottom: 1px solid #000;
            text-transform: uppercase;
            font-family: "Lato Bold";
            width: fit-content;
            margin: 0
        }

        .Previous {
            transform: rotate(180deg)
        }

        .Previous, .Next {
            width: 12px
        }

        .slick-initialized .slick-slide {
            outline: none
        }

        .slick-list {
            padding-bottom: 5px
        }

        .slick-dots {
            bottom: -25px;
            z-index: 4
        }

            .slick-dots li {
                margin: 0
            }

        .BottomWeeklyBannerContainer {
            max-width: 1560px;
            margin: 0 auto
        }

        .VideoBanner {
            max-width: 50%
        }

        .dimmer {
            display: none;
            background: #000;
            opacity: .7;
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 10001
        }

        .popupLetter {
            display: none;
            width: 94%;
            max-width: 860px;
            height: 670px;
            height: fit-content;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            margin: auto;
            z-index: 10002;
            background: #fff;
            position: fixed;
            padding: 20px 70px
        }

        .popup_close {
            position: absolute;
            right: 10px;
            top: 10px;
            z-index: 1003;
            background: url(/cx/images/X_Icon.png) 0 0 no-repeat;
            display: block;
            width: 30px;
            height: 30px;
            cursor: pointer;
            font-size: 22px;
            font-weight: 700
        }

        .LetterText {
            font-size: 16px;
            line-height: 30px;
            letter-spacing: .36px;
            text-align: center
        }

        .PopLogo {
            max-width: 270px;
            padding-bottom: 15px
        }

        .Signature {
            max-width: 130px
        }

        .PaymentOptionsPop {
            display: none;
            width: 94%;
            max-width: 930px;
            height: 863px;
            height: fit-content;
            max-height: 100vh;
            overflow: auto;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            margin: auto;
            z-index: 10002;
            background: #fff;
            position: fixed
        }

        .PaymentOptionsPopCopyContainer {
            max-width: 930px;
            font-size: 18px;
            line-height: 27px;
            letter-spacing: .56px;
            padding: 25px 120px
        }

            .PaymentOptionsPopCopyContainer li {
                font-style: italic
            }

                .PaymentOptionsPopCopyContainer li span {
                    font-family: "Lato Bold"
                }

        .PaymentOptionsPopLinkContainer {
            font-family: "Lato Bold";
            font-size: 16px;
            line-height: 19px;
            letter-spacing: 2.44px
        }

            .PaymentOptionsPopLinkContainer p {
                text-align: center;
                margin: 30px 0
            }

                .PaymentOptionsPopLinkContainer p a {
                    color: #000;
                    text-decoration: none;
                    cursor: pointer
                }

                    .PaymentOptionsPopLinkContainer p a span {
                        padding-bottom: 3px;
                        border-bottom: 1px solid #000
                    }

        .btn01 {
            margin: 0;
            padding: 0;
            width: 27.6em;
            height: 3.5em;
            font-size: 10px;
            letter-spacing: .214em;
            font-family: "Lato Bold";
            text-transform: uppercase;
            border-radius: 50px !important;
            font-size: 12px;
            width: 23em;
            height: 2.916em
        }

        .whiteButton {
            background-color: #fff;
            color: #000;
            border-color: #fff
        }

        .VideoHeader {
            font-size: 25px;
            font-family: "Lato Bold";
            line-height: 32px
        }

            .VideoHeader span {
                color: #e74387
            }

        .VideoPopup {
            display: none;
            width: 90%;
            max-width: 900px;
            height: 550px;
            height: fit-content;
            padding: 40px;
            background-color: #fff;
            position: fixed;
            top: 0;
            bottom: 0;
            left: 0;
            right: 0;
            margin: auto;
            z-index: 10002
        }

        .VideoDimmer {
            display: none;
            background-color: #000;
            opacity: .7;
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 10001
        }

        .VideoPopup_close {
            position: absolute;
            right: 10px;
            top: 10px;
            background: url(/cx/images/X_Icon.png) 0 0 no-repeat;
            display: block;
            width: 30px;
            height: 30px;
            cursor: pointer;
            font-size: 22px;
            font-weight: 700
        }

        hr.grid {
            margin: 0;
            border: 1px solid #d8d8d8;
            border-bottom: none
        }

        .TriGrid {
            max-width: 1625px;
            margin: 0 auto
        }

        .GridCell {
            width: 33%;
            display: inline-block;
            vertical-align: top;
            border-right: 1px solid #d8d8d8
        }

            .GridCell:last-child {
                border-right: none
            }

        .Cell {
            max-width: 477px;
            margin: 60px auto;
            padding: 0 10px
        }

        .CellText {
            max-width: 455px;
            margin: 25px auto 0;
            text-align: left;
            min-height: 386px;
            position: relative
        }

            .CellText.Lower {
                min-height: 300px
            }

        .CellTitle {
            font-family: "Times Sans Serif";
            font-size: 25px;
            line-height: 28px;
            letter-spacing: .5px;
            text-transform: uppercase
        }

        .CellTextBody {
            font-size: 18px;
            line-height: 30px;
            letter-spacing: .68px;
            min-height: 5em
        }

        .CellButton {
            padding-top: 20px;
            text-align: center;
            position: absolute;
            bottom: 0
        }

            .CellButton a {
                text-decoration: none;
                color: #000
            }

        @media(max-width:1507px) {
            .TriGrid {
                max-width: 1005px
            }
        }

        @media(max-width:1079px) {
            .TriGrid {
                max-width: 502px;
                padding-bottom: 10px
            }

            .GridCell {
                width: 100%;
                display: block;
                border-right: none
            }

            .Cell {
                margin: 25px auto
            }

            .CellTitle {
                letter-spacing: .42px
            }

            .CellText {
                min-height: unset;
                padding: 0 30px
            }

            .CellTextBody {
                font-size: 14px;
                line-height: 23px
            }

            .CellButton {
                position: relative;
                bottom: unset;
                padding-top: 25px
            }
        }

        .LoyaltyBannerContainer {
            max-width: 1560px;
            margin: 0 auto;
            position: relative;
            color: #000
        }

        .LoyaltyBannerCopy, .PaymentBannerCopy {
            position: absolute;
            transform: translate(-50%,-50%);
            top: 50%;
            left: 30%;
            width: 23%
        }

            .LoyaltyBannerCopy .SubHeader, .PaymentBannerCopy .SubHeader {
                font-size: .897vw !important;
                line-height: 2.143em !important;
                letter-spacing: .229em !important
            }

            .LoyaltyBannerCopy h2, .PaymentBannerCopy h2 {
                font-size: 1.923vw;
                line-height: 1.133em;
                letter-spacing: normal;
                margin: 0
            }

            .LoyaltyBannerCopy .BodyText, .PaymentBannerCopy .BodyText {
                font-size: 1.154vw;
                line-height: 1.667em;
                letter-spacing: .056em;
                padding-top: 0;
                padding-bottom: 1em
            }

            .LoyaltyBannerCopy h3, .PaymentBannerCopy h3 {
                font-size: .769vw !important;
                line-height: 1.188em !important;
                letter-spacing: .153em !important;
                padding-bottom: .188em !important
            }

        .PaymentBannerCopy {
            left: 75%;
            width: 25%
        }

        @media(min-width:1560px) {
            .LoyaltyBannerCopy .SubHeader, .PaymentBannerCopy .SubHeader {
                font-size: 14px !important
            }

            .LoyaltyBannerCopy h2, .PaymentBannerCopy h2 {
                font-size: 30px
            }

            .LoyaltyBannerCopy .BodyText, .PaymentBannerCopy .BodyText {
                font-size: 18px
            }

            .LoyaltyBannerCopy h3, .PaymentBannerCopy h3 {
                font-size: 12px !important
            }
        }

        @media(max-width:768px) {
            .LoyaltyBannerCopy, .PaymentBannerCopy {
                position: unset;
                transform: none;
                top: unset;
                left: unset;
                width: auto;
                background-color: #f5f5f5;
                padding: 35px 25px;
                margin-top: -4px
            }

                .LoyaltyBannerCopy .SubHeader, .PaymentBannerCopy .SubHeader {
                    font-size: 10px !important
                }

                .LoyaltyBannerCopy h2, .PaymentBannerCopy h2 {
                    font-size: 30px;
                    margin-bottom: 12px
                }

                .LoyaltyBannerCopy .BodyText, .PaymentBannerCopy .BodyText {
                    font-size: 14px;
                    line-height: 21px;
                    letter-spacing: .44px;
                    padding-bottom: 25px
                }

                .LoyaltyBannerCopy h3, .PaymentBannerCopy h3 {
                    font-size: 10px !important
                }
        }

        .FeaturedProductsContainer .BodyText {
            max-width: 655px;
            margin: 0 auto;
            text-align: center
        }

        .FeaturedProducts {
            max-width: 1080px;
            margin: 30px auto
        }

        .ProductCard {
            max-width: 300px;
            padding: 0 30px;
            display: inline-block;
            position: relative
        }

            .ProductCard img {
                max-width: 300px
            }

        .ProductText {
            font-size: 18px;
            line-height: 26px;
            letter-spacing: 1.96px;
            text-align: center;
            width: 100%;
            max-width: 300px;
            margin: 0 auto;
            padding-top: 10px;
            padding-bottom: 5px
        }

        sup {
            position: initial !important
        }

        .ProductText .SpecialText {
            font-family: "Lato Bold";
            font-size: 13px;
            line-height: 16px;
            letter-spacing: 1.63px;
            text-align: center;
            color: #01839b
        }

        .ProductText a {
            text-decoration: none;
            color: #000
        }

        .slick-prev, .slick-next {
            top: unset;
            bottom: -34px;
            z-index: 5
        }

        .slick-next {
            left: calc(50% + 44px)
        }

        .slick-prev {
            left: calc(50% - 56px);
            bottom: -24px
        }

        .LeftImageTable, .RightImageTable {
            max-width: 1355px;
            margin: 70px auto
        }

            .LeftImageTable td, .RightImageTable td {
                width: 50%
            }

                .LeftImageTable td:nth-child(2) {
                    padding-left: 100px
                }

                .RightImageTable td:first-child {
                    padding-right: 100px
                }

                .LeftImageTable td div div, .RightImageTable td div div {
                    font-size: 18px;
                    line-height: 30px;
                    letter-spacing: .68px
                }

        @media(min-width:1254px) {
            .RightImageTable td:last-child {
                display: none
            }
        }

        @media(max-width:1253px) {
            .LeftImageTable, .RightImageTable {
                max-width: 728px;
                margin: 60px auto;
                display: block;
                border-spacing: 0
            }

                .LeftImageTable tr, .RightImageTable tr {
                    display: block
                }

                .LeftImageTable td, .RightImageTable td {
                    display: block;
                    width: unset;
                    padding: 0
                }

                    .LeftImageTable td:nth-child(2) {
                        padding-left: 0
                    }

                    .RightImageTable td:first-child {
                        display: none;
                        padding-right: 0
                    }

                    .LeftImageTable td:last-child, .RightImageTable td:last-child {
                        padding: 0 25px
                    }

                    .LeftImageTable td div div, .RightImageTable td div div {
                        font-size: 20px;
                        line-height: 30px;
                        letter-spacing: .5px
                    }

                    .LeftImageTable td div .SubHeader, .RightImageTable td div .SubHeader {
                        padding-top: 25px
                    }
        }

        @media(min-width:769px) {
            .mobileHomeOnly {
                display: none !important
            }

            .verticalLines {
                border-left: 2px solid #ebebeb;
                border-right: 2px solid #ebebeb
            }

            .mobileLine {
                display: none !important
            }
        }

        @media(max-width:1159px) {
            .FeaturedProducts {
                max-width: 720px;
                overflow-x: unset
            }

            .ProductCard {
                max-width: unset
            }
        }

        @media(max-width:799px) {
            .FeaturedProducts {
                max-width: 300px
            }

            .ProductCard {
                padding: 0
            }
        }

        @media(max-width:768px) {
            .DesktopHomeOnly {
                display: none !important
            }

            h1, .h1 {
                font-family: "Times Sans Serif";
                font-size: 32px;
                line-height: 37px;
                letter-spacing: .32px;
                text-align: center;
                margin: 36px auto
            }

            h2, .h2 {
                font-size: 30px;
                letter-spacing: normal;
                line-height: 33px
            }

            h3, .box_margin_no_padding a h3 {
                font-size: 10px;
                line-height: 12px;
                letter-spacing: 1.25px
            }

            .DesktopHomeOnly {
                display: none !important
            }

            .mobileLine {
                border: 1px solid #979797;
                margin: 30px auto !important;
                max-width: calc(100% - 45px)
            }

            .slick-dotted.slick-slider {
                margin-bottom: 45px
            }

            .BottomWeeklyBannerContainer {
                margin-bottom: 12px
            }

            .VideoBanner {
                max-width: 100%
            }

            .BodyText {
                font-size: 14px;
                line-height: 25px;
                letter-spacing: .5px
            }

            .FeaturedProductsContainer .BodyText {
                text-align: center;
                padding: 5px 10px 0
            }

            .FeaturedProducts {
                margin: 15px auto 25px
            }

            .CellText .SubHeader {
                font-size: 10px !important;
                letter-spacing: 1.21px;
                padding-bottom: 0
            }

            .LeftImageTable td div .SubHeader, .RightImageTable td div .SubHeader {
                font-size: 12px !important;
                letter-spacing: 1.53px;
                padding-bottom: 0
            }

            .popupLetter {
                height: 84vh;
                max-height: 730px;
                width: 85%;
                padding: 10px;
                overflow-y: scroll
            }

                .popupLetter::-webkit-scrollbar {
                    width: 12px !important;
                    -webkit-overflow-scrolling: Auto
                }

                .popupLetter::-webkit-scrollbar-track {
                    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3) !important
                }

                .popupLetter::-webkit-scrollbar-thumb {
                    background: #a4a4a4 !important
                }

                    .popupLetter::-webkit-scrollbar-thumb:window-inactive {
                        background: #a4a4a4 !important
                    }

            .PaymentOptionsPop {
                display: none;
                width: 100%;
                max-width: 400px;
                height: auto;
                height: fit-content;
                max-height: 100vh;
                overflow: auto;
                padding: 0
            }

            .PaymentOptionsPopCopyContainer {
                width: calc(100% - 56px);
                margin: 0 auto;
                font-size: 14px;
                line-height: 20px;
                letter-spacing: .5px;
                padding: 0
            }

            .PaymentOptionsImage {
                max-width: 50% !important
            }

            .PaymentOptionsPopLinkContainer {
                font-size: 12px;
                line-height: 15px;
                letter-spacing: 1.83px
            }

            .popup_close {
                right: 0;
                background-size: 15px
            }

            .LetterText {
                font-size: 14px;
                line-height: 30px;
                letter-spacing: .32px
            }

            .PopLogo {
                max-width: 200px
            }

            .Signature {
                max-width: 147px
            }

            .LeftImageTable td div div, .RightImageTable td div div {
                font-size: 14px;
                line-height: 22px;
                letter-spacing: .5px
            }

            .RetailTopSection {
                margin-top: 0
            }

            .VideoHeader {
                font-size: 20px;
                line-height: 28px;
                padding-bottom: 10px
            }

            .VideoPopup {
                display: none;
                width: 100%;
                max-width: 600px;
                padding: 30px 0
            }

            .VideoPopup_close {
                right: 0;
                background-size: 15px
            }
        }

        @media(max-width:585px) {
            .box_margin_no_padding a span {
                font-size: 12px;
                line-height: 15px;
                letter-spacing: 1.83px;
                padding: 0 2px 3px
            }

            .slick-next.FeaturedProductsArrow {
                left: calc(50% + 64px)
            }

            .slick-prev.FeaturedProductsArrow {
                left: calc(50% - 76px)
            }

            .Cell {
                padding: 0;
                margin: 0 auto
            }
        }

        #TopBannerPrevArrow, #TopBannerNextArrow {
            width: 18px;
            height: auto;
            padding: 12px 11px;
            border-radius: 6px;
            transform: translate(0,-50%);
            top: 50%;
            background-color: #444;
            opacity: 0.8;
        }

        #TopBannerPrevArrow {
            transform: translate(0, -50%) rotate(180deg);
            left: 0;
        }

        #TopBannerNextArrow {
            left: unset;
            right: 0;
        }

        .FancyFont {
            font-family: 'Collection';
        }

        .FeaturedProducts .btn01, .LoyaltyBannerContainer .btn01, .PaymentBannerCopy .btn01 {
            width: 16em;
        }

        .FeaturedProducts .btn01 {
            margin-top: 1em;
        }

        .TrainingVideo {
            width: 100%;
        }

        @media(max-width: 768px) {
            #TopBannerPrevArrow, #TopBannerNextArrow {
                width: 13px;
            }

            .trustpilotBannerWidget {
                width: 200px;
                margin: 0 auto;
            }

            .TrainingVideo {
                width: 100%;
            }
        }
