:root {
    --blue: #3f87f5;
}

@font-face {
    font-family: 'Atkinson';
    src: url('/font/atkinson/atkinson.ttf');
    font-weight: normal;
    font-style: normal;
}
body {
    background: #f3f6f8 !important;
    font-family: Atkinson, sans-serif;
}

h1, h2, h3, h4, h5, h6 {
    /*font-family: Arial, sans-serif;*/
}
.main-content p {
    line-height: 1.3;
}

.sm_logo {
    width: 200px;
}

.header {
    background: #fff;
    height: 4rem;
    border-bottom: 1px solid #edf2f9;
    box-shadow: 1px 0 10px rgba(0, 0, 0, 0.1);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 1030;
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: center;
    padding: 0.2em 2em;
}

.header a:has(.logo) {
    height: 100%;
}

.header .logo {
    width: auto;
    height: 100%;
    object-fit: contain;
    object-position: center;
    border: none;
    margin-right: 1em;
    max-width: 150px;
}

.header .mobile-toggle {
    cursor: pointer;
    display: none;
    width: 3rem;
    height: 2rem;
    justify-content: center;
    align-items: center;
}

.header .mobile-toggle i {
    font-size: 1.2rem;
}

.side-nav {
    top: 4rem;
    padding-top: 1em;
}

.side-nav-inner::-webkit-scrollbar {
    display: none;
    opacity: 0;
}

.side-nav .side-nav-inner .side-nav-menu {
    padding-bottom: 20px;
}

.side-nav .side-nav-inner .side-nav-menu {
    overflow: unset;
}

.side-nav-inner {
    overflow-y: scroll;
}
.side-nav .app_logo {
    width: 100%;
    max-height: 50px;
    object-fit: contain;
    object-position: center;
    padding: 1em;
}
.side-nav-underlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 999;
    backdrop-filter: blur(2px);
    background: rgba(0, 0, 0, 0.3);
}

.side-nav hr {
    margin: 1em 2em 0;
    width: calc(100% - 4em);
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 2px;
}

.is-expand .side-nav-underlay {
    display: block;
}

.fullscreen .header,
.fullscreen .side-nav,
.fullscreen .dashboard-header {
    display: none;
}

.header .header_search {
    display: flex;
    flex-flow: row nowrap;
    padding: 0.4em 1em;
    background: #fff;
    border: 1px solid var(--lt-lt-gray);
    justify-content: center;
    align-items: center;
    gap: 1em;
    border-radius: var(--border-sm);
}

.company_id_select {
    border: 1px solid rgba(255, 31, 31, 0.5);
    background: rgba(255, 31, 31, 0.05);
    font-size: 1rem;
}

.select2-container .select2-choice {
    border: none;
    border-radius: var(--border-sm);
    background: transparent;
}

.header_icon {
    margin-right: 1.2em;
}

.header_icon .icon {
    font-size: 1.3rem;
}

@media screen and (max-width: 992px) {
    .header {
        padding: 0.2em;
    }

    .header .mobile-toggle {
        display: flex;
    }

    .breadcrumbed_locations > div {
        flex-direction: column;
    }
}

@media screen and (max-width: 768px) {
    .header #search-mobile span {
        display: none;
    }
}

.bg {
    background-position: top;
}

.top_app_div {
    border: 1px solid #edf2f9;
    padding: 0px 10px;
    background-color: #edf2f9;
}

.top_app_div:hover {
    background-color: #fff;
}

.header .selected_app .logo {
    border-right: none;
    opacity: 1 !important;
}

.selected_app {
    background-color: #E1FFE2;
}

.card {
    border-radius: 0.5rem;
}

.card.sizer {
    min-height: 256px !important;
}

.card-body {
    padding: 1rem;
    border-bottom-left-radius: 0.5rem;
    border-bottom-right-radius: 0.5rem;
}

.btn-lg {
    padding: 1.2rem 2rem;
}

.modal-header {
    border-bottom: none;
    z-index: 999;
}

.modal-content {
    overflow-x: scroll;
}

.modal-footer {
    border-top: none;
}

.div-scroll {
    overflow-x: scroll;
}

.card-body::-webkit-scrollbar, .modal-content::-webkit-scrollbar, .image_gallery_div::-webkit-scrollbar {
    display: none;
}

.page-container .page-header {
    margin-bottom: 15px;
}

.no-sort::after, .no-sort::before {
    display: none !important;
}

.no-sort {
    pointer-events: none !important;
    cursor: default !important;
}

.cursor-pointer {
    cursor: pointer;
}

.text-green {
    color: green;
}

.text-light-green {
    color: #00c9a7;
}

.text-purple {
    color: #3E1C96;
}

.text-dark-red {
    color: #58151C;
}

.hide {
    display: none;
}

.scroll_list {
    border: 1px solid #ededed;
    padding: 1em;
    height: 350px;
    width: 100%;
    margin-bottom: 2em;
    overflow-x: hidden;
    overflow-y: scroll;
}

.scroll_list .scroll_record {
    width: 100%;
    padding: 5px;
    border-bottom: 1px solid #ededed;
}

.scroll_list .scroll_record .scroll_record_actions {
    float: right;
}

.asset_img {
    width: 100%;
    border: 1px solid #ededed;
}

.asset_img img {
    width: 100%;
}

.accordion-large > .card > .card-header > .card-title > a {
    background-color: var(--blue);
    color: #fff;
    font-size: 25px;
}
.card-header {
    border-bottom: 1px solid #ced4da;
}
.card-header.stock_cart {
    border-bottom: 0px !important;
}
.card-header.reports {
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    border-top-left-radius: 0.5rem;
    border-top-right-radius: 0.5rem;
}

.select2-container .select2-choice {
    padding: 0.4rem 1rem;
    height: 40px;
}

.select2-container .select2-choice .select2-arrow {
    width: 25px;
    padding-top: 5px;
    padding-left: 5px;
}

#s2id_company_id_select {
    width: 200px;
}

.icon-holder img {
    width: 25px;
}

.icon-img {
    width: 20px;
}

#map {
    height: 75vh;
    width: 100%;
    background-color: grey;
}

.map_key {
    height: 75vh;
    overflow-y: scroll;
}

.modal-side-xl {
    width: 100% !important;
    position: fixed;
    right: 0px;
}

.modal-side-xl .modal-content {
    overflow: auto;
}

.font-18 {
    font-size: 18px;
}

.thumbnail {
    height: 30px;
    max-width: 100%;
    object-fit: contain;
}

.thumbnail-med {
    width: 55px !important;
    max-width: 100%;
}

.thumbnail-lg {
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    background-position: center center;
    height: 115px !important;
    max-width: 100%;
}

.avatar_img {
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.notifications_div {
    height: 250px;
}

.input_padding_sm {
    padding: 5px;
    color: #53535f;
    margin-right: 10px;
    margin-left: 10px;
    width: 50px;
    text-align: center;
}

hr {
    margin-top: 1rem;
    margin-bottom: 1rem;
    border: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.u_link {
    color: #163172;
    text-decoration: underline;
    cursor: pointer;
}

.rco_time {
    font-size: 10px;
}

.rco_stock {
    font-size: 10px;
    color: #1E56A0;
}

.rco_name {
    font-size: 16px;
}

.rco_partial_tag {
    background: white;
    width: 3rem;
}

.rco_partial_text {
    font-size: 10px;
    color: #C03221;
}

.rco_location {
    font-size: 10px;
}

.rco_card_completed {
    background: #ecf6ff;
}

.rco_card_draft {
    background: #F1F1F1;
}

.rco_card_draft_flair {
    background: #302B63;
    border-radius: 5px;
}

.rco_card_draft_margins {
    margin-top: 10px;
    margin-left: 60px;
}

.button_shadow {
    box-shadow: -4px 4px 6px 0px #2C2D3133;
}

.btn {
    border: 1px solid #ced4da;
    /*    cursor: pointer !important;*/
}

.btn-outline-primary {
    color: var(--blue);
    border-color: var(--blue);
}

.btn-outline-secondary {
    background-color: white;
    color: #302B63;
}

.btn-primary {
    background-color: var(--blue);
    border: 0;
}

.text-secondary {
    color: #6c757d !important;
}

.rco_background {
    background-color: #EBF4E1;
}

.dropdown-toggle {
    white-space: normal;
}

.nav-tabs > li > a.active.nav-link {
    border-bottom: 2px solid var(--blue);
}

.pagination .page-item.active .page-link {
    position: relative;
    min-width: 32px;
    min-height: 32px;
    width: 32px;
    height: 32px;
    max-width: 32px;
    max-height: 32px;
    border-radius: 16px;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1;
    margin: 0px;
}

.sorting_desc:before,
.sorting_desc:after,
.sorting_asc:before,
.sorting_asc:after {
    color: var(--blue);
}

.switch input[type=checkbox]:checked + label {
    background: var(--blue);
    border-color: var(--blue);
}

.img_general {
    width: 150px;
    height: 150px;
    object-fit: cover;
}

.text-primary {
    color: var(--blue) !important;
}

.par_num {
    font-size: 16px;
}

.par_text {
    font-size: 10px;
}

.rco_scanner_footer {
    position: fixed;
    bottom: 0;
    margin-left: -10rem;
    height: 8.5rem;
}

.station_saver_card {
    height: 110px !important;
    overflow: hidden;
}

.station_saver_card .media {
}

.station_saver_price {
}

.station_saver_card .recalculate {
}

.station_saver_card .recalculate span {
}

.dashboard_header h1 {
    margin-bottom: 0px;
    display: flex;
    flex-direction: column;
    padding-top: 12px;
    padding-bottom: 16px;
    line-height: 1;
}
.dashboard_header h1 span {
    margin-top: 2px;
}
.dashboard_header h1 small {
    margin-top: 0px;
    font-size: 1rem;
}
.dashboard_header {
    padding: 24px !important;
    background-color: white;
    margin-bottom: 24px;
    border-radius: 0.5rem;
}
.dashboard_header nav {
    position: relative;
    margin: 0 0 -20px 0;
}

.dashboard_widget_sm {
    padding: 1em;
    width: 20%;
    max-width: 20em;
    min-width: 10em;
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
    gap: 0em;
    padding: 24px;
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 1em;
    box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.05);
    text-align: center;
    transition: 0.15s all ease-in-out;
    cursor: pointer;
}
.dashboard_widget_sm:hover {
    box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.075);
    transform: scale(1.01);
}

