
@font-face {
    font-family: 'CerebriSans Regular';
    src: url('/fonts/CerebriSans-Regular.eot');
    src: local('CerebriSans Regular'),
    local('CerebriSans Regular'),
    url('/fonts/CerebriSans-Regular.ttf') format('truetype'),
    url('/fonts/CerebriSans-Regular.svg#font') format('svg');
    font-display: swap;
}
@font-face {
    font-family: 'CerebriSans Medium';
    src: url('/fonts/CerebriSans-Medium.eot');
    src: local('CerebriSans Medium'),
    local('CerebriSans Medium'),
    url('/fonts/CerebriSans-Medium.ttf') format('truetype'),
    url('/fonts/CerebriSans-Medium.svg#font') format('svg');
    font-display: swap;
}
@font-face {
    font-family: 'CerebriSans Bold';
    src: url('/fonts/CerebriSans-Bold.eot');
    src: local('CerebriSans Bold'),
    local('CerebriSans Bold'),
    url('/fonts/CerebriSans-Bold.ttf') format('truetype'),
    url('/fonts/CerebriSans-Bold.svg#font') format('svg');
    font-display: swap;
}
@font-face {
    font-family: 'Inter-Regular';
    src: url('/fonts/Inter-Regular.eot');
    src: local('Inter-Regular'),
    local('Inter-Regular'),
    url('/fonts/Inter-Regular.ttf') format('truetype'),
    url('/fonts/Inter-Regular.svg#font') format('svg');
    font-display: swap;
}
@font-face {
    font-family: 'Inter-Medium';
    src: url('/fonts/Inter-Medium.eot');
    src: local('Inter-Medium'),
    local('Inter-Medium'),
    url('/fonts/Inter-Medium.ttf') format('truetype'),
    url('/fonts/Inter-Medium.svg#font') format('svg');
    font-display: swap;
}
@font-face {
    font-family: 'Inter-Bold';
    src: url('/fonts/Inter-Bold.eot');
    src: local('Inter-Bold'),
    local('Inter-Bold'),
    url('/fonts/Inter-Bold.ttf') format('truetype'),
    url('/fonts/Inter-Bold.svg#font') format('svg');
    font-display: swap;
}
@font-face {
    font-family: 'Inter-ExtraBold';
    src: url('/fonts/Inter-ExtraBold.eot');
    src: local('Inter-ExtraBold'),
    local('Inter-ExtraBold'),
    url('/fonts/Inter-ExtraBold.ttf') format('truetype'),
    url('/fonts/Inter-ExtraBold.svg#font') format('svg');
    font-display: swap;
}
body {
    font-family: var(--body-font-family);
    font-weight: var(--body-font-weight);
    position: relative;
    color: var(--body-font-color);
    padding-top: 60px;
    background-size: cover;
}
h1, h2, h3, h4, h5, h6 {
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    color: var(--title-font-color);
}
strong {
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
}
.bold {
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    color: #000;
}
.semi-bold {
    color: var(--title-font-color);
}
/*
General
*/
.container-xl {
    max-width: 1520px;
}
.pac-container {
    z-index: 1100 !important;
}
.bite {
    display: block;
    margin-top: 10px;
}
.alert_image_container {
    position: absolute;
    top: -50px;
    width: 100%;
}
.alert_image_container .alert_image {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    margin: 0 auto;
    box-shadow: 0px 0px 6px rgb(0 0 0 / 50%);
}
#alert_modal .modal-content {
    overflow: visible;
}
.cart_alert_container {
    background: #F9F9F9;
    padding: 15px;
    text-align: center;
    margin-bottom: 15px;
    border-radius: 10px;
}
#payment_modal .cart_alert_container {
    background: #F2F2F2;
}
.cart_allergen_container p {
    margin: 0px;
    font-size: 12px;
}
.cart_allergen_container p.name {
    margin-bottom: 5px;
    color: #203152;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-family);
}
.cart_allergen_container p.message {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2; /* number of lines to show */
    -webkit-box-orient: vertical;
}
.cart_allergen_container button {
    border: none;
    background: none;
    box-shadow: none;
    padding: 0px;
    font-size: 12px;
    margin-top: 5px;
    text-decoration: underline;
}
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
input[type="number"] {
    -moz-appearance: textfield;
}
.pt-30 {
    padding-top: 30px;
}
.pb-30 {
    padding-bottom: 30px;
}
.loader.md {
    width: 40px;
    height: 40px;
    margin: 0 auto;
}
.loader.sm {
    width: 20px;
    height: 20px;
    margin: 0 auto;
    margin-top: -5px;
}
.loader.grey path {
    stroke: #C4C4C4;
}
.loader.white path {
    stroke: #fff;
}
.loader.red path {
    stroke: #E62929;
}
.loader.primary path {
    stroke: var(--background-btn-primary);
}
.link-btn {
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    background: none;
    border: none;
    padding: 0px;
    font-size: 14px;
    color: var(--background-btn-primary);
}
.link-btn span {
    color: var(--title-font-color);
}
.or_line {
    margin-left: 20px !important;
    margin-right: 20px !important;
    margin-top: 10px;
    display: inline-block;
}
.cta_container .btn {
    width: 100%;
    max-width: 240px;
}
.hero {
    height: var(--hero-height);
    position: relative;
}
.hero .overlay {
    background: rgba(0,0,0,0.6);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding-top: var(--hero-padding-top);
    padding-bottom: var(--hero-padding-bottom);
}
.hero h1 {
    color: #fff;
}
.hero h1 span {
    display: block;
}
.hero p {
    color: #f9f9f9;
    max-width: 500px;
    margin: 0 auto;
}
#header {
    z-index: 98 !important;
}
.announcement_bar {
    padding: 15px 0px;
    background: var(--announcment-bar-background-color);
}
span.reset_order {
    cursor: pointer;
    color: var(--announcment-bar-font-color);
    font-size: 14px;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
}
#header.has_accouncement_bar {
    top: 54px;
}
/*
Store/Order Type Landing Page
*/
#map {
    width: 100%;
    height: 100%;
    border-right: 1px solid rgba(0,0,0, 0.4);
}
#map div {
    border: none !important;
}
html, body.order_type_landing, .order_type_landing .row:not(.more_locations), .order_type_landing .map_col {
    height: 100%;
}
body.order_type_landing  {
    -webkit-text-stroke-width: 0px !important;
}
.order_type_landing .map_col {
    z-index: 0;
}
.order_type_landing .site_list_col {
    height: 100%;
    border-left: 1px solid #ddd;
}
.map_col {
    z-index: 0;
}
.sites_col {
    height: 100%;
}
.sites_list {
    padding: 20px;
    color: #000;
    overflow-y: scroll;
    height: calc(100% - 125px);
}
@-webkit-keyframes img_fade_pulse {
    0% { background: rgb(189, 189, 177, 0.2); }
    50% { background: rgb(189, 189, 177, 0.05); }
    100% { background: rgb(189, 189, 177, 0.2); }
}
@keyframes img_fade_pulse {
    0% { background: rgb(189, 189, 177, 0.2); }
    50% { background: rgb(189, 189, 177, 0.05); }
    100% { background: rgb(189, 189, 177, 0.2); }
}
.site_image {
    border-radius: 8px;
    margin-bottom: 10px;
    width: 100%;
    height: 200px;
    background: rgb(189, 189, 177, 0.2);
    display: inline-block;
    -webkit-animation: img_fade_pulse 2s infinite ease-in-out;
    -o-animation: img_fade_pulse 2s infinite ease-in-out;
    -ms-animation: img_fade_pulse 2s infinite ease-in-out; 
    -moz-animation: img_fade_pulse 2s infinite ease-in-out; 
    animation: img_fade_pulse 2s infinite ease-in-out;
    object-fit: cover;
}
.site_block_title {
    text-transform: uppercase;
    font-weight: bold;
    font-size: 50px;
    letter-spacing: 2px;
    -webkit-font-smoothing: antialiased; 
    transform: perspective(1px);
}
.site_title {
    color: #000;
    margin-bottom: 2px;
    font-size: 20px;
}
.site_address, .site_hours {
    margin-bottom: 0px;
    font-size: 14px;
    color: var(--body-font-color);
}
.order_type_site_container {
    cursor: pointer;
    transition: all ease-in-out 0.2s;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(14, 21, 14, 0.1);
}
.order_type_site_container.opaque {
    opacity: 0.3;
}
.order_type_site_container:hover {
    opacity: 0.5;
}
.order_type_site_container .btn i {
    margin-left: 3px;
    margin-top: 2px;
}
.site_search_container {
    padding: 16px 20px 0px 20px;
}
.site_search_container input {
    padding-left: 0px;
    padding-right: 0px;
    border: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 0px;
    background: none;
}
.site_search_container input:active, .site_search_container input:focus {
    background: none;
    border-color: none;
    border-bottom: 1px solid #000;
    box-shadow: none;
}
.site_order_type_container {
    padding: 20px 20px 0px 20px;
    text-align: center;
}
.site_order_type_container .btn {
    background: #E0E0E0;
    border-radius: 26px;
    border: none;
    font-size: 14px;
    margin-right: 5px;
    height: auto;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    color: var(--title-font-color);
}
.site_order_type_container .btn:hover, .site_order_type_container .btn:active, .site_order_type_container .btn:focus {
    background: #D0D0D0 !important;
    color: var(--title-font-color) !important;
}
.site_order_type_container .btn.active {
    font-weight: bold;
}
.site_order_type_container .btn.active:hover, .site_order_type_container .btn.active:active, .site_order_type_container .btn.active:focus {
    background: var(--background-hover-btn-primary) !important;
    color: var(--btn-font-color) !important;
}
.more_locations {
    display: none;
}
.start_order_button {
    white-space: nowrap;
}
@media (max-width: 1200px) {
    .start_order_button {
        width: 100%;
        margin-top: 15px;
    }
}
@media (max-width: 991px) {
    .start_order_button {
        width: auto;
        margin-top: 0px;
    }
    .sites_col {
        height: auto;
    }
    .more_locations {
        display: block;
        border-bottom: 1px solid rgba(14, 21, 14, 0.1);
        padding: 12px 16px;
        text-align: center;
        font-size: 14px;
        color: rgba(0,0,0,0.7);
        margin-bottom: 16px;
        cursor: pointer;
    }
    .more_locations span {
        position: relative;
        padding-left: 24px;
    }
    .more_locations i {
        font-size: 24px;
        color: #000000;
        position: absolute;
        left: 0px;
        top: -2px;
    }
    body.order_type_landing {
        padding-top: 0px;
        overflow: hidden;
    }
    .order_type_landing #header {
        display: none;
    }
    .order_type_landing .row, .order_type_landing .col {
        height: auto;
    }
    .order_type_landing .map_col {
        height: 100%;
    }
    .order_type_row {
        height: 100%;
    }
    .order_type_row .btn:last-child {
        margin-right: 0px;
    }
    .details_col {
        height: 0px;
    }
    #map {
        height: 100%;
    }
    .mobile_site_search_area {
        height: 122px;
    }
    .site_filter_container {
        background: #ffffff;
        position: fixed;
        top: 0px;
        left: 0;
        right: 0;
        box-shadow: rgba(0, 0, 0, 0.23) 0px 2px 2.62px;
        padding-bottom: 20px;
    }
    .site_block_title {
        font-size: 40px;
    }
    .sites_list {
        position: fixed;
        z-index: 910;
        bottom: 20px;
        left: 20px;
        right: 20px;
        height: 100%;
        max-height: 157px;
        padding: 20px;
        overflow-x: hidden;
        overflow-y: hidden;
        white-space: nowrap;
        border-radius: 8px;
        background: #fff;
        white-space: normal;
        display: inline-block;
        padding: 0px 20px 20px 20px;
        box-shadow: rgba(0, 0, 0, 0.23) 0px 2px 2.62px;
        transition: max-height 0.5s;
    }
    .sites_list.expanded {
        overflow-y: scroll;
        max-height: calc(100% - 179px);
    }
    .sites_list .order_type_site_container {
        border-bottom: none;
    }
    .sites_list.expanded .order_type_site_container {
        border-bottom: 1px solid rgba(14, 21, 14, 0.1);
    }
    .sites_list.expanded .order_type_site_container:last-child {
        border-bottom: none;
        padding-bottom: 0px;
        margin-bottom: 0px !important;
    }
    .sites_list:hover {
        opacity: 1;
        box-shadow: rgba(0, 0, 0, 0.23) 0px 2px 2.62px;
    }
    .sites_list .site_image {
        height: 90px;
        width: 90px;
        display: inline-block;
        margin-bottom: 0px;
        margin-right: 16px;
        float: left;
    }
    .map_overlay {
        position: absolute;
        top: 0;
        right: 0;
        left: 0;
        bottom: 0;
        background: rgba(0,0,0,0);
        transition: all ease-in-out 0.3s;
        z-index: 0;
    }
    .map_overlay.visible {
        background: rgba(0,0,0,0.7);
        z-index: 900;
    }
}
/*
Modals
*/
#modal, #order_type_modal, #order_time_modal, #site_modal, #loyalty_points_modal, #authentication_modal {
    z-index: 1060;
}
#alert_modal {
    z-index: 1070;
}
#item_modal, #address_modal {
    z-index: 1080;
}
#payment_modal {
    z-index: 1040;
}
.modal-content {
    border: none;
}
.modal-dialog {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}
.modal-md {
    max-width: 800px;
}
.modal-sm {
    max-width: 600px;
}
.modal .loading {
    padding: 80px 0px;
}
.modal .content {
    display: none;
    flex-direction: column;
    max-height: 100%;
    overflow: hidden;
    -ms-overflow-style: none;  /* IE and Edge */
    scrollbar-width: none;  /* Firefox */
}
.modal .modal-body::-webkit-scrollbar {
    display: none;
}
.modal .modal-body, .modal .modal-footer {
    padding: 30px;
}
.modal .container-fluid {
    padding-left: 0px;
    padding-right: 0px;
}
.modal .modal-content, .modal .modal-body {
    border-radius: 30px;
}
.modal .close {
    position: absolute;
    top: 30px;
    right: 30px;
    font-size: 16px;
    z-index: 99;
    color: var(--body-font-color);
}
.modal .product_image {
    border-radius: 15px;
    width: 100%;
    object-fit: cover;
    height: 20vh;
}
.modal h3 {
    font-size: 18px;
    margin-bottom: 15px;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
}
.modal p {
    font-size: 16px;
}
.modal .description {
    margin-bottom: 0px;
}
/*
Order Type & Time Modal
*/
.modal#order_type_modal .modal-dialog, .modal#order_time_modal .modal-dialog, .modal#site_modal .modal-dialog {
    max-width: 600px;
}
.modal#address_modal .modal-dialog {
    max-width: 500px;
}
.order_type_option p {
    margin-top: 5px;
    margin-bottom: 0px;
    font-size: 14px;
}
.modal#order_type_modal .order_type_option .name {
    margin-top: 0px;
    font-size: 16px;
    color: var(--title-font-color);
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
}
.modal#order_type_modal .form-group {
    margin-bottom: 10px;
}
.order_type_options p.name_label {
    font-size: 12px;
    color: var(--body-font-color);
    font-family: var(--body-font-family);
    font-weight: var(--body-font-weight);
    margin-top: 0px;
    margin-bottom: 5px;
}
.order_type_options {
    border-top: 1px solid #eee;
    margin-top: 25px;
    padding-top: 15px;
}
.order_type_options .order_type_option {
    padding: 15px;
    margin: 0 -15px 0 -15px;
    border-radius: 10px;
}
.order_type_options .order_type_option:not(.no_edit) {
    cursor: pointer;
    transition: background ease-in-out 0.2s;
}
.order_type_options .order_type_option.no_edit .link-btn {
    display: none;
}
.order_type_options .order_type_option:not(.no_edit):hover {
    background: #f2f2f2;
}
.new_address_container {
    margin: 0px -15px;
}
.new_address_container .new_address {
    padding: 15px 15px;
    border-radius: 10px;
    transition: background ease-in-out 0.2s;
    width: 100%;
    text-align: left;
    color: var(--title-font-color);
    height: 58px;
}
.new_address_container .new_address:hover {
    background: #f2f2f2;
}
.new_address_container .new_address .icon {
    display: inline-block;
    padding: 4px;
    margin-right: 5px;
    border-radius: 50%;
    background: #aaa;
    width: 28px;
    height: 28px;
    text-align: center;
}
.new_address_container .new_address .icon {
    background: #E0E0E0;
    color: var(--title-font-color);
}
/*
Site Modal
*/
.site_select_container {
    border: 2px solid #EEEEEE;
    background: #FEFEFE;
    padding: 20px;
    border-radius: 10px;
    cursor: pointer;
    transition: all ease-in-out 0.2s;
    margin-top: 20px;
}
.site_select_container.selected {
    border: 2px solid var(--background-btn-primary);
    background: var(--background-quantity-selector);
}
.site_select_container:not(.selected):hover {
    background: #f2f2f2;
}
.site_select_container .custom-radio .custom-control-label {
    font-size: 16px;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    padding-top: 0px;
    padding-left: 8px;
}
.site_select_container p {
    margin-bottom: 0px;
    font-size: 14px;
    padding-left: 8px;
}
.site_select_container .site_detail_container {
    padding-left: 10px;
}
.site_select_container .custom-radio .custom-control-label::before, .site_select_container .custom-radio .custom-control-label::after {
    top: 3px;
}
/*
Payment Modal
*/
.modal#payment_modal .modal-dialog {
    max-width: 900px;
}
#payment_modal p {
    font-size: 14px;
}
#payment_modal #complete_order {
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
    font-size: 18px;
    padding: 14px;
    height: auto;
    border-radius: 28px;
    margin-top: 20px;
    height: 57px;
}
#payment_modal #complete_order .order-total {
    right: 12px;
    top: 12px;
    padding: 5px 10px;
    font-size: 13px;
}
#complete_order .loader.sm {
    margin-top: -7px;
}
#payment_modal .complete_wallet_order {
    background: #000 !important;
    color: #fff;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
    font-size: 18px;
    padding: 14px;
    height: auto;
    border-radius: 28px;
    margin-top: 20px;
    height: 57px;
}
#payment_modal .complete_wallet_order:hover, #payment_modal .complete_wallet_order:focus, #payment_modal .complete_wallet_order:active, #payment_modal .complete_wallet_order:disabled {
    background: #141414 !important;
    color: #fff;
}
.complete_wallet_order .loader.sm {
    margin-top: -7px;
}
#payment_modal .complete_wallet_order img {
    height: 21px;
    margin-left: 2px;
    display: inline-block;
}
#payment_modal .payment_methods {
    margin-top: 30px;
}
#payment_modal .payment_details_container h4 {
    font-size: 16px;
    margin-bottom: 10px;
}
#payment_modal .line_items {
    max-height: 320px;
}
#card-element {
    height: auto;
}
.payment_cart_summary_container {
    background: #FBFBFB;
    margin-left: -30px;
    margin-right: -30px;
    margin-top: -30px;
    margin-bottom: -30px;
}
.payment_cart_summary_container .cart_summary {
    padding: 30px 60px 30px 30px;
}
.payment_cart_summary_container .line_items {
    margin-top: 15px;
    padding-top: 15px;
}
.payment_cart_summary_container .site_container {
    border-bottom: 1px solid #F0F0F0;
    padding-bottom: 30px;
}
.payment_details_container {
    background: #fff;
    padding: 30px !important;
    margin-right: -30px;
    margin-top: -30px;
    margin-bottom: -30px;
    border-radius: 30px;
    box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.1);
}
.payment_details_container h3 {
    margin-bottom: 20px;
    display: block;
}
.payment_details_container .order_details {
    margin-top: 5px;
}
.payment_details_container .order_details .form-group {
    margin-top: 5px;
}
.payment_methods .payment_form {
    margin-top: 15px;
}
.payment_details_container .outcome {
    margin-bottom: 15px;
    font-size: 14px;
}
.payment_details_container .outcome .success {
    color: green;
}
.payment_details_container .outcome .error {
    color: red;
}
.unavailable_cart_container {
    max-width: 350px;
    margin: 0 auto;
}
.empty_cart_container p strong, .unavailable_cart_container p strong {
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    color: var(--title-font-color);
    font-size: 16px;
}
/*
Authentication Modal
*/
.modal#authentication_modal .modal-dialog, .modal#verify_modal .modal-dialog {
    max-width: 500px;
}
.sign_in_container {
    margin-top: 30px;
}
.sign_in_container .btn-link-light {
    margin-top: 10px;
}
.or {
    display: inline-block;
    width: 100%;
    border-top: 1px solid #EEEEEE;
    text-align: center;
    margin-top: 20px;
}
.or span {
    display: inline-block;
    position: relative;
    top: -14px;
    color: #727F96;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    background: #fff;
    padding: 5px 7px;
    font-size: 12px;
}
.btn-email {
    background: #fff;
    color: var(--title-font-color);
    padding: 10px 30px;
    height: 46px;
    border-radius: 25px;
    border: 1px solid #ddd;
    position: relative;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    transition: all ease-in-out 0.2s;
}
.btn-email:hover, .btn-email:focus, .btn-email:active, .btn-email:disabled {
    background: #fefefe;
}
.btn-google {
    margin-top: 15px !important;
    background: #0091EB;
    color: #fff;
    padding: 10px 30px;
    height: 46px;
    border-radius: 25px;
    border: 1px solid #0091EB;
    position: relative;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    transition: all ease-in-out 0.2s;
}
.btn-google:hover, .btn-google:focus, .btn-google:active, .btn-google:disabled {
    background: #007DCA;
    color: #fff;
}
.btn-facebook {
    margin-top: 15px !important;
    background: #3E5895;
    color: #fff;
    padding: 10px 30px;
    height: 46px;
    border-radius: 25px;
    border: 1px solid #3E5895;
    position: relative;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    transition: all ease-in-out 0.2s;
}
.btn-facebook:hover, .btn-facebook:focus, .btn-facebook:active, .btn-facebook:disabled {
    background: #264284;
    color: #fff;
}
.btn-apple {
    margin-top: 15px !important;
    background: #000;
    color: #fff;
    padding: 10px 30px;
    height: 46px;
    border-radius: 25px;
    border: 1px solid #000;
    position: relative;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    transition: all ease-in-out 0.2s;
}
.btn-apple i {
    margin-right: 5px;
}
.btn-apple:hover, .btn-apple:focus, .btn-apple:active, .btn-apple:disabled {
    background: #141414;
    color: #fff;
}
.btn-email img {
    height: 12px;
    margin-top: -2px;
    margin-right: 5px;
}
.btn-google img, .btn-facebook img {
    height: 14px;
    margin-top: -2px;
    margin-right: 5px;
}
/*
Account
*/
.sign_in_container label {
    z-index: 10 !important;
}
.iti__country-list {
    top: 45px !important;
    border-top: none;
    box-shadow: none;
    border: 1px solid #ddd;
    border-radius: 0px;
    border-bottom-right-radius: 10px;
    border-bottom-left-radius: 10px;
    width: 440px;
    height: 300px;
}
.iti__country, .iti-mobile .iti__country {
    padding: 10px 22px;
}
.iti__divider {
    padding: 0px;
    margin: 0px;
    border-color: #eee;
}
.iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag {
    background-color: rgba(0,0,0,0) !important;
}
.iti {
    width: 100% !important;
}
.iti__selected-flag {
    padding: 0 6px 0 22px !important;
}
.iti-mobile .iti--container {
    top: auto !important;
    bottom: -30px;
    z-index: 9999;
    height: 400px;
}
#verify_phone {
    padding-left: 65px;
}
#verify_modal .modal-dialog, #verify_modal .modal-content, #verify_modal .content, #verify_modal .modal-body {
    overflow: visible !important;
} 
.nav-link.account.processing {
    padding: 13px 32px;
}
.nav-link.account img {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    margin-right: 5px;
    margin-top: -3px;
}
.account_container {
    background: #FBFBFB;
    margin-left: -30px;
    margin-right: -30px;
    margin-top: -30px;
    margin-bottom: -30px;
}
.account_container .account_menu {
    padding: 30px 60px 30px 30px;
}
.account_details_container {
    background: #fff;
    padding: 30px !important;
    margin-right: -30px;
    margin-top: -30px;
    margin-bottom: -30px;
    border-radius: 30px;
    box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.1);
}
.account_menu img {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    margin-right: 10px;
}
.account_menu .name {
    color: var(--title-font-color);
    font-size: 16px;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    margin-bottom: 0px;
}
.account_menu .section_heading {
    margin-top: 30px;
    margin-bottom: 0px;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    font-size: 12px;
    color: var(--body-font-color);
}
.account_menu .list-group {
    font-size: 14px;
    margin-left: -15px;
    cursor: pointer;
}
.account_menu .list-group-item {
    background: none;
    padding: 15px;
    border: none !important;
    transition: all ease-in-out 0.2s;
    border-radius: 10px;
    color: var(--title-font-color);
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.account_menu .list-group-item:hover {
    background: #f2f2f2;
}
.account_menu .list-group-item:last-child:hover {
    background: none;
}
.account_menu .list-group-item+.list-group-item.active {
    margin-top: 0px;
}
.account_menu .list-group-item.active {
    color: var(--background-btn-primary);
}
.account_menu .list-group-item i {
    width: 20px;
}
.accordion .card-header {
    background: none;
    border: none;
    padding: 0px;
}
.accordion>.card {
    padding: 20px 0px;
    border: none;
    border-bottom: 1px solid #EEEEEE;
    overflow: visible;
}
.accordion>.card:last-child {
    border-bottom: none;
}
.accordion.cards .card:first-child {
    border-top: 1px solid #EEEEEE;
}
.accordion .item_name {
    font-size: 14px;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    color: var(--title-font-color);
    margin-bottom: 0px;
}
.accordion .item_detail {
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    color: #727F96;
    font-size: 14px;
    margin-left: 10px;
}
.account_details_container .order_summary {
    font-size: 14px;
    color: #727F96;
    margin-bottom: 0px;
    margin-top: 10px;
}
.accordion .card-header {
    cursor: pointer;
    padding-right: 30px;
}
.accordion .card-body {
    border-top: 1px solid #f9f9f9;
    margin-top: 20px;
    padding: 15px 0px 0px 0px;
}
.accordion .card-body .table {
    margin-bottom: 0px;
}
.accordion .card-body .table tr td {
    border: none;
    padding: 5px 0px;
    font-size: 14px;
    color: var(--body-font-color);
}
.accordion .card-body .product_name, .accordion .card-body .product_price {
    font-size: 14px;
    color: var(--title-font-color);
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    margin-bottom: 10px;
}
.accordion .card-body .product_name>span {
    color: var(--body-font-color);
}
.accordion strong {
    font-size: 14px;
    color: var(--title-font-color);
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.accordion .card-body ul {
    padding: 0px;
    margin: 0px;
    list-style: none;
}
.log_out .loader.sm {
    margin-left: 0px;
}
.log_out_menu_item {
    display: none;
}
.referral_program_image_container .referral_program_image {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    margin: 0 auto;
}
.referral_program_code_header {
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    color: #000;
    font-size: 14px !important;
    text-transform: uppercase;
}
.referral_program_code {
    background: #f2f2f2;
    padding: 15px;
    width: 100%;
    border-radius: 30px;
}
.referral_program_code p {
    margin-bottom: 0px;
    font-size: 22px;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.referral_program_terms_url {
    font-size: 14px;
    color: #000;
    text-decoration: underline;
}
.referral_program_terms_url:hover {
    color: rgba(0,0,0,0.7);
}
/* Menu */
#header .container {
    padding: 0px;
}
.navbar-expand-lg .navbar-nav .nav-link {
    padding: 10px 25px;
    border-radius: 10px;
    cursor: pointer;
    white-space: nowrap;
}
.navbar-expand-lg .navbar-nav .nav-item:hover .nav-link {
    background: #f2f2f2;
}
.bg-dark {
    background-color: #000!important;
}
.navbar-expand-lg.navbar-dark .navbar-nav .nav-item .nav-link {
    color: #fff;
}
.navbar-expand-lg.navbar-dark .navbar-nav .nav-item:hover .nav-link {
    background: rgba(255,255,255,0.1);
}
.nav-link.account {
    cursor: pointer;
}
#menu_icon {
    width: 25px;
    height: 20px;
    position: relative;
    margin: 0px;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    -o-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
    cursor: pointer;
}
#menu_icon span {
    display: block;
    position: absolute;
    height: 3px;
    width: 100%;
    background: #434E62;
    border-radius: 9px;
    opacity: 1;
    left: 0;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: .25s ease-in-out;
    -moz-transition: .25s ease-in-out;
    -o-transition: .25s ease-in-out;
    transition: .25s ease-in-out;
}
#menu_icon span:nth-child(1) {
    top: 0px;
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -o-transform-origin: left center;
    transform-origin: left center;
}
#menu_icon span:nth-child(2) {
    top: 8px;
    width: 80%;
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -o-transform-origin: left center;
    transform-origin: left center;
}
#menu_icon span:nth-child(3) {
    top: 16px;
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -o-transform-origin: left center;
    transform-origin: left center;
}
#menu_icon.open span:nth-child(1) {
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
    top: -1px;
    left: 3px;
}
#menu_icon.open span:nth-child(2) {
    width: 0%;
    opacity: 0;
}
#menu_icon.open span:nth-child(3) {
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    transform: rotate(-45deg);
    top: 17px;
    left: 3px;
}
/*
Accordion
*/
.accordion .card-header {
    position: relative;
}
.accordion .card-header::after {
    flex-shrink: 0;
    font-size: 14px;
    content: "\f054";
    font-family:"Font Awesome 5 Pro";
    color: var(--body-font-color);
    transition: transform .2s;
    position: absolute;
    margin: auto;
    top: 0;
    right: 5px;
    bottom: 0;
    height: 18px;
}
.accordion .card-header:not(.collapsed)::after {
    transform: rotate(90deg);
}
/*
Forms
*/
.form-group {
    position: relative;
}
.form-group label {
    font-size: 12px;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    color: #727F96;
    position: absolute;
    left: 15px;
    background: #fff;
    padding: 2px 7px;
    top: -11px;
}
.form-group input, .form-group textarea, .form-group select, .form-control#card-element {
    font-size: 16px;
    color: var(--title-font-color);
    padding: 13px 20px;
    height: auto;
    border-radius: 10px;
    border-color: #E5E8EF;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
}
/* do not group these rules */
.form-control::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    font-family: var(--body-font-family);
    font-weight: var(--body-font-weight);
    color: var(--body-font-color);
    font-size: 16px;
    opacity: 1; /* Firefox */
}
.form-control:-ms-input-placeholder { /* Internet Explorer 10-11 */
    font-family: var(--body-font-family);
    font-weight: var(--body-font-weight);
    color: var(--body-font-color);
    font-size: 16px;
}
.form-control::-ms-input-placeholder { /* Microsoft Edge */
    font-family: var(--body-font-family);
    font-weight: var(--body-font-weight);
    color: var(--body-font-color);
    font-size: 16px;
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
    transition: background-color 5000s ease-in-out 0s;
}
/*
Cart
*/
#cart_summary {
    background: #fff;
    box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.1);
    border-radius: 30px;
    padding: 30px;
    z-index: 97;
    position: -webkit-sticky;
    position: sticky;
    top: 86px;
    bottom: 90px;
}
.menu_container #cart_summary {
    box-shadow: 0px 10px 10px rgba(0, 0, 0, 0.1);
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
}
.cart_summary {
    font-size: 14px;
    color: var(--body-font-color);
}
.site_container .order_type {
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    font-size: 14px;
    color: var(--body-font-color);
    margin: 0px;
}
.site_container .order_type span {
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
}
.site_container .site_name {
    font-size: 16px;
    color: var(--title-font-color);
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    margin: 10px 0 0 0;
}
.site_container p {
    margin: 10px 0 10px 0;
}
.site_container .change_type {
    margin: 10px 0 0 0;
}
.order_type_data_container {
    padding: 15px;
    border-radius: 10px;
    background: #f2f2f2;
    margin-bottom: 10px;
}
.order_type_data_container strong {
    color: #000;
}
.cart_button_container {
    text-align: center;
    border-bottom: 1px solid #F0F0F0;
    padding: 15px 0px;
}
#sm_order_type .cart_button_container {
    border-bottom: none;
    padding: 0px;
    margin-top: 10px;
}
.cart_button_container .button_container {
    margin: 0px -15px;
}
.cart_button_container .link-btn {
    padding: 15px 15px;
    margin: 0px -50px;
    border-radius: 10px;
    transition: background ease-in-out 0.2s;
    width: 100%;
    text-align: left;
    color: var(--title-font-color);
    height: 58px;
}
.cart_button_container .link-btn.loyalty {
    height: auto;
}
.cart_button_container .link-btn:hover {
    background: #f2f2f2;
}
.cart_button_container .link-btn .icon, .loyalty .icon {
    display: inline-block;
    padding: 4px;
    margin-right: 5px;
    border-radius: 50%;
    background: #aaa;
    width: 28px;
    height: 28px;
    text-align: center;
}
.cart_button_container .link-btn.redeem .icon {
    background: #E0E0E0;
    color: var(--title-font-color);
}
.loyalty .icon {
    background: #FF9B05 !important;
    color: #000 !important;
}
.line_items {
    padding: 30px 23px 15px 30px;
    margin: 0px -30px 0px -30px;
    max-height: calc(100vh - 630px);
    overflow-y: scroll;
}
.line_items.minus_60 {
    max-height: calc(100vh - 660px);
}
.line_items .loader.sm {
    margin-top: 0px !important;
}
.line_item {
    font-size: 14px;
    cursor: pointer;
    margin: -15px;
    padding: 15px;
    margin-bottom: 15px;
    border-radius: 10px;
    transition: background ease-in-out 0.2s;
}
.line_item.payment {
    cursor: initial;
}
.line_items .line_item:last-child {
    margin-bottom: 0px;
}
.line_item:hover {
    background: #f2f2f2;
}
.line_item p {
    margin: 0px;
}
.line_item .quantity {
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    background: #f2f2f2;
    border-radius: 5px;
    width: 30px;
    height: 30px;
    display: inline-block;
    text-align: center;
    margin-right: 10px;
    line-height: 30px;
}
.line_item .product_name {
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    color: var(--title-font-color);
    margin: 0px;
    margin-bottom: 0px;
}
.line_item .price {
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    color: var(--title-font-color);
}
.line_item.has_modifiers .product_name, .line_item.has_modifiers .price {
    padding-top: 0px;
}
.line_item ul {
    list-style: none;
    padding: 0px;
    margin: 0px;
}
.line_item ul li ul {
    margin-left: 1rem;
}
.line_item .remove {
    color: #E62929;
    margin-top: 0px;
    display: inline-block;
    padding: 6px 10px 0px 10px;
    margin-left: -10px;
    height: 27px;
    text-align: left;
    cursor: pointer;
}
.line_item .remove .loader {
    margin-top: 0px !important;
}
.change_order_type.payment {
    display: none;
}
.cart_summary .totals {
    border-top: 1px solid #F0F0F0;
    padding-top: 30px;
    color: var(--body-font-color);
}
.cart_summary .totals .row {
    margin-top: 10px;
    margin-bottom: 0px;
}
.cart_summary .totals .row:first-child {
    margin-top: 0px;
}
.cart_summary .totals .total_row {
    color: var(--title-font-color);
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    font-size: 18px;
}
#cart_summary ::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 7px;
}
#cart_summary ::-webkit-scrollbar-thumb {
    border-radius: 4px;
    background-color: rgba(0,0,0,.1);
    -webkit-box-shadow: 0 0 1px rgba(255, 255, 255, .2);
}
/*
Code Modal
*/
#code_welcome_modal .order_type_image {
    max-width: 180px;
    border: 2px solid #E5E8EF;
    border-radius: 10px;
    margin-top: 10px;
    margin-bottom: 20px;
}
/*
Categories
*/
.category_container h3 {
    color: var(--category-title-font-color);
}
.category_container p {
    color: var(--category-description-font-color);
}
.menu_container {
    margin-top: -56px;
}
.category_background {
    background: #fff;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
    height: 56px;
    z-index: 10 !important;
}
#category_navbar {
    height: 56px;
    z-index: 97 !important;
    background: #fff;
    padding-right: 0px;
}
#category_navbar ul {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
#category_navbar ul::-webkit-scrollbar {
    display: none;
}
#category_navbar li {
    flex: 0 0 auto;
}
#category_navbar .nav-pills a {
    color: var(--background-btn-primary);
}
#category_navbar .nav-pills .nav-link.active, #category_navbar .nav-pills .show>.nav-link {
    background: var(--background-btn-primary);
    color: var(--btn-font-color);
}
#category_navbar .nav-pills .nav-link {
    border-radius: 20px;
}
.category_container {
    padding: 40px 0px;
}
.category_container h3 {
    margin-bottom: 20px;
}
/*
Products
*/
.product_search_container .search {
    border: 1px solid #EEEEEE;
}
.product.card, .promotion.card {
    background: var(--product-card-background-color);
}
.product .card-title, .promotion .card-title {
    font-size: 18px;
    line-height: 26px;
    color: var(--product-card-title-font-color);
}
.product .card-text, .promotion .card-text {
    color: var(--product-card-description-font-color);
}
.product .card-text.price, .promotion .card-text.price {
    color: var(--product-card-price-font-color);
}
.product {
    border-radius: 15px;
    cursor: pointer;
    transition: box-shadow 0.2s ease-in-out;
}
.product:hover {
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
}
.product .card-img, .product .card-img-top {
    border-top-left-radius: 15px;
    border-top-right-radius: 15px;
}
.product .card-img-top {
    width: 100%;
    height: 10vw;
    max-height: 200px;
    object-fit: cover;
}
.product .card-text {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3; /* number of lines to show */
    -webkit-box-orient: vertical;
}
.product .card-text.price {
    font-size: 14px;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    line-height: 26px;
}
.product .card-text.price.border {
    border: 1px solid #ddd;
    padding: 3px 6px;
    border-radius: 5px;
    display: inline-block;
}
.product_details {
    padding-bottom: 30px;
}
.product.loyalty_product .card-body {
    padding-right: 55px;
}
.product.loyalty_product .loyalty {
    position: absolute;
    right: 20px;
    top: 20px;
}
.product.loyalty_product .loyalty .icon {
    height: 25px;
    width: 25px;
    margin-right: 0px;
    font-size: 12px;
}
.half_half_variations, .variations {
    margin-top: 20px;
}
.half_half_variations .hidden, .variations.hidden {
    display: none;
}
.custom-control-input:checked ~ .custom-control-label::before {
    color: #fff;
    border-color: var(--background-btn-primary);
    background-color: var(--background-btn-primary);
}
.custom-control-label::before, .custom-control-label::after {
    top: 17px;
}
.custom-control-label {
    cursor: pointer;
    color: var(--title-font-color);
    font-size: 14px;
    vertical-align: middle;
    width: 100%;
    padding: 15px 0px;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.custom-radio .custom-control-label {
    padding: 8px 0px;
}
.custom-radio .custom-control-label::before, .custom-radio .custom-control-label::after {
    top: 10px;
}
.custom-control-label span {
    color: var(--body-font-color);
}
.custom-control-label span.description {
    font-weight: var(--body-font-weight);
}
.modifier_list_name {
    font-size: 14px;
    margin-bottom: 0px;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.modifier_list_name span {
    display: inline-block;
    margin-left: 5px;
    font-family: var(--body-font-family);
    font-weight: var(--body-font-weight);
}
.modifier_list_name span.errors {
    color: #E62929;
}
.modifier_container {
    margin-left: -15px;
    margin-right: -15px;
    padding-left: 15px;
    padding-right: 15px;
    border-radius: 10px;
    transition: background ease-in-out 0.2s;
}
.modifier_list .modifier {
    border-top: 1px solid #F2F2F2;
    cursor: pointer;
}
.modifier_list .modifier_container:hover {
    background: #f2f2f2;
}
.modifier_list .modifier_items .modifier_container:first-child .modifier {
    border-top: none;
}
.modifier_list.collapsible.collapsible .modifier_items {
    display: none;
}
.modifier_list_header {
    position: relative;
    padding: 10px 15px 5px 15px;
    margin-left: -15px;
    margin-right: -15px;
    margin-top: 20px;
}
.modifier_list.collapsible .modifier_list_header {
    cursor: pointer;
}
.modifier_list_header .arrow {
    position: absolute;
    top: 12px;
    right: 15px;
}
.modifier_list.collapsible .arrow:before {
    float: right;
    display: inline;
    font-size: 12px;
    font-family: "Font Awesome 5 Pro";
    height: auto;
    content: "\f078";
    font-weight: 500;
    text-shadow: none;
    -webkit-transition: all 0.12s ease;
    transition: all 0.12s ease;
}
.modifier_list.collapsible.collapsed .arrow:before {
    transform: rotate(-90deg);
}
.item_with_modifiers {
    transition: all 0.2s ease-in-out !important;
    margin-bottom: 10px;
    margin-right: 10px;
}
.item_with_modifiers:not(.custom-control):hover {
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
}
.custom-control.custom-ingredient-control .custom-control-label:after, .custom-control.custom-ingredient-control .custom-control-label:before {
    display: none;
}
.custom-control.custom-ingredient-control {
    padding-left: 0px;
}
.custom-control.custom-ingredient-control .ingredient_count {
    display: none;
    padding-right: 2px;
}
.modifier_list.ingredient_list .custom-control.custom-ingredient-control .ingredient_count, .modifier_list:not(.ingredient_list) .modifier.edited .custom-control.custom-ingredient-control .ingredient_count {
    display: inline-block;
}
.modifier.edited .custom-control.custom-ingredient-control .ingredient_count {
    color: var(--background-btn-primary);
}
.modifier {
    user-select: none;
}
.custom-control.custom-ingredient-control .remove_modifier {
    position: absolute;
    color: #E62929;
    display: none;
    cursor: pointer;
    right: 0px;
    top: 7px;
    padding: 7px 15px;
    background: #fff;
    border-radius: 5px;
}
.modifier:not(.hide_remove) .custom-control.custom-ingredient-control.ingredient_included .remove_modifier, .modifier_list:not(.ingredient_list) .modifier.edited:not(.hide_remove) .custom-control.custom-ingredient-control .remove_modifier {
    display: block;
}
.btn, .quantity-selector .minus-quantity, .quantity-selector .plus-quantity {
    transition: background ease-in-out 0.2s;
}
.btn-primary {
    background: var(--background-btn-primary);
    border: none;
    color: var(--btn-font-color);
    padding: 10px 30px;
    height: 46px;
    border-radius: 25px;
    position: relative;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.btn-primary:hover, .btn-primary:focus, .btn-primary:active, .btn-primary:disabled {
    background: var(--background-hover-btn-primary) !important;
    border: none;
    color: var(--btn-font-color);
}
.btn-primary:not(:disabled):not(.disabled).active, .btn-primary:not(:disabled):not(.disabled):active, .show>.btn-primary.dropdown-toggle {
    background: var(--background-btn-primary);
    border: none;
    color: var(--btn-font-color);
}
.btn-primary-link {
    color: var(--background-btn-primary);
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
    background: none;
    border: none;
    padding: 0px;
}
.btn-primary-link:hover, .btn-primary-link:focus, .btn-primary-link:active, .btn-primary-link:disabled {
    color: var(--background-hover-btn-primary) !important;
}
.btn-secondary {
    background: #fff;
    border: none;
    color: #000;
    padding: 10px 30px;
    height: 46px;
    border-radius: 25px;
    position: relative;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.btn-secondary:hover, .btn-secondary:focus, .btn-secondary:active, .btn-secondary:disabled {
    background: #eee;
    border: none;
    color: #000;
}
.btn-delete {
    color: var(--background-btn-delete-color);
    padding: 10px 30px;
    height: 46px;
    border-radius: 25px;
    position: relative;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.btn-delete:hover, .btn-delete:focus, .btn-delete:active, .btn-delete:disabled {
    color: var(--background-btn-delete-color-hover);
}
.btn-link-light {
    color: #727F96;
    padding: 10px 30px;
    transition: all ease-in-out 0.2s;
}
.btn-link-light:hover, .btn-link-light:focus, .btn-link-light:active, .btn-link-light:disabled {
    color: var(--title-font-color);
}
.btn-complete {
    margin-top: 20px;
}
.btn-add {
    padding: 10px 90px 10px 30px;
}
.btn-add.processing {
    padding: 7px 35px;
}
.btn-primary .order-total {
    position: absolute;
    right: 8px;
    top: 8px;
    background: var(--background-cost);
    padding: 5px 10px;
    font-size: 12px;
    border-radius: 20px;
}
.btn-close {
    background: #fff;
    border: 1px solid #DDDDDD;
    padding: 10px 30px;
    border-radius: 25px;
    color: var(--title-font-color);
}
.btn-close:hover {
    background: #f9f9f9;
}
.quantity-selector {
    padding-top: 5px;
    user-select: none;
}
.quantity-selector span {
    display: inline-block;
    text-align: center;
}
.quantity-selector .minus-quantity, .quantity-selector .plus-quantity {
    background: var(--background-btn-primary);
    width: 30px;
    height: 30px;
    border-radius: 50%;
    padding-top: 4px;
    color: #fff;
    cursor: pointer;
}
.quantity-selector .minus-quantity:hover, .quantity-selector .plus-quantity:hover {
    background: var(--background-hover-btn-primary);
}
.quantity-selector .minus-quantity.disabled, .quantity-selector .plus-quantity.disabled {
    background: var(--background-hover-btn-primary);
    opacity: 0.25;
}
.quantity-selector .quantity-display {
    display: inline-block;
    text-align: center;
    padding: 4px 12px;
    color: var(--title-font-color);
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
}
/*
Promotions
*/
#site_promotions h3 {
    margin-top: 40px;
    margin-bottom: 20px;
}
.promotion {
    border-radius: 15px;
    cursor: pointer;
    transition: box-shadow 0.2s ease-in-out;
}
.product .card-title {
    font-size: 18px;
    line-height: 26px;
}
.promotion:hover {
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
}
.promotion .card-img, .promotion .card-img-top {
    border-top-left-radius: 15px;
    border-top-right-radius: 15px;
}
.promotion .card-img-top {
    width: 100%;
    height: 10vw;
    object-fit: cover;
}
.promotion .card-text {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3; /* number of lines to show */
    -webkit-box-orient: vertical;
}
#promotion_modal .product.btn-close {
    margin-bottom: 10px;
    margin-right: 5px;
}
.item_name i.fa-check-circle {
    color: #2BCB6B;
    margin-left: 10px;
}
.card-header.has_product::after {
    display: none;
}
.card-header.has_product {
    padding-right: 0px;
}
.card-header.has_product .item_name {
    color: var(--body-font-color);
}
.card-header .remove, .card-header .remove_half, .selected_element .remove {
    color: #E62929;
    font-size: 14px;
    display: inline-block;
    cursor: pointer;
}
.selected_element {
    margin-top: 15px;
    padding: 20px;
    border: 1px solid #eee;
    border-radius: 15px;
}
.selected_element p {
    font-size: 14px;
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
    color: var(--title-font-color);
    padding-top: 0px;
    margin-bottom: 0px;
}
.selected_element ul, .custom-control ul {
    list-style: none;
    padding: 0px;
    margin: 5px 0px 0px 0px;
    font-size: 14px;
    color: var(--body-font-color);
    font-weight: normal;
}
/*
Footer
*/
footer {
    font-size: 14px;
    color: var(--body-font-color);
}
footer .company_info {
    background: var(--footer-detail-section-background-color);
    color: var(--footer-detail-section-font-color);
    padding: 40px 0px;
}
footer .company_info a {
    color: var(--footer-detail-section-font-color);
}
footer .company_info strong, footer .company_info .semi-bold {
    color: var(--footer-detail-section-bold-font-color);
}
footer .privacy_policy {
    font-size: 14px;
}
footer .attribution {
    background: var(--footer-copyright-section-background-color);
    padding: 40px 0px;
    text-align: center;
}
footer .attribution p {
    color: var(--footer-copyright-section-font-color);
    font-size: 14px;
    margin-bottom: 0px;
}
footer p strong {
    font-family: var(--title-font-family);
    font-weight: var(--title-font-weight);
}
footer .map {
    max-height: 95px;
    overflow: hidden;
    border-radius: 15px;
}
footer .map iframe {
    margin-top: -102px;
    width: 100%;
}
footer a, footer a:hover {
    color: var(--body-font-color);
}
.footer_site_container {
    margin-bottom: 30px;
}
/*
Misc
*/
#header {
    background-color: var(--header-background-color) !important;
}
.logo {
    max-width: var(--logo-max-width);
}
body {
    padding-top: var(--body-padding-top);
}
.order_type_data {
    margin-top: 15px;
    font-family: var(--detail-font-family);
    font-weight: var(--detail-font-weight);
}
.order_time_data {
    margin-top: 30px;
}
.order_type_data .form-group {
    margin-top: 25px;
}
.order_type_data .custom-control-label {
    padding: 5px 0px;
}
.order_type_data .custom-control-label::before, .order_type_data .custom-control-label::after {
    top: 7px;
}
.modal#order_type_modal .address {
    margin-top: 25px;
}
div.pac-container {
    z-index: 99999999999 !important;
}
.search_container, .product_search_container {
    position: relative;
    margin-top: 30px;
    margin-bottom: 10px;
}
.search_container i, .product_search_container i {
    position: absolute;
    top: 20px;
    left: 20px;
    color: #DDDFE4;
}
.search {
    background: #F8F8F8;
    border: none;
    color: #DDDFE4;
    padding: 15px 20px 15px 50px;
    height: auto;
}
.search:before {
    font-family: FontAwesome;
    content: "\f095";
    display: inline-block;
    padding-right: 3px;
    vertical-align: middle;
}
.sm-gutters {
    margin-left: -10px;
    margin-right: -10px;
}
.sm-gutters>.col, .sm-gutters>[class*=col-] {
    padding-right: 10px;
    padding-left: 10px;
}
p.fine-print {
    font-size: 12px !important;
    color: var(--body-font-color);
    max-width: 280px;
    margin-top: 20px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    margin-bottom: 0px;
}
#sm_cart_container {
    display: none;
    box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.1);
}
#sm_cart_container .btn-complete {
    margin-top: 0px;
}
#sm_order_type {
    display: none;
    background: #fff;
}
#sm_order_type .line_items, #sm_order_type .totals, #sm_order_type .complete_order, #payment_modal .complete_order {
    display: none;
}
#sm_order_type p {
    font-size: 14px;
}
.no_menu {
    padding: 30px 0px;
}
.form-control:disabled, .form-control[readonly] {
    background: #fff;
    color: #989FB0;
}
#redemption_code {
    text-transform: uppercase;
}
.group_product {
    cursor: pointer;
}
.reward, .group_product {
    border: 1px solid #eee;
    border-radius: 20px;
    padding: 20px;
    margin-bottom: 10px;
}
.reward:last-child, .group_product:last-child {
    margin-bottom: 0px;
}
.side_selection ul {
    list-style: none;
    padding: 0px;
    margin: 0px;
    font-size: 14px;
}
.item_name.errors {
    color: #E62929;
}
#half_half_modal .card .btn-close {
    margin-bottom: 10px;
    margin-right: 5px;
}
.restriction_message {
    font-size: 12px;
    font-weight: bold;
    margin-top: 8px !important;
}
.restriction_message .far {
    display: inline-block;
    margin-right: 2px;
}
.order_type_restriction_message {
    font-size: 14px;
    font-style: italic;
}
.custom-switch .custom-control-label::after {
    top: calc(1.19rem);
}
.brand_landing_page_container {
    max-width: 1000px;
    margin: 0 auto;
}
.brand_container {
    border: 1px solid #ddd;
    border-radius: 15px;
    padding: 30px;
    transition: box-shadow 0.2s ease-in-out;
    cursor: pointer;
}
.brand_container:hover {
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.1);
}
.brand_container img {
    height: 30vh;
    max-height: 300px;
    object-fit: cover;
}
/*
Cart Summary Overrides
*/
@media (max-height: 680px) {
    #cart_summary {
        position: relative;
        top: auto;
        bottom: auto;
    }
    #cart_summary .line_items {
        max-height: 100%;
    }
}
/*
Tablet Overrides
*/
@media (max-width: 1119px) {
    .navbar-expand-lg .navbar-nav .nav-link {
        padding: 10px 15px;
        border-radius: 10px;
        cursor: pointer;
        white-space: nowrap;
    }
}
/*
Mobile Overrides
*/
@media (max-width: 991px) {
    /* Hero */
    .hero {
        height: var(--hero-height);
    }
    .hero .overlay {
        padding-top: var(--hero-padding-top);
        padding-bottom: var(--hero-padding-bottom);
    }
    .category_background {
        display: none;
    }
    .cta_container .btn {
        margin-bottom: 20px;
    }
    .cta_container .btn:last-child {
        margin-bottom: 0px;
    }
    @media (pointer:none), (pointer:coarse) {
        .hero {
            background-attachment: unset;
            background-size: cover;
            background-position: center center !important;
        }
    }
    .h3, h3 {
        font-size: 1.5rem;
    }
    .products .col, #site_promotions .col {
        padding-left: 5px;
        padding-right: 5px;
    }
    .product .card-title, .promotion .card-title {
        font-size: 16px;
        line-height: 20px;
    }
    .product .card-text, .promotion .card-text {
        font-size: 14px;
    }
    .product .card-text.price, .promotion .card-text.price {
        font-size: 12px;
        line-height: 24px;
    }
    /* Fonts */
    .hero h1 {
        font-size: 34px;
    }
    /* Navbar */
    #header.navbar {
        padding: 15px 10px;
    }
    /* Category */
    #category_navbar {
        position: absolute;
        left: 0;
        right: 0;
        overflow: hidden;
    }
    #category_navbar li:first-child {
        margin-left: 20px;
    }
    #category_navbar li:last-child a {
        margin-right: 20px;
    }
    #category_navbar-sticky-wrapper.sticky-wrapper #category_navbar {
        width: 100% !important;
    }
    /* Product */
    #site_category_list, #site_menu {
        padding: 0px 15px 15px 15px;
    }
    #site_promotions {
        padding-left: 15px;
        padding-right: 15px;
    }
    .product .card-img-top, .promotion .card-img-top {
        height: 30vw;
    }
    .modal .product_image {
        height: 30vh;
        margin-bottom: 30px;
    }
    .product_details {
        padding-bottom: 0px;
    }
    .product_details h3, .product_details .description {
        text-align: center;
    }
    .product_details .quantity-selector {
        text-align: center;
        margin-top: 20px;
    }
    .modifiers {
        margin-top: 20px;
    }
    .half_half_variations, .variations {
        margin-top: 30px;
    }
    .modal-footer .quantity-selector {
        display: none;
    }
    .btn-add {
        width: 100%;
        padding-left: 90px;
    }
    .add_half_half {
        width: 100%;
    }
    .modifier_list .modifier_container:hover {
        background: #fff;
    }
    /* Modal */
    #modal .close {
        text-shadow: none;
        opacity: 1;
        border: 1px solid #fff;
        width: 30px;
        height: 30px;
        top: 30px;
        right: 30px;
        border-radius: 50%;
        background: rgba(255,255,255,0.9);
        color: #4a4a4a;
        box-shadow: 0px 4px 4px rgb(0 0 0 / 10%);
    }
    #modal .close.with_image {
        top: 40px;
        right: 40px;
    }
    .modal-open {
        overflow: hidden;
    }
    .modal .modal-content {
        border: none;
    }
    .modal:not(#payment_modal):not(#account_modal):not(#authentication_modal):not(#verify_modal):not(#qr_code_welcome_modal):not(#redeem_modal):not(.group_modal) .modal-body {
        padding-bottom: 145px;
    }
    .modal .modal-body.extra_padding {
        padding-bottom: 185px !important;
    }
    .modal#account_modal .modal-body .account_details_container {
        padding-bottom: 75px !important;
    }
    .modal-footer {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: #fff;
        z-index: 999;
    }
    .modal .modal-dialog {
        position: fixed;
        margin: auto;
        width: 100%;
        max-width: 100% !important;
        height: auto;
        padding-top: 70px;
    }
    .modal#account_modal .modal-dialog {
        padding-top: 40px;
    }
    .modal#payment_modal .modal-dialog {
        padding-top: 30px;
    }
    .modal .modal-content {
        height: auto;
        overflow-y: auto;
    }
    .modal .modal-dialog {
        -webkit-transform: translate3d(0%, 0, 0) !important;
        -ms-transform: translate3d(0%, 0, 0) !important;
        -o-transform: translate3d(0%, 0, 0) !important;
        transform: translate3d(0%, 0, 0) !important;
    }
    .modal.fade .modal-dialog {
        bottom: -100%;
        -webkit-transition: opacity 0.3s linear, bottom 0.3s ease-out;
        -moz-transition: opacity 0.3s linear, bottom 0.3s ease-out;
        -o-transition: opacity 0.3s linear, bottom 0.3s ease-out;
        transition: opacity 0.3s linear, bottom 0.3s ease-out;
    }
    .modal.fade.show .modal-dialog {
        bottom: 0;
        flex-direction: column;
        -ms-flex-pack: center;
        justify-content: flex-end;
        height: 100%;
        margin: 0px;
    }
    .modal .modal-body, .modal .modal-footer, .modal .modal-content {
        border-bottom-left-radius: 0px;
        border-bottom-right-radius: 0px;
    }
    #code_welcome_modal .modal-dialog {
        padding-top: 0px;
    }
    #code_welcome_modal.modal .modal-content {
        height: 100%;
    }
    #code_welcome_modal.modal .modal-body, #code_welcome_modal.modal .modal-content {
        border-radius: 0px;
    }
    #code_welcome_modal.modal.fade.show .modal-dialog {
        top: 0;
        max-height: 100%;
    }
    /* Cart */
    .order_type_data_container {
        margin-top: 10px;
    }
    .qr_ordering .cart_code_container {
        display: none;
    }
    #cart_summary, #cart_summary-sticky-wrapper {
        display: none;
    }
    #sm_cart_container {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        padding: 20px 20px 30px 20px;
        background: #fff;
        z-index: 97;
    }
    #sm_cart_container.show {
        display: block;
    }
    .payment_cart_summary_container {
        margin: 0px 0px 30px 0px;
    }
    .payment_cart_summary_container .site_container {
        padding-right: 20px;
    }
    .payment_cart_summary_container .cart_summary {
        padding: 30px;
        padding-bottom: 60px;
        margin: -30px;
        background: #FBFBFB;
    }
    .payment_details_container {
        margin-left: -30px;
    }
    #payment_modal #complete_order {
        font-size: 16px;
    }
    .change_order_type.payment {
        display: inline-block;
    }
    .line_item.payment .remove {
        display: inline-block;
    }
    #payment_modal p.address {
        margin-bottom: 0px;
    }
    .payment_details_container {
        margin: -30px;
        max-width: none;
        width: auto;
    }
    .cart_code_container {
        border-bottom: none;
        padding-bottom: 0px;
    }
    /* Account */
    .logout_section {
        display: none;
    }
    .account_container {
        margin: 0px 0px 30px 0px;
    }
    .account_container .account_menu {
        padding: 30px;
        padding-bottom: 40px;
        margin: -30px;
        background: #FBFBFB;
    }
    .account_details_container {
        margin: -30px;
        max-width: none;
        width: auto;
    }
    .account_menu .list-group-item:hover {
        background: none;
    }
    .account_container .list-group {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        flex-direction: row;
        -webkit-overflow-scrolling: touch;
        margin-left: -30px;
        margin-right: -30px;
    }
    .account_container .list-group-item:first-child {
        margin-left: 15px;
    }
    .account_container .list-group-item:last-child {
        padding-right: 30px;
    }
    .account_container .list-group::-webkit-scrollbar {
        display: none;
    }
    .account_container .list-group-item {
        flex: 0 0 auto;
        width: auto;
    }
    .log_out_menu_item {
        display: inline-block;
    }
    /* Misc */
    .logo {
        max-width: var(--mobile-logo-max-width);
    }
    body {
        padding-top: var(--mobile-body-padding-top);
    }
    .order_time_data .row .col-12:first-child .form-group {
        margin-bottom: 30px;
    }
    #sm_order_type .site_container.no_options {
        margin-bottom: 20px;
    }
    #sm_order_type {
        display: block;
        padding: 30px 20px 10px 20px;
        border-bottom: 1px solid #eee;
        margin-left: -15px;
        margin-right: -15px;
    }
    #sm_order_type p.address {
        margin-bottom: 0px;
    }
    .empty_cart_container, .unavailable_cart_container {
        padding: 50px 0px;
        min-height: 0px;
    }
    .add_promotion {
        width: 100%;
    }
    /* Menu */
    .navbar-toggler {
        padding: 0px 15px;
    }
    .navbar-expand-lg .navbar-nav .nav-link {
        padding: 10px 15px;
    }
    .navbar-expand-lg .navbar-nav .nav-link.account, .navbar-expand-lg .navbar-nav .nav-link.support {
        padding: 0px;
    }
    .navbar-expand-lg .navbar-nav:hover .nav-link.account, .navbar-expand-lg .navbar-nav:hover .nav-link.support {
        background: none;
    }
    .nav-link.account img {
        margin-right: 0px;
    }
    .offcanvas-collapse {
        position: fixed;
        top: 66px; /* Height of navbar */
        bottom: 0;
        right: 100%;
        width: 100%;
        padding: 15px;
        overflow-y: auto;
        background-color: #f2f2f2;
        z-index: 999 !important;
        -webkit-transition: right 0.2s ease-in-out;
        -moz-transition: right 0.2s ease-in-out;
        -o-transition: right 0.2s ease-in-out;
        transition: right 0.2s ease-in-out;
    }
    .offcanvas-collapse.open {
        right: 0%;
    }
    /* Footer */
    footer .company_info, footer .attribution {
        padding: 40px 15px;
    }
}