/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 0.1
*/

/*************** ADD CUSTOM CSS HERE.   ***************/
:root {
    --color-background: #53af01;
    --accent-color: 83, 175, 1;
}

.marquee {
    overflow-x: hidden;
    white-space: nowrap;
    box-sizing: border-box;
}

.marquee-content {
    display: flex;
    align-items: center;
    width: fit-content;
    column-gap: 100px;
    animation: marquee 20s linear infinite normal forwards;
}

.marquee-content span {
    color: #fff;
    line-height: 1;
    white-space: nowrap;
    font-weight: 500;
    font-size: 16px;
	padding: 5px 0;
}

@keyframes marquee {
    to {
        transform: translateX(calc(-50% - 30px));
    }
}

.bg-green {
    background-color: #53af01;
}

.text-green {
    color: #53af01;
}

.py-6px {
    padding-top: 6px;
    padding-bottom: 6px;
}

.text-center {
    text-align: center;
}

.my-10px {
    margin-top: 10px;
    margin-bottom: 10px;
}

.m-auto {
    margin: auto;
}

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

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

.font-italic {
    font-style: italic;
}

.line-heigh-38px {
	line-height: 38px;
}

.splide__slide {
    backface-visibility: hidden;
    box-sizing: border-box;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    list-style-type: none !important;
    margin: 0;
    position: relative;
}

.ratio {
    display: flex;
    position: relative;
    align-items: stretch;
}

.media--transparent {
    background-color: transparent;
}

.media {
    display: block;
    background-color: rgba(18, 18, 18, 0.1);
    overflow: hidden;
}

.ratio:before {
    content: " ";
    display: block;
    width: 0;
    height: 0;
    padding-bottom: 177.61989342806396%;
}

.media > :not(.zoom):not(.deferred-media__poster-button) {
    display: block;
    max-width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
}

.internal-video {
    display: block;
    position: relative;
    z-index: 0;
}

video {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}

.internal-video__play {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    outline: none;
    z-index: 1;
    cursor: pointer;
}

.play-button {
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    position: relative;
    z-index: 0;
    background: var(--color-background);
    outline: none;
    border: none;
    cursor: pointer;
}

.ripple-animation:after,
.ripple-animation:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: -1;
    border-radius: 50%;
    border: solid 1px var(--color-background);
    animation: 2s linear infinite ripple;
}

.ripple-animation:before {
    animation-duration: 1s;
}

.play-button svg {
    color: var(--color-foreground);
    height: 50%;
    width: 50%;
}

@keyframes ripple {
    0% {
        opacity: 0;
        transform: none;
    }
    20%,
    70% {
        opacity: 1;
    }
    100% {
        opacity: 0;
        transform: scale(1.5);
    }
}

.color-accent-1 {
    color: rgba(255, 255, 255, 0.9);
    background-color: var(--color-background);
}

/** PROOF **/
.results__row {
    padding: 1rem 0;
    display: flex;
    align-items: center;
    border-bottom: 2px solid #1212120d;
}

.results__row:first-of-type {
    border-top: 2px solid #1212120d;
}

.results__percentage {
    width: 70px;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border-radius: 50%;
    position: relative;
    flex-shrink: 0;
    margin-right: 15px;
    z-index: 0;
}

.results__percentage:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    border-radius: 50%;
    z-index: -2;
    background: conic-gradient(
        from 0deg at 50% 50%,
        #53af01 0%,
        #53af01 var(--percentage),
        #fdfdfd var(--percentage),
        #fdfdfd 100%
    );
}

.results__percentage:after {
    content: " ";
    display: block;
    position: absolute;
    top: 7px;
    left: 7px;
    bottom: 7px;
    right: 7px;
    border-radius: 50%;
    z-index: -1;
    background: #fdfdfd;
}

.results__percentage p {
    margin: 0;
    color: #53af01;
    font-size: 18px;
    font-weight: 700;
}

.results__text p {
    margin-bottom: 0;
}

/*** Reviews ***/
.testimonial_single_item {
    background-color: #fff;
    border-radius: 10px;
    padding: 20px;
    border: 1px solid #ddd;
}
.testimonial_item--reviewer {
    display: flex;
    align-items: center;
    gap: 10px;
}
.testimonial_item--reviewer-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    overflow: hidden;
}
.elementor img {
    border: none;
    border-radius: 0;
    box-shadow: none;
    height: auto;
    max-width: 100%;
}
.testimonial_item--reviewer-avatar img {
    object-fit: cover;
}
.testimonial_item--reviewer-info {
    line-height: 1.2;
}
.testimonial_item--reviewer-name {
    font-size: 16px;
    font-weight: 600;
    color: #333;
}
.testimonial_item--reviewer-time {
    font-size: 14px;
    font-weight: 400;
    color: #6a6a67;
}
.testimonial_item--star_rating_small img {
    height: 22px !important;
    width: auto;
    margin-top: 15px;
}
.testimonial_item--text {
    color: #18181b;
    font-size: 16px;
    margin-top: 20px;
    margin-bottom: 0 !important;
    font-weight: 500;
}

.box-site-reviews .box-content {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr 1fr;
    grid-auto-columns: 1fr;
    align-items: stretch;
    display: grid;
}

.box-site-reviews .box-heading {
    text-align: center;
    margin-bottom: 40px;
}

/** FOOTER **/
.footer-logo {
    height: 40px;
    width: auto;
    margin-bottom: 20px;
}

#footer .widget-title {
    font-size: 20px;
    display: block;
    margin-bottom: 20px;
}

#footer .is-divider {
    display: none;
}

#footer .widget > ul > li + li,
#footer ul.menu > li + li {
    border-top: none;
}

#footer .footer-secondary {
    border-top: 1px solid #ddd;
    padding-top: 25px;
}

/** PRODUCT **/
.product-small .product-title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 20px;
}

.product-small .add-to-cart-button .add_to_cart_button {
    display: block;
    width: 100%;
    font-size: 16px;
    font-weight: 600;
    padding: 8px 0;
    border-radius: 5px;
}