.dashboard_widget_container {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 1em;
}
.dashboard_widget {
    flex: 40%;
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
    gap: 0em;
    padding: 24px;
    background-color: #fff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 1em;
    box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.05);
}
.dashboard_widget h2,
.dashboard_widget_sm h2 {
    margin-bottom: 0px !important;
}
.all_rigs_card {
    display: flex;
    flex-flow: column nowrap;
    align-items: flex-start;
    justify-content: space-between;
    background-color: #fff;
    border-radius: 0.5em;
    border: 1px solid #e3e3e3;
    width: 20%;
    min-width: 300px;
    padding: 1em;
    transition: 0.15s all ease-in-out;
}
.all_rigs_card .card_header {
    display: flex;
    flex-flow: column nowrap;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 2px;
    width: 100%;
    height: 4rem;
}
.all_rigs_card:hover {
    box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.1);
}
.all_rigs_card_cont {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: stretch;
}
.search_stations {
    display: flex;
    flex-flow: row nowrap;
    justify-content: flex-end;
    margin: 1em 0;
    width: 100%;
}
.card_fulfillments, .card_stock_cart {
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: 4px;
}

.all_stations,
.all_rigs,
.vehicle_locations_div,
.station_locations_div {
    margin: 10px;
}
.all_stations img,
.all_rigs img,
.card-body .card-content img {
    position: relative;
    display: flex;
    margin-right: 12px;
}
.all_rigs img.float-left,
.all_stations img.float-left {
    top: 6px;
}
.search-box {
    padding: 16px 8px;
    width: 100%;
}
.select-sub-title {
    margin-top: -2px;
    font-size: 14px;
    font-weight: normal;
}
.select-sub-title.is-primary {
    margin-bottom: 0px;
    font-weight: normal;
}
.card p.banner-sub-title {
    padding-left: 44px;
    margin-top: -8px;
}

.quick_inventory_div .card-header,
.full_inventory_div .card-header,
.quick_restock_div .card-header{
    padding: 0px !important;
    position: relative;
    background-color: transparent;
    border-bottom: 1px solid #edf2f9;
    min-height: 3rem;
    color: #53535f;
    line-height: 1.28 !important;
    min-height: 0px;
}
.past-due-tag {
    position: relative;
    background-color: #de4436;
    color: white;
    padding: 8px 16px 8px 8px;
}
.past-due-tag img {
    margin-right: 8px;
}
.past-due-tag > span {
    font-weight: bold;
}
.past-due-length {
    font-size: 0.7rem;
}
.go-tag {
    position: absolute;
    width: 80px;
    height: 80px;
    top: 0;
    bottom: 0;
    margin: auto 0px;
    right: 0px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.go-tag .svg-red {
    opacity: 0.7;
}


/*TAGS*/
.tag {
    width: fit-content;
    padding: 0.2em 0.6em;
    border-radius: var(--border-sm);
    display: flex;
    flex-flow: row nowrap;
    justify-content: center;
    align-items: center;
    gap: 6px;
}

.tag span {
    font-size: 0.75rem;
}

.tag .icon {
    width: 0.75rem;
    height: 0.75rem;
}

.tag.success {
    color: var(--success);
    background: var(--pale-success);
}

.tag.danger {
    color: var(--danger);
    background: var(--pale-danger);
}

.tag.info {
    color: var(--dk-blue);
    background: var(--pale-blue);
}

.tag.warning {
    color: var(--warning);
    background: var(--pale-warning);
}
.tag .badge {
    border-radius: 50%;
    color: white;
    width: 1.4rem;
    height: 1.4rem;
    font-size: 0.75rem;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0;
}
.tag.info .badge {
    background: var(--dk-blue);
}
.tag.success .badge {
    background: var(--success);
}

.tag-badge {
    position: absolute;
    top: -6px;
    right: 2px;
    width: 21px;
    height: 21px;
    border-radius: 11px;
    background-color: rgba(21,112,239, 1);
    color: white;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 11px;
    font-weight: bold;
    padding-top: 1px;
}
.quick_restock_div .card-body {

}
.quick_restock_div .card-header {
    padding: 0px;
    background-color: white;
}
.banner-tag {
    position: relative;
    display: flex;
    flex-direction: row;
    padding: 16px;
}
.banner-tag img {
    margin-right: 12px;
    position: relative;
    top: 5px;
}
.banner-tag h2 {
    font-weight: bold;
}
.banner-tag .banner-content {
    position: relative;
    display: flex;
    flex-direction: column;
}
.banner-tag .banner-content * {
    margin: 0px;
    padding: 0px;
    line-height: 1.28 !important;
}/*TAGS*/
.tag {
    width: fit-content;
    padding: 0.2em 0.6em;
    border-radius: var(--border-sm);
    display: flex;
    flex-flow: row nowrap;
    justify-content: center;
    align-items: center;
    gap: 6px;
}

.tag span {
    font-size: 0.75rem;
}

.tag .icon {
    width: 0.75rem;
    height: 0.75rem;
}

.tag.info {
    color: var(--dk-blue);
    background-color: #c6eaff;
}
.tag-icon {
    position: relative;
    top: 10px;
    right: 10px;
}
.tag-number {
    width: 42px;
    height: 42px;
    border-radius: 21px;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1;
    border: 3px solid rgba(21,112,239, 0.8);
    background-color: white;
    color: rgba(21,112,239, 1);
    font-weight: bold;
    font-size: 14px;
    line-height: 1;
    padding-top: 2px;
}
.tag-icon .tag-number {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: 0px auto;
    right: -8px;
}
.stock_cart .notice,
.fulfillment_div .notice {
    position: absolute;
    font-size: 2rem;
    top: -10px;
    color: rgba(21,112,239, 1);
}
.card-content {
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
}
.card-content > div {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
}
.card-content h3 {
    margin-bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    font-weight: bold;
}
.card-content h3 small {
    display: inline-block;
}
.card-content img.cta {
    margin-right: 0px;
}

.status-spot {
    display: flex;
    position: absolute;
    width: 100%;
    max-width: 42px;
    min-width: 42px;
    max-height: 42px;
    min-height: 42px;
    justify-content: center;
    align-items: center;
    font-size: 2rem;
    top: 0;
    bottom: 0;
    margin: auto 0px;
    right: 12px;
    border-radius: 21px;
}
/*.status-spot.*/
.status-spot.red {
    background-color: #de4436;
}
.status-spot.green {
    background-color: #3a7a1b;
}
.status-spot.blue {
    background-color: rgba(21,112,239, 1);
}
.status-spot.gray {
    background-color: #878787;
}
.border-gray {
    border: 1px solid rgba(0,0,0, 0.2);
}
.border-green {
    border: 1px solid #3a7a1b;
}
.border-blue {
    border: 1px solid rgba(21,112,239, 1);
}
.checklist {
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 16px 0px;
}
.checklist-info {
    display: flex;
    flex-direction: column;
    line-height: 1.5;
    width: 100%;
    color: #282828;
}
.checklist-info span {
    font-size: 12px;
    line-height: 1.2;
}
.checklist-name {
    display: flex;
    padding-left: 16px;
    padding-right: 60px;
    width: 100%;
    max-width: 768px;
    position: relative;
    justify-content: center;
    align-items: flex-start;
    flex-direction: column;
}
.all_checklists {
    position: relative;
    display: flex;
    flex-direction: row;
    margin: 16px 0px;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    min-height: 86px;
    border-radius: 8px;
    overflow: hidden;
    background-color: rgba(0,0,0, 0.01);
}
.all_checklists.past_due {
    background-color: rgba(0,0,0, 0);
}
.all_checklists.past_due h4 {
    color: #de4436;
    text-decoration: underline;
}
.checklist-name h4,
.checklist-name p {
    margin: 0px;
    padding: 0px;
    line-height: 1.2;
}
.checklist-name h4 {
    margin-top: 3px;
    margin-bottom: 3px;
    font-weight: bold;
}
.checklist-name p {
    padding-left: 2px !important;
}
.checklist-name p .red {
    color: #de4436;
}
.inspection_checklists {
    margin-bottom: 16px;
}
.inspection_checklists {
    margin-bottom: 16px;
}

.radio-icon-group {
    position: relative;
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    padding: 0px 0px 20px 5px;
}
.radio-icon-group .label {
    position: relative;
    font-size: 14px;
    min-width: 100%;
}
.radio-icon-group label {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-right: 16px;
    cursor: pointer;
}
.radio-icon-group img.checked {
    filter: brightness(0) saturate(100%) invert(45%) sepia(68%) saturate(5172%) hue-rotate(203deg) brightness(92%) contrast(104%);
}

.fleet-icon {
    position: relative;
    display: flex;
    width: 124px;
/*    border: 1px solid red;*/
    justify-content: center;
    align-items: center;
    margin-bottom: 8px;
}
.fleet-icon img {
    position: relative;
    width: 28px !important;
    height: 28px !important;
    margin-right: 6px;
}
.no_checklists {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
@media all and (max-width: 768px) {
    .dashboard_widget_sm {
        flex-flow: row wrap;
    }
    .all_rigs_card_cont {
        justify-content: center;
    }
    .search_stations {
        justify-content: center;
    }
    .checklist {
        padding: 0px 0px;
    }
    .quick_inventory_div .card-body,
    .full_inventory_div .card-body,
    .quick_restock_div .card-body {
        padding-top: 0px;
    }

    .all_checklists > div.checklist {
        flex-direction: row;
        position: relative;
        display: flex;
        justify-content: stretch;
        align-items: stretch;
    }
    .stock_cart .card-body,
    .fulfillment_div .card-body {
        position: relative;
        display: flex;
        flex-direction: row;
        justify-content: flex-start;
        align-items: center;
    }
    .rco_scanner_footer {
        margin-left: -10px;
    }
    .page-container .main-content{
        padding: 70px 0px 0px 0px !important;
        border-radius: 0px;
    }
    .Inspections_edit .main-content {
        padding: 85px 10px 10px 10px !important;
    }

    .card {
        position: relative;
        background-color: #fff;
        margin-bottom: 0px;
        border: 1px solid #b8c4d0 !important;
        border-radius: 8px;
        overflow: hidden;
    }
    .search-box {
        border-bottom: 1px solid #b8c4d0 !important;
    }
    .dashboard_header {
        margin-bottom: 0px;
        border-radius: 0px;
        border-bottom: 1px solid #b8c4d0 !important;
    }

    .card-content h3 {
        font-size: 19px !important;
    }

    .station_saver_icon {
        display: none;
    }

    .station_saver_card {
        height: 120px !important;
    }

    .station_saver_card .media {
        justify-content: stretch;
    }

    .station_saver_price {
        display: flex;
        flex: 1;
        flex-direction: column;
        margin-left: 0px !important;
    }

    .station_saver_card .recalculate {
        position: relative;
        display: flex;
        width: 100%;
        justify-content: center;
        align-items: center;
        margin-top: 10px;
        margin-bottom: 10px;
    }

    .station_saver_card .recalculate span {
        margin-left: 10px;
    }

    .card-body.sizer {
        min-height: 256px !important;
    }
}

@media all and (max-width: 768px) {
    .mobile-space-between {
        position: relative;
        width: 100%;
        padding-left: 0% !important;
        display: flex !important;
        justify-content: space-between;
        align-items: center;
        text-align: left !important;
    }

    .hide-mobile {
        display: none !important;
    }

    .card-body.sizer {
        min-height: auto !important;
    }

    .is-mobile {
        display: block;
    }
}
@media all and (min-width: 768px) {
    h2, .h2 {
        font-size: 18px;
    }
    .show-mobile {
        display: none !important;
    }

    .card-body.sizer {
        min-height: 256px !important;
    }

    .is-mobile {
        display: none !important;
    }
}

.cards-po-table {
    position: relative;
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    align-items: stretch;
}
.card-po-table {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: calc(50% - 8px);
    margin: 4px;
    border: 1px solid rgba(0,0,0, 0.2);
    min-height: 256px;
    padding: 0px;
    border-radius: 4px;
}
.po-header {
    position: relative;
    display: flex;
    width: 100%;
    padding: 16px 12px 0px 12px;
    font-size: 1.2rem;
    font-weight: bold;
}
.po-header span {
    position: relative;
    display: flex;
    width: 100%;
    font-size: 0.5rem;
    position: absolute;
    top: 16px;
}
.po-status-main {
    font-size: 0.8rem;
    padding: 0px 13px;
}
.po-status-body {
    position: relative;
    display: flex;
    flex-flow: column;
    font-size: 0.7rem;
    padding: 0px 13px;
    margin-top: 2px;
    min-height: 58px;
}
.po-status-body span {
    margin-top: -2px;
}
.po-controls {
    position: relative;
    display: flex;
    flex-flow: row wrap;
    padding: 12px 0px;
}
.po-controls a {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    max-width: 50%;
    padding: 4px 0px;
}
.po-page {
    position: relative;
    display: flex;
    flex-direction: column;
}
.po-page-header {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 12px;
    padding-bottom: 24px;
}
.po-head h1 {
    margin: 0px;
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}
.po-head h1 span {
    font-size: 1rem;
}
.po-number {
    position: relative;
}
.po-number input {
    padding: 8px 12px 8px 24px;
    font-size: 1.25rem;
    outline: 0px !important;
    border-radius: 4px;
    width: 100%;
    border: 1px solid var(--lt-gray);
}
.po-number > span {
    position: absolute;
    top: 7px;
    left: 11px;
    font-size: 1.1rem;
}

.po-created {
    margin-top: 4px;
    position: relative;
    display: flex;
    flex-direction: column;
}
.po-created > span {
    margin-bottom: -3px;
    font-size: 0.8rem;
}

.card-tabs,
.card-tabs-controls {
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: stretch;
    align-items: center;
}
.card-tabs-controls {
    justify-content: space-between;
    padding: 0px 14px;
}
.card-tab {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 12px;
    justify-content: center;
    align-items: center;
    width: 100%;
}
.card-content {
    font-size: 1.25rem;
    font-weight: bold;
}
.card.inactive:hover {
    box-shadow: none !important;
    cursor: default;
}




















.icon-stack {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.icon-stack span {
    padding: 2px 4px;
    font-size: 0.6rem;
    color: var(--gray);
}
.icon-stack span.regular {
    font-size: 0.75rem;
}
.icon-stack.cancel,
.icon-stack.receive {
    margin-top: 12px;
    padding: 4px;
}
.icon-stack.receive {
    color: black;
}
.card-tab-option {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: stretch;
    align-items: center;
}
.card-tab-option a {
    display: flex;
    flex: 1;
    justify-content: center;
    align-items: center;
}
.card-tab-option a.active {
    background-color: var(--blue);
    color: white;
    border-radius: 8px;
}
.stock_cart .card-body,
.fulfillment_div .card-body {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.circle_button_side {
    border-radius: 60px;
    height: 60px;
    width: 60px;
    box-shadow: -3px 5px 6px 0px #354A591A;
}

.circle_button_main {
    border-radius: 60px;
    height: 70px;
    width: 70px;
    box-shadow: -3px 5px 6px 0px #354A591A;
}

.rco_footer_background {
    background-color: #F1F1F1;
    box-shadow: 0px -4px 16px 0px #00000033;
}

.circle_button_text {
    margin-top: 0.3rem;
    font-size: 10px;
    color: #302B63;
}

/* .modal input[type=number] {
    outline: none;
    border: none;
    border-bottom: 2px solid #2b2b2b;
    width: 94px;
    text-align: center;
} */

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    appearance: none;
    margin: 0;
}

.location_actions {
    display: none;
}

ul.simpleTreeMenu .stm-content {
    padding: 10px 0px;
}

ul.simpleTreeMenu .stm-content:hover, ul.simpleTreeMenu li.Node > .stm-icon:hover {
    background-color: inherit;
}

#location_tree li .location_span a {
    color: #53535f;
}

#location_tree li .location_span:hover a, #location_tree li .location_span a.selected {
    color: var(--blue);
}

a.stm-content.selected {
    color: var(--blue);
    text-decoration: underline;
}

.selected-label {
    opacity: 1 !important;
    color: var(--blue);
    font-weight: 700;
}

.sort-icon {
    cursor: pointer;
}

.ui-sortable-handle {
    cursor: pointer;
}


.scroll-full-height .form-row {
    padding-right: 10px;
}

.scroll-full-height::-webkit-scrollbar {
    display: none;
}

.modal-right .modal-dialog .modal-content .modal-footer, .modal-left .modal-dialog .modal-content .modal-footer {
    background: #fff;
}

.modal-right .modal-body {
    height: 100vh;
    padding-bottom: 125px;
}

.custom_fields {
    display: none;
}

.mobile_filter {
    display: none;
}

@media (max-width: 760px) {
    .bottom_nav {
        padding-left: 0px !important;
    }
}

/*Mobile View Table*/
@media only screen and  (max-width: 760px) {
    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) td {
        display: block;
        width: inherit !important;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) tbody {
        width: 85vw;
    }

    /* Hide table headers (but not display: none;, for accessibility) */
    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar):not(.ui-datepicker-calendar) thead tr {
        position: absolute;
        top: -9999px;
        left: -9999px;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) tr {
        border: 1px solid #4a4a4a;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) tr + tr {
        margin-top: 1.5em;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar):not(.ui-datepicker-calendar) td {
        /* make like a "row" */
        border: none;
        border-bottom: 1px solid #eee;
        border-right: 1px solid grey;
        position: relative;
        padding-left: 50% !important;
        background-color: #fff;
        text-align: left;
    }

    table.all-vehicles:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar):not(.ui-datepicker-calendar) td {
        padding-left: 15px !important;
        padding: 5px 15px 5px 15px;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) td:before {
        content: attr(data-label);
        display: inline-block;
        line-height: 1.5;
        margin-left: -100%;
        width: 100%;
        white-space: nowrap;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) td.hide-mobile {
        display: none !important;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) td:last-of-type {
        padding-bottom: 32px !important;
    }

    table.all-vehicles:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) td:before {
        display: none;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) .mobile_filter {
        display: inline;
    }

    table:not(.table_normal_mobile):not(.table-condensed):not(.ui-datepicker-calendar) .full_row {
        float: left;
        left: -87%;
        position: relative;
        height: 252px;
        width: 100%;
    }

    .location-name {
        font-size: 1.15rem;
        font-weight: bold;
    }
}

