/* ============================================
 * Abri Slider — Frontend styles (FLUID v1.2)
 * Lightweight, no framework, ~7 KB minified
 * Truly responsive from 380px to 3440px+
 * ============================================ */

.abri-slider {
	--abri-accent: #1F7B4D;
	--abri-text: #1a1f2e;
	--abri-muted: #6b7280;
	--abri-bg-1: #f8fafc;
	--abri-bg-2: #ffffff;
	--abri-bg-3: #fef9f9;
	--abri-radius: clamp(20px, 1.8vw, 36px);
	--abri-card-radius: clamp(28px, 2.5vw, 56px);
	--abri-shadow: 0 25px 50px rgba(20,30,50,.18);
	--abri-max-width: 1240px;
	--abri-height: 520px;
	--abri-aspect: calc(var(--abri-max-width) / var(--abri-height));

	position: relative;
	width: 100%;
	max-width: var(--abri-max-width);
	margin: 0 auto;
	border-radius: var(--abri-radius);
	overflow: hidden;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
	color: var(--abri-text);
	box-sizing: border-box;
	container-type: inline-size; /* enables container queries */
}
.abri-slider *, .abri-slider *::before, .abri-slider *::after { box-sizing: border-box; }

/* ----- Viewport ----- */
.abri-slider__viewport {
	position: relative;
	width: 100%;
	/* Hauteur fixe = ce que l'utilisateur a réglé. Toutes les slides ont la même taille. */
	height: var(--abri-height, 520px);
	overflow: hidden;
	border-radius: var(--abri-radius);
	background:
		radial-gradient(ellipse at 25% 25%, rgba(220,232,245,.55) 0%, transparent 60%),
		radial-gradient(ellipse at 75% 80%, rgba(255,228,228,.30) 0%, transparent 55%),
		linear-gradient(135deg, var(--abri-bg-1) 0%, var(--abri-bg-2) 50%, var(--abri-bg-3) 100%);
}
.abri-slider__viewport::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='0.5'/></svg>");
	opacity: .25;
	mix-blend-mode: overlay;
	pointer-events: none;
	z-index: 1;
}

/* ----- Track / Slides ----- */
.abri-slider__track {
	position: relative;
	width: 100%;
	min-height: 100%;
	height: auto;
	z-index: 2;
}
.abri-slider__slide {
	position: absolute;
	inset: 0;
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(300px, 1.2fr);
	grid-template-rows: 1fr;  /* une seule ligne qui remplit le slider */
	gap: clamp(20px, 2.5vw, 60px);
	/* Padding latéral dynamique : assure que le contenu ne dépasse jamais 1500px */
	padding-top: clamp(40px, 4vw, 80px);
	padding-bottom: clamp(60px, 5vw, 100px);
	padding-left: max(clamp(40px, 5vw, 100px), calc((100% - 1500px) / 2));
	padding-right: max(clamp(40px, 5vw, 100px), calc((100% - 1500px) / 2));
	opacity: 0;
	visibility: hidden;
	transition: opacity .6s ease, visibility 0s .6s;
	pointer-events: none;
	align-items: stretch; /* image et texte remplissent toute la hauteur de la grille */
}
.abri-slider__slide.is-active {
	opacity: 1;
	visibility: visible;
	transition: opacity .6s ease;
	pointer-events: auto;
}
.abri-slider__bg { position: absolute; inset: 0; pointer-events: none; }

/* ----- Content (text left) ----- */
.abri-slider__content {
	display: flex;
	flex-direction: column;
	gap: clamp(10px, 1.2vw, 18px);
	justify-content: center;
	min-width: 0;
	max-width: 100%;
	height: 100%; /* remplit la grille verticalement, centre via justify-content */
}
.abri-slider__pretitle { display: flex; align-items: center; }
.abri-slider__pretitle span {
	display: inline-block;
	font-size: clamp(10px, 0.75vw, 13px);
	font-weight: 700;
	letter-spacing: 3px;
	color: var(--abri-accent);
	text-transform: uppercase;
	border-left: 3px solid var(--abri-accent);
	padding-left: 10px;
}

