/** Shopify CDN: Minification failed

Line 2860:25 Expected ":"

**/
/* MYLO MEAL PERSONALIZER STYLES */
@font-face {
    font-family: 'PP Nikkei Maru', sans-serif;
    src: url('pp-nikkei-maru.otf') format('opentype');
    font-style: normal;
    font-display: swap;
}
#shopify-section-header {
    display: none;
}
.mylo-meal {
    padding-bottom: 100px;
}
.wrapper-footer {
    display: none;
}
.survey-header {
    display: flex;
    align-items: center;
    position: relative;
    padding-bottom: 0px;
}

.survey-back-button {
    text-decoration: none;
    color: #160102;
    transition: all 400ms ease;
    width: 100px;
}
.survey-back-button span {
    position: relative;
}
.survey-back-button span:before {
    content: "";
    display: inline-block;
    width: 6px;
    height: 6px;
    border-top: 1px solid #160102;
    border-left: 1px solid #160102;
    transform: rotate(-45deg);
    position: relative;
    top: -1px;
    margin-right: 10px;
}

.survey-logo {
    text-align: center;
    margin: 0;
    width: calc(100% - 200px);
}

.survey-logo img {
    display: block;
    margin: 0 auto;
}
.survet-form-title {
    font-family: 'PP Nikkei Maru', sans-serif;
    font-size: 24px;
    font-weight: 400;
    padding-bottom: 60px;
}

.progress-indicator {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    padding-bottom: 30px;
}
.progress-indicator .step {
    background: #ffffff;
    color: #160102;
    display: flex;
    border-radius: 40px;
    margin: 0px 40px;
    padding: 6px 18px;
    transition: all 400ms ease;
    position: relative;
}
.progress-indicator .step .step-circle {
    padding-right: 4px;
}
.progress-indicator .step.active,
.progress-indicator .step.completed {
    background: #A0A223;
    color: #fff;
}
.progress-indicator .step:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -35px;
    width: 37px;
    height: 5px;
    background: #ffffff;
    transform: translateY(-50%);
    border-radius: 20px;
    transition: all 400ms ease;
}
.progress-indicator .step:after {
    content: "";
    position: absolute;
    top: 50%;
    right: -37px;
    width: 37px;
    height: 5px;
    background: #ffffff;
    transform: translateY(-50%);
    border-radius: 20px;
    transition: all 400ms ease;
}
.progress-paw {
    color: #ffffff;
}
.progress-indicator .step:first-child:before,
.progress-indicator .step:last-child:after {
    content: unset;
}
.progress-indicator .step.completed:after,
.progress-indicator .step.completed:before {
    background: #A0A223;
}
.progress-indicator .step.completed + .progress-paw {
    color: #A0A223;
}
.progress-indicator .step.active:before {
    background: #A0A223;
}

.survey-form .step-content {
    display: none;
}
.survey-form .step-content.active {
    display: block;
}

.form-title {
    font-size: 20px;
    text-align: center;
    padding-bottom: 10px;
    color: #160102;
}
.form-title .info-tooltip {
    display: inline-block;
    position: relative;
    margin-left: 8px;
}
.form-title .info-icon-circle {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 8px;
    background: transparent;
    color: #160102;
    border: 1px solid #C8C8C8;
    cursor: pointer;
    position: relative;
    top: -4px;
}
.form-title .info-tooltip-content {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    top: auto;
    left: 50%;
    transform: translateX(-50%);
    background: #160102;
    color: #ffffff;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 12px;
    line-height: 1.4;
    width: 260px;
    box-shadow: 0 6px 20px rgba(0,0,0,0.12);
    z-index: 20;
}
.form-title .info-tooltip-content:after {
    content: "";
    position: absolute;
    top: auto;
    bottom: -12px;
    left: 50%;
    transform: translate(-50%);
    border-width: 6px;
    border-style: solid;
    border-color: #000000 #00000000 #16010200 #00000000;
}
.form-title .info-tooltip:hover .info-tooltip-content,
.form-title .info-tooltip:focus .info-tooltip-content,
.form-title .info-tooltip:focus-within .info-tooltip-content {
    display: block;
}
.input-group {
    max-width: 386px;
    margin: 0 auto;
}
.form-control {
    width: 100%;
    font-size: 14px;
    border: 1px solid #ffffff;
    background: #ffffff;
    border-radius: 30px;
    padding: 11px 14px;
    font-family: var(--font-body-family);
}
select.form-control {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 18px;
    appearance: none;
}
.form-control:focus, .form-control:focus-visible {
    outline: none;
}
 .info-box {
     background: #ffffff;
     max-width: 386px;
     margin: 35px auto 0px auto;
     border-radius: 10px;
     color: rgb(22 1 2 / 50%);
     font-size: 14px;
     line-height: 20px;
     text-align: center;
     padding: 10px 20px;
     letter-spacing: -0.2px;
     position: relative;
 }
 .info-box .icon {
    width: 32px;
    height: 32px;
    display: flex;
    background: #fff;
    border-radius: 100%;
    align-items: center;
    justify-content: center;
    color: #000;
    margin: -25px auto 10px auto;
    font-size: 18px;
}

 /* Age Input Toggle Styles */
 .age-input-toggle {
     max-width: 386px;
     margin: 0 auto;
 }

 .toggle-buttons {
    display: flex;
    border-radius: 40px;
    padding: 5px;
    margin-bottom: 20px;
    border: 1px solid #fff;
    background: #fff;
    gap: 5px;
 }

 .toggle-btn {
    flex: 1;
    padding: 8px 16px;
    border: none;
    background: transparent;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 400;
    color: #000;
    cursor: pointer;
    transition: all 400ms ease;
    background: #F5F5F5;
    border: 1px solid #EBEDE4;
 }

 .toggle-btn.active {
     background: #000;
     color: #fff;
 }

 .age-input-label {
     display: block;
     font-size: 16px;
     font-weight: 400;
     color: #160102;
     margin-bottom: 15px;
     text-align: center;
 }

 .age-input {
     display: none;
 }

 .age-input.active {
     display: block;
 }

 .age-inputs-row {
     display: flex;
     gap: 10px;
 }

 .age-input-field {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
 }
 .age-input-field input {
    padding: 0;
    border-radius: 0;
    border: 0;
    text-align: center;
    padding-left: 10px;
    color: #160102;
    font-size: 16px;
}

 .age-input-field label {
    display: block;
    text-align: center;
    font-size: 14px;
    color: #160102;
    margin-top: 0;
    background: #F5F5F5;
    padding: 5px 20px;
    min-width: 97px;
    border-radius: 40px;
    position: absolute;
    right: 4px;
 }

 .weight-input-section input:disabled + label {
    background: #E6E6E6;
}

 /* Remove number input arrows */
 .age-input-field input[type="number"] {
     -moz-appearance: textfield;
     -webkit-appearance: none;
     appearance: none;
 }

 .age-input-field input[type="number"]::-webkit-outer-spin-button,
 .age-input-field input[type="number"]::-webkit-inner-spin-button {
     -webkit-appearance: none;
     margin: 0;
 }

 .age-input-field input[type="number"]::-moz-number-spin-box,
 .age-input-field input[type="number"]::-moz-number-spin-up,
 .age-input-field input[type="number"]::-moz-number-spin-down {
     display: none;
 }

 /* Custom Date Input Styling */
 .dob-input .form-control[type="date"] {
     -webkit-appearance: none;
     -moz-appearance: none;
     appearance: none;
     background-image: none;
     padding-right: 40px;
     cursor: pointer;
     position: relative;
     z-index: 1;
 }

 /* Hide default calendar icon in Chrome/Safari */
 .dob-input .form-control[type="date"]::-webkit-calendar-picker-indicator {
     display: none;
     -webkit-appearance: none;
 }

 /* Hide spinner buttons in Chrome/Safari */
 .dob-input .form-control[type="date"]::-webkit-inner-spin-button,
 .dob-input .form-control[type="date"]::-webkit-clear-button {
     display: none;
     -webkit-appearance: none;
 }

 /* Hide calendar icon in Firefox */
 .dob-input .form-control[type="date"]::-moz-calendar-picker-indicator {
     display: none;
     -moz-appearance: none;
 }

 /* Make sure input is clickable */
 .dob-input .input-group {
     position: relative;
 }

 .calendar-icon {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 16px;
    pointer-events: all;
    z-index: 2;
    cursor: pointer;
    padding: 5px;
    transition: all 400ms ease;
    background: #F5F5F5;
    width: 32px;
    height: 32px;
    border-radius: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
 }