.all-vehicles .badge {
    font-size: 1em;
    min-width: 96px;
}

.all-vehicles .badge-primary.counter {
    min-width: 32px;
    max-width: 32px !important;
}

#asset_trak_activity_date .ui-datepicker-inline {
    margin: auto;
}

@media (max-width: 1020px) {
    .modal-dialog {
        max-width: 100vw;
    }
}

#reader__dashboard {
    display: none;
}

#reader {
    background-color: #000;
    width: 100%;
    min-height: 275px;
    padding: 20px 0px !important;
    overflow: hidden;
}

.pagination .active {
    background: #3f87f5;
    border-color: transparent;
}

.pagination .disabled {
    display: none;
}

.pagination .active a {
    color: #fff;
}

.pagination li {
    border: 1px solid transparent;
    border-radius: 50%;
    padding: 0;
    min-width: 2rem;
    line-height: 2rem;
    height: 2rem;
    margin: 0px 5px;
    color: #53535f;
    background-color: transparent;
    text-align: center;
    transition: all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -ms-transition: all 0.3s ease-in-out;
}

.uppercase {
    text-transform: uppercase;
}

.capitalise {
    text-transform: capitalize;
}

ul {
    padding-left: 15px;
}

.btn-group.dropdown {
    display: inherit;
}

.scroll-container {
    height: 100%;
    overflow-y: scroll;
}

.disabled {
    pointer-events: none;
    cursor: not-allowed;
    background-color: #ededed;
}

.pointer {
    cursor: pointer !important;
}

.avatar-sm, .avatar_img {
    background-size: auto 100% !important;
}
.avatar.avatar-icon i {
    position: relative;
    top: 3px;
}
.dashboard_widget .avatar-lg.avatar-icon,
.dashboard_widget_sm .avatar-lg.avatar-icon{
    margin-top: 6px;
    margin-bottom: 10px;
}
.timeline-item-head:after {
    bottom: -6px;
}

label.is-invalid {
    color: #de4436;
}

#fireworks_card {
    min-height: 70vh;
}

select.form-control.is-invalid, select.form-control.is-valid {
    background-position: center right calc(0.375em + .8rem);
}

.card {
    border: 1px solid #ced4da;
}
.form-control, .checkbox input[type=checkbox] + label:before, .select2-container .select2-choice {
    border: 1px solid #acadad;
}
.border{
    border: 1px solid #ced4da !important;
}

.border-bottom {
    border-bottom: 1px solid #ced4da !important;
}

.border-top {
    border-top: 1px solid #ced4da !important;
}

.border-danger {
    border: 1px solid #dc3545 !important;
}

#html5-qrcode-button-camera-stop, #html5-qrcode-button-camera-start, #html5-qrcode-select-camera {
    width: 85%;
    padding: 15px;
    margin: 15px;
}

.enable_handheld_scanner, .enable_qr_printer {
    display: none;
}

.dashboard_div_height {
    height: 775px;
    overflow-y: scroll;
}

.hide-valid-check {
    background-image: none !important;
    padding: 0.55rem 0.35rem !important;
}