.abri-slider__title {
	/* Fluid scaling, cappé à 60px pour ne pas exploser le layout sur grand écran */
	font-size: clamp(26px, 3vw, 60px);
	font-weight: 800;
	line-height: 1.04;
	letter-spacing: -0.04em;
	color: var(--abri-text);
	margin: 0;
}
.abri-slider__title .accent { color: var(--abri-accent); }

.abri-slider__subtitle {
	font-size: clamp(13px, 1.1vw, 19px);
	line-height: 1.55;
	color: var(--abri-muted);
	margin: 0;
}

.abri-slider__metas {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 4px;
}
.abri-slider__pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: clamp(5px, 0.5vw, 8px) clamp(10px, 1vw, 14px);
	background: #fff;
	border: 1px solid #e6e6e0;
	border-radius: 999px;
	font-size: clamp(10px, 0.85vw, 13px);
	font-weight: 500;
	letter-spacing: .3px;
	color: var(--abri-text);
}
.abri-slider__pill .dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--abri-accent);
}

.abri-slider__cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--abri-accent);
	color: #fff;
	padding: clamp(10px, 1vw, 16px) clamp(20px, 2vw, 36px);
	border-radius: 999px;
	text-decoration: none;
	font-weight: 600;
	font-size: clamp(13px, 1vw, 17px);
	box-shadow: 0 8px 20px rgba(31,123,77,.35);
	transition: transform .2s, box-shadow .2s;
	align-self: flex-start;
	margin-top: 8px;
}
.abri-slider__cta:hover { transform: translateY(-2px); box-shadow: 0 12px 24px rgba(31,123,77,.45); }
.abri-slider__cta .arrow { transition: transform .2s; }
.abri-slider__cta:hover .arrow { transform: translateX(4px); }

/* ----- Image card (right) ----- */
.abri-slider__image {
	position: relative;
	border-radius: var(--abri-card-radius);
	overflow: visible; /* decos peuvent déborder */
	min-width: 0;
	/* La card remplit exactement la cellule grid (width 100% × height 100%).
	   Comme la grid row est 1fr et identique pour toutes les slides, toutes les cards
	   ont automatiquement les mêmes dimensions. Pas besoin d'aspect-ratio (qui causait
	   un bug Firefox de calcul de hauteur en grid + max-height). */
	width: 100%;
	height: 100%;
}
.abri-slider__image::before {
	/* Crée le fond blanc + ombre du card sans clipper les decos */
	content: "";
	position: absolute;
	inset: 0;
	background: #fff;
	border-radius: var(--abri-card-radius);
	box-shadow: var(--abri-shadow);
	z-index: 0;
}
/* Image fill — couvre 3 cas :
   1. <img class="abri-slider__img"> direct (pas de picture wrapper)
   2. <picture class="abri-slider__img"><img></picture> (WP Rocket / Imagify WebP)
   3. <picture><img class="abri-slider__img"></picture> (Imagify variant)
   Dans tous les cas, le wrapper ET le <img> à l'intérieur remplissent .abri-slider__image. */
.abri-slider__image > .abri-slider__img,
.abri-slider__image > picture,
.abri-slider__image > .abri-slider__img > img,
.abri-slider__image > picture > img {
	display: block !important;
	position: absolute !important;
	inset: 0 !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	max-height: none !important;
	min-width: 100% !important;
	min-height: 100% !important;
	object-fit: cover !important;
	object-position: center !important;
	aspect-ratio: auto !important;
	border-radius: var(--abri-card-radius) !important;
	z-index: 1;
}

/* ----- Decos (% relative to image card → auto-scale, peuvent déborder) ----- */
.abri-slider__deco {
	position: absolute;
	transform-origin: center;
	pointer-events: none;
	z-index: 5;
	will-change: transform, opacity;
}
.abri-slider__deco img {
	display: block;
	width: 100%;
	height: auto;
	filter: drop-shadow(0 8px 16px rgba(0,0,0,.18));
}
.abri-slider__deco.hide-mobile { /* set by JS / data attr if needed */ }

