/* ==========================
   GLOBAL
   ========================== */


@media (min-width: 1024px) {
	.hob-container {
    gap: 30px;
    display: flex;
    flex-direction: column;
}
	
.page-id-6 .hobpi-section-range .hobpi-section-inner, .home .hobpi-section-range .hobpi-section-inner {
    max-width: 100% !important;
    margin: 0 auto;
    padding: 0 30px !important;
}
}
.hobpi-hero-shop-cta-primary:focus, .hobpi-choice-link:focus {
    color: #ffffff !important;
}


html {
	scroll-behavior: smooth;
}















/* ==========================
  Mini cart
   ========================== */

@media only screen and (min-width: 576px) {
    #side-cart {
        width: 560px !important;
    }
}
@media (max-width: 1024px) {
	#side-cart .hobpi-sidecart-picks { display: none !important; }
}



@media (min-width: 1025px) {
	#side-cart .added_to_cart{
		display: none !important;
	}
	
	#side-cart .hobpi-sidecart-pick-meta {
	right: 54px;
}

#side-cart .hobpi-sidecart-pick-add {
    position: absolute;
    right: 12px;
    bottom: 12px;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255,255,255,0.85);
    background: rgba(15, 20, 15, 0.05);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    color: #fff;
    font-size: 18px;
    line-height: 1;
    padding: 0;
    text-decoration: none;
    transition: transform .25s ease, background .25s ease;
}

#side-cart .hobpi-sidecart-pick:hover .hobpi-sidecart-pick-add {
	transform: scale(1.05);
	background: rgba(15, 20, 15, 0.55);
}

	
	#side-cart { overflow: visible; }

#side-cart .hobpi-sidecart-picks {
    position: absolute;
    top: 40px;
    left: -220px;
    width: 220px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-right: 12px;
    z-index: 2;
}
	
	

#side-cart .hobpi-sidecart-pick {
    position: relative;
    display: block;
    border: 1px solid rgba(255,255,255,.8);
    border-radius: 14px;
    overflow: hidden;
    background: #f9f6f3;
    box-shadow: 0 10px 30px rgba(0,0,0,.25);
    text-decoration: none;
}
	
	aside.hobpi-sidecart-picks {
    pointer-events: none;
}
	.panel-open-cart aside.hobpi-sidecart-picks {
    pointer-events: auto; 
}
	
#side-cart .hobpi-sidecart-pick-img {
    display: block;
    width: 100%;
    height: 200px;
    object-fit: cover;
    transform: scale(1.02);
    transition: transform .35s ease;
}

#side-cart .hobpi-sidecart-pick::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}
	
	
#side-cart .hobpi-sidecart-pick::before {
    background-image: linear-gradient(120deg,#2c3425,#6c7c52,#2c3425);
    background-size: 300% 300%;
    filter: saturate(1.35) contrast(1.15);
    opacity: .3;
    animation: hobGradientShiftminicart 8s ease-in-out infinite;
}

@keyframes hobGradientShiftminicart {
  0%   { background-position: 0% 50%;  transform: scale(1.02); }
  50%  { background-position: 100% 50%; transform: scale(1.06); }
  100% { background-position: 0% 50%;  transform: scale(1.02); }
}

	
	
	
	
	
	
	
	
	#side-cart .hobpi-sidecart-pick-meta {
		position: absolute;
		left: 12px;
		right: 12px;
		bottom: 10px;
		display: flex;
		flex-direction: column;
		gap: 4px;
		color: #fff;
	}

	#side-cart .hobpi-sidecart-pick-title {
		font-size: 13px;
		line-height: 1.2;
	}

	#side-cart .hobpi-sidecart-pick-price {
		font-size: 12px;
		opacity: 0.95;
	}

	#side-cart .hobpi-sidecart-pick-price .amount,
	#side-cart .hobpi-sidecart-pick-price bdi {
		color: #fff;
	}

	#side-cart .hobpi-sidecart-pick:hover .hobpi-sidecart-pick-img {
		transform: scale(1.06);
	}
}






























































/* ==========================
   HERO SECTION
   ========================== */

.hobpi-section-hero {
	padding: 72px 0 80px;
	background: radial-gradient(circle at top left, #f4f8f3 0%, #f9f6f3 40%, #f3f8f2 100%);
}

.hobpi-section-hero .hobpi-hero-inner {
	max-width: 1220px;
	margin: 0 auto;
	padding: 0 16px;
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.1fr);
	gap: 52px;
	align-items: center;
}

/* Colonne texte */

.hobpi-hero-content {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

/* Rating (inchangé) */

.hobpi-hero-rating {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.9);
    box-shadow: 0px 6px 15px rgba(0, 0, 0, 0.04);
	    width: fit-content;
}

.hobpi-hero-rating-stars {
	display: inline-flex;
	gap: 4px;
	font-size: 15px;
	line-height: 1;
}

.hobpi-hero-star {
	display: inline-block;
	position: relative;
}

.hobpi-hero-star-full {
    color: #fabc5b;
}

.hobpi-hero-star-half {
	color: #e0d6c9;
}

.hobpi-hero-star-half::before {
	content: "★";
	position: absolute;
	left: 0;
	top: 0;
	width: 50%;
	overflow: hidden;
	color: #f3b057;
}

.hobpi-hero-rating-text {
	display: flex;
	align-items: baseline;
	gap: 6px;
	font-size: 12px;
	color: #5f5247;
}

.hobpi-hero-rating-score {
	font-weight: 600;
	color: #2c3425;
}

/* Titre + sous-titre */

.hobpi-hero-title {
	font-size: 36px;
	line-height: 1.1;
	color: #2c3425;
	margin: 0;
}



@media (min-width: 1024px) {
	.hobpi-hero-title {
		font-size: 40px;
	}
}

.hobpi-hero-subtitle {
	margin: 0;
	font-size: 14px;
	line-height: 1.7;
	color: #6a5e54;
	max-width: 460px;
}

/* Boutons */

.hobpi-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 4px;
}

.hobpi-hero-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 11px 22px;
    border-radius: 4px;
	font-size: 14px;
	text-decoration: none;
	cursor: pointer;
	border: 1px solid transparent;
	transition: transform 0.25s ease, box-shadow 0.15s ease, background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
	
	

}

.hobpi-hero-btn span {
	white-space: nowrap;
}

.hobpi-hero-btn-primary {
	  overflow: hidden;
  background-image: linear-gradient(120deg, #2c3425, #6c7c52);
  background-size: 200% 200%;
  color: #F9F6F3;
	  animation: hobGradientShift 6s ease infinite;
    box-shadow: 0px 9px 12px rgba(44, 52, 37, 0.2);
		transition: transform 0.25s ease, box-shadow 0.15s ease, background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.hobpi-hero-btn-primary:hover {
	transform: translateY(-1px);
    box-shadow: 0px 10px 16px rgba(44, 52, 37, 0.35);
	    color: #fff !important;
}

.hobpi-hero-btn-secondary {
	background: #ffffff;
	color: #2c3425;
	border-color: rgba(44, 52, 37, 0.18);
	box-shadow: 0 10px 26px rgba(0, 0, 0, 0.04);
}

.hobpi-hero-btn-secondary:hover {
	background: #f7f4f0;
}

/* Ligne de réassurance avec icônes */

.hobpi-hero-reassurance {
	margin-top: 6px;
	font-size: 12px;
	color: #7a6e63;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
}

.hobpi-hero-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.hobpi-hero-icon {
	width: 18px;
	height: 18px;
	border-radius: 999px;
	overflow: hidden;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;

}

.hobpi-hero-icon img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Mini drapeau France */

.hobpi-hero-icon-flag {
	background: none;
	box-shadow: none;
	border-radius: 3px;
	width: 18px;
	height: 12px;
	overflow: hidden;
	display: inline-flex;
	padding: 0;
}

.hobpi-flag-part {
	flex: 1 1 auto;
	height: 100%;
	display: block;
}

.hobpi-flag-blue {
	background: #0053a5;
}

.hobpi-flag-white {
	background: #ffffff;
}

.hobpi-flag-red {
	background: #ef4135;
}

.hobpi-hero-bullet {
	opacity: 0.5;
}

/* Colonne image, plus grande et collée à droite */

.hobpi-hero-media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

.hobpi-hero-media-bg {
    position: absolute;
    inset: 0;
    border-radius: 32px;
    overflow: hidden;
}

.hobpi-hero-bg-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.06);
}

.hobpi-hero-media-main {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 400px;
	border-radius: 30px;
	overflow: hidden;
}

/* Badge et chip identiques */

.hobpi-hero-main-image {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

.hobpi-hero-badge-pill {
	position: absolute;
	z-index: 2;
	top: 18px;
	right: 18px;
padding: 12px 18px;
	border-radius: 999px;
	background: rgba(249, 246, 243, 0.96);
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.22);
	display: flex;
	flex-direction: column;
	gap: 2px;
	max-width: 70%;
}

.hobpi-hero-badge-eyebrow {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #2c3425;
}

.hobpi-hero-badge-text {
	font-size: 12px;
	color: #5f5247;
}

.hobpi-hero-chip {
	position: absolute;
	z-index: 2;
	left: 14px;
	bottom: 16px;
	display: flex;
	align-items: center;
	gap: 0px;
	padding: 8px 20px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.96);
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.22);
	max-width: 80%;
}

.hobpi-hero-chip-image {
    width: 82px;
    height: 52px;
    border-radius: 999px;
    overflow: hidden;
    flex-shrink: 0;
	margin-left: -14px;
}

.hobpi-hero-chip-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hobpi-hero-chip-text p {
	margin: 0;
	font-size: 11px;
	line-height: 1.5;
	color: #5b4f45;
}

/* Bleed à droite sur grands écrans */

@media (min-width: 1200px) {
			.hobpi-hero-badge-pill {
    right: 108px;
}
	.hobpi-hero-media-bg {

    left: -40px;
    top: 50px;
}
	.hobpi-section-hero .hobpi-hero-inner {
		max-width: 1300px;
	}

	.hobpi-hero-media {
		margin-right: -80px;
	}

	.hobpi-hero-media-main {
		max-width: 440px;
	}
}

@media (min-width: 1440px) {
	.hobpi-section-hero .hobpi-hero-inner {
		max-width: 1380px;
	}
	.hobpi-hero-badge-pill {
    right: 98px;
}

	.hobpi-hero-media {
		margin-right: -130px;
	}

	.hobpi-hero-media-main {
		max-width: 500px;
	}
}

@media (min-width: 1540px) {
	.hobpi-section-hero .hobpi-hero-inner {
		max-width: 1450px;
	}
		.hobpi-hero-badge-pill {
    right: 98px;
}

	.hobpi-hero-media {
		margin-right: -130px;
	}

	.hobpi-hero-media-main {
		max-width: 500px;
	}
}


@media (min-width: 1640px) {

		.hobpi-hero-badge-pill {
    right: 28px;
}

	
}


/* Responsive */

@media (max-width: 1024px) {
	.hobpi-section-hero .hobpi-hero-inner {
		grid-template-columns: minmax(0, 1fr);
		gap: 32px;
	}
				.hobpi-hero-badge-pill {
    right: 18px;
}

	.hobpi-hero-content {
		order: 1;
	}

	.hobpi-hero-media {
		order: 0;
		margin-right: 0;
	}

	.hobpi-hero-media-main {
		max-width: 320px;
	}

	.hobpi-section-hero {
		padding: 56px 0 64px;
	}
}

@media (max-width: 720px) {


	.hobpi-hero-subtitle {
		font-size: 13px;
	}

	.hobpi-hero-rating {
		transform: translateX(-4px);
	}

	.hobpi-hero-actions {
		flex-direction: row;
	}

	.hobpi-hero-btn {
		flex: 1 1 auto;
		justify-content: center;
	}

	.hobpi-hero-media-main {
		max-width: 280px;
	}

	.hobpi-hero-badge-pill {
		top: 14px;
		right: 14px;
	}

.hobpi-hero-chip {
    left: 10px;
    right: 10px;
    bottom: 10px;
    max-width: none;
    box-shadow: 0px 8px 8px rgba(0, 0, 0, .22);
}
}

@media (max-width: 480px) {
	.hobpi-hero-title {
    font-size: 40px;
    margin-bottom: -10px;
    margin-top: -10px;
}
	.hobpi-section-hero {
		padding: 44px 0 56px;
	}

.hobpi-hero-rating {
    font-size: 11px;
    display: flex;
    flex-direction: column;
    padding: 12px 40px;
    align-items: flex-start;
    width: 100%;
	        order: 4;
}

	.hobpi-hero-reassurance {
		font-size: 11px;
	}
}













/* ==========================
   HERO SHOP
   ========================== */

