/* =========================================================
 * Pureflex — component styles.
 * Design tokens live in theme.json (CSS vars: --wp--preset--*).
 * ========================================================= */

:root {
	--pf-primary:       #D15C2B;
	--pf-primary-hover: #A8461E;
	--pf-soft:          #F0865A;
	--pf-tint:          #FBEDE3;
	--pf-tint-2:        #FDF1EA;
	--pf-ink:           #241611;
	--pf-dark-2:        #3A241A;
	--pf-dark-3:        #5A2410;
	--pf-body:          #3F444C;
	--pf-body-2:        #4A4F57;
	--pf-muted:         #6B7079;
	--pf-faint:         #9AA0A8;
	--pf-faint-2:       #AEB3BA;
	--pf-hairline:      #ECECEF;
	--pf-border-2:      #DADBE0;
	--pf-border-3:      #E4E5E9;
	--pf-surface:       #F5F6F8;
	--pf-success:       #25A85B;
	--pf-container-max: 1280px;
	--pf-container-pad: 22px;
	--pf-shadow-card:       0 6px 14px -8px rgba(20,23,28,.32);
	--pf-shadow-card-hover: 0 20px 38px -24px rgba(20,23,28,.42);
	--pf-shadow-dropdown:   0 40px 70px -34px rgba(20,23,28,.4);
	--pf-shadow-cta:        0 18px 34px -14px rgba(209,92,43,.6);
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
	font-family: 'Barlow', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
	background: #fff;
	color: var(--pf-ink);
	-webkit-font-smoothing: antialiased;
	line-height: 1.55;
}
[dir="rtl"] body { font-family: 'Cairo', 'Barlow', sans-serif; }

h1, h2, h3, h4, h5, h6 {
	font-family: 'Barlow Condensed', 'Barlow', sans-serif;
	font-weight: 800;
	margin: 0;
	color: var(--pf-ink);
	text-transform: uppercase;
	letter-spacing: .3px;
}
h1 { font-size: clamp(34px, 4.6vw, 58px); line-height: 1; letter-spacing: .4px; }
h2 { font-size: clamp(26px, 3.4vw, 38px); line-height: 1.05; }
h3 { font-size: 22px; line-height: 1.1; }
h4 { font-size: 17px; line-height: 1.15; }

