/*
Theme Name: stc - Trade Federation Market
Theme URI: https://dot.swc-tf.com/
Description: Standard Template Construct for https://dot.swc-tf.com/
Version: 1.0
Author: Martin Mulholland Web Design
Author URI: https://mmulholland.co.uk/
*/

@font-face {
    font-family: 'Lato';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('./fonts/Lato-Regular.ttf') format('truetype');
}

/* latin */
@font-face {
    font-family: 'Lato';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('./fonts/Lato-Bold.ttf') format('truetype');
}

:root {
    --color-background: #ffffff;
    --color-background-elevated: #F0F0F0;
    --color-background-evidence: #ccdbff;
    --text-color: #606060;
    --text-lighter: #727272;
    --text-darker: #333333;
    --color-primary: #294263;
    --color-primary-lighter: #2f4b72;
    --color-primary-contrast: #ffffff;
    --color-primary-text: #294263;
    --color-secondary: #396e9c;

    --menu-shadow: #808080;

    --navbar-search-back: #f2f2f6;
    --navbar-search-fore: #333333;

    --flasher-primary: #ff0000;
    --flasher-secondary: #ffffff;

    --input-color: #495057;
    --input-border: #ced4da;
    --input-disabled: var(--text-color);

    --hc-color-0: var(--color-secondary);
    --hc-color-1: #c21515;

    --announcement-warning: #ffff66;
    --announcement-success: #93DB70;
    --announcement-error: #EE6363;

    --listing-overlay: rgba(42, 67, 97, 0.6);

    --black: #000000;
    --grey: #808080;
    --white: #ffffff;

    --color-hr: #d2d2d2;
}
.logo-dark {display: none;}
body.theme-3 .logo-dark {display: block;}
body.theme-3 .logo-light {display: none;}
@media (prefers-color-scheme: dark) {
    body.theme-1 {
        /* AUTO DARK THEME */
        --color-background: #191D21;
        --color-background-elevated: #24282C;
        --color-background-evidence: #35414d;
        --text-color: #d2d2d2;
        --text-lighter: #e9e9e9;
        --text-darker: #a0a0a0;

        --color-primary-text: #426A9E;

        --navbar-search-back: #333333;
        --navbar-search-fore: #e6e6e6;

        --input-color: #777f86;
        --input-border: #e6e6e6;

        --color-hr: #efefef;
    }
    body.theme-1 .logo-dark {display: block;}
    body.theme-1 .logo-light {display: none;}
    .table-events font {
        color: #d2d2d2!important; /* Old events have black hard-coded in the event text that we need to override */
    }
}

body.theme-3 {
    /* DARK THEME */
    --color-background: #191D21;
    --color-background-elevated: #24282C;
    --color-background-evidence: #35414d;
    --text-color: #d2d2d2;
    --text-lighter: #e9e9e9;
    --text-darker: #a0a0a0;

    --color-primary-text: #426A9E;

    --navbar-search-back: #333333;
    --navbar-search-fore: #e6e6e6;

    --input-color: #777f86;
    --input-border: #d9d9d9;
    --input-disabled: var(--text-darker);

    --color-hr: #efefef;
}

/* Global Styles */
body{
    font-family: 'lato', sans-serif;
    font-size: 14px;
    font-weight: 400;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    line-height: 2em;
    color: var(--text-color);
    background: var(--color-background);
}

hr {border-color: var(--color-hr);}

.container-full {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
}

/* Overrides old <font> tags in events and requests */
font[color] {
    color: inherit !important;
}

.form-control {
    background-color: transparent !important;
    border-color: var(--input-border);
    color: var(--text-color) !important;
}
.form-control:disabled, .form-control.disabled {
    background-color: rgba(0, 0, 0, .2) !important;
    color: var(--input-disabled) !important;
    cursor: not-allowed;
}
.form-control option {
    background-color: var(--color-background);
    color: var(--text-color);
}
.table-wrapper {
    max-width: 100vw;
    overflow: hidden;
}
#page-filler {
    flex-grow: 1;
}
.header-top, nav.navbar, .announcement-bar, #dev-info, #theme-switch {order: 1;}
#alert-bar {order: 2;}
body>div, body>section, body>footer, body>table {order: 3;}