.card-hover:hover .card .card-body {
    background-color: #e8f1ff;
}
.card-hover:hover .card .card-header {
    background-color: #cbe0ff;
}
.card-hover:hover .card {
    border-color: #7da1d8 !important;
}
.card-hover:hover .card .card-header {
    border-color: #7da1d8 !important;
}
.card-hover.stationstok:hover .card .card-body {
    background-color: #e2f2f9;
}
.card-hover.stationstok:hover .card .card-header {
    background-color: #c8e6f3;
}
.card-hover.stationstok:hover .card {
    border-color: #7db6ce !important;
}
.card-hover.stationstok:hover .card .card-header {
    border-color: #7db6ce !important;
}

.spin i{
    animation-name: spin;
    animation-duration: 1000ms;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}
.side-nav {
    border-top: 1px solid #ced4da;
}
.side-nav .side-nav-inner .side-nav-menu {
    padding-bottom: 20px;
}

.fullscreen .page-container {
    padding-left: 0px;
    margin-top: -65px;
}

.module_divs .card {
    height: 350px;
    overflow-y: scroll;
}

.Dashboard_index .card:not(.not-scroll-card) {
    height: 600px;
}

.Dashboard_index .card:not(.not-scroll-card) .card-body {
    overflow-y: scroll;
}

.border-red {
    border: 1px solid red;
}

.location-header {
    border-bottom: 1px solid #72849a;
    margin-bottom: 0px;
}

.no-border {
    border: none;
}

.all_reports .card-body {
    height: 175px;
    overflow: hidden;
}

.no_border {
    border: none !important;
}

.no-y-overflow {
    overflow-x: hidden !important;
}

.no-y-overflow input {
    max-width: 165px;
}

.width-300 {
    width: 300px;
}

.loading_circle {
    height: 250px;
    width: 250px;
    background-color: #bbb;
    border-radius: 50%;
    display: inline-block;
    opacity: 0.2;
}

/* Make the badge float in the top right corner of the button */

.button__badge {
    background-color: #1570EF;
    border: 1px solid #1570EF;
    border-radius: 10px;
    color: #fff;
    padding: 3px 6px;
    font-size: 10px;
    position: relative;
    top: -20px;
    right: 25px;
    font-weight: 500;
}

.side__badge {
    background-color: #1570EF;
    border-radius: 5px;
    color: #fff;
    padding: 0px 5px 0px 5px;
    font-weight: 500;
}

.open .dropdown-toggle .side__badge {
    display: none !important;
}

.footer-menu .button__badge {
    position: relative;
    top: 5px !important;
    right: 45px;
    width: 25px;
    float: right;
}

#locations_list {
    overflow: hidden;
}

.bottom_nav {
    position: fixed;
    float: right;
    bottom: 0px;
    left: 0px;
    background-color: #fff;
    width: 100%;
    padding-left: 290px;
    box-shadow: -1px -38px 39px -35px rgba(0, 0, 0, 0.61);
    -webkit-box-shadow: -1px -38px 39px -35px rgba(0, 0, 0, 0.61);
    -moz-box-shadow: -1px -38px 39px -35px rgba(0, 0, 0, 0.61);
    z-index: 99;
}

#top_sticky {
    z-index: 999;
}

.input-group .select2-container .select2-choice {
    border-radius: 0px;
}

.text-small {
    font-size: x-small;
}

.top_no_border {
    background-color: #fff;
    margin: -25px -25px 25px;
    padding: 20px;
}

@media all and (max-width: 992px) {
    .mobile-css .mobile-padding-top-55 {
        margin-top: 55px;
    }

    .mobile-css.page-container {
        padding-bottom: 85px;
        width: 100vw;
        overflow-x: hidden;
    }
}

.text-mute {
    color: #ABAEB7;
}

.badge-default {
    border: 1px solid #ABAEB7;
}

.badge-mute {
    border: 1px solid #edf2f9;
    background-color: #F9FAFB;
    color: #2a2a2a;
    font-weight: 500;
}

.badge-red {
    border: 1px solid #de4436;
}

.badge-orange {
    background-color: #FCEBDB;
    color: #F2994A;
    border: 1px solid #F2994A;
}

.badge-orange img {
    filter: invert(36%) sepia(82%) saturate(1062%) hue-rotate(3deg) brightness(104%) contrast(103%);
}

.badge_circle::before {
    content: '';
    display: inline-block;
    width: 0.6em;
    height: 0.6em;
    -moz-border-radius: 7.5px;
    -webkit-border-radius: 7.5px;
    border-radius: 7.5px;
    background-color: #00c9a7;
}

.badge-red .badge_circle::before {
    background-color: #de4436;
    margin-right: 5px;
}

.badge-mute .badge_circle::before {
    background-color: #2a2a2a;
    margin-right: 5px;
}

.badge-blue .badge_circle::before {
    background-color: #3f87f5;
    margin-right: 5px;
}

.badge-green .badge_circle::before {
    background-color: #52c41a;
    margin-right: 5px;
}

.badge-orange .badge_circle::before {
    background-color: #F2994A;
    margin-right: 5px;
}

.footer_float_nav, .footer_float_nav_under_side {
    width: 100%;
    padding-left: 280px;
    background-color: #fff;
    position: fixed;
    bottom: 0;
    height: 88px;
    left: 0;
    box-shadow: -1px 0 10px rgba(0, 0, 0, 0.15);
    border-top: 1px solid rgba(0, 0, 0, 0.15);
    display: flex;
    flex-flow: row nowrap;
    justify-content: stretch;
    align-items: stretch;
}

.footer_float_nav_under_side {
    height: 115px;
}

.footer_float_nav_btn {
    flex: 50%;
    display: flex;
    justify-content: stretch;
    align-items: stretch;
}

.footer_float_nav_btn > div {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1em;
}

@media (max-width: 992px) {
    .footer_float_nav {
        padding-left: unset;
    }
}

@media only screen and (min-width: 992px) and (max-width: 1440px) {
    .footer_float_nav {
        padding-left: 230px;
    }
}

.bg_button_mute {
    background-color: #F2F4F7;
}

.bg_button_ready, .bg_button_ready_seal {
    background-color: #079455;
    border: 1px solid #079455;
    color: #fff;
}

.bg-red {
    background-color: #EB5757;
    color: #fff;
}

.bg-green {
    background-color: #6FCF97;
    color: #fff;
}

.bg-light-red {
    background-color: #FEF3F2;
}

.bg-light-purple {
    background-color: #F4F3FF
}

.bg-light-grey {
    background-color: #F2F4F7
}

.bg-light {
    background-color: #F9FAFB;
}

.bg-light-blue {
    background-color: rgba(63, 135, 245, 0.1)
}

.border-top-red {
    border-top: 2px solid #EB5757;
}

.no-border {
    border: none !important;
    border-top: none !important;
    border-bottom: none !important;
}

.large_round_button {
    background-color: #EFF8FF;
    border: 1px solid #B2DDFF;
    border-radius: 40px;
    color: #175CD3;
    padding: 25px;
    font-size: 20px;
    position: relative;
    right: 10px;
    cursor: pointer;
}

.large_round_button i {
    font-size: 25px;
}

.badge {
    font-size: 1em;
}

.border-rounded {
    border: 1px solid #EAECF0 !important;
    border-radius: 10px;
}

.border-circle {
    border: 1px solid #EAECF0 !important;
    border-radius: 25px;
    padding: 7px;
}

/* SVG fill colors */
/* https://codepen.io/sosuke/pen/Pjoqqp */

.svg {
    /* filter: invert(100%) sepia(1%) saturate(5930%) hue-rotate(70deg) brightness(102%) contrast(91%); */
}

.svg-gray {
    filter: brightness(0) saturate(100%) invert(62%) sepia(1%) saturate(0%) hue-rotate(216deg) brightness(91%) contrast(87%);
}

.svg-green {
    filter: invert(48%) sepia(79%) saturate(2476%) hue-rotate(86deg) brightness(118%) contrast(119%);
}
.svg-green-dark {
    filter: brightness(0) saturate(100%) invert(33%) sepia(31%) saturate(1067%) hue-rotate(81deg) brightness(98%) contrast(91%);
}
.svg-red{
    filter: invert(38%) sepia(38%) saturate(3060%) hue-rotate(338deg) brightness(88%) contrast(97%);
}

.svg-orange {
    filter: invert(75%) sepia(70%) saturate(856%) hue-rotate(336deg) brightness(97%) contrast(106%);
}

.svg-grey {
    filter: invert(71%) sepia(11%) saturate(435%) hue-rotate(179deg) brightness(89%) contrast(87%);
}
/* with 'a' not 'e' */
.svg-gray {
    filter: brightness(0) saturate(100%) invert(62%) sepia(1%) saturate(0%) hue-rotate(216deg) brightness(91%) contrast(87%);
}
.svg-gray-dark {
    filter: brightness(0) saturate(100%) invert(44%) sepia(13%) saturate(7%) hue-rotate(349deg) brightness(103%) contrast(88%);
}
.svg-gray-light {
    filter: brightness(0) saturate(100%) invert(97%) sepia(0%) saturate(55%) hue-rotate(108deg) brightness(113%) contrast(90%);
}
.svg-white{
    filter: invert(93%) sepia(100%) saturate(0%) hue-rotate(248deg) brightness(106%) contrast(106%);
}

.svg-blue {
    filter: brightness(0) saturate(100%) invert(45%) sepia(68%) saturate(5172%) hue-rotate(203deg) brightness(92%) contrast(104%);
}

.underline {
    text-decoration: underline;
}

.pop_div {
    -webkit-box-shadow: 0px 0px 100px 0px rgba(0, 0, 0, 0.75);
    -moz-box-shadow: 0px 0px 100px 0px rgba(0, 0, 0, 0.75);
    box-shadow: 0px 0px 100px 0px rgba(0, 0, 0, 0.75);
    z-index: 999;
}

.div_float_center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.hidden_input {
    border: none !important;
}

h3, .h3 {
    font-size: 22px !important;
}

.savings_evaluator_bg {
    background-image: linear-gradient(to right, #586DD9, #A3B5E2);
}

.savings_evaluator_bg .btn-primary {
    background-color: #175CD3 !important;
}

.footer-menu span {
    font-size: 0.8em !important;
}

.accordion > .card > .card-header > .card-title > a.no_arrow:after {
    content: none !important;
}

.box-shadow {
    -webkit-box-shadow: 0px 0px 8px 1px rgba(0, 0, 0, 0.1) !important;
    -moz-box-shadow: 0px 0px 8px 1px rgba(0, 0, 0, 0.1) !important;
    box-shadow: 0px 0px 8px 1px rgba(0, 0, 0, 0.1) !important;
}

.round-corners {
    border-bottom-right-radius: 5px !important;
    border-bottom-left-radius: 5px !important;
    border-top-left-radius: 5px !important;
    border-top-right-radius: 5px !important;
}

/*.RigCheckOff_compartmentChecklist .footer-menu, .RigCheckOff_selectCompartment .footer-menu, .ShoppingCart_cart .footer-menu, .Locations_sealAllCompartments .footer-menu, .Inspections_edit .footer-menu, .Orders_detail .footer-menu {*/
/*    display: none;*/
/*}*/

#open_tickets {
    max-height: 200px;
    overflow-y: scroll;
    overflow-x: hidden;
}

