/**
 * Medinatouna Travel Manager — styles publics.
 *
 * Tout est scopé sous .mtm-wrap pour ne pas déborder sur le thème.
 * Les couleurs passent par des variables CSS : le thème enfant (Bloc 5) peut
 * les redéfinir pour aligner précisément le rendu sur la charte.
 */

.mtm-wrap {
	--mtm-emerald: #0C5C4C;
	--mtm-emerald-dark: #08463A;
	--mtm-sand: #F4EFE6;
	--mtm-cream: #FBF9F5;
	--mtm-gold: #B8954A;
	--mtm-gold-soft: #D9C38C;
	--mtm-ink: #23231D;
	--mtm-muted: #5E5D54;
	--mtm-line: rgba(35, 35, 29, .12);
	--mtm-wa: #1f8a55;
	--mtm-wa-dark: #1a7549;
	--mtm-radius: 14px;

	max-width: 1180px;
	margin: 0 auto;
	padding: 28px 20px 72px;
	color: var(--mtm-ink);
	font-size: 17px;
	line-height: 1.65;
}

.mtm-wrap * {
	box-sizing: border-box;
}

.mtm-wrap h1,
.mtm-wrap h2,
.mtm-wrap h3 {
	line-height: 1.18;
	margin: 0;
}

/* ---- Fil d'Ariane ---- */
.mtm-breadcrumb {
	font-size: .85rem;
	color: var(--mtm-muted);
	margin-bottom: 18px;
}

.mtm-breadcrumb a {
	color: var(--mtm-muted);
	text-decoration: none;
}

.mtm-breadcrumb a:hover {
	color: var(--mtm-emerald);
}

.mtm-breadcrumb span[aria-hidden] {
	margin: 0 .4em;
	color: var(--mtm-gold);
}

.mtm-breadcrumb .mtm-current {
	color: var(--mtm-ink);
}

/* ---- En-tête du circuit ---- */
.mtm-circuit-header {
	margin-bottom: 26px;
}

.mtm-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 9px;
	margin-bottom: 14px;
}

.mtm-tag {
	background: rgba(12, 92, 76, .08);
	color: var(--mtm-emerald);
	font-size: .74rem;
	font-weight: 700;
	letter-spacing: .05em;
	text-transform: uppercase;
	padding: 5px 12px;
	border-radius: 999px;
}

.mtm-title {
	font-size: clamp(1.9rem, 3.4vw, 2.8rem);
	color: var(--mtm-emerald);
}

.mtm-lead {
	margin: 14px 0 0;
	font-size: 1.12rem;
	color: var(--mtm-muted);
	max-width: 60ch;
}

/* ---- Grille principale + colonne latérale ---- */
.mtm-circuit-grid {
	display: grid;
	grid-template-columns: 1.6fr .9fr;
	gap: 40px;
	align-items: start;
}

.mtm-section {
	margin-top: 38px;
}

.mtm-section:first-child {
	margin-top: 0;
}

.mtm-section > h2 {
	font-size: 1.55rem;
	color: var(--mtm-emerald);
	margin-bottom: 14px;
}

/* ---- Prose ---- */
.mtm-prose p {
	margin: 0 0 1em;
	color: #3c3b34;
}

.mtm-prose p:last-child {
	margin-bottom: 0;
}

/* ---- Galerie ---- */
.mtm-gallery-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
}

.mtm-gallery-cell {
	display: block;
	border-radius: 12px;
	overflow: hidden;
	aspect-ratio: 4 / 3;
}

.mtm-gallery-cell .mtm-gallery-img,
.mtm-gallery-cell img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .3s ease;
}

.mtm-gallery-cell:hover img {
	transform: scale(1.04);
}

/* ---- Inclus / non inclus ---- */
.mtm-incl-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
}

.mtm-incl-col h2 {
	font-size: 1.3rem;
	color: var(--mtm-emerald);
	margin-bottom: 8px;
}

