﻿
/* CSS RESET */

* {
    margin: 0;
    outline: none;
    padding: 0;
    text-decoration: none;
    box-sizing: border-box;
}

html {
    margin: 0 !important;
    -webkit-text-size-adjust: none;
}

ol, ul {
    list-style: none;
}

a img {
    border: none;
}

a:active {
    outline: none;
}

button::-moz-focus-inner,
input[type="button"]::-moz-focus-inner,
input[type="submit"]::-moz-focus-inner,
input[type="reset"]::-moz-focus-inner,
input[type="file"] > input[type="button"]::-moz-focus-inner {
    margin: 0;
    border: 0;
    padding: 0;
}

input[type="button"],
input[type="submit"],
input[type="reset"],
input[type="number"],
input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
textarea, button, select {
    min-width: 0;
    border-radius: 0;
}

input[type="button"],
input[type="submit"],
input[type="reset"] {
    -webkit-appearance: none;
}

input::-moz-placeholder,
textarea::-moz-placeholder {
    opacity: 1;
}

input:focus::-webkit-input-placeholder,
textarea:focus::-webkit-input-placeholder {
    color: transparent;
}

input:focus::placeholder,
textarea:focus::placeholder {
    color: transparent;
}

input:-webkit-autofill {
    -webkit-box-shadow: inset 0 0 0 1000px #fff;
    -webkit-transition-delay: 9999s;
}

select:disabled {
    color: inherit;
}

script {
    display: none !important;
}


/* FONT FACES */


@font-face {
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/poppins/v15/pxiEyp8kv8JHgFVrJJnecmNE.woff2) format('woff2'); /* latin-ext */
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/poppins/v15/pxiByp8kv8JHgFVrLEj6Z1JlFc-K.woff2) format('woff2'); /* latin-ext */
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/poppins/v15/pxiEyp8kv8JHgFVrJJfecg.woff2) format('woff2'); /* latin */
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/poppins/v15/pxiByp8kv8JHgFVrLEj6Z1xlFQ.woff2) format('woff2'); /* latin */
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'DM Serif Display';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/dmserifdisplay/v5/-nFnOHM81r4j6k0gjAW3mujVU2B2G_5x0ujy.woff2) format('woff2'); /* latin-ext */
    unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: 'DM Serif Display';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/dmserifdisplay/v5/-nFnOHM81r4j6k0gjAW3mujVU2B2G_Bx0g.woff2) format('woff2'); /* latin */
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'voyage-icons';
    src: url('../fonts/voyage.woff') format('woff'), url('../fonts/voyage.svg#voyage') format('svg');
    font-weight: normal;
    font-style: normal;
}

*:before, *:after {
    font-family: 'voyage-icons';
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    box-sizing: border-box;
}


/* ANIMATION */


@keyframes fadein {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes loader {
    0% {
        transform: scale(0.1);
        opacity: 1;
    }

    70% {
        transform: scale(1);
        opacity: 0.7;
    }

    100% {
        opacity: 0.0;
    }
}


/* GLOBAL STYLES */


html {
    overflow-x: hidden;
}

body {
    background-color: #fff;
    font-family: 'Poppins', sans-serif;
    font-size: 13px;
    font-weight: 400;
    color: #000;
}

h1, h2 {
    font-weight: 600;
}

table {
    width: 100%;
    border-collapse: collapse;
}

p {
    line-height: 24px;
    color: #888;
}

a {
    color: inherit;
    transition: 0.2s ease;
    cursor: pointer;
}

p a {
    text-decoration: underline;
    color: #000;
}

strong {
    font-weight: 600;
}

p strong, p b {
    color: #444;
}

p + p {
    margin-top: 20px;
}

img {
    max-width: 100%;
}

input[type="text"],
input[type="password"],
input[type="number"],
input[type="email"],
input[type="tel"],
textarea, select {
    height: 40px;
    border: 1px solid #ddd;
    padding: 0px 10px 0px 10px;
    vertical-align: middle;
    font-family: 'Poppins', sans-serif;
    font-size: 13px;
}

textarea {
    min-height: 180px;
    padding: 15px;
}

select {
    min-width: 60px;
    max-width: 100%;
    background: url('../img/arrow-select1.svg') right 15px center no-repeat;
    background-size: 7px;
    padding: 0 25px 0 15px; /*not cross-browser consistent*/
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

    select::-ms-expand {
        display: none;
    }

    input[type="text"]:focus,
    input[type="password"]:focus,
    input[type="number"]:focus,
    input[type="email"]:focus,
    input[type="tel"]:focus,
    textarea:focus, select:focus {
        border-color: #ccc;
    }

input[type="button"],
input[type="submit"],
button {
    border: none;
    background-color: transparent;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    white-space: nowrap;
    transition: 0.2s ease;
    cursor: pointer;
}

input[type="radio"],
input[type="checkbox"],
label, label + * {
    vertical-align: middle;
}

    input[type="radio"] + span,
    input[type="checkbox"] + span {
        vertical-align: middle;
    }
/*custom checkboxes and radio buttons*/
input[type="radio"],
input[type="checkbox"] {
    margin-right: -19px;
    opacity: 0;
    z-index: 999;
    position: relative;
}

    input[type="radio"] + label,
    input[type="checkbox"] ~ label {
        position: relative;
        padding-top: 1px; /*cross-browser consistency*/
        padding-left: 23px;
        cursor: pointer;
    }

        input[type="radio"] + label:before,
        input[type="checkbox"] ~ label:before {
            content: "";
            position: absolute;
            top: 0;
            bottom: 0;
            left: 0;
            width: 15px;
            height: 15px;
            margin: auto;
            border: 1px solid #ccc;
            box-shadow: inset 0 0 0 2px #fff;
            background-color: #fff;
        }

    input[type="radio"]:checked + label,
    input[type="checkbox"]:checked ~ label {
        color: #000;
    }

        input[type="radio"]:checked + label:before {
            background-color: #000;
        }

        input[type="checkbox"]:checked ~ label:before {
            content: "\e918";
            font-size: 10px;
            padding: 2px;
        }

.date-picker-wrapper {
    display: flex;
    column-gap: 10px;
}

    .date-picker-wrapper select {
        flex: 1 0 0;
        min-width: 0 !important;
    }

html:not(.html-account-page)
.master-column-wrapper {
    display: flex;
    flex-flow: column-reverse;
}

.home-page .page-body > div {
    margin: 50px 0;
}

.home-page .slider-wrapper {
    padding-top: 15px;
}

.center-1, .center-2 {
    margin: 0 0 80px;
    padding: 0 2.5%;
}

.side-2 {
    margin: 0 0 80px;
}

.page {
    min-height: 200px;
    text-align: center;
}

.page-title {
    padding: 15px 0;
    text-align: center;
}

    .page-title h1 {
        font-family: 'DM Serif Display', serif;
        font-size: 28px;
        font-weight: 400;
    }

.product-grid .title,
.topic-block .title,
.home-page .title {
    padding: 15px 0;
    text-align: center;
    font-family: 'DM Serif Display', serif;
    font-size: 28px;
    text-transform: capitalize;
}

    .product-grid .title strong,
    .home-page .title strong {
        font-weight: 400;
    }

.home-page-polls {
    text-align: center;
}

.mfp-bg, .mfp-wrap {
    z-index: 1090 !important;
}

li.total-summary {
    display: none !important;
}

.payment-logo {
    display: none;
}

.plus-button {
    display: none;
}

.buttons {
    text-align: center;
}

.link-rss {
    display: none;
}

.no-data {
    text-align: center;
}

.noscript {
    background-color: #ff9;
    padding: 10px 15px;
    text-align: center;
}

.product-rating-box,
.product-review-box {
    display: flex;
    align-items: center;
}

    .product-rating-box .rating,
    .product-review-box .rating {
        position: relative;
        height: 15px;
        font-size: 0;
        letter-spacing: 1px;
    }

        .product-rating-box .rating:before,
        .product-review-box .rating:before {
            content: "\e90a \e90a \e90a \e90a \e90a";
            position: absolute;
            left: 0;
            color: #ccc;
            font-size: 14px;
        }

        .product-rating-box .rating div,
        .product-review-box .rating div {
            position: relative;
            overflow: hidden;
            background-color: #fff;
        }

            .product-rating-box .rating div:before,
            .product-review-box .rating div:before {
                content: "\e909 \e909 \e909 \e909 \e909";
                font-size: 14px;
                color: #e43d51;
            }

.qty-wrapper {
    display: inline-block;
    position: relative;
    height: 50px;
    border: 1px solid #ddd;
}

    .qty-wrapper.focus {
        border-color: #ccc;
    }

    .qty-wrapper .increase,
    .qty-wrapper .decrease {
        display: flex;
        align-items: center;
        position: absolute;
        bottom: 2px;
        width: 20px;
        height: 44px;
        background-color: #f3f3f3;
        padding: 6px;
        font-size: 0;
        cursor: pointer;
    }

    .qty-wrapper .increase {
        right: 2px;
    }

    .qty-wrapper .decrease {
        left: 2px;
    }

        .qty-wrapper .increase:after,
        .qty-wrapper .decrease:before {
            font-size: 8px;
            font-weight: bold;
            color: #666;
        }

    .qty-wrapper .increase:after {
        content: "\e917";
    }

    .qty-wrapper .decrease:before {
        content: "\e916";
    }

    .qty-wrapper .qty-input {
        width: 40px;
        height: 100%;
        border: none;
        margin: 0 22px;
        padding: 0;
        text-align: center;
        font-size: 14px;
    }

    .qty-wrapper .qty-dropdown {
        min-width: 60px;
        height: 100%;
        border: none;
        text-align: left;
        font-size: 14px;
    }

.category-description ul,
.manufacturer-description ul,
.vendor-description ul,
.full-description ul,
.topic-html-content ul,
.topic-page ul, .custom-tab ul,
.post-body ul, .news-body ul {
    margin: 20px 0;
    padding: 0 0 0 36px;
    list-style: disc;
}

.category-description ol,
.manufacturer-description ol,
.vendor-description ol,
.full-description ol,
.topic-html-content ol,
.topic-page ol, .custom-tab ol,
.post-body ol, .news-body ol {
    margin: 20px 0;
    padding: 0 0 0 36px;
    list-style: decimal;
}

.category-description td,
.manufacturer-description td,
.vendor-description td,
.full-description td,
.topic-html-content td,
.topic-page td, .custom-tab td,
.post-body td, .news-body td {
    border: 1px solid #ebebeb;
    padding: 10px 20px;
}

.category-description p,
.manufacturer-description p,
.vendor-description p,
.full-description p,
.topic-page p, .custom-tab p,
.topic-html-content p {
    word-wrap: break-word;
}

.post-body p ~ p,
.news-body p ~ p {
    margin-top: 20px;
}

.post-body p ~ table,
.news-body p ~ table {
    margin-top: 20px;
}


/* GLOBAL FORMS */


.fieldset .title,
.section .title {
    margin: 0 0 10px;
    text-align: center;
    font-size: 15px;
}

.form-fields {
    position: relative;
}

.inputs {
    position: relative;
    width: 600px;
    max-width: 100%;
    margin: 0 auto 25px;
    text-align: center;
    font-size: 0;
}

    .inputs:after {
        content: "";
        display: block;
        clear: both;
    }

    .inputs label {
        display: block;
        width: 100%;
        margin: 0 0 5px;
        text-align: left;
        font-size: 13px; /*reset zeroing*/
        color: #888;
    }

    .inputs input[type="text"],
    .inputs input[type="password"],
    .inputs input[type="email"],
    .inputs input[type="tel"],
    .inputs select, .inputs textarea {
        width: 100%;
        max-width: 100%;
        vertical-align: middle;
    }

.custom-attributes > label {
    color: #000;
}

.inputs .option-list {
    text-align: left;
}

    .inputs .option-list li {
        margin: 15px 0 0;
    }

    .inputs .option-list label {
        display: inline;
        width: auto;
        margin-left: 5px;
    }

.required {
    font-size: 18px;
    line-height: 0;
    font-weight: 400;
    color: #e31d31;
}

.inputs .required {
    position: absolute;
    margin: 14px 0 0 -14px;
}

.message-error,
.field-validation-error,
.username-not-available-status,
.poll-vote-error, .password-error {
    display: block;
    text-align: center;
    font-size: 11px;
    color: #e31d31;
}

.field-validation-valid,
.username-available-status,
.new-comment .result {
    display: block;
    text-align: center;
    font-size: 11px;
    color: #22b482;
}

.captcha-box {
    margin: 0 0 25px;
    text-align: center;
    line-height: 0; /*firefox line-height bug fix*/
}

    .captcha-box > div {
        display: inline-block;
    }

    .captcha-box iframe {
        margin: 0;
    }

    .captcha-box input {
        height: auto;
    }

.account-page .message-error {
    margin: 0 0 10px;
}

.account-button {
    min-width: 240px;
    height: 50px;
    background-color: #000;
    padding: 0 20px;
    font-size: 14px;
    color: #fff;
}

    .account-button:hover {
        background-color: #e43d51;
    }


/* GLOBAL TABLES */


.cart, .data-table,
.compare-products-table,
.forums-table-section table {
    margin: 0 0 30px;
    overflow-x: auto;
    display: inline-table;
}

    .cart th, .data-table th,
    .forums-table-section th {
        /*padding: 10px;
        white-space: initial !important;*/
        border-bottom: 1px solid #eee;
        padding: 10px 0px 10px;
        font-weight: 400;
        color: #888;
    }

    .cart tr, .data-table tr,
    .compare-products-table tr,
    .forums-table-section tr {
        border-bottom: 1px solid #eee;
    }

    .cart td, .data-table td, .compare-products-table td, .forums-table-section td {
        min-width: 50px;
        padding: 10px;
    }

.account-page .data-table td {
    padding: 8px !important;
}

.cart a:hover, .data-table a:hover,
.compare-products-table a:hover,
.forums-table-section a:hover {
    text-decoration: underline;
}

.cart .product,
.data-table .product,
.data-table .message,
.data-table .info,
.data-table .name,
.data-table .note {
    text-align: left;
}

.cart .remove-from-cart,
.cart .add-to-cart,
.data-table .select-boxes,
.data-table .order {
    position: relative;
    text-align: center;
}

    .cart .remove-from-cart input {
        position: absolute;
    }

    .cart .remove-from-cart button {
        position: relative;
        font-size: 12px;
        text-decoration: underline;
    }

    .cart .add-to-cart label {
        font-size: 0;
    }

.cart td.product-picture {
    font-size: 0;
}

.cart .product-picture a {
    display: inline-block;
    border: 1px solid #eee;
}

.cart .product-picture img {
    min-width: 80px;
}

.cart .attributes,
.cart .rental-info {
    margin: 5px 0 0;
    font-size: 12px;
    color: #888;
}

.cart .edit-item {
    text-decoration: underline;
    font-size: 12px;
    color: #888;
}

    .cart .edit-item:hover {
        color: #000;
    }

.cart .message-error {
    margin: 5px 0 0;
    text-align: left;
}

.cart .unit-price {
    white-space: nowrap;
    color: #666;
}

.cart .quantity .qty-input {
    font-size: 12px;
}

.cart .product-subtotal {
    white-space: nowrap;
}

.cart .discount label {
    white-space: nowrap;
}

.discount-additional-info {
    font-size: 12px;
    color: #888;
}


/* RESPONSIVE TABLES */


table:not(.breakpoint) .footable-first-column {
    min-width: 0;
    padding: 0;
    font-size: 0;
}

table:not(.breakpoint) .footable-toggle {
    display: none;
}

.breakpoint .footable-first-column {
    position: relative;
}

.breakpoint .footable-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #fff;
    cursor: pointer;
}

.footable-toggle:after {
    content: "\e917";
    font-size: 10px;
}

.footable-detail-show
.footable-toggle:after {
    content: "\e916";
    font-size: 10px;
}

.footable-row-detail {
    text-align: left;
}

.footable-row-detail-row {
    display: table-row;
}

.footable-row-detail-name,
.footable-row-detail-value {
    display: table-cell;
    padding: 5px 10px;
}


/* NOTIFICATIONS & POPUPS */


.bar-notification {
    display: none;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1040;
    box-shadow: 0 0 20px rgba(0,0,0,.15);
    padding: 20px;
    opacity: 0.95;
}

    .bar-notification.success {
        background-color: #22b482;
    }

    .bar-notification.warning {
        background-color: #e4903d;
    }

    .bar-notification.error {
        background-color: #e31d31;
    }

    .bar-notification .content {
        padding-right: 30px;
        text-align: left;
        color: #fff;
    }

        .bar-notification .content a {
            text-decoration: underline;
            color: inherit;
        }

    .bar-notification .close {
        position: absolute;
        top: 0;
        bottom: 0;
        right: 8px;
        width: 40px;
        height: 40px;
        margin: auto;
        transition: 0.6s ease;
        cursor: pointer;
    }

        .bar-notification .close:after {
            content: "\e919";
            position: absolute;
            top: 0;
            right: 0;
            bottom: 0;
            left: 0;
            width: 14px;
            height: 14px;
            margin: auto;
            font-size: 14px;
            color: #fff;
        }

        .bar-notification .close:hover {
            transform: rotate(-180deg);
        }

.ajax-loading-block-window {
     position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 9999;
    height: 50px !important;
    width: 50px !important;
    margin: auto !important;
    border-radius: 100%;
    border: 2px solid #e43d51;
    animation: loader 1s 0s infinite cubic-bezier(.21,.53,.56,.8);

 /*   position: fixed;
    right: 50%;
    left: 50%;
    top: 50%;
    width: 100%;
    height: 100%;
    background: rgb(0 0 0 / 50%) url(../img/loading.gif) center no-repeat;
    transform: translate(-50%, -50%);
    bottom: 0px;
    z-index: 9999;*/
}

.ui-dialog {
    position: absolute !important;
    z-index: 1050;
    width: 500px !important;
    max-width: 95%;
    box-shadow: 0 0 20px rgba(0,0,0,0.15);
    background-color: #fff;
    padding: 15px 20px;
}

    .ui-dialog:before {
        content: "";
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: -1;
        background-color: rgba(0,0,0,.5);
    }

    .ui-dialog:after {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: -1;
        box-shadow: 0 0 20px rgba(0,0,0,0.15);
        background-color: #fff;
    }

.ui-dialog-titlebar {
    padding: 10px;
    font-size: 15px;
    font-weight: 600;
}

    .ui-dialog-titlebar button {
        position: absolute;
        top: 0;
        right: 0;
        width: 40px;
        height: 40px;
        overflow: hidden;
        border: 1px solid #eee;
        font-size: 0;
    }

        .ui-dialog-titlebar button:after {
            content: "\e919";
            font-size: 14px;
        }

        .ui-dialog-titlebar button:hover {
            color: #e43d51;
        }

.ui-dialog-content {
    height: auto !important;
    padding: 10px;
}

    .ui-dialog-content p {
        color: #000;
    }

    .ui-dialog-content .page {
        min-height: 0;
    }

    .ui-dialog-content .page-title {
        display: none !important;
    }

    .ui-dialog-content .page-body {
        line-height: 24px;
    }

    .ui-dialog-content .tooltip {
        margin-bottom: 15px;
    }

    .ui-dialog-content button {
        border: 1px solid #000;
        padding: 10px 20px;
        font-size: 13px;
    }

        .ui-dialog-content button:hover {
            border-color: #e43d51;
            color: #e43d51;
        }

.eu-cookie-bar-notification {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1050;
    box-shadow: 0 0 20px rgba(0,0,0,.15);
    background-color: #fff;
    padding: 20px;
}

    .eu-cookie-bar-notification .content {
        display: flex;
        flex-flow: column;
        align-items: center;
    }

    .eu-cookie-bar-notification .buttons-more {
        display: flex;
        column-gap: 5px;
    }

    .eu-cookie-bar-notification .ok-button,
    .eu-cookie-bar-notification .learn-more {
        min-width: 120px;
        padding: 10px 20px;
        font-size: 14px;
        font-weight: 600;
    }

    .eu-cookie-bar-notification .ok-button {
        background-color: #000;
        color: #fff;
    }

        .eu-cookie-bar-notification .ok-button:hover {
            background-color: #e43d51;
        }

    .eu-cookie-bar-notification .learn-more {
        border: 1px solid #000;
        white-space: nowrap;
    }

        .eu-cookie-bar-notification .learn-more:hover {
            border-color: #e43d51;
            color: #e43d51;
        }


/* TABULATION */


.ui-tabs {
    border: 1px solid #eee;
    padding: 25px 3%;
}

    .ui-tabs .ui-tabs-nav {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        row-gap: 10px;
        margin: 0 0 20px;
    }

        .ui-tabs .ui-tabs-nav li {
            display: flex;
            align-items: center;
            font-size: 14px;
        }

.ui-tabs-nav li + li:before {
    content: "";
    display: block;
    width: 3px;
    height: 3px;
    margin: 0 10px;
    border-radius: 50%;
    background-color: #333;
}

.ui-tabs .ui-tabs-nav a {
    display: block;
    white-space: nowrap;
}

.ui-tabs .ui-tabs-selected a,
.ui-tabs .ui-tabs-active a {
    position: relative;
    color: #e43d51;
}

.ui-tabs-selected a:after,
.ui-tabs-active a:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 1px;
    background-color: #e43d51;
}

