.mt-shortcode {
	margin: 1.5rem 0;
	padding: 1.25rem;
	border: 1px solid #d8d8d8;
	border-radius: 8px;
	background: #fff;
}

.mt-shortcode__inner {
	display: block;
}

.mt-shortcode__title {
	margin: 0 0 0.75rem;
	font-size: 1.25rem;
	line-height: 1.3;
}

.mt-shortcode__body {
	color: #444;
}

.mt-shortcode--catalog {
	background: #fcfcfc;
}

.mt-shortcode--session {
	background: #f8fbff;
}

.mt-button {
	display: inline-block;
	padding: 0.7rem 1rem;
	border: 1px solid #222;
	border-radius: 6px;
	background: #222;
	color: #fff;
	text-decoration: none;
	cursor: pointer;
	font: inherit;
}

.mt-button:hover,
.mt-button:focus {
	background: #111;
	color: #fff;
}

.mt-button--ghost {
	background: #fff;
	color: #222;
}

.mt-button--ghost:hover,
.mt-button--ghost:focus {
	background: #f5f5f5;
	color: #111;
}

.mt-catalog__header {
	margin-bottom: 1rem;
}

.mt-catalog__filters {
	margin-bottom: 1rem;
	padding: 1rem;
	background: #fff;
	border: 1px solid #ececec;
	border-radius: 6px;
}

.mt-catalog__filters-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 0.9rem;
}

.mt-catalog__field label {
	display: block;
	margin-bottom: 0.35rem;
	font-weight: 600;
}

.mt-catalog__field select,
.mt-catalog__field input[type="search"] {
	width: 100%;
	padding: 0.65rem 0.75rem;
	border: 1px solid #c9c9c9;
	border-radius: 6px;
	background: #fff;
	font: inherit;
}

.mt-catalog__actions {
	margin-top: 0.9rem;
}

.mt-catalog__status {
	margin-bottom: 1rem;
	color: #555;
}

.mt-catalog__status.is-loading {
	color: #1d4ed8;
}

.mt-catalog__status.is-error {
	color: #b91c1c;
}

.mt-catalog__status.is-empty {
	color: #666;
}

.mt-catalog__results--list {
	display: grid;
	gap: 1rem;
}

.mt-catalog__results--cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
}

.mt-catalog-item {
	padding: 1rem;
	background: #fff;
	border: 1px solid #ececec;
	border-radius: 6px;
}

.mt-catalog-item__title {
	margin: 0 0 0.5rem;
	font-size: 1.05rem;
}

.mt-catalog-item__excerpt {
	margin: 0 0 0.75rem;
	color: #555;
}

.mt-catalog-item__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 0.8rem;
}

.mt-catalog-item__badge {
	display: inline-block;
	padding: 0.35rem 0.55rem;
	background: #f6f6f6;
	border-radius: 999px;
	font-size: 0.92rem;
}

.mt-catalog-item__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
}

.mt-program-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	background: #fff;
	border: 1px solid #ececec;
	border-radius: 8px;
}

.mt-program-card__media {
	aspect-ratio: 16 / 9;
	background: #f3f3f3;
}

.mt-program-card__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mt-program-card__body {
	padding: 1rem;
}

.mt-program-card__title {
	margin: 0 0 0.5rem;
	font-size: 1.05rem;
}

.mt-program-card__excerpt {
	margin: 0 0 0.75rem;
	color: #555;
}

.mt-program-card__meta {
	display: grid;
	gap: 0.5rem;
	margin-bottom: 0.85rem;
}

.mt-program-card__badge {
	display: inline-block;
	padding: 0.35rem 0.55rem;
	background: #f6f6f6;
	border-radius: 999px;
	font-size: 0.92rem;
}

.mt-program-card__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
}

.mt-catalog__empty {
	margin: 0;
	padding: 1rem;
	background: #fff;
	border: 1px dashed #cfcfcf;
	border-radius: 6px;
	color: #666;
}

.mt-catalog__pagination {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 1rem;
}

.mt-catalog__pagination-text {
	color: #555;
}

.mt-exercise__header {
	margin-bottom: 1rem;
}

.mt-exercise__title {
	margin: 0 0 0.75rem;
}