::selection { background: var(--pf-primary); color: #fff; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; transition: color .2s; }
a:hover { color: var(--pf-primary); }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul { margin: 0; padding: 0; list-style: none; }

/* ---------- Utilities ---------- */
.pf-container { max-width: var(--pf-container-max); margin: 0 auto; padding: 0 var(--pf-container-pad); }
.pf-hide-sm { }
.pf-only-sm { display: none !important; }
.pf-badge { position: absolute; top: 0; inset-inline-end: 6px; min-width: 17px; height: 17px; padding: 0 4px; background: var(--pf-primary); color: #fff; font-size: 10px; font-weight: 700; border-radius: 16px; display: inline-flex; align-items: center; justify-content: center; }
.pf-badge--empty { display: none; }

/* ---------- Buttons ---------- */
.pf-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 15px;
	letter-spacing: .5px; text-transform: uppercase;
	padding: 14px 22px; border: 1px solid transparent; border-radius: 0;
	transition: background .25s, color .25s, border-color .25s, filter .2s;
	cursor: pointer;
}
.pf-btn--lg { padding: 15px 30px; font-size: 16px; }
.pf-btn--primary { background: var(--pf-primary); color: #fff; box-shadow: var(--pf-shadow-cta); }
.pf-btn--primary:hover { background: var(--pf-primary-hover); color: #fff; }
.pf-btn--dark { background: var(--pf-ink); color: #fff; }
.pf-btn--dark:hover { background: var(--pf-dark-2); color: #fff; }
.pf-btn--outline { background: transparent; color: var(--pf-ink); border-color: var(--pf-border-2); }
.pf-btn--outline:hover { border-color: var(--pf-primary); color: var(--pf-primary); }
.pf-btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.pf-btn--ghost:hover { background: rgba(255,255,255,.08); border-color: #fff; }
.pf-btn--wa { background: var(--pf-success); color: #fff; }
.pf-btn--wa:hover { background: #1e8f4d; color: #fff; }

/* ---------- Utility bar ---------- */
.pf-utility { background: var(--pf-ink); color: #C4C8CE; font-size: 12.5px; font-weight: 500; }
.pf-utility__inner { max-width: var(--pf-container-max); margin: 0 auto; padding: 8px var(--pf-container-pad); display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.pf-utility__msg { display: flex; align-items: center; gap: 9px; min-width: 0; }
.pf-utility__msg svg { color: var(--pf-primary); flex: 0 0 auto; }
.pf-utility__msg > span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pf-utility__right { display: flex; align-items: center; gap: 18px; white-space: nowrap; }
.pf-utility__phone { display: inline-flex; align-items: center; gap: 7px; font-weight: 600; color: #fff; }
.pf-lang, .pf-lang-fallback ul { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 4px; font-family: 'Barlow Condensed'; font-weight: 700; font-size: 13px; }
.pf-lang li, .pf-lang a { color: #C4C8CE; }
.pf-lang li:not(:last-child)::after { content: '/'; opacity: .4; margin-inline-start: 6px; }
.pf-lang .current-lang a, .pf-lang-fallback .active { color: var(--pf-primary); }

/* ---------- Header ---------- */
.pf-header { position: sticky; top: 0; z-index: 60; background: #fff; border-bottom: 1px solid var(--pf-hairline); }
.pf-header__inner { max-width: var(--pf-container-max); margin: 0 auto; padding: 15px var(--pf-container-pad); display: flex; align-items: center; gap: 20px; }
.pf-header__logo { flex: 0 0 auto; display: flex; align-items: center; }
.pf-header__logo img { height: 46px; width: auto; display: block; }
.pf-header__search { margin-inline-start: 24px; flex: 1; max-width: 520px; display: flex; align-items: center; gap: 10px; background: var(--pf-surface); border: 1px solid var(--pf-hairline); border-radius: 0; padding: 11px 16px; color: var(--pf-faint); font-size: 14px; text-align: start; }
.pf-header__search:hover { border-color: var(--pf-border-2); }
.pf-header__search span { flex: 1; }
.pf-header__tools { margin-inline-start: auto; display: flex; align-items: center; gap: 6px; }
.pf-tool { position: relative; display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 6px 12px; color: var(--pf-ink); }
.pf-tool > span:not(.pf-badge) { font-size: 10.5px; font-weight: 600; letter-spacing: .2px; }
.pf-tool:hover { color: var(--pf-primary); }
.pf-icon-btn { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; color: var(--pf-ink); }
.pf-icon-btn:hover { color: var(--pf-primary); }

/* Nav row */
.pf-navrow { border-top: 1px solid var(--pf-hairline); background: #fff; }
.pf-navrow__inner { max-width: var(--pf-container-max); margin: 0 auto; padding: 0 var(--pf-container-pad); display: flex; align-items: stretch; gap: 2px; }
.pf-nav-link { display: inline-flex; align-items: center; gap: 6px; padding: 14px 16px; font-family: 'Barlow Condensed'; font-weight: 700; font-size: 13.5px; letter-spacing: .5px; text-transform: uppercase; color: var(--pf-ink); border-bottom: 2px solid transparent; }
.pf-nav-link:hover { color: var(--pf-primary); }
.pf-nav-link.is-active { border-bottom-color: var(--pf-primary); color: var(--pf-primary); }
.pf-nav-link--promo { margin-inline-start: auto; color: var(--pf-primary); }

/* Mega menu */
.pf-mega { position: relative; }
.pf-mega__panel { position: absolute; top: 100%; inset-inline-start: 0; z-index: 70; width: min(960px, 86vw); background: #fff; border: 1px solid var(--pf-hairline); box-shadow: var(--pf-shadow-dropdown); padding: 26px 28px; display: none; grid-template-columns: repeat(4, 1fr); gap: 26px 30px; animation: pfFade .18s ease; }
.pf-mega.is-open .pf-mega__panel, .pf-mega:hover .pf-mega__panel { display: grid; }
.pf-mega__cat { display: flex; align-items: center; gap: 8px; font-family: 'Barlow Condensed'; font-weight: 700; font-size: 15px; text-transform: uppercase; letter-spacing: .4px; color: var(--pf-ink); margin-bottom: 12px; text-align: start; }
.pf-mega__cat .dot { width: 8px; height: 8px; background: var(--pf-dot, var(--pf-primary)); display: inline-block; }
.pf-mega__cat:hover { color: var(--pf-primary); }
.pf-mega__subs { display: flex; flex-direction: column; gap: 8px; }
.pf-mega__subs a { text-align: start; font-size: 13.5px; color: var(--pf-muted); transition: color .2s; }
.pf-mega__subs a:hover { color: var(--pf-primary); }

/* Search overlay */
.pf-search-overlay { position: fixed; inset: 0; z-index: 200; background: rgba(20,23,28,.62); backdrop-filter: blur(3px); animation: pfFade .18s ease; }
.pf-search-overlay[hidden] { display: none; }
.pf-search-overlay__inner { max-width: 720px; margin: 10vh auto 0; padding: 22px; }
.pf-search-form { display: flex; align-items: center; gap: 12px; background: #fff; padding: 18px 20px; }
.pf-search-form svg { color: var(--pf-primary); flex: 0 0 auto; }
.pf-search-form input { flex: 1; border: 0; outline: 0; font: 600 18px 'Barlow', sans-serif; color: var(--pf-ink); background: transparent; }
.pf-search-close { color: var(--pf-muted); display: inline-flex; }
.pf-search-close:hover { color: var(--pf-ink); }
.pf-search-popular { margin-top: 18px; color: #fff; }
.pf-search-popular__label { font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; opacity: .7; margin-bottom: 10px; }
.pf-search-popular__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.pf-chip { display: inline-flex; align-items: center; padding: 8px 14px; background: rgba(255,255,255,.1); color: #fff; font-size: 13px; font-weight: 600; }
.pf-chip:hover { background: var(--pf-primary); color: #fff; }

/* ---------- Hero ---------- */
.pf-hero-section { position: relative; overflow: hidden; background: #140C09; }
.pf-hero-section::before { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(20,12,9,.94) 0%, rgba(20,12,9,.82) 34%, rgba(20,12,9,.35) 62%, rgba(20,12,9,.55) 100%), radial-gradient(circle at 70% 40%, rgba(209,92,43,.28), transparent 60%), linear-gradient(135deg, #140C09 0%, #241611 45%, #3A241A 78%, #5A2410 100%); }
.pf-hero { position: relative; display: grid; grid-template-columns: 1fr; min-height: 540px; align-items: center; padding: 72px var(--pf-container-pad) 78px; }
.pf-hero__body { max-width: 600px; }
.pf-hero__eyebrow { display: inline-flex; align-items: center; gap: 10px; background: rgba(209,92,43,.18); border: 1px solid rgba(209,92,43,.5); padding: 7px 14px; margin-bottom: 22px; color: var(--pf-soft); font-family: 'Barlow Condensed'; font-weight: 700; font-size: 12.5px; letter-spacing: 1.5px; text-transform: uppercase; }
.pf-hero__eyebrow-icon { color: var(--pf-soft); }
.pf-hero__ar { font-family: 'Cairo', sans-serif; font-weight: 800; font-size: clamp(26px, 3.7vw, 44px); color: #fff; line-height: 1.25; letter-spacing: -.5px; text-shadow: 0 2px 18px rgba(0,0,0,.5); }
.pf-hero__t { font-family: 'Barlow Condensed'; font-weight: 800; font-size: clamp(34px, 4.6vw, 58px); color: #fff; line-height: 1; letter-spacing: .4px; text-transform: uppercase; margin: 14px 0 0; text-shadow: 0 2px 22px rgba(0,0,0,.5); }
.pf-hero__t-accent { color: var(--pf-soft); }
.pf-hero__sub { font-size: 16.5px; line-height: 1.6; color: #D6CFC9; max-width: 440px; margin: 18px 0 0; text-shadow: 0 1px 10px rgba(0,0,0,.55); }
.pf-hero__cta { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 30px; }
.pf-hero__stats { display: flex; flex-wrap: wrap; align-items: center; gap: 22px; margin-top: 38px; }
.pf-hero__stat .n { font-family: 'Barlow Condensed'; font-weight: 800; font-size: 26px; color: #fff; line-height: 1; }
.pf-hero__stat .l { font-size: 11px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: #B7ADA5; margin-top: 3px; }
.pf-hero__div { width: 1px; height: 34px; background: rgba(255,255,255,.22); }

/* ---------- Trust strip ---------- */
.pf-trust-section { border-bottom: 1px solid var(--pf-hairline); }
.pf-trust { display: grid; grid-template-columns: repeat(4, 1fr); }
.pf-trust__cell { display: flex; align-items: center; gap: 12px; padding: 26px 18px; border-inline-end: 1px solid var(--pf-hairline); }
.pf-trust__cell:last-child { border-inline-end: none; }
.pf-trust__icon { width: 26px; height: 26px; color: var(--pf-primary); font-size: 22px; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.pf-trust__t { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 15px; text-transform: uppercase; letter-spacing: .3px; color: var(--pf-ink); }
.pf-trust__s { font-size: 12.5px; color: var(--pf-faint); margin-top: 1px; }

/* ---------- Section header ---------- */
.pf-section-header { display: flex; align-items: center; gap: 14px; margin: 58px 0 26px; }
.pf-section-header--split { justify-content: space-between; margin-bottom: 22px; }
.pf-section-header__left { display: flex; align-items: center; gap: 14px; }
.pf-section-header__bar { width: 5px; height: 26px; background: var(--pf-primary); }
.pf-section-header__link { display: inline-flex; align-items: center; gap: 8px; color: var(--pf-ink); font-family: 'Barlow Condensed'; font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: .4px; border-bottom: 2px solid var(--pf-primary); padding-bottom: 3px; }

/* ---------- Category tiles ---------- */
.pf-cat-grid { padding: 30px 0 8px; }
.pf-cat-tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(178px, 1fr)); gap: 14px; }
.pf-cat-tile { display: flex; flex-direction: column; gap: 14px; padding: 20px; background: #fff; border: 1px solid var(--pf-hairline); text-align: start; transition: box-shadow .28s, border-color .28s, transform .28s; }
.pf-cat-tile:hover { box-shadow: var(--pf-shadow-card-hover); border-color: var(--pf-primary); }
.pf-cat-tile__top { display: flex; align-items: center; justify-content: space-between; }
.pf-cat-tile__icon { width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; color: #fff; background: var(--pf-dot, var(--pf-primary)); }
.pf-cat-tile__arrow { width: 16px; height: 16px; color: #C4C8CE; display: inline-flex; }
.pf-cat-tile__t { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 17px; text-transform: uppercase; letter-spacing: .3px; color: var(--pf-ink); line-height: 1.1; }
.pf-cat-tile__c { font-size: 12px; color: var(--pf-faint); margin-top: 4px; }

/* ---------- Product cards (Woo loop) ---------- */
.pf-featured-section, .pf-offers-grid { padding: 40px 0 8px; }
ul.products { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(216px, 1fr)); gap: 16px; }
ul.products li.product { position: relative; margin: 0; padding: 0; }
.pf-card { background: #fff; border: 1px solid var(--pf-hairline); position: relative; display: flex; flex-direction: column; height: 100%; transition: box-shadow .28s, border-color .28s, transform .28s; }
.pf-card:hover { box-shadow: var(--pf-shadow-card-hover); border-color: var(--pf-primary); z-index: 3; }
.pf-card:hover .pf-card__actions { opacity: 1; }
.pf-card:hover .pf-card__quick { opacity: 1; transform: translate(-50%, 0); }
.pf-card__actions { position: absolute; top: 10px; inset-inline-end: 10px; z-index: 6; display: flex; flex-direction: column; gap: 8px; opacity: 0; transition: opacity .22s; }
.pf-card__wish { width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center; background: #fff; border: 1px solid var(--pf-border-2); color: var(--pf-ink); }
.pf-card__wish:hover, .pf-card__wish.is-active { border-color: var(--pf-primary); color: var(--pf-primary); }
.pf-badge-sale { position: absolute; top: 10px; inset-inline-start: 10px; z-index: 5; background: var(--pf-primary); color: #fff; font-family: 'Barlow Condensed'; font-weight: 700; font-size: 12.5px; padding: 4px 8px; letter-spacing: .3px; }
.pf-badge-oos { position: absolute; top: 10px; inset-inline-start: 10px; z-index: 5; background: #B5121B; color: #fff; font-family: 'Barlow Condensed'; font-weight: 700; font-size: 12px; padding: 4px 8px; letter-spacing: .3px; text-transform: uppercase; }
.pf-card__media { position: relative; display: block; background: var(--pf-surface); aspect-ratio: 1 / 1; overflow: hidden; }
.pf-card__media img { width: 100%; height: 100%; object-fit: contain; padding: 12px; }
.pf-card__quick { position: absolute; bottom: 12px; left: 50%; z-index: 4; display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; background: #fff; color: var(--pf-ink); font-family: 'Barlow Condensed'; font-weight: 700; font-size: 12.5px; text-transform: uppercase; letter-spacing: .3px; box-shadow: var(--pf-shadow-card); opacity: 0; transform: translate(-50%, 10px); transition: opacity .24s, transform .24s; }
.pf-card__body { padding: 14px 15px 16px; display: flex; flex-direction: column; flex: 1; }
.pf-card__cat { display: inline-flex; align-items: center; gap: 6px; font-family: 'Barlow Condensed'; font-weight: 700; font-size: 10.5px; text-transform: uppercase; letter-spacing: .5px; color: var(--pf-muted); }
.pf-card__cat .dot { width: 6px; height: 6px; background: var(--pf-dot, var(--pf-primary)); display: inline-block; }
.pf-card__title { font-family: 'Barlow'; font-weight: 700; font-size: 15px; line-height: 1.28; color: var(--pf-ink); margin: 6px 0 0; min-height: 38px; text-transform: none; letter-spacing: 0; }
.pf-card__title a { color: inherit; }
.pf-card__title a:hover { color: var(--pf-primary); }
.pf-card__hl-label { font-size: 10px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; color: var(--pf-faint-2); margin: 11px 0 6px; }
.pf-card__hl { display: flex; flex-direction: column; gap: 3px; flex: 1; }
.pf-card__hl li { font-size: 12px; line-height: 1.4; color: var(--pf-muted); display: flex; gap: 7px; }
.pf-card__hl .chev { color: var(--pf-primary); font-weight: 800; line-height: 1.2; }
.pf-card__price { display: flex; align-items: baseline; gap: 8px; margin-top: 14px; }
.pf-card__price .amount, .pf-card__price bdi, .pf-card__price ins { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 23px; color: var(--pf-primary); letter-spacing: .3px; text-decoration: none; }
.pf-card__price del { font-size: 13px; color: var(--pf-faint-2); text-decoration: line-through; }
.pf-card__price del .amount, .pf-card__price del bdi { font-family: 'Barlow'; font-size: 13px; color: var(--pf-faint-2); font-weight: 400; }
.pf-card > .pf-btn { margin: 12px 15px 16px; }

/* ---------- Promo band ---------- */
.pf-promo-band { background: linear-gradient(135deg, #241611 0%, #3A241A 55%, #5A2410 100%); color: #fff; position: relative; overflow: hidden; margin-top: 60px; }
.pf-promo-band::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 80% 50%, rgba(240,134,90,.25), transparent 55%); }
.pf-promo-band__inner { position: relative; display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center; padding: 44px var(--pf-container-pad); }
.pf-promo-band__kicker { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 12.5px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--pf-soft); margin-bottom: 10px; }
.pf-promo-band__t { color: #fff; font-size: clamp(28px, 3.4vw, 40px); }
.pf-promo-band__s { color: #D6CFC9; margin: 10px 0 20px; max-width: 480px; }
.pf-promo-band__timer { display: flex; gap: 10px; }
.pf-cd-cell { background: rgba(255,255,255,.1); padding: 14px 16px; text-align: center; min-width: 68px; }
.pf-cd-cell span { display: block; font-family: 'Barlow Condensed'; font-weight: 800; font-size: 34px; color: #fff; line-height: 1; }
.pf-cd-cell small { font-size: 10.5px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.65); }

/* ---------- Reviews ---------- */
.pf-reviews-section { padding: 20px 0; }
.pf-reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.pf-review { background: #fff; border: 1px solid var(--pf-hairline); padding: 24px; }
.pf-review__stars { color: var(--pf-primary); font-size: 18px; letter-spacing: 2px; }
.pf-review__text { color: var(--pf-body-2); font-size: 15px; line-height: 1.6; margin: 12px 0 18px; }
.pf-review__foot { display: flex; align-items: center; gap: 12px; }
.pf-review__avatar { width: 40px; height: 40px; background: var(--pf-tint); color: var(--pf-primary); font-family: 'Barlow Condensed'; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; }
.pf-review__foot .n { font-weight: 700; font-size: 14px; color: var(--pf-ink); }
.pf-review__foot .v { font-size: 12px; color: var(--pf-success); }

/* ---------- Brand marquee ---------- */
.pf-marquee-section { border-top: 1px solid var(--pf-hairline); border-bottom: 1px solid var(--pf-hairline); margin-top: 60px; padding: 24px 0; overflow: hidden; }
.pf-marquee { position: relative; overflow: hidden; mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%); }
.pf-marquee__track { display: inline-flex; gap: 44px; padding-inline: 22px; animation: pfmarq 34s linear infinite; white-space: nowrap; }
.pf-marquee__brand { font-family: 'Barlow Condensed'; font-weight: 800; font-size: 22px; text-transform: uppercase; letter-spacing: 1px; color: var(--pf-faint-2); opacity: .6; }

/* ---------- Footer ---------- */
.pf-footer { background: var(--pf-ink); color: #C4C8CE; margin-top: 70px; }
.pf-footer__inner { max-width: var(--pf-container-max); margin: 0 auto; padding: 56px var(--pf-container-pad) 40px; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 40px; }
/* Logo footer : PNG transparent affiché intact (le logo est déjà contouré
   en blanc côté fichier → visible sur fond sombre, aucun filtre appliqué). */
.pf-footer__plaque { background: transparent; display: inline-block; padding: 0; }
.pf-footer__plaque img { height: 54px; width: auto; }
.pf-footer__tag { font-size: 13.5px; line-height: 1.6; color: #A7ACB3; margin: 18px 0 0; max-width: 320px; }
.pf-footer__socials { display: flex; gap: 10px; margin-top: 18px; }
.pf-footer__socials a { width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.08); color: #fff; }
.pf-footer__socials a:hover { background: var(--pf-primary); color: #fff; }
.pf-footer__h { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 15px; text-transform: uppercase; letter-spacing: 1px; color: #fff; margin-bottom: 18px; }
.pf-footer__list { display: flex; flex-direction: column; gap: 10px; }
.pf-footer__list a { color: #A7ACB3; font-size: 14px; }
.pf-footer__list a:hover { color: var(--pf-primary); }
.pf-footer__s { font-size: 13px; color: #A7ACB3; margin-bottom: 14px; }
.pf-footer__news input { width: 100%; padding: 12px 14px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); color: #fff; font-family: inherit; margin-bottom: 10px; }
.pf-footer__news input::placeholder { color: #7A7F87; }
.pf-footer__news .pf-btn { width: 100%; }
.pf-footer__ok { color: var(--pf-success); font-size: 13px; margin-top: 10px; }
.pf-footer__bar { border-top: 1px solid rgba(255,255,255,.08); }
.pf-footer__bar-inner { max-width: var(--pf-container-max); margin: 0 auto; padding: 18px var(--pf-container-pad); display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: 12.5px; color: #7A7F87; }
.pf-footer__legal { display: flex; gap: 18px; align-items: center; }
.pf-footer__legal a { color: #A7ACB3; }
.pf-footer__legal a:hover { color: var(--pf-primary); }
.pf-footer__proud { color: #A7ACB3; }

/* ---------- Mobile tab bar ---------- */
.pf-tabbar { display: none; position: fixed; bottom: 0; inset-inline: 0; z-index: 90; background: #fff; border-top: 1px solid var(--pf-hairline); height: 66px; grid-template-columns: repeat(5, 1fr); }
.pf-tabbar__item { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; color: var(--pf-ink); background: transparent; border: 0; }
.pf-tabbar__item span:not(.pf-badge) { font-size: 10.5px; font-weight: 700; letter-spacing: .3px; }
.pf-tabbar__item.is-active { color: var(--pf-primary); background: var(--pf-tint); }
.pf-tabbar__item:active { background: var(--pf-tint); }

/* ---------- WhatsApp FAB ---------- */
.pf-fab { position: fixed; bottom: 22px; inset-inline-end: 22px; z-index: 80; display: inline-flex; align-items: center; gap: 10px; padding: 14px 20px; background: var(--pf-success); color: #fff; font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; box-shadow: 0 16px 32px -14px rgba(37,168,91,.55); }
.pf-fab:hover { background: #1e8f4d; color: #fff; }

/* ---------- Shop ---------- */
.pf-shop-wrap { padding: 22px 0 60px; }
.pf-shop-header { margin-bottom: 22px; }
.pf-breadcrumb { font-size: 13px; color: var(--pf-muted); }
.pf-breadcrumb .sep { color: var(--pf-faint-2); margin: 0 6px; }
.pf-shop-grid { display: grid; grid-template-columns: 260px 1fr; gap: 32px; align-items: start; }
.pf-side { position: sticky; top: 150px; background: #fff; border: 1px solid var(--pf-hairline); padding: 20px; }
.pf-side-title { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 12.5px; text-transform: uppercase; letter-spacing: 1px; color: var(--pf-muted); margin-bottom: 14px; }
.pf-side-list { display: flex; flex-direction: column; gap: 4px; }
.pf-side-list a { display: flex; align-items: center; gap: 8px; padding: 8px 10px; font-size: 14px; color: var(--pf-body); }
.pf-side-list .dot { width: 8px; height: 8px; background: var(--pf-dot, var(--pf-primary)); display: inline-block; flex: 0 0 auto; }
.pf-side-list .count { margin-inline-start: auto; font-size: 12px; color: var(--pf-faint); }
.pf-side-list a:hover, .pf-side-list a.is-active { background: var(--pf-tint); color: var(--pf-primary); }
.pf-side-help { margin-top: 20px; padding: 18px; background: var(--pf-ink); color: #fff; }
.pf-side-help__t { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 15px; text-transform: uppercase; }
.pf-side-help__s { font-size: 13px; color: #C4C8CE; margin: 8px 0 14px; }

/* ---------- Legal pages ---------- */
.pf-legal { max-width: 860px; }
.pf-legal h1 { font-size: clamp(30px, 3.6vw, 42px); margin-bottom: 24px; }
.pf-legal h2 { font-size: 22px; margin-top: 32px; margin-bottom: 12px; }
.pf-legal ol, .pf-legal ul { padding-inline-start: 24px; }
.pf-legal li { margin-bottom: 8px; color: var(--pf-body); }
.pf-legal p { color: var(--pf-body); font-size: 15px; line-height: 1.7; margin: 0 0 14px; }
.pf-legal--cndp .pf-legal__shield { text-align: start; margin-bottom: 18px; }
.pf-shield-badge { display: inline-flex; align-items: center; justify-content: center; width: 60px; height: 60px; background: var(--pf-tint); color: var(--pf-primary); }
.pf-shield-badge svg { width: 28px; height: 28px; }

/* ---------- About ---------- */
.pf-about-hero { background: linear-gradient(135deg, #241611 0%, #3A241A 55%, #5A2410 100%); color: #fff; padding: 80px 0; text-align: center; }
.pf-about-hero__kicker { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 12.5px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--pf-soft); }
.pf-about-hero h1 { color: #fff; margin: 12px auto 16px; max-width: 780px; }
.pf-about-hero__lead { max-width: 640px; margin: 0 auto; color: #D6CFC9; font-size: 17px; line-height: 1.65; }
.pf-about-story { padding: 60px 0; }
.pf-about-story__grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px; align-items: start; }
.pf-about-story p { color: var(--pf-body); font-size: 15px; line-height: 1.75; margin: 12px 0; }
.pf-about-story__stats { display: grid; grid-template-columns: 1fr; gap: 14px; padding: 22px; background: var(--pf-surface); border: 1px solid var(--pf-hairline); }
.pf-stat__n { font-family: 'Barlow Condensed'; font-weight: 800; font-size: 40px; color: var(--pf-primary); line-height: 1; }
.pf-stat__l { font-size: 13px; color: var(--pf-muted); margin-top: 4px; }
.pf-about-why { padding: 20px 0 60px; }
.pf-why-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
.pf-why { background: #fff; border: 1px solid var(--pf-hairline); padding: 22px; }
.pf-why__i { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; background: var(--pf-tint); color: var(--pf-primary); font-size: 20px; margin-bottom: 14px; }
.pf-why__t { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 17px; text-transform: uppercase; color: var(--pf-ink); }
.pf-why__d { font-size: 13.5px; color: var(--pf-muted); margin-top: 6px; line-height: 1.5; }

/* ---------- Contact ---------- */
.pf-contact-section { padding: 40px 0 60px; }
.pf-contact-section__lead { max-width: 640px; color: var(--pf-muted); margin: 0 0 30px; }
.pf-contact { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: start; }
.pf-contact__form { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; background: #fff; border: 1px solid var(--pf-hairline); padding: 24px; }
.pf-field { display: flex; flex-direction: column; grid-column: 1 / -1; }
.pf-field--half { grid-column: auto; }
.pf-field label { font-size: 12px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--pf-muted); margin-bottom: 6px; }
.pf-field input, .pf-field textarea, .pf-field select { padding: 12px 14px; background: var(--pf-surface); border: 1px solid var(--pf-hairline); font: 400 14px 'Barlow', sans-serif; color: var(--pf-ink); }
.pf-field input:focus, .pf-field textarea:focus, .pf-field select:focus { outline: 0; border-color: var(--pf-primary); background: #fff; }
.pf-contact__ok { grid-column: 1 / -1; color: var(--pf-success); font-weight: 600; }
.pf-contact__notice { grid-column: 1 / -1; color: var(--pf-faint); margin: 0; }
.pf-contact__info { background: var(--pf-ink); color: #fff; padding: 30px; display: flex; flex-direction: column; gap: 18px; }
.pf-contact__row { display: flex; gap: 12px; align-items: flex-start; }
.pf-contact__ic { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.06); font-size: 18px; flex: 0 0 auto; }
.pf-contact__row .l { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: rgba(255,255,255,.55); }
.pf-contact__row .v { color: #fff; font-weight: 600; margin-top: 3px; }
.pf-contact__info .pf-btn { margin-top: auto; }

/* ---------- Offres header ---------- */
.pf-offres-hero { background: linear-gradient(135deg, #241611 0%, #3A241A 55%, #5A2410 100%); color: #fff; padding: 60px 0 40px; }
.pf-offres-hero__inner { display: grid; grid-template-columns: 1fr auto; gap: 30px; align-items: center; }
.pf-offres-hero__kicker { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 12.5px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--pf-soft); margin-bottom: 8px; }
.pf-offres-hero h1 { color: #fff; }
.pf-offres-hero p { color: #D6CFC9; margin: 8px 0 0; }
.pf-offres-hero__timer { display: flex; gap: 10px; }

/* ---------- 404 ---------- */
.pf-404 { text-align: center; padding: 80px 0; }
.pf-404 h1 { color: var(--pf-primary); }
.pf-404 .wp-block-buttons { justify-content: center; }

/* ---------- Toast ---------- */
.pf-toast { position: fixed; left: 50%; bottom: 32px; transform: translateX(-50%); z-index: 300; background: var(--pf-ink); color: #fff; padding: 14px 22px; font-size: 14px; font-weight: 600; box-shadow: var(--pf-shadow-card-hover); animation: pfIn .28s ease; }
.pf-toast--success { background: var(--pf-success); }
.pf-toast--error { background: #B5121B; }

/* ---------- Animations ---------- */
@keyframes pfmarq { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes pffloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@keyframes pfIn { from { opacity: 0; transform: translate(-50%, 14px); } to { opacity: 1; transform: translate(-50%, 0); } }
@keyframes pfFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes pfPop { from { opacity: 0; transform: translateY(18px) scale(.98); } to { opacity: 1; transform: translateY(0) scale(1); } }

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #D6D8DC; border: 3px solid #fff; }

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
	.pf-hero { grid-template-columns: 1fr !important; }
	.pf-shop-grid { grid-template-columns: 1fr !important; }
	.pf-side { display: none !important; }
	.pf-2col, .pf-about-story__grid, .pf-contact { grid-template-columns: 1fr !important; }
	.pf-footer__inner { grid-template-columns: 1fr 1fr !important; }
	.pf-promo-band__inner { grid-template-columns: 1fr; }
	.pf-offres-hero__inner { grid-template-columns: 1fr; }
	.pf-reviews { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
	.pf-hide-sm { display: none !important; }
	.pf-only-sm { display: inline-flex !important; }
	.pf-navrow__inner { overflow-x: auto; -ms-overflow-style: none; scrollbar-width: none; gap: 0; }
	.pf-navrow__inner::-webkit-scrollbar { display: none; }
	.pf-nav-link { white-space: nowrap; flex: 0 0 auto; padding-left: 12px; padding-right: 12px; font-size: 13px; }
	.pf-trust { grid-template-columns: repeat(2, 1fr); }
	.pf-trust__cell { border-inline-end: none; padding: 16px 14px; }
	.pf-trust__cell:nth-child(odd) { border-inline-end: 1px solid var(--pf-hairline); }
	.pf-header__logo img { height: 34px; }
	ul.products { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.pf-app { padding-bottom: 66px; }
	.pf-tabbar { display: grid; }
	.pf-fab { bottom: 78px; inset-inline-end: 14px; padding: 12px 14px; }
	.pf-fab span { display: none; }
	.pf-toast { bottom: 82px; }
	.pf-cat-tiles { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
	.pf-footer__inner { grid-template-columns: 1fr; }
	.pf-footer__bar-inner { justify-content: center; text-align: center; }
	.pf-hero { padding: 46px var(--pf-container-pad) 52px; min-height: 420px; }
}

/* =========================================================
 * PATCH v1.1.0 — closer to the design source-of-truth
 * ========================================================= */

/* HERO — real image + dark overlay */
.pf-hero-section {
	position: relative;
	background: #140C09;
	overflow: hidden;
}
.pf-hero-section::before {
	content: '';
	position: absolute; inset: 0;
	background-image: var(--pf-hero-img, none);
	background-size: cover;
	background-position: 70% center;
	opacity: 1;
	z-index: 0;
}
.pf-hero-section::after {
	content: '';
	position: absolute; inset: 0;
	background:
		linear-gradient(90deg, rgba(20,12,9,.96) 0%, rgba(20,12,9,.82) 32%, rgba(20,12,9,.28) 62%, rgba(20,12,9,.55) 100%),
		linear-gradient(0deg,  rgba(20,12,9,.55) 0%, transparent 30%);
	z-index: 1;
}
.pf-hero { position: relative; z-index: 2; }
@media (max-width: 760px) {
	.pf-hero-section::before { background-position: 50% center; }
	.pf-hero-section::after {
		background:
			linear-gradient(180deg, rgba(20,12,9,.55) 0%, rgba(20,12,9,.86) 55%, rgba(20,12,9,.96) 100%);
	}
}

/* CATEGORY TILE — dark slate icon, hover reveals accent color */
.pf-cat-tile__icon {
	width: 44px; height: 44px;
	display: inline-flex; align-items: center; justify-content: center;
	color: #fff;
	background: #2C2F38;
	transition: background .3s ease, transform .35s cubic-bezier(.34,1.56,.64,1);
}
.pf-cat-tile:hover .pf-cat-tile__icon {
	background: var(--pf-dot, var(--pf-primary));
}

/* Product card OOS pill (dark) */
.pf-badge-oos {
	position: absolute;
	top: 10px; inset-inline-start: 10px;
	z-index: 5;
	background: #241611; color: #fff;
	font-family: 'Barlow Condensed', sans-serif;
	font-weight: 700; font-size: 11px;
	padding: 5px 9px;
	letter-spacing: .5px;
	text-transform: uppercase;
}

/* SHOP PAGE — full redesign */
.pf-shop-page { padding: 22px 0 60px; }
.pf-shop-page__head { margin-bottom: 18px; }
.pf-shop-page__title {
	font-family: 'Barlow Condensed'; font-weight: 800;
	font-size: clamp(28px, 3.4vw, 42px); text-transform: uppercase;
	color: var(--pf-ink); margin: 8px 0 6px;
}
.pf-shop-page__head .woocommerce-result-count {
	font-size: 13px; color: var(--pf-muted); margin: 0;
}

/* Subcategory chip strip */
.pf-chips {
	display: flex; flex-wrap: wrap; gap: 10px;
	margin: 0 0 26px;
	padding-bottom: 4px;
}
.pf-chip {
	display: inline-flex; align-items: center;
	padding: 12px 22px;
	background: #fff;
	border: 1px solid var(--pf-hairline);
	font-family: 'Barlow Condensed', sans-serif;
	font-weight: 700; font-size: 13px;
	text-transform: uppercase; letter-spacing: .5px;
	color: var(--pf-ink);
	transition: background .2s, color .2s, border-color .2s;
}
.pf-chip:hover {
	border-color: var(--pf-primary);
	color: var(--pf-primary);
}
.pf-chip.is-active {
	background: var(--pf-ink);
	color: #fff;
	border-color: var(--pf-ink);
}

/* Empty state */
.pf-empty {
	text-align: center; padding: 80px 20px;
	background: var(--pf-surface); border: 1px solid var(--pf-hairline);
}
.pf-empty h3 { margin-bottom: 8px; }
.pf-empty p { color: var(--pf-muted); margin: 0 0 20px; }

/* ========= PDP ========= */
.pf-pdp { padding: 32px 0 40px; }
.pf-pdp__grid {
	display: grid;
	grid-template-columns: 1fr 1.05fr;
	gap: 48px;
	align-items: start;
}
.pf-pdp__gallery {
	position: sticky; top: 130px;
	background: var(--pf-surface);
	padding: 24px;
	position: relative;
}
.pf-badge-sale--pdp {
	position: absolute; top: 20px; inset-inline-start: 20px;
	font-size: 15px !important;
	padding: 8px 14px !important;
}
.pf-pdp__gallery img { max-width: 100%; height: auto; }

.pf-pdp__summary { padding-top: 8px; }
.pf-pdp__summary .pf-breadcrumb { margin-bottom: 20px; font-size: 13px; color: var(--pf-muted); }
.pf-pdp__cat {
	display: inline-flex; align-items: center; gap: 6px;
	font-family: 'Barlow Condensed'; font-weight: 700;
	font-size: 12px; text-transform: uppercase; letter-spacing: .5px;
	color: var(--pf-muted);
	margin-bottom: 4px;
}
.pf-pdp__cat .dot {
	width: 8px; height: 8px;
	background: var(--pf-dot, var(--pf-primary));
	display: inline-block;
}
.pf-pdp__brand {
	font-size: 13px; font-weight: 700;
	color: var(--pf-primary);
	text-transform: uppercase; letter-spacing: 1px;
	margin: 10px 0 6px;
}
.pf-pdp__title {
	font-family: 'Barlow'; font-weight: 700;
	font-size: clamp(24px, 3vw, 34px);
	line-height: 1.2;
	text-transform: none; letter-spacing: 0;
	color: var(--pf-ink);
	margin: 0 0 14px;
}
.pf-pdp__meta {
	display: flex; align-items: center; gap: 16px;
	margin: 0 0 20px;
	flex-wrap: wrap;
}
.pf-pdp__rating .star-rating { font-size: 14px; }
.pf-pdp__stock {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 6px 12px;
	font-family: 'Barlow Condensed';
	font-weight: 700; font-size: 12px;
	text-transform: uppercase; letter-spacing: .5px;
}
.pf-pdp__stock.in { background: #E8F7EE; color: #1E8F4D; }
.pf-pdp__stock.out { background: #241611; color: #fff; }

.pf-pdp__price {
	font-family: 'Barlow Condensed'; font-weight: 700;
	font-size: 44px; line-height: 1;
	color: var(--pf-primary);
	margin: 6px 0 26px;
}
.pf-pdp__price del {
	color: var(--pf-faint-2);
	font-size: 22px; font-weight: 400;
	margin-inline-start: 12px;
}
.pf-pdp__price ins {
	background: transparent;
	text-decoration: none;
	color: var(--pf-primary);
}

.pf-pdp__hl-label {
	font-size: 11px; font-weight: 700;
	letter-spacing: 1px; text-transform: uppercase;
	color: var(--pf-faint);
	margin: 0 0 10px;
}
.pf-pdp__hl-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px 22px;
	padding: 18px 20px;
	background: var(--pf-surface);
	border: 1px solid var(--pf-hairline);
	margin: 0 0 24px;
}
.pf-pdp__hl-item {
	display: flex; gap: 8px;
	font-size: 13.5px; line-height: 1.5;
	color: var(--pf-body);
}
.pf-pdp__hl-item .chev {
	color: var(--pf-primary);
	font-weight: 800;
	flex: 0 0 auto;
}

.pf-pdp__desc {
	font-size: 15px; line-height: 1.7;
	color: var(--pf-body);
	margin: 0 0 22px;
}
.pf-pdp__desc p { margin: 0 0 10px; }

.pf-pdp__form-wrap .quantity { display: inline-flex; }
.pf-pdp__form-wrap form.cart {
	display: flex; align-items: stretch; gap: 10px;
	flex-wrap: wrap;
	margin: 0 0 12px;
}
.pf-pdp__form-wrap form.cart .quantity input.qty {
	width: 80px; padding: 14px 8px;
	border: 1px solid var(--pf-hairline);
	background: var(--pf-surface);
	text-align: center; font: 700 16px 'Barlow';
	border-radius: 0;
}
.pf-pdp__form-wrap form.cart .single_add_to_cart_button {
	flex: 1; padding: 14px 22px;
	background: var(--pf-primary); color: #fff !important;
	font-family: 'Barlow Condensed'; font-weight: 700;
	font-size: 16px; letter-spacing: .5px; text-transform: uppercase;
	border: 0; border-radius: 0;
	box-shadow: var(--pf-shadow-cta);
}
.pf-pdp__form-wrap form.cart .single_add_to_cart_button:hover {
	background: var(--pf-primary-hover);
}
.pf-pdp__actions {
	display: flex; gap: 10px; flex-wrap: wrap;
	margin: 12px 0 24px;
}
.pf-pdp__actions .pf-btn { flex: 1; min-width: 200px; }

.pf-pdp__trust {
	display: grid; grid-template-columns: 1fr 1fr 1fr;
	gap: 12px;
	padding: 18px 0;
	border-top: 1px solid var(--pf-hairline);
	border-bottom: 1px solid var(--pf-hairline);
	margin-top: 8px;
}
.pf-pdp__trust > div {
	display: flex; align-items: center; gap: 8px;
	font-size: 12.5px; color: var(--pf-body);
}
.pf-pdp__trust svg { color: var(--pf-primary); flex: 0 0 auto; }

/* Woo tabs / related restyle */
.woocommerce-tabs { padding: 40px 0 20px; }

/* ========= CART PAGE ========= */
.pf-cart-page { padding: 26px 0 60px; }
.pf-cart-page__head { margin-bottom: 26px; }
.pf-cart-page__head h1 {
	font-size: clamp(28px, 3.4vw, 38px);
	margin-bottom: 4px;
}
.pf-cart-page__head p { color: var(--pf-muted); margin: 0; }

.pf-cart-page__grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: 32px;
	align-items: start;
}

.pf-cart-form { background: #fff; border: 1px solid var(--pf-hairline); }

.pf-cart-item {
	display: grid;
	grid-template-columns: 100px 1fr auto auto 40px;
	gap: 16px;
	align-items: center;
	padding: 20px;
	border-bottom: 1px solid var(--pf-hairline);
}
.pf-cart-item:last-child { border-bottom: 0; }
.pf-cart-item__media {
	width: 100px; height: 100px;
	background: var(--pf-surface);
	display: flex; align-items: center; justify-content: center;
}
.pf-cart-item__media img {
	max-width: 100%; max-height: 100%;
	object-fit: contain;
}
.pf-cart-item__brand {
	font-size: 11px; font-weight: 700;
	color: var(--pf-primary);
	text-transform: uppercase; letter-spacing: .5px;
	margin-bottom: 3px;
}
.pf-cart-item__title {
	display: block;
	font-weight: 700; font-size: 14.5px;
	color: var(--pf-ink);
	line-height: 1.35;
}
.pf-cart-item__qty input.qty {
	width: 68px; padding: 10px;
	border: 1px solid var(--pf-hairline);
	background: var(--pf-surface);
	text-align: center;
	font: 700 15px 'Barlow';
	border-radius: 0;
}
.pf-cart-item__total {
	font-family: 'Barlow Condensed'; font-weight: 700;
	font-size: 18px;
	color: var(--pf-primary);
	white-space: nowrap;
}
.pf-cart-item__remove {
	display: inline-flex; align-items: center; justify-content: center;
	width: 36px; height: 36px;
	color: var(--pf-faint);
	border: 1px solid var(--pf-hairline);
	transition: all .2s;
}
.pf-cart-item__remove:hover {
	color: #B5121B; border-color: #B5121B;
}

.pf-cart-actions {
	display: flex; justify-content: space-between; gap: 12px;
	padding: 20px;
	border-top: 1px solid var(--pf-hairline);
	flex-wrap: wrap;
}

/* Dark summary panel */
.pf-cart-summary {
	background: var(--pf-ink);
	color: #fff;
	padding: 28px 24px;
	position: sticky; top: 130px;
}
.pf-cart-summary h2 {
	color: #fff;
	font-family: 'Barlow Condensed';
	font-size: 22px;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin: 0 0 20px;
}
.pf-coupon {
	display: flex; gap: 8px;
	margin: 0 0 22px;
	padding-bottom: 22px;
	border-bottom: 1px solid rgba(255,255,255,.1);
}
.pf-coupon__input {
	flex: 1;
	padding: 12px 14px;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.14);
	color: #fff;
	font: 500 14px 'Barlow';
}
.pf-coupon__input::placeholder { color: #8A8F97; }
.pf-coupon__btn {
	padding: 12px 18px;
	background: #fff !important;
	color: var(--pf-ink) !important;
}
.pf-coupon__btn:hover { background: var(--pf-tint) !important; }

.pf-cart-summary__rows { margin: 0; }
.pf-cart-summary__rows .row {
	display: flex; justify-content: space-between; align-items: center;
	padding: 10px 0;
	color: #C4C8CE;
	font-size: 14px;
}
.pf-cart-summary__rows .row dd { margin: 0; color: #fff; font-weight: 600; }
.pf-cart-summary__rows .row--discount dd { color: var(--pf-primary); }
.pf-cart-summary__rows .row--total {
	border-top: 1px solid rgba(255,255,255,.1);
	margin-top: 8px; padding-top: 16px;
}
.pf-cart-summary__rows .row--total dt { color: #fff; font-weight: 700; font-size: 16px; text-transform: uppercase; letter-spacing: .5px; font-family: 'Barlow Condensed'; }
.pf-cart-summary__rows .row--total dd { color: var(--pf-primary); font-family: 'Barlow Condensed'; font-weight: 800; font-size: 26px; }
.pf-cart-summary__cta {
	width: 100%;
	margin-top: 22px;
	padding: 18px !important;
	font-size: 16px !important;
}
.pf-cart-summary__note {
	display: flex; align-items: center; justify-content: center; gap: 8px;
	color: #B7BCC4; font-size: 12.5px;
	margin: 14px 0 0;
}

/* Empty cart */
.pf-cart-empty {
	text-align: center; padding: 80px 20px;
}
.pf-cart-empty svg {
	color: var(--pf-faint);
	margin: 0 auto 20px;
	display: block;
}
.pf-cart-empty h1 { margin-bottom: 8px; }
.pf-cart-empty p { color: var(--pf-muted); margin: 0 0 24px; }

/* Responsive */
@media (max-width: 1000px) {
	.pf-pdp__grid { grid-template-columns: 1fr; gap: 24px; }
	.pf-pdp__gallery { position: static; }
	.pf-cart-page__grid { grid-template-columns: 1fr; }
	.pf-cart-summary { position: static; }
}
@media (max-width: 760px) {
	.pf-cart-item {
		grid-template-columns: 80px 1fr auto;
		grid-template-areas:
			"m b t"
			"m q x";
		gap: 10px;
	}
	.pf-cart-item__media { grid-area: m; width: 80px; height: 80px; }
	.pf-cart-item__body { grid-area: b; }
	.pf-cart-item__total { grid-area: t; }
	.pf-cart-item__qty { grid-area: q; }
	.pf-cart-item__remove { grid-area: x; }
	.pf-pdp__hl-grid { grid-template-columns: 1fr; }
	.pf-pdp__trust { grid-template-columns: 1fr; }
}

/* ==== v1.2.0 — express buy button on cards ==== */
.pf-card__btns {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 8px;
	margin-top: 12px;
}
.pf-card__btns .pf-btn { padding: 12px 14px; font-size: 13.5px; }
.pf-card__express { white-space: nowrap; }
.pf-card__express svg { flex: 0 0 auto; }
@media (max-width: 760px) {
	.pf-card__btns { grid-template-columns: 1fr; }
	.pf-card__express span { display: inline; }
}
/* Serious icon rendering in kickers */
.pf-promo-band__kicker, .pf-offres-hero__kicker, .pf-about-hero__kicker {
	display: inline-flex; align-items: center; gap: 8px;
}
.pf-footer__proud { display: inline-flex; align-items: center; gap: 6px; }
.pf-contact__ic svg { color: #fff; }

/* ==== v1.3.0 — modal commande express ==== */
.pf-express-overlay {
	position: fixed; inset: 0; z-index: 400;
	background: rgba(20,23,28,.62);
	backdrop-filter: blur(3px);
	display: flex; align-items: center; justify-content: center;
	padding: 20px;
	animation: pfFade .18s ease;
}
.pf-express-overlay[hidden] { display: none; }
.pf-express {
	position: relative;
	background: #fff;
	width: min(460px, 100%);
	max-height: 92vh; overflow-y: auto;
	padding: 30px 28px;
	animation: pfPop .22s ease;
}
.pf-express__close {
	position: absolute; top: 14px; inset-inline-end: 14px;
	display: inline-flex; color: var(--pf-muted);
}
.pf-express__close:hover { color: var(--pf-ink); }
.pf-express__kicker {
	display: inline-flex; align-items: center; gap: 8px;
	font-family: 'Barlow Condensed'; font-weight: 700;
	font-size: 12.5px; letter-spacing: 1.2px; text-transform: uppercase;
	color: var(--pf-primary);
}
.pf-express__product {
	font-family: 'Barlow'; font-weight: 700; font-size: 18px;
	text-transform: none; letter-spacing: 0;
	margin: 8px 0 2px; line-height: 1.3;
}
.pf-express__sub { font-size: 13.5px; color: var(--pf-muted); margin: 0 0 18px; }
.pf-express__form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pf-express__form .pf-field { grid-column: 1 / -1; }
.pf-express__form .pf-field--half { grid-column: auto; }
.pf-express__consent {
	grid-column: 1 / -1;
	display: flex; gap: 10px; align-items: flex-start;
	font-size: 12.5px; color: var(--pf-body);
	cursor: pointer;
}
.pf-express__consent input { margin-top: 2px; accent-color: var(--pf-primary); }
.pf-express__error {
	grid-column: 1 / -1;
	background: #FDECEE; color: #B5121B;
	padding: 10px 14px; font-size: 13px; font-weight: 600;
}
.pf-express__submit { grid-column: 1 / -1; width: 100%; }
.pf-express__note {
	grid-column: 1 / -1;
	display: flex; align-items: center; justify-content: center; gap: 8px;
	color: var(--pf-success); font-size: 12.5px; margin: 0;
}
.pf-express__success { text-align: center; padding: 14px 0; }
.pf-express__success[hidden] { display: none; }
.pf-express__form-state[hidden] { display: none; }
.pf-express__check {
	display: inline-flex; align-items: center; justify-content: center;
	width: 64px; height: 64px;
	background: #E8F7EE; color: var(--pf-success);
	margin-bottom: 14px;
	border-radius: 50%;
}
.pf-express__success h3 {
	font-family: 'Barlow'; font-weight: 700; font-size: 19px;
	text-transform: none; letter-spacing: 0; margin-bottom: 10px;
}
.pf-express__success p { color: var(--pf-body); font-size: 14.5px; margin: 4px 0; }
.pf-express__success strong { color: var(--pf-primary); }
.pf-express__success .pf-btn { margin-top: 16px; }
.pf-lang .is-active { color: var(--pf-primary); }
.pf-lang a:hover { color: #fff; }

/* =========================================================
 * PATCH v1.4.0 — PDP propre, icônes catégories, compte
 * ========================================================= */

/* Icône de catégorie (remplace les carrés de couleur) */
.pf-cat-ic {
	display: inline-flex; align-items: center; justify-content: center;
	flex: 0 0 auto;
	line-height: 0;
}
.pf-cat-ic--all { color: var(--pf-muted); }

/* Liste catégories (sidebar) : icône + label alignés */
.pf-side-list a {
	display: flex; align-items: center; gap: 9px;
	padding: 9px 10px; font-size: 14px; color: var(--pf-body);
}
.pf-side-list .count { margin-inline-start: auto; }

/* Badge catégorie sur cartes + PDP : icône + texte */
.pf-card__cat, .pf-pdp__cat {
	display: inline-flex; align-items: center; gap: 6px;
}
.pf-card__cat .dot, .pf-pdp__cat .dot { display: none; }

/* PDP : conteneur simple (plus de sidebar qui fuit) */
.pf-single-wrap { padding: 22px 0 20px; }
.pf-single-wrap .pf-pdp { padding: 0; }
.pf-single-wrap .related.products { padding-top: 40px; }

/* PDP : image vide → placeholder discret plutôt qu'un grand cadre gris */
.pf-pdp__gallery .woocommerce-product-gallery__image img { width: 100%; height: auto; }
.pf-pdp__gallery img[src*="placeholder"] { opacity: .35; }

/* ==== Compte : grille 2 colonnes UNIQUEMENT si connecté ==== */
body.woocommerce-account.logged-in .woocommerce {
	display: grid !important;
	grid-template-columns: 240px 1fr !important;
	gap: 32px !important;
	align-items: start;
}
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation { grid-column: 1; }
body.woocommerce-account.logged-in .woocommerce-MyAccount-content { grid-column: 2; min-width: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none; margin: 0; padding: 0;
	background: #fff; border: 1px solid var(--pf-hairline);
}
.woocommerce-account .woocommerce-MyAccount-navigation li { margin: 0; border-bottom: 1px solid var(--pf-hairline); }
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child { border-bottom: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li a {
	display: block; padding: 13px 16px;
	font-family: 'Barlow Condensed'; font-weight: 700;
	text-transform: uppercase; letter-spacing: .5px; font-size: 13.5px;
	color: var(--pf-ink);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
	background: var(--pf-tint); color: var(--pf-primary);
}
.woocommerce-account .woocommerce-MyAccount-content { background: #fff; border: 1px solid var(--pf-hairline); padding: 26px 28px; }
.woocommerce-account .woocommerce-MyAccount-content a { color: var(--pf-primary); }

/* Formulaire de connexion (déconnecté) : centré, pas en grille */
body.woocommerce-account:not(.logged-in) .woocommerce { max-width: 480px; margin: 0 auto; }
.woocommerce-account form.login,
.woocommerce-account form.register {
	background: #fff; border: 1px solid var(--pf-hairline); padding: 26px 28px;
}
.woocommerce-account form .button,
.woocommerce-account .woocommerce-Button {
	background: var(--pf-primary) !important; color: #fff !important;
	border: 0 !important; border-radius: 0 !important;
	font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
	padding: 12px 22px !important;
}

/* Related / loop grid — verrou définitif */
.related.products ul.products,
.up-sells ul.products {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(216px, 1fr)) !important;
	gap: 16px !important;
	padding: 0 !important; margin: 0 !important;
}
@media (max-width: 1000px) {
	body.woocommerce-account.logged-in .woocommerce { grid-template-columns: 1fr !important; }
}
@media (max-width: 760px) {
	.related.products ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
}

/* =========================================================
 * PATCH v1.6.0 — galerie PDP, compte, à propos
 * ========================================================= */

/* PDP : layout en bloc (la grille est sur .pf-pdp__grid uniquement) */
.pf-pdp { display: block; }
.pf-pdp__grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 48px; align-items: start; }

/* Galerie : image principale bien visible */
.pf-pdp__gallery { position: sticky; top: 120px; }
.pf-pdp__stage {
	background: var(--pf-surface);
	border: 1px solid var(--pf-hairline);
	aspect-ratio: 1 / 1;
	display: flex; align-items: center; justify-content: center;
	padding: 28px;
	position: relative;
}
.pf-pdp__main { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; }
.pf-pdp__thumbs { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.pf-pdp__thumb {
	width: 70px; height: 70px; padding: 6px;
	background: #fff; border: 1px solid var(--pf-hairline);
	display: flex; align-items: center; justify-content: center;
	cursor: pointer;
}
.pf-pdp__thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.pf-pdp__thumb.is-active, .pf-pdp__thumb:hover { border-color: var(--pf-primary); }
.pf-pdp__gallery .pf-badge-sale--pdp { position: absolute; top: 14px; inset-inline-start: 14px; z-index: 3; }

/* Onglets + description pleine largeur SOUS la grille */
.pf-pdp .woocommerce-tabs { clear: both; padding: 44px 0 10px; }
.pf-pdp .related.products { clear: both; }

/* ==== Compte : nav large et lisible ==== */
body.woocommerce-account.logged-in .woocommerce {
	display: grid !important;
	grid-template-columns: 260px minmax(0, 1fr) !important;
	gap: 30px !important;
	align-items: start;
}
body.woocommerce-account.logged-in .woocommerce-MyAccount-navigation {
	grid-column: 1 !important; width: 100% !important; margin: 0 !important; float: none !important;
}
body.woocommerce-account.logged-in .woocommerce-MyAccount-content {
	grid-column: 2 !important; width: 100% !important; margin: 0 !important; float: none !important; min-width: 0;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul { display: block; }
.woocommerce-account .woocommerce-MyAccount-navigation li a {
	white-space: normal; line-height: 1.2; font-size: 13px; padding: 14px 18px;
}

/* ==== À propos développée ==== */
.pf-about-hero { padding: 90px 0; }
.pf-about-hero h1 { max-width: 820px; }
.pf-about-cta {
	background: linear-gradient(135deg, #241611 0%, #3A241A 55%, #5A2410 100%);
	color: #fff; padding: 60px 0; text-align: center; margin-top: 20px;
}
.pf-about-cta h2 { color: #fff; margin-bottom: 12px; }
.pf-about-cta p { color: #D6CFC9; max-width: 560px; margin: 0 auto 26px; }
.pf-about-values { padding: 20px 0 40px; }
.pf-about-values .pf-why-grid { margin-top: 24px; }
.pf-mission { padding: 20px 0; }
.pf-mission__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.pf-mission__media { background: var(--pf-surface); border: 1px solid var(--pf-hairline); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; }
.pf-mission__media img { max-width: 70%; opacity: .9; }
.pf-mission p { color: var(--pf-body); font-size: 15.5px; line-height: 1.75; margin: 0 0 14px; }

@media (max-width: 1000px) {
	.pf-pdp__grid { grid-template-columns: 1fr; gap: 24px; }
	.pf-pdp__gallery { position: static; }
	.pf-mission__grid { grid-template-columns: 1fr; gap: 24px; }
	body.woocommerce-account.logged-in .woocommerce { grid-template-columns: 1fr !important; }
}

/* =========================================================
 * PATCH v1.8.0 — pages de contenu lisibles + footer
 * ========================================================= */

/* Pages simples (Livraison & retours, FAQ, Suivi…) : lisibles */
.pf-page { max-width: 820px; }
.pf-page > .wp-block-post-title,
.pf-page h1 { font-size: clamp(30px, 3.6vw, 42px); margin-bottom: 22px; }
.pf-page h2 {
	font-size: 20px; margin: 30px 0 10px;
	text-transform: none; letter-spacing: 0;
	color: var(--pf-ink); font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
}
.pf-page h3 { font-size: 17px; margin: 22px 0 8px; text-transform: none; letter-spacing: 0; }
.pf-page p { color: var(--pf-body); font-size: 15.5px; line-height: 1.75; margin: 0 0 14px; }
.pf-page ul, .pf-page ol { padding-inline-start: 22px; margin: 0 0 16px; }
.pf-page li { color: var(--pf-body); font-size: 15.5px; line-height: 1.7; margin-bottom: 6px; }
.pf-page a { color: var(--pf-primary); text-decoration: underline; }
.pf-page strong { color: var(--pf-ink); }

/* Suivi de commande (formulaire WooCommerce) */
.pf-page form.woocommerce-form-track-order { max-width: 520px; margin-top: 10px; }
.pf-page form.woocommerce-form-track-order .button {
	background: var(--pf-primary) !important; color: #fff !important; border: 0 !important; border-radius: 0 !important;
	font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; padding: 12px 24px !important;
}

/* Footer : drapeau + réseaux */
.pf-flag { font-size: 15px; line-height: 1; }
.pf-footer__socials { flex-wrap: wrap; }

/* =========================================================
 * PATCH v1.9.0 — case CNDP, footer collant
 * ========================================================= */

/* Case à cocher CNDP (formulaire contact) */
.pf-consent {
	grid-column: 1 / -1;
	display: flex; gap: 10px; align-items: flex-start;
	font-size: 13px; color: var(--pf-body); cursor: pointer;
	margin: 4px 0 4px;
}
.pf-consent input { margin-top: 3px; accent-color: var(--pf-primary); flex: 0 0 auto; }
.pf-consent a { color: var(--pf-primary); text-decoration: underline; }

/* (footer collant géré en v1.13 via .wp-site-blocks) */

/* =========================================================
 * PATCH v1.11.0 — section "Nos marques" (logos ou badges)
 * ========================================================= */
.pf-brands-section { padding: 30px 0 50px; margin-top: 40px; border-top: 1px solid var(--pf-hairline); }
.pf-brands-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 16px;
	margin-top: 24px;
}
.pf-brand {
	display: flex; align-items: center; justify-content: center;
	height: 90px; padding: 14px;
	background: #fff; border: 1px solid var(--pf-hairline);
	transition: border-color .2s, box-shadow .2s;
}
.pf-brand:hover { border-color: var(--pf-primary); box-shadow: var(--pf-shadow-card); }
.pf-brand.has-logo img { max-width: 100%; max-height: 52px; width: auto; object-fit: contain; filter: grayscale(1); opacity: .8; transition: filter .2s, opacity .2s; }
.pf-brand.has-logo:hover img { filter: grayscale(0); opacity: 1; }
.pf-brand__name {
	font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
	font-size: 15px; text-transform: uppercase; letter-spacing: .5px;
	color: var(--pf-muted); text-align: center; line-height: 1.2;
}
.pf-brand:hover .pf-brand__name { color: var(--pf-ink); }
@media (max-width: 1000px) { .pf-brands-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 640px) { .pf-brands-grid { grid-template-columns: repeat(3, 1fr); } .pf-brand { height: 74px; } }

/* =========================================================
 * PATCH v1.13.0 — footer collant (fix), confirmation, contact
 * ========================================================= */

/* Footer toujours en bas : le thème bloc enveloppe tout dans .wp-site-blocks */
.wp-site-blocks { display: flex; flex-direction: column; min-height: 100vh; }
.wp-site-blocks > main,
.wp-site-blocks > .wp-block-group:not(:first-child):not(:last-child) { flex: 1 0 auto; }
.wp-site-blocks > footer { flex-shrink: 0; margin-top: auto; }

/* Erreur formulaire contact */
.pf-contact__err { grid-column: 1 / -1; background: #FDECEE; color: #B5121B; padding: 10px 14px; font-size: 13px; font-weight: 600; }

/* ===== Page « Commande reçue » ===== */
.pf-confirm { max-width: 780px; padding: 40px 0 60px; }
.pf-confirm__head { text-align: center; margin-bottom: 30px; }
.pf-confirm__check {
	display: inline-flex; align-items: center; justify-content: center;
	width: 74px; height: 74px; margin: 0 auto 18px;
	background: #E8F7EE; color: var(--pf-success); border-radius: 50%;
}
.pf-confirm__head h1 { font-size: clamp(26px, 3.4vw, 38px); }
.pf-confirm__sub { color: var(--pf-muted); margin-top: 10px; font-size: 15.5px; }
.pf-confirm__meta {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
	background: var(--pf-hairline); border: 1px solid var(--pf-hairline);
	margin-bottom: 28px;
}
.pf-confirm__meta-item { background: #fff; padding: 16px 18px; display: flex; flex-direction: column; gap: 4px; }
.pf-confirm__meta-item .l { font-size: 11px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; color: var(--pf-faint); }
.pf-confirm__meta-item .v { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 17px; color: var(--pf-ink); }
.pf-confirm__meta-item .v--total { color: var(--pf-primary); font-size: 20px; }
.pf-confirm__recap { background: #fff; border: 1px solid var(--pf-hairline); padding: 24px; margin-bottom: 24px; }
.pf-confirm__recap h2 { font-size: 20px; margin-bottom: 16px; }
.pf-confirm__line { display: grid; grid-template-columns: 56px 1fr auto; gap: 14px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--pf-hairline); }
.pf-confirm__line-media { width: 56px; height: 56px; background: var(--pf-surface); display: flex; align-items: center; justify-content: center; }
.pf-confirm__line-media img { max-width: 100%; max-height: 100%; object-fit: contain; }
.pf-confirm__line-name { font-weight: 700; font-size: 14px; color: var(--pf-ink); }
.pf-confirm__line-name .qty { color: var(--pf-muted); font-weight: 500; margin-inline-start: 6px; }
.pf-confirm__line-total { font-family: 'Barlow Condensed'; font-weight: 700; color: var(--pf-primary); }
.pf-confirm__totals { margin: 16px 0 0; }
.pf-confirm__totals .row { display: flex; justify-content: space-between; padding: 7px 0; font-size: 14px; color: var(--pf-body); }
.pf-confirm__totals .row dd { margin: 0; font-weight: 600; }
.pf-confirm__totals .row--total { border-top: 1px solid var(--pf-hairline); margin-top: 8px; padding-top: 14px; }
.pf-confirm__totals .row--total dt { font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; font-size: 16px; }
.pf-confirm__totals .row--total dd { color: var(--pf-primary); font-family: 'Barlow Condensed'; font-weight: 800; font-size: 22px; }
.pf-confirm__addr { background: var(--pf-surface); border: 1px solid var(--pf-hairline); padding: 20px 22px; margin-bottom: 26px; }
.pf-confirm__addr h3 { font-size: 15px; margin-bottom: 8px; }
.pf-confirm__addr p { color: var(--pf-body); font-size: 14px; margin: 0 0 4px; font-style: normal; }
.pf-confirm__addr address { font-style: normal; }
.pf-confirm__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.pf-confirm__actions .pf-btn { flex: 1; min-width: 220px; }

/* ===== Favoris (TI Wishlist) stylé ===== */
.tinv-wishlist h2 { font-size: 20px; margin-bottom: 16px; }
.tinv-wishlist table.tinvwl-table { border: 1px solid var(--pf-hairline); border-collapse: collapse; width: 100%; }
.tinv-wishlist table.tinvwl-table th { background: var(--pf-surface); color: var(--pf-muted); font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; font-size: 12.5px; padding: 12px 14px; text-align: start; }
.tinv-wishlist table.tinvwl-table td { padding: 14px; border-top: 1px solid var(--pf-hairline); vertical-align: middle; }
.tinv-wishlist .product-name a { color: var(--pf-ink); font-weight: 700; }
.tinv-wishlist .amount, .tinv-wishlist ins .amount { color: var(--pf-primary); font-weight: 700; }
.tinv-wishlist .tinvwl-btn, .tinv-wishlist button, .tinv-wishlist .button {
	background: var(--pf-primary) !important; color: #fff !important; border: 0 !important; border-radius: 0 !important;
	font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; padding: 10px 18px !important;
}
.tinv-wishlist .tinvwl-remove, .tinv-wishlist .product-remove button { background: transparent !important; color: var(--pf-muted) !important; padding: 4px !important; }
.tinv-wishlist select { padding: 10px 12px; border: 1px solid var(--pf-hairline); background: #fff; font: inherit; }
/* Popup TI */
.tinv-modal .tinv-modal-inner { border-radius: 0 !important; padding: 30px !important; }
.tinv-modal .tinvwl-btn, .tinv-modal .button {
	background: var(--pf-primary) !important; color: #fff !important; border-radius: 0 !important;
	font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase;
}
@media (max-width: 700px) {
	.pf-confirm__meta { grid-template-columns: 1fr 1fr; }
	.pf-confirm__actions .pf-btn { min-width: 100%; }
}

/* =========================================================
 * PATCH v1.14.0 — fil animé des marques + logo footer
 * ========================================================= */
.pf-brands-marquee {
	position: relative; overflow: hidden; padding: 8px 0;
	-webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
	        mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.pf-brands-track {
	display: inline-flex; align-items: center; gap: 18px;
	white-space: nowrap; padding-inline: 18px;
	animation: pfmarq 45s linear infinite;
	will-change: transform;
}
.pf-brands-marquee:hover .pf-brands-track { animation-play-state: paused; }
.pf-brand-logo {
	flex: 0 0 auto;
	display: inline-flex; align-items: center; justify-content: center;
	width: 150px; height: 84px; padding: 14px 18px;
	background: #fff; border: 1px solid var(--pf-hairline);
	transition: border-color .2s, box-shadow .2s;
}
.pf-brand-logo:hover { border-color: var(--pf-primary); box-shadow: var(--pf-shadow-card); }
.pf-brand-logo img {
	max-width: 100%; max-height: 100%; width: auto; object-fit: contain;
	filter: grayscale(1); opacity: .72; transition: filter .25s, opacity .25s;
}
.pf-brand-logo:hover img { filter: grayscale(0); opacity: 1; }
[dir="rtl"] .pf-brands-track { animation-direction: reverse; }
@media (max-width: 760px) {
	.pf-brand-logo { width: 120px; height: 68px; }
	.pf-brands-track { animation-duration: 32s; }
}

/* Logo footer : fichier fourni, affiché tel quel (couleurs conservées) */
.pf-footer__plaque img { height: 58px; }
.pf-footer__err { color: #F0865A; font-size: 12.5px; margin-top: 8px; }

/* =========================================================
 * PATCH v1.15.0 — page Favoris aérée (pleine largeur)
 * ========================================================= */
/* La page favoris utilise toute la largeur (pas le gabarit texte 820px) */
.pf-fullwidth .pf-page { max-width: 100% !important; }
.pf-fullwidth .pf-page > .wp-block-post-title,
.pf-fullwidth .pf-page h1 { margin-bottom: 30px; }

/* Tableau des favoris : aéré et lisible */
.tinv-wishlist .tinvwl-table,
.tinv-wishlist table.tinvwl-table { width: 100%; table-layout: auto; }
.tinv-wishlist table.tinvwl-table th,
.tinv-wishlist table.tinvwl-table td {
	padding: 20px 18px !important;
	vertical-align: middle;
	border-top: 1px solid var(--pf-hairline);
}
.tinv-wishlist table.tinvwl-table thead th { border-top: 0; }
/* Colonne nom du produit : large, pas de retour à la ligne mot par mot */
.tinv-wishlist td.product-name { min-width: 280px; }
.tinv-wishlist td.product-name a {
	font-family: 'Barlow', sans-serif; font-weight: 700; font-size: 15px;
	line-height: 1.4; color: var(--pf-ink); text-transform: none; letter-spacing: 0;
}
.tinv-wishlist td.product-thumbnail { width: 90px; }
.tinv-wishlist td.product-thumbnail img { width: 72px; height: auto; }
.tinv-wishlist td.product-price { min-width: 130px; white-space: nowrap; }
.tinv-wishlist td.product-stock { min-width: 110px; }
.tinv-wishlist .product-remove button,
.tinv-wishlist .product-remove .button { width: 34px; height: 34px; padding: 0 !important; }
/* Boutons d'action du tableau */
.tinv-wishlist .tinvwl-btn,
.tinv-wishlist td.product-action .button,
.tinv-wishlist .product-action .tinvwl_add_to_cart_button {
	white-space: nowrap; padding: 11px 18px !important; font-size: 12.5px;
}
/* Barre d'actions du bas + partage : espacée */
.tinv-wishlist .tinv-wishlist-actions,
.tinv-wishlist .social-buttons { margin-top: 24px; gap: 14px; }
.tinv-wishlist .tinvwl-input-group,
.tinv-wishlist .tinv-wishlist-buttons-group { gap: 12px; flex-wrap: wrap; }
.tinv-wishlist .social-buttons { display: flex; align-items: center; justify-content: flex-end; }
.tinv-wishlist .social-buttons > span { color: var(--pf-muted); font-size: 14px; margin-inline-end: 6px; }
@media (max-width: 900px) {
	.tinv-wishlist table.tinvwl-table th,
	.tinv-wishlist table.tinvwl-table td { padding: 12px 10px !important; }
	.tinv-wishlist td.product-name { min-width: 160px; }
}

/* =========================================================
 * PATCH v1.16.0 — compte (nav + boutons), commande reçue
 * ========================================================= */
/* Nav compte : items compacts */
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li { margin: 0; border-bottom: 1px solid var(--pf-hairline); }
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child { border-bottom: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation li a {
	display: block; padding: 13px 18px !important; line-height: 1.2;
	font-family: 'Barlow Condensed'; font-weight: 700; font-size: 13px;
	text-transform: uppercase; letter-spacing: .5px; color: var(--pf-ink);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover { background: var(--pf-tint); color: var(--pf-primary); }

/* Boutons du compte (Voir commande, etc.) — texte blanc visible + hover */
.woocommerce-account .woocommerce-orders-table .button,
.woocommerce-account .woocommerce-MyAccount-content .button,
.woocommerce-account a.button,
.woocommerce-account button.button {
	display: inline-block !important;
	background: var(--pf-primary) !important; color: #fff !important;
	border: 0 !important; border-radius: 0 !important;
	font-family: 'Barlow Condensed', sans-serif !important; font-weight: 700 !important;
	font-size: 13px !important; text-transform: uppercase !important; letter-spacing: .4px !important;
	padding: 10px 18px !important; line-height: 1.2 !important; text-align: center;
	transition: background .2s !important;
}
.woocommerce-account .woocommerce-orders-table .button:hover,
.woocommerce-account .woocommerce-MyAccount-content .button:hover,
.woocommerce-account a.button:hover { background: var(--pf-primary-hover) !important; color: #fff !important; }
.woocommerce-account .woocommerce-orders-table { border: 1px solid var(--pf-hairline); border-collapse: collapse; width: 100%; }
.woocommerce-account .woocommerce-orders-table th { background: var(--pf-surface); font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; font-size: 12px; color: var(--pf-muted); padding: 12px 14px; text-align: start; }
.woocommerce-account .woocommerce-orders-table td { padding: 14px; border-top: 1px solid var(--pf-hairline); vertical-align: middle; }
.woocommerce-account .woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions { text-align: end; }
/* Honeypot anti-spam (invisible) */
.pf-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }

/* =========================================================
 * PATCH v1.17.0 — mobile + RTL + hover catégorie
 * ========================================================= */

/* Hover des tuiles catégories → orange de marque (au lieu de la couleur cat.) */
.pf-cat-tile:hover .pf-cat-tile__icon { background: var(--pf-primary) !important; }
.pf-cat-tile:hover { border-color: var(--pf-primary); }

/* ---- GRILLE PRODUITS : 2 colonnes sur mobile (prioritaire) ---- */
@media (max-width: 767px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products,
	div.woocommerce ul.products,
	ul.products.pf-grid,
	ul.products,
	.related.products ul.products,
	.up-sells ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 10px !important;
	}
	/* cartes plus compactes */
	.pf-card__body { padding: 10px 10px 12px; }
	.pf-card__title { font-size: 13px; min-height: 0; }
	.pf-card__hl { display: none; }          /* points forts masqués sur mobile (gain de place) */
	.pf-card__hl-label { display: none; }
	.pf-card__btns { grid-template-columns: 1fr; gap: 6px; }
	.pf-card__price .amount, .pf-card__price bdi, .pf-card__price ins { font-size: 19px; }
	.pf-card__cat { font-size: 9.5px; }
}

/* ---- MARGES : conteneur toujours avec padding latéral sur mobile ---- */
@media (max-width: 767px) {
	.pf-container,
	.pf-shop-page > .pf-container,
	.woocommerce .pf-container,
	.pf-single-wrap,
	.pf-shop-wrap {
		padding-inline: 16px !important;
	}
	.pf-shop-page { padding-inline: 0; }
	.pf-shop-page__title { font-size: 26px; }
	.woocommerce-products-header, .pf-shop-page__head { padding-inline: 0; }
	main.pf-shop-page .pf-container { padding-inline: 16px !important; }
	/* titres de section pas collés au bord */
	.pf-section-header { margin-inline: 0; }
}

/* ---- RTL MOBILE : remettre les compartiments à leur place ---- */
[dir="rtl"] .pf-tabbar { direction: rtl; }
[dir="rtl"] .pf-utility__inner,
[dir="rtl"] .pf-header__inner,
[dir="rtl"] .pf-navrow__inner { direction: rtl; }
[dir="rtl"] .pf-fab { inset-inline-end: auto; inset-inline-start: 22px; }
@media (max-width: 760px) {
	[dir="rtl"] .pf-fab { inset-inline-start: 14px; inset-inline-end: auto; }
	/* la barre du bas garde l'ordre logique en RTL */
	[dir="rtl"] .pf-tabbar { grid-auto-flow: column; }
	/* header mobile RTL : logo à droite, outils à gauche (déjà géré par logical props) */
	[dir="rtl"] .pf-header__search { text-align: right; }
	/* prix + badges en RTL restent lisibles */
	[dir="rtl"] .pf-badge-sale, [dir="rtl"] .pf-badge-oos { inset-inline-start: 10px; inset-inline-end: auto; }
	[dir="rtl"] .pf-card__price { direction: ltr; justify-content: flex-end; }
}
/* Prix Woo en RTL : forcer LTR sur les montants (chiffres) */
[dir="rtl"] .amount, [dir="rtl"] .woocommerce-Price-amount { direction: ltr; display: inline-block; unicode-bidi: embed; }

/* =========================================================
 * PATCH v1.18.0 — anti-débordement horizontal + grille mobile blindée
 * ========================================================= */

/* Empêcher le débordement horizontal SANS casser le header sticky.
   (overflow sur .wp-site-blocks cassait position:sticky → header disparaissait) */
html { overflow-x: hidden; max-width: 100%; }
body.pf-app { max-width: 100%; }
.wp-site-blocks { max-width: 100vw; }
img, table, iframe, video { max-width: 100%; }
/* On confine plutôt les sections larges individuellement (voir marquee/hero). */
.pf-hero-section, .pf-promo-band, .pf-offres-hero, .pf-about-hero, .pf-about-cta,
.pf-trust-section, .pf-marquee-section, .pf-reviews-section { overflow-x: clip; }

/* Marquee marques : bien confiné */
.pf-brands-section, .pf-brands-marquee { max-width: 100vw; overflow: hidden; }

/* Cartes produit : autoriser le rétrécissement en grille + couper les mots longs */
ul.products li.product, .pf-card, .pf-card * { min-width: 0; }
.pf-card__title, .pf-card__hl li, .pf-card__cat { overflow-wrap: anywhere; word-break: break-word; }

/* GRILLE PRODUITS : 2 colonnes strictes sur mobile, quelle que soit la section */
@media (max-width: 767px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products,
	div.woocommerce ul.products,
	section ul.products,
	.pf-featured-section ul.products,
	.pf-offers-grid ul.products,
	ul.products.pf-grid,
	ul.products,
	.related.products ul.products,
	.up-sells ul.products {
		display: grid !important;
		grid-template-columns: 1fr 1fr !important;
		gap: 10px !important;
		width: 100% !important;
		max-width: 100% !important;
	}
}

/* =========================================================
 * PATCH v1.19.0 — hover chips (texte visible), langue, RTL pages
 * ========================================================= */
/* Chips de recherche (overlay) : fond orange + texte BLANC au survol */
.pf-search-popular__chips .pf-chip { background: rgba(255,255,255,.12); color: #fff; border: 0; }
.pf-search-popular__chips .pf-chip:hover,
.pf-search-popular__chips .pf-chip:active { background: var(--pf-primary) !important; color: #fff !important; }
/* Chips de la boutique (fond blanc) : texte orange lisible au survol */
.pf-chips .pf-chip:hover,
.pf-chips .pf-chip:active { background: #fff !important; border-color: var(--pf-primary) !important; color: var(--pf-primary) !important; }
.pf-chips .pf-chip.is-active { background: var(--pf-ink) !important; color: #fff !important; border-color: var(--pf-ink) !important; }

/* Sélecteur de langue à drapeaux (déroulant, pratique sur mobile) */
.pf-langflags { position: relative; font-family: 'Barlow Condensed', sans-serif; }
.pf-langflags__cur {
	display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
	background: transparent; color: #fff; font-weight: 700; font-size: 13px; padding: 4px 6px;
}
.pf-langflags__cur .flag { font-size: 16px; line-height: 1; }
.pf-langflags__cur .chev { font-size: 9px; opacity: .7; }
.pf-langflags__menu {
	position: absolute; top: 100%; inset-inline-end: 0; z-index: 200;
	background: #fff; border: 1px solid var(--pf-hairline); box-shadow: var(--pf-shadow-dropdown);
	min-width: 130px; display: none; margin-top: 4px;
}
.pf-langflags.is-open .pf-langflags__menu { display: block; }
.pf-langflags__menu a {
	display: flex; align-items: center; gap: 8px; padding: 10px 14px;
	color: var(--pf-ink); font-size: 14px; font-weight: 600;
}
.pf-langflags__menu a:hover { background: var(--pf-tint); color: var(--pf-primary); }
.pf-langflags__menu .flag { font-size: 18px; }

/* =========================================================
 * PATCH v1.20.0 — débordement confiné sur <main> (préserve header sticky)
 *                 + grille produits auto-responsive (2 col mobile garantie)
 * ========================================================= */

/* Confiner le débordement sur le contenu (main), PAS sur .wp-site-blocks :
   le header sticky est hors de <main>, donc il reste collant.
   Uniquement <=1000px (desktop garde la galerie PDP sticky). */
@media (max-width: 1000px) {
	.wp-site-blocks > main { overflow-x: clip; max-width: 100vw; }
}

/* Grille produits : colonnes basées sur clamp(vw) → 2 sur mobile, 4 sur desktop,
   SANS dépendre du déclenchement du media query. */
.woocommerce ul.products,
.woocommerce-page ul.products,
div.woocommerce ul.products,
ul.products.pf-grid,
ul.products,
.related.products ul.products,
.up-sells ul.products {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(clamp(150px, 44vw, 300px), 1fr)) !important;
	gap: 14px !important;
	width: 100% !important;
	max-width: 100% !important;
}
@media (min-width: 1001px) {
	/* Desktop : 4 colonnes nettes */
	.woocommerce ul.products, ul.products, .related.products ul.products {
		grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
	}
}
@media (max-width: 480px) {
	.woocommerce ul.products, ul.products, .related.products ul.products { gap: 10px !important; }
}
