/*
Theme Name: EEnov
Theme URI: 
Author: Eenov
Author URI: https://eenov.com/
Description: Thème personnalisé EEnov
Tested up to: 6.9
Requires PHP: 8.1
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: eenov
*/

html, body {
    font-family: var(--wp--preset--font-family--nunito);
}

.main-header {
	position: sticky;
	top: 0;
	width: 100%;
	background: #fff;
	z-index: 100;
}

main.is-layout-constrained {
	width: 100%;
}

.conteneur {
	max-width: 1440px;
	margin: 0 auto;
    box-sizing: border-box;
}

.single-product h1, 
.single-product .product_title {
    font-weight: 700; /* Ou 600 selon ce que tu as chargé */
}


.wp-block-group.sku {
	font-size: 0.875rem;
	margin: 0.75rem 0;
}

.wp-block-group.sku .wp-block-post-terms__prefix {
	font-weight: 800;
}

.ppc-shortcode-wrapper {
	border: 1px solid rgb(233 233 233 / 1);
	background: rgb(245 245 245 / 1);
	padding: 3rem 2rem 2rem;
	border-radius: 2rem;
}

#ppc-open-configurator br{
	display: none;
}


.dimensions {
	display: flex;
	gap: 1rem;
}


.wp-block-group.product {
	display: flex;
	justify-content: center;
}

.wp-block-woocommerce-product-image-gallery {
	width: 100% !important;
	max-width: 100% !important;
}


/* Slider suggestions */
.ppc-related-slider,
.ppc-related-slider .wp-block-shortcode {
	overflow: visible;
	width: 100%;
}

.ppc-related-slider {
	margin-top: 5rem;
	padding: 10rem 1.4rem 5rem;
	background: rgb(0 0 0 / .05);
}

.ppc-related-slider .prix {
	gap: .5rem;
}

.section-collection {
	margin-top: 3rem!important;
	position: relative;
}

.section-collection .navigation {
	position: absolute;
	top: calc( 50% - 5rem );
	width: 100%;
	margin: 0;
}

.wc-block-next-previous-buttons {
	width: 100%;
	justify-content: space-between;
}