.footer-navigation {
    background: #ffffff;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 999;
}
.footer-btn-group {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 17px 0px;
}
.footer-btn-group #nextBtn {
    background: #111;
    border: 1px solid #111111;
    color: #fff;
    font-size: 16px;
    padding: 10px 31px 10px 7px;
    border-radius: 40px;
    min-width: 124px;
    position: relative;
    transition: all 400ms ease;
    font-weight: 700;
}
.footer-btn-group #nextBtn span {
    background: #fff;
    width: 25px;
    height: 25px;
    border-radius: 100%;
    display: inline-flex;
    color: #170508;
    top: 50%;
    right: 7px;
    align-items: center;
    justify-content: center;
    transform: translateY(-50%) rotate(-45deg);
    transition: all 400ms ease;
    position: absolute;
}

.footer-btn-group #nextBtn:hover {
    background: #fff;
    color: #111;
}
.footer-btn-group #nextBtn:hover span {
    background: #111;
    color: #fff;
}
.footer-btn-group #prevBtn {
    font-size: 14px;
    color: #160102;
    padding: 0;
    border-radius: 0 !important;
    border: unset;
    margin-right: 30px;
    background: transparent;
}
.step-progress-bar {
    max-width: 386px;
    margin: 0 auto;
    padding-bottom: 15px;
}
.step-progress-bar .progress-line {
    background: #ffffff;
    height: 8px;
    border-radius: 30px;
    position: relative;
}
.step-progress-bar .progress-line-inner {
    background: #A0A223;
    height: 8px;
    border-radius: 30px;
    transition: all 400ms ease;
}
.progress-line-label {
    background: #fff;
    width: 46px;
    height: 23px;
    font-size: 12px;
    color: #717171;
    display: flex;
    align-items: center;
    justify-content: center;
    border-top-left-radius: 100px;
    border-top-right-radius: 100px;
    margin: 0 auto;
    padding-top: 2px;
}
.inner-step-content {
    display: none;
}
.inner-step-content.active {
    display: block;
}
.buuon-group-extra {
    padding-top: 15px;
}
.buuon-group-extra .btn.more-add {
    background: #fff;
    border: 1px solid #fff;
    margin-bottom: 15px;
    font-family: var(--font-body-family);
    font-size: 14px;
}
.buuon-group-extra .btn.more-add span {
    padding-right: 5px;
}
.buuon-group-extra .btn.dont-know {
    border: 1px solid #D9D9D9;
    background: #D9D9D9;
}

.buuon-group-extra .btn.dont-know.selected {
    background: #160102;
    color: #fff;
    border-color: #160102;
}
.buuon-group-extra .btn {
    display: block;
    width: 100%;
    padding: 11px 0px;
    border-radius: 40px;
}

.cross-breed-selector {
    margin-top: 15px;
}

.breed-dropdown-item {
    position: relative;
    margin-bottom: 15px;
}

/* Custom Select Dropdown Styles */
.custom-select-wrapper {
    position: relative;
    width: 100%;
}

.custom-select-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 15px;
    border: 1px solid #fff;
    border-radius: 40px;
    background: #fff;
    cursor: pointer;
    font-size: 14px;
    transition: border-color 0.3s ease;
}

.custom-select-value {
    flex: 1;
    color: #333;
}

.custom-select-arrow {
    margin-left: 10px;
    color: #666;
    transition: transform 0.3s ease;
}

.custom-select-wrapper.active .custom-select-arrow {
    transform: rotate(180deg);
}

.custom-select-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 4px;
    margin-top: 5px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 1000;
    max-height: 400px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.custom-select-search {
    padding: 10px;
    border-bottom: 1px solid #eee;
}

.custom-select-search-input {
    width: 100%;
    padding: 11px 12px;
    border: 1px solid #ddd;
    border-radius: 30px;
    font-size: 14px;
}

.custom-select-search-input:focus {
    outline: none;
}

.custom-select-options {
    max-height: 300px;
    overflow-y: auto;
    padding: 5px 0;
}

.custom-select-option {
    padding: 10px 15px;
    cursor: pointer;
    font-size: 14px;
    color: #333;
    transition: background-color 0.2s ease;
}

.custom-select-option:hover {
    background-color: #f5f5f5;
}

.custom-select-option[data-value=""] {
    color: #999;
    font-style: italic;
}

.breed-select-main {
    position: relative;
    z-index: 1;
}

.cross-breed-item .custom-select-wrapper {
    flex: 1;
    position: relative;
    order: 1;
}

.cross-breed-item .custom-select-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 15px;
    border: 1px solid #fff;
    border-radius: 40px;
    background: #fff;
    cursor: pointer;
    font-size: 14px;
    transition: border-color 0.3s ease;
}

.cross-breed-item .custom-select-value {
    flex: 1;
    color: #333;
}

.cross-breed-item .custom-select-arrow {
    margin-left: 10px;
    color: #666;
    transition: transform 0.3s ease;
}

.cross-breed-item .custom-select-wrapper.active .custom-select-arrow {
    transform: rotate(180deg);
}

.cross-breed-item .custom-select-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 4px;
    margin-top: 5px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 1000;
    max-height: 400px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.cross-breed-item .custom-select-search {
    padding: 10px;
    border-bottom: 1px solid #eee;
}

.cross-breed-item .custom-select-search-input {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
}

.cross-breed-item .custom-select-search-input:focus {
    outline: none;
    border-color: #160102;
}

.cross-breed-item .custom-select-options {
    max-height: 300px;
    overflow-y: auto;
    padding: 5px 0;
}

.cross-breed-item .custom-select-option {
    padding: 10px 15px;
    cursor: pointer;
    font-size: 14px;
    color: #333;
    transition: background-color 0.2s ease;
}

.cross-breed-item .custom-select-option:hover {
    background-color: #f5f5f5;
}

.cross-breed-item .custom-select-option[data-value=""] {
    color: #999;
    font-style: italic;
}

.cross-breed-item .cross-breed-select {
    position: relative;
    z-index: 1;
}