.ui-tabs .message-error li {
    font-size: 11px;
}

.ui-tabs .ui-tabs-hide {
    display: none;
}


/* HEADER */


.header-upper {
    display: flex;
    justify-content: space-between;
    background-color: #f3f3f3;
    padding: 0 4%;
    text-align: center;
    color: #444;
}

.header-selectors-wrapper,
.header-links-wrapper,
.header-text-wrapper {
    margin: auto 0; /*prepare for flex*/
}

.header-selectors {
    display: flex;
    column-gap: 20px;
    white-space: nowrap;
}

    .header-selectors select {
        min-width: 0;
        border: none;
        height: 37px; /*odd value*/
        background: url('../img/arrow-select2.svg') right center no-repeat;
        background-size: 10px;
        padding: 0 15px 0 0; /*not cross-browser consistent*/
        box-sizing: content-box; /*workaround*/
        font-size: 12px;
        text-transform: uppercase;
        color: #444;
    }

.language-list {
    margin-left: -8px;
    font-size: 0;
}

    .language-list li {
        display: inline-block;
        margin: 0 1px;
    }

    .language-list a {
        display: block;
        position: relative;
        width: 32px;
        height: 32px;
    }

    .language-list img {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        margin: auto;
    }

.admin-header-links {
    white-space: nowrap;
}

    .admin-header-links a {
        display: inline-block;
        padding: 7px 0;
        font-size: 12px;
    }

        .admin-header-links a + a {
            display: inline-block;
            margin-left: 20px;
        }

.impersonated.session {
    padding-top: 24px;
}

.impersonated .impersonate {
    display: flex;
    justify-content: center;
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    z-index: 1060;
    background-color: #000;
    padding: 2px 0;
    color: #fff;
}

    .impersonated .impersonate span {
        display: inline-block;
        max-width: calc(100% - 40px);
        margin: auto 5px;
        overflow-x: hidden;
        text-overflow: ellipsis;
    }

.finish-impersonation {
    margin: auto 5px !important;
    background-color: #000;
    padding: 0 !important;
    font-size: 0 !important;
}

    .finish-impersonation:after {
        content: "\e919";
        font-size: 16px;
    }

.impersonated .admin-header-links {
    flex-basis: 0 !important;
}

.header-lower {
    border-bottom: 1px solid #eee;
    background-color: #fff;
}

.header-logo {
    text-align: center;
    font-size: 0;
}

    .header-logo.mobile {
        flex-grow: 1;
        display: flex;
        padding: 12px 0;
    }

    .header-logo.desktop {
        display: none;
    }

    .header-logo a {
        display: block;
        max-width: 100%;
        margin: auto;
    }

        .header-logo a img {
            display: block;
            max-width: 100%;
        }

.search-box form {
    position: relative;
    width: 260px;
    border-bottom: 1px solid #eee;
}

.search-box .search-box-text {
    display: block;
    width: calc(100% - 30px);
    height: 40px;
    border: none;
    background: none;
    padding: 1px 0 0 5px;
    font-size: 12px;
}

.search-box-text::placeholder {
    color: #aaa;
}

.search-box .search-box-button {
    position: absolute;
    top: 0;
    right: 0;
    width: 40px;
    height: 40px;
    font-size: 0;
    padding: 0px 10px;
}

    .search-box .search-box-button:after {
        content: "\e903";
        font-size: 20px;
    }

.ui-helper-hidden-accessible {
    display: none !important;
}

.search-box .ui-autocomplete {
    width: 100% !important;
    max-width: 100%;
    overflow: hidden;
    text-align: left;
}

.ui-autocomplete li:first-child {
    padding-top: 10px;
}

.ui-autocomplete li:last-child {
    padding-bottom: 10px;
}

.ui-autocomplete .ui-menu-item a {
    display: flex;
    width: 100%;
    padding: 5px 20px;
}

.ui-autocomplete .ui-state-active,
.ui-autocomplete .ui-state-focus {
    background-color: #f6f6f6;
}

.ui-autocomplete .ui-menu-item img {
    margin-right: 10px;
}

.flyout-cart-wrapper {
    display: none;
}

.mini-shopping-cart .count {
    display: none;
}

.mini-shopping-cart .item {
    display: flex;
    margin: 0 0 10px;
}

.mini-shopping-cart .picture {
    flex: 0 1 100px;
    width: 100px;
    font-size: 0;
}

    .mini-shopping-cart .picture a {
        display: inline-block;
    }

.mini-shopping-cart .product {
    flex: 1 0 0;
    display: flex;
    flex-flow: column;
    padding-left: 10px;
    font-size: 12px;
}

.mini-shopping-cart .name {
    font-size: 13px;
}

.mini-shopping-cart .attributes {
    margin: 5px 0 0;
    color: #888;
}

.mini-shopping-cart .quantity {
    margin: 5px 0;
    color: #888;
}

.mini-shopping-cart .price {
    font-weight: 600;
}

.mini-shopping-cart .remove {
    flex: 1 0 auto;
    align-self: flex-end;
    display: flex;
    font-size: 11px;
    text-decoration: underline;
    color: #888;
}

.mini-shopping-cart .remove-btn {
    align-self: flex-end;
    transition: 0.2s ease;
    cursor: pointer;
}

    .mini-shopping-cart .remove-btn:hover {
        color: #000;
    }

.mini-shopping-cart .totals {
    display: flex;
    justify-content: space-between;
    margin: 0 -10px;
    border-top: 1px solid #eee;
    padding: 20px 15px;
    font-size: 14px;
}

    .mini-shopping-cart .totals strong {
        font-weight: 600;
        color: #e43d51;
    }

.mini-shopping-cart .buttons {
    padding: 0 5px;
    font-size: 0;
}

.mini-shopping-cart button {
    width: 48.5%;
    height: 45px;
    background-color: #000;
    padding: 0 15px;
    font-size: 14px;
    color: #fff;
}

    .mini-shopping-cart button:hover {
        background-color: #e43d51;
    }

    .mini-shopping-cart button + button {
        margin-left: 3%;
    }

    .mini-shopping-cart button:only-child {
        width: 100%;
    }

.mini-shopping-cart .no-data {
    margin: 4px 0 0;
    padding: 10px;
    font-size: 12px;
    color: #888;
}


/* FOOTER */


.footer-upper {
    position: relative;
    background-color: #f3f3f3;
    text-align: center;
}

    .footer-upper:before,
    .footer-upper:after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        background-color: #fff;
    }

    .footer-upper:before {
        top: 0;
        height: 30px;
    }

    .footer-upper:after {
        bottom: 0;
        height: 20px;
    }

.footer .newsletter {
    position: relative;
    z-index: 1;
    background-color: #222;
    padding: 50px 20px;
    color: #fff;
}

.newsletter .title strong {
    display: block;
    font-family: 'DM Serif Display', serif;
    font-size: 32px;
    font-weight: 400;
    letter-spacing: 0.5px;
}

.newsletter .title span {
    display: block;
    margin-bottom: 20px;
}

.footer .newsletter-form {
    display: flex;
    column-gap: 1px;
    width: 340px;
    max-width: 100%;
    margin: auto;
    border: 1px solid #ddd;
    background-color: #ddd;
}

.footer .newsletter-subscribe-text {
    flex-grow: 1;
    height: 40px;
    border: none !important;
    background-color: #fff;
}

.footer .newsletter-subscribe-button {
    height: 40px;
    background-color: #fff;
    padding: 0 15px;
    font-size: 13px;
    text-decoration: underline;
    color: #e43d51;
}