.mtm-list {
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: .98rem;
}

.mtm-list li {
	display: flex;
	align-items: flex-start;
	gap: .6em;
	padding: 7px 0;
	color: #3c3b34;
}

.mtm-list li::before {
	flex: none;
	font-weight: 700;
	line-height: 1.5;
}

.mtm-list-yes li::before {
	content: "\2713"; /* ✓ */
	color: var(--mtm-wa);
}

.mtm-list-no li::before {
	content: "\2715"; /* ✕ */
	color: #b3543f;
}

/* ---- Programme (frise) ---- */
.mtm-timeline {
	border-left: 2px solid rgba(184, 149, 74, .4);
	padding-left: 24px;
	margin-top: 4px;
}

.mtm-day {
	position: relative;
	padding-bottom: 24px;
}

.mtm-day:last-child {
	padding-bottom: 0;
}

.mtm-day::before {
	content: "";
	position: absolute;
	left: -31px;
	top: 4px;
	width: 13px;
	height: 13px;
	border-radius: 50%;
	background: var(--mtm-gold);
	border: 3px solid var(--mtm-cream);
}

.mtm-day-num {
	font-weight: 800;
	font-size: .74rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--mtm-gold);
}

.mtm-day-title {
	font-size: 1.12rem;
	color: var(--mtm-ink);
	margin: 3px 0 6px;
}

.mtm-day p {
	margin: 0;
	color: var(--mtm-muted);
	font-size: .97rem;
}

/* ---- Lieux visités ---- */
.mtm-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.mtm-chip {
	background: var(--mtm-cream);
	border: 1px solid var(--mtm-line);
	border-radius: 10px;
	padding: 9px 14px;
	font-size: .92rem;
	font-weight: 600;
	color: var(--mtm-ink);
	text-decoration: none;
	transition: border-color .15s ease, color .15s ease;
}

.mtm-chip:hover {
	border-color: var(--mtm-emerald);
	color: var(--mtm-emerald);
}

/* ---- Carte de réservation ---- */
.mtm-book-card {
	position: sticky;
	top: 96px;
	background: #fff;
	border: 1px solid var(--mtm-line);
	border-radius: var(--mtm-radius);
	padding: 26px 24px;
	box-shadow: 0 18px 44px -30px rgba(12, 92, 76, .5);
}

.mtm-price {
	font-size: 2rem;
	font-weight: 700;
	color: var(--mtm-emerald);
	line-height: 1.1;
}

.mtm-price small {
	display: block;
	font-size: .78rem;
	font-weight: 600;
	color: var(--mtm-muted);
	margin-top: 2px;
}

.mtm-price-od {
	font-size: 1.5rem;
}

.mtm-facts {
	list-style: none;
	margin: 18px 0;
	padding: 0;
	font-size: .94rem;
}

.mtm-facts li {
	display: flex;
	align-items: center;
	gap: .6em;
	padding: 7px 0;
	color: #3c3b34;
	border-bottom: 1px solid var(--mtm-line);
}

.mtm-facts li:last-child {
	border-bottom: none;
}

.mtm-facts li::before {
	content: "\2713";
	color: var(--mtm-emerald);
	font-weight: 700;
	flex: none;
}

/* ---- Bouton WhatsApp ---- */
.mtm-wa-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .55em;
	font-weight: 700;
	font-size: .95rem;
	line-height: 1.2;
	padding: .85em 1.4em;
	border-radius: 999px;
	background: var(--mtm-wa);
	color: #fff;
	text-decoration: none;
	border: none;
	transition: background .15s ease, transform .15s ease;
}

.mtm-wa-btn:hover {
	background: var(--mtm-wa-dark);
	color: #fff;
	transform: translateY(-1px);
}

.mtm-wa-btn svg {
	width: 19px;
	height: 19px;
	fill: #fff;
	flex: none;
}

