@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&display=swap');





html, body {
    font-family: 'Nunito', sans-serif;
    background-color: #00CDDD;
    overflow-x: hidden;
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: #0071c1;
}

.text-right {
    text-align: right!important;
}

.w-15 {
    width: 15% !important;
}

.reports-select {
    min-height: 200px;
    overflow-y: hidden;
}

#fileuploadbtn {
    cursor: pointer;
}

.cursor-pointer {
    cursor: pointer;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.authorizing-height {
    height: 75vh!important;
}

.sub-nav.collapse {
    display: none !important;
}

.sub-nav.collapse.show {
    display: block!important;
}

.sub-nav div {
    padding-top: 0!important;
}

.ml-20 {
    margin-left: 20px;
}

.font-nunito {
    font-family: 'Nunito', sans-serif;
}

.admin-nav-item {
    font-size: 16px!important;
}

    .admin-nav-item .nav-link {
        cursor: pointer;
    }

.admin-nav-item a {
    line-height: 18px !important;
}

    .admin-nav-item img {
        width: 10%;
        margin-right: 15px;
    }

.admin-nav-item span.fa {
    font-size: 25px !important;
    margin-right: 15px !important;
}

.admin-nav-item span.fa-comment, .admin-nav-item span.fa-folder {
    font-size: 22px !important;
    margin-right: 10px !important;
}

.admin-nav-item span.fa-home, .admin-nav-item span.fa-shopping-cart {
    font-size: 20px !important;
    margin-right: 10px !important;
}

.admin-nav-item span.fa-bar-chart, .admin-nav-item span.fa-cog {
    font-size: 16px !important;
}

.admin-nav-item span.fa-cogs {
    font-size: 20px !important;
    margin-right: 10px !important;
}

.admin-nav-item span.fa-gift {
    font-size: 20px !important;
    margin-right: 15px !important;
}

.admin-content .custom-text-area {
    min-height: 450px;
    max-height: 450px;
}

.admin-content .custom-text-area-small {
    min-height: 200px;
    max-height: 200px;
}

.font-helvetica {
    font-family: 'Helvetica', 'Arial', sans-serif;
}

.font-montserrat {
    font-family: 'Montserrat', sans-serif;
}

.footer-image {
    width: 376px;
}

table {
    font-family: 'Helvetica', 'Arial', sans-serif;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 20vh auto 1rem auto;
}

    .loading-progress circle {
        fill: none;
        stroke: #e0e0e0;
        stroke-width: 0.6rem;
        transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

        .loading-progress circle:last-child {
            stroke: #1b6ec2;
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    inset: calc(20vh + 3.25rem) 0 auto 0.2rem;
}

    .loading-progress-text:after {
        content: var(--blazor-load-percentage-text, "Loading");
    }


.navbar .nav-logo {
    max-width: 67px;
}

.navbar-dark {
    background-color: #14879F !important;
}


.sign-in-header {
    background-color: #14879F;
    height: 50px;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: baseline;
}

    .sign-in-header img {
        padding-top: 10px;
    }

.sign-in-con {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100vh;
    padding-top: 140px;
}

.sign-in-body {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

    .sign-in-body h2 {
        color: #FFF;
        text-transform: uppercase;
        font-size: 2.5rem;
        margin: 0;
        letter-spacing: 2px;
        font-weight: bold;
    }

        .sign-in-body h2:after {
            content: "";
            height: 1px;
            background-color: #FFF;
            width: 100%;
            display: block;
        }

    .sign-in-body p:first-of-type {
        margin-top: 10px;
    }

    .sign-in-body p {
        color: #FFF;
        margin: 2px 0;
        font-size: 21px;
        line-height: 1;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

        .sign-in-body p strong {
            font-size: 22px;
            line-height: 1;
        }

.sign-in-form {
    display: flex;
    flex-direction: column;
}

.sign-in-form:first-child {
    width: 15%;
}

.admin-page .sign-in-field {
    text-align: unset;
}

.admin-page .checkmark {
    top: 27px;
    color: #0a697d;
}

.admin-page .checkmark::after {
    background-color: #0a697d!important;
}

.admin-page h3 {
    font-weight: bold;
}

.admin-page .chosen-choices, .admin-page .chosen-results {
    min-width: 400px;
    background-color: #FFF;
}

.filter-field {
    display: flex;
    flex-direction: column;
    justify-content: end;
    text-align: left;
}

    .filter-field label {
        padding-bottom: 5px;
        padding-top: 20px;
        font-weight: bold;
        font-size: 18px;
        color: #0a697d;
    }

.filter-field input {
    padding: 10px;
    border-radius: 5px;
    border: 1px solid #0a697d;
    font-size: 18px;
    max-height: 37px;
    font-family: 'Helvetica', 'Arial', sans-serif;
}

.filter-field select {
    border-top: none;
    border-left: none;
    border-right: none;
    padding: 5px 0;
    outline: none;
}

.sign-in-field {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
}

    .sign-in-field label {
        padding-bottom: 5px;
        padding-top: 20px;
        font-weight: bold;
        font-size: 25px;
        color: #0a697d;
    }

    .sign-in-field .password-con {
        position: relative;
    }

        .sign-in-field .password-con i {
            position: absolute;
            right: 12%;
            bottom: 10px;
            color: #B7B7B7;
            opacity: 0.6;
            cursor: pointer;
        }

    .sign-in-field input {
        padding: 10px;
        border-radius: 5px;
        border: 1px solid #0a697d;
        font-size: 18px;
        max-height: 37px;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

    .sign-in-field select {
        border-radius: 5px;
        border: 1px solid #0a697d;
        font-size: 18px;
        max-height: 37px;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

        .sign-in-field input::placeholder {
            color: #707070;
            opacity: 0.5;
        }

.sign-in-form a {
    color: #0a697d;
    padding-top: 20px;
    text-decoration: underline;
    text-align: center;
    padding-bottom: 20px;
}

.sign-in-form input[type='submit'] {
    background-color: #0B697D;
    border-radius: 5px;
    color: #FFF;
    padding: 5px;
    outline: none;
    border: none;
    font-size: 22px;
    width: 80%;
    margin: 0 auto;
    box-shadow: rgba(000,000,000,0.16) 0 -3px 6px inset;
    margin-top: 35px;
}

.sign-in-footer {
    height: 50px;
    width: 100%;
    background-color: #14879F;
}

.home-header {
    /*width: 58%;*/
    display: flex;
    justify-content: flex-end;
    align-items: baseline;
}

    .home-header img {
        /*padding-top: 10px;*/
        width: 75px;
    }

.page {
    min-height: 100vh;
}

.admin-page {
    background-color: #FFF;
    min-height: 100vh;
}


.home-body {
    display: flex;
    flex-direction: column;
    /*    justify-content: center;*/
    align-items: center;
    min-height: 85vh;
}

    .home-body h2 {
        color: #FFF;
        text-transform: uppercase;
        font-size: 2.5rem;
        margin: 10px;
        letter-spacing: 2px;
        text-align: center;
        font-weight: bold;
        font-family: 'Montserrat', sans-serif;
    }

        .home-body h2:after {
            content: "";
            height: 2px;
            background-color: #FFF;
            width: 50%;
            display: block;
            margin: 10px auto;
        }

.sign-in-con h2:after {
    width: 90%;
    margin-top: 10px;
}

.home-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 40px;
}

    .home-links a {
        padding: 5px;
        color: #FFF;
        text-align: center;
        width: 33%;
        text-decoration: none;
        font-weight: bold;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: space-between;
        font-size: 15px;
        line-height: 1.2;
        margin-bottom: 10px;
        margin-top: 10px;
        height: 100px;
    }

        .home-links a span:last-of-type {
            height: 38px;
            display: flex;
            flex-direction: column;
            justify-content: flex-start;
            font-family: 'Lato', sans-serif;
        }

        .home-links a img {
            max-width: 40px;
            max-height: 40px;
        }

        .home-links a small {
            font-size: 10px;
            white-space: nowrap;
            text-align: center;
            display: block;
        }

    .home-links .home-links-icons {
        width: 50px;
        height: 50px;
        display: flex;
        justify-content: center;
        margin-bottom: 10px;
    }

.home-footer {
    height: 50px;
    width: 100%;
    background-color: #0a697d;
}


.nav-item {
    padding: 0px !important;
}

    .nav-item .nav-link {
        padding: 0 !important;
        color: #0a697d !important;
        height: 2rem !important;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

        .nav-item .nav-link img {
            width: 20px !important;
            height: 20px !important;
            margin-right: 10px;
        }

.engagement-reports .nav-link {
    color: #14879F !important;
    font-weight: 600;
    padding: 10px !important;
    height: 3rem !important;
    cursor: pointer;
}


.title-header {
    background-color: #00CDDD;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
}

    .title-header p {
        color: #FFF;
        text-transform: uppercase;
        font-weight: bold;
        font-size: 25px;
        /*letter-spacing: 2px;*/
        text-align: center;
        margin: 0;
        font-family: 'Montserrat', sans-serif;
    }

    .title-header .left, .title-header .right {
        flex: 1;
        padding-left: 10px;
        display: block;
        line-height: 49px;
    }

.page-content {
    background-color: #FFF;
}

.nav-section {
    width: 33%;
}

    .nav-section:nth-of-type(2) {
        display: flex;
        justify-content: center;
    }

        .nav-section:nth-of-type(2) img {
            width: 40px;
        }

.offcanvas-start {
    width: 75vw;
}

.offcanvas-header {
    padding-bottom: 0;
}

.offcanvas-body {
    padding-top: 0 !important;
}

article.content {
    width: 100%;
    padding: 0 !important;
}

article.admin-content {
    width: 100%;
    min-height: 100vh;
    font-family: 'Lato', sans-serif;
}

.admin-content .ck-editor {
    max-height: 500px;
}

.admin-content textarea {
    max-height: 450px !important;
    overflow-y: scroll !important;
}

.admin-content .ck-content {
    max-height: 450px !important;
    overflow-y: scroll !important;
}

.app-iframe {
    width: 400px;
    height: 728px;
    border: 1px solid black;
}

.admin-content .current-event {
    color: #FEC907;
    margin-left: 10px;
}

.ck-source-editing-area {
    max-height: 450px !important;
}

.smile-video {
    margin: 0 auto;
    width: 100%;
    max-height: 500px;
    height: 211px;
}

.page-content h3 {
    padding: 30px 15px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
}

.page-content {
    min-height: 82vh;
}

.smile-copy {
    background-color: #e9f8fb;
    padding: 20px;
    border-top: 20px solid #00CDDD;
    border-bottom: 20px solid #00CDDD;
    margin-top: -10px;
}

    .smile-copy p {
        padding: 10px 15px;
        text-align: center;
        font-size: 16px;
        font-weight: bold;
        margin-bottom: 0;
    }

.mystar {
    background: url(../img/star-rewards.svg) no-repeat;
    height: 100px;
    width: 100px;
    margin: auto;
    background-size: contain;
    position: relative;
}

    .mystar p {
        position: absolute;
        top: 45%;
        left: 37px;
        font-weight: bold;
        font-size: 20px;
    }

.border-blue {
    background-color: #00CDDD;
    height: 5px !important;
    opacity: 1;
}

#starInfo .modal-body {
    text-align: center;
}

    #starInfo .modal-body span {
        text-transform: uppercase;
        color: #00CDDD;
        font-weight: bold;
    }

#starInfo .modal-header {
    text-align: right;
    justify-content: flex-end;
    font-weight: bold;
    font-size: 20px;
    border: none;
    padding: 0 1rem;
}

.enter-code-btn {
    background-color: #00CDDD;
    color: #FFF;
    padding: 8px;
    display: block;
    text-decoration: none;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

    .enter-code-btn span {
        position: absolute;
        right: 10px;
    }

.event-info-con p {
    margin-bottom: 1px;
    font-size: 14px;
}

.invite-links {
    background-color: #14879F;
    padding: 5px;
    display: flex;
    justify-content: center;
}

    .invite-links a {
        padding: 5px;
        background-color: #00CDDD;
        box-shadow: rgba(000,000,000,0.16) 0 -3px 6px inset;
        border-radius: 5px;
        padding: 5px;
        margin: 10px;
        color: #FFF !important;
        width: 43%;
        text-align: center;
        font-weight: bold;
        font-family: 'Lato', sans-serif;
    }

.text-lightblue {
    color: #00CDDD;
}

.enter-code {
    background-color: rgba(79,201,218, 0.13);
    border: 1px solid #00CDDD;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

    .enter-code input {
        width: 90%;
        border-radius: 5px;
        padding: 5px;
        text-align: center;
        border: 1px solid #000;
    }

    .enter-code a {
        padding: 5px;
        background-color: #FEC907;
        box-shadow: rgba(000,000,000,0.16) 0 -3px 6px inset;
        border-radius: 5px;
        padding: 5px;
        margin: 10px;
        color: #FFF !important;
        width: 40%;
        text-align: center;
        font-weight: bold;
    }

.btn-yellow {
    padding: 5px;
    background-color: #FEC907;
    box-shadow: rgba(000,000,000,0.16) 0 -3px 6px inset;
    border-radius: 5px;
    padding: 5px;
    margin: 10px;
    color: #FFF !important;
    text-align: center;
    font-weight: bold;
    text-decoration: none;
}


.recipe-image {
    position: relative;
}

.thumbs-up {
    background-color: #00CDDD;
    padding: 5px;
    border-radius: 0 0 5px 0;
    position: absolute;
    width: 40px;
    height: 40px;
    text-align: center;
}

a.added-btn {
    background-color: #6DCE9A !important;
    color: #FFF !important;
}

.recipe-checkout a:not(.added-btn) {
    color: #000 !important;
    border: 1px solid #000;
}

.congrats-container .swal2-modal {
    background: #FFF url(../img/modal_bg.png) !important;
}


.swal2-confirm {
    background-color: #FEC907 !important;
    padding-top: 5px !important;
    padding-bottom: 5px !important;
    box-shadow: rgba(000,000,000,0.16) 0 -3px 6px inset !important;
}

    .swal2-confirm em {
        background: inherit !important;
    }

.swal2-cancel {
    padding-top: 5px !important;
    padding-bottom: 5px !important;
    box-shadow: rgba(000,000,000,0.16) 0 -3px 6px inset !important;
}

.swal2-modal *:not(button):not(.swal2-icon) {
    background-color: #FFF;
    margin-top: 0 !important;
}

.accordion-button {
    color: #14879F !important;
    font-weight: bold;
    background-color: #E8F8FA !important;
}

.input-text-con {
    display: flex;
    flex-direction: column;
    text-align: left;
    margin-bottom: 15px;
}

    .input-text-con label {
        color: black;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

    .input-text-con input, .input-text-con input:focus-visible {
        border-top: none;
        border-left: none;
        border-right: none;
        padding: 5px 0;
        outline: none;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

    .input-text-con select {
        border-top: none;
        border-left: none;
        border-right: none;
        padding: 5px 0;
        outline: none;
    }

    .input-text-con input::placeholder {
        color: #707070;
        opacity: 0.6;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }



.btn-blue {
    padding: 5px;
    background-color: #0B697D;
    /*background: #0B697D 0% 0% no-repeat padding-box;*/
    box-shadow: inset 0px -3px 6px #00000029;
    border-radius: 5px;
    padding: 5px 15px;
    margin: 10px 0;
    color: #FFF !important;
    text-align: center;
    text-decoration: none;
    font-family: 'Lato', sans-serif;
    font-size: 25px;
    cursor: pointer;
    border: none;
}

.btn-red {
    padding: 5px;
    background-color: #7F1832;
    /*background: #7F1832 0% 0% no-repeat padding-box;*/
    box-shadow: inset 0px -3px 6px #00000029;
    border-radius: 5px;
    padding: 5px 15px;
    margin: 10px 0;
    color: #FFF !important;
    text-align: center;
    text-decoration: none;
    font-family: 'Lato', sans-serif;
    font-size: 25px;
    cursor: pointer;
    border: none;
}

.prize-pref img {
    width: 75px;
}

.radio-con input[type=radio] {
    border-radius: 2px;
}

.signup-form {
    background-color: #91EAF4;
    border-radius: 10px;
    padding: 20px 30px;
    max-width: 852px;
}


    .signup-form label {
        font-family: 'Nunito', sans-serif;
        font-weight: bold;
    }

    .signup-form input {
        width: 80%;
        margin: auto;
    }

        .signup-form input::placeholder {
            opacity: 0.5;
        }

    .signup-form select {
        width: 80%;
        margin: auto;
        padding-right: 2rem;
        background: url('data:image/svg+xml;utf8,<svg fill="%23555" height="10" viewBox="0 0 20 20" width="10" xmlns="http://www.w3.org/2000/svg"><polygon points="0,0 20,0 10,10"/></svg>') no-repeat right 0.5rem center;
        background-color: rgb(255, 255, 255)!important;
        background-size: 0.65rem auto;
    }

    .signup-form button {
        font-size: 23px;
        padding: 0 15px;
    }

.questionsSignup {
    font-size: 20px;
    font-family: 'Helvetica', 'Arial', sans-serif;
}


    .questionsSignup a {
        color: #1A59B8 !important;
    }

.signup-form .form-submit button {
    margin-top: 35px;
    margin-bottom: 15px;
    font-size: 23px;
}

/* Customize the label (the container) */
.radio-con {
    display: block;
    position: relative;
    padding-left: 29px;
    margin-bottom: 12px;
    cursor: pointer;
    font-size: 15px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    text-align: left;
}

    /* Hide the browser's default checkbox */
    .radio-con input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
        height: 0;
        width: 0;
    }

/* Create a custom checkbox */
.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 20px;
    width: 20px;
    border: 1px solid #000;
    border-radius: 5px;
}

/* On mouse-over, add a grey background color */
.radio-con:hover input ~ .checkmark {
    background-color: #FFF;
}

/* When the checkbox is checked, add a blue background */
.radio-con input:checked ~ .checkmark {
    background-color: #FFF;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

/* Show the checkmark when checked */
.radio-con input:checked ~ .checkmark:after {
    display: block;
}

/* Style the checkmark/indicator */
.radio-con .checkmark:after {
    width: 14px;
    height: 14px;
    background-color: #000;
    border-radius: 3px;
    top: 2px;
    left: 2px;
}

.recipe-scale {
    display: flex;
    justify-content: space-between;
    text-align: left;
    align-items: flex-start;
}

    .recipe-scale select {
        width: 75px;
        border-radius: 5px;
        text-align: center;
    }

.radio-con p {
    margin-top: -5px;
}

.header-row {
    border-bottom: 3px solid #00CDDD;
}

.close-btn-swal {
    position: absolute;
    color: #000 !important;
    outline: none;
    -webkit-tap-highlight-color: transparent !important;
}

#upload {
    display: none;
}

.monthly-hes {
    display: flex;
    flex-direction: column;
    border: 3px solid #00CDDD;
    border-radius: 5px;
    margin: 10px auto;
    width: 90%;
    align-items: center;
}

    .monthly-hes h3 {
        font-size: 25px;
        padding: 10px;
    }

    .monthly-hes .hes-score {
        color: #499C25;
        border: 5px solid #499C25;
        height: 100px;
        width: 100px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

        .monthly-hes .hes-score p {
            margin-bottom: 0;
            font-weight: bold;
            font-size: 2.5rem;
        }


.score-info {
    border-top: 1px solid #000;
    display: flex;
    width: 90%;
    margin: 15px auto;
    justify-content: space-between;
}

    .score-info .score {
        width: 28%;
        display: flex;
        flex-direction: column;
        align-items: center;
        margin-top: 20px;
    }

        .score-info .score:nth-of-type(2) {
            width: 44% !important;
        }

    .score-info p:first-of-type {
        width: 70px;
        height: 70px;
        border: 4px solid;
        border-radius: 50%;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        line-height: 1;
    }

    .score-info p.beneficial-score {
        color: #499C25;
        border-color: #499C25;
    }

    .score-info p.improvement-score {
        color: #FEC907;
        border-color: #FEC907;
    }

    .score-info p.subpar-score {
        color: #AB1919;
        border-color: #AB1919;
    }

    .score-info p:last-of-type {
        font-size: 14px;
        margin-bottom: 0;
    }

.average-scores {
    display: flex;
    flex-wrap: wrap;
    padding-bottom: 50px;
}

    .average-scores h3 {
        font-size: 25px;
        padding: 10px;
        width: 100%;
    }

    .average-scores .average-score {
        width: 25%;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

        .average-scores .average-score p:first-of-type {
            width: 60px;
            height: 60px;
            border: #499C25 4px solid;
            border-radius: 50%;
            display: flex;
            justify-content: center;
            align-items: center;
            text-align: center;
            line-height: 1;
            color: #499C25;
            font-size: 25px;
            margin-bottom: 10px;
        }

        .average-scores .average-score p:last-of-type {
            text-align: center;
            font-size: 14px;
            line-height: 1.2;
        }


.Portionlink {
    display: flex;
    color: #000;
    text-decoration: none;
    font-weight: bold;
    align-items: center;
    font-size: 22px;
    justify-content: space-between;
    padding: 15px;
    width: 90%;
    margin: auto;
    font-family: 'Montserrat', sans-serif;
}

    .Portionlink .fas {
        /*margin-right: auto;*/
    }

.portions p {
    margin-bottom: 2px;
}

.portions table {
    font-size: 13px;
}

.quiz-con {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

    .quiz-con a {
        text-align: center;
        width: 40%;
        display: flex;
        flex-direction: column;
        padding: 10px;
    }

        .quiz-con a img {
            display: block;
        }

.recipe-info-con {
    border: 5px solid #00CDDD;
    border-radius: 5px;
    background-color: #00CDDD;
}

.recipe-info {
    margin-bottom: 0;
}

    .recipe-info tr td, .recipe-info tr th {
        padding: 5px 25px !important;
        font-weight: normal !important;
    }

.nutrition-info td:nth-of-type(2) {
    text-align: right;
}

.blue-header, .blue-header th {
    background-color: #00CDDD !important;
    color: #FFF;
    padding-top: 2px;
    padding-bottom: 2px;
}

.recipe-ingredients th tr:nth-of-type(2) {
    text-align: center;
}

.recipe-ingredient td:nth-of-type(2) {
    text-align: center;
}

.blue-striped.table-striped > tbody > tr:nth-child(even) > td,
.blue-striped.table-striped > tbody > tr:nth-child(even) > th {
    background-color: #E8F8FA;
}

.blue-striped.table-striped > tbody > tr:nth-child(odd) > td,
.blue-striped.table-striped > tbody > tr:nth-child(odd) > th {
    background-color: #FFF;
    box-shadow: none;
}

.serves {
    border-top: 5px solid #00CDDD !important;
    border-bottom: 5px solid #00CDDD !important;
}

.recipe-ingredients {
    margin-bottom: 0;
}

.recipe-info-con p {
    color: #FFF;
    text-align: center;
    font-weight: bold;
    font-size: 18px;
    margin-bottom: 5px;
}

.recipe-reference {
    margin-bottom: 0;
}

.recipe-reference-con {
    background-color: #FFF;
    border-radius: 5px;
    padding: 5px;
}

.recipe-reference tr td {
    padding: 0;
    text-align: center;
}

.recipe-directions li {
    padding-bottom: 10px;
}


.recipe-search-con {
    display: flex;
    align-items: center;
    justify-content: center;
}

.recipe-search {
    width: 80%;
    position: relative;
}

    .recipe-search input {
        width: 100%;
        border: 1px solid #00CDDD;
        border-radius: 5px;
        padding-left: 30px;
        outline: none;
        padding-right: 30px;
    }

        .recipe-search input::placeholder {
            opacity: 0.5;
        }

    .recipe-search i {
        position: absolute;
        color: #00CDDD;
        top: 5px;
        left: 5px;
    }

    .recipe-search img {
        position: absolute;
        color: #00CDDD;
        top: 5px;
        right: 5px;
    }

.recipe-item {
    background-color: #E8F8FA;
    border: 1px solid #000;
    border-radius: 5px;
    padding: 10px;
}

.recipe-item-info .recipe-item-info-title {
    border: 1px solid #000;
    border-radius: 5px;
    background-color: #FFF;
    text-align: center;
    line-height: 1.2;
    font-size: 15px;
    margin-bottom: 5px;
    min-height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.recipe-item-info a {
    box-shadow: rgba(000,000,000,0.16) 0 -3px 6px inset;
    border: 1px solid #000;
    border-radius: 5px;
    padding: 2px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 2px;
    font-family: 'Lato', sans-serif;
}

    .recipe-item-info a:has(img) {
        background-color: #00CDDD;
        max-width: 35px;
        max-height: 35px;
        box-shadow: none;
    }


.top-row {
    background-color: #14879F !important;
    border: none !important;
    justify-content: center !important;
    position: relative;
    height: 5rem !important;
}

    .top-row img {
        max-width: 175px;
        margin-top: 9rem;
    }

.admin-top-row {
    background-color: #14879F !important;
    border: none !important;
    justify-content: center !important;
    height: 7rem !important;
}

.admin-top-row img {
    width: 85px;
    margin-right: 15px;
}

.admin-page .navbar-brand {
    font-size: 30px!important;
}

.admin-content .fa-pencil, .admin-content .fa-chain, .admin-content .fulfill-link, .admin-content .fa-copy {
    color: #14879F;
    cursor: pointer;
}

.admin-content .btn-blue, .admin-content .btn-red {
    font-size: 16px;
}

.sidebar {
    background: #00CDDD!important;
    height: unset !important;
}

.sidebar span, .sidebar a {
    color: #FFF!important;
}

.Signup-con {
    margin-top: 9rem;
}

    .Signup-con h3 {
        color: #FFF;
        font-weight: bold;
        text-transform: uppercase;
        font-family: 'Montserrat', sans-serif;
        text-align: center;
        font-size: 3rem;
    }

    .Signup-con p {
        font-size: 25px;
        max-width: 1100px;
        margin-bottom: 35px;
        line-height: 39px;
        letter-spacing: 1.5px;
    }


.terms-con {
    background-color: #FFF;
    border-radius: 10px;
    padding: 40px 60px;
    margin-top: 150px;
    max-width: 1241px;
    border: 1px solid #000;
}

    .terms-con p {
        text-align: center;
        font-size: 21px;
        margin-bottom: 0px;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

    .terms-con .radio-con {
        font-size: 18px;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

        .terms-con .radio-con .checkmark {
            top: 7px;
        }

.terms-field {
    max-width: 250px;
    margin: 30px auto 40px;
}

    .terms-field input {
        font-size: 18px;
        font-family: 'Helvetica', 'Arial', sans-serif;
    }

    .terms-con .btn-blue {
        display: block;
        margin: 20px auto;
        max-width: 250px;
        font-size: 19px;
        width: 100%;
    }

.app-links {
    max-width: 852px;
    min-height: 213px;
    padding: 0;
}

    .app-links a {
        display: block;
        width: 40%;
        text-align: center;
    }

        .app-links a img {
            width: 100%;
        }


.confirmation-con p {
    margin-top: 30px;
}

    .confirmation-con p br {
        display: none;
    }

.invalid-link-con {
    margin-top: 15rem;
}

.invalid-link-con p {
    height: 30vh;
}

.deals-image-field > img {
    width: 30%;
}

.deals-image-field .btn-yellow {
    width: 25%;
}

.fa-warning {
    margin-right: 5px;
}

.warning-orange {
    color: orange;
}

.warning-red {
    color : red;
}

.dropdown-check-list {
    display: block;
    position: relative;
    min-height: 37px;
    max-height: 37px;
}

    .dropdown-check-list .anchor {
        position: relative;
        cursor: pointer;
        display: inline-block;
        padding: 5px 50px 5px 10px;
        border: 1px solid #0a697d;
        border-radius: 5px;
        width: 100%;
        min-height: 37px;
        max-height: 37px;
        font-weight: bold;
        font-size: 18px;
        color: #0a697d;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

        .dropdown-check-list .anchor:after {
            position: absolute;
            content: "";
            border-left: 2px solid black;
            border-top: 2px solid black;
            padding: 5px;
            right: 10px;
            top: 20%;
            -moz-transform: rotate(-135deg);
            -ms-transform: rotate(-135deg);
            -o-transform: rotate(-135deg);
            -webkit-transform: rotate(-135deg);
            transform: rotate(-135deg);
        }

        .dropdown-check-list .anchor:active:after {
            right: 8px;
            top: 21%;
        }

    .dropdown-check-list ul.items {
        padding: 2px;
        display: none;
        margin: 0;
        border: 1px solid #ccc;
        border-top: none;
        max-height: 300px;
        overflow-y: auto;
        position: absolute;
        width: 100%;
        z-index: 100;
    }

        .dropdown-check-list ul.items li {
            list-style: none;
        }

        .dropdown-check-list ul.items li label {
            margin-bottom: 0;
            margin-left: 10px;
        }

    .dropdown-check-list.visible .items {
        display: block;
        background-color: #FFF;
    }

.btn-hidden {
    display: none;
}

.datatable, .multi-sort-note {
    display: none;
}

.quiz-learn-editor .ck-editor, .quiz-learn-editor .ck-content {
    max-height: 500px;
    min-height: 200px;
}

.engagement-tables table {
    width: 100%!important;
}

@media (max-width: 1536px) {
    .actual-report {
        max-width: 1200px !important;
    }
}


@media (max-width: 641px) {
    .Signup-con p {
        font-size: 18px;
        width: 90%;
        line-height: 30px;
    }

    .signup-form {
        width: 90% !important;
        padding: 0;
    }

        .signup-form input {
            width: 100%;
        }

        .signup-form label {
            padding-top: 20px;
        }

        .signup-form .btn-blue {
            font-size: 18px;
            display: block;
            margin-top: 15px;
            width: 100%;
            padding: 5px 15px;
        }

    .sign-in-field .password-con i {
        right: 5%;
    }

    .terms-con {
        width: 90%;
        margin-top: 95px;
    }

    .app-links {
        flex-direction: column;
        padding: 20px;
    }

        .app-links a {
            width: 100%;
        }

            .app-links a img {
                max-width: 200px;
            }

    .top-row img {
        max-width: 130px;
        margin-top: 6rem;
    }

    .Signup-con {
        margin-top: 5rem;
    }

    .signup-form .form-submit button {
        font-size: 16px;
    }



    .app-links {
        flex-direction: column;
        padding: 20px;
    }

        .app-links a {
            width: 100%;
        }

            .app-links a img {
                max-width: 200px;
                max-height: 100%;
            }


            .app-links a:last-of-type img {
                max-width: 180px;
            }

}


@media (max-width: 980px) {
    .signup-form input {
        width: 100%;
    }

    .sign-in-field label {
        font-size: 18px;
    }

    .sign-in-field input {
        font-size: 14px;
    }

    .sign-in-field .password-con i {
        right: 10px;
    }

    .terms-con p {
        font-size: 20px;
    }

    .terms-con .radio-con {
        font-size: 20px;
    }

    .Signup-con p {
        font-size: 18px;
        margin-top: 10px;
        line-height: 24px;
        margin-bottom: 25px;
    }

    .terms-con {
        padding: 30px 20px;
    }

    .app-links {
        min-height: 139px;
    }



}

@media (max-width: 450px) {
    .confirmation-con p br {
        display: block;
    }
}