main.wp-block-group {
	overflow: visible !important;
}
.ppc-slider {
	width: 100%;
	max-width: 100%;
	display: flex;
	flex-wrap: nowrap;
	gap: 1.6rem;
	overflow-x: auto;
	overflow-y: visible;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 1rem;
	box-sizing: border-box;
}
.ppc-slider::-webkit-scrollbar { height: 4px; }
.ppc-slider::-webkit-scrollbar-thumb { background: #ccc; border-radius: 2px; }
.ppc-slider > .ppc-slide {
	flex: 0 0 220px;
	min-width: 220px;
	scroll-snap-align: start;
	display: flex;
	flex-direction: column;
	position: relative;
}
.ppc-slide__link {
	position: absolute;
	inset: 0;
	z-index: 1;
}
.ppc-slider > .ppc-slide img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	border-radius: 6px;
	display: block;
	flex-shrink: 0;
}
.ppc-slider > .ppc-slide h3 { font-size: 1.4rem; margin: 0.6rem 0 0.2rem; }
.ppc-slider > .ppc-slide .ppc-slide__price { font-weight: 700; margin: 0; }
.ppc-slider > .ppc-slide .price-prefix,
.ppc-slider > .ppc-slide .price-suffix { font-size: 1.2rem; color: #666; margin: 0; }

/* PARTIE HAUTE FICHE PRODUIT */
.fiche-principale {
	gap: 6rem;
}

.wc-block-breadcrumbs {
	padding-block: 1rem;
}

.wc-block-breadcrumbs nav.woocommerce-breadcrumb {
	margin: 0;
}

.is-product-collection-layout-carousel {
	gap: 6rem;
	margin-top: 2rem;
}

.is-product-collection-layout-carousel a {
	color: #000;
	font-size: 2rem;
	font-weight: normal;
}


.is-product-collection-layout-carousel .wp-block-woocommerce-product-image {
	border-radius: 2rem;
	overflow: hidden;
}

/* Galerie clients */
.galerie-clients {
	display: flex;
	gap: 1rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 1rem;
}

.galerie-clients::-webkit-scrollbar { height: 4px; }
.galerie-clients::-webkit-scrollbar-thumb { background: #ccc; border-radius: 2px; }

.galerie-clients__item {
	flex: 0 0 240px;
	scroll-snap-align: start;
	margin: 0;
}

.galerie-clients__btn {
	all: unset;
	cursor: zoom-in;
	display: block;
	width: 100%;
}

.galerie-clients__item img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	border-radius: 8px;
	display: block;
}

/* Lightbox */
.gc-lightbox {
	border: none;
	border-radius: 12px;
	padding: 0;
	background: rgba(0, 0, 0, 0.92);
	max-width: 90vw;
	max-height: 90vh;
	display: flex;
	align-items: center;
	gap: 1rem;
}

.gc-lightbox::backdrop {
	background: rgba(0, 0, 0, 0.7);
}

.gc-lightbox__img-wrap {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

.gc-lightbox__img {
	max-width: 80vw;
	max-height: 80vh;
	object-fit: contain;
	border-radius: 6px;
}

.gc-lightbox__close,
.gc-lightbox__prev,
.gc-lightbox__next {
	background: none;
	border: none;
	color: #fff;
	font-size: 3rem;
	cursor: pointer;
	padding: 1rem 1.5rem;
	line-height: 1;
	opacity: 0.8;
	transition: opacity 0.2s;
}

.gc-lightbox__close:hover,
.gc-lightbox__prev:hover,
.gc-lightbox__next:hover { opacity: 1; }

.gc-lightbox__close {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	font-size: 2.4rem;
}


.conteneur_search {
	flex: 1;
} 



/* --- Nuage de catégories personnalisé --- */
.mon-nuage-custom a {
    display: inline-block;
    border: 1px solid #0000FF; /* Ton bleu actuel */
    border-radius: 4px;
    padding: 6px 14px;
    margin: 4px;
    text-decoration: none;
    font-size: 14px;
    color: #0000FF;
    background-color: transparent;
    transition: all 0.2s ease-in-out;
}

.mon-nuage-custom a:hover {
    background-color: #0000FF;
    color: #ffffff;
    transform: translateY(-2px);
}





/****
FIL D'ARIANE
*/

.wc-block-breadcrumbs nav {
    color: rgb(0 0 0 / 0.5);
}

.wc-block-breadcrumbs nav a{
    text-decoration: none;
	color: #000;
}

.single-product .taxonomy-product_cat a {
    text-decoration: none;
    color: #000;
}


/*BLOC PRIX*/
.wp-block-group.bloc-prix {
    font-size: .875rem;
    line-height: 1.25rem;
}

.bloc-prix {
	display: flex;
	align-items: center;
	gap: 5px;
    font-size: 2rem;
    margin-block: 1.5rem;
}

.bloc-prix > * {
	margin: 0;
}

.bloc-prix .woocommerce-Price-amount {
	font-weight: 800;
}

.wc-block-components-product-price {
    font-size: 1.25rem;
}


/* BLOC DIMENSIONS */
.dimensions br {
	display: none;
}

.dimensions .floating-label {
	display: flex;
	font-size: 0.75rem;
}

.dimensions input {
	background: transparent;
	border: 0 none;
}


.dimensions label {
    display: flex;
    flex-wrap: wrap;
    background: #fff;
    border: 1px solid #ccc;
    padding: .5rem;
    border-radius: .5em;    
}

.dimensions input {
    width: 100%;
    font-size: 1rem;
}


.ppc-surface-preview {
    font-weight: 600;
    margin: 0;
}

.ppc-surface-value {
    font-weight: normal;
}


/*Galerie Produit*/
.galerie-produit .flex-control-nav {
    display: flex;
    
}


.woocommerce-product-gallery .flex-control-nav {
    transform: translateY(-50%);
    justify-content: center;
}

.woocommerce div.product div.images .flex-control-thumbs {
    overflow: clip visible;
}

.woocommerce div.product div.images .flex-control-thumbs li {
	border-radius: 1rem;
	overflow: hidden;
	margin-right: 2rem;
	width: inherit;
    box-shadow: 0 0 0 0 rgb(255 255 255 / 1);
}

.woocommerce div.product div.images .flex-control-thumbs li img {
    opacity: 1;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.woocommerce div.product div.images .flex-control-thumbs li:has( img.flex-active),
.woocommerce div.product div.images .flex-control-thumbs li:hover {
    box-shadow: 0 0 0 5px rgb(255 255 255 / 1);
}


.flex-control-thumbs li {
    transition: filter 0.35s ease, box-shadow 0.35s ease;
    transition-delay: 0.2s;
}

@supports selector(:has(*)) {
    .flex-control-thumbs:has(li:hover) li:not(:hover) {
        filter: brightness(0.5);
        transition-delay: 0s; 
    }
}

.flex-control-thumbs li:hover {
    filter: brightness(1);
    box-shadow: 0 0 0 5px white;
    transition-delay: 0s;
}


/*Bloc paiement*/
.bloc-paiement {
	display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
}

.trustmark {
	padding: 0 2rem 0 0;
	display: flex;
	padding: 0 1rem 0;
	align-items: center;
}

.checkout-widget {
	display: flex;
    margin: 0 auto;
    border: 1px solid #999;
    border-radius: 1.25rem;
    width: fit-content;
    overflow: hidden;
}

.checkout-widget .description{
	font-size: 0.875rem;
}


.checkout-widget .description p {
	margin: 0;
}

.checkout-widget .footer {
	background: #ffdc0f;
	display: flex;
	align-items: center;
	padding: 0.55rem;
}

.description {
    margin-block: 1.25rem;
    padding-right: 1rem;
    max-width: 25rem; 
}

/* Icônes de paiement */
.payment-icons {
	display: flex;
	align-items: center;
	gap: 0.8rem;
	flex-wrap: wrap;
}
.payment-icons img {
	border-radius: 4px;
	opacity: 0.85;
	max-width: 2.25rem;
}

/* Barre sticky configurateur */
#ppc-sticky-bar {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 200;
	background: #fff;
	border-top: 1px solid #e0e0e0;
	box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.10);
	transform: translateY(100%);
	transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
	will-change: transform;
}

#ppc-sticky-bar.is-visible {
	transform: translateY(0);
}

