/*!
 * MPE Theme — main.css
 * CSS 100 % natif — aucune dépendance Tailwind.
 * @package MPE
 */

/* ==========================================================================
   1. Reset & box-model
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 5rem; -webkit-text-size-adjust: 100%; }
body { min-height: 100vh; line-height: 1.6; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img, svg, video { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }

/* ==========================================================================
   2. Variables de design — MPE Branding
   ========================================================================== */
:root {
	/* --- COULEURS PRINCIPALES (Tirées du logo) --- */
	--mpe-primary:       #1F9B42;
	--mpe-primary-light: #28B852;
	--mpe-primary-dark:  #167330;

	--mpe-accent:        #003f13;
	--mpe-accent-hover:  #175a35;

	/* --- COULEURS DE FOND --- */
	--mpe-bg-body:   #F8F9FA;
	--mpe-bg-card:   #FFFFFF;
	--mpe-bg-footer: #1A202C;

	/* --- COULEURS DE TEXTE --- */
	--mpe-text-main:    #2D3748;
	--mpe-text-heading: #1A202C;
	--mpe-text-muted:   #718096;
	--mpe-text-light:   #FFFFFF;

	/* --- TYPOGRAPHIES --- */
	--mpe-font-heading: 'Poppins', sans-serif;
	--mpe-font-body:    'Inter', sans-serif;

	/* --- BORDURES ET COURBES --- */
	--mpe-radius-sm:   8px;
	--mpe-radius-md:   16px;
	--mpe-radius-lg:   24px;
	--mpe-radius-xl:   40px;
	--mpe-radius-pill: 50px;

	/* --- OMBRES --- */
	--mpe-shadow-sm:    0 2px 4px rgba(0, 0, 0, 0.05);
	--mpe-shadow-bento: 0 10px 30px rgba(0, 0, 0, 0.06);
	--mpe-shadow-hover: 0 15px 35px rgba(31, 155, 66, 0.15);

	/* --- GLASSMORPHISM --- */
	--mpe-glass-bg:       rgba(255, 255, 255, 0.75);
	--mpe-glass-blur:     12px;              /* valeur seule — utilisée dans blur() */
	--mpe-glass-border:   rgba(255, 255, 255, 0.30); /* couleur seule */
	--mpe-glass-saturate: 160%;

	/* --- TRANSITIONS --- */
	--mpe-transition-fast:   0.2s ease-in-out;
	--mpe-transition-smooth: 0.3s cubic-bezier(0.4, 0, 0.2, 1);

	/* ----------------------------------------------------------------
	   Alias de compatibilité — permettent aux composants existants
	   de continuer à fonctionner sans modification.
	   ---------------------------------------------------------------- */

	/* Couleurs d'accent secondaires (conservées pour dégradés & halos) */
	--mpe-blue:    var(--mpe-primary);
	--mpe-indigo:  #5E5CE6;
	--mpe-purple:  #BF5AF2;
	--mpe-pink:    #014b19;
	--mpe-emerald: #30D158;
	--mpe-amber:   #FFD60A;

	/* Niveaux d'encre → texte de marque */
	--mpe-ink-900: var(--mpe-text-heading);
	--mpe-ink-700: var(--mpe-text-main);
	--mpe-ink-500: var(--mpe-text-muted);
	--mpe-ink-300: #CBD5E1;

	/* Surfaces → fonds de marque */
	--mpe-surface:       var(--mpe-bg-card);
	--mpe-surface-soft:  var(--mpe-bg-body);
	--mpe-surface-muted: #EDF2F7;

	/* Ombres → ombres de marque */
	--mpe-shadow-soft: var(--mpe-shadow-bento);

	/* Typographie → fonts de marque */
	--mpe-font-sans:  var(--mpe-font-body);
	--mpe-font-serif: 'Poppins', Georgia, serif;

	/* Easing & layout */
	--mpe-ease:  cubic-bezier(0.4, 0, 0.2, 1);
	--mpe-max-w: 1280px;
	--mpe-px:    1rem;
}

/* ==========================================================================
   3. Base body
   ========================================================================== */
body {
	font-family: var(--mpe-font-body);
	background-color: var(--mpe-bg-body);
	color: var(--mpe-text-main);
}
h1, h2, h3, h4, h5, h6 {
	font-family: var(--mpe-font-heading);
	color: var(--mpe-text-heading);
}

/* Highlight texte */
::selection { background: rgba(10, 132, 255, 0.25); }

/* Focus accessible */
:focus-visible {
	outline: 2px solid var(--mpe-primary);
	outline-offset: 3px;
	border-radius: var(--mpe-radius-sm);
}

/* Scrollbar discrète */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: rgba(15,23,42,0.2); border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: rgba(15,23,42,0.35); }

/* ==========================================================================
   4. Utilitaires globaux
   ========================================================================== */
.sr-only {
	position: absolute;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}
.site-main { display: block; }

/* Clamp de texte */
.line-clamp-2 {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.line-clamp-3 {
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ==========================================================================
   5. Layout — Container
   ========================================================================== */
.mpe-container {
	width: 100%;
	max-width: var(--mpe-max-w);
	margin-inline: auto;
	padding-inline: var(--mpe-px);
}
@media (min-width: 640px)  { .mpe-container { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .mpe-container { padding-inline: 2rem;   } }

.mpe-container--narrow { max-width: 900px; }
.mpe-container--wide   { max-width: 1152px; }

/* ==========================================================================
   6. HEADER
   ========================================================================== */
.skip-link {
	position: absolute;
	top: -100px;
	left: 1rem;
	z-index: 1000;
	padding: .5rem 1rem;
	background: var(--mpe-surface);
	color: var(--mpe-ink-900);
	border-radius: var(--mpe-radius-sm);
	font-weight: 500;
	transition: top .2s;
}
.skip-link:focus { top: .75rem; }

.mpe-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 50;
	background: rgba(255,255,255,0.60);
	-webkit-backdrop-filter: blur(24px) saturate(150%);
	        backdrop-filter: blur(24px) saturate(150%);
	border-bottom: 1px solid rgba(255,255,255,0.20);
	box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset;
	transition: background-color .3s var(--mpe-ease),
	            backdrop-filter .3s var(--mpe-ease),
	            box-shadow .3s var(--mpe-ease);
}
.mpe-header[data-scrolled="true"] {
	background: rgba(255,255,255,0.88);
	box-shadow: 0 1px 0 rgba(15,23,42,0.06), 0 10px 30px -20px rgba(15,23,42,0.2);
}

.mpe-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	height: 4rem;
}

/* Logo par défaut (texte/badge) */
.mpe-logo {
	display: flex;
	align-items: center;
	gap: .75rem;
	text-decoration: none;
	color: inherit;
}

/* Logo personnalisé WordPress (Image) */
.custom-logo-link {
	display: flex;
	align-items: center;
	height: 100%;
}
.custom-logo {
	max-height: 3.25rem;
	width: auto;
	object-fit: contain;
}
.mpe-logo__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem; height: 2.25rem;
	border-radius: var(--mpe-radius-sm);
	background: linear-gradient(135deg, var(--mpe-primary), var(--mpe-primary-dark));
	color: #fff;
	font-weight: 700;
	font-size: .8rem;
	box-shadow: 0 4px 12px rgba(31,155,66,0.35);
	flex-shrink: 0;
}
.mpe-logo__text { display: none; flex-direction: column; line-height: 1.2; }
@media (min-width: 640px) { .mpe-logo__text { display: flex; } }
.mpe-logo__name    { font-weight: 600; font-size: .95rem; color: var(--mpe-ink-900); }
.mpe-logo__tagline { font-size: .7rem; color: var(--mpe-ink-500); }

/* Nav principale */
.mpe-nav { display: none; }
@media (min-width: 1024px) {
	.mpe-nav { display: flex; align-items: center; gap: .25rem; }
}
.mpe-nav__list {
	display: flex;
	align-items: center;
	gap: .25rem;
	font-size: .875rem;
	font-weight: 500;
	color: var(--mpe-ink-700);
}
.mpe-nav__list li a {
	display: block;
	padding: .5rem .75rem;
	border-radius: 9999px;
	color: var(--mpe-ink-700);
	transition: background-color .2s var(--mpe-ease);
}
.mpe-nav__list li a:hover { background: rgba(15,23,42,0.05); }

/* Lien actif (page courante) */
.mpe-nav__list li.current-menu-item > a,
.mpe-nav__list li.current-menu-ancestor > a,
.mpe-nav__list li.current-page-ancestor > a {
	background: rgba(31,155,66,.10);
	color: var(--mpe-primary);
	font-weight: 600;
}

/* Item parent avec flèche */
.mpe-nav__list .menu-item-has-children > a {
	padding-right: 1.5rem;
	position: relative;
}
.mpe-nav__list .menu-item-has-children > a::after {
	content: '';
	position: absolute;
	right: .5rem;
	top: 50%;
	transform: translateY(-50%);
	border: 4px solid transparent;
	border-top-color: currentColor;
	border-bottom: none;
	opacity: .55;
	transition: transform .2s;
}
.mpe-nav__list .menu-item-has-children:hover > a::after,
.mpe-nav__list .menu-item-has-children:focus-within > a::after {
	transform: translateY(-30%) rotate(180deg);
}

/* Sous-menu desktop — dropdown */
.mpe-nav__list .sub-menu {
	position: absolute;
	top: calc(100% + .5rem);
	left: 0;
	min-width: 14rem;
	background: rgba(255,255,255,.97);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border: 1px solid rgba(0,0,0,.08);
	border-radius: var(--mpe-radius-md);
	box-shadow: 0 12px 40px rgba(0,0,0,.12), 0 2px 8px rgba(0,0,0,.06);
	padding: .5rem;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(-6px);
	transition: opacity .2s var(--mpe-ease), transform .2s var(--mpe-ease), visibility .2s;
	z-index: 100;
	list-style: none;
}
.mpe-nav__list .menu-item-has-children {
	position: relative;
}
.mpe-nav__list .menu-item-has-children:hover .sub-menu,
.mpe-nav__list .menu-item-has-children:focus-within .sub-menu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
}
.mpe-nav__list .sub-menu li a {
	display: flex;
	align-items: center;
	padding: .5rem .875rem;
	border-radius: var(--mpe-radius-sm);
	font-size: .875rem;
	color: var(--mpe-text-main);
	transition: background .15s, color .15s;
	white-space: nowrap;
}
.mpe-nav__list .sub-menu li a:hover {
	background: rgba(31,155,66,.08);
	color: var(--mpe-primary);
}
.mpe-nav__list .sub-menu li.current-menu-item > a {
	background: rgba(31,155,66,.10);
	color: var(--mpe-primary);
	font-weight: 600;
}

/* Actions header */
.mpe-header__actions {
	display: flex;
	align-items: center;
	gap: .75rem;
}

/* Bouton panier */
.mpe-cart-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem; height: 2.5rem;
	border-radius: 9999px;
	background: rgba(255,255,255,0.60);
	border: 1px solid rgba(15,23,42,0.06);
	color: var(--mpe-ink-900);
	transition: background-color .2s var(--mpe-ease);
}
.mpe-cart-btn:hover { background: var(--mpe-surface); }
.mpe-cart-badge {
	position: absolute;
	top: -.25rem; right: -.25rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.25rem; height: 1.25rem;
	padding: 0 .375rem;
	background: var(--mpe-accent);
	border-radius: 9999px;
	font-size: .625rem;
	font-weight: 700;
	color: #fff;
	line-height: 1;
}

/* Bouton "Faire un don" header */
.mpe-btn-donate {
	display: none;
	align-items: center;
	gap: .375rem;
	padding: .5rem 1rem;
	border-radius: 9999px;
	background: var(--mpe-ink-900);
	color: #fff;
	font-size: .875rem;
	font-weight: 500;
	transition: background-color .2s var(--mpe-ease);
	box-shadow: 0 1px 6px rgba(15,23,42,0.18);
}
@media (min-width: 640px) { .mpe-btn-donate { display: inline-flex; } }
.mpe-btn-donate:hover { background: var(--mpe-ink-700); }

/* Bouton Mon compte (connecté) */
.mpe-header-account {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	padding: .35rem .75rem .35rem .35rem;
	border-radius: 9999px;
	background: var(--mpe-surface);
	border: 1px solid var(--mpe-border);
	color: var(--mpe-ink);
	font-size: .8rem;
	font-weight: 600;
	text-decoration: none;
	transition: background .2s var(--mpe-ease), border-color .2s var(--mpe-ease);
}
.mpe-header-account:hover {
	background: var(--mpe-surface-alt, #e8f5ec);
	border-color: var(--mpe-primary);
	color: var(--mpe-primary);
}
.mpe-header-account__avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem; height: 2rem;
	border-radius: 9999px;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .02em;
	flex-shrink: 0;
}
.mpe-header-account__label {
	display: none;
}
@media (min-width: 768px) {
	.mpe-header-account__label { display: inline; }
}

/* Bouton Connexion (non connecté) */
.mpe-header-login {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .4rem .85rem;
	border-radius: 9999px;
	background: transparent;
	border: 1.5px solid var(--mpe-primary);
	color: var(--mpe-primary);
	font-size: .82rem;
	font-weight: 600;
	text-decoration: none;
	transition: background .2s var(--mpe-ease), color .2s var(--mpe-ease);
}
.mpe-header-login:hover {
	background: var(--mpe-primary);
	color: #fff;
}

/* Bouton menu mobile */
.mpe-menu-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem; height: 2.5rem;
	border-radius: 9999px;
	background: rgba(255,255,255,0.60);
	border: 1px solid rgba(15,23,42,0.06);
	cursor: pointer;
	color: var(--mpe-ink-900);
}
@media (min-width: 1024px) { .mpe-menu-toggle { display: none; } }

/* Menu mobile */
.mpe-mobile-menu {
	display: none;
	border-top: 1px solid rgba(255,255,255,0.30);
	background: rgba(255,255,255,0.72);
	-webkit-backdrop-filter: blur(24px);
	        backdrop-filter: blur(24px);
}
.mpe-mobile-menu.is-open { display: block; }
.mpe-mobile-nav { padding: 1rem; }
.mpe-mobile-nav__list {
	display: flex;
	flex-direction: column;
	gap: .25rem;
	font-weight: 500;
	color: var(--mpe-ink-700);
}
.mpe-mobile-nav__list li a {
	display: block;
	padding: .625rem .875rem;
	border-radius: var(--mpe-radius-sm);
	transition: background-color .2s var(--mpe-ease);
}
.mpe-mobile-nav__list li a:hover { background: rgba(15,23,42,0.05); }
.mpe-mobile-nav__list li.current-menu-item > a {
	background: rgba(31,155,66,.10);
	color: var(--mpe-primary);
	font-weight: 600;
}

/* Ligne item parent + bouton bascule */
.mpe-mobile-nav__list .menu-item-has-children {
	display: flex;
	flex-direction: column;
}
.mpe-mobile-nav__list .menu-item-has-children > a {
	flex: 1;
}

/* Bouton toggle sous-menu */
.mpe-submenu-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem; height: 2.25rem;
	border: none;
	background: rgba(0,0,0,.04);
	border-radius: var(--mpe-radius-sm);
	cursor: pointer;
	color: var(--mpe-text-muted);
	transition: background .15s, transform .25s;
	align-self: center;
	flex-shrink: 0;
	margin-left: auto;
}
.mpe-submenu-toggle:hover { background: rgba(0,0,0,.08); }
.is-sub-open > .mpe-submenu-toggle { transform: rotate(180deg); background: rgba(31,155,66,.10); color: var(--mpe-primary); }

/* Row parent link + toggle button */
.mpe-mobile-nav__list .menu-item-has-children {
	flex-direction: row;
	flex-wrap: wrap;
}
.mpe-mobile-nav__list .menu-item-has-children > a {
	flex: 1;
	min-width: 0;
}

/* Sous-menu mobile — masqué par défaut, expand sur is-sub-open */
.mpe-mobile-nav__list .sub-menu {
	display: none;
	width: 100%;
	padding-left: 1rem;
	margin-top: .25rem;
	border-left: 2px solid rgba(31,155,66,.20);
	list-style: none;
}
.mpe-mobile-nav__list .is-sub-open > .sub-menu { display: block; }

/* Compensateur hauteur header */
.mpe-header-spacer { height: 4rem; }

/* ==========================================================================
   7. Boutons génériques
   ========================================================================== */
.mpe-btn {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .75rem 1.5rem;
	border-radius: 9999px;
	font-weight: 500;
	font-size: .9375rem;
	transition: background-color .25s var(--mpe-ease),
	            transform .2s var(--mpe-ease),
	            box-shadow .25s var(--mpe-ease);
	cursor: pointer;
	border: none;
	text-decoration: none;
}
.mpe-btn--primary {
	background: var(--mpe-ink-900);
	color: #fff;
	box-shadow: 0 4px 20px rgba(15,23,42,0.2);
}
.mpe-btn--primary:hover {
	background: var(--mpe-ink-700);
	transform: translateY(-1px);
	box-shadow: 0 8px 28px rgba(15,23,42,0.25);
}
.mpe-btn--ghost {
	background: rgba(255,255,255,0.72);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,0.60);
	color: var(--mpe-ink-900);
}
.mpe-btn--ghost:hover { background: var(--mpe-surface); }
.mpe-btn--white { background: var(--mpe-surface); color: var(--mpe-ink-900); }
.mpe-btn--white:hover { background: var(--mpe-surface-muted); }
.mpe-btn--sm { padding: .5rem 1rem; font-size: .875rem; }
.mpe-btn--outline {
	background: var(--mpe-surface);
	border: 1px solid rgba(15,23,42,0.12);
	color: var(--mpe-ink-900);
}
.mpe-btn--outline:hover { background: var(--mpe-surface-muted); }

/* ==========================================================================
   8. Badges / Pastilles
   ========================================================================== */
.mpe-badge {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .25rem .75rem;
	border-radius: 9999px;
	font-size: .75rem;
	font-weight: 500;
}
.mpe-badge--glass {
	background: rgba(255,255,255,0.60);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,0.40);
	color: var(--mpe-ink-700);
}
.mpe-badge--dark {
	background: rgba(255,255,255,0.10);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,0.20);
	color: #fff;
}
.mpe-badge__dot {
	display: inline-block;
	width: .375rem; height: .375rem;
	border-radius: 9999px;
	background-color: currentColor;
}
.mpe-badge__dot--green { background-color: var(--mpe-emerald); }

/* ==========================================================================
   9. Sections — Structure générale
   ========================================================================== */
.mpe-section {
	position: relative;
	padding-block: 5rem;
}
@media (min-width: 768px) { .mpe-section { padding-block: 7rem; } }
.mpe-section--muted { background: rgba(241,245,249,0.60); }

.mpe-section-header { max-width: 42rem; margin-bottom: 3rem; }
.mpe-section-title {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 600;
	letter-spacing: -.025em;
	line-height: 1.15;
	color: var(--mpe-ink-900);
}
.mpe-section-desc {
	margin-top: 1rem;
	color: var(--mpe-ink-500);
	line-height: 1.7;
}

/* ==========================================================================
   10. HERO
   ========================================================================== */
.mpe-hero {
	position: relative;
	overflow: hidden;
}
.mpe-hero__bg {
	position: absolute;
	inset: 0;
	z-index: -1;
	pointer-events: none;
}
.mpe-hero__blob {
	position: absolute;
	border-radius: 9999px;
	filter: blur(80px);
}
.mpe-hero__blob--1 {
	top: -10rem; left: -10rem;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(96,165,250,.40), rgba(99,102,241,.20));
}
.mpe-hero__blob--2 {
	top: 5rem; right: -10rem;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(52,211,153,.30), rgba(34,211,238,.20));
}
.mpe-hero__blob--3 {
	bottom: 0; left: 33%;
	width: 300px; height: 300px;
	background: radial-gradient(circle, rgba(251,191,36,.30), rgba(251,113,133,.10));
}
.mpe-hero__inner {
	text-align: center;
	padding-top: 5rem;
	padding-bottom: 6rem;
}
@media (min-width: 768px) {
	.mpe-hero__inner { padding-top: 7rem; padding-bottom: 8rem; }
}
.mpe-hero__title {
	font-size: clamp(2.25rem, 6vw, 3.75rem);
	font-weight: 600;
	letter-spacing: -.03em;
	line-height: 1.05;
	color: var(--mpe-ink-900);
	max-width: 56rem;
	margin-inline: auto;
	margin-top: 1.5rem;
}
.mpe-hero__gradient-text {
	display: block;
	background: linear-gradient(90deg, var(--mpe-primary), var(--mpe-primary-dark));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.mpe-hero__desc {
	margin-top: 1.5rem;
	max-width: 42rem;
	margin-inline: auto;
	font-size: 1.125rem;
	color: var(--mpe-ink-500);
	line-height: 1.7;
}
.mpe-hero__cta {
	margin-top: 2.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .75rem;
}
@media (min-width: 640px) {
	.mpe-hero__cta { flex-direction: row; justify-content: center; }
}

/* ==========================================================================
   11. BENTO GRID
   ========================================================================== */
.mpe-bento-section { position: relative; }

.mpe-bento-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	grid-auto-rows: 220px;
}
@media (min-width: 768px) {
	.mpe-bento-grid {
		grid-template-columns: repeat(4, 1fr);
		gap: 1.5rem;
		grid-auto-rows: 200px;
	}
}

/* Classes injectées par mpe_bento_item_classes() */
.mpe-bento-item {
	position: relative;
	overflow: hidden;
	border-radius: var(--mpe-radius-lg);
	border: 1px solid rgba(255,255,255,0.10);
	background: rgba(255,255,255,0.05);
	-webkit-backdrop-filter: blur(20px);
	        backdrop-filter: blur(20px);
	box-shadow: 0 10px 40px -10px rgba(15,23,42,0.25);
	transition: transform .5s var(--mpe-ease), box-shadow .5s var(--mpe-ease);
	animation: mpeBentoIn .8s var(--mpe-ease) both;
	animation-delay: calc(var(--mpe-index, 0) * 80ms);
}
.mpe-bento-item:hover {
	transform: scale(1.01);
	box-shadow: 0 20px 60px -10px rgba(15,23,42,0.35);
}
/* Les classes md:col-span-2 et md:row-span-2 viennent du PHP
   mais on ne peut pas les convertir en media query depuis PHP.
   On fournit les équivalents avec un préfixe natif. */
@media (min-width: 768px) {
	.mpe-bento-item.col-span-2  { grid-column: span 2; }
	.mpe-bento-item.row-span-2  { grid-row: span 2; }
}

.mpe-bento-item__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.mpe-bento-item__bg img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .7s var(--mpe-ease);
}
.mpe-bento-item:hover .mpe-bento-item__bg img { transform: scale(1.08); }
.mpe-bento-item__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(2,6,23,.85) 0%, rgba(2,6,23,.40) 50%, transparent 100%);
}
.mpe-bento-item__link {
	position: absolute;
	inset: 0;
	z-index: 2;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 1.5rem;
	color: #fff;
}
@media (min-width: 768px) { .mpe-bento-item__link { padding: 2rem; } }

.mpe-bento-item__featured-badge {
	align-self: flex-start;
	margin-bottom: auto;
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	padding: .25rem .625rem;
	border-radius: 9999px;
	background: rgba(255,255,255,0.15);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,0.25);
	font-size: .6875rem;
	font-weight: 500;
}
.mpe-bento-item__featured-dot {
	display: inline-block;
	width: .375rem; height: .375rem;
	border-radius: 9999px;
}
.mpe-bento-item__title {
	font-weight: 600;
	letter-spacing: -.02em;
	line-height: 1.2;
	margin-top: 1rem;
}
.mpe-bento-item--featured .mpe-bento-item__title {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
}
.mpe-bento-item__tagline {
	margin-top: .5rem;
	font-size: .875rem;
	color: rgba(255,255,255,0.80);
	max-width: 28rem;

	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.mpe-bento-item__cta {
	margin-top: 1rem;
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	font-size: .875rem;
	font-weight: 500;
	opacity: 0;
	transition: opacity .3s var(--mpe-ease);
}
.mpe-bento-item:hover .mpe-bento-item__cta { opacity: 1; }

/* Fallback vide bento */
.mpe-bento-empty {
	border-radius: var(--mpe-radius-lg);
	border: 2px dashed var(--mpe-ink-300);
	background: rgba(255,255,255,0.50);
	padding: 2.5rem;
	text-align: center;
	color: var(--mpe-ink-500);
}

/* Lien "Voir tous les programmes" */
.mpe-bento-more {
	margin-top: 2.5rem;
	text-align: center;
}

/* ==========================================================================
   12. GLASS card (réutilisable)
   ========================================================================== */
.mpe-glass {
	background: var(--mpe-glass-bg);
	-webkit-backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	        backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	border: 1px solid var(--mpe-glass-border);
	box-shadow: var(--mpe-shadow-soft);
	border-radius: var(--mpe-radius-lg);
}

/* ==========================================================================
   13. LEADERSHIP
   ========================================================================== */
.mpe-leadership-group + .mpe-leadership-group { margin-top: 4rem; }
.mpe-leadership-group__title {
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
	font-weight: 600;
	letter-spacing: -.02em;
	color: var(--mpe-ink-900);
	margin-bottom: 2rem;
}

.mpe-leadership-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}
@media (min-width: 768px)  { .mpe-leadership-grid { grid-template-columns: repeat(3, 1fr); gap: 1.5rem; } }
@media (min-width: 1024px) { .mpe-leadership-grid { grid-template-columns: repeat(4, 1fr); } }

.mpe-leader-card {
	position: relative;
	overflow: hidden;
	border-radius: var(--mpe-radius-lg);
	background: var(--mpe-glass-bg);
	-webkit-backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	        backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	border: 1px solid var(--mpe-glass-border);
	box-shadow: var(--mpe-shadow-soft);
	transition: transform .5s var(--mpe-ease), box-shadow .5s var(--mpe-ease);
}
.mpe-leader-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--mpe-shadow-hover);
}
.mpe-leader-card__photo {
	aspect-ratio: 1 / 1;
	overflow: hidden;
}
.mpe-leader-card__photo img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .7s var(--mpe-ease);
}
.mpe-leader-card:hover .mpe-leader-card__photo img { transform: scale(1.05); }
.mpe-leader-card__info { padding: 1.25rem; }
.mpe-leader-card__name {
	font-size: clamp(.9rem, 2vw, 1.125rem);
	font-weight: 600;
	color: var(--mpe-ink-900);
	line-height: 1.3;
}
.mpe-leader-card__position {
	margin-top: .25rem;
	font-size: .8125rem;
	color: var(--mpe-ink-500);
	line-height: 1.4;
}
.mpe-leader-card__link {
	position: absolute;
	inset: 0;
	border-radius: var(--mpe-radius-lg);
}
.mpe-leader-card__link:focus-visible {
	outline: 2px solid var(--mpe-blue);
	outline-offset: 2px;
}

/* ==========================================================================
   14. BIBLIYOTEK CTA
   ========================================================================== */
.mpe-bibliyotek__card {
	position: relative;
	overflow: hidden;
	border-radius: var(--mpe-radius-xl);
	padding: 2.5rem;
	background: linear-gradient(135deg, #0f172a 0%, #1e1b4b 50%, #0f172a 100%);
	color: #fff;
}
@media (min-width: 768px) { .mpe-bibliyotek__card { padding: 4rem; } }
.mpe-bibliyotek__deco {
	position: absolute;
	border-radius: 9999px;
	filter: blur(80px);
	pointer-events: none;
}
.mpe-bibliyotek__deco--1 {
	top: -5rem; right: -5rem;
	width: 400px; height: 400px;
	background: rgba(59,130,246,0.30);
}
.mpe-bibliyotek__deco--2 {
	bottom: -5rem; left: -5rem;
	width: 400px; height: 400px;
	background: rgba(139,92,246,0.20);
}
.mpe-bibliyotek__grid {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 2.5rem;
	align-items: center;
}
@media (min-width: 768px) {
	.mpe-bibliyotek__grid { grid-template-columns: 1fr 1fr; }
}
.mpe-bibliyotek__books {
	position: relative;
	aspect-ratio: 4 / 5;
}
.mpe-bibliyotek__book {
	position: absolute;
	inset: 0;
	border-radius: var(--mpe-radius-md);
	-webkit-backdrop-filter: blur(24px);
	        backdrop-filter: blur(24px);
}
.mpe-bibliyotek__book--back {
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.10);
	transform: rotate(3deg);
	transition: transform .7s var(--mpe-ease);
}
.mpe-bibliyotek__book--front {
	background: rgba(255,255,255,0.10);
	border: 1px solid rgba(255,255,255,0.20);
	transform: rotate(-3deg);
	transition: transform .7s var(--mpe-ease);
}
.mpe-bibliyotek__card:hover .mpe-bibliyotek__book--back  { transform: rotate(1deg); }
.mpe-bibliyotek__card:hover .mpe-bibliyotek__book--front { transform: rotate(-1deg); }

/* ==========================================================================
   15. FOOTER
   ========================================================================== */
.mpe-footer {
	margin-top: 6rem;
	background: var(--mpe-bg-footer);
	color: rgba(203,213,225,0.90);
}
.mpe-footer__inner {
	padding-block: 3.5rem;
}
.mpe-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}
@media (min-width: 768px) {
	.mpe-footer__grid { grid-template-columns: 2fr 1fr 1fr; }
}
@media (min-width: 1024px) {
	.mpe-footer__grid { grid-template-columns: 2fr 1fr 1fr; gap: 3rem; }
}
.mpe-footer__logo-img a {
	display: inline-block;
	line-height: 0;
}
.mpe-footer__logo-img img {
	max-height: 52px;
	width: auto;
	display: block;
	filter: brightness(0) invert(1); /* logo blanc sur fond sombre */
}
.mpe-footer__logo {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem; height: 2.5rem;
	border-radius: var(--mpe-radius-sm);
	background: var(--mpe-surface);
	color: var(--mpe-ink-900);
	font-weight: 700;
	font-size: .9rem;
	flex-shrink: 0;
}
.mpe-footer__identity-header {
	display: flex;
	align-items: center;
	gap: .75rem;
	margin-bottom: 1rem;
}
.mpe-footer__site-name { font-size: 1.125rem; font-weight: 600; color: #fff; }
.mpe-footer__desc { font-size: .875rem; line-height: 1.7; color: rgba(148,163,184,.90); max-width: 28rem; }
.mpe-footer__socials { display: flex; align-items: center; gap: .75rem; margin-top: 1.5rem; }
.mpe-footer__social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem; height: 2.25rem;
	border-radius: 9999px;
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.10);
	color: rgba(203,213,225,.80);
	transition: background-color .2s var(--mpe-ease), color .2s;
}
.mpe-footer__social-link:hover { background: rgba(255,255,255,0.10); color: #fff; }
.mpe-footer__col-title { font-weight: 600; color: #fff; margin-bottom: 1rem; }
.mpe-footer__nav {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	font-size: .875rem;
	color: rgba(148,163,184,.90);
}
.mpe-footer__nav a { transition: color .2s; }
.mpe-footer__nav a:hover { color: #fff; }
.mpe-footer__contact-list {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	font-size: .875rem;
	color: rgba(148,163,184,.90);
}
.mpe-footer__contact-list a { transition: color .2s; }
.mpe-footer__contact-list a:hover { color: #fff; }
.mpe-footer__bottom {
	margin-top: 3rem;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(255,255,255,0.10);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	font-size: .75rem;
	color: rgba(100,116,139,.90);
}
@media (min-width: 1024px) {
	.mpe-footer-col--newsletter {
		flex: 1.5;
	}
}

/* ==========================================================================
   TEAM SLIDER (LEADERSHIP)
   ========================================================================== */
.mpe-leadership-swiper {
	position: relative;
	overflow: hidden;
	padding-block: 1rem;
	border-radius: var(--mpe-radius-lg);
}

.mpe-about-leadership {
	background: #fff;
}

.mpe-leader-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	background: #fff;
	border: 1.5px solid #e5e7eb;
	border-radius: var(--mpe-radius-lg);
	padding: 1.25rem 1rem;
	height: 100%;
	position: relative;
	transition: border-color .2s, box-shadow .2s, transform .2s;
}
.mpe-leader-card:hover {
	border-color: var(--mpe-primary);
	box-shadow: 0 6px 20px rgba(31,155,66,0.12);
	transform: translateY(-3px);
}

.mpe-leader-card__photo {
	width: 80px; height: 80px;
	border-radius: 50%;
	border: 2px solid var(--mpe-primary);
	overflow: hidden;
	margin-bottom: .875rem;
	background: #f3f4f6;
	flex-shrink: 0;
}
.mpe-leader-card__photo img {
	width: 100%; height: 100%;
	object-fit: cover;
}

.mpe-leader-card__name {
	font-size: .9375rem;
	font-weight: 700;
	color: var(--mpe-ink-900);
	margin-bottom: .2rem;
	line-height: 1.3;
}
.mpe-leader-card__position {
	font-size: .78rem;
	color: var(--mpe-primary-dark);
	font-weight: 600;
	margin-bottom: .4rem;
	text-transform: uppercase;
	letter-spacing: .03em;
}
.mpe-leader-card__desc {
	font-size: .78rem;
	color: #6b7280;
	line-height: 1.45;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.mpe-leader-card__link {
	position: absolute;
	inset: 0;
	z-index: 2;
}

/* Fades blancs gauche / droite */
.mpe-slide-fade {
	position: absolute;
	top: 0; bottom: 0;
	width: 120px;
	z-index: 10;
	pointer-events: none;
}
.mpe-slide-fade--left {
	left: 0;
	background: linear-gradient(to right, #ffffff 0%, rgba(255,255,255,0) 100%);
}
.mpe-slide-fade--right {
	right: 0;
	background: linear-gradient(to left, #ffffff 0%, rgba(255,255,255,0) 100%);
}
.mpe-footer__credit {
	font-size: .7rem;
	color: rgba(100,116,139,.6);
}
.mpe-footer__credit a {
	color: rgba(148,163,184,.7);
	text-decoration: none;
	transition: color .2s;
}
.mpe-footer__credit a:hover {
	color: #fff;
}
@media (min-width: 768px) {
	.mpe-footer__bottom { flex-direction: row; justify-content: space-between; flex-wrap: wrap; }
}

/* ==========================================================================
   16. Single programme — design éditorial premium
   ========================================================================== */

/* ── 1. EN-TÊTE programme ────────────── */
.mpe-sp-header {
	background: #fff;
	padding-bottom: 3rem;
}
.mpe-sp-header__topbar {
	height: 4px;
	width: 100%;
	margin-bottom: 2rem;
}

/* Breadcrumb */
.mpe-sp-header__bc {
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	gap: .35rem;
	font-size: .75rem;
	color: var(--mpe-ink-500);
	margin-bottom: 2.5rem;
}
.mpe-sp-header__bc a { color: inherit; transition: color .18s; }
.mpe-sp-header__bc a:hover { color: var(--mpe-ink-900); }
.mpe-sp-header__bc svg { flex-shrink: 0; opacity: .5; }
.mpe-sp-header__bc span { color: var(--mpe-ink-900); font-weight: 500; }

/* Layout header : gauche texte / droite image */
.mpe-sp-header__layout {
	display: grid;
	gap: 2.5rem;
	align-items: center;
}
@media (min-width: 768px) {
	.mpe-sp-header__layout {
		grid-template-columns: 1fr 1fr;
		gap: 4rem;
	}
}
@media (min-width: 1024px) {
	.mpe-sp-header__layout {
		grid-template-columns: 1fr 480px;
		gap: 5rem;
	}
}

/* Tag "Programme actif" */
.mpe-sp-header__tag {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .35rem .875rem .35rem .6rem;
	border-radius: 9999px;
	border: 1.5px solid;
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin-bottom: 1.25rem;
}
.mpe-sp-header__dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	flex-shrink: 0;
	animation: mpe-sp-dot 2.2s ease-in-out infinite;
}
@keyframes mpe-sp-dot {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%       { opacity: .5; transform: scale(.75); }
}

/* Titre */
.mpe-sp-header__title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 800;
	letter-spacing: -.04em;
	line-height: 1.0;
	color: var(--mpe-ink-900);
	margin: 0 0 1.25rem;
}

/* Tagline */
.mpe-sp-header__tagline {
	font-size: clamp(.9375rem, 1.8vw, 1.125rem);
	color: var(--mpe-ink-500);
	line-height: 1.7;
	margin: 0 0 2rem;
	max-width: 48rem;
}

/* Pills méta */
.mpe-sp-header__meta { display: flex; flex-wrap: wrap; gap: .625rem; }
.mpe-sp-header__pill {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .45rem 1rem;
	border-radius: 9999px;
	background: var(--mpe-surface-muted);
	font-size: .8125rem;
	color: var(--mpe-ink-700);
	font-weight: 500;
}

/* Image à la une */
.mpe-sp-header__thumb {
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 3;
	box-shadow: 0 8px 40px rgba(0,0,0,.12);
}
.mpe-sp-header__thumb img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}

/* ── 2. (section hero supprimée) ─ */
.mpe-sp-card {
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0,0,0,.06), 0 12px 40px rgba(0,0,0,.08);
	background: #fff;
	border: 1px solid rgba(0,0,0,.06);
}
.mpe-sp-card__stripe {
	height: 5px;
	width: 100%;
}
.mpe-sp-card__body { padding: 1.5rem 1.5rem 1.25rem; }
.mpe-sp-card__row {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	padding: 1rem 0;
	border-bottom: 1px solid var(--mpe-surface-muted);
}
.mpe-sp-card__row:first-child { padding-top: 0; }
.mpe-sp-card__row:last-child  { border-bottom: none; padding-bottom: 0; }
.mpe-sp-card__icon { flex-shrink: 0; margin-top: 2px; }
.mpe-sp-card__lbl {
	font-size: .68rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--mpe-ink-500);
	margin: 0 0 .2rem;
}
.mpe-sp-card__val {
	font-size: .9375rem;
	font-weight: 700;
	color: var(--mpe-ink-900);
	margin: 0;
}
.mpe-sp-card__foot {
	padding: 1.25rem 1.5rem 1.5rem;
	border-top: 1px solid var(--mpe-surface-muted);
	display: flex;
	flex-direction: column;
	gap: .75rem;
}
.mpe-sp-card__donate {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	width: 100%;
	padding: .9rem 1.25rem;
	border-radius: var(--mpe-radius-md);
	color: #fff;
	font-size: .9375rem;
	font-weight: 700;
	transition: filter .2s, transform .15s;
	text-align: center;
}
.mpe-sp-card__donate:hover { filter: brightness(1.1); transform: translateY(-1px); }
.mpe-sp-card__back {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .375rem;
	font-size: .8125rem;
	font-weight: 500;
	color: var(--mpe-ink-500);
	transition: color .2s;
}
.mpe-sp-card__back:hover { color: var(--mpe-ink-900); }

/* ── 3. IMPACT (bande stats) ─────────── */
.mpe-sp-impact {
	position: relative;
	overflow: hidden;
	padding-block: 3.5rem;
	color: #fff;
}
.mpe-sp-impact__bg {
	position: absolute;
	inset: 0;
	opacity: .95;
}
.mpe-sp-impact__inner {
	position: relative;
	z-index: 1;
}
.mpe-sp-impact__eyebrow {
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	opacity: .7;
	margin-bottom: 2.5rem;
	text-align: center;
}
.mpe-sp-impact__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
}
@media (min-width: 640px) {
	.mpe-sp-impact__grid { grid-template-columns: repeat(var(--cols, 4), 1fr); }
}
.mpe-sp-impact__item {
	padding: 1rem 1.5rem;
	text-align: center;
	border-right: 1px solid rgba(255,255,255,.15);
}
.mpe-sp-impact__item:last-child { border-right: none; }
@media (max-width: 639px) {
	.mpe-sp-impact__item:nth-child(2n) { border-right: none; }
	.mpe-sp-impact__item:nth-child(-n+2) { border-bottom: 1px solid rgba(255,255,255,.15); }
}
.mpe-sp-impact__num {
	display: block;
	font-size: clamp(2.5rem, 5vw, 3.5rem);
	font-weight: 800;
	letter-spacing: -.05em;
	line-height: 1;
	color: #fff;
}
.mpe-sp-impact__lbl {
	display: block;
	margin-top: .5rem;
	font-size: .7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .09em;
	opacity: .75;
}

