/*!
	Package:          Cherish Local CSS for WooCommerce
	Author:           Christina Arasmo Beymer
	Author URI:       https://christinacreativedesign.com
	Version:          1.0.0
	License:          GPLv3 or later
	License URI:      https://www.gnu.org/licenses/gpl-3.0.en.html
	Copyright:        (c) 2016 Christina Arasmo Beymer | ChristinaCreativeDesign.com.
	Attribution:      Copyright Notice/license information must stay intact for legal use as per section 7 (b)
*/

/*  ------------------ TOC --------------------------------------------------

See: rtl.css for Right to left language styles specifically.

- Site Wide Notice / WooCommerce > Settings > General
- Download / Completed Order Page
- Single Page Header
- My Account 
- On Sale
- Product Single
- WooCommerce Product Meta
- WooCommerce Shop Page Ordering Select
- Price
- PrettyPhoto
- Previous Next Product Links
- Shop/Archive Top Results Pagination
- Product Archive & Content Widget
- Fluid Product Columns
- Up-sells/Cross Sells Related
- Product Tabs (they were never responsive)
- Page Header
- General Typography
- Messages
- Forms
- Payment Box
- Cart
- Table Styles
- Product Variations
- Buttons
- Checkout Page
- Widgets

------------------ end TOC --------------------------------------------- */



/* ## Site Wide Notice / WooCommerce > Settings > General
 * this has the class .page-main-section -- all styles 
 * pertaining to color are set there
----------------------------------------------------------- */

.cherish-woocommerce-store-notice {
    display: none;
    padding: 0px;
    font-size: 14px;
    letter-spacing: .5px;
    line-height: 1.5;
    margin: 0;
    box-shadow: none;
    font-family: inherit;
    width: 100%;
    position: fixed;
    z-index: 200;
    top: 0;
    text-align: center;
}

.cherish .cherish-woocommerce-store-notice * {
    margin-bottom: 0
}

.cherish-woocommerce-store-notice > div {
    padding: 10px 50px
}

.woocommerce-demo-store a.store-notice-dismiss-link {
    display: block;
    line-height: .8;
    font-size: 25px;
    position: absolute;
    right: 0;
    top: 50%;
    margin-top: -10px;
    padding: 0 10px;
    cursor: pointer;
    text-decoration: none;
    border-bottom: none;
}


/* ## Download / Completed Order Page
--------------------------------------------- */

.woocommerce-thankyou-order-received {
    font-weight: bold;
    font-size: 30px;
    text-align: center;
}

.woocommerce-order-received .entry-content > .woocommerce  h2,
.woocommerce-order-received .entry-content > .woocommerce  h3 {
    font-size: 20px;
    border-bottom: 2px solid #222;
    padding: 10px 0;
    text-transform: uppercase;
}

.woocommerce-thankyou-order-details {
    padding: 20px;
    background: #f7f7f7;
    text-align: center;
}

.woocommerce .woocommerce-thankyou-order-details li {
    margin: 0;
    padding: 10px;
    float: none;
    display: block;
    border: none;
}

@media (min-width: 800px) { 
	.woocommerce .woocommerce-thankyou-order-details li {
	    padding: 0 5%;
	    display: inline-block;
	    text-align: left;
	}
}

.woocommerce table.shop_table td {
    vertical-align: top
}

.woocommerce table.shop_table td small {
    font-weight: bold;
    font-size: 20px;
    margin-top: 5px;
    padding: 5px 15px;
    display: inline-block;
    background: #fff;
    border: 2px solid #222;
    border-radius: 3px;
}


/* ## Single Page Header
--------------------------------------------- */

.page-header .woocommerce-product-rating {
    text-align: center
}

.page-header .woocommerce-product-rating .star-rating {
    display: inline-block;
    float: none;
    margin: 0;
}

.page-header .woocommerce-product-rating .star-rating:before {
    color: #fff
}

.page-header .price ins .amount,
.summary .price {
    font-weight: bold
}

.woocommerce .price ins,
.woocommerce ins,
.woocommerce-Price-amount.amount {
    text-decoration: none!important
}

.page-header .price {
    margin: 0
}

@media (min-width: 700px) { 
	.page-header .price {
	    font-size: 22px
	}
}


/* ## My Account 
--------------------------------------------- */

nav.woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

nav.woocommerce-MyAccount-navigation a {
    text-decoration: none;
    padding: 10px 0;
    display: block;
    border-bottom: 0px!important;
}

nav.woocommerce-MyAccount-navigation .is-active a {
    font-weight: bold
}

.woocommerce-account .woocommerce-MyAccount-content {
    float: right;
    width: 68%;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    float: left;
    width: 25%;
    padding: 20px 20px 30px;
    margin-bottom: 30px;
}

@media (max-width: 1000px) { 
	.woocommerce-account .woocommerce-MyAccount-content,
	.woocommerce-account .woocommerce-MyAccount-navigation {
	    float: none;
	    width: 100%;
	}
}

.woocommerce-MyAccount-content > p:first-child {
    font-size: 20px
}


/* ## On Sale
--------------------------------------------- */