.file-manager-wrapper .file-manager-content .file-manager-content-body .file-manager-content-files .file-wrapper {
    display: inline-block;
}

.full_bg_img {
    background-repeat: no-repeat;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    -o-background-size: contain;
    background-size: contain;
    background-position: center center;
}

.h-100px {
    height: 100px;
}

.h-125px {
    height: 125px;
}

.h-200px {
    height: 200px;
}

.qr_label {
    border: 1px solid #000;
    padding: 10px;
    border-radius: 5px;
}

.img_file_name {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
    overflow-wrap: break-word;
    overflow: hidden;
    max-width: 210px;
}

.item-failed {
    color: #de4436 !important;
}

.stepper-wrapper {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}

.stepper-item {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;

    @media (max-width: 768px) {
        font-size: 12px;
    }
}

.stepper-item::before {
    position: absolute;
    content: "";
    border-bottom: 2px solid #ccc;
    width: 100%;
    top: 20px;
    left: -50%;
    z-index: 2;
}

.stepper-item::after {
    position: absolute;
    content: "";
    border-bottom: 2px solid #ccc;
    width: 100%;
    top: 20px;
    left: 50%;
    z-index: 2;
}

.stepper-item .step-counter {
    position: relative;
    z-index: 5;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #ccc;
    margin-bottom: 6px;
}

.stepper-item.active {
    font-weight: bold;
}

.stepper-item.completed .step-counter {
    background-color: #4bb543;
}

.stepper-item.completed::after {
    position: absolute;
    content: "";
    border-bottom: 2px solid #4bb543;
    width: 100%;
    top: 20px;
    left: 50%;
    z-index: 3;
}

.stepper-item:first-child::before {
    content: none;
}

.stepper-item:last-child::after {
    content: none;
}

:root {
    --black: #212121;
    --md-gray: #3e3e3e;
    --lt-gray: #6c757d;
    --lt-lt-gray: #ced4da;
    --lt-lt-lt-gray: #ededf1;
    --dk-blue: #0446B0;
    --dk-blue-hover: #033588;
    --md-blue: #27AAE1;
    --md-blue-hover: #198ebf;
    --pale-blue: #EFF2F4;
    --white: #fff;
    --off-white: #FEFEFE;
    --warning: #d66100 !important;
    --pale-warning: #ffe3c7 !important;
    --danger: #E11B25;
    --pale-danger: #ffced1;
    --danger-hover: #c00;

    --pale-success: #dfefe7;
    --mid-success: #68b69a;
    --success: #008055;
    --success-hover: #006b4a;

    --border-sm: 0.3rem;
    --border-md: 1.2em;
}

/*BUTTONS*/

.btn {
    padding: 0.5rem 1rem;
    outline: none;
    border-radius: 0.3rem;
    cursor: pointer;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    line-height: 1rem !important;
    text-wrap: nowrap;
    gap: 6px;
}

.btn_sm {
    padding: 0.2rem 0.6rem !important;
}

.btn_warning {
    background-color: var(--warning) !important;
    color: var(--white) !important;
}

.btn_primary {
    background-color: var(--md-blue) !important;
    color: var(--white) !important;
}

.btn_primary:hover {
    background-color: var(--md-blue-hover) !important;
}

.btn_dk_blue {
    background-color: var(--dk-blue) !important;
    color: var(--white) !important;
}

.btn_dk_blue:hover {
    background-color: var(--dk-blue-hover) !important;
}

.btn_outline {
    background-color: transparent !important;
    color: var(--md-blue) !important;
    border: 1px solid var(--md-blue) !important;
}

.btn_outline:hover {
    background-color: var(--md-blue) !important;
    color: var(--white) !important;
}

.btn_text {
    text-decoration: underline;
    /** @TODO app styles overriding these **/
    border: none !important;
    padding: 0.5rem !important;
    text-wrap: nowrap;
}

.btn_text:hover {
    text-decoration: underline !important;
}

.btn_icon_plain {
    background: transparent;
    outline: none;
    border: none;
}

.btn_product_popout {
    position: relative;
    top: -0.4rem;
    right: 0;
}

.btn_product_popout:hover {
    background-color: rgba(0, 0, 0, 0.05);
}

.btn:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.btn_outline:disabled:hover {
    background-color: transparent !important;
    color: var(--md-blue) !important;
}

.btn_icon {
    border-radius: 8px;
    padding: 6px !important;
    border: 2px solid var(--dk-blue) !important;
    width: 2.2rem;
    height: 2.2rem;
}

/*FLEX*/

.flex {
    display: flex;
}

.align_center {
    align-items: center;
}

.align_end {
    align-items: flex-end;
}

.align_start {
    align-items: flex-start;
}

.gap_xs {
    gap: 4px;
}

.gap_sm {
    gap: 0.6rem;
}

.gap_md {
    gap: 1.2rem;
}

.flex_row {
    flex-flow: row wrap;
}

.flex_row_force {
    flex-flow: row nowrap;
}

.flex_column {
    flex-flow: column nowrap;
}

.justify_between {
    justify-content: space-between;
}

.justify_center {
    justify-content: center;
}

.justify_end {
    justify-content: flex-end;
}

.sticky {
    position: sticky;
}

.relative {
    position: relative;
}

.bottom_0 {
    bottom: 0;
}

.grid {
    display: grid !important;
}

/*TEXT*/

.text_black {
    color: var(--black) !important;
}

.text_white {
    color: var(--white) !important;
}

.text_md_blue {
    color: var(--md-blue) !important;
}

.text_blue {
    color: var(--dk-blue) !important;
}

.text_lt_gray, .text_mute {
    color: var(--lt-gray) !important;
}

.text_md_gray {
    color: var(--md-gray) !important;
}

.text_success {
    color: var(--success) !important;
}

.text_warning {
    color: var(--warning) !important;
}

.text_danger {
    color: var(--danger) !important;
}

.text_xs {
    font-size: 0.6rem;
    letter-spacing: 1px;
}

.text_sm {
    font-size: 0.8rem;
}

.text_normal {
    font-size: 1rem;
}

.text_md {
    font-size: 1.2rem;
}

.text_lg {
    font-size: 1.6rem;
}

.font_bold {
    font-weight: bold;
}

.font_regular {
    font-weight: normal;
}

.font_upper {
    text-transform: uppercase;
}

.text_right {
    text-align: right;
}

.text_center {
    text-align: center;
}

.bg_dk_blue {
    background-color: var(--dk-blue) !important;
}

.bg_white {
    background-color: var(--white) !important;
}

.bg_warning {
    background-color: var(--warning) !important;
}

.bg_success {
    background-color: var(--success) !important;
}

.bg_pale_success {
    background-color: var(--pale-success) !important;
}

.bg_white_fade {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.7), rgba(255, 255, 255, 1)) !important;
}

.bg_pale_blue {
    background-color: var(--pale-blue);
}

.tooltip_container {
    position: relative;
}

.tooltip_container .tooltip_text {
    visibility: hidden;
    background-color: var(--white);
    color: var(--black);
    text-align: center;
    border-radius: var(--border-sm);
    padding: 0.4rem;
    position: absolute;
    z-index: 1;
    top: 100%;
    right: 0;
    min-width: 200px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    border: 1px solid var(--lt-lt-gray);
    margin: 0;
}

.tooltip_container .tooltip_text.top {
    top: unset;
    bottom: 90%;
}

.tooltip_container:hover .tooltip_text {
    visibility: visible;
}

.tooltip_container .tooltip_text a {
    transition: none;
}

/*MARGIN & PADDING*/

.p_sm {
    padding: 0.6rem;
}

.p_md {
    padding: 1rem;
}

.p_y_lg {
    padding-top: 1.8rem;
    padding-bottom: 1.8rem;
}