/* ── 3. CORPS : contenu + sidebar ───── */
.mpe-sp-body {
	background: var(--mpe-bg-body);
	padding-block: 5rem;
}
@media (min-width: 1024px) { .mpe-sp-body { padding-block: 6rem 5rem; } }
.mpe-sp-body__layout {
	display: grid;
	gap: 3rem;
	align-items: start;
}
@media (min-width: 1024px) {
	.mpe-sp-body__layout {
		grid-template-columns: 1fr 300px;
		gap: 4.5rem;
	}
}
@media (min-width: 1280px) {
	.mpe-sp-body__layout { grid-template-columns: 1fr 320px; }
}
.mpe-sp-body__aside { position: relative; }
@media (min-width: 1024px) {
	.mpe-sp-body__aside { position: sticky; top: 5.5rem; }
}

/* ── 4. Prose ───────────────────────── */

/* Prose enrichie */
.mpe-prose { line-height: 1.85; color: var(--mpe-ink-700); font-size: 1.0625rem; }
.mpe-prose h2 {
	font-size: clamp(1.375rem, 3vw, 1.75rem);
	font-weight: 800;
	letter-spacing: -.03em;
	color: var(--mpe-ink-900);
	margin: 2.5em 0 .75em;
	padding-bottom: .5em;
	border-bottom: 2px solid var(--mpe-surface-muted);
}
.mpe-prose h3 {
	font-size: 1.1875rem;
	font-weight: 700;
	letter-spacing: -.02em;
	color: var(--mpe-ink-900);
	margin: 2em 0 .6em;
}
.mpe-prose h4 { font-size: 1rem; font-weight: 700; color: var(--mpe-ink-900); margin: 1.75em 0 .5em; }
.mpe-prose p { margin-bottom: 1.4em; }
.mpe-prose a { color: var(--mpe-primary); font-weight: 500; }
.mpe-prose a:hover { text-decoration: underline; }
.mpe-prose img { border-radius: var(--mpe-radius-md); margin-block: 2em; max-width: 100%; display: block; }
.mpe-prose ul, .mpe-prose ol { padding-left: 1.5em; margin-bottom: 1.4em; }
.mpe-prose ul { list-style: disc; }
.mpe-prose ol { list-style: decimal; }
.mpe-prose li { margin-bottom: .55em; }
.mpe-prose strong { font-weight: 700; color: var(--mpe-ink-900); }
.mpe-prose blockquote {
	position: relative;
	margin: 2.5em 0;
	padding: 1.5em 1.75em;
	background: linear-gradient(135deg, rgba(31,155,66,.05) 0%, rgba(31,155,66,.02) 100%);
	border-left: 4px solid var(--mpe-primary);
	border-radius: 0 var(--mpe-radius-md) var(--mpe-radius-md) 0;
	font-size: 1.0625rem;
	font-style: italic;
	color: var(--mpe-ink-700);
}
.mpe-sp-prose .mpe-prose p:first-child::first-letter {
	float: left;
	font-size: 3.5em;
	line-height: .8;
	padding-right: .12em;
	padding-top: .08em;
	font-weight: 800;
	color: var(--mpe-primary);
}

/* ── 5. GALERIE ──────────────────────── */
.mpe-sp-gallery {
	background: #fff;
	padding-block: 4rem 5rem;
}

/* Section heading */
.mpe-sp-sh {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 2.5rem;
}
.mpe-sp-sh__bar {
	display: block;
	width: 4px;
	height: 2rem;
	border-radius: 9999px;
	flex-shrink: 0;
}
.mpe-sp-sh__title {
	font-size: clamp(1.25rem, 3vw, 1.75rem);
	font-weight: 800;
	letter-spacing: -.03em;
	color: var(--mpe-ink-900);
	margin: 0;
}

/* Mosaïque photos */
.mpe-sp-gallery__mosaic {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: .625rem;
}
@media (min-width: 640px)  { .mpe-sp-gallery__mosaic { grid-template-columns: repeat(3, 1fr); gap: .875rem; } }
@media (min-width: 1024px) { .mpe-sp-gallery__mosaic { grid-template-columns: repeat(4, 1fr); gap: 1rem; } }
.mpe-sp-gallery__item {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--mpe-radius-md);
	background: var(--mpe-surface-muted);
}
.mpe-sp-gallery__item--wide {
	grid-column: span 2;
	aspect-ratio: 16 / 9;
}
.mpe-sp-gallery__item img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .55s var(--mpe-ease);
}
.mpe-sp-gallery__item:hover img { transform: scale(1.07); }
.mpe-sp-gallery__overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,.40);
	color: #fff;
	opacity: 0;
	transition: opacity .25s;
	border-radius: var(--mpe-radius-md);
}
.mpe-sp-gallery__item:hover .mpe-sp-gallery__overlay { opacity: 1; }

/* ── 6. CTA ──────────────────────────── */
.mpe-sp-cta {
	position: relative;
	overflow: hidden;
	background: #0d1f12;
	padding-block: 6rem;
	color: #fff;
}
.mpe-sp-cta__pattern {
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 20% 50%, rgba(31,155,66,.35) 0%, transparent 50%),
		radial-gradient(circle at 80% 20%, rgba(31,155,66,.20) 0%, transparent 45%),
		radial-gradient(circle at 60% 80%, rgba(31,155,66,.15) 0%, transparent 40%);
}
.mpe-sp-cta__inner {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 3rem;
	align-items: center;
}
@media (min-width: 768px) {
	.mpe-sp-cta__inner {
		grid-template-columns: 1fr auto;
		gap: 4rem;
	}
}
.mpe-sp-cta__eyebrow {
	display: inline-block;
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: #4ade80;
	margin-bottom: .875rem;
}
.mpe-sp-cta__title {
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: 800;
	letter-spacing: -.04em;
	line-height: 1.1;
	margin: 0 0 1rem;
}
.mpe-sp-cta__desc {
	font-size: 1.0625rem;
	color: rgba(255,255,255,.65);
	line-height: 1.7;
	max-width: 40rem;
	margin: 0;
}
.mpe-sp-cta__right {
	display: flex;
	flex-direction: column;
	gap: .875rem;
	flex-shrink: 0;
}
@media (min-width: 640px) {
	.mpe-sp-cta__right { flex-direction: row; align-items: center; }
}
@media (min-width: 768px) {
	.mpe-sp-cta__right { flex-direction: column; min-width: 220px; }
}
.mpe-sp-cta__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	padding: .9rem 1.75rem;
	border-radius: var(--mpe-radius-md);
	font-size: .9375rem;
	font-weight: 700;
	white-space: nowrap;
	transition: filter .2s, transform .15s;
}
.mpe-sp-cta__btn:hover { filter: brightness(1.1); transform: translateY(-1px); }
.mpe-sp-cta__btn--white {
	background: #fff;
	color: #0d1f12;
}
.mpe-sp-cta__btn--outline {
	background: transparent;
	color: rgba(255,255,255,.85);
	border: 1.5px solid rgba(255,255,255,.25);
}
.mpe-sp-cta__btn--outline:hover {
	border-color: rgba(255,255,255,.6);
	color: #fff;
	filter: none;
}

/* ── Classes legacy (compatibilité autres templates) ── */
.mpe-gallery-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: .75rem;
}
@media (min-width: 768px)  { .mpe-gallery-grid { grid-template-columns: repeat(3, 1fr); gap: 1rem; } }
@media (min-width: 1024px) { .mpe-gallery-grid { grid-template-columns: repeat(4, 1fr); } }
.mpe-gallery-item {
	position: relative; display: block;
	aspect-ratio: 1; overflow: hidden;
	border-radius: var(--mpe-radius-md);
	background: var(--mpe-surface-muted);
}
.mpe-gallery-item img { width:100%; height:100%; object-fit:cover; transition: transform .7s var(--mpe-ease); }
.mpe-gallery-item:hover img { transform: scale(1.1); }
.mpe-cta-donation { border-radius: var(--mpe-radius-lg); background: var(--mpe-ink-900); color:#fff; padding:2.5rem; text-align:center; }
@media (min-width: 768px) { .mpe-cta-donation { padding: 3rem; } }
.mpe-cta-donation__title { font-size: clamp(1.375rem,3vw,1.875rem); font-weight:600; letter-spacing:-.02em; }
.mpe-cta-donation__desc { margin-top:.75rem; color:rgba(255,255,255,.70); max-width:36rem; margin-inline:auto; line-height:1.65; }
.mpe-cta-donation__btn { margin-top: 1.5rem; }

/* ==========================================================================
   17. Archive programmes — cartes modernes
   ========================================================================== */

/* ── En-tête ── */
.mpe-ap-header {
	position: relative;
	overflow: hidden;
	background: #fff;
	border-bottom: 1px solid var(--mpe-surface-muted);
	padding-block: 4rem 4.5rem;
}
@media (min-width: 768px) { .mpe-ap-header { padding-block: 5.5rem 6rem; } }

/* Déco blob */
.mpe-ap-header__deco { position: absolute; inset: 0; pointer-events: none; }
.mpe-ap-header__blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(90px);
}
.mpe-ap-header__blob--1 {
	width: 520px; height: 520px;
	background: rgba(31,155,66,.10);
	top: -160px; right: -100px;
}
.mpe-ap-header__blob--2 {
	width: 320px; height: 320px;
	background: rgba(31,155,66,.06);
	bottom: -100px; left: 40%;
}

/* Layout header */
.mpe-ap-header__inner {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 3rem;
	align-items: center;
}
@media (min-width: 1024px) {
	.mpe-ap-header__inner {
		grid-template-columns: 1fr auto;
		gap: 4rem;
	}
}

/* Badge */
.mpe-ap-header__badge {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .4rem 1rem .4rem .65rem;
	border-radius: 9999px;
	background: rgba(31,155,66,.08);
	border: 1px solid rgba(31,155,66,.20);
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--mpe-primary-dark);
	margin-bottom: 1.5rem;
}
.mpe-ap-header__badge-dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	background: var(--mpe-primary);
	flex-shrink: 0;
	animation: mpe-sp-dot 2.2s ease-in-out infinite;
}

/* Titre */
.mpe-ap-header__title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 800;
	letter-spacing: -.04em;
	line-height: 1.05;
	color: var(--mpe-ink-900);
	margin: 0 0 1.25rem;
}
.mpe-ap-header__title em {
	font-style: normal;
	color: var(--mpe-primary);
}

/* Description */
.mpe-ap-header__desc {
	font-size: clamp(.9375rem, 1.8vw, 1.0625rem);
	color: var(--mpe-ink-500);
	line-height: 1.75;
	max-width: 52rem;
	margin: 0 0 2.5rem;
}

/* Stats ligne */
.mpe-ap-header__stats {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex-wrap: wrap;
}
.mpe-ap-header__stat { display: flex; flex-direction: column; gap: .15rem; }
.mpe-ap-header__stat-num {
	font-size: 1.5rem;
	font-weight: 800;
	letter-spacing: -.03em;
	color: var(--mpe-ink-900);
}
.mpe-ap-header__stat-lbl {
	font-size: .7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--mpe-ink-500);
}
.mpe-ap-header__stat-sep {
	width: 1px;
	height: 2.5rem;
	background: var(--mpe-surface-muted);
	flex-shrink: 0;
}

/* Visuel décoratif */
.mpe-ap-header__visual {
	display: none;
	position: relative;
	width: 180px; height: 180px;
	flex-shrink: 0;
}
@media (min-width: 1024px) { .mpe-ap-header__visual { display: block; } }
.mpe-ap-header__ring {
	position: absolute;
	inset: 0;
	border-radius: 50%;
}
.mpe-ap-header__ring--1 {
	background: rgba(31,155,66,.08);
	border: 2px solid rgba(31,155,66,.15);
}
.mpe-ap-header__ring--2 {
	inset: 24px;
	background: rgba(31,155,66,.12);
	border: 2px solid rgba(31,155,66,.20);
}
.mpe-ap-header__icon-wrap {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--mpe-primary);
}

/* ── Grille ── */
.mpe-ap-grid-section {
	background: var(--mpe-bg-body);
	padding-block: 4rem 5rem;
}
@media (min-width: 768px) { .mpe-ap-grid-section { padding-block: 5rem 6rem; } }

.mpe-ap-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.75rem;
}
@media (min-width: 640px)  { .mpe-ap-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mpe-ap-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; } }

/* ── Carte ── */
.mpe-ap-card {
	background: #fff;
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.06);
	border: 1px solid rgba(0,0,0,.05);
	transition: transform .25s var(--mpe-ease), box-shadow .25s var(--mpe-ease);
	/* Barre colorée en haut via pseudo-élément */
	position: relative;
}
.mpe-ap-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 4px;
	background: var(--card-accent, #1F9B42);
	z-index: 1;
}
.mpe-ap-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 4px 8px rgba(0,0,0,.06), 0 16px 48px rgba(0,0,0,.12);
}

/* Image */
.mpe-ap-card__img-wrap {
	position: relative;
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--mpe-surface-muted);
}
.mpe-ap-card__img-wrap img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .55s var(--mpe-ease);
}
.mpe-ap-card:hover .mpe-ap-card__img-wrap img { transform: scale(1.05); }
.mpe-ap-card__img-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,.18) 0%, transparent 50%);
	transition: opacity .3s;
}
.mpe-ap-card:hover .mpe-ap-card__img-overlay { opacity: .5; }
.mpe-ap-card__img-ph {
	width: 100%; height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Corps */
.mpe-ap-card__body {
	flex: 1;
	padding: 1.5rem 1.5rem 1rem;
	display: flex;
	flex-direction: column;
	gap: .75rem;
}

/* Tag */
.mpe-ap-card__tag {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .09em;
	text-transform: uppercase;
	color: var(--mpe-ink-500);
}
.mpe-ap-card__tag-dot {
	width: 6px; height: 6px;
	border-radius: 50%;
	flex-shrink: 0;
}

/* Titre */
.mpe-ap-card__title {
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: -.02em;
	line-height: 1.3;
	color: var(--mpe-ink-900);
	margin: 0;
}
.mpe-ap-card__title a { color: inherit; }
.mpe-ap-card__title a:hover { color: var(--card-accent, #1F9B42); }

/* Tagline */
.mpe-ap-card__tagline {
	font-size: .875rem;
	color: var(--mpe-ink-500);
	line-height: 1.6;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	line-clamp: 3;
	overflow: hidden;
}

/* Méta */
.mpe-ap-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	margin-top: auto;
	padding-top: .5rem;
}
.mpe-ap-card__meta-item {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	font-size: .75rem;
	color: var(--mpe-ink-500);
	font-weight: 500;
}

/* Pied */
.mpe-ap-card__foot {
	padding: 1rem 1.5rem 1.25rem;
	border-top: 1px solid var(--mpe-surface-muted);
}
.mpe-ap-card__cta {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	font-size: .875rem;
	font-weight: 700;
	transition: gap .2s;
}
.mpe-ap-card__cta:hover { gap: .6rem; }

/* Pagination WordPress */
.mpe-pagination { margin-top: 3rem; }
.mpe-pagination .nav-links {
	display: flex;
	align-items: center;
	gap: .5rem;
	flex-wrap: wrap;
}
.mpe-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem; height: 2.5rem;
	padding-inline: .75rem;
	border-radius: 9999px;
	background: var(--mpe-surface);
	border: 1px solid rgba(15,23,42,0.10);
	color: var(--mpe-ink-700);
	font-size: .875rem;
	font-weight: 500;
	transition: background-color .2s;
}
.mpe-pagination .page-numbers:hover { background: var(--mpe-surface-muted); }
.mpe-pagination .page-numbers.current {
	background: var(--mpe-ink-900);
	color: #fff;
	border-color: var(--mpe-ink-900);
}

/* ==========================================================================
   18. Bouton liseuse WooCommerce
   ========================================================================== */
.mpe-reader-btn {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .75rem 1.25rem;
	border-radius: 9999px;
	background: rgba(255,255,255,0.1);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,0.2);
	color: var(--mpe-ink-900);
	font-weight: 500;
	transition: background-color .3s var(--mpe-ease), transform .2s var(--mpe-ease);
}
.mpe-reader-btn:hover {
	background: rgba(255,255,255,0.2);
	transform: translateY(-1px);
}

/* ==========================================================================
   19. Overrides WooCommerce
   ========================================================================== */
.woocommerce ul.products li.product a img { border-radius: var(--mpe-radius-md); }
.woocommerce span.onsale {
	background: var(--mpe-ink-900) !important;
	color: #fff !important;
	border-radius: 9999px !important;
	padding: .25rem .75rem !important;
	font-size: .7rem !important;
	font-weight: 600 !important;
	min-height: auto !important;
	min-width: auto !important;
	line-height: 1.4 !important;
}
.woocommerce button.button, .woocommerce a.button,
.woocommerce input.button, .woocommerce #respond input#submit {
	background: var(--mpe-ink-900) !important;
	color: #fff !important;
	border-radius: 9999px !important;
	padding: .75rem 1.5rem !important;
	font-weight: 500 !important;
	transition: background-color .2s var(--mpe-ease) !important;
}
.woocommerce button.button:hover, .woocommerce a.button:hover {
	background: var(--mpe-ink-700) !important;
}
.woocommerce button.button.alt, .woocommerce a.button.alt,
.woocommerce #respond input#submit.alt, .woocommerce input.button.alt {
	background: var(--mpe-blue) !important;
}
.woocommerce button.button.alt:hover, .woocommerce a.button.alt:hover {
	background: #0066CC !important;
}
.woocommerce .price { color: var(--mpe-ink-900) !important; font-weight: 600 !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs { padding: 0 !important; border-bottom: 1px solid rgba(15,23,42,0.08) !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
	padding: 0 !important;
	margin-right: 1rem !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a { padding: 1rem 0 !important; color: var(--mpe-ink-500) !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--mpe-ink-900) !important; border-bottom: 2px solid var(--mpe-ink-900) !important; }

/* ==========================================================================
   20. Animations
   ========================================================================== */
@keyframes mpeBentoIn {
	from { opacity: 0; transform: translateY(20px) scale(0.98); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}
@media (prefers-reduced-motion: reduce) {
	.mpe-bento-item { animation: none; }
	html { scroll-behavior: auto; }
	* { transition: none !important; }
}

/* ==========================================================================
   21. Halo de fond générique (page-hero, 404, leadership…)
   ========================================================================== */
.mpe-page-hero { position: relative; overflow: hidden; }
.mpe-page-hero__bg {
	position: absolute;
	inset: 0;
	z-index: -1;
	pointer-events: none;
}
.mpe-page-hero__blob {
	position: absolute;
	border-radius: 9999px;
	filter: blur(80px);
	pointer-events: none;
}
.mpe-page-hero__blob--blue-tl {
	top: -10rem; left: -10rem;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(96,165,250,.30), rgba(99,102,241,.10));
}
.mpe-page-hero__blob--blue-center-top {
	top: -10rem; left: 25%;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(96,165,250,.20), rgba(99,102,241,.10));
}
.mpe-page-hero__blob--emerald-tr {
	top: -5rem; right: 0;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(52,211,153,.20), rgba(34,211,238,.10));
}
.mpe-page-hero__blob--emerald-br {
	bottom: 0; right: 0;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(52,211,153,.20), rgba(34,211,238,.10));
}
.mpe-page-hero__blob--pink-tr {
	top: -5rem; right: 0;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(244,114,182,.20), rgba(167,139,250,.10));
}
.mpe-page-hero__inner {
	max-width: 56rem;
	margin-inline: auto;
	padding-inline: 1rem;
	padding-block: 4rem;
	text-align: center;
}
@media (min-width: 640px)  { .mpe-page-hero__inner { padding-inline: 1.5rem; } }
@media (min-width: 768px)  { .mpe-page-hero__inner { padding-block: 6rem; } }
@media (min-width: 1024px) { .mpe-page-hero__inner { padding-inline: 2rem; } }
.mpe-page-hero__inner--wide { max-width: var(--mpe-max-w); }

.mpe-page-hero__title {
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 600;
	letter-spacing: -.025em;
	line-height: 1.1;
	color: var(--mpe-ink-900);
}
.mpe-page-hero__desc {
	margin-top: 1rem;
	font-size: 1.125rem;
	color: var(--mpe-ink-500);
	line-height: 1.7;
	max-width: 36rem;
	margin-inline: auto;
}
.mpe-page-breadcrumb {
	font-size: .75rem;
	color: var(--mpe-ink-500);
	margin-bottom: 1rem;
}

/* ==========================================================================
   22. Wrappers de contenu
   ========================================================================== */
.mpe-content-wide {
	max-width: 72rem;
	margin-inline: auto;
	padding-inline: 1rem;
	margin-bottom: 3rem;
}
@media (min-width: 640px)  { .mpe-content-wide { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .mpe-content-wide { padding-inline: 2rem; } }

.mpe-content-narrow {
	max-width: 48rem;
	margin-inline: auto;
	padding-inline: 1rem;
	padding-bottom: 5rem;
}
@media (min-width: 640px)  { .mpe-content-narrow { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .mpe-content-narrow { padding-inline: 2rem; } }

.mpe-featured-thumb {
	border-radius: var(--mpe-radius-xl);
	overflow: hidden;
	aspect-ratio: 16 / 9;
	background: var(--mpe-surface-muted);
}
.mpe-featured-thumb img {
	width: 100%; height: 100%;
	object-fit: cover;
}

/* ==========================================================================
   23. Header d'article (single.php)
   ========================================================================== */
.mpe-single-header {
	max-width: 56rem;
	margin-inline: auto;
	padding-inline: 1rem;
	padding-top: 3rem;
}
@media (min-width: 640px)  { .mpe-single-header { padding-inline: 1.5rem; } }
@media (min-width: 768px)  { .mpe-single-header { padding-top: 4rem; } }
@media (min-width: 1024px) { .mpe-single-header { padding-inline: 2rem; } }

.mpe-single-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .5rem;
	font-size: .75rem;
	color: var(--mpe-ink-500);
	margin-bottom: 1rem;
}
.mpe-single-title {
	font-size: clamp(1.75rem, 4vw, 3rem);
	font-weight: 600;
	letter-spacing: -.025em;
	line-height: 1.1;
	color: var(--mpe-ink-900);
}
.mpe-single-excerpt {
	margin-top: 1rem;
	font-size: 1.125rem;
	color: var(--mpe-ink-700);
	line-height: 1.7;
}
.mpe-single-thumb-wrap {
	max-width: 72rem;
	margin-inline: auto;
	padding-inline: 1rem;
	margin-top: 2.5rem;
	margin-bottom: 3rem;
}
@media (min-width: 640px)  { .mpe-single-thumb-wrap { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .mpe-single-thumb-wrap { padding-inline: 2rem; } }
.mpe-single-thumb-gap { margin-top: 2.5rem; }

.mpe-post-tags {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .5rem;
	margin-top: 2.5rem;
}
.mpe-post-tags__label {
	font-size: .7rem;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--mpe-ink-500);
}

.mpe-post-nav {
	max-width: 48rem;
	margin-inline: auto;
	padding-inline: 1rem;
	padding-bottom: 3rem;
	border-top: 1px solid rgba(15,23,42,0.08);
	padding-top: 2rem;
}
@media (min-width: 640px)  { .mpe-post-nav { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .mpe-post-nav { padding-inline: 2rem; } }
.mpe-post-nav__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	font-size: .875rem;
}
.mpe-post-nav__label {
	display: block;
	font-size: .75rem;
	color: var(--mpe-ink-500);
	margin-bottom: .25rem;
}
.mpe-post-nav__link {
	font-weight: 500;
	color: var(--mpe-ink-900);
	transition: color .2s;
}
.mpe-post-nav__link:hover { color: var(--mpe-blue); }
.mpe-post-nav__next { text-align: right; }

/* ==========================================================================
   24. Layout archive / index / search
   ========================================================================== */
.mpe-archive-main {
	max-width: var(--mpe-max-w);
	margin-inline: auto;
	padding-inline: 1rem;
	padding-block: 3rem;
}
@media (min-width: 640px)  { .mpe-archive-main { padding-inline: 1.5rem; } }
@media (min-width: 768px)  { .mpe-archive-main { padding-block: 4rem; } }
@media (min-width: 1024px) { .mpe-archive-main { padding-inline: 2rem; } }

.mpe-archive-header { margin-bottom: 3rem; }
.mpe-archive-header--narrow { max-width: 48rem; }

.mpe-archive-title {
	font-size: clamp(1.75rem, 4vw, 3rem);
	font-weight: 600;
	letter-spacing: -.025em;
	color: var(--mpe-ink-900);
}
.mpe-archive-title__accent { color: var(--mpe-blue); }
.mpe-archive-search { margin-top: 1.5rem; }

.mpe-archive-desc {
	margin-top: 1rem;
	color: var(--mpe-ink-500);
	line-height: 1.7;
	max-width: 36rem;
}

.mpe-posts-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 768px)  { .mpe-posts-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mpe-posts-grid { grid-template-columns: repeat(3, 1fr); } }
.mpe-pagination-wrap { margin-top: 3rem; }

/* ==========================================================================
   25. Carte d'article (content-card.php)
   ========================================================================== */
.mpe-card {
	position: relative;
	overflow: hidden;
	border-radius: var(--mpe-radius-xl);
	background: var(--mpe-surface);
	border: 1px solid rgba(15,23,42,0.07);
	box-shadow: 0 1px 4px rgba(15,23,42,0.06);
	transition: box-shadow .3s var(--mpe-ease), transform .3s var(--mpe-ease);
}
.mpe-card:hover {
	box-shadow: 0 20px 60px -10px rgba(15,23,42,0.20);
	transform: translateY(-2px);
}
.mpe-card__thumb {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--mpe-surface-muted);
}
.mpe-card__thumb img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .7s var(--mpe-ease);
}
.mpe-card:hover .mpe-card__thumb img { transform: scale(1.05); }
.mpe-card__body { padding: 1.5rem; }
.mpe-card__meta {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: .75rem;
	color: var(--mpe-ink-500);
	margin-bottom: .5rem;
}
.mpe-card__title {
	font-size: 1.125rem;
	font-weight: 600;
	letter-spacing: -.02em;
	color: var(--mpe-ink-900);
	line-height: 1.3;
	margin-bottom: .5rem;
}
.mpe-card__title a:hover { color: var(--mpe-blue); }
.mpe-card__excerpt {
	font-size: .875rem;
	color: var(--mpe-ink-500);
	line-height: 1.6;
}
.mpe-card__cta {
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	margin-top: 1rem;
	font-size: .875rem;
	font-weight: 500;
	color: var(--mpe-blue);
}

/* ==========================================================================
   26. Message "aucun contenu" (content-none.php)
   ========================================================================== */
.mpe-no-results {
	border-radius: var(--mpe-radius-xl);
	border: 2px dashed var(--mpe-ink-300);
	background: rgba(255,255,255,0.60);
	padding: 2.5rem;
	text-align: center;
}
.mpe-no-results__title { font-size: 1.25rem; font-weight: 600; color: var(--mpe-ink-900); }
.mpe-no-results__desc  { margin-top: 1rem; color: var(--mpe-ink-500); }
.mpe-no-results__search { margin-top: 1.5rem; max-width: 28rem; margin-inline: auto; }
.mpe-no-results__link { color: var(--mpe-blue); text-decoration: underline; }

/* ==========================================================================
   27. Formulaire de recherche (searchform.php)
   ========================================================================== */
.mpe-search-form { position: relative; }
.mpe-search-form__inner { position: relative; }
.mpe-search-form__icon {
	position: absolute;
	left: 1rem;
	top: 50%;
	transform: translateY(-50%);
	width: 1rem; height: 1rem;
	color: var(--mpe-ink-500);
	pointer-events: none;
}
.mpe-search-form__input {
	width: 100%;
	padding: .75rem 7rem .75rem 2.75rem;
	border-radius: 9999px;
	background: rgba(255,255,255,0.70);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border: 1px solid rgba(15,23,42,0.10);
	color: var(--mpe-ink-900);
	font-size: .9375rem;
	transition: border-color .2s, box-shadow .2s;
}
.mpe-search-form__input::placeholder { color: var(--mpe-ink-500); }
.mpe-search-form__input:focus {
	outline: none;
	border-color: var(--mpe-blue);
	box-shadow: 0 0 0 3px rgba(10,132,255,0.15);
}
.mpe-search-form__btn {
	position: absolute;
	right: .375rem;
	top: 50%;
	transform: translateY(-50%);
	display: inline-flex;
	align-items: center;
	padding: .5rem 1rem;
	border-radius: 9999px;
	background: var(--mpe-ink-900);
	color: #fff;
	font-size: .875rem;
	font-weight: 500;
	border: none;
	cursor: pointer;
	transition: background-color .2s;
}
.mpe-search-form__btn:hover { background: var(--mpe-ink-700); }

/* ==========================================================================
   28. Page 404
   ========================================================================== */
.mpe-404 {
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}
.mpe-404__bg { position: absolute; inset: 0; z-index: -1; pointer-events: none; }
.mpe-404__blob { position: absolute; border-radius: 9999px; filter: blur(80px); }
.mpe-404__blob--blue {
	top: 2.5rem; left: 25%;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(96,165,250,.20), rgba(99,102,241,.10));
}
.mpe-404__blob--pink {
	bottom: 2.5rem; right: 25%;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(244,114,182,.20), rgba(167,139,250,.10));
}
.mpe-404__content {
	max-width: 36rem;
	margin-inline: auto;
	padding: 4rem 1rem;
	text-align: center;
}
.mpe-404__number {
	font-size: clamp(5rem, 15vw, 8rem);
	font-weight: 700;
	letter-spacing: -.04em;
	background: linear-gradient(90deg, var(--mpe-primary), var(--mpe-primary-dark));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	line-height: 1;
}
.mpe-404__title {
	margin-top: 1rem;
	font-size: clamp(1.25rem, 3vw, 1.75rem);
	font-weight: 600;
	letter-spacing: -.025em;
	color: var(--mpe-ink-900);
}
.mpe-404__desc { margin-top: 1rem; color: var(--mpe-ink-500); line-height: 1.7; }
.mpe-404__actions {
	margin-top: 2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: .75rem;
}
@media (min-width: 640px) { .mpe-404__actions { flex-direction: row; } }
.mpe-404__search { margin-top: 2.5rem; max-width: 28rem; margin-inline: auto; }

/* ==========================================================================
   29. Commentaires (comments.php)
   ========================================================================== */
.mpe-comments { margin-top: 3rem; }
.mpe-comments__title {
	font-size: 1.5rem;
	font-weight: 600;
	letter-spacing: -.02em;
	color: var(--mpe-ink-900);
	margin-bottom: 1.5rem;
}
.mpe-comment-list { display: flex; flex-direction: column; gap: 1.5rem; list-style: none; }
.mpe-comment-item {
	border-radius: var(--mpe-radius-md);
	background: var(--mpe-surface);
	border: 1px solid rgba(15,23,42,0.07);
	padding: 1.25rem;
}
.mpe-comment-item__header {
	display: flex;
	align-items: flex-start;
	gap: .75rem;
}
.mpe-comment-item__avatar { flex-shrink: 0; }
.mpe-comment-item__avatar img { border-radius: 9999px; }
.mpe-comment-item__body { flex: 1; min-width: 0; }
.mpe-comment-item__meta {
	display: flex;
	align-items: baseline;
	gap: .5rem;
	flex-wrap: wrap;
	margin-bottom: .5rem;
}
.mpe-comment-item__author { font-size: .875rem; font-weight: 600; color: var(--mpe-ink-900); }
.mpe-comment-item__date   { font-size: .75rem; color: var(--mpe-ink-500); }
.mpe-comment-item__actions { margin-top: .5rem; font-size: .75rem; }
.mpe-comment-item__reply-link { color: var(--mpe-blue); }
.mpe-comment-item__reply-link:hover { text-decoration: underline; }
.mpe-comment-item__pending {
	margin-top: .75rem;
	font-size: .75rem;
	color: #d97706;
	font-style: italic;
}
.mpe-comment-form {
	margin-top: 2.5rem;
	border-radius: var(--mpe-radius-lg);
	background: rgba(255,255,255,0.60);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border: 1px solid rgba(15,23,42,0.07);
	padding: 1.5rem;
}
@media (min-width: 768px) { .mpe-comment-form { padding: 2rem; } }
.mpe-comment-form__title {
	font-size: 1.25rem;
	font-weight: 600;
	letter-spacing: -.02em;
	color: var(--mpe-ink-900);
	margin-bottom: 1rem;
}
.mpe-comment-form__fields { display: flex; flex-direction: column; gap: 1rem; }