.hobpi-hero-shop {
	padding: clamp(3.5rem, 6vw, 4.8rem) 1.5rem 3.2rem;
	background: radial-gradient(circle at top left, #f6f2ec 0, #f8f4ee 40%, #f1ece4 100%);
}

.hobpi-hero-shop-inner {
	max-width: 1120px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(0, 1.1fr);
	gap: 2.5rem;
	align-items: center;
}

@media (max-width: 900px) {
	.hobpi-hero-shop-inner {
		grid-template-columns: minmax(0, 1fr);
		gap: 2rem;
	}
}

.hobpi-hero-shop-content {
	display: flex;
	flex-direction: column;
	gap: 1.4rem;
}

.hobpi-hero-shop-kicker {
	font-size: 0.82rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: #8b7b65;
	margin: 0;
}

.hobpi-hero-shop-title {
	margin: 0;
	font-size: clamp(2rem, 3.2vw, 2.6rem);
	line-height: 1.1;
	color: #252c1f;
}

.hobpi-hero-shop-text {
	margin: 0;
	max-width: 620px;
	font-size: 0.98rem;
	line-height: 1.6;
	color: #4a3b32;
}

.hobpi-hero-shop-cta-group {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	align-items: center;
	margin-top: 0.2rem;
}

.hobpi-hero-shop-cta-primary,
.hobpi-hero-shop-cta-secondary {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	padding: 0.75rem 1.6rem;
	font-size: 0.94rem;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 150ms ease-out, color 150ms ease-out, box-shadow 150ms ease-out, transform 150ms ease-out;
}

.hobpi-hero-shop-cta-primary {
	background: #2c3425;
	color: #f7f3eb;
    box-shadow: 0 10px 10px rgba(10, 12, 6, .06);
}

.hobpi-hero-shop-cta-primary:hover,
.hobpi-hero-shop-cta-primary:focus-visible {
	background: #22291b;
	transform: translateY(-2px);
    box-shadow: 0 10px 15px rgba(10, 12, 6, .12);
	color: #ffffff;
}

.hobpi-hero-shop-cta-secondary {
	background: rgba(255, 255, 255, 0.7);
	color: #2c3425;
	border: 1px solid rgba(44, 52, 37, 0.15);
}

.hobpi-hero-shop-cta-secondary:hover,
.hobpi-hero-shop-cta-secondary:focus-visible {
	background: #ffffff;
	border-color: rgba(44, 52, 37, 0.3);
}

/* Points de réassurance */

.hobpi-hero-shop-trust {
	margin-top: 0.8rem;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 0.75rem;
}

.hobpi-hero-shop-trust-item {
	display: flex;
	align-items: flex-start;
	gap: 0.55rem;
	padding: 0.5rem 0.3rem 0.5rem 0;
}

.hobpi-hero-shop-trust-icon {
	width: 22px;
	height: 22px;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: radial-gradient(circle at 30% 30%, #f8fbf5 0, #dde6d5 45%, #c2cfbd 100%);
	flex-shrink: 0;
}

.hobpi-hero-shop-trust-svg {
	width: 14px;
	height: 14px;
	fill: none;
	stroke: #2c3425;
	stroke-width: 1.4;
	stroke-linecap: round;
	stroke-linejoin: round;
	opacity: 0.95;
}

.hobpi-hero-shop-trust-text {
	font-size: 0.8rem;
	line-height: 1.5;
	color: #4a3b32;
}

/* Colonne media */

.hobpi-hero-shop-media {
	display: grid;
	grid-template-rows: auto auto;
	gap: 1rem;
}

@media (max-width: 900px) {
	.hobpi-hero-shop-media {
		max-width: 420px;
		margin: 0 auto;
	}
}

.hobpi-hero-shop-media-card {
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0px 12px 11px rgba(26, 21, 12, 0.1);
    overflow: hidden;
    position: relative;
}

.hobpi-hero-shop-media-main {
	padding: 0.85rem;
}

.hobpi-hero-shop-media-image-wrap {
	overflow: hidden;
	border-radius: 14px;
	position: relative;
}

.hobpi-hero-shop-media-image {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    transform: scale(1.02);
    transition: transform 300ms ease-out;
    height: 200px;
}

.hobpi-hero-shop-media-main:hover .hobpi-hero-shop-media-image {
	transform: scale(1.05);
}

.hobpi-hero-shop-media-tag {
	position: absolute;
	left: 1.35rem;
	bottom: 1.35rem;
	padding: 0.35rem 0.85rem;
	font-size: 0.78rem;
	border-radius: 999px;
	background: rgba(247, 243, 235, 0.96);
	color: #2c3425;
}

.hobpi-hero-shop-media-secondary {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
	gap: 0.9rem;
}

@media (max-width: 640px) {
	.hobpi-hero-shop-media-secondary {
		grid-template-columns: minmax(0, 1fr);
	}
}

.hobpi-hero-shop-media-card-small {
	padding: 0.75rem 0.8rem 0.85rem;
}

.hobpi-hero-shop-media-caption {
	margin: 0.55rem 0 0;
	font-size: 0.78rem;
	line-height: 1.5;
	color: #4a3b32;
}

.hobpi-hero-shop-media-card-accent {
	background: linear-gradient(145deg, #2c3425 0, #3e4b32 45%, #5a6e4f 100%);
	color: #f6f2ea;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	padding: 0.9rem 1rem;
    box-shadow: 0px 12px 11px rgba(26, 21, 12, 0.1);
}

.hobpi-hero-shop-media-stat-label {
	margin: 0;
	font-size: 0.78rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: #dcd7c5;
}

.hobpi-hero-shop-media-stat-value {
    margin: .15rem 0 .2rem;
    font-size: 0.95rem;
    line-height: 1.5;
    font-weight: 600;
    text-transform: uppercase;
    color: #fdf8ee;
}

.hobpi-hero-shop-media-stat-text {
	margin: 0;
	font-size: 0.8rem;
	line-height: 1.5;
	color: #f2ede0;
}




































/* ==========================
   FAQ
   ========================== */



.page-id-6 .hobpi-section-compare {
 background: transparent !important;
}

/* Section FAQ d'achat */

.hobpi-faq-achat {
	padding: clamp(3rem, 5vw, 3.8rem) 1.5rem 3.2rem;
    background: #f9f6f3;
}

.hobpi-faq-achat-inner {
	max-width: 980px;
	margin: 0 auto;
}

.hobpi-faq-achat-header {
	text-align: center;
	margin-bottom: 2.4rem;
}

.hobpi-faq-achat-kicker {
	margin: 0 0 0.6rem;
	font-size: 0.82rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: #8b7b65;
}

.hobpi-faq-achat-title {
	margin: 0 0 0.9rem;
	font-size: clamp(1.6rem, 2.4vw, 2rem);
	line-height: 1.1;
	color: #262e22;
}

.hobpi-faq-achat-intro {
	max-width: 620px;
	margin: 0 auto;
	font-size: 0.96rem;
	line-height: 1.6;
	color: #4a3b32;
}

/* Liste FAQ */

.hobpi-faq-achat-list {
	display: grid;
	gap: 0.7rem;
}

/* Item FAQ avec details/summary */

.hobpi-faq-item {
	border-radius: 14px;
	background: #ffffff;
	border: 1px solid rgba(149, 129, 106, 0.18);
	overflow: hidden;
}

.hobpi-faq-summary {
	list-style: none;
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.9rem 1.1rem;
	cursor: pointer;
	position: relative;
}

.hobpi-faq-summary::-webkit-details-marker {
	display: none;
}

/* Bullet radar devant la question */

.hobpi-faq-bullet {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: #738a57;
	position: relative;
	margin-top: 0.35rem;
	box-shadow: 0 0 0 0 rgba(76, 94, 63, 0.7);
	animation: hobpi-faq-radar 1.8s infinite ease-out;
	flex-shrink: 0;
}

@keyframes hobpi-faq-radar {
	0% {
		transform: scale(0.7);
		box-shadow: 0 0 0 0 rgba(76, 94, 63, 0.6);
	}
	40% {
		box-shadow: 0 0 0 7px rgba(121, 143, 90, 0.4);
	}
	70% {
		box-shadow: 0 0 0 11px rgba(163, 189, 123, 0);
	}
	100% {
		transform: scale(0.7);
		box-shadow: 0 0 0 0 rgba(163, 189, 123, 0);
	}
}

.hobpi-faq-question {
	font-size: 0.98rem;
	line-height: 1.5;
	color: #262e22;
	padding-right: 1.5rem;
}

/* Chevron à droite du summary */

.hobpi-faq-summary::after {
	content: "";
	position: absolute;
	right: 1.1rem;
	top: 50%;
	transform: translateY(-50%) rotate(0deg);
	width: 10px;
	height: 10px;
	border-right: 1.5px solid #4a3b32;
	border-bottom: 1.5px solid #4a3b32;
	transition: transform 160ms ease-out;
}

/* Etat ouvert: chevron pivoté */

.hobpi-faq-item[open] .hobpi-faq-summary::after {
	transform: translateY(-50%) rotate(45deg);
}

/* Réponse */

.hobpi-faq-answer {
	padding: 0 1.1rem 0.9rem 2.7rem;
	font-size: 0.9rem;
	line-height: 1.6;
	color: #4a3b32;
	border-top: 1px solid rgba(226, 215, 205, 0.7);
}

.hobpi-faq-answer p {
	margin: 0.7rem 0 0;
}

/* Responsive léger */

@media (max-width: 640px) {
	.hobpi-faq-achat {
		padding-inline: 1.3rem;
	}

	.hobpi-faq-answer {
		padding-left: 2.4rem;
	}
}
























































/* ==========================
   CHOIX PRODUIT
   ========================== */
.hobpi-choice li{
 list-style: none;
}

.hobpi-choice {
	padding: clamp(3rem, 5vw, 3.8rem) 1.5rem 3rem;
    background: #f9f6f3;
}

.hobpi-choice-inner {
	max-width: 1120px;
	margin: 0 auto;
}

.hobpi-choice-header {
	text-align: center;
	margin-bottom: 2.4rem;
}

.hobpi-choice-kicker {
	margin: 0 0 0.6rem;
	font-size: 0.82rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: #8b7b65;
}

.hobpi-choice-title {
	margin: 0 0 0.9rem;
	font-size: clamp(1.6rem, 2.8vw, 2rem);
	line-height: 1.1;
	color: #262e22;
}

.hobpi-choice-intro {
	max-width: 620px;
	margin: 0 auto;
	font-size: 0.96rem;
	line-height: 1.6;
	color: #4a3b32;
}

/* Grille de cartes produit */

.hobpi-choice-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.3rem;
}

@media (max-width: 960px) {
	.hobpi-choice-grid {
		grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	}
}

.hobpi-choice-card {
	border-radius: 18px;
	background: #ffffff;
	padding: 1.4rem 1.5rem 1.5rem;
	box-shadow: 0 14px 36px rgba(25, 21, 12, 0.06);
	border: 1px solid rgba(149, 129, 106, 0.14);
	display: flex;
	flex-direction: column;
	gap: 0.7rem;
}

.hobpi-choice-card-top {
	display: grid;
	grid-template-columns: minmax(0, 1.6fr) auto;
	gap: 0.8rem;
	align-items: start;
	margin-bottom: 0.2rem;
}

.hobpi-choice-card-text-head {
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}

.hobpi-choice-tag {
	margin: 0;
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #8b7b65;
}

.hobpi-choice-card-title {
	margin: 0;
	font-size: 1rem;
	line-height: 1.35;
	color: #262e22;
}

/* Micro image produit */

.hobpi-choice-thumb {
	width: 75px;
	height: 95px;
	border-radius: 14px;
	overflow: hidden;
	background: #f4eee6;
	display: flex;
	align-items: center;
	justify-content: center;
}

.hobpi-choice-thumb img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    animation: hobpiFloat 4s ease-in-out infinite;
}

@keyframes hobpiFloat {
    0%   { transform: translateY(3px); }
    50%  { transform: translateY(-2px); }
    100% { transform: translateY(3px); }
}


/* Liste avec bullets radar */

.hobpi-choice-list {
	margin: 0.2rem 0 0;
	padding-left: 1.3rem;
	display: grid;
	gap: 0.25rem;
	font-size: 0.9rem;
	line-height: 1.5;
	color: #4a3b32;
	position: relative;
}

.hobpi-choice-list li {
	position: relative;
	padding-left: 0.3rem;
}

.hobpi-choice-list li::before {
	content: "";
	position: absolute;
	left: -1.1rem;
	top: 0.55em;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: #738a57;
	box-shadow: 0 0 0 0 rgba(76, 94, 63, 0.7);
	animation: hobpi-radar-choix-produit 1.6s infinite ease-out;
}

/* Animation radar */

@keyframes hobpi-radar-choix-produit {
	0% {
		transform: scale(0.6);
		box-shadow: 0 0 0 0 rgba(76, 94, 63, 0.7);
	}
	40% {
		box-shadow: 0 0 0 6px rgba(121, 143, 90, 0.5);
	}
	70% {
		box-shadow: 0 0 0 10px rgba(163, 189, 123, 0);
	}
	100% {
		transform: scale(0.6);
		box-shadow: 0 0 0 0 rgba(163, 189, 123, 0);
	}
}

.hobpi-choice-result {
	margin: 0.5rem 0 0.2rem;
	font-size: 0.9rem;
	line-height: 1.5;
	color: #3a2c24;
}

/* Liens vers produits et packs */

.hobpi-choice-actions {
	margin-top: 0.4rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem 0.8rem;
}

.hobpi-choice-link,
.hobpi-choice-link-secondary {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	padding: 0.55rem 1.1rem;
	font-size: 0.86rem;
	text-decoration: none;
	white-space: nowrap;
}

.hobpi-choice-link {
	background: #2c3425;
	color: #f7f3eb;
}

.hobpi-choice-link:hover,
.hobpi-choice-link:focus-visible {
	background: #22291b;
	color: #ffffff;
}

.hobpi-choice-link-secondary {
	background: #f7f1ea;
	color: #2c3425;
	border: 1px solid rgba(44, 52, 37, 0.15);
}

.hobpi-choice-link-secondary:hover,
.hobpi-choice-link-secondary:focus-visible {
	background: #ffffff;
	border-color: rgba(44, 52, 37, 0.3);
}

/* Responsive léger */

@media (max-width: 640px) {
	.hobpi-choice {
		padding-inline: 1.3rem;
	}

	.hobpi-choice-card-top {
		grid-template-columns: minmax(0, 1fr) auto;
	}
}
































/* ==========================
   ABOUT SECTION 
   ========================== */

.hobpi-about-intro-wrap {
    position: relative;
    overflow: hidden;
    background: #f9f6f3;
    border-bottom: 1px solid #2c342512;
}


/* Contenu */
.hobpi-about-intro {
	position: relative;
	z-index: 2;
	padding: 70px 52px;
	max-width: 760px;
}

.hobpi-about-intro p,
.hobpi-about-intro h2 {
	position: relative;
	z-index: 2;
}

/* Responsive */
@media (max-width: 680px) {
	.hobpi-about-intro {
		padding: 48px 26px;
	}
}

.hobpi-about {
    padding: 0px 0 60px;
	background: #ffffff;
}

.hobpi-about-inner {
	max-width: 1080px;
	margin: 0 auto;
	padding: 0 16px;
}

/* Intro */

.hobpi-about-intro {
      max-width: 950px;
    text-align: center;
    margin: 0 auto;
    padding-bottom: 50px;
}

.hobpi-about-eyebrow {
	font-size: 12px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #8b827a;
	margin: 0 0 6px;
}

.hobpi-about-title {
	font-size: 28px;
	line-height: 1.3;
	color: #231b16;
	margin: 0 0 14px;
}

.hobpi-about-lead {
	font-size: 15px;
	line-height: 1.8;
	color: #5f5248;
	margin: 0 0 10px;
}

/* Rows */

.hobpi-about-row {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.3fr);
	gap: 40px;
	align-items: center;
	padding: 32px 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.hobpi-about-row:last-of-type {
	
	margin-bottom: 28px;
}

/* Variante Constance: image à droite */

.hobpi-about-row-constance {
	grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.95fr);
}

