/**
 * Animations et couleurs SODEFOR
 * Hovers, apparitions au scroll, fonds alternés – cohérents avec la charte (verts, orange).
 */

/* ===== Fonds alternés (verts très légers) ===== */
.section-bg-sodefor {
	background-color: var(--sodefor-green-light);
}
.section-bg-sodefor-strong {
	background-color: var(--sodefor-green-light-strong);
}

/* ===== Titres de section – apparition au scroll ===== */
.section-header-pif2 .section-header-pif2_line--top {
	transition: transform 0.5s ease, opacity 0.5s ease;
}
.section-header-pif2 .section-header-pif2_label {
	transition: color 0.3s ease, transform 0.4s ease;
}
.section-header-pif2 .section-header-pif2_title {
	transition: color 0.3s ease;
}
.section-header-pif2 .section-header-pif2_dot {
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.section-header-pif2:hover .section-header-pif2_dot {
	transform: scale(1.1);
	box-shadow: inset 0 0 0 2px #fff, inset 0 0 0 4px var(--sodefor-green-accent), 0 0 0 2px rgba(var(--sodefor-green-rgb), 0.2);
}

/* ===== Boutons principaux – hover plus vivant ===== */
.theme-btn.btn-style-one {
	transition: transform 0.25s ease, box-shadow 0.3s ease, background-color 0.3s ease;
}
.theme-btn.btn-style-one:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(var(--sodefor-green-rgb), 0.35);
}
.theme-btn.btn-style-two {
	transition: transform 0.25s ease, border-color 0.3s ease, color 0.3s ease;
}
.theme-btn.btn-style-two:hover {
	transform: translateY(-2px);
	border-color: var(--sodefor-green-accent);
	color: var(--sodefor-green-accent);
	box-shadow: 0 4px 16px rgba(var(--sodefor-green-rgb), 0.2);
}

/* ===== Cartes services / composantes – hover renforcé ===== */
.service-block_three-inner {
	transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.3s ease;
}
.service-block_three-inner:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 32px rgba(0,0,0,0.1), 0 0 0 1px rgba(var(--sodefor-green-rgb), 0.15);
}
.service-block_three-inner .service-block_three-icon,
.service-block_three-inner .service-block_three-number {
	transition: color 0.3s ease, transform 0.3s ease;
}
.service-block_three-inner:hover .service-block_three-icon {
	color: var(--sodefor-green-accent);
}
.service-block_three-inner:hover .service-block_three-number {
	color: var(--sodefor-green-accent);
}

.composantes-card {
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.composantes-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 16px 40px rgba(0,0,0,0.15), 0 0 0 1px rgba(var(--sodefor-green-rgb), 0.2);
}

.about-block_two-inner {
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.about-block_two-inner:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(var(--sodefor-green-rgb), 0.12);
}

/* ===== Blocs actualités / news ===== */
.news-block_two-inner {
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.news-block_two-inner:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 28px rgba(0,0,0,0.1), 0 0 0 1px rgba(var(--sodefor-green-rgb), 0.1);
}
.news-block_two-more:hover {
	color: var(--sodefor-green-accent);
}

/* ===== Liens – underline animé vert ===== */
.section-header-pif2_text a,
.sec-title_text a,
.section-header-pif2_text a {
	color: var(--sodefor-green-accent);
	text-decoration: none;
	background-image: linear-gradient(currentColor, currentColor);
	background-size: 0 2px;
	background-repeat: no-repeat;
	background-position: left bottom;
	transition: color 0.25s ease, background-size 0.3s ease;
}
.section-header-pif2_text a:hover,
.sec-title_text a:hover {
	color: var(--main-color);
	background-size: 100% 2px;
}

/* ===== Statistiques / compteurs – léger accent au hover ===== */
.counter-block_two-inner {
	transition: transform 0.3s ease, color 0.3s ease;
}
.counter-block_two-inner:hover {
	transform: scale(1.02);
}
.counter-block_two-inner .counter-block_two-icon,
.counter-block_two-inner .counter-block_two-count {
	transition: color 0.3s ease;
}
.counter-block_two-inner:hover .counter-block_two-icon,
.counter-block_two-inner:hover .counter-block_two-count {
	color: var(--sodefor-green-accent);
}

/* ===== Animation douce d’entrée pour les titres (si WOW présent) ===== */
.wow.sodefor-title .section-header-pif2_label {
	animation-duration: 0.6s;
}
.wow.sodefor-title .section-header-pif2_title {
	animation-duration: 0.7s;
}

/* ===== Cartes infos centre de gestion ===== */
.center-detail_info-grid{
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
	margin-top: 30px;
	margin-bottom: 10px;
}

.center-detail_info-card{
	background: #f7fbf5;
	border-radius: 16px;
	padding: 16px 18px;
	box-shadow: 0 8px 24px rgba(0,0,0,0.05);
	border: 1px solid rgba(0,0,0,0.03);
}

.center-detail_info-label{
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--color-two);
	margin-bottom: 8px;
}

.center-detail_info-label .icon{
	font-size: 16px;
	color: var(--main-color);
}

.center-detail_info-value{
	margin: 0;
	font-size: 15px;
	line-height: 1.5;
	color: #444;
}

.center-detail_info-value a{
	color: var(--color-two);
	text-decoration: none;
	border-bottom: 1px dashed rgba(var(--color-two-rgb), 0.7);
}