/* ==========================================================================
   30. Champs de formulaire génériques
   ========================================================================== */
.mpe-form-label {
	display: block;
	font-size: .875rem;
	font-weight: 500;
	color: var(--mpe-ink-700);
	margin-bottom: .25rem;
}
.mpe-form-required { color: #ef4444; }
.mpe-form-field {
	width: 100%;
	border-radius: var(--mpe-radius-md);
	border: 1px solid rgba(15,23,42,0.12);
	background: var(--mpe-surface);
	padding: .75rem 1rem;
	font-size: .9375rem;
	color: var(--mpe-ink-900);
	transition: border-color .2s, box-shadow .2s;
}
.mpe-form-field:focus {
	outline: none;
	border-color: var(--mpe-blue);
	box-shadow: 0 0 0 3px rgba(10,132,255,0.15);
}
.mpe-form-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}
@media (min-width: 768px) { .mpe-form-row--2col { grid-template-columns: repeat(2, 1fr); } }
.mpe-form-note { font-size: .75rem; color: var(--mpe-ink-500); margin-top: .75rem; }

.mpe-alert {
	margin-top: 1.5rem;
	border-radius: var(--mpe-radius-md);
	padding: 1rem;
	font-size: .875rem;
}
.mpe-alert--success { background: #ecfdf5; border: 1px solid #a7f3d0; color: #065f46; }
.mpe-alert--error   { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }

/* ==========================================================================
   31. Page Contact
   ========================================================================== */
.mpe-contact-section {
	max-width: 72rem;
	margin-inline: auto;
	padding-inline: 1rem;
	padding-bottom: 5rem;
}
@media (min-width: 640px)  { .mpe-contact-section { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .mpe-contact-section { padding-inline: 2rem; } }
.mpe-contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 1024px) { .mpe-contact-grid { grid-template-columns: 2fr 3fr; } }

.mpe-contact-aside { display: flex; flex-direction: column; gap: 1.5rem; }
.mpe-contact-block { padding: 1.5rem; }
@media (min-width: 768px) { .mpe-contact-block { padding: 2rem; } }
.mpe-contact-block__title {
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--mpe-ink-900);
	margin-bottom: 1rem;
	display: flex;
	align-items: center;
	gap: .5rem;
}
.mpe-contact-block__icon { color: var(--mpe-blue); flex-shrink: 0; }
.mpe-contact-list {
	display: flex;
	flex-direction: column;
	gap: .25rem;
	font-size: .875rem;
	color: var(--mpe-ink-500);
}
.mpe-contact-list a { transition: color .2s; word-break: break-all; }
.mpe-contact-list a:hover { color: var(--mpe-blue); }
.mpe-contact-text { font-size: .875rem; color: var(--mpe-ink-500); line-height: 1.65; }
.mpe-contact-form-panel { padding: 1.5rem; }
@media (min-width: 768px) { .mpe-contact-form-panel { padding: 2.5rem; } }
.mpe-contact-form { display: flex; flex-direction: column; gap: 1rem; }

/* ==========================================================================
   32. Archive leadership
   ========================================================================== */
.mpe-leadership-hero-inner {
	max-width: var(--mpe-max-w);
	margin-inline: auto;
	padding-inline: 1rem;
	padding-block: 4rem;
}
@media (min-width: 640px)  { .mpe-leadership-hero-inner { padding-inline: 1.5rem; } }
@media (min-width: 768px)  { .mpe-leadership-hero-inner { padding-block: 5rem; } }
@media (min-width: 1024px) { .mpe-leadership-hero-inner { padding-inline: 2rem; } }
.mpe-leadership-hero__title {
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 600;
	letter-spacing: -.025em;
	line-height: 1.1;
	color: var(--mpe-ink-900);
}
.mpe-leadership-hero__desc {
	margin-top: 1rem;
	font-size: 1.125rem;
	color: var(--mpe-ink-500);
	max-width: 40rem;
	line-height: 1.7;
}
.mpe-leadership-content {
	max-width: var(--mpe-max-w);
	margin-inline: auto;
	padding-inline: 1rem;
	padding-bottom: 5rem;
}
@media (min-width: 640px)  { .mpe-leadership-content { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .mpe-leadership-content { padding-inline: 2rem; } }
.mpe-leadership-section-gap { margin-top: 4rem; }

/* ==========================================================================
   33. Single leadership (biographie)
   ========================================================================== */
.mpe-leader-bio-inner {
	max-width: 72rem;
	margin-inline: auto;
	padding-inline: 1rem;
	padding-top: 4rem;
	padding-bottom: 5rem;
}
@media (min-width: 640px)  { .mpe-leader-bio-inner { padding-inline: 1.5rem; } }
@media (min-width: 768px)  { .mpe-leader-bio-inner { padding-top: 6rem; } }
@media (min-width: 1024px) { .mpe-leader-bio-inner { padding-inline: 2rem; } }
.mpe-leader-bio-breadcrumb {
	font-size: .75rem;
	color: var(--mpe-ink-500);
	margin-bottom: 1.5rem;
}
.mpe-leader-bio-breadcrumb a { transition: color .2s; }
.mpe-leader-bio-breadcrumb a:hover { color: var(--mpe-ink-900); }
.mpe-leader-bio-breadcrumb__sep { margin-inline: .5rem; }
.mpe-leader-bio-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	align-items: flex-start;
}
@media (min-width: 768px) {
	.mpe-leader-bio-grid { grid-template-columns: 1fr 2fr; gap: 3.5rem; }
}
.mpe-leader-bio-portrait {
	border-radius: var(--mpe-radius-xl);
	overflow: hidden;
	aspect-ratio: 1 / 1;
}
.mpe-leader-bio-portrait img { width: 100%; height: 100%; object-fit: cover; }
.mpe-leader-bio-bodies {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	margin-bottom: 1rem;
}
.mpe-leader-bio-body-tag {
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	padding: .25rem .75rem;
	border-radius: 9999px;
	background: rgba(255,255,255,0.70);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border: 1px solid rgba(15,23,42,0.10);
	font-size: .75rem;
	font-weight: 500;
	color: var(--mpe-ink-700);
}
.mpe-leader-bio-title {
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 600;
	letter-spacing: -.025em;
	line-height: 1.05;
	color: var(--mpe-ink-900);
}
.mpe-leader-bio-position {
	margin-top: .75rem;
	font-size: 1.25rem;
	color: var(--mpe-ink-500);
	font-weight: 500;
}
.mpe-leader-bio-email {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	margin-top: 1.25rem;
	font-size: .875rem;
	color: var(--mpe-blue);
}
.mpe-leader-bio-email:hover { text-decoration: underline; }
.mpe-leader-bio-content { margin-top: 2rem; }

/* ==========================================================================
   34. WooCommerce layout natif
   ========================================================================== */
.mpe-single-product {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}
@media (min-width: 1024px) {
	.mpe-single-product { grid-template-columns: 1fr 1fr; gap: 4rem; }
}
.mpe-single-product__gallery {
	position: sticky;
	top: 6rem;
	border-radius: var(--mpe-radius-xl);
	overflow: hidden;
	background: var(--mpe-surface);
	border: 1px solid rgba(15,23,42,0.07);
	box-shadow: 0 1px 4px rgba(15,23,42,0.06);
}
.mpe-woo-main {
	max-width: var(--mpe-max-w);
	margin-inline: auto;
	padding-inline: 1rem;
	padding-block: 2.5rem;
}
@media (min-width: 640px)  { .mpe-woo-main { padding-inline: 1.5rem; } }
@media (min-width: 1024px) { .mpe-woo-main { padding-inline: 2rem; } }

/* Page Mon compte : pleine largeur sans marges latérales */
.mpe-account-page {
	width: 100%;
	margin: 0;
	padding: 0;
}
.mpe-free-read-badge {
	position: absolute;
	top: .75rem; left: .75rem;
	z-index: 10;
	padding: .25rem .75rem;
	border-radius: 9999px;
	font-size: .75rem;
	font-weight: 600;
	background: rgba(52,199,89,0.90);
	color: #fff;
	-webkit-backdrop-filter: blur(4px);
	        backdrop-filter: blur(4px);
	box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

/* ==========================================================================
   35. Sélecteur de langue (Polylang) — <details>/<summary>, zéro JS
   ========================================================================== */

/* <details> wrapper */
.mpe-lang-switcher {
	position: relative;
	font-size: .82rem;
	font-weight: 600;
	line-height: 1;
}

/* Supprime le triangle natif de <summary> sur tous les navigateurs */
.mpe-lang-switcher summary { list-style: none; }
.mpe-lang-switcher summary::-webkit-details-marker { display: none; }

/* <summary> = bouton langue courante */
.mpe-lang-btn {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .38rem .65rem;
	border-radius: 9999px;
	background: rgba(255, 255, 255, .60);
	border: 1px solid rgba(15, 23, 42, .07);
	color: var(--mpe-text-main);
	cursor: pointer;
	user-select: none;
	transition: background .2s var(--mpe-ease), border-color .2s var(--mpe-ease);
	white-space: nowrap;
}
.mpe-lang-btn:hover,
.mpe-lang-switcher[open] .mpe-lang-btn {
	background: var(--mpe-bg-card);
	border-color: rgba(15, 23, 42, .14);
}

/* Drapeau */
.mpe-lang-flag {
	border-radius: 2px;
	flex-shrink: 0;
	display: block;
}

/* Code 2 lettres */
.mpe-lang-code { letter-spacing: .04em; }

/* Chevron — tourne quand <details> est ouvert */
.mpe-lang-chevron {
	opacity: .55;
	flex-shrink: 0;
	transition: transform .2s var(--mpe-ease);
}
.mpe-lang-switcher[open] .mpe-lang-chevron {
	transform: rotate(180deg);
}

/* Dropdown — visible automatiquement quand [open] */
.mpe-lang-dropdown {
	position: absolute;
	top: calc(100% + .45rem);
	right: 0;
	min-width: 11rem;
	list-style: none;
	padding: .3rem 0;
	background: var(--mpe-bg-card);
	border: 1px solid rgba(15, 23, 42, .08);
	border-radius: var(--mpe-radius-sm);
	box-shadow: 0 8px 24px rgba(0, 0, 0, .10);
	z-index: 9000;
	overflow: hidden;
}

/* Items */
.mpe-lang-dropdown a {
	display: flex;
	align-items: center;
	gap: .5rem;
	padding: .5rem .875rem;
	color: var(--mpe-text-main);
	font-size: .82rem;
	font-weight: 500;
	text-decoration: none;
	white-space: nowrap;
	transition: background .15s, color .15s;
}
.mpe-lang-dropdown a:hover {
	background: var(--mpe-bg-body);
	color: var(--mpe-primary);
}
.mpe-lang-dropdown img {
	border-radius: 2px;
	flex-shrink: 0;
	display: block;
}

/* ── Sélecteur plat dans le menu mobile ── */
.mpe-mobile-lang {
	display: flex;
	flex-wrap: wrap;
	gap: .45rem;
	padding: .875rem 1.25rem;
	border-top: 1px solid rgba(15, 23, 42, .06);
}
.mpe-mobile-lang a {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .35rem .65rem;
	border-radius: 9999px;
	border: 1px solid rgba(15, 23, 42, .12);
	font-size: .78rem;
	font-weight: 600;
	color: var(--mpe-text-muted);
	text-decoration: none;
	transition: background .2s, border-color .2s, color .2s;
}
.mpe-mobile-lang a:hover {
	background: rgba(31, 155, 66, .08);
	border-color: var(--mpe-primary);
	color: var(--mpe-primary);
}
.mpe-mobile-lang a.mpe-lang--active {
	background: var(--mpe-primary);
	border-color: var(--mpe-primary);
	color: #fff;
}
.mpe-mobile-lang img {
	border-radius: 2px;
	flex-shrink: 0;
	display: block;
}

/* ==========================================================================
   36. Widget title
   ========================================================================== */
/* ==========================================================================
   37. Bouton primaire — couleur de marque verte
   ========================================================================== */
.mpe-btn--primary {
	background: var(--mpe-primary);
	color: #fff;
	box-shadow: 0 4px 20px rgba(31,155,66,0.25);
}
.mpe-btn--primary:hover {
	background: var(--mpe-primary-dark);
	transform: translateY(-1px);
	box-shadow: 0 8px 28px rgba(31,155,66,0.30);
}
.mpe-btn-donate {
	background: var(--mpe-primary) !important;
}
.mpe-btn-donate:hover { background: var(--mpe-primary-dark) !important; }

/* ==========================================================================
   38. Hero v2 (front-page)
   ========================================================================== */
.mpe-hero-v2 {
	position: relative;
	overflow: hidden;
	padding-top: 5rem;
	padding-bottom: 5rem;
	background: linear-gradient(180deg, rgba(31,155,66,.05) 0%, transparent 70%);
}
.mpe-hero-v2__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.mpe-hero-v2__circle {
	position: absolute;
	border-radius: 9999px;
	pointer-events: none;
}
.mpe-hero-v2__circle--1 {
	top: -8rem; right: -8rem;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(31,155,66,.12), transparent 70%);
}
.mpe-hero-v2__circle--2 {
	bottom: -5rem; left: -5rem;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(227,24,24,.06), transparent 70%);
}

.mpe-hero-v2__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: center;
}
@media (min-width: 1024px) {
	.mpe-hero-v2__inner { grid-template-columns: 1fr 1fr; gap: 4rem; }
}

.mpe-hero-v2__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .35rem .875rem;
	border-radius: 9999px;
	background: rgba(31,155,66,.10);
	border: 1px solid rgba(31,155,66,.20);
	font-size: .78rem;
	font-weight: 600;
	color: var(--mpe-primary);
	margin-bottom: 1.5rem;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.mpe-hero-v2__eyebrow-dot {
	width: .45rem; height: .45rem;
	border-radius: 9999px;
	background: var(--mpe-primary);
}
.mpe-hero-v2__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(2.25rem, 5.5vw, 3.75rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -.03em;
	color: var(--mpe-text-heading);
}
.mpe-hero-v2__title-accent {
	display: block;
	color: var(--mpe-primary);
}
.mpe-hero-v2__desc {
	margin-top: 1.5rem;
	font-size: 1.0625rem;
	color: var(--mpe-text-muted);
	line-height: 1.75;
	max-width: 36rem;
}
.mpe-hero-v2__actions {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	margin-top: 2rem;
}
.mpe-hero-v2__stats {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(31,155,66,.15);
}
.mpe-hero-v2__stat-value {
	font-family: var(--mpe-font-heading);
	font-size: 1.875rem;
	font-weight: 700;
	color: var(--mpe-primary);
	line-height: 1;
}
.mpe-hero-v2__stat-label {
	font-size: .8rem;
	color: var(--mpe-text-muted);
	margin-top: .3rem;
}

/* Visuel hero */
.mpe-hero-v2__visual { position: relative; }
.mpe-hero-v2__image-wrap {
	position: relative;
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 3;
	background: var(--mpe-surface-muted);
	box-shadow: var(--mpe-shadow-hover);
}
.mpe-hero-v2__image-wrap img { width: 100%; height: 100%; object-fit: cover; }

.mpe-hero-v2__image-badge {
	position: absolute;
	bottom: 1.25rem; left: 1.25rem;
	background: rgba(255,255,255,.92);
	-webkit-backdrop-filter: blur(12px);
	        backdrop-filter: blur(12px);
	border-radius: var(--mpe-radius-sm);
	padding: .875rem 1.25rem;
	box-shadow: var(--mpe-shadow-bento);
	display: flex;
	align-items: center;
	gap: .75rem;
}
.mpe-hero-v2__badge-icon {
	width: 2.5rem; height: 2.5rem;
	border-radius: var(--mpe-radius-sm);
	background: linear-gradient(135deg, var(--mpe-primary), var(--mpe-primary-dark));
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	flex-shrink: 0;
}
.mpe-hero-v2__badge-text strong {
	display: block;
	font-size: .875rem;
	font-weight: 600;
	color: var(--mpe-text-heading);
}
.mpe-hero-v2__badge-text span { font-size: .75rem; color: var(--mpe-text-muted); }

.mpe-hero-v2__image-placeholder {
	width: 100%;
	aspect-ratio: 4 / 3;
	border-radius: var(--mpe-radius-lg);
	background: linear-gradient(160deg, rgba(31,155,66,.07), rgba(31,155,66,.13));
	border: 2px dashed rgba(31,155,66,.25);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: .75rem;
	color: var(--mpe-primary);
	font-size: .875rem;
}

/* ==========================================================================
   39. Chiffres clés (impact)
   ========================================================================== */
.mpe-impact {
	background: linear-gradient(135deg, var(--mpe-primary) 0%, var(--mpe-primary-dark) 100%);
	padding-block: 4rem;
}
.mpe-impact-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	text-align: center;
}
@media (min-width: 768px) { .mpe-impact-grid { grid-template-columns: repeat(4, 1fr); } }
.mpe-impact-item__value {
	font-family: var(--mpe-font-heading);
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 700;
	color: #fff;
	line-height: 1;
}
.mpe-impact-item__sep {
	display: block;
	width: 2rem; height: 2px;
	background: rgba(255,255,255,.30);
	margin: .75rem auto;
}
.mpe-impact-item__label {
	font-size: .875rem;
	color: rgba(255,255,255,.75);
	line-height: 1.4;
}

/* ==========================================================================
   40. Grille programmes (front-page)
   ========================================================================== */
.mpe-programs-section { background: var(--mpe-bg-body); }
.mpe-programs-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin-top: 3rem;
}
@media (min-width: 640px)  { .mpe-programs-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mpe-programs-grid { grid-template-columns: repeat(3, 1fr); } }

.mpe-program-card {
	position: relative;
	border-radius: var(--mpe-radius-lg);
	background: var(--mpe-bg-card);
	border: 1px solid rgba(0,0,0,.06);
	box-shadow: var(--mpe-shadow-sm);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .3s var(--mpe-ease), box-shadow .3s var(--mpe-ease);
}
.mpe-program-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--mpe-shadow-hover);
}
.mpe-program-card__image {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--mpe-surface-muted);
	position: relative;
}
.mpe-program-card__image img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .6s var(--mpe-ease);
}
.mpe-program-card:hover .mpe-program-card__image img { transform: scale(1.05); }
.mpe-program-card__image-ph {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	background: linear-gradient(135deg, rgba(31,155,66,.08), rgba(31,155,66,.04));
	color: rgba(31,155,66,.35);
}
.mpe-program-card__badge {
	position: absolute;
	top: .75rem; left: .75rem;
	padding: .25rem .625rem;
	border-radius: 9999px;
	background: rgba(31,155,66,.90);
	color: #fff;
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	z-index: 1;
}
.mpe-program-card__body {
	padding: 1.5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.mpe-program-card__title {
	font-family: var(--mpe-font-heading);
	font-size: 1.0625rem;
	font-weight: 600;
	color: var(--mpe-text-heading);
	line-height: 1.3;
	margin-bottom: .625rem;
}
.mpe-program-card__desc {
	font-size: .875rem;
	color: var(--mpe-text-muted);
	line-height: 1.65;
	flex: 1;
}
.mpe-program-card__footer {
	display: flex;
	align-items: center;
	margin-top: 1.25rem;
	padding-top: 1rem;
	border-top: 1px solid rgba(0,0,0,.06);
}
.mpe-program-card__link {
	font-size: .875rem;
	font-weight: 600;
	color: var(--mpe-primary);
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	transition: gap .2s;
}
.mpe-program-card:hover .mpe-program-card__link { gap: .625rem; }
.mpe-program-card__full-link {
	position: absolute;
	inset: 0;
	border-radius: var(--mpe-radius-lg);
}
/* Programme en vedette (1er) */
.mpe-program-card--featured {
	grid-column: 1 / -1;
}
@media (min-width: 1024px) {
	.mpe-program-card--featured {
		grid-column: span 2;
		flex-direction: row;
	}
	.mpe-program-card--featured .mpe-program-card__image {
		aspect-ratio: auto;
		flex: 1;
		min-height: 260px;
	}
	.mpe-program-card--featured .mpe-program-card__body { flex: 1; }
	.mpe-program-card--featured .mpe-program-card__title { font-size: 1.25rem; }
}

.mpe-section-cta { margin-top: 3rem; text-align: center; }

/* ---------- Swiper wrapper ---------- */
.mpe-programs-swiper {
	position: relative;
	overflow: hidden;
	border-radius: var(--mpe-radius-lg);
}
.mpe-programs-swiper .swiper-slide {
	height: auto;
}
.mpe-programs-swiper .mpe-program-card {
	height: 100%;
}

/* ---------- Compteur de slide ---------- */
.mpe-program-card__num {
	position: absolute;
	top: .75rem; right: .75rem;
	padding: .25rem .625rem;
	border-radius: 9999px;
	background: rgba(0,0,0,.45);
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	color: #fff;
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .04em;
	z-index: 1;
}

/* ---------- Dots (pagination glassmorphism) ---------- */
.mpe-swiper-dots {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: .75rem;
	padding: 2.5rem 0 .5rem;
}
.mpe-swiper-dots .mpe-dot {
	display: inline-block;
	width: .875rem; height: .875rem;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.4);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(0, 0, 0, 0.1);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	cursor: pointer;
	transition: background .3s, transform .3s var(--mpe-ease), border-color .3s;
}
.mpe-swiper-dots .mpe-dot--active {
	background: var(--mpe-primary);
	border-color: var(--mpe-primary);
	transform: scale(1.3);
	box-shadow: 0 6px 16px rgba(31, 155, 66, 0.35);
}

/* ---------- Flèches prev / next (glassmorphism) ---------- */
.mpe-swiper-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	width: 3rem; height: 3rem;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.7);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.4);
	box-shadow: 0 4px 16px rgba(0,0,0,0.1);
	color: var(--mpe-text-heading);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background .3s, box-shadow .3s, transform .3s, color .3s;
}
.mpe-swiper-btn:hover {
	background: var(--mpe-primary);
	color: #fff;
	border-color: var(--mpe-primary);
	box-shadow: 0 8px 24px rgba(31, 155, 66, 0.35);
}
.mpe-swiper-btn--prev { left: 1rem; }
.mpe-swiper-btn--next { right: 1rem; }

@media (max-width: 639px) {
	.mpe-swiper-btn { display: none; }
}

/* ==========================================================================
   41. Section Mission / À propos
   ========================================================================== */

.mpe-mission { background: #fff; }
.mpe-mission-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: center;
}
@media (min-width: 1024px) { .mpe-mission-grid { grid-template-columns: 1fr 1fr; gap: 5rem; } }

.mpe-mission__tag {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .3rem .8rem;
	border-radius: 9999px;
	background: rgba(31,155,66,.08);
	color: var(--mpe-primary);
	font-size: .78rem;
	font-weight: 600;
	letter-spacing: .06em;
	text-transform: uppercase;
	margin-bottom: 1.25rem;
}
.mpe-mission__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -.02em;
	color: var(--mpe-text-heading);
	margin-bottom: 1.25rem;
}
.mpe-mission__desc {
	font-size: 1.0625rem;
	color: var(--mpe-text-muted);
	line-height: 1.8;
	margin-bottom: 2rem;
}
.mpe-mission__values { display: flex; flex-direction: column; gap: 1.25rem; }
.mpe-mission__value { display: flex; align-items: flex-start; gap: 1rem; }
.mpe-mission__value-icon {
	flex-shrink: 0;
	width: 2.5rem; height: 2.5rem;
	border-radius: var(--mpe-radius-sm);
	background: rgba(31,155,66,.10);
	color: var(--mpe-primary);
	display: flex;
	align-items: center;
	justify-content: center;
}
.mpe-mission__value-text strong {
	display: block;
	font-size: .9375rem;
	font-weight: 600;
	color: var(--mpe-text-heading);
	margin-bottom: .2rem;
}
.mpe-mission__value-text span {
	font-size: .875rem;
	color: var(--mpe-text-muted);
	line-height: 1.5;
}
.mpe-mission__image-wrap { position: relative; }
.mpe-mission__image {
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 5;
	background: var(--mpe-surface-muted);
	box-shadow: var(--mpe-shadow-bento);
}
.mpe-mission__image img { width: 100%; height: 100%; object-fit: cover; }
.mpe-mission__image-card {
	position: absolute;
	bottom: -1.5rem; right: -1rem;
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-md);
	padding: 1.25rem 1.5rem;
	box-shadow: var(--mpe-shadow-bento);
	text-align: center;
	min-width: 9rem;
}
@media (max-width: 1023px) { .mpe-mission__image-card { display: none; } }
.mpe-mission__image-card strong {
	display: block;
	font-family: var(--mpe-font-heading);
	font-size: 2rem;
	font-weight: 700;
	color: var(--mpe-primary);
	line-height: 1;
}
.mpe-mission__image-card span {
	font-size: .75rem;
	color: var(--mpe-text-muted);
	margin-top: .25rem;
	display: block;
}
.mpe-mission__image-placeholder {
	width: 100%;
	aspect-ratio: 4 / 5;
	border-radius: var(--mpe-radius-lg);
	background: linear-gradient(160deg, rgba(31,155,66,.07), rgba(31,155,66,.13));
	border: 2px dashed rgba(31,155,66,.25);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(31,155,66,.45);
}

/* ==========================================================================
   42. CTA Don (bandeau rouge)
   ========================================================================== */
.mpe-cta-don {
	background: linear-gradient(135deg, var(--mpe-accent) 0%, #07522f 100%);
	padding-block: 5rem;
	text-align: center;
	color: #fff;
	position: relative;
	overflow: hidden;
}
.mpe-cta-don__deco {
	position: absolute;
	border-radius: 9999px;
	pointer-events: none;
}
.mpe-cta-don__deco--1 {
	top: -6rem; right: -6rem;
	width: 300px; height: 300px;
	background: rgba(255,255,255,.06);
}
.mpe-cta-don__deco--2 {
	bottom: -6rem; left: -6rem;
	width: 400px; height: 400px;
	background: rgba(255,255,255,.04);
}
.mpe-cta-don__inner {
	position: relative;
	z-index: 1;
	max-width: 42rem;
	margin-inline: auto;
}
.mpe-cta-don__eyebrow {
	display: inline-block;
	padding: .3rem .875rem;
	border-radius: 9999px;
	background: rgba(255,255,255,.15);
	font-size: .78rem;
	font-weight: 600;
	letter-spacing: .06em;
	text-transform: uppercase;
	margin-bottom: 1.25rem;
	color: rgba(255,255,255,.9);
}
.mpe-cta-don__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -.02em;
	margin-bottom: 1rem;
	color: #fff;
}
.mpe-cta-don__desc {
	font-size: 1.05rem;
	color: rgba(255,255,255,.80);
	line-height: 1.7;
	margin-bottom: 2rem;
}
.mpe-btn--donation {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	background: #fff;
	color: var(--mpe-accent);
	font-family: var(--mpe-font-heading);
	font-weight: 700;
	font-size: 1rem;
	padding: .875rem 2.5rem;
	border-radius: var(--mpe-radius-pill);
	transition: transform .2s, box-shadow .2s;
	box-shadow: 0 4px 20px rgba(0,0,0,.20);
	text-decoration: none;
}
.mpe-btn--donation:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 30px rgba(0,0,0,.25);
}
.widget-title {
	font-size: 1.125rem;
	font-weight: 600;
	margin-bottom: 1rem;
}

/* ==========================================================================
   43. Page produit — Bibliothèque (single-product)
   ========================================================================== */

/* --- Bouton lg --- */
.mpe-btn--lg { padding: .875rem 2rem; font-size: 1rem; font-weight: 600; }

/* --- Hero --- */
.mpe-book-hero {
	position: relative;
	overflow: hidden;
	padding: 2rem 0 5rem;
	background: linear-gradient(160deg, rgba(31,155,66,.06) 0%, var(--mpe-bg-body) 55%);
}
.mpe-book-hero__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.mpe-book-hero__circle {
	position: absolute;
	border-radius: 9999px;
}
.mpe-book-hero__circle--1 {
	top: -10rem; right: -10rem;
	width: 600px; height: 600px;
	background: radial-gradient(circle, rgba(31,155,66,.08), transparent 65%);
}
.mpe-book-hero__circle--2 {
	bottom: -8rem; left: -8rem;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(227,24,24,.05), transparent 65%);
}

/* Fil d'Ariane */
.mpe-book-breadcrumb {
	position: relative;
	z-index: 1;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .375rem;
	font-size: .8125rem;
	color: var(--mpe-text-muted);
	margin-bottom: 2.5rem;
}
.mpe-book-breadcrumb a { color: var(--mpe-text-muted); transition: color .2s; }
.mpe-book-breadcrumb a:hover { color: var(--mpe-primary); }
.mpe-book-breadcrumb span[aria-current] { color: var(--mpe-text-heading); font-weight: 500; }

/* Grille principale */
.mpe-book-layout {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: start;
}
@media (min-width: 640px) {
	.mpe-book-layout { grid-template-columns: 240px 1fr; gap: 3rem; }
}
@media (min-width: 1024px) {
	.mpe-book-layout { grid-template-columns: 300px 1fr; gap: 5rem; }
}

/* --- Colonne couverture --- */
.mpe-book-cover-col { position: relative; }
.mpe-book-cover-wrap {
	position: relative;
	border-radius: var(--mpe-radius-md);
	overflow: hidden;
	box-shadow:
		6px 16px 40px rgba(0,0,0,.22),
		0 2px 8px rgba(0,0,0,.12),
		inset -2px 0 4px rgba(0,0,0,.08);
	background: var(--mpe-surface-muted);
}
.mpe-book-cover { width: 100%; display: block; height: auto; }

/* Badge lecture gratuite sur la couverture */
.mpe-book-cover-badge {
	position: absolute;
	bottom: .875rem;
	left: 50%;
	transform: translateX(-50%);
	white-space: nowrap;
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	padding: .45rem .9rem;
	border-radius: 9999px;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .03em;
	box-shadow: 0 4px 14px rgba(31,155,66,.45);
}

/* Miniatures galerie */
.mpe-book-gallery-thumbs {
	display: flex;
	gap: .5rem;
	margin-top: .75rem;
	flex-wrap: wrap;
}
.mpe-book-thumb {
	width: 3.25rem;
	height: 4rem;
	border-radius: 4px;
	overflow: hidden;
	border: 2px solid transparent;
	background: none;
	cursor: pointer;
	padding: 0;
	transition: border-color .2s;
	flex-shrink: 0;
}
.mpe-book-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mpe-book-thumb.is-active,
.mpe-book-thumb:hover { border-color: var(--mpe-primary); }

/* --- Colonne détails --- */
.mpe-book-cats {
	font-size: .78rem;
	font-weight: 700;
	color: var(--mpe-primary);
	text-transform: uppercase;
	letter-spacing: .06em;
	margin-bottom: .625rem;
}

.mpe-book-title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(1.75rem, 3.5vw, 2.75rem);
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -.02em;
	color: var(--mpe-text-heading);
	margin-bottom: .875rem;
}

.mpe-book-rating { margin-bottom: 1rem; }
/* WooCommerce star override */
.mpe-book-rating .woocommerce-product-rating { display: flex; align-items: center; gap: .5rem; }
.mpe-book-rating .star-rating { font-size: 1rem; }
.mpe-book-rating .woocommerce-review-link { font-size: .8rem; color: var(--mpe-text-muted); }

/* Prix */
.mpe-book-price {
	margin-bottom: 1.25rem;
}
.mpe-book-price .price {
	font-family: var(--mpe-font-heading);
	font-size: 2rem;
	font-weight: 700;
	color: var(--mpe-text-heading);
	line-height: 1;
}
.mpe-book-price .price del {
	font-size: 1.25rem;
	color: var(--mpe-text-muted);
	opacity: .7;
	margin-right: .5rem;
}
.mpe-book-price .price ins { text-decoration: none; color: var(--mpe-primary); }

/* Résumé court */
.mpe-book-short-desc {
	font-size: .9375rem;
	color: var(--mpe-text-muted);
	line-height: 1.75;
	margin-bottom: 1.75rem;
	border-top: 1px solid rgba(0,0,0,.06);
	padding-top: 1.5rem;
}

/* Boutons d'action */
.mpe-book-actions {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	align-items: center;
	margin-bottom: 2rem;
}

/* WooCommerce add-to-cart intégré dans les actions */
.mpe-book-cart-wrap form.cart { display: flex; align-items: center; gap: .625rem; }
.mpe-book-cart-wrap .quantity input {
	width: 4rem;
	text-align: center;
	border: 1px solid rgba(0,0,0,.12);
	border-radius: var(--mpe-radius-sm);
	padding: .625rem .5rem;
	font-size: .9rem;
}
.mpe-book-cart-wrap .single_add_to_cart_button {
	background: var(--mpe-bg-card);
	border: 1px solid rgba(0,0,0,.12);
	color: var(--mpe-text-heading);
	padding: .75rem 1.5rem;
	border-radius: 9999px;
	font-size: .9375rem;
	font-weight: 500;
	cursor: pointer;
	transition: background .2s, transform .2s;
	white-space: nowrap;
}
.mpe-book-cart-wrap .single_add_to_cart_button:hover {
	background: var(--mpe-surface-muted);
	transform: translateY(-1px);
}

/* Méta */
.mpe-book-meta {
	font-size: .8125rem;
	color: var(--mpe-text-muted);
	line-height: 1.7;
	border-top: 1px solid rgba(0,0,0,.06);
	padding-top: 1.25rem;
}
.mpe-book-meta .sku_wrapper,
.mpe-book-meta .posted_in,
.mpe-book-meta .tagged_as { display: block; }
.mpe-book-meta a { color: var(--mpe-primary); }
.mpe-book-meta a:hover { text-decoration: underline; }

/* --- Description longue --- */
.mpe-book-full-desc {
	padding: 4rem 0;
	background: #fff;
	border-top: 1px solid rgba(0,0,0,.06);
}
.mpe-book-desc-title {
	font-family: var(--mpe-font-heading);
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--mpe-text-heading);
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 2px solid rgba(31,155,66,.15);
}

/* --- Produits similaires --- */
.mpe-book-related {
	padding: 4rem 0;
	background: var(--mpe-bg-body);
}
.mpe-book-related-title {
	font-family: var(--mpe-font-heading);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--mpe-text-heading);
	margin-bottom: 2rem;
}
.mpe-book-related-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.25rem;
}
@media (min-width: 640px)  { .mpe-book-related-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .mpe-book-related-grid { grid-template-columns: repeat(4, 1fr); } }

.mpe-book-related-card {
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-md);
	border: 1px solid rgba(0,0,0,.06);
	overflow: hidden;
	transition: transform .25s var(--mpe-ease), box-shadow .25s var(--mpe-ease);
}
.mpe-book-related-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--mpe-shadow-hover);
}
.mpe-book-related-card__img-wrap {
	position: relative;
	aspect-ratio: 2 / 3;
	overflow: hidden;
	background: var(--mpe-surface-muted);
}
.mpe-book-related-card__img-wrap img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .5s var(--mpe-ease);
}
.mpe-book-related-card:hover .mpe-book-related-card__img-wrap img { transform: scale(1.04); }
.mpe-book-related-card__badge {
	position: absolute;
	top: .5rem; left: .5rem;
	padding: .2rem .55rem;
	border-radius: 9999px;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .65rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.mpe-book-related-card__body { padding: .875rem; }
.mpe-book-related-card__title {
	font-size: .875rem;
	font-weight: 600;
	color: var(--mpe-text-heading);
	line-height: 1.35;
	margin-bottom: .4rem;
}
.mpe-book-related-card__title a { color: inherit; }
.mpe-book-related-card__title a:hover { color: var(--mpe-primary); }
.mpe-book-related-card__price { font-size: .8125rem; color: var(--mpe-text-muted); }

/* ==========================================================================
   44. Page Bibliothèque — archive-product (refonte)
   ========================================================================== */

/* ── Hero sombre ── */
.mpe-lib-page { min-height: 100vh; }

.mpe-lib-hero {
	position: relative;
	overflow: hidden;
	background: linear-gradient(135deg, #0d1117 0%, #0f1923 60%, #111827 100%);
	padding: 7rem 0 4rem;
}
.mpe-lib-hero__deco {
	position: absolute;
	border-radius: 9999px;
	pointer-events: none;
}
.mpe-lib-hero__deco--1 {
	top: -10rem; right: -10rem;
	width: 600px; height: 600px;
	background: radial-gradient(circle, rgba(31,155,66,.14), transparent 65%);
}
.mpe-lib-hero__deco--2 {
	bottom: -8rem; left: -8rem;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(227,24,24,.08), transparent 65%);
}
.mpe-lib-hero__deco--3 {
	top: 30%; left: 40%;
	width: 300px; height: 300px;
	background: radial-gradient(circle, rgba(31,155,66,.05), transparent 70%);
}

.mpe-lib-hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	align-items: center;
}
@media (min-width: 900px) {
	.mpe-lib-hero__inner { grid-template-columns: 1fr 1fr; gap: 4rem; }
}