.woocommerce .product .onsale {
    z-index: 5;
    text-align: center;
    line-height: 30px;
    font-size: 14px;
    border-radius: 0px;
    box-shadow: inset 2px 2px 0px 0px rgba(255,255,255,0.4), inset -2px -2px 0px 0px rgba(255,255,255,0.4);
    width: 200px;
    min-height: 0px;
    min-width: 0px;
    padding: 0;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.woocommerce .product .onsale,
.woocommerce ul.products li.product .onsale {
    top: 15px;
    left: -70px;
}

.woocommerce ul.products li.product .onsale {
    left: -75px;
    font-size: 11px;
}

.woocommerce ul.products li.product a:first-of-type,
.woocommerce.single-product .entry {
    position: relative;
    overflow: hidden;
    padding: 2px;
}


/* ## Product Single
--------------------------------------------- */

.cherish .woo-summary-container {
    margin-left: auto;
    margin-right: auto;
    max-width: 500px;
    position: relative;
    overflow: hidden;
    padding: 1px;
}

@media (min-width:1000px) { 
	.cherish .woo-summary-container {
	    max-width: none
	}
}

.product_meta {
    text-transform: uppercase;
    font-size: 12px;
}

.product_meta a:not(:hover) {
    text-decoration: none;
    border-bottom: 1px dotted #222;
}

.woocommerce #content div.product div.summary,
.woocommerce div.product div.summary,
.woocommerce-page #content div.product div.summary,
.woocommerce-page div.product div.summary {
    float: none;
    width: 100%;
}

.woocommerce #content div.product div.images,
.woocommerce div.product div.images,
.woocommerce-page #content div.product div.images,
.woocommerce-page div.product div.images {
    float: none;
    width: 100%;
}

@media (min-width:1000px) { 
	.woocommerce #content div.product div.summary,
	.woocommerce div.product div.summary,
	.woocommerce-page #content div.product div.summary,
	.woocommerce-page div.product div.summary {
	    float: right;
	    padding-left: 15px;
	    width: 50%;
	}

	.woocommerce #content div.product div.images,
	.woocommerce div.product div.images,
	.woocommerce-page #content div.product div.images,
	.woocommerce-page div.product div.images {
	    float: left;
	    width: 50%;
	    padding-right: 15px;
	}
}

/* WC 2.6 thumbnails */

body.woo-legacy.cherish .woo-summary-container .thumbnails {
    text-align: center;
    font-size: 0;
    margin-bottom: 5px;
}

body.woo-legacy.cherish .woo-summary-container .thumbnails img {
    display: block;
}

body.woo-legacy.cherish .woo-summary-container .thumbnails a {
    margin: 5px 2.5px 0;
    float: none;
    display: inline-block;
    width: auto;
    max-width: 45px;
}


/* WC 2.7 single product image */

body.woo-2-7.cherish .product .images .woocommerce-product-gallery__trigger {
	right: 30px;
	box-shadow: -2px -2px 0px 0px rgba(0,0,0,0.1), inset -2px -2px 0px 0px rgba(0,0,0,0.1);
}

body.woo-2-7.cherish .woocommerce-product-gallery .flex-control-nav.flex-control-thumbs {
	padding-top: 5px;
}

body.woo-2-7  .woo-summary-container .woocommerce-product-gallery .flex-control-nav.flex-control-thumbs {
	margin-left: -2.5px;
	margin-right: -2.5px;
}

body.woo-2-7 .woo-summary-container .woocommerce-product-gallery .flex-control-nav.flex-control-thumbs > li {
	padding: 0 2.5px 5px;
	width: 20%;
}

body.woo-2-7.single-product .images {
	opacity: 0;
	transition: opacity .5s linear;
}


/* ## WooCommerce Product Meta
--------------------------------------------- */

.product_meta {
    margin-top: -20px;
    margin-bottom: 20px;
}

.product_meta > span {
    display: block
}


/* ## WooCommerce Shop Page Ordering Select
--------------------------------------------- */

.page-sorting-wrapper {
    position: relative;
    max-width: 1200px;
    width: 90%;
    margin: 20px auto 0;
}

.woocommerce-page .woocommerce-ordering {
    padding: 0;
    position: relative;
    font-size: 12px;
    border-radius: 3px;
    width: 100%;
    max-width: 400px;
    overflow: hidden;
    float: none;
    margin: 0 auto;
}

.woocommerce-page .woocommerce-ordering select option { 
    padding: 2px;
}

form.woocommerce-ordering:after {
    font-family: 'FontAwesome';
    content: "\f107";
    position: absolute;
    right: 10px;
    font-size: 14px;
    line-height: 1;
    z-index: 5;
    top: 50%;
    margin-top: -7px;
}

form.woocommerce-ordering select.orderby {
    padding: 7px;
    z-index: 5;
    position: relative;
    width: 100%;
    border: none;
    box-shadow: none;
    background-image: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}


/* ## Price
--------------------------------------------- */

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    color: #222;
    font-size: 1.25em;
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
    background: inherit;
    font-weight: 700;
}

.woocommerce div.product .stock,
.woocommerce ul.products li.product .price {
    color: #222
}

.woocommerce div.product .out-of-stock {
    color: #e01700 /* out of stock */
}

.woocommerce ul.products li.product .price del {
    display: inline
}

.woocommerce p.stock.in-stock {
    font-weight: bold
}


/* ## PrettyPhoto
--------------------------------------------- */

.single-product.woocommerce.woocommerce-page > .pp_pic_holder.pp_woocommerce > .ppt[style] {
    display: none!important
}

div.pp_left > div.pp_right > div.pp_content > div.pp_fade > div.pp_details > div.pp_nav > p.currentTextHolder {
    margin: 0;
    line-height: normal;
    color: #fff;
    font-family: sans-serif;
    text-align: center;
}