.ppc-sticky-bar__inner {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	max-width: 1440px;
	margin: 0 auto;
	padding: 1rem 2rem;
	flex-wrap: wrap;
}

.ppc-sticky-bar__dims {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex: 1;
	flex-wrap: wrap;
}

.ppc-sticky-bar__label {
	display: flex;
	flex-direction: column;
	font-size: 0.75rem;
	color: #666;
	gap: 0.25rem;
}

.ppc-sticky-bar__input {
	width: 90px;
	padding: 0.4rem 0.6rem;
	border: 1px solid #ccc;
	border-radius: 0.4rem;
	font-size: 1rem;
	background: #fff;
}

.ppc-sticky-bar__surface {
	font-size: 0.875rem;
	white-space: nowrap;
}

.ppc-sticky-bar__btn {
	flex-shrink: 0;
	white-space: nowrap;
}

/* Overlay recherche Algolia */
#ee-algolia-logo img {
	width: 150px;
	height: auto;
}

.ee-searchbox-reset,
.ais-SearchBox-reset {
	display: none !important;
}

/* =========================================================
   Mega Menu
   ========================================================= */

/* Masque le sous-menu natif WP pour l'item mm-all (remplacé par notre panel) */
li.mm-all > .wp-block-navigation__submenu-container {
	display: none !important;
}