.p_y_md {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.p_b_lg {
    padding-bottom: 1.8rem;
}

.p_x_sm {
    padding-left: 0.6rem;
    padding-right: 0.6rem;
}

.m_y_sm {
    margin-top: 0.2rem;
    margin-bottom: 0.2rem;
}

.mt_sm {
    margin-top: 0.6rem;
}

.mt_md {
    margin-top: 1rem;
}

.ml_md {
    margin-left: 1rem;
}

/*LAYOUT*/

.w_fit {
    width: fit-content;
}

.w_full {
    width: 100%;
}

.vertical_rule, .vertical_rule_sm {
    width: 2px;
    align-self: stretch;
    background-color: var(--lt-lt-gray);
}

.vertical_rule_sm {
    height: 50%;
    align-self: center;
}

/*ETC*/

.no_scroll {
    overflow: hidden;
    max-height: calc(100vh - 120px);
}

.icon_sm {
    width: 0.7rem;
    height: 0.7rem;
}

.icon {
    width: 1rem;
    height: 1rem;
}

.icon_md {
    width: 1.5rem;
    height: 1.5rem;
}

.line_height_initial {
    line-height: initial;
}

.rounded_sm {
    border-radius: var(--border-sm);
}

.rounded_full {
    border-radius: 50%;
}


/*TABLE*/

.table {
    margin: 2em 0;
    width: 100%;
    border-radius: var(--border-md);
    box-shadow: 1px 1px 10px rgba(0, 0, 0, 0.08);
    background-color: var(--off-white);
    padding: 1em;
    color: var(--black) !important;
    border-collapse: collapse;
}

.card .table {
    box-shadow: none;
}

.table_header {
    display: grid;
    grid-template-columns: 5fr 2.5fr 1.5fr 1fr;
    gap: 1em;
    padding: 1em;
    background-color: var(--pale-blue);
    color: var(--dk-blue);
    border-radius: var(--border-sm);
}

.table_header:has(tr) {
    display: block;
}

.table th, .table td {
    border: none !important;
}

.table_header:has(tr) tr {
    display: grid;
    grid-template-columns: 5fr 2.5fr 1.5fr 1fr;
    gap: 1em;
}

table.dataTable thead .sorting:before,
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:before,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:before,
table.dataTable thead .sorting_desc:after,
table.dataTable thead .sorting_asc_disabled:before,
table.dataTable thead .sorting_asc_disabled:after,
table.dataTable thead .sorting_desc_disabled:before,
table.dataTable thead .sorting_desc_disabled:after {
    bottom: 50% !important;
    font-size: 1.2rem !important;
    color: var(--dk-blue) !important;
}

table thead th:first-child {
    border-top-left-radius: var(--border-sm);
}

table thead th:last-child {
    border-top-right-radius: var(--border-sm);
}

.table_body {
    display: flex;
    flex-flow: column nowrap;
    justify-content: stretch;
}

.table_row {
    background-color: var(--pale-blue);
    border-radius: var(--border-md);
    padding: 1em;
    display: grid;
    grid-template-columns: 5fr 2.5fr 1.5fr 1fr;
    gap: 1em;
    height: 10rem;
}

.table_body .alternate, table .alternate, .alternate {
    background-color: var(--pale-blue);
    padding: 1em;
    gap: 1em;
}
.table_body .alternate {
    border-radius: var(--border-md);
}

.table_row:nth-child(odd),
.table_body .alternate:nth-child(odd),
table .alternate:nth-child(odd),
.alternate:nth-child(odd) {
    background-color: var(--white);
}

.product_img, .product_img_sm {
    height: 8rem;
    width: 8rem;
    border-radius: var(--border-sm);
    object-fit: contain;
    object-position: center;
    background-color: var(--white);
}

.product_img_sm {
    height: 5rem;
    width: 5rem;
}

/*INPUT*/

.input {
    display: flex;
    align-items: stretch;
    flex-flow: row nowrap;
    margin: 0;
}

.input input {
    display: flex;
    align-items: center;
    border-radius: var(--border-sm);
}

.input input, .input_prefix {
    padding: 0.6rem;
    font-size: 1rem;
    border: 1px solid var(--lt-lt-gray);
    background-color: var(--white);
    white-space: nowrap;
    overflow: hidden;
}

.input_has_prefix input {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.input_prefix {
    border-top-left-radius: 0.6rem;
    border-bottom-left-radius: 0.6rem;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: -1px;
}

.input_dropdown {
    border: none;
    outline: none;
    background: inherit;
    color: inherit;
    width: fit-content;
}

.input_dropdown_outline {
    padding: 0.6rem;
    font-size: 1rem;
    border: 1px solid var(--lt-lt-gray);
    background-color: var(--white);
}

.input_checkbox {
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
    gap: 0.6rem;
    position: relative;
}

.input_checkbox:has(.checkmark) {
    gap: 0;
    margin-bottom: 0;
}

.input_checkbox:has(.checkmark) input {
    appearance: none;
    width: 0;
    height: 0;
    opacity: 0;
}

.checkmark {
    height: 1.2rem;
    width: 1.2rem;
    background-color: var(--lt-lt-gray);
    border-radius: 2px;
    margin-right: 6px;
}

.input_checkbox:hover input ~ .checkmark {
    background-color: #ccc;
}

.input_checkbox input:checked ~ .checkmark {
    background-color: var(--pale-success);
}

.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

.input_checkbox .success_checked ~ .checkmark:after {
    display: block;
}

.input_checkbox .checkmark:after {
    left: 7px;
    top: 7px;
    width: 6px;
    height: 10px;
    border: solid var(--success);
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.input_checkbox .success_checked {
    color: var(--success);
}

.loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: rgba(255, 255, 255, 0.5);
    z-index: 300000;
    backdrop-filter: blur(5px);
}

/*.loader div {*/
/*    width: 60px;*/
/*    aspect-ratio: 1;*/
/*    --g: conic-gradient(from -90deg at 10px 10px, #fff 90deg, #0000 0);*/
/*    background: var(--g), var(--g), var(--g);*/
/*    background-size: 50% 50%;*/
/*    animation: loading 1s infinite;*/
/*}*/

.logo-loading {
    position: fixed;
    left: calc(50% - 24px);
    top: calc(50% - 24px);
    z-index: 900000;
    width: 48px;
    height: 48px;
    background: url('/img/logo-loading.webp') left top;
    background-size: 3456px 48px;
    animation: play-loading-animation 2s steps(72) infinite;
}

@keyframes play-loading-animation {
    100% { background-position: -3456px 0; }
}

.cover_page {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(15px);
    z-index: 1000000;
    color: var(--black);
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
    gap: 1em;
    padding: 1em;
}
@media screen and (min-width: 768px) {
    .cover_page {
        display: none;
    }
}

.modal_slide {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    padding: 2em;
    width: fit-content;
    min-width: 30%;
    max-width: 100vw;
    max-height: 100vh;
    overflow: auto;
    z-index: 200001;
    background-color: var(--white);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s;
    transform: translateX(100%);
    border-top-left-radius: var(--border-md);
    border-bottom-left-radius: var(--border-md);
}

.modal_slide.active {
    transform: translateX(0);
}

.modal_slide_backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 200000;
}

.modal_backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(6, 28, 99, 0.5);
    z-index: 10000;
    backdrop-filter: blur(2px);
}
.popup_modal {
    position: fixed;
    top: 5%;
    left: 5%;
    width: 90%;
    height: 90%;
    display: flex;
    flex-flow: column nowrap;
    padding: 2em;
    background-color: var(--white);
    border-radius: var(--border-md);
    z-index: 100001;
    overflow: auto;
}

.popup_modal .rows .link {
    background-color: var(--pale-blue);
    padding: 1em;
    border-radius: var(--border-sm);
}

.popup_modal .rows .link:nth-child(even) {
    background-color: var(--white);
}

.popup_modal .rows .link:hover {
    background-color: rgba(0, 0, 35, 0.1);
}

.popup_modal .rows .link:nth-child(even):hover {
    background-color: rgba(0, 0, 35, 0.05);
}

.popup_modal .close {
    border-radius: var(--border-sm);
}

.popup_modal .close:hover {
    cursor: pointer;
    background-color: rgba(0, 0, 0, 0.05);
}

.popup_modal.inline {
    position: static;
    top: unset;
    left: unset;
    width: unset;
    height: unset;
    min-height: 80%;
}

.filter_tag {
    background-color: var(--pale-success);
    color: var(--success);
    border-radius: 2rem;
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
    align-items: center;
    gap: 6px;
}

.filter_tag span {
    padding: 0.6rem;
}

.filter_tag span:first-child {
    font-size: 0.75rem;
    line-height: 1.75rem;
    height: 100%;
    background-color: rgba(40, 167, 69, 0.3);
    border-top-left-radius: 2rem;
    border-bottom-left-radius: 2rem;
}


.nav-item {
    margin-left: 1rem;
}

.nav-item.active > a, .nav-sub-item {
    border-bottom-left-radius: 4px;
    border-top-left-radius: 4px;
}

.nav-item.active > a .icon-holder {
    color: var(--dk-blue);
}

.nav-item.active > a {
    background: rgba(4, 70, 176, 0.1);
}
.nav-sub-item.active {
    background: rgba(4, 70, 176, 0.08);
}

.nav-item.active > a .title, .nav-sub-item.active > a {
    color: var(--dk-blue) !important;
    font-weight: bold;
}

.nav-item.active > a::before {
    content: '';
    position: absolute;
    top: 0;
    left: -1rem;
    width: 0.3rem;
    height: 100%;
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    background: var(--dk-blue);
}

.side-nav .side-nav-inner .side-nav-menu li a:hover .icon-holder,
.side-nav .side-nav-inner .side-nav-menu li a:focus .icon-holder {
    color: var(--dk-blue);
}

.nav-item.active > a:hover, .nav-sub-item.active > a:hover {
    background: rgba(4, 70, 176, 0.2);
}

.nav-sub-item > a:hover {
    background: rgba(4, 70, 176, 0.04) !important;
}

.filter_tag span:last-child {
    height: 100%;
    cursor: pointer;
    border-bottom-right-radius: 2rem;
    border-top-right-radius: 2rem;
}

.filter_tag span:last-child:hover {
    background-color: rgba(40, 167, 69, 0.1);
}