.footer .subscribe-options {
    margin-top: 10px;
}

    .footer .subscribe-options span {
        margin: 0 10px;
    }

    .footer .subscribe-options label {
        padding-left: 20px;
        font-size: 12px;
        color: #fff !important;
    }

.subscribe-options label:before {
    width: 13px !important;
    height: 13px !important;
    border: none !important;
    opacity: 0.2;
}

.footer input:checked ~ label:before {
    background-color: #e43d51;
    opacity: 1;
}

.footer .newsletter-validation,
.footer .newsletter-result {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 20px;
    padding: 0 20px;
    font-size: 12px;
}

.newsletter-validation .please-wait {
    display: none !important;
}

.newsletter-validation .message {
    color: #fff !important;
}

.footer-middle {
    padding: 40px 0;
    text-align: center;
}

.footer-block {
    text-align: left;
}

    .footer-block .title {
        font-size: 15px;
    }

    .footer-block ul {
        display: none;
    }

    .footer-block li {
        padding: 5px 0;
    }

    .footer-block a {
        color: #888;
    }

        .footer-block a:hover {
            color: #e43d51;
        }

.social-networks {
    margin-top: 40px;
    text-align: center;
    font-size: 0;
}

    .social-networks li {
        display: inline-flex;
        position: relative;
        width: 40px;
        height: 40px;
        margin: 0 3px;
        align-items: center;
        justify-content: center;
        transition: 0.2s ease;
    }

        .social-networks li:hover {
            background-color: #e43d51;
        }

        .social-networks li:before {
            font-size: 20px;
            transition: 0.2s ease;
        }

        .social-networks li:hover:before {
            color: #fff;
        }

    .social-networks .facebook:before {
        content: "\e920";
        position: relative;
        right: -1px;
    }

    .social-networks .twitter:before {
        content: "\e921";
        font-size: 22px;
    }

    .social-networks .pinterest:before {
        content: "\e923";
    }

    .social-networks .instagram:before {
        content: "\e922";
    }

    .social-networks .youtube:before {
        content: "\e924";
    }

    .social-networks .vimeo:before {
        content: "\e936";
        font-size: 18px;
    }

    .social-networks li:after {
        content: "";
        position: absolute;
        top: 3px;
        right: -3px;
        bottom: -3px;
        left: 3px;
        z-index: -1;
        opacity: 0;
        border: 1px solid #e43d51;
        transition: 0.5s ease;
    }

    .social-networks li:hover:after {
        opacity: 1;
    }

    .social-networks .link {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
    }

.footer-lower {
    background-color: #f3f3f3;
    padding: 25px 15px;
    text-align: center;
    font-size: 11px;
    color: #888;
}

.footer-text {
    padding: 5px 0;
}

    .footer-text img {
        display: block;
        margin: 5px auto;
    }

.footer-powered-by a,
.footer-designed-by a {
    display: inline-block;
    text-decoration: underline;
    color: #000;
}

.theme-selector {
    margin: 15px 0 0;
}

    .theme-selector select {
        width: 200px;
        background-color: #fff;
    }


/* SIDEBAR COLUMN */


.block .title {
    font-size: 15px;
    cursor: pointer;
}

    .block .title strong {
        display: block;
        font-weight: 400;
    }

.block .listbox {
    display: none;
    font-size: 12px;
    color: #000;
}

    .block .listbox:after {
        content: "";
        display: block;
        clear: both;
    }

.block .list a {
    display: inline-block;
    padding: 5px 0;
}

.block .listbox a:hover {
    color: #000;
}

.block .active > a {
    color: #000;
}

.block .list img {
    display: none;
}

.block .sublist {
    padding-left: 15px;
}

.block .view-all a {
    display: inline-block;
    padding: 5px 0 1px;
    text-decoration: underline;
    color: #000;
}

.block .tags ul,
.block ul.tags {
    display: flex;
    flex-wrap: wrap;
    column-gap: 15px;
}

.block .tags a,
.product-tags-all-page a {
    display: block;
    padding: 5px 0;
    font-size: 12px !important;
    text-decoration: underline;
}

.block .tags ~ .view-all {
    display: none;
}

.block .accordion {
    position: relative;
}

    .block .accordion > a {
        position: relative;
        z-index: 1;
    }

    .block .accordion > ul:after {
        content: "\e917";
        position: absolute;
        top: 0;
        right: 0;
        width: 100%;
        padding: 10px 0;
        text-align: right;
        font-size: 8px;
        cursor: pointer;
        color: #000;
    }

.block .expanded > ul:after {
    content: "\e916";
}

.block .collapsed > ul:after {
    content: "\e917";
}

.block .accordion:not(.active) li {
    display: none;
}

.filter-title {
    margin-bottom: 12px;
    font-size: 15px;
    color: #000;
}

    .filter-title strong {
        display: block;
        font-weight: 400;
    }

.filters .item {
    margin: 6px 0 0;
}

.filters input {
    margin-right: -16px;
}

.filters label {
    display: inline-block;
}

.filters .name strong {
    font-weight: 400;
}

.selected-price-range {
    margin: -12px 0 6px;
    overflow: hidden;
    font-weight: 600;
    color: #e43d51;
}

    .selected-price-range .from {
        float: left;
    }

    .selected-price-range .to {
        float: right;
    }

.filters .ui-slider {
    position: relative;
    width: auto;
    height: 8px;
    margin: 0 3px 12px;
    background-color: #f3f3f3;
}

.filters .ui-slider-range {
    position: absolute;
    height: 8px;
    background-color: #ccc;
}

.filters .ui-slider-handle {
    position: absolute;
    top: -5px;
    width: 12px;
    height: 18px;
    margin-left: -6px;
    border: 2px solid #fff;
    background-color: #000;
    cursor: pointer;
}

.filters .attribute-squares {
    font-size: 12px; /*reset zeroing*/
}

:checked + .attribute-squares:before {
    z-index: 1;
    background: none;
    border: 1px solid #fff;
    box-shadow: 0 0 0 1px #000;
    font-size: 0 !important;
}

.filters .attribute-square {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0; /**/
    width: 15px;
    height: 15px;
    margin: auto;
    border-color: #222;
}

.poll strong {
    display: block;
    margin: 0 0 10px;
}

.poll-options,
.poll-results {
    margin: 0 0 15px;
}

    .poll-options li,
    .poll-results li {
        display: inline-block;
        margin: 5px 5px;
    }

.poll .buttons button {
    text-decoration: underline;
}

.poll-total-votes {
    display: block;
    margin: 10px 0 0;
    font-weight: 600;
}

.poll-vote-error {
    margin: 10px 0 0;
}


/* CATALOG PAGES */


.breadcrumb {
    border-bottom: 1px solid #eee;
    padding: 20px 5%;
    text-align: center;
}

    .breadcrumb ul {
        font-size: 0;
        color: #888;
    }

    .breadcrumb li {
        display: inline-block;
    }

    .breadcrumb a,
    .breadcrumb strong,
    .breadcrumb .delimiter {
        display: inline-block;
        margin: 0 3px;
        font-size: 12px;
        font-weight: 400;
    }

    .breadcrumb a {
        color: #000;
    }

        .breadcrumb a:hover {
            color: #e43d51;
        }

.category-description,
.manufacturer-description,
.vendor-description {
    margin: 0 0 30px;
}

.contact-vendor {
    margin: 0 0 30px;
}

.contact-vendor-button {
    text-decoration: underline;
}

.product-selectors {
    display: flex;
    column-gap: 2%;
    border-top: 1px solid #eee;
    padding: 20px 0;
}

    .product-selectors span {
        margin-right: 5px;
        font-size: 12px;
        white-space: nowrap;
    }

    .product-selectors select {
        flex-grow: 1;
        border: none;
        height: 40px;
        background: #f3f3f3 url(../img/arrow-select2.svg) right 8px center no-repeat;
        background-size: 10px;
        padding: 0 25px 0 10px; /*not cross-browser consistent*/
        box-sizing: content-box; /*workaround*/
        cursor: pointer;
    }

        .product-selectors select + span {
            display: none !important;
        }

.product-viewmode {
    display: none;
}

.product-sorting,
.product-page-size {
    display: flex;
    align-items: center;
    width: 50%;
    color: #888;
}

.category-grid .item-grid,
.manufacturer-grid .item-grid,
.vendor-grid .item-grid,
.product-grid .item-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 25px 2%;
}

.item-box {
    display: flex;
    flex-flow: column;
    text-align: left;
}

    .item-box .product-item {
        display: flex;
        flex-flow: column;
        position: relative;
        height: 100%;
    }

    .item-box .picture {
        position: relative;
        margin-bottom: 15px;
        border: 1px solid #eee;
    }

.item-grid .item-box .picture {
    display: none;
}

.item-grid .item-box {
    min-height: 110px;
    background: #ffffff;
    padding: 10px;
    box-shadow: 0 0 10px #0000001a;
}

.item-box .picture a {
    display: block;
    position: relative;
    overflow: hidden;
}

    .item-box .picture a:before {
        content: "";
        display: block;
        padding-top: 130%;
    }

.item-box .picture img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    max-width: 100%;
    margin: auto;
}

.item-box .navigation {
    transition: 0.5s ease;
    opacity: 0;
}

.item-box:hover .navigation {
    opacity: 1;
}

.item-box .color-attributes {
    display: none;
    position: absolute;
    bottom: 7px;
    left: 10px;
}

.item-box .attribute-square {
    width: 15px;
    height: 15px;
    margin: 0 -1px;
    border-width: 1px;
    border-radius: 50%;
}

.item-box .details {
    flex-grow: 1;
    display: flex;
    flex-flow: column;
}

.item-box .product-title {
    flex-grow: 1;
    font-size: 13px;
    font-weight: 400;
    color: #888;
}

    .item-box .product-title a {
        display: block;
    }

.item-box .sku { /**/
    margin-top: 5px;
}

.item-box .product-rating-box {
    display: none;
}

.item-box .description {
    display: none;
    font-size: 12px;
    color: #888;
}

.item-box .add-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 10px;
}

.item-box .old-price {
    color: #999;
    text-decoration: line-through;
}

.item-box .actual-price {
    font-weight: 600;
}

.item-box .old-price + .actual-price {
    color: #e43d51;
}

.item-box .tax-shipping-info {
    font-size: 11px;
}

.item-box .base-price-pangv {
    margin-top: 5px;
}

.item-box .product-box-add-to-cart-button {
    position: relative;
    top: -1px; /*v-align*/
    text-decoration: underline;
    white-space: nowrap;
}

    .item-box .product-box-add-to-cart-button:hover {
        color: #e43d51;
    }

.item-box .add-to-wishlist-button,
.item-box .add-to-compare-list-button {
    font-size: 0;
}

    .item-box .add-to-wishlist-button:before {
        content: "\e906";
        font-size: 18px;
    }

    .item-box .add-to-compare-list-button:before {
        content: "\e907";
        font-size: 18px;
    }

.item-box .carousel {
    position: relative;
}

    .item-box .carousel:before {
        content: "";
        display: block;
        padding-top: 130%;
    }

    .item-box .carousel .slick-list {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        height: auto !important;
    }

.item-box .navigation .slick-prev,
.item-box .navigation .slick-next {
    display: flex;
    position: absolute;
    top: calc(50% - 20px);
    width: 36px;
    height: 40px;
    text-align: center;
    font-size: 0;
    cursor: pointer;
}

.item-box .navigation .slick-prev {
    left: 0;
}

.item-box .navigation .slick-next {
    right: 0;
}

    .item-box .navigation .slick-prev:before,
    .item-box .navigation .slick-next:after {
        margin: auto;
        font-size: 13px;
    }

.item-box .navigation .slick-prev:before {
    content: "\e90d";
}

.item-box .navigation .slick-next:after {
    content: "\e90e";
}

.home-page-category-grid .picture-wrapper {
    position: relative;
}

.home-page-category-grid .picture a:before {
    padding-top: 130%;
}

.home-page-category-grid .sub-category-list {
    display: none;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    row-gap: 20px;
    position: absolute;
    top: 7%;
    right: 8%;
    bottom: 7%;
    left: 8%;
    background-color: #fff;
    padding: 7% 8%;
    text-align: center;
    animation: fadein 0.3s
}

.category-grid .sub-category-item a:hover {
    text-decoration: underline;
    color: #e43d51;
}

.home-page-category-grid .view-more {
    border-bottom: 1px solid #e43d51;
    color: #e43d51;
}

    .home-page-category-grid .view-more span,
    .home-page-category-grid .view-all span {
        display: inline-block;
        vertical-align: middle;
        margin-right: 5px;
    }

    .home-page-category-grid .view-more:after,
    .home-page-category-grid .view-all:after {
        content: "\e910";
        display: inline-block;
        vertical-align: middle;
    }

.home-page-category-grid .text-wrapper {
    text-align: center;
}

.home-page-category-grid .category-title {
    font-size: 15px;
}

.home-page-category-grid .view-all {
    border-bottom: 1px solid #000;
    font-size: 12px;
}

    .home-page-category-grid .view-all:hover {
        border-color: #e43d51;
        color: #e43d51;
    }

.sub-category-grid {
    margin-bottom: 30px;
}

    .sub-category-grid .item-grid {
        grid-template-columns: repeat(auto-fit, 100%);
        grid-row-gap: 5px;
    }

    .sub-category-grid .item-box {
        position: relative;
        background-color: #f3f3f3;
        padding: 20px 15px;
        text-align: center;
    }

    .sub-category-grid .picture {
        display: none;
    }

    .sub-category-grid .title {
        font-size: 14px;
    }

    .sub-category-grid .number {
        font-size: 12px;
        color: #888;
    }

    .sub-category-grid .view-all {
        display: flex;
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        border: 1px solid #e43d51;
        background-color: #fff;
        transition: 0.2s ease;
        opacity: 0; /**/
    }

        .sub-category-grid .view-all a {
            margin: auto auto;
            /*transform: translateY(-2px);*/
            border-bottom: 1px solid #e43d51;
            font-size: 12px;
            color: #e43d51;
            transition: 0.2s ease;
            opacity: 0; /**/
        }

        .sub-category-grid .view-all span {
            display: inline-block;
            vertical-align: middle;
            margin-right: 5px;
        }

        .sub-category-grid .view-all a:before {
            content: "";
            position: absolute;
            top: 0;
            right: 0;
            bottom: 0;
            left: 0;
        }

        .sub-category-grid .view-all a:after {
            content: "\e910";
            display: inline-block;
            vertical-align: middle;
        }

