/**
 * Theme Name: Blocksy Child
 * Description: Blocksy Child theme
 * Author: Creative Themes
 * Template: blocksy
 * Text Domain: blocksy
 */

/* Hero Slider */
.hero-slider {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: #f5f5f5;
    border-radius: 15px;
}

.hero-slider-wrapper {
    position: relative;
    width: 100%;
}

.hero-slide {
    display: none;
    width: 100%;
}

.hero-slide.active {
    display: block;
}

.hero-slide img {
    width: 100%;
    height: auto;
    display: block;
}

.hero-slide picture {
    display: block;
    width: 100%;
}

.hero-slide picture img {
    width: 100%;
    height: auto;
    display: block;
}

.hero-slider-prev,
.hero-slider-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.9);
    color: #778867;
    border: none;
    width: 50px;
    height: 50px;
    font-size: 24px;
    cursor: pointer;
    z-index: 10;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.hero-slider-prev:hover,
.hero-slider-next:hover {
    background: #778867;
    color: #fff;
}

.hero-slider-prev {
    left: 20px;
}

.hero-slider-next {
    right: 20px;
}

.hero-slider-dots {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
    z-index: 10;
}

.hero-slider-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.5);
    border: 2px solid #778867;
    cursor: pointer;
    transition: all 0.3s ease;
}

.hero-slider-dot.active,
.hero-slider-dot:hover {
    background: #778867;
}

/* Hero Slider Responsive */
@media (max-width: 768px) {
    .hero-slider-prev,
    .hero-slider-next {
        width: 40px;
        height: 40px;
        font-size: 18px;
    }

    .hero-slider-prev {
        left: 10px;
    }

    .hero-slider-next {
        right: 10px;
    }

    .hero-slider-dots {
        bottom: 10px;
    }

    .hero-slider-dot {
        width: 10px;
        height: 10px;
    }
}

/* Service Boxes */
.service-boxes {
    width: 100%;
    max-width: 100% !important;
    padding: 25px 0;
    background: #F0F3EF;
    margin: 50px 0 55px;
}

.service-boxes-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    gap: 15px;
    max-width: 1290px;
    margin: 0 auto;
    padding: 0;
}

.service-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 20px 15px;
    flex: 1;
    min-width: 180px;
    max-width: 230px;
    background: #778867;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    transition: all 0.3s ease;
}

.service-box:hover {
    transform: translateY(-5px);
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(151, 181, 111, 0.5);
}

.service-icon {
    width: 50px;
    height: 50px;
    margin-bottom: 12px;
    color: #fff;
    transition: all 0.3s ease;
}

.service-icon svg {
    width: 100%;
    height: 100%;
}
.service-box:hover .service-title,
.service-box:hover svg{
    color: #778867;
}
.service-box:hover .service-icon {
    color: #C9A87C;
    transform: scale(1.1);
}

.service-title {
    font-family: 'Lato', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #ffffff;
    line-height: 1.4;
}

/* Service Boxes Responsive */
@media (max-width: 1024px) {
    .service-boxes-wrapper {
        justify-content: center;
    }

    .service-box {
        min-width: 150px;
        max-width: 180px;
        padding: 15px 10px;
    }

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

@media (max-width: 768px) {
    .service-boxes {
        padding: 20px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .service-boxes-wrapper {
        flex-wrap: nowrap;
        justify-content: flex-start;
        gap: 12px;
        padding: 0 10px;
    }

    .service-box {
        min-width: 140px;
        max-width: 140px;
        padding: 15px 10px;
        flex-shrink: 0;
    }

    .service-icon {
        width: 40px;
        height: 40px;
    }

    .service-title {
        font-size: 12px;
    }
}

/**----------------------------------------------------
    This Code was added by Energiedin
 ---------------------------------------------------- **/

body.no-scroll {
    overflow: hidden;
}

.laptopWidth {
	max-width: 1290px !important;
	width: 1290px !important;
}

.page-id-12135 img.wp-image-12158 {
	position: relative;
    top: 65px;
    left: 35px;
    z-index: 1;
}
/* Home Page */
.DecouvrezNosProduitsLeft {
	display: flex;
	flex-direction: column;
	justify-content: end;
} 

div#gspb_container-id-gsbp-570e2e50-6e3b {
	display: flex;
	align-items: center;
}
div#gspb_container-id-gsbp-7347da23-b4b9 {
	position: absolute;
	padding: 15px;
	color: white;
}
div#gspb_container-id-gsbp-7347da23-b4b9 h3 {
		color: white;
}
/*Card*/
ul.products .product {
 	border: 1px solid #778867 !important;
 	min-height: calc(383px - 20px) !important;
 	/*width: 232px !important;*/
 	border-radius: 8px;
 	padding: 0 !important;
 	margin: 0 !important;
 	justify-content: space-between;
 	padding: 0 0 12px 0 !important;
 }

ul.products .product a.button.product_type_variable.add_to_cart_button {
	padding: 10px !important;
    font-size: 10px !important;
    min-height: fit-content !important;
    margin-bottom: 24px !important;
}
 ul.products .product .wp-post-image {
 	border-radius: 8px 8px 0 0 !important;
 	background: #fff;
 }
 ul.products .product a.button.product_type_simple {
 	padding: 0 10px !important;
 	font-size: 12px !important;
 }
ul.products .product a.button.product_type_simple,
ul.products .product a.added_to_cart.wc-forward {
	height: 45px !important;
	min-height: 45px !important;
	padding: 10px !important;
	font-size: 12px !important;
}
ul.products .product .button.product_type_simple.add_to_cart_button.ajax_add_to_cart {
	font-size: 0px !important;
	height: 45px !important;
	min-height: 45px !important;
	width: 45px !important;
	padding: 0px !important;
	margin: 0px !important;
}
ul.products .product .button.product_type_simple.add_to_cart_button.ajax_add_to_cart::after {
	content: " ";
	background-image: url('/wp-content/uploads/2025/09/wishlisticon.svg');
	background-repeat: no-repeat;
	background-position: center;
	height: 20px;
	width: 100%;
	background-size: contain;
}

/*Title*/
ul.products .product .woocommerce-loop-product__title {
	text-align: left !important;
}
ul.products .product span.onsale {
	display: none;
}

ul.products .product .woocommerce-LoopProduct-link.woocommerce-loop-product__link,
ul.products .product .woocommerce-loop-product__title {
	font-weight: 700 !important;
	font-size: 17px !important;
	color: #4B4743 !important;
	line-height: 25.5px !important;
	text-align: left !important;
}

/*Price*/
ul.products .product .price {
  display: inline-block !important;
  width: 100% !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  font-size: 22px !important;
  /*color: #D53541 !important;*/
  position: unset;
  text-align: left;
}

ul.products .product span.sale-price {
  display: inline-flex;
  justify-content: flex-start;
  position: unset;
}

ul.products .product del {
  display: inline-block;
  margin-right: 8px;
  font-size: 16px !important;
  color: #4B4743 !important;  
  text-decoration: none !important;
  opacity: 1 !important;
}

ul.products .product ins {
  display: block;
  font-size: 22px !important;
  font-weight: 700 !important;
  /*color: #D53541 !important;*/
  text-decoration: none !important;
  margin-top: 6px;
}

span.discount span {
	font-size: 12px !important;
}
.NotreSelectionMoment .product span.discount,
ul.products .product span.discount {
  position: unset;
  top: 12px;
  right: -5px;
  transform: unset;
  height: 23px !important;
  background: #D53541 !important;
  border-radius: 8px !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: #fff !important;
  padding: 1px 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  order: unset; 
}
ul.products .product bdi {
	text-decoration: none !important;
}
/*ul.products .product .price del bdi::after {
    content: ' ';
    background: #FFFF54;
    height: 2px;
    width: 100%;
    display: flex;
    transform: rotate(-8.4deg);
    position: absolute;
    top: 5px;
}*/


/* Wishlist Button */
ul.products .product .ct-woo-card-actions {
    padding: 0 15px !important;
}
/* Btn Add to wish list */
ul.products .product .ct-woo-card-actions {
	width: fit-content !important;
	justify-content: end;
	padding: 0 !important;
	margin: 0 !important;
	position: absolute;
	bottom: 10px;
	right: 15px;
}

.nouveautespage div.woo-listing-top {
	display: none;
}

.custom-loop-description,
.products .product .entry-meta,
.products .product .ct-compare-button-archive,
.products .product .ct-open-quick-view,
.products .product .ct-wishlist-button-archive span {
	display: none !important;
}

ul.products .product .ct-wishlist-button-archive {
	display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 29px;
    height: 26px;
    cursor: pointer;
    position: relative;
    border: none;
    background: none;
    padding: 0;
    position: relative;
    top: -8px;
}

ul.products .product .ct-wishlist-button-archive:hover {
	background: none !important;
}

ul.products .product .ct-wishlist-button-archive::after {
	content: ' ';
	background-image: url('/wp-content/uploads/2025/09/heart.svg');
	background-repeat: no-repeat;
	background-position: center;
	height: 100% !important;
	width: 100% !important;
	fill: none !important;
	stroke: #4B4743 !important;
}

.ct-woo-card-extra[data-type=type-1] .ct-button:is(:hover,[data-button-state=active],[data-button-state=loading]) {
	 background: none !important;	
}
ul.products .product .ct-wishlist-button-archive:hover::after,
ul.products .product .ct-wishlist-button-archive[data-button-state="active"]::after {
  background-image: url('/wp-content/uploads/2025/09/heartHover.svg');
}

ul.products .product .has-hover-effect img {
	transition: none !important;
	height: auto;
	width: 100%;
	object-fit: contain;
}
.nouveautespage .product .has-hover-effect img {
	height: auto !important;
}


.page-id-1071 div.woocommerce-info:before {
	display: none !important;
}



/*  Notre Selection Du Moment Cards */
.NotreSelectionMoment .product {
	padding-top: 10px;
	background-color: #F9FFF1 !important;
	width: 420px !important;
	min-height: 233px !important;
	border-radius: 20px !important;
	display: flex !important;
	flex-wrap: wrap !important;
	position: relative;
	flex-direction: unset !important;
	justify-content: center !important;
	position: relative;
}
.NotreSelectionMoment .product span.discount {
	top: 24px !important;
	right: 34px !important;
}

.NotreSelectionMoment .custom-loop-description {
	display: flex !important;
}
.NotreSelectionMoment .product .wp-post-image {
	height: auto !important;
	width: 100% !important;
	object-fit: contain !important;
	mix-blend-mode: multiply !important;
}

.NotreSelectionMoment .product .ct-woo-card-extra,
.NotreSelectionMoment .product .entry-meta {
	display: none !important;
}

.NotreSelectionMoment .product .ct-woo-card-actions {
	width: 100% !important;
}

.NotreSelectionMoment .product .ct-woo-card-actions a {
	width: 100% !important;
	border-radius: 0 0 20px 20px !important;
	font-weight: 600 !important;
	font-size: 20px !important;
	line-height: 14px !important;
	color: white !important;
	background: #778867 !important;
}

.NotreSelectionMoment .product .woocommerce-loop-product__title {
	font-weight: 600 !important;
	font-size: 20px !important;
	color: #4B4743 !important;
	min-width: 50% !important;
	width: 50% !important;
	text-align: left !important;
	order: -1;
	line-height: 28px;
	display: flex;
	flex-direction: column;
}
.NotreSelectionMoment .product figure {
	width: 37% !important;
}
.NotreSelectionMoment .product .ct-media-container {
	background: #F9FFF1 !important;
}
/*.NotreSelectionMoment .product .price*/