.report-cards {
    position: relative;
    display: flex;
    flex-flow: row wrap;
    width: 100%;
    padding: 0px 24px;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px;
}
.report-cards .card {
    width: 100%;
    max-width: 256px;
    margin: 0px 8px;
    padding: 8px 12px 4px 12px;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
}
.report-cards .card h4 {
    font-size: 2rem;
    margin: 0px;
}
.report-cards .card > div {
    position: relative;
    display: flex;
    top: -8px;
    font-size: 1rem;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.report-cards .card > div > span {
    font-size: 0.6rem;
    line-height: 0.8 !important;
}

.product, .product * {
    /*border: 1px solid red;*/
}
.product {
    position: relative;
    display: flex;
    width: 100%;
    flex-flow: row wrap;
    justify-content: stretch;
    align-items: flex-start;
    margin-top: 20px;
}
.card.bread {
    position: relative;
    display: flex;
    flex-direction: row;
    margin-top: 16px;
    margin-bottom: 0px;
}

.bread .product {
    margin-top: 0px !important;
    width: 100%;
    position: relative;
    display: flex;
}
.product .locations {
    /*min-height: 200px;*/
}
.product .col.locations {
    padding: 0px !important;
}
.product_header .label {
    font-size: 0.7rem;
    color: #1d262f;
}
.product_header h4 {
    font-size: 1.2rem;
    margin: 0px;
    margin-top: -5px;
}
.request_qty {
    font-size: 0.75rem;
    padding-left: 4px;
}
.destination {
    max-width: 20%;
}
.bucket {
    max-width: 20%;
}
button.accordian_btn {
    position: relative;
    display: flex;
    width: 100%;
    max-width: 256px;
    height: 58px;
}
.breadcrumbed_locations {
    position: relative;
    display: flex;
    flex-direction: row;
    margin-top: 24px;
    width: 100%;
}
.breadcrumbed_locations > div {
    position: relative;
    display: flex;
    flex-direction: row;
}
.product_selection {
    position: relative;
    display: flex;
    flex-direction: row;
}

.row .separate {
    justify-content: space-between;
}
.row .separate .center {
    justify-content: space-between;
    align-items: center;
}
.product_source_name {
    margin-right: 12px;
    font-weight: bold;
    font-size: 1.1rem;
}

.breadcrumb_select {
    /*border: 1px solid red;*/
    display: flex;
    /*min-height: 58px;*/
}
.breadcrumbed select {
    padding: 6px 12px;
    font-size: 1rem;
    margin-right: 8px;
}
.breadcrumbed .red {
    color: red;
    font-weight: bold;
}
.product_selection {
    padding: 16px;
    font-size: 1rem;
    display: flex;
    width: 100%;
    min-width: 100%;
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
}
.product_selection input {
    padding: 6px 12px;
    font-size: 1rem;
    max-width: 58px;
    text-align: center;
}
.product_selection button {
    padding: 6px 12px;
    font-size: 1rem;
}
.product_source_on_hand {
    margin-right: 16px;
}
.product_location {
    display: flex;
    width: 100%;
    flex-direction: column;
    border: 1px solid rgba(0,0,0, 0.1);
    background-color: rgba(0,0,0, 0.05);
    margin-top: 24px;
}
.product_location  .breadcrumbed {
    width: 100%;
}
.product_source_header {
    display: flex;
    flex-direction: row;
    align-items: center;
}
.pulling_controls button {
    background-color: #0f69f2;
    border-radius: 5px;
    outline: 0px;
    border: 0px;
    width: 40px;
    height: 40px;
    color: white;
    font-size: 1rem;
}
button.pull {
    background-color: #0f69f2;
    border-radius: 5px;
    outline: 0px;
    border: 0px;
    width: 128px;
    height: 40px;
    color: white;
    font-size: 1rem;
}
button.pull:disabled {
    opacity: 0.4;
    background-color: rgba(0,0,0, 0.7);
}
.pull_small {
    background-color: #0f69f2;
    border-radius: 5px;
    outline: 0px;
    border: 0px;
    width: 72px;
    height: 40px;
    color: white;
    font-size: 0.9rem;
    margin-right : 12px;
}
.pull_small:active,
.pull_small:focus {
    outline: 0px;
}
.pull_small.has_low_stock {
    background-color: #FFDE59;
    color: #282828;
}
.pull_ghost {
    display: flex;
    width: 128px;
    height: 40px;
}
.locations.destination {
    padding-top: 20px;
}
.fulfillments {
    position: fixed;
    display: flex;
    bottom: 0px;
    right: 0px;
    flex-direction: column;
    width: 100%;
    justify-content: flex-start;
    align-items: flex-start;
    border: 1px solid rgba(0,0,0, 0.1);
    padding: 24px;
    background-color: white;
    z-index: 1;
    padding: 24px;
    padding-left: 300px;
}
.full_view {
    position: relative;
    overflow-y: hidden;
    height: 0%;
    max-height: 0px;
    width: 100%;
}
.full_view.open {
    position: relative;
    overflow-y: visible;
    height: 100%;
    max-height: 75vh;
    margin-bottom: 16px;
    overflow-y: auto;
}
/*.fulfillments {*/
/*    position: relative;*/
/*    display: flex;*/
/*    flex-direction: column;*/
/*    width: 100%;*/
/*    justify-content: flex-start;*/
/*    border-radius: 0.5rem;*/
/*}*/
.fulfillments_list {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    justify-content: flex-start;
}
.fulfillment {
    position: relative;
    display: flex;
    flex-direction: row;
    width: 100%;
    justify-content: flex-start;
    align-items: center;
    padding: 8px;
    border: 2px solid white;
    margin-bottom: 6px;
    border-radius: 8px;
}
.fulfillment:nth-child(even) {
    background-color: rgba(0,0,0, 0.05);
}
.stock_carts.card {
    position: relative;
}
.attention {
    border: 2px solid red;
}
.cover {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
    z-index: 1;
}
.fulfill_controls {
    position: relative;
    display: flex;
    width: 100%;
    justify-content: space-between;
    align-items: center;
}
.fulfill_controls button {
    background-color: #0f69f2;
    border-radius: 5px;
    outline: 0px;
    border: 0px;
    height: 40px;
    color: white;
    font-size: 1rem;
    margin-left: 16px;
    padding: 0px 12px
}
.low_stock {
    font-size: 1rem;
    margin-left: 24px
}
.fulfill_controls button.self_checkout {
    background-color: #1c7430;
}
.fulfill_controls button:disabled {
    opacity: 0.4;
    background-color: rgba(0,0,0, 0.7);
}
.fulfillment button {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 32px;
    height: 32px;
    background-color: white;
    border: 1px solid rgba(0, 0, 0, 0.34);
    border-radius: 5px;
    margin-right: 16px;
}
.highest {
    margin-bottom: 4px;
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    font-size: 0.9rem;
}
.highest_qty {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
}
.low_stock,
.out_of_stock{
    font-size: 1rem;
    font-weight: bold;
    color: #ba8b00;
    line-height: 1;
    margin: 0px;
    padding: 0px;
}
.out_of_stock {
    color: #d70206;
}
.notice_message {
    padding: 4px 0px;
    font-size: 1rem;
}
.linkem {
    cursor: pointer;
    font: 0.9rem;
}
.linkem span {
    text-decoration: underline;
}
.linkem:hover {
    color: #1E56A0;
}
.linkem span img {
    margin-right: 12px;
}
.linkem_desktop {
    display: flex !important;
}
.linkem_mobile {
    display: none !important;
}
.yarrow {
    font-size: 0.7rem;
    opacity: 0.6;
    margin: 0px 8px 3px 8px;
    color: #0f69f2;
    position: relative;
    top: -1px;
}
.bread .card-content img {
    margin-right: 20px;
}
.img-title {
    display: flex;
    flex-direction: row;
}

.product .ctai {
    display: none;
}
.highlight_path {
    position: relative;
    display: flex;
    flex-flow: row wrap;
}
.bread .card-header .card-title {
    white-space: wrap;
    text-align: center;
}








.input-group-append {
    border: 1px solid #ced4da;
    border-top-right-radius: 0.25rem;
    border-bottom-right-radius: 0.25rem;
}








.debugging {
    position: relative;
    display: flex;
    width: 100%;
    max-width: 1200px;
    padding: 0px;
    margin: 0px;
    flex-direction: column;
}
.debugging pre {
    white-space: pre-wrap;
    overflow-wrap: break-word;
    word-wrap: break-word;
    max-width: 1200px;
}
.debugging pre code {
    white-space: pre-wrap;
    overflow-wrap: break-word;
    word-wrap: break-word;
    max-width: 1200px;
}

/*
    PAGE HEADER TITLE
    h1 / h2
 */
.page_header {
    padding: 24px 16px;
}
.page_header h1 {
    margin: 0px;
}
.breadcrumbs a {
    margin-bottom: 8px;
}

.modal-right .modal-dialog, .modal-left .modal-dialog {
    width: 75%;
    min-width: 300px;
    max-width: unset;
}
.modal-left {
    width: 100%;
}
.modal-left .modal-dialog {
    padding-right: 75%;
    width: 100%;
}


/* For tablets (typically 768px to 1024px) */
@media screen and (min-width: 768px) and (max-width: 1024px) {
    .modal-left .modal-dialog {
        padding-right: 5%;
        width: 100%;
    }
}

/* For mobile phones (typically up to 767px) */
@media screen and (max-width: 767px) {
    .modal-left .modal-dialog {
        padding-right: 5%;
        width: 100%;
    }
    .page_header {
        padding: 16px 8px;
    }
    .page_header h1 {
        font-size: 1.25rem;
    }
    .page_header h1 img {
        width: 32px !important;
        height: 32px !important;
    }
    .img-title {
        display: flex !important;
        flex-direction: column !important;
        width: 100%;
    }
    .img-title > img {
        min-height: 100px;
        margin-top: 20px;
    }
    .cta.svg {
        display: none !important;
    }
    .all_stations img,
    .all_rigs img {
        margin-right: 0px;
    }
    .card-body .card-content img {
        margin-right: 12px;
    }
    .fulfillments {
        padding: 12px 12px 12px 12px !important;
        -webkit-box-shadow: 0px 0px 16px -4px rgba(0,0,0,0.3);
        -moz-box-shadow: 0px 0px 16px -4px rgba(0,0,0,0.3);
        box-shadow: 0px 0px 16px -4px rgba(0,0,0,0.3);
    }
    .fulfill_buttons {
        display: flex;
    }
    .fulfill_buttons button {
        padding: 0px 14px;
        font-weight: bold;
        margin-left: 8px;
    }
    .linkem_desktop {
        display: none !important;
    }
    .linkem_mobile {
        display: flex !important;
    }
    .linkem span img {
        margin-right: 4px !important;
    }
    .linkem span {
        font-size: 1.1rem;
        text-decoration: none;
        align-items: center;
    }
    .linkem:hover {
        text-decoration: none;
    }
    .card-body {
        padding: 0.5rem;
        border-radius: 0px;
    }
    .card.bread {
        margin-bottom: 16px;
        border-radius: 0px;
        border: 0px;
    }
    .product h4 {
        font-size: 1rem !important;
        max-width: 320px;
    }
    .product .ctai {
        display: flex;
    }
    .product .ctax {
        /*display: flex;*/
        width: 32px !important;
        height: 32px !important;
        max-width: 32px !important;
        max-height: 32px !important;
        margin-right: 8px;
    }
    .show-mobile .pull_small {
        margin-right: 0px;
        margin-left: 8px;
        width: 90px;
        height: 44px;
        line-height: 1rem;
    }
    .highlight_controls button {
        font-weight: bold;
        letter-spacing: 0.5px;
    }
    .highlight_controls button > span {
    }
    .highlight_controls {
        padding: 0px 2px;
    }
    .breadcrumb_select {
        position: relative;
        width: 100%;
        flex-direction: column;
    }
    .location_selections {
        position: relative;
        width: 100%;
        flex-direction: column;
    }
    .breadcrumbed {
        position: relative;
        width: 100%;
        flex-direction: column;
    }
    .breadcrumbed_locations > div select {
        width: 100%;
        margin-right: 0px;
        margin-bottom: 8px;
        padding: 12px 12px
    }
    .product_selection {
        flex-direction: column;
    }
    .pulling_controls {
        padding: 12px 0px
    }
    .bread .card-header .card-title {
        white-space: wrap !important;
        text-align: center;
    }
}


.nav-item {
    margin-left: 1rem;
}

.nav-item.active > a, .nav-sub-item {
    border-bottom-left-radius: 4px;
    border-top-left-radius: 4px;
}

.nav-item.active > a .icon-holder {
    color: var(--dk-blue);
}

.nav-item.active > a {
    background: rgba(4, 70, 176, 0.1);
}
.nav-sub-item.active {
    background: rgba(4, 70, 176, 0.08);
}

.nav-item.active > a .title, .nav-sub-item.active > a {
    color: var(--dk-blue) !important;
    font-weight: bold;
}

.nav-item.active > a::before {
    content: '';
    position: absolute;
    top: 0;
    left: -1rem;
    width: 0.3rem;
    height: 100%;
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    background: var(--dk-blue);
}

.side-nav .side-nav-inner .side-nav-menu li a:hover .icon-holder,
.side-nav .side-nav-inner .side-nav-menu li a:focus .icon-holder {
    color: var(--dk-blue);
}

.nav-item.active > a:hover, .nav-sub-item.active > a:hover {
    background: rgba(4, 70, 176, 0.2);
}

.nav-sub-item > a:hover {
    background: rgba(4, 70, 176, 0.04) !important;
}
.fcc {
    position: relative;
    display: inline-block;
    font-size: 0.86rem;
    margin-left: 3px;
}
.fcs {
    color: #52c41a;
    margin-right: 4px;
    top: -6px;
}
#merge_video {
    position: fixed;
    background-color: rgba(200,200,200, 0.8);
    display: flex;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
    z-index: 10001;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    backdrop-filter: blur(10px);
}
.mv_container {
    position: relative;
    display: inline-block;
    background-color: white;
    /*border:1px solid rgba(0,0,0, 0.2);*/
    padding: 32px;
    border-radius: 16px;
    -webkit-box-shadow: 0px 4px 20px 0px rgba(0,0,0,0.3);
    -moz-box-shadow: 0px 4px 20px 0px rgba(0,0,0,0.3);
    box-shadow: 0px 4px 20px 0px rgba(0,0,0,0.3);
}
.mv_controls {
    position: relative;
    display: flex;
    padding: 16px 0px 0px 0px;
    text-align: right;
    width: 100%;
    justify-content: flex-end;
}
.mv_controls button {
    background-color: white;
    color: #0f69f2;
    padding: 4px 12px;
    outline: 0px;
    border-radius: 8px;
    border: 0px;
    font-size: 1rem;
    font-weight: bold;
}
.card-head {
    position: relative;
    border-radius: 0px;
    border-top: 2px solid rgba(0,0,0, 0.1);
    padding: 16px 16px 0px 16px
}
.card-head.in-card {
    border-bottom: 2px solid rgba(0,0,0, 0.1);
    border-top: 0px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 16px;
}
.card-head.in-card h5 {
    margin: 0px;
}
.badges-fw {
    min-width: 100px;
}
.badge-fw {
    min-width: 100%;
}
.card-controls {
    padding: 12px 24px;
    position: relative;
    display: flex;
    justify-content: space-between;
}
.card-controls a,
.card-controls button {
    padding: 14px 24px;
    font-size: 1.1rem;
}
.card-controls .btn-outline-primary {
    background-color: white;
}
.fa-action-btn {
    position: relative;
    width: 32px;
    height: 32px;
    font-size: 1.2rem;
}

