@import url(https://fonts.googleapis.com/css2?family=Noto+Sans:wght@400;500;600;700&family=Poppins:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500;1,600;1,700;1,800&display=swap);

.btn-login,
.btn-signup,
.btn-white,
.homepage-navbar .dropdown-item,
.homepage-navbar .navbar-nav .nav-link,
body {
    font-family: "Noto Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif
}

#loginModalathlete .terms-label span,
#paymentModal .modal-body .coupon-code,
#paymentModal .modal-body .terms-link,
#paymentModalPlan .modal-body .coupon-code,
#paymentModalPlan .modal-body .terms-link,
#planChooseModal .modal-body .terms-link,
#signupModalathlete .terms-label span,
.otp-resend-text,
.signup-container .login-link {
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-thickness: auto;
    text-underline-offset: auto
}

*,
body {
    margin: 0;
    padding: 0
}

.quiz-step .food-checkbox,
.quiz-step .radio-option input[type=radio] {
    fill: var(--White, #fff);
    stroke-width: .5px;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, .12))
}

*,
.slider-track .card {
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

#choose-plan-section {
    scroll-margin-top: 80px
}

body {
    overflow-x: hidden
}

#congratsModal .modal-content #congratsContent,
#congratsModalConsultation .modal-content #congratsContent,
#paymentModal .modal-content #paymentContentConsultation,
#paymentModalPlan .modal-content #paymentContentConsultation,
#planChooseModal .modal-content .modal-body {
    height: 100%;
    overflow-y: auto;
    padding-top: 20px !important
}

.container-homepage {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
    margin-right: auto;
    margin-left: auto
}

.navbar>.container-homepage {
    display: flex;
    flex-wrap: inherit;
    align-items: center;
    justify-content: space-between;
    padding: 0 !important
}

@media (min-width:576px) {
    .container-homepage {
        max-width: 540px
    }
}

@media (min-width:768px) {
    .container-homepage {
        max-width: 720px
    }
}

@media (min-width:992px) {
    .container-homepage {
        max-width: 960px
    }
}

@media (min-width:1200px) {

    .container-homepage,
    .testimonial-section .container {
        max-width: 1140px
    }
}

@media (min-width:1400px) {
    .container-homepage {
        max-width: 1320px
    }

    #congratsModal .modal-content,
    #congratsModalConsultation .modal-content,
    #loginModalathlete .modal-content,
    #paymentModal .modal-content,
    #paymentModalPlan .modal-content,
    #planChooseModal .modal-content,
    #quizModal .modal-content,
    #signupModalathlete .modal-content {
        max-height: 82vh;
        border-radius: 12px
    }
}

@media (min-width:1680px) {

    #congratsModal .modal-content,
    #congratsModalConsultation .modal-content,
    #loginModalathlete .modal-content,
    #paymentModal .modal-content,
    #paymentModalPlan .modal-content,
    #planChooseModal .modal-content,
    #quizModal .modal-content,
    #signupModalathlete .modal-content {
        max-height: 89vh;
        border-radius: 12px
    }

    .signup-container .form-section {
        max-height: 89vh;
        overflow: auto
    }
}

@media (min-width:1800px) {

    #congratsModal .modal-content,
    #congratsModalConsultation .modal-content,
    #loginModalathlete .modal-content,
    #paymentModal .modal-content,
    #paymentModalPlan .modal-content,
    #planChooseModal .modal-content,
    #quizModal .modal-content,
    #signupModalathlete .modal-content {
        max-height: 83vh;
        border-radius: 12px
    }

    .signup-container .form-section {
        max-height: 83vh;
        overflow: auto
    }
}

.homepage-navbar.navbar-custom {
    background: 0 0;
    padding: 30.5px 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1000;
    transition: .3s
}

.homepage-navbar .navbar-brand {
    padding: 0
}

.homepage-navbar .navbar-brand img {
    width: 170px;
    height: auto
}

.homepage-navbar .navbar-nav .nav-link {
    color: #fff !important;
    font-weight: 500;
    margin: 0 15px;
    transition: color .3s
}

.homepage-navbar .navbar-nav .nav-link.active,
.homepage-navbar .navbar-nav .nav-link:focus,
.homepage-navbar .navbar-nav .nav-link:hover {
    color: #4fc3f7 !important
}

.homepage-navbar .navbar-nav .nav-link:focus svg path,
.homepage-navbar .navbar-nav .nav-link:hover svg path {
    stroke: #4fc3f7 !important
}

.homepage-navbar .dropdown-menu {
    background: #fff;
    border: none;
    border-radius: 8px;
    padding: 16px;
    min-width: 230px
}

.homepage-navbar .dropdown-item {
    color: #3b3b3b;
    padding: 8px 0
}

.homepage-navbar .dropdown-item:hover {
    background: 0 0;
    color: #4fc3f7
}

#loginModalathlete .age-selection-box .custom-radio,
#loginModalathlete .phone-input-container .hidden,
#quizModal .phone-input-container .hidden,
#signupModalathlete .age-selection-box .custom-radio,
#signupModalathlete .phone-input-container .hidden,
.carousel-indicators,
.chat-widget.mobile-view.web-hide,
.choose-plan-section .choose-plan-label,
.footer-bg .buttons-mobile,
.homepage-navbar .dropdown-toggle::after,
.quiz-step:not(:first-child)~.image-section,
.testimonial-section .carousel-controls-mobile,
.testimonial-section .quote-icon.mobile,
.web-hide {
    display: none
}

.btn-login {
    background: 0 0;
    color: #fff;
    border: 2px solid #fff;
    padding: 10px 20px;
    margin-right: 10px;
    border-radius: 6px;
    font-weight: 600;
    transition: .3s
}

.btn-signup,
.btn-white {
    padding: 12px 18px;
    font-style: normal;
    line-height: normal;
    width: max-content;
    font-size: 16px;
    font-weight: 600
}

.btn-login:hover {
    background: #fff;
    color: #333
}

.btn-login.active,
.btn-login.show,
.btn-login:active,
.btn-login:checked+.btn-login,
.btn-login:first-child:active,
.btn-login:focus-visible,
.btn-login:hover,
:not(.btn-check)+.btn-login:active {
    background: #fff;
    color: #333;
    border-color: #fff
}

.btn-signup {
    border-radius: 6px;
    background: var(--Blue-600, #4a84dd);
    color: #fff;
    border: 1px solid var(--Blue-600, #4a84dd);
    position: relative
}

.btn-signup.active,
.btn-signup.show,
.btn-signup:active,
.btn-signup:checked+.btn-signup,
.btn-signup:first-child:active,
.btn-signup:focus-visible,
.btn-signup:hover,
:not(.btn-check)+.btn-signup:active {
    background: #1751aa;
    border-color: #1751aa;
    color: #fff
}

.btn-white {
    border-radius: 6px;
    background: #fff;
    border: 1px solid #fff;
    color: #3b3b3b;
    transition: .3s
}

.carousel-item,
.food-section {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat
}

.about-section .about-title,
.hero-title-homepage,
.recommended-plans-section .about-title {
    font-family: Poppins, sans-serif;
    font-style: italic;
    font-weight: 800;
    text-transform: uppercase
}

.hero-content-fixed {
    position: absolute;
    bottom: 49px;
    z-index: 10;
    color: #fff;
    max-width: 600px
}

.hero-content-fixed .btn-quiz {
    pointer-events: all
}

.hero-title-homepage {
    font-size: 64px;
    line-height: 62px;
    letter-spacing: 0;
    background-image: linear-gradient(to bottom, #fff, #c1d8fc);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 4px 12px rgba(0, 0, 0, .15);
    margin-bottom: 12px
}

.chat-widget .chat-bubble span,
.hero-subtitle-homepage {
    font-family: "Noto Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-style: normal;
    line-height: normal
}

.hero-subtitle-homepage {
    color: var(--White, #fff);
    font-size: 18px;
    font-weight: 400;
    margin-bottom: 24px
}

.carousel-item {
    height: 100vh;
    position: relative;
    transition: transform .8s ease-in-out
}

.carousel-item::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    transition: opacity .8s
}

.carousel-fade .carousel-item {
    opacity: 0;
    transition: opacity .8s ease-in-out
}

.chat-widget.desktop-view,
.chat-widget.mobile-view {
    z-index: 999;
    align-items: center;
    gap: 10px;
    transition: .3s;
    position: absolute;
    width: 100%;
    display: flex;
    cursor: pointer
}

.carousel-fade .carousel-item.active {
    opacity: 1
}

.chat-widget.desktop-view {
    max-width: 213px;
    bottom: 24px;
    right: 24px
}

.chat-widget.mobile-view {
    max-width: 253px;
    top: -144px;
    right: 0;
    height: max-content
}

.chat-widget .chat-avatar {
    width: 67.2px;
    height: 67.2px;
    position: absolute;
    bottom: -12px;
    right: 10px;
    border-radius: 67.2px
}

.chat-widget .chat-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    box-shadow: 0 2.4px 9.6px 0 rgba(0, 0, 0, .15);
    border-radius: 67.2px
}

.chat-widget.desktop-view.mob-hide .chat-avatar {
    right: 0
}

.chat-widget .chat-bubble {
    background-color: #fff;
    position: relative;
    padding: 16px;
    border-radius: 12px;
    background: linear-gradient(57deg, #e0ecff 18.68%, #c9ddfc 53.76%, #fff 118.89%);
    max-width: 250px;
    margin-bottom: 67px
}

.chat-widget .bubble-arrow {
    position: absolute;
    bottom: -13px;
    width: 26.5px;
    height: 16.5px;
    right: 10px
}

.chat-widget .chat-bubble span {
    color: var(--Blue-700, #1751aa);
    font-size: 16px;
    font-weight: 600
}

.carousel-indicators .active {
    background-color: #4fc3f7;
    transform: scale(1.2)
}

.about-section {
    padding-top: 80px;
    padding-bottom: 80px;
    position: relative;
    overflow: hidden;
    min-height: 760px;
    margin: 80px 0
}

.about-section .container {
    position: relative;
    z-index: 2;
    margin: 0 auto;
    padding: 0 15px
}

.about-section .about-content-wrapper {
    display: flex;
    align-items: center;
    position: relative
}

.about-section .about-text-content {
    flex: 1;
    max-width: 500px;
    margin-right: 60px
}

.about-section .about-title,
.recommended-plans-section .about-title {
    color: var(--Kerry-grey-700, #080808);
    font-size: 48px;
    line-height: 54px;
    margin-bottom: 24px
}

.about-section .about-credentials,
.about-section .about-signature,
.about-section .about-text,
.about-section .about-text-bold {
    font-family: "Noto Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: var(--Text-Color, #333);
    font-style: normal
}

.about-section .about-text,
.about-section .about-text-bold {
    margin-bottom: 16px;
    line-height: normal
}

.about-section .about-text-bold {
    font-size: 18px;
    font-weight: 700
}

.about-section .about-text {
    font-size: 16px;
    font-weight: 400
}

.about-section .about-signature {
    font-size: 18px;
    font-weight: 700;
    line-height: normal;
    margin-bottom: 8px
}

.about-section .about-credentials {
    font-size: 14px;
    font-weight: 400;
    line-height: normal
}

.food-section .food-title,
.why-it-works-section h1 {
    font-size: 48px;
    line-height: normal;
    text-transform: uppercase
}

.about-section .about-image-container {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    width: 50vw;
    overflow: hidden;
    z-index: 1
}

.about-section .about-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    border-radius: 16px 0 0 16px
}

.about-section .fade-in {
    animation: 1s ease-in fadeIn
}

.partners-section .logo-row,
.partners-section .slide-left,
.partners-section .slide-right {
    animation-timing-function: linear;
    animation-iteration-count: infinite
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(30px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.food-section {
    position: relative;
    padding: 80px 0;
    background-image: url("images/eat better.webp");
    background-attachment: fixed;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start
}

.food-section::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(51, 50, 50, .8);
    z-index: 1
}

.food-section .food-content {
    position: relative;
    z-index: 2;
    text-align: center;
    color: #fff;
    max-width: 900px;
    margin: 0 auto 60px;
    padding: 0 20px
}

.food-section .food-title {
    font-family: Poppins, sans-serif;
    color: var(--White, #fff);
    text-align: center;
    font-style: italic;
    font-weight: 800;
    margin-bottom: 4px
}

.food-section .food-subtitle {
    font-family: "Noto Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: var(--White, #fff);
    text-align: center;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    max-width: 708px;
    margin-bottom: 24px
}

.food-section .food-carousel-container {
    position: relative;
    width: 100%;
    max-width: 100vw;
    margin: 0;
    overflow: hidden;
    z-index: 2;
    -webkit-overflow-scrolling: touch
}

.food-section .food-carousel-track {
    display: flex;
    transition: transform .25s ease-in-out;
    width: fit-content;
    padding: 0 10px;
    will-change: transform;
    touch-action: pan-y pinch-zoom
}

.cards-wrapper .btn-learn-more-blue,
a.btn-learn-more-blue,
a.btn-signup {
    -webkit-tap-highlight-color: transparent !important;
    touch-action: manipulation !important
}

.food-section .food-card {
    width: 380px;
    height: 380px;
    border-radius: 16px;
    margin: 0 10px;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: transform .3s, box-shadow .3s;
    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, .1)
}

.food-section .food-card:hover {
    box-shadow: 0 8px 25px 0 rgba(0, 0, 0, .2)
}

.food-section .food-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 16px
}

.food-section .food-card-title {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, .7);
    color: #fff;
    padding: 10px;
    font-size: 14px;
    font-weight: 500;
    border-radius: 0 0 16px 16px;
    text-align: center
}

.food-section .carousel-nav-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    background: rgba(255, 255, 255, .9);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    color: #333;
    transition: .3s;
    z-index: 10
}

.food-section .carousel-nav-btn:hover {
    background: #fff;
    transform: translateY(-50%) scale(1.1)
}

.food-section .nav-icon {
    font-weight: 700
}

.why-it-works-section {
    background-color: #2a2a2a;
    color: #fff;
    padding: 80px 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif
}

.why-it-works-section h1 {
    font-family: Poppins, sans-serif;
    font-style: italic;
    font-weight: 800;
    color: #fff;
    margin-bottom: 22px
}

.why-it-works-section .nav-tabs {
    border: none;
    margin-bottom: 22px;
    position: relative
}

.why-it-works-section .nav-tabs::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: #626262
}

.why-it-works-section .nav-tabs .nav-link {
    color: var(--Blue-400, #83b1f9);
    font-family: Poppins;
    font-size: 26px;
    font-style: italic;
    font-weight: 800;
    line-height: 36px;
    text-transform: uppercase;
    position: relative
}

.why-it-works-section .nav-tabs .nav-link:focus,
.why-it-works-section .nav-tabs .nav-link:hover {
    border-color: transparent !important
}

.why-it-works-section .nav-tabs .nav-link.active {
    color: #fff;
    background: 0 0;
    border: none
}

.why-it-works-section .nav-tabs .nav-link.active::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background-color: #fff
}

.why-it-works-section .nav-tabs .nav-link:not(.active)::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background-color: transparent
}