.nopadding{padding: 0 !important;}
.nopadding-left{padding-left: 0 !important;}
.nopadding-right{padding-right: 0 !important;}
.nopadding-top{padding-top: 0 !important;}
.nopadding-bottom{padding-bottom: 0 !important;}
.nomargin{margin: 0 !important;}
.nomargin-left{margin-left: 0 !important;}
.nomargin-right{margin-right: 0 !important;}
.nomargin-top{margin-top: 0 !important;}
.nomargin-bottom{margin-bottom: 0 !important;}

.mobile-brand{
    display: none;
}

.clickable {
    cursor: pointer;
}
.strikethrough {text-decoration: line-through;}

.justify-content-evenly {justify-content: space-evenly;}
/* Bootstrap overrides for dark theme */
.nav-tabs .nav-item.show .nav-link, .nav-tabs .nav-link.active {
    background-color: var(--color-primary);
    color: var(--color-primary-contrast) !important;
}
.modal-content {
    background-color: var(--color-background);
}
.close {color: var(--text-color);}
.close:not(.disabled):not(:disabled):hover, .close:not(.disabled):not(:disabled):focus {
    color: var(--text-lighter);
}
.close:focus {
    outline: none;
}

.form-control:focus {
    border-color: var(--color-primary-lighter);
    /*box-shadow: 0 0 0 0.2rem rgba(0, 135, 255, 0.25);*/
    box-shadow: 0 0 0.2rem 0.1rem var(--color-secondary);

}


/**Theme Spacing Customization**/
.theme-spacing-top-margin{
    margin-top: 20px;
}
.theme-spacing-top-padding{
    padding-top: 40px;
}
.theme-spacing-bottom-padding{
    padding-bottom: 40px;
}
.left-padding-none{
    padding-left: 0 !important;
}

/**Global**/
.btn-primary, .btn-listing {
    font-size: 14px;
    color: var(--color-primary-contrast) !important;
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}
.btn-primary:hover, .btn-primary:active, .btn-primary:focus, .btn-listing:hover {
    background-color: var(--color-primary-lighter) !important;
    border-color: var(--color-primary-lighter) !important;
}

.btn-secondary {
    color: var(--color-primary-contrast);
    background: var(--color-secondary);
    border-color: var(--color-secondary);
}

.btn-listing{
    width: 100%;
}
#form-add-to-cart {
    margin-top: 20px;
}
.select-cart {
    font-size: 14px;
}
.avatar {width: 100px; height: 100px; object-fit: contain;}
.shop-logo {width: 100px; height: 100px; object-fit: contain;}
.shop-banner {max-width: 100%; max-height: 100%; width: 468px; height: 60px; object-fit: contain;}
.img-entity {width: 100px; height: 100px; max-width: 100%; object-fit: contain;}

.shop-logo.preview, .shop-banner.preview {
    box-sizing: content-box;
    border: 1px solid var(--grey);
}

/* SHOPS */
.assembly-row {
    padding-top: 4px;
    padding-bottom: 4px;
    border-bottom-width: 1px;
    border-bottom-style: solid;
    border-color: #d3d3d3;
}
#shop-quantity-table .form-control{
    min-width: 80px;
}
.message-row {
    align-items: center;
    border-bottom: 1px solid;
    border-color: #d3d3d3;
}
.message-unread {
    background-color: var(--color-background-evidence);
}

.btn-text {
    border: none;
    display: inline-block;
    background: none;
    cursor: pointer;
    color: var(--text-color);
}

/**Utilities**/
.credit-symbol{
    width: 15px;
    height: 15px;
    margin-top: -5px;
}

/* Header */
/** Navigation **/
.header-top, .navbar{
    line-height: 1.5em!important;
}
.navbar {
    flex-shrink: 0;
}
.navbar-brand{
    height: auto;
}