/* Colonnes */

.hobpi-about-col {
	min-width: 0;
}

/* Image */

.hobpi-about-figure {
	margin: 0;
	border-radius: 6px;
	overflow: hidden;
	position: relative;
	background: #e5efe3;
}

.hobpi-about-figure img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

.hobpi-about-caption {
	position: absolute;
	left: 14px;
	bottom: 14px;
	padding: 6px 10px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.92);
	font-size: 11px;
	color: #2c3425;
}

/* Texte */

.hobpi-about-name {
    font-size: 25px;
    font-weight: 600;
    color: #2c3425;
    margin: 0 0 10px;
}
.hobpi-about-col.hobpi-about-col-paragraphe {
    padding: 15px 18px 25px;
    background: #f9f6f3;
    border-radius: 6px;
}
.hobpi-about-role {
	font-size: 13px;
	color: #8a7a6f;
	margin: 0 0 12px;
}

.hobpi-about-col-text p {
	font-size: 14px;
	line-height: 1.8;
	color: #605349;
	margin: 0 0 10px;
}

/* Liste */

.hobpi-about-list {
	list-style: none;
	padding: 0;
	margin: 8px 0 0;
}

.hobpi-about-list li {
	position: relative;
	padding-left: 14px;
	font-size: 13px;
	line-height: 1.7;
	color: #74665b;
	margin-bottom: 4px;
}
.hobpi-about-list li::before {
    content: "";
    position: absolute;
    left: -2px;
    top: 0.5em;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #738a57;
    box-shadow: 0 0 0 0 rgba(76, 94, 63, 0.7);
    animation: hobpi-radar-about 1.6s infinite ease-out;
}

/* Animation du halo qui se dilate et disparaît */
@keyframes hobpi-radar-about {
0% {
    transform: scale(0.6);
    box-shadow: 0 0 0 0 rgba(76, 94, 63, 0.7);
}

40% {
    box-shadow: 0 0 0 6px rgba(121, 143, 90, 0.5);
}
70% {
    box-shadow: 0 0 0 10px rgba(163, 189, 123, 0);
}
100% {
    transform: scale(0.6);
    box-shadow: 0 0 0 0 rgba(163, 189, 123, 0);
    }
}

/* Outro */

.hobpi-about-outro {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}

.hobpi-about-outro-text {
	margin: 0;
	max-width: 640px;
	font-size: 14px;
	line-height: 1.8;
	color: #5f5248;
}

.hobpi-about-outro-link {
	font-size: 13px;
	text-decoration: none;
	color: #2c3425;
	padding: 8px 18px;
	border-radius: 999px;
	border: 1px solid rgba(44, 52, 37, 0.25);
	background: #ffffff;
	box-shadow: 0 10px 26px rgba(0, 0, 0, 0.05);
	white-space: nowrap;
	transition: background-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.hobpi-about-outro-link:hover {
	background: #f3efe7;
	transform: translateY(-1px);
	box-shadow: 0 16px 36px rgba(0, 0, 0, 0.09);
}

/* Responsive */

@media (max-width: 992px) {
	.hobpi-about-row,
	.hobpi-about-row-constance {
		grid-template-columns: minmax(0, 1fr);
		gap: 24px;
	}

	.hobpi-about-row-constance .hobpi-about-col-image {
		order: -1;
	}
}

@media (max-width: 600px) {


	.hobpi-about-title {
		font-size: 24px;
	}

	.hobpi-about-intro {
		margin-bottom: 36px;
	}

	.hobpi-about-row {
		padding: 24px 0;
	}

.hobpi-about-outro {
    align-items: center;
    text-align: center;
    display: flex;
    justify-content: center;
}
}


.hob-container-routine {
    max-width: 1350px;
    margin: auto;
    padding: 0px 30px;
}































/* ==========================
   NOTRE VISION SECTION 
   ========================== */

.hobpi-section-science-global {
	padding: 72px 0 72px;
background: #fff;
}

.hobpi-section-science-global .hobpi-section-inner {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 16px;
}

/* HEADER */

.hobpi-science-global-header {
	text-align: left;
	max-width: 880px;
	margin-bottom: 38px;
}

.hobpi-section-science-global .hobpi-eyebrow {
	font-size: 12px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #8c8277;
	margin: 0 0 6px;
}

.hobpi-section-science-global .hobpi-section-title {
	font-size: 28px;
	line-height: 1.25;
	color: #2c3425;
	margin: 0 0 10px;
}

.hobpi-section-science-global .hobpi-section-lead {
	font-size: 15px;
	line-height: 1.7;
	color: #63584e;
	margin: 0;
}

.hobpi-science-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 18px;
}

.hobpi-science-pills span {
    font-size: 12px;
    padding: 6px 11px;
    border-radius: 999px;
    background: rgb(249 246 243);
    color: #3b342b;
    border: 1px solid #2a242314;
}

/* HEADER EXTRA: PIERRE + ABSTRACT */

.hobpi-science-header-extra {
	margin-top: 22px;
	display: grid;
	grid-template-columns: minmax(0, 1.8fr) minmax(0, 1.2fr);
	gap: 18px;
	align-items: stretch;
}

.hobpi-science-person {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 14px;
	align-items: center;
	padding: 12px 14px;
	border-radius: 16px;
	background: #fff;
	box-shadow: 0 16px 32px rgba(0, 0, 0, 0.04);
	border: 1px solid rgba(0, 0, 0, 0.04);
}

.hobpi-science-person-avatar {
    width: 200px;
    height: 220px;
    border-radius: 9px;
    overflow: hidden;
    flex-shrink: 0;
    position: relative;
}

.hobpi-science-person-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.hobpi-science-person-text {
	font-size: 12px;
	line-height: 1.6;
	color: #6d6258;
}

.hobpi-science-person-name {
	font-size: 13px;
	color: #2f291f;
	margin: 0 0 2px;
}

.hobpi-science-person-role {
	font-size: 11px;
	color: #8b7f74;
	margin: 0 0 4px;
}

.hobpi-science-person-note {
	margin: 0;
}

.hobpi-science-header-abstract {
	position: relative;
}

.hobpi-science-abstract-inner {
	border-radius: 20px;
	overflow: hidden;
	height: 100%;
	min-height: 80px;
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.08);
}

.hobpi-science-abstract-inner img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: saturate(1.05);
}

/* GRID PRINCIPALE */

.hobpi-science-main-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 24px;
	margin-bottom: 40px;
}

.hobpi-science-column {
	display: flex;
}

.hobpi-science-card {
	background: #ffffff;
	border-radius: 22px;
	padding: 20px 20px 22px;
	box-shadow: 0 18px 40px rgba(0, 0, 0, 0.04);
	border: 1px solid rgba(0, 0, 0, 0.04);
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.hobpi-science-card-with-media {
	padding-top: 18px;
}

.hobpi-science-card-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 4px;
}

.hobpi-science-card-badge-image {
    width: 74px;
    height: 74px;
    border-radius: 999px;
    overflow: hidden;
    flex-shrink: 0;
    background: #ffffff;
}

.hobpi-science-card-badge-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.hobpi-science-card-title {
	font-size: 18px;
	line-height: 1.4;
	color: #2f291f;
	margin: 0;
}

.hobpi-science-card-text {
	font-size: 14px;
	line-height: 1.6;
	color: #6a5f55;
	margin: 0;
}

.hobpi-science-list-vision {
	list-style: none;
	margin: 6px 0 0;
	padding: 0;
}

.hobpi-science-list-vision li {
	font-size: 13px;
	line-height: 1.6;
	color: #6d6258;
	position: relative;
	padding-left: 14px;
	margin-bottom: 4px;
}

.hobpi-science-list-vision li::before {
    content: "";
    position: absolute;
    left: 0px;
    top: 0.55em;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #014518;
    box-shadow: 0 0 0 0 rgba(76, 94, 63, 0.7);
    animation: hobpi-radar-vision 1.6s infinite ease-out;
}

/* Animation du halo qui se dilate et disparaît */
@keyframes hobpi-radar-vision {
0% {
    transform: scale(0.6);
    box-shadow: 0 0 0 0 rgba(76, 94, 63, 0.7);
}

40% {
    box-shadow: 0 0 0 6px rgba(121, 143, 90, 0.5);
}
70% {
    box-shadow: 0 0 0 10px rgba(163, 189, 123, 0);
}
100% {
    transform: scale(0.6);
    box-shadow: 0 0 0 0 rgba(163, 189, 123, 0);
    }
}

/* MÉTHODE */

.hobpi-science-method {
	margin-bottom: 44px;
}

.hobpi-science-method-header {
	max-width: 640px;
	margin-bottom: 18px;
}

.hobpi-science-subtitle {
	font-size: 16px;
	color: #2f291f;
	margin: 0 0 4px;
}

.hobpi-science-method-header p {
	font-size: 14px;
	line-height: 1.7;
	color: #6b6056;
	margin: 0;
}

.hobpi-science-steps-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}



.hobpi-science-step {
    background: #ffffff;
    border-radius: 18px;
    padding: 14px 14px 16px;
    border: 1px solid rgba(0, 0, 0, 0.04);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.025);
    display: flex;
    gap: 10px;
	   transition: transform .3s ease;
}


article.hobpi-science-step:hover {
    transform: scale(1.05);
    transition: transform .3s ease;
}