.why-it-works-section .tab-description {
    font-size: 1.2rem;
    margin-bottom: 3rem;
    color: #ccc;
    line-height: 1.6
}

.why-it-works-section .feature-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
    margin-bottom: 0
}

.why-it-works-section .feature-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem
}

.why-it-works-section .feature-icon {
    color: #4a9eff;
    font-size: 2rem;
    margin-top: 0;
    flex-shrink: 0
}

.why-it-works-section .feature-content h3 {
    color: var(--White, #fff);
    margin-bottom: 8px;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 26px
}

.why-it-works-section .feature-content p {
    color: var(--Kerry-grey-100, #ebebeb);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin-bottom: 0
}

.why-it-works-section .phone-mockup {
    position: relative;
    margin: 45px auto 0
}

.why-it-works-section .phone-frame {
    border-radius: 15.898px;
    border: 5.962px solid #f0f1f4;
    background: var(--White, #fff)
}

.why-it-works-section .phone-screen {
    background: #fff;
    border-radius: 15px;
    overflow: hidden;
    position: relative
}

.why-it-works-section .app-header {
    background: #f8f9fa;
    padding: 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #eee
}

.why-it-works-section .app-logo {
    font-weight: 700;
    color: #4a9eff;
    font-size: 1.1rem
}

.why-it-works-section .hamburger {
    color: #666;
    font-size: 1.2rem
}

.why-it-works-section .app-content {
    padding: 20px 15px;
    height: calc(100% - 60px);
    overflow-y: auto;
    color: #333
}

.why-it-works-section .welcome-message {
    background: #e3f2fd;
    padding: 15px;
    border-radius: 10px;
    margin-bottom: 20px;
    font-size: .9rem;
    color: #1976d2
}

.why-it-works-section .chat-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 8px;
    font-size: .8rem;
    color: #666
}

.why-it-works-section .user-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #ddd;
    margin-top: 10px
}

.why-it-works-section .training-plan {
    margin-top: 25px
}

.why-it-works-section .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px
}

.why-it-works-section .section-title {
    font-weight: 600;
    color: #333;
    font-size: 1.1rem
}

.why-it-works-section .see-plan {
    color: #4a9eff;
    font-size: .9rem;
    text-decoration: none
}

.why-it-works-section .meal-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 15px;
    flex-wrap: wrap
}

.why-it-works-section .meal-tab {
    background: #f0f0f0;
    border: none;
    padding: 8px 12px;
    border-radius: 20px;
    font-size: .8rem;
    color: #666;
    cursor: pointer
}

.why-it-works-section .meal-tab.active {
    background: #4a9eff;
    color: #fff
}

.why-it-works-section .food-scroll {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 10px;
    margin-bottom: 20px
}

.why-it-works-section .food-scroll::-webkit-scrollbar {
    height: 4px
}

.why-it-works-section .food-scroll::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 2px
}

.why-it-works-section .food-scroll::-webkit-scrollbar-thumb {
    background: #ccc;
    border-radius: 2px
}

.why-it-works-section .food-item {
    flex-shrink: 0;
    width: 120px
}

.why-it-works-section .food-image {
    width: 120px;
    height: 80px;
    border-radius: 8px;
    object-fit: cover;
    margin-bottom: 5px
}

.why-it-works-section .food-title {
    font-size: .8rem;
    font-weight: 500;
    color: #333;
    line-height: 1.2
}

.why-it-works-section .challenges-section {
    margin-top: 20px
}

.why-it-works-section .challenge-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px
}

.why-it-works-section .challenge-item {
    width: 100%;
    height: 60px;
    border-radius: 8px;
    object-fit: cover
}

.why-it-works-section .scrollable-image-wrapper {
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.3) transparent;
    transition: scrollbar-color .3s
}

.why-it-works-section .scrollable-image-wrapper::-webkit-scrollbar {
    width: 4px;
    transition: opacity .3s;
    opacity: 0
}

.why-it-works-section .scrollable-image-wrapper::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, .3);
    border-radius: 4px
}

.why-it-works-section .scrollable-image-wrapper:hover::-webkit-scrollbar {
    opacity: 1
}

.why-it-works-section .phone-screen-img {
    display: block;
    width: 100%;
    height: auto
}

.choose-plan-section {
    padding: 80px 0;
    background-color: #f8f9fa;
    text-align: center
}

.choose-plan-section .row {
    padding-bottom: 24px
}

.choose-plan-section .choose-plan-title {
    font-family: Poppins, sans-serif;
    font-weight: 800;
    font-style: italic;
    font-size: 48px;
    line-height: 1.2;
    color: #333;
    margin-bottom: 15px;
    text-transform: uppercase
}