div.pp_woocommerce .pp_content_container {
    background-color: transparent;
    box-shadow: none;
}

.pp_gallery ul {
    height: 60px
}

.pp_gallery ul a {
    border: 1px solid #222;
    border: 1px solid rgba(0,0,0,.5);
    border-radius: 0px;
    display: block;
    float: left;
    height: 50px;
    position: relative;
    overflow: hidden;
}

.pp_gallery > div {
    top: -10px
}

.pp_gallery ul a img {
    max-width: none!important;
    position: absolute;
    width: 180%;
    left: -50%;
}

.pp_gallery ul a {
    position: relative;
    width: 50px;
}

@media (max-width:768px) { 
	div.pp_woocommerce .pp_close {
	    background-color: transparent!important;
	    z-index: 30000;
	}

	div.pp_woocommerce .pp_arrow_next,
	div.pp_woocommerce .pp_arrow_previous {
	    height: .75em;
	    width: .75em;
	    font-size: 25px!important;
	    text-shadow: none;
	    line-height: .75em;
	    transition: all ease-in-out .2s;
	}

	div.pp_left > div.pp_right > div.pp_content > div.pp_fade > div.pp_details > div.pp_nav {
	    position: absolute;
	    top: 0;
	    margin-top: -10px;
	    left: 0;
	    right: 0;
	    z-index: 20000;
	    width: 100%;
	}

	div.pp_left > div.pp_right > div.pp_content > div.pp_fade > div.pp_details {
	    width: 100%;
	    float: none;
	    left: 0;
	    right: 0;
	}

	div.pp_woocommerce .pp_arrow_next,
	div.pp_woocommerce .pp_arrow_previous {
	    background-color: transparent!important
	}

	div.pp_woocommerce .pp_arrow_next:hover,
	div.pp_woocommerce .pp_arrow_previous:hover {
	    background-color: #222
	}

	div.pp_left > div.pp_right > div.pp_content > div.pp_fade > div.pp_details > div.pp_nav p.currentTextHolder {
	    display: none
	}

	div.pp_woocommerce div.pp_nav .pp_next:before,
	div.pp_woocommerce div.pp_nav .pp_previous:before {
	    background-color: #222!important;
	    color: #fff!important;
	    position: relative;
	    top: auto;
	}

	a.pp_arrow_next,
	a.pp_arrow_previous {
	    float: none;
	    position: absolute;
	}

	a.pp_arrow_next:before,
	a.pp_arrow_previous:before {
	    top: 0;
	    font-size: 20px!important;
	}

	div.pp_woocommerce a.pp_close:before {
	    font-size: 20px
	}

	div.pp_woocommerce div.pp_nav a.pp_arrow_next {
	    left: 50px;
	    margin-top: -18px;
	}

	div.pp_woocommerce div.pp_nav a.pp_arrow_previous {
	    left: 20px
	}
}


/* ## Previous Next Product Links
--------------------------------------------- */

.woocommerce-page .prev-next-post-links {
    margin-bottom: 30px
}


/* ## Shop/Archive Top Results Pagination
--------------------------------------------- */

.woo-results-pagination {
    margin: 0 0 10px;
    padding-bottom: 5px;
    font-size: 13px;
    text-align: center;
}

.woo-results-pagination .archive-pagination li,
.woo-results-pagination .archive-pagination span,
.woo-results-pagination .archive-pagination a {
    font-size: 13px
}

.woocommerce .woo-results-pagination .archive-pagination,
.woocommerce-page .woo-results-pagination .archive-pagination {
    margin: 0;
}

.woocommerce .woo-results-pagination .woocommerce-result-count,
.woocommerce-page .woo-results-pagination .woocommerce-result-count {
    float: none;
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 10px;
}

@media (min-width: 800px) { 
	.woo-results-pagination {
	    display: table;
	    width: 100%;
	    margin-bottom: 20px;
	    border-bottom: 1px solid #ddd;
	    position: relative;
	    top: -5px;
	}

	.woocommerce .woo-results-pagination .woocommerce-result-count,
	.woocommerce-page .woo-results-pagination .woocommerce-result-count {
	    text-align: left;
	    margin-bottom: 0;
	}

	.woocommerce .woo-results-pagination .archive-pagination,
	.woocommerce-page .woo-results-pagination .archive-pagination {
	    display: table-cell;
	    text-align: right;
	    position: relative;
	    right: -7px;
	}
}


/* ## Product Archive & Content Widget
--------------------------------------------- */

.content > .woocommerce ul.products li.product h3,
.related ul.products li.product h3,
.up-sells ul.products li.product h3,
.cross-sells ul.products li.product h3,
.page-widgets ul.products li.product h3,
.entry-content ul.products li.product h3 {
    margin-top: 10px;
    font-weight: bold;
}

.related ul.products li.product h3,
.up-sells ul.products li.product h3,
.cross-sells ul.products li.product h3 {
    font-size: 14px
}

.page-widgets ul.products li.product h3 {
    padding: 0 10px
}

ul.products li > a {
    display: block
}

ul.products li {
    text-align: center;
    position: relative;
}

.woocommerce ul.products .entry {
    border-bottom: 0px
}

.woocommerce ul.products li.product a img {
    margin: 0
}


/* ## Fluid Product Columns
--------------------------------------------- */

.woocommerce ul.products {
    font-size: 0px; /* line-height inline block fix on parent */
    margin-bottom: -20px;
}