.mtm-wa-btn.mtm-wa-block {
	display: flex;
	width: 100%;
}

/* ---- Accessibilité ---- */
.mtm-wrap a:focus-visible,
.mtm-wa-btn:focus-visible {
	outline: 3px solid var(--mtm-gold-soft);
	outline-offset: 2px;
}

/* ---- Responsive ---- */
@media (max-width: 980px) {
	.mtm-circuit-grid {
		grid-template-columns: 1fr;
		gap: 34px;
	}

	.mtm-book-card {
		position: static;
	}
}

@media (max-width: 680px) {
	.mtm-wrap {
		font-size: 16px;
		padding: 22px 16px 60px;
	}

	.mtm-gallery-grid {
		grid-template-columns: 1fr 1fr;
	}

	.mtm-incl-grid {
		grid-template-columns: 1fr;
		gap: 22px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.mtm-wrap *,
	.mtm-wa-btn {
		transition: none !important;
	}
}

/* =================================================================
   Bloc 3b — archives (liste de circuits / services), cartes, filtres
   ================================================================= */

.mtm-archive-header {
	margin-bottom: 26px;
}

.mtm-archive-header .mtm-lead {
	margin-top: 12px;
}

/* ---- Barre de filtres ---- */
.mtm-filters {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 14px;
	padding: 18px 20px;
	margin-bottom: 30px;
	background: var(--mtm-sand);
	border: 1px solid var(--mtm-line);
	border-radius: var(--mtm-radius);
}

.mtm-filter {
	display: flex;
	flex-direction: column;
	gap: 5px;
	min-width: 150px;
	flex: 1 1 150px;
}

.mtm-filter-label {
	font-size: .74rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--mtm-emerald);
}

.mtm-filters select {
	width: 100%;
	padding: 9px 12px;
	border: 1px solid var(--mtm-line);
	border-radius: 9px;
	background: #fff;
	font-size: .95rem;
	color: var(--mtm-ink);
}

.mtm-filter-actions {
	display: flex;
	align-items: center;
	gap: 12px;
}

.mtm-btn-filter {
	border: none;
	cursor: pointer;
	background: var(--mtm-emerald);
	color: #fff;
	font-weight: 700;
	font-size: .92rem;
	padding: .7em 1.4em;
	border-radius: 999px;
	transition: background .15s ease;
}

.mtm-btn-filter:hover {
	background: var(--mtm-emerald-dark);
}

.mtm-filter-reset {
	font-size: .88rem;
	font-weight: 600;
	color: var(--mtm-muted);
	text-decoration: none;
}

.mtm-filter-reset:hover {
	color: var(--mtm-emerald);
}

/* ---- Grille de cartes ---- */
.mtm-cards {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 22px;
}

.mtm-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--mtm-line);
	border-radius: var(--mtm-radius);
	overflow: hidden;
	transition: transform .18s ease, box-shadow .18s ease;
}

.mtm-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 18px 40px -22px rgba(12, 92, 76, .45);
}

.mtm-card-media {
	position: relative;
	display: block;
	aspect-ratio: 3 / 2;
	overflow: hidden;
}

.mtm-card-media .mtm-card-img,
.mtm-card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .3s ease;
}

.mtm-card:hover .mtm-card-media img {
	transform: scale(1.04);
}

.mtm-card-ph {
	display: block;
	width: 100%;
	height: 100%;
	background:
		radial-gradient(120% 90% at 50% 0%, rgba(184, 149, 74, .28), transparent 60%),
		linear-gradient(160deg, var(--mtm-emerald-dark), #063229);
}

.mtm-card-badge {
	position: absolute;
	top: 12px;
	left: 12px;
	background: rgba(8, 70, 58, .92);
	color: #fff;
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	padding: 5px 11px;
	border-radius: 999px;
}

.mtm-card-body {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 18px 20px 22px;
}

.mtm-card-title {
	font-size: 1.2rem;
	line-height: 1.25;
	color: var(--mtm-ink);
	margin: 0;
}

.mtm-card-title a {
	color: inherit;
	text-decoration: none;
}

.mtm-card-title a:hover {
	color: var(--mtm-emerald);
}

.mtm-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 14px;
	margin-top: 8px;
	font-size: .85rem;
	color: var(--mtm-muted);
}