.choose-plan-section .choose-plan-subtitle {
    color: var(--kerry-grey-600-main, #3b3b3b);
    text-align: center;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin-bottom: 56px;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto
}

.choose-plan-section .plan-card {
    background: linear-gradient(231deg, var(--Kerry-grey---ultra-light, #e5eaf4) 9.49%, #b4d1ff 72.32%);
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, .05);
    min-height: 380px;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start
}

.choose-plan-section .plan-card .plan-card-wrapper {
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

.choose-plan-section .plan-card:hover {
    box-shadow: 0 8px 30px rgba(0, 0, 0, .1)
}

.choose-plan-section .plan-card.orange-card {
    background: linear-gradient(232deg, #fff -2.09%, var(--Orange-300, #f9cc99) 95.9%)
}

.choose-plan-section .plan-card.white-card {
    background: linear-gradient(219deg, var(--White, #fff) -8.51%, #e3e7f2 97.57%);
    box-shadow: 0 4px 12px 0 rgba(0, 0, 0, .08)
}

.choose-plan-section .card-title {
    color: var(--Kerry-grey-700, #080808);
    text-align: left;
    font-size: 22px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    margin: 12px 0
}

.choose-plan-section .card-text {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    text-align: left
}

.testimonial-section .author-name,
.testimonial-section .quote-text {
    color: var(--Kerry-grey-700, #080808);
    font-family: "Noto Sans";
    font-style: normal
}

.footer-bg .contact-desktop,
.mob-hide,
.testimonial-section .quote-icon.web {
    display: block
}

.sport-nutrition-promo {
    width: 100vw;
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
    background: #fff;
    font-family: Poppins, sans-serif
}

.sport-nutrition-promo__title,
.testimonial-section .section-title {
    font-family: Poppins;
    font-style: italic;
    font-weight: 800;
    text-transform: uppercase
}

.sport-nutrition-promo__container {
    display: flex;
    width: 100%;
    min-height: 588px
}

.sport-nutrition-promo__half {
    position: relative;
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden
}

.sport-nutrition-promo__half--left {
    padding: 80px 40px 80px 80px
}

.sport-nutrition-promo__half--right {
    padding: 80px 80px 80px 40px
}

.sport-nutrition-promo__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1
}

.sport-nutrition-promo__overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #25252599;
    z-index: 2
}

.sport-nutrition-promo__content {
    position: relative;
    z-index: 3;
    color: #fff;
    text-align: left;
    margin: 0 auto
}

.sport-nutrition-promo__title {
    color: var(--White, #fff);
    text-shadow: 0 4px 4px rgba(0, 0, 0, .25);
    font-size: 48px;
    line-height: 56px
}

.sport-nutrition-promo__desc {
    color: var(--White, #fff);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin-bottom: 24px
}

.sport-nutrition-promo__form {
    display: flex;
    gap: .5rem;
    background-color: #fff;
    width: 100%;
    padding: 16px 24px;
    border-radius: 6px;
    margin-bottom: 24px;
    justify-content: space-between
}

.sport-nutrition-promo__form button,
.sport-nutrition-promo__form select {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    border: none;
    width: 100%;
    cursor: pointer
}

.sport-nutrition-promo__form select {
    padding: 12px 16px !important;
    line-height: 1.5 !important
}

.sport-nutrition-promo__form select::-webkit-listbox {
    padding: 8px !important;
    border-radius: 6px !important;
    border: 1px solid #ddd !important
}

.sport-nutrition-promo__form select::-webkit-option {
    padding: 12px 16px !important;
    margin: 2px 0 !important;
    border-radius: 4px !important;
    font-family: "Noto Sans" !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: var(--kerry-grey-600-main, #3b3b3b) !important;
    background-color: #fff !important;
    cursor: pointer !important;
    line-height: 1.5 !important;
    min-height: 44px !important
}

.sport-nutrition-promo__form select::-webkit-option:hover {
    background-color: #f8f9fa !important
}

.sport-nutrition-promo__form select::-webkit-option:checked {
    background-color: #4fc3f7 !important;
    color: #fff !important
}

.sport-nutrition-promo__form select option,
.sport-nutrition-promo__form select[data-custom=true] option {
    padding: 12px 16px !important;
    border: none !important;
    margin: 2px 0 !important;
    font-family: "Noto Sans" !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: var(--kerry-grey-600-main, #3b3b3b) !important;
    background-color: #fff !important;
    line-height: 1.5 !important;
    min-height: 44px !important;
    cursor: pointer !important
}

.sport-nutrition-promo__form select[data-custom=true]:focus {
    outline: 0 !important;
    border-color: transparent !important;
    box-shadow: none !important
}

.sport-nutrition-promo__form select[data-custom=true]:focus-visible {
    outline: 0 !important;
    border-color: transparent !important;
    box-shadow: none !important
}

.sport-nutrition-promo__form select[data-custom=true]:focus+.custom-select-arrow svg path,
.sport-nutrition-promo__form select[data-custom=true]:hover+.custom-select-arrow svg path {
    stroke: #3b3b3b !important
}

.sport-nutrition-promo__form select[data-custom=true] {
    padding: 0 30px 0 16px !important;
    line-height: 1.5 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    width: 100% !important;
    box-sizing: border-box !important;
    text-indent: 0 !important
}

.sport-nutrition-promo__form select[data-custom=true] option {
    height: 44px !important;
    display: block !important;
    box-sizing: border-box !important;
    white-space: normal !important;
    overflow: visible !important
}

.sport-nutrition-promo__form select[data-custom=true]::-webkit-listbox {
    padding: 8px !important;
    border-radius: 6px !important;
    border: 1px solid #ddd !important
}

.sport-nutrition-promo__form select[data-custom=true]::-webkit-option {
    padding: 12px 16px !important;
    margin: 2px 0 !important;
    border-radius: 4px !important;
    font-family: "Noto Sans" !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: var(--kerry-grey-600-main, #3b3b3b) !important;
    background-color: #fff !important;
    cursor: pointer !important;
    line-height: 1.5 !important;
    min-height: 44px !important;
    white-space: normal !important;
    overflow: visible !important
}

.sport-nutrition-promo__form select[data-custom=true]::-webkit-option:hover {
    background-color: #f8f9fa !important
}

.sport-nutrition-promo__form select[data-custom=true]::-webkit-option:checked {
    background-color: #4fc3f7 !important;
    color: #fff !important
}

.sport-nutrition-promo__form select:focus-visible {
    outline: 0
}

.sport-nutrition-promo__form button:last-of-type,
.sport-nutrition-promo__form select:last-of-type {
    border: none
}

.custom-select-wrapper {
    position: relative;
    width: 100%
}

.custom-select-wrapper select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 40px;
    background: 0 0
}

.custom-select-arrow {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    transition: transform .3s
}

.custom-select-wrapper select:focus+.custom-select-arrow {
    transform: translateY(-50%) rotate(180deg)
}

.custom-select-wrapper select:not([data-custom=true]):hover+.custom-select-arrow svg path {
    stroke: #4fc3f7
}

.vertical-line {
    width: 1px;
    height: 24px;
    background-color: #000;
    margin: 0 20px
}

.testimonial-section {
    background-color: #fff;
    padding: 80px 0
}

.testimonial-section .section-title {
    color: var(--Kerry-grey-700, #080808);
    font-size: 36px;
    line-height: normal;
    margin-bottom: 36px
}

.testimonial-section .testimonial-card {
    background-color: #fff;
    border-radius: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 450px
}

.testimonial-section .testimonial-image-wrapper {
    flex-shrink: 0;
    width: 254px;
    height: 334px;
    overflow: hidden;
    border-radius: .75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #eee
}

.testimonial-section .testimonial-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: .75rem
}

.testimonial-section .testimonial-content {
    flex-grow: 1;
    max-width: 600px
}

.testimonial-section .quote-icon {
    display: inline-block;
    margin-bottom: 12px
}

.testimonial-section .quote-text {
    font-size: 20px;
    font-weight: 500;
    line-height: normal;
    margin-bottom: 36px
}

.testimonial-section .author-name {
    font-size: 18px;
    font-weight: 800;
    line-height: normal
}

.kerry-section .hero-subtitle,
.testimonial-section .author-title {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

.testimonial-section .carousel-control-next,
.testimonial-section .carousel-control-prev {
    width: 32px;
    height: 32px;
    background-color: #e0e0e0;
    border-radius: 50%;
    opacity: 1;
    transition: background-color .3s;
    top: 50%;
    transform: translateY(-50%)
}

.testimonial-section .carousel-control-next-mobile:hover,
.testimonial-section .carousel-control-next:hover,
.testimonial-section .carousel-control-prev-mobile:hover,
.testimonial-section .carousel-control-prev:hover {
    background-color: #d0d0d0
}

.testimonial-section .carousel-control-next-icon,
.testimonial-section .carousel-control-prev-icon {
    background-image: none;
    width: 13px;
    height: 7.6px;
    border: solid #333;
    border-width: 0 3px 3px 0;
    display: inline-block;
    padding: 3px
}

.testimonial-section .carousel-control-prev-icon {
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg)
}

.testimonial-section .carousel-control-next-icon {
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg)
}

.testimonial-section .carousel-control-prev {
    left: -70px
}

.testimonial-section .carousel-control-next {
    right: -70px
}

.testimonial-section .carousel-control-next-mobile,
.testimonial-section .carousel-control-prev-mobile {
    width: 40px;
    height: 40px;
    background-color: #e0e0e0;
    border-radius: 50%;
    opacity: 1;
    transition: background-color .3s;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center
}

.footer-bg .footer-link,
.footer-bg .social-icon {
    transition: color .2s ease-in-out
}

.testimonial-section .carousel-item {
    height: 100%;
    background: 0 0
}

.testimonial-section .carousel-item::before {
    content: none
}

.carousel {
    height: max-content !important
}

.partners-section {
    background-color: #333;
    padding: 80px 0;
    overflow: hidden
}

.partners-section .section-title {
    color: var(--White, #fff);
    font-family: Poppins;
    font-size: 36px;
    font-style: italic;
    font-weight: 800;
    line-height: 48px;
    text-transform: uppercase;
    margin-bottom: 36px
}

.footer-bg .copyright-text,
.footer-bg .tagline,
.security-note,
.signup-container .welcome-text {
    font-weight: 400;
    font-family: "Noto Sans";
    font-style: normal
}

.partners-section .slider-container {
    width: 100%;
    overflow: hidden
}

.partners-section .logo-row {
    display: flex;
    white-space: nowrap;
    margin-bottom: 24px;
    gap: 24px
}

.partners-section .logo-row:last-child,
.signup-container .input-group {
    margin-bottom: 0
}

.partners-section .logo-card {
    flex-shrink: 0;
    width: 280px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: #fff;
    max-height: 140px
}

.partners-section .logo-card img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain
}

.partners-section .slide-left {
    animation-name: slide-left;
    animation-duration: 25s
}

@keyframes slide-left {
    0% {
        transform: translateX(0)
    }

    100% {
        transform: translateX(-100%)
    }
}

.partners-section .slide-right {
    animation-name: slide-right;
    animation-duration: 25s
}

@keyframes slide-right {
    0% {
        transform: translateX(-100%)
    }

    100% {
        transform: translateX(0)
    }
}

.contact-section {
    background-color: #f8f8f8;
    padding: 80px 0
}

.contact-card {
    background-color: #fff;
    border-radius: 1rem;
    box-shadow: 0 10px 20px rgba(0, 0, 0, .08);
    padding: 0;
    overflow: hidden
}

.contact-form-wrapper {
    padding: 3rem;
    width: 50%
}

.contact-title {
    font-size: 2.2rem;
    font-weight: 900;
    color: #333;
    text-transform: uppercase;
    letter-spacing: -.05em
}

.contact-description {
    font-size: 1rem;
    color: #555;
    line-height: 1.6
}

.form-label {
    font-weight: 600;
    color: #333;
    margin-bottom: .5rem
}

.form-control {
    border-radius: .5rem;
    padding: .75rem 1rem;
    border: 1px solid #ddd;
    font-size: 1rem
}

.form-control:focus {
    border-color: inherit;
    box-shadow: none
}

.send-message-btn {
    background-color: #4285f4;
    border-color: #4285f4;
    padding: .75rem 2rem;
    border-radius: .5rem;
    font-weight: 600;
    transition: background-color .3s, border-color .3s
}

.otp-input,
.user-type-box {
    transition: border-color .2s ease-in-out, box-shadow .2s ease-in-out
}

.send-message-btn:hover {
    background-color: #357ae8;
    border-color: #357ae8
}

.phone-mockup-wrapper {
    flex-shrink: 0;
    width: 400px;
    border-top-right-radius: 1rem;
    border-bottom-right-radius: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 0 2rem 2rem
}

.phone-mockup-wrapper img {
    max-width: 100%;
    height: auto;
    display: block
}

.footer-bg {
    background-color: #2c2c2c;
    color: #d1d1d1;
    padding: 3rem 1rem
}

.footer-bg .tagline {
    color: var(--White, #fff);
    font-size: 16px;
    line-height: normal;
    margin: 24px 0;
    max-width: 364px
}

.footer-bg .copyright-text a:hover,
.footer-bg .footer-link:hover,
.footer-bg .social-icon:hover {
    color: #fff
}

.footer-bg .footer-link {
    color: #d1d1d1;
    text-decoration: none
}

#termsModal .terms-link,
.login-link:hover,
.signup-container .login-link:hover {
    text-decoration: underline
}

.footer-bg .copyright-text {
    color: var(--White, #fff);
    font-size: 14px;
    line-height: normal;
    margin-top: 25px
}

.footer-bg .copyright-text a {
    color: #a0a0a0;
    text-decoration: underline
}

.footer-bg .dropdown-menu {
    background-color: #fff;
    border: none;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .1);
    padding: .5rem 0
}

.footer-bg .dropdown-item {
    color: #333;
    padding: .5rem 1rem;
    font-size: .9rem
}

.footer-bg .dropdown-item:focus,
.footer-bg .dropdown-item:hover {
    background-color: #f0f0f0;
    color: #333
}

.footer-bg .nav-links {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.footer-bg .footer-bg {
    padding: 4rem 1rem
}

.footer-bg .footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 2rem
}

.footer-bg .buttons-desktop {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    justify-content: flex-end
}

.signup-container {
    height: 100%;
    overflow-y: auto;
    border-radius: 12px
}

.signup-container .signup-modal {
    display: flex;
    background: #fff;
    overflow: hidden;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);
    min-height: 600px;
    position: relative
}

.signup-container .signup-modal .form-section-content.steps {
    min-height: 600px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start
}

.signup-container .close-button {
    position: absolute;
    top: 8px;
    right: 8px;
    cursor: pointer;
    border: none;
    padding: 15px;
    z-index: 10;
    border-radius: 150.009px;
    background: var(--White, #fff);
    box-shadow: 0 4px 12px 0 rgba(0, 0, 0, .25)
}

.signup-container .email-input,
.signup-container .social-button {
    border-radius: 6px;
    font-weight: 600;
    position: relative;
    padding: 12px 18px
}

.otp-input,
.signup-container .email-input {
    box-shadow: 0 1px 4px 0 rgba(0, 0, 0, .08);
    outline: 0
}

.signup-container .close-button:hover {
    color: #4b5563
}

.signup-container .close-button:focus {
    outline: 0
}

.signup-container .form-section {
    flex: 1;
    justify-content: center;
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    padding: 32px
}

.signup-container .form-section#step3 {
    justify-content: start
}

.signup-container .welcome-title {
    color: var(--Kerry-grey-700, #080808);
    font-family: "Noto Sans";
    font-size: 28px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    margin-bottom: 12px
}

.signup-container .welcome-text {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-size: 18px;
    line-height: normal;
    margin-bottom: 36px
}

.security-note {
    color: #3b3b3b;
    font-size: 12px;
    line-height: 24px
}

.signup-container .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0
}

.signup-container .email-input {
    color: #374151;
    background-color: #fff;
    cursor: pointer;
    transition: background-color .15s ease-in-out;
    width: 100%;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    line-height: normal
}

.form-group .input-group select,
.signup-container .social-button {
    transition: background-color .15s ease-in-out;
    box-shadow: 0 1px 8px 0 rgba(0, 0, 0, .08);
    cursor: pointer
}

.signup-container .email-input::placeholder {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: normal
}

.signup-container .email-input:focus {
    border-color: #e5e7eb;
    box-shadow: 0 0 0 2px rgba(229, 231, 235, .5)
}

.plan-inclusion-section .plan-features.consultations .feature-column .or-divider,
.signup-container .or-divider {
    display: flex;
    align-items: center;
    margin: 24px 0;
    width: 100%
}

.signup-container .divider-line {
    flex-grow: 1;
    border-top: 1px solid #d1d5db
}

.signup-container .or-text {
    margin-left: 1rem;
    margin-right: 1rem;
    color: #6b7280;
    font-size: .875rem
}

.signup-container .login-link-text,
.signup-container .social-button {
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    width: 100%
}

.signup-container .social-buttons {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%
}

.signup-container .social-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #374151;
    background-color: #fff;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    color: var(--kerry-grey-600-main, #3b3b3b);
    line-height: normal;
    opacity: .75
}

.signup-container .social-button:hover {
    background-color: #f9fafb
}

.signup-container .social-button:focus {
    outline: 0;
    border-color: #e5e7eb;
    box-shadow: 0 0 0 2px rgba(229, 231, 235, .5)
}

.signup-container .login-link-text {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-weight: 400;
    line-height: normal;
    margin-top: 1.5rem;
    text-align: left
}

.otp-resend-text,
.signup-container .login-link {
    color: var(--Blue-600, #4a84dd);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: normal
}

.signup-container .login-link {
    text-underline-position: from-font
}

.signup-container .image-section {
    flex: 1;
    padding: 0 0 0 16px;
    max-height: 100%
}

.signup-container .food-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 12px
}

.otp-input-group {
    display: flex;
    gap: 24px;
    justify-content: flex-start;
    align-items: center;
    width: 100%
}

.otp-input {
    width: 57px;
    height: 55px;
    padding: 12px 18px;
    border-radius: 6px;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    text-align: center
}

.otp-input:focus {
    border-color: #a0aec0;
    box-shadow: none
}

.form-section-content.steps {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex: 1;
    min-height: 100%;
    padding: 24px
}

.progress-indicators {
    display: flex;
    gap: .5rem;
    margin-bottom: auto
}

.progress-step {
    width: 60px;
    height: .25rem;
    background-color: #e5e7eb;
    border-radius: 9999px
}

#loginModalathlete .age-box,
#signupModalathlete .age-box,
.user-type-box {
    border-radius: 6px;
    background: var(--White, #fff);
    box-shadow: 0 1px 4px 0 rgba(0, 0, 0, .08)
}

.progress-step.active {
    background-color: #3b82f6
}

.welcome-title {
    font-size: 1.875rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    line-height: 1.3
}

.user-type-text-subtitle,
.user-type-text-title {
    font-family: "Noto Sans";
    font-style: normal;
    line-height: 24px
}

.user-type-selection {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 22px
}

.user-type-box {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    padding: 16px 25px;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background-color: #fff;
    cursor: pointer;
    flex: 1;
    gap: 12px
}

.user-type-box.selected,
.user-type-box:hover {
    border: 1px solid #649ef7
}

.user-type-box .title-wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start
}

.user-type-text-title {
    color: #080808;
    font-size: 18px;
    font-weight: 700
}

.user-type-text-subtitle {
    color: #000;
    font-size: 16px;
    font-weight: 400
}

.user-type-box input[type=radio] {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0)
}

.custom-radio {
    position: absolute;
    top: .75rem;
    right: .75rem;
    width: 1rem;
    height: 1rem;
    border: 1px solid #d1d5db;
    border-radius: 9999px;
    background-color: #fff;
    transition: background-color .2s ease-in-out, border-color .2s ease-in-out
}

.user-type-box input[type=radio]:checked+.custom-radio {
    background-color: #3b82f6;
    border-color: #3b82f6
}

.user-type-box input[type=radio]:checked+.custom-radio::after {
    content: "";
    display: block;
    width: .5rem;
    height: .5rem;
    background-color: #fff;
    border-radius: 9999px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}

.user-type-box input[type=radio]:checked~.user-type-icon {
    color: #3b82f6
}

.user-type-box input[type=radio]:checked {
    border-color: #3b82f6;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, .5)
}

.user-type-icon {
    width: 2.5rem;
    height: 2.5rem;
    color: #6b7280;
    margin-bottom: .5rem
}

#loginModalathlete .age-box,
#loginModalathlete .age-selection-box .user-type-box,
#signupModalathlete .age-box,
#signupModalathlete .age-selection-box .user-type-box,
.user-type-text {
    color: var(--Kerry-grey-500, #626262);
    font-weight: 400;
    font-size: 14px;
    font-family: "Noto Sans";
    font-style: normal;
    line-height: 24px
}

svg.user-type-icon,
svg.user-type-icon path {
    stroke: rgba(0, 56, 145, 1)
}

#loginModalathlete .age-box-selection,
#signupModalathlete .age-box-selection {
    display: flex;
    gap: 12px;
    margin-bottom: 20px
}

#loginModalathlete .age-box,
#signupModalathlete .age-box {
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    padding: 8px 21px;
    text-align: center
}

#loginpModalathlete .age-selection-box,
#signupModalathlete .age-selection-box {
    display: flex;
    flex-direction: row;
    gap: 1rem;
    margin-bottom: 44px
}

#loginModalathlete .age-selection-box .user-type-box,
#signupModalathlete .age-selection-box .user-type-box {
    border-radius: 6px;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    box-shadow: 0 1px 4px 0 rgba(0, 0, 0, .08);
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    padding: 10px;
    cursor: pointer;
    transition: border-color .2s ease-in-out, box-shadow .2s ease-in-out;
    flex: 1;
    min-height: 50px;
    gap: 12px;
    white-space: nowrap
}

#loginModalathlete .age-selection-box .user-type-box.selected,
#signupModalathlete .age-selection-box .user-type-box.selected {
    border: 2px solid #649ef7
}

#loginModalathlete .age-selection-box .user-type-text.selected,
#signupModalathlete .age-selection-box .user-type-text.selected {
    font-size: 14px
}

#loginModalathlete #login-step2,
#loginModalathlete #step2,
#signupModalathlete #step2 {
    align-items: start
}

.next-button {
    margin-top: 44px
}

.next-button:hover {
    background-color: #4a84dd
}

.login-link-text {
    font-size: .875rem;
    color: #4b5563;
    margin-top: 1.5rem;
    text-align: center
}

.login-link {
    color: #4a84dd;
    text-decoration: none
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 24px
}

#paymentModal .modal-body form label,
#paymentModalPlan .modal-body form label,
#planChooseModal .modal-body form label,
.form-group .input-group label {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: normal
}

.form-group .input-group span {
    color: red;
    padding-left: 2px
}

.form-group .input-group select {
    outline: 0;
    padding: 12px 18px;
    color: #374151;
    background-color: #fff;
    width: 100%;
    position: relative;
    border-radius: 6px;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: normal
}

.form-section-content.steps {
    justify-content: center !important
}

.quiz-step {
    width: 100%;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-bottom: 0;
    position: relative
}

.quiz-popup-title {
    color: #4a84dd !important;
    font-family: Poppins !important;
    font-size: 44px !important;
    font-style: italic !important;
    font-weight: 800 !important;
    line-height: 54px !important;
    text-transform: uppercase
}

.quiz-popup-subtitle {
    color: var(--Kerry-grey-700, #080808);
    font-family: "Noto Sans";
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

.quiz-step .quiz-step-header {
    margin-bottom: 24px
}

.quiz-step .step-title {
    color: var(--Blue-700, #1751aa);
    font-family: Poppins;
    font-size: 30px;
    font-style: italic;
    font-weight: 800;
    line-height: normal;
    margin-bottom: 24px
}

.quiz-step .food-label,
.quiz-step .step-instruction {
    font-family: Poppins;
    font-weight: 600;
    font-style: italic
}

.quiz-step .step-instruction {
    border-radius: 12px;
    border: 1px solid var(--Blue-400, #83b1f9);
    background: var(--Blue-100, #e0ecfd);
    color: #fff;
    padding: 12px 16px;
    color: var(--Blue-700, #1751aa);
    font-size: 18px;
    line-height: normal;
    margin-bottom: 24px
}

.quiz-step .food-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 16px;
    flex: 1
}

.quiz-step .five-grid {
    grid-template-columns: repeat(5, 1fr)
}

.quiz-step .three-grid {
    grid-template-columns: repeat(3, 1fr)
}

.quiz-step .two-grid {
    grid-template-columns: repeat(2, 1fr)
}

.quiz-step .food-item {
    text-align: center
}

.signup-container.quiz-container .close-button {
    position: absolute;
    top: 8px;
    right: 8px;
    cursor: pointer;
    border: none;
    padding: 15px;
    z-index: 10;
    border-radius: 150.009px
}

.quiz-step .food-image-container {
    position: relative;
    border-radius: 12px;
    background: var(--White, #fff);
    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, .12);
    padding: 12px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: start
}

.quiz-step .food-image-container:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, .15)
}

.quiz-step .food-image-container.selected {
    border: 2px solid #4a84dd
}

.quiz-step .food-placeholder {
    width: auto;
    min-height: 123px;
    max-height: 123px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 8px
}

.quiz-step .food-checkbox {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    border: .5px solid #898989;
    flex-shrink: 0
}

.quiz-step .food-checkbox:checked,
.quiz-step .unsure-radio:checked {
    background: #4a84dd;
    border-color: #4a84dd
}

.quiz-step .food-checkbox:checked::after,
.quiz-step .radio-option input:checked::after,
.quiz-step .unsure-radio:checked::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    background: #fff;
    border-radius: 50%
}

.quiz-step .food-label {
    font-size: 14px;
    color: #374151;
    display: block;
    margin-top: 4px;
    margin-bottom: 6px;
    line-height: 1.2
}

.quiz-step .unsure-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    position: relative;
    justify-content: flex-end
}

.quiz-step .unsure-label {
    font-family: "Noto Sans";
    font-size: 14px;
    font-weight: 500;
    color: #6b7280;
    cursor: pointer
}

.quiz-step .unsure-radio {
    width: 18px;
    height: 18px;
    border: 2px solid #d1d5db;
    border-radius: 50%;
    background: #fff;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none
}

.quiz-step .quiz-navigation {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-top: auto;
    padding: 20px 0;
    border-top: 1px solid #e5e7eb
}

.quiz-step .btn-back {
    border-radius: 6px;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, .08);
    padding: 12px 18px;
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    cursor: pointer;
    transition: background-color .3s
}

.quiz-step .question-header {
    background: var(--Blue-100, #e0ecfd);
    color: var(--Blue-700, #1751aa);
    border: 1px solid var(--Blue-400, #83b1f9);
    margin-bottom: 22px
}

.quiz-step .btn-back:hover {
    background-color: #d8d8d8
}

.quiz-step .radio-options {
    display: flex;
    gap: 12px;
    flex-wrap: wrap
}

.quiz-step .radio-option {
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer
}

.quiz-step .radio-option:hover {
    border-color: #4a84dd
}

.quiz-step .radio-option input[type=radio] {
    appearance: none;
    -webkit-appearance: none;
    flex-shrink: 0
}

.quiz-step .radio-option label {
    cursor: pointer;
    flex: 1;
    color: #000;
    font-family: Poppins;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

.signup-image {
    padding: 20px;
    object-fit: contain;
    max-width: calc(100% - 40px);
    max-height: calc(100% - 40px);
    margin: auto
}

.signup-container .image-section {
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center
}

.quiz-step.completed {
    max-width: 100%;
    margin-bottom: 0
}

.quiz-step .question-container {
    margin-bottom: 32px
}

.quiz-step .question-header {
    border-radius: 12px;
    border: 1px solid var(--Blue-400, #83b1f9);
    padding: 12px 16px;
    font-family: Poppins;
    font-size: 18px;
    font-style: italic;
    font-weight: 600;
    line-height: normal
}

.hero-section-landing .hero-title-landing,
.plan-inclusion-section .feature-title,
.plan-inclusion-section .title {
    font-family: Poppins, sans-serif;
    text-transform: uppercase
}

.quiz-step .radio-options {
    display: flex;
    gap: 6px;
    justify-content: space-between;
    flex-wrap: wrap
}

.quiz-step .radio-option {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 6px 0
}

.quiz-step .radio-option input[type=radio] {
    width: 18px;
    height: 18px;
    border: .5px solid #898989;
    border-radius: 50%;
    background: #fff;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    transition: .3s;
    flex-shrink: 0
}

.quiz-step .radio-option input[type=radio]:checked {
    background: #fff;
    border-radius: 50%;
    border: 5px solid #4a84dd
}

.quiz-step .radio-option input[type=radio]:checked::after {
    content: "";
    content: "";
    display: none;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    background: #fff;
    border-radius: 50%
}

#step-9.quiz-step .radio-option label {
    color: #000;
    font-family: Poppins;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

#loginModalathlete .phone-input-container,
#quizModal .phone-input-container,
#signupModalathlete .phone-input-container {
    display: flex;
    align-items: center;
    border-radius: 6px;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    box-shadow: 0 1px 4px 0 rgba(0, 0, 0, .08);
    padding: 16px;
    width: 100%;
    position: relative
}

#loginModalathlete .phone-input-container .dropdown-wrapper,
#quizModal .phone-input-container .dropdown-wrapper,
#signupModalathlete .phone-input-container .dropdown-wrapper {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    position: relative
}

#loginModalathlete .phone-input-container .arrow,
#quizModal .phone-input-container .arrow,
#signupModalathlete .phone-input-container .arrow {
    color: #666;
    transition: transform .3s;
    display: inline-block;
    margin-left: 8px;
    width: 12px;
    height: 8px
}

#loginModalathlete .phone-input-container .dropdown-wrapper:hover .arrow,
#quizModal .phone-input-container .dropdown-wrapper:hover .arrow,
#signupModalathlete .phone-input-container .dropdown-wrapper:hover .arrow {
    color: #1751aa
}

#loginModalathlete .phone-input-container .dropdown-wrapper.active .arrow,
#quizModal .phone-input-container .dropdown-wrapper.active .arrow,
#signupModalathlete .phone-input-container .dropdown-wrapper.active .arrow {
    transform: rotate(180deg);
    color: #1751aa
}

#loginModalathlete .phone-input-container .phone-input,
#quizModal .phone-input-container .phone-input,
#signupModalathlete .phone-input-container .phone-input {
    border: none;
    outline: 0;
    flex: 1;
    margin-left: 10px
}