.sub-category-item:hover .view-all,
.sub-category-item:hover .view-all a {
    opacity: 1; /**/
}

.featured-product-grid {
    margin: -20px 0 50px;
}

.product-grid .buttons .wrapper {
    display: none;
    position: absolute;
    top: 0;
    right: 0;
}

.product-grid .wrapper button {
    display: block;
    width: 36px;
    height: 28px;
    margin: 6px 0 -6px;
}

.product-grid .wrapper
.add-to-wishlist-button {
    order: -1; /**/
}

.product-grid .wrapper
.add-to-compare-list-button {
    opacity: 0;
}

.product-grid .item-box:hover
.add-to-compare-list-button {
    opacity: 1;
}

.manufacturer-item .wrapper,
.vendor-item .wrapper {
    position: relative;
    margin: 0 0 10px;
}

.manufacturer-item .picture,
.vendor-item .picture {
    margin-bottom: 0;
}

    .manufacturer-item .picture a:before,
    .vendor-item .picture a:before {
        padding-top: 75%;
    }

.manufacturer-item .view-all a,
.vendor-item .view-all a {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 1px;
    right: 1px;
    bottom: 1px;
    left: 1px;
    background: rgba(255,255,255,.9);
    font-weight: 600;
    color: #e43d51;
    text-decoration: underline;
    transition: 0.2s ease;
    opacity: 0;
}

.manufacturer-item .wrapper:hover a,
.vendor-item .wrapper:hover a {
    opacity: 1;
}

.manufacturer-item .title a:hover,
.vendor-item .title a:hover {
    color: #e43d51;
}

.manufacturer-item .title,
.vendor-item .title {
    font-size: 14px;
    font-weight: 400;
    color: #666;
}

.cross-sells {
    margin-top: 40px;
}

.pager {
    /*margin-top: 60px;*/
    margin-top: 30px;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
    padding: 10px 0;
}

    .pager ul {
        text-align: center;
        font-size: 14px;
    }

    .pager li {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        position: relative;
        width: 40px;
        height: 40px;
        margin: 0 1px;
        vertical-align: middle;
        transition: 0.2s ease;
    }

        .pager li a {
            display: block;
            width: 100%;
            padding: 8px 0;
        }

    .pager .current-page {
        background-color: #e43d51;
        color: #fff;
    }

    .pager li:before {
        font-size: 20px;
        transition: 0.2s ease;
    }

    .pager li:after {
        content: "";
        position: absolute;
        top: 3px;
        right: -3px;
        bottom: -3px;
        left: 3px;
        z-index: -1;
        opacity: 0;
        border: 1px solid #e43d51;
        transition: 0.5s ease;
    }

    .pager .current-page:after {
        opacity: 1;
    }

    .pager li:hover a {
        color: #e43d51;
    }

    .pager .previous-page a,
    .pager .next-page a,
    .pager .first-page a,
    .pager .last-page a {
        font-size: 0;
    }

        .pager .previous-page a:before,
        .pager .next-page a:after,
        .pager .first-page a:before,
        .pager .last-page a:after {
            display: inline-block;
            line-height: 21px;
        }

        .pager .first-page a:before {
            content: "\e911";
            font-size: 16px;
        }

        .pager .previous-page a:before {
            content: "\e90d";
            font-size: 14px;
        }

        .pager .next-page a:after {
            content: "\e90e";
            font-size: 14px;
        }

        .pager .last-page a:after {
            content: "\e912";
            font-size: 16px;
        }


/* PRODUCT PAGE */


.product-essential {
    max-width: 500px;
    margin: auto;
}

    .product-essential:after {
        content: "";
        display: block;
        clear: both;
    }

.gallery {
    margin: 0 0 30px;
    text-align: center;
    font-size: 0;
}

    .gallery .picture {
        position: relative;
        border: 1px solid #eee;
    }

        .gallery .picture a {
            display: inline-block;
            max-width: 100%; /*Ie fix*/
        }

    .gallery .picture-thumbs {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        grid-gap: 10px 10px;
        margin: 10px auto 0;
    }

    .gallery .thumb-item {
        border: 1px solid #eee;
    }

.extended-gallery .thumb-item {
    display: inline-block;
    width: 115px;
    max-width: 23%;
    margin: 10px 1% 0;
}

.overview, .variant-overview {
    text-align: left;
}

.discontinued-product {
    color: #e31d31;
}

.overview .product-name {
    display: none;
}

.overview .short-description {
    margin: 0 0 25px;
    color: #888;
}

.price-reviews-wrapper {
    margin: 0 0 30px;
    border-bottom: 1px solid #eee;
}

    .price-reviews-wrapper .prices {
        display: flex;
        flex-wrap: wrap;
        align-items: baseline;
        justify-content: left;
        margin: 0 0 25px;
    }

.old-product-price,
.non-discounted-price,
.prices .product-price {
    margin: 0 6px;
    font-size: 15px;
    color: #888;
}

.prices .product-price {
    color: #e43d51;
}

.old-product-price,
.non-discounted-price {
    text-decoration: line-through;
}

    .old-product-price +
    .non-discounted-price {
        display: none; /*hidden by default*/
    }

.prices .tax-shipping-info {
    font-size: 11px;
    white-space: nowrap;
    color: #888;
}

.prices .rental-price {
    width: 100%;
    text-align: center;
    white-space: nowrap;
}

.tier-prices {
    margin: 0 0 30px;
}

    .tier-prices .title {
        display: none;
    }

    .tier-prices .prices-table {
        display: grid;
        grid-template-columns: 50% 50%;
    }

    .tier-prices .prices-cell {
        box-shadow: 0 0 0 1px #eee;
        background-color: #fff;
        padding: 10px;
    }

    .tier-prices .field-header {
        font-weight: bold;
    }

    .tier-prices .item-price {
        color: #e43d51;
    }

.product-reviews-overview {
    display: flex;
    justify-content: center;
    margin: 0 0 25px;
    font-size: 0;
    color: #888;
}

    .product-reviews-overview * {
        height: 14px !important;
        line-height: 13px; /*cross-browser compatibility*/
        white-space: nowrap;
    }

.product-no-reviews,
.product-review-links {
    font-size: 12px;
}

    .product-no-reviews span,
    .product-review-links span {
        margin: 0 8px;
    }

    .product-no-reviews a,
    .product-review-links a:hover {
        color: #000;
    }

.product-review-links {
    display: flex;
}

.stock-delivery-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 10px;
    align-items: center;
    margin: 0 0 25px;
    white-space: nowrap;
}

    .stock-delivery-wrapper.empty {
        display: none;
    }

.availability .stock .label {
    display: none;
}

.availability .stock .value {
    display: inline-block;
    background-color: #f3f3f3;
    padding: 5px 10px;
}

.delivery .free-shipping {
    display: inline-block;
    background-color: #f3f3f3;
    padding: 5px 10px;
    vertical-align: middle;
    font-weight: 600;
}

.delivery .delivery-date {
    display: inline-block;
    vertical-align: middle;
}

.free-shipping + .delivery-date {
    margin-left: 8px;
}

.stock-delivery-wrapper .availability {
    display: flex;
    align-items: center;
}

.back-in-stock-subscription {
    margin: 0 5px 0 15px;
    font-size: 0;
}

.availability .subscribe-button {
    display: inline-flex;
    font-weight: 400;
}

    .availability .subscribe-button:before {
        content: "\e93a";
        position: relative;
        bottom: 1px;
        margin-right: 6px;
        font-size: 20px;
    }

.overview .label,
.variant-overview .label {
    color: #888;
}

.overview .value,
.variant-overview .value {
    font-weight: 600;
}

    .overview .value a,
    .variant-overview .value a {
        text-decoration: underline;
    }

.overview .manufacturers {
    margin: 0 0 20px;
}

.overview .additional-details,
.variant-overview .additional-details {
    display: flex;
    flex-wrap: wrap;
    gap: 5px 15px;
    margin: 0 0 25px;
}

.download-sample {
    margin: 0 0 25px;
}

.download-sample-button {
    display: inline-flex;
}

    .download-sample-button:before {
        content: "\e929";
        margin-right: 5px;
        font-size: 20px;
    }

.attributes dl {
    margin: 0 0 30px;
}

.attributes dt {
    margin: 0 0 5px;
    color: #888;
}

.attributes dd {
    margin: 0 0 10px;
}

.attributes li {
    margin: 8px 0 12px;
}

    .attributes li.disabled {
        pointer-events: none;
        opacity: 0.5;
    }

        .attributes li.disabled label {
            text-decoration: line-through;
        }

.attributes select,
.attributes .textbox,
.attributes textarea {
    width: 100%;
}

.attributes option.disabled {
    color: #ddd;
}

.attributes .option-list label {
    margin: 0 3px;
}

.attributes .qty-select {
    max-width: calc(100% - 70px);
}

.attributes .qty-box {
    margin: 0 0 0 5px;
}

    .attributes .qty-box label {
        display: none;
    }

    .attributes .qty-box input {
        width: 60px;
    }

.attribute-squares {
    display: flex;
    font-size: 0;
}

    .attribute-squares li {
        position: relative;
        margin: 3px 6px 3px 0;
        text-align: center;
    }

    .attribute-squares label {
        display: block;
        margin: 0 !important;
    }

    .attribute-squares input {
        position: relative;
        z-index: -1;
        margin: -32px 0 0;
    }

    .attribute-squares span {
        display: block;
    }

.attribute-square {
    width: 34px;
    height: 34px;
    border: 2px solid #fff;
    cursor: pointer;
}

.attribute-squares [title~="White"] span {
    box-shadow: inset 0 0 0 1px #ddd;
}

.selected-value .attribute-square {
    box-shadow: 0 0 0 1px #333 !important;
}

.attribute-squares li.disabled {
    position: relative;
    opacity: 1;
}

    .attribute-squares li.disabled:after {
        content: "\e919";
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        border: 2px solid #fff;
        background-color: #f3f3f3;
        font-size: 10px;
        line-height: 30px;
        opacity: 0.95;
    }

.image-squares .tooltip-container {
    display: none;
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translate(-50%,-5px);
    width: 200px;
    height: 200px;
    box-shadow: 0 0 10px rgba(0,0,0,0.15);
    background-color: #fff;
    padding: 10px;
    z-index: 1;
    animation: fadein 0.5s;
}

    .image-squares .tooltip-container:after {
        content: "";
        position: absolute;
        bottom: -10px;
        left: 50%;
        margin-left: -10px;
        border-width: 10px 10px 0;
        border-style: solid dashed dashed;
        border-color: #fff transparent transparent;
        filter: drop-shadow(0px 2px 2px rgba(0,0,0,0.06));
        opacity: 0; /*hidden by default*/
    }

.image-squares li:hover .tooltip-container {
    display: block;
}

.rental-attributes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 20px;
    margin: 0 0 20px;
}

    .rental-attributes .datepicker {
        width: 340px;
        max-width: 100%;
    }

.ui-datepicker {
    width: 340px;
    background-color: #fff;
    text-align: center;
    z-index: 99 !important;
}

.ui-datepicker-header {
    position: relative;
    background-color: #222;
    color: #fff;
}

    .ui-datepicker-header a {
        display: flex;
        align-items: center;
        justify-content: center;
        position: absolute;
        top: 0;
        bottom: 0;
        z-index: 1;
        width: 40px;
        font-size: 0;
    }

.ui-datepicker-prev {
    left: 0;
}

.ui-datepicker-next {
    right: 0;
}

.ui-datepicker-prev:before {
    content: "\e914";
    font-size: 13px;
}

.ui-datepicker-next:after {
    content: "\e915";
    font-size: 13px;
}

.ui-datepicker-title {
    position: relative;
    z-index: 0;
    padding: 8px 0;
}

.ui-datepicker-calendar th {
    background-color: #f3f3f3;
}

.ui-datepicker-calendar th,
.ui-datepicker-calendar td {
    width: 14.285%;
    border: 1px solid #ddd;
}

    .ui-datepicker-calendar th span,
    .ui-datepicker-calendar td a {
        display: block;
        min-height: 32px;
        line-height: 32px;
    }

        .ui-datepicker-calendar td a:hover,
        .ui-datepicker-calendar a.ui-state-active,
        .ui-datepicker-calendar a.ui-state-active:hover {
            background-color: #e43d51;
            color: #fff;
        }

.page .qq-upload-button,
.k-window .qq-upload-button {
    width: 100%;
}

.page .qq-upload-list li,
.k-window .qq-upload-list li {
    background: none !important;
}

.page .qq-upload-list span,
.k-window .qq-upload-list span {
    margin: 0 5px;
}

    .page .qq-upload-list span:empty,
    .k-window .qq-upload-list span:empty {
        display: none;
    }

.giftcard {
    width: 100%;
    margin: 0 0 30px;
}

    .giftcard div {
        position: relative;
        margin: 0 0 10px;
    }

    .giftcard label {
        display: block;
        margin: 0 0 5px;
        color: #888;
    }

    .giftcard input,
    .giftcard textarea {
        width: 100%;
        max-width: 100%;
    }

    .giftcard .required {
        position: absolute;
        margin: 14px 0 0 -14px;
    }

.product-estimate-shipping {
    margin: 0 0 15px;
}

    .product-estimate-shipping a {
        display: inline-block;
    }

    .product-estimate-shipping i {
        display: inline-block;
        transform: rotate(45deg);
        margin: 0 0 3px 10px;
        border: solid black;
        border-width: 0 1px 1px 0;
        padding: 3px 3px;
    }

    .product-estimate-shipping span {
        vertical-align: middle;
    }

    .product-estimate-shipping .shipping-loading {
        display: none !important; /*disable preloader*/
    }

    .product-estimate-shipping .shipping-title {
        margin: 0 0 5px;
    }

    .product-estimate-shipping .shipping-price {
        margin: 0 0 0 5px;
        font-weight: 600;
    }

    .product-estimate-shipping .shipping-date {
        margin: 5px 0 0;
        color: #888;
    }

.customer-entered-price {
    display: flex;
    align-items: center;
    position: relative;
    width: 100%;
    max-width: 100%;
    margin: 25px 0 0;
}

    .customer-entered-price .price-input {
        margin-right: 10px;
    }

    .customer-entered-price .enter-price-label {
        position: absolute;
        top: -25px;
        color: #e43d51;
    }

    .customer-entered-price .enter-price-input {
        width: 86px;
        height: 48px;
        padding-right: 0;
    }

.cart-buttons-wrapper {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 5px 5px;
    margin: 0 0 30px;
}