.hobpi-science-step-index {
	width: 26px;
	height: 26px;
	border-radius: 999px;
	border: 1px solid rgba(44, 52, 37, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	color: #2c3425;
	flex-shrink: 0;
	background: #f5f1ea;
}

.hobpi-science-step-body h4 {
	font-size: 13px;
	margin: 0 0 4px;
	color: #332b22;
}

.hobpi-science-step-body p {
	font-size: 12px;
	line-height: 1.6;
	color: #72665b;
	margin: 0;
}

/* ENGAGEMENTS */

.hobpi-science-commitments {
	margin-bottom: 44px;
}

.hobpi-science-commitments-header {
	max-width: 580px;
	margin-bottom: 16px;
}

.hobpi-science-commitments-header p {
	font-size: 14px;
	line-height: 1.7;
	color: #6c6157;
	margin: 0;
}

.hobpi-science-commitments-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px;
}

.hobpi-science-commitment-card {
    background: #f9f6f3;
	border-radius: 16px;
	padding: 12px 13px 13px;
	border: 1px solid rgba(0, 0, 0, 0.04);
}

.hobpi-commitment-label {
	font-size: 13px;
	color: #322a21;
	margin: 0 0 4px;
}

.hobpi-commitment-text {
	font-size: 12px;
	line-height: 1.6;
	color: #74685e;
	margin: 0;
}

/* HIGHLIGHT INGREDIENT (OPC) */

.hobpi-science-ingredient-highlight {
	margin-top: 18px;
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	gap: 14px;
	align-items: center;
	padding: 11px 14px;
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid rgba(0, 0, 0, 0.04);
	box-shadow: 0 10px 26px rgba(0, 0, 0, 0.03);
}

.hobpi-ingredient-image {
	width: 64px;
	height: 64px;
	border-radius: 16px;
	overflow: hidden;
	background: #f3eee6;
	flex-shrink: 0;
}

.hobpi-ingredient-image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

.hobpi-ingredient-text {
	font-size: 13px;
	line-height: 1.6;
	color: #6b6156;
}

.hobpi-ingredient-label {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: #8a7e73;
	margin: 0 0 4px;
}

/* PRODUITS PHARES */

.hobpi-science-products-header {
	text-align: left;
	margin-bottom: 18px;
}

.hobpi-science-products-header .hobpi-section-subtitle {
	font-size: 15px;
	line-height: 1.6;
	color: #5f544b;
	margin: 4px 0 0;
}

/* Layout produits + portrait */

.hobpi-science-products-layout {
    display: grid;
    grid-template-columns: minmax(0,3fr) minmax(0,1fr);
    gap: 22px;
    align-items: stretch;
    margin-bottom: 22px;
}

.hobpi-science-products-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.hobpi-science-product-card {
    background: #ffffff;
    border-radius: 22px;
    padding: 18px 18px 20px;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.04);
    border: 1px solid rgba(0, 0, 0, 0.05);
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 350px;
    justify-content: flex-start;
}

.hobpi-product-pill {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 9px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .12em;
    background: #f9f6f3;
    color: #3b3329;
}

.hobpi-product-title {
	font-size: 16px;
	margin: 4px 0 2px;
	color: #2f291f;
}

.hobpi-product-tagline {
	font-size: 13px;
	line-height: 1.5;
	color: #6d6258;
	margin: 0 0 4px;
}

.hobpi-product-list {
	list-style: none;
	margin: 0 0 8px;
	padding: 0;
}

.hobpi-product-list li {
	font-size: 12px;
	line-height: 1.6;
	color: #71675c;
	position: relative;
	padding-left: 13px;
	margin-bottom: 3px;
}

.hobpi-product-list li::before {
	content: "";
	position: absolute;
	left: 3px;
	top: 0.8em;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: #2c3425;
	transform: translateY(-50%);
}
.hobpi-product-link {
    display: inline-flex;
    align-items: center;
    font-size: 13px;
    color: #2c3425;
    text-decoration: none;
    border-bottom: 1px solid rgba(44, 52, 37, 0.45);
    padding-bottom: 1px;
    max-width: max-content;
}



.hobpi-product-link:hover {
	border-bottom-color: rgba(44, 52, 37, 0.9);
}

.hobpi-science-products-portrait {
	display: flex;
	align-items: stretch;
}

.hobpi-products-portrait-inner {
	border-radius: 22px;
	overflow: hidden;
	background: #1e2520;
	color: #f6f2ea;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.hobpi-products-portrait-inner img {
	width: 100%;
	height: 210px;
	object-fit: cover;
	display: block;
}

.hobpi-products-portrait-inner p {
	font-size: 13px;
	line-height: 1.7;
	padding: 12px 14px 14px;
	margin: 0;
}

/* CTA produits */

.hobpi-science-products-cta {
	text-align: left;
}

.hobpi-products-main-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 22px;
    border-radius: 999px;
    border: none;
    background: #2c3425;
    color: #f6f2ea;
    font-size: 13px;
    text-decoration: none;
    box-shadow: 0 8px 16px rgba(0,0,0,.05);
	transition: all .3s ease;
}

.hobpi-products-main-cta:hover {
    opacity: 0.8;
    color: #fff !important;
	    transition: all .3s ease;
}



.hobpi-products-note {
	font-size: 11px;
	line-height: 1.6;
	color: #7a6f65;
	margin: 8px 0 0;
}

/* RESPONSIVE */

@media (max-width: 1024px) {
	.hobpi-science-main-grid {
		grid-template-columns: 1fr;
	}

	.hobpi-science-steps-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hobpi-science-commitments-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hobpi-science-products-layout {
		grid-template-columns: 1fr;
	}

	.hobpi-science-products-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hobpi-science-header-extra {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 720px) {
	.hobpi-section-science-global {
		padding: 52px 0 56px;
	}

	.hobpi-science-global-header {
		margin-bottom: 28px;
	}

	.hobpi-section-science-global .hobpi-section-title {
		font-size: 24px;
	}

	.hobpi-science-steps-grid {
		grid-template-columns: 1fr;
	}

	.hobpi-science-commitments-grid {
		grid-template-columns: 1fr;
	}

	.hobpi-science-products-grid {
		grid-template-columns: 1fr;
	}

	.hobpi-science-header-extra {
		margin-top: 18px;
	}
	
	.hobpi-science-person-avatar {
    width: 100px;
    height: 200px;

}
}



/* ==========================
   Bannière science / univers
   ========================== */

.hobpi-science-banner {
	margin: 56px auto 0;
}

.hobpi-science-banner-inner {
	max-width: 100%;
	margin: 0 auto;
}

.hobpi-science-banner-media {
    position: relative;
    display: block;
    border-radius: 0px;
    overflow: hidden;
    margin-bottom: 50px;
    background: #0f1810;
}

.hobpi-science-banner-image {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    filter: saturate(1.1) contrast(1.03);
    max-height: 520px;
    object-position: center center;
}
/* Pill en bas à gauche */

.hobpi-science-banner-pill {
	padding: 12px 18px;
	position: absolute;
	left: 20px;
	bottom: 20px;
	display: inline-flex;
	flex-direction: column;
	gap: 4px;

	border-radius: 999px;
	background: rgba(9, 22, 13, 0.9);
	color: #f6f3ec;
	box-shadow: 0 14px 40px rgba(0, 0, 0, 0.35);
	max-width: 80%;
}

.hobpi-banner-pill-eyebrow {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	opacity: 0.9;
}

.hobpi-banner-pill-main {
	font-size: 13px;
	line-height: 1.4;
}

/* Responsive */

@media (max-width: 768px) {
	.hobpi-science-banner-pill {
    display: none;
	}
	.hobpi-science-product-card {

    min-height: 250px;

}
}
@media (min-width: 768px) {
	.hobpi-science-banner {
		margin-top: 72px;
	}

	.hobpi-science-banner-inner {
	}

	.hobpi-science-banner-pill {
		left: 28px;
		bottom: 28px;
 padding: 12px 48px;
	}

	.hobpi-banner-pill-main {
		font-size: 14px;
	}
}

@media (min-width: 1024px) {
	.hobpi-science-banner-inner {
		padding: 0;
	}

	.hobpi-science-banner-media {
		border-radius: 0px;
	}

	.hobpi-science-banner-pill {
		left: 36px;
		bottom: 32px;
	}
}

.hobpi-science-card-badge-image {
    opacity: 0.7;
}














































































/* ==========================
   ABONNEMENT
   ========================== */


.hobpi-abonnement {
	padding: clamp(3rem, 5vw, 4.5rem) 1.5rem;
	background: radial-gradient(circle at top left, #f6f2ec 0, #f8f5f0 40%, #f2eee8 100%);
}

.hobpi-abonnement-inner {
	max-width: 1120px;
	margin: 0 auto;
}

.hobpi-abonnement-header {
	text-align: center;
	margin-bottom: clamp(2.5rem, 4vw, 3.5rem);
}

.hobpi-abonnement-kicker {
	font-size: 0.85rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #8a7a64;
	margin: 0 0 0.75rem;
}

.hobpi-abonnement-title {
	font-size: clamp(1.8rem, 3vw, 2.4rem);
	line-height: 1.1;
	margin: 0 0 1rem;
	color: #2c3425;
}

.hobpi-abonnement-intro {
	max-width: 640px;
	margin: 0 auto;
	font-size: 0.98rem;
	line-height: 1.6;
	color: #5a5144;
}

.hobpi-abonnement-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

/* Cartes de base */

.hobpi-abonnement-card {
	background: #ffffff;
	border-radius: 16px;
	padding: 1.4rem 1.5rem 1.5rem;
	box-shadow: 0 14px 40px rgba(17, 19, 12, 0.06);
	border: 1px solid rgba(44, 52, 37, 0.06);
	display: flex;
	flex-direction: column;
	gap: 0.8rem;
}

.hobpi-abonnement-card-header {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 0.25rem;
}

.hobpi-abonnement-icon {
    width: 15px;
    height: 15px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    top: 2px;
    background: radial-gradient(circle at 30% 30%,#e6f0e2 0,#c7d6c1 45%,#a8b79c 100%);
    position: relative;
}

.hobpi-abonnement-icon-svg {
	width: 11px;
	height: 11px;
	fill: #2c3425;
	opacity: 0.9;
}

.hobpi-abonnement-card-title {
	font-size: 1rem;
	line-height: 1.3;
	margin: 0;
	color: #2c3425;
}

.hobpi-abonnement-card-body {
	font-size: 0.95rem;
	line-height: 1.6;
	color: #4c4336;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.hobpi-abonnement-card-body p {
	margin: 0;
}

/* Variantes de cartes */

.hobpi-abonnement-card-wide {
	grid-column: auto;
}

.hobpi-abonnement-card-accent {
	background: linear-gradient(140deg, #2c3425 0, #3b4730 45%, #586d4e 100%);
	color: #f6f3ea;
	border-color: rgba(255, 255, 255, 0.08);
}

.hobpi-abonnement-card-accent .hobpi-abonnement-card-title {
	color: #f9f5ee;
}

.hobpi-abonnement-card-accent .hobpi-abonnement-card-body {
	color: #f3eee3;
}

.hobpi-abonnement-card-accent .hobpi-abonnement-icon {
	background: radial-gradient(circle at 30% 30%, #f9fbf6 0, #d8e0d2 45%, #c0cdbc 100%);
}

.hobpi-abonnement-card-accent .hobpi-abonnement-icon-svg {
	fill: #2c3425;
}

/* Highlight prix / phrases clés */

.hobpi-abonnement-highlight {
	font-weight: 600;
	color: #2c3425;
}

.hobpi-abonnement-card-accent .hobpi-abonnement-highlight {
	color: #fdf8ee;
}

.hobpi-price-strong {
	font-weight: 700;
	color: #2c3425;
}

.hobpi-price-muted {
	text-decoration: line-through;
	color: #9a8c79;
}

/* Liste */

.hobpi-abonnement-list {
	margin: 0.3rem 0 0.5rem 0;
	padding-left: 1.1rem;
	display: grid;
	gap: 0.25rem;
}

.hobpi-abonnement-list li {
	font-size: 0.94rem;
}

/* CTA */

.hobpi-abonnement-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 0.9rem;
	padding: 0.75rem 1.6rem;
	border-radius: 999px;
	background: #f6f2ec;
	color: #2c3425;
	font-size: 0.94rem;
	font-weight: 600;
	text-decoration: none;
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
	transform: translateY(0);
	transition: transform 160ms ease-out, box-shadow 160ms ease-out, background-color 160ms ease-out, color 160ms ease-out;
}

.hobpi-abonnement-cta:hover,
.hobpi-abonnement-cta:focus-visible {
	background: #ffffff;
	color: #1f261b;
	box-shadow: 0 16px 32px rgba(0, 0, 0, 0.24);
	transform: translateY(-2px);
}

/* Responsive */

@media (min-width: 640px) {
	.hobpi-abonnement {
		padding-inline: 2.5rem;
	}

	.hobpi-abonnement-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hobpi-abonnement-card-wide {
		grid-column: 1 / -1;
	}
}

@media (min-width: 960px) {
	.hobpi-abonnement {
		padding-inline: 3.5rem;
	}

	.hobpi-abonnement-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 1.75rem;
	}

	.hobpi-abonnement-card:nth-child(1),
	.hobpi-abonnement-card:nth-child(2),
	.hobpi-abonnement-card:nth-child(3) {
		grid-column: span 1;
	}

	.hobpi-abonnement-card-wide {
		grid-column: 1 / span 2;
	}

	.hobpi-abonnement-card-accent {
		grid-column: 3 / span 1;
		align-self: stretch;
		display: flex;
	}
}

































/* ==========================
   AVIS GLOBAUX
   ========================== */



/* Page avis globaux BLORËM */

.hobpi-all-reviews {
	padding: clamp(3rem, 5vw, 4.5rem) 1.5rem 3rem;
	background: #f7f2ea;
}

.hobpi-all-reviews-inner {
	max-width: 1120px;
	margin: 0 auto;
}

.hobpi-all-reviews-header {
	text-align: center;
	margin-bottom: 2.6rem;
}

.hobpi-all-reviews-title {
	margin: 0 0 0.8rem;
	font-size: 28px;
	line-height: 1.1;
	color: #252c1f;
}

.hobpi-all-reviews-intro {
	max-width: 640px;
	margin: 0 auto;
	font-size: 0.98rem;
	line-height: 1.6;
	color: #4a3b32;
}

/* Wrapper général (on réutilise la classe mais on l adapte) */

.hobpi-all-reviews .hobpi-reviews-wrapper {
	margin-top: 0;
	font-size: 14px;
	color: #2c3425;
}

/* Header en 3 colonnes */

.hobpi-reviews-header {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.1fr) minmax(0, 1.1fr);
	gap: 24px;
	align-items: flex-start;
	margin-bottom: 24px;
}

@media (max-width: 960px) {
	.hobpi-reviews-header {
		grid-template-columns: 1fr;
		gap: 18px;
	}
}

/* Bloc note globale */

.hobpi-all-reviews .hobpi-rating-block {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 16px 18px;
	border-radius: 16px;
	background: #ffffff;
	box-shadow: 0 14px 40px rgba(26, 23, 17, 0.06);
}

.hobpi-all-reviews .hobpi-stars {
	display: inline-flex;
	gap: 3px;
	font-size: 18px;
}

.hobpi-all-reviews .hobpi-star {
	display: inline-block;
}

.hobpi-all-reviews .hobpi-star-full {
	color: #c08b5a;
}

.hobpi-all-reviews .hobpi-star-half {
	color: #d9cec4;
	position: relative;
}

.hobpi-all-reviews .hobpi-star-empty {
	color: #e1d5ca;
}

.hobpi-all-reviews .hobpi-rating-meta {
	display: flex;
	align-items: baseline;
	gap: 10px;
	font-size: 13px;
}

.hobpi-all-reviews .hobpi-rating-score {
	font-size: 22px;
	font-weight: 600;
}

.hobpi-all-reviews .hobpi-rating-count {
	color: #7c6b5f;
}

.hobpi-all-reviews .hobpi-reviews-summary-text {
	margin-top: 10px;
	font-size: 13px;
	line-height: 1.6;
	color: #4a3b32;
}

/* Distribution des notes */

.hobpi-rating-distribution {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 7px;
}

.hobpi-rating-distribution-row {
	display: grid;
	grid-template-columns: 70px minmax(0, 1fr) 36px;
	gap: 8px;
	align-items: center;
	font-size: 12px;
}

.hobpi-rating-distribution-label {
	color: #4a3b32;
}

.hobpi-rating-distribution-bar {
	position: relative;
	width: 100%;
	height: 7px;
	background: #eee4d9;
	border-radius: 999px;
	overflow: hidden;
}

.hobpi-rating-distribution-bar-fill {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	border-radius: 999px;
	background: #2c3425;
}

.hobpi-rating-distribution-count {
	text-align: right;
	color: #7c6b5f;
}

/* Encart info à droite */

.hobpi-reviews-cta-box {
    padding: 16px 18px;
    border-radius: 16px;
    background: #f6f1ea;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-top: 0px;
}

.hobpi-reviews-cta-title {
	font-weight: 600;
	margin: 0;
	font-size: 14px;
	color: #2c3425;
}

.hobpi-reviews-cta-text {
	margin: 0;
	font-size: 13px;
	color: #4a3b32;
}

.hobpi-reviews-cta-list {
	margin: 4px 0 6px 1.1rem;
	padding: 0;
	font-size: 12px;
	color: #4a3b32;
}

.hobpi-reviews-cta-list li {
	margin: 0.1rem 0;
}

.hobpi-reviews-cta-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 4px;
	padding: 7px 16px;
	border-radius: 999px;
	border: 1px solid #2c3425;
	font-size: 12px;
	text-decoration: none;
	color: #2c3425;
	background: #ffffff;
	    transition: opacity .35s ease;
}

a.hobpi-reviews-cta-link:hover {
    opacity: 0.65;
    transition: opacity .35s ease;
		color: #2c3425;
}

/* Séparateur */

.hobpi-reviews-divider {
	margin: 24px 0 20px;
	border-bottom: 1px solid #e2d7cd;
}

/* Liste des avis en grille */

.hobpi-reviews-list-wrapper {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.hobpi-reviews-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 16px;
}

.hobpi-no-reviews-text {
	font-size: 13px;
	color: #7c6b5f;
}

/* Carte avis */

.hobpi-review {
	padding: 14px 14px 16px;
	border-radius: 14px;
	border: 1px solid #efe3d7;
	background: #ffffff;
	display: flex;
	flex-direction: column;
	gap: 8px;
	box-shadow: 0 12px 26px rgba(23, 18, 8, 0.04);
}

.hobpi-review.is-hidden {
	display: none;
}

.hobpi-review-header {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr) auto;
	gap: 10px;
	align-items: center;
}