#loginModalathlete .phone-input-container .dropdown,
#quizModal .phone-input-container .dropdown,
#signupModalathlete .phone-input-container .dropdown {
    position: absolute;
    top: 59px;
    left: -1px;
    width: 100%;
    background: #fff;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    border-radius: 6px;
    max-height: 250px;
    overflow-y: auto;
    z-index: 1000;
    box-shadow: 0 1px 4px 0 rgba(0, 0, 0, .08)
}

#loginModalathlete .phone-input-container .dropdown input,
#quizModal .phone-input-container .dropdown input,
#signupModalathlete .phone-input-container .dropdown input {
    width: 100%;
    padding: 6px 10px;
    border: none;
    border-bottom: 1px solid #eee;
    outline: 0
}

#loginModalathlete .phone-input-container #login-country-list li,
#quizModal .phone-input-container #country-list li,
#quizModal .phone-input-container #quiz-phone-country-list li,
#signupModalathlete .phone-input-container #country-list li,
#signupModalathlete .phone-input-container #login-country-list li {
    padding: 8px;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer
}

#loginModalathlete .phone-input-container #country-list li:hover,
#loginModalathlete .phone-input-container #login-country-list li:hover,
#quizModal .phone-input-container #country-list li:hover,
#quizModal .phone-input-container #quiz-phone-country-list li:hover,
#signupModalathlete .phone-input-container #country-list li:hover,
#signupModalathlete .phone-input-container #login-country-list li:hover {
    background: #f5f5f5
}

#loginModalathlete .phone-input-container #login-country-list li.selected,
#quizModal .phone-input-container #country-list li.selected,
#quizModal .phone-input-container #quiz-phone-country-list li.selected,
#signupModalathlete .phone-input-container #country-list li.selected,
#signupModalathlete .phone-input-container #login-country-list li.selected {
    background: #f0f8ff;
    border: 2px solid #4a84dd;
    position: relative
}

#loginModalathlete .phone-input-container #login-country-list li.selected::after,
#quizModal .phone-input-container #country-list li.selected::after,
#quizModal .phone-input-container #quiz-phone-country-list li.selected::after,
#signupModalathlete .phone-input-container #country-list li.selected::after,
#signupModalathlete .phone-input-container #login-country-list li.selected::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translate(0, -50%);
    width: 18px;
    height: 18px;
    background: #4a84dd;
    border-radius: 50%;
    border: 2px solid #4a84dd
}

#loginModalathlete .phone-input-container #login-country-list li.selected::before,
#quizModal .phone-input-container #country-list li.selected::before,
#quizModal .phone-input-container #quiz-phone-country-list li.selected::before,
#signupModalathlete .phone-input-container #country-list li.selected::before,
#signupModalathlete .phone-input-container #login-country-list li.selected::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 19px;
    transform: translate(0, -50%);
    width: 6px;
    height: 6px;
    background: #fff;
    border-radius: 50%;
    z-index: 1
}

#loginModalathlete .terms-label,
#signupModalathlete .terms-label {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    margin-top: 8px
}

#loginModalathlete .terms-label span,
#signupModalathlete .terms-label span {
    color: #4a84dd;
    font-family: "Noto Sans";
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: 24px;
    cursor: pointer
}

#termsModal {
    background-color: #000000cc;
    z-index: 9999
}

#termsModal .terms-link {
    color: #007bff;
    cursor: pointer;
    font-weight: 500
}

#termsModal .terms-link:hover {
    color: #0056b3
}

#termsModal .terms-content {
    max-height: 400px;
    overflow-y: auto;
    padding: 10px
}

#termsModal .terms-content h4 {
    color: #333;
    margin-top: 20px;
    margin-bottom: 10px;
    font-size: 16px;
    font-weight: 600
}