.woocommerce ul.products a:hover img {
    opacity: 1;
}

.woocommerce ul.products:hover li {
	opacity: .7;
	transition: all .25s linear;
}

.woocommerce ul.products:hover > li:hover {
	opacity: 1;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    width: 100%!important;
    float: none!important;
    vertical-align: top;
    font-size: 16px;
    clear: both;
    margin: 0 0 20px!important;
    padding-bottom: 12px;
}

.woocommerce ul.products li.product > a:first-child,
.woocommerce-page ul.products li.product  > a:first-child {
    display: block;
    position: relative;
}

.woocommerce.columns-1 ul.products li.product {
    width: 100%!important
}

@media (min-width: 401px) { 
	.woocommerce ul.products li.product,
	.woocommerce-page ul.products li.product {
	    padding-bottom: 45px;
	    margin-bottom: 40px;
	}

	.woocommerce ul.products {
	    margin: 0 -2% 20px
	}

	.woocommerce ul.products li.product,
	.woocommerce-page ul.products li.product {
	    width: 50%!important;
	    /* 2 columns */
	    display: inline-block;
	    padding: 0 2% 2%;
	    clear: none!important;
	}

	.woocommerce.columns-2 ul.products li.product {
	    width: 50%!important
	}

	.woocommerce ul.products li.product.first,
	.woocommerce-page ul.products li.product.first {
	    clear: none!important;
	    display: inline-block;
	}

	.woocommerce ul.products li.product.last,
	.woocommerce-page ul.products li.product.last {
	    clear: none!important;
	    display: inline-block;
	}
}

@media (min-width: 500px) { 
	.woocommerce.columns-4 ul.products li.product {
	    width: 50%!important
	}
}

@media (min-width: 900px) { 
	.woocommerce.columns-4 ul.products li.product {
	    width: 25%!important
	}
}

@media (min-width: 800px) { 
	.woocommerce ul.products li.product,
	.woocommerce-page ul.products li.product {
	    width: 33.333%!important;
	    /* 3 columns */
	}

	.woocommerce.columns-3 ul.products li.product {
	    width: 33.333%!important
	}

	.woocommerce.columns-5 ul.products li.product {
	    width: 25%!important
	}

	.woocommerce.columns-6 ul.products li.product {
	    width: 20%!important
	}
}

@media (min-width:1200px) { 
	/* 4 columns */

	.woocommerce ul.products li.product,
	.woocommerce-page ul.products li.product,
	.woocommerce.columns-4 ul.products li.product {
	    width: 25%!important
	}

	.woocommerce.columns-5 ul.products li.product {
	    width: 20%!important
	}

	.woocommerce.columns-6 ul.products li.product {
	    width: 16.66%!important
	}
}


/* ## Up-sells/Cross Sells Related
--------------------------------------------- */

.woo-related-img {
    width: 100%;
    padding-top: 100%;
    overflow: hidden;
    position: relative;
}

.woo-related-img img {
    position: absolute;
    left: 0;
    top: 0;
}

.cherish.woocommerce .related h2,
.cherish.woocommerce .up-sells h2,
.cherish .woocommerce .cart-collaterals .cross-sells h2 {
    font-size: 18px;
    border-bottom: 2px solid #222;
    text-transform: uppercase;
}

.woocommerce .related ul.products li.product .button,
.woocommerce .up-sells ul.products li.product .button,
.woocommerce .cart-collaterals .cross-sells ul.products li.product .button {
    font-size: 12px!important;
    padding: 5px 10px;
}

@media (min-width: 500px) { 
	.woocommerce .related ul.products li.product,
	.woocommerce .up-sells ul.products li.product,
	.woocommerce .cart-collaterals .cross-sells ul.products li.product {
	    width: 33.33%!important
	}
}

@media (min-width: 800px) { 
	.woocommerce .related ul.products li.product,
	.woocommerce .up-sells ul.products li.product,
	.woocommerce .cart-collaterals .cross-sells ul.products li.product {
	    width: 25%!important
	}
}

@media (min-width: 1000px) { 
	.woocommerce .related ul.products li.product,
	.woocommerce .up-sells ul.products li.product,
	.woocommerce .cart-collaterals .cross-sells ul.products li.product {
	    width: 20%!important
	}
}


/* ## Product Tabs (they were never responsive)
--------------------------------------------- */

.woocommerce-tabs.wc-tabs-wrapper .panel.entry-content.wc-tab {
    padding: 5% 5% 0;
    background: transparent;
}

.woocommerce .panel.entry-content > h2 {
    font-size: 24px
}

.woocommerce div.product .woocommerce-tabs {
    margin: 3% 0 4%
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
    margin-bottom: 0;
    margin-top: 0;
    padding: 0;
    text-align: center;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li:before {
    display: none
}

.woocommerce div.product .woocommerce-tabs ul.tabs li:after {
    display: none
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    border: none;
    position: relative;
    background-color: transparent;
    display: inline-block;
    float: none;
    border-radius: 0px;
    padding: 0;
    margin: 0 10px 0 0;
    text-transform: uppercase;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: block;
    padding-bottom: 12px;
    font-weight: normal;
    color: inherit;
    text-decoration: none;
    padding: 0 0 5px 0;
    margin: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
    color: inherit;
    background: transparent;
    border-bottom: 5px solid #222;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    text-decoration: none;
    opacity: .7;
}

.woocommerce div.product .woocommerce-tabs ul.tabs:before {
    border-bottom: 2px solid #222
}


/* ## Page Header
--------------------------------------------- */

.single-product .page-header a {
    text-decoration: none
}

a.woocommerce-review-link {
    font-size: 12px
}


/* ## General Typography
--------------------------------------------- */

.content body.product h2,
.woocommerce-cart .woocommerce h2,
.woocommerce-account .woocommerce h2 {
    font-size: 18px
}

.woocommerce-cart .woocommerce .cart_totals h2 {
    text-transform: uppercase
}

.woocommerce-checkout > h3#order_review_heading,
.woocommerce-Reviews h3#reply-title.comment-reply-title,
#customer_details h3 {
    text-transform: uppercase;
    border-bottom: 2px solid #222;
    font-size: 18px;
}