.hobpi-review-avatar {
	width: 32px;
	height: 32px;
	border-radius: 999px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 600;
	background: #2c3425;
	color: #ffffff;
}

.hobpi-review-meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
	font-size: 12px;
}

.hobpi-review-author {
	font-weight: 600;
}

.hobpi-review-date {
	color: #7c6b5f;
	font-size: 11px;
}

.hobpi-review-stars {
	display: inline-flex;
	gap: 1px;
	font-size: 14px;
	color: #c08b5a;
}

/* Texte avis */

.hobpi-review-body {
	font-size: 13px;
	line-height: 1.5;
	color: #3a2c24;
}

.hobpi-review-text-short,
.hobpi-review-text-full {
	margin: 0;
}

.hobpi-review-more {
	border: none;
	background: none;
	padding: 0;
	margin: 0 0 0 4px;
	cursor: pointer;
	font-size: 13px;
	text-decoration: underline;
	color: #2c3425;
}

/* Bouton "Plus d avis" */

.hobpi-reviews-load-more-wrapper {
	display: flex;
	justify-content: center;
	margin-top: 4px;
}

.hobpi-reviews-load-more {
	border-radius: 999px;
	border: 1px solid #2c3425;
	background: #ffffff;
	padding: 8px 18px;
	font-size: 13px;
	cursor: pointer;
}
















































/* ==========================
 PAGE CONTACT
   ========================== */

.hob-contact-hero {
    padding: 60px 0 80px;
    background: #f9f6f3;
    border-bottom: 1px solid #2c342512;
}


/* HERO */


.hob-contact-hero-inner {
	max-width: 880px;
	margin: 0 auto;
}

.hob-contact-eyebrow {
	font-size: 13px;
	letter-spacing: 0.11em;
	text-transform: uppercase;
	color: #8a7e72;
	margin-bottom: 8px;
}

.hob-contact-title {
	font-size: 32px;
	line-height: 1.2;
	color: #2c3425;
	margin: 0 0 12px;
}

.hob-contact-subtitle {
	font-size: 15px;
	line-height: 1.6;
	color: #5b4f44;
	max-width: 620px;
}

.hob-contact-hero-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 18px;
}

.hob-contact-hero-tags span {
	font-size: 12px;
	padding: 6px 10px;
	border-radius: 999px;
	background: rgba(44, 52, 37, 0.06);
	color: #3b342a;
}

/* MAIN LAYOUT */
.hob-contact-main {
    padding: 40px 0 40px;
    max-width: 1220px;
    margin: 0 auto;
}

.hob-contact-main-inner {
    display: grid;
    grid-template-columns: minmax(0,1.25fr) minmax(0,3fr);
    gap: 32px;
    align-items: flex-start;
}
.hob-contact-form-col {
    order: 2;
}

/* FORM COL */
.hob-contact-form-card {
    background: #ffffff;
    border-radius: 6px;
    padding: 26px 26px 30px;
    /* box-shadow: 0 18px 40px rgba(0, 0, 0, 0.04); */
    border: 1px solid rgba(0, 0, 0, 0.04);
}

.hob-contact-block-title {
	font-size: 20px;
	margin: 0 0 8px;
	color: #2f271f;
}

.hob-contact-block-intro {
	font-size: 14px;
	color: #6b5e53;
	margin-bottom: 18px;
}

/* INFO COL */
.hob-contact-info-col {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.hob-contact-info-card {
    background: #f4f1eb52;
    border-radius: 8px;
    padding: 16px 18px;
    border: 1px solid rgba(0, 0, 0, 0.03);
}

.hob-contact-info-highlight {
    background: #fbfaf9;
}

.hob-contact-info-title {
	font-size: 14px;
	margin: 0 0 6px;
	color: #312820;
}

.hob-contact-info-text {
	font-size: 13px;
	color: #6a5f54;
	margin: 0 0 8px;
}

.hob-contact-info-main {
	font-size: 14px;
	margin: 0;
}

.hob-contact-info-main a {
	color: #2c3425;
	text-decoration: none;
	border-bottom: 1px solid rgba(44, 52, 37, 0.35);
	padding-bottom: 1px;
}

.hob-contact-info-main a:hover {
	border-bottom-color: rgba(44, 52, 37, 0.8);
}

/* EXTRA BLOCS */
.hob-contact-extra {
    padding: 24px 0 40px;
    max-width: 1250px;
    margin: auto;
}

.hob-contact-extra-inner {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.hob-contact-extra-block {
	background: #ffffff;
	border-radius: 18px;
	padding: 18px 18px 20px;
	border: 1px solid rgba(0, 0, 0, 0.04);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
}

.hob-contact-extra-title {
	font-size: 15px;
	margin: 0 0 6px;
	color: #312820;
}

.hob-contact-extra-text {
	font-size: 13px;
	color: #6b5f55;
	margin: 0 0 10px;
}

.hob-contact-extra-link {
	display: inline-flex;
	align-items: center;
	font-size: 13px;
	color: #2c3425;
	text-decoration: none;
	border-bottom: 1px solid rgba(44, 52, 37, 0.4);
	padding-bottom: 1px;
}

.hob-contact-extra-link:hover {
	border-bottom-color: rgba(44, 52, 37, 0.85);
}

/* REASSURANCE SECTION WRAPPER */
.hob-contact-reassurance {
	padding-top: 10px;
}

/* RESPONSIVE */
@media (max-width: 960px) {
	.hob-contact-main-inner {
		grid-template-columns: 1fr;
	}

	.hob-contact-extra-inner {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 680px) {
.hob-contact-hero {
    padding: 48px 18px 58px 18px;
}

	.hob-contact-title {
		font-size: 26px;
	}

	.hob-contact-main {
		padding-top: 28px;
	}

	.hob-contact-form-card {
		padding: 20px 18px 22px;
	}

	.hob-contact-extra-inner {
		grid-template-columns: 1fr;
	}
	.hob-contact-info-col {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 0px 18px;
}
	.hob-contact-extra {
    padding: 0px 18px;
}
}









/* ==========================
  ROUTINE SECTION
   ========================== */


section.hobpi-section.hobpi-section-routine {
    padding: 80px 0px 80px;
	background: #fff;
}

.hobpi-routine-layout {
	display: grid;
	grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr);
	gap: 24px;
	align-items: center;
}

.hobpi-routine-text {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.hobpi-routine-block {
	padding: 15px 11px;
	border-radius: 14px;
	background: #ffffff;
	box-shadow: 0 10px 22px rgba(0, 0, 0, 0.03);
	font-size: 13px;
	color: #3b2f25;
}

.hobpi-steps-list {
	list-style: none;
	margin: 6px 0 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.hobpi-steps-list li {
	display: flex;
    align-items: flex-end;
	gap: 8px;
}

.hobpi-step-index {
	width: 20px;
	height: 20px;
	border-radius: 999px;
	border: 1px solid #2c3425;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	color: #2c3425;
	margin-top: 3px;
}

.hobpi-step-body p {
	margin: 0;
	font-size: 13px;
	line-height: 1.5;
}


.hobpi-section-routine h3 {
    margin-top: 0px !important;
    margin-bottom: 10px !important;
}



/* Meta dans routine */

.hobpi-routine-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    font-size: 12px;
    margin-top: 20px;
}

.hobpi-routine-meta .hobpi-meta-value {
	font-size: 12px;
}

/* Visuel routine */

.hobpi-routine-media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

.hobpi-routine-card {
	position: relative;
	width: 100%;
	max-width: 340px;
	border-radius: 24px;
	overflow: hidden;
	box-shadow:
		0 16px 40px rgba(0, 0, 0, 0.18),
		0 0 0 1px rgba(255, 255, 255, 0.6);
background: #313a29;
	    z-index: 1;
}

.hobpi-routine-main-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.hobpi-routine-tag {
	position: absolute;
	top: 10px;
	left: 10px;
	padding: 5px 10px;
	border-radius: 999px;
	background: rgba(44, 52, 37, 0.92);
	color: #f6f2ec;
	font-size: 11px;
}

.hobpi-routine-overlay {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 10px 12px;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.75), transparent);
	color: #f7f2ea;
	font-size: 12px;
}

.hobpi-routine-overlay p {
	margin: 0;
}

.hobpi-routine-background {
    position: absolute;
    inset: 12% -18% -18% 12%;
    z-index: 0;
    opacity: 1;
    filter: saturate(70%);
    border-radius: 9px;
}

.hobpi-routine-background img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	    border-radius: 9px;
}