/* Overlay — couvre toute la page header compris */
.eenov-mm-overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0,0,0,.35);
	z-index: 101; /* au-dessus du header (100) */
}
.eenov-mm-overlay.is-open {
	display: block;
}

/* Panel wrapper — top défini dynamiquement par JS (sous le header) */
.eenov-mm-panels {
	position: fixed;
	top: 0; /* overridé par JS */
	left: 0;
	right: 0;
	z-index: 999;
	pointer-events: none;
}
.eenov-mm-panels.is-open {
	pointer-events: auto;
}

/* Individual panel — largeur contrainte au contenu, centré */
.eenov-mm-panel {
	display: none;
	max-width: var(--wp--style--global--content-size, 1440px);
	margin: 0 auto;
	background: #fff;
	box-shadow: 0 8px 32px rgba(0,0,0,.12);
}
.eenov-mm-panel.is-open {
	display: block;
}

.eenov-mm-panel__inner {
	padding: 2rem 1.5rem;
}

/* ── Hierarchical panel (mm-all) ── */
.eenov-mm-panel--all .eenov-mm-panel__inner {
	display: flex;
	gap: 2.5rem;
}

/* Sidebar */
.eenov-mm-sidebar {
	flex: 0 0 220px;
}
.eenov-mm-sidebar__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: .25rem;
}
.eenov-mm-sidebar__list li.is-active > .eenov-mm-sidebar__btn,
.eenov-mm-sidebar__btn:hover {
	background: #f4f4f4;
}
.eenov-mm-sidebar__btn {
	width: 100%;
	display: flex;
	align-items: center;
	gap: .75rem;
	padding: .6rem .75rem;
	background: none;
	border: none;
	cursor: pointer;
	font-size: .95rem;
	text-align: left;
	border-radius: .4rem;
	transition: background .15s;
}
.eenov-mm-sidebar__img {
	width: 36px;
	height: 36px;
	object-fit: cover;
	border-radius: .25rem;
	flex-shrink: 0;
}

/* Sub-groups */
.eenov-mm-groups {
	flex: 1 1 0;
	min-width: 0;
}
.eenov-mm-group {
	display: none;
}
.eenov-mm-group.is-active {
	display: flex;
	gap: 2rem;
	align-items: flex-start;
}
.eenov-mm-group__cols {
	flex: 1 1 0;
	display: flex;
	gap: 1.5rem;
}
.eenov-mm-group__col {
	flex: 1 1 0;
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: .4rem;
}
.eenov-mm-group__col a {
	font-size: .9rem;
	color: #333;
	text-decoration: none;
}
.eenov-mm-group__col a:hover {
	text-decoration: underline;
}
.eenov-mm-group__cat-link {
	flex: 0 0 140px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .5rem;
	text-decoration: none;
	color: #333;
	font-size: .85rem;
	font-weight: 600;
}
.eenov-mm-group__img {
	width: 140px;
	height: 100px;
	object-fit: cover;
	border-radius: .5rem;
}

/* ── Visual grid panel (mm-cat) ── */
.eenov-mm-visual-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem;
}
.eenov-mm-visual-grid__item {
	flex: 0 0 calc(20% - 1rem);
}
.eenov-mm-visual-grid__link {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .5rem;
	text-decoration: none;
	color: #333;
}
.eenov-mm-visual-grid__img-wrap {
	width: 100%;
	aspect-ratio: 4/3;
	overflow: hidden;
	border-radius: .5rem;
}
.eenov-mm-visual-grid__img-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .3s;
}
.eenov-mm-visual-grid__link:hover .eenov-mm-visual-grid__img-wrap img {
	transform: scale(1.04);
}
.eenov-mm-visual-grid__label {
	font-size: .9rem;
	font-weight: 500;
	text-align: center;
}