#termsModal .terms-content p {
    color: #666;
    line-height: 1.6;
    margin-bottom: 15px
}

#termsModal .modal-header {
    border-bottom: 1px solid #dee2e6;
    padding: 1rem 1.5rem
}

#termsModal .modal-footer {
    border-top: 1px solid #dee2e6;
    padding: 1rem 1.5rem
}

.homepage-navbar .dropdown-menu.show {
    margin-top: 0 !important;
    padding-left: 10px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .1) !important
}

.sports-select-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%
}

.sports-select {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #ccc;
    border-radius: 6px;
    background: #fff;
    font-size: 14px;
    color: #333;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer
}

.hero-section-landing,
.plan-inclusion-section {
    background-size: cover;
    background-repeat: no-repeat;
    display: flex;
    overflow: hidden
}

.sports-select:focus {
    outline: 0;
    border-color: #1751aa
}

.sports-arrow {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #666;
    transition: transform .3s;
    pointer-events: none;
    width: 12px;
    height: 8px
}

.phone-vertical-line {
    position: absolute;
    top: 50%;
    right: 40px;
    transform: translate(-50%, -63%)
}

.hero-section-landing {
    position: relative;
    height: 580px;
    align-items: center
}

.hero-section-landing .hero-section::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(0, 0, 0, .4) 0, rgba(0, 0, 0, .2) 100%);
    z-index: 1
}

.hero-section-landing .hero-section .container-homepage {
    position: relative;
    z-index: 2;
    height: 100%;
    display: flex;
    align-items: center
}

.hero-section-landing .hero-title-landing {
    color: #fff;
    text-shadow: 0 4px 12px rgba(0, 0, 0, .25);
    font-size: 56px;
    font-style: italic;
    font-weight: 900;
    line-height: 64px;
    margin-bottom: 16px;
    text-align: left
}

.about-section.training-nutrition-landing .about-content-wrapper,
.wizard-inner a:first-child:after {
    width: 50%
}

.about-section.training-nutrition-landing .about-image {
    object-fit: contain;
    object-position: bottom;
    border-radius: 0
}

.about-section.training-nutrition-landing {
    margin: 80px 0 0;
    min-height: 635px
}

.about-section.training-nutrition-landing .about-image-container {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 24px;
    width: 50%;
    overflow: hidden;
    z-index: 1;
    max-width: 644px
}

.plan-inclusion-section {
    position: relative;
    padding: 80px 0;
    background-image: url(images/training-nutrition-plan-landing/overlay-bg.webp);
    background-position: center;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start
}

.plan-inclusion-section .title-content {
    position: relative;
    z-index: 2;
    color: #fff
}

.plan-inclusion-section .title {
    color: var(--White, #fff);
    text-align: left;
    font-size: 48px;
    font-style: italic;
    font-weight: 800;
    line-height: normal;
    margin-bottom: 4px
}

.plan-inclusion-section .plan-features {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
    margin-top: 36px
}

.plan-inclusion-section .feature-column {
    text-align: left;
    color: #fff
}

.plan-inclusion-section .feature-title {
    color: var(--White, #fff);
    font-size: 22px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px
}

.plan-inclusion-section .feature-list {
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: left
}

.plan-inclusion-section .feature-list li {
    color: var(--White, #fff);
    font-family: "Noto Sans";
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin-bottom: 12px;
    color: #fff;
    position: relative;
    padding-left: 20px
}

.plan-inclusion-section .feature-list li:before {
    content: "\2022";
    position: absolute;
    left: 0;
    color: #fff;
    font-weight: 700
}

.plan-inclusion-section .pricing-section {
    position: relative;
    z-index: 2;
    text-align: left;
    color: #fff;
    margin-top: 24px
}

.plan-inclusion-section .pricing-amount,
.plan-inclusion-section .pricing-text {
    font-family: Poppins, sans-serif;
    color: var(--White, #fff);
    font-style: normal;
    line-height: 36px
}

.plan-inclusion-section .pricing-text {
    font-size: 18px;
    font-weight: 600
}

.plan-inclusion-section .pricing-amount {
    font-size: 48px;
    font-weight: 700;
    margin-bottom: 24px
}

.plan-inclusion-section .pricing-buttons {
    display: flex;
    gap: 16px;
    justify-content: flex-start
}

.recommended-plans-section {
    padding: 80px 0;
    text-align: center
}

.recommended-plans-section .section-title {
    font-size: 2.5em;
    font-weight: 800;
    margin-bottom: 10px;
    color: #333;
    letter-spacing: -.02em
}

.recommended-plans-section .section-subtitle {
    font-size: 1.1em;
    color: #666;
    margin-bottom: 50px
}

#paymentModal .modal-title,
#paymentModalPlan .modal-title,
.recommended-plans-section .card-title {
    font-size: 24px;
    font-weight: 700;
    font-family: "Noto Sans"
}

#paymentModal .modal-title,
#paymentModalPlan .modal-title,
.recommended-plans-section .card-description,
.recommended-plans-section .card-title {
    color: var(--Kerry-grey-700, #080808);
    font-style: normal;
    line-height: normal
}

.recommended-plans-section .cards-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px
}

.recommended-plans-section .card {
    padding: 20px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    position: relative;
    overflow: hidden;
    width: 100%;
    box-sizing: border-box;
    border-radius: 12px;
    background: linear-gradient(231deg, var(--Kerry-grey---ultra-light, #e5eaf4) 9.49%, #b4d1ff 72.32%);
    box-shadow: 0 2px 12px 0 rgba(0, 0, 0, .12);
    border: none;
    min-height: 320px
}

.recommended-plans-section .card-title {
    margin-bottom: 12px
}

.recommended-plans-section .card-description {
    font-family: "Noto Sans";
    font-size: 18px;
    font-weight: 400;
    flex-grow: 1
}

.recommended-plans-section .card-image {
    display: block;
    object-fit: cover;
    position: absolute;
    z-index: 0
}

.recommended-plans-section .left-card-image,
.recommended-plans-section .right-card-image {
    bottom: 0;
    right: 0;
    width: 219px;
    height: 246px;
    border-radius: 10px 0 0
}

.recommended-plans-section .card:not(.right-card) .card-description {
    padding-right: 250px
}

.recommended-plans-section .right-card .card-description {
    padding-right: 260px
}

.plan-injury {
    display: flex;
    gap: 24px;
    justify-content: space-between
}

.pricing-right-section {
    width: 22%;
    color: #fff
}

.plan-inclusion-section .plan-features.consultations {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    margin-top: 36px
}

.plan-inclusion-section .plan-features.consultations .feature-column {
    border-radius: 8px;
    border: 1px solid var(--White, #fff);
    padding: 28px 24px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start
}

.plan-inclusion-section .plan-features.consultations .feature-column .pricing-section {
    margin-top: 31px
}

.label-title {
    color: #fff;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    margin-bottom: 8px;
    padding-top:20px;
    padding-bottom:20px;
}

.plan-inclusion-section .plan-features.consultations .feature-column .divider-line {
    flex-grow: 1;
    border-top: 1px solid #fff
}

.plan-inclusion-section .plan-features.consultations .feature-column .or-text {
    margin-left: 1rem;
    margin-right: 1rem;
    color: #fff;
    font-size: 1rem
}

.slider-container-plan {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center
}

.slider-wrapper-consult {
    overflow: hidden;
    position: relative;
    flex: 1
}

.slider-track {
    display: flex;
    transition: transform .3s
}

.slider-track .card {
    flex: 0 0 48%;
    min-width: 48%;
    margin: 0 15px
}

.slider-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    border: none;
    background: #fff;
    box-shadow: 0 4px 10px rgba(0, 0, 0, .15);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    cursor: pointer;
    z-index: 10
}

.slider-arrow.left-arrows {
    left: -50px;
    font-size: 16px
}

.slider-arrow.right-arrows {
    right: -50px;
    font-size: 16px
}

#congratsModalConsultation .modal-content,
#paymentModal .modal-content,
#paymentModalPlan .modal-content,
#planChooseModal .modal-content {
    max-width: 700px
}

#paymentModal .modal-body .modal-subtitle,
#paymentModalPlan .modal-body .modal-subtitle {
    color: var(--Kerry-grey-700, #080808);
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

#paymentModal .modal-body .amount,
#paymentModalPlan .modal-body .amount,
#planChooseModal .modal-body .amount {
    color: var(--Blue-700, #1751aa);
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    text-align: left;
    margin-bottom: 0
}

#paymentModal .modal-body .amount strong,
#paymentModalPlan .modal-body .amount strong,
#planChooseModal .modal-body .amount strong {
    font-size: 18px;
    font-weight: 500
}

#paymentModal .modal-body .divider,
#paymentModalPlan .modal-body .divider,
#planChooseModal .modal-body .divider {
    display: block;
    height: 1px;
    width: 100%;
    background: var(--Kerry-grey-200, #d8d8d8);
    margin: 16px 0
}

#congratsModal .congrats-subtitle,
#paymentModal .congrats-subtitle,
#paymentModal .modal-body .sign-in-text,
#paymentModalPlan .modal-body .sign-in-text,
#planChooseModal .modal-body .sign-in-text {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-family: "Noto Sans";
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

#paymentModal .modal-body .sign-in-text strong,
#planChooseModal .modal-body .sign-in-text strong {
    font-size: 14px;
    font-weight: 600
}

#paymentModal .modal-body .coupon-code,
#paymentModalPlan .modal-body .coupon-code {
    color: var(--Blue-600, #4a84dd);
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal
}

#paymentModal .modal-body form .form-wrap,
#paymentModalPlan .modal-body form .form-wrap,
#planChooseModal .modal-body form .form-wrap {
    border-radius: 12px;
    background: rgba(235, 235, 235, .5);
    padding: 12px;
    margin-bottom: 16px
}

#paymentModal .modal-body form input #planChooseModal .modal-body form input,
#paymentModalPlan .modal-body form input {
    border-radius: 6px;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    box-shadow: 0 1px 4px 0 rgba(0, 0, 0, .06);
    padding: 12px
}

#paymentModal .congrats-para,
#paymentModal .modal-body .confirm-text,
#planChooseModal .congrats-para,
#planChooseModal .modal-body .confirm-text {
    color: var(--kerry-grey-600-main, #3b3b3b);
    text-align: center;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

#paymentModal .modal-body .terms-link,
#paymentModalPlan .modal-body .terms-link,
#planChooseModal .modal-body .terms-link {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    text-underline-position: from-font
}

#congratsModal .modal-dialog {
    max-width: 500px
}

#congratsModalConsultation .btn-close.congrats-modal,
#congratsModalPlan .btn-close.congrats-modal,
#paymentModal .btn-close.congrats-modal {
    position: absolute;
    top: 16px;
    right: 16px;
    border-radius: 100px;
    background: var(--White, #fff);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999
}

#congratsModal .congrats-title,
#paymentModal .congrats-title {
    color: var(--Kerry-grey-700, #080808);
    text-align: center;
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: normal
}

#congratsModal .congrats-subtitle strong,
#paymentModal .congrats-subtitle strong,
#paymentModal .congrats-title strong,
#planChooseModal .congrats-title strong {
    font-weight: 600
}

#monthlyPlans .card-body h6,
#onePaymentPlans .card-body h6,
#planChooseModal .modal-title {
    color: var(--Kerry-grey-700, #080808);
    font-weight: 700;
    line-height: normal;
    font-style: normal
}

.hero-section-landing.consultations {
    background-position: top
}

.w-fit {
    width: fit-content !important
}

.payment-toggle-swich {
    display: flex;
    justify-content: center;
    border-radius: 100px;
    background-color: #ebebeb
}

.toggle-btn {
    background-color: transparent;
    border: none;
    outline: 0;
    padding: 10px 24px;
    border-radius: 100px
}

.badge-discount,
.popular-badge {
    text-align: center;
    padding: 3px 5px;
    font-size: 10px;
    font-weight: 600;
    line-height: normal;
    position: absolute;
    top: -10px;
    font-style: normal
}