/* RESPONSIVE */

@media (max-width: 1024px) {
.hobpi-active-media {
    max-width: 110px;
}
	.hobpi-active-media img {

    object-fit: contain;
}
	.hobpi-active-card {

    align-items: center;

}
	.hobpi-section-overview .hobpi-section-inner {
		grid-template-columns: minmax(0, 1fr);
	}

	.hobpi-overview-media {
		order: -1;
	}

	.hobpi-overview-card {
		max-width: 320px;
		margin: 0 auto;
	}

	.hobpi-overview-grid {
		grid-template-columns: minmax(0, 1fr);
	}
	
	.hobpi-how-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hobpi-actives-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hobpi-routine-layout {
		grid-template-columns: minmax(0, 1fr);
	}
}

@media (max-width: 720px) {
	
	section.hobpi-section.hobpi-section-routine {
    padding: 60px 0px 150px;
}

	.hobpi-section {
		padding: 22px 14px;
		border-radius: 16px;
	}

	.hobpi-section-title {
		font-size: 19px;
	}

	.hobpi-section-subtitle {
		font-size: 13px;
	}

	.hobpi-main-description {
		padding-top: 20px;
		gap: 28px;
	}

	.hobpi-how-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.hobpi-actives-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.hobpi-routine-meta {
		grid-template-columns: minmax(0, 1fr);
	}
	
	
	.hobpi-step-body {
    max-width: 80%;
}
	.hobpi-steps-list li {

    align-items: center;

}
	
	
}



p.hobpi-section-subtitle {
    margin-bottom: 7px;
}
































/* ==========================
  Comparatif BLORËM vs cosmétique classique
   ========================== */



