/* Apidae SIT Plugin – Frontend (même rendu que Base44). Préfixe .apidae-plugin pour isolation. */

.apidae-plugin {
	--apidae-primary: #1e3a5f;
	--apidae-primary-dark: #162d4a;
	--apidae-slate-50: #f8fafc;
	--apidae-slate-100: #f1f5f9;
	--apidae-slate-200: #e2e8f0;
	--apidae-slate-300: #cbd5e1;
	--apidae-slate-400: #94a3b8;
	--apidae-slate-500: #64748b;
	--apidae-slate-600: #475569;
	--apidae-slate-700: #334155;
	--apidae-slate-800: #1e293b;
	--apidae-radius: 0.75rem;
	--apidae-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--apidae-shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
}

.apidae-plugin {
	min-height: 200px;
	background: linear-gradient(to bottom right, var(--apidae-slate-50), #fff, #eff6ff);
	width: 100%;
	max-width: 1400px;
	margin-left: auto;
	margin-right: auto;
	padding: 1rem 1rem 1.5rem;
	box-sizing: border-box;
}
@media (min-width: 768px) {
	.apidae-plugin {
		padding: 1.5rem 1.5rem 2rem;
	}
}
.apidae-plugin *,
.apidae-plugin *::before,
.apidae-plugin *::after {
	box-sizing: border-box;
}

/* Header */
.apidae-plugin__header {
	margin-bottom: 1.5rem;
}
.apidae-plugin__header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.apidae-plugin__title {
	font-size: 0.9375rem !important;
	font-weight: 700;
	color: var(--apidae-slate-800);
	margin: 0;
	line-height: 1.3;
}
.apidae-plugin h2.apidae-plugin__title {
	font-size: 0.9375rem !important;
}
.apidae-plugin__meta {
	font-size: 0.875rem;
	color: var(--apidae-slate-500);
	margin: 0;
}
.apidae-plugin__count {
	font-weight: 600;
	color: var(--apidae-slate-700);
}
.apidae-plugin__link-all {
	color: var(--apidae-primary);
	text-decoration: none;
}
.apidae-plugin__link-all:hover {
	text-decoration: underline;
}

/* Barre de recherche (shortcode liste uniquement) */
.apidae-plugin__search-form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1.25rem;
	align-items: center;
}
.apidae-plugin__search-input {
	flex: 1;
	min-width: 12rem;
	padding: 0.5rem 0.75rem;
	font-size: 0.875rem;
	border: 1px solid var(--apidae-slate-300);
	border-radius: var(--apidae-radius);
	background: #fff;
}
.apidae-plugin__search-input:focus {
	outline: none;
	border-color: var(--apidae-primary);
	box-shadow: 0 0 0 2px rgb(30 58 95 / 0.15);
}
.apidae-plugin__search-btn {
	padding: 0.5rem 1rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: #fff;
	background: var(--apidae-primary);
	border: none;
	border-radius: var(--apidae-radius);
	cursor: pointer;
}
.apidae-plugin__search-btn:hover {
	background: var(--apidae-primary-dark);
}
.apidae-plugin .screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Grid : 4 colonnes comme le visuel (éviter l’empilement) */
/* Liste avec panneau détail : comme sur la maquette (titre + recherche en haut, grille | panneau en dessous) */
.apidae-plugin--list-with-panel {
	position: relative;
	max-width: none;
	box-sizing: border-box;
}
.apidae-plugin--list-with-panel .apidae-plugin__list-header {
	width: 100%;
	margin-bottom: 0;
}
.apidae-plugin--list-with-panel .apidae-plugin__list-body {
	display: flex;
	flex-wrap: nowrap;
	gap: 1.25rem;
	align-items: flex-start;
	min-height: 50vh;
}
.apidae-plugin--list-with-panel .apidae-plugin__list-main {
	flex: 1 1 0;
	min-width: 0;
	box-sizing: border-box;
}
.apidae-plugin--list-with-panel .apidae-plugin__list-main .apidae-plugin__content {
	min-width: 0;
}
.apidae-plugin--list-with-panel .apidae-plugin__list-main .apidae-plugin__grid {
	min-width: 0;
	max-width: 100%;
}
/* Panneau aligné sur la grille (même hauteur de départ), sticky au scroll, même écart que entre les cartes */
.apidae-plugin--list-with-panel .apidae-plugin__detail-panel {
	position: sticky;
	top: 1rem;
	align-self: flex-start;
	width: 20rem;
	flex: 0 0 20rem;
	max-height: calc(100vh - 2rem);
	overflow: auto;
	background: #fff;
	border: 1px solid var(--apidae-slate-200);
	border-radius: var(--apidae-radius);
	box-shadow: 0 4px 20px rgb(0 0 0 / 0.12);
	padding: 1rem 1rem 2.5rem;
	box-sizing: border-box;
	z-index: 10;
}
.apidae-plugin__detail-panel-close {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	z-index: 2;
	width: 2rem;
	height: 2rem;
	padding: 0;
	border: 0;
	background: var(--apidae-slate-100);
	border-radius: 0.25rem;
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	color: var(--apidae-slate-600);
	transition: background 0.2s, color 0.2s;
}
.apidae-plugin__detail-panel-close:hover {
	background: var(--apidae-slate-200);
	color: var(--apidae-slate-800);
}
.apidae-plugin__detail-panel-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 12rem;
	padding: 1.5rem;
	text-align: center;
	color: var(--apidae-slate-500);
	font-size: 0.875rem;
}
.apidae-plugin__detail-panel.is-active .apidae-plugin__detail-panel-placeholder {
	display: none;
}
.apidae-plugin__detail-panel-loading {
	padding: 2rem;
	text-align: center;
	color: var(--apidae-slate-500);
	font-size: 0.875rem;
}
.apidae-plugin__detail-panel-inner {
	padding: 0;
}
.apidae-plugin__detail-panel-inner h2 {
	font-size: 0.9375rem !important;
	margin: 0 0 0.75rem;
	line-height: 1.3;
}
.apidae-plugin__detail-panel .apidae-plugin__modal-hero {
	border-radius: var(--apidae-radius);
	overflow: hidden;
	margin-bottom: 0.75rem;
}
.apidae-plugin__detail-panel .apidae-plugin__modal-hero img {
	width: 100%;
	height: auto;
	display: block;
}
.apidae-plugin__detail-panel .apidae-plugin__detail-address,
.apidae-plugin__detail-panel .apidae-plugin__detail-contact {
	margin-bottom: 0.5rem;
	font-size: 0.8125rem;
}
.apidae-plugin__detail-panel .apidae-plugin__detail-desc-wrap {
	padding: 0 0 1rem;
}
.apidae-plugin__detail-panel .apidae-plugin__detail-desc-title {
	font-size: 0.875rem;
}
.apidae-plugin__detail-panel .apidae-plugin__detail-desc {
	font-size: 0.875rem;
}
.apidae-plugin__card.is-selected {
	outline: 2px solid var(--apidae-primary);
	outline-offset: 2px;
}
/* Téléphone : masquer le panneau droit, la grille prend toute la largeur (clic = popup) */
@media (max-width: 900px) {
	.apidae-plugin--list-with-panel .apidae-plugin__list-body {
		flex-direction: column;
	}
	.apidae-plugin--list-with-panel .apidae-plugin__detail-panel {
		display: none !important;
	}
}