.mt-exercise__meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 0.75rem;
	margin-bottom: 1rem;
}

.mt-exercise__meta-item {
	padding: 0.75rem;
	background: #f7f7f7;
	border-radius: 6px;
}

.mt-exercise__meta-label {
	display: block;
	margin-bottom: 0.25rem;
	font-size: 0.9rem;
	color: #666;
}

.mt-exercise__meta-value {
	font-weight: 600;
}

.mt-exercise__metronome {
	margin-bottom: 1rem;
	padding: 1rem;
	border: 1px dashed #c8c8c8;
	border-radius: 6px;
	background: #fafafa;
}

.mt-exercise__metronome-placeholder {
	color: #666;
}

.mt-exercise__media {
	margin: 0 0 1rem;
}

.mt-exercise__image {
	display: block;
	max-width: 100%;
	height: auto;
	border-radius: 6px;
}

.mt-exercise__actions {
	margin-bottom: 1rem;
}

.mt-exercise__content > :first-child {
	margin-top: 0;
}

.mt-exercise__content > :last-child {
	margin-bottom: 0;
}

.mt-program__header {
	margin-bottom: 1rem;
}

.mt-program__title {
	margin: 0 0 0.75rem;
}

.mt-program__meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 0.75rem;
	margin-bottom: 1rem;
}

.mt-program__meta-item {
	padding: 0.75rem;
	background: #f7f7f7;
	border-radius: 6px;
}

.mt-program__meta-label {
	display: block;
	margin-bottom: 0.25rem;
	font-size: 0.9rem;
	color: #666;
}

.mt-program__meta-value {
	font-weight: 600;
}

.mt-program__media {
	margin: 0 0 1rem;
}

.mt-program__image {
	display: block;
	max-width: 100%;
	height: auto;
	border-radius: 6px;
}

.mt-program__actions {
	margin-bottom: 1rem;
}

.mt-program__content {
	margin-bottom: 1.25rem;
}

.mt-program__content > :first-child {
	margin-top: 0;
}

.mt-program__content > :last-child {
	margin-bottom: 0;
}

.mt-program__section-title {
	margin: 0 0 0.75rem;
	font-size: 1.1rem;
}

.mt-program__exercise-list {
	margin: 0;
	padding-left: 1.25rem;
}

.mt-program__exercise-item {
	margin: 0 0 0.9rem;
	padding: 0.9rem;
	background: #fcfcfc;
	border: 1px solid #ececec;
	border-radius: 6px;
}

.mt-program__exercise-title {
	margin: 0 0 0.6rem;
	font-size: 1rem;
}

.mt-program__exercise-meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 0.5rem;
}

.mt-program__exercise-meta-item {
	padding: 0.5rem 0.65rem;
	background: #fff;
	border: 1px solid #ececec;
	border-radius: 4px;
}

.mt-program__exercise-meta-label {
	display: block;
	margin-bottom: 0.2rem;
	font-size: 0.85rem;
	color: #666;
}

.mt-program__exercise-meta-value {
	font-weight: 600;
}

.mt-program__empty {
	color: #666;
}

.mt-notice {
	padding: 1rem 1.25rem;
}

.mt-notice--error {
	border-color: #d63638;
	background: #fff5f5;
}

.mt-notice--warning {
	border-color: #dba617;
	background: #fff9e6;
}

@media (max-width: 640px) {
	.mt-catalog__pagination {
		flex-direction: column;
		align-items: stretch;
	}

	.mt-catalog-item__actions,
	.mt-program-card__actions {
		flex-direction: column;
	}
}

.mt-button--small {
	padding: 0.4rem 0.65rem;
	font-size: 0.9rem;
}

.mt-session__layout {
	display: grid;
	grid-template-columns: minmax(280px, 34%) minmax(0, 66%);
	gap: 1.25rem;
	align-items: start;
}

.mt-session__sidebar,
.mt-session__detail {
	background: #fff;
	border: 1px solid #e8e8e8;
	border-radius: 8px;
	padding: 1rem;
}

.mt-session__sidebar {
	position: sticky;
	top: 1rem;
}

.mt-session__sidebar-header {
	margin-bottom: 1rem;
}

.mt-session__summary {
	margin: 0.5rem 0 0;
	color: #555;
}