.cross-breed-item {
    position: relative;
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.cross-breed-item select {
    flex: 1;
}

.cross-breed-item .remove-breed-btn {
    width: 40px;
    height: 40px;
    padding: 0;
    border: 1px solid #fff;
    border-radius: 100%;
    background: #fff;
    color: #160102;
    font-size: 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.4s ease;
    flex-shrink: 0;
    order: 2;
}

.cross-breed-item .remove-breed-btn:hover {
    background: #160102;
    color: #fff;
    border-color: #160102;
}
.cross-breed-item .cross-breed-other {
    order: 3;
    width: 100%;
    margin-top: 0px !important;
}
.btn.clear-breeds {
    border: 1px solid #EBEDE4;
    background: #fff;
    color: #160102;
    font-family: var(--font-body-family);
    font-size: 14px;
}
.btn.clear-breeds:hover {
    border: 1px solid #160102;
    background: #160102;
    color: #fff;
}

/* Size Options */
.size-options {
    display: flex;
    flex-wrap: wrap;
    max-width: 800px;
    margin: 0 auto;
    justify-content: center;
}

.size-option {
    position: relative;
    width: calc(100% / 3);
    padding: 0px 10px 20px 10px;
}

.size-option .btn-check {
    position: absolute;
    top: 15px;
    right: 15px;
    width: 20px;
    height: 20px;
    z-index: 10;
    opacity: 0;
}

.size-option .btn {
    width: 100%;
    height: 100%;
    min-height: 120px;
    padding: 20px;
    text-align: left;
    border: 1px solid #E0E0E0;
    border-radius: 8px;
    background: #fff;
    color: #717171;
    transition: all 400ms ease;
    cursor: pointer;
    position: relative;
    display: block;
}

.size-option .btn:hover {
    border-color: #A0A223;
}

.size-option .btn-check:checked + .btn {
    border-color: #A0A223;
}

.size-option .btn strong {
    display: block;
    font-size: 16px;
    font-weight: 700;
    color: #160102;
    margin-bottom: 5px;
}

.size-option .btn small {
    display: block;
    font-size: 12px;
    color: #666;
    line-height: 1.4;
    margin-top: 4px;
}

/* Custom radio button styling */
.size-option .btn:before {
    content: "";
    position: absolute;
    top: 23px;
    right: 15px;
    width: 16px;
    height: 16px;
    border: 2px solid rgb(22 1 2 / 50%);
    border-radius: 50%;
    background: #fff;
    z-index: 5;
    transition: all 400ms ease;
}

.size-option .btn-check:checked + .btn:after {
    content: "";
    position: absolute;
    top: 28px;
    right: 20px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #160102;
    z-index: 6;
}

/* gender Options */
.gender-options {
    margin-top: 20px;
    display: flex;
    gap: 30px;
    justify-content: center;
    align-items: center;
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
}
.continue-session {
    text-align: center;
    font-size: 12px;
    padding-top: 30px;
}
.continue-session i {
    position: relative;
    top: 1px;
    padding-left: 5px;
}
.gender-option {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.gender-option .form-check-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.gender-option .form-check-label {
    font-weight: 400;
    color: #160102;
    font-size: 16px;
    cursor: pointer;
    margin: 0;
    position: relative;
    padding-left: 30px;
}

.gender-option .form-check-label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    border: 2px solid #160102;
    border-radius: 50%;
    background-color: #fff;
    transition: all 0.3s ease;
}

.gender-option .form-check-input:checked + .form-check-label::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #160102;
}

/* Paw Icon Section */
.paw-icon-section {
    text-align: center;
    margin: 20px 0;
}

.paw-icon {
    font-size: 24px;
    color: #160102;
}

/* Weight Input Section */
.weight-input-section {
    max-width: 386px;
    margin: 0 auto;
    margin-top: 20px;
}

.weight-input-container {
    position: relative;
    margin-bottom: 20px;
}

.weight-input-container .form-control {
    padding-right: 60px;
    text-align: left;
    font-size: 18px;
    font-weight: 600;
    height: 50px;
}

.weight-unit-btn {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    background: #f5f5f5;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 8px 12px;
    color: #666;
    font-weight: 500;
    font-size: 14px;
    pointer-events: none;
}

.weight-options-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.weight-options-row .form-check {
    margin: 0;
}

.weight-options-row .form-check-input {
    display: none;
}

.weight-options-row .form-check-label {
    color: #160102;
    font-size: 12px;
    cursor: pointer;
    position: relative;
    padding-left: 17px;
}

.weight-options-row .form-check-label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 12px;
    height: 12px;
    border: 1px solid #24502B;
    border-radius: 2px;
    background-color: #fff;
}

.weight-options-row .form-check-input:checked + .form-check-label::before {
    background-color: #24502B;
}
.weight-options-row .form-check-input:checked + .form-check-label::after {
    content: "";
    display: block;
    position: absolute;
    top: 2px;
    left: 5px;
    width: 3px;
    height: 7px;
    border: solid #ffffff;
    border-width: 0 1px 1px 0;
    transform: rotate(45deg);
}

.weight-warning {
    display: flex;
    align-items: center;
    gap: 5px;
    color: #AD9400;
    font-size: 10px;
}

.weight-dont-know {
    width: 100%;
    margin-top: 20px;
    padding: 11px 0px;
    border: 1px solid #EBEDE4;
    background: #fff;
    border-radius: 40px;
    font-size: 14px;
    color: #160102;
    cursor: pointer;
    transition: all 400ms ease;
}

.weight-dont-know.selected {
    background: #160102;
    color: #fff;
    border-color: #160102;
}

.weight-warning-message {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 20px;
    color: #AD9400;
    font-size: 10px;
    justify-content: center;
}

.weight-warning-message .warning-icon {
    font-size: 12px;
    flex-shrink: 0;
    margin-top: 0;
}

.weight-input-section input:disabled {
    background-color: #f5f5f5;
    cursor: not-allowed;
    opacity: 0.6;
}

.warning-icon {
    font-size: 9px;
}
.age-input-field #current_weight {
    text-align: left;
    border: 1px solid #EBEDE4;
    border-radius: 40px;
}

/* bcs Grid */
.bcs-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    max-width: 630px;
    margin: 20px auto;
}
.bcs-option input:checked + .bcs-card .bcs-radio:before {
    content: "";
    width: 10px;
    height: 10px;
    border-radius: 100%;
    background: #160102;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.bcs-option {
    position: relative;
}

.bcs-card {
    width: 100%;
    min-height: 140px;
    padding: 15px;
    border: none;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}

/* Background colors for different bcs groups */
.bcs-thin .bcs-card {
    background: #FFFBF3;
}

.bcs-ideal .bcs-card {
    background: #F2F7F4;
}

.bcs-overweight .bcs-card {
    background: #FDF3F3;
}

.bcs-card:has(.btn-check:checked) {
    box-shadow: 0 0 0 2px #160102;
}

.bcs-content {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 15px;
}

.bcs-radio {
    width: 20px;
    height: 20px;
    border: 2px solid #160102;
    border-radius: 50%;
    background: transparent;
    flex-shrink: 0;
    position: relative;
}

.bcs-card:has(.btn-check:checked) .bcs-radio {
    background: #160102;
}

.bcs-card:has(.btn-check:checked) .bcs-radio::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #fff;
}

.bcs-text {
    font-size: 14px;
    font-weight: 700;
    color: #160102;
    line-height: 1.4;
}

.bcs-dog-illustration {
    width: 100%;
    height: 80px;
    margin-top: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
}