.NotreSelectionMoment .custom-loop-description {
	color: #888888;
	font-weight: 400;
	font-size: 14px;
	line-height: 112.99%;
	text-align: left;
	width: 100%;
	margin-top: 5px;
	display: flex;
}
.custom-loop-description,
.NotreSelectionMoment .product .price bdi,
.NotreSelectionMoment .product .price bdi{
	display: none;
}

/* BLOGS */
.blogs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.blogs-grid .blog-item {
	position: relative;
	width: 380px;
	min-height: 446px;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.NotreSelectionMoment  span.onsale {
	display: none;
}
.blogs-grid .blog-item img {
	width: 380px;
	height: 214px;
	object-fit: cover;
	margin-top: 40px;
}

.blogs-grid .blog-item .blog-date {
	font-size: Lato;
	position: absolute;
	top: 0;
	background: #D53541;
	min-width: 85px;
	height: 85px;
	left: 29px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: white;
	font-size: 16px;
	line-height: 16px;
	letter-spacing: 1px;
	text-transform: uppercase;
	font-weight: 600;
	padding: 0 5px;
}
.blogs-grid .blog-item .blog-date span {
	font-size: 32px;
	margin-bottom: 10px;
}

.blogs-grid .blog-item .blog-linkBlog {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 75px;
	height: 34px;
	border-radius: 25px;
	border: 1px solid #D53541;
	background: white;
	font-weight: 700;
	font-size: 16px;
	line-height: 14px;
	letter-spacing: 1px;
	color: #D53541;
	margin: 25px auto 10px 0;
}
.blogs-grid .blog-item .blog-linkBlog:hover {
	background: #D5354133;
	border: none;
}

.blogs-grid .blog-item .blog-title,
.blogs-grid .blog-item .blog-title a {
	font-weight: 600;
	font-size: 18px;
	line-height: 28px;
	color: #121212;
	width: 100%;
	text-align: left;
}

.blogs-grid .blog-item .read-more-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    height: auto;
    width: auto;
    border-radius: 50px;
    background: #778867;
    font-weight: 700;
    font-size: 18px;
    line-height: unset;
    letter-spacing: 1px;
    color: #fff;
    margin-top: auto;
    padding: 15px 25px;
}
.blogs-grid .blog-item .read-more-btn:hover {
	background: #7E9560;
}


/* form */
.fluentform .ff-el-input--label {
	display: none !important;
}



/* FOOTER */
body:not(.home):not(.page-id-20) #post-167 {
    margin-top: 40px;
}

#post-2309 {
	margin-top: 20px;
}

footer h6 {
	color: #4B4743 !important;
	font-weight: 700 !important;
	font-size: 16px !important;
	line-height: 24px !important;
}

footer li a {
	font-size: 16px !important;
	font-weight: 400 !important;
	line-height: 26.4px !important;
}

footer p {
	color: #4B4743 !important;
	font-weight: 400 !important;
	font-size: 16px !important;
	line-height: 26.4px !important;
}

footer .ct-footer-copyright {
	font-size: 15px !important;
	line-height: 19.5px !important;
}

footer div.ct-social-box {
	--theme-icon-color: #778867 !important;
}

/* CONTACT FORM */
.contactForm form {
	min-width: 756.35px !important;
}
.contactSocial div.gspb_iconBox__wrapper {
    background: none !important;
    border: 1px solid #DADEE480;
    border-radius: 40px;
}

.contactForm form input,
.contactForm form textarea {
	background: white !important;
	border: 1px solid #E6E6E6 !important;
	border-radius: 10px !important;
	max-width: 100% !important;
}

.contactForm div.wpforms-field-row.wpforms-field-medium {
	max-width: 100% !important;
}
.contactForm form label {
	display: none !important;
}

.contactForm form .ff-btn.ff-btn-submit.ff-btn-md.ff_btn_style {
	height: 44px !important;
	width: 245px !important;
	border-radius: 50px !important;
	background: #778867 !important;
	font-size: 16px !important;
	line-height: 14px !important;
	letter-spacing: 1px !important;
	color: white !important;
}

.contactForm form .ff-el-group.ff-text-left.ff_submit_btn_wrapper {
	text-align: center !important;
}

.contactForm form .ff-btn.ff-btn-submit.ff-btn-md.ff_btn_no_style {
	width: 245px !important;
}


/* Menu */
header { box-shadow: none !important }
header #menu-menufr {
	align-items: center !important;
}
header #menu-menufr li,
header #menu-menufr li a{
	color: #000000 !important;
	font-weight: 400;
	font-size: 16px;
	line-height: 19.5px;
}

header {
	box-shadow: 0 4px 16.7px #0000000D;
	margin-bottom: 30px;
}
header #menu-menufr .menu-item-146534 {
	border: 1px solid #D1D5DB;
	height: 44px !important;
	width: 168px !important;
	border-radius: 79px;
	color: #778867 !important;
	font-size: 16px;
	font-weight: 700;
	line-height: 16.7px;
	text-transform: capitalize !important;
	display: flex !important;
	align-items: center;
	justify-content: center;
	gap: 8px;
	cursor: pointer;
}

header #menu-menufr .menu-item-146534::before {
	content: " "; 
    display: inline-block;
	background-image: url('/wp-content/uploads/2026/01/Vector-11.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	display: inline-block;
	height: 12px;
	width: 18px;
}

header #menu-menufr .menu-item-146534 a.ct-menu-link {
	padding: 0 !important;
	margin: 0 !important;
	width: fit-content !important;
	text-transform: math-auto !important;
	color: #778867 !important;
	font-weight: 700;
	font-size: 16px;
	line-height: 15.6px;
}

header .sub-menu.hierarchical-categories {
    position: absolute;
    /*left: 0%;*/
    /*top: 82px;*/
    background: none;
    height: 100vh;
    overflow-y: auto;
    /*width: 900px; */
    display: flex;
    z-index: 9999;
    /* ------------------- */
    width: 100% !important;
    max-width: calc(1290px + 40px) !important;
    left: 50% !important;	
    transform: translateX(-50%);
    top: 83px !important;
}

@media (max-width: 1430px) {
	header .sub-menu.hierarchical-categories {
		max-width: calc(90vw + 40px) !important;
	}
}

/* *********************** */
/* page product edit price */

.single-product .price {
	/*border: 1px solid red;*/
	gap: 10px;
}
.single-product span.sale-price {
	justify-content: start !important;
}
.single-product span.sale-price del {
	order: 0 !important;
	font-size: 20px !important;
	font-weight: 700 !important;
	line-height: 24.75px !important;
	color: #4B4743 !important;
	opacity: 1 !important;
}
/*.single-product span.sale-price del::before {
	content: ' ';
	display: block;
	background: #FFFF54;
	height: 2px;
	width: 88.95px;
	position: absolute;
	top: 45%;
	transform: rotate(-8.4deg);
}*/
.single-product span.discount {
	background: #D53541;
	border-radius: 8px;
	padding: 0px 10px;
	color: #FFFFFF;
	font-size: 16px;
	line-height: 25px;
	font-weight: 500;
}
.single-product .price del bdi {
	text-decoration: none !important;
}
.single-product .product-entry-wrapper .price ins .woocommerce-Price-amount.amount {
	color: #D53541;
	font-weight: 800;
	font-size: 31px;
	line-height: 24.75px;
	width: 100% !important;
}
.single-product .price ins {
	width: 100% !important;
}
.single-product span.sale-price {
	row-gap: 10px !important;
}
/* *********************** */

.category-column {
    flex: 1;
    border-right: 1px solid #eee;
    overflow-y: auto;
}

.category-column:last-child {
    border-right: none;
}

.main-column {
    background: white;
    max-width: 300px;
}

.sub-column, .subsub-column {
    background: white;
    max-width: 300px;
}

.column-header {
    padding: 15px;
    border-bottom: 1px solid #eee;
}

.column-header h3 {
    margin: 0 0 5px 0;
    font-size: 16px;
    font-weight: 600;
    color: #000;
}

a.view-all {
    color: #707070 !important;
    text-decoration: none;
    font-size: 14px !important;
    line-height: 19.5px !important;
    text-transform: initial !important;
}

.category-item {
    list-style: none;
}

.category-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 50px;
    padding: 0 20px;
    text-decoration: none;
    color: #000;
    transition: background-color 0.2s;
    font-size: 16px;
    line-height: 19.5px;
}

.category-link:hover,
.category-item.active .category-link {
    background-color: #f8fdf1;
    color: #778867 !important;
}


.category-arrow {
    font-size: 10px;
    color: #666;
}

ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.mobileLinks {
	display: flex;
	flex-direction: column;
}

.mobileLinks a {
	padding: 20px;
	border-bottom: 1px solid #f0f0f0;
}
.mobileLinks a:first-child,
header #menu-item-146536 a.ct-menu-link {
	color: #D53541 !important;
	font-size: 16px !important;
	line-height: 15.6px !important;
	text-transform: capitalize !important;
	font-weight: 400 !important;
}

.mobileLinks a:nth-child(2),
header #menu-item-12247 a.ct-menu-link {
	color: #B45309 !important;
	font-size: 16px !important;
	line-height: 15.6px !important;
	text-transform: capitalize !important;
	font-weight: 400 !important;
}

.mobileLinks a:last-child,
header #menu-item-12389 a.ct-menu-link {
	color: #2346B0 !important;
	font-size: 16px !important;
	line-height: 15.6px !important;
	text-transform: capitalize !important;
	font-weight: 400 !important;
}



.wp-block-columns.is-layout-flex.wp-container-core-columns-is-layout-5b601ef2.wp-block-columns-is-layout-flex {
    gap: 20px;
}

./*ct-drawer-canvas {
	display: none !important;
}*/

header div.ct-panel-inner {
	display: none !important;
}




/*SEARCH*/
.nasa-show-search-form {
	border: none !important;
}
div.nasa-show-search-form.nasa-search-relative.nasa-rightToLeft {
	border: none !important;
	background: none !important;
}
form.nasa-search.nasa-ajax-search-form {
	width: 511.5px;
	height: 50px;
	display: flex;
	align-items: center;
	border: 2px solid #778867;
	border-radius: 45px;
	
}

form input#nasa-input-1.search-field.search-input.live-search-input.nasa-header-input-search {
	width: 461.5px;
	border: none !important;
	color: #4B4743 !important;
	background: none;
}
button.nasa-submit-search {
	font-size: 0 !important;
	background: none !important;
	background-image: url('/wp-content/uploads/2025/09/Vector-2.svg') !important;
	background-repeat: no-repeat !important;
	background-size: contain !important;
	height: 26.09px !important;
	width: 26.02px !important;
}

form label.hidden-tag {
	display: none !important;
}

div #searchOverlay.search-overlay {
    top:150px !important;
    padding: 50px 5%;
}

div .typing-search-wrapper,
div .h3.gds-title.ClientsSearchesList_gwz-clients-searches-list_title_41U90 {
	color: #4B4743 !important;
}

.jnl-search-products-and-post h3, .jnl-search-texonomies h3, h3.jnl-sub-sub-menu-title {
	color: #000;
}

.jnl-search-results .gds-icon {
	max-height: 25px !important;
}

header #darkenOverlay {
	position: absolute;
}
header .jnl-search-results ul.products {
	gap: 9px !important;
	flex-wrap: nowrap !important;
}

