.shop-padding {
    padding: 20px 4vw;
}

.woocommerce a.added_to_cart {
    display: none;
}

.woocommerce-notices-wrapper .woocommerce-message {
    text-align: center;
    padding: 20px 0;
    background: #f1f1f1;
    border-radius: 10px;
    margin: 20px 0;
}

.woocommerce-notices-wrapper .woocommerce-message .button {
    display: block;
    max-width: 200px;
    margin: 15px auto;
}

.woocommerce-NoticeGroup-updateOrderReview {
    margin: 30px 0;
    font-weight: bold;
}

ul.woocommerce-error {
    margin: 20px 0;
    padding: 20px;
    background: #ffe0e0;
    font-weight: bold;

}

ul.woocommerce-error li {
    list-style: none;
}

.woocommerce .quantity .qty {
    padding: 11px 5px;
    border: none;
    display: block;
    text-align: center;
    -moz-appearance: textfield;
}

.woocommerce .quantity .qty::-webkit-outer-spin-button,
.woocommerce .quantity .qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.sf-quantity-buttons {
    width: 150px;
    display: grid;
    grid-template-columns: 50px 50px 50px;
    align-items: center;
    text-align: center;
    border: 1px solid #eeeeee;
}

.product.sold-individually .sf-quantity-buttons {
    display: none;
}

.woocommerce-variation-add-to-cart .sf-quantity-buttons {
    float: left;
    margin-right: 4px;
}

.sf-quantity-buttons .quantity {
    border-right: 1px solid #eeeeee;
    border-left: 1px solid #eeeeee;
}

.sf-quantity-buttons .quantity label {
    display: none;
}

.product-qty-button {
    display: block;
    cursor: pointer;
}

.seaflora-shop-header-notice {
    padding: 15px 4vw;
    text-align: center;
    font-style:italic;
    font-size:calc(11px + 0.3vw);
    background:#101010;
    color:#f1f1f1;
    position: relative;
    z-index: 10;
}


/* ==== CART MENU ==== */

.cart-contents {
    position: relative;
}

.cart-contents:before {
    position: relative;
    top: -2px;
    margin: 0 auto;
    content: "";
    display: block;
    vertical-align: middle;
    background-size: 20px 20px;
    background-image: url("../../icons/shopping-bag.svg");
    background-repeat: no-repeat;
    background-position: center;
    width: 20px;
    height: 20px;
}

.cart-contents:hover {
    text-decoration: none;
}
.cart-contents-count {
    display: block;
    color: #101010;
    border-radius: 50%;
    line-height: 1;
    width: 15px;
    height: 15px;
    font-size: 12px;
    width: 100%;
    bottom: 1px;
    position: absolute;
    text-align: center;
}

.seaflora-product-loop-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    transition: all 0.4s ease 0s;
    -webkit-transition: all 0.4s ease 0s;
    -moz-transition: all 0.4s ease 0s;
}

.seaflora-product-loop-buttons {
    width: 100%;
    max-width: 200px;
    text-align: center;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 0.33fr));
    align-items: center;
    justify-content: center;
}

.woocommerce ul.products li.product .seaflora-product-loop-button .button {
    margin: 0;
    padding: 10px;
    border: none;
    border-radius: 50%;
    background: #FBF9F9;
}

.woocommerce ul.products li.product:hover > a.woocommerce-LoopProduct-link {
    overflow: hidden;
}

.woocommerce ul.products li.product:hover > a.woocommerce-LoopProduct-link img.attachment-woocommerce_thumbnail {
    display: none;
}

.sf-product-hover-image, .woocommerce ul.products.slick-slider li a.woocommerce-LoopProduct-link img.sf-product-hover-image {
    display: none;
}

.woocommerce ul.products li.product:hover > a.woocommerce-LoopProduct-link img.sf-product-hover-image {
    display: inline;
    transform: scale(1.5);
    -webkit-transform: scale(1.5);
    -moz-transform: scale(1.5);
}

.woocommerce ul.products li.product .seaflora-product-loop-button .ajax_add_to_cart .dashicons-cart,
.woocommerce ul.products li.product .seaflora-product-loop-button .ajax_add_to_cart .dashicons-update {
    display: none;
}

.woocommerce ul.products li.product .seaflora-product-loop-button .ajax_add_to_cart.loading > .dashicons-update {
    display: inline-block;
    -webkit-animation: spin 4s infinite linear;
    animation: spin 4s infinite linear;
}

@-moz-keyframes wcloadingspin {
    from { -moz-transform: rotate(0deg); }
    to { -moz-transform: rotate(360deg); }
}
@-webkit-keyframes wcloadingspin {
    from { -webkit-transform: rotate(0deg); }
    to { -webkit-transform: rotate(360deg); }
}
@keyframes wcloadingspin {
    from {transform:rotate(0deg);}
    to {transform:rotate(360deg);}
}

.woocommerce ul.products li.product .seaflora-product-loop-button .ajax_add_to_cart.added > .dashicons-cart {
    display: inline-block;
}