.banner-layers .button.primary {
    font-size: 16px;
    font-weight: 600;
    padding: 8px 30px;
    border-radius: 5px;
}

/** Single products **/
.social-icons .button {
    margin-right: 6px;
}
.social-icons .button i {
    top: 0.5px;
}

.rating-stars-and-text {
    display: flex;
    justify-content: flex-start;
    align-items: center;
	flex-wrap: wrap;
	gap: 5px;
}

.rating-stars__container--underlay {
    position: relative;
}
.rating-stars__container {
    display: flex;
}
.rating-stars__container svg:first-of-type {
    margin-left: 0;
}
.rating-stars__container--underlay svg {
    color: #ffcc00;
}
.rating-stars__container svg {
    width: 1em;
    height: 1em;
    margin-left: 0.125em;
    flex-shrink: 0;
}

.rating-stars__label {
    margin-left: 0;
    line-height: 1.2;
    font-size: 15px;
}

.quantity-breaks__title {
    margin: 0;
    font-size: 1.4rem;
    line-height: 1;
    column-gap: 10px;
    margin-bottom: 1.3rem;
}

.flex-center {
    display: flex;
    align-items: center;
    justify-content: center;
}

.quantity-breaks__title span:nth-of-type(1),
.quantity-breaks__title span:nth-of-type(3) {
    display: block;
    height: 2px;
    flex-grow: 1;
    background: #53af01;
}

.custom-title {
    font-size: 14px;
}

.payment-badges {
    padding: 0;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
    margin: 0;
}

.list-payment__item {
    align-items: center;
    display: flex;
    padding: 5px;
    margin-left: 0 !important;
}

.list-payment__item:first-child {
    padding-left: 0;
}

.box-remaining {
    /* background-color: #CDE8F6;
    border: #2697d1 2px solid;
    color: #447EAF; */
    background-color: #f8f4d5;
    border: #e9dd7e 2px solid;
    color: #96722e;
    font-size: 16px;
    border-radius: 5px;
    padding: 10px 20px;
}

.product .woocommerce-variation-add-to-cart .ux-quantity {
    display: none !important;
}
/* 
.product .ux-buy-now-button,
.product .single_add_to_cart_button {
    display: block;
    width: 100%;
    border-radius: 5px;
} */

.variation-radio-label {
    background-color: #53af0105;
    border: solid 2px #53af014d;
    border-radius: 5px;
    outline: 0;
    display: flex;
    align-items: center;
    margin-left: 0;
    cursor: pointer;
    margin-bottom: 15px;
    padding: 20px 20px 20px 10px;
    position: relative;
}

.variation-radio-label:last-child {
    margin-bottom: 0;
}

.variation-radio-label:hover,
.variation-radio-label.selected {
    background-color: #53af011a;
    border-color: #53af01;
}

.variant-label__value {
    font-size: 16px;
    color: rgba(18, 18, 18, 0.9);
    font-weight: bold;
}

.variation-description {
    font-size: 14px;
    color: rgba(18, 18, 18, 0.9);
    font-weight: 400;
}

.variation-radio-label input[type="radio"] {
    margin: 0;
    margin-right: 12px;
    margin-left: 8px;
}

.variation-radio-label input[type="radio"] {
    position: relative;
    width: 20px;
    height: 20px;
    margin-right: 10px;
    -webkit-appearance: none; /* Ẩn giao diện mặc định của radio */
    -moz-appearance: none;
    appearance: none;
    border: 2px solid #53af01; /* Màu viền của radio */
    border-radius: 50%;
    background: #fff;
    cursor: pointer;
    transition: all 0.2s;
}
.variation-radio-label input[type="radio"]:checked::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 12px;
    height: 12px;
    background: #53af01; /* Màu khi radio được selected */
    border-radius: 50%;
}
.variation-radio-label input[type="radio"]:focus {
    outline: none;
    box-shadow: 0 0 3px #53af01; /* Hiệu ứng focus */
}

.variation-radio-label .variant-info {
    display: flex;
    justify-content: space-between;
    flex-grow: 1;
}

.variation-radio-label ins,
.variation-radio-label del {
    display: block;
    text-align: right;
}

.variation-radio-label ins {
    margin-bottom: 8px;
}

.variation-radio-label ins .amount {
    color: rgb(83, 175, 1);
    font-size: 16px;
    font-weight: 700;
}

.variation-radio-label del .amount {
    color: rgba(18, 18, 18, 0.9);
    font-size: 15px;
    font-weight: 400;
}

.variation-radio-label .free-shipping {
    margin-left: 12px;
    display: inline-block;
    font-size: 12px;
    background: #fdfdfd;
    color: #53af01;
    line-height: 1.2;
    padding: 3px 10px;
    font-weight: 700;
    border: solid 1px #53af01;
    border-radius: 6px;
    white-space: nowrap;
}

.variation-radio-label .badge-label {
    position: absolute;
    font-weight: 700;
    font-size: 16px;
    line-height: 1.2;
    top: -10px;
    right: -10px;
    transform: rotate(3deg);
    margin: 0;
    padding: 3px 15px;
    border-radius: 3px;
    color: #ffffffe6;
    background-color: #53af01;
}

.custom-pro-variant-add_to_cart {
    padding: 12px 20px;
    color: #ffffffe6 !important;
    background-color: #53af01 !important;
    font-size: 20px;
    text-transform: uppercase;
    margin: 0;
}

.custom-pro-variant-list .variation-radio-wrapper {
    padding-bottom: 10px;
}

.custom-pro-variant-list .single_variation_wrap {
    padding-bottom: 0;
}

.custom-pro-variant-list .variations_form {
    margin-bottom: 0;
}

/** Cart page **/
.wc-block-components-totals-coupon__form .wc-block-components-button {
    border-radius: 5px;
}

.wc-block-components-totals-coupon__input-coupon {
    border-color: #ddd;
}