.mt-session__summary-label {
	display: block;
	font-size: 0.92rem;
}

.mt-session__summary-value {
	font-size: 1.1rem;
}

.mt-session__toolbar {
	margin-bottom: 1rem;
}

.mt-session__list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.mt-session__empty {
	margin: 0;
	padding: 1rem;
	border: 1px dashed #d0d0d0;
	border-radius: 6px;
	color: #666;
	background: #fafafa;
}

.mt-session-item {
	padding: 0.75rem;
	border: 1px solid #ececec;
	border-radius: 6px;
	background: #fcfcfc;
}

.mt-session-item + .mt-session-item {
	margin-top: 0.75rem;
}

.mt-session-item.is-active {
	border-color: #222;
	background: #f5f7ff;
}

.mt-session-item__select {
	display: block;
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	text-align: left;
	cursor: pointer;
}

.mt-session-item__title {
	display: block;
	margin-bottom: 0.2rem;
	font-weight: 600;
	color: #111;
}

.mt-session-item__meta {
	display: block;
	color: #666;
	font-size: 0.92rem;
}

.mt-session-item__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.75rem;
}

.mt-session__detail-placeholder {
	color: #666;
}

.mt-session-detail__header {
	margin-bottom: 1rem;
}

.mt-session-detail__title {
	margin: 0 0 0.75rem;
}

.mt-session-detail__meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: 0.75rem;
	margin-bottom: 1rem;
}

.mt-session-detail__meta-item {
	padding: 0.75rem;
	background: #f7f7f7;
	border-radius: 6px;
}

.mt-session-detail__meta-label {
	display: block;
	margin-bottom: 0.25rem;
	font-size: 0.9rem;
	color: #666;
}

.mt-session-detail__meta-value {
	font-weight: 600;
}

.mt-session-detail__metronome {
	margin-bottom: 1rem;
	padding: 1rem;
	border: 1px dashed #c8c8c8;
	border-radius: 6px;
	background: #fafafa;
}

.mt-session-detail__metronome-placeholder {
	color: #666;
}

.mt-session-detail__media {
	margin: 0 0 1rem;
}

.mt-session-detail__image {
	display: block;
	max-width: 100%;
	height: auto;
	border-radius: 6px;
}

.mt-session-detail__content > :first-child {
	margin-top: 0;
}

.mt-session-detail__content > :last-child {
	margin-bottom: 0;
}

@media (max-width: 900px) {
	.mt-session__layout {
		grid-template-columns: 1fr;
	}

	.mt-session__sidebar {
		position: static;
	}
}

.mt-metronome {
	margin-bottom: 1rem;
	padding: 1rem;
	border: 1px dashed #c8c8c8;
	border-radius: 6px;
	background: #fafafa;
}

.mt-metronome__controls {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 0.75rem;
	align-items: center;
	margin-bottom: 0.75rem;
}

.mt-metronome__range {
	width: 100%;
}

.mt-metronome__step {
	min-width: 2.75rem;
	padding-inline: 0;
}

.mt-metronome__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

.mt-metronome__display {
	font-weight: 600;
}

@media (max-width: 640px) {
	.mt-metronome__controls {
		grid-template-columns: 1fr;
	}

	.mt-metronome__footer {
		flex-direction: column;
		align-items: stretch;
	}
}

.mt-session-item.is-active-metronome {
	border-color: #1d4ed8;
	box-shadow: inset 0 0 0 1px #1d4ed8;
}

.mt-session-item__actions .is-current {
	background: #e8f0ff;
	border-color: #1d4ed8;
	color: #123a8c;
}

.mt-catalog-item__terms,
.mt-program-card__terms {
	margin-bottom: 0.8rem;
}

.mt-catalog-item__terms .mt-catalog-item__badge,
.mt-program-card__terms .mt-program-card__badge {
	display: inline-block;
}

/* Titres généraux des shortcodes */
.mt-shortcode__title {
	font-size: 1.15rem;
	line-height: 1.35;
}

/* Titres des cartes / items (catalogue + programmes + séance) */
.mt-catalog-item__title,
.mt-program-card__title,
.mt-session-item__title,
.mt-exercise__title,
.mt-program__title,
.mt-session-detail__title {
	font-size: 1rem;
	line-height: 1.4;
}