header .jnl-search-products h3:last-of-type,
header .jnl-search-products div.jnl-search-posts {
	display: none !important;
}
/*--------------PRODUCT*/

div .typing-search-wrapper li.product {
	background: #fff;
	/*box-shadow: 2px 2px 5px 3px #00000024;*/
	border: 1px solid #778867;
}
div .typing-search-wrapper li.product span.woocommerce-Price-amount.amount {
	color: #D53541 !important;
}
header .jnl-search-products li.product {
	flex-direction: unset !important;
	flex-wrap: wrap;
	justify-content: space-between;
}
h2.woocommerce-loop-product__title a,
h3.woocommerce-loop-product__title a{
	font-size: 17px !important;
    color: #1f2737 !important;
    font-weight: 700;
    overflow: hidden;
    white-space: normal;
    text-overflow: ellipsis;
    line-height: 20px !important;
    text-align: left;
    display: flex;
}

div .typing-search-wrapper li.product ul.entry-meta,
div .typing-search-wrapper li.product figure {
	order: -1;
}
div .typing-search-wrapper li.product ul.entry-meta {
	width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
div .typing-search-wrapper li.product ul.entry-meta a{
	font-weight: 500;
    font-size: 12px;
    line-height: 1rem;
    color: #6b7180 !important;
    text-align: left;
}

div .typing-search-wrapper li.product .ct-compare-button, 
div .typing-search-wrapper li.product .ct-compare-button-archive, 
div .typing-search-wrapper li.product .ct-open-quick-view {
	display: none !important;
}

div .typing-search-wrapper li.product a.button.product_type_simple.add_to_cart_button.ajax_add_to_cart {
	font-size: 0 !important;
	padding: 0 !important;
	background-image: url('/wp-content/uploads/2025/09/wishlisticon.svg') !important;
	background-repeat: no-repeat;
	background-position: center;
	height: 38px;
	width: 48px;
}

div .typing-search-wrapper li.product div.ct-woo-card-extra {
	top: -10px !important;
	inset-inline-end: 0px !important;
}
div .typing-search-wrapper li.product div.ct-woo-card-extra svg {
	/*stroke: #000 !important;*/
	color: #000 !important;
	height: 20px !important;
	width: 20px !important;
}

.nasa-search-space .nasa-suggestions {
    display: none !important;
}

.search-row {
	justify-content: end !important;
}

header .jnl-search-products-and-post {
	padding-left: 35px !important;
}

.jnl-search-texonomies a {
	color: black !important;
	line-height: 28px !important;
    font-size: 14px;
}


/*products in page articles*/


.articleproduct .product {
	display: flex; flex-direction: column; align-items: center; justify-content: center; 
	min-width: 306px;
	max-width: 306px;
}

.articleproduct {
	display: flex; justify-content: space-evenly; 
}
.articleproduct .ct-woo-card-extra {
    	top: 30px !important;
    }

.page-id-1126 div.entry-content.is-layout-constrained ul,
.page-id-3 div.entry-content.is-layout-constrained ul,
.page-id-13 #post-13 ul,
.page-id-1086 #post-1086 ul {
	list-style: disc;
	padding-left: 18px;
}	


ul.InformationsLivraisonList {
    overflow-y: auto;
    height: 542.96px;
}

ul.InformationsLivraisonList li {
	display: flex !important;
    justify-content: space-between;
    font-size: clamp(16px, 2vw, 24px); 
    font-weight: 300;
    line-height: 1.2; 
    color: #4b4743;
    margin: clamp(16px, 1.5vw, 20px) 0;
}



.formtextabove {
	width: fit-content;
	position: relative;
	top: -50px;
}

.quisommesnous {
	display: flex;
    flex-direction: column;
    justify-content: end;
    position: relative;
    z-index: -1;
    top: -362px;
}

@media (max-width: 1024px) {
	.blogs-grid {
  		display: flex;
	  	flex-wrap: wrap;
	  	width: 100% !important;
	}

	.blogs-grid .blog-item,
	.blogs-grid .blog-item img {
		min-width: 100%;
	}

	.NotreSelectionMoment .product {
		min-width: 100% !important;
		max-width: 100% !important;
		width: 100% !important;
	}


	.page-id-572 div.fluentform.ff-inherit-theme-style.fluentform_wrapper_1.ff_guten_block {
		max-width: 100% !important;
		width: 100% !important;
	} 
	.contactForm form {
		width: 90% !important;
		min-width: 90% !important;
		max-width: 90% !important;
	}

	.contactForm .fluentform.ff-inherit-theme-style.fluentform_wrapper_1.ff_guten_block {
		width: 100% !important;
		display: flex; 
		justify-content: center;
	}

	   header .sub-menu.hierarchical-categories {
        width: 100vw !important;
        left: -50px !important;
        top: 82px !important;
        box-shadow: 0 4px 20px rgba(0,0,0,0.15) !important;
        /*display: flex;*/
        /*visibility: visible;*/
    }
    
    .category-column {
        max-width: 300px !important;
        min-width: 300px !important;
    }
    
    .category-link {
        padding: 0 15px !important;
        font-size: 15px !important;
        height: 45px !important;
    }

    .wp-block-columns.is-layout-flex.wp-container-core-columns-is-layout-28f84493.wp-block-columns-is-layout-flex {
    	flex-direction: column-reverse;
    	padding: 14px 0;
    }

    div #searchOverlay.search-overlay { 
    	top:75px !important; 
    	box-shadow:0 2px 8px rgba(0, 0, 0, 0.12) !important; 
    }
    .EmptyQueryOverlayContent_gwz-empty-query-overlay-content_clients-searches_Rey1u {
    	height: 105% !important;
    }

    #searchOverlay ul.products.columns-4 {
    	display: flex !important;
    	flex-wrap: nowrap !important;
    	overflow-x: auto !important;
    }
    div.typing-search-wrapper li.product {
    	min-width: 50% !important;
    }
    .search-overlay div.search-column {
    	z-index: -1;
    }

    div.brandpage {
    	grid-template-columns: repeat(auto-fill,minmax(134px,2fr)) !important;
    }

    .contactForm div.wpforms-container {
    	max-width: 100% !important;
    	width: 100% !important;
    	display: flex;
    	flex-direction: column;
    	align-items: center;
    }

    /* qui sommes nous */
    .page-id-20 .wp-container-core-group-is-layout-988b637e {
    	display: flex !important;
    	flex-wrap: wrap !important;
    } 
    .page-id-20 .wp-block-image.size-large.is-resized.has-custom-border img {
    	height: 350px !important;
    }
    .page-id-20 .wp-container-core-group-is-layout-cb46ffcb {
    	display: flex !important;
    	flex-direction: column !important;
    }
    .page-id-20 .quisommesnous {
    	top: 0 !important;
    }
    .page-id-20 .wp-container-core-group-is-layout-b6c1f246 .wp-container-core-group-is-layout-cb46ffcb {
    	display: flex !important;
    	flex-direction: column !important;
    	width: 100% !important;
    	max-width: 100% !important;
    	min-width: 100% !important;
    }
    .page-id-20 .wp-container-core-group-is-layout-b6c1f246 .wp-container-core-group-is-layout-d22ff40a {
    	width: 100% !important;
    	min-width: 100% !important;
    	max-width: 100% !important;
    }

    /* distribuer votre-marque au maroc */
    .page-id-12135 .wp-container-core-group-is-layout-7a9066b1 {
    	flex-wrap: wrap !important;
    }
}


@media (max-width: 768px) {
	.products .product .button.product_type_simple.add_to_cart_button.ajax_add_to_cart {
		min-height: 33px !important;
		max-height: 33px !important;
		height: 33px !important;
		width: 33px !important;
	}

	/* ******************************* */

.products .product a.button.product_type_variable.add_to_cart_button {
	font-size: 0px !important;
	height: 33px !important;
	min-height: 33px !important;
	width: 33px !important;
	padding: 0px !important;
	margin: 0px !important;
	position: relative !important;
	bottom: 60px !important;
}
.products .product a.button.product_type_variable.add_to_cart_button::after {
	content: " ";
	background-image: url('/wp-content/uploads/2025/10/more.png');
	background-repeat: no-repeat;
	background-position: center;
	height: 17px;
	width: 100%;
	background-size: contain;
}

.products .product a.button.product_type_simple,
.products .product a.added_to_cart.wc-forward  {
	font-size: 0px !important;
	height: 33px !important;
	min-height: 33px !important;
	width: 33px !important;
	padding: 0px !important;
	margin: 0px !important;
	margin: 0px !important;
}
.products .product a.button.product_type_simple::after,
.products .product a.added_to_cart.wc-forward::after {
	content: " ";
	background-image: url('/wp-content/uploads/2025/09/wishlisticon.svg');
	background-repeat: no-repeat;
	background-position: center;
	height: 20px;
	width: 100%;
	background-size: contain;
}
	/* ******************************* */

	.page-id-572 div.wp-container-core-group-is-layout-d22ff40a {
		background-size: cover !important;
		background-position: 15% 50% !important;
	}
	body.home .wp-container-core-group-is-layout-3b9d79fa {
		padding-left: 0 !important;
	}
    /* Remove any existing mobile menu styles that force display or positioning */
    header .sub-menu.hierarchical-categories {
        /* Let JavaScript handle all positioning and display */
    }
    
    /* Mobile category links styling */
    .hierarchical-categories .category-link {
        padding: 15px 20px !important;
        height: auto !important;
        min-height: 50px !important;
        font-size: 16px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        border-bottom: 1px solid #f0f0f0 !important;
        color: #333 !important;
    }
    
    .hierarchical-categories .category-link:hover {
        background-color: #EAF8F4 !important;
        color: #778867 !important;
    }
    
    .hierarchical-categories .category-arrow {
        font-size: 14px !important;
        color: #666 !important;
        font-weight: bold !important;
    }
    
    .hierarchical-categories ul {
        padding: 0 !important;
        margin: 0 !important;
        list-style: none !important;
    }
    
    .hierarchical-categories .category-item {
        list-style: none !important;
    }
    .articleproduct {
    	justify-content: unset !important;
    }
    .articleproduct .product {
    	max-width: 49% !important;
    	min-width: 49% !important;
    }


    .articleproduct,
    ul.products{
    	grid-template-columns: repeat(2, 1fr) !important; 
    	grid-column-gap: var(--grid-columns-gap, 10px) !important;
    	grid-row-gap: var(--grid-rows-gap, 10px) !important;
    	--grid-columns-gap: 10px !important;
    }
    
    /*Information de liver second section*/
    .wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column {
    	flex-basis: fit-content !important;
    }
    .wp-block-columns.is-layout-flex.wp-container-core-columns-is-layout-28f84493.wp-block-columns-is-layout-flex {
    	flex-direction: unset; !important;
    }
    div.wp-block-columns.is-layout-flex p {
    	font-size: clamp(18px, 4vw, 20px) !important;	
    }

    
    div.nasa-show-search-form.nasa-search-relative.nasa-rightToLeft,
    header form.nasa-search.nasa-ajax-search-form {
    	width: 100% !important;
    	max-width: 100% !important;
    }

    header div.ct-header-text {
    	margin: 0 !important;
    	width: 100% !important;
    }

    form input#nasa-input-1.search-field.search-input.live-search-input.nasa-header-input-search {
    	width: 90% !important;
    	max-width: 100% !important;
    }



    .flexcol {
    	display: flex !important;
    	flex-direction: column !important;
    	align-items: start !important;
    	width: 90% !important;
    }
    .abovefooter {
    	min-height: 560px !important;
    	height: 100% !important;
    	padding: 20px;
    	width: 100% !important;
    	min-width: 100% !important;
    }

    .heightContent {
    	min-height: 100% !important;
    	max-height: 450px !important;
    	height: 450px !important;
    }
    .home .btnsproduitsplusvendus {
    	width: 100% !important;
    	min-height: 0 !important;
    	max-height: 55px !important;
    }
    .home .homelogos {
    	display: flex !important;
    	flex-direction: row !important;
    	flex-wrap: wrap !important;
    }
    .home .homelogos figure {
    	width: 45%;
    }
    .home .wp-container-core-group-is-layout-23441af8 {
    	background-position: center !important;
    	aspect-ratio: 16 / 9; 
		background-size: cover;
    }
    .home .wp-elements-d88f27df675dc31f995b71d611483793 {
    	font-size: 24px !important;
    }
    .home .wp-container-core-columns-is-layout-5b601ef2 img {
    	object-fit: contain !important;
    }
    .home .wp-container-core-group-is-layout-3be9d861 {
    	max-height: 590px !important;
    	position: relative !important;
    }
    .home .wp-container-core-group-is-layout-3be9d861 img {
    	object-fit: cover !important;
    	height: 190px !important;
    }
    .home .wp-elements-ce29a14453eb023f31cbdc64829b80b7 {
    	font-size: 10px !important;
    }

    /* page contact */
    .page-id-572 .wp-container-core-group-is-layout-9aae6ca3 {
    	padding: 0 !important;
    	min-height: 350px !important;
    	max-height: 350px !important;
    	height: 350px !important;
    }
    .page-id-572 .contactForm {
    	padding: 0 20px !important;
    }
    .page-id-572 p.formtextabove {
    	font-size: 11px !important;
    	padding-left:20px !important;
    	padding-right:20px !important;
    }
    .contactForm form {
    	width: 100% !important;
    	min-width: 100% !important;
    	max-width: 100% !important;
    }
    .formtextabove {
    	top: -20px !important;
    }
    .page-id-572 .wp-container-core-group-is-layout-9aae6ca3 figure {
    	display: none;
    }
}