.woocommerce-Reviews h3#reply-title.comment-reply-title {
    margin-bottom: 3%
}


/* ## Messages
--------------------------------------------- */

.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
    color: #fff;
    line-height: 36px;
    border: 0px;
    padding: 5px 5px 5px 40px!important;
    margin-bottom: 20px;
}

.woocommerce-error:before,
.woocommerce-info:before,
.woocommerce-message:before {
    color: #fff;
    line-height: inherit;
    margin: 0;
    top: 50%;
    left: 10px;
    margin-top: -18px;
}

.woocommerce-error > li {
    padding: 0
}

.woocommerce .woocommerce-error .button,
.woocommerce .woocommerce-message .button.wc-forward,
.woocommerce .woocommerce-Message .woocommerce-Button,
.woocommerce .woocommerce-message .button {
    color: #fff;
    border-color: #fff;
    box-shadow: none;
    background: transparent;
    margin: 0;
    font-size: 14px;
    padding: 2px 10px 0;
}

.woocommerce .woocommerce-message .button.wc-forward,
.woocommerce .woocommerce-Message .woocommerce-Button,
.woocommerce .woocommerce-message .button {
    line-height: 32px!important
}

.woocommerce-error {
    background: #e01700
}

.cherish .woocommerce-error .button.wc-forward {
    color: #fff;
    background: #e01700;
    border-color: #fff;
}

.cherish .woocommerce-error .button.wc-forward:hover,
.cherish .woocommerce-error .button.wc-forward:focus {
    color: #e01700;
    background: #fff;
}

.woocommerce-error a:not(.button),
.woocommerce-info a:not(.button),
.woocommerce-message a:not(.button) {
    color: #fff;
    border-bottom: 1px solid #fff;
    text-decoration: none;
}

.woocommerce-error a:not(.button):hover,
.woocommerce-info a:not(.button):hover,
.woocommerce-message a:not(.button):hover {
    opacity: .6
}

@media (max-width:900px) { 
	.woocommerce-message .button {
	    position: relative;
	    text-align: center;
	    float: none;
	    clear: both;
	    margin-bottom: 10px!important;
	    padding: 0;
	    border: none;
	    width: auto;
	    display: table!important;
	    margin: 0 auto 10px!important;
	}

	.woocommerce-error,
	.woocommerce-info,
	.woocommerce-message {
	    line-height: normal;
	    padding: 15px!important;
	    text-align: center;
	}

	.woocommerce-error:before,
	.woocommerce-info:before,
	.woocommerce-message:before {
	    display: none
	}
}


/* ## Forms
--------------------------------------------- */

.woocommerce-product-search {
    position: relative
}

.woocommerce-product-search input[type="search"],
.woocommerce-product-search input {
    padding: 10px 40px 10px 15px
}

.woocommerce-product-search input[type="submit"] {
    padding: 0;
    height: 40px;
    width: 34px;
    background: transparent;
    border: none;
    position: absolute;
    right: 0;
    top: 0;
    text-indent: -50000px;
    z-index: 1;
}

.woocommerce-product-search input[type="submit"]:hover,
.woocommerce-product-search input[type="submit"]:focus {
    -webkit-box-shadow: none!important;
    -moz-box-shadow: none!important;
    box-shadow: none!important;
    background: transparent!important;
}

.woocommerce-product-search:hover::after,
.woocommerce-product-search:focus::after {
    opacity: .5
}

.woocommerce-product-search::after {
    font-family: 'FontAwesome';
    content: "\f002";
    font-size: 20px;
    position: absolute;
    top: 0;
    font-size: 16px;
    right: 15px;
    text-indent: 0;
    width: 34px;
    line-height: 40px;
    text-align: right;
    opacity: .7;
}

.woocommerce .form-row {
    padding-left: 0!important;
    padding-right: 0!important;
}

@media (max-width:800px) { 
	.woocommerce form .form-row-first,
	.woocommerce form .form-row-last,
	.woocommerce-page form .form-row-first,
	.woocommerce-page form .form-row-last {
	    float: none;
	    width: 100%;
	}
}

.woocommerce #reviews #comments ol.commentlist li .comment-text {
    border: none;
    padding: 0 3% 3% 50px;
}

.woocommerce form .form-row.woocommerce-invalid label {
    color: #e01700!important
}

.woocommerce-invalid.woocommerce-invalid-required-field input {
    border-color: #e01700!important
}

.woocommerce form .form-row .required {
    color: #e01700
}

.woocommerce-validated input {
    border-color: #222!important
}

.woocommerce #reviews #comments ol.commentlist li img.avatar {
    padding: 0;
    width: 60px;
    border: none;
}

.woocommerce-Tabs-panel--reviews .comment-form > p.form-submit {
    clear: both;
    margin-bottom: 40px;
}