.bcs-dog-illustration img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Pregnancy Options */
.pregnancy-options {
    margin-top: 20px;
}
.pregnancy-dropdown-section .pregnancy-week-select {
    margin-bottom: 15px;
}

.pregnancy-dont-know {
    font-size: 16px;
    color: #333;
    cursor: pointer;
    transition: all 0.4s ease;
    text-align: center;
    position: relative;
    border: 1px solid #EBEDE4;
    background: #fff;
    display: block;
    width: 100%;
    padding: 11px 0px;
    border-radius: 40px;
}

.pregnancy-dont-know.selected {
    background: #160102;
    color: #fff;
    border-color: #160102;
}

.pregnancy-week-select:disabled {
    background-color: #f5f5f5;
    cursor: not-allowed;
    opacity: 0.6;
}

.pregnancy-stage-section {
    margin-top: 20px;
}

.pregnancy-warning-message {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 20px;
    color: #AD9400;
    font-size: 10px;
    justify-content: center;
}

.pregnancy-warning-message .warning-icon {
    font-size: 11px;
    flex-shrink: 0;
    margin-top: 0px;
}

.pregnancy-stage-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    max-width: 485px;
    margin: 0 auto;
}
.pregnancy-stage-option input:checked + .pregnancy-stage-card .pregnancy-stage-radio:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 10px;
    height: 10px;
    border-radius: 100%;
    background: #160102;
}

.pregnancy-stage-option {
    position: relative;
}

.pregnancy-stage-card {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 15px;
    border: 1px solid #EBEDE4;
    border-radius: 8px;
    background: #fff;
    cursor: pointer;
    transition: all 0.3s ease;
    min-height: 80px;
}

.pregnancy-stage-content {
    flex: 1;
}

.pregnancy-stage-label {
    font-size: 16px;
    font-weight: 700;
    color: #160102;
    margin-bottom: 10px;
}

.pregnancy-stage-desc {
    font-size: 14px;
    font-weight: 500;
    color: #717171;
}

.pregnancy-stage-radio {
    width: 20px;
    height: 20px;
    border: 2px solid rgb(22 1 2 / 50%);
    border-radius: 50%;
    background: #fff;
    flex-shrink: 0;
    position: relative;
    margin-top: 2px;
}

.pregnancy-stage-card:has(.btn-check:checked) .pregnancy-stage-radio {
    background: #160102;
}

.pregnancy-stage-card:has(.btn-check:checked) .pregnancy-stage-radio::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #fff;
}

/* Lactating Options */
.lactating-options {
    margin-top: 20px;
}

.lactating-dropdown-section {
    margin-top: 15px;
}

.lactating-week-select:focus {
    outline: none;
    border-color: #160102;
    box-shadow: 0 0 0 2px rgba(22, 1, 2, 0.1);
}
.lactating-dropdown-section .pregnancy-warning-message {
    padding-top: 15px;
    margin-bottom: 0 !important;
}

/* Activity Cards */
.activity-cards {
    display: flex;
    gap: 15px;
    margin-top: 20px;
    max-width: 1065px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 0px;
    padding-right: 0px;
}

.activity-card {
    flex: 1;
    position: relative;
}

.activity-card-btn {
    width: 100%;
    padding: 20px;
    border: 1px solid #EBEDE4;
    border-radius: 12px;
    background: #fff;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    position: relative;
}

.activity-card-btn:hover {
    border-color: #160102;
}

.activity-card .btn-check:checked + .activity-card-btn {
    border: 1px solid #160102;
    background-color: #fff;
}

.activity-card-radio {
    position: absolute;
    top: 21px;
    right: 15px;
    width: 20px;
    height: 20px;
    border: 2px solid rgb(22 1 2 / 50%);
    border-radius: 50%;
    background: #fff;
    transition: all 0.3s ease;
}

.activity-card .btn-check:checked + .activity-card-btn .activity-card-radio::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #160102;
}

.activity-card-content {
    display: flex;
    gap: 15px;
    align-items: center;
    flex: 1;
}

.activity-icon {
    font-size: 40px;
    flex-shrink: 0;
    line-height: 1;
    width: 37%;
}

.activity-details {
    display: flex;
    gap: 5px;
    width: calc(100% - 37%);
    flex-wrap: wrap;
}

.activity-title {
    font-size: 16px;
    font-weight: 700;
    color: #160102;
    margin-bottom: 5px;
}

.activity-description {
    font-size: 14px;
    color: #717171;
    line-height: 1.4;
}

.activity-exercise {
    font-size: 10px;
    color: rgb(113 113 113 / 70%);
}

/* allergies Options */
.allergies-options, .fresh-food-options, .health-options {
    display: flex;
    gap: 30px;
    justify-content: center;
    align-items: center;
    margin: 20px 0;
    margin-bottom: 0px !important;
}

.allergy-option, .fresh-food-option, .health-option {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.allergies-checkboxes, .health-checkboxes {
    margin-top: 20px;
}

/* General Form Check Styling for Radio Buttons and Checkboxes */
.form-check {
    margin-bottom: 15px;
}

.form-check-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.form-check-label {
    font-weight: 400;
    color: #160102;
    font-size: 16px;
    cursor: pointer;
    margin: 0;
    position: relative;
    padding-left: 30px;
    display: block;
}

/* Radio Button Styling */
.form-check-input[type="radio"] + .form-check-label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    border: 2px solid #160102;
    border-radius: 50%;
    background-color: transparent;
    transition: all 0.3s ease;
}

.form-check-input[type="radio"]:checked + .form-check-label::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #160102;
}
.weight-input-section .form-control {
    padding: 9px 15px;
}

/* Checkbox Styling */
.form-check-input[type="checkbox"] + .form-check-label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 18px;
    height: 18px;
    border: 2px solid #160102;
    border-radius: 3px;
    background-color: #fff;
    transition: all 0.3s ease;
}

.form-check-input[type="checkbox"]:checked + .form-check-label::before {
    background-color: #160102;
    border-color: #160102;
}

.form-check-input[type="checkbox"]:checked + .form-check-label::after {
    content: '';
    position: absolute;
    left: 6px;
    top: 2px;
    width: 6px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/* Hover Effects */
.form-check-input + .form-check-label:hover::before {
    border-color: #160102;
    box-shadow: 0 0 0 2px rgba(22, 1, 2, 0.1);
}

/* Digestive Issues Specific Styling */
.digestive-issues-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 15px;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
}

.digestive-issue-item {
    position: relative;
    width: 100%;
}

.digestive-card-btn {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    border-radius: 10px;
    color: #160102;
    cursor: pointer;
    transition: all 0.3s ease;
    width: 100%;
    border: 1px solid #E4E4E4;
}

.digestive-checkbox {
    width: 12px;
    height: 12px;
    border: 1px solid rgb(22 1 2 / 50%);
    border-radius: 50%;
    background: transparent;
    flex-shrink: 0;
    position: relative;
    transition: all 0.3s ease;
}

.digestive-issue-item .btn-check:checked + .digestive-card-btn .digestive-checkbox::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #160102;
}