@media (min-width: 769px) {
    .mobile-header {
        display: none !important;
    }
    
    .mobile-back-btn,
    .close-mobile-menu {
        display: none !important;
    }
}

.hierarchical-categories .category-item .category-icon {
	min-width: 38px !important;
	width: 38px !important;
	height: 38px !important;
}

.hierarchical-categories .category-item.main-category {
	margin-bottom: 5px;
}

.hierarchical-categories .category-item .category-link.main-link {
	justify-content: flex-start;
}

.hierarchical-categories .category-item .category-link.main-link .category-arrow {
	margin-left: auto;
}

.home .ct-container-full {
	padding-top: 0;
}

.intro2 {
	margin-bottom: 20px !important;
}

.fpt3 img {
    border-radius: 15px;
}

/* Rayons Bio Tendance */
.rayons-tendance {
background: #544948;
    border-radius: 0px;
    padding: 25px 0px;
    text-align: center;
    max-width: 100%;
    width: 100%;
}

.rayons-tendance .rayons-title,
.rayons-tendance h3 {
    font-family: 'Lato', sans-serif;
    font-size: 36px;
    font-weight: 700;
    color: #ffffff !important;
    margin: 0 0 25px 0;
}

/* Gutenberg Buttons */
.rayons-tendance .wp-block-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px;
}

.rayons-tendance .wp-block-button {
    margin: 0;
}

.rayons-tendance .wp-block-button__link {
	padding: 15px 24px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 25px !important;
    color: #ffffff !important;
    font-family: 'Lato', sans-serif;
    font-size: 20px !important;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
}

.rayons-tendance .wp-block-button__link:hover {
    background: #889c77 !important;
    border-color: #889c77 !important;
    color: #ffffff !important;
    transform: translateY(-2px);
}

.rayons-tendance .wp-block-buttons>.wp-block-button.wp-block-button__width-25 {
    width: fit-content;
}

.out-of-stock-badge{
    color: #F27114!important;
    border: solid 1px #F27114!important;
    border-radius: 3px!important;
    background-color: hsla(25, 90%, 51%, 0.10)!important;
}
.out-of-stock-badge::before{
    content: " ";
    display: inline-block;
    background-image: url('/wp-content/uploads/2026/04/icon-repture.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    height: 12px;
    width: 12px;
    margin-right: 5px;
}



/* Rayons Tendance Responsive */
@media (max-width: 768px) {
    .rayons-tendance {
        padding: 20px 15px;
    }

    .rayons-tendance .rayons-title,
    .rayons-tendance h3 {
        font-size: 18px;
        margin-bottom: 15px;
    }

    .rayons-tendance .wp-block-buttons {
        gap: 8px;
    }

    .rayons-tendance .wp-block-button__link {
        padding: 8px 14px !important;
        font-size: 14px !important;
    }
}

/* ===============================
======== Brand Carousel ==========
================================== */
.brand-carousel-wrapper {
  position: relative;
  overflow: hidden;
  padding: 0 50px 55px;
}

.brand-carousel-track {
  display: grid;
  grid-auto-flow: column;
  grid-template-rows: repeat(3, 110px);
  grid-auto-columns: calc((100% - 70px) / 6);
  gap: 18px 14px;
  overflow: hidden;
  scroll-behavior: auto;
}

.brand-carousel-item {
  height: 110px;
  background: #fff;
  border: 1px solid #e5e5e5;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  box-sizing: border-box;
}

.brand-carousel-item a {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.brand-carousel-item img {
  max-width: 95%;
  width: auto;
  max-height: 100px;
  object-fit: contain;
}

.brand-carousel-prev,
.brand-carousel-next {
  position: absolute;
  bottom: 10px;
  width: 26px;
  height: 26px;
  border: none;
  border-radius: 50%;
  background: #f3f0ec;
  color: #8a9b70;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  z-index: 5;
}

.brand-carousel-prev {
  left: 50%;
  transform: translateX(-35px);
}

.brand-carousel-next {
  left: 50%;
  transform: translateX(10px);
}

.brand-carousel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: 24px;
    padding: 0 52px;
}
.brand-carousel-header .brand-carousel-title{
    font-size: 30px;
    font-weight: 600;
}
.brand-carousel-header a.cta-brands{
    height: auto;
    width: auto;
    border-radius: 50px;
    background: #778867;
    font-weight: 700;
    font-size: 18px;
    line-height: unset;
    letter-spacing: 1px;
    color: #fff;
    margin-top: auto;
    padding: 16px 25px;
}
/* Tablet */
@media (max-width: 1024px) {
  .brand-carousel-wrapper {
    padding: 0 35px 55px;
  }

  .brand-carousel-track {
    grid-template-rows: repeat(3, 110px);
    grid-auto-columns: calc((100% - 42px) / 4);
    gap: 18px 14px;
  }
}

/* Mobile */
@media (max-width: 600px) {
  .brand-carousel-wrapper {
    padding: 0 20px 55px;
  }

  .brand-carousel-track {
    grid-template-rows: repeat(2, 110px);
    grid-auto-columns: calc((100% - 14px) / 2);
    gap: 16px 14px;
  }

  .brand-carousel-prev {
    left: 46%;
  }

  .brand-carousel-next {
    left: 54%;
  }
  .brand-carousel-header{
    padding: 0;
  }
  .brand-carousel-header .brand-carousel-title{
    font-size: 21px;
  }
}
@media (max-width: 600px) {
    .brand-carousel-header a.cta-brands {
        padding: 12px 10px;
        font-size: 12px;
    }
}
/* =====================================
 === Text Container - Produits Bio === 
=======================================*/
.text-container {
    position: relative;
    background: #52B3E8;
    border-radius: 15px;
    padding: 50px 40px;
    margin: 30px 0;
    overflow: hidden;
}

.text-container::before {
    content: '';
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 350px;
    height: 220px;
    background-image: url('/wp-content/uploads/2024/03/herboristerie-e-commerce-watermark.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    opacity: 0.4;
    pointer-events: none;
}

.text-container .text-title,
.text-container h3 {
    font-family: 'Lato', sans-serif;
    font-size: 36px;
    font-weight: 700;
    color: #FFF;
    margin: 0 0 20px 0;
    position: relative;
    z-index: 1;
}

.text-container p {
    font-family: 'Lato', sans-serif;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.7;
    color: #FFF;
    margin: 0;
    max-width: 70%;
    position: relative;
    z-index: 1;
    margin-left: 0 !important;
}

/* Text Container Responsive */
@media (max-width: 1024px) {
    .text-container::before {
        width: 250px;
        height: 160px;
        opacity: 0.25;
    }

    .text-container p {
        max-width: 80%;
    }
}

@media (max-width: 768px) {
    .text-container {
        padding: 30px 20px;
    }

    .text-container::before {
        display: none;
    }

    .text-container .text-title,
    .text-container h3 {
        font-size: 26px;
    }

    .text-container p {
        max-width: 100%;
        font-size: 15px;
    }
}

/* Global Product Card Style */
ul.products .product {
    border: 1px solid #778867 !important;
    border-radius: 8px;
    padding: 0 0 12px 0 !important;
    margin: 0 !important;
    justify-content: space-between;
    transition: all 0.3s ease;
}

ul.products .product:hover {
    box-shadow: 0 4px 15px rgba(151, 181, 111, 0.2);
    transform: translateY(-3px);
}

ul.products .product .wp-post-image {
    border-radius: 8px 8px 0 0 !important;
    background: #fff;
}

ul.products .product span.onsale {
    display: none;
}

/* Product Title */
ul.products .product .woocommerce-loop-product__title {
    font-weight: 700 !important;
    font-size: 17px !important;
    color: #4B4743 !important;
    line-height: 1.4 !important;
    text-align: left !important;
    padding: 0 15px !important;
}

/* Product Price */
ul.products .product .price {
    font-weight: 700 !important;
    font-size: 22px !important;
    text-align: left;
    padding: 0 15px !important;
}

ul.products .product .price del {
    font-size: 16px !important;
    color: #4B4743 !important;
    text-decoration: none !important;
    opacity: 1 !important;
    position: relative;
    order: unset !important;
}

ul.products .product .price del::after {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 100%;
    height: 1.5px;
    background: #D53541;
    transform: rotate(-8deg);
}

ul.products .product .price ins {
    font-size: 22px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    /*color: #D53541 !important;*/
    width: 100%;
}

ul.products .product .price bdi {
    text-decoration: none !important;
}

/* Discount Badge */
ul.products .product span.discount {
    position: absolute;
    top: 12px;
    left: 98px;
    right: auto;
    background: #D53541 !important;
    border-radius: 8px !important;
    font-size: 22px !important;
    font-weight: 900 !important;
    color: #fff !important;
    padding: 8px 13px;
    height: unset !important;
}
ul.products li:not(.outofstock) span.discount{
   left: 10px; 
}
/* Add to Cart Button */
ul.products .product .button.add_to_cart_button {
    background: #778867 !important;
    color: #fff !important;
    border-radius: 25px !important;
    padding: 10px 20px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    margin: 10px 15px !important;
    transition: all 0.3s ease;
}

ul.products .product .button.add_to_cart_button:hover {
    background: #889c77 !important;
}

ul.products .product .ct-wishlist-button-archive span {
    display: none !important;
}

/* Hide elements */
ul.products .product .ct-compare-button-archive,
ul.products .product .ct-open-quick-view {
    display: none !important;
}

/* Global Product Responsive */
@media (max-width: 768px) {
    ul.products .product .woocommerce-loop-product__title {
        font-size: 14px !important;
    }

    ul.products .product .price {
        font-size: 18px !important;
    }

    ul.products .product .price ins {
        font-size: 18px !important;
    }

    ul.products .product .button.add_to_cart_button {
        padding: 8px 15px !important;
        font-size: 12px !important;
    }
}

/* Incontournables Section */
.incourtournables-section {
	background: linear-gradient(135deg, #778867 0%, #5a6b4d 100%);
    border-radius: 0px;
    padding: 35px 0px;
    text-align: center;
    position: relative;
    overflow: hidden;
    width: 100%;
    max-width: 100%;
}

.incourtournables-section::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 50%;
    pointer-events: none;
}

.incourtournables-section::after {
    content: '';
    position: absolute;
    bottom: -30%;
    left: -5%;
    width: 200px;
    height: 200px;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 50%;
    pointer-events: none;
}

.incourtournables-section .incontournables-title,
.incourtournables-section h2 {
    font-family: 'Lato', sans-serif;
    font-size: 36px;
    font-weight: 700;
    color: #ffffff !important;
    margin: 0 0 25px 0;
    position: relative;
    z-index: 1;
}

/* Gutenberg Buttons */
.incourtournables-section .wp-block-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    position: relative;
    z-index: 1;
    max-width: 1140px;
    margin: 0 auto;
}

.incourtournables-section .wp-block-button {
    margin: 0;
}

.incourtournables-section .wp-block-button__link {
    padding: 14px 25px !important;
    background: transparent !important;
    border: 2px solid rgba(255, 255, 255, 0.6) !important;
    border-radius: 30px !important;
    color: #ffffff !important;
    font-family: 'Lato', sans-serif;
    font-size: 21px !important;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
    backdrop-filter: blur(5px);
}

.incourtournables-section .wp-block-button__link:hover {
    background: #ffffff !important;
    border-color: #ffffff !important;
    color: #778867 !important;
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

.incourtournables-section .wp-block-buttons>.wp-block-button.wp-block-button__width-25 {
    width: fit-content;
}

/* Incontournables Section Responsive */
@media (max-width: 768px) {
    .incourtournables-section {
        padding: 25px 15px;
    }

    .incourtournables-section .incontournables-title,
    .incourtournables-section h2 {
        font-size: 22px;
        margin-bottom: 20px;
    }

    .incourtournables-section .wp-block-buttons {
        gap: 8px;
    }

    .incourtournables-section .wp-block-button__link {
        padding: 10px 16px !important;
        font-size: 14px !important;
    }
}

.top-p p {
    margin-bottom: 0 !important;
}

.logo-footer img {
    mix-blend-mode: darken;
    width: 195px;
}

.ct-footer-copyright p {
    font-size: 12px !important;
}

[redirect-href] {
    cursor: pointer;
}

#header [data-row="top"] .menu a {
    color: #FFF;
    font-size: 14px;
    padding-left: 5px;
}

#header [data-row="top"] .menu a path {
    fill: #FFF;
}