.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
    border: 0px;
    padding: 0;
}

/* -- woocommerce-lost-password -- */

div.woocommerce > form.woocommerce-ResetPassword.lost_reset_password > p:first-child {
    font-size: 30px;
    line-height: 1.3;
    font-weight: 300;
    padding: 0 5%;
}

.woocommerce .woocommerce-ResetPassword.lost_reset_password {
    text-align: center
}

.woocommerce .woocommerce-ResetPassword.lost_reset_password div,
.woocommerce .woocommerce-ResetPassword.lost_reset_password p.woocommerce-FormRow.woocommerce-FormRow {
    margin: 0 auto!important;
    display: block!important;
    max-width: 600px!important;
    float: none;
}


/* ## Payment Box
--------------------------------------------- */

.woocommerce-checkout #payment ul.payment_methods {
    border-bottom: 0px
}

.wc_payment_methods.payment_methods.methods,
.form-row.place-order {
    border-radius: 0px;
    background: transparent;
}

.woocommerce-checkout #payment.woocommerce-checkout-payment > div.form-row.place-order {
    border-radius: 0px;
    background: transparent!important;
}

#add_payment_method #payment,
.woocommerce-checkout #payment {
    background: transparent;
    border-radius: 0px;
}

#add_payment_method #payment ul.payment_methods,
.woocommerce-checkout #payment ul.payment_methods {
    border: 2px solid #222;
    background: #fff;
}

.woocommerce-checkout #payment div.payment_box {
    background: #f7f7f7
}

.woocommerce-checkout #payment div.payment_box:before {
    border-bottom-color: #f7f7f7
}


/* ## Cart
--------------------------------------------- */

p.cart-empty,
p.return-to-shop {
    text-align: center
}

p.cart-empty {
    font-weight: 300
}

@media (min-width: 1000px) { 
	p.cart-empty {
	    font-weight: 200;
	    font-size: 250%;
	}
}

.cart_totals > h2 {
    text-align: center
}

.woocommerce a.remove {
    color: #222!important;
    border: 2px solid #222;
    height: 30px;
    width: 30px;
    line-height: 26px;
}

.woocommerce a.remove:hover {
    background-color: #222;
    color: #fff!important;
}

div.quantity input.input-text.qty.text {
    width: 100%;
    max-width: 100px;
}

.woocommerce a.added_to_cart {
    font-size: 14px
}

.woocommerce-cart table.cart img {
    width: 100px
}

.woocommerce-cart .woocommerce .cross-sells {
    clear: both;
    float: none;
    width: 100%;
    padding-top: 15px;
}

.woocommerce-cart .woocommerce {
    margin-bottom: 30px
}

.wc-proceed-to-checkout {
    text-align: right
}

.woocommerce-cart td.actions {
    padding-top: 15px!important;
    padding-bottom: 15px!important;
}

.actions div.coupon {
    width: auto
}

.actions div.coupon input#coupon_code.input-text,
.woocommerce-cart table.cart input {
    width: 200px;
    line-height: normal!important;
    padding: 15px 10px;
    border-color: inherit;
    display: inline-block;
    border-width: 2px;
}

@media (max-width:600px) { 
	.actions div.coupon {
	    margin-bottom: 10px
	}

	.actions div.coupon input#coupon_code.input-text {
	    width: 100%;
	    margin-bottom: 5px;
	}

	.woocommerce-cart td.actions .button {
	    display: block;
	    width: 100%!important;
	}

	.woocommerce-cart td.actions .input-text {
	    text-align: center
	}
}

.woocommerce form .form-row .select2-container {
    border-radius: 3px;
    line-height: 38px;
}

.woocommerce form .form-row .select2-container * {
    border-radius: 3px;
    border-color: #222;
    border-width: 2px;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 40px;
  height: 42px;
}

.select2-container--default .select2-selection--single {
  line-height: 40px;
  height: 42px;
}

.select2-selection.select2-selection--single > .select2-selection__arrow {
 height: 40px;
}


.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
    border-radius: 0px;
    border-color: #222;
}

.woocommerce form.checkout_coupon input {
    width: 100%;
    display: block;
}

div#customer_details.col2-set {
    margin-bottom: 30px
}

.woocommerce form.checkout_coupon input:not([type="checkbox"]),
.woocommerce form.login input:not([type="checkbox"]),
.woocommerce form.register input:not([type="checkbox"]) {
    padding-top: 10px;
    padding-bottom: 10px;
    line-height: normal;
}

.cherish.woocommerce-cart .cart-collaterals .shop_table.shop_table_responsive {
    width: 100%!important
}

.cherish.woocommerce-cart .cart-collaterals .cart_totals tr td,
.cherish.woocommerce-cart .cart-collaterals .cart_totals tr th {
    border-top: 2px solid rgba(0,0,0,.05);
    padding: 10px 5%;
    background: #fff;
}

@media (min-width: 769px) { 
	.cherish.woocommerce-cart .cart-collaterals .cart_totals tr th {
	    text-align: right;
	    width: 50%;
	    padding-right: 10px!important;
	}

	.cherish.woocommerce-cart .cart-collaterals .cart_totals tr td {
	    padding-left: 10px!important;
	    width: 50%;
	}
}

.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals {
    float: none;
    width: 100%;
    margin: 0 auto 3%;
    padding: 0;
    border: 0px;
}