.woocommerce ul.products li.product .seaflora-product-loop-button .ajax_add_to_cart.added > .dashicons-plus-alt2,
.woocommerce ul.products li.product .seaflora-product-loop-button .ajax_add_to_cart.loading > .dashicons-plus-alt2 {
    display: none;
}

.woocommerce ul.products li.product .seaflora-product-loop-button .ajax_add_to_cart.added:after {
    margin-left: 0;
}

/* ==== BUTTONS ==== */

.woocommerce ul.products li.product .button {
    background: #ffffff;
    color: #101010;
}

.woocommerce ul.products li.product .button, .woocommerce a.button.members-link {
    background:#ffffff;
}

.woocommerce ul.products li.product .button:hover {
    background: #101010;
    color: #ffffff;
}

/* ==== WOOCOMMERCE PRODUCT LOOP * ==== */

.woocommerce ul.products {
    width: 100%;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 0.5fr));
}

.woocommerce ul.products.slick-slider {
    display: block;
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

.woocommerce ul.products li {
    list-style: none;
    margin: 0;
    padding: 20px;
    position: relative;
    text-align: center;
}

.woocommerce ul.products.slick-slider li {
    padding: 0;
    margin: 0 10px;
}

.woocommerce ul.products.slick-slider li a.woocommerce-LoopProduct-link img {
    display: inline-block;
}

.woocommerce ul.products li > a.woocommerce-LoopProduct-link {
    display: block;
    position: relative;
}

.woocommerce ul.products li > a.woocommerce-LoopProduct-link img {
    transition: all 0.4s ease 0s;
    -webkit-transition: all 0.4s ease 0s;
    -moz-transition: all 0.4s ease 0s;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    color: #101010;
    font-weight: 300;
    font-size: 14px;
}

.product-loop-category-link {
    margin: 0 0 10px;
    font-size: 15px;
}

.product-loop-category-link a {
    color: #565656;
}

/* ==== FILTERING PRODUCTS ==== */

.woocommerce-notices-wrapper {
    clear: both;
}

.seaflora-shop-filtering-box {
    overflow: hidden;
    padding: 10px;
    margin-bottom: 10px;

}
.woocommerce-result-count {
    text-align: center;
    margin: 0;
    font-size: 15px;
}

.seaflora-shop-filtering-box .woocommerce-ordering {
    margin: 0;
    text-align: center;
}

.seaflora-shop-filtering-box .woocommerce-ordering select {
    text-align: center;
    padding: 0;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 15px;
}

.seaflora-shop-filtering-box .woocommerce-ordering:after {
    content: "\f347";
    font-family: dashicons;
    display: inline-block;
    vertical-align: middle;
    line-height: 1.2;
}

/* ==== BADGES ==== */
.seaflora-custom-badge,
.woocommerce span.onsale {
    position:absolute;
    top: 15px;
    right: 0;
    width: 70px;
    padding: 10px;
    overflow: hidden;
    z-index: 10;
    color: #ffffff;
    line-height: 1;
    font-size: 14px;
    text-align: center;
}

.woocommerce span.onsale {
    background: #5ccad6;
}

.seaflora-custom-badge.new {
    background: #77a464;
}

.seaflora-custom-badge.award-winning {
    background: gold;
}

.seaflora-custom-badge.out-of-stock {
    background: #898988;
}

.woocommerce ul.products li.product .star-rating {
    margin: 20px auto;
}

.star-rating .star-full:before {
content: "\f155";
}

.star-rating .star-half:before {
content: "\f459";
}

.star-rating .star-empty:before {
content: "\f154";
}

.star-rating .star {
    color: #34A798;
    display: inline-block;
    font-family: dashicons;
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    height: 20px;
    line-height: 1;
    text-align: center;
    text-decoration: inherit;
    vertical-align: top;
    width: 20px;
}

.woocommerce-pagination {
    text-align: center;
    margin: 25px auto;
}

.woocommerce-pagination ul {
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: center;
}

.woocommerce-pagination ul li {
    list-style: none;
    margin: 0 4px;
    padding: 0;
}

.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span.page-numbers.current {
    display: block;
    padding: 20px;
    background: #f1f1f1;
    font-size: 20px;
    line-height: 1;
}

.woocommerce-pagination ul li span.page-numbers.current {
    background: #101010;
    color: #ffffff;
}

.quick-view-sku {
    margin-bottom: 5px;
    color: #989898;
}

.button.quick-view-button {
    font-size: 14px;
    background: #101010;
    color: #ffffff;
}

.button.quick-view-button:hover {
    background: #ffffff;
    color: #101010;
}

.quick-view-added {
    margin-top: 15px;
    padding: 10px;
    background: #eeeeee;
    color: #989898;
    text-align: center;
    display: none;
}

.quick-view-added.show {
    display: block;
}

.woocommerce ul.products li.product .seaflora-product-loop-button .button.add-to-wish-list.added {
    background: #101010;
    color: #ffffff;
}

/* ==== SUBSCRIPTIONS ==== */


.wcsatt-sub-options,
.product-list-desc .wcsatt-sub-options {
    /*display: none;*/
}

.woocommerce ul.products li.product .wcsatt-sub-options {
    display: block;
    margin-top: 5px;
}
.woocommerce ul.products li.product .wcsatt-sub-options .wcsatt-dash {
    display: none;
}


/* ==== SEAONAL CATEGORIES ==== */

.term-sub-suggestions ul.products li.product-category {
    border-bottom: none;
}

.term-sub-suggestions ul.products li.product-category a img {
    opacity: 0.75;
}

.term-sub-suggestions ul.products li.product-category:hover > a img {
    opacity: 1;
}

.term-sub-suggestions ul.products li.product-category h2.woocommerce-loop-category__title {
    font-weight: bold;
    font-size: 20px;
}

.term-sub-suggestions .product-category mark {
    background: none;
    display: none;
}

.seaflora-sub-category-section {
    overflow: hidden;
    clear: both;
    display: none;
}

p.sf-sub-section-description {
    margin: 0 0 40px;
    font-style:italic;
    font-size: 15px;
    padding: 15px;
    background: #fafafa;
    border-left: 4px solid #eeeeee;
}

.seaflora-sub-category-section.active {
    display: block;
}

h3#seaflora-sub-section-title {
    font-weight: bold;
    margin: 0;
    padding: 20px 0;
    border-bottom: 4px solid #eeeeee;
}