.center-detail_info-value a:hover{
	color: var(--main-color);
	border-bottom-color: rgba(var(--color-two-rgb), 1);
}

/* ============================================================
   ANIMATIONS POUR RENDRE LE SITE PLUS ATTRACTIF
   ============================================================ */

/* ----- 1. Hero / Slider : apparition en cascade au changement de slide ----- */
.slider-three .swiper-slide .slider-three_title {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.6s ease 0.1s, transform 0.6s ease 0.1s;
}
.slider-three .swiper-slide .slider-three_heading {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.65s ease 0.2s, transform 0.65s ease 0.2s;
}
.slider-three .swiper-slide .slider-three_text {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s ease 0.35s, transform 0.6s ease 0.35s;
}
.slider-three .swiper-slide .slider-three_button {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.5s ease 0.5s, transform 0.5s ease 0.5s;
}
.slider-three .swiper-slide-active .slider-three_title,
.slider-three .swiper-slide-active .slider-three_heading,
.slider-three .swiper-slide-active .slider-three_text,
.slider-three .swiper-slide-active .slider-three_button {
	opacity: 1;
	transform: translateY(0);
}

/* ----- 2. Bouton « En savoir plus » du slider : flèche qui avance au survol ----- */
.slider-three_btn-ensavoir {
	transition: transform 0.25s ease, box-shadow 0.3s ease;
}
.slider-three_btn-ensavoir:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(var(--sodefor-green-rgb), 0.4);
}
.slider-three_btn-arrow {
	display: inline-block;
	transition: transform 0.25s ease;
}
.slider-three_btn-ensavoir:hover .slider-three_btn-arrow {
	transform: translate(4px, -4px);
}

/* ----- 3. Listes à puces : apparition décalée ----- */
.about-two_list li,
.customer-one_list li {
	opacity: 0;
	transform: translateX(-12px);
	animation: sodefor-list-item-in 0.5s ease forwards;
}
.about-two_list li:nth-child(1), .customer-one_list li:nth-child(1) { animation-delay: 0.05s; }
.about-two_list li:nth-child(2), .customer-one_list li:nth-child(2) { animation-delay: 0.15s; }
.about-two_list li:nth-child(3), .customer-one_list li:nth-child(3) { animation-delay: 0.25s; }
.about-two_list li:nth-child(4), .customer-one_list li:nth-child(4) { animation-delay: 0.35s; }
.about-two_list li:nth-child(5), .customer-one_list li:nth-child(5) { animation-delay: 0.45s; }
.about-two_list li:nth-child(6), .customer-one_list li:nth-child(6) { animation-delay: 0.55s; }
@keyframes sodefor-list-item-in {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* ----- 4. Cartes témoignages : soulèvement + bordure verte au survol ----- */
.testimonial-block_two-inner {
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.testimonial-block_two-inner:hover {
	transform: translateY(-6px);
	box-shadow: 0 14px 36px rgba(0,0,0,0.12), 0 0 0 1px rgba(var(--sodefor-green-rgb), 0.15);
}
.testimonial-block_two-icon {
	transition: transform 0.3s ease, color 0.3s ease;
}
.testimonial-block_two-inner:hover .testimonial-block_two-icon {
	transform: scale(1.08);
	color: var(--sodefor-green-accent);
}

/* ----- 5. Logos partenaires : gris → couleur + léger zoom ----- */
.client-image img {
	filter: grayscale(0.85);
	transition: filter 0.4s ease, transform 0.35s ease;
}
.client-image:hover img {
	filter: grayscale(0);
	transform: scale(1.08);
}

/* ----- 6. Lignes décoratives titres / composantes : léger scale au survol ----- */
.composantes-header_line--top,
.composantes-header_line--bottom {
	transition: transform 0.35s ease;
}
.composantes-header:hover .composantes-header_line--top,
.composantes-header:hover .composantes-header_line--bottom {
	transform: scaleY(1.1);
}

/* ----- 7. Images des cartes : zoom fluide au survol ----- */
.composantes-card_bg,
.news-block_two-image {
	overflow: hidden;
}
.composantes-card_bg,
.news-block_two-image img {
	transition: transform 0.5s ease;
}
.composantes-card:hover .composantes-card_bg,
.news-block_two-inner:hover .news-block_two-image img {
	transform: scale(1.08);
}

/* ----- 8. Bullets de pagination : pulse sur l’actif ----- */
.composantes-pagination-bullet,
.swiper-pagination-bullet {
	transition: transform 0.25s ease, background-color 0.25s ease;
}
.composantes-pagination-bullet:hover,
.swiper-pagination-bullet:hover {
	transform: scale(1.25);
}
.swiper-pagination-bullet-active,
.composantes-pagination-bullet-active {
	animation: sodefor-bullet-pulse 2s ease-in-out infinite;
}
@keyframes sodefor-bullet-pulse {
	0%, 100% { opacity: 1; transform: scale(1.2); }
	50% { opacity: 0.85; transform: scale(1.35); }
}

/* ----- 9. Barres de compétence : remplissage animé ----- */
.skill-bar .bar.progress-line {
	transition: width 1.2s ease-out;
}

/* ----- 10. Icônes de liste : rebond + vert au survol ----- */
.about-two_list li i,
.customer-one_list li i {
	transition: transform 0.25s ease, color 0.3s ease;
}
.about-two_list li:hover i,
.customer-one_list li:hover i {
	transform: scale(1.15);
	color: var(--sodefor-green-accent);
}