.mtm-card-meta span {
	position: relative;
}

.mtm-card-meta span + span::before {
	content: "·";
	position: absolute;
	left: -9px;
	color: var(--mtm-gold);
}

.mtm-card-desc {
	margin: 10px 0 0;
	font-size: .92rem;
	color: #3c3b34;
}

.mtm-card-price {
	margin-top: 14px;
	font-size: 1.3rem;
	font-weight: 700;
	color: var(--mtm-emerald);
	line-height: 1.2;
}

.mtm-card-price small {
	display: block;
	font-size: .72rem;
	font-weight: 600;
	color: var(--mtm-muted);
}

.mtm-card-price .mtm-price-txt {
	font-size: 1.1rem;
}

.mtm-card-price .mtm-od {
	font-size: 1.05rem;
	color: var(--mtm-muted);
	font-weight: 600;
}

.mtm-card-cta {
	display: flex;
	gap: 9px;
	margin-top: auto;
	padding-top: 16px;
}

.mtm-card-cta > * {
	flex: 1;
	padding-left: .6em;
	padding-right: .6em;
	font-size: .85rem;
	white-space: nowrap;
}

/* ---- Bouton contour ---- */
.mtm-btn-outline {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: .85rem;
	padding: .7em 1em;
	border-radius: 999px;
	text-decoration: none;
	color: var(--mtm-emerald);
	background: transparent;
	border: 1.5px solid rgba(12, 92, 76, .35);
	transition: background .15s ease, border-color .15s ease;
}

.mtm-btn-outline:hover {
	background: rgba(12, 92, 76, .06);
	border-color: var(--mtm-emerald);
	color: var(--mtm-emerald);
}

/* ---- Pagination ---- */
.mtm-pagination {
	margin-top: 38px;
}

.mtm-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	margin: 0 3px;
	border-radius: 9px;
	border: 1px solid var(--mtm-line);
	color: var(--mtm-ink);
	text-decoration: none;
	font-weight: 600;
}

.mtm-pagination .page-numbers.current {
	background: var(--mtm-emerald);
	border-color: var(--mtm-emerald);
	color: #fff;
}

.mtm-pagination a.page-numbers:hover {
	border-color: var(--mtm-emerald);
	color: var(--mtm-emerald);
}

/* ---- Vide ---- */
.mtm-empty {
	padding: 40px 20px;
	text-align: center;
	color: var(--mtm-muted);
	background: var(--mtm-sand);
	border-radius: var(--mtm-radius);
}

/* ---- Éléments page lieu ---- */
.mtm-eyebrow {
	font-size: .76rem;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--mtm-gold);
	margin-bottom: 8px;
}

.mtm-single-lieu .mtm-gallery-pub {
	margin-top: 0;
	margin-bottom: 30px;
}

@media (max-width: 680px) {
	.mtm-filter {
		flex-basis: 100%;
	}
}

/* =================================================================
   Bloc 4a — bouton WhatsApp flottant (site-wide, hors .mtm-wrap)
   ================================================================= */

.mtm-wa-float {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 9999;
	display: inline-flex;
	align-items: center;
	gap: 9px;
	padding: 13px 18px;
	border-radius: 999px;
	background: #1f8a55;
	color: #fff;
	font-family: inherit;
	font-weight: 700;
	font-size: .95rem;
	line-height: 1;
	text-decoration: none;
	box-shadow: 0 14px 30px -10px rgba(31, 138, 85, .7);
	transition: background .15s ease, transform .15s ease;
}