.dropdown-submenu {
    position: relative;
}
.dropdown-submenu a::after {
    transform: rotate(-90deg);
    position: absolute;
    right: 6px;
    top: 0.9em;
}
.dropdown-menu{
    top: 36px;
    background: var(--color-background);
    color: var(--text-color);
    padding-top: 0 ;
    padding-bottom: 0 ;
    font-size: 14px;
    border: 0;
    box-shadow: 0 1px 3px 0 var(--menu-shadow);
}
.dropdown-menu li:first-child a.dropdown-item {border-radius: 0.25rem 0.25rem 0 0;}
.dropdown-menu li:last-child a.dropdown-item {border-radius: 0 0 0.25rem 0.25rem;}
.dropdown-submenu .dropdown-menu {
    top: 0;
    left: 100%;
    margin-top: -1px;
}
.dropdown-submenu-left .dropdown-menu {
    left: unset;
    right: 100%;
}
.dropdown-item {
    color: var(--text-color);
}
.dropdown-item:focus, .dropdown-item:hover{
    background-color: var(--color-primary);
    color: var(--color-primary-contrast);
}
.navbar-cart{
    font-size: 30px;
}

.navbar-search-prepend{
    border: none;
    border-radius: 1em;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}
.navbar-search-prepend svg{
    margin-left: 15px;
}
.navbar-search-input{
    border: none;
    border-radius: 1em;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}
.navbar-search-prepend{
    background: var(--navbar-search-back);
}
.navbar-search-prepend svg,
.navbar-search-input::-webkit-input-placeholder,
.navbar-search-input::-moz-placeholder,
.navbar-search-input:-moz-placeholder, /* Older versions of Firefox */
.navbar-search-input:-ms-input-placeholder {
    color: var(--navbar-search-fore);
}
.navbar-search-input{
    background: var(--navbar-search-back) !important;
    color: var(--navbar-search-fore) !important;
}

.nav-link{
    padding-bottom: 0;
    color: var(--navbar-search-fore)!important;
}

.mobile-header-events{
    display: inline-block!important;
    padding: 0 15px 0 15px;
    margin-bottom: 10px;
}

.event-flasher {
    position: relative;
    display: inline-block;
    width: 2em;
}
.event-flasher .event-num {
    position: absolute;
    display: block;
    top: 0;
    right: 0;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border-radius: 8px;
    line-height: 16px;
    text-align: center;
    font-size: 12px;
    background-color: var(--flasher-primary);
    color: var(--flasher-secondary);
}
.event-flasher.flashing .event-num {
    animation: flasher;
    animation-duration: 1.6s;
    animation-iteration-count: infinite;
    animation-direction: alternate;
    animation-timing-function: ease-in-out;
}
.event-flasher.event-none .event-num{display: none;}
@keyframes flasher {
    from {background-color: var(--flasher-primary); color: var(--flasher-secondary);}
    to {background-color:  var(--flasher-secondary); color: var(--flasher-primary);}
}
.mobile-events .event-num {right: -7px;}

.useAsButton {
    cursor: pointer;
}

#alert-bar {position: sticky; top: 0; padding-top: 12px; z-index: 999;}

.table-events .unread {font-weight: bold;}

/** Links **/
a {text-decoration: none;}
a:link {text-decoration: none;color:inherit;}
a:visited {text-decoration: none;color:inherit;}
a:hover {text-decoration: underline;}
a:active {text-decoration: none;color:inherit;}

/** Announcement Bar **/
.announcement-bar{
    line-height: 1.5em;
}
.announcement-row {
    padding-top: 10px;
    padding-bottom: 10px;
    border-color: #ffffff;
}
.announcement-bar p{
    font-size: 14px;
    margin-bottom: 0;
}
.announcement-row+.announcement-row,
.announcement-row.announcement+.announcement-row.announcement,
.announcement-row.error+.announcement-row.error,
.announcement-row.warning+.announcement-row.warning,
.announcement-row.message+.announcement-row.message {
    border-top-width: 1px;
    border-top-style: solid;
}

.announcement-row.announcement{background: var(--color-primary); color: var(--color-primary-contrast);}
.announcement-row.warning {background: var(--announcement-warning); color: var(--black);}
.announcement-row.message {background: var(--announcement-success); color: var(--black);}
.announcement-row.error {background: var(--announcement-error); color: var(--black);}


.dropdownbutton{
    width: 100%;
}

#privacypolicycontainer {
    display: flex;
    align-items: center;
}
.privacypolicycontent {
    margin-right: 2em;
}

@media (max-width: 767px) {
    #privacypolicycontainer {
        flex-direction: column;
    }
}