.wc-block-components-sale-badge {
    line-height: 1.2;
    padding: 3px 10px !important;
    color: #ffffffe6;
    background-color: #53af01;
    border-color: #53af01;
}

.wc-block-components-product-price__value.is-discounted {
    color: #53af01;
    font-weight: 700;
}

.wc-block-cart-item__total .wc-block-components-product-price__value {
    font-weight: 700;
    color: #222;
}

.wc-block-cart__submit-container .wc-block-cart__submit-button {
    color: #ffffffe6;
    background-color: #e53835;
	border-color: #cc1512;
    border-radius: 5px;
    font-weight: 700;
    font-size: 18px;
}

.wc-block-cart__submit-container .wc-block-cart__submit-button:hover {
    /* background-color: #3c7f02;
    border-color: #3c7f02; */
	background-color: #cc1512;
	border-color: #cc1512;
}

.mt-15px {
    margin-top: 15px;
}

.ml-15px {
    margin-left: 15px;
}

.mb-25px {
    margin-bottom: 25px;
}

.ul-li-mb-3px li {
    margin-bottom: 3px;
}

.featured-in-item {
    display: block;
    width: 160px;
    height: 40px;
    overflow: hidden;
    position: relative;
}

.section-featured-in .featured-in-item img {
    display: block;
    max-width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: contain;
    object-position: center center;
    transition: opacity 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.horizontal-ticker__container {
    display: flex;
    align-items: center;
    width: fit-content;
}
.horizontal-ticker__item {
    margin: 0;
    color: #fff;
    line-height: 1;
    white-space: nowrap;
    font-size: 18px;
}

.section-features-marquee-padding {
    padding-top: 12px;
    padding-bottom: 12px;
}
.horizontal-ticker-template .horizontal-ticker__container {
    animation: mobileHorTickertemplate 150s linear infinite normal forwards;
    column-gap: 60px;
}
.horizontal-ticker-template .review-item {
    width: 300px;
}
@media screen and (min-width: 750px) {
    .section-features-marquee-padding {
        padding-top: 12px;
        padding-bottom: 12px;
    }
    .horizontal-ticker-template .horizontal-ticker__container {
        column-gap: 100px;
        animation-name: desktopHorTickertemplate;
    }
    .horizontal-ticker-template .review-item {
        width: 400px;
    }
}
.horizontal-ticker-template.color-custom {
    --color-background: 255, 255, 255;
    --gradient-background: #ffffff;
    --color-foreground: 46, 42, 57;
}
@keyframes mobileHorTickertemplate {
    to {
        transform: translateX(calc(-50% - 30px));
    }
}
@keyframes desktopHorTickertemplate {
    to {
        transform: translateX(calc(-50% - 50px));
    }
}


/*** Comparison Table ***/
.flex {
	display: flex;
}

.flex-grow {
	flex-grow: 1;
}

.w-75px {
	width: 75px;
}
.h-40px {
	height: 40px;
}
.w-40px {
	width: 40px;
}

.w-22px {
	width: 22px;
}

.font-bold {
	font-weight: 700;
}

.rounded-full {
	border-radius: 50%;
}

.text-white,
.color-white {
	color: #fff;
}

.align-center {
	align-items: center;
}

.text-right {
	text-align: right;
}

.border-b {
	border-bottom: 1px solid;
}
.border-gray {
	border-color: #ddd;
}

.comparison-item {
	padding-top: 15px;
	padding-bottom: 15px;
}

.m-w-675px {
	max-width: 675px;
}
.m-auto {
	margin: auto;
}

.custom-faq-box {
	max-width: 675px;
	margin: auto;
}


.review-heading-box .product-review-count .rating-stars-and-text {
	text-align: center;
	justify-content: center;
	color: #fff;
}

.col-full-without-padding,
.col-full-without-padding .col.small-12.large-12 {
	padding-left: 0;
	padding-right: 0;
}

.image-with-text__text img {
	border-radius: 3px;
}

.review-image .item-img {
	position: relative;
}

.single-product.badge-container {

}

body.page:not(.home) .content-area a {
	color: #53af01;
}

#affwp-login-form,
#affwp-register-form {
	max-width: 600px;
	margin: auto;
}

.contact-left-info {
	background: #f2f2f2;
	padding: 20px;
	margin-top: 10px;
	border-radius: 5px;
}

body.page-id-3 #content,
body.page-id-87 #content,
body.page-id-11 #content,
body.page-id-81 #content,
body.page-id-78 #content,
body.page-id-188 #content,
body.page-id-190 #content,
body.page-id-83 #content,
body.page-id-386 #content,
body.page-id-2414 #content,
body.page-id-2418 #content,
body.page-id-2422 #content,
body.page-id-2431 #content,
body.page-id-2433 #content,
body.page-id-2435 #content,
body.page-id-10 #content,
body.page-id-2429 #content,
body.page-id-2437 #content,
body.page-id-2576 #content,
body.page-id-2420 #content
{
	max-width: 900px;
    margin: 40px auto;
}

body.page-id-2416 #content {
	max-width: 720px;
    margin: 40px auto;
}

body.page-id-2575 .no-access {
	text-align: center;
}

#affwp-login-form {
	margin-top: 60px;
}

/*** RESPONSIVE ***/
@media screen and (max-width: 800px) {
    .box-site-reviews .box-content {
        grid-template-columns: 1fr 1fr;
    }
}

@media screen and (max-width: 520px) {
    .box-site-reviews .box-content {
        grid-template-columns: 1fr;
    }
}

/** PRODUCT **/
.product-small .price-wrapper {
	margin-top: 15px;
}

.product-small .woocommerce-loop-product__link {
	color: #111;
    font-weight: 700;
	font-size: 16px;

	display: -webkit-box;
	-webkit-line-clamp: 2;       /* số dòng tối đa */
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
}

.product-small .woocommerce-loop-product__link:hover {
	color: var(--fs-color-primary);
}