.digestive-card-btn span {
    font-size: 14px;
    color: #220203;
    width: calc(100% - 20px);
}
.digestive-card-btn .digestive-issue-description {
    font-size: 12px;
    line-height: 1.4;
    display: none;
}
.digestive-issue-item .btn-check:checked + .digestive-card-btn .digestive-issue-description {
    display: block;
    width: 100%;
    margin-top: 8px;
}
.digestive-issue-item .btn-check:checked + .digestive-card-btn {
    border-color: #000000;
}
.digestive-warning {
    padding-top: 20px;
}
.unified-warning-item .warning-box {
    font-size: 10px;
    color: #AD9400;
    justify-content: center;
}
.unified-warning-item .warning-box .warning-icon {
    font-size: 11px;
    margin-top: 0px;
}
.unified-warning-item .confirm-checkbox {
    display: flex;
    justify-content: center;
}
.digestive-checkboxes .form-check-label {
    width: fit-content;
    margin-left: auto !important;
    margin-right: auto !important;
}

.warning-box {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.merged-warning-section .unified-warning-item {
    padding-top: 20px;
}

.warning-icon {
    color: #f39c12;
    font-size: 18px;
    margin-top: 2px;
}

.warning-text {
    color: #856404;
    font-size: 14px;
    line-height: 1.4;
}

.confirm-checkbox {
    margin-top: 15px;
}

.confirm-checkbox .form-check-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.confirm-checkbox .form-check-label {
    font-weight: 500;
    color: #160102;
    font-size: 14px;
    cursor: pointer;
    margin: 0;
    position: relative;
    padding-left: 25px;
    display: block;
}

.confirm-checkbox .form-check-input[type="checkbox"] + .form-check-label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 16px;
    height: 16px;
    border: 2px solid #160102;
    border-radius: 3px;
    background-color: #fff;
    transition: all 0.3s ease;
}

.confirm-checkbox .form-check-input[type="checkbox"]:checked + .form-check-label::before {
    background-color: #160102;
    border-color: #160102;
}

.confirm-checkbox .form-check-input[type="checkbox"]:checked + .form-check-label::after {
    content: '';
    position: absolute;
    left: 8px;
    top: 4px;
    width: 4px;
    height: 9px;
    border: solid #fff;
    border-width: 0 1px 1px 0;
    transform: rotate(45deg);
}

/* Health Options Styling */
.health-options {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
}

.health-option {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.health-option .form-check-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.health-option .form-check-label {
    font-weight: 400;
    color: #160102;
    font-size: 16px;
    cursor: pointer;
    margin: 0;
    position: relative;
    padding-left: 30px;
}

.health-option .form-check-input[type="radio"] + .form-check-label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    border: 2px solid #160102;
    border-radius: 50%;
    background-color: #fff;
    transition: all 0.3s ease;
}

.health-option .form-check-input[type="radio"]:checked + .form-check-label::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #160102;
}

.allergies-grid, .health-issues-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 15px;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
}

.allergies-grid .allergy-item:nth-child(5),
.allergies-grid .allergy-item:nth-child(6) {
    grid-column: span 2;
}

.allergy-item {
    position: relative;
}

.allergy-card-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    border-radius: 10px;
    color: #160102;
    cursor: pointer;
    transition: all 0.3s ease;
    width: 100%;
    border: 1px solid transparent;
}
.allergy-item .btn-check:checked + .allergy-card-btn {
    border-color: #000;
}

.allergy-checkbox {
    width: 12px;
    height: 12px;
    border: 1px solid rgb(22 1 2 / 50%);
    border-radius: 50%;
    background: transparent;
    flex-shrink: 0;
    position: relative;
    transition: all 0.3s ease;
}

.allergy-item .btn-check:checked + .allergy-card-btn .allergy-checkbox::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #160102;
}

.allergy-card-btn span {
    font-size: 14px;
    color: rgb(34 2 3 / 70%);
}

/* Digestive Options Styling */
.digestive-options {
    display: flex;
    gap: 30px;
    justify-content: center;
    align-items: center;
    margin: 20px 0;
    margin-bottom: 0px;
}
.digestive-checkboxes {
    padding-top: 20px;
}

.digestive-option {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.digestive-option .form-check-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.digestive-option .form-check-label {
    font-weight: 400;
    color: #160102;
    font-size: 16px;
    cursor: pointer;
    margin: 0;
    position: relative;
    padding-left: 30px;
}

.digestive-option .form-check-input[type="radio"] + .form-check-label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    border: 2px solid #160102;
    border-radius: 50%;
    background-color: #fff;
    transition: all 0.3s ease;
}

.digestive-option .form-check-input[type="radio"]:checked + .form-check-label::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #160102;
}

.health-item {
    position: relative;
    width: 100%;
}

.health-card-btn {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    border-radius: 10px;
    color: #160102;
    cursor: pointer;
    transition: all 0.3s ease;
    width: 100%;
    border: 1px solid #E4E4E4;
}
.health-issue-description {
    font-size: 12px;
    line-height: 1.4;
    display: none;
}
.health-item .btn-check:checked + .health-card-btn .health-issue-description {
    display: block;
    width: 100%;
    margin-top: 8px;
}
.health-item .btn-check:checked + .health-card-btn {
    border-color: #000;
}

.health-checkbox {
    width: 12px;
    height: 12px;
    border: 1px solid rgb(22 1 2 / 50%);
    border-radius: 50%;
    background: transparent;
    flex-shrink: 0;
    position: relative;
    transition: all 0.3s ease;
}

.health-item .btn-check:checked + .health-card-btn .health-checkbox::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #160102;
}

.health-card-btn span {
    font-size: 14px;
    color: #220203;
}
.health-checkboxes .confirm-checkbox {
    max-width: fit-content;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Testimonial Box */
.testimonial-box {
    background: #f8f9fa;
    border-radius: 12px;
    padding: 25px;
    margin: 20px auto;
    text-align: center;
    max-width: 386px;
    width: calc(100% - 10px);
}

.testimonial-content p {
    line-height: 1.6;
    margin-bottom: 10px;
    font-size: 14px;
    color: #160102;
    text-align: left;
}

.testimonial-author {
    font-weight: 700;
    color: #160102;
    text-align: left;
    font-size: 18px;
    padding-top: 30px;
}

/* Health Issues Section */

.other-health-issues {
    margin-top: 20px;
    padding-top: 15px;
    border-top: 1px solid #E0E0E0;
}

.form-subtitle {
    font-weight: 400;
    color: #160102;
    font-size: 16px;
    text-align: center;
}

/* Weight Activity Grid */
.weight-activity-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
}
.size-option .btn div {
    font-weight: 500;
    font-size: 14px;
}
.size-option .btn small {
    display: block;
    font-size: 14px;
    line-height: 1.4;
}
body.has-mylo-meal #shopify-section-announcement-bar + #shopify-section-marquee,
body.has-mylo-meal .shopify-header-section {
    display: none;
}
#inner-step-content-2-3 .info-box {
    margin: 15px auto 0px auto;
}
.age-input-toggle .age-input-field {
    border: 1px solid #fff;
    border-radius: 40px;
    padding: 9px 0;
    background: #fff;
}
.age-input-toggle .age-input-field label {
    min-width: 118px;
}
.age-input-toggle .age-input-field input {
    width: calc(100% - 118px);
}

/* Product Recommendations Design */
.product-recommendations-container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
    margin: 40px auto 0px auto;
}

.product-option-card {
    background: #F5F5F5;
    border-radius: 24px;
    padding: 24px;
    width: 100%;
    max-width: 440px;
    position: relative;
}

.product-image-wrapper {
    position: relative;
    width: 100%;
    margin-bottom: 60px;
    border-radius: 20px;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    border-bottom-right-radius: 0;
}

