/* =========================================================================
 * Affichage des massages — Shams Bien-être
 * © Jérôme Riboulet 2026
 * Utilise les variables du thème si présentes, avec valeurs de repli.
 * ========================================================================= */

.shams-massages-grille,
.shams-mosaique {
	--shams-or: var(--sh-or, #c88114);
	--shams-or-clair: var(--sh-or-clair, #e9c878);
	--shams-creme: var(--sh-creme, #fbf6ec);
	--shams-encre: var(--sh-encre, #3a322a);
	--shams-sauge: var(--sh-sauge, #93a487);
	display: grid;
	grid-template-columns: repeat(var(--shams-cols, 4), 1fr);
	gap: clamp(16px, 2.4vw, 32px);
	width: 100%;
}

/* ---------- Grille simple (accueil) ---------- */
.shams-massage-carte {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 10px 30px -18px rgba(58, 50, 42, 0.4);
	transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.shams-massage-carte:hover {
	transform: translateY(-6px);
	box-shadow: 0 22px 44px -22px rgba(58, 50, 42, 0.5);
}
.shams-massage-media {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--shams-creme);
}
.shams-massage-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}
.shams-massage-media.shams-has-picto {
	display: flex;
	align-items: center;
	justify-content: center;
}
.shams-massage-media.shams-has-picto img {
	width: 46%;
	height: auto;
	object-fit: contain;
}
.shams-massage-carte:hover .shams-massage-media img { transform: scale(1.05); }
.shams-massage-corps {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 20px 22px 24px;
	flex: 1;
}
.shams-massage-titre {
	margin: 0;
	font-size: 1.25rem;
	color: var(--shams-encre);
	font-family: var(--sh-police-titre, Georgia, "Times New Roman", serif);
}
.shams-massage-court {
	margin: 0;
	color: rgba(58, 50, 42, 0.78);
	line-height: 1.5;
	flex: 1;
}
.shams-massage-meta {
	margin: 4px 0 0;
	font-weight: 600;
	color: var(--shams-or);
	letter-spacing: 0.02em;
}
.shams-massage-meta .shams-sep { margin: 0 8px; opacity: 0.5; }
.shams-massage-cta {
	align-self: flex-start;
	margin-top: 8px;
	display: inline-block;
	padding: 10px 22px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--shams-or), var(--shams-or-clair));
	color: #fff;
	text-decoration: none;
	font-weight: 600;
	letter-spacing: 0.03em;
	transition: filter 0.3s ease, transform 0.3s ease;
}
.shams-massage-cta:hover { filter: brightness(1.06); transform: translateY(-2px); color: #fff; }

/* ---------- Mosaïque cartes recto / verso ---------- */
.shams-flip {
	perspective: 1400px;
	aspect-ratio: 3 / 4;
	border-radius: 18px;
	outline: none;
}
.shams-flip-inner {
	position: relative;
	width: 100%;
	height: 100%;
	transition: transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1);
	transform-style: preserve-3d;
}
/* Desktop : retournement au survol / focus */
@media (hover: hover) {
	.shams-flip:hover .shams-flip-inner,
	.shams-flip:focus-within .shams-flip-inner { transform: rotateY(180deg); }
}
/* Mobile / clic : classe ajoutée par JS */
.shams-flip.is-flipped .shams-flip-inner { transform: rotateY(180deg); }

.shams-flip-recto,
.shams-flip-verso {
	position: absolute;
	inset: 0;
	border-radius: 18px;
	overflow: hidden;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	box-shadow: 0 14px 36px -20px rgba(58, 50, 42, 0.55);
}
.shams-flip-recto {
	background-size: cover;
	background-position: center;
	background-color: var(--shams-sauge);
	display: flex;
	align-items: flex-end;
}
.shams-flip-recto-voile {
	width: 100%;
	padding: 22px;
	color: #fff;
	background: linear-gradient(to top, rgba(40, 32, 22, 0.82) 0%, rgba(40, 32, 22, 0.15) 60%, rgba(40, 32, 22, 0) 100%);
}
.shams-flip-recto-voile h3 {
	margin: 0 0 4px;
	font-size: 1.4rem;
	font-family: var(--sh-police-titre, Georgia, serif);
}
.shams-flip-recto-voile p { margin: 0; opacity: 0.92; line-height: 1.45; }
.shams-flip-indice {
	display: inline-block;
	margin-top: 10px;
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	opacity: 0.85;
}
.shams-flip-verso {
	transform: rotateY(180deg);
	background: var(--shams-creme);
	color: var(--shams-encre);
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 24px 22px;
}
.shams-flip-verso h3 {
	margin: 0;
	font-size: 1.3rem;
	color: var(--shams-or);
	font-family: var(--sh-police-titre, Georgia, serif);
}
.shams-flip-texte {
	flex: 1;
	overflow: auto;
	line-height: 1.55;
	font-size: 0.96rem;
}
.shams-flip-verso .shams-massage-meta { color: var(--shams-encre); }
.shams-flip-verso .shams-massage-cta { margin-top: auto; }

.shams-massages-vide {
	text-align: center;
	font-style: italic;
	opacity: 0.7;
}

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
	.shams-massages-grille,
	.shams-mosaique { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
	.shams-massages-grille,
	.shams-mosaique { grid-template-columns: 1fr; }
	.shams-flip { aspect-ratio: 4 / 3; }
}