.single-product form.cart .single_add_to_cart_button {
	flex-grow: 1;
}

.single-product form.cart .ux-buy-now-button {
	display: block;
    width: 100%;
}

.single-product .sticky-add-to-cart-wrapper .ux-buy-now-button {
	display: none!important;
}

.single-product .sticky-add-to-cart__product .product-title-small {
	max-width: 250px;
	width: 100%;
}

.product-thumbnails .flickity-slider .is-selected a {
	border-color: var(--fs-color-primary);
}


.bg-theme-primary {
	background-color: var(--fs-color-primary);
}

.text-primary {
	color: var(--fs-color-primary);
}

/** Collection Grid **/
.custom-section-collection-grid .wd-grid-g {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.custom-section-collection-grid .wd-col {
	position: relative;
}

.custom-section-collection-grid .cat-design-mask-subcat .wd-cat-inner {
    overflow: hidden;
    border-radius: 12px;
    transform: translate3d(0, 0, 0);
}

.custom-section-collection-grid .cat-design-mask-subcat .wd-cat-thumb {
    transition: transform 0.5s cubic-bezier(0,0,.44,1.18)
}

.custom-section-collection-grid .cat-design-mask-subcat .wd-cat-content {
    display: inline-flex;
    flex-direction: column;
    padding: 30px;
    max-height: 100%;
    text-align: start
}

.custom-section-collection-grid .cat-design-mask-subcat .wd-cat-header {
    display: flex;
    align-items: center;
    gap: 8px
}

.custom-section-collection-grid .cat-design-mask-subcat .wd-cat-footer {
    flex: 1 1 auto;
    margin-top: 10px;
    max-height: none;
    padding-inline-end:5px}

.custom-section-collection-grid .cat-design-mask-subcat.color-scheme-light .wd-cat-content {
    background: linear-gradient(180deg,rgb(0 0 0 / .15) 0%,#fff0 100%)
}

.custom-section-collection-grid .cat-design-mask-subcat:hover .wd-cat-thumb {
    transform: scale3d(1.1,1.1,1)
}

.custom-section-collection-grid .wd-fill {
    position: absolute;
    inset: 0;
}

.custom-section-collection-grid .wd-cat .wd-entities-title {
    margin-bottom: 0;
    text-transform: uppercase;
    font-size: 20px;
}

.custom-section-collection-grid .wd-entities-title {
    display: block;
    
    word-wrap: break-word;
    font-weight: 700;
    text-transform: uppercase;
    line-height: 1.4;
	max-width: 235px;
}

.custom-section-collection-grid .wd-entities-title a {
	color: #333;
}

.custom-section-collection-grid .wd-entities-title a:hover {
	color: var(--fs-experimental-link-color);
}

@media screen and (max-width: 720px) {
	.custom-section-collection-grid .wd-grid-g {
	    grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 430px) {
	.custom-section-collection-grid .wd-grid-g {
	    grid-template-columns: 1fr;
	}
}

/** Hero Section **/
.hero-row img {
	border-radius: 12px;
}

.header-search-form-wrapper .submit-button{
	background-color: #444;
}
.header-search-form-wrapper .submit-button:hover{
	background-color: #000;
}


.wcpa_row .wcpa_option_price {
	display: none;
}


.wcpa_row .wcpa_radio.wcpa_selected > label {
	background-color: #333!important;
}

.wcpa_row .wcpa_radio > label span:not(.wcpa_option_price) {
	padding: 0 10px;
}

.wcpa_row .wcpa_radio.wcpa_selected > label span:not(.wcpa_option_price) {
    color: #fff;
}

.wcpa_wrap .wcpa_group_field, 
.wcpa_wrap .wcpa_grp_items {
	gap: 10px!important;
}

.wcpa_section label.wcpa_field_label,
fieldset.wcpa_field_wrap legend.wcpa_field_label {
	font-size: 16px;
    text-transform: capitalize;
    font-weight: 600;
    color: #000;
    border-bottom: 0;
    margin-bottom: 10px;
}

.wcpa_selected_items span {
    color: var(--fs-color-primary);
    font-size: 16px;
    font-weight: 700;
}

.wcpa_tooltip_icon {
	border-radius: 50%;
}

.wcpa_field_wrap {
	position: relative;
}

.wcpa_field_wrap .wcpa_clear {
	position: absolute;
	top: -40px;
	right: 0;
}

.wcpa_field_wrap .wcpa_clear a {
	color: #333;
}

.wcpa_field_wrap .wcpa_clear a:hover {
	color: var(--fs-experimental-link-color);
}

.wcpa_price_summary .wcpa_options_total,
.wcpa_price_summary .wcpa_product_total,
.wcpa_field_bottom .wcpa_field_price {
	display: none;
}

.wcpa_price_summary {
	margin-top: 0;
}

.wcpa_price_summary .wcpa_total .wcpa_price_outer {
	color: #ad2e08;
	font-weight: bold;
	font-size: 20px!important;
}

.wcpa_price_summary del {
    color: var(--wcpalabelcolor);
}

.ux-quantity .input-text,
.ux-quantity ~ .single_add_to_cart_button {
	height: 52px;
}

.header-nav .woocommerce-mini-cart__buttons a[href*="/cart"],
.ux-quantity ~ .button.single_add_to_cart_button {
	background-color: #eeeeee!important;
    color: #333;
}

.header-nav .woocommerce-mini-cart__buttons a[href*="/cart"]:hover,
.ux-quantity ~ .single_add_to_cart_button:hover {
	background-color: #000!important;
    color: #fff;
}

.single-product form.cart .ux-buy-now-button {
	height: 56px;
	font-size: 20px;
	font-weight: bold;
	overflow: hidden;
	background-color: #e53835;
	border-bottom: 4px solid #cc1512;
}

.single-product form.cart .ux-buy-now-button:hover {
	border-bottom: 0;
}

.ux-buy-now-button::before{
  content: '';
  position: absolute;
  top: 0;
  left: -150%;
  width: 150%;
  height: 100%;
  background: linear-gradient(120deg,transparent,rgba(255,255,255,0.5),transparent);
  /* animation: streak 3.5s linear infinite; */
}

.ux-buy-now-button:hover::before {
	animation: none;
}

@keyframes streak{
  0%{left:-150%}
  100%{left:150%}
}

.product-info .woocommerce-breadcrumb {
	display: none;
}

.product-details__features {
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	margin: 20px 0 20px 0;
	padding: 20px 0 10px 0;
}

.product-details__features ul {
	list-style: none;
	
}

.product-details__features ul li {
	margin-left: 0px;
	padding-left: 0px;
	margin-bottom: 0;
}

.product-details__features .feature-icon {
	color: #4CAF50;
    font-size: 20px;
}

.product-details__trusted,
.product-details__trusted .trusted-item {
	display: flex;
    align-items: center;
}

.product-details__trusted {
	gap: 10px;
	margin: 15px 0;
	justify-content: space-between;
}

.product-details__trusted .trusted-item {
	flex-direction: column;
	text-align: center;
	justify-content: center;
}

.product-details__trusted .trusted-item__icon {
	display: inline-flex;
	width: 60px;
	height: 60px;
	justify-content: center;
    align-items: center;
	padding: 10px;
	background: #Eeeeee;
    border-radius: 50%;
    border: 1px solid #e1e1e1;
	margin-bottom: 10px;
}

.product-details__trusted .trusted-item__content {
	font-size: 14px;
	font-weight: 600;
	color: #222;
	max-width: 190px;
}

/** Single product review & shipping accordions **/
.product-details__reviews_shipping {
	margin-bottom: 30px;
}

.product-details__reviews_shipping .review-container {
  position: relative;
}
.product-details__reviews_shipping .review {
  display: none;
  align-items: flex-start;
}
.product-details__reviews_shipping .review.active {
  display: flex;
}
.product-details__reviews_shipping .review img {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  margin-right: 15px;
  margin-top: 10px;
}
.product-details__reviews_shipping .stars {
  color: gold;
  font-size: 20px;
}
.product-details__reviews_shipping .controls {
  text-align: center;
  margin: 0;
  display: inline-block;
  position: absolute;
  top: 15px;
  right: 0;
}
.product-details__reviews_shipping .accordion {
  border-top: 1px solid #ddd;
}
.product-details__reviews_shipping .accordion-item {
  border-bottom: 1px solid #ddd;
}
.product-details__reviews_shipping .accordion-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 15px 0;
  cursor: pointer;
  font-weight: bold;
}
.product-details__reviews_shipping .accordion-content {
  display: none;
  padding: 0 0 15px 0;
  color: #333;
}
.product-details__reviews_shipping .accordion-item.active .accordion-content {
  display: block;
}


.pp-h-22px {
	height: 22px;
}

.pp-w-22px {
	width: 22px;
}

.pp-min-w-22px {
	min-width: 22px;
}

.product-details__reviews_shipping .accordion-item.active .accordion-header__toggle_icon > svg {
	transform: rotate(180deg);
}

.product-details__reviews_shipping .accordion-header__icon,
.product-details__reviews_shipping .accordion-header__toggle_icon {
	cursor: pointer;
	z-index: 1;
}

.product-details__reviews_shipping .customer-name {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-bottom: 0;
}

.product-details__reviews_shipping .customer-name > svg {
	width: 18px;
}

.product-details__reviews_shipping .purchase-verified {
	font-size: 15px;
}


.product-details__reviews_shipping .nav-control {
	padding: 0;
	margin: 0;
}
.product-details__reviews_shipping .nav-control > svg {
	width: 20px;
	height: 20px;
	padding: 0;
	color: #b9b9b9;
}

.product-details__reviews_shipping .nav-control > svg:hover {
	color: #111;
}

.product-details__reviews_shipping .review-container {
	border-top: 1px solid #ddd;
	margin-top: 30px;
	padding-top: 20px;
}

.product-details__reviews_shipping .customer-content {
	font-size: 15px;
}

#custom-sticky-gallery-wrapper {
	position: sticky;
	top: 20px;
}


body.woocommerce-cart .wc-block-components-quantity-selector input.wc-block-components-quantity-selector__input:focus {
    box-shadow: inset 0 0 1px 1px #ddd;
}

body.woocommerce-cart  #wc-block-components-totals-coupon__input-coupon {
	border: 1px solid #ddd;
}