.apidae-plugin__content {
	width: 100%;
}
.apidae-plugin__grid {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr) !important;
	gap: 1.25rem !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}
/* Mobile : 1 colonne */
@media (max-width: 575px) {
	.apidae-plugin__grid {
		grid-template-columns: 1fr !important;
	}
}
/* Tablette : 2 colonnes */
@media (min-width: 576px) and (max-width: 767px) {
	.apidae-plugin__grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}
/* Tablette large : 3 colonnes */
@media (min-width: 768px) and (max-width: 991px) {
	.apidae-plugin__grid {
		grid-template-columns: repeat(3, 1fr) !important;
	}
}
/* Desktop : 4 colonnes (visuel) */
@media (min-width: 992px) {
	.apidae-plugin__grid {
		grid-template-columns: repeat(4, 1fr) !important;
	}
}

/* Carrousel : une ligne, 4 fiches visibles (container query pour largeur exacte) */
.apidae-plugin--carousel {
	background: transparent;
}
.apidae-plugin--carousel .apidae-plugin__header {
	margin-bottom: 1rem;
}
.apidae-plugin__carousel-wrap {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	width: 100%;
}
.apidae-plugin__carousel-btn {
	flex-shrink: 0;
	width: 2rem;
	height: 2rem;
	min-width: 2rem;
	min-height: 2rem;
	padding: 0;
	border: 1px solid var(--apidae-slate-200);
	background: #fff;
	border-radius: 50%;
	color: var(--apidae-slate-700);
	font-size: 0.875rem;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s;
}
.apidae-plugin__carousel-btn:hover {
	background: var(--apidae-slate-50);
	border-color: var(--apidae-slate-300);
	color: var(--apidae-primary);
}
.apidae-plugin__carousel-viewport {
	container-type: inline-size;
	container-name: apidae-carousel;
	flex: 1;
	min-width: 0;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
}
.apidae-plugin__carousel-track {
	display: flex;
	flex-wrap: nowrap;
	gap: 1.25rem;
	width: max-content;
	min-height: 100%;
	padding: 0 0 0.25rem 0;
}
.apidae-plugin--carousel .apidae-plugin__card--carousel {
	flex: 0 0 calc((100cqw - 1.25rem * 3) / 4);
	min-width: calc((100cqw - 1.25rem * 3) / 4);
	scroll-snap-align: start;
}
/* Fallback si container queries non supportées : largeur fixe pour ~4 cartes sur grand écran */
@supports not (container-type: inline-size) {
	.apidae-plugin__carousel-viewport {
		container-type: unset;
		container-name: unset;
	}
	.apidae-plugin--carousel .apidae-plugin__card--carousel {
		flex: 0 0 min(320px, calc(25vw - 1rem));
		min-width: min(260px, calc(25vw - 1rem));
	}
}
@container apidae-carousel (max-width: 767px) {
	.apidae-plugin--carousel .apidae-plugin__card--carousel {
		flex: 0 0 calc((100cqw - 1rem) / 2);
		min-width: calc((100cqw - 1rem) / 2);
	}
	.apidae-plugin__carousel-track {
		gap: 1rem;
	}
}
@container apidae-carousel (max-width: 479px) {
	.apidae-plugin--carousel .apidae-plugin__card--carousel {
		flex: 0 0 calc(100cqw - 0.5rem);
		min-width: calc(100cqw - 0.5rem);
	}
	.apidae-plugin__carousel-track {
		gap: 0.5rem;
	}
}
@media (max-width: 767px) {
	.apidae-plugin__carousel-btn {
		width: 1.75rem;
		height: 1.75rem;
		min-width: 1.75rem;
		min-height: 1.75rem;
		font-size: 0.75rem;
	}
}
@media (max-width: 479px) {
	.apidae-plugin__carousel-btn {
		width: 1.75rem;
		height: 1.75rem;
		min-width: 1.75rem;
		min-height: 1.75rem;
		font-size: 0.75rem;
	}
}