.woocommerce .cart-collaterals .cart_totals h2 {
    border-bottom: 2px solid #222;
    font-size: 18px;
    padding: 3% 0 0 0;
}

.wc-proceed-to-checkout a.checkout-button.button.alt.wc-forward {
    float: none;
    margin: 0;
    padding-left: 5%;
    padding-right: 5%;
    width: 100%;
}

table.shop_table.shop_table_responsive.cart dl.variation dd {
    padding-left: 0;
    text-align: left;
    margin: 0;
}


/* ## Table Styles
--------------------------------------------- */

.woocommerce table.shop_table {
    border-radius: 0px
}

.woocommerce table {
    border: none!important
}

@media (min-width:801px) { 
	.woocommerce td,
	.woocommerce th {
	    padding: 8px 0!important
	}
}


/* ## Product Variations
--------------------------------------------- */

table.variations td {
    border: 0px
}

.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
    line-height: 24px
}

.variations .select-wrapper {
    padding: 0;
    border-radius: 3px;
    position: relative;
    display: block;
    margin: 0;
    border: 2px solid #222;
    width: 100%;
    overflow: hidden;
    background: transparent;
}

.variations .select-wrapper:after {
    font-family: 'FontAwesome';
    content: "\f107";
    position: absolute;
    z-index: 1;
    line-height: 1;
    right: 10px;
    top: 50%;
    margin-top: -8px;
}

.variations select {
    padding: 10px 8px;
    position: relative;
    z-index: 5;
    width: 100%!important;
    border: none;
    box-shadow: none;
    background-color: transparent;
    background-image: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

table.variations td {
    display: block;
    float: left;
    width: 100%;
    padding: 10px 0 0 0!important;
}

@media (min-width:1200px) { 
	.variations .select-wrapper {
	    width: 70%
	}

	.variations select {
	    width: 70%
	}
}


/* ## Buttons
--------------------------------------------- */

.woocommerce #respond input#submit.alt.disabled,
.woocommerce #respond input#submit.alt.disabled:hover,
.woocommerce #respond input#submit.alt:disabled,
.woocommerce #respond input#submit.alt:disabled:hover,
.woocommerce #respond input#submit.alt:disabled[disabled],
.woocommerce #respond input#submit.alt:disabled[disabled]:hover,
.woocommerce a.button.alt.disabled,
.woocommerce a.button.alt.disabled:hover,
.woocommerce a.button.alt:disabled,
.woocommerce a.button.alt:disabled:hover,
.woocommerce a.button.alt:disabled[disabled],
.woocommerce a.button.alt:disabled[disabled]:hover,
.woocommerce button.button.alt.disabled,
.woocommerce button.button.alt.disabled:hover,
.woocommerce button.button.alt:disabled,
.woocommerce button.button.alt:disabled:hover,
.woocommerce button.button.alt:disabled[disabled],
.woocommerce button.button.alt:disabled[disabled]:hover,
.woocommerce input.button.alt.disabled,
.woocommerce input.button.alt.disabled:hover,
.woocommerce input.button.alt:disabled,
.woocommerce input.button.alt:disabled:hover,
.woocommerce input.button.alt:disabled[disabled],
.woocommerce input.button.alt:disabled[disabled]:hover {
    background-color: transparent;
    color: #222!important;
    border-color: #222!important;
    opacity: .3;
}

ul.products .button,
.woocommerce a.button.wc-forward,
.wc-proceed-to-checkout a.checkout-button.button.alt.wc-forward,
.woocommerce-checkout-payment input#place_order.button.alt,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .product-type-external button.single_add_to_cart_button.button,
.woocommerce .single_add_to_cart_button.button,
.woocommerce .single_add_to_cart_button.button.alt {
    background-color: transparent;
    color: #222;
    border: 2px solid #222;
    cursor: pointer;
    font-size: 16px;
    border-radius: 3px;
    font-weight: normal;
    padding: 10px 15px;
    line-height: normal;
    width: auto;
    text-decoration: none;
    vertical-align: baseline;
    font-weight: normal;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
}

.woocommerce-checkout-payment input#place_order.button.alt,
.woocommerce .product-type-external .single_add_to_cart_button.button,
.woocommerce .single_add_to_cart_button.button,
.woocommerce .single_add_to_cart_button.button.alt {
    font-weight: bold;
}


ul.products .button:hover,
ul.products .button:focus,
.woocommerce a.button.wc-forward:hover,
.woocommerce a.button.wc-forward:focus,
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:focus,
.woocommerce a.button:focus,
.woocommerce button.button:focus,
.woocommerce input.button:focus,
.woocommerce .product-type-external .single_add_to_cart_button.button:hover,
.woocommerce .product-type-external .single_add_to_cart_button.button:focus,
.woocommerce .single_add_to_cart_button.button.alt:hover,
.woocommerce .single_add_to_cart_button.button.alt:focus,
.wc-proceed-to-checkout a.checkout-button.button.alt.wc-forward:hover,
.wc-proceed-to-checkout a.checkout-button.button.alt.wc-forward:focus,
.woocommerce-checkout-payment input#place_order.button.alt:hover,
.woocommerce-checkout-payment input#place_order.button.alt:focus,
.woocommerce .woocommerce-Message .woocommerce-Button:hover {
    background-color: #222;
    color: #fff;
    text-decoration: none;
    transition: background-color 0.2s linear;
}

ul.products .product .button {
    padding: 8px 15px!important;
    line-height: normal;
    font-size: 14px;
}

.wc-proceed-to-checkout a.checkout-button.button.alt.wc-forward,
.woocommerce-checkout-payment input#place_order.button.alt {
    font-size: 16px;
    padding: 10px 20px;
    display: inline-block;
}