/* Index */


/** Index Products **/
.summary-title-area{
    margin-top: 20px;
}
.product-listing-summary{
    margin-bottom: 40px;
	display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    color: var(--text-darker);
}
.product-listing-summary a:hover{
    text-decoration: none;
}
.product-listing-summary h2{
    font-size: 16px;
    font-weight: bold;
    margin-top: 10px;
    margin-bottom: 0;
}
.product-listing-summary p{
    margin-bottom: 0 ;
    line-height: 20px;
    margin-top: 10px;
}

.listing-image-box, .order-image-box {
    min-height: 201px;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    background: #000000;
}
.order-image-box {
    min-height: unset;
}

.listing-image-div {
    flex: 0 0 auto;
    max-width: 50%;
}
.listing-image {
    max-width: 100%;
}
.image-div-1 {max-width: 100%;}
.listing-summary-image-overlay {
    z-index: 1;
    position: absolute;
    top: 0;
    right: 0;
    height: 100%;
    width: 50%;
    background-color: var(--listing-overlay);
}
.listing-summary-image-overlay p{
    font-size: 24px;
    font-weight: bold;
    color: var(--white);
    position: absolute;
    right: 30px;
    bottom: 45%;
}
.product-listing-summary .product-price p img{
    width: 15px;
    height: 15px;
    margin-top: -5px;
}
.product-listing-summary-item p{margin-top: 0;}
.product-listing-summary-item a{margin-top: 0;}

.product-listing-summary-user a{font-weight: bold;}
.product-listing-summary-user p{
	margin-top: 5px;
}
.product-listing-summary-item a,
.product-listing-summary-user a {color: var(--color-primary-text);}

.product-listing-summary-item a:hover,
.product-listing-summary-user a:hover{color: var(--color-primary-lighter);}

.product-listing-summary hr{
	margin-top: 3px!important;
	margin-bottom: 3px!important;
}
.product-listing-summary-body {
    flex-grow: 1;
}

.category-filter-open {
    display: none;
}
/* remove spinner/helpers on slider filter inputs */
.slider-input::-webkit-outer-spin-button,
.slider-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.slider-input[type=number] {
    -moz-appearance: textfield;
}

.noUi-target {
    border-radius: 4px;

}
.noUi-horizontal {
    height: 8px;
}
.noUi-horizontal .noUi-handle {
    background-color: var(--color-primary);
    box-shadow: inset 0 0 1px #fff, inset 0 4px 4px var(--color-primary-lighter), 0 3px 6px -3px #bbb;
    width: 24px;
    height: 24px;
    border-radius: 12px;
    right: -12px;
    top: -9px;
}
.noUi-handle::after, .noUi-handle::before {display: none;}


.review-star-radio {
    display: inline-flex;
    align-items: center;
}

    /* Add listing page */
.add-listing-options label {
    justify-content: flex-start;
}
.removeEntity {cursor: pointer;}

#preview-listing button {pointer-events: none !important;}

.heading-container {
    padding: 10px;
    line-height: 1.5em;
    margin-bottom: .5em;
    background: var(--color-primary);
    color: var(--color-primary-contrast);
}
.heading-container h4 {margin-bottom: 0;}
.heading-clear {
    background: transparent;
    color: inherit;
}

/* Listing details */
.carousel {
    background-color: black;
}

#productlistingcarousel .carousel-item img {
    width: 100%;
    max-height: 350px;
    object-fit: scale-down;
}

/* Cart page */
.cart-shop-heading{
    padding-top: 10px;
    padding-bottom: 10px;
    line-height: 1.5em;
    background: var(--color-primary);
    color: var(--color-primary-contrast);
}

.cart-shop-heading h4{
    margin-bottom: 0;
}

.cart_checkout_btn{
    font-weight: bolder;
}
.cart-side {
    position: sticky;
    top: 50px;
}

/* Checkout Page */
.product-price {
    white-space: nowrap;
}

/* Registration Page */
.form-check-input{
    position: relative;
    margin-left: 0;
}

.form-control.force-inline {
    display: inline-block;
    width: auto;
    vertical-align: middle;
}