/* Petits titres de section (ex : "Niveaux", "Durée", etc.) */
.mt-catalog__field label,
.mt-exercise__meta-label,
.mt-program__meta-label,
.mt-program__exercise-meta-label,
.mt-session-detail__meta-label,
.mt-session__summary-label {
	font-size: 0.85rem;
}

/* Badges (durée, BPM, niveaux…) un peu plus discrets */
.mt-catalog-item__badge,
.mt-program-card__badge {
	font-size: 0.85rem;
	padding: 0.3rem 0.5rem;
}

/* Texte d’élément (extraits, statuts, messages vides) */
.mt-catalog-item__excerpt,
.mt-program-card__excerpt,
.mt-catalog__status,
.mt-catalog__empty,
.mt-session__empty,
.mt-session__detail-placeholder,
.mt-exercise__metronome-placeholder,
.mt-program__empty {
	font-size: 0.9rem;
}

/* Boutons légèrement plus compacts */
.mt-button {
	font-size: 0.95rem;
	padding: 0.6rem 0.9rem;
}

.mt-button--small {
	font-size: 0.85rem;
	padding: 0.35rem 0.6rem;
}

/* Panel "Ma séance" : garder une hiérarchie douce */
.mt-session__summary-value {
	font-size: 1rem;
}

.mt-session-detail__meta-value,
.mt-exercise__meta-value,
.mt-program__meta-value,
.mt-program__exercise-meta-value,
.mt-metronome__display {
	font-size: 0.95rem;
}

/* Sous-titre métronome dans le détail séance (si présent) */
.mt-session-detail__section-title {
	font-size: 0.95rem;
}

/* Bouton principal : bleu moderne */
.mt-button {
	display: inline-block;
	padding: 0.6rem 1rem;
	border-radius: 6px;
	border: 1px solid #1a5276;
	background: linear-gradient(135deg, #2d6085, #1a5276);
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
	font: inherit;
	font-size: 0.95rem;
	transition:
		background 150ms ease,
		border-color 150ms ease,
		box-shadow 150ms ease,
		transform 80ms ease;
}

.mt-button:hover,
.mt-button:focus {
	background: linear-gradient(135deg, #1a5276, #004568);
	border-color: #004568;
	color: #ffffff;
	box-shadow: 0 10px 18px rgba(37, 99, 235, 0.25);
	transform: translateY(-1px);
}

.mt-button:active {
	box-shadow: 0 4px 10px rgba(37, 99, 235, 0.2);
	transform: translateY(0);
}

/* Versions "ghost" : contour + fond clair */
.mt-button--ghost {
	background: #ffffff;
	color: #1e293b;
	border-color: #cbd5f5;
}

.mt-button--ghost:hover,
.mt-button--ghost:focus {
	background: #eff3ff;
	border-color: #94a3ff;
	color: #111827;
	box-shadow: 0 4px 10px rgba(148, 163, 255, 0.25);
}

/* Petits boutons (actions de séance, meta) */
.mt-button--small {
	padding: 0.35rem 0.7rem;
	font-size: 0.85rem;
	border-radius: 999px;
}

/* Bouton "danger" éventuel (si tu en ajoutes plus tard) */
.mt-button--danger {
	border-color: #dc2626;
	background: linear-gradient(135deg, #ef4444, #dc2626);
}

.mt-button--danger:hover,
.mt-button--danger:focus {
	background: linear-gradient(135deg, #dc2626, #b91c1c);
	border-color: #b91c1c;
	box-shadow: 0 10px 18px rgba(239, 68, 68, 0.25);
}

/* Filtres catalogue : label et champs plus compacts */
.mt-catalog__field label {
	font-size: 0.9rem;
}

.mt-catalog__field select,
.mt-catalog__field input[type="search"] {
	font-size: 0.95rem;
	padding: 0.45rem 0.6rem;
	border-radius: 10px;
}

/* Conteneur des filtres un peu plus léger visuellement */
.mt-catalog__filters {
	padding: 0.8rem 0.9rem;
}

/* Alignement : garder la grille mais réduire légèrement l’écart */
.mt-catalog__filters-grid {
	gap: 0.7rem;
}