.pre-order-availability-date,
.min-qty-notification {
    width: 100%;
}

.cart-buttons-wrapper .add-to-cart {
    margin: 5px 0;
}

.add-to-cart .add-to-cart-panel {
    display: flex;
    align-items: center;
    position: relative;
}

.add-to-cart-panel .qty-wrapper {
    margin-right: 10px;
}

.add-to-cart-panel .add-to-cart-button {
    width: 250px;
    max-width: calc(100% - 100px);
    height: 50px;
    background-color: #000;
    padding: 0 15px;
    font-size: 14px;
    color: #fff;
}

    .add-to-cart-panel .add-to-cart-button:hover {
        background-color: #e43d51;
    }

.variants-scroll-button {
    width: 240px !important;
    max-width: 100% !important;
}

    .variants-scroll-button:before,
    .variants-scroll-button:after {
        content: "\e913";
        position: absolute;
        top: 0;
        bottom: 0;
        height: 15px;
        margin: auto;
    }

    .variants-scroll-button:before {
        left: 15px;
    }

    .variants-scroll-button:after {
        right: 15px;
    }

.overview-buttons {
    display: flex;
    column-gap: 5px;
    margin: 5px 0;
    font-size: 0;
}

    .overview-buttons button,
    .variants .add-to-wishlist-button {
        width: 45px;
        height: 45px;
        border: 1px solid #ddd;
        font-size: 0;
    }

.add-to-wishlist-button:before {
    content: "\e906";
    font-size: 18px;
}

.add-to-compare-list-button:before {
    content: "\e907";
    font-size: 16px;
}

.email-a-friend-button:before {
    content: "\e908";
    font-size: 16px;
}

.overview-buttons button:hover,
.variants .add-to-wishlist-button:hover {
    border-color: #ccc;
    color: #e43d51;
}

.product-share-button {
    margin: -10px 0 30px;
    font-size: 0;
}

    .product-share-button a {
        margin-bottom: 0 !important;
    }

.full-description {
    line-height: 24px;
    color: #666;
}

    .full-description ~ div {
        margin-top: 50px;
    }

.product-collateral {
    max-width: 500px;
    margin: auto;
    text-align: left;
}

    .product-collateral .title {
        margin: 0 0 20px;
        font-size: 15px;
    }

    .product-collateral ~ .product-grid {
        margin: 25px 0 50px;
    }

.product-specs-box .title {
    margin: 0 0 20px;
    font-size: 15px;
}

.product-specs-box table {
    margin-bottom: 0;
}

.product-specs-box thead {
    display: none;
}

.product-specs-box td {
    border: 1px solid #eee;
    padding: 10px;
}

.product-specs-box .spec-group-name {
    display: none !important; /*hidden because invalid markup in default nopCommerce code*/
}

.product-specs-box .attribute-squares {
    display: inline-block;
    vertical-align: middle;
}

.product-specs-box .attribute-square {
    cursor: default !important;
}

.overview .product-specs-box {
    margin-top: 25px; /*grouped products*/
}

.product-tags-box {
    display: none; /*hidden by default*/
}

.product-tags-list {
    font-size: 0;
}

    .product-tags-list li {
        display: inline-block;
        font-size: 13px; /*reset zeroing*/
    }

        .product-tags-list li.separator {
            margin: 0 5px 0 3px;
        }

    .product-tags-list a {
        display: inline-block;
        line-height: 24px;
    }

.product-variant-list {
    margin-top: 30px !important;
}

.product-variant-line {
    margin: 30px 0 0;
    border-bottom: 1px solid #eee;
    padding: 20px 0 0;
}

.variant-picture {
    position: relative;
    margin: 0 0 30px;
    border: 1px solid #eee;
    font-size: 0;
}

.variant-overview .desktop {
    display: none;
}

.variant-overview .prices {
    justify-content: flex-start;
}

.variant-overview .variant-name {
    margin: 0 0 15px;
    text-align: left;
    font-size: 15px;
    font-weight: 600;
}

.variant-overview .variant-description {
    margin: 0 0 25px;
    line-height: 24px;
    color: #666;
}

.variant-overview .attributes select {
    width: 395px;
}


/* ESTIMATE SHIPPING */


.estimate-shipping-popup {
    position: relative;
    max-width: 800px;
    margin: auto;
    background-color: #fff;
    padding: 25px;
    transform: scale(0.8);
    transition: all 0.2s ease;
    opacity: 0;
}

    .estimate-shipping-popup strong {
        visibility: hidden;
    }

.mfp-ready .estimate-shipping-popup {
    transform: scale(1);
    opacity: 1;
}

.mfp-removing .estimate-shipping-popup {
    transform: scale(0.8);
    opacity: 0;
}

.estimate-shipping-popup-zoom-in.mfp-removing {
    transition: all 0.3s ease;
    opacity: 0;
}

.estimate-shipping-row {
    display: flex;
    display: -webkit-flex;
    align-items: center;
    position: relative;
}

.estimate-shipping-row-item {
    flex: 0 1 100%;
}

.mfp-container .address-item {
    margin: 10px 0 0;
}

    .mfp-container .address-item + div {
        padding: 0 0 0 15px;
    }

.estimate-shipping-address-control {
    width: 100%;
}

.mfp-container .address-item .required {
    position: absolute;
    top: -5px;
    right: -5px;
}

.mfp-container .shipping-options {
    position: relative; /*preloader referrence*/
    margin: 10px 0 25px;
}

.mfp-container .shipping-header-item {
    align-self: flex-end;
    border: none !important;
    padding: 12px 5px !important;
    font-size: 14px;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.mfp-container .shipping-options-body {
    display: table;
    table-layout: fixed;
    width: 100%;
    border: 1px solid #ddd;
    border-collapse: collapse;
}

.mfp-container .shipping-option {
    display: table-row;
    cursor: pointer;
    color: #888;
}

    .mfp-container .shipping-option.active {
        color: #000;
    }

    .mfp-container .shipping-option > div {
        display: table-cell;
        border-top: 1px solid #ddd;
        padding: 10px 11px;
    }

.mfp-container .shipping-item {
    border-right: 1px solid #ddd;
    overflow: hidden;
    padding: 8px 0;
    overflow-wrap: break-word;
}

.estimate-shipping-row-item-radio {
    flex: 0 0 30px;
    width: 24px;
}

.estimate-shipping-radio {
    display: none;
}

.apply-shipping-button-container {
    text-align: center;
}

    .apply-shipping-button-container + button {
        font-weight: 400;
    }

.mfp-container .apply-shipping-button {
    min-width: 150px;
    height: 45px;
    margin: 5px 0;
    background-color: #000;
    padding: 0 15px;
    font-size: 14px;
    color: #fff;
}

    .mfp-container .apply-shipping-button:hover {
        background-color: #e43d51;
    }

.mfp-container .no-shipping-options {
    padding: 30px 15px;
    text-align: center;
}

.mfp-container .message-failure {
    margin: 10px 0 -5px;
}

@media all and (max-width: 600px) {

    .estimate-shipping-popup {
        padding: 25px 3%;
    }

    .mfp-container .shipping-address {
        flex-flow: column;
    }

    .mfp-container .address-item {
        width: 100%;
    }

        .mfp-container .address-item + div {
            padding: 0;
        }

        .mfp-container .address-item .required {
            top: 14px;
            right: 4px;
        }
}


/* PRODUCT REVIEWS */


.product-reviews-page h1 a {
    display: inline-block;
    border-bottom: 2px solid #000;
    line-height: 30px;
}

    .product-reviews-page h1 a:before,
    .product-reviews-page h1 a:after {
        content: "''";
    }

.product-reviews-page .title {
    margin: 0 0 10px;
    text-align: center;
    font-size: 15px;
}

.product-reviews-page .result,
.product-reviews-page .message-error {
    margin: 0 0 20px;
}

.write-review .review-rating {
    text-align: center;
    font-size: 0;
}

    .write-review .review-rating > label {
        text-align: center;
    }

.write-review .rating-options input {
    position: absolute;
    margin: 4px 0 0 4px;
}

.write-review .rating-options label {
    display: inline-block;
    max-width: 20px;
    margin: 0 1px;
    padding: 0;
    font-size: 0;
}

    .write-review .rating-options label:before {
        content: "\e909";
        display: block;
        position: static;
        width: auto;
        height: auto;
        border: none !important;
        background: none !important;
        box-shadow: none;
        font-size: 20px;
        color: #e43d51;
    }

.write-review :checked + label ~ label:before {
    content: "\e90a";
    color: #ccc;
}

.write-review .additional-rating {
    margin-top: -10px;
}

.write-review .tooltip-text p {
    display: none; /*do not use the tooltip*/
}

.write-review .captcha-box {
    margin: 25px 0;
}

.write-product-review-button {
    min-width: 240px;
    height: 50px;
    background-color: #000;
    padding: 0 20px;
    font-size: 14px;
    color: #fff;
}

    .write-product-review-button:hover {
        background-color: #e43d51;
    }

.product-review-list {
    margin-top: 70px;
    overflow: hidden;
}

.product-review-item {
    margin: 0 0 20px;
    border: 1px solid #eee;
    padding: 20px;
}

    .product-review-item .review-title {
        margin: 0 0 5px;
        font-size: 15px;
    }

    .product-review-item .product-review-box {
        display: inline-flex;
        margin: 0 0 15px;
    }

    .product-review-item .additional-rating {
        display: none; /*hidden by default on both review page and customer reviews page*/
    }

    .product-review-item .review-avatar {
        margin: 0 0 25px;
    }

        .product-review-item .review-avatar a {
            display: table;
            margin: auto;
        }

        .product-review-item .review-avatar img {
            display: block;
            margin: auto;
        }

        .product-review-item .review-avatar .user {
            margin-top: 5px;
            word-break: break-all;
            font-size: 12px;
            color: #888;
        }

    .product-review-item .review-text {
        margin: 0 0 25px;
        text-align: left;
        color: #666;
    }

    .product-review-item .review-date {
        display: block;
        margin: 0 0 10px;
        padding: 5px 0;
        font-size: 12px;
        color: #888;
    }

    .product-review-item .review-info label {
        color: #888;
    }

    .product-review-item .review-info a:hover {
        text-decoration: underline;
    }

    .product-review-item .separator {
        margin: 0 5px;
        color: #888;
    }

.product-review-helpfulness .vote {
    display: inline-block;
    padding: 0 3px;
    font-weight: bold;
    text-decoration: underline;
    cursor: pointer;
}

.product-review-helpfulness {
    margin: 25px 0 10px;
}

    .product-review-helpfulness .question {
        margin-right: 5px;
        color: #888;
    }

    .product-review-helpfulness .vote + .vote:before {
        content: "|";
        position: relative;
        bottom: 1px;
        margin: 0 5px 0 -4px;
    }

    .product-review-helpfulness .vote-stats {
        position: relative;
        bottom: -1px;
        margin-left: 5px;
        font-size: 12px;
        color: #888;
    }

    .product-review-helpfulness .result {
        margin-left: 10px;
        color: #888;
    }

.product-review-item .review-reply {
    margin: 25px 0 0;
    border: 1px dashed #eee;
    background-color: #f9f9f9;
    padding: 15px;
}

.product-review-item .reply-header {
    margin: 0 0 10px;
    font-weight: bold;
}


/* WISHLIST & COMPARE PAGE */


.wishlist-content .buttons {
    display: flex;
    flex-flow: column;
    gap: 10px 10px;
    max-width: 350px;
    margin: auto;
}

.update-wishlist-button,
.email-wishlist-button {
    min-width: 200px;
    height: 50px;
    border: 1px solid #000;
    padding: 0 15px;
    font-size: 14px;
}

    .update-wishlist-button:hover,
    .email-wishlist-button:hover {
        border-color: #e43d51;
        color: #e43d51;
    }

.wishlist-add-to-cart-button {
    min-width: 220px;
    height: 50px;
    background-color: #000;
    padding: 0 15px;
    font-size: 14px;
    color: #fff;
}

    .wishlist-add-to-cart-button:hover {
        background-color: #e43d51;
    }

.wishlist-content > .message-error {
    margin: 0 0 10px;
}

.wishlist-page .tax-shipping-info {
    margin: 30px 0 0;
    text-align: center;
}

.wishlist-page .share-info {
    margin: 40px -2.5% 0;
    background-color: #f3f3f3;
    padding: 30px 20px 40px;
    text-align: center;
}

    .wishlist-page .share-info:before {
        content: "\e906";
        display: block;
        font-size: 20px;
    }

.wishlist-page .share-label {
    display: block;
    margin: 5px 0 10px;
    color: #888;
}

.wishlist-page .share-link {
    display: block;
    font-weight: 600;
}

.compare-products-page {
    position: relative;
    overflow: hidden;
}

.compare-products-clear-list {
    margin: 0 0 15px;
    font-weight: 600;
    color: #e43d51;
    text-decoration: underline;
}

.compare-products-page .remove-button {
    font-size: 12px;
    text-decoration: underline;
}

.compare-products-page .picture {
    display: block;
    font-size: 0;
}

.compare-products-page .attribute-squares {
    display: inline-block;
    vertical-align: middle;
}

.compare-products-page .attribute-square {
    width: 24px;
    height: 24px;
    cursor: default !important;
}

.compare-products-table {
    display: none;
}

    .compare-products-table td {
        padding: 20px 5px;
        vertical-align: top;
    }

        .compare-products-table td label {
            font-weight: 400;
        }

        .compare-products-table td:first-child,
        .compare-products-table .short-description {
            color: #888;
        }

    .compare-products-table .product-price {
        font-weight: 600;
    }

    .compare-products-table .wrapper {
        position: relative;
        max-width: 80%;
        padding-top: 0;
    }

    .compare-products-table button {
        display: flex;
        align-items: center;
        position: absolute;
        top: 0;
        right: 0;
        max-width: 38px;
        height: 38px;
        overflow: hidden;
        background: rgba(255,255,255,.8);
        text-decoration: none !important;
        transition: 0.8s ease-out;
    }

        .compare-products-table button:before {
            content: "\e919";
            display: block;
            min-width: 38px;
            max-width: 38px;
            vertical-align: middle;
        }

        .compare-products-table button span {
            margin-right: 8px;
            vertical-align: middle;
        }

        .compare-products-table button:hover {
            max-width: 150px;
        }

.compare-section + .compare-section {
    margin-top: 30px;
}

.compare-products-mobile .title {
    background-color: #f3f3f3;
    padding: 10px;
}

.compare-products-mobile .item {
    display: flex;
    column-gap: 10px;
    border-bottom: 1px solid #eee;
    padding: 10px 1px;
    text-align: left;
}

.compare-products-mobile .picture img {
    max-width: 80px;
}

.compare-section.specification .item {
    display: block;
}


/* TOPICS */


.page .topic-block,
.page.topic-page {
    text-align: center;
}

.topic-block .title {
    padding: 20px 0;
    font-weight: 400;
}

.topic-block-body,
.topic-page .page-body {
    line-height: 24px;
}

.not-found-page p {
    margin: 0 0 30px;
}

.topic-password {
    margin: 70px 0 50px;
    text-align: center;
}

.page .page-body >
.topic-password:first-child {
    margin-top: 0;
}

.enter-password-title {
    margin: 0 0 30px;
}

.enter-password-form {
    width: 600px;
    max-width: 100%;
    margin: auto;
}

    .enter-password-form input {
        display: block;
        width: 100%;
    }

    .enter-password-form button {
        min-width: 240px;
        height: 50px;
        margin: 30px 0 0;
        border: 1px solid #000;
        background: none !important;
        padding: 0 20px;
        font-size: 14px;
        color: #000 !important;
    }

.topic-password .password-error {
    margin-top: 10px;
}


/* CONTACT PAGES */


.contact-page .topic-block,
.apply-vendor-page .topic-block {
    margin: 0 0 30px;
    text-align: center;
}

    .contact-page .topic-block p,
    .apply-vendor-page .topic-block p {
        color: #000;
    }

.contact-page .message-error,
.email-a-friend-page .message-error,
.apply-vendor-page .message-error {
    margin: 0 0 10px;
}

.contact-page .buttons,
.email-a-friend-page .buttons,
.apply-vendor-page .buttons {
    margin-top: 30px;
}

.contact-page .button-1,
.email-a-friend-page .button-1,
.apply-vendor-page .button-1 {
    min-width: 240px;
    height: 50px;
    background-color: #000;
    padding: 0 20px;
    font-size: 14px;
    color: #fff;
}

    .contact-page .button-1:hover,
    .email-a-friend-page .button-1:hover,
    .apply-vendor-page .button-1:hover {
        background-color: #e43d51;
    }

.email-a-friend-page .title {
    margin: 0 0 30px;
    text-align: center;
}

    .email-a-friend-page .title h2 {
        font-weight: 400;
    }

.apply-vendor-page input[type="file"] {
    background-color: #eee;
}

.apply-vendor-page .terms-of-service {
    width: 600px;
    max-width: 100%;
    margin: 40px auto 30px;
    background-color: #f3f3f3;
    padding: 20px;
    text-align: center;
}


/* REGISTRATION & LOGIN */


.gender {
    text-align: left;
}

    .gender span {
        display: inline-block;
        margin-right: 10px;
        padding: 5px;
    }

    .gender label {
        display: inline-block;
        width: auto !important;
        margin: 0 !important;
        cursor: pointer;
    }

.email-to-revalidate {
    display: block;
    text-align: left;
    font-size: 13px;
}

.email-to-revalidate-note {
    display: block;
    text-align: left;
    font-size: 12px;
    color: #888;
}

#check-availability-button {
    display: block;
    margin-top: 10px;
    font-size: 12px;
    text-decoration: underline;
}