.main-content > .card {
    margin-bottom: 12px;
}
.side__badge {
    position: relative;
    background-color: #1570EF;
    border-radius: 12px;
    color: #fff;
    padding: 0px 5px 0px 5px;
    position: relative;
    font-weight: 500;
    width: 24px;
    height: 24px;
    max-width: 24px;
    max-height: 24px;
    font-size: 0.80rem;
    justify-content: center;
    align-items: center;
    top: 5px;
    left: 2px;
}
.checklist_group_div .card-header > div {
    position: relative;
    width: 100%;
    display: block;
    padding: 24px;
}
.progress {
    margin-top: 16px;
    margin-bottom: 0px;
}
.count_header {
    width: 40px;
    height: 40px;
    max-width: 40px;
    max-height: 40px;
    border-radius: 20px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
}
.card-header > a, .card-header > button, .card-header > div > a, .card-header > div > button {
    /*padding: 8px 12px;*/
}
.checklist_done_button,
.checklist_back_button{
    font-size: 1.25rem;
    padding: 16px 32px;
}
.radio label {
    font-size: 1.25rem;
    display: flex;
    align-items: center;
    position: relative;
    width: 100%;
}
.checklist_group_div {
    z-index: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.2) !important;
}
.radio-group {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-direction: column;
    border: 1px solid rgba(0,0,0, 0.1);
    background-color: rgba(0,0,0, 0.05);
    border-radius: 8px;
    padding: 16px 24px 16px 32px;
}
.radio-group .radio {
    margin: 0px;
    margin-top: 12px;
}
.radio-group .radio label {
    font-weight: bold;
}
.btn.add-image {
    font-size: 1.25rem
}
.checklist-form {
    margin-bottom: 12px;
}
.checklist-form select {
    font-size: 1.25rem;
}
.checklist-form input {
    font-size: 1.25rem;
}

.scroll-full-height {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.control-baser {
    position: relative;
    display: flex;
    flex: 1;
    justify-content: flex-end;
    align-items: flex-end;
    min-height: 96px;
}
.all_checklist_details {
    min-height: 512px;
    max-height: 512px;
    overflow-y: scroll;
    height: 100%;
}
.checklist_radio {
    margin: 8px 0px;
}
.checklist-description {
    font-size: 1.2rem;
    padding: 0 12px 8px 12px;
}
.all_checklist_details .checkbox input[type=checkbox]+label:before {
    width: 28px;
    height: 28px;
    font-size: 19px;
    margin-left: 10px;
}
.progress_container {
    padding: 0px 12px;
    box-sizing: border-box;
}

.card-header.progress-completed {
    background-color: rgba(255,255,255, 0.9);
}
.card-header.progress-completed .h3 {
    color: rgba(144,144,144, 1);
}
.progress-bar.progress-completed {
    background-color: #a1d1ad;
    /*background-color: #6497ea;*/
}
.progress-status {
    padding-left: 12px;
}
.card-header.progress-completed .progress {
    border-color: #a1d1ad;
}

.badge.badge-pill.count_header.badge-primary {
    background-color: var(--green);
}
.checklist_file {
    font-size: 1.25rem;
    background-color: #007bac;
}
.checklist-card {
    background-color: rgba(144,144,144, 0.05);
}


.file_manager_image {
    width: 10em;
}
.img_title {
    display: inline-block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: middle;
}

.row_aid {
    display: none;
}
.reverse_row_aid {
    display: block;
}

.audit_table {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 2fr;
    align-items: center;
}

.dragging-row {
    background-color: var(--pale-danger);
    outline: 2px dashed var(--danger);
}

/* Smartphones (portrait and landscape) */
@media (max-width: 767px) {
    .all_checklist_details {
        min-height: 320px;
        max-height: 320px;
    }

    .checklist_group_div {
        border-radius: 8px !important;
    }

    .checklist_group_div .card-header > div {
        padding: 10px 0px 0px 0px;
    }

    .page-container .main-content {
        padding: 0em 0em 110px 0em !important;
    }

    .file_manager_image {
        width: 100%;
    }

    .simple_mobile_table thead tr {
        position: absolute;
        top: -9999px;
        left: -9999px;
    }

    .simple_mobile_table td {
        display: block;
        width: inherit !important;
    }

    .row_aid {
        display: block;
    }

    .reverse_row_aid {
        display: none;
    }

    .audit_table {
        grid-template-columns: 1fr;
        align-items: center;
    }

    #search_products_table tr {
        display: flex;
        flex-flow: column nowrap;
        justify-content: flex-start;
        align-items: flex-start;
        gap: 6px;
        border: 1px solid rgba(0, 0, 0, 0.1);
    }

    #search_products_table tr td {
        padding: 0 !important;
        background-color: unset;
    }

    #search_products_table tr td:before {
        content: '';
        display: none;
    }

    #search_products_table tr td .product_search_actions {
        width: 100% !important;
    }

    .product_search_header {
        flex-flow: column nowrap;
    }

    .product_search_header_details {
        flex-flow: row wrap;
        justify-content: stretch;
        align-items: center;
    }

    .product_search_header_details button {
        flex: 48%;
    }

    .product_search_header_details input, .product_search_header_details label {
        width: 100%;
    }

    .inv_product_row > div {
        width: 100%;
    }
}
.inv_product_row {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: center;
    gap: 1em;
    margin-bottom: 1em;
}

@media (max-width: 1212px) {
    .tracked_row_group {
        flex: 100%;
        width: 100%;
    }
    .tracked_row_group input {
        width: 100%;
    }
    .inv_product_row:has(.inv_tracked_product_row) > div {
        width: 100%;
    }
    .inv_product_row > div:first-child {
        justify-content: center;
    }
}
/* Tablets (portrait and landscape) */
@media (min-width: 768px) and (max-width: 1024px) {
  /* Tablet styles */
}

.mini_loader {
    width: 100%;
    height: 100%;
    min-height: 200px;
    background: inherit;
    display: flex;
    justify-content: center;
    align-items: center;
}
.mini_loader > i {
    font-size: 2rem;
    color: var(--blue);
    animation: spin 2s linear infinite;
}

.input_dropdown_menu {
    padding: 0;
    position: absolute;
    top: 100%;
    right: 0;
    z-index: 100;
    width: 100%;
    background: white;
    border: 1px solid rgba(0, 0, 0, 0.1);
    list-style: none;
    box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.1);
    border-radius: 5px;
    cursor: pointer;
}
.input_dropdown_menu li {
    padding: 0.6em;
}
.input_dropdown_menu li:hover {
    background: rgba(0, 0, 0, 0.12);
}

.circular-progress {
    --progress: 0; /* fallback */
    transition: --progress 1s ease-out;
    --size: 250px;
    --half-size: calc(var(--size) / 2);
    --stroke-width: 20px;
    --radius: calc((var(--size) - var(--stroke-width)) / 2);
    --circumference: calc(var(--radius) * pi * 2);
    --dash: calc((var(--progress) * var(--circumference)) / 100);
    animation: progress-animation 5s linear 0s 1 forwards;
    max-width: 42px;
    min-width: 42px;
    max-height: 42px;
    min-height: 42px;
}
.circular-progress, .inspection_progress_text {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 12px;
    margin: auto 0px;
}
.inspection_progress_text {
    height: fit-content;
    right: 18px;
}

.circular-progress circle {
    cx: var(--half-size);
    cy: var(--half-size);
    r: var(--radius);
    stroke-width: var(--stroke-width);
    fill: none;
    stroke-linecap: round;
}

.circular-progress circle.bg {
    stroke: #ddd;
}

.circular-progress circle.fg {
    transform: rotate(-90deg);
    transform-origin: var(--half-size) var(--half-size);
    stroke-dasharray: var(--dash) calc(var(--circumference) - var(--dash));
    transition: stroke-dasharray 0.3s linear 0s;
    stroke: #5394fd;
}

@keyframes progress-animation {
    from {
        --progress: 0;
    }
    to {
        --progress: var(--progress);
    }
}

/* New notification settings styles */
.notification-number-input {
    width: 50px;
    padding: 2px 4px;
    font-size: 0.9rem;
    border: 1px solid #ccc;
    vertical-align: baseline;
    display: inline;
}

.notification-select-dropdown {
    border: 1px solid #ccc;
    display: inline-block;
    vertical-align: top;
}

.notification-inline-label {
    display: inline-block;
    margin-right: 10px;
    vertical-align: top;
}

.notification-section-divider {
    border-top: 2px solid #edf2f9;
}