.toggle-btn.active {
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    background: var(--White, #fff);
    box-shadow: 0 2px 4px 0 rgba(0, 0, 0, .08);
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal
}

.badge-discount {
    border-radius: 100px;
    background: var(--Orange-600, #ef7f00);
    color: #fff;
    color: var(--White, #fff);
    left: -10px
}

#planChooseModal .modal-title {
    text-align: center;
    font-size: 24px;
    margin-bottom: 24px
}

#monthlyPlans .card-body,
#onePaymentPlans .card-body {
    border-radius: 12px;
    border: 1px solid var(--Cloud-100, #e5eaf4);
    background: var(--White, #fff);
    box-shadow: 0 2px 6px 0 rgba(0, 0, 0, .08);
    padding: 12px
}

#monthlyPlans .card-body h6,
#onePaymentPlans .card-body h6 {
    font-size: 18px
}

#monthlyPlans .card-body span,
#onePaymentPlans .card-body span {
    color: var(--Blue-700, #1751aa);
    text-align: center;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: normal
}

#monthlyPlans .card-body small,
#onePaymentPlans .card-body small {
    color: var(--Blue-700, #1751aa);
    text-align: center;
    font-size: 11px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

#monthlyPlans .card-body p,
#onePaymentPlans .card-body p {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    margin-bottom: 12px
}

#monthlyPlans .card-body a,
#onePaymentPlans .card-body a {
    color: var(--kerry-grey-600-main, #3b3b3b);
    font-size: 13px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 4px
}

.popular-badge {
    border-radius: 100px;
    background: var(--Blue-100, #e0ecfd);
    color: var(--Blue-800, #003891);
    left: 18px
}

@media (max-width:1200px) {
    .multi-item-carousel {
        max-width: 900px
    }

    .food-section .food-card {
        width: 300px;
        height: 300px
    }

    .about-section .about-content-wrapper {
        gap: 40px;
        max-width: 1000px
    }

    .about-section .about-text-content {
        max-width: 450px
    }

    .recommended-plans-section .cards-wrapper {
        display: grid;
        grid-template-columns: 1fr;
        gap: 24px
    }
}

@media (max-width:1024px) {
    body {
        padding-top: 0 !important
    }

    .sport-nutrition-promo__container {
        flex-direction: column;
        min-height: 0
    }

    .sport-nutrition-promo__half {
        height: 100%;
        min-height: 466px
    }

    .sport-nutrition-promo__half--left,
    .sport-nutrition-promo__half--right {
        padding: 48px 16px
    }

    .sport-nutrition-promo__form {
        display: flex;
        gap: 16px;
        background-color: transparent;
        width: 100%;
        padding: 0;
        border-radius: 6px;
        margin-bottom: 24px;
        flex-direction: column;
        max-width: 100vw;
        overflow: hidden;
        box-sizing: border-box
    }

    .sport-nutrition-promo__content {
        max-width: 100%
    }

    .plan-inclusion-section .plan-features {
        grid-template-columns: repeat(2, 1fr);
        gap: 30px;
        grid-template-columns: 1fr;
        gap: 40px;
        margin-bottom: 40px
    }

    .recommended-plans-section .card {
        width: 100%;
        padding: 30px;
        min-height: 300px
    }

    .hero-section-landing {
        height: 480px
    }

    .plan-inclusion-section .feature-subtitle,
    .plan-inclusion-section .feature-title {
        font-size: 16px
    }

    .plan-inclusion-section .feature-list li {
        font-size: 13px
    }

    .plan-inclusion-section .pricing-amount {
        font-size: 36px;
        margin-bottom: 24px
    }

    .recommended-plans-section .card:not(.right-card) .card-description,
    .recommended-plans-section .card:not(.right-card) .card-title,
    .recommended-plans-section .right-card .card-description,
    .recommended-plans-section .right-card .card-title {
        padding-right: 0
    }

    .recommended-plans-section .card-image {
        display: none
    }

    .recommended-plans-section .section-title {
        font-size: 2em
    }

    .recommended-plans-section .card-title {
        font-size: 1.5em
    }

    .recommended-plans-section .card-description {
        font-size: .9em
    }
}

@media (min-width:768px) and (max-width:991.98px) {
    .testimonial-section .testimonial-card {
        padding: 2.5rem
    }

    .testimonial-section .testimonial-image-wrapper {
        width: 200px;
        height: 200px
    }

    .testimonial-section .carousel-control-prev {
        left: -50px
    }

    .testimonial-section .carousel-control-next {
        right: -50px
    }

    .partners-section .section-title {
        font-size: 2.2rem
    }

    .partners-section .logo-card {
        width: 180px;
        height: 90px;
        margin-right: 25px
    }
}

@media (max-width:767px) {
    .sport-nutrition-promo__half {
        height: 466px
    }

    .sport-nutrition-promo__half--right {
        height: 366px;
        min-height: 366px
    }
}

@media (max-width:768px) {
    .sport-nutrition-promo__form select[data-custom=true] {
        font-size: 16px !important;
        padding: 14px 16px !important
    }

    .sport-nutrition-promo__form select[data-custom=true]::-webkit-listbox {
        max-height: 60vh !important;
        overflow-y: auto !important;
        padding: 8px !important;
        border-radius: 6px !important;
        border: 1px solid #ddd !important;
        background-color: #fff !important
    }

    .sport-nutrition-promo__form select[data-custom=true]::-webkit-option {
        padding: 10px 16px !important;
        font-size: 14px !important;
        line-height: 1.4 !important;
        min-height: 40px !important;
        margin: 2px 0 !important;
        border-radius: 4px !important
    }

    .sport-nutrition-promo__form select[data-custom=true] option {
        padding: 10px 16px !important;
        font-size: 14px !important;
        line-height: 1.4 !important;
        min-height: 40px !important
    }

    .sport-nutrition-promo__form select[data-custom=true]:focus {
        max-height: none !important
    }

    .sport-nutrition-promo__form select[data-custom=true]:focus::-webkit-listbox {
        max-height: 60vh !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        line-height: 1.4 !important;
        min-height: 40px !important
    }

    .plan-inclusion-section .plan-features.consultations {
        grid-template-columns: repeat(1, 1fr)
    }

    .slider-track .card {
        flex: 0 0 calc(100% - 40px);
        min-width: calc(100% - 40px);
        margin: 0 20px
    }

    .slider-arrow {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        border: none;
        background: #fff;
        box-shadow: 0 4px 10px rgba(0, 0, 0, .15);
        border-radius: 50%;
        width: 24px;
        height: 24px;
        cursor: pointer;
        z-index: 10
    }

    .slider-arrow.left-arrows {
        left: -8px
    }

    .slider-arrow.right-arrows {
        right: -8px
    }

    .pricing-right-section {
        width: 100%
    }

    .custom-select-arrow {
        right: 12px
    }

    .btn-login {
        font-size: 14px;
        padding: 7px 20px;
        height: 43px
    }

    #quizModal .signup-container .signup-modal,
    .navbar .container,
    .navbar-toggler,
    .signup-container .form-section,
    .signup-container .image-section {
        padding: 0
    }

    .signup-container.quiz-container .close-button {
        top: 23px;
        right: 12px;
        padding: 6px
    }

    .user-type-box {
        position: relative;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
        padding: 16px;
        border: 1px solid #d1d5db;
        border-radius: .5rem;
        background-color: #fff;
        cursor: pointer;
        transition: border-color .2s ease-in-out, box-shadow .2s ease-in-out;
        flex: 1
    }

    .mob-btn-wrap {
        display: flex;
        justify-content: flex-end;
        align-items: center;
        gap: 16px
    }

    .homepage-navbar .navbar-brand img {
        width: 142px;
        height: 30px
    }

    .hero-content-fixed {
        left: 20px;
        max-width: calc(100% - 40px)
    }

    .hero-title-homepage {
        font-size: 48px;
        line-height: 46px
    }

    .hero-subtitle-homepage {
        font-size: 1rem
    }

    .homepage-navbar .navbar-nav {
        text-align: center;
        margin: 20px 0;
        overflow: auto;
        max-height: 430px
    }

    .homepage-navbar .navbar-nav .nav-link {
        margin: 5px 0;
        text-align: left;
        font-size: 18px
    }

    .homepage-navbar .dropdown-menu.show {
        box-shadow: none !important;
        margin-top: 0 !important;
        padding-left: 10px !important
    }

    .homepage-navbar .dropdown-menu {
        background: 0 0 !important;
        border: none !important;
        border-radius: 8px !important;
        padding: 0 !important;
        box-shadow: none !important;
        margin-top: 0 !important
    }

    .homepage-navbar .dropdown-item {
        color: #ebebeb;
        font-family: "Noto Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
        padding: 8px 0;
        font-size: 16px;
        text-align: left
    }

    .navbar-collapse {
        flex-basis: 100%;
        flex-grow: 1;
        align-items: center;
        background-color: #3b3b3b;
        padding: 24px 16px;
        transition: .3s
    }

    .bars-icon,
    .cross-icon {
        width: 32px;
        height: 22px;
        transition: opacity .3s
    }

    .homepage-navbar.navbar-custom {
        background-color: transparent;
        padding: 16px;
        transition: background-color .3s
    }

    .navbar-toggler:focus {
        box-shadow: none
    }

    .menu-icon {
        position: relative;
        display: inline-block
    }

    .bars-icon,
    .chat-widget.mobile-view.web-hide,
    .footer-bg .contact-mobile,
    .navbar-collapse.show .menu-icon .cross-icon,
    .navbar-collapse:not(.show) .menu-icon .bars-icon,
    .web-hide {
        display: block
    }

    .cross-icon,
    .mob-hide,
    .navbar-collapse.show .menu-icon .bars-icon,
    .navbar-collapse:not(.show) .menu-icon .cross-icon {
        display: none
    }

    .homepage-navbar.navbar-custom.menu-open,
    .navbar-collapse.show+.navbar-custom,
    .navbar-collapse.show~.navbar-custom {
        background-color: #3b3b3b !important
    }

    .chat-widget {
        bottom: 10px;
        right: 10px;
        padding: 10px 15px
    }

    .why-it-works-section .feature-item {
        border-bottom: 1px solid rgba(255, 255, 255, .2);
        padding-bottom: 16px
    }

    .why-it-works-section .feature-content h3 {
        color: var(--White, #fff);
        margin-bottom: 8px;
        font-size: 16px;
        font-style: normal;
        font-weight: 700;
        line-height: 26px
    }

    .why-it-works-section .feature-content p {
        color: var(--Kerry-grey-100, #ebebeb);
        font-family: "Noto Sans";
        font-size: 13px;
        font-style: normal;
        font-weight: 400;
        line-height: normal
    }

    .why-it-works-section .feature-icon {
        color: #4a9eff;
        font-size: smaller;
        margin-top: .2rem;
        flex-shrink: 0
    }

    .food-section .food-title {
        font-size: 32px;
        line-height: 38px;
        margin-bottom: 8px
    }

    .choose-plan-section .card-text,
    .food-section .food-subtitle,
    .quiz-step .radio-option label,
    .quiz-step.radio-option label {
        font-size: 14px
    }

    .food-section .food-carousel-container {
        max-width: 100%;
        padding: 0 20px;
        overflow: hidden
    }

    .food-section .food-card {
        width: 280px;
        height: 280px;
        margin: 0 5px
    }

    .why-it-works-section .feature-grid {
        grid-template-columns: 1fr;
        gap: 16px;
        padding-top: 16px;
        border-top: 1px solid rgba(255, 255, 255, .2)
    }

    .why-it-works-section h1 {
        font-size: 30px
    }

    .why-it-works-section .nav-tabs .nav-link {
        font-size: 18px;
        margin-right: 24px
    }

    .choose-plan-section .col-md-4:last-child,
    .why-it-works-section .nav-tabs .nav-link:last-of-type {
        margin-right: 0
    }

    .why-it-works-section .nav-tabs {
        margin-bottom: 16px
    }

    .why-it-works-section .tab-description {
        font-size: 16px;
        margin-bottom: 36px
    }

    .about-content-wrapper {
        flex-direction: column;
        gap: 30px;
        text-align: center
    }

    .about-section .about-text-content {
        max-width: 100%;
        margin-right: 0;
        text-align: left
    }

    .about-section .container {
        padding: 0 20px
    }

    .about-section .about-image-container {
        position: relative;
        top: unset;
        right: unset;
        width: 100%;
        max-width: 100%;
        padding: 0 20px;
        margin: 30px auto;
        height: auto;
        overflow: visible
    }

    .about-section .about-image {
        display: block;
        width: 100%;
        height: auto;
        border-radius: 12px
    }

    .choose-plan-section .choose-plan-title {
        font-size: 36px
    }

    .choose-plan-section .card-title,
    .choose-plan-section .choose-plan-subtitle,
    .testimonial-section .author-name {
        font-size: 16px
    }

    .choose-plan-section .choose-plan-label {
        display: block;
        color: var(--kerry-grey-600-main, #3b3b3b);
        font-family: "Noto Sans";
        font-size: 14px;
        font-style: normal;
        font-weight: 700;
        line-height: normal;
        text-align: left;
        margin-bottom: 8px
    }

    .choose-plan-section .row {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 20px;
        scrollbar-width: none;
        -ms-overflow-style: none
    }

    .choose-plan-section .row::-webkit-scrollbar {
        display: none
    }

    .choose-plan-section .col-md-4 {
        flex: 0 0 auto;
        min-width: 310px;
        max-width: 310px
    }

    .choose-plan-section .plan-card {
        min-height: 365px;
        margin-bottom: 0;
        transition: none;
        padding: 16px
    }

    .footer-bg .buttons-desktop,
    .footer-bg .contact-desktop,
    .testimonial-section .quote-icon.web {
        display: none
    }

    .testimonial-section .quote-icon.mobile {
        margin-top: 24px;
        margin-bottom: 0;
        display: inline-block
    }

    .testimonial-section .quote-icon.mobile svg {
        margin-top: -15px;
        width: 24px;
        height: 24px
    }

    .testimonial-section .section-title {
        text-align: center !important;
        font-size: 2rem;
        margin-bottom: 2rem
    }

    .testimonial-section .testimonial-card {
        flex-direction: column;
        padding: 0;
        min-height: auto
    }

    .testimonial-section .testimonial-image-wrapper {
        margin-bottom: 0 !important;
        margin-right: 0 !important;
        width: 100%;
        height: 272px
    }

    .testimonial-section .testimonial-image-wrapper img {
        object-position: top
    }

    .testimonial-section .testimonial-content {
        text-align: center !important
    }

    .testimonial-section .quote-text {
        font-size: 16px;
        margin-bottom: 16px;
        padding: 16px
    }

    .testimonial-section .author-title {
        font-size: 12px
    }

    .testimonial-section .carousel-control-next,
    .testimonial-section .carousel-control-prev {
        display: none !important
    }

    .testimonial-section .carousel-controls-mobile {
        display: flex !important
    }

    .partners-section .section-title {
        text-align: left !important;
        color: var(--White, #fff);
        font-family: Poppins;
        font-size: 30px;
        font-style: italic;
        font-weight: 800;
        line-height: 38px;
        text-transform: uppercase;
        margin-bottom: 16px !important
    }

    .partners-section .logo-card {
        width: 387px;
        height: 104px;
        margin-right: 12px;
        padding: 0 12px;
        flex-shrink: 0
    }

    .partners-section .logo-row {
        margin-bottom: 10px;
        display: flex;
        gap: 0;
        overflow: hidden;
        width: max-content
    }

    .partners-section .slide-left,
    .partners-section .slide-right {
        animation-duration: 35s;
        animation-timing-function: linear;
        animation-iteration-count: infinite
    }

    .contact-form-wrapper {
        padding: 3rem;
        width: 100%
    }

    .footer-bg .nav-links {
        display: flex;
        flex-direction: row;
        gap: 30px 50px;
        flex-wrap: wrap
    }

    .footer-bg .footer-grid {
        display: flex;
        flex-direction: column;
        gap: 2rem
    }

    .footer-bg .buttons-mobile {
        display: flex;
        flex-direction: row-reverse;
        gap: 1rem;
        margin-top: 0;
        justify-content: flex-end
    }

    .footer-bg .tagline {
        margin: 16px 0;
        white-space: break-spaces
    }

    .footer-bg .copyright-text {
        margin-top: 0
    }

    .signup-container .welcome-title,
    .welcome-title {
        font-size: 1.5rem
    }

    .signup-container.quiz-container .welcome-title {
        margin-top: 0;
        font-size: 28px !important;
        line-height: 39px !important
    }

    .signup-container .welcome-title.steps {
        margin-top: 24px
    }

    .signup-container .login-link-text {
        margin-top: 24px !important
    }

    .signup-container .signup-modal {
        flex-direction: column-reverse;
        padding: 0
    }

    .signup-container .form-section {
        padding: 24px 16px
    }

    .signup-container .image-section img {
        max-height: 300px !important;
        object-position: top
    }

    .otp-input-group {
        gap: 12px
    }

    .signup-container .otp-input {
        width: 50px;
        height: 50px;
        padding: 12px
    }

    .user-type-selection {
        flex-direction: column;
        gap: 1rem
    }

    .quiz-step .food-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px
    }

    .quiz-step .food-image-container {
        height: 280px;
        padding: 8px;
        justify-content: flex-end
    }

    .quiz-step#step-6 .food-image-container,
    .quiz-step#step-7 .food-image-container,
    .quiz-step#step-8 .food-image-container {
        height: 200px
    }

    .quiz-step.food-placeholder {
        width: 40px;
        height: 40px;
        font-size: 24px
    }

    .quiz-step.food-label {
        font-size: 12px;
        margin-top: 32px;
        margin-bottom: 12px
    }

    .quiz-step.question-header,
    .quiz-step.step-instruction {
        font-size: 14px;
        padding: 10px 12px
    }

    .quiz-step.quiz-navigation,
    .signup-container .signup-modal .form-section-content.steps.quiz {
        padding: 16px
    }

    .quiz-step.btn-back,
    .quiz-step.next-step-btn {
        width: max-content
    }

    .quiz-step.unsure-option {
        bottom: 0;
        right: 16px;
        padding: 8px 12px
    }

    .quiz-step.radio-option {
        padding: 10px 12px
    }

    .signup-container .signup-modal .form-section-content.steps {
        min-height: 250px
    }

    .quiz-step .quiz-final-container {
        flex-direction: column
    }

    .quiz-step .quiz-final-left {
        padding: 0 0 24px !important
    }

    .quiz-step .quiz-final-left h2 {
        width: 95%
    }

    .navbar-collapse .dropdown-menu {
        position: static !important;
        float: none !important;
        margin: 0 !important;
        border: none !important;
        box-shadow: none !important;
        background: 0 0 !important;
        padding: 0 !important;
        max-height: none !important;
        overflow: visible !important
    }

    .navbar-collapse .dropdown-item {
        padding: 8px 0 !important;
        color: #ebebeb !important;
        background: 0 0 !important;
        border: none !important
    }

    .navbar-collapse .dropdown-item:focus,
    .navbar-collapse .dropdown-item:hover {
        background: rgba(255, 255, 255, .1) !important;
        color: #fff !important
    }
}

@media (max-width:480px) {
    .sport-nutrition-promo__form select[data-custom=true] {
        max-height: 40vh !important;
        overflow-y: auto !important
    }

    .sport-nutrition-promo__form select[data-custom=true] option {
        padding: 8px 16px !important;
        font-size: 13px !important;
        line-height: 1.3 !important;
        min-height: 36px !important
    }

    .sport-nutrition-promo__form select[data-custom=true]::-webkit-option {
        padding: 8px 16px !important;
        font-size: 13px !important;
        line-height: 1.3 !important;
        min-height: 36px !important
    }

    .about-section.training-nutrition-landing.consultations {
        padding-bottom: 48px
    }

    .hero-section-landing.consultations {
        background-position: 70% center
    }

    .otp-input-group svg,
    .vertical-line {
        display: none
    }

    .quiz-step .radio-options {
        display: flex;
        gap: 0 12px;
        justify-content: center;
        flex-wrap: wrap;
        margin-bottom: 10px;
        margin-top: 5px
    }

    #congratsModalConsultation .modal-content,
    #congratsModalPlan .modal-content,
    #loginModalathlete .modal-content,
    #paymentModal .modal-content,
    #paymentModalPlan .modal-content,
    #planChooseModal .modal-content,
    #quizModal .modal-content,
    #signupModalathlete .modal-content {
        max-height: 80vh
    }

    #congratsModalConsultation .modal-content #congratsContentConsultation,
    #congratsModalPlan .modal-content #congratsContentPlan,
    #paymentModal .modal-content #paymentContentConsultation,
    #paymentModalPlan .modal-content #congratsContentConsultation,
    #planChooseModal .modal-content .modal-body {
        height: 100%;
        overflow-y: auto;
        padding-top: 20px !important
    }

    #congratsModalConsultation .modal-content #congratsContentConsultation,
    #paymentModalPlan .modal-content #congratsContentConsultation {
        border-radius: 10px
    }

    #congratsModalConsultation .modal-content #congratsContentConsultation,
    #congratsModalPlan .modal-content #congratsContentPlan {
        padding-top: 0 !important
    }

    .phone-vertical-line {
        position: absolute;
        top: 61%;
        right: 20px;
        transform: translate(-50%, -63%)
    }

    .btn-signup,
    .btn-white {
        width: max-content;
        font-size: 14px
    }

    .about-section,
    .about-section.training-nutrition-landing,
    .choose-plan-section,
    .food-section,
    .plan-inclusion-section,
    .testimonial-section,
    .why-it-works-section {
        padding-top: 48px;
        padding-bottom: 48px
    }

    .about-section {
        margin: 0;
        padding-top: 48px;
        padding-bottom: 120px
    }

    .hero-title-homepage {
        font-size: 36px;
        line-height: 34px
    }

    .food-section .food-card {
        width: 280px;
        height: 280px;
        margin: 0 5px
    }

    .food-section .food-carousel-track {
        padding: 0 120px
    }

    .carousel-item {
        min-height: 820px
    }

    .about-section .about-content-wrapper {
        gap: 20px
    }

    .about-section .about-title,
    .recommended-plans-section .about-title {
        font-size: 32px;
        line-height: 40px
    }

    .about-section .about-image-container {
        padding: 0 20px;
        margin: 30px auto
    }

    .about-section .about-image {
        border-radius: 8px
    }

    .choose-plan-section .choose-plan-section {
        padding: 60px 0
    }

    .choose-plan-section .choose-plan-title {
        font-size: 30px
    }

    .choose-plan-section .choose-plan-subtitle {
        margin-bottom: 40px
    }

    .choose-plan-section .plan-card,
    .plan-inclusion-section .pricing-text {
        margin-bottom: 0
    }

    .choose-plan-section .col-md-4 {
        min-width: 310px;
        max-width: 310px;
        padding: 0 8px
    }

    .sport-nutrition-promo__title {
        font-size: 30px;
        line-height: 38px
    }

    .sport-nutrition-promo__desc {
        font-size: 14px
    }

    .sport-nutrition-promo__form button,
    .sport-nutrition-promo__form select,
    .sport-nutrition-promo__quiz-btn {
        padding: 14px 16px;
        border-radius: 6px;
        background-color: #fff;
        color: var(--kerry-grey-600-main, #3b3b3b);
        font-family: "Noto Sans";
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: normal;
        min-width: 100%
    }

    .nutrition-quiz-modal {
        max-width: 370px
    }

    .nutrition-quiz-modal__image-container {
        height: 180px
    }

    .partners-section .logo-card {
        width: 296px;
        height: 105px;
        margin-right: 8px;
        padding: 12px
    }

    .hero-section-landing {
        height: 520px;
        background-position: 70% center !important
    }

    .btn-purchase-plan {
        padding: 12px 24px;
        font-size: 14px
    }

    .about-section.training-nutrition-landing .about-image-container {
        position: relative;
        top: unset;
        bottom: 0;
        right: unset;
        width: 100%;
        overflow: hidden;
        z-index: 1;
        margin: 0
    }

    .about-section.training-nutrition-landing .about-content-wrapper {
        width: 100%
    }

    .about-section.training-nutrition-landing {
        margin: 0;
        padding-bottom: 0;
        min-height: max-content
    }

    .plan-inclusion-section .title {
        font-size: 24px;
        line-height: 36px
    }

    .plan-inclusion-section .plan-features {
        gap: 16px;
        margin-bottom: 24px;
        margin-top: 12px
    }

    .plan-inclusion-section .feature-subtitle,
    .plan-inclusion-section .feature-title {
        font-size: 16px
    }

    .plan-inclusion-section .feature-list li {
        font-size: 14px;
        margin-bottom: 8px
    }

    .plan-inclusion-section .pricing-amount {
        font-size: 32px;
        margin-bottom: 20px
    }

    .hero-section-landing .hero-title-landing {
        font-size: 36px;
        line-height: 44px
    }

    .recommended-plans-section {
        padding: 48px 0
    }

    .recommended-plans-section .card {
        padding: 16px;
        min-height: 280px
    }

    .recommended-plans-section .card-logo {
        margin-bottom: 8px
    }

    .recommended-plans-section .section-title {
        font-size: 24px
    }

    .recommended-plans-section .card-title {
        font-size: 1.3em
    }

    .recommended-plans-section .card-description {
        font-size: .85em
    }

    .plan-injury {
        flex-direction: column
    }
}

@media (max-width:400px) {
    .phone-vertical-line {
        position: absolute;
        top: 61%;
        right: 10px;
        transform: translate(-50%, -63%)
    }

    #heroCarouselMobile.carousel {
        margin-top: -60px
    }

    .quiz-step .food-grid {
        grid-template-columns: repeat(1, 1fr);
        gap: 12px
    }

    .quiz-step .food-image-container {
        height: max-content;
        padding: 8px;
        justify-content: flex-end
    }

    .otp-input-group {
        gap: 16px
    }

    .input-group {
        margin-top: 0 !important
    }

    .signup-container .otp-input {
        width: 40px;
        height: 40px;
        padding: 12px
    }

    .otp-input-group svg {
        display: none
    }

    .age-selection-box {
        flex-wrap: wrap
    }
}

.fade-right {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    background: #ffffff69;
    z-index: 3
}

.purchase-plan-overlay {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 3
}

.purchase-plan-btn {
    background: #4a84dd;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 8px 16px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .15);
    transition: .2s;
    text-decoration: none
}

ul#country-list,
ul#login-country-list,
ul#quiz-phone-country-list {
    padding-left: 0;
    margin-bottom: 0
}

.signup-login-h2-title {
    width: 100%
}

.coming-soon-tooltip {
    background-color: #333;
    color: #fff;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .15);
    animation: .3s ease-out tooltipFadeIn;
    white-space: nowrap
}

.coming-soon-tooltip::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: #333
}