#header [data-row="top"] .sub-menu a {
    color: #000 !important;
}

li#menu-item-117521 .sub-menu {
    top: 100% !important;
}

header #menu-menufr li.menu-item-146669 a {
    color: #D53541 !important;
}

header #menu-menufr li.menu-item-146670 a {
    color: #B45309 !important;
}

header #menu-menufr li.menu-item-146671 a {
    color: #2346B0 !important;
}

[data-products] .product .ct-woo-card-rating {
    width: 100%;
    margin-left: 25px;
}

body .banner {
    max-width: 100%;
    margin-top: -40px !important;
}

.page-id-587 .ct-container-full {
    padding-top: 0;
}

.ct-footer {
    margin-top: 50px;
}

/* Footer Category Summary */
.footer-category-summary {
    margin-top: 50px !important;
    padding-bottom: 10px;
}

.fcs-container {
    max-width: 1290px;
    margin: 0 auto;
    padding: 0;
}

.fcs-description {
    margin-bottom: 40px;
}

.fcs-main-title {
    font-size: 28px;
    font-weight: 700;
    color: #1f2937;
    margin-bottom: 20px;
}

.fcs-description p {
    font-size: 15px;
    line-height: 1.7;
    color: #4b5563;
    margin-bottom: 15px;
	text-align: justify;
}

.fcs-title {
    font-size: 20px;
    font-weight: 600;
    color: #1f2937;
    margin-bottom: 10px;
}

.fcs-subtitle {
    font-size: 14px;
    color: #6b7280;
    margin-bottom: 15px;
}

/* Catégories associées */
.fcs-related-categories {
    margin-bottom: 40px;
    padding: 25px;
    background: #fff;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
}

.fcs-category-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.fcs-category-list li a {
    display: inline-block;
    padding: 8px 16px;
    background: #f3f4f6;
    color: #374151;
    text-decoration: none;
    border-radius: 20px;
    font-size: 14px;
    transition: all 0.2s ease;
    font-weight: 700;
}

.fcs-category-list li a:hover {
    background: #778867;
    color: #fff;
}

/* Articles associés - Slick Slider */
.fcs-related-posts {
    margin-top: 30px;
    position: relative;
}

.fcs-posts-slider {
    margin: 20px -10px 0;
}

.fcs-posts-slider .fcs-post-item {
    margin: 0 10px;
}

.fcs-post-item {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #e5e7eb;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.fcs-post-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
}

.fcs-post-item a {
    text-decoration: none;
    display: block;
}

.fcs-post-item img {
    width: 100%;
    height: 160px;
    object-fit: cover;
}

.fcs-post-item h4 {
    padding: 15px;
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: #1f2937;
    line-height: 1.4;
}

/* Slick Slider Arrows */
.fcs-posts-slider .slick-prev,
.fcs-posts-slider .slick-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 50%;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    color: #374151;
}

.fcs-posts-slider .slick-prev:hover,
.fcs-posts-slider .slick-next:hover {
    background: #778867;
    border-color: #778867;
    color: #fff;
}

.fcs-posts-slider .slick-prev {
    left: -15px;
}

.fcs-posts-slider .slick-next {
    right: -15px;
}

.fcs-posts-slider .slick-prev:before,
.fcs-posts-slider .slick-next:before {
    display: none;
}

.fcs-posts-slider .slick-disabled {
    opacity: 0.3;
    cursor: default;
}

.fcs-posts-slider .slick-disabled:hover {
    background: #fff;
    border-color: #e5e7eb;
    color: #374151;
}

/* Responsive */
@media (max-width: 768px) {
    .fcs-main-title {
        font-size: 22px;
    }

    .footer-category-summary {
        padding: 30px 0;
    }

    .fcs-posts-slider .slick-prev {
        left: 5px;
    }

    .fcs-posts-slider .slick-next {
        right: 5px;
    }
}

@media (max-width: 480px) {
    .fcs-category-list {
        flex-direction: column;
    }

    .fcs-category-list li a {
        display: block;
        text-align: center;
    }
}

/* Bloc livraison fiche produit */
.dil-info-sticky {
    margin-top: 25px;
    margin-bottom: 25px !important;
}

.dil-info {
    background: #f9fafb;
    border-radius: 12px;
    padding: 20px;
    border: 1px solid #e5e7eb;
}

.dil-header {
    font-size: 14px;
    font-weight: 600;
    color: #1f2937;
    margin-bottom: 10px;
}

.dil-header:last-child {
    margin-bottom: 0;
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid #e5e7eb;
}

.middle-bx {
    display: flex;
    align-items: flex-start;
    gap: 15px;
}

.dil-icon {
    flex-shrink: 0;
}

.dil-icon svg {
    width: 40px;
    height: auto;
}

.dil-text {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.dil-text span {
    font-size: 13px;
    color: #4b5563;
    line-height: 1.4;
}

/* Footer Category Summary - Fiche produit */
.fcs-single-product {
    margin-top: 30px;
}

.fcs-columns {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.fcs-column {
    flex: 1;
    min-width: 280px;
    padding: 25px;
    background: #fff;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
}

@media (max-width: 768px) {
    .fcs-columns {
        flex-direction: column;
    }

    .fcs-column {
        min-width: 100%;
    }
}

#tab-description ul {
    list-style: disc;
    padding-left: 15px;
}

.single-product h2, 
.taxonomy-product_cat h2, 
.archive.woocommerce h2 {
    font-size: 1.2em !important;
    margin-top: 10px !important;
    margin-bottom: 10px !important;
}

.our_historical_values,
.company-mission {
    max-width: 100%;
    width: 100%;
}

.content li {
    margin-left: 0 !important;
}

/* Herbier Archive - Banner & Title */
.archive_banner {
    position: relative;
    margin: 1rem auto;
    max-width: 1290px;
}

.archive_banner img {
    width: 100%;
    max-height: 350px;
    object-fit: cover;
    border-radius: 15px;
}

.archive_banner_container {
    position: absolute;
    top: 15%;
    color: white;
    width: 100%;
}

.archive_banner_text {
    max-width: 1290px;
    margin: 0 auto;
    padding: 0 20px;
}

.archive_banner_text p {
    font-size: 3.5rem;
    margin-bottom: 0;
    font-weight: 700;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}

.archive_banner_text span {
    font-family: cursive;
    font-size: 2.5rem;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}

.herbier_title {
    margin-bottom: 2rem;
    text-align: center;
    max-width: 1290px;
    margin-left: auto;
    margin-right: auto;
    padding: 0 20px;
}

.herbier_title h1 {
    font-size: 2.5rem;
    font-weight: 700;
    color: #1f2937;
    margin-bottom: 15px;
}

.herbier_title h2 {
    font-family: cursive;
    font-size: 1.3rem;
    max-width: 1000px;
    margin: auto;
    color: #4b5563;
    line-height: 1.6;
}

.herbier_title h2 a {
    color: #768767;
}

.herbier_title h2 a:hover {
    text-decoration: underline;
}

/* Plants Container */
.plants-container {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 40px;
}

.plant-item {
    box-sizing: border-box;
    margin-bottom: 20px;
    text-align: center;
    width: 25%;
    padding: 10px;
}

.plant-item a {
    display: block;
    text-decoration: none;
    background: #fff;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    overflow: hidden;
    transition: all 0.3s ease;
}

.plant-item a:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
    border-color: #768767;
}

.plant-item img {
    width: 100%;
    height: 180px;
    object-fit: content;
}

.plant-item .plant-no-image {
    width: 100%;
    height: 180px;
    background: #f3f4f6;
}

.plant-item h3 {
    padding: 15px;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-family: 'Lato', sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    color: #1f2937;
}

.no-plants {
    width: 100%;
    text-align: center;
    padding: 40px;
    color: #6b7280;
}

/* Herbier Responsive */
@media screen and (max-width: 1024px) {
    .plant-item {
        width: 33.33%;
    }
}

@media screen and (max-width: 768px) {
    .plant-item {
        width: 50%;
    }

    .archive_banner img {
        height: 275px;
    }

    .archive_banner_text p {
        font-size: 2.5rem;
    }

    .archive_banner_text span {
        font-size: 1.5rem;
    }

    .herbier_title h1 {
        font-size: 2rem;
    }

    .herbier_title h2 {
        font-size: 1rem;
    }
}