/* Public account lists */
#public-list-page #pagination_inner>.row {
    justify-content: space-evenly;
}
.account-list-card {
    border-radius: .25rem;
    flex: 0 0 160px;
    text-align: center;
    padding: .8em;
    margin: 0 .6em 1.6em;
    line-height: 1.4em;
    display: flex;
    flex-direction: column;
    align-items: center;
    border: 1px solid rgba(0,0,0,.125);
}
.account-list-card>* {flex: 0 0 auto;}
.account-list-name {
    margin-top: 0.4em;
    flex: 1 0 auto;
}
.page-link, .page-item.disabled .page-link, .page-link:hover {
    background-color: transparent;
}
.page-item.active .page-link {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-primary-contrast);
}

@media (max-width: 360px) {
    .account-list-card {
        flex-basis: 140px;
    }
}



/* Footer */
/** Footer Main Section **/
body>footer {
    margin-top: 1em;
}
.footer{
    padding-top: 20px;
    padding-bottom: 0;
    background: var(--color-primary);
    color: var(--color-primary-contrast);
}
.footer h2{
    margin-top: 0 ;
}
.footer-sections{
    margin-top: 20px;
    margin-bottom: 20px;
}
.footer-sections ul{
    list-style: none;
    padding-left: 0 ;
}
/** Copyright **/
.copyright {
    background: var(--color-primary);
    color: var(--color-primary-contrast);
}
.copyright p {
    padding-top: 0;
    padding-bottom: 30px;
    margin-bottom: 0;
    color: var(--white);
}

/* API Viewer */
#api-viewer-wrapper {
    max-width: 100%;
}
.api-viewer {
    max-width: 100%;
}
.api-viewer tr {
    border: 1px solid var(--color-hr);
}
td>.api-viewer {
    width: 100%;
}
.api-viewer .td-collapse {
    padding: 0;
}
.api-viewer .api-viewer tr {
    border-top: 0;
    border-right: 0;
}
.api-viewer .api-viewer tr:last-child {
    border-bottom: 0;
}

/** Dev stuff **/
#dev-info {background-color: #fff965; color: var(--black); text-align: center;}
#dev-info form {display: inline-block;}
#dev-info form input {line-height: 1em;}

#theme-switch {background-color: mediumorchid; color: var(--white)}
.theme-switch {cursor: pointer;}

/** Bug Base Tweaks **/
.bugbase-button {
    margin-left: 1px;
    margin-right: 1px;
}

/** ADMIN AREA **/
.user-row {
    padding-bottom: 2em;
    margin-bottom: 1em;
    border-bottom: 1px solid lightgrey;
}
.user-row:last-of-type {border-bottom: none;}
.user-row .alert, .user-row .btn {padding: 0.375rem 1rem; text-align: center; margin-bottom: 1em;}
.user-row .alert:last-child, .user-row .btn:last-child{margin-bottom: 0;}
.user-row .avatar {display: block; margin: 0 auto 4px;}

.user-admin-priv-list{
    list-style: none;
    padding-left: 0;
}
.custom-select{
    margin-top: 4px;
}

.blacklist-select-type, .as-select-type {
    display: none;
}

.card {
    background-color: var(--color-background-elevated) !important;
}
.card-header{
    background-color: var(--color-primary) !important;
    border-color: var(--color-primary) !important;
}
.card-header h5 button{
    color: var(--color-primary-contrast) !important;
}

.ajax_loading_gif {
    position: absolute;
    top: 40px;
    left: 0;
    right: 0;
    visibility: visible;
    display: none;
    z-index: 999;
}
.ajax_loading_gif img {
    display: block;
    margin: 0 auto;
}