.hobpi-section-compare {
	padding: 60px 0;
	background: radial-gradient(circle at top left, #f4f8f2 0, #f9f5f2 40%, #ffffff 100%);
}

.hobpi-section-compare .hobpi-section-inner {
	max-width: 1080px;
	margin: 0 auto;
	padding: 0 20px;
}

/* Header */

.hobpi-compare-header {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 40px auto;
}

.hobpi-section-title-centered {
	text-align: center;
	margin-bottom: 10px;
}

.hobpi-section-compare .hobpi-eyebrow {
	font-size: 12px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #6a7b58;
	margin-bottom: 8px;
}

.hobpi-section-compare .hobpi-section-title {
	font-size: 26px;
	line-height: 1.25;
	color: #20251a;
}

.hobpi-section-compare .hobpi-section-intro {
	font-size: 14px;
	line-height: 1.6;
	color: #4a3b32;
	margin-top: 10px;
}

/* Grid comparatif */

.hobpi-compare-grid {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 22px;
	align-items: stretch;
}

/* Cartes */

.hobpi-compare-card {
	position: relative;
	border-radius: 18px;
	padding: 20px 20px 22px 20px;
	background: #ffffff;
	box-shadow: 0 16px 35px rgba(0, 0, 0, 0.04);
	border: 1px solid rgba(0, 0, 0, 0.045);
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.hobpi-compare-card-blorem {
	background: radial-gradient(circle at top left, #f0f6ec 0, #ffffff 60%);
	border-color: #d4e3c8;
}

.hobpi-compare-card-classic {
	background: radial-gradient(circle at top right, #fdf4ec 0, #ffffff 60%);
	border-color: #ecd7c4;
}

/* Pills titres de colonnes */

.hobpi-compare-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 5px 12px;
	border-radius: 999px;
	font-size: 11px;
	line-height: 1.3;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #223019;
	background: rgba(82, 95, 64, 0.08);
	border: 1px solid rgba(82, 95, 64, 0.25);
	margin-bottom: 4px;
}

.hobpi-compare-pill-muted {
	color: #6b4a32;
	background: rgba(163, 116, 80, 0.08);
	border-color: rgba(163, 116, 80, 0.25);
}

/* Groupes internes */

.hobpi-compare-group {
	padding-top: 4px;
	border-top: 1px dashed rgba(0, 0, 0, 0.06);
}

.hobpi-compare-group:first-of-type {
	border-top: none;
	padding-top: 2px;
}

.hobpi-compare-title {
    font-size: 13px !important;
    font-weight: 600;
    margin-bottom: 6px !important;
    color: #303928;
    text-transform: uppercase;
    font-family: 'Montserrat';
}

/* Listes */

.hobpi-compare-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.hobpi-compare-list li {
	font-size: 13px;
	line-height: 1.55;
	color: #4a3b32;
	position: relative;
	padding-left: 16px;
	margin-bottom: 4px;
}

.hobpi-compare-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.6em;
	width: 6px;
	height: 6px;
	border-radius: 999px;
	background: #7c9361;
	box-shadow: 0 0 0 3px rgba(124, 147, 97, 0.13);
}

.hobpi-compare-card-classic .hobpi-compare-list li::before {
	background: #c58a5b;
	box-shadow: 0 0 0 3px rgba(197, 138, 91, 0.14);
}

/* Pastille VS */

.hobpi-compare-vs {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 46px;
	height: 46px;
	border-radius: 50%;
	background: #ffffff;
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
	pointer-events: none;
}

.hobpi-compare-vs span {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: #39442b;
}

/* Footer */

.hobpi-compare-footer {
	max-width: 760px;
	margin: 28px auto 0 auto;
	text-align: center;
}

.hobpi-compare-footer p {
	font-size: 13px;
	line-height: 1.6;
	color: #3b3027;
}

/* Responsive */

@media (max-width: 900px) {
	/* On passe de grid à flex en colonne pour mieux contrôler l’ordre */
	.hobpi-compare-grid {
		display: flex;
		flex-direction: column;
		gap: 0px;
		position: relative;
	}

	/* Carte BLORËM en premier */
	.hobpi-compare-card-blorem {
		order: 1;
	}

	/* Le badge VS en deuxième, centré */
.hobpi-compare-vs {
    position: static;
    transform: none;
    margin: 0 auto 4px auto;
    order: 2;
    margin-top: -15px;
    margin-bottom: -15px;
    border: 1px solid #ecd7c4;
}

	/* Carte cosmétique classique en troisième */
	.hobpi-compare-card-classic {
		order: 3;
	}

	.hobpi-compare-card {
		padding: 18px 16px 18px 16px;
	}
}

@media (max-width: 600px) {
	.hobpi-section-compare {
		padding: 44px 0;
	}

	.hobpi-compare-header {
		margin-bottom: 28px;
	}

	.hobpi-section-compare .hobpi-section-title {
		font-size: 22px;
	}

	.hobpi-compare-footer {
		margin-top: 22px;
	}
}




.hobpi-compare-group.hobpi-compare-group--5, .hobpi-compare-group.hobpi-compare-group--2 {
    min-height: 140px;
}

.hobpi-compare-group.hobpi-compare-group--4, .hobpi-compare-group.hobpi-compare-group--1 {
    min-height: 180px;
}

ul.hobpi-compare-list {
    margin-bottom: 0;
}
































/* ==========================
  GAMME PRODUITS
   ========================== */

.hobpi-section-range {
	margin-top: 56px;
	margin-bottom: 56px;
}

.hobpi-section-range .hobpi-section-inner {
	max-width: 1320px;
	margin: 0 auto;
	padding: 0 0px;
}

.hobpi-range-header {
	text-align: center;
	margin-bottom: 32px;
}

.hobpi-section-title-center {
	font-size: 24px;
	line-height: 1.2;
	margin: 4px 0 8px 0;
}

.hobpi-section-subtitle-center {
	font-size: 14px;
	color: #6e6157;
	max-width: 520px;
	margin: 0 auto;
}

/* Grille produits */

.hobpi-range-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

/* Carte produit */

.hobpi-range-card {
	position: relative;
	border-radius: 6px;
	background: #f9f6f3;
	overflow: hidden;
	transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.hobpi-range-card:hover {
	transform: translateY(-4px);

}

.hobpi-range-card-link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
}

/* Partie visuelle */

.hobpi-range-media {
	position: relative;
	padding: 13px 13px 8px 13px;
}

.hobpi-range-image-wrap {
	border-radius: 6px;
	overflow: hidden;
	background: #e7dfd6;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 180px;
}

.hobpi-range-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    height: 360px;
}

.hobpi-section.hobpi-section-range{
	background: transparent;
}

/* Pastille en haut à gauche */

.hobpi-range-pill {
	position: absolute;
	left: 24px;
	top: 22px;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(44, 52, 37, 0.9);
	color: #f5f2ec;
	font-size: 10px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

/* Contenu texte */

.hobpi-range-content {
	padding: 10px 16px 14px 16px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

h3.hobpi-range-title {
    font-size: 16px !important;
}
.hobpi-range-tagline {
	font-size: 13px;
	color: #6e6157;
	margin: 0;
}

/* Tags */

.hobpi-range-tags {
    list-style: none;
    padding: 0;
    margin: 6px 0 0 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.hobpi-range-tag-item span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 3px 8px;
	border-radius: 999px;
	border: 1px solid rgba(82, 95, 64, 0.14);
	background: rgba(246, 242, 236, 0.9);
	font-size: 11px;
	color: #4a3b32;
}

/* Ligne bas: prix + rating + CTA */

.hobpi-range-meta-row {
	margin-top: 10px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}

.hobpi-range-price-rating {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.hobpi-range-price {
	font-size: 15px;
}

.hobpi-range-price .woocommerce-Price-amount {
    font-size: 20px;
    font-weight: 600;
    color: #4a563a;
}

.hobpi-range-rating {
	font-size: 11px;
	color: #6e6157;
	display: flex;
	gap: 6px;
	align-items: baseline;
}

.hobpi-range-rating-score {
	font-size: 12px;
}

.hobpi-range-cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 11px;
	border-radius: 5px;
	background: #2c3425;
	color: #f7f3ec;
	font-size: 12px;
	white-space: nowrap;
	transition: background 0.16s ease, transform 0.16s ease;
}

.hobpi-range-card:hover .hobpi-range-cta {
	background: #3a4630;
	transform: translateX(2px);
}

.hobpi-range-cta-arrow {
	font-size: 12px;
}

/* Responsive */

@media (max-width: 1024px) {
	.hobpi-range-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 720px) {
	.hobpi-section-range {
		margin-top: 40px;
		margin-bottom: 40px;
	}

	.hobpi-range-grid {
		grid-template-columns: 1fr;
		gap: 14px;
	}

	.hobpi-range-card {
		border-radius: 16px;
	}
}


/* Wishlist dans la carte gamme */

.hobpi-range-card {
	position: relative;
}

/* Conteneur du bouton wishlist */
.hobpi-range-wishlist {
    position: relative;
    z-index: 3;
    background: #ffffff;
    border-radius: 999px;
    height: 36px;
    width: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hobpi-range-content-title-wishlist {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
}

/* Optionnel: réduire un peu si besoin dans ce contexte */
.hobpi-range-wishlist .yith-wcwl-add-button {
	margin: 0;
}

/* Si tu veux un rendu uniquement icône dans cette section: */
.hobpi-range-wishlist .yith-wcwl-add-button .text {
	display: none;
}

























/* ==========================
  RÉASSURANCE ICONES & SECTION
   ========================== */

/* Section globale */
.hobpi-section-trust {
	padding: 48px 0;
    background: #fff;
}

.hobpi-section-trust .hobpi-section-inner {
	max-width: 1320px;
	margin: 0 auto;
	padding: 0 0px;
}

/* Header */
.hobpi-trust-header {
	text-align: center;
	max-width: 640px;
	margin: 0 auto 32px;
}

.hobpi-eyebrow {
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: #7a6a5e;
	margin-bottom: 6px;
}

h2#hobpi-trust-title {
    font-size: 25px !important;
}

.hobpi-section-title-center {
	font-size: 24px;
	line-height: 1.25;
	color: #2c3425;
	margin-bottom: 8px;
}

.hobpi-section-subtitle-center {
	font-size: 13px;
	line-height: 1.6;
	color: #7a6a5e;
}

/* Layout principal: cartes + pharmacie */
.hobpi-trust-layout {
	display: grid;
	grid-template-columns: minmax(0, 2fr) minmax(0, 1.1fr);
	gap: 24px;
	align-items: stretch;
}

/* Grid de réassurance */
.hobpi-trust-main {
    background: #f9f6f3;
	border-radius: 20px;
	padding: 18px 18px 20px;
}

.hobpi-trust-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}

/* Carte individuelle */
.hobpi-trust-card {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px 12px 13px;
	border-radius: 14px;
	background: #ffffff;
    flex-direction: column;
	position: relative;
	overflow: hidden;
}

.hobpi-trust-card::after {
	content: "";
	position: absolute;
	right: -20px;
	bottom: -20px;
	width: 70px;
	height: 70px;
	background: radial-gradient(circle at center, rgb(29 189 72 / 15%) 0, transparent 60%);
	opacity: 0.5;
	pointer-events: none;
}

/* Icône cercle */
.hobpi-trust-icon-circle {
	width: 32px;
	height: 32px;
	border-radius: 999px;
	background: #eef0e7;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.hobpi-trust-icon {
	display: block;
	width: 16px;
	height: 16px;
	position: relative;
}

/* Petits pictos en CSS simple, dans l'esprit du site */
.hobpi-trust-icon-delivery::before,
.hobpi-trust-icon-fast::before,
.hobpi-trust-icon-france::before,
.hobpi-trust-icon-lock::before {
	content: "";
	position: absolute;
	inset: 0;
	margin: auto;
}

/* Camion */
.hobpi-trust-icon-delivery::before {
	width: 16px;
	height: 11px;
	border-radius: 3px;
	border: 1.2px solid #2c3425;
	box-sizing: border-box;
}

.hobpi-trust-icon-delivery::after {
	content: "";
	position: absolute;
	left: 2px;
	top: 9px;
	width: 6px;
	height: 2px;
	border-radius: 999px;
	background: #2c3425;
}

/* Chronomètre */
.hobpi-trust-icon-fast::before {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	border: 1.2px solid #2c3425;
	box-sizing: border-box;
}

.hobpi-trust-icon-fast::after {
	content: "";
	position: absolute;
	width: 5px;
	height: 1.2px;
	background: #2c3425;
	left: 7px;
	top: 7px;
	transform-origin: left center;
	transform: rotate(-40deg);
}


    
/* Drapeau France simplifié */
.hobpi-trust-icon-france::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 2px;
	margin: 0 auto;
	width: 18px;
	height: 12px;
	background: linear-gradient(
		to right,
		#244a87 0 33%,
		#ffffff 33% 66%,
		#b12028 66% 100%
	);
	border-radius: 2px;
}

/* Cadenas */
.hobpi-trust-icon-lock::before {
	width: 12px;
	height: 8px;
	border-radius: 3px;
	border: 1.2px solid #2c3425;
	box-sizing: border-box;
	bottom: 1px;
}

.hobpi-trust-icon-lock::after {
	content: "";
	position: absolute;
	left: 4px;
	right: 4px;
	top: 0;
	height: 6px;
	border-radius: 999px 999px 0 0;
	border: 1.2px solid #2c3425;
	border-bottom: none;
}

/* Texte des cartes */
.hobpi-trust-text {
	flex: 1;
}

.hobpi-trust-title {
	font-size: 14px !important;
	color: #2c3425;
	margin: 0 0 2px;
}

.hobpi-trust-desc {
	font-size: 12px;
	line-height: 1.6;
	color: #7a6a5e;
	margin: 0;
}

/* Carte paiement un peu plus dense */
.hobpi-trust-card-payments {
	flex-direction: column;
	align-items: flex-start;
}

.hobpi-trust-card-payments .hobpi-trust-text {
	margin-top: 6px;
}

/* Icônes paiement */
.hobpi-payment-icons {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	margin-top: 8px;
}

.hob-payment-icon {
	width: 40px;
	height: 26px;
	border-radius: 6px;
	background: transparent;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.hob-payment-icon img {
	max-width: 80%;
	max-height: 80%;
	display: block;
}

/* Bloc pharmacie à droite */
.hobpi-trust-pharmacy {
	display: flex;
	align-items: stretch;
}

.hobpi-pharmacy-card {
    background: #f9f6f3;
	border-radius: 20px;
	padding: 14px 14px 16px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	position: relative;
	overflow: hidden;
}

.hobpi-pharmacy-card::before {
	content: "";
	position: absolute;
	right: -40px;
	top: -40px;
	width: 120px;
	height: 120px;
	background: radial-gradient(circle at center, rgb(29 189 72 / 61%) 0, transparent 60%);
	opacity: 0.5;
	pointer-events: none;
}


.hobpi-pharmacy-media {
	width: 60px;
	height: 60px;
	border-radius: 16px;

	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	margin-bottom: 2px;
}

.hobpi-pharmacy-image {
	max-width: 100%;
	max-height: 100%;
	display: block;
}

.hobpi-pharmacy-body {
	position: relative;
	z-index: 1;
}

.hobpi-pharmacy-label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: #7a6a5e;
	margin: 0 0 4px;
}

.hobpi-pharmacy-title {
	font-size: 20px !important;
	line-height: 1.4;
	color: #2c3425;
	margin: 0 0 4px;
}

.hobpi-pharmacy-text {
	font-size: 12px;
	line-height: 1.6;
	color: #7a6a5e;
	margin: 0;
}

/* Responsive */
@media (max-width: 900px) {
	.hobpi-trust-layout {
		grid-template-columns: minmax(0, 1fr);
	}

	.hobpi-trust-main {
		order: 1;
	}

	.hobpi-trust-pharmacy {
		order: 2;
	}

	.hobpi-trust-grid {
		grid-template-columns: minmax(0, 1fr);
	}
}

@media (max-width: 600px) {
.hobpi-section-trust {
    padding: 40px 10px;
}

	.hobpi-trust-header {
		margin-bottom: 24px;
	}

	.hobpi-section-title-center {
		font-size: 20px;
	}

	.hobpi-trust-main {
		padding: 14px 12px 16px;
		border-radius: 18px;
	}

	.hobpi-trust-card {
		padding: 10px 10px 11px;
		border-radius: 12px;
	}

	.hobpi-pharmacy-card {
		padding: 12px 12px 14px;
		border-radius: 18px;
	}
}




























/* ===========================
   Avant / Après – section
   =========================== */

.hobpi-section-avant-apres {
	padding: 56px 0;
	background: #f9f6f3;
}

.hobpi-section-avant-apres .hobpi-section-inner {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 20px;
}

/* Header centré et épuré */

.hobpi-ba-header {
	max-width: 640px;
	margin: 0 auto 32px auto;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.hobpi-ba-eyebrow {
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #7a6a5e;
	margin-bottom: 6px;
}

.hobpi-ba-title {
    font-size: 24px !important;
    line-height: 1.25;
    color: #2c3425;
    margin-bottom: 10px;
}
.hobpi-ba-intro {
	font-size: 14px;
	line-height: 1.6;
	color: #4a3b32;
	margin-bottom: 6px;
}

.hobpi-ba-microcopy {
	font-size: 12px;
	line-height: 1.4;
	color: #8b7a6d;
}

/* Layout principal */

.hobpi-ba-layout {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
	gap: 24px;
	align-items: stretch;
}

/* Carte carousel */

.hobpi-ba-carousel {
    position: relative;
    background: #fff;
    display: flex;
    border-radius: 18px;
    padding: 18px 18px 14px;
    box-shadow: 0 14px 30px rgba(0,0,0,.05);
    overflow: hidden;
    flex-direction: column;
    justify-content: flex-start;
    height: fit-content;
}

button.hobpi-ba-nav-prev ,button.hobpi-ba-nav-next {
    padding: 20px;
}


/* Track et slides */

.hobpi-ba-track {
	position: relative;
	min-height: 260px;
}

.hobpi-ba-slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	transform: translateX(8px);
	pointer-events: none;
	transition: opacity 0.25s ease, transform 0.25s ease;
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: 18px;
	align-items: center;
}

.hobpi-ba-slide.is-active {
	opacity: 1;
	transform: translateX(0);
	pointer-events: auto;
}

/* Media image, format maîtrisé et pas trop grand */

.hobpi-ba-media {
	position: relative;
	border-radius: 14px;
	overflow: hidden;
	background: #e7efe4;
}

.hobpi-ba-img-wrap {
	position: relative;
	width: 100%;
	padding-top: 68%;
}

.hobpi-ba-image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Badge durée */

.hobpi-ba-badge {
	position: absolute;
	left: 12px;
	top: 12px;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.96);
	font-size: 11px;
	color: #2c3425;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.hobpi-ba-badge-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #525f40;
}

/* Caption texte */

.hobpi-ba-caption {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 8px;
}

.hobpi-ba-name-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 2px;
}

.hobpi-ba-avatar {
	width: 32px;
	height: 32px;
	border-radius: 999px;
	background: #2c3425;
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 500;
}

.hobpi-ba-name-block {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.hobpi-ba-name {
	font-size: 14px;
	color: #2c3425;
}

.hobpi-ba-role {
	font-size: 11px;
	color: #8b7a6d;
}

.hobpi-ba-quote {
	font-size: 13px;
	line-height: 1.55;
	color: #4a3b32;
}

.hobpi-ba-product {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 11px;
	color: #2c3425;
	padding: 4px 10px;
	border-radius: 999px;
	background: #e7efe4;
	margin-top: 4px;
}

.hobpi-ba-product-label {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 10px;
	color: #6b7a61;
}

.hobpi-ba-meta {
	display: flex;
	flex-direction: column;
	gap: 3px;
	margin-top: 6px;
	font-size: 11px;
	color: #8b7a6d;
}

.hobpi-ba-meta strong {
	font-weight: 500;
}

/* Panneau latéral */

.hobpi-ba-sidepanel {
	border-radius: 18px;
	padding: 18px 18px 14px;
	background: #2c3425;
	color: #f6f4ef;
	display: flex;
	flex-direction: column;
	gap: 12px;
	position: relative;
	overflow: hidden;
}


.hobpi-ba-sidepanel-header {
	position: relative;
	z-index: 1;
}

.hobpi-ba-sidepanel-title {
	font-size: 15px;
	margin-bottom: 4px;
}

.hobpi-ba-sidepanel-sub {
	font-size: 12px;
	color: #d4d0c6;
}

.hobpi-ba-sidepanel-list {
	position: relative;
	z-index: 1;
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.hobpi-ba-sidepanel-list li {
	font-size: 12px;
	display: flex;
	align-items: flex-start;
	gap: 8px;
}

.hobpi-ba-bullet {
	width: 6px;
	height: 3px;
	border-radius: 999px;
	background: #f3e6cf;
	margin-top: 6px;
}

.hobpi-ba-sidepanel-note {
	border: 0px !important;
	position: relative;
	z-index: 1;
	font-size: 11px;
	color: #c5c0b4;
}

/* Navigation */

.hobpi-ba-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 16px;
	gap: 12px;
}

.hobpi-ba-nav-buttons {
	display: flex;
	gap: 8px;
}

.hobpi-ba-nav-prev,
.hobpi-ba-nav-next {
	width: 32px;
	height: 32px;
	border-radius: 999px;
	border: 1px solid #d8cec4;
	background: #ffffff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 12px;
	color: #2c3425;
	cursor: pointer;
	transition: background 0.16s ease, color 0.16s ease, border-color 0.16s ease, transform 0.12s ease;
}

.hobpi-ba-nav-prev:hover,
.hobpi-ba-nav-next:hover {
	background: #2c3425;
	color: #ffffff;
	border-color: #2c3425;
	transform: translateY(-1px);
}

/* Dots */

.hobpi-ba-nav-right {
	display: flex;
	align-items: center;
	gap: 10px;
}

.hobpi-ba-dots {
	display: flex;
	align-items: center;
	gap: 6px;
}

.hobpi-ba-dot {
	width: 7px;
	height: 7px;
	border-radius: 999px;
	border: 1px solid #b7aa9c;
	background: transparent;
	cursor: pointer;
	padding: 0;
	transition: background 0.16s ease, border-color 0.16s ease, width 0.16s ease;
}

.hobpi-ba-dot.is-active {
	width: 18px;
	background: #2c3425;
	border-color: #2c3425;
}

.hobpi-ba-legend {
	font-size: 11px;
	color: #8b7a6d;
}

/* Responsive */

@media (max-width: 960px) {
	.hobpi-ba-layout {
		grid-template-columns: minmax(0, 1fr);
	}

	.hobpi-ba-carousel {
		order: 1;
	}

	.hobpi-ba-sidepanel {
		order: 2;
	}

	.hobpi-ba-slide {
		grid-template-columns: minmax(0, 1fr);
	}

	.hobpi-ba-track {
		min-height: 460px;
	}
}

@media (max-width: 640px) {
	.hobpi-section-avant-apres {
		padding: 44px 0;
	}

	.hobpi-ba-header {
		margin-bottom: 24px;
	}

	.hobpi-ba-title {
		font-size: 21px;
	}

	.hobpi-ba-carousel {
		padding: 14px;
	}

	.hobpi-ba-nav {
		flex-direction: column;
		align-items: flex-start;
	}

	.hobpi-ba-nav-right {
		width: 100%;
		justify-content: space-between;
	}
}





























/* ===========================
   Section Avantages BLORËM
   =========================== */

.hobpi-section-avantages {
	padding: 56px 0;
	background: #ffffff;
}



.hobpi-section-avantages .hobpi-section-inner {
	max-width: 1320px;
	margin: 0 auto;
	padding: 0 0px;
}

/* Header centré */

.hobpi-avantages-header {
	max-width: 640px;
	margin: 0 auto 32px auto;
	text-align: center;
}

.hobpi-section-avantages .hobpi-eyebrow {
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #7a6a5e;
	margin-bottom: 6px;
}

.hobpi-section-title-center {
font-size: 24px !important;
	line-height: 1.25;
	color: #2c3425;
	margin-bottom: 8px;
}

.hobpi-section-subtitle-center {
	font-size: 14px;
	line-height: 1.6;
	color: #4a3b32;
}

/* Grid des avantages */

.hobpi-avantages-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
	align-items: stretch;
}