#username-availabilty {
    margin: 5px 0 0;
}

    #username-availabilty:empty {
        display: none;
    }

.readonly-username {
    display: block;
    text-align: left;
    font-size: 13px;
}

.vat-status, .vat-note {
    display: block;
    margin: 5px 0 0;
    text-align: center;
    font-size: 12px;
}

.accept-privacy-policy {
    width: 600px;
    max-width: 100%;
    margin: 50px auto;
    background-color: #f3f3f3;
    padding: 20px;
    text-align: center;
}

    .accept-privacy-policy .read {
        cursor: pointer;
    }

    .accept-privacy-policy + .accept-consent {
        margin-top: -45px;
    }

.registration-page .fieldset {
    margin: 0 0 50px;
}

.registration-result-page .result {
    margin: 0 0 30px;
    text-align: center;
    font-weight: 600;
}

.registration-result-page .buttons {
    display: none;
}

.login-page .customer-blocks {
    display: flex;
    flex-flow: column-reverse;
}

.login-page .fieldset,
.login-page .new-wrapper {
    width: 600px;
    max-width: 100%;
    margin: 50px auto 0;
    border: 1px solid #eee;
    padding: 0 5% 35px;
}

    .login-page .fieldset .title,
    .login-page .new-wrapper .title {
        position: relative;
        top: -35px;
    }

.login-page .message-error {
    margin-bottom: 10px;
}

.login-page .new-wrapper {
    margin-top: 70px;
}

    .login-page .new-wrapper .title {
        margin: 0 0 10px;
        text-align: center;
        font-size: 15px;
    }

    .login-page .new-wrapper .text {
        margin: 0 0 30px;
        text-align: center;
    }

.login-page .text .topic-block {
    text-align: center;
}

.login-page .new-wrapper .buttons {
    display: flex;
    flex-flow: row-reverse;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px 10px;
}

.login-page .new-wrapper button {
    border: 1px solid #000;
    background: none !important;
    color: #000;
}

    .login-page .new-wrapper button:hover {
        border-color: #e43d51;
        color: #e43d51;
    }

.login-page .inputs.reversed {
    display: flex;
    justify-content: space-between;
    white-space: nowrap;
}

    .login-page .inputs.reversed label {
        margin: 0 0 0 5px;
    }

    .login-page .inputs.reversed a {
        font-size: 12px;
        text-decoration: underline;
    }

.customer-blocks ~ .topic-block {
    margin: 30px 0 0;
}

.external-authentication {
    margin: 30px 0 0;
    text-align: center;
}

    .external-authentication .title {
        display: none;
    }

.add-more-external-records {
    width: 600px;
    max-width: 100%;
    margin: auto;
}

.password-recovery-page .tooltip {
    width: 600px;
    max-width: 100%;
    margin: 0 auto 30px;
}

.password-recovery-page .result {
    margin: 0 0 30px;
    text-align: center;
    font-weight: 600;
}


/* ACCOUNT PAGES */


.block-account-navigation a {
    display: flex !important;
    padding: 10px 0 !important;
    font-size: 14px;
    color: #000;
}

    .block-account-navigation a:before {
        display: block;
        min-width: 20px;
        margin-right: 10px;
        text-align: center;
        font-size: 20px;
    }

.block .customer-info a:before {
    content: "\e926";
}

.block .customer-addresses a:before {
    content: "\e927";
}

.block .customer-orders a:before {
    content: "\e928";
}

.block .downloadable-products a:before {
    content: "\e929";
}

.back-in-stock-subscriptions a:before {
    content: "\e93a";
}

.block .return-requests a:before {
    content: "\e92a";
}

.block .reward-points a:before {
    content: "\e92b";
}

.block .change-password a:before {
    content: "\e92c";
}

.block .customer-avatar a:before {
    content: "\e92d";
}

.block .forum-subscriptions a:before {
    content: "\e930";
}

.block .customer-reviews a:before {
    content: "\e92e";
}

.block .customer-vendor-info a:before {
    content: "\e92f";
}

.block .customer-gdpr a:before {
    content: "\e931";
}

.block .price-match-requests a:before {
    content: "\e93b";
}

.customer-check-gift-card-balance a:before {
    content: "\e932";
}

.customer-multiFactor-authentication a:before {
    content: "\e933";
}

.customer-info-page .fieldset {
    margin: 0 0 50px;
}

.address-list-page .addresses,
.order-list-page .order-list,
.return-list-page .return-list,
.gdpr-tools-page .gdpr-form {
    display: grid;
    grid-gap: 25px 0;
    max-width: 600px;
    margin: auto;
}

.address-list-page .section,
.order-list-page .section,
.return-list-page .section,
.gdpr-tools-page .fieldset {
    border: 1px solid #eee;
    padding: 30px 20px;
    text-align: center;
}

.address-list-page .title,
.order-list-page .title,
.return-list-page .title,
.gdpr-tools-page .title {
    margin-bottom: 15px;
}

.address-list-page .info,
.order-list-page .info,
.return-list-page .info {
    line-height: 24px;
    color: #888;
}

.address-list-page .email {
    margin-bottom: 10px;
    color: #000;
}

.address-list-page .buttons,
.order-list-page .buttons {
    display: flex;
    justify-content: space-between;
    margin: -15px 0 15px;
}

.address-list-page .button-2,
.order-list-page .button-2 {
    text-decoration: underline;
}

.address-list-page .add-address {
    display: flex;
    flex-flow: column;
    border: 1px dashed #ddd;
}

.address-list-page .add:before {
    content: "\e91c";
    flex-grow: 1;
    display: flex;
    align-items: center;
    margin: 0 auto 30px;
    font-size: 90px;
    color: #bbb;
}

.address-list-page .button-1 {
    align-self: center;
}

.address-list-page .no-data + .add {
    max-width: 600px;
    margin: 30px auto 0;
}

.address-edit-page .edit-address {
    margin: 0 0 30px;
}

.order-list-page .buttons {
    flex-flow: row-reverse;
}

.order-list-page .disabled {
    text-decoration: line-through;
    cursor: default;
    opacity: 0.5;
}

.order-list-page .info span,
.return-list-page .info span {
    color: #000;
}

.return-list-page .info {
    margin-top: 25px;
    text-align: left;
}

    .return-list-page .info label {
        margin-right: 5px;
        white-space: nowrap;
    }

.return-list-page .product a {
    font-weight: 600;
}

.return-list-page .comments {
    margin: 15px 0 0;
    text-align: left;
}

.back-in-stock-list-page .description,
.forum-subscriptions-page .description {
    margin: 0 0 20px;
    text-align: center;
}

.downloadable-products-page .download {
    text-align: center;
}

    .downloadable-products-page .download a {
        font-size: 12px;
        font-weight: 600;
        text-decoration: underline;
        white-space: nowrap;
    }

.user-agreement-page .terms-of-agreement {
    min-height: 100px;
    margin: 0 0 30px;
}

.reward-points-overview {
    margin: 0 0 30px;
    border: 1px solid #eee;
    padding: 30px 15px;
    text-align: center;
}

.reward-points-history .date,
.reward-points-history .endDate {
    white-space: nowrap;
}

.reward-points-history .empty {
    display: none;
}

.change-password-page .buttons {
    margin-top: 30px;
}

.avatar-page .page-body {
    border: 1px solid #eee;
    padding: 30px 15px;
    text-align: center;
}

.avatar-page .image {
    margin-bottom: 30px;
    font-size: 0;
}

    .avatar-page .image img {
        border: 1px solid #eee;
    }

.avatar-page .buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px 10px;
    margin: 30px 0;
}

.avatar-page .button-2,
.vendorinfo-page .button-2 {
    min-width: 240px;
    height: 50px;
    border: 1px solid #000;
    padding: 0 20px;
    font-size: 14px;
}

    .avatar-page .button-2:hover,
    .vendorinfo-page .button-2:hover {
        border-color: #e43d51;
        color: #e43d51;
    }

.gdpr-tools-page .fieldset {
    display: flex;
    flex-flow: column;
}

.gdpr-tools-page .form-fields {
    flex-grow: 1;
    margin: 0 0 20px;
}

.gdpr-export-data-button,
.gdpr-delete-account-button {
    border: 1px solid #000;
    background: none !important;
    color: #000;
}

    .gdpr-export-data-button:hover,
    .gdpr-delete-account-button:hover {
        border-color: #e43d51;
        color: #e43d51;
    }

.check-gift-card-balance-page .result {
    margin: 0 0 20px;
}

.check-gift-card-balance-page .buttons {
    margin-top: 30px;
}

.vendorinfo-page .vendor-picture {
    display: flex;
    flex-flow: column;
    margin-top: 30px;
}

    .vendorinfo-page .vendor-picture img {
        align-self: center;
    }

    .vendorinfo-page .vendor-picture button {
        align-self: center;
        margin-top: 20px;
        text-decoration: underline;
    }

.vendorinfo-page .vendor-attributes {
    max-width: 600px;
    margin: 0 auto 25px;
}

.multifactor-auth-page .description {
    margin: 0 0 30px;
    text-align: left;
}

.multifactor-auth-page .is-enabled {
    margin: 40px 0;
    background-color: #f3f3f3;
    padding: 20px 15px;
}

    .multifactor-auth-page .is-enabled .inputs {
        margin-bottom: 0;
    }

    .multifactor-auth-page .is-enabled label {
        display: inline;
        width: auto;
    }

.multifactor-auth-page .method-name {
    display: flex;
}

    .multifactor-auth-page .method-name button {
        height: auto;
        background: none;
        padding: 0;
        color: #000;
        text-decoration: underline;
    }

.configure-provider .table-wrapper {
    margin: 40px 0;
    text-align: left;
}

.configure-provider table .qr-code {
    vertical-align: top;
    font-size: 0;
}

    .configure-provider table .qr-code img {
        border: 1px solid #eee;
    }

.configure-provider table .manual-code {
    padding: 5px 0 5px 15px;
    vertical-align: top;
}


/* SHOPPING CART */


.order-progress {
    position: relative;
    background-color: #f3f3f3;
    padding: 25px 0;
    text-align: center;
}

    .order-progress:before {
        content: "";
        position: absolute;
        top: 0;
        right: -2.5%;
        bottom: 0;
        left: -2.5%;
        background-color: #f3f3f3;
    }

    .order-progress ul {
        display: flex;
        justify-content: center;
    }

    .order-progress li {
        position: relative;
        width: 16.666%;
        max-width: 80px;
    }

    .order-progress a {
        display: block;
        position: relative;
        z-index: 1;
        padding-top: 40px;
        font-family: 'DM Serif Display', serif;
        font-size: 0;
        color: #888;
    }

    .order-progress li:before,
    .order-progress li:after {
        position: absolute;
        top: 0;
        z-index: 0;
        left: 0;
        right: 0;
        width: 40px;
        height: 40px;
        margin: auto auto;
        border: 1px solid #888;
        background-color: #f3f3f3;
    }

    .order-progress li:before {
        content: "\e910";
        display: flex;
        justify-content: center;
        align-items: center;
        z-index: 1;
        color: #888;
    }

    .order-progress li:after {
        content: "";
        margin-top: 3px;
        left: 3px;
        right: -3px;
    }

    .order-progress .active-step:before {
        content: "\e918";
        border-color: #000;
        color: #000;
    }

    .order-progress .active-step:after {
        border-color: #000;
    }

    .order-progress .current-step:before {
        content: "\e91a";
        border-color: #e43d51;
        background-color: #e43d51;
        color: #fff;
    }

    .order-progress .current-step:after {
        border-color: #e43d51;
    }

    .order-progress .inactive-step a {
        cursor: default;
    }

    .order-progress .active-step a {
        cursor: pointer;
        color: #000;
    }

    .order-progress .current-step a {
        color: #e43d51;
    }