ul.product_list_widget li.wcpa_cart_meta_item {
	min-height: unset;
}

ul.product_list_widget li.wcpa_cart_meta_item .wcpa_cart_price {
	display: none;
}



.custom-desc-box1 {
	display: flex;
	column-gap: 80px;
	row-gap: 40px;
	align-items: center;
	margin: 80px 0;
}

.custom-desc-box1__col {
	flex: 1;
}

.custom-desc-label {
	font-size: 34px;
}

.custom-desc-box1__img img {
	border-radius: 20px;
	border: 1px solid #ddd;
}

.cta-to-buynow {
	display: block;
	width: 100%;
	padding: 8px 50px;
	font-size: 18px;
	margin-top: 40px;
	background: #333;
}

.cta-to-buynow:hover {
	background: #111;
}

@media screen and (max-width: 600px) {
	.custom-desc-box1,
	.custom-desc-box3,
	.custom-desc-box4 {
		flex-direction: column;
	}
}

.custom-desc-box2 .part-2 {
	display: flex;
	align-items: center;
	gap: 40px;
	margin: 80px 0;
}

.custom-desc-box2 .part-2 .icon-box__label {
	font-size: 22px;
	font-weight: bold;
	color: #111;
}

.custom-desc-box2 .part-2 .icon-box__desc {
	max-width: 350px;
}

.custom-desc-box2 .part-2 .icon-box__icon {
	font-size: 60px;
}

.custom-desc-box2 .part-2__col-1,
.custom-desc-box2 .part-2__col-3 {
	width: 400px;
}