.product-image-wrapper-inner {
    margin-top: -95px;
    background: #ecede4;
    position: relative;
    padding-top: 82%;
    width: 100%;
    border-radius: 20px;
}
.product-image {
    width: 100%;
    height: 100%;
    max-height: 275px;
    object-fit: contain;
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
}

.product-number-badge {
    position: absolute;
    bottom: -40px;
    left: 20px;
    width: 82px;
    height: 82px;
    background: #ffffff;
    color: #160102;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    font-weight: 700;
}

.product-info {
    text-align: left;
}

.product-name {
    font-family: 'PP Nikkei Maru', sans-serif;
    font-size: 24px;
    font-weight: 400;
    color: #160102;
    margin: 0 0 5px 0;
}

.product-pricing {
    display: flex;
    align-items: center;
    gap: 5px;
}

.compare-price {
    text-decoration: line-through;
    font-size: 14px;
    font-weight: 400;
    color: #160102;
    font-family: PP Nikkei Maru, sans-serif;
}

.current-price {
    font-size: 14px;
    font-weight: 400;
    color: #160102;
    font-family: PP Nikkei Maru, sans-serif;
}

.recommendation-text {
    font-size: 12px;
    color: #160102;
    margin: 0 0 16px;
    line-height: 1.5;
}

.portion-pills {
    position: relative;
    display: flex;
    gap: 12px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}

.portion-pill {
    background: #fff;
    border-radius: 30px;
    padding: 13px 26px;
    font-size: 15px;
    color: #160102;
    font-weight: 400;
}

.bowl-selection-buttons {
    display: flex;
    position: absolute;
    top: -60px;
    right: 0;
}

.bowl-btn {
    background: #ffffff;
    border: 1px solid #fff;
    border-radius: 10px;
    padding: 13px 26px;
    font-size: 14px;
    color: #160102;
    font-weight: 400;
    cursor: pointer;
    transition: all 0.3s ease;
    font-family: inherit;
}
.bowl-selection-buttons .bowl-btn.full-bowl-btn {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-top-left-radius: 0;
}
.bowl-selection-buttons .bowl-btn.half-bowl-btn {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    border-bottom-left-radius: 0;
}

.bowl-btn.active {
    background: #160102;
    color: #ffffff;
    border-color: #160102;
}

.bowl-btn:hover {
    opacity: 0.9;
}

.profile-avatar-overlay {
    position: absolute;
    right: -8px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
}

.avatar-placeholder {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #D9D9D9;
    border: 3px solid #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.build-your-box-btn {
    display: block;
    text-align: center;
    width: 100%;
    background: #000000;
    color: #ffffff;
    border-radius: 50px;
    padding: 10px 30px;
    font-size: 16px;
    font-weight: 400;
    cursor: pointer;
    transition: all 400ms ease;
    font-family: inherit;
    border: 1px solid #000000;
    position: relative;
}

.product-separator {
    font-size: 24px;
    font-weight: 400;
    color: #160102;
    font-family: PP Nikkei Maru, sans-serif;
    padding: 0 20px;
    flex-shrink: 0;
}
.build-your-box-btn span {
    background: #fff;
    width: 28px;
    height: 28px;
    border-radius: 100%;
    display: inline-flex;
    color: #111;
    top: 50%;
    right: 7px;
    align-items: center;
    justify-content: center;
    transform: translateY(-50%) rotate(-45deg);
    transition: all .4s ease;
    position: absolute;
}
.build-your-box-btn:hover {
    background: #fff;
    color: #000;
}
.build-your-box-btn:hover span {
    background: #000;
    color: #fff;
}

.survey-info-form-section .survey-info-form__content {
    text-align: center;
    font-size: 18px;
    color: #160102;
    padding-bottom: 30px;
}

.survey-info-form-section .contact-form-area {
    margin: 0 auto;
    padding: 40px 100px;
}
.survey-info-form-section {
    padding-bottom: 120px;
}
.filter-variables-section {
    display: none;
}
.mylo-meal-servey {
    background: url(survey-bg.png) !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-size: cover !important;
    padding-top: 25px !important;
}
.step-bg-white {
    background: #fff;
    max-width: 590px;
    margin: 0px auto;
    margin-top: 20px;
    border-radius: 12px;
    padding: 30px 30px;
}
.survey-info-form-section-main .footer-navigation {
    background: #F5F5F5;
}
.bounding-box {
    border: 1px solid #ECE9C9;
    background: rgb(255 251 243 / 50%);
    max-width: 1030px;
    margin: 0 auto;
    border-radius: 20px;
    padding: 34px 34px;
}
.size-selector {
    padding-top: 35px;
}
button#pregnancyDontKnow {
    display: none;
}
.survey-result-title-group {
    text-align: center;
}
.survey-result-title-group .survey-result-title {
    color: #fff;
    font-size: 40px;
}
.survey-result-title-group .survey-result-title-2 {
    color: #24502B;
    font-size: 48px;
    font-weight: 700;
    padding-top: 12px;
    padding-bottom: 30px;
}
.survey-result-title-group .survey-result-title-2 .dog-name {
    color: #24502B;
}
.result-page .result-main-description.result-main-description-2 {
    padding-top: 30px;
}
.result-page .progress-indicator {
    padding-bottom: 50px;
}
.mylo-meal.result-page {
    min-height: unset !important;
    padding-bottom: calc(4% + 100px);
    background: url(body-bg.png) !important;
}
.result-products-contant {
    margin-top: -160px;
    padding-bottom: 150px;
}
.footer-navigation.result-footer {
    background: #F5F5F5;
}
.survey-result-title-group .survey-result-title-2 span {
    color: #EB532B;
}
.btn-footer {
    background: #111;
    border: 1px solid #111111;
    color: #fff;
    font-size: 16px;
    padding: 10px 31px 10px 15px;
    border-radius: 40px;
    min-width: 150px;
    position: relative;
    transition: all .4s ease;
    font-weight: 700;
}
.btn-footer span {
    background: #fff;
    width: 25px;
    height: 25px;
    border-radius: 100%;
    display: inline-flex;
    color: #170508;
    top: 50%;
    right: 7px;
    align-items: center;
    justify-content: center;
    transform: translateY(-50%) rotate(-45deg);
    transition: all .4s ease;
    position: absolute;
}
.btn-footer:hover {
    background: #fff;
    color: #111;
}
.btn-footer:hover span {
    background: #111;
    color: #fff;
}
.no-products-found + .section-divider {
    display: none;
}
.mylo-meal.result-page.no-products-found,
.mylo-meal.result-page.same-plan-found {
    min-height: 100vh !important;
}
.product-option-card .bowl-selection-wrapper {
    position: relative;
}
.result-page .result-main-description a {
    text-decoration: underline;
}
div#resultArea .alert.alert-warning {
    display: none;
}
.btn-footer.exit-to-homepage {
    padding-right: 50px;
}