.shopping-cart-page .button-1,
.checkout-page .button-1 {
    min-width: 240px;
    height: 50px;
    background-color: #000;
    padding: 0 20px;
    font-size: 14px;
    color: #fff;
    text-transform: capitalize;
}

    .shopping-cart-page .button-1:hover,
    .checkout-page .button-1:hover {
        background-color: #e43d51;
    }

.remove-discount-button,
.remove-gift-card-button {
    margin: 0 0 0 5px;
    padding: 5px;
    cursor: pointer;
}

    .remove-discount-button:before,
    .remove-gift-card-button:before {
        content: "\e919";
        font-size: 10px;
    }

.shopping-cart-page .message-error,
.checkout-page .message-error {
    margin: 0 0 10px;
}

.cart-options {
    margin: 0 0 30px;
    text-align: center;
}

    .cart-options .common-buttons {
        display: flex;
        flex-flow: column;
        gap: 10px 10px;
        max-width: 250px;
        margin: auto;
    }

    .cart-options .tax-shipping-info {
        max-width: 290px;
        margin: 0 0 15px;
    }

    .cart-options .update-cart-button,
    .cart-options .continue-shopping-button,
    .cart-options .estimate-shipping-button {
        min-width: 200px;
        height: 50px;
        border: 1px solid #000;
        padding: 0 15px;
        font-size: 14px;
    }

    /*.cart-options .continue-shopping-button {
		display: none;
	}*/
    /*.tax-shipping-info ~ .continue-shopping-button {
	display: none;
}*/
    .cart-options .estimate-shipping-button {
        display: inline-flex;
        justify-content: center;
        align-items: center;
        font-weight: 600;
        order: 3; /**/
    }

        .cart-options .update-cart-button:hover,
        .cart-options .continue-shopping-button:hover,
        .cart-options .estimate-shipping-button:hover {
            border-color: #e43d51;
            color: #e43d51;
        }

.checkout-attributes dt {
    margin: 0 0 5px;
    color: #888;
}

.checkout-attributes dd {
    margin: 0 0 10px;
}

.checkout-attributes select {
    min-width: 250px;
}

.checkout-attributes li {
    margin: 8px 5px;
    text-align: left;
}

.checkout-attributes + .deals {
    margin-top: 30px;
}

.cart-collaterals .title {
    font-family: 'DM Serif Display', serif;
    font-size: 20px;
}

    .cart-collaterals .title strong {
        font-weight: 400;
    }

.cart-collaterals .hint {
    display: none;
    margin: 0 0 5px;
    color: #888;
}

.coupon-box, .giftcard-box {
    margin: 0 0 2px;
}

.cart-collaterals .coupon-code {
    display: flex;
    border: 1px solid #ddd;
    padding-right: 15px;
}

    .cart-collaterals .coupon-code input {
        flex-grow: 1;
        height: 50px;
        border: none;
    }

    .cart-collaterals .coupon-code button {
        text-decoration: underline;
    }

.cart-collaterals .message-failure {
    margin: 5px 0 0;
    font-size: 12px;
    color: #e31d31;
}

.cart-collaterals .message-success {
    margin: 5px 0 0;
    font-size: 12px;
}

.cart-collaterals .current-code {
    margin: 5px 0 0;
}

.total-info {
    margin: 0 0 20px;
    background-color: #f3f3f3;
    padding: 20px 15px;
}

.cart-total td {
    width: 50%;
    border: none;
    padding: 5px 1px;
}

.cart-total-left {
    text-align: left;
}

.cart-total-right {
    text-align: right;
}

.cart-total .order-total {
    font-size: 14px;
    font-weight: 600;
}

.terms-of-service {
    max-width: 350px;
    margin: 0 auto 30px;
}

    .terms-of-service label:before {
        top: 3px !important;
        bottom: auto !important;
    }

    .terms-of-service .read {
        margin: 0 0 0 3px;
        cursor: pointer;
    }

.cart-footer .totals-txt {
    display: none;
}

.cart-footer .amount-warning {
    margin: 0 0 20px;
    font-weight: 600;
    color: #e31d31;
}

.save-quote-button-grid {
    display: inline-block;
    float: left;
}

.cart-footer .checkout-button {
    width: 50%;
    height: 50px;
    font-size: 15px;
    display: inline-block;
    float: left;
    margin-left: 0px;
}

.cart-footer .checkout-disabled {
    font-weight: 600;
    color: #e31d31;
}

.cart-footer .addon-buttons {
    display: flex;
    align-items: center;
}

    .cart-footer .addon-buttons img {
        margin: 20px auto 0;
    }

    .cart-footer .addon-buttons p {
        margin: 20px 0 0;
    }


/* CHECKOUT */


.checkout-page .warning {
    margin: 0 0 20px;
}

.checkout-page .order-summary {
    margin: 50px 0 0;
}

    .checkout-page .order-summary > .title {
        margin-bottom: 10px;
        font-family: 'DM Serif Display', serif;
        font-size: 24px;
    }

        .checkout-page .order-summary > .title strong {
            font-weight: 400;
        }

.pickup-in-store,
.ship-to-same-address,
.use-reward-points {
    max-width: 600px;
    margin: 0 auto 20px;
    background-color: #f3f3f3;
    padding: 30px 15px;
    text-align: center;
}

    .pickup-in-store.additional,
    .use-reward-points {
        max-width: 600px;
        margin: 0 auto 30px;
    }

    .pickup-in-store .description {
        margin-top: 5px;
    }

.checkout-page .address-grid {
    display: grid;
    grid-gap: 25px 0;
    max-width: 600px;
    margin: auto;
}

.checkout-page .address-item {
    border: 1px solid #eee;
    padding: 30px 20px;
    text-align: center;
}

    .checkout-page .address-item.last {
        border: 1px dashed #ddd;
    }

.checkout-page .address-buttons {
    display: flex;
    justify-content: space-between;
    margin: -15px 0 15px;
    display: none; /*hidden, theme specific*/
}

.checkout-page .address-button {
    text-decoration: underline;
}

.checkout-page .address-title {
    margin-bottom: 15px;
    color: #000;
}

.checkout-page .address-box {
    margin-bottom: 20px;
    line-height: 24px;
    color: #888;
}

.checkout-page .dummy-buttons {
    min-height: 20px;
}

.checkout-page .enter-address {
    flex-grow: 1;
    display: flex;
    flex-flow: column;
}

    .checkout-page .enter-address:before {
        content: "\e91c";
        flex-grow: 1;
        display: flex;
        align-items: center;
        margin: 15px auto 30px;
        font-size: 90px;
        color: #bbb;
    }

.checkout-page .add-address-button {
    background: #eee !important;
    color: #000;
}

    .checkout-page .add-address-button:hover {
        opacity: 0.75;
    }

.checkout-page .new-address-wrapper {
    display: none;
    margin-top: 45px;
}

.checkout-page .enter-address .inputs {
    width: auto;
}

.checkout-page .cancel-address-button {
    border: 1px solid #000;
    background: none !important;
    color: #000;
}

.cancel-address-button:hover {
    border-color: #e43d51;
    color: #e43d51;
}

.select-pickup-point {
    margin: 40px 0 0;
    text-align: center;
}

    .select-pickup-point ul {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 10px 15px;
    }

    .select-pickup-point label {
        display: block;
        margin-bottom: 10px;
        font-weight: 600;
    }

.pickup-points select {
    min-width: 300px;
}

.pickup-points-map {
    height: 340px;
    margin: 25px 0 0;
}

.method-list {
    max-width: 600px;
    margin: auto;
}

    .method-list li {
        position: relative;
        margin-bottom: 10px;
        border: 1px solid #eee;
        padding: 20px;
        cursor: pointer;
    }

    .method-list .selected {
        color: #000;
    }

        .method-list .selected:before {
            content: "";
            position: absolute;
            top: 0;
            bottom: 0;
            left: 0;
            width: 5px;
            background-color: #000;
        }

    .method-list :checked + label {
        font-weight: 600;
    }

.method-description {
    margin-top: 5px;
    padding-left: 20px;
    color: #888;
}

.method-list ~ .buttons {
    margin-top: 30px;
}

.payment-info .info {
    margin: 0 0 30px;
}

.payment-info table,
.payment-info tbody,
.payment-info tr,
.payment-info td {
    display: block;
}

    .payment-info table.form {
        max-width: 600px;
        margin: 0 auto -25px;
        overflow: hidden;
    }

.payment-info .form tr {
    margin-bottom: 25px;
}

.payment-info .form input {
    width: 100% !important;
}

#ExpireMonth, #ExpireYear {
    width: 49%;
}

    #ExpireMonth + #ExpireYear {
        margin-left: 2%;
    }

.payment-info table:not(.form) {
    border: 1px solid #eee;
    padding: 30px 4%;
    text-align: center;
}

.confirm-order .terms-of-service {
    margin: 0 auto 30px; /*override shopping cart page*/
    text-align: center;
}

    .confirm-order .terms-of-service label {
        display: inline;
    }

.order-completed .title {
    margin-bottom: 15px;
}

.order-completed .details {
    margin: 0 0 30px;
    border: 1px solid #eee;
    padding: 30px 4%;
    text-align: center;
}

    .order-completed .details a {
        margin: 5px 0 0;
        text-decoration: underline;
    }

.opc .tab-section {
    margin: 0 0 10px;
    border: 1px solid #f3f3f3;
}

    .opc .tab-section.active {
        margin-bottom: 15px;
    }

.opc .step-title {
    display: flex;
    align-items: center;
    background-color: #f3f3f3;
    padding: 20px;
}

.allow:not(.active) .step-title,
.allow:not(.active) .step-title .number,
.allow:not(.active) .step-title .title {
    cursor: pointer;
}

    .allow:not(.active) .step-title:hover {
        background-color: #eee;
    }

.opc .step-title .number {
    position: relative;
    bottom: 1px;
    margin-right: 5px;
    font-family: 'DM Serif Display', serif;
    font-size: 27px;
    color: #ccc;
}

.opc .step-title .title {
    font-family: 'DM Serif Display', serif;
    font-size: 21px;
    font-weight: 400;
}

.opc .step-title .number:after {
    content: ".";
}

.opc .step.a-item {
    padding: 30px 15px;
    text-align: center;
}

.opc .section > label {
    display: block;
    margin: 0 0 10px;
}

.opc p.selector {
    line-height: normal;
}

.opc .buttons {
    display: flex;
    justify-content: center;
    margin-top: 30px;
}

.opc .back-link {
    width: 200px;
}

    .opc .back-link a {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 50px;
        border: 1px solid #000;
        padding: 0 15px;
        font-size: 14px;
        font-weight: 600;
        text-decoration: none;
    }

        .opc .back-link a:hover {
            border-color: #e43d51;
            color: #e43d51;
        }

    .opc .back-link small {
        display: none;
    }

    .opc .back-link + button {
        min-width: 0;
        width: 200px;
        margin-left: 10px;
        padding: 0 15px;
    }

.opc .please-wait {
    display: none !important;
}

.opc .min-amount-warning {
    font-size: 11px;
    color: #e31d31;
}

.opc .pickup-in-store,
.opc .ship-to-same-address,
.opc .use-reward-points {
    background: none;
    padding: 0;
}

.opc .select-pickup-point {
    margin-top: 20px;
}

.opc .method-list {
    text-align: left;
}

.opc .payment-info table {
    border: none;
    padding: 0;
}

.opc .order-summary:first-child {
    margin-top: 0;
}

.opc .terms-of-service {
    max-width: 500px;
    margin: 15px auto 0;
}


/* ORDER DETAILS & RETURN REQUEST */


.order-review-data,
.order-details-area,
.shipment-details-area {
    max-width: 600px;
    margin: 0 auto 20px;
    overflow: hidden;
}

    .order-review-data ul,
    .order-details-area ul,
    .shipment-details-area ul {
        margin: 0 0 30px;
        border: 1px solid #eee;
        padding: 30px 20px;
        line-height: 24px;
        color: #888;
    }

    .order-review-data .name,
    .order-details-area .name {
        color: #000;
    }

    .order-review-data .email,
    .order-details-area .email {
        margin-bottom: 10px;
        color: #000;
    }

.order-details-page .buttons {
    display: flex;
    justify-content: center;
    margin-bottom: 30px;
}

    .order-details-page .buttons a {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 200px;
        height: 50px;
        margin: 0 5px;
        padding: 0 15px;
        font-size: 14px;
        font-weight: 600;
    }

.print-order-button {
    background-color: #000;
    color: #fff;
}

    .print-order-button:hover {
        background-color: #e43d51;
    }

.pdf-invoice-button {
    border: 1px solid #000;
}

    .pdf-invoice-button:hover {
        border-color: #e43d51;
        color: #e43d51;
    }

.order-details-page .order-overview {
    margin: 0 0 30px;
    /*border: 1px solid #eee;
	padding: 20px 20px;*/
    text-align: center;
    line-height: 24px;
}

.order-details-page .order-number {
    text-transform: uppercase;
}

.order-details-page .order-total {
    font-weight: 600;
}

.order-details-page .retry-button {
    margin: 10px 0 5px;
    border: 1px solid #000;
    padding: 8px 12px;
}

    .order-details-page .retry-button:hover {
        border-color: #e43d51;
        color: #e43d51;
    }

.order-details-page table:not(.last) {
    margin-bottom: 50px;
}

.order-details-page .shipments
td:not(.shipment-id) label {
    display: none;
}

.order-details-page td.vendor {
    float: none;
}

.order-details-page .options {
    margin-bottom: 30px;
}

.order-details-page .cart-total {
    margin-bottom: 0 !important;
}

.order-details-page .total-info {
    margin-bottom: 0;
}

.order-details-page .actions {
    display: flex;
    justify-content: center;
    column-gap: 2%;
    margin-top: 20px;
}

.actions .re-order-button,
.actions .return-items-button {
    width: 49%;
    height: 50px;
    padding: 0 15px;
    font-size: 14px;
}