.custom-desc-box2 .part-2__col-2 {
	flex-grow: 1;
}

.custom-desc-box2 .part-2__col-2 img {
	border: 1px solid #ddd;
	border-radius: 50%;
}

.mb-40 {
	margin-bottom: 40px;
}

@media screen and (max-width: 800px) {
	.custom-desc-box2 .part-2 {
		flex-wrap: wrap;
		gap: 0;
	}
	.custom-desc-box2 .part-2__col-1 {
		order: 2;
		flex: 0 0 50%;
	}
	.custom-desc-box2 .part-2__col-3 {
		order: 3;
		flex: 0 0 50%;
	}

	.custom-desc-box2 .part-2__col-2 {
		flex: 0 0 100%;
		order: 1;
		text-align: center;
	}

	.custom-desc-box2 .part-2 .icon-box__desc {
		padding: 0 20px;
	}

	.custom-desc-box2 .part-2__col-2 img {
		max-width: 400px;
		width: 100%;
		height: auto;
	}
}


@media screen and (max-width: 460px) {
	.custom-desc-box2 .part-2__col-1,
	.custom-desc-box2 .part-2__col-2,
	.custom-desc-box2 .part-2__col-3 {
		flex: 0 0 100%;
	}

	.custom-desc-box2 .part-2__col-1 {
		margin-top: 40px;
	}

	.product-details__reviews_shipping .customer-name {
		flex-wrap: wrap;
    	row-gap: 2px;
	}

	.product-details__reviews_shipping .customer-name b {
		flex: 0 0 100%;
	}
}

/** COMPARE BOX **/
.compare-box {
  display: flex;
  gap: 80px;
  align-items: center;
  font-family: Arial, sans-serif;
  margin: 80px 0;
}

.compare-box .compare-text {
  flex: 1;
}

.compare-box .compare-text p {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 20px;
}


.compare-box .compare-table {
  flex: 1;
  border-radius: 12px;
  overflow: hidden;
}

.compare-box .compare-header,
.compare-box .compare-row {
  display: flex;
  align-items: center;
}

.compare-box .compare-body .compare-row {
	align-items: stretch;
}

.compare-box .compare-header div,
.compare-box .compare-row div {
  flex: 1;
  padding: 14px;
  text-align: center;
}

.compare-box .compare-row div:first-child {
  text-align: center;
  background: #4a555f;
  color: white;
  font-weight: 500;
  border-bottom: 1px solid #656565;
}

.compare-box .compare-header div:first-child {
  background: #fff;
}

.compare-box .compare-header div {
  font-weight: 600;
  font-size: 18px;
  background: #fff;
}

.compare-box .check {
  font-size: 20px;
  font-weight: bold;
  max-width: 125px;
}

.compare-box .cross {
  color: #000;
  font-size: 20px;
  font-weight: bold;
  max-width: 125px;
}

/* Responsive */
@media (max-width: 768px) {
  .compare-box .compare-box {
    flex-direction: column;
  }
}

.compare-box .compare-body {
	border: 1px solid #ddd;
	border-radius: 15px;
	overflow: hidden;
}

.not-icon,
.checked-icon {
	width: 25px;
	height: 25px;
}

.text-black {
	color: #000;
}

@media screen and (max-width: 800px) {
	.compare-box .compare-text {
		flex: 0 0 250px;
	}
}

@media screen and (max-width: 750px) {
	.compare-box {
		flex-wrap: wrap;
	}
	.compare-box .compare-text {
		flex: 0 0 100%;
	}
}

@media screen and (min-width: 600px) and (max-width: 750px) {
	.compare-box .cross,
	.compare-box .check {
		max-width: 180px;
	}
}

@media screen and (max-width: 600px) {
	.compare-box {
		gap: 30px;
	}
	.compare-box .cross,
	.compare-box .check {
		max-width: 80px;
	}

	.compare-box .compare-header .first-col {
		flex: 0 0 0;
		width: 0;
	}

	.compare-box .compare-header .cross {
		flex: 0 0 80px;
		max-width: 80px;
	}

	.compare-box .compare-header .check {
		flex: 1;
		min-width: 0;
		max-width: unset;
		text-align: right;
	}
}


/** Box description 3 **/
.custom-desc-box3 {
	display: flex;
	column-gap: 80px;
	row-gap: 40px;
	align-items: center;
	margin: 80px 0;
}

.custom-desc-box3 img {
	border-radius: 20px;
    border: 1px solid #ddd;
}

.custom-desc-box3 h2 {
	margin-bottom: 30px;
}

/** Box description 4 **/
.custom-desc-box4 {
	display: flex;
	column-gap: 80px;
	row-gap: 40px;
	align-items: center;
	margin: 80px 0;
}

.custom-desc-box4 .part-1,
.custom-desc-box4 .part-2 {
	width: 50%;
}

.custom-desc-box4 img {
	border-radius: 20px;
    border: 1px solid #ddd;
}

.custom-desc-box4 h2 {
	margin-bottom: 30px;
}

.custom-desc-box4 ul {
	padding-left: 20px;
}


@media screen and (max-width: 600px) {
	.custom-desc-box4 {
		flex-direction: column-reverse;
	}
	.custom-desc-box4 .part-1,
	.custom-desc-box4 .part-2 {
		width: 100%;
	}
}

/** Product FAQs **/
.faq-container {
  max-width: 900px;
  width: 100%;
  padding: 40px 20px;
  margin: 80px auto;
}

.faq-container .faq-item {
  border: 1px solid #0003;
  border-radius: 16px;
  margin-bottom: 20px;
  overflow: hidden;
}

.faq-container .faq-question {
	background: #fff;
	border: none;
	outline: none;
	width: 100%;
	text-align: left;
	padding: 18px 20px;
	font-size: 16px;
	font-weight: bold;
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
	margin: 0;
	text-transform: none;
}

.faq-container .faq-question:hover {
  background: #f9f9f9;
}