.survey-popup-main {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.survey-popup-overlay {
    background: rgb(0 0 0 / 40%);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.survey-popup-content {
    background: #FFFBF3;
    position: relative;
    max-width: 485px;
    border-radius: 16px;
    overflow: hidden;
}
.survey-popup-header {
    background: #170508;
    padding: 15px 24px;
    position: relative;
}
.survey-popup-header h2 {
    color: #fff;
    font-size: 24px;
    font-weight: 400;
}
.survey-popup-body {
    padding: 15px 24px;
    padding-top: 24px;
}
.survey-popup-footer {
    padding: 15px 24px;
}
button.survey-popup-button.btn-dismiss {
    padding: 0;
    border-radius: 0;
    border: unset;
    background: unset;
    font-size: 16px;
    color: #170508;
}
button.survey-popup-button.btn-dismiss:hover {
    color: #A0A223;
}
button.survey-popup-button.btn-continue {
    background: #170508;
    color: #fff;
    border: unset;
    border-radius: 30px;
    font-size: 16px;
    font-weight: 700;
    padding: 12px 15px;
}
button.survey-popup-button.btn-continue:hover {
    background: #eb532b;
}
.survey-popup-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.survey-popup-close {
    position: absolute;
    top: 50%;
    right: 24px;
    transform: translateY(-50%);
    cursor: pointer;
}
.survey-popup-close svg {
    stroke: #fff;
    display: block;
}
.survey-popup-close:hover svg {
    stroke: #a0a223;
}
.product-variant-selection {
    display: none;
}

.survey-biome-section {
    padding-bottom: 100px;
    background: url(survey-bg.png) !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-size: cover !important;
}
.survey-biome-products-container {
    display: flex;
    flex-wrap: wrap;
    max-width: 1100px;
    margin-left: auto;
    margin-right: auto;
}
.survey-biome-optional {
    width: calc(100% - 33.33%);
    padding-right: 15px;
}
.survey-biome-required {
    width: 33.33%;
    padding-left: 15px;
}
.survey-biome-product-card-inner {
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    padding: 15px 15px;
    height: 100%;
}
.survey-biome-product-image {
    background: url(product-bg.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 14px;
    overflow: hidden;
    padding: 24px 24px 0px 24px;
    text-align: center;
}
.survey-biome-product-image img {
    display: block;
    margin: 0 auto;
}
.survey-biome-product-info {
    padding-top: 12px;
}
.survey-biome-product-category {
    font-size: 14px;
    font-family: var(--font-heading-family);
    padding-bottom: 5px;
}
.survey-biome-product-title {
    font-size: 22px;
    padding-bottom: 10px;
}
.survey-biome-product-price .price-item--regular {
    font-size: 14px;
    color: #160102;
}
.survey-biome-products .productGrid {
    margin-bottom: -30px;
    margin-left: -15px;
    margin-right: -15px;
}
.survey-biome-products .productGrid .product {
    padding-left: 15px;
    padding-right: 15px;
    padding-bottom: 30px;
}
.survey-biome-required-inner {
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    padding: 15px 15px;
}
.survey-biome-required-title {
    font-size: 28px;
    padding-bottom: 5px;
}
.survey-biome-review {
    font-size: 14px;
    font-family: var(--font-heading-family);
    padding-bottom: 4px;
}
.survey-biome-count {
    font-size: 10px;
    padding-bottom: 12px;
}
.survey-biome-card-list .cart-list {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -5px;
}
.survey-biome-card-list .cart-list .cart-item {
    width: 33.33%;
    padding: 0 5px;
    padding-bottom: 10px;
}
.survey-biome-card-list .cart-list .cart-item-block {
    background: url(product-bg.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 6px;
    overflow: hidden;
    padding: 12px 12px 0px 12px;
    position: relative;
}
.survey-biome-card-list .cart-item-qty-input::-webkit-outer-spin-button,
.survey-biome-card-list .cart-item-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
    display: none;
}
.survey-biome-card-list .cart-item-qty-input[type=number] {
    -moz-appearance: textfield;
}
.survey-biome-card-list .cart-item-qty-input {
    background: #160102;
    color: #fff;
    text-align: center;
    border-radius: 14px;
    height: unset;
    padding: 0;
    font-size: 11px;
    max-width: 35px;
    line-height: 20px;
}
.survey-biome-card-list .cart-list .cart-item-block img {
    display: block;
}
.survey-biome-card-list .cart-item-blocks-left .cart-item-block {
    padding: 0;
}
.survey-biome-card-list .cart-item-block-right {
    position: absolute;
    bottom: 5px;
    right: 5px;
}
.survey-biome-card-list .cart-item:last-child .cart-item-block-right,
.survey-biome-card-list .cart-item:nth-last-child(2) .cart-item-block-right {
    display: block;
}
.survey-biome-card-list .cart-total-label {
    font-size: 16px;
    padding-bottom: 5px;
}
.survey-biome-card-list .cart-total-value {
    font-size: 16px;
}
.survey-biome-card-list .t4s-cartPage__footer .t4s-col-item {
    display: flex;
    justify-content: space-between;
}
.survey-biome-card-list .button-checkout {
    padding: 15px 60px 15px 30px;
    background: #eb532b;
    border-color: #eb532b;
}
.survey-biome-card-list .button-checkout span {
    background: #fff;
    width: 35px;
    height: 35px;
    border-radius: 100%;
    display: inline-flex;
    color: #eb532b;
    top: 50%;
    right: 7px;
    align-items: center;
    justify-content: center;
    transform: translateY(-50%) rotate(-45deg);
    transition: all .4s ease;
    position: absolute;
}
.survey-biome-card-list .button-checkout:hover {
    background: #24502b;
    border-color: #24502b;
}
.survey-biome-card-list .button-checkout:hover span {
    color: #24502b;
}
.survey-biome-card-list .cart-content-item {
    padding-bottom: 10px;
}
.survey-biome-qty-input::-webkit-outer-spin-button,
.survey-biome-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
    display: none;
}
.survey-biome-qty-input[type=number] {
    -moz-appearance: textfield;
}
.survey-biome-quantity {
    border: 1px solid #000;
    border-radius: 7px;
    width: 80px;
    position: relative;
    padding: 2px 0;
}
.survey-biome-quantity button {
    position: absolute;
    top: 50%;
    left: 10px;
    padding: 0;
    background: transparent;
    border: unset;
    transform: translateY(-50%);
}
.survey-biome-quantity button.survey-biome-qty-plus {
    right: 10px;
    left: unset;
}
.survey-biome-quantity .survey-biome-qty-input {
    text-align: center;
    border: unset;
    width: 100%;
}
.survey-biome-product-price-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.survey-biome-card-list .cart-list .cart-item-block .cart-item-block-left {
    padding-top: 118%;
    position: relative;
}
.survey-biome-card-list .cart-list .cart-item-block .cart-item-block-left img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.product-info form.variants,
.footer-btn-group .next-btn-group {
    position: relative;
}

.product-info form.variants .loading,
.next-btn-group .loading,
.page-waiting-loader .loading {
	border-bottom: 4px solid rgb(255 255 255 / 50%);
    border-left: 4px solid rgb(255 255 255 / 50%);
    border-right: 4px solid rgb(255 255 255 / 50%);
    border-top: 4px solid rgb(255 255 255);
    border-radius: 100%;
    height: 32px;
    width: 32px;
    animation: spin .6s infinite linear;
    text-indent: 999em;
    position: absolute;
    top: calc(50% - 16px);
    left: calc(50% - 16px);
}
@keyframes spin {
	from {transform: rotate(0deg);}
	to {transform: rotate(359deg);}
}
.build-your-box-btn.disabel,
.next-btn-group .btn.disabel {
    opacity: 0.5 !important;
    pointer-events: none !important;
}
.page-waiting-loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgb(255 255 255 / 80%);
    z-index: 4;
    display: flex;
    align-items: center;
    justify-content: center;
}
.page-waiting-loader .loading {
    border-bottom: 4px solid rgb(36 80 43 / 80%);
    border-left: 4px solid rgb(36 80 43 / 80%);
    border-right: 4px solid rgb(36 80 43 / 80%);
    border-top: 4px solid rgb(0 0 0);
    position: unset;
}
.mylo-meal.result-page.data-loading {
    min-height: 100vh !important;
}
.build-your-box-btn + .loading,
.next-btn-group .btn + .loading {
    display: none;
}
.build-your-box-btn.disabel + .loading,
.next-btn-group .btn.disabel + .loading {
    display: block;
}
.survey-biome-product-price .price--on-sale .price__sale {
    flex-direction: column;
}
.survey-biome-product-price .price-item {
    font-size: 16px;
}
.survey-biome-product-price .price--on-sale .price__sale dd.price__compare .price-item {
    font-size: 12px;
}
.survey-biome-product-price .price-item span.text {
    display: none;
}
.product-info .ingredient-note {
    padding-bottom: 25px;
}
.product-option-card.option-3 {
    display: none !important;
}
.product-pricing.only-price-container .only-price, .product-pricing.only-price-container .current-price, .product-pricing.only-price-container .per-day {
    font-size: 16px;
    font-family: PP Nikkei Maru, sans-serif;
    margin-bottom: 15px;s
}
.survey-biome-product-description {
    font-size: 12px;
    padding-bottom: 10px;
}
.product-pricing.only-price-container {
    gap: 0;
}
.product-pricing.only-price-container span.per-day {
    padding-left: 5px;
}
.bird-discount {
    font-size: 12px;
    font-style: italic;
    padding-bottom: 15px;
}


@media (max-width: 1199px) {
    .mylo-meal {
        padding-top: 17px;
    }
    .loving-it-card-2 {
        margin-bottom: 50px;
    }
}

@media (max-width: 1024px) {
    .activity-card {
        width: 50%;
        flex: unset;
    }
    .activity-card {
        width: calc(50% - 8px);
        flex: unset;
    }
    .activity-cards {
        justify-content: center;
        flex-wrap: wrap;
    }
    .product-separator {
        padding: 0 0px;
        font-size: 16px;
    }
    product-recommendations-container {
        gap: 10px;
    }
    .product-option-card {
        padding: 15px;
    }
    .product-number-badge {
        width: 60px;
        height: 60px;
        font-size: 36px;
        bottom: -28px;
    }
    .product-image-wrapper-inner {
        margin-top: -85px;
    }
    .product-image-wrapper {
        margin-bottom: 50px;
    }
    .mylo-meal.result-page {
        padding-bottom: 170px;
    }
    .certified-content.subscribe-result .passion-main-box .ps-box {
        margin-bottom: 15px;
        padding-bottom: 15px;
    }
    .result-food .collectionGrid {
        margin-bottom: -30px;
    }
    .mylo-meal .announcement-right {
        display: block;
        width: 100px;
    }
    .mylo-meal .announcement-right .disclosure button {
        margin-left: auto;
    }
    .mylo-meal .announcement-right .disclosure button .text-language {
        font-family: var(--font-body-family);
        font-size: 14px;
    }
    .survey-biome-optional {
        order: 2;
        width: 100%;
        padding-right: 0;
    }
    .survey-biome-required {
        order: 1;
        width: 100%;
        padding-left: 0;
        padding-bottom: 30px;
    }
}

@media (max-width: 767px) {
    .product-recommendations-container {
        flex-direction: column;
        gap: 20px;
    }
    
    .product-separator {
        padding: 0px 0;
        font-size: 28px;
    }
    .product-separator + .product-option-card {
        margin-top: 35px;
    }
    
    .product-option-card {
        max-width: 100%;
    }
    
    .portion-pills {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .profile-avatar-overlay {
        position: absolute;
        right: 8px;
        top: auto;
        transform: none;
        bottom: -20px;
    }
    .survey-logo img {
        max-width: 90px;
    }
    .survey-back-button span {
        font-size: 14px;
    }
    .mylo-meal {
        padding-top: 10px;
    }
    .survet-form-title {
        font-size: 24px;
        padding-bottom: 15px;
    }
    .progress-indicator .step {
        margin: 15px 5px;
        font-size: 14px;
        padding: 4px 8px;
        letter-spacing: -0.5px;
    }
    .progress-indicator {
        padding-bottom: 20px;
    }
    .progress-indicator .step:after {
        right: -36px;
        height: 3px;
    }
    .progress-indicator .step:before {
        top: unset;
        bottom: calc(100% - 1px);
        left: 50%;
        width: 3px;
        height: 15px;
        transform: translate(-50%);
        content: unset;
    }
    .progress-paw {
        font-size: 12px;
        display: none;
    }
    .size-option {
        width: calc(100% / 1);
        padding: 0 0px 20px;
    }
    .age-input-toggle .age-input-field input {
        width: calc(100% - 80px);
    }
    .age-input-toggle .age-input-field label {
        min-width: 80px;
    }
    .bcs-grid {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
    }
    .pregnancy-stage-options {
        display: flex;
        flex-wrap: wrap;
    }
    .pregnancy-stage-option {
        width: 100%;
    }
    .activity-card {
        width: calc(100% - 0px);
    }
    .activity-cards {
        padding-left: 0px;
        padding-right: 0px;
    }
    .mylo-meal.result-page {
        padding-bottom: 180px;
    }
    .result-products-contant {
        padding-bottom: 50px;
    }
    .bounding-box {
        padding: 34px 15px;
    }
    .bounding-box {
        width: calc(100% - 30px);
    }
    .subscribe-result .container>.row .img-image {
        width: 100%;
    }
    .subscribe-result .container>.row {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    .subscribe-result .container>.row .img-image div {
        padding-left: 0;
        padding-right: 0;
    }
    .subscribe-result .container>.row .img-image {
        width: 100%;
        padding-left: 30px !important;
        padding-right: 30px !important;
        padding-bottom: 30px;
    }
    .certified-content.subscribe-result .passion-main-box {
        padding-left: 0px;
    }
    .certified-content.subscribe-result .container>.row>.content-im {
        padding-left: 0;
        padding-right: 0;
    }
    .survey-info-form-section .contact-form-area {
        padding: 30px 20px;
    }
    .survey-info-form-section .survey-info-form__content {
        font-size: 16px;
    }
    .mylo-meal {
        min-height: calc(100vh - 58px);
    }
    .step-bg-white {
        padding: 30px 20px;
    }
    .survey-biome-card-list .button-checkout {
        font-size: 16px;
        padding: 12px 50px 12px 20px;
    }
    .survey-biome-card-list .button-checkout span {
        right: 3px;
    }
    .survey-biome-products .productGrid {
        margin-left: -5px;
        margin-right: -5px;
    }
    .survey-biome-product-title {
        font-size: 16px;
    }
    .survey-biome-product-price-container {
        flex-direction: column;
        align-items: self-start;
    }
    .survey-biome-product-price-container .survey-biome-product-price {
        padding-bottom: 8px;
    }
    .progress-indicator .step[data-step="3"]:after {
        content: unset;
    }
    .result-page .progress-indicator {
        margin-left: auto;
        margin-right: auto;
        max-width: 400px;
    }
}

@media (max-width: 374px) {
    .progress-indicator .step {
        margin: 15px 5px;
        font-size: 12px;
        padding: 4px 5px;
    }
}