@media screen and (max-width: 480px) {
    .plant-item {
        width: 50%;
        padding: 5px;
    }

    .plant-item img {
        height: 140px;
    }

    .plant-item h3 {
        font-size: 0.95rem;
        padding: 10px;
    }
}

.archive_banner {
    max-width: 100%;
    width: 100%;
    margin-top: -40px !important;
}

.archive_banner img {
    border-radius: 0 !important;
}

.banner h1 {
    margin-bottom: 0 !important;
}

@media (max-width: 767px) {

    .hero-slider {
        width: 90%;
    }

    .service-boxes {
        width: 100%;
    }

    ul.products .product .ct-woo-card-actions {
        bottom: 5px !important;
        right: 5px !important;
    }

    ul.products .product .button.product_type_simple.add_to_cart_button.ajax_add_to_cart {
        height: 35px !important;
        min-height: 35px !important;
        width: 35px !important;
    }

    ul.products .product a.button.product_type_simple, ul.products .product a.added_to_cart.wc-forward {
        font-size: 0 !important;
        padding: 0 !important;
        height: 35px !important;
        min-height: 35px !important;
        width: 35px !important;
        min-width: 35px !important;
    }

    .service-boxes-wrapper {
        padding: 0 !important;
        flex-wrap: wrap;
    }

    .service-box {
        max-width: 100%;
    }

    #header [data-row="bottom"] [data-column="middle"] > div {
        flex-direction: column;
    }
 

}

.hierarchical-categories .category-item .category-link.main-link {
    text-transform: none !important;
}

#searchOverlay .typing-search-wrapper li.product a.button.product_type_simple.add_to_cart_button.ajax_add_to_cart {
    background-image: unset !important;
    height: 42px !important;
    min-height: 42px !important;
    width: 42px !important;
}

#searchOverlay ul.products .product .ct-woo-card-actions {
    bottom: 15px;
    right: 8px;
}

#searchOverlay ul.products .product .woocommerce-LoopProduct-link.woocommerce-loop-product__link, 
#searchOverlay ul.products .product .woocommerce-loop-product__title {
    font-size: 15px !important;
    line-height: 20.5px !important;
}

#searchOverlay ul.products .product .price {
    font-size: 16px !important;
}

#searchOverlay ul.products .product .woocommerce-loop-product__title {
    padding: 0 10px !important;
    margin-top: 10px !important;
    margin-bottom: 25px !important;
}

#searchOverlay ul.products .product .price {
    padding: 0 10px !important;
    margin-top: auto;
    margin-bottom: 15px;
}

#searchOverlay ul.products .product .ct-wishlist-button-archive {
    top: 0;
    right: 10px;
}

#searchOverlay .typing-search-wrapper li.product div.ct-woo-card-extra {
    top: -4px !important;
}

#searchOverlay ul.products .product .has-hover-effect img {
    aspect-ratio: 4 / 4 !important;
}

#searchOverlay ul.products .product {
    min-height: auto !important;
    max-width: 20%;
}

#searchOverlay header .jnl-search-products li.product {
    align-items: flex-start;
    justify-content: flex-start !important;
}

@media (max-width: 767px) {

    header .jnl-search-products-and-post {
        padding-left: 0 !important;
    }

    #searchOverlay .typing-search-wrapper li.product div.ct-woo-card-extra {
        align-items: flex-end;
        position: absolute;
        top: 6px !important;
    }

    body div#searchOverlay {
        max-height: calc(100vh - 190px) !important;
    }

    div#searchOverlay ul.products .product:hover {
        transform: unset !important;
    }

    div#searchOverlay .jnl-search-texonomies {
        padding-right: 0 !important;
    }

    div#searchOverlay ul.products .product .ct-woo-card-actions {
        bottom: 15px !important;
        right: 8px !important;
    }

}



#header .ct-header-text p {
	font-size: 16px !important;
}

#header .contact-info {
	font-size: 16px;
}

#header .ct-contact-info .ct-icon-container svg {
	width: 32px;
	height: 32px;
}

#header [data-row="bottom"] .menu-container .menu-item a {
	font-size: 17px !important;
	padding: 0 15px;
}

#header [data-row="bottom"] .menu-container .menu-item:first-child {
	margin-right: 10px;
}


#header [data-row="bottom"] [data-column="end"] .ct-icon-container svg {
	width: 25px;
	height: 25px;
}

#header [data-row="bottom"] [data-column="end"] .ct-label {
	font-size: 17px !important;
}

form input#nasa-input-1.search-field.search-input.live-search-input.nasa-header-input-search {
	font-size: 17px;
}

@media (max-width: 767px) {

	form input#nasa-input-1.search-field.search-input.live-search-input.nasa-header-input-search {
		font-size: 14px;
	}

}

/* ======================= 
= Catégorie Bio - Section d'accueil=
=======================
*/

.bio-categorie-home-section {
  padding: 35px 20px 45px;
  background: #F0F3EF;
  width: 100%;
  max-width: 100%;
  margin-bottom: 0;
}

.bio-categorie-home-container {
  max-width: 1280px;
  margin: 0 auto;
}

.bio-categorie-home-title {
  text-align: center;
  font-size: 30px;
  font-weight: 700;
  color: #5a4b46;
  margin-bottom: 30px;
  line-height: 1.2;
}

.bio-categorie-home-slider-wrapper {
  overflow: hidden;
  position: relative;
  width: 100%;
  touch-action: pan-y;
  -webkit-overflow-scrolling: touch;
}

.bio-categorie-home-track {
  display: flex;
  gap: 18px;
  will-change: transform;
  touch-action: pan-y;
}

.bio-categorie-home-card {
  flex: 0 0 auto;
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  touch-action: pan-y;
}

.bio-categorie-home-card a {
  display: block;
  width: 100%;
    height: auto;
  position: relative;
  text-decoration: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.bio-categorie-home-card img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  transition: transform 0.4s ease;
  touch-action: pan-y;
  pointer-events: none;
  -webkit-user-drag: none;
  user-select: none;
}

.bio-categorie-home-card:hover img {
  transform: scale(1.05);
}

.bio-categorie-home-label {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 22px 14px 18px;
  background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.6) 55%, rgba(0,0,0,0) 100%);
  color: #fff;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  line-height: 1.25;
  letter-spacing: 0.2px;
  pointer-events: none;
  z-index: 2;
}

.bio-categorie-home-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
}

.bio-categorie-home-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #d2d2d2;
  cursor: pointer;
  transition: all 0.3s ease;
}

.bio-categorie-home-dot.active {
  background: #6c8a67;
  transform: scale(1.15);
}



@media (max-width: 1024px) {
  /* .bio-categorie-home-card {
    height: 280px;
  } */
}

@media (max-width: 767px) {
  .bio-categorie-home-section {
    padding: 28px 15px 38px;
  }

  .bio-categorie-home-title {
    font-size: 24px;
    margin-bottom: 22px;
  }

 

  .bio-categorie-home-card:hover img {
    transform: none;
  }

  .bio-categorie-home-label {
    font-size: 16px;
    padding: 16px 10px 14px;
  }
}










/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Description catégorie - Compléments cheveux
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.hp-cat-wrap {
    color: #4a4a4a;
    line-height: 1.65;
    max-width: 1100px;
    margin: 0 auto;
    padding: 20px 0;
    box-sizing: border-box;
    /* ↓ AJOUT : conteneur flex pour gérer l'espace vertical en UN SEUL endroit */
    display: flex;
    flex-direction: column;
    gap: 35px;
}
.hp-cat-wrap h2 {
    color: #15243d;
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 18px 0;
    line-height: 1.3;
}
.hp-cat-wrap h3 {
    color: #15243d;
    font-size: 17px;
    font-weight: 700;
    margin: 0 0 12px 0;
    line-height: 1.35;
}
.hp-cat-wrap p {
    color: #5a5a5a;
    font-size: 13px;
    margin: 0;
}
.hp-cat-wrap a {
    text-decoration: underline;
    font-weight: 600;
}
/* Sections 1 et 2 : texte 60% / image 40% */
.hp-cat-wrap .hp-row {
    display: flex;
    flex-wrap: wrap;
    gap: 35px;
    align-items: center;
    /* ↓ SUPPRIMÉ : margin-bottom:35px (géré par le parent maintenant) */
}
.hp-cat-wrap .hp-row > .hp-col-text {
    flex: 1.25 1 380px !important;
    min-width: 280px;
}
.hp-cat-wrap .hp-row > .hp-col-img {
    flex: 0.85 1 300px !important;
    min-width: 240px;
    max-width: 440px;
}
.hp-cat-wrap .hp-img {
    width: 100%;
    height: auto;
    border-radius: 14px;
    display: block;
}
.hp-cat-wrap .hp-center-title {
    text-align: center;
    margin: 0; /* ↓ SUPPRIMÉ : margin:30px 0 25px 0 (géré par le parent) */
    font-size: 22px;
    color: #15243d;
}
/* Cartes "Notre sélection" — IMAGE ET CARTE STRICTEMENT MÊME TAILLE */
.hp-cat-wrap .hp-card-row {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: stretch;
    /* ↓ SUPPRIMÉ : margin-bottom:22px (géré par le parent maintenant) */
}
.hp-cat-wrap .hp-card-row > .hp-img-box,
.hp-cat-wrap .hp-card-row > .hp-card-wrap {
    flex: 1 1 0 !important;
    min-width: 280px;
    display: flex;
}
.hp-cat-wrap .hp-card-wrap {
    flex-direction: column;
}
.hp-cat-wrap .hp-card {
    background: #F6FAF4;
    padding: 28px 30px;
    border-radius: 14px;
    width: 100%;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.hp-cat-wrap .hp-card h3 { font-size: 16px; }
.hp-cat-wrap .hp-card p { font-size: 13px; color: #5a5a5a; }
.hp-cat-wrap .hp-img-box {
    min-height: 280px;
}
.hp-cat-wrap .hp-img-box img {
    width: 100%;
    height: 100%;
    border-radius: 14px;
    object-fit: cover;
    display: block;
    flex: 1;
}
/* Section verte pâle */
.hp-cat-wrap .hp-gray-section {
    background: #F0F3EF;
    padding: 40px 35px;
    border-radius: 8px;
    margin: 10px 0 10px 0; /* ↓ réduit : 45px top → 10px (le parent gap:35px donne déjà 35px, total 45px) */
}
.hp-cat-wrap .hp-gray-section .hp-row { margin-bottom: 0; }
.hp-cat-wrap .hp-gray-section .hp-row:last-child { margin-bottom: 0; }
/* Section verte : texte 70% + image 30% */
.hp-cat-wrap .hp-row-merged {
    gap: 35px;
    row-gap: 0;
}
.hp-cat-wrap .hp-row-merged .hp-text-stack {
    flex: 0 0 calc(70% - 35px);
    min-width: 280px;
}
.hp-cat-wrap .hp-row-merged .hp-merged-img-box {
    flex: 0 0 30%;
    min-width: 200px;
}
.hp-cat-wrap .hp-row-merged .hp-merged-img-box img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 14px;
    display: block;
}
.hp-cat-wrap .hp-stack-gap { margin-top: 25px; }
/* Mobile */
@media (max-width: 720px) {
    .hp-cat-wrap { padding: 15px 0; gap: 25px; }
    .hp-cat-wrap h2 { font-size: 20px; }
    .hp-cat-wrap .hp-row { gap: 20px; }
    .hp-cat-wrap .hp-gray-section { padding: 25px 20px; margin: 0; }
    .hp-cat-wrap .hp-row-merged .hp-text-stack,
    .hp-cat-wrap .hp-row-merged .hp-merged-img-box { flex: 1 1 100%; }
	.hp-cat-wrap .hp-row > .hp-col-img {min-width: 100%;}
	.hp-cat-wrap .hp-card-row > .hp-img-box, .hp-cat-wrap .hp-card-row > .hp-card-wrap {min-width: 100%;}
}


/* =============================== */
/* ======= Media section ========= */
/* =============================== */
.hp-media-section {
  padding: 80px 20px;
  /* background:
    radial-gradient(circle at top left, rgba(108, 135, 74, 0.12), transparent 35%),
    linear-gradient(180deg, #fbf7ec 0%, #fffaf0 100%); */
  position: relative;
  overflow: hidden;
  width: 100%;
  max-width: 100%;
}

.hp-media-container {
  max-width: 1180px;
  margin: 0 auto;
}

.hp-media-header {
  text-align: center;
  margin-bottom: 45px;
}

.hp-media-subtitle {
  display: inline-block;
  color: #9b7b35;
  font-size: 14px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.hp-media-header h2 {
  font-family: Georgia, serif;
  color: #778867;
  font-size: 48px;
  line-height: 1.15;
  margin: 0 0 15px;
}

.hp-media-header p {
  color: #5d594f;
  font-size: 18px;
  max-width: 620px;
  margin: 0 auto;
}

.hp-media-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}

.hp-media-card {
  position: relative;
  background: rgba(255, 253, 247, 0.95);
  border: 1px solid rgba(47, 74, 36, 0.12);
  border-radius: 22px;
  padding: 34px 26px 28px;
  min-height: 245px;
  box-shadow: 0 12px 35px rgba(47, 74, 36, 0.09);
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.hp-media-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 45px rgba(47, 74, 36, 0.15);
  border-color: rgba(47, 74, 36, 0.28);
}

.hp-media-number {
  position: absolute;
  top: 16px;
  left: 16px;
  width: 34px;
  height: 34px;
  background: #36582a;
  color: #fffaf0;
  border-radius: 50%;
  font-weight: 700;
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hp-media-card .h3 {
  color: #778867;
  font-size: 22px;
  margin: 18px 0 18px;
  font-weight: 700;
}
.hp-media-logo img{
     height: auto;
    max-width: 100%;
    vertical-align: middle;
    max-height: 75px;
    width: auto;
}
.hp-media-card p {
  color: #2f2b24;
  font-size: 17px;
  line-height: 1.65;
  margin: 0 0 24px;
  flex: 1;
}
.hp-media-card span.hp-media-btn{
    color: #778867;
}
.hp-media-card a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #36582a;
  color: #fff !important;
  text-decoration: none;
  padding: 12px 24px;
  border-radius: 8px;
  font-weight: 600;
  transition: all 0.3s ease;
  min-width: 155px;
}

.hp-media-card a::after {
  content: "↗";
  font-size: 15px;
}

.hp-media-card a:hover {
  background: #9b7b35;
  color: #fff !important;
}
.hp-media-more-btn{
    display: flex;
    align-items: center;
    justify-content: center;
}
.hp-media-more-btn a{
    height: auto;
    width: auto;
    border-radius: 50px;
    background: #778867;
    font-weight: 700;
    font-size: 18px;
    line-height: unset;
    letter-spacing: 1px;
    color: #fff;
    margin-top: auto;
    padding: 16px 20px;
    margin-top: 29px;
}
/* Tablet */
@media (max-width: 991px) {
  .hp-media-section {
    padding: 65px 18px;
  }

  .hp-media-header h2 {
    font-size: 38px;
  }

  .hp-media-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
  }
  .btn-cta-home a{
    font-size: 15px;
  }
}