.mtm-wa-float:hover {
	background: #1a7549;
	color: #fff;
	transform: translateY(-2px);
}

.mtm-wa-float svg {
	width: 22px;
	height: 22px;
	fill: #fff;
	flex: none;
}

.mtm-wa-float:focus-visible {
	outline: 3px solid #D9C38C;
	outline-offset: 2px;
}

@media (max-width: 600px) {
	.mtm-wa-float .mtm-wa-float-label {
		display: none;
	}

	.mtm-wa-float {
		padding: 14px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.mtm-wa-float {
		transition: none;
	}
}

/* =================================================================
   Bloc 4b — shortcodes : variables hors « single », témoignages, FAQ
   ================================================================= */

/* Les shortcodes ne sont pas dans .mtm-wrap : on leur fournit les variables
   de couleur (sans contrainte de largeur ni de marge). */
.mtm-shortcode {
	--mtm-emerald: #0C5C4C;
	--mtm-emerald-dark: #08463A;
	--mtm-sand: #F4EFE6;
	--mtm-cream: #FBF9F5;
	--mtm-gold: #B8954A;
	--mtm-gold-soft: #D9C38C;
	--mtm-ink: #23231D;
	--mtm-muted: #5E5D54;
	--mtm-line: rgba(35, 35, 29, .12);
	--mtm-wa: #1f8a55;
	--mtm-wa-dark: #1a7549;
	--mtm-radius: 14px;
}

.mtm-shortcode * {
	box-sizing: border-box;
}

.mtm-wa-inline {
	display: inline-block;
}

/* ---- Lieu : époque sur la carte ---- */
.mtm-card-epoque {
	margin: 6px 0 0;
	font-size: .84rem;
	font-weight: 600;
	color: var(--mtm-muted);
}

/* ---- Témoignages ---- */
.mtm-quotes {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
}

.mtm-quote {
	display: flex;
	flex-direction: column;
	margin: 0;
	padding: 26px 24px;
	background: #fff;
	border: 1px solid var(--mtm-line);
	border-radius: var(--mtm-radius);
}

.mtm-stars {
	color: var(--mtm-gold);
	letter-spacing: 2px;
	font-size: 1rem;
}

.mtm-quote blockquote {
	margin: 14px 0 0;
	padding: 0;
	border: none;
	font-size: .98rem;
	color: #3c3b34;
}

.mtm-quote-who {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 18px;
}

.mtm-quote-av {
	flex: none;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	color: #fff;
	background: linear-gradient(150deg, var(--mtm-emerald), var(--mtm-emerald-dark));
}

.mtm-quote-meta b {
	display: block;
	font-size: .92rem;
}

.mtm-quote-meta small {
	color: var(--mtm-muted);
	font-size: .8rem;
}

/* ---- FAQ (accordéon natif) ---- */
.mtm-faq {
	max-width: 780px;
	margin: 0 auto;
}

.mtm-qa {
	border-bottom: 1px solid var(--mtm-line);
}

.mtm-qa summary {
	position: relative;
	cursor: pointer;
	list-style: none;
	padding: 20px 40px 20px 0;
	font-weight: 700;
	font-size: 1.04rem;
	color: var(--mtm-ink);
}

.mtm-qa summary::-webkit-details-marker {
	display: none;
}

.mtm-qa summary::after {
	content: "+";
	position: absolute;
	right: 6px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.4rem;
	font-weight: 400;
	color: var(--mtm-gold);
}

.mtm-qa[open] summary::after {
	content: "\2013"; /* – */
}

.mtm-qa-body {
	padding: 0 0 20px;
	color: var(--mtm-muted);
}

.mtm-qa-body p {
	margin: 0 0 .8em;
}

.mtm-qa-body p:last-child {
	margin-bottom: 0;
}

@media (max-width: 880px) {
	.mtm-quotes {
		grid-template-columns: 1fr;
	}
}