@keyframes tooltipFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.modal-backdrop {
    backdrop-filter: none !important;
    background-color: #000 !important
}

.quiz-step#step-2 .food-image-container,
.quiz-step#step-3 .food-image-container,
.quiz-step#step-4 .food-image-container,
.quiz-step#step-5 .food-image-container {
    cursor: default
}

a.btn-signup {
    text-decoration: none;
    cursor: pointer !important;
    -webkit-touch-callout: none !important;
    -webkit-user-select: none !important
}

@supports (-webkit-touch-callout:none) {

    .sport-nutrition-promo__form button,
    .sport-nutrition-promo__form select[data-custom=true] {
        padding: 14px 16px !important;
        font-size: 16px !important;
        line-height: 1.4 !important;
        min-height: 44px !important;
        height: auto !important;
        width: 100% !important;
        cursor: pointer !important;
        box-sizing: border-box !important;
        outline: 0 !important
    }

    .sport-nutrition-promo__form select[data-custom=true] {
        max-height: 45vh !important;
        overflow-y: auto !important;
        -webkit-appearance: none !important;
        appearance: none !important;
        background: 0 0 !important;
        border: none !important;
        position: relative !important;
        z-index: 1 !important;
        -webkit-tap-highlight-color: transparent !important;
        -webkit-touch-callout: none !important;
        -webkit-user-select: none !important;
        user-select: none !important;
        touch-action: manipulation !important;
        -webkit-touch-callout: none !important;
        -webkit-user-select: none !important;
        -moz-user-select: none !important;
        -ms-user-select: none !important;
        user-select: none !important
    }

    .custom-select-wrapper {
        position: relative !important;
        width: 100% !important;
        display: block !important;
        background: #fff !important;
        border-radius: 6px !important;
        overflow: hidden !important
    }

    .sport-nutrition-promo__form select[data-custom=true] option {
        padding: 12px 16px !important;
        font-size: 16px !important;
        line-height: 1.4 !important;
        min-height: 44px !important;
        background: #fff !important;
        color: #3b3b3b !important;
        border: none !important;
        margin: 0 !important;
        display: block !important;
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: unset !important
    }

    .sport-nutrition-promo__form select[data-custom=true]::-webkit-listbox {
        max-height: 50vh !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 8px !important;
        border-radius: 6px !important;
        border: 1px solid #ddd !important;
        background: #fff !important
    }

    .sport-nutrition-promo__form select[data-custom=true]::-webkit-option {
        padding: 12px 16px !important;
        font-size: 16px !important;
        line-height: 1.4 !important;
        min-height: 44px !important;
        background: #fff !important;
        color: #3b3b3b !important;
        border: none !important;
        margin: 2px 0 !important;
        border-radius: 4px !important;
        white-space: normal !important;
        overflow: visible !important
    }

    .sport-nutrition-promo__form {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        background: 0 0 !important;
        padding: 0 !important;
        margin-bottom: 24px !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: visible !important
    }

    .custom-select-arrow {
        position: absolute !important;
        right: 12px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        pointer-events: none !important;
        z-index: 2 !important;
        background: 0 0 !important
    }

    .vertical-line {
        display: none !important
    }

    .sport-nutrition-promo__form button {
        border: none !important;
        border-radius: 6px !important;
        background: #4a84dd !important;
        color: #fff !important;
        -webkit-appearance: none !important;
        appearance: none !important
    }

    .sport-nutrition-promo__form button:active,
    .sport-nutrition-promo__form select[data-custom=true]:active {
        transform: scale(.98) !important;
        transition: transform .1s !important
    }

    .sport-nutrition-promo__form select[data-custom=true]:focus {
        outline: 0 !important;
        border: none !important;
        box-shadow: none !important;
        background: #fff !important
    }

    .sport-nutrition-promo__form button:focus {
        outline: 0 !important;
        box-shadow: 0 0 0 3px rgba(74, 132, 221, .3) !important
    }
}