.mpe-lib-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .35rem .875rem;
	border-radius: 9999px;
	background: rgba(31,155,66,.15);
	border: 1px solid rgba(31,155,66,.25);
	font-size: .75rem;
	font-weight: 700;
	color: #34d17a;
	letter-spacing: .06em;
	text-transform: uppercase;
	margin-bottom: 1.25rem;
}
.mpe-lib-hero__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -.03em;
	color: #fff;
	margin-bottom: 1rem;
}
.mpe-lib-hero__desc {
	font-size: 1rem;
	color: rgba(255,255,255,.55);
	line-height: 1.75;
	max-width: 36rem;
}

/* Barre de recherche */
.mpe-lib-search { width: 100%; }
.mpe-lib-search__wrap {
	display: flex;
	align-items: center;
	gap: .5rem;
	background: rgba(255,255,255,.07);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: var(--mpe-radius-pill);
	padding: .5rem .5rem .5rem 1.25rem;
	transition: border-color .2s, background .2s;
}
.mpe-lib-search__wrap:focus-within {
	border-color: rgba(31,155,66,.5);
	background: rgba(255,255,255,.10);
	box-shadow: 0 0 0 3px rgba(31,155,66,.12);
}
.mpe-lib-search__icon { color: rgba(255,255,255,.35); flex-shrink: 0; }
.mpe-lib-search__input {
	flex: 1;
	min-width: 0;
	border: none;
	background: transparent;
	color: #fff;
	font-size: .9375rem;
	outline: none;
}
.mpe-lib-search__input::placeholder { color: rgba(255,255,255,.3); }
.mpe-lib-search__btn {
	flex-shrink: 0;
	padding: .6rem 1.25rem;
	border-radius: 9999px;
	border: none;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .875rem;
	font-weight: 600;
	cursor: pointer;
	transition: background .2s, transform .2s;
}
.mpe-lib-search__btn:hover { background: var(--mpe-primary-dark); transform: scale(1.02); }

.mpe-lib-hero__stats {
	margin-top: .875rem;
	font-size: .8125rem;
	color: rgba(255,255,255,.35);
}
.mpe-lib-hero__stats span {
	font-family: var(--mpe-font-heading);
	font-weight: 700;
	font-size: 1rem;
	color: #34d17a;
}

/* ── Corps : layout sidebar + main ── */
.mpe-lib-body {
	background: var(--mpe-bg-body);
	padding: 3rem 0 5rem;
}
.mpe-lib-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: start;
}
@media (min-width: 1024px) {
	.mpe-lib-layout { grid-template-columns: 220px 1fr; gap: 3rem; }
}

/* ── Sidebar ── */
.mpe-lib-sidebar__inner {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 1.5rem;
}
@media (min-width: 1024px) {
	.mpe-lib-sidebar__inner {
		flex-direction: column;
		position: sticky;
		top: 5.5rem;
	}
}

.mpe-lib-filter-block {
	flex: 1;
	min-width: 140px;
}
.mpe-lib-filter-block__title {
	font-size: .7rem;
	font-weight: 700;
	color: var(--mpe-text-muted);
	letter-spacing: .08em;
	text-transform: uppercase;
	margin-bottom: .75rem;
	padding-bottom: .5rem;
	border-bottom: 1px solid rgba(0,0,0,.06);
}

/* Liste catégories */
.mpe-lib-cat-list { list-style: none; display: flex; flex-direction: column; gap: .25rem; }
.mpe-lib-cat-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
	padding: .45rem .75rem;
	border-radius: var(--mpe-radius-sm);
	font-size: .875rem;
	color: var(--mpe-text-main);
	transition: background .15s, color .15s;
}
.mpe-lib-cat-link:hover { background: rgba(31,155,66,.07); color: var(--mpe-primary); }
.mpe-lib-cat-link.is-active {
	background: rgba(31,155,66,.10);
	color: var(--mpe-primary);
	font-weight: 600;
}
.mpe-lib-cat-link__name { flex: 1; }
.mpe-lib-cat-link__count {
	font-size: .7rem;
	background: rgba(0,0,0,.06);
	border-radius: 9999px;
	padding: .1rem .45rem;
	color: var(--mpe-text-muted);
	font-variant-numeric: tabular-nums;
}
.mpe-lib-cat-link.is-active .mpe-lib-cat-link__count {
	background: rgba(31,155,66,.15);
	color: var(--mpe-primary);
}

/* Disponibilité */
.mpe-lib-avail-list { display: flex; flex-direction: column; gap: .375rem; }
.mpe-lib-avail-item {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .45rem .75rem;
	border-radius: var(--mpe-radius-sm);
	font-size: .875rem;
	color: var(--mpe-text-main);
	border: 1px solid rgba(0,0,0,.08);
	transition: background .15s, border-color .15s, color .15s;
}
.mpe-lib-avail-item:hover { background: rgba(0,0,0,.03); }
.mpe-lib-avail-item--free {
	background: rgba(31,155,66,.07);
	border-color: rgba(31,155,66,.18);
	color: var(--mpe-primary);
}
.mpe-lib-avail-item--free:hover { background: rgba(31,155,66,.12); }

/* Tri */
.mpe-lib-orderby select {
	width: 100%;
	appearance: none;
	-webkit-appearance: none;
	border: 1px solid rgba(0,0,0,.10);
	border-radius: var(--mpe-radius-sm);
	padding: .5rem .875rem;
	font-size: .875rem;
	color: var(--mpe-text-main);
	background: var(--mpe-bg-card);
	cursor: pointer;
}
.mpe-lib-orderby select:focus { outline: 2px solid var(--mpe-primary); outline-offset: 1px; }

/* ── Barre résultats ── */
.mpe-lib-bar {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: 1.5rem;
	font-size: .875rem;
}
.mpe-lib-bar__count { color: var(--mpe-text-muted); }
.mpe-lib-bar__crumb { color: var(--mpe-text-heading); font-weight: 500; }
.mpe-lib-bar__clear {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25rem; height: 1.25rem;
	border-radius: 9999px;
	background: rgba(0,0,0,.08);
	color: var(--mpe-text-muted);
	font-size: .875rem;
	margin-left: .25rem;
	line-height: 1;
	transition: background .15s;
}
.mpe-lib-bar__clear:hover { background: rgba(227,24,24,.12); color: var(--mpe-accent); }

/* ── Grille livres ── */
.mpe-lib-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
}
@media (min-width: 900px)  { .mpe-lib-grid { grid-template-columns: repeat(3, 1fr); } }

/* ── Carte livre ── */
.mpe-book-card {
	background: #fff;
	border-radius: 12px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	box-shadow: 0 1px 3px rgba(0,0,0,.07), 0 4px 14px rgba(0,0,0,.05);
	border: 1px solid rgba(0,0,0,.06);
	transition: transform .3s var(--mpe-ease), box-shadow .3s var(--mpe-ease);
}
.mpe-book-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 20px 50px rgba(0,0,0,.13), 0 6px 18px rgba(0,0,0,.07);
}

/* Couverture */
.mpe-book-card__cover-wrap {
	position: relative;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	background: #e8ecf0;
	flex-shrink: 0;
}
.mpe-book-card__cover-link { display: block; height: 100%; }
.mpe-book-card__cover {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .5s var(--mpe-ease);
}
.mpe-book-card:hover .mpe-book-card__cover { transform: scale(1.05); }

/* Badge statut */
.mpe-book-card__badge {
	position: absolute;
	top: .5rem; right: .5rem;
	display: inline-flex;
	align-items: center;
	gap: .2rem;
	padding: .22rem .5rem;
	border-radius: 9999px;
	font-size: .6rem;
	font-weight: 700;
	letter-spacing: .05em;
	text-transform: uppercase;
	color: #fff;
	z-index: 2;
}
.mpe-book-card__badge--free {
	background: var(--mpe-primary);
	box-shadow: 0 2px 8px rgba(31,155,66,.4);
}
.mpe-book-card__badge--premium {
	background: linear-gradient(135deg,#7c3aed,#6d28d9);
	box-shadow: 0 2px 8px rgba(124,58,237,.4);
}

/* Overlay survol — bouton Lire glisse depuis le bas */
.mpe-book-card__hover-layer {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(10,15,25,.8) 0%, rgba(10,15,25,.15) 55%, transparent 100%);
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 1rem;
	opacity: 0;
	transition: opacity .25s var(--mpe-ease);
	z-index: 3;
}
.mpe-book-card:hover .mpe-book-card__hover-layer { opacity: 1; }
.mpe-book-card__read-cta {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .55rem 1.75rem;
	background: #fff;
	color: var(--mpe-primary);
	border-radius: 9999px;
	font-size: .8rem;
	font-weight: 700;
	font-family: inherit;
	border: none;
	cursor: pointer;
	transform: translateY(10px);
	transition: transform .3s var(--mpe-ease), background .2s;
}
.mpe-book-card:hover .mpe-book-card__read-cta { transform: translateY(0); }
.mpe-book-card__read-cta:hover { background: #f0fdf4; }

/* Corps */
.mpe-book-card__body {
	padding: .875rem 1rem 1rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.mpe-book-card__cat {
	font-size: .6rem;
	font-weight: 700;
	color: var(--mpe-primary);
	text-transform: uppercase;
	letter-spacing: .07em;
	display: block;
	margin-bottom: .35rem;
}
.mpe-book-card__title {
	font-family: var(--mpe-font-heading);
	font-size: .9rem;
	font-weight: 600;
	color: var(--mpe-ink-900);
	line-height: 1.35;
	flex: 1;
	margin: 0 0 .75rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.mpe-book-card__title a { color: inherit; text-decoration: none; }
.mpe-book-card__title a:hover { color: var(--mpe-primary); }

.mpe-book-card__foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
	margin-top: auto;
	padding-top: .625rem;
	border-top: 1px solid rgba(0,0,0,.07);
}
.mpe-book-card__price .price {
	font-size: .9rem;
	font-weight: 700;
	color: var(--mpe-ink-900);
}
.mpe-book-card__price .price ins { text-decoration: none; color: var(--mpe-primary); }
.mpe-book-card__price .price del { opacity: .4; font-size: .75rem; }

.mpe-book-card__buy-btn,
.mpe-book-card__read-btn {
	display: inline-flex;
	align-items: center;
	gap: .25rem;
	padding: .3rem .7rem;
	border-radius: 6px;
	font-size: .72rem;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
	border: none;
	text-decoration: none;
	white-space: nowrap;
	transition: background .15s, transform .15s;
}
.mpe-book-card__buy-btn {
	background: var(--mpe-primary);
	color: #fff;
}
.mpe-book-card__buy-btn:hover {
	background: #178038;
	transform: translateY(-1px);
}
.mpe-book-card__read-btn {
	background: rgba(31,155,66,.1);
	color: var(--mpe-primary);
}
.mpe-book-card__read-btn:hover {
	background: rgba(31,155,66,.18);
	transform: translateY(-1px);
}

/* Bouton "Voir dans le panier" */
.mpe-book-card__buy-btn--in-cart {
	background: transparent;
	color: var(--mpe-primary);
	border: 1.5px solid var(--mpe-primary);
}
.mpe-book-card__buy-btn--in-cart:hover {
	background: rgba(31,155,66,.08);
	transform: translateY(-1px);
}

/* Page produit — bouton "Voir dans le panier" */
.mpe-book-actions--dual .single_add_to_cart_button.mpe-btn--in-cart {
	background: transparent;
	color: var(--mpe-primary);
	border-color: var(--mpe-primary);
}
.mpe-book-actions--dual .single_add_to_cart_button.mpe-btn--in-cart:hover {
	background: rgba(31,155,66,.08);
	transform: translateY(-1px);
}

/* Meta : auteur + extrait */
.mpe-book-card__meta {
	margin-bottom: .5rem;
	display: flex;
	flex-direction: column;
	gap: .25rem;
}
.mpe-book-card__author {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	font-size: .68rem;
	font-weight: 600;
	color: var(--mpe-text-muted, #6b7280);
}
.mpe-book-card__excerpt {
	font-size: .7rem;
	color: var(--mpe-text-muted, #6b7280);
	line-height: 1.45;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	line-clamp: 2;
	overflow: hidden;
}

/* ── Pagination ── */
.mpe-lib-pagination {
	margin-top: 3.5rem;
	display: flex;
	justify-content: center;
}
.mpe-lib-pagination .woocommerce-pagination ul {
	display: flex;
	flex-wrap: wrap;
	gap: .375rem;
	list-style: none;
	padding: 0; margin: 0;
	align-items: center;
}
.mpe-lib-pagination .woocommerce-pagination li a,
.mpe-lib-pagination .woocommerce-pagination li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.375rem; height: 2.375rem;
	border-radius: var(--mpe-radius-sm);
	border: 1px solid rgba(0,0,0,.10);
	font-size: .9rem;
	font-weight: 500;
	color: var(--mpe-text-heading);
	transition: background .2s, border-color .2s;
}
.mpe-lib-pagination .woocommerce-pagination li a:hover {
	background: rgba(31,155,66,.08);
	border-color: rgba(31,155,66,.25);
	color: var(--mpe-primary);
}
.mpe-lib-pagination .woocommerce-pagination li span.current {
	background: var(--mpe-primary);
	border-color: var(--mpe-primary);
	color: #fff;
}

/* ── Écran vide ── */
.mpe-lib-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding: 5rem 2rem;
	text-align: center;
	color: var(--mpe-text-muted);
}
.mpe-lib-empty h2 { font-size: 1.25rem; color: var(--mpe-text-heading); }
.mpe-lib-empty p { max-width: 28rem; line-height: 1.65; }

/* --- Ancien CSS .mpe-shop-* conservé pour compatibilité (non utilisé dans les templates) --- */
.mpe-shop-hero {
	position: relative;
	overflow: hidden;
	padding: 6.5rem 0 3rem;
	background: linear-gradient(160deg, rgba(31,155,66,.06) 0%, var(--mpe-bg-body) 60%);
}
.mpe-shop-hero__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.mpe-shop-hero__circle {
	position: absolute;
	border-radius: 9999px;
}
.mpe-shop-hero__circle--1 {
	top: -10rem; right: -8rem;
	width: 520px; height: 520px;
	background: radial-gradient(circle, rgba(31,155,66,.10), transparent 65%);
}
.mpe-shop-hero__circle--2 {
	bottom: -6rem; left: -6rem;
	width: 380px; height: 380px;
	background: radial-gradient(circle, rgba(227,24,24,.05), transparent 65%);
}

.mpe-shop-hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: center;
}
@media (min-width: 1024px) {
	.mpe-shop-hero__inner { grid-template-columns: 1fr auto; gap: 3rem; }
}

.mpe-shop-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	padding: .3rem .8rem;
	border-radius: 9999px;
	background: rgba(31,155,66,.10);
	border: 1px solid rgba(31,155,66,.18);
	font-size: .75rem;
	font-weight: 700;
	color: var(--mpe-primary);
	letter-spacing: .05em;
	text-transform: uppercase;
	margin-bottom: .875rem;
}
.mpe-shop-hero__eyebrow-dot {
	width: .4rem; height: .4rem;
	border-radius: 9999px;
	background: var(--mpe-primary);
}

.mpe-shop-hero__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -.03em;
	color: var(--mpe-text-heading);
	margin-bottom: .75rem;
}

.mpe-shop-hero__desc {
	font-size: 1rem;
	color: var(--mpe-text-muted);
	line-height: 1.7;
	max-width: 40rem;
}

/* Barre de recherche dans le hero */
.mpe-shop-search { width: 100%; max-width: 26rem; }
@media (min-width: 1024px) { .mpe-shop-search { width: 22rem; flex-shrink: 0; } }

.mpe-shop-search__inner {
	display: flex;
	align-items: center;
	gap: .5rem;
	background: var(--mpe-bg-card);
	border: 1px solid rgba(0,0,0,.10);
	border-radius: var(--mpe-radius-pill);
	padding: .4rem .4rem .4rem 1rem;
	box-shadow: var(--mpe-shadow-sm);
	transition: border-color .2s, box-shadow .2s;
}
.mpe-shop-search__inner:focus-within {
	border-color: rgba(31,155,66,.4);
	box-shadow: 0 0 0 3px rgba(31,155,66,.12);
}
.mpe-shop-search__icon { color: var(--mpe-text-muted); flex-shrink: 0; }
.mpe-shop-search__input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: .875rem;
	color: var(--mpe-text-heading);
	outline: none;
	min-width: 0;
}
.mpe-shop-search__input::placeholder { color: var(--mpe-text-muted); }

/* --- Barre de filtres --- */
.mpe-shop-toolbar {
	background: var(--mpe-bg-card);
	border-bottom: 1px solid rgba(0,0,0,.06);
	position: sticky;
	top: 4rem;
	z-index: 20;
}
.mpe-shop-toolbar__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .75rem 1.5rem;
	padding: .75rem 0;
}

.mpe-shop-toolbar__count {
	font-size: .8125rem;
	color: var(--mpe-text-muted);
	white-space: nowrap;
	flex-shrink: 0;
}

.mpe-shop-filters {
	display: flex;
	flex-wrap: wrap;
	gap: .375rem;
	flex: 1;
}

.mpe-shop-filter {
	display: inline-flex;
	align-items: center;
	padding: .3rem .875rem;
	border-radius: 9999px;
	border: 1px solid rgba(0,0,0,.10);
	background: transparent;
	font-size: .8rem;
	font-weight: 500;
	color: var(--mpe-text-muted);
	transition: background .2s, border-color .2s, color .2s;
	white-space: nowrap;
}
.mpe-shop-filter:hover {
	background: rgba(31,155,66,.06);
	border-color: rgba(31,155,66,.25);
	color: var(--mpe-primary);
}
.mpe-shop-filter--active {
	background: var(--mpe-primary);
	border-color: var(--mpe-primary);
	color: #fff;
}
.mpe-shop-filter--active:hover {
	background: var(--mpe-primary-dark);
	border-color: var(--mpe-primary-dark);
	color: #fff;
}

/* Tri WooCommerce natif */
.mpe-shop-orderby select {
	appearance: none;
	-webkit-appearance: none;
	background: transparent;
	border: 1px solid rgba(0,0,0,.10);
	border-radius: var(--mpe-radius-sm);
	padding: .3rem .75rem;
	font-size: .8rem;
	color: var(--mpe-text-muted);
	cursor: pointer;
}
.mpe-shop-orderby select:focus { outline: 2px solid var(--mpe-primary); outline-offset: 1px; }

/* --- Zone principale --- */
.mpe-shop-main {
	padding: 2.5rem 0 5rem;
	background: var(--mpe-bg-body);
}

/* --- Grille de livres --- */
.mpe-shop-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.25rem;
}
@media (min-width: 640px)  { .mpe-shop-grid { grid-template-columns: repeat(3, 1fr); gap: 1.5rem; } }
@media (min-width: 1024px) { .mpe-shop-grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1280px) { .mpe-shop-grid { grid-template-columns: repeat(5, 1fr); } }

/* --- Carte livre --- */
.mpe-book-card {
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-md);
	border: 1px solid rgba(0,0,0,.06);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .25s var(--mpe-ease), box-shadow .25s var(--mpe-ease);
}
.mpe-book-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(0,0,0,.12);
}

/* Couverture */
.mpe-book-card__cover-wrap {
	position: relative;
	aspect-ratio: 2 / 3;
	overflow: hidden;
	background: var(--mpe-surface-muted);
	flex-shrink: 0;
}
.mpe-book-card__cover-link { display: block; height: 100%; }
.mpe-book-card__cover {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .5s var(--mpe-ease);
}
.mpe-book-card:hover .mpe-book-card__cover { transform: scale(1.04); }

/* Badge "Gratuit" */
.mpe-book-card__free-badge {
	position: absolute;
	top: .5rem; left: .5rem;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	gap: .25rem;
	padding: .2rem .5rem;
	border-radius: 9999px;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .65rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	box-shadow: 0 2px 6px rgba(31,155,66,.4);
}

/* Overlay au survol */
.mpe-book-card__overlay {
	position: absolute;
	inset: 0;
	background: rgba(15,23,42,.55);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	opacity: 0;
	transition: opacity .25s var(--mpe-ease);
	z-index: 3;
}
.mpe-book-card:hover .mpe-book-card__overlay { opacity: 1; }

.mpe-book-card__overlay-btn {
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	padding: .5rem 1rem;
	border-radius: 9999px;
	font-size: .8rem;
	font-weight: 600;
	transition: transform .15s;
	text-decoration: none;
}
.mpe-book-card__overlay-btn:hover { transform: scale(1.05); }
.mpe-book-card__overlay-btn--read {
	background: var(--mpe-primary);
	color: #fff;
}
.mpe-book-card__overlay-btn--view {
	background: rgba(255,255,255,.15);
	border: 1px solid rgba(255,255,255,.3);
	color: #fff;
}

/* Corps de la carte */
.mpe-book-card__body {
	padding: .75rem .875rem .875rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.mpe-book-card__cat {
	font-size: .65rem;
	font-weight: 700;
	color: var(--mpe-primary);
	text-transform: uppercase;
	letter-spacing: .05em;
	display: block;
	margin-bottom: .3rem;
}
.mpe-book-card__title {
	font-family: var(--mpe-font-heading);
	font-size: .875rem;
	font-weight: 600;
	color: var(--mpe-text-heading);
	line-height: 1.3;
	flex: 1;
	margin: 0 0 .625rem;
}
.mpe-book-card__title a { color: inherit; }
.mpe-book-card__title a:hover { color: var(--mpe-primary); }

.mpe-book-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
	border-top: 1px solid rgba(0,0,0,.05);
	padding-top: .5rem;
	margin-top: auto;
}
.mpe-book-card__price .price {
	font-size: .875rem;
	font-weight: 700;
	color: var(--mpe-text-heading);
}
.mpe-book-card__price .price ins { text-decoration: none; color: var(--mpe-primary); }
.mpe-book-card__price .price del { opacity: .5; font-size: .75rem; }

.mpe-book-card__read-link {
	display: inline-flex;
	align-items: center;
	gap: .25rem;
	font-size: .75rem;
	font-weight: 600;
	color: var(--mpe-primary);
	white-space: nowrap;
	transition: gap .15s;
}
.mpe-book-card__read-link:hover { gap: .4rem; }

/* --- Pagination boutique --- */
.mpe-shop-pagination {
	margin-top: 3rem;
	display: flex;
	justify-content: center;
}
.mpe-shop-pagination .woocommerce-pagination ul {
	display: flex;
	flex-wrap: wrap;
	gap: .375rem;
	list-style: none;
	padding: 0;
	margin: 0;
	align-items: center;
}
.mpe-shop-pagination .woocommerce-pagination li a,
.mpe-shop-pagination .woocommerce-pagination li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: var(--mpe-radius-sm);
	border: 1px solid rgba(0,0,0,.10);
	font-size: .875rem;
	font-weight: 500;
	color: var(--mpe-text-heading);
	transition: background .2s, border-color .2s;
}
.mpe-shop-pagination .woocommerce-pagination li a:hover {
	background: rgba(31,155,66,.08);
	border-color: rgba(31,155,66,.25);
	color: var(--mpe-primary);
}
.mpe-shop-pagination .woocommerce-pagination li span.current {
	background: var(--mpe-primary);
	border-color: var(--mpe-primary);
	color: #fff;
}

/* --- Écran vide --- */
.mpe-shop-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.25rem;
	padding: 5rem 2rem;
	text-align: center;
	color: var(--mpe-text-muted);
}
.mpe-shop-empty p { font-size: 1rem; max-width: 28rem; line-height: 1.6; }

/* ==========================================================================
   45. Section Bibliyotèk — front-page dynamique
   ========================================================================== */
.mpe-fp-biblio {
	background: linear-gradient(160deg, #0d1117 0%, #1a202c 100%);
	padding-block: 5rem;
	position: relative;
	overflow: hidden;
}
.mpe-fp-biblio__deco {
	position: absolute;
	border-radius: 9999px;
	pointer-events: none;
}
.mpe-fp-biblio__deco--1 {
	top: -8rem; right: -8rem;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(31,155,66,.12), transparent 65%);
}
.mpe-fp-biblio__deco--2 {
	bottom: -6rem; left: -6rem;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(227,24,24,.07), transparent 65%);
}

.mpe-fp-biblio__head {
	position: relative;
	z-index: 1;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 2.5rem;
}
.mpe-fp-biblio__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	padding: .3rem .8rem;
	border-radius: 9999px;
	background: rgba(31,155,66,.15);
	border: 1px solid rgba(31,155,66,.25);
	font-size: .75rem;
	font-weight: 700;
	color: #34d17a;
	letter-spacing: .06em;
	text-transform: uppercase;
	margin-bottom: .875rem;
}
.mpe-fp-biblio__eyebrow-dot {
	width: .4rem; height: .4rem;
	border-radius: 9999px;
	background: #34d17a;
}
.mpe-fp-biblio__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -.025em;
	color: #fff;
}
.mpe-fp-biblio__title span { color: #34d17a; }
.mpe-fp-biblio__view-all {
	display: inline-flex;
	align-items: center;
	gap: .375rem;
	padding: .55rem 1.25rem;
	border-radius: 9999px;
	border: 1px solid rgba(255,255,255,.15);
	background: rgba(255,255,255,.06);
	color: rgba(255,255,255,.8);
	font-size: .875rem;
	font-weight: 500;
	transition: background .2s, border-color .2s;
	flex-shrink: 0;
}
.mpe-fp-biblio__view-all:hover {
	background: rgba(255,255,255,.12);
	border-color: rgba(255,255,255,.25);
	color: #fff;
}

/* Grille livres front-page */
.mpe-fp-biblio__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}
@media (min-width: 640px)  { .mpe-fp-biblio__grid { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; } }
@media (min-width: 1024px) { .mpe-fp-biblio__grid { grid-template-columns: repeat(4, 1fr); gap: 1.5rem; } }

/* Carte livre (dark) */
.mpe-fp-book-card {
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.08);
	border-radius: var(--mpe-radius-md);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .25s var(--mpe-ease), background .25s var(--mpe-ease), border-color .25s;
}
.mpe-fp-book-card:hover {
	transform: translateY(-4px);
	background: rgba(255,255,255,.10);
	border-color: rgba(31,155,66,.30);
}

.mpe-fp-book-card__cover-wrap {
	position: relative;
	aspect-ratio: 2 / 3;
	overflow: hidden;
	background: rgba(255,255,255,.04);
}
.mpe-fp-book-card__cover {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .5s var(--mpe-ease);
}
.mpe-fp-book-card:hover .mpe-fp-book-card__cover { transform: scale(1.05); }

.mpe-fp-book-card__free {
	position: absolute;
	top: .5rem; left: .5rem;
	display: inline-flex;
	align-items: center;
	gap: .25rem;
	padding: .2rem .5rem;
	border-radius: 9999px;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .625rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
}

.mpe-fp-book-card__body {
	padding: .75rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.mpe-fp-book-card__title {
	font-size: .8125rem;
	font-weight: 600;
	color: rgba(255,255,255,.9);
	line-height: 1.35;
	margin-bottom: .5rem;
	flex: 1;
}
.mpe-fp-book-card__title a { color: inherit; }
.mpe-fp-book-card__title a:hover { color: #34d17a; }
.mpe-fp-book-card__price {
	font-size: .8rem;
	color: rgba(255,255,255,.45);
}
.mpe-fp-book-card__price .price { color: rgba(255,255,255,.7); }
.mpe-fp-book-card__price ins { text-decoration: none; color: #34d17a; }

/* ==========================================================================
   46. Double boutons Lire / Acheter — single-product & cards
   ========================================================================== */

/* --- Page produit --- */
.mpe-book-actions--dual {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	align-items: stretch;
	margin-bottom: .75rem;
}

/* Bouton Lire en ligne (peut être <button> ou <a>) */
.mpe-btn--read {
	flex: 1;
	justify-content: center;
	min-width: 10rem;
	cursor: pointer;
	border: none;
	font-family: inherit;
}

/* WC add-to-cart dans le double bouton */
.mpe-book-actions--dual .mpe-book-cart-wrap { flex: 1; min-width: 10rem; }
.mpe-book-actions--dual .mpe-book-cart-wrap form.cart {
	display: block;
	width: 100%;
	height: 100%;
}
/* Neutralise WooCommerce .button.alt global styles */
.mpe-book-actions--dual .single_add_to_cart_button,
.mpe-book-actions--dual .single_add_to_cart_button.button,
.mpe-book-actions--dual .single_add_to_cart_button.alt {
	all: unset;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	width: 100%;
	height: 100%;
	min-height: 3rem;
	padding: .875rem 1.5rem;
	background: var(--mpe-bg-card);
	border: 1.5px solid rgba(0,0,0,.14);
	border-radius: 9999px;
	color: var(--mpe-text-heading);
	font-family: inherit;
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	white-space: nowrap;
	transition: background .2s, transform .2s, border-color .2s;
}
.mpe-book-actions--dual .single_add_to_cart_button:hover {
	background: var(--mpe-surface-muted);
	transform: translateY(-1px);
	border-color: rgba(0,0,0,.22);
}
/* Indisponible */
.mpe-out-of-stock {
	font-size: .875rem;
	color: #6b7280;
	padding: .5rem 0;
}

/* Note protection */
.mpe-book-protected-note {
	display: flex;
	align-items: center;
	gap: .4rem;
	font-size: .78rem;
	color: var(--mpe-text-muted);
	padding: .5rem .75rem;
	border-radius: var(--mpe-radius-sm);
	background: rgba(0,0,0,.03);
	border: 1px solid rgba(0,0,0,.06);
	width: fit-content;
}
.mpe-book-protected-note svg { color: var(--mpe-primary); flex-shrink: 0; }


/* ================================================================
   MODALE LISEUSE PDF — MPE Reader Modal
   ================================================================ */

.mpe-rdr-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
}
.mpe-rdr-modal[hidden] { display: none; }

.mpe-rdr-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.82);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}

.mpe-rdr-modal__panel {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	width: min(96vw, 1100px);
	height: min(94vh, 860px);
	background: #0d1117;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 32px 80px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.07);
}

/* Topbar */
.mpe-rdr-modal__topbar {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 0 1.25rem;
	height: 3.25rem;
	background: rgba(22,27,34,.97);
	border-bottom: 1px solid rgba(255,255,255,.08);
}

.mpe-rdr-modal__brand {
	display: flex;
	align-items: center;
	gap: .625rem;
	min-width: 0;
}
.mpe-rdr-modal__logo {
	flex-shrink: 0;
	width: 1.6rem; height: 1.6rem;
	background: linear-gradient(135deg, #1F9B42, #167330);
	border-radius: 5px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: .65rem;
	font-weight: 700;
	color: #fff;
}
.mpe-rdr-modal__book-title {
	font-size: .8rem;
	font-weight: 500;
	color: rgba(255,255,255,.75);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 22rem;
}

.mpe-rdr-modal__controls {
	display: flex;
	align-items: center;
	gap: .375rem;
	flex-shrink: 0;
}

.mpe-rdr-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .35rem;
	height: 1.875rem;
	padding: 0 .75rem;
	border-radius: 6px;
	border: 1px solid rgba(255,255,255,.12);
	background: rgba(255,255,255,.06);
	color: rgba(255,255,255,.8);
	font-size: .78rem;
	font-weight: 500;
	cursor: pointer;
	transition: background .15s, border-color .15s;
	font-family: inherit;
}
.mpe-rdr-btn:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); }
.mpe-rdr-btn--icon { width: 1.875rem; padding: 0; }
.mpe-rdr-btn--close { color: rgba(255,100,100,.85); border-color: rgba(255,80,80,.2); }
.mpe-rdr-btn--close:hover { background: rgba(255,80,80,.12); }

.mpe-rdr-zoom-label {
	font-size: .72rem;
	color: rgba(255,255,255,.4);
	min-width: 2.75rem;
	text-align: center;
}

.mpe-rdr-divider {
	width: 1px;
	height: 1.25rem;
	background: rgba(255,255,255,.1);
	margin: 0 .125rem;
}

/* Watermark */
.mpe-rdr-modal__watermark {
	flex-shrink: 0;
	padding: .3rem 1rem;
	background: rgba(10,15,25,.8);
	color: rgba(255,255,255,.3);
	font-size: .66rem;
	text-align: center;
	letter-spacing: .05em;
	user-select: none;
	-webkit-user-select: none;
	pointer-events: none;
	border-bottom: 1px solid rgba(255,255,255,.05);
}

/* Canvas zone */
.mpe-rdr-modal__canvas-wrap {
	flex: 1;
	overflow: auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	padding: 1.5rem 1rem;
	background: #161b22;
	user-select: none;
	-webkit-user-select: none;
}
.mpe-rdr-modal__canvas-wrap canvas {
	display: block;
	box-shadow: 0 8px 40px rgba(0,0,0,.55);
	background: #fff;
	flex-shrink: 0;
}

/* Loader — [hidden] doit l'emporter sur display:flex */
.mpe-rdr-modal__loader[hidden],
.mpe-rdr-modal__error[hidden],
.mpe-auth-gate[hidden] { display: none !important; }

.mpe-rdr-modal__loader {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	margin: auto;
	padding: 3rem;
	color: rgba(255,255,255,.4);
	font-size: .875rem;
}
.mpe-rdr-modal__loader-ring {
	width: 2.5rem; height: 2.5rem;
	border: 3px solid rgba(255,255,255,.1);
	border-top-color: #1F9B42;
	border-radius: 9999px;
	animation: mpe-rdr-spin .8s linear infinite;
}
@keyframes mpe-rdr-spin { to { transform: rotate(360deg); } }

/* Error */
.mpe-rdr-modal__error {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .75rem;
	margin: auto;
	padding: 3rem 2rem;
	color: rgba(255,150,150,.8);
	font-size: .875rem;
	text-align: center;
	line-height: 1.6;
}
.mpe-rdr-modal__error[hidden] { display: none; }

/* Pager */
.mpe-rdr-modal__pager {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .875rem;
	padding: .6rem 1rem;
	background: rgba(22,27,34,.97);
	border-top: 1px solid rgba(255,255,255,.08);
	font-size: .8rem;
	color: rgba(255,255,255,.5);
}
.mpe-rdr-modal__pager-info {
	display: flex;
	align-items: center;
	gap: .4rem;
}