.side-menu-toggler {display: none;}
/* Media Queries ----------- */
/** xs **/
@media only screen
and (min-width : 0 )
and (max-width : 575px) {
    .table-wrapper {
        overflow-x: auto;
    }

    .hero-bar-text-background{
        width: 100%;
    }
    .theme-spacing-top-margin{
        margin-top: 0 ;
    }
    .mobile-nopadding-left{
        padding-left: 0 ;
    }
    .mobile-nopadding-right{
        padding-right: 0 ;
    }
    /**Global**/
    .hide-mobile{
        display: none;
    }
    .hero-banner .container{
        padding-top: 40px;
    }
    #main-menu {
        position: fixed;
        top: 0;
        right: -240px;
        bottom: 0;
        width: 240px;
        z-index: 100;
        transition: right 400ms;
        overflow-y: auto;
        padding-left: 0;
        padding-right: 0;
        background: var(--color-background);
    }
    #main-menu.open {
        right: 0;
        box-shadow: 0 0 3px 0 var(--menu-shadow);
    }
    #main-menu>.navbar-nav {align-self: flex-start; width: 100%;}
    #main-menu .nav-item {text-align: left;}
    #main-menu .nav-link {padding: 8px 12px; display: block;}
    /*#main-menu .nav-link:hover {
        background-color: var(--color-primary);
        color: var(--color-primary-contrast) !important;
    }*/
    #main-menu .nav-item>.dropdown-menu {display: block; border: 0; box-shadow: none;}
    #main-menu-back {
        display: none;
        position: fixed;
        top: 0; bottom: 0;
        left: 0; right: 0;
        z-index: 99;
    }
    #main-menu.open ~ #main-menu-back {display: block;}

    #main-menu-toggler {font-size: 30px;}
    #main-menu-toggler-container {align-content: flex-start; align-items: flex-start; order: 1;}
    .logged-out #main-menu-toggler {margin-top: 7px;}
    .logged-out #main-menu-toggler-container.search-open {display: none;}
    #user-dropdown-wrapper .btn {font-size: 16px;}

    .navbar-search{
        margin-top: 10px;
        margin-bottom: 10px;
    }
    .dropdown-submenu .dropdown-menu {
        position: static;
        float: none;
        max-width: 100%;
    }
    .sub-dropdown-item::before{
        content: "- ";
    }
    .mobile-events{
        flex-direction: row;
        justify-content: space-evenly;
        margin-bottom: 10px;
    }
    .mobile-events .nav-item {margin-right: .8em;}
    .mobile-events .nav-item:last-child {margin-right: 0;}
    .mobile-events .event-num {right: -9px;}
    .navbar-search-prepend svg{
        margin-right: 15px;
    }
    .navbar-search-prepend{
        border-top-right-radius: 1em!important;
        border-bottom-right-radius: 1em!important;
    }
    #search-bar{
        width: 0;
        flex-grow: 0;
        flex-shrink: 0;
        padding-right: 0 ;
        padding-left: 0 ;
    }
    #search-bar-wrapper.search-open {width: 100%; max-width: none; min-width: 100%;}
    #search-bar-wrapper.search-open #search-bar{
        width: auto;
        flex-grow: 1;
        transition: all ease-in-out .3s;
        display: inline-block;
    }
    #search-bar-wrapper.search-open .navbar-search-prepend{
        border-top-right-radius: 0!important;
        border-bottom-right-radius: 0!important;
    }
    #user-dropdown-wrapper.search-open, #navigation-dropdown-wrapper.search-open{
        display: none!important;
    }
    #user-dropdown-wrapper>.dropdown-menu {
        left: 0;
        right: 30px;
    }
    .announcement-bar-close{
        padding-left: 0 ;
    }
    .logged-out .fa-search{
        margin: 0 !important;
    }
    .category-filter-area {
        position: fixed;
        height: 100vh;
        max-height: 100vh;
        width: 200px;
        top: 0;
        left: -200px;
        transition: left ease-in-out 250ms;
        border-right: 1px solid grey;
        z-index: 10;
        background: var(--color-background);
        overflow: auto;
        padding-top: 1em;
        padding-bottom: 1em;
    }
    .category-filter-area.open {
        display: block;
        left: 0;
    }
    .category-filter-back {
        display: none;
        position: fixed;
        top: 0; bottom: 0;
        left: 0; right: 0;
        z-index: 6;
    }
    .category-filter-area.open~.category-filter-back {display: block;}

    .side-menu-toggler {display: inline-block;margin-right: .6em; font-size: 20px; vertical-align: middle;}
    .side-menu-toggler ~ h4 {display: inline-block; vertical-align: middle;}
    .side-menu {
        position: fixed;
        width: 200px;
        top: 0;
        bottom: 0;
        left: -200px;
        transition: left ease-in-out 250ms;
        z-index: 1050;
        overflow: auto;
        padding-top: 1em;
        max-width: none;
        background: var(--color-background);
    }
    .side-menu.open {
        left: 0;
        box-shadow: 0 0 3px 0 var(--menu-shadow);
    }
    .side-menu-back {
        content: '';
        display: none;
        position: fixed;
        top: 0; bottom: 0;
        left: 0; right: 0;
        z-index: 1040;
    }
    .side-menu-back, .category-filter-back, #main-menu-back {background: rgba(0, 0, 0, .2);}

    /*.navbar-collapse{
        border-top: 1px solid #e9ecef;
    }*/
}
/** sm **/
@media only screen
and (min-width : 576px)
and (max-width : 767px) {
    .table-wrapper {
        overflow-x: auto;
    }

    .hero-bar-text-background{
        width: 100%;
    }
    .theme-spacing-top-margin{
        margin-top: 0 ;
    }
    .mobile-nopadding-left{
        padding-left: 0 ;
    }
    .mobile-nopadding-right{
        padding-right: 0 ;
    }
    .mobile-header-button{
        margin-top: -5px;
    }
    /**Global**/
    .hide-mobile{
        display: none;
    }
    .hero-banner .container{
        padding-top: 40px;
    }

    .navbar-search{
        margin-top: 10px;
        margin-bottom: 10px;
    }
    .mobile-admin{
        margin-top: 10px;
        margin-bottom: 10px;
    }
    .mobile-events {
        flex-direction: row;
        justify-content: space-evenly;
        margin-bottom: 10px;
    }
    .mobile-header-events {
        margin-top: 10px;
        padding: 0 10px 0 10px;
    }
    .product-listing-summary-image-container-2{
        min-height: 0 ;
    }
    .product-listing-summary-image-container-2 .clear-left{
        padding-left: 0 ;
        margin-top: 0;
    }
    .product-listing-summary-image-container-2 .clear-right{
        padding-right: 0 ;
        margin-top: 0;
    }
}
/** md **/
@media only screen
and (min-width : 768px)
and (max-width : 991px) {
    .theme-spacing-top-margin{
        margin-top: 0 ;
    }
    .hero-bar-text-background{
        width: 100%;
    }
    /**Global**/
    .hide-mobile{
        display: none;
    }
    .mobile-admin{
        margin-top: 0 ;
    }
    button.mobile-admin{
        margin-top: 0 ;
    }
    .mobile-events{
        flex-direction: row;
        justify-content: space-evenly;
        margin-bottom: 10px;
        margin-top: 10px;
    }
	.product-listing-summary-image-container{
		min-height: 251px;
	}
    .product-listing-summary-image-container-2{
        min-height: 251px;
    }
    .product-listing-summary-image-container-2 .clear-left{
        padding-left: 0 ;
        margin-top: 45px;
    }
    .product-listing-summary-image-container-2 .clear-right{
        padding-right: 0 ;
        margin-top: 45px;
    }
}
/** lg **/
@media only screen
and (min-width : 992px)
and (max-width : 1200px) {
	.product-listing-summary-image-container{
		min-height: 167px;
	}
    .product-listing-summary-image-container-2{
        min-height: 167px;
    }
    .product-listing-summary-image-container-2 .clear-left{
        padding-left: 0 ;
        margin-top: 35px;
    }
    .product-listing-summary-image-container-2 .clear-right{
        padding-right: 0 ;
        margin-top: 35px;
    }
}

@media (min-width: 576px) and (max-width: 992px) {
    #main-menu .navbar-nav {
        flex-direction: row;
        width: 100%;
        justify-content: space-between;
    }
    #main-menu .navbar-nav .dropdown-menu {position: absolute;}
    #main-menu .nav-item.dropdown:last-child .dropdown-menu {
        right: 0;
        left: auto;
    }
}

/* BOOTSTRAP VALIDATION */
.was-validated .form-control:invalid+.bs-button {border-color: #dc3545;}
.was-validated .form-control:invalid+.bs-button:focus{box-shadow: 0 0 0 0.2rem rgba(220,53,69,.25);}
.was-validated .form-control:valid+.bs-button {border-color: #28a745;}
.was-validated .form-control:valid+.bs-button:focus {box-shadow: 0 0 0 0.2rem rgba(40,167,69,.25);}