.seaflora-sub-category-section-tabs {
    display: flex;
    margin: 10px 0;
    align-items: center;
    overflow-x: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.seaflora-sub-category-section-tabs::-webkit-scrollbar {
    display: none;
    width: 0;
    background:transparent;
}

.exfoliant-guide {
    padding: 15px;
    margin-bottom: 40px;
}
.exfoliant-guide ul {
    display: flex;
    margin: 20px 0;
    padding: 0;
}
.exfoliant-guide ul li {
    list-style: none;
    display: block;
    padding: 10px 15px;
    text-align: center;
    background: #fafafa;
    margin-right: 5px;
    border-left: 2px solid #eeeeee;
    font-size: 14px;
}

.sf-filter-icon {
    margin: 0 5px;
}

.seaflora-sub-category-tab {
    padding: 10px 15px;
    text-align: center;
    background: #fafafa;
    margin-right: 5px;
    border-radius: 20px;
    cursor: pointer;
    border: 1px solid #eeeeee;
    color: #ababab;
    font-size: 14px;
    white-space: nowrap;
}

.seaflora-sub-category-tab.active {
    color: #34A798;
    font-weight: bold;
}

.seaflora-sub-category-tab:hover {
    color: #34A798;
}

/* === GIFT CARDS === */

.add_gift_card_form {
    margin-top: 20px;
}

.woocommerce-checkout-review-order .button[name="apply_coupon"] {
    margin: 0;
}

.add_gift_card_form #wc_gc_cart_redeem_form button {
    display: inline-block;
    width: auto !important;
    padding: 15px 20px;
    font-size: 16px;
    text-align: center;
    cursor: pointer;
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    transition: all .2s linear;
    -webkit-transition: all .2s linear;
    -moz-transition: all .2s linear;
    -ms-transition: all .2s linear;
    line-height: 1;
    border-radius: 0;
    border: 1px solid #101010;
    background: #101010;
    color: #ffffff;
}

.add_gift_card_form #wc_gc_cart_redeem_form input[type=text] {
    display: inline-block;
    width: auto;
}

.add_gift_card_form #wc_gc_cart_redeem_form button:hover {
    background: #ffffff;
    color: #101010;
}

#wcdp_va_amount {
    margin: 1.5em 0;
}

#wcdp_va_amount .wcdp-variation-heading {
    margin: 10px 0;
    display: block;
}

.wcdp-divider, .wcdp-body svg.wcdp-divider-arrow {
    display: none;
}

button#place_order {
    margin: 15px 0;
}

@media screen and (min-width: 600px) {
.woocommerce-result-count {
    width: 50%;
    float: left;
    text-align: left;
}

.seaflora-shop-filtering-box .woocommerce-ordering {
    width: 50%;
    float: right;
    text-align: right;
}
.seaflora-shop-filtering-box .woocommerce-ordering select {
    text-align: right;
}
.woocommerce ul.products li.product .seaflora-product-loop-button .button {
    padding: 15px;
}

.seaflora-sub-category-tab {
    font-size: 16px;
}

}

@media screen and (min-width: 768px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(2, minmax(0, 0.5fr));
    }

}

@media screen and (min-width: 960px) {
    .shop-padding {
        padding: 50px 4vw;
    }
    .woocommerce ul.products li.product .woocommerce-loop-product__title {
        font-size: 16px;
    }
    .woocommerce ul.products {
        grid-template-columns: repeat(3, minmax(0, 0.3333fr));
    }

    .seaflora-featured-product-list .woocommerce ul.products.columns-4 {
        grid-template-columns: repeat(4, minmax(0, 0.25fr));
    }
}

@media screen and (min-width: 1800px) {
    .woocommerce ul.products.columns-4 {
        grid-template-columns: repeat(4, minmax(0, 0.25fr));
    }
}