.actions .re-order-button {
    background-color: #000;
    color: #fff;
}

    .actions .re-order-button:hover {
        background-color: #e43d51;
    }

.actions .return-items-button {
    border: 1px solid #000;
}

    .actions .return-items-button:hover {
        border-color: #e43d51;
        color: #e43d51;
    }

.shipment-details-page .shipping-method {
    margin-bottom: 10px;
}

.shipment-details-page .tracking-number {
    color: #000;
}

.return-request-page .data-table {
    margin-bottom: 50px;
}

.return-request-page .unit-price,
.return-request-page .quantity {
    text-align: center;
}

.return-request-page .fieldset {
    margin-bottom: 30px;
}

.return-request-page .qq-upload-button {
    display: flex;
    align-items: center;
    width: 100%;
    height: 50px;
    border: 1px solid #ddd;
    background-color: #fff;
    padding: 0 15px;
    text-align: left;
    font-size: 13px; /*reset*/
    color: #000; /*reset*/
}

.return-request-page .qq-upload-list li {
    color: #333 !important;
    padding-bottom: 0;
    font-size: 12px;
}


/* SEARCH & SITEMAP */


.search-input .inputs.reversed {
    margin-top: -15px;
}

.search-input .search-button {
    min-width: 240px;
    height: 50px;
    background-color: #000;
    padding: 0 20px;
    font-size: 14px;
    color: #fff;
}

    .search-input .search-button:hover {
        background-color: #e43d51;
    }

.search-input ~ .product-selectors {
    margin-top: 50px;
}

.search-results .warning,
.search-results .no-result {
    display: block;
    margin-top: 30px;
    text-align: center;
    font-size: 12px;
    color: #e43d51;
}

.sitemap-page .description {
    margin: 0 0 40px;
}

.sitemap-page .entity {
    border: 1px solid #f3f3f3;
}

    .sitemap-page .entity + .entity {
        margin-top: 50px;
    }

.sitemap-page .entity-title {
    background-color: #f3f3f3;
    padding: 15px;
    font-family: 'DM Serif Display', serif;
}

    .sitemap-page .entity-title h2 {
        font-size: 20px;
        font-weight: 400;
    }

.sitemap-page .entity-body {
    padding: 15px;
    line-height: 24px;
}

.sitemap-page li {
    display: inline-block;
    margin: 3px;
}

    .sitemap-page li:after {
        content: "/";
        margin-left: 8px;
        color: #888;
    }

.sitemap-page a:empty {
    display: none;
}


/* BLOG & NEWS */


.year strong {
    display: block;
    padding: 5px 0;
    color: #000;
    cursor: default;
}

.blog-posts .post + .post,
.news-items .news-item + .news-item {
    margin-top: 40px;
}

.post-title, .news-title {
    display: inline-block;
    margin: 0 0 20px;
    font-family: 'DM Serif Display', serif;
    font-size: 22px;
}

.post-date, .news-date {
    display: block;
    margin: 0 0 20px;
    font-size: 12px;
    color: #aaa;
}

.post-body, .news-body {
    margin: 0 0 20px;
    text-align: left;
    line-height: 24px;
}

.blog-details {
    display: flex;
    flex-flow: row-reverse;
    justify-content: flex-end;
    column-gap: 15px;
}

    .blog-details .tags {
        display: flex;
        margin: 0;
    }

        .blog-details .tags:before {
            content: "/";
            position: relative;
            bottom: -1px;
            margin: 0 10px 0 -2px;
            font-size: 15px;
            color: #aaa;
        }

.blog-page .tags {
    text-align: left;
}

.blogpost-page .tags {
    margin: 30px 0 0;
}

    .blog-page .tags label,
    .blogpost-page .tags label {
        display: none;
    }

    .blog-page .tags ul,
    .blogpost-page .tags ul {
        display: flex;
        flex-wrap: wrap;
    }

    .blog-page .tags li,
    .blogpost-page .tags li {
        font-size: 12px;
    }

        .blog-page .tags li.separator,
        .blogpost-page .tags li.separator {
            margin: 0 5px 0 3px;
        }

    .blog-page .tags a,
    .blogpost-page .tags a {
        text-decoration: underline;
    }

.read-comments:before {
    content: "\e91f";
    font-size: 18px;
    vertical-align: middle;
    margin-right: 5px;
}

.blog-posts .read-more,
.news-items .read-more {
    display: none;
}

    .blog-posts .read-more:after,
    .news-items .read-more:after {
        content: "\e915";
        margin-left: 8px;
        vertical-align: middle;
    }

.new-comment {
    margin: 50px 0 0;
}

    .new-comment .title {
        margin-bottom: 15px;
    }

    .new-comment .notifications {
        margin: 0 0 10px;
    }

    .new-comment .inputs label {
        display: none;
    }

.news-item-page .inputs label {
    display: block;
}

.new-comment .button-1 {
    min-width: 240px;
    height: 50px;
    background-color: #000;
    padding: 0 20px;
    font-size: 14px;
    color: #fff;
}

    .new-comment .button-1:hover {
        background-color: #e43d51;
    }

.comment-list {
    margin: 50px 0 0;
}

    .comment-list .title {
        margin: 0 0 15px;
        text-align: center;
        font-size: 15px;
    }

.comment.blog-comment,
.comment.news-comment {
    margin: 0 0 -1px;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
    padding: 20px 0;
}

.comment-info .user-info {
    display: flex;
    flex-flow: column-reverse;
    row-gap: 5px;
    margin: 5px 0 15px;
}

.comment-info .username {
    word-break: break-all;
    font-size: 12px;
    color: #888;
}

.comment-info .avatar {
    font-size: 0;
}

    .comment-info .avatar a {
        display: block;
    }

.comment-content {
    display: flex;
    flex-flow: column;
}

.comment-author {
    font-size: 12px;
    font-weight: 600;
}

.comment-time {
    margin: 15px 0;
    font-size: 12px;
    color: #888;
}

    .comment-time label {
        display: none;
    }

.comment-title {
    display: none;
}

.comment-body {
    text-align: left;
    color: #666;
}

.news-list-homepage .title {
    display: none;
}

.news-list-homepage .read-more {
    display: inline;
}

.news-list-homepage .view-all {
    margin: 30px 0 0;
    text-align: center;
}

    .news-list-homepage .view-all a {
        display: inline-block;
        border: 1px solid #000;
        padding: 10px 20px;
        font-size: 14px;
        font-weight: 600;
    }

        .news-list-homepage .view-all a:hover {
            border-color: #e43d51;
            color: #e43d51;
        }

/* PROFILE & INBOX */

.profile-info-box {
    text-align: center;
}

    .profile-info-box .avatar {
        margin: 0 0 5px;
        font-size: 0;
    }

        .profile-info-box .avatar img {
            border: 1px solid #eee;
        }

    .profile-info-box .title {
        display: none;
    }

    .profile-info-box .stats {
        line-height: 24px;
    }

    .profile-info-box .send-pm {
        margin: 15px 0 5px;
    }

    .profile-info-box .pm-button {
        display: inline-block;
        min-width: 120px;
        border: 1px solid #000;
        padding: 10px 20px;
        font-size: 14px;
        font-weight: 600;
    }

        .profile-info-box .pm-button:hover {
            border-color: #e43d51;
            color: #e43d51;
        }

.profile-page .topic + .topic {
    margin-top: 15px;
}

.profile-page .topic-title {
    margin: 0 0 10px;
    text-align: center;
    font-size: 15px;
    font-weight: 600;
}

    .profile-page .topic-title label {
        display: none;
    }

.profile-page .topic-body {
    text-align: left;
    line-height: 24px;
    color: #888;
}

    .profile-page .topic-body .hide {
        display: none;
    }

    .profile-page .topic-body .quote {
        background-color: #f3f3f3;
        padding: 15px 20px;
    }

.profile-page .quote:before {
    content: '"';
}

.profile-page .quote:after {
    content: '"';
}

.profile-page .topic-data {
    margin: 15px 0 0;
}

.private-messages .inputs a,
.private-messages .inputs span,
.forum-edit-page .inputs strong {
    font-size: 14px;
    font-weight: 400;
}

.private-messages .inputs a {
    text-decoration: underline;
}

.private-messages .buttons,
.forum-edit-page .buttons,
.move-topic-page .buttons {
    display: flex;
    justify-content: center;
}

.private-messages button,
.forum-edit-page button,
.move-topic-page button {
    width: 200px;
    height: 50px;
    margin: 0 5px;
    padding: 0 20px;
    font-size: 14px;
}

.private-messages .button-1,
.forum-edit-page .button-1,
.move-topic-page .button-1 {
    background-color: #000;
    color: #fff;
}

.private-messages .button-2,
.forum-edit-page .button-2,
.move-topic-page .button-2 {
    border: 1px solid #000;
}

.private-messages .button-1:hover,
.forum-edit-page .button-1:hover,
.move-topic-page .button-1:hover {
    background-color: #e43d51;
}

.private-messages .button-2:hover,
.forum-edit-page .button-2:hover,
.move-topic-page .button-2:hover {
    border-color: #e43d51;
    color: #e43d51;
}

.private-messages-page th,
.private-messages-page td {
    text-align: left;
}

.private-messages-page .from a,
.private-messages-page .to a {
    word-break: break-word;
}

.private-messages-page .select input {
    margin: 0;
    opacity: 1;
}

.private-messages-page .date {
    display: none;
}

.private-messages-page .pm-unread {
    text-decoration: underline;
    color: #e43d51;
}

.private-messages-page .pager {
    margin: -31px 0 30px;
}

.private-message-view-page .view-message {
    margin: 0 0 30px;
    border: 1px solid #eee;
    padding: 3% 3%;
}

.private-message-view-page .message-head {
    margin-bottom: 3%;
    border-bottom: 1px solid #eee;
    padding-bottom: 3%;
    line-height: 24px;
}

    .private-message-view-page .message-head label {
        color: #aaa;
    }

.private-message-view-page .message-body {
    padding: 5px;
    text-align: left;
    line-height: 24px;
    color: #888;
}

.private-message-view-page .back-pm-button {
    display: none;
}

/*.order-details-page .data-table label {
    display: none;
}*/


.pdf-invoice-button {
    border: none;
    background-color: #000;
    padding: 10px 8px;
    font-size: 14px;
    color: #fff;
}

    .pdf-invoice-button:hover {
        background-color: #e43d51;
        color: #fff !important;
    }

.labelprice-input {
    width: 90px;
    text-align:center;
}

/*.otsrating-attributes {
    margin-top: 10px;
    display: inline-block;
}*/

.outstandingqty-attribute {
    padding-top: 10px;
    overflow-wrap: break-word;
    white-space: normal;
}

button.remove-btn {
    background: none;
}

td.product a.product-name {
    padding-top: 10px;
}


.header-links a.ico-account {
    text-transform: capitalize;
    padding: 0px 10px;
    margin-left: 15px;
    border-left: 1px solid #ccc;
    padding-left: 15px;
}


.table-wrapper table thead tr {
    background-color: #959595;
    border-radius: 10px 10px 0px 0px;
    border: none;
}

    .table-wrapper table thead tr th {
        color: #fff !important;
        font-size: 0.8rem;
        white-space: nowrap;
        /*min-width: 90px;*/
    }

.table-wrapper table tbody tr {
    background: #fff;
}

    .table-wrapper table tbody tr td {
        color: #808080;
        /*white-space: nowrap !important;*/
    }

    .table-wrapper table tbody tr:nth-child(even) {
        background-color: #f7f7f7;
    }

.table-wrapper {
    text-align: center;
}

.table-wrapper {
    overflow: auto;
}

.products .table-wrapper {
    overflow: auto;
}

.table-wrapper {
    overflow-x: auto;
    overflow-y: auto;
    min-height: 100%;
    max-height: 450px;
}

    .table-wrapper table thead tr:first-child {
        position: sticky;
        top: 0px;
        right: 0px;
        z-index: 9;
    }

    .table-wrapper table thead tr {
        position: relative;
    }


.cart .remove-from-cart {
    position: static !important;
}

    .cart .remove-from-cart button {
        position: static !important;
    }

.wishlist-content {
    overflow-x: auto;
    overflow-y: auto;
    min-height: 100%;
    max-height: 450px;
}

    .wishlist-content table thead tr {
        position: relative;
        background-color: #959595;
    }

        .wishlist-content table thead tr th {
            color: #fff !important;
        }


        .wishlist-content table thead tr:first-child {
            position: sticky;
            top: 0px;
            right: 0px;
            z-index: 9;
        }

.products .table-wrapper table thead tr th {
    /*white-space: nowrap !important;*/
    padding: 15px 4px;
    text-wrap: balance;
}

.order-summary-content .table-wrapper table thead tr th {
    white-space: inherit;
    min-width: 50px;
    max-width: 80px;
    padding-right: 10px;
}

.table-wrapper .erptablelist thead tr th {
    background-color: #959595 !important;
    border: none;
}

.table-wrapper .data-table thead tr th {
    min-width: auto;
    width: auto;
    text-wrap: balance;
}

.erptablelist thead tr th:first-child {
    min-width: 120px;
    max-width: 150px;
}

.compare-products-page .table-wrapper {
    max-height: 100%;
}

table.dataTable thead th, table.dataTable thead td {
    padding: 10px 18px;
    border-bottom: 1px solid #ddd;
    background-color: #959595 !important;
    color: #fff;
}

.PrePricingDetailsBlock {
    overflow: auto;
}

input.updatelines-btn {
    margin: 5px 0px;
}


.products-wrapper .table-wrapper table tbody tr td {
    white-space: inherit !important;
    padding: 0px !important;
}

.products-wrapper .table-wrapper .erptablelist thead tr th:first-child {
    min-width: 80px !important;
    max-width: 100px !important;
}

.products-wrapper .table-wrapper table thead tr th {
    color: #fff !important;
    font-size: 0.8rem;
    white-space: inherit !important;
    min-width: 60px !important;
}

.products-wrapper .table-wrapper .erptablelist th {
    padding:5px;
}

.products-container .ajax-products-busy {
    display: none;
    position: fixed;
    right: 0px;
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    background: rgb(0 0 0 / 50%) url(../img/loading.gif) center no-repeat;
    bottom: 0px;
    z-index: 9999;
}
.updatesaleslinesbtn {
    padding-left: 100px;
}

.product-grid .item-grid .item-box .product-title a {
    display: inline-block;
    width: 240px;
    max-width: 100%;
}

.QtytoShip ~ label {
    padding: 0px 20px 0px 20px !important;
}