/* Cartes */

.hobpi-avantage-card {
	background: #ffffff;
	border-radius: 6px;
	padding: 14px 14px 16px;
box-shadow: 0px 6px 13px rgba(0, 0, 0, .04);
	display: flex;
	flex-direction: column;
	gap: 10px;
	position: relative;
	overflow: hidden;
}

.hobpi-avantage-card::before {
	content: "";
	position: absolute;
	inset: auto -40%;
	top: -60px;
	height: 80px;
	background: radial-gradient(circle at center, rgba(82, 95, 64, 0.16), transparent 65%);
	opacity: 0.6;
	pointer-events: none;
}

/* Media */

.hobpi-avantage-media {
	position: relative;
	margin-bottom: 4px;
}

.hobpi-avantage-image-wrap {
	position: relative;
	width: 100%;
	padding-top: 68%;
	border-radius: 4px;
	overflow: hidden;
	background: #e7efe4;
}

.hobpi-avantage-image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Media version drapeau */

.hobpi-avantage-media-flag {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	height: 60px;
}

.hobpi-flag-fr {
	display: inline-flex;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
}

.hobpi-flag-fr .fr-flag-part {
	width: 12px;
	height: 26px;
}

.hobpi-flag-fr .fr-blue {
	background: #0055a4;
}

.hobpi-flag-fr .fr-white {
	background: #ffffff;
}

.hobpi-flag-fr .fr-red {
	background: #ef4135;
}

/* Corps de carte */

.hobpi-avantage-body {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.hobpi-avantage-title {
    font-size: 14px !important;
    color: #2c3425;
    font-weight: 600;
    margin: 0;
}
.hobpi-avantage-text {
	font-size: 13px;
	line-height: 1.55;
	color: #4a3b32;
	margin: 0;
}

.hobpi-avantage-note {
	font-size: 11px;
	line-height: 1.4;
	color: #8b7a6d;
	margin: 0;
}

/* Hover léger */

.hobpi-avantage-card {
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.hobpi-avantage-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.06);
}

/* Responsive */

@media (max-width: 1024px) {
	.hobpi-avantages-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.hobpi-section-avantages {
		padding: 44px 0;
	}

	.hobpi-section-title-center {
		font-size: 21px;
	}

	.hobpi-avantages-grid {
		grid-template-columns: minmax(0, 1fr);
		gap: 14px;
	}

	.hobpi-avantage-card {
		padding: 12px 12px 14px;
	}
}












































/* ==========================
SECTION SCIENCE / NOTRE DIFFERENCE
   ========================== */


.hobpi-section-science {
	padding: 64px 0;
	background: #f6f3ef;
}
.hob-container .hobpi-section-science {
    background: #ffffff;
}
.hobpi-section-science .hobpi-section-inner {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 16px;
}

.hobpi-science-layout {
	display: flex;
	align-items: stretch;
	gap: 40px;
}

.hobpi-science-media {
    flex: 0 0 40%;
    min-width: 280px;
    position: relative;
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

.hobpi-science-media-main {
	position: relative;
	z-index: 2;
	border-radius: 24px;
	overflow: hidden;
	box-shadow: 0 18px 45px rgba(0, 0, 0, 0.18);
}

.hobpi-science-main-image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hobpi-science-media-bg {
    position: absolute;
    z-index: 1;
    opacity: 0.6;
    transform: translate(12px, 24px) scale(1.02);
    pointer-events: none;
    left: -50px;
    top: 0;
}

.hobpi-science-bg-image {
    display: block;
    width: 100%;
    max-height: 420px;
    object-fit: cover;
    border-radius: 28px;
}

/* Colonne texte */

.hobpi-science-content {
	flex: 0 0 60%;
	max-width: 720px;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.hobpi-science-content .hobpi-eyebrow {
	font-size: 12px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: #7b6a5d;
	margin-bottom: 2px;
}

.hobpi-science-content .hobpi-section-title {
	font-size: 26px;
	line-height: 1.25;
	color: #2f241d;
	margin: 0;
}

.hobpi-science-content .hobpi-section-subtitle {
	font-size: 14px;
	line-height: 1.6;
	color: #5b4b40;
	margin: 6px 0 10px;
}

/* Badges */

.hobpi-science-badges {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin-bottom: 6px;
}

.hobpi-science-badge {
	border-radius: 6px;
	background: #fff;
	border: 1px solid rgba(0, 0, 0, 0.04);
	padding: 8px 14px;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.hobpi-science-badge-label {
	font-size: 12px;
	font-weight: 600;
	color: #2f241d;
}

.hobpi-science-badge-note {
	font-size: 11px;
	color: #7b6a5d;
}

/* Blocks colonne droite */

.hobpi-science-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
	margin-top: 4px;
}

.hobpi-science-block {
	background: #fff;
	border-radius: 6px;
	padding: 14px 16px;
	border: 1px solid rgba(0, 0, 0, 0.03);
}

.hobpi-science-block-title {
    font-size: 16px !important;
    font-weight: 600;
    color: #2f241d;
    margin: 0 0 6px;
}

.hobpi-science-block p {
	font-size: 13px;
	line-height: 1.6;
	color: #5b4b40;
	margin: 0 0 6px;
}

.hobpi-science-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.hobpi-science-list li {
	position: relative;
	padding-left: 14px;
	font-size: 12px;
	line-height: 1.5;
	color: #6b5b4f;
}

.hobpi-science-list li::before {
	content: "";
	position: absolute;
	left: 4px;
	top: 0.65em;
	width: 5px;
	height: 5px;
	border-radius: 999px;
	background: #2c3425;
}

/* Etapes */

.hobpi-science-steps {
	margin-top: 10px;
    background: #f9f6f3;
	border-radius: 18px;
	padding: 14px 16px 12px;
}

.hobpi-science-steps .hobpi-science-block-title {
	margin-bottom: 10px;
}

.hobpi-science-steps-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.hobpi-science-steps-list li {
	display: flex;
	gap: 10px;
	align-items: flex-start;
}

.hobpi-step-index {
	flex: 0 0 22px;
	height: 22px;
	border-radius: 999px;
	background: #2c3425;
	color: #fff;
	font-size: 11px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 2px;
}

.hobpi-step-body strong {
	display: block;
	font-size: 12px;
	color: #2f241d;
	margin-bottom: 2px;
}

.hobpi-step-body p {
	font-size: 12px;
	line-height: 1.5;
	color: #5b4b40;
	margin: 0;
}

/* Footer */

.hobpi-science-footer {
	margin-top: 8px;
}

.hobpi-science-commitment {
	font-size: 12px;
	line-height: 1.6;
	color: #4b3f35;
	margin: 0;
}

/* Responsive */

@media (max-width: 900px) {
	.hobpi-science-layout {
		flex-direction: column;
		gap: 28px;
	}

	.hobpi-science-media {
		max-width: 420px;
		margin: 0 auto;
	}

	.hobpi-science-bg-image {
		max-height: 260px;
	}

	.hobpi-science-content {
		max-width: 100%;
	}

	.hobpi-science-badges {
		grid-template-columns: minmax(0, 1fr);
	}

	.hobpi-science-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.hobpi-section-science {
		padding: 48px 0;
	}
}

@media (max-width: 600px) {
	.hobpi-science-media-bg {
		display: none;
	}

	.hobpi-science-media-main {
		border-radius: 18px;
	}

	.hobpi-science-content .hobpi-section-title {
		font-size: 22px;
	}

	.hobpi-science-content .hobpi-section-subtitle {
		font-size: 13px;
	}
}



.hobpi-science-wrapper-scroll {
	position: relative;
}


.hobpi-science-media {
	position: relative;
	will-change: transform;
	transition: transform 0.2s ease-out;
}


.hobpi-science-main-image,
.hobpi-science-bg-image {
	display: block;
	max-width: 100%;
	height: auto;
}





































/* ===========================
   Section Nos pharmacies partenaires
   =========================== */

.hobpi-section-partenaires {
	padding: 52px 0;
	background: #fff;
}

.hobpi-section-partenaires .hobpi-section-inner {
	max-width: 1320px;
	margin: 0 auto;
	padding: 0 0px;
}


/* Header centré */

.hobpi-partenaires-header {
	max-width: 640px;
	margin: 0 auto 26px auto;
	text-align: center;
}

.hobpi-section-partenaires .hobpi-eyebrow {
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #7a6a5e;
	margin-bottom: 6px;
}

.hobpi-section-partenaires .hobpi-section-title-center {
	font-size: 24px;
	line-height: 1.25;
	color: #2c3425;
	margin-bottom: 8px;
}

.hobpi-section-partenaires .hobpi-section-subtitle-center {
	font-size: 14px;
	line-height: 1.6;
	color: #4a3b32;
}

/* Strip partenaires */

.hobpi-partners-strip {
	position: relative;
	margin: 10px auto 18px auto;
}

.hobpi-partners-mask {
	overflow: hidden;
	border-radius: 999px;
	background: #f2ece6;
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.05);
}

/* Track: on ne met plus d’animation CSS ici,
   le JS va gérer transform: translateX(...) */
.hobpi-partners-track {
	display: flex;
	align-items: center;
	gap: 40px;
	padding: 12px 32px;
	will-change: transform;
}

/* Chaque logo garde sa taille, mais est centré dans une "case" fluide */
.hobpi-partner-item {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 120px;
}

.hobpi-partner-item img {
	max-height: 40px;
	width: auto;
	display: block;
	filter: grayscale(20%);
	opacity: 0.9;
	transition: filter 0.25s ease, opacity 0.25s ease, transform 0.25s ease;
}

.hobpi-partner-item img:hover {
	filter: grayscale(0%);
	opacity: 1;
	transform: translateY(-2px);
}

/* Note */

.hobpi-partenaires-note {
	font-size: 12px;
	line-height: 1.5;
	color: #8b7a6d;
	text-align: center;
	max-width: 580px;
	margin: 0 auto;
}

/* Responsive */

@media (max-width: 768px) {
	.hobpi-section-partenaires {
		padding: 42px 0;
	}

	.hobpi-section-partenaires .hobpi-section-title-center {
		font-size: 21px;
	}

	.hobpi-partners-track {
		gap: 28px;
		padding: 10px 20px;
	}

	.hobpi-partner-item {
		min-width: 100px;
	}

	.hobpi-partner-item img {
		max-height: 34px;
	}
}