.faq-container .faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  padding: 0 16px;
  color: #444;
}

.faq-container .faq-answer.open {
  padding: 10px 16px 20px;
  max-height: unset;
}

.faq-container .arrow {
  transition: transform 0.3s ease;
  line-height: 22px;
  height: 22px;
}

.faq-container .arrow.open {
  transform: rotate(180deg);
}

.faq-container .btn {
  display: inline-block;
  background: #000;
  color: #fff;
  font-weight: bold;
  padding: 16px 30px;
  text-decoration: none;
  border-radius: 10px;
  margin-top: 30px;
  text-align: center;
  transition: background 0.3s ease;
}

.faq-container .btn:hover {
  background: #333;
}

.mb-80 {
	margin-bottom: 80px;
}

.m-w-800 {
	max-width: 800px;
}

.m-w-400 {
	max-width: 400px;
}

.risk-free-icon {
	text-align: center;
}

.risk-free-icon img {
	width: 80px;
}

.related-products-wrapper {
	padding-bottom: 100px;
}

.related-products-wrapper .product-section-title {
	text-align: center;
	margin-top: 40px;
}

.wc-block-cart-item__product .wc-block-cart-item__wrap a,
.woocommerce-mini-cart li a {
	color: #222;
	font-weight: bold;
}

.trusted-gateway-logos {
	margin: 20px 0;
}

.trusted-gateway-logos img {
	width: 100%;
}

/** Single product sticky bar **/
/* Sticky bottom bar */
.product-sticky-bar {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	background: #fff;
	border-top: 1px solid #ccc;
	box-shadow: 0 -2px 8px rgba(0,0,0,0.1);
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 10px 20px;
	z-index: 9999;
	transition: transform 0.3s;
	transform: translateY(100%); /* ẩn ban đầu */
}

.product-sticky-bar.show {
	transform: translateY(0); /* hiển thị */
}

.product-sticky-bar .product-info {
	display: flex;
	align-items: center;
	width: calc(100% - 160px);
}

.product-sticky-bar .product-info img {
	height: 50px;
	width: auto;
	margin-right: 10px;
	object-fit: cover;
}

.product-sticky-bar .product-info span {
	font-weight: bold;
}

.product-sticky-bar button.shop-now-btn {
	background: #333;
	color: #fff;
	padding: 8px 15px;
	border-radius: 4px;
	border: none;
	cursor: pointer;
	margin: 0;
	width: 160px;
}

.product-sticky-bar button.shop-now-btn:hover {
	background: #000;
}


.btn-sizechart {
	background: #efefef;
    color: #000;
    font-size: 12px;
    text-transform: capitalize;
}

.btn-sizechart:hover {
	background: #111;
    color: #fff;
}

#newsletter-signup-link {
	border-radius: 12px;
	text-align: center;
	padding-bottom: 0!important;
}

#newsletter-signup-link h2 {
	font-size: 52px;
	margin-bottom: 5px;
	line-height: 1.2;
}

#newsletter-signup-link h3 {
	font-size: 28px;
	margin-bottom: 5px;
	line-height: 1.2;
}

#newsletter-signup-link p.desc {
	font-size: 18px;
}

#newsletter-signup-link .form-flat input[type="text"],
#newsletter-signup-link .form-flat input[type="email"] {
	border-radius: 5px;
	height: 52px;
}

#newsletter-signup-link .form-flat input[type="submit"] {
	width: 100%;
    padding: 10px 0;
    margin-top: 10px;
}

#newsletter-signup-link form.wpcf7-form {
	margin-bottom: 0;
}

.popup-newsleter-signup .popup-trigger {
	display: block;
    position: fixed;
    bottom: 20px;
    left: 20px;
    width: 56px;
    height: 56px;
	background: #eee;
	border: 1px solid #ddd;
    border-radius: 50%;
	transition: background-color 0.3s ease;
}

.popup-newsleter-signup .popup-trigger:hover {
	background: #333;
	border: 1px solid #333;
}

.popup-newsleter-signup .popup-trigger a {
	position: relative;
	display: block;
	color: #666;
	transition: color 0.3s ease;
	width: 100%;
	height: 100%;
	padding: 10px;
}

.popup-newsleter-signup .popup-trigger:hover a {
	color: #fff;
}

.popup-newsleter-signup .popup-trigger .trigger-count {
	position: absolute;
	top: -6px;
    left: 38px;
	display: block;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background-color: var(--fs-color-primary);
	text-align: center;
	color: #fff;
	line-height: 18px;
	font-size: 12px;
	font-weight: bold;
}


@media screen and (max-width: 460px) {
	.product-sticky-bar {
		flex-direction: column;
	}
	.product-sticky-bar .product-info,
	.product-sticky-bar button.shop-now-btn {
		width: 100%;
	}

	.product-sticky-bar button.shop-now-btn {
		margin-top: 15px;
		padding: 5px 0;
	}

	#newsletter-signup-link {
		padding: 40px 20px 0 20px!important;
	}

	#newsletter-signup-link h2 {
		font-size: 32px;
	}
	#newsletter-signup-link h3 {
		font-size: 18px;
	}

	#newsletter-signup-link p.desc {
		font-size: 16px;
		line-height: 1.2;
	}
}


body .grecaptcha-badge {
	right: -99999999px!important;
}

.starting-price-text {
	color: #333;
	font-size: 16px;
	font-weight: 700;
}

.mfp-content.off-canvas-cart {
	background: #fff;
}

#cart-popup ul.product_list_widget li img {
	border: 1px solid #ddd;
    border-radius: 5px;
}

#cart-popup .payment-icons.inline-block {
	/* text-align: center;
	margin-bottom: 20px; */
	display: none;
}

.widget_shopping_cart .woocommerce-mini-cart__buttons .button {
	padding-top: 1px;
	padding-bottom: 1px;
}


.widget_shopping_cart .woocommerce-mini-cart__buttons .button[href*="/cart"] {
	background: #f1f1f1;
    color: #000;
    border: 1px solid #ddd;
}