/* Card */
.apidae-plugin__grid .apidae-plugin__card,
.apidae-plugin__card {
	display: block !important;
	background: #fff;
	border-radius: var(--apidae-radius);
	box-shadow: var(--apidae-shadow);
	overflow: hidden;
	cursor: pointer;
	transition: box-shadow 0.3s ease, transform 0.2s ease;
	border: 0;
	min-width: 0; /* évite que la grille explose */
	width: 100%;
	max-width: 100%;
}
.apidae-plugin__card:hover {
	box-shadow: var(--apidae-shadow-lg);
}
.apidae-plugin__card-media {
	position: relative;
	height: 11rem;
	overflow: hidden;
}
.apidae-plugin__card-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}
.apidae-plugin__card:hover .apidae-plugin__card-img {
	transform: scale(1.05);
}
.apidae-plugin__card-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(to bottom right, var(--apidae-slate-100), var(--apidae-slate-200));
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.5rem;
	font-weight: 300;
	color: var(--apidae-slate-300);
}
.apidae-plugin__badge {
	position: absolute;
	top: 0.75rem;
	left: 0.75rem;
	padding: 0.25rem 0.5rem;
	font-size: 0.75rem;
	font-weight: 500;
	border-radius: 0.25rem;
	border: 0;
	box-shadow: 0 1px 2px rgb(0 0 0 / 0.05);
}
.apidae-plugin__badge--amber { background: #fef3c7; color: #92400e; }
.apidae-plugin__badge--emerald { background: #d1fae5; color: #065f46; }
.apidae-plugin__badge--orange { background: #ffedd5; color: #c2410c; }
.apidae-plugin__badge--blue { background: #dbeafe; color: #1e40af; }
.apidae-plugin__badge--violet { background: #ede9fe; color: #5b21b6; }
.apidae-plugin__badge--pink { background: #fce7f3; color: #9d174d; }
.apidae-plugin__badge--cyan { background: #cffafe; color: #0e7490; }
.apidae-plugin__badge--slate { background: var(--apidae-slate-100); color: var(--apidae-slate-700); }

.apidae-plugin__card-body {
	padding: 1rem;
}
.apidae-plugin__card-title {
	font-size: 0.6875rem !important;
	font-weight: 600;
	color: var(--apidae-slate-800);
	line-height: 1.35;
	margin: 0 0 0.2rem 0;
	transition: color 0.2s;
}
.apidae-plugin h3.apidae-plugin__card-title {
	font-size: 0.6875rem !important;
}
.apidae-plugin__card:hover .apidae-plugin__card-title {
	color: var(--apidae-primary);
}
.apidae-plugin__card-location {
	font-size: 0.6875rem;
	color: var(--apidae-slate-500);
	margin: 0 0 0.35rem 0;
	display: flex;
	align-items: center;
	gap: 0.25rem;
}
.apidae-plugin__card-location::before {
	content: "";
	display: inline-block;
	width: 0.875rem;
	height: 0.875rem;
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") no-repeat center;
}
.apidae-plugin__card-desc {
	font-size: 0.6875rem;
	color: var(--apidae-slate-500);
	line-height: 1.45;
	margin: 0 0 0.5rem 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.apidae-plugin__card-link {
	font-size: 0.625rem;
	color: var(--apidae-slate-400);
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.25rem;
	transition: color 0.2s;
}
.apidae-plugin__card:hover .apidae-plugin__card-link {
	color: var(--apidae-primary);
}

/* Empty */
.apidae-plugin__empty {
	text-align: center;
	padding: 3rem 1rem;
	color: var(--apidae-slate-500);
}

/* Afficher plus */
.apidae-plugin__load-more-wrap {
	text-align: center;
	padding: 1.5rem 0 0;
	margin-top: 1rem;
}
.apidae-plugin__load-more-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem 1.5rem;
	font-size: 1rem;
	font-weight: 500;
	color: var(--apidae-primary);
	background: #fff;
	border: 2px solid var(--apidae-primary);
	border-radius: var(--apidae-radius);
	cursor: pointer;
	transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.apidae-plugin__load-more-btn:hover {
	background: var(--apidae-primary);
	color: #fff;
}
.apidae-plugin__load-more-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}
.apidae-plugin__load-more-arrow {
	font-size: 1.25rem;
	line-height: 1;
}

/* Pagination */
.apidae-plugin__pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	padding: 1.5rem 0 0;
	margin-top: 1rem;
}
.apidae-plugin__pagination-prev,
.apidae-plugin__pagination-next {
	display: inline-block;
	padding: 0.5rem 0.75rem;
	font-size: 0.875rem;
	border: 1px solid var(--apidae-slate-200);
	border-radius: 0.5rem;
	background: #fff;
	color: var(--apidae-slate-700);
	text-decoration: none;
	transition: border-color 0.2s, background 0.2s;
}
.apidae-plugin__pagination-prev:hover,
.apidae-plugin__pagination-next:hover {
	border-color: var(--apidae-slate-300);
	background: var(--apidae-slate-50);
}
.apidae-plugin__pagination-info {
	font-size: 0.875rem;
	color: var(--apidae-slate-600);
	padding: 0 0.5rem;
}

/* Error */
.apidae-plugin--error {
	padding: 1rem;
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #b91c1c;
	border-radius: var(--apidae-radius);
}

/* Modal : z-index très élevé pour passer au-dessus du header/footer du thème (ex. Avada) */
.apidae-plugin__modal {
	position: fixed;
	inset: 0;
	z-index: 2147483647;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
	box-sizing: border-box;
}
.apidae-plugin__modal[hidden] {
	display: none;
}
.apidae-plugin__modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
}
.apidae-plugin__modal-dialog {
	position: relative;
	width: 100%;
	max-width: 42rem;
	max-height: 90vh;
	background: #fff;
	border-radius: var(--apidae-radius);
	box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
	overflow: hidden;
}
.apidae-plugin__modal-content {
	position: relative;
	max-height: 90vh;
	overflow: auto;
}
.apidae-plugin__modal-close {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	z-index: 2;
	width: 2rem;
	height: 2rem;
	padding: 0;
	border: 0;
	background: rgba(255,255,255,0.9);
	border-radius: 0.25rem;
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	color: var(--apidae-slate-600);
	transition: background 0.2s, color 0.2s;
}
.apidae-plugin__modal-close:hover {
	background: #fff;
	color: var(--apidae-slate-800);
}
.apidae-plugin__modal-body {
	padding: 0;
}
.apidae-plugin__modal-loading {
	padding: 2rem;
	text-align: center;
	color: var(--apidae-slate-500);
}
.apidae-plugin__modal-inner {
	padding: 0;
}
/* Image en-tête pop-up (comme capture) */
.apidae-plugin__modal-hero {
	position: relative;
	height: 14rem;
	overflow: hidden;
	background: var(--apidae-slate-100);
}
.apidae-plugin__modal-hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.apidae-plugin__modal-hero .apidae-plugin__badge {
	position: absolute;
	bottom: 1rem;
	left: 1.25rem;
	top: auto;
	background: rgba(255,255,255,0.9);
}
.apidae-plugin__modal-inner h2 {
	font-size: 0.9375rem !important;
	font-weight: 700;
	color: var(--apidae-slate-800);
	margin: 0 0 0.75rem 0;
	padding: 0 1.25rem;
	padding-top: 1rem;
}
.apidae-plugin__modal-inner .apidae-plugin__detail-address,
.apidae-plugin__modal-inner .apidae-plugin__detail-contact {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
	font-size: 0.875rem;
	color: var(--apidae-slate-600);
	padding: 0 1.25rem;
}
.apidae-plugin__modal-inner .apidae-plugin__detail-contact a {
	color: var(--apidae-primary);
	text-decoration: none;
}
.apidae-plugin__modal-inner .apidae-plugin__detail-contact a:hover {
	text-decoration: underline;
}
.apidae-plugin__modal-inner .apidae-plugin__detail-desc-wrap {
	padding: 0 1.25rem 1.25rem;
}
.apidae-plugin__modal-inner .apidae-plugin__detail-desc-title {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--apidae-slate-700);
	margin: 1rem 0 0.5rem 0;
}
.apidae-plugin__modal-inner .apidae-plugin__detail-desc {
	font-size: 0.875rem;
	color: var(--apidae-slate-600);
	line-height: 1.6;
	white-space: pre-line;
	margin: 0;
}
.apidae-plugin__modal-inner .apidae-plugin__detail-id {
	font-size: 0.75rem;
	color: var(--apidae-slate-400);
	margin-top: 1rem;
	padding: 0 1.25rem 1.25rem;
}

/* Override Avada / thème : forcer les tailles de titres dans le bloc du plugin */
.apidae-plugin .apidae-plugin__title,
.apidae-plugin h2.apidae-plugin__title,
.fusion-body .apidae-plugin .apidae-plugin__title,
.fusion-body .apidae-plugin h2.apidae-plugin__title {
	font-size: 0.9375rem !important;
}
.apidae-plugin .apidae-plugin__card-title,
.apidae-plugin h3.apidae-plugin__card-title,
.fusion-body .apidae-plugin .apidae-plugin__card-title,
.fusion-body .apidae-plugin h3.apidae-plugin__card-title {
	font-size: 0.6875rem !important;
}
.apidae-plugin .apidae-plugin__modal-inner h2,
.fusion-body .apidae-plugin .apidae-plugin__modal-inner h2 {
	font-size: 0.9375rem !important;
}