/* ----- Nav arrows ----- */
.abri-slider__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: clamp(36px, 3vw, 50px);
	height: clamp(36px, 3vw, 50px);
	background: rgba(255,255,255,.85);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,.6);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 4px 12px rgba(0,0,0,.10);
	z-index: 20;
	font-size: clamp(14px, 1.2vw, 20px);
	color: var(--abri-text);
	transition: transform .2s, background .2s;
	font-family: inherit;
	padding: 0;
}
.abri-slider__nav:hover { background: #fff; transform: translateY(-50%) scale(1.05); }
.abri-slider__nav--prev { left: 16px; }
.abri-slider__nav--next { right: 16px; }

/* ----- Bullets ----- */
.abri-slider__bullets {
	position: absolute;
	bottom: 16px;
	right: 16px;
	display: flex;
	gap: 6px;
	background: rgba(255,255,255,.7);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	padding: 7px 11px;
	border-radius: 999px;
	border: 1px solid rgba(255,255,255,.5);
	z-index: 20;
}
.abri-slider__bullet {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: rgba(15,28,20,.25);
	transition: all .25s;
	cursor: pointer;
	border: none;
	padding: 0;
}
.abri-slider__bullet.is-active { width: 22px; border-radius: 4px; background: var(--abri-accent); }

/* ============================================
 * Animations
 * ============================================ */
@keyframes abri-fade-in   { from { opacity: 0; } to { opacity: 1; } }
@keyframes abri-slide-up  { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes abri-slide-down{ from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes abri-slide-left{ from { opacity: 0; transform: translateX(-20px); } to { opacity: 1; transform: translateX(0); } }
@keyframes abri-slide-right{ from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }
@keyframes abri-pop {
	0% { opacity: 0; transform: scale(0); }
	70% { opacity: 1; transform: scale(1.1); }
	100% { opacity: 1; transform: scale(1); }
}
@keyframes abri-stamp {
	0% { opacity: 0; transform: rotate(-50deg) scale(0); }
	70% { opacity: 1; transform: rotate(0deg) scale(1.1); }
	100% { opacity: 1; transform: scale(1); }
}

.is-active .abri-slider__content > * { animation: abri-slide-up .55s cubic-bezier(.2,.8,.2,1) both; }
.is-active .abri-slider__content > *:nth-child(1) { animation-delay: .25s; }
.is-active .abri-slider__content > *:nth-child(2) { animation-delay: .4s; }
.is-active .abri-slider__content > *:nth-child(3) { animation-delay: .55s; }
.is-active .abri-slider__content > *:nth-child(4) { animation-delay: .7s; }
.is-active .abri-slider__content > *:nth-child(5) { animation-delay: .85s; }
.is-active .abri-slider__image { animation: abri-image-in .8s cubic-bezier(.2,.8,.2,1) .15s both; }
@keyframes abri-image-in {
	from { opacity: 0; transform: translateX(20px); }
	to   { opacity: 1; transform: translateX(0); }
}

.is-active .abri-slider__deco {
	animation-fill-mode: both;
	animation-duration: .7s;
	animation-delay: var(--anim-delay, 0ms);
	animation-timing-function: cubic-bezier(.34,1.56,.64,1);
	/* opacity: 1 par défaut — animation gère opacity 0→1 dans les keyframes.
	   Si l'animation foire pour une raison X, la déco reste visible au lieu d'invisible. */
	opacity: 1;
}
.is-active .abri-slider__deco[data-anim-in="fade"]        { animation-name: abri-fade-in; }
.is-active .abri-slider__deco[data-anim-in="slide-up"]    { animation-name: abri-slide-up; }
.is-active .abri-slider__deco[data-anim-in="slide-down"]  { animation-name: abri-slide-down; }
.is-active .abri-slider__deco[data-anim-in="slide-left"]  { animation-name: abri-slide-left; }
.is-active .abri-slider__deco[data-anim-in="slide-right"] { animation-name: abri-slide-right; }
.is-active .abri-slider__deco[data-anim-in="pop"]         { animation-name: abri-pop; }
.is-active .abri-slider__deco[data-anim-in="stamp"]       { animation-name: abri-stamp; }

@keyframes abri-pendulum { 0%,100% { transform: rotate(-2deg); } 50% { transform: rotate(2deg); } }
@keyframes abri-pulse    { 0%,100% { transform: scale(1); } 50% { transform: scale(1.05); } }
@keyframes abri-float    { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }

.is-active .abri-slider__deco[data-anim-loop="pendulum"] { animation: abri-pendulum 3s ease-in-out 3s infinite; }
.is-active .abri-slider__deco[data-anim-loop="pulse"]    { animation: abri-pulse 2.5s ease-in-out 3s infinite; }
.is-active .abri-slider__deco[data-anim-loop="float"]    { animation: abri-float 3s ease-in-out 3s infinite; }

@media (prefers-reduced-motion: reduce) {
	.abri-slider__slide,
	.abri-slider__content > *,
	.abri-slider__image,
	.abri-slider__deco {
		animation: none !important;
		transition: none !important;
		opacity: 1 !important;
	}
}

/* ============================================
 * Container queries — layout adapts to slider width
 * (works whether slider is 380px or 3440px wide)
 * ============================================ */

/* Tablet : layout image-top / text-bottom quand le slider lui-même est < 768px */
@container (max-width: 768px) {
	.abri-slider__viewport { height: 760px; }
	.abri-slider__slide {
		grid-template-columns: 1fr;
		grid-template-rows: 360px 1fr;  /* hauteur fixe pour l'image, le reste pour le texte */
		text-align: center;
	}
	.abri-slider__content { order: 2; align-items: center; height: auto; }
	.abri-slider__pretitle span { border-left: none; padding-left: 0; }
	.abri-slider__metas { justify-content: center; }
	.abri-slider__cta { align-self: center; }
	.abri-slider__image { order: 1; }
}

/* Mobile : encore plus compact */
@container (max-width: 480px) {
	.abri-slider__viewport { height: 580px; }
	.abri-slider__slide {
		grid-template-rows: 240px 1fr;
		gap: 16px;
	}
	.abri-slider__bullets { left: 50%; right: auto; transform: translateX(-50%); bottom: 12px; }
	.abri-slider__deco.hide-mobile { display: none !important; }
	/* Boost décos sur mobile : +30% pour rester visibles malgré la card plus petite */
	.abri-slider__deco img {
		transform: scale(1.3);
		transform-origin: 50% 50%;
	}
}

/* Fallback @media queries pour navigateurs sans support container queries */
@supports not (container-type: inline-size) {
	@media (max-width: 1023px) {
		.abri-slider__viewport { height: 760px; }
		.abri-slider__slide {
			grid-template-columns: 1fr;
			grid-template-rows: 360px 1fr;
			text-align: center;
		}
		.abri-slider__content { order: 2; align-items: center; height: auto; }
		.abri-slider__pretitle span { border-left: none; padding-left: 0; }
		.abri-slider__metas { justify-content: center; }
		.abri-slider__cta { align-self: center; }
		.abri-slider__image { order: 1; }
	}
	@media (max-width: 600px) {
		.abri-slider__viewport { height: 580px; }
		.abri-slider__slide {
			grid-template-rows: 240px 1fr;
			gap: 16px;
		}
		.abri-slider__bullets { left: 50%; right: auto; transform: translateX(-50%); bottom: 12px; }
		.abri-slider__deco.hide-mobile { display: none !important; }
		.abri-slider__deco img {
			transform: scale(1.3);
			transform-origin: 50% 50%;
		}
	}
}