.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .product-type-external .button.single_add_to_cart_button.button,
.woocommerce .single_add_to_cart_button.button,
.woocommerce .single_add_to_cart_button.button.alt,
.actions div.coupon input#coupon_code.input-text,
.woocommerce-cart table.cart input {
    display: inline-block;
    line-height: normal!important;
    padding: 10px 15px;
    font-size: 16px;
}

.actions div.coupon input#coupon_code.input-text,
.woocommerce-cart table.cart input {
    background-color: transparent;
    color: #222;
    border: 2px solid #222;
    border-radius: 3px;
    font-weight: normal;
    padding: 8px;
    line-height: normal;
    width: auto;
    text-decoration: none;
    vertical-align: baseline;
    font-weight: normal;
}

.woocommerce form .form-row input.input-text {
    border: 2px solid #222;
    font-size: 16px;
    line-height: normal;
    padding-left: 15px;
    padding-right: 15px;
    text-transform: none;
    width: 100%;
    border-radius: 3px;
    margin-bottom: 5px;
}

.woocommerce form .form-row textarea {
    border: 2px solid #222;
    font-size: 16px !important;
    font-weight: inherit;
    padding: 8px;
    text-transform: none;
    width: 100%;
    height: 200px;
    min-height: 200px;
    max-height: 700px;
    resize: vertical;
}

.woocommerce form input[type="search"]:hover,
.woocommerce form input[type="text"]:hover,
.woocommerce form input[type="url"]:hover,
.woocommerce form input[type="tel"]:hover,
.woocommerce form input[type="number"]:hover,
.woocommerce form input[type="color"]:hover,
.woocommerce form input[type="email"]:hover,
.woocommerce form input[type="password"]:hover,
.woocommerce form input[type="search"]:focus,
.woocommerce form input[type="text"]:focus,
.woocommerce form input[type="url"]:focus,
.woocommerce form input[type="tel"]:focus,
.woocommerce form input[type="number"]:focus,
.woocommerce form input[type="color"]:focus,
.woocommerce form input[type="email"]:focus,
.woocommerce form input[type="password"]:focus,
.woocommerce form textarea:hover,
.woocommerce form textarea:focus,
.woocommerce div.coupon > input#coupon_code.input-text:hover,
.woocommerce div.coupon > input#coupon_code.input-text:focus {
    outline: none;
    border-style: dotted;
    border-radius: 0px;
}

.woocommerce form.cart .button,
.wc-proceed-to-checkout a.checkout-button.button.alt.wc-forward {
    font-weight: bold
}


/* ## Checkout Page
----------------------------------------------------------- */

.woocommerce-checkout  .col2-set > div.col-1 {
    width: 100%;
    margin-bottom: 30px;
}

.woocommerce-checkout  .col2-set > div.col-2 {
    width: 100%
}

@media (min-width: 1000px) { 
	.woocommerce-checkout .col2-set > div.col-1 {
	    width: 55%;
	    margin-bottom: 30px;
	}

	.woocommerce-checkout .col2-set > div.col-2 {
	    width: 40%
	}
}


/* ## Widgets
----------------------------------------------------------- */

ul.product_list_widget > li img {
    width: 70px!important
}

.aside-area .woocommerce ul.products li.product {
    padding-bottom: 0;
    margin-bottom: 0;
    margin-top: 15px;
}

.aside-area .woocommerce ul.products li.product h3 {
    font-size: 14px;
    font-weight: normal;
}

.aside-area .woocommerce ul.products li.product img {
    margin-bottom: 5px;
    display: block;
}

.aside-area .woocommerce ul.products li.product .button {
    display: none
}

.aside-area .woocommerce ul.products {
    margin-bottom: -15px!important;
    margin-top: -10px;
}

.aside-area .woocommerce ul.products li.product,
.aside-area .woocommerce.columns-1 ul.products li.product {
    width: 100%!important;
    display: block!important;
    margin-left: auto!important;
    margin-right: auto!important;
    max-width: 300px;
}

@media (min-width: 400px) { 
	.aside-area .woocommerce ul.products li.product {
	    width: 50%!important;
	    display: inline-block!important;
	    margin-left: 0!important;
	    margin-right: 0!important;
	}
}

@media (min-width: 600px) { 
	.aside-area .woocommerce ul.products li.product {
	    width: 25%!important
	}
}

@media (min-width: 1000px) { 
	.aside-area .woocommerce ul.products li.product {
	    width: 50%!important
	}
}

.widget.woocommerce .button {
    font-size: 14px;
    line-height: 1;
    padding: 10px!important;
}

.woocommerce .widget_shopping_cart .cart_list li,
.woocommerce.widget_shopping_cart .cart_list li {
    padding-left: 40px
}

.page-widgets .woocommerce ul.products {
    margin: 0;
    padding-left: 4%;
    padding-right: 4%;
}

.widget.hide-price .woocommerce ul.products span.price {
    display: none
}

.widget.hide-button .woocommerce ul.products .button {
    display: none
}

.widget.hide-rating .woocommerce ul.products .star-rating {
    display: none
}

.widget.hide-title .woocommerce ul.products h3 {
    display: none
}

.widget ul.products .star-rating,
.content ul.products .star-rating {
    margin-left: auto;
    margin-right: auto;
}