.widget_shopping_cart .woocommerce-mini-cart__buttons .button[href*="/cart"]:hover {
	background-color: #ff4c60 !important;
	border-color: #ff4c60 !important;
	box-shadow: inset 0 0 0 100px rgba(0, 0, 0, .2);
	color: #fff;
}

#cart-popup .inner-padding {
    padding-left: 20px;
    padding-right: 20px;
}

.ux-mini-cart-footer .woocommerce-Price-amount,
.wc-block-cart-item__prices ins.wc-block-components-product-price__value {
    color: #ad2e08;
}


.off-canvas .off-canvas-cart .ux-mini-cart-footer{
	padding-top: 0;
	padding-bottom: 20px;
}

.ux-mini-cart-footer .amount {
	font-size: 20px;
}

.ux-mini-cart-footer .woocommerce-mini-cart__total {
	align-items: center;
}

.trust-badges-checkout {
	margin-bottom: 20px;
	text-align: center;
}

.trust-badges-checkout small {
	text-align: center;
	margin-bottom: 5px;
}

.trust-badges-checkout img {
	width: auto;
	height: 25px;
	margin: auto;
}

.off-canvas.mfp-ready .mfp-content.off-canvas-cart {
    --drawer-width: 390px;
}

.free-shipping-notice .free-shipping-bar {
	height: 8px;
    background: #e2e2e2;
    position: relative;
	border-radius: 5px;
	overflow: hidden;
}

.free-shipping-notice .free-shipping-bar span {
    height: 100%;
    background-image: linear-gradient(-45deg, rgba(252, 247, 247, .15) 25%, transparent 0, transparent 50%, rgba(252, 247, 247, .15) 0, rgba(252, 247, 247, .15) 75%, transparent 0, transparent);
    background-color: #178b00;
    background-size: 1rem 1rem;
    animation: shipping-stripe-left 5s linear infinite;
    border-radius: 5px 0 0 5px;
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
}

@keyframes shipping-stripe-left {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 20px 0;
  }
}

body.woocommerce-cart .wp-block-woocommerce-cart-order-summary-totals-block,
body.woocommerce-cart .wp-block-woocommerce-cart-order-summary-coupon-form-block {
	font-size: 16px;
}

body.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
	font-size: 18px;
}

body.woocommerce-cart #wc-block-components-totals-coupon__form button .wc-block-components-button__text {
	font-size: 16px;
    text-transform: capitalize;
}

body.woocommerce-cart .wc-block-components-totals-item__value .wc-block-components-totals-footer-item-tax-value {
	color: #ad2e08;
}


/** Product crafting timeline **/
.crafting-section-container {
	border-top: 1px solid #ddd;
	padding-top: 30px;
}

.crafting-section {
	text-align: center;
	max-width: 800px;
	margin: 0 auto;
	font-family: Arial, sans-serif;
	padding: 20px;
}

.crafting-section h2 {
	font-size: 28px;
	font-weight: bold;
}

.crafting-section .highlight {
	background: #e60000;
	color: white;
	display: inline-block;
	padding: 6px 14px;
	margin: 10px 0;
	font-weight: bold;
	font-size: 20px;
}

.crafting-section .steps {
	font-size: 18px;
	margin: 15px 0;
	font-weight: bold;
}

.crafting-section .desc {
	line-height: 1.6;
}

.crafting-section .timeline {
	display: flex;
	justify-content: space-around;
	margin-top: 15px;
}

.crafting-section .step {
	flex: 1;
	padding: 10px;
}

.crafting-section .circle {
	width: 90px;
	height: 90px;
	background: #333;
	color: white;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	flex-direction: column;
	align-items: center;
	margin: 0 auto 10px;
	font-weight: bold;
	font-size: 18px;
}

.crafting-section .circle .label {
	font-size: 15px;
}

.crafting-section .circle .value {
	font-size: 22px;
}

.crafting-section .step h4 {
	font-size: 16px;
	margin-top: 8px;
}

.crafting-section .sub-heading {
	margin-top: 35px;
}

@media screen and (max-width: 420px) {
	.crafting-section .timeline {
		flex-wrap: wrap;
	}

	.crafting-section .timeline .step:nth-child(1),
	.crafting-section .timeline .step:nth-child(2) {
		flex: 0 0 50%;
	}
}

.mb-15 {
	margin-bottom: 15px;
}

body.archive .product-small.col,
body.archive .product-small.col .col-inner,
body.archive .product-small.col .product-small.box  {
	border-radius: 8px;
}

body.archive .product-small.col .product-small.box {
	overflow: hidden;
}

.product-size-chart {
	text-align: right;
}


/** Personalized box **/
.tuyenpro-personalized-box{
	margin-top:20px;
	padding:18px;

	border:1px solid #e5e5e5;
	border-radius:8px;
	background:#fafafa;
}

.tuyenpro-title{
	font-size:18px;
	font-weight:700;
	margin-bottom:12px;
}

.tuyenpro-personalized-box label{
	display:block;
	font-weight:600;
	margin-bottom:6px;
}

.tuyenpro-personalized-box input,
.tuyenpro-personalized-box textarea{
	width:100%!important;
	max-width: 100%!important;
	min-width: 100%!important;
	padding:10px;

	border:1px solid #ddd;
	border-radius:6px;
	font-size: 14px!important;
}

.tuyenpro-personalized-box input:focus,
.tuyenpro-personalized-box textarea:focus{
	border-color:#000;
	outline:none;
}

.tuyenpro-personalized-box textarea {
	min-height: 70px;
}


.tuyenpro-personalized-box .form-row small {
	font-size: 12px;
	margin-top: -10px;
	font-style: italic;
	color: #797979;
}

/** Cart page **/

body.woocommerce-cart .woocommerce-cart-form__cart-item .product-name > a {
	font-size: 16px;
	color: #333;
	font-weight: 600;
}


/** MISC **/
.category-filtering {
	display: none;
}