/* Mobile */
@media (max-width: 575px) {
  .hp-media-section {
    padding: 50px 15px;
  }

  .hp-media-header {
    margin-bottom: 30px;
  }

  .hp-media-header h2 {
    font-size: 32px;
  }

  .hp-media-header p {
    font-size: 16px;
  }

  .hp-media-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .hp-media-card {
    padding: 32px 20px 24px;
    min-height: auto;
  }

  .hp-media-card .h3 {
    font-size: 20px;
  }

  .hp-media-card p {
    font-size: 16px;
  }
}
/* ============================ */
/* ============================ */
/* ============================ */
/* ============================ */

.hp-banners-home {
  width: 100%;
  padding: 25px 15px;
  background: #fff;
}

.hp-banners-home-grid {
  max-width: 1157px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.hp-banner {
  display: block;
  width: 100%;
  overflow: hidden;
  border-radius: 14px;
  text-decoration: none;
}

.hp-banner img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.35s ease;
}

.hp-banner:hover img {
  transform: scale(1.03);
}

/* .hp-banner-small {
  height: 154px;
} */

.hp-banner-large {
  grid-column: 1 / -1;
  /* height: 194px; */
}

/* Tablet */
@media (max-width: 991px) {
  .hp-banners-home-grid {
    gap: 14px;
  }

  /* .hp-banner-small {
    height: 135px;
  }

  .hp-banner-large {
    height: 170px;
  } */
}

/* Mobile */
@media (max-width: 767px) {
  .hp-banners-home-grid {
    grid-template-columns: 1fr;
  }

  .hp-banner-small,
  .hp-banner-large {
    height: auto;
  }

  .hp-banner img {
    height: auto;
    object-fit: contain;
  }
}
/* ============================= */
/* ============================= */
/* ============================= */

.hp-products-tabs-section {
    background: #F0F3EF;
    padding: 35px 20px;
    width: 100%;
    max-width: 100%;
}

.hp-products-tabs-title {
    text-align: center;
    color: #4e4744;
    font-size: 32px;
    font-weight: 700;
    margin-bottom: 30px;
}

.hp-products-tabs-nav {
    max-width: 1280px;
    margin: 0 auto 30px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
}

.hp-products-tab-btn {
    border: 1px solid #4e4744;
    background: #fff0;
    color: #4e4744;
    border-radius: 50px;
    padding: 15px 25px;
    font-size: 17px;
    cursor: pointer;
    transition: all .25s ease;
    font-weight: bold;
}

.hp-products-tab-btn.active,
.hp-products-tab-btn:hover {
    background: #4e4744;
    color: #fff;
}

.hp-products-tab-panel {
    display: none;
}

.hp-products-tab-panel.active {
    display: block;
}

.hp-tab-products {
    max-width: 1280px;
    margin: 0 auto;
}

.hp-tab-products ul.products.hp-products-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 28px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.hp-tab-products ul.products.hp-products-grid li.product {
    width: calc((100% - 84px) / 4) !important;
    flex: 0 0 calc((100% - 84px) / 4) !important;
    margin: 0 !important;
    background: #f9fbf7;
    border: 1px solid #9aaa92;
    border-radius: 8px;
    padding: 14px;
    position: relative;
    min-width: auto!important;
}

.hp-tab-products li.product figure {
    position: relative;
    margin: 0 0 15px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hp-tab-products .ct-media-container {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    /* height: 200px; */
}

.hp-tab-products .ct-media-container img {
    /* max-height: 190px; */
    width: 100%;
    object-fit: contain;
    aspect-ratio: 3 / 4;
}

.hp-stock-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 1;
    position: var(--has-container, absolute);
    top: var(--has-container, var(--badge-top, 15px));
    inset-inline-start: var(--has-container, var(--badge-left, 15px));
    height: var(--badge-height, 28px);
    min-width: var(--badge-min-width, 55px);
    border-radius: var(--badge-radius, 0px);
    padding: var(--badge-padding, 5px 10px);
    text-align: center;
    color: var(--badge-text-color, #fff);
    background-color: var(--badge-background-color, var(--theme-palette-color-1));
    color: #F27114 !important;
    border: solid 1px #F27114 !important;
    border-radius: 3px !important;
    background-color: hsla(25, 90%, 51%, 0.10) !important;
}
.hp-stock-badge::before {
    content: " ";
    display: inline-block;
    background-image: url(/wp-content/uploads/2026/04/icon-repture.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    height: 12px;
    width: 12px;
    margin-right: 5px;
}
.hp-tab-products .onsale {
    position: absolute;
    top: 0;
    left: 58px;
    background: #df2838;
    color: #fff;
    font-size: 10px;
    padding: 5px 8px;
    border-radius: 4px;
    z-index: 3;
    min-height: auto;
    min-width: auto;
    line-height: 1;
}

.hp-tab-products .ct-woo-card-extra {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 4;
}

.hp-tab-products .woocommerce-loop-product__title {
    font-size: 14px;
    line-height: 1.45;
    margin-bottom: 10px;
}

.hp-tab-products .woocommerce-loop-product__title a {
    color: #222;
    text-decoration: none;
}

.hp-tab-products .custom-loop-description {
    display: block;
    margin-top: 4px;
    font-size: 12px;
    color: #555;
}

.hp-tab-products .price {
    display: block;
    color: #71835f;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 8px;
}

.hp-tab-products .price del {
    display: block;
    color: #d83939;
    font-size: 12px;
    opacity: 1;
}

.hp-tab-products .price ins {
    text-decoration: none;
}

.hp-tab-products .entry-meta {
    margin: 0 0 10px;
    padding: 0;
    list-style: none;
    font-size: 12px;
}

.hp-tab-products .entry-meta a {
    color: #71835f;
    text-decoration: none;
}

.hp-tab-products .ct-woo-card-actions .button {
    background: #71835f;
    color: #fff;
    border-radius: 50px;
    padding: 9px 14px;
    font-size: 12px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.hp-tab-view-all{
    display: flex;
    align-items: center;
    justify-content: center;
}
.hp-tab-view-all a{
    height: auto;
    width: auto;
    border-radius: 50px;
    background: #778867;
    font-weight: 700;
    font-size: 18px;
    line-height: unset;
    letter-spacing: 1px;
    color: #fff;
    margin-top: auto;
    padding: 16px 25px;
    margin-top: 29px;
}
@media (max-width: 1024px) {
    .hp-tab-products ul.products.hp-products-grid li.product {
        width: calc((100% - 56px) / 3) !important;
        flex: 0 0 calc((100% - 56px) / 3) !important;
    }
}

@media (max-width: 767px) {
    .hp-products-tabs-title {
        font-size: 25px;
    }

    .hp-products-tab-btn {
        font-size: 12px;
        padding: 7px 15px;
    }

    .hp-tab-products ul.products.hp-products-grid {
        gap: 15px !important;
    }

    .hp-tab-products ul.products.hp-products-grid li.product {
        width: calc((100% - 15px) / 2) !important;
        flex: 0 0 calc((100% - 15px) / 2) !important;
        padding: 10px;
    }

    .hp-tab-products li.product figure {
        min-height: 150px;
    }

    /* .hp-tab-products .ct-media-container {
        height: 145px;
    } */

    /* .hp-tab-products .ct-media-container img {
        max-height: 135px;
    } */

    .hp-tab-products .woocommerce-loop-product__title {
        font-size: 12px;
    }

    .hp-tab-products .custom-loop-description {
        font-size: 11px;
    }

    .hp-tab-products .ct-woo-card-actions .button {
        font-size: 10px;
        padding: 8px 10px;
    }
}

/* ===================================
============ HOME REVIEWS ============
======================================

*/


.mo-home-reviews {
  /* background: linear-gradient(180deg, #f8f5ef 0%, #f3eee5 100%);*/
  padding: 70px 20px;
  overflow: hidden;
  
}

.mo-reviews-container {
  max-width: 1200px;
  margin: 0 auto;
}

.mo-reviews-header {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 40px;
}

.mo-reviews-subtitle {
 display: flex;
    align-items: center;
    justify-content: center;
    height: 44px;
    width: 134px;
    font-weight: 700;
    font-size: 16px;
    line-height: 14px;
    letter-spacing: 1px;
    color: white;
	margin: 15px auto;
    border-radius: 50px;
    background: #778867 ;
}

.mo-reviews-header h2 {
  font-size: 36px;
  line-height: 1.2;
  color: #24311f;
  margin-bottom: 14px;
  font-weight: 700;
}

.mo-reviews-google-badge {
  display: inline-block;
  margin: 6px auto 18px;
  transition: transform 0.25s ease;
}

.mo-reviews-google-badge img {
  display: block;
  max-width: 220px;
  height: auto;
}

.mo-reviews-google-badge:hover {
  transform: translateY(-2px);
}

.mo-reviews-header p {
  font-size: 16px;
  line-height: 1.8;
  color: #5f6b5a;
}

.mo-reviews-slider-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  gap: 16px;
}

.mo-reviews-slider {
  overflow: hidden;
  width: 100%;
}

.mo-reviews-track {
  display: flex;
}

.mo-review-card {
  flex: 0 0 calc(33.333% - 16px);
  margin-right: 16px;
  background: #ffffff;
  border-radius: 22px;
  padding: 28px;
  border: 1px solid #778867 ;
  min-height: 260px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-top: 15px;
  margin-bottom: 15px;
}

.mo-review-stars {
  font-size: 20px;
  color: #d6a84f;
  margin-bottom: 18px;
  letter-spacing: 2px;
}

.mo-review-text {
    font-size: 15px;
    line-height: 1.9;
    color: #4d5848;
    margin-bottom: 0;
}

.mo-review-user {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: auto;
}

.mo-review-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #778867;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 700;
  flex-shrink: 0;
}

.mo-review-user h4 {
  font-size: 16px;
  color: #24311f;
  margin: 0 0 4px;
  font-weight: 700;
}

.mo-review-user span {
  font-size: 13px;
  color: #7a8574;
}

.mo-review-nav {
  width: 48px;
  height: 48px;
  border: none;
  border-radius: 50%;
  background: #778867;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  flex-shrink: 0;
  transition: all 0.3s ease;
}

.mo-review-nav:hover {
  background: #49622c;
  transform: scale(1.05);
}

.mo-review-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 28px;
}