.mpe-rdr-page-input {
	width: 3rem;
	text-align: center;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 5px;
	color: #fff;
	font-size: .8rem;
	padding: .2rem .3rem;
	font-family: inherit;
}
.mpe-rdr-page-input:focus { outline: 2px solid #1F9B42; outline-offset: 1px; }

/* Bloquer impression */
@media print {
	.mpe-rdr-modal { display: none !important; }
}

@media (max-width: 600px) {
	.mpe-rdr-modal__panel {
		width: 100vw;
		height: 100dvh;
		border-radius: 0;
	}
	.mpe-rdr-modal__book-title { max-width: 8rem; }
}

/* ================================================================
   PAGE CONNEXION / INSCRIPTION
   ================================================================ */

/* ==========================================================================
   AUTH PAGE — Connexion / Inscription (split-screen redesign)
   ========================================================================== */

.mpe-auth {
	display: grid;
	grid-template-columns: 1fr;
	min-height: 100vh;
}
@media (min-width: 900px) {
	.mpe-auth { grid-template-columns: 480px 1fr; }
}

/* ── Left hero panel ── */
.mpe-auth__hero {
	display: none;
	background: linear-gradient(150deg, #1a7a36 0%, #1F9B42 55%, #25b84e 100%);
	position: relative;
	overflow: hidden;
}
@media (min-width: 900px) { .mpe-auth__hero { display: flex; } }

.mpe-auth__hero-inner {
	display: flex;
	flex-direction: column;
	padding: 3rem 2.5rem;
	height: 100%;
	position: relative;
	z-index: 1;
}

/* Logo */
.mpe-auth__logo {
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	text-decoration: none;
}
.mpe-auth__logo-img { max-height: 2.5rem; width: auto; filter: brightness(0) invert(1); }
.mpe-auth__logo-badge {
	background: rgba(255,255,255,.2);
	color: #fff;
	font-weight: 800;
	font-size: .9rem;
	padding: .25rem .6rem;
	border-radius: 8px;
	letter-spacing: .05em;
}
.mpe-auth__logo-name {
	color: #fff;
	font-size: 1.1rem;
	font-weight: 700;
}

/* Hero body */
.mpe-auth__hero-body {
	margin-top: clamp(2rem, 8vh, 5rem);
	padding-bottom: 1rem;
}
.mpe-auth__hero-title {
	font-size: 2rem;
	font-weight: 800;
	color: #fff;
	line-height: 1.15;
	margin-bottom: .75rem;
	letter-spacing: -.02em;
}
.mpe-auth__hero-sub {
	font-size: 1rem;
	color: rgba(255,255,255,.8);
	line-height: 1.65;
	margin-bottom: 2rem;
}
.mpe-auth__hero-features {
	list-style: none;
	padding: 0; margin: 0;
	display: flex;
	flex-direction: column;
	gap: .75rem;
}
.mpe-auth__hero-features li {
	display: flex;
	align-items: center;
	gap: .6rem;
	color: rgba(255,255,255,.9);
	font-size: .9rem;
	font-weight: 500;
}
.mpe-auth__hero-features svg { flex-shrink: 0; color: #fff; }

/* Deco circles */
.mpe-auth__hero-deco {
	position: absolute;
	border-radius: 9999px;
	background: rgba(255,255,255,.07);
	pointer-events: none;
}
.mpe-auth__hero-deco--1 { width: 500px; height: 500px; top: -180px; right: -180px; }
.mpe-auth__hero-deco--2 { width: 300px; height: 300px; bottom: -80px; left: -80px; background: rgba(0,0,0,.08); }
.mpe-auth__hero-deco--3 { width: 160px; height: 160px; top: 40%; right: 2rem; background: rgba(255,255,255,.05); }

/* ── Right form pane ── */
.mpe-auth__form-pane {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f9fafb;
	padding: 2rem 1rem;
}

.mpe-auth__form-inner {
	width: 100%;
	max-width: 420px;
}

/* Back link */
.mpe-auth__back {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	color: #6b7280;
	font-size: .8rem;
	text-decoration: none;
	margin-bottom: 2rem;
	transition: color .15s;
}
.mpe-auth__back:hover { color: var(--mpe-primary); }

/* Mobile brand (hidden on desktop where hero shows) */
.mpe-auth__mobile-brand {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: 1.5rem;
}
@media (min-width: 900px) { .mpe-auth__mobile-brand { display: none; } }
.mpe-auth__mobile-badge {
	background: var(--mpe-primary);
	color: #fff;
	font-weight: 800;
	font-size: .85rem;
	padding: .2rem .55rem;
	border-radius: 7px;
}
.mpe-auth__mobile-name {
	font-size: 1rem;
	font-weight: 700;
	color: #111827;
}

/* ── Tabs ── */
.mpe-auth__tabs {
	position: relative;
	display: flex;
	background: #e5e7eb;
	border-radius: 10px;
	padding: 4px;
	margin-bottom: 1.75rem;
}
.mpe-auth__tab {
	position: relative;
	z-index: 1;
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: .55rem 1rem;
	background: none;
	border: none;
	font-size: .875rem;
	font-weight: 600;
	color: #6b7280;
	cursor: pointer;
	border-radius: 7px;
	transition: color .2s;
	font-family: inherit;
	white-space: nowrap;
}
.mpe-auth__tab.is-active { color: #111827; }
.mpe-auth__tab-indicator {
	position: absolute;
	top: 4px; bottom: 4px;
	left: 4px;
	width: calc(50% - 4px);
	background: #fff;
	border-radius: 7px;
	box-shadow: 0 1px 4px rgba(0,0,0,.12);
	transition: transform .25s cubic-bezier(.4,0,.2,1);
	pointer-events: none;
}

/* ── Panels ── */
.mpe-auth__panel { display: none; }
.mpe-auth__panel.is-active { display: block; }

.mpe-auth__panel-desc {
	font-size: .875rem;
	color: #6b7280;
	margin-bottom: 1.5rem;
	line-height: 1.6;
}

/* ── Fields (custom register form) ── */
.mpe-auth__field { margin-bottom: 1.1rem; }
.mpe-auth__label {
	display: block;
	font-size: .82rem;
	font-weight: 600;
	color: #374151;
	margin-bottom: .4rem;
}
.mpe-auth__required { color: #ef4444; margin-left: .15rem; }
.mpe-auth__input-wrap {
	position: relative;
}
.mpe-auth__input-icon {
	position: absolute;
	left: .85rem;
	top: 50%;
	transform: translateY(-50%);
	color: #9ca3af;
	pointer-events: none;
}
.mpe-auth__input {
	width: 100%;
	padding: .7rem .875rem .7rem 2.5rem;
	border: 1.5px solid #d1d5db;
	border-radius: 9px;
	font-size: .9rem;
	font-family: inherit;
	color: #111827;
	background: #fff;
	transition: border-color .15s, box-shadow .15s;
	box-sizing: border-box;
}
.mpe-auth__input:focus {
	outline: none;
	border-color: var(--mpe-primary);
	box-shadow: 0 0 0 3px rgba(31,155,66,.12);
}

/* WooCommerce login form fields harmonised */
.mpe-auth__panel .woocommerce-form__label,
.mpe-auth__panel label {
	display: block;
	font-size: .82rem;
	font-weight: 600;
	color: #374151;
	margin-bottom: .4rem;
}
.mpe-auth__panel .woocommerce-form__input,
.mpe-auth__panel input[type="text"],
.mpe-auth__panel input[type="email"],
.mpe-auth__panel input[type="password"] {
	width: 100%;
	padding: .7rem .875rem;
	border: 1.5px solid #d1d5db;
	border-radius: 9px;
	font-size: .9rem;
	font-family: inherit;
	color: #111827;
	background: #fff;
	transition: border-color .15s, box-shadow .15s;
	box-sizing: border-box;
}
/* Restore left padding for icon inputs (overrides the generic rule above) */
.mpe-auth__input-wrap > input.mpe-auth__input {
	padding-left: 2.5rem;
}
.mpe-auth__panel input[type="text"]:focus,
.mpe-auth__panel input[type="email"]:focus,
.mpe-auth__panel input[type="password"]:focus {
	outline: none;
	border-color: var(--mpe-primary);
	box-shadow: 0 0 0 3px rgba(31,155,66,.12);
}
.mpe-auth__panel .form-row { margin-bottom: 1.1rem; }
.mpe-auth__panel .woocommerce-form__input-checkbox { width: auto; margin-right: .4rem; }

/* Remember me row */
.mpe-auth__panel .woocommerce-form__label-for-checkbox {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: .82rem;
	font-weight: 500;
	cursor: pointer;
}

/* Lost password */
.mpe-auth__panel .woocommerce-LostPassword {
	margin-top: .5rem;
	text-align: right;
}
.mpe-auth__panel .woocommerce-LostPassword a {
	font-size: .8rem;
	color: var(--mpe-primary);
	text-decoration: none;
}
.mpe-auth__panel .woocommerce-LostPassword a:hover { text-decoration: underline; }

/* Submit buttons */
.mpe-auth__submit,
.mpe-auth__panel .woocommerce-Button,
.mpe-auth__panel button[name="login"],
.mpe-auth__panel input[type="submit"] {
	width: 100%;
	padding: .8rem 1.5rem;
	background: var(--mpe-primary);
	color: #fff;
	border: none;
	border-radius: 9px;
	font-size: .95rem;
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
	transition: background .15s, transform .1s, box-shadow .15s;
	margin-top: .25rem;
	box-shadow: 0 2px 8px rgba(31,155,66,.25);
}
.mpe-auth__submit:hover,
.mpe-auth__panel .woocommerce-Button:hover,
.mpe-auth__panel button[name="login"]:hover,
.mpe-auth__panel input[type="submit"]:hover {
	background: #178038;
	transform: translateY(-1px);
	box-shadow: 0 4px 14px rgba(31,155,66,.35);
}

/* Switch link below form */
.mpe-auth__switch {
	text-align: center;
	margin-top: 1.5rem;
	font-size: .82rem;
	color: #6b7280;
}
.mpe-auth__switch-btn {
	background: none;
	border: none;
	color: var(--mpe-primary);
	font-weight: 600;
	cursor: pointer;
	font-size: inherit;
	font-family: inherit;
	padding: 0;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.mpe-auth__switch-btn:hover { color: #178038; }

/* ── Deux colonnes prénom / nom ── */
.mpe-auth__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .75rem;
}

/* ── Bouton afficher/masquer mot de passe ── */
.mpe-auth__input--pw { padding-right: 2.8rem; }
.mpe-auth__pw-toggle {
	position: absolute;
	right: .7rem; top: 50%;
	transform: translateY(-50%);
	background: none; border: none; padding: 0;
	color: #9ca3af; cursor: pointer;
	display: flex; align-items: center;
	transition: color .15s;
}
.mpe-auth__pw-toggle:hover { color: var(--mpe-primary); }
.mpe-auth__pw-toggle.is-visible { color: var(--mpe-primary); }

/* ── Indicateur force du mot de passe ── */
.mpe-auth__strength { margin-top: .6rem; }
.mpe-auth__strength-bar {
	height: 5px; border-radius: 3px;
	background: #e5e7eb; overflow: hidden;
	margin-bottom: .5rem;
}
.mpe-auth__strength-fill {
	height: 100%; border-radius: 3px; width: 0;
	transition: width .3s ease, background-color .3s ease;
}
.mpe-auth__strength-fill[data-level="1"] { width: 25%; background: #ef4444; }
.mpe-auth__strength-fill[data-level="2"] { width: 50%; background: #f97316; }
.mpe-auth__strength-fill[data-level="3"] { width: 75%; background: #eab308; }
.mpe-auth__strength-fill[data-level="4"] { width: 100%; background: #22c55e; }
.mpe-auth__strength-rules {
	display: flex; flex-wrap: wrap; gap: .3rem .8rem;
}
.mpe-auth__strength-rule {
	display: inline-flex; align-items: center; gap: .25rem;
	font-size: .72rem; color: #d1d5db;
	transition: color .2s;
}
.mpe-auth__strength-rule svg { flex-shrink: 0; }
.mpe-auth__strength-rule.ok { color: #22c55e; }

/* ── Correspondance mots de passe ── */
.mpe-auth__match-hint {
	margin-top: .4rem; font-size: .76rem; font-weight: 600;
}
.mpe-auth__match-hint.ok  { color: #22c55e; }
.mpe-auth__match-hint.err { color: #ef4444; }

/* ── Note vérification e-mail ── */
.mpe-auth__verify-note {
	display: flex; align-items: flex-start; gap: .45rem;
	font-size: .78rem; color: #6b7280;
	background: #f0fdf4; border: 1px solid #bbf7d0;
	border-radius: 8px; padding: .6rem .85rem;
	margin-bottom: 1rem; line-height: 1.5;
}
.mpe-auth__verify-note svg { flex-shrink: 0; margin-top: .1rem; color: var(--mpe-primary); }

/* ── Notices système (vérification email confirmée / erreur) ── */
.mpe-auth__notice {
	display: flex; align-items: center; gap: .5rem;
	border-radius: 9px; padding: .75rem 1rem;
	font-size: .875rem; font-weight: 500;
	margin-bottom: 1.25rem; line-height: 1.4;
}
.mpe-auth__notice--success {
	background: #f0fdf4; border: 1px solid #86efac; color: #166534;
}
.mpe-auth__notice--error {
	background: #fef2f2; border: 1px solid #fca5a5; color: #991b1b;
}
.mpe-auth__notice--info {
	background: #eff6ff; border: 1px solid #93c5fd; color: #1e40af;
}
.mpe-auth__notice svg { flex-shrink: 0; }

/* ── Notices WooCommerce MPE (remplace le design par défaut WC) ── */
.mpe-woo-notices {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	margin: 1rem 0;
}
.mpe-woo-notice {
	display: flex;
	align-items: flex-start;
	gap: .6rem;
	padding: .75rem 1rem;
	border-radius: 10px;
	font-size: .875rem;
	font-weight: 500;
	line-height: 1.45;
	border-left: 3px solid transparent;
}
.mpe-woo-notice svg { flex-shrink: 0; margin-top: .1rem; }
.mpe-woo-notice--success,
.mpe-woo-notice--message {
	background: #f0fdf4;
	color: #166534;
	border-left-color: var(--mpe-primary);
}
.mpe-woo-notice--success svg,
.mpe-woo-notice--message svg { stroke: var(--mpe-primary); }
.mpe-woo-notice--error {
	background: #fef2f2;
	color: #991b1b;
	border-left-color: #ef4444;
}
.mpe-woo-notice--error svg { stroke: #ef4444; }
.mpe-woo-notice--notice,
.mpe-woo-notice--info {
	background: #eff6ff;
	color: #1e40af;
	border-left-color: #3b82f6;
}
.mpe-woo-notice--notice svg,
.mpe-woo-notice--info svg { stroke: #3b82f6; }

/* WooCommerce notices inside auth */
.mpe-auth__form-inner .woocommerce-error,
.mpe-auth__form-inner .woocommerce-message,
.mpe-auth__form-inner .woocommerce-info {
	border-radius: 9px;
	margin-bottom: 1.25rem;
	padding: .8rem 1rem;
	font-size: .875rem;
}

/* ── Écran vérification e-mail en attente ── */
.mpe-auth__verify-screen {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 1.5rem 0 2rem;
	max-width: 420px;
	margin: 0 auto;
}

.mpe-auth__verify-icon {
	position: relative;
	width: 88px;
	height: 88px;
	border-radius: 50%;
	background: #f0fdf4;
	border: 2px solid #bbf7d0;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--mpe-primary);
	margin-bottom: 1.75rem;
}
.mpe-auth__verify-icon::before {
	content: '';
	position: absolute;
	inset: -8px;
	border-radius: 50%;
	border: 2px solid #dcfce7;
	animation: mpe-verify-ring 2s ease-in-out infinite;
}
@keyframes mpe-verify-ring {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%       { opacity: .4; transform: scale(1.08); }
}

.mpe-auth__verify-dot {
	position: absolute;
	top: 6px; right: 6px;
	width: 14px; height: 14px;
	border-radius: 50%;
	background: #22c55e;
	border: 2px solid #fff;
	animation: mpe-verify-pulse 1.8s ease-in-out infinite;
}
@keyframes mpe-verify-pulse {
	0%, 100% { transform: scale(1); }
	50%       { transform: scale(1.25); }
}

.mpe-auth__verify-title {
	font-size: 1.5rem;
	font-weight: 800;
	color: #111827;
	margin: 0 0 .6rem;
	line-height: 1.2;
}

.mpe-auth__verify-sub {
	font-size: .9rem;
	color: #6b7280;
	line-height: 1.65;
	margin: 0 0 1.75rem;
}
.mpe-auth__verify-email {
	display: block;
	color: var(--mpe-primary);
	font-weight: 700;
	margin: .3rem 0 .4rem;
	word-break: break-all;
}

.mpe-auth__verify-steps {
	display: flex;
	flex-direction: column;
	gap: .65rem;
	width: 100%;
	background: #f9fafb;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	padding: 1rem 1.25rem;
	margin-bottom: 1.75rem;
	text-align: left;
}
.mpe-auth__verify-step {
	display: flex;
	align-items: center;
	gap: .75rem;
	font-size: .875rem;
	color: #374151;
}
.mpe-auth__verify-step-num {
	width: 24px; height: 24px;
	border-radius: 50%;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .72rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.mpe-auth__verify-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .75rem;
	width: 100%;
	margin-bottom: 1.25rem;
}
.mpe-auth__verify-resend {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .875rem;
	font-weight: 700;
	padding: .75rem 1.75rem;
	border-radius: 999px;
	text-decoration: none;
	transition: background .2s, transform .2s;
	width: 100%;
	justify-content: center;
}
.mpe-auth__verify-resend:hover {
	background: #167a34;
	transform: translateY(-1px);
}
.mpe-auth__verify-back {
	font-size: .82rem;
	color: #6b7280;
	text-decoration: none;
	transition: color .15s;
}
.mpe-auth__verify-back:hover { color: #111827; }

.mpe-auth__verify-spam {
	display: flex;
	align-items: center;
	gap: .4rem;
	font-size: .75rem;
	color: #9ca3af;
	margin: 0;
}
.mpe-auth__verify-spam svg { flex-shrink: 0; }

/* Modale login — quand non connecté et clic sur Lire */
.mpe-auth-gate {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 1rem;
	margin: auto;
	padding: 3rem 2rem;
	color: rgba(255,255,255,.75);
}
.mpe-auth-gate__icon {
	width: 3.5rem; height: 3.5rem;
	background: rgba(31,155,66,.12);
	border-radius: 9999px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.mpe-auth-gate__title {
	font-size: 1.1rem;
	font-weight: 700;
	color: #fff;
}
.mpe-auth-gate__desc { font-size: .875rem; opacity: .7; line-height: 1.6; }
.mpe-auth-gate__btns { display: flex; gap: .75rem; flex-wrap: wrap; justify-content: center; margin-top: .5rem; }
.mpe-auth-gate__btn {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .6rem 1.25rem;
	border-radius: 8px;
	font-size: .875rem;
	font-weight: 600;
	text-decoration: none;
	transition: background .15s;
}
.mpe-auth-gate__btn--login {
	background: var(--mpe-primary);
	color: #fff;
}
.mpe-auth-gate__btn--login:hover { background: #178038; }
.mpe-auth-gate__btn--register {
	background: rgba(255,255,255,.1);
	color: rgba(255,255,255,.85);
	border: 1px solid rgba(255,255,255,.2);
}
.mpe-auth-gate__btn--register:hover { background: rgba(255,255,255,.18); }

/* ================================================================
   MON COMPTE — Layout pleine largeur
   ================================================================ */

.mpe-account-page { background: #f3f4f6; min-height: 60vh; }

/* ── Hero banner ── */
.mpe-acct-hero {
	position: relative;
	background: linear-gradient(135deg, #167330 0%, var(--mpe-primary) 60%, #25b84e 100%);
	overflow: hidden;
	padding: 2.5rem 0 2rem;
}
.mpe-acct-hero__deco {
	position: absolute;
	border-radius: 9999px;
	background: rgba(255,255,255,.06);
	pointer-events: none;
}
.mpe-acct-hero__deco--1 { width: 500px; height: 500px; top: -200px; right: -100px; }
.mpe-acct-hero__deco--2 { width: 300px; height: 300px; bottom: -120px; left: -60px; }

.mpe-acct-hero__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	flex-wrap: wrap;
}

/* Profil */
.mpe-acct-hero__profile {
	display: flex;
	align-items: center;
	gap: 1.25rem;
}
.mpe-acct-hero__avatar {
	width: 5rem; height: 5rem;
	border-radius: 9999px;
	background: rgba(255,255,255,.2);
	border: 3px solid rgba(255,255,255,.5);
	color: #fff;
	font-size: 1.6rem;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	letter-spacing: -.02em;
}
.mpe-acct-hero__name {
	font-size: 1.5rem;
	font-weight: 800;
	color: #fff;
	letter-spacing: -.02em;
	margin-bottom: .2rem;
}
.mpe-acct-hero__email {
	font-size: .85rem;
	color: rgba(255,255,255,.75);
	margin-bottom: .15rem;
}
.mpe-acct-hero__since {
	font-size: .75rem;
	color: rgba(255,255,255,.55);
}

/* Stats */
.mpe-acct-hero__stats {
	display: flex;
	align-items: center;
	gap: 0;
	background: rgba(255,255,255,.12);
	border-radius: 14px;
	border: 1px solid rgba(255,255,255,.18);
	overflow: hidden;
}
.mpe-acct-hero__stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 1rem 2rem;
}
.mpe-acct-hero__stat-sep {
	width: 1px;
	height: 2.5rem;
	background: rgba(255,255,255,.2);
}
.mpe-acct-hero__stat-val {
	font-size: 2rem;
	font-weight: 800;
	color: #fff;
	line-height: 1;
	margin-bottom: .3rem;
}
.mpe-acct-hero__stat-lbl {
	display: flex;
	align-items: center;
	gap: .3rem;
	font-size: .72rem;
	font-weight: 600;
	color: rgba(255,255,255,.7);
	text-transform: uppercase;
	letter-spacing: .06em;
}

/* ── Barre de navigation horizontale ── */
.mpe-acct-nav-bar {
	background: #fff;
	border-bottom: 1px solid #e5e7eb;
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.mpe-acct-nav { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.mpe-acct-nav__list {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	white-space: nowrap;
}
.mpe-acct-nav__item { flex-shrink: 0; }
.mpe-acct-nav__link {
	display: flex;
	align-items: center;
	gap: .45rem;
	padding: .9rem 1.1rem;
	font-size: .84rem;
	font-weight: 600;
	color: #6b7280;
	text-decoration: none;
	border-bottom: 2px solid transparent;
	transition: color .15s, border-color .15s;
	white-space: nowrap;
}
.mpe-acct-nav__link:hover { color: var(--mpe-primary); }
.mpe-acct-nav__icon { display: flex; align-items: center; }

.mpe-acct-nav__item.is-active .mpe-acct-nav__link,
.mpe-acct-nav__item.woocommerce-MyAccount-navigation-link--active .mpe-acct-nav__link {
	color: var(--mpe-primary);
	border-bottom-color: var(--mpe-primary);
}
.mpe-acct-nav__item--logout .mpe-acct-nav__link { color: #ef4444; margin-left: auto; }
.mpe-acct-nav__item--logout .mpe-acct-nav__link:hover { color: #dc2626; }

/* ── Zone contenu ── */
.mpe-acct-content {
	padding: 2rem 0 4rem;
}

/* ── Dashboard pleine largeur ── */
.mpe-dash__welcome {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	background: linear-gradient(135deg, #0f5c25 0%, #1F9B42 100%);
	border-radius: 16px;
	padding: 1.75rem 2rem;
	margin-bottom: 1.75rem;
	color: #fff;
}
.mpe-dash__greeting {
	font-size: 1.2rem;
	font-weight: 700;
	margin-bottom: .35rem;
}
.mpe-dash__intro {
	font-size: .875rem;
	opacity: .8;
	line-height: 1.6;
}
.mpe-dash__welcome-cta {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .65rem 1.25rem;
	background: rgba(255,255,255,.15);
	border: 1.5px solid rgba(255,255,255,.35);
	border-radius: 9px;
	color: #fff;
	font-size: .84rem;
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	transition: background .15s;
	flex-shrink: 0;
}
.mpe-dash__welcome-cta:hover { background: rgba(255,255,255,.25); color: #fff; }

/* Accès rapide */
.mpe-dash__quick {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	margin-bottom: 2rem;
}
@media (max-width: 768px) { .mpe-dash__quick { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 400px) { .mpe-dash__quick { grid-template-columns: 1fr; } }

.mpe-dash__qcard {
	display: flex;
	align-items: center;
	gap: .875rem;
	padding: 1.25rem 1.5rem;
	background: #fff;
	border-radius: 14px;
	box-shadow: 0 1px 6px rgba(0,0,0,.06);
	text-decoration: none;
	color: #374151;
	font-weight: 600;
	font-size: .875rem;
	transition: transform .15s, box-shadow .15s;
	border: 1px solid transparent;
}
.mpe-dash__qcard:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0,0,0,.1);
}
.mpe-dash__qcard-icon {
	width: 2.5rem; height: 2.5rem;
	border-radius: 10px;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
}
.mpe-dash__qcard-label { flex: 1; }
.mpe-dash__qcard-arrow { font-size: .85rem; color: #d1d5db; }

.mpe-dash__qcard--books  .mpe-dash__qcard-icon { background: #dcfce7; color: var(--mpe-primary); }
.mpe-dash__qcard--orders .mpe-dash__qcard-icon { background: #ede9fe; color: #7c3aed; }
.mpe-dash__qcard--shop   .mpe-dash__qcard-icon { background: #e0f2fe; color: #0284c7; }
.mpe-dash__qcard--profile .mpe-dash__qcard-icon { background: #fef9c3; color: #b45309; }

/* Grille livres + commandes */
.mpe-dash__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
	align-items: start;
}
@media (max-width: 900px) { .mpe-dash__grid { grid-template-columns: 1fr; } }

.mpe-dash__panel {
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 1px 6px rgba(0,0,0,.06);
	overflow: hidden;
}
.mpe-dash__panel-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid #f3f4f6;
}
.mpe-dash__panel-title {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: .95rem;
	font-weight: 700;
	color: #111827;
}
.mpe-dash__panel-title svg { color: var(--mpe-primary); }
.mpe-dash__panel-link {
	font-size: .8rem;
	color: var(--mpe-primary);
	font-weight: 600;
	text-decoration: none;
}
.mpe-dash__panel-link:hover { text-decoration: underline; }

/* Book grid dans dashboard */
.mpe-dash__bookgrid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1px;
	background: #f3f4f6;
}
@media (max-width: 600px) { .mpe-dash__bookgrid { grid-template-columns: repeat(2, 1fr); } }

.mpe-dash__bookitem {
	background: #fff;
	padding: 1rem;
	display: flex;
	flex-direction: column;
	gap: .5rem;
}
.mpe-dash__bookitem-cover {
	position: relative;
	aspect-ratio: 3/4;
	border-radius: 8px;
	overflow: hidden;
	background: #f9fafb;
}
.mpe-dash__bookitem-cover img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .25s;
}
.mpe-dash__bookitem:hover .mpe-dash__bookitem-cover img { transform: scale(1.04); }
.mpe-dash__bookitem-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.45);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity .2s;
}
.mpe-dash__bookitem:hover .mpe-dash__bookitem-overlay { opacity: 1; }
.mpe-dash__bookitem-read {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .55rem 1rem;
	background: var(--mpe-primary);
	color: #fff;
	border: none;
	border-radius: 8px;
	font-size: .78rem;
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
	transition: background .15s;
}
.mpe-dash__bookitem-read:hover { background: #178038; }
.mpe-dash__bookitem-title {
	font-size: .78rem;
	font-weight: 600;
	color: #111827;
	line-height: 1.4;
	margin: 0;
}
.mpe-dash__bookitem-title a { color: inherit; text-decoration: none; }
.mpe-dash__bookitem-title a:hover { color: var(--mpe-primary); }

/* Orders dans dashboard */
.mpe-dash__ordertable {
	display: flex;
	flex-direction: column;
}
.mpe-dash__orderrow {
	display: flex;
	align-items: center;
	gap: .875rem;
	padding: .875rem 1.5rem;
	font-size: .84rem;
	border-bottom: 1px solid #f3f4f6;
	flex-wrap: wrap;
}
.mpe-dash__orderrow:last-child { border-bottom: none; }
.mpe-dash__orderrow-num { display: flex; flex-direction: column; flex: 1; min-width: 80px; }
.mpe-dash__orderrow-id { font-weight: 700; color: #111827; }
.mpe-dash__orderrow-date { font-size: .72rem; color: #9ca3af; }
.mpe-dash__orderstatus {
	padding: .2rem .65rem;
	border-radius: 20px;
	font-size: .7rem;
	font-weight: 700;
}
.mpe-dash__orderstatus--completed  { background: #d1fae5; color: #065f46; }
.mpe-dash__orderstatus--processing { background: #dbeafe; color: #1e40af; }
.mpe-dash__orderstatus--pending    { background: #fef3c7; color: #92400e; }
.mpe-dash__orderstatus--cancelled  { background: #fee2e2; color: #991b1b; }
.mpe-dash__orderrow-total { font-weight: 700; color: #111827; }
.mpe-dash__orderrow-link {
	font-size: .78rem;
	color: var(--mpe-primary);
	font-weight: 600;
	text-decoration: none;
}
.mpe-dash__orderrow-link:hover { text-decoration: underline; }

/* Empty inline */
.mpe-dash__empty-inline {
	display: flex; flex-direction: column;
	align-items: center; gap: .75rem;
	padding: 2.5rem 1.5rem;
	text-align: center;
	color: #9ca3af;
}
.mpe-dash__empty-inline p { font-size: .9rem; margin: 0; }

/* Empty state (standalone) */
.mpe-dash__empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding: 3rem 2rem;
	text-align: center;
	color: #9ca3af;
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 1px 6px rgba(0,0,0,.06);
}
.mpe-dash__empty p { font-size: .95rem; }

/* ── Mes livres (page complète) ── */
.mpe-mybooks {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 1.25rem;
}
.mpe-mybooks__card {
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 2px 12px rgba(0,0,0,.07);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .15s, box-shadow .15s;
}
.mpe-mybooks__card:hover {
	transform: translateY(-3px);
	box-shadow: 0 6px 20px rgba(0,0,0,.12);
}
.mpe-mybooks__cover-wrap {
	position: relative;
	aspect-ratio: 3/4;
	overflow: hidden;
	background: #f3f4f6;
}
.mpe-mybooks__cover {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.mpe-mybooks__badge {
	position: absolute;
	top: .625rem;
	right: .625rem;
	display: flex;
	align-items: center;
	gap: .3rem;
	padding: .25rem .6rem;
	background: #d1fae5;
	color: #065f46;
	border-radius: 20px;
	font-size: .68rem;
	font-weight: 700;
}
.mpe-mybooks__body {
	padding: 1rem;
	display: flex;
	flex-direction: column;
	gap: .5rem;
	flex: 1;
}
.mpe-mybooks__cat {
	font-size: .72rem;
	font-weight: 600;
	color: var(--mpe-primary);
	text-transform: uppercase;
	letter-spacing: .04em;
}
.mpe-mybooks__title {
	font-size: .9rem;
	font-weight: 700;
	color: #111827;
	line-height: 1.4;
}
.mpe-mybooks__title a { color: inherit; text-decoration: none; }
.mpe-mybooks__title a:hover { color: var(--mpe-primary); }
.mpe-mybooks__desc {
	font-size: .78rem;
	color: #6b7280;
	line-height: 1.5;
	flex: 1;
}
.mpe-mybooks__actions {
	display: flex;
	gap: .5rem;
	margin-top: .25rem;
}
.mpe-mybooks__btn {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .5rem .875rem;
	border-radius: 7px;
	font-size: .78rem;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	border: none;
	font-family: inherit;
	transition: background .15s;
	flex: 1;
	justify-content: center;
}
.mpe-mybooks__btn--read {
	background: var(--mpe-primary);
	color: #fff;
}
.mpe-mybooks__btn--read:hover { background: #178038; }
.mpe-mybooks__btn--view {
	background: #f3f4f6;
	color: #374151;
	border: 1px solid #e5e7eb;
}
.mpe-mybooks__btn--view:hover { background: #e5e7eb; }

/* ================================================================
   PANIER — Cart MPE
   ================================================================ */

.mpe-cart-page {
	background: var(--mpe-bg-body, #f8f9fa);
	min-height: 60vh;
	padding: 2.5rem 0 5rem;
}

/* ── En-tête ── */
.mpe-cart-header {
	margin-bottom: 2rem;
}
.mpe-cart-header__bc {
	display: flex;
	align-items: center;
	gap: .4rem;
	font-size: .78rem;
	color: var(--mpe-ink-500, #6b7280);
	margin-bottom: 1rem;
}
.mpe-cart-header__bc a { color: inherit; text-decoration: none; }
.mpe-cart-header__bc a:hover { color: var(--mpe-primary); }
.mpe-cart-header__bc svg { flex-shrink: 0; opacity: .5; }
.mpe-cart-header__bc span { color: var(--mpe-ink-900, #111827); font-weight: 500; }
.mpe-cart-header__top { display: flex; align-items: center; gap: 1rem; }
.mpe-cart-header__title {
	display: flex;
	align-items: center;
	gap: .6rem;
	font-family: var(--mpe-font-heading);
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
	margin: 0;
}
.mpe-cart-header__count {
	font-size: .95rem;
	font-weight: 500;
	color: var(--mpe-ink-500, #6b7280);
}

/* ── Layout deux colonnes ── */
.mpe-cart-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: start;
}
@media (min-width: 1024px) {
	.mpe-cart-layout {
		grid-template-columns: 1fr 340px;
		gap: 2.5rem;
	}
}

/* ── Liste articles ── */
.mpe-cart-list {
	background: #fff;
	border-radius: 14px;
	border: 1px solid rgba(0,0,0,.07);
	overflow: hidden;
	margin-bottom: 1rem;
}

/* En-tête colonnes (desktop only) */
.mpe-cart-list__head {
	display: none;
}
@media (min-width: 768px) {
	.mpe-cart-list__head {
		display: grid;
		grid-template-columns: 1fr 90px 110px 90px;
		gap: 1rem;
		padding: .75rem 1.5rem .75rem calc(56px + 88px + 1.5rem + 1rem + 1rem);
		border-bottom: 1px solid rgba(0,0,0,.07);
		font-size: .7rem;
		font-weight: 700;
		letter-spacing: .06em;
		text-transform: uppercase;
		color: var(--mpe-ink-500, #6b7280);
		background: #fafafa;
	}
}

/* Ligne article */
.mpe-cart-row {
	display: grid;
	grid-template-columns: 40px 72px 1fr;
	grid-template-areas:
		"del  thumb  info"
		".    thumb  price"
		".    thumb  qty"
		".    thumb  sub";
	gap: .5rem 1rem;
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid rgba(0,0,0,.06);
	align-items: start;
}
.mpe-cart-row:last-child { border-bottom: none; }
@media (min-width: 768px) {
	.mpe-cart-row {
		grid-template-columns: 40px 72px 1fr 90px 110px 90px;
		grid-template-areas: "del thumb info price qty sub";
		align-items: center;
		gap: 1rem;
		padding: 1.25rem 1.5rem;
	}
}

.mpe-cart-row__remove { grid-area: del; display: flex; align-items: center; }
.mpe-cart-row__thumb  { grid-area: thumb; }
.mpe-cart-row__info   { grid-area: info; }
.mpe-cart-row__price  { grid-area: price; }
.mpe-cart-row__qty    { grid-area: qty; }
.mpe-cart-row__subtotal { grid-area: sub; }

/* Bouton supprimer */
.mpe-cart-row__del {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px; height: 28px;
	border-radius: 50%;
	background: rgba(239,68,68,.08);
	color: #ef4444;
	text-decoration: none;
	transition: background .15s, transform .15s;
	flex-shrink: 0;
}
.mpe-cart-row__del:hover { background: rgba(239,68,68,.16); transform: scale(1.08); }

/* Miniature livre */
.mpe-cart-row__thumb img {
	width: 72px;
	height: 96px;
	object-fit: cover;
	border-radius: 6px;
	box-shadow: 0 2px 8px rgba(0,0,0,.12);
	display: block;
}

/* Infos produit */
.mpe-cart-row__cat {
	display: block;
	font-size: .6rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--mpe-primary);
	margin-bottom: .25rem;
}
.mpe-cart-row__name {
	font-size: .9rem;
	font-weight: 600;
	color: var(--mpe-ink-900, #111827);
	line-height: 1.35;
}
.mpe-cart-row__name a { color: inherit; text-decoration: none; }
.mpe-cart-row__name a:hover { color: var(--mpe-primary); }

/* Prix + sous-total */
.mpe-cart-row__price,
.mpe-cart-row__subtotal {
	font-size: .9rem;
	font-weight: 600;
	color: var(--mpe-ink-900, #111827);
}
.mpe-cart-row__subtotal { font-weight: 700; }

/* Label mobile (data-label) */
@media (max-width: 767px) {
	.mpe-cart-row__price::before  { content: attr(data-label) ' : '; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--mpe-ink-500, #6b7280); display: block; margin-bottom: .15rem; }
	.mpe-cart-row__qty::before    { content: attr(data-label) ' : '; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--mpe-ink-500, #6b7280); display: block; margin-bottom: .15rem; }
	.mpe-cart-row__subtotal::before { content: attr(data-label) ' : '; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--mpe-ink-500, #6b7280); display: block; margin-bottom: .15rem; }
}

/* Quantity input WooCommerce */
.mpe-cart-row__qty .quantity { display: flex; align-items: center; gap: .3rem; }
.mpe-cart-row__qty .qty {
	width: 56px;
	padding: .35rem .5rem;
	border-radius: 6px;
	border: 1px solid rgba(0,0,0,.15);
	font-size: .85rem;
	font-weight: 600;
	text-align: center;
	color: var(--mpe-ink-900, #111827);
	background: #fff;
}
.mpe-cart-row__qty .qty:focus { outline: 2px solid var(--mpe-primary); border-color: transparent; }

/* Spinner auto-update quantité */
.mpe-qty-spinner {
	display: inline-block;
	width: 14px; height: 14px;
	border: 2px solid rgba(31,155,66,.25);
	border-top-color: var(--mpe-primary);
	border-radius: 50%;
	animation: mpe-spin .6s linear infinite;
	vertical-align: middle;
	flex-shrink: 0;
}
@keyframes mpe-spin { to { transform: rotate(360deg); } }

/* ── Actions : coupon + mise à jour ── */
.mpe-cart-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .75rem;
	justify-content: space-between;
}

/* Coupon */
.mpe-cart-coupon__wrap {
	display: flex;
	align-items: center;
	gap: 0;
	background: #fff;
	border: 1px solid rgba(0,0,0,.15);
	border-radius: 8px;
	padding: 0 .75rem;
	overflow: hidden;
	transition: border-color .2s;
}
.mpe-cart-coupon__wrap:focus-within { border-color: var(--mpe-primary); }
.mpe-cart-coupon__wrap svg { color: var(--mpe-ink-500, #6b7280); flex-shrink: 0; }
.mpe-cart-coupon__input {
	border: none;
	outline: none;
	padding: .55rem .6rem;
	font-size: .85rem;
	color: var(--mpe-ink-900, #111827);
	background: transparent;
	min-width: 160px;
	font-family: inherit;
}
.mpe-cart-coupon__btn {
	background: var(--mpe-primary);
	color: #fff;
	border: none;
	padding: .45rem .9rem;
	border-radius: 6px;
	font-size: .78rem;
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
	transition: background .15s;
	white-space: nowrap;
}
.mpe-cart-coupon__btn:hover { background: #178038; }

/* Bouton mise à jour */
.mpe-cart-update-btn {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .55rem 1.1rem;
	border-radius: 8px;
	border: 1px solid rgba(0,0,0,.15);
	background: #fff;
	color: var(--mpe-ink-700, #374151);
	font-size: .8rem;
	font-weight: 600;
	cursor: pointer;
	font-family: inherit;
	transition: background .15s, border-color .2s;
}
.mpe-cart-update-btn:hover { background: #f3f4f6; border-color: rgba(0,0,0,.25); }

/* ── Colonne récapitulatif ── */
.mpe-cart-summary { position: sticky; top: 100px; }

/* Card totaux */
.mpe-cart-totals {
	background: #fff;
	border-radius: 14px;
	border: 1px solid rgba(0,0,0,.07);
	overflow: hidden;
}

.mpe-cart-totals__head {
	display: flex;
	align-items: center;
	gap: .5rem;
	padding: 1.1rem 1.5rem;
	border-bottom: 1px solid rgba(0,0,0,.07);
	background: #fafafa;
}
.mpe-cart-totals__head svg { color: var(--mpe-primary); }
.mpe-cart-totals__head h2 {
	font-family: var(--mpe-font-heading);
	font-size: 1rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
	margin: 0;
}

.mpe-cart-totals__rows {
	padding: 1rem 1.5rem;
	display: flex;
	flex-direction: column;
	gap: .75rem;
}

.mpe-cart-totals__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
	font-size: .88rem;
}
.mpe-cart-totals__lbl { color: var(--mpe-ink-700, #374151); }
.mpe-cart-totals__val { font-weight: 600; color: var(--mpe-ink-900, #111827); }
.mpe-cart-totals__val--discount { color: #16a34a; }

.mpe-cart-totals__row--coupon .mpe-cart-totals__lbl {
	display: flex; align-items: center; gap: .35rem; flex-wrap: wrap;
}

/* Séparateur avant total */
.mpe-cart-totals__row--total {
	padding-top: .75rem;
	border-top: 2px solid rgba(0,0,0,.08);
	font-size: 1.05rem;
}
.mpe-cart-totals__row--total .mpe-cart-totals__lbl { font-weight: 700; color: var(--mpe-ink-900, #111827); }
.mpe-cart-totals__row--total .mpe-cart-totals__val { font-size: 1.2rem; font-weight: 800; color: var(--mpe-primary); }

/* Bouton commander (WC génère le lien) */
.mpe-cart-totals__checkout {
	padding: 0 1.5rem 1rem;
}
.mpe-cart-totals__checkout .checkout-button,
.mpe-cart-totals__checkout a.button {
	display: flex !important;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	width: 100%;
	padding: .9rem 1.5rem;
	background: var(--mpe-primary);
	color: #fff !important;
	border-radius: 10px;
	font-size: .95rem;
	font-weight: 700;
	text-decoration: none;
	border: none;
	cursor: pointer;
	font-family: inherit;
	transition: background .2s, transform .2s;
}
.mpe-cart-totals__checkout .checkout-button:hover,
.mpe-cart-totals__checkout a.button:hover {
	background: #178038;
	transform: translateY(-1px);
}

/* Lien retour boutique */
.mpe-cart-totals__back {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: .35rem;
	padding: .75rem 1.5rem 1.25rem;
	font-size: .8rem;
	color: var(--mpe-ink-500, #6b7280);
	text-decoration: none;
	transition: color .15s;
}
.mpe-cart-totals__back:hover { color: var(--mpe-primary); }

/* ── Panier vide ── */
.mpe-cart-empty {
	text-align: center;
	padding: 5rem 1rem;
	max-width: 440px;
	margin: 0 auto;
}
.mpe-cart-empty__icon {
	position: relative;
	display: inline-block;
	color: #d1d5db;
	margin-bottom: 1.5rem;
}
.mpe-cart-empty__badge {
	position: absolute;
	top: -6px; right: -10px;
	width: 22px; height: 22px;
	border-radius: 50%;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .65rem;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
}
.mpe-cart-empty__title {
	font-family: var(--mpe-font-heading);
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
	margin: 0 0 .75rem;
}
.mpe-cart-empty__desc {
	font-size: .9rem;
	color: var(--mpe-ink-500, #6b7280);
	margin: 0 0 2rem;
	line-height: 1.6;
}
.mpe-cart-empty__btn {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	padding: .8rem 2rem;
	background: var(--mpe-primary);
	color: #fff;
	border-radius: 10px;
	font-weight: 700;
	font-size: .9rem;
	text-decoration: none;
	transition: background .2s, transform .2s;
}
.mpe-cart-empty__btn:hover { background: #178038; transform: translateY(-2px); }

/* Compatibilité WooCommerce notices dans le panier */
.mpe-cart-page .woocommerce-message,
.mpe-cart-page .woocommerce-error,
.mpe-cart-page .woocommerce-info {
	border-radius: 10px;
	margin-bottom: 1.5rem;
}

/* ================================================================
   CHECKOUT — Commander MPE
   ================================================================ */

.mpe-co-page {
	background: var(--mpe-bg-body, #f8f9fa);
	min-height: 70vh;
	padding: 2.5rem 0 5rem;
}

/* ── En-tête ── */
.mpe-co-header { margin-bottom: 2rem; }
.mpe-co-header__bc {
	display: flex;
	align-items: center;
	gap: .4rem;
	font-size: .78rem;
	color: var(--mpe-ink-500, #6b7280);
	margin-bottom: 1rem;
}
.mpe-co-header__bc a { color: inherit; text-decoration: none; }
.mpe-co-header__bc a:hover { color: var(--mpe-primary); }
.mpe-co-header__bc svg { opacity: .5; flex-shrink: 0; }
.mpe-co-header__bc span { color: var(--mpe-ink-900, #111827); font-weight: 500; }
.mpe-co-header__title {
	display: flex;
	align-items: center;
	gap: .6rem;
	font-family: var(--mpe-font-heading);
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
	margin: 0;
}
.mpe-co-header__title svg { color: var(--mpe-primary); }

/* ── Layout deux colonnes ── */
.mpe-co-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: start;
}
@media (min-width: 1024px) {
	.mpe-co-layout {
		grid-template-columns: 1fr 380px;
		gap: 2.5rem;
	}
}

/* ── Sections (étapes) ── */
.mpe-co-section {
	background: #fff;
	border-radius: 14px;
	border: 1px solid rgba(0,0,0,.07);
	overflow: hidden;
	margin-bottom: 1.25rem;
}
.mpe-co-section:last-child { margin-bottom: 0; }

.mpe-co-section__head {
	display: flex;
	align-items: center;
	gap: .75rem;
	padding: 1.1rem 1.5rem;
	border-bottom: 1px solid rgba(0,0,0,.07);
	background: #fafafa;
}
.mpe-co-section__num {
	width: 28px; height: 28px;
	border-radius: 50%;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .78rem;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.mpe-co-section__title {
	font-family: var(--mpe-font-heading);
	font-size: .95rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
	margin: 0;
}
.mpe-co-section__body { padding: 1.5rem; }

/* ── Champs WooCommerce ── */
.mpe-co-form .form-row {
	margin-bottom: 1.1rem;
}
.mpe-co-form .form-row label {
	display: block;
	font-size: .78rem;
	font-weight: 600;
	color: var(--mpe-ink-700, #374151);
	margin-bottom: .35rem;
	letter-spacing: .01em;
}
.mpe-co-form .form-row .required { color: var(--mpe-primary); }
.mpe-co-form .form-row .input-text,
.mpe-co-form .form-row select {
	width: 100%;
	padding: .6rem .85rem;
	border: 1.5px solid rgba(0,0,0,.15);
	border-radius: 8px;
	font-size: .875rem;
	color: var(--mpe-ink-900, #111827);
	background: #fff;
	transition: border-color .2s, box-shadow .2s;
	font-family: inherit;
	appearance: none;
	-webkit-appearance: none;
}
.mpe-co-form .form-row .input-text:focus,
.mpe-co-form .form-row select:focus {
	outline: none;
	border-color: var(--mpe-primary);
	box-shadow: 0 0 0 3px rgba(31,155,66,.12);
}
.mpe-co-form .form-row.woocommerce-invalid .input-text {
	border-color: #ef4444;
	box-shadow: 0 0 0 3px rgba(239,68,68,.1);
}

/* Rangées côte à côte */
.mpe-co-form .col2-set { display: grid; gap: 1rem; }
@media (min-width: 640px) {
	.mpe-co-form .col2-set { grid-template-columns: 1fr 1fr; }
}
.mpe-co-form .form-row-first,
.mpe-co-form .form-row-last { margin-bottom: 0; }

/* Champ textarea notes */
.mpe-co-form textarea.input-text {
	min-height: 90px;
	resize: vertical;
}

/* Titre "Informations supplémentaires" */
.mpe-co-form h3#order_comments_heading {
	font-size: .85rem;
	font-weight: 700;
	color: var(--mpe-ink-700, #374151);
	margin: 1.5rem 0 .75rem;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(0,0,0,.07);
}

/* ── Section paiement WC (rendu dans #order_review) ── */
.mpe-co-form #payment {
	background: #fff;
	border-radius: 12px;
	border: 1px solid rgba(0,0,0,.08);
	overflow: hidden;
	margin-top: 1rem;
}
.mpe-co-form #payment .payment_methods {
	list-style: none;
	padding: 0; margin: 0;
	border-bottom: 1px solid rgba(0,0,0,.07);
}
.mpe-co-form #payment .payment_methods li {
	border-bottom: 1px solid rgba(0,0,0,.06);
}
.mpe-co-form #payment .payment_methods li:last-child { border-bottom: none; }
.mpe-co-form #payment .payment_methods li label {
	display: flex;
	align-items: center;
	gap: .65rem;
	padding: .9rem 1.25rem;
	cursor: pointer;
	font-size: .875rem;
	font-weight: 500;
	color: var(--mpe-ink-900, #111827);
	transition: background .15s;
}
.mpe-co-form #payment .payment_methods li label:hover { background: #f9fafb; }
.mpe-co-form #payment .payment_methods li input[type="radio"] {
	accent-color: var(--mpe-primary);
	width: 16px; height: 16px;
	flex-shrink: 0;
}
.mpe-co-form #payment .payment_box {
	padding: .75rem 1.25rem;
	background: #f9fafb;
	font-size: .82rem;
	color: var(--mpe-ink-700, #374151);
}
.mpe-co-form #payment .place-order {
	padding: 1.25rem 1.25rem 1.5rem;
}
.mpe-co-form #payment #place_order {
	display: block;
	width: 100%;
	padding: .95rem 1.5rem;
	background: var(--mpe-primary);
	color: #fff;
	border: none;
	border-radius: 10px;
	font-size: 1rem;
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
	transition: background .2s, transform .2s;
}
.mpe-co-form #payment #place_order:hover {
	background: #178038;
	transform: translateY(-1px);
}
.mpe-co-form #payment .woocommerce-terms-and-conditions-wrapper {
	font-size: .8rem;
	color: var(--mpe-ink-500, #6b7280);
	margin-bottom: .75rem;
}
.mpe-co-form #payment .woocommerce-privacy-policy-text { font-size: .75rem; color: var(--mpe-ink-500); margin-top: .5rem; }

/* ── Sidebar récapitulatif ── */
.mpe-co-sidebar { position: sticky; top: 100px; }

.mpe-co-summary {
	background: #fff;
	border-radius: 14px;
	border: 1px solid rgba(0,0,0,.07);
	overflow: hidden;
}
.mpe-co-summary__head {
	display: flex;
	align-items: center;
	gap: .5rem;
	padding: 1.1rem 1.5rem;
	border-bottom: 1px solid rgba(0,0,0,.07);
	background: #fafafa;
}
.mpe-co-summary__head svg { color: var(--mpe-primary); flex-shrink: 0; }
.mpe-co-summary__title {
	font-family: var(--mpe-font-heading);
	font-size: .95rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
	margin: 0;
	flex: 1;
}
.mpe-co-summary__edit {
	font-size: .75rem;
	font-weight: 600;
	color: var(--mpe-primary);
	text-decoration: none;
	white-space: nowrap;
}
.mpe-co-summary__edit:hover { text-decoration: underline; }

/* Contenu récapitulatif */
.mpe-co-review { padding: 1rem 1.5rem 0; }

/* Articles */
.mpe-co-review__items {
	display: flex;
	flex-direction: column;
	gap: .75rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(0,0,0,.07);
}
.mpe-co-item {
	display: flex;
	align-items: flex-start;
	gap: .75rem;
}
.mpe-co-item__thumb {
	position: relative;
	flex-shrink: 0;
}
.mpe-co-item__thumb img {
	width: 48px;
	height: 64px;
	object-fit: cover;
	border-radius: 5px;
	box-shadow: 0 1px 6px rgba(0,0,0,.12);
	display: block;
}
.mpe-co-item__qty {
	position: absolute;
	top: -6px; right: -6px;
	width: 18px; height: 18px;
	border-radius: 50%;
	background: var(--mpe-primary);
	color: #fff;
	font-size: .6rem;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
}
.mpe-co-item__info {
	flex: 1;
	min-width: 0;
}
.mpe-co-item__name {
	font-size: .82rem;
	font-weight: 600;
	color: var(--mpe-ink-900, #111827);
	display: block;
	line-height: 1.35;
}
.mpe-co-item__sub {
	font-size: .82rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
	white-space: nowrap;
	align-self: center;
}

/* Totaux */
.mpe-co-review__totals {
	padding: 1rem 0;
	display: flex;
	flex-direction: column;
	gap: .6rem;
}
.mpe-co-review__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
	font-size: .83rem;
	color: var(--mpe-ink-700, #374151);
}
.mpe-co-review__discount { color: #16a34a; font-weight: 600; }
.mpe-co-review__row--total {
	padding-top: .75rem;
	border-top: 2px solid rgba(0,0,0,.08);
	font-size: 1rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
}
.mpe-co-review__row--total span:last-child { color: var(--mpe-primary); font-size: 1.15rem; }

/* Coupon dans checkout */
.mpe-co-form .woocommerce-form-coupon-toggle { margin-bottom: 1rem; }
.mpe-co-form .showcoupon { color: var(--mpe-primary); font-weight: 600; }
.mpe-co-form .checkout_coupon {
	background: #fff;
	border-radius: 12px;
	border: 1px solid rgba(0,0,0,.1);
	padding: 1rem 1.25rem;
	margin-bottom: 1.25rem;
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	align-items: flex-end;
}
.mpe-co-form .checkout_coupon .form-row { margin: 0; flex: 1 1 200px; }
.mpe-co-form .checkout_coupon button[name="apply_coupon"] {
	padding: .6rem 1.2rem;
	background: var(--mpe-primary);
	color: #fff;
	border: none;
	border-radius: 8px;
	font-size: .82rem;
	font-weight: 700;
	cursor: pointer;
	font-family: inherit;
	white-space: nowrap;
	transition: background .15s;
}
.mpe-co-form .checkout_coupon button[name="apply_coupon"]:hover { background: #178038; }

/* ── Page de remerciement ── */
.mpe-thankyou {
	background: var(--mpe-bg-body, #f8f9fa);
	min-height: 70vh;
	padding: 4rem 0 6rem;
}

.mpe-thankyou__success,
.mpe-thankyou__failed {
	max-width: 560px;
	margin: 0 auto;
	text-align: center;
}

/* Icône check animée */
.mpe-thankyou__check {
	display: inline-block;
	margin-bottom: 1.75rem;
}
.mpe-thankyou__check-svg {
	width: 80px; height: 80px;
}
.mpe-thankyou__check-circle {
	stroke: var(--mpe-primary);
	stroke-width: 2;
	stroke-dasharray: 166;
	stroke-dashoffset: 166;
	animation: mpe-circle-draw .6s ease-in-out forwards .1s;
}
.mpe-thankyou__check-mark {
	stroke: var(--mpe-primary);
	stroke-width: 2.5;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-dasharray: 48;
	stroke-dashoffset: 48;
	animation: mpe-check-draw .4s ease-in-out forwards .65s;
}
@keyframes mpe-circle-draw {
	to { stroke-dashoffset: 0; }
}
@keyframes mpe-check-draw {
	to { stroke-dashoffset: 0; }
}

.mpe-thankyou__title {
	font-family: var(--mpe-font-heading);
	font-size: 1.8rem;
	font-weight: 800;
	color: var(--mpe-ink-900, #111827);
	margin: 0 0 .75rem;
}
.mpe-thankyou__desc {
	font-size: .95rem;
	color: var(--mpe-ink-500, #6b7280);
	line-height: 1.7;
	margin: 0 0 2rem;
}

/* Détails commande */
.mpe-thankyou__details {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1px;
	background: rgba(0,0,0,.07);
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid rgba(0,0,0,.07);
	margin-bottom: 2rem;
	text-align: left;
}
.mpe-thankyou__detail-item {
	background: #fff;
	padding: .9rem 1.25rem;
	display: flex;
	flex-direction: column;
	gap: .2rem;
}
.mpe-thankyou__detail-lbl {
	font-size: .7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--mpe-ink-500, #6b7280);
}
.mpe-thankyou__detail-val {
	font-size: .9rem;
	font-weight: 600;
	color: var(--mpe-ink-900, #111827);
}
.mpe-thankyou__detail-val--total {
	font-size: 1.05rem;
	color: var(--mpe-primary);
}

/* Actions */
.mpe-thankyou__actions {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	justify-content: center;
}
.mpe-thankyou__btn {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	padding: .8rem 1.75rem;
	border-radius: 10px;
	font-size: .9rem;
	font-weight: 700;
	text-decoration: none;
	transition: background .2s, transform .2s;
}
.mpe-thankyou__btn--primary {
	background: var(--mpe-primary);
	color: #fff;
}
.mpe-thankyou__btn--primary:hover { background: #178038; transform: translateY(-2px); }
.mpe-thankyou__btn--outline {
	border: 1.5px solid rgba(0,0,0,.15);
	color: var(--mpe-ink-700, #374151);
	background: #fff;
}
.mpe-thankyou__btn--outline:hover { border-color: var(--mpe-primary); color: var(--mpe-primary); }

/* État échoué */
.mpe-thankyou__failed-icon { color: #ef4444; margin-bottom: 1.5rem; }
.mpe-thankyou__failed h1 {
	font-size: 1.8rem;
	font-weight: 800;
	color: var(--mpe-ink-900, #111827);
	margin: 0 0 .75rem;
}
.mpe-thankyou__failed p { color: var(--mpe-ink-500, #6b7280); margin: 0 0 2rem; }
.mpe-thankyou__failed-actions { display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center; }

/* Notices checkout */
.mpe-co-page .woocommerce-message,
.mpe-co-page .woocommerce-error,
.mpe-co-page .woocommerce-info {
	border-radius: 10px;
	margin-bottom: 1.5rem;
}

/* ================================================================
   PAGE À PROPOS — MPE
   ================================================================ */

/* ── Utilitaires section ── */
.mpe-about-section {
	padding: 5rem 0;
}
.mpe-about-sh {
	display: flex;
	align-items: center;
	gap: .75rem;
	margin-bottom: 2.5rem;
}
.mpe-about-sh--center {
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: .5rem;
}
.mpe-about-sh__bar {
	display: block;
	width: 4px;
	height: 28px;
	border-radius: 9999px;
	background: var(--mpe-primary);
	flex-shrink: 0;
}
.mpe-about-sh--center .mpe-about-sh__bar {
	width: 40px;
	height: 4px;
}
.mpe-about-sh__title {
	font-family: var(--mpe-font-heading);
	font-size: 1.6rem;
	font-weight: 800;
	color: var(--mpe-ink-900, #111827);
	margin: 0;
}
.mpe-about-sh__sub {
	font-size: .88rem;
	color: var(--mpe-ink-500, #6b7280);
	margin: .25rem 0 0;
	line-height: 1.6;
}

/* ══════════════════════════════════════════
   1. HERO
   ══════════════════════════════════════════ */
.mpe-about-hero {
	position: relative;
	background: linear-gradient(135deg, #0b2617 0%, #167330 55%, #1a8a3a 100%);
	color: #fff;
	padding: 5rem 0 4rem;
	overflow: hidden;
}
.mpe-about-hero__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	overflow: hidden;
}
.mpe-about-hero__blob {
	position: absolute;
	border-radius: 9999px;
	filter: blur(70px);
	opacity: .18;
}
.mpe-about-hero__blob--1 {
	width: 500px; height: 500px;
	background: #4ade80;
	top: -200px; left: -100px;
}
.mpe-about-hero__blob--2 {
	width: 400px; height: 400px;
	background: #22d3ee;
	bottom: -150px; right: 10%;
}
.mpe-about-hero__blob--3 {
	width: 300px; height: 300px;
	background: #a78bfa;
	top: 30%; left: 40%;
}

.mpe-about-hero__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	align-items: center;
}
@media (min-width: 900px) {
	.mpe-about-hero__inner { grid-template-columns: 1fr 300px; }
}

/* Badge */
.mpe-about-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .3rem .85rem;
	border-radius: 9999px;
	background: rgba(255,255,255,.12);
	border: 1px solid rgba(255,255,255,.2);
	font-size: .78rem;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	margin-bottom: 1.25rem;
}
.mpe-about-hero__badge-dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	background: #4ade80;
	animation: mpe-pulse 2s infinite;
}
@keyframes mpe-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%       { opacity: .5; transform: scale(1.3); }
}

.mpe-about-hero__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	line-height: 1.1;
	color: #fff;
	margin: 0 0 1rem;
}
.mpe-about-hero__title em {
	font-style: normal;
	color: #4ade80;
}
.mpe-about-hero__tagline {
	font-size: 1.05rem;
	color: rgba(255,255,255,.75);
	font-style: italic;
	margin: 0 0 1.75rem;
}

/* Pills infos */
.mpe-about-hero__pills {
	display: flex;
	flex-wrap: wrap;
	gap: .6rem;
}
.mpe-about-hero__pill {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .35rem .85rem;
	border-radius: 9999px;
	background: rgba(255,255,255,.1);
	border: 1px solid rgba(255,255,255,.18);
	font-size: .78rem;
	font-weight: 500;
	color: rgba(255,255,255,.9);
}

/* Carte fondateur */
.mpe-about-hero__card {
	background: rgba(255,255,255,.08);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,.18);
	border-radius: 18px;
	padding: 1.75rem;
}
.mpe-about-hero__card-avatar {
	width: 64px; height: 64px;
	border-radius: 50%;
	background: rgba(255,255,255,.15);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #4ade80;
	margin-bottom: 1rem;
}
.mpe-about-hero__card-role {
	font-size: .7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: #4ade80;
	margin: 0 0 .2rem;
}
.mpe-about-hero__card-name {
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	margin: 0;
	line-height: 1.3;
}
.mpe-about-hero__card-divider {
	height: 1px;
	background: rgba(255,255,255,.15);
	margin: 1.25rem 0;
}
.mpe-about-hero__card-meta {
	display: flex;
	gap: 1.5rem;
}
.mpe-about-hero__card-meta span {
	display: flex;
	flex-direction: column;
	gap: .15rem;
}
.mpe-about-hero__card-meta strong {
	font-size: 1.05rem;
	font-weight: 800;
	color: #fff;
}
.mpe-about-hero__card-meta small {
	font-size: .68rem;
	color: rgba(255,255,255,.55);
	text-transform: uppercase;
	letter-spacing: .05em;
}

/* ══════════════════════════════════════════
   2. PRÉSENTATION
   ══════════════════════════════════════════ */
.mpe-about-pres { background: #fff; }
.mpe-about-pres__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	align-items: start;
}
@media (min-width: 900px) {
	.mpe-about-pres__layout { grid-template-columns: 1fr 280px; }
}
.mpe-about-pres__lead {
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--mpe-ink-900, #111827);
	line-height: 1.7;
	margin: 0 0 1.25rem;
}
.mpe-about-pres__body {
	font-size: .95rem;
	color: var(--mpe-ink-700, #374151);
	line-height: 1.8;
	margin: 0 0 1rem;
}
.mpe-about-pres__body:last-child { margin-bottom: 0; }

/* Encart origine */
.mpe-about-origin {
	background: linear-gradient(135deg, #0b2617 0%, var(--mpe-primary) 100%);
	border-radius: 16px;
	padding: 2rem;
	color: #fff;
	text-align: center;
}
.mpe-about-origin__year {
	font-size: 3.5rem;
	font-weight: 900;
	font-family: var(--mpe-font-heading);
	color: #4ade80;
	line-height: 1;
	margin-bottom: .5rem;
}
.mpe-about-origin__label {
	font-size: .8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: rgba(255,255,255,.7);
	margin: 0 0 .5rem;
}
.mpe-about-origin__desc {
	font-size: .88rem;
	color: rgba(255,255,255,.85);
	margin: 0 0 1.25rem;
}
.mpe-about-origin__tags {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
	justify-content: center;
}
.mpe-about-origin__tags span {
	padding: .2rem .65rem;
	border-radius: 9999px;
	background: rgba(255,255,255,.12);
	border: 1px solid rgba(255,255,255,.2);
	font-size: .7rem;
	font-weight: 600;
}

/* ══════════════════════════════════════════
   3. MISSION / VISION / DEVISE
   ══════════════════════════════════════════ */
.mpe-about-mvd { background: var(--mpe-bg-body, #f8f9fa); }
.mpe-about-mvd__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 768px) {
	.mpe-about-mvd__grid { grid-template-columns: repeat(3, 1fr); }
}

.mpe-about-mvd-card {
	background: #fff;
	border-radius: 16px;
	padding: 2rem;
	border: 1px solid rgba(0,0,0,.07);
	position: relative;
	overflow: hidden;
	transition: transform .3s var(--mpe-ease), box-shadow .3s var(--mpe-ease);
}
.mpe-about-mvd-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 16px 40px rgba(0,0,0,.1);
}
.mpe-about-mvd-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 4px;
}
.mpe-about-mvd-card--mission::before { background: var(--mpe-primary); }
.mpe-about-mvd-card--vision::before  { background: #0ea5e9; }
.mpe-about-mvd-card--devise::before  { background: #8b5cf6; }

.mpe-about-mvd-card__icon {
	width: 52px; height: 52px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.25rem;
}
.mpe-about-mvd-card--mission .mpe-about-mvd-card__icon { background: rgba(31,155,66,.1); color: var(--mpe-primary); }
.mpe-about-mvd-card--vision .mpe-about-mvd-card__icon  { background: rgba(14,165,233,.1); color: #0ea5e9; }
.mpe-about-mvd-card--devise .mpe-about-mvd-card__icon  { background: rgba(139,92,246,.1); color: #8b5cf6; }

.mpe-about-mvd-card__label {
	font-family: var(--mpe-font-heading);
	font-size: 1rem;
	font-weight: 800;
	color: var(--mpe-ink-900, #111827);
	text-transform: uppercase;
	letter-spacing: .06em;
	margin: 0 0 .875rem;
}
.mpe-about-mvd-card__text {
	font-size: .88rem;
	color: var(--mpe-ink-700, #374151);
	line-height: 1.75;
	margin: 0;
}
.mpe-about-mvd-card__text--quote {
	font-size: 1.25rem;
	font-weight: 700;
	font-style: italic;
	color: #8b5cf6;
	line-height: 1.4;
}

/* ══════════════════════════════════════════
   4. VALEURS FONDAMENTALES
   ══════════════════════════════════════════ */
.mpe-about-values { background: #fff; }
.mpe-about-values__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.25rem;
}
@media (min-width: 640px)  { .mpe-about-values__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .mpe-about-values__grid { grid-template-columns: repeat(4, 1fr); } }

.mpe-about-value-card {
	--val-color: var(--mpe-primary);
	background: #fff;
	border-radius: 14px;
	padding: 1.5rem;
	border: 1px solid rgba(0,0,0,.07);
	transition: transform .25s var(--mpe-ease), box-shadow .25s var(--mpe-ease);
	position: relative;
	overflow: hidden;
}
.mpe-about-value-card::after {
	content: '';
	position: absolute;
	bottom: 0; left: 0; right: 0;
	height: 3px;
	background: var(--val-color);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform .3s var(--mpe-ease);
}
.mpe-about-value-card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(0,0,0,.09); }
.mpe-about-value-card:hover::after { transform: scaleX(1); }

.mpe-about-value-card__icon {
	width: 44px; height: 44px;
	border-radius: 10px;
	background: color-mix(in srgb, var(--val-color) 12%, transparent);
	color: var(--val-color);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
}
.mpe-about-value-card__title {
	font-family: var(--mpe-font-heading);
	font-size: .85rem;
	font-weight: 700;
	color: var(--mpe-ink-900, #111827);
	margin: 0 0 .5rem;
	line-height: 1.3;
}
.mpe-about-value-card__text {
	font-size: .78rem;
	color: var(--mpe-ink-500, #6b7280);
	line-height: 1.6;
	margin: 0;
}

/* ══════════════════════════════════════════
   5. CTA FINAL
   ══════════════════════════════════════════ */
.mpe-about-cta {
	position: relative;
	background: linear-gradient(135deg, #0b2617 0%, #167330 60%, #1a8a3a 100%);
	color: #fff;
	padding: 5rem 0;
	overflow: hidden;
}
.mpe-about-cta__pattern {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
	background-size: 24px 24px;
	pointer-events: none;
}
.mpe-about-cta__inner {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	align-items: flex-start;
}
@media (min-width: 768px) {
	.mpe-about-cta__inner {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}
}
.mpe-about-cta__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 800;
	color: #fff;
	margin: 0 0 .5rem;
}
.mpe-about-cta__desc { font-size: .95rem; color: rgba(255,255,255,.7); margin: 0; }
.mpe-about-cta__right {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
	flex-shrink: 0;
}
.mpe-about-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .8rem 1.75rem;
	border-radius: 10px;
	font-size: .9rem;
	font-weight: 700;
	text-decoration: none;
	transition: background .2s, transform .2s, border-color .2s;
}
.mpe-about-cta__btn--white {
	background: #fff;
	color: var(--mpe-primary-dark, #167330);
}
.mpe-about-cta__btn--white:hover { background: #f0fdf4; transform: translateY(-2px); }
.mpe-about-cta__btn--outline {
	border: 1.5px solid rgba(255,255,255,.4);
	color: #fff;
	background: transparent;
}
.mpe-about-cta__btn--outline:hover { border-color: rgba(255,255,255,.8); transform: translateY(-2px); }

/* ================================================================
   PAGE NOS RÉALISATIONS — MPE
   ================================================================ */

/* ── HERO ── */
.mpe-real-hero {
	position: relative;
	background: linear-gradient(135deg, #0b2617 0%, #167330 55%, #1a8a3a 100%);
	color: #fff;
	padding: 5rem 0 4rem;
	overflow: hidden;
}
.mpe-real-hero__bg {
	position: absolute; inset: 0;
	pointer-events: none; overflow: hidden;
}
.mpe-real-hero__blob {
	position: absolute;
	border-radius: 9999px;
	filter: blur(70px);
	opacity: .15;
}
.mpe-real-hero__blob--1 { width: 520px; height: 520px; background: #4ade80; top: -200px; right: -100px; }
.mpe-real-hero__blob--2 { width: 380px; height: 380px; background: #38bdf8; bottom: -150px; left: 5%; }

.mpe-real-hero__inner {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
}
@media (min-width: 900px) {
	.mpe-real-hero__inner { flex-direction: row; align-items: center; justify-content: space-between; }
}

.mpe-real-hero__badge {
	display: inline-flex; align-items: center; gap: .5rem;
	padding: .3rem .85rem;
	border-radius: 9999px;
	background: rgba(255,255,255,.12);
	border: 1px solid rgba(255,255,255,.2);
	font-size: .78rem; font-weight: 600;
	letter-spacing: .04em; text-transform: uppercase;
	margin-bottom: 1.25rem;
}
.mpe-real-hero__badge-dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	background: #4ade80;
	animation: mpe-pulse 2s infinite;
}
.mpe-real-hero__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	line-height: 1.1;
	color: #fff;
	margin: 0 0 1rem;
}
.mpe-real-hero__title em { font-style: normal; color: #4ade80; }
.mpe-real-hero__desc {
	font-size: .95rem;
	color: rgba(255,255,255,.75);
	line-height: 1.7;
	margin: 0;
	max-width: 520px;
}

/* Stats hero */
.mpe-real-hero__stats {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	background: rgba(255,255,255,.08);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255,255,255,.15);
	border-radius: 16px;
	padding: 1.5rem 2rem;
	flex-shrink: 0;
}
@media (max-width: 899px) { .mpe-real-hero__stats { flex-wrap: wrap; } }
.mpe-real-hero__stat { text-align: center; }
.mpe-real-hero__stat-num {
	display: block;
	font-family: var(--mpe-font-heading);
	font-size: 1.6rem;
	font-weight: 900;
	color: #4ade80;
	line-height: 1;
	margin-bottom: .25rem;
}
.mpe-real-hero__stat-lbl {
	font-size: .7rem;
	color: rgba(255,255,255,.65);
	text-transform: uppercase;
	letter-spacing: .06em;
}
.mpe-real-hero__stat-sep {
	width: 1px; height: 40px;
	background: rgba(255,255,255,.2);
	flex-shrink: 0;
}
@media (max-width: 899px) { .mpe-real-hero__stat-sep { display: none; } }

/* ── Section wrapper ── */
.mpe-real-section {
	padding: 5rem 0;
	background: var(--mpe-bg-body, #f8f9fa);
}

/* ── En-tête de section ── */
.mpe-real-sh {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
	margin-bottom: 3rem;
}
.mpe-real-sh__num {
	font-family: var(--mpe-font-heading);
	font-size: 3.5rem;
	font-weight: 900;
	color: rgba(31,155,66,.12);
	line-height: 1;
	flex-shrink: 0;
	min-width: 3rem;
}
.mpe-real-sh__title {
	font-family: var(--mpe-font-heading);
	font-size: 1.75rem;
	font-weight: 800;
	color: var(--mpe-ink-900, #111827);
	margin: 0 0 .4rem;
}
.mpe-real-sh__sub {
	font-size: .9rem;
	color: var(--mpe-ink-500, #6b7280);
	line-height: 1.6;
	margin: 0;
	max-width: 600px;
}

/* ── Grille villages ── */
.mpe-real-villages {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 900px) {
	.mpe-real-villages { grid-template-columns: 1fr 1fr; }
}

/* ── Carte village ── */
.mpe-real-village {
	--village-accent: var(--mpe-primary);
	background: #fff;
	border-radius: 20px;
	overflow: hidden;
	border: 1px solid rgba(0,0,0,.07);
	display: flex;
	flex-direction: column;
	box-shadow: 0 2px 8px rgba(0,0,0,.06);
	transition: transform .3s var(--mpe-ease), box-shadow .3s var(--mpe-ease);
}
.mpe-real-village:hover {
	transform: translateY(-6px);
	box-shadow: 0 20px 50px rgba(0,0,0,.12);
}

/* Header de la carte (fond coloré) */
.mpe-real-village__header {
	background: var(--village-accent);
	padding: 1.75rem 1.75rem 2rem;
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
.mpe-real-village__header::after {
	content: '';
	position: absolute;
	bottom: -20px; left: 0; right: 0;
	height: 40px;
	background: #fff;
	border-radius: 50% 50% 0 0 / 100% 100% 0 0;
}
.mpe-real-village__header-deco {
	color: rgba(255,255,255,.9);
	flex-shrink: 0;
}

.mpe-real-village__badge {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: .75rem;
}
.mpe-real-village__badge span {
	padding: .2rem .6rem;
	border-radius: 9999px;
	background: rgba(255,255,255,.2);
	font-size: .65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: #fff;
}
.mpe-real-village__year {
	background: rgba(0,0,0,.2) !important;
}
.mpe-real-village__name {
	font-family: var(--mpe-font-heading);
	font-size: 1.35rem;
	font-weight: 800;
	color: #fff;
	margin: 0 0 .6rem;
	line-height: 1.2;
}
.mpe-real-village__location {
	display: flex;
	align-items: center;
	gap: .35rem;
	font-size: .8rem;
	color: rgba(255,255,255,.85);
	margin: 0;
}

/* Corps de la carte */
.mpe-real-village__body {
	padding: 1rem 1.75rem 1.75rem;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

/* Stats */
.mpe-real-village__stats {
	display: flex;
	align-items: center;
	justify-content: space-around;
	gap: .75rem;
	padding: 1.1rem;
	background: var(--mpe-bg-body, #f8f9fa);
	border-radius: 12px;
}
.mpe-real-village__stat {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .1rem;
}
.mpe-real-village__stat-num {
	font-family: var(--mpe-font-heading);
	font-size: 1.8rem;
	font-weight: 900;
	color: var(--village-accent);
	line-height: 1;
}
.mpe-real-village__stat-unit {
	font-size: .72rem;
	font-weight: 700;
	color: var(--mpe-ink-700, #374151);
	text-transform: uppercase;
	letter-spacing: .04em;
}
.mpe-real-village__stat-sub {
	font-size: .65rem;
	color: var(--mpe-ink-500, #6b7280);
}
.mpe-real-village__stat-div {
	width: 1px;
	height: 36px;
	background: rgba(0,0,0,.1);
	flex-shrink: 0;
}

/* Infrastructures */
.mpe-real-village__infra-title {
	display: flex;
	align-items: center;
	gap: .45rem;
	font-size: .78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--village-accent);
	margin: 0 0 .75rem;
}
.mpe-real-village__infra-list {
	list-style: none;
	padding: 0; margin: 0;
	display: flex;
	flex-direction: column;
	gap: .55rem;
}
.mpe-real-village__infra-list li {
	display: flex;
	align-items: flex-start;
	gap: .55rem;
	font-size: .875rem;
	color: var(--mpe-ink-700, #374151);
	line-height: 1.4;
}
.mpe-real-village__infra-list li svg {
	color: var(--village-accent);
	flex-shrink: 0;
	margin-top: 2px;
}

/* Financement */
.mpe-real-village__funding {
	margin-top: auto;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(0,0,0,.07);
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: .5rem;
}
.mpe-real-village__funding-lbl {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	font-size: .68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .07em;
	color: var(--mpe-ink-500, #6b7280);
	white-space: nowrap;
}
.mpe-real-village__funding-name {
	font-size: .82rem;
	font-weight: 600;
	color: var(--mpe-ink-900, #111827);
}

/* ── CTA ── */
.mpe-real-cta {
	position: relative;
	background: linear-gradient(135deg, #0b2617 0%, #167330 60%, #1a8a3a 100%);
	color: #fff;
	padding: 5rem 0;
	overflow: hidden;
}
.mpe-real-cta__pattern {
	position: absolute; inset: 0;
	background-image: radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
	background-size: 24px 24px;
	pointer-events: none;
}
.mpe-real-cta__inner {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}
@media (min-width: 768px) {
	.mpe-real-cta__inner {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}
}
.mpe-real-cta__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 800; color: #fff; margin: 0 0 .5rem;
}
.mpe-real-cta__desc { font-size: .9rem; color: rgba(255,255,255,.7); margin: 0; max-width: 480px; }
.mpe-real-cta__btns { display: flex; flex-wrap: wrap; gap: .75rem; flex-shrink: 0; }
.mpe-real-cta__btn {
	display: inline-flex; align-items: center; gap: .45rem;
	padding: .8rem 1.75rem;
	border-radius: 10px; font-size: .9rem; font-weight: 700;
	text-decoration: none;
	transition: background .2s, transform .2s, border-color .2s;
}
.mpe-real-cta__btn--white { background: #fff; color: var(--mpe-primary-dark, #167330); }
.mpe-real-cta__btn--white:hover { background: #f0fdf4; transform: translateY(-2px); }
.mpe-real-cta__btn--outline { border: 1.5px solid rgba(255,255,255,.4); color: #fff; background: transparent; }
.mpe-real-cta__btn--outline:hover { border-color: rgba(255,255,255,.8); transform: translateY(-2px); }

/* ============================================================
   PAGE DONATION — .mpe-don-*
   ============================================================ */

/* ── Hero ── */
.mpe-don-hero {
	position: relative;
	background: linear-gradient(140deg, #072010 0%, #0d3b1c 45%, #1a6b35 100%);
	color: #fff;
	padding: 5rem 0 4rem;
	overflow: hidden;
}
.mpe-don-hero__bg { position: absolute; inset: 0; pointer-events: none; }
.mpe-don-hero__blob {
	position: absolute; border-radius: 50%;
	filter: blur(80px); opacity: .18;
}
.mpe-don-hero__blob--1 { width: 500px; height: 500px; background: #1F9B42; top: -160px; right: -80px; }
.mpe-don-hero__blob--2 { width: 350px; height: 350px; background: #0ea5e9; bottom: -100px; left: -60px; }
.mpe-don-hero__pattern {
	position: absolute; inset: 0;
	background-image: radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
	background-size: 28px 28px; pointer-events: none;
}
.mpe-don-hero__inner {
	position: relative;
	display: flex; flex-direction: column; gap: 3rem;
}
@media (min-width: 900px) {
	.mpe-don-hero__inner { flex-direction: row; align-items: center; justify-content: space-between; gap: 4rem; }
}
.mpe-don-hero__badge {
	display: inline-flex; align-items: center; gap: .5rem;
	padding: .35rem .9rem; border-radius: 9999px;
	background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
	font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em;
	color: rgba(255,255,255,.9); margin-bottom: 1.25rem;
}
.mpe-don-hero__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(2rem, 5vw, 3.2rem);
	font-weight: 900; line-height: 1.1; color: #fff; margin: 0 0 1.1rem;
}
.mpe-don-hero__title em { font-style: normal; color: #6ee89a; }
.mpe-don-hero__desc {
	font-size: 1rem; color: rgba(255,255,255,.75);
	line-height: 1.7; max-width: 480px; margin: 0 0 2rem;
}
.mpe-don-hero__cta {
	display: inline-flex; align-items: center; gap: .6rem;
	padding: .9rem 2rem; background: #1F9B42; color: #fff;
	border-radius: 12px; font-size: .95rem; font-weight: 700;
	text-decoration: none; transition: background .2s, transform .2s;
}
.mpe-don-hero__cta:hover { background: #167330; transform: translateY(-2px); }
.mpe-don-hero__stats {
	display: flex; flex-wrap: wrap; gap: 1.5rem 2rem; align-items: center; flex-shrink: 0;
}
@media (min-width: 900px) {
	.mpe-don-hero__stats {
		flex-direction: column; align-items: flex-start;
		padding: 2rem 2.5rem;
		background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12);
		border-radius: 20px; backdrop-filter: blur(10px); min-width: 220px; gap: 1.25rem;
	}
}
.mpe-don-hero__stat { text-align: center; }
@media (min-width: 900px) { .mpe-don-hero__stat { text-align: left; } }
.mpe-don-hero__stat-num {
	display: block; font-family: var(--mpe-font-heading);
	font-size: 2rem; font-weight: 900; color: #6ee89a; line-height: 1;
}
.mpe-don-hero__stat-lbl {
	display: block; font-size: .72rem; font-weight: 600;
	text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.6); margin-top: .2rem;
}
.mpe-don-hero__stat-sep { width: 100%; height: 1px; background: rgba(255,255,255,.12); display: none; }
@media (min-width: 900px) { .mpe-don-hero__stat-sep { display: block; } }

/* ── Shared section header ── */
.mpe-don-sh { display: flex; align-items: flex-start; gap: 1.25rem; margin-bottom: 3rem; }
.mpe-don-sh--center { justify-content: center; text-align: center; flex-direction: column; align-items: center; }
.mpe-don-sh__bar {
	flex-shrink: 0; width: 4px; min-height: 52px;
	background: linear-gradient(180deg, #1F9B42 0%, #6ee89a 100%);
	border-radius: 4px; margin-top: 4px;
}
.mpe-don-sh--center .mpe-don-sh__bar { width: 48px; height: 4px; min-height: auto; }
.mpe-don-sh__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(1.4rem, 3vw, 1.9rem);
	font-weight: 800; color: var(--mpe-ink-900, #111827); margin: 0 0 .4rem;
}
.mpe-don-sh__sub { font-size: .9rem; color: var(--mpe-ink-500, #6b7280); margin: 0; max-width: 540px; }

/* ── Amounts section ── */
.mpe-don-amounts { padding: 5rem 0; background: var(--mpe-bg-alt, #f8faf9); }
.mpe-don-amounts__grid {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1.5rem;
}
.mpe-don-amount-card {
	position: relative; background: #fff;
	border: 2px solid transparent; border-radius: 18px; padding: 2rem 1.75rem;
	display: flex; flex-direction: column; gap: 1rem;
	box-shadow: 0 2px 12px rgba(0,0,0,.06);
	transition: transform .25s, box-shadow .25s, border-color .25s;
}
.mpe-don-amount-card:hover {
	transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,.1);
	border-color: var(--don-color);
}
.mpe-don-amount-card--featured { border-color: var(--don-color); box-shadow: 0 8px 28px rgba(0,0,0,.1); }
.mpe-don-amount-card__ribbon {
	position: absolute; top: -1px; right: 20px;
	background: var(--don-color); color: #fff;
	font-size: .65rem; font-weight: 800; text-transform: uppercase; letter-spacing: .07em;
	padding: .3rem .75rem; border-radius: 0 0 8px 8px;
}
.mpe-don-amount-card__icon {
	width: 52px; height: 52px; border-radius: 14px;
	background: color-mix(in srgb, var(--don-color) 12%, transparent);
	display: flex; align-items: center; justify-content: center; color: var(--don-color);
}
.mpe-don-amount-card__amount { display: flex; flex-direction: column; gap: .1rem; }
.mpe-don-amount-card__htg {
	font-family: var(--mpe-font-heading); font-size: 1.8rem; font-weight: 900;
	color: var(--don-color); line-height: 1;
}
.mpe-don-amount-card__htg small { font-size: .9rem; font-weight: 600; }
.mpe-don-amount-card__usd { font-size: .75rem; color: var(--mpe-ink-400, #9ca3af); font-weight: 500; }
.mpe-don-amount-card__label { font-size: 1rem; font-weight: 700; color: var(--mpe-ink-900, #111827); margin: 0; }
.mpe-don-amount-card__desc { font-size: .85rem; color: var(--mpe-ink-500, #6b7280); line-height: 1.6; flex: 1; margin: 0; }
.mpe-don-amount-card__btn {
	display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
	margin-top: auto; padding: .7rem 1.25rem; border-radius: 10px;
	background: color-mix(in srgb, var(--don-color) 10%, transparent);
	color: var(--don-color); font-size: .85rem; font-weight: 700;
	text-decoration: none; transition: background .2s, color .2s;
}
.mpe-don-amount-card__btn:hover { background: var(--don-color); color: #fff; }

/* ── Payment methods ── */
.mpe-don-methods { padding: 5rem 0; }
.mpe-don-methods__grid {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.25rem; margin-bottom: 2rem;
}
.mpe-don-method-card {
	padding: 1.75rem; border-radius: 16px;
	border: 1.5px solid var(--mpe-border, #e5e7eb); background: #fff;
	display: flex; flex-direction: column; gap: .75rem;
	transition: border-color .2s, box-shadow .2s;
}
.mpe-don-method-card:hover { border-color: #1F9B42; box-shadow: 0 4px 20px rgba(31,155,66,.1); }
.mpe-don-method-card__icon {
	width: 48px; height: 48px; border-radius: 12px;
	display: flex; align-items: center; justify-content: center;
}
.mpe-don-method-card__icon--green  { background: #f0fdf4; color: #1F9B42; }
.mpe-don-method-card__icon--blue   { background: #eff6ff; color: #0ea5e9; }
.mpe-don-method-card__icon--amber  { background: #fffbeb; color: #f59e0b; }
.mpe-don-method-card__icon--purple { background: #faf5ff; color: #8b5cf6; }
.mpe-don-method-card__name { font-size: 1rem; font-weight: 700; color: var(--mpe-ink-900, #111827); margin: 0; }
.mpe-don-method-card__desc { font-size: .83rem; color: var(--mpe-ink-500, #6b7280); line-height: 1.55; flex: 1; margin: 0; }
.mpe-don-method-card__tag {
	display: inline-block; padding: .2rem .65rem; border-radius: 9999px;
	background: var(--mpe-bg-alt, #f3f4f6);
	font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
	color: var(--mpe-ink-500, #6b7280);
}
.mpe-don-methods__note {
	display: flex; align-items: flex-start; gap: .5rem;
	font-size: .85rem; color: var(--mpe-ink-500, #6b7280);
	background: #f0fdf4; border: 1px solid #bbf7d0;
	border-radius: 10px; padding: .9rem 1.2rem;
	max-width: 680px; margin: 0 auto; line-height: 1.5;
}
.mpe-don-methods__note svg { color: #1F9B42; flex-shrink: 0; margin-top: 1px; }

/* ── Form section ── */
.mpe-don-form-section {
	position: relative;
	background: linear-gradient(140deg, #072010 0%, #0d3b1c 60%, #167330 100%);
	padding: 5rem 0; overflow: hidden;
}
.mpe-don-form-section__pattern {
	position: absolute; inset: 0;
	background-image: radial-gradient(rgba(255,255,255,.03) 1px, transparent 1px);
	background-size: 24px 24px; pointer-events: none;
}
.mpe-don-form-layout {
	position: relative; display: grid; grid-template-columns: 1fr; gap: 3rem;
}
@media (min-width: 960px) {
	.mpe-don-form-layout { grid-template-columns: 1fr 1.1fr; align-items: start; }
}
.mpe-don-form-left__eyebrow {
	display: inline-block; font-size: .72rem; font-weight: 700;
	text-transform: uppercase; letter-spacing: .1em; color: #6ee89a; margin-bottom: .75rem;
}
.mpe-don-form-left__title {
	font-family: var(--mpe-font-heading);
	font-size: clamp(1.5rem, 3vw, 2.1rem); font-weight: 800; color: #fff;
	line-height: 1.2; margin: 0 0 1rem;
}
.mpe-don-form-left__desc { font-size: .9rem; color: rgba(255,255,255,.7); line-height: 1.7; margin: 0 0 2rem; }
.mpe-don-form-left__bullets {
	list-style: none; padding: 0; margin: 0 0 2rem;
	display: flex; flex-direction: column; gap: .8rem;
}
.mpe-don-form-left__bullets li {
	display: flex; align-items: flex-start; gap: .65rem;
	font-size: .875rem; color: rgba(255,255,255,.8); line-height: 1.5;
}
.mpe-don-form-left__bullets li svg { color: #6ee89a; flex-shrink: 0; margin-top: 2px; }
.mpe-don-form-left__contact {
	padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.12);
	display: flex; flex-direction: column; gap: .6rem;
}
.mpe-don-form-left__contact-label {
	font-size: .7rem; font-weight: 700;
	text-transform: uppercase; letter-spacing: .08em; color: rgba(255,255,255,.45); margin: 0;
}
.mpe-don-form-left__contact-link {
	display: inline-flex; align-items: center; gap: .5rem;
	font-size: .875rem; color: rgba(255,255,255,.8); text-decoration: none; transition: color .2s;
}
.mpe-don-form-left__contact-link:hover { color: #6ee89a; }

/* Form card */
.mpe-don-form-card {
	background: #fff; border-radius: 20px; padding: 2.5rem;
	box-shadow: 0 20px 60px rgba(0,0,0,.25);
}
.mpe-don-form-card__title {
	font-family: var(--mpe-font-heading); font-size: 1.15rem; font-weight: 800;
	color: var(--mpe-ink-900, #111827); margin: 0 0 1.75rem;
	padding-bottom: 1.25rem; border-bottom: 1.5px solid var(--mpe-border, #e5e7eb);
}
.mpe-don-form { display: flex; flex-direction: column; gap: 1.25rem; }
.mpe-don-form__row { display: flex; flex-direction: column; gap: .45rem; }
.mpe-don-form__row--2col { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 500px) { .mpe-don-form__row--2col { grid-template-columns: 1fr; } }
.mpe-don-form__label {
	font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
	color: var(--mpe-ink-700, #374151);
}
.mpe-don-form__label span { color: #1F9B42; }
.mpe-don-form__field {
	width: 100%; padding: .7rem 1rem;
	border: 1.5px solid var(--mpe-border, #e5e7eb); border-radius: 10px;
	font-size: .9rem; font-family: inherit; color: var(--mpe-ink-900, #111827);
	background: #fafafa; transition: border-color .2s, box-shadow .2s; box-sizing: border-box;
}
.mpe-don-form__field:focus {
	outline: none; border-color: #1F9B42; background: #fff;
	box-shadow: 0 0 0 3px rgba(31,155,66,.12);
}
.mpe-don-form__field--custom-amount { display: none; margin-top: .6rem; }
.mpe-don-form__amounts { display: flex; flex-wrap: wrap; gap: .5rem; }
.mpe-don-form__amount-opt { display: flex; }
.mpe-don-form__amount-opt input[type="radio"] { display: none; }
.mpe-don-form__amount-opt span {
	display: inline-block; padding: .5rem 1rem;
	border: 1.5px solid var(--mpe-border, #e5e7eb); border-radius: 8px;
	font-size: .85rem; font-weight: 700; color: var(--mpe-ink-700, #374151);
	cursor: pointer; transition: border-color .2s, background .2s, color .2s;
}
.mpe-don-form__amount-opt input:checked + span {
	border-color: #1F9B42; background: #f0fdf4; color: #167330;
}
.mpe-don-form__amount-opt span:hover { border-color: #1F9B42; }
.mpe-don-form__submit {
	display: flex; align-items: center; justify-content: center; gap: .6rem;
	width: 100%; padding: .95rem 1.5rem;
	background: #1F9B42; color: #fff; border: none; border-radius: 12px;
	font-size: 1rem; font-weight: 700; font-family: inherit;
	cursor: pointer; transition: background .2s, transform .2s;
}
.mpe-don-form__submit:hover { background: #167330; transform: translateY(-1px); }
.mpe-don-form__note {
	display: flex; align-items: flex-start; gap: .45rem;
	font-size: .75rem; color: var(--mpe-ink-400, #9ca3af); line-height: 1.5; margin: 0;
}
.mpe-don-flash {
	display: flex; align-items: flex-start; gap: .75rem;
	padding: 1rem 1.25rem; border-radius: 10px;
	margin-bottom: 1.25rem; font-size: .875rem; line-height: 1.5;
}
.mpe-don-flash strong { display: block; font-weight: 700; margin-bottom: .15rem; }
.mpe-don-flash p { margin: 0; }
.mpe-don-flash--success { background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534; }
.mpe-don-flash--error   { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }

/* ==========================================================================
   MÉDIATHÈQUE
   ========================================================================== */

/* ── Hero ──────────────────────────────────────────────────────────────── */
.mpe-mm-hero {
	position: relative;
	overflow: hidden;
	background: linear-gradient(135deg, var(--mpe-accent) 0%, var(--mpe-primary-dark) 60%, var(--mpe-primary) 100%);
	padding: 5rem 0 4rem;
	color: #fff;
}
.mpe-mm-hero__blob {
	position: absolute;
	border-radius: 50%;
	opacity: .12;
	pointer-events: none;
}
.mpe-mm-hero__blob--1 {
	width: 480px; height: 480px;
	background: var(--mpe-primary-light);
	top: -140px; right: -100px;
}
.mpe-mm-hero__blob--2 {
	width: 300px; height: 300px;
	background: #fff;
	bottom: -120px; left: -60px;
}
.mpe-mm-hero__inner { position: relative; z-index: 1; }
.mpe-mm-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	font-size: .8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: rgba(255,255,255,.75);
	margin-bottom: 1rem;
}
.mpe-mm-hero__eyebrow-bar {
	display: block;
	width: 28px; height: 3px;
	background: var(--mpe-primary-light);
	border-radius: 2px;
}
.mpe-mm-hero__title {
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	line-height: 1.1;
	margin-bottom: .75rem;
}
.mpe-mm-hero__sub {
	font-size: 1.05rem;
	color: rgba(255,255,255,.8);
	max-width: 520px;
	margin-bottom: 2.5rem;
}
.mpe-mm-hero__stats {
	display: inline-flex;
	align-items: center;
	gap: 0;
	background: rgba(255,255,255,.1);
	border: 1px solid rgba(255,255,255,.2);
	border-radius: var(--mpe-radius-pill);
	padding: .5rem 1.5rem;
	backdrop-filter: blur(8px);
	flex-wrap: wrap;
	row-gap: .5rem;
}
.mpe-mm-hero__stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: .25rem 1.25rem;
}
.mpe-mm-hero__stat-num {
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1.1;
}
.mpe-mm-hero__stat-label {
	display: flex;
	align-items: center;
	gap: .3rem;
	font-size: .7rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: rgba(255,255,255,.75);
	margin-top: .15rem;
}
.mpe-mm-hero__stat-sep {
	width: 1px;
	height: 2.5rem;
	background: rgba(255,255,255,.2);
}

/* ── Filtres ───────────────────────────────────────────────────────────── */
.mpe-mm-filters {
	position: sticky;
	top: 0;
	z-index: 90;
	background: #fff;
	border-bottom: 1px solid #e5e7eb;
	box-shadow: 0 1px 0 rgba(0,0,0,.04);
}
.mpe-mm-filters__inner {
	display: flex;
	align-items: center;
	gap: .5rem;
	padding: .875rem 0;
	overflow-x: auto;
	scrollbar-width: none;
}
.mpe-mm-filters__inner::-webkit-scrollbar { display: none; }
.mpe-mm-filter {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .45rem 1.1rem;
	border-radius: var(--mpe-radius-pill);
	border: 1.5px solid #e5e7eb;
	background: transparent;
	color: #6b7280;
	font-size: .875rem;
	font-weight: 500;
	cursor: pointer;
	transition: all .2s;
	white-space: nowrap;
	flex-shrink: 0;
}
.mpe-mm-filter__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 20px;
	padding: 0 .35rem;
	border-radius: 999px;
	background: #f3f4f6;
	color: #6b7280;
	font-size: .7rem;
	font-weight: 700;
	transition: background .2s, color .2s;
}
.mpe-mm-filter:hover,
.mpe-mm-filter.is-active {
	border-color: var(--mpe-primary);
	background: var(--mpe-primary);
	color: #fff;
}
.mpe-mm-filter:hover .mpe-mm-filter__count,
.mpe-mm-filter.is-active .mpe-mm-filter__count {
	background: rgba(255,255,255,.25);
	color: #fff;
}

/* ── En-têtes de section ───────────────────────────────────────────────── */
.mpe-mm-section {
	padding: 4rem 0;
}
.mpe-mm-section--alt {
	background: #f8f9fa;
}
.mpe-mm-sh {
	display: flex;
	align-items: center;
	gap: .875rem;
	margin-bottom: 2rem;
}
.mpe-mm-sh__bar {
	display: block;
	width: 4px; height: 2rem;
	background: var(--mpe-primary);
	border-radius: 2px;
	flex-shrink: 0;
}
.mpe-mm-sh__title {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--mpe-text-heading);
}
.mpe-mm-sh__count {
	margin-left: auto;
	font-size: .8rem;
	font-weight: 600;
	color: #9ca3af;
	background: #f3f4f6;
	padding: .2rem .65rem;
	border-radius: 999px;
}

/* ── Galerie photos — colonnes masonry CSS ─────────────────────────────── */
.mpe-mm-photo-grid {
	column-count: 2;
	column-gap: .75rem;
}
@media (min-width: 640px)  { .mpe-mm-photo-grid { column-count: 3; } }
@media (min-width: 1024px) { .mpe-mm-photo-grid { column-count: 4; } }

.mpe-mm-photo {
	break-inside: avoid;
	display: block;
	margin-bottom: .75rem;
	border-radius: var(--mpe-radius-md);
	overflow: hidden;
	cursor: pointer;
	position: relative;
	line-height: 0;
}
.mpe-mm-photo--featured {
	column-span: all;   /* sera ignoré dans les navigateurs sans support */
}
@media (min-width: 640px) {
	.mpe-mm-photo--featured {
		break-inside: avoid;
	}
}
.mpe-mm-photo img {
	width: 100%;
	display: block;
	transition: transform .45s ease;
}
.mpe-mm-photo:hover img,
.mpe-mm-photo:focus img {
	transform: scale(1.04);
}
.mpe-mm-photo:focus { outline: 3px solid var(--mpe-primary); outline-offset: 2px; }

.mpe-mm-photo__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,.15) 55%, transparent 100%);
	opacity: 0;
	transition: opacity .3s;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: flex-start;
	padding: 1rem;
	color: #fff;
}
.mpe-mm-photo:hover .mpe-mm-photo__overlay,
.mpe-mm-photo:focus .mpe-mm-photo__overlay {
	opacity: 1;
}
.mpe-mm-photo__zoom {
	position: absolute;
	top: .75rem;
	right: .75rem;
	width: 36px; height: 36px;
	background: rgba(255,255,255,.15);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur(4px);
}
.mpe-mm-photo__title {
	font-size: .8rem;
	font-weight: 600;
	line-height: 1.3;
}

/* ── Grille vidéos ──────────────────────────────────────────────────────── */
.mpe-mm-video-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 580px)  { .mpe-mm-video-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mpe-mm-video-grid { grid-template-columns: repeat(3, 1fr); } }

.mpe-mm-video {
	background: #fff;
	border: 1.5px solid #e5e7eb;
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	cursor: pointer;
	transition: transform .2s, box-shadow .2s, border-color .2s;
}
.mpe-mm-video:hover,
.mpe-mm-video:focus {
	transform: translateY(-4px);
	box-shadow: 0 12px 28px rgba(31,155,66,.12);
	border-color: var(--mpe-primary);
	outline: none;
}
.mpe-mm-video__thumb {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #111827;
}
.mpe-mm-video__thumb img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .4s;
}
.mpe-mm-video:hover .mpe-mm-video__thumb img { transform: scale(1.05); }
.mpe-mm-video__thumb-placeholder {
	width: 100%; height: 100%;
	background: linear-gradient(135deg, #1f2937, #374151);
}
.mpe-mm-video__play {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0,0,0,.25);
	transition: background .2s;
}
.mpe-mm-video:hover .mpe-mm-video__play { background: rgba(0,0,0,.45); }
.mpe-mm-video__play svg {
	color: #fff;
	filter: drop-shadow(0 2px 8px rgba(0,0,0,.5));
	transition: transform .2s;
}
.mpe-mm-video:hover .mpe-mm-video__play svg { transform: scale(1.15); }
.mpe-mm-video__duration {
	position: absolute;
	bottom: .6rem; right: .6rem;
	background: rgba(0,0,0,.75);
	color: #fff;
	font-size: .7rem;
	font-weight: 700;
	padding: .15rem .45rem;
	border-radius: .25rem;
	letter-spacing: .03em;
}
.mpe-mm-video__info {
	padding: 1rem 1.25rem 1.25rem;
}
.mpe-mm-video__title {
	font-size: .9375rem;
	font-weight: 700;
	color: var(--mpe-text-heading);
	margin-bottom: .35rem;
	line-height: 1.35;
}
.mpe-mm-video__excerpt {
	font-size: .8rem;
	color: #6b7280;
	line-height: 1.5;
	margin-bottom: .5rem;
}
.mpe-mm-video__date {
	font-size: .75rem;
	color: #9ca3af;
}

/* ── Grille directs ─────────────────────────────────────────────────────── */
.mpe-mm-direct-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 580px)  { .mpe-mm-direct-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mpe-mm-direct-grid { grid-template-columns: repeat(3, 1fr); } }

.mpe-mm-direct {
	background: #fff;
	border: 1.5px solid #e5e7eb;
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	cursor: pointer;
	transition: transform .2s, box-shadow .2s, border-color .2s;
}
.mpe-mm-direct:hover,
.mpe-mm-direct:focus { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(31,155,66,.12); border-color: var(--mpe-primary); outline: none; }
.mpe-mm-direct--live { border-color: #ef4444; box-shadow: 0 0 0 3px rgba(239,68,68,.12); }
.mpe-mm-direct--live:hover { border-color: #ef4444; box-shadow: 0 12px 28px rgba(239,68,68,.2); }

.mpe-mm-direct__thumb {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #111827;
}
.mpe-mm-direct__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.mpe-mm-direct:hover .mpe-mm-direct__thumb img { transform: scale(1.05); }
.mpe-mm-direct__thumb-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #1a1a2e, #16213e); }

.mpe-mm-direct__badge {
	position: absolute;
	top: .65rem; left: .65rem;
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	padding: .25rem .65rem;
	border-radius: 999px;
	font-size: .68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
}
.mpe-mm-direct__badge--live   { background: #ef4444; color: #fff; }
.mpe-mm-direct__badge--replay { background: rgba(0,0,0,.6); color: #fff; backdrop-filter: blur(4px); }

.mpe-mm-direct__live-dot {
	display: inline-block;
	width: 7px; height: 7px;
	background: #fff;
	border-radius: 50%;
	animation: mpe-live-pulse 1.2s ease-in-out infinite;
}
@keyframes mpe-live-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%       { opacity: .4; transform: scale(.7); }
}

.mpe-mm-direct__info { padding: 1rem 1.25rem 1.25rem; }
.mpe-mm-direct__title  { font-size: .9375rem; font-weight: 700; color: var(--mpe-text-heading); margin-bottom: .35rem; line-height: 1.35; }
.mpe-mm-direct__excerpt { font-size: .8rem; color: #6b7280; line-height: 1.5; margin-bottom: .5rem; }
.mpe-mm-direct__date   { font-size: .75rem; color: #9ca3af; }

/* ── État vide ──────────────────────────────────────────────────────────── */
.mpe-mm-empty { padding: 6rem 0; }
.mpe-mm-empty__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 1rem;
	color: #9ca3af;
}
.mpe-mm-empty__inner svg { color: #d1d5db; }
.mpe-mm-empty__inner h2 { font-size: 1.25rem; font-weight: 600; color: #4b5563; }
.mpe-mm-empty__inner p  { font-size: .9rem; }

/* ── Lightbox photos ────────────────────────────────────────────────────── */
.mpe-lb {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	opacity: 0;
	pointer-events: none;
	transition: opacity .25s;
}
.mpe-lb.is-open {
	opacity: 1;
	pointer-events: all;
}
.mpe-lb__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.93);
	backdrop-filter: blur(6px);
}
.mpe-lb__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	max-width: min(92vw, 1100px);
}
.mpe-lb__img {
	display: block;
	max-width: 100%;
	max-height: 80vh;
	object-fit: contain;
	border-radius: .5rem;
	box-shadow: 0 24px 64px rgba(0,0,0,.6);
}
.mpe-lb__caption {
	margin-top: 1rem;
	text-align: center;
	color: #fff;
}
.mpe-lb__title { display: block; font-size: 1rem; font-weight: 600; }
.mpe-lb__desc  { font-size: .8rem; color: rgba(255,255,255,.6); margin-top: .2rem; }

.mpe-lb__close {
	position: fixed;
	top: 1.25rem; right: 1.25rem;
	z-index: 2;
	width: 42px; height: 42px;
	border-radius: 50%;
	border: none;
	background: rgba(255,255,255,.12);
	color: #fff;
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background .2s;
	backdrop-filter: blur(4px);
}
.mpe-lb__close:hover { background: rgba(255,255,255,.25); }

.mpe-lb__nav {
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	width: 48px; height: 48px;
	border-radius: 50%;
	border: none;
	background: rgba(255,255,255,.12);
	color: #fff;
	font-size: 2rem;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background .2s;
	backdrop-filter: blur(4px);
}
.mpe-lb__nav:hover { background: rgba(255,255,255,.25); }
.mpe-lb__nav--prev { left: 1rem; }
.mpe-lb__nav--next { right: 1rem; }

/* ── Modale vidéo ───────────────────────────────────────────────────────── */
.mpe-vm {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	opacity: 0;
	pointer-events: none;
	transition: opacity .25s;
}
.mpe-vm.is-open {
	opacity: 1;
	pointer-events: all;
}
.mpe-vm__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.92);
	backdrop-filter: blur(6px);
}
.mpe-vm__inner {
	position: relative;
	z-index: 1;
	width: min(900px, 92vw);
}
.mpe-vm__title {
	color: #fff;
	font-size: 1rem;
	font-weight: 600;
	margin-bottom: .75rem;
	padding-right: 2.5rem;
}
.mpe-vm__frame {
	aspect-ratio: 16 / 9;
	background: #000;
	border-radius: var(--mpe-radius-md);
	overflow: hidden;
}
.mpe-vm__frame iframe { width: 100%; height: 100%; border: none; display: block; }

.mpe-vm__close {
	position: absolute;
	top: -2.75rem; right: 0;
	width: 38px; height: 38px;
	border-radius: 50%;
	border: none;
	background: rgba(255,255,255,.12);
	color: #fff;
	font-size: 1.375rem;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background .2s;
	backdrop-filter: blur(4px);
}

/* ═══════════════════════════════════════════════════════════
   MON COMPTE — ÉTAT DÉCONNECTÉ / POST-LOGOUT
   ═══════════════════════════════════════════════════════════ */

.mpe-account-page--guest {
	min-height: 100vh;
}

.mpe-acct-logout {
	position: relative;
	min-height: 100vh;
	background: linear-gradient(135deg, #0d6b2d 0%, #1a9b42 45%, #16a34a 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	padding: 4rem 0;
}

/* Blobs décoratifs */
.mpe-acct-logout__blob--1,
.mpe-acct-logout__blob--2,
.mpe-acct-logout__blob--3 {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}
.mpe-acct-logout__blob--1 {
	width: 520px;
	height: 520px;
	background: rgba(255,255,255,.06);
	top: -140px;
	right: -140px;
}
.mpe-acct-logout__blob--2 {
	width: 340px;
	height: 340px;
	background: rgba(255,255,255,.05);
	bottom: -80px;
	left: -80px;
}
.mpe-acct-logout__blob--3 {
	width: 200px;
	height: 200px;
	background: rgba(255,255,255,.04);
	top: 50%;
	left: 20%;
	transform: translateY(-50%);
}

.mpe-acct-logout__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	max-width: 480px;
	margin: 0 auto;
	padding: 0 1.5rem;
}

/* Icône centrale */
.mpe-acct-logout__icon-wrap {
	width: 96px;
	height: 96px;
	border-radius: 50%;
	background: rgba(255,255,255,.15);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1.5px solid rgba(255,255,255,.3);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	margin-bottom: 1.75rem;
	box-shadow: 0 8px 32px rgba(0,0,0,.12);
}

/* Badge statut */
.mpe-acct-logout__badge {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	background: rgba(255,255,255,.15);
	border: 1px solid rgba(255,255,255,.25);
	border-radius: 999px;
	padding: .3rem .9rem;
	font-size: .75rem;
	font-weight: 600;
	color: rgba(255,255,255,.92);
	letter-spacing: .04em;
	text-transform: uppercase;
	margin-bottom: 1.25rem;
}

.mpe-acct-logout__badge-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #86efac;
	animation: mpe-logout-pulse 2s ease-in-out infinite;
	flex-shrink: 0;
}

@keyframes mpe-logout-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%       { opacity: .55; transform: scale(.8); }
}

/* Titre & sous-titre */
.mpe-acct-logout__title {
	font-size: clamp(1.6rem, 4vw, 2.25rem);
	font-weight: 700;
	color: #fff;
	line-height: 1.2;
	margin: 0 0 .85rem;
}

.mpe-acct-logout__sub {
	font-size: .975rem;
	color: rgba(255,255,255,.8);
	line-height: 1.65;
	margin: 0 0 2rem;
	max-width: 360px;
}

/* Boutons */
.mpe-acct-logout__actions {
	display: flex;
	gap: .875rem;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 2rem;
}

.mpe-acct-logout__btn-primary {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	background: #fff;
	color: #16a34a;
	font-size: .875rem;
	font-weight: 700;
	padding: .7rem 1.6rem;
	border-radius: 999px;
	text-decoration: none;
	transition: transform .2s, box-shadow .2s, background .2s;
	box-shadow: 0 4px 20px rgba(0,0,0,.15);
}
.mpe-acct-logout__btn-primary:hover {
	background: #f0fdf4;
	transform: translateY(-2px);
	box-shadow: 0 8px 28px rgba(0,0,0,.2);
}

.mpe-acct-logout__btn-ghost {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	background: transparent;
	color: rgba(255,255,255,.9);
	font-size: .875rem;
	font-weight: 600;
	padding: .7rem 1.5rem;
	border-radius: 999px;
	border: 1.5px solid rgba(255,255,255,.4);
	text-decoration: none;
	transition: border-color .2s, background .2s, transform .2s;
}
.mpe-acct-logout__btn-ghost:hover {
	background: rgba(255,255,255,.1);
	border-color: rgba(255,255,255,.7);
	transform: translateY(-2px);
}

/* Séparateur */
.mpe-acct-logout__divider {
	width: 100%;
	height: 1px;
	background: rgba(255,255,255,.2);
	margin-bottom: 1.5rem;
}

/* Navigation rapide */
.mpe-acct-logout__nav {
	display: flex;
	gap: 1.25rem;
	flex-wrap: wrap;
	justify-content: center;
}
.mpe-acct-logout__nav a {
	font-size: .8rem;
	color: rgba(255,255,255,.7);
	text-decoration: none;
	font-weight: 500;
	transition: color .2s;
}
.mpe-acct-logout__nav a:hover {
	color: #fff;
}

@media (max-width: 480px) {
	.mpe-acct-logout__actions {
		flex-direction: column;
		align-items: stretch;
	}
	.mpe-acct-logout__btn-primary,
	.mpe-acct-logout__btn-ghost {
		justify-content: center;
	}
}
.mpe-vm__close:hover { background: rgba(255,255,255,.25); }

/* ==========================================================================
   LOADER GLOBAL
   ========================================================================== */
.mpe-global-loader {
	position: fixed;
	inset: 0;
	z-index: 999999;
	background-color: var(--mpe-bg-body, #F8F9FA);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	opacity: 1;
	visibility: visible;
}

.mpe-global-loader.is-hidden {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.mpe-loader-spinner {
	width: 48px;
	height: 48px;
	border: 3px solid rgba(31, 155, 66, 0.15);
	border-top-color: var(--mpe-primary, #1F9B42);
	border-radius: 50%;
	animation: mpe-spin 1s linear infinite;
}

@keyframes mpe-spin {
	to { transform: rotate(360deg); }
}

/* ==========================================================================
   ACTUALITÉS (PAGE MAGAZINE)
   ========================================================================== */

/* 1. Hero Section */
.mpe-news-hero {
	position: relative;
	padding: 8rem 0 5rem;
	overflow: hidden;
	background-color: var(--mpe-bg-body);
}
@media (min-width: 768px) {
	.mpe-news-hero { padding: 10rem 0 6rem; }
}

.mpe-news-hero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
}
.mpe-news-hero__blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: 0.6;
}
.mpe-news-hero__blob--1 {
	top: -10rem; left: -10rem;
	width: 400px; height: 400px;
	background: radial-gradient(circle, rgba(31,155,66,0.15), rgba(40,184,82,0.05));
}
.mpe-news-hero__blob--2 {
	bottom: -5rem; right: -5rem;
	width: 500px; height: 500px;
	background: radial-gradient(circle, rgba(94,92,230,0.08), rgba(191,90,242,0.05));
}
.mpe-news-hero__blob--3 {
	top: 20%; left: 60%;
	width: 300px; height: 300px;
	background: radial-gradient(circle, rgba(255,214,10,0.1), rgba(255,214,10,0.02));
}

.mpe-news-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 48rem;
	margin: 0 auto;
	text-align: center;
}
.mpe-news-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.35rem 0.85rem;
	border-radius: var(--mpe-radius-pill);
	background: rgba(31,155,66,0.1);
	color: var(--mpe-primary-dark);
	font-size: 0.875rem;
	font-weight: 600;
	margin-bottom: 1.5rem;
}
.mpe-news-hero__title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--mpe-text-heading);
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin-bottom: 1.25rem;
}
.mpe-news-hero__desc {
	font-size: 1.125rem;
	color: var(--mpe-text-muted);
	line-height: 1.6;
	margin-bottom: 2.5rem;
}

/* Hero Search */
.mpe-news-hero__search {
	max-width: 32rem;
	margin: 0 auto;
}
.mpe-news-hero__search-wrap {
	position: relative;
	display: flex;
	align-items: center;
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-pill);
	padding: 0.5rem;
	box-shadow: 0 4px 20px rgba(0,0,0,0.05), 0 1px 3px rgba(0,0,0,0.02);
	border: 1px solid rgba(0,0,0,0.05);
	transition: box-shadow var(--mpe-transition-fast), border-color var(--mpe-transition-fast);
}
.mpe-news-hero__search-wrap:focus-within {
	box-shadow: 0 8px 30px rgba(31,155,66,0.15);
	border-color: rgba(31,155,66,0.3);
}
.mpe-news-hero__search-icon {
	color: var(--mpe-text-muted);
	margin-left: 1rem;
	flex-shrink: 0;
}
.mpe-news-hero__search-input {
	flex-grow: 1;
	border: none;
	background: transparent;
	padding: 0.75rem 1rem;
	font-size: 1rem;
	color: var(--mpe-text-main);
	outline: none;
}
.mpe-news-hero__search-input::placeholder {
	color: #A0AEC0;
}
.mpe-news-hero__search-btn {
	background: var(--mpe-primary);
	color: #fff;
	border: none;
	padding: 0.75rem 1.5rem;
	border-radius: var(--mpe-radius-pill);
	font-weight: 600;
	cursor: pointer;
	transition: background var(--mpe-transition-fast), transform var(--mpe-transition-fast);
}
.mpe-news-hero__search-btn:hover {
	background: var(--mpe-primary-dark);
}
.mpe-news-hero__stats {
	margin-top: 1rem;
	font-size: 0.875rem;
	color: var(--mpe-text-muted);
}
.mpe-news-hero__stats strong {
	color: var(--mpe-text-heading);
}

/* 2. Filtre Catégories */
.mpe-news-filter {
	position: sticky;
	top: 4rem; /* Below header */
	z-index: 40;
	background: rgba(248,249,250,0.85);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid rgba(0,0,0,0.05);
	padding: 1rem 0;
}
.mpe-news-filter__pills {
	display: flex;
	gap: 0.75rem;
	overflow-x: auto;
	padding-bottom: 0.5rem; /* for scrollbar */
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none; /* Firefox */
}
.mpe-news-filter__pills::-webkit-scrollbar {
	display: none; /* Chrome/Safari */
}
.mpe-news-filter__pill {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	background: var(--mpe-bg-card);
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: var(--mpe-radius-pill);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--mpe-text-main);
	white-space: nowrap;
	transition: all var(--mpe-transition-fast);
	box-shadow: var(--mpe-shadow-sm);
}
.mpe-news-filter__pill:hover {
	border-color: var(--mpe-primary-light);
	color: var(--mpe-primary);
}
.mpe-news-filter__pill.is-active {
	background: var(--mpe-primary);
	border-color: var(--mpe-primary);
	color: #fff;
	box-shadow: 0 4px 15px rgba(31,155,66,0.3);
}
.mpe-news-filter__count {
	background: rgba(0,0,0,0.06);
	color: inherit;
	padding: 0.1rem 0.4rem;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 600;
}
.mpe-news-filter__pill.is-active .mpe-news-filter__count {
	background: rgba(255,255,255,0.25);
}

/* 3. Main Content Wrapper */
.mpe-news-main {
	padding: 4rem 0 6rem;
}

/* 4. Tags */
.mpe-news-tag {
	display: inline-block;
	padding: 0.35rem 0.85rem;
	background: rgba(0,0,0,0.05);
	color: var(--mpe-text-heading);
	border-radius: var(--mpe-radius-pill);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	transition: background var(--mpe-transition-fast);
	text-decoration: none;
}
.mpe-news-tag:hover {
	background: rgba(0,0,0,0.1);
}
.mpe-news-tag--primary {
	background: rgba(31,155,66,0.1);
	color: var(--mpe-primary-dark);
}
.mpe-news-tag--primary:hover {
	background: rgba(31,155,66,0.15);
}
.mpe-news-tag--light {
	background: rgba(255,255,255,0.2);
	backdrop-filter: blur(8px);
	color: #fff;
	border: 1px solid rgba(255,255,255,0.3);
}
.mpe-news-tag--light:hover {
	background: rgba(255,255,255,0.3);
}

/* 5. Article Vedette (Hero Card) */
.mpe-news-featured {
	margin-bottom: 4rem;
}
.mpe-news-hero-card {
	display: flex;
	flex-direction: column;
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-xl);
	overflow: hidden;
	box-shadow: var(--mpe-shadow-bento);
	transition: transform var(--mpe-transition-smooth), box-shadow var(--mpe-transition-smooth);
	border: 1px solid rgba(0,0,0,0.03);
}
@media (min-width: 992px) {
	.mpe-news-hero-card {
		flex-direction: row;
		align-items: center;
	}
}
.mpe-news-hero-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 40px rgba(0,0,0,0.08);
}
.mpe-news-hero-card__img-wrap {
	position: relative;
	width: 100%;
	height: 300px;
	overflow: hidden;
}
@media (min-width: 992px) {
	.mpe-news-hero-card__img-wrap {
		width: 55%;
		height: 450px;
	}
}
.mpe-news-hero-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.mpe-news-hero-card:hover .mpe-news-hero-card__img {
	transform: scale(1.03);
}
.mpe-news-hero-card__img--placeholder {
	background: linear-gradient(135deg, #E2E8F0, #CBD5E1);
}
.mpe-news-hero-card__body {
	padding: 2rem;
	width: 100%;
}
@media (min-width: 992px) {
	.mpe-news-hero-card__body {
		width: 45%;
		padding: 3.5rem;
	}
}
.mpe-news-hero-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: #E53E3E;
	font-weight: 700;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 1rem;
	margin-right: 1rem;
}
.mpe-news-hero-card__title {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	line-height: 1.25;
	margin: 1rem 0;
}
.mpe-news-hero-card__title a {
	background-image: linear-gradient(transparent calc(100% - 2px), var(--mpe-primary) 2px);
	background-repeat: no-repeat;
	background-size: 0% 100%;
	transition: background-size 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.mpe-news-hero-card:hover .mpe-news-hero-card__title a {
	background-size: 100% 100%;
}
.mpe-news-hero-card__excerpt {
	font-size: 1.125rem;
	color: var(--mpe-text-muted);
	line-height: 1.6;
	margin-bottom: 2rem;
}
.mpe-news-hero-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(0,0,0,0.06);
}
.mpe-news-hero-card__meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--mpe-text-muted);
	font-weight: 500;
}
.mpe-news-hero-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 600;
	color: var(--mpe-primary);
	font-size: 0.9375rem;
	transition: gap var(--mpe-transition-fast), color var(--mpe-transition-fast);
}
.mpe-news-hero-card__cta:hover {
	color: var(--mpe-primary-dark);
	gap: 0.75rem;
}

/* 6. Bento Grid (Posts 2-4) */
.mpe-news-bento-section {
	margin-bottom: 4rem;
}
.mpe-news-bento {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 992px) {
	.mpe-news-bento {
		grid-template-columns: 2fr 1fr;
	}
}

.mpe-news-bento__main {
	position: relative;
	border-radius: var(--mpe-radius-xl);
	overflow: hidden;
	min-height: 400px;
	background-size: cover;
	background-position: center;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 2.5rem;
	color: #fff;
	box-shadow: var(--mpe-shadow-bento);
	transition: transform var(--mpe-transition-smooth), box-shadow var(--mpe-transition-smooth);
}
.mpe-news-bento__main:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 40px rgba(0,0,0,0.15);
}
.mpe-news-bento__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.2) 60%, transparent 100%);
	z-index: 1;
	transition: opacity var(--mpe-transition-fast);
}
.mpe-news-bento__main:hover .mpe-news-bento__overlay {
	opacity: 0.9;
}
.mpe-news-bento__content {
	position: relative;
	z-index: 2;
}
.mpe-news-bento__title {
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	font-weight: 700;
	line-height: 1.3;
	margin: 1rem 0;
}
.mpe-news-bento__title a {
	color: #fff;
}
.mpe-news-bento__title a:hover {
	text-decoration: underline;
	text-underline-offset: 4px;
	text-decoration-thickness: 2px;
}
.mpe-news-bento__meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: rgba(255,255,255,0.8);
}

.mpe-news-bento__side {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.mpe-news-bento__card {
	display: flex;
	flex-direction: column;
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	box-shadow: var(--mpe-shadow-bento);
	transition: transform var(--mpe-transition-fast), box-shadow var(--mpe-transition-fast);
	border: 1px solid rgba(0,0,0,0.03);
	height: 100%;
}
@media (min-width: 576px) and (max-width: 991px) {
	.mpe-news-bento__card {
		flex-direction: row;
	}
}
.mpe-news-bento__card:hover {
	transform: translateY(-3px);
	box-shadow: 0 15px 30px rgba(0,0,0,0.08);
}
.mpe-news-bento__card-img-wrap {
	position: relative;
	height: 180px;
	overflow: hidden;
}
@media (min-width: 576px) and (max-width: 991px) {
	.mpe-news-bento__card-img-wrap {
		width: 40%;
		height: auto;
	}
}
.mpe-news-bento__card-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}
.mpe-news-bento__card:hover .mpe-news-bento__card-img {
	transform: scale(1.05);
}
.mpe-news-bento__card-body {
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	flex-grow: 1;
}
@media (min-width: 576px) and (max-width: 991px) {
	.mpe-news-bento__card-body {
		width: 60%;
	}
}
.mpe-news-bento__card-title {
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.4;
	margin: 0.75rem 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.mpe-news-bento__card-meta {
	margin-top: auto;
	font-size: 0.8125rem;
	color: var(--mpe-text-muted);
	font-weight: 500;
}

/* 7. Grid (Posts 5+) */
.mpe-news-grid-section {
	margin-bottom: 5rem;
}
.mpe-news-cards-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 2rem;
}
.mpe-news-card {
	display: flex;
	flex-direction: column;
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-lg);
	overflow: hidden;
	box-shadow: var(--mpe-shadow-bento);
	transition: transform var(--mpe-transition-smooth), box-shadow var(--mpe-transition-smooth);
	border: 1px solid rgba(0,0,0,0.04);
	height: 100%;
}
.mpe-news-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 15px 35px rgba(0,0,0,0.1);
}
.mpe-news-card__img-wrap {
	position: relative;
	height: 220px;
	overflow: hidden;
}
.mpe-news-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}
.mpe-news-card:hover .mpe-news-card__img {
	transform: scale(1.05);
}
.mpe-news-card__img--placeholder {
	background: linear-gradient(135deg, #E2E8F0, #CBD5E1);
}
.mpe-news-card__tag {
	position: absolute;
	top: 1rem;
	left: 1rem;
	background: rgba(255,255,255,0.85);
	backdrop-filter: blur(8px);
	padding: 0.25rem 0.75rem;
	border-radius: var(--mpe-radius-pill);
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--mpe-text-heading);
	box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}
.mpe-news-card__body {
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}
.mpe-news-card__meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.8125rem;
	color: var(--mpe-text-muted);
	margin-bottom: 0.75rem;
}
.mpe-news-card__title {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.35;
	margin-bottom: 0.75rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.mpe-news-card__excerpt {
	font-size: 0.9375rem;
	color: var(--mpe-text-muted);
	line-height: 1.6;
	margin-bottom: 1.5rem;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	flex-grow: 1;
}
.mpe-news-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--mpe-primary);
	transition: color var(--mpe-transition-fast), gap var(--mpe-transition-fast);
	margin-top: auto;
}
.mpe-news-card:hover .mpe-news-card__cta {
	color: var(--mpe-primary-dark);
	gap: 0.5rem;
}

/* 8. Pagination */
.mpe-news-pagination {
	margin-top: 4rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(0,0,0,0.08);
}
.mpe-news-pagination__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 32rem;
	margin: 0 auto;
}
.mpe-news-pagination__btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.65rem 1.25rem;
	background: var(--mpe-bg-card);
	border: 1px solid rgba(0,0,0,0.1);
	border-radius: var(--mpe-radius-pill);
	font-weight: 500;
	font-size: 0.9375rem;
	color: var(--mpe-text-heading);
	transition: all var(--mpe-transition-fast);
	box-shadow: var(--mpe-shadow-sm);
}
.mpe-news-pagination__btn:hover {
	border-color: var(--mpe-primary);
	color: var(--mpe-primary);
	box-shadow: 0 4px 15px rgba(31,155,66,0.15);
	transform: translateY(-1px);
}
.mpe-news-pagination__info {
	font-size: 0.9375rem;
	color: var(--mpe-text-muted);
	font-weight: 500;
}

/* 9. Empty State */
.mpe-news-empty {
	text-align: center;
	padding: 6rem 1rem;
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-xl);
	border: 1px dashed rgba(0,0,0,0.15);
	max-width: 40rem;
	margin: 0 auto;
}
.mpe-news-empty svg {
	color: var(--mpe-text-muted);
	margin: 0 auto 1.5rem;
	opacity: 0.5;
}
.mpe-news-empty h2 {
	font-size: 1.75rem;
	font-weight: 600;
	margin-bottom: 1rem;
}
.mpe-news-empty p {
	font-size: 1.125rem;
	color: var(--mpe-text-muted);
	margin-bottom: 2rem;
}

/* ==========================================================================
   ARTICLE SEUL (SINGLE POST)
   ========================================================================== */
.mpe-single {
	padding-top: 6rem;
	padding-bottom: 5rem;
}
@media (min-width: 768px) {
	.mpe-single { padding-top: 8rem; }
}

/* En-tête de l'article */
.mpe-single-header {
	max-width: 48rem;
	margin: 0 auto;
	text-align: center;
	padding: 0 1rem;
	margin-bottom: 3rem;
}
.mpe-single-meta {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.5rem;
	font-size: 0.9375rem;
	color: var(--mpe-text-muted);
	font-weight: 500;
	margin-bottom: 1.5rem;
}
.mpe-single-meta a {
	color: var(--mpe-primary);
	text-decoration: none;
}
.mpe-single-meta a:hover {
	text-decoration: underline;
}
.mpe-single-title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--mpe-text-heading);
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin-bottom: 1.5rem;
}
.mpe-single-excerpt {
	font-size: 1.25rem;
	color: var(--mpe-text-muted);
	line-height: 1.6;
	max-width: 42rem;
	margin: 0 auto;
}

/* Image à la une */
.mpe-single-thumb-wrap {
	max-width: 1200px;
	margin: 0 auto 4rem;
	padding: 0 1rem;
}
.mpe-featured-thumb {
	position: relative;
	width: 100%;
	border-radius: var(--mpe-radius-xl);
	overflow: hidden;
	box-shadow: var(--mpe-shadow-bento);
}
.mpe-featured-thumb img {
	width: 100%;
	height: auto;
	max-height: 600px;
	object-fit: cover;
	display: block;
}
.mpe-single-thumb-gap {
	height: 3rem;
}

/* Conteneur principal (centré, étroit pour la lecture) */
.mpe-content-narrow {
	max-width: 45rem;
	margin: 0 auto;
	padding: 0 1rem;
}

/* Typographie du contenu (Prose) */
.mpe-prose {
	font-size: 1.125rem;
	line-height: 1.8;
	color: var(--mpe-text-main);
}
.mpe-prose > * + * {
	margin-top: 1.5rem;
}
.mpe-prose h2, .mpe-prose h3, .mpe-prose h4 {
	color: var(--mpe-text-heading);
	font-weight: 700;
	margin-top: 3rem;
	margin-bottom: 1rem;
	line-height: 1.3;
}
.mpe-prose h2 { font-size: 2rem; }
.mpe-prose h3 { font-size: 1.5rem; }
.mpe-prose a {
	color: var(--mpe-primary);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
}
.mpe-prose a:hover {
	color: var(--mpe-primary-dark);
	text-decoration-thickness: 2px;
}
.mpe-prose blockquote {
	border-left: 4px solid var(--mpe-primary);
	padding-left: 1.5rem;
	font-style: italic;
	font-size: 1.25rem;
	color: var(--mpe-text-heading);
	background: rgba(31,155,66,0.05);
	padding: 1.5rem;
	border-radius: 0 var(--mpe-radius-sm) var(--mpe-radius-sm) 0;
}
.mpe-prose ul {
	list-style: disc;
	padding-left: 1.5rem;
}
.mpe-prose ol {
	list-style: decimal;
	padding-left: 1.5rem;
}
.mpe-prose li {
	margin-bottom: 0.5rem;
}
.mpe-prose img {
	border-radius: var(--mpe-radius-md);
	margin: 2rem auto;
	box-shadow: var(--mpe-shadow-sm);
}

/* Footer d'article : Étiquettes & Partage */
.mpe-post-footer {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(0,0,0,0.08);
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
@media (min-width: 768px) {
	.mpe-post-footer {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
	}
}

.mpe-post-tags {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
}
.mpe-post-tags__label {
	font-weight: 600;
	color: var(--mpe-text-heading);
	margin-right: 0.5rem;
}
.mpe-post-tags a {
	display: inline-block;
	padding: 0.35rem 0.85rem;
	background: rgba(0,0,0,0.04);
	color: var(--mpe-text-muted);
	border-radius: var(--mpe-radius-pill);
	font-size: 0.875rem;
	font-weight: 500;
	text-decoration: none;
	transition: background var(--mpe-transition-fast), color var(--mpe-transition-fast);
}
.mpe-post-tags a:hover {
	background: var(--mpe-primary);
	color: #fff;
}

.mpe-post-share {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
}
.mpe-post-share__label {
	font-weight: 600;
	color: var(--mpe-text-heading);
}
.mpe-post-share__links {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.mpe-share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	background: var(--mpe-bg-card);
	border: 1px solid rgba(0,0,0,0.08);
	color: var(--mpe-text-muted);
	transition: all var(--mpe-transition-fast);
	cursor: pointer;
	box-shadow: var(--mpe-shadow-sm);
	text-decoration: none;
}
.mpe-share-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.mpe-share-btn--fb:hover { color: #fff; background: #1877F2; border-color: #1877F2; }
.mpe-share-btn--x:hover  { color: #fff; background: #000000; border-color: #000000; }
.mpe-share-btn--in:hover { color: #fff; background: #0A66C2; border-color: #0A66C2; }
.mpe-share-btn--wa:hover { color: #fff; background: #25D366; border-color: #25D366; }
.mpe-share-btn--copy:hover { color: #fff; background: var(--mpe-primary); border-color: var(--mpe-primary); }

/* Navigation Article Précédent/Suivant */
.mpe-post-nav {
	margin-top: 4rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(0,0,0,0.08);
}
.mpe-post-nav__inner {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	max-width: 48rem;
	margin: 0 auto;
	padding: 0 1rem;
}
@media (min-width: 768px) {
	.mpe-post-nav__inner {
		flex-direction: row;
		justify-content: space-between;
	}
}
.mpe-post-nav__inner > div {
	flex: 1;
}
.mpe-post-nav__next {
	text-align: right;
}
.mpe-post-nav a {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	text-decoration: none;
	padding: 1.5rem;
	background: var(--mpe-bg-card);
	border-radius: var(--mpe-radius-lg);
	border: 1px solid rgba(0,0,0,0.05);
	box-shadow: var(--mpe-shadow-sm);
	transition: transform var(--mpe-transition-fast), box-shadow var(--mpe-transition-fast);
	height: 100%;
}
.mpe-post-nav a:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 25px rgba(0,0,0,0.08);
	border-color: rgba(31,155,66,0.2);
}
.mpe-post-nav__label {
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--mpe-primary);
}
.mpe-post-nav__link {
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--mpe-text-heading);
	line-height: 1.4;
}

/* ==========================================================================
   WOOCOMMERCE : MON COMPTE (PAGES INTERNES)
   ========================================================================== */

/* 1. Conteneur principal & typographie */
.woocommerce-MyAccount-content {
	font-family: var(--mpe-font-body);
	color: var(--mpe-text-main);
	line-height: 1.6;
}
.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
	font-family: var(--mpe-font-heading);
	color: var(--mpe-text-heading);
	font-weight: 600;
	margin-bottom: 1.5rem;
	letter-spacing: -0.01em;
}

/* 2. Messages et Notices WooCommerce (Glassmorphism) */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
	background: var(--mpe-glass-bg);
	-webkit-backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	border: 1px solid var(--mpe-glass-border);
	border-left: 4px solid var(--mpe-primary);
	border-radius: var(--mpe-radius-md);
	padding: 1.25rem 1.5rem;
	margin-bottom: 2rem;
	box-shadow: 0 1px 0 rgba(255,255,255,0.8) inset, var(--mpe-shadow-sm);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
}
.woocommerce-error { border-left-color: #E53E3E; }
.woocommerce-info { border-left-color: #3182CE; }
.woocommerce-message .button,
.woocommerce-error .button,
.woocommerce-info .button {
	background: var(--mpe-primary);
	color: #fff;
	padding: 0.5rem 1.25rem;
	border-radius: var(--mpe-radius-pill);
	font-size: 0.875rem;
	font-weight: 600;
	border: none;
	transition: all var(--mpe-transition-fast);
	box-shadow: 0 4px 12px rgba(31,155,66,0.2);
}
.woocommerce-message .button:hover,
.woocommerce-error .button:hover,
.woocommerce-info .button:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(31,155,66,0.3);
}

/* 3. Tableaux (Commandes, Téléchargements) - Bento Glass */
.woocommerce-MyAccount-orders,
.woocommerce-table--downloads,
.woocommerce-MyAccount-paymentMethods {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	background: var(--mpe-glass-bg);
	-webkit-backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	border-radius: var(--mpe-radius-xl);
	overflow: hidden;
	box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, var(--mpe-shadow-bento);
	border: 1px solid var(--mpe-glass-border);
	margin-bottom: 2.5rem;
}
.woocommerce-MyAccount-orders th,
.woocommerce-table--downloads th,
.woocommerce-MyAccount-paymentMethods th {
	background: rgba(0,0,0,0.02);
	padding: 1.25rem 1.5rem;
	text-align: left;
	font-weight: 600;
	color: var(--mpe-text-heading);
	border-bottom: 1px solid rgba(0,0,0,0.06);
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.woocommerce-MyAccount-orders td,
.woocommerce-table--downloads td,
.woocommerce-MyAccount-paymentMethods td {
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid rgba(0,0,0,0.04);
	vertical-align: middle;
	font-size: 0.9375rem;
}
.woocommerce-MyAccount-orders tr:last-child td,
.woocommerce-table--downloads tr:last-child td,
.woocommerce-MyAccount-paymentMethods tr:last-child td {
	border-bottom: none;
}
.woocommerce-MyAccount-orders tbody tr,
.woocommerce-table--downloads tbody tr,
.woocommerce-MyAccount-paymentMethods tbody tr {
	transition: background-color var(--mpe-transition-fast);
}
.woocommerce-MyAccount-orders tbody tr:hover,
.woocommerce-table--downloads tbody tr:hover,
.woocommerce-MyAccount-paymentMethods tbody tr:hover {
	background-color: rgba(255,255,255,0.5);
}

/* Boutons d'action dans les tableaux */
.woocommerce-button.view,
.woocommerce-MyAccount-downloads-file {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.5rem 1.25rem;
	background: rgba(31,155,66,0.1);
	border: 1px solid transparent;
	border-radius: var(--mpe-radius-pill);
	color: var(--mpe-primary-dark);
	font-size: 0.8125rem;
	font-weight: 600;
	text-decoration: none;
	transition: all var(--mpe-transition-fast);
	white-space: nowrap;
}
.woocommerce-button.view:hover,
.woocommerce-MyAccount-downloads-file:hover {
	background: var(--mpe-primary);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(31,155,66,0.2);
}

/* Responsive Tableaux */
@media (max-width: 768px) {
	.woocommerce-MyAccount-orders,
	.woocommerce-table--downloads,
	.woocommerce-MyAccount-paymentMethods {
		display: block;
		border: none;
		box-shadow: none;
		background: transparent;
		backdrop-filter: none;
	}
	.woocommerce-MyAccount-orders thead,
	.woocommerce-table--downloads thead,
	.woocommerce-MyAccount-paymentMethods thead {
		display: none;
	}
	.woocommerce-MyAccount-orders tr,
	.woocommerce-table--downloads tr,
	.woocommerce-MyAccount-paymentMethods tr {
		display: block;
		background: var(--mpe-glass-bg);
		-webkit-backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
		backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
		border-radius: var(--mpe-radius-xl);
		margin-bottom: 1.5rem;
		padding: 1.25rem;
		box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, var(--mpe-shadow-bento);
		border: 1px solid var(--mpe-glass-border);
	}
	.woocommerce-MyAccount-orders td,
	.woocommerce-table--downloads td,
	.woocommerce-MyAccount-paymentMethods td {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 0.875rem 0;
		border-bottom: 1px solid rgba(0,0,0,0.04);
		text-align: right;
	}
	.woocommerce-MyAccount-orders td::before,
	.woocommerce-table--downloads td::before,
	.woocommerce-MyAccount-paymentMethods td::before {
		content: attr(data-title);
		font-weight: 600;
		color: var(--mpe-text-heading);
		text-transform: uppercase;
		font-size: 0.8125rem;
		margin-right: 1rem;
		text-align: left;
	}
	.woocommerce-MyAccount-orders td:last-child,
	.woocommerce-table--downloads td:last-child,
	.woocommerce-MyAccount-paymentMethods td:last-child {
		border-bottom: none;
	}
}

/* 4. Adresses (Cards Bento) */
.u-columns.woocommerce-Addresses {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	margin-top: 2rem;
}
@media (min-width: 768px) {
	.u-columns.woocommerce-Addresses {
		grid-template-columns: 1fr 1fr;
	}
}
.woocommerce-Address {
	background: var(--mpe-glass-bg);
	-webkit-backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	border-radius: var(--mpe-radius-xl);
	padding: 2.5rem;
	box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, var(--mpe-shadow-bento);
	border: 1px solid var(--mpe-glass-border);
	position: relative;
	transition: transform var(--mpe-transition-fast), box-shadow var(--mpe-transition-fast);
}
.woocommerce-Address:hover {
	transform: translateY(-4px);
	box-shadow: 0 1px 0 rgba(255,255,255,0.8) inset, var(--mpe-shadow-hover);
}
.woocommerce-Address-title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(0,0,0,0.06);
}
.woocommerce-Address-title h3 {
	margin: 0;
	font-size: 1.25rem;
}
.woocommerce-Address-title .edit {
	color: var(--mpe-primary);
	font-weight: 600;
	font-size: 0.875rem;
	text-decoration: none;
	padding: 0.5rem 1rem;
	background: rgba(31,155,66,0.1);
	border-radius: var(--mpe-radius-pill);
	transition: background var(--mpe-transition-fast), color var(--mpe-transition-fast);
}
.woocommerce-Address-title .edit:hover {
	background: var(--mpe-primary);
	color: #fff;
}
.woocommerce-Address address {
	font-style: normal;
	color: var(--mpe-text-muted);
	line-height: 1.8;
}

/* 5. Formulaires (Édition compte, adresses) */
.woocommerce-EditAccountForm,
.woocommerce-address-fields {
	background: var(--mpe-glass-bg);
	-webkit-backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	backdrop-filter: blur(var(--mpe-glass-blur)) saturate(var(--mpe-glass-saturate));
	border-radius: var(--mpe-radius-xl);
	padding: 2.5rem;
	box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, var(--mpe-shadow-bento);
	border: 1px solid var(--mpe-glass-border);
	max-width: 800px;
}
@media (min-width: 768px) {
	.woocommerce-EditAccountForm,
	.woocommerce-address-fields {
		padding: 3.5rem;
	}
}
.woocommerce-form-row {
	margin-bottom: 1.75rem;
}
.woocommerce-form-row label {
	display: block;
	font-weight: 600;
	color: var(--mpe-text-heading);
	margin-bottom: 0.5rem;
	font-size: 0.9375rem;
}
.woocommerce-form-row input[type="text"],
.woocommerce-form-row input[type="email"],
.woocommerce-form-row input[type="password"],
.woocommerce-form-row input[type="tel"],
.woocommerce-form-row select,
.woocommerce-form-row textarea {
	width: 100%;
	padding: 0.875rem 1.25rem;
	background: rgba(255,255,255,0.8);
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: var(--mpe-radius-md);
	color: var(--mpe-text-main);
	transition: all var(--mpe-transition-fast);
	font-size: 1rem;
	box-shadow: inset 0 2px 4px rgba(0,0,0,0.02);
}
.woocommerce-form-row input:focus,
.woocommerce-form-row select:focus,
.woocommerce-form-row textarea:focus {
	outline: none;
	border-color: var(--mpe-primary);
	box-shadow: 0 0 0 4px rgba(31,155,66,0.15), inset 0 2px 4px rgba(0,0,0,0.02);
	background: #fff;
}
.woocommerce-form-row fieldset {
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: var(--mpe-radius-lg);
	padding: 2rem;
	margin-top: 2.5rem;
	margin-bottom: 2rem;
	background: rgba(255,255,255,0.4);
}
.woocommerce-form-row fieldset legend {
	font-weight: 600;
	color: var(--mpe-text-heading);
	padding: 0 1rem;
	font-size: 1.125rem;
}
.woocommerce-Button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--mpe-primary), var(--mpe-primary-dark));
	color: #fff;
	padding: 1rem 2.5rem;
	border-radius: var(--mpe-radius-pill);
	font-weight: 600;
	font-size: 1rem;
	border: none;
	cursor: pointer;
	transition: background var(--mpe-transition-fast), transform var(--mpe-transition-fast), box-shadow var(--mpe-transition-fast);
	box-shadow: 0 4px 15px rgba(31,155,66,0.3);
}
.woocommerce-Button:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 25px rgba(31,155,66,0.4);
}

/* Select2 / Select WooCommerce (optionnel mais utile) */
.select2-container--default .select2-selection--single {
	height: auto;
	padding: 0.75rem 1.25rem;
	border: 1px solid rgba(0,0,0,0.08);
	border-radius: var(--mpe-radius-md);
	background: rgba(255,255,255,0.8);
	box-shadow: inset 0 2px 4px rgba(0,0,0,0.02);
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height: 1.5;
	color: var(--mpe-text-main);
	padding-left: 0;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 100%;
	right: 1.25rem;
}

/* ── Bouton retour en haut ──────────────────────────────────────────────────── */
.mpe-back-top {
	position: fixed;
	bottom: 2rem;
	right: 2rem;
	z-index: 999;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: none;
	cursor: pointer;
	background: var(--mpe-primary, #1f9b42);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 16px rgba(31,155,66,0.35);
	opacity: 0;
	transform: translateY(12px);
	transition: opacity .25s ease, transform .25s ease, background .2s ease;
	pointer-events: none;
}
.mpe-back-top:not([hidden]) {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
.mpe-back-top:hover {
	background: var(--mpe-primary-dark, #187a34);
	box-shadow: 0 6px 20px rgba(31,155,66,0.45);
}
@media (max-width: 640px) {
	.mpe-back-top {
		bottom: 1.25rem;
		right: 1.25rem;
		width: 42px;
		height: 42px;
	}
}