@media (max-width:375px) and (-webkit-touch-callout:none) {

    .sport-nutrition-promo__form button,
    .sport-nutrition-promo__form select[data-custom=true] {
        padding: 12px 16px !important;
        font-size: 16px !important;
        min-height: 44px !important
    }

    .sport-nutrition-promo__form select[data-custom=true] option {
        padding: 10px 16px !important;
        font-size: 16px !important;
        min-height: 44px !important
    }
}

@media (max-width:768px) and (orientation:landscape) and (-webkit-touch-callout:none) {
    .sport-nutrition-promo__form {
        gap: 8px !important;
        margin-bottom: 16px !important
    }

    .sport-nutrition-promo__form button,
    .sport-nutrition-promo__form select[data-custom=true] {
        padding: 10px 16px !important;
        min-height: 40px !important;
        font-size: 16px !important
    }
}

@media (max-width:768px) and (orientation:portrait) and (-webkit-touch-callout:none) {
    .sport-nutrition-promo__form {
        gap: 12px !important;
        margin-bottom: 24px !important
    }

    .sport-nutrition-promo__form button,
    .sport-nutrition-promo__form select[data-custom=true] {
        padding: 14px 16px !important;
        min-height: 44px !important;
        font-size: 16px !important
    }
}

.hero-section-landing {
    background-position: center
}

@media (max-width:480px) {
    .hero-section-landing {
        background-position: 70% center !important
    }

    .choose-plan-section .plan-card,
    .choose-plan-section .plan-card:hover {
        box-shadow: none
    }
}

.about-us .hero-section {
    text-align: center;
    padding: 80px 0 60px
}

.hero-title-landing {
    color: #000;
    text-align: center;
    font-size: 32px;
    font-style: normal;
    font-weight: 600;
    line-height: 48px
}

.profile-images {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative
}

.profile-img {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    position: relative;
    overflow: hidden
}

.athlete-card img,
.kerry-image img,
.profile-img img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.profile-img:nth-child(2),
.profile-img:nth-child(3) {
    margin-left: -15px
}

.kerry-section {
    display: flex;
    gap: 60px;
    align-items: flex-start;
    margin-bottom: 60px
}

.kerry-content {
    flex: 1
}

.kerry-title {
    font-size: 24px;
    font-weight: 600;
    color: #333;
    margin-bottom: 20px
}

.kerry-text {
    font-size: 16px;
    color: #555;
    line-height: 1.6;
    margin-bottom: 20px
}

.kerry-image {
    flex: 0 0 532px;
    height: 484px;
    border-radius: 12px;
    overflow: hidden
}

.biohealth-header,
.steps-list {
    align-items: center;
    display: flex
}

.biohealth-section {
    border-radius: 12px;
    background: #254d4d;
    padding: 36px;
    margin-bottom: 60px;
    position: relative;
    color: #fff
}

.biohealth-header {
    gap: 15px;
    margin-bottom: 20px
}

.biohealth-title {
    font-size: 20px;
    font-weight: 600
}

.biohealth-text {
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 25px;
    opacity: .9
}

.learn-more-btn {
    border-radius: 6px;
    border: 1px solid var(--Kerry-grey-200, #d8d8d8);
    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, .08);
    cursor: pointer;
    transition: .3s;
    color: var(--White, #fff);
    padding: 12px 18px;
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    background-color: transparent
}

.athlete-name,
.athletes-title {
    font-family: Poppins;
    font-size: 36px;
    font-style: italic;
    font-weight: 800;
    text-transform: uppercase;
    text-align: center
}

.learn-more-btn:hover {
    background: rgba(255, 255, 255, .3)
}

.athletes-header {
    text-align: center;
    margin-bottom: 40px;
    padding: 0 20px
}

.athletes-title {
    color: var(--Kerry-grey-700, #080808);
    line-height: 54px
}

.athletes-grid {
    display: flex;
    gap: 0;
    overflow: hidden
}

.athlete-card {
    flex: 1;
    position: relative;
    cursor: pointer;
    transition: .3s;
    overflow: hidden;
    min-height: 474px
}

.athlete-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, .22);
    transition: .3s;
    z-index: 2
}

.athlete-card:hover::before {
    background: rgba(0, 0, 0, .6)
}

.athlete-card:hover .athlete-content {
    opacity: 1;
    visibility: visible
}

.athlete-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
    text-align: center;
    transition: .3s;
    opacity: 0;
    visibility: hidden
}

.wizard-inner,
.wizard-inner a {
    z-index: 1;
    display: flex
}

.input-with-icon,
.wizard-inner {
    position: relative
}

.athlete-name {
    color: #fff;
    line-height: 42px
}

.athlete-title {
    color: var(--White, #fff);
    text-align: center;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

@media (max-width:768px) {
    .hero-section.overlapping-img-section {
        background-color: transparent
    }

    .hero-title-landing {
        font-size: 32px;
        line-height: 40px
    }

    .athlete-name,
    .athlete-title,
    .athletes-title {
        line-height: normal
    }

    .kerry-section {
        flex-direction: column;
        gap: 30px;
        margin-bottom: 36px
    }

    .biohealth-header img {
        width: 100%
    }

    .athletes-header {
        margin-bottom: 24px
    }

    .kerry-image {
        height: 250px;
        flex: auto
    }

    .biohealth-section {
        margin-bottom: 36px;
        padding: 24px
    }

    .athlete-card {
        height: 200px;
        flex: 0 0 80%
    }

    .athlete-name {
        font-size: 20px
    }

    .athlete-title {
        font-size: 12px
    }

    .athletes-grid {
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch
    }
}

.input-with-icon .input-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    pointer-events: none;
    opacity: .6
}

#paymentModalPlan .input-with-icon .form-control,
.input-with-icon .form-control {
    padding-left: 40px
}

#congratsContentConsultation .btn-signup,
#consultation-payment-form .btn-signup,
.steps-list,
.w-100.btn.btn-learn-more-blue,
.w-100.btn.btn-signup {
    justify-content: center
}

.pre-plan-section {
    min-height: calc(100vh - 109px - 176px);
    padding: 165px 0 56px
}

.connecting-line,
.wizard-inner a:after {
    position: absolute;
    top: 20px;
    height: 3px;
    background: #ccc;
    z-index: -1
}

.connecting-line {
    left: 35px;
    right: 35px
}

.connecting-line span {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    background: #649ef7
}

.round-tab {
    height: 40px;
    width: 40px;
    border: 1px solid #ccc;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 5px;
    background: #fafafa;
    transition: .35s
}

.wizard-inner a {
    flex-direction: column;
    align-items: center;
    font-family: "sans-serif", Helvetica, Arial;
    font-weight: 700;
    color: #3b3b3b;
    transition: .35s;
    text-align: center;
    width: 80px;
    position: relative
}

.wizard-inner a:after {
    content: "";
    right: 0;
    width: 100%;
    transition: .35s
}

.wizard-inner a:last-child:after {
    width: 50%;
    left: 0;
    right: auto
}

.wizard-inner a.active:after {
    background: #649ef7
}

.wizard-inner a.active .round-tab,
.wizard-inner a:hover .round-tab {
    background: #649ef7;
    border-color: #649ef7;
    color: #fff
}

.wizard-inner a.active,
.wizard-inner a:hover {
    color: #649ef7
}

.step-tab-box+.step-tab-box {
    margin-top: 2rem
}

.step-tab-box .card {
    border-radius: 1rem
}

.step-tab-box .card-header:first-child {
    border-radius: calc(1rem - 1px) calc(1rem - 1px) 0 0
}

.step-tab-box .card-footer:last-child {
    border-radius: 0 0 calc(1rem - 1px) calc(1rem - 1px)
}

.no-form-floating.form-floating>label {
    position: static;
    padding: 0;
    margin-bottom: .6rem;
    white-space: break-spaces
}

.no-form-floating.form-floating .form-control {
    padding: .635rem 1rem;
    height: 48px
}

.step-tab-box h5 {
    font-size: 1rem;
    margin-top: 1rem
}

.tab-main-box {
    max-width: 1000px;
    margin: 0 auto;
    width: 100%
}

.step-tab-box tr th {
    background: #dee2e6;
    border: 0
}

.step-tab-box .table {
    border: 1px solid #dee2e6
}

.step-tab-box table tbody:not(:first-child) {
    border-top: 0
}

@media only screen and (max-width:767px) {
    .wizard-inner a {
        width: 60px;
        font-size: 14px
    }

    .round-tab {
        height: 35px;
        width: 35px
    }

    .wizard-inner a::after {
        top: 18px
    }

    .step-tab-box h5 {
        margin-top: 0
    }
}

@media only screen and (max-width:575px) {
    .wizard-inner a {
        width: 50px
    }

    .wizard-inner a:after {
        top: 16px
    }

    .wizard-inner a i {
        display: none
    }

    .round-tab {
        margin-bottom: 0
    }

    .tab-main-box .btn {
        padding: .5rem 1.2rem;
        font-size: .9rem
    }
}

@media only screen and (max-width:479px) {
    .wizard-inner a {
        width: auto;
        padding: 0 5px
    }

    .round-tab {
        height: 24px;
        width: 24px;
        font-size: 13px
    }

    .wizard-inner a::after {
        top: 12px;
        height: 2px
    }
}

.form-submitted-thank-you {
    justify-self: center
}

.cards-wrapper .btn-learn-more-blue,
a.btn-learn-more-blue {
    text-decoration: none !important;
    pointer-events: auto !important
}

.btn-learn-more-blue {
    border-radius: 6px;
    background: #4a84dd;
    padding: 9.5px 18px;
    color: #fff;
    font-family: "Noto Sans", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    width: max-content;
    border: 1px solid #4a84dd;
    justify-content: center
}

@media (hover:none) {
    .choose-plan-section .plan-card:hover {
        box-shadow: none
    }
}

.form-floating>.form-control-plaintext~label,
.form-floating>.form-control:focus~label,
.form-floating>.form-control:not(:placeholder-shown)~label,
.form-floating>.form-select~label {
    color: rgba(var(--bs-body-color-rgb), .65);
    transform: scale(.85) translateY(-1rem) translateX(.15rem)
}

.sub-food-checkbox {
    min-height: 16px;
    min-width: 16px;
    margin-top: 4px !important
}

.slider-container {
    overflow: hidden;
    position: relative;
    width: 100%
}

.logo-row {
    display: flex;
    align-items: center;
    white-space: nowrap
}

.infinite-slider-left {
    animation: 10s linear infinite scroll-left !important
}

.infinite-slider-right {
    animation: 10s linear infinite scroll-right !important
}

@keyframes scroll-left {
    0% {
        transform: translateX(0)
    }

    100% {
        transform: translateX(-50%)
    }
}

@keyframes scroll-right {
    0% {
        transform: translateX(-50%)
    }

    100% {
        transform: translateX(0)
    }
}

.dropdown-content.services {
    min-width: 240px !important
}

@media only screen and (max-width:600px) {
    .infinite-slider-left {
        animation: 300s linear infinite scroll-left !important
    }

    .infinite-slider-right {
        animation: 300s linear infinite scroll-right !important
    }

    .w-114-mob {
        width: 114px
    }

    .dropdown-content.services {
        min-width: auto !important
    }
}

.w-100.btn.btn-learn-more-blue:hover {
    background-color: #1751aa;
    color: #fff
}

@media (max-width:370px) {
    .carousel-item {
        min-height: 830px
    }
}