.mo-review-dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: #cfc8bb;
  cursor: pointer;
  transition: all 0.3s ease;
}

.mo-review-dot.active {
  background: #778867;
  transform: scale(1.2);
}

/* Tablet */
@media (max-width: 1024px) {
  .mo-review-card {
    flex: 0 0 calc(50% - 12px);
  }

  .mo-reviews-header h2 {
    font-size: 30px;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .mo-home-reviews {
    padding: 50px 15px;
  }

  .mo-reviews-header {
    margin-bottom: 30px;
  }

  .mo-reviews-header h2 {
    font-size: 26px;
  }

  .mo-reviews-header p {
    font-size: 15px;
    line-height: 1.7;
  }

  .mo-review-card {
    flex: 0 0 100%;
    margin-right: 0;
    min-height: auto;
    padding: 22px;
  }

  .mo-review-nav {
   position: absolute;
   bottom: -25px;
   left: 50%;
   width: 35px;
   height: 35px;
   font-size: 16px;
   transform: translateX(-50%);
   z-index: 1;
  }
button.mo-review-nav.mo-review-next{
	transform: translateX(calc(-50% + 20px) );
}
.mo-review-nav.mo-review-prev {
	transform: translateX(calc(-50% - 20px) );
}
  .mo-reviews-slider-wrapper {
    gap: 10px;
	padding-bottom: 35px;
  }
}
.h6.wp-block-heading.widget-title{
    --theme-font-size: 16px;
    --theme-line-height: 1.5;
    --theme-font-weight: 700;
    font-weight: 700;
}
.h4.ct-dynamic-data{
    --theme-font-size: 25px;
    --theme-line-height: 1.5;
    --theme-font-weight: 700;
    color: var(--theme-heading-color, var(--theme-heading-4-color, var(--theme-headings-color)));
}
.hp-home-h1 {
    max-width: 1200px;
    margin: 0px auto 25px;
    padding: 0 20px;
    font-size: clamp(22px, 2.5vw, 32px);
    font-weight: 700;
    color: #1f2737;
    text-align: center;
    line-height: 1.3;
}
.hp-home-h1-sub {
    display: block;
    font-size: clamp(15px, 1.4vw, 18px);
    font-weight: 500;
    color: #4B4743;
    margin-top: 6px;
}

.wp-block-buttons .wp-block-button__link {
    width: 100%;
    font-size: 20px !important;
    font-weight: bold;
    padding: 20px 25px;
}
@media (max-width: 768px) {
    .wp-block-buttons .wp-block-button__link {
        width: 100%;
        font-size: 16px !important;
        font-weight: bold;
        padding: 20px 20px;
    }
}
@media (max-width: 768px) {
    ul.products .product .price {
        font-size: 16px !important;
    }
}

/* Barre sticky "ajouter au panier" pages produit — override couleur fond */
.ct-floating-bar {
    --top-position-override: var(--false);
    --translate-offset: 70px;
    background-color: #778867;
    --theme-box-shadow: 0px 10px 20px rgba(44, 62, 80, 0.15);
}
.ct-floating-bar .single_add_to_cart_button {
    background-color: #fff !important;
    color: #778867 !important;
    font-weight: 600 !important;
}
.ct-floating-bar .single_add_to_cart_button:hover,
.ct-floating-bar .single_add_to_cart_button:focus {
    background-color: #fff !important;
    color: #778867 !important;
    opacity: 0.9;
}
.ct-floating-bar .product-title,
.ct-floating-bar :is(.price,.stock) {
    color: #fff !important;
}
.ct-floating-bar .quantity {
    background: #fff;
    border-radius: 20px !important;
}

/* =======================================================
   SOCIAL FEEDS — Instagram + TikTok (manual, no plugin)
   Wrapper .hp-social-feeds-preview holds display:none
   ======================================================= */

.hp-social-section {
  padding: 50px 20px 40px;
  background: #fff;
}

.hp-social-section--tiktok {
  background: #f8f8f8;
}

.hp-social-container {
  max-width: 1200px;
  margin: 0 auto;
}

.hp-social-header {
  text-align: center;
  margin-bottom: 28px;
}

.hp-social-title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 28px;
  font-weight: 700;
  color: #24311f;
  margin: 0 0 10px;
  line-height: 1.2;
  text-align: center;
  flex-wrap: wrap;
}

.hp-social-logo {
  width: 30px;
  height: 30px;
}

.hp-social-section--instagram .hp-social-logo {
  color: #e1306c;
}

.hp-social-section--tiktok .hp-social-logo {
  color: #000;
}

.hp-social-handle {
  display: inline-block;
  font-size: 15px;
  font-weight: 500;
  color: #5f6b5a;
  text-decoration: none;
  margin-top: 2px;
}

.hp-social-handle:hover {
  text-decoration: underline;
}

.hp-social-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
}

.hp-social-card {
  position: relative;
  display: block;
  aspect-ratio: 9 / 16;
  overflow: hidden;
  border-radius: 12px;
  background: #eee;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  contain: layout paint;
}

.hp-social-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
}

.hp-social-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.hp-social-card:hover img {
  transform: scale(1.05);
}

.hp-social-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  transition: background 0.25s ease;
}

.hp-social-play::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-left: 4px;
  border-style: solid;
  border-width: 9px 0 9px 14px;
  border-color: transparent transparent transparent #fff;
}

.hp-social-card:hover .hp-social-play {
  background: rgba(0,0,0,0.75);
}

.hp-social-cta-wrap {
  text-align: center;
  margin-top: 28px;
}

.hp-social-cta {
  display: inline-block;
  padding: 12px 28px;
  border-radius: 50px;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  color: #fff;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.hp-social-cta--instagram {
  background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
}

.hp-social-cta--tiktok {
  background: #000;
}

.hp-social-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.22);
}

@media (max-width: 991px) {
  .hp-social-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 575px) {
  .hp-social-section {
    padding: 36px 14px 28px;
  }

  .hp-social-title {
    font-size: 22px;
  }

  .hp-social-logo {
    width: 24px;
    height: 24px;
  }

  .hp-social-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  .hp-social-play {
    width: 40px;
    height: 40px;
  }

  .hp-social-play::before {
    border-width: 7px 0 7px 12px;
  }
}

/* Modal player for reels */
.hp-social-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.82);
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.hp-social-modal.is-open {
  display: flex;
}

.hp-social-modal-frame {
  position: relative;
  width: min(420px, 100%);
  max-height: 90vh;
  aspect-ratio: 9 / 16;
  background: #000;
  border-radius: 14px;
  overflow: auto;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}

.hp-social-modal-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.hp-social-modal-close {
  position: absolute;
  top: 18px;
  right: 22px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  border: 0;
  color: #fff;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s ease;
}

.hp-social-modal-close:hover {
  background: rgba(255,255,255,0.22);
}

.hp-social-modal-open {
  position: absolute;
  top: 22px;
  left: 22px;
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  padding: 8px 14px;
  border-radius: 50px;
  background: rgba(255,255,255,0.14);
  transition: background 0.2s ease;
}

.hp-social-modal-open:hover {
  background: rgba(255,255,255,0.24);
  color: #fff;
}

@media (max-width: 575px) {
  .hp-social-modal {
    padding: 12px;
  }
  .hp-social-modal-close {
    top: 10px;
    right: 12px;
    width: 38px;
    height: 38px;
    font-size: 24px;
  }
  .hp-social-modal-open {
    top: 14px;
    left: 12px;
    font-size: 12px;
    padding: 6px 10px;
  }
}
/* ===========================================================
   Partner site cross-link strip (above footer)
   =========================================================== */
.hp-partner-strip {
  background: #f5f3ee;
  border-top: 1px solid #e6e3da;
  border-bottom: 1px solid #e6e3da;
  padding: 16px 20px;
}
.hp-partner-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 8px;
  text-align: center;
  font-size: 15px;
  line-height: 1.5;
  color: #4a4a4a;
}
.hp-partner-label {
  color: #4a4a4a;
}
.hp-partner-link {
  color: #6b8a4a;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 0.2s ease;
}
.hp-partner-link:hover {
  color: #4a6c2f;
}
@media (max-width: 575px) {
  .hp-partner-strip { padding: 14px 16px; }
  .hp-partner-inner { font-size: 13.5px; gap: 6px; }
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SEO block homepage : cap image height to keep balance with text
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body.home .hp-cat-wrap .hp-row {
    align-items: center;
}
body.home .hp-cat-wrap .hp-col-img {
    align-self: center;
    display: flex;
}
body.home .hp-cat-wrap .hp-col-img .hp-img {
    width: 100%;
    height: 460px;
    object-fit: cover;
    object-position: center;
    border-radius: 14px;
}
@media (max-width: 720px) {
    body.home .hp-cat-wrap .hp-col-img .hp-img {
        height: 320px;
    }
}

