body{font-family:var(--global-font-family);overflow-y:scroll;background-color:var(--base-white-color)}
body,html{font-family:var(--global-font-family);height:100%;overflow-x:hidden}
h1{font-family:var(--global-font-family-titre);margin-bottom:1rem;color:var(--base-noir-color);font-size:var(--font-size-h1);line-height:1.2}
h2{font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);margin-bottom:1rem;color:var(--base-white-color)}
h3{font-family:var(--global-font-family-titre);font-size:var(--font-size-h3);margin-bottom:1rem;color:var(--base-noir-color)}
@keyframes slideIn{
from{transform:translateY(100px);opacity:0}
to{transform:translateY(0);opacity:1}
}
.main-content{opacity:0;transform:translateY(100px);transition:opacity 3s ease-out,transform 3s ease-out}
.main-content.visible{opacity:1;transform:translateY(0)}
.star{position:absolute;background-color:#fff;border-radius:50%}
.container{max-width:1200px;margin:0 auto;padding:2rem}
@media (max-width:968px){
h1{font-size:var(--font-size-h1-mobile)}
.quote,.subtitle{font-size:var(--font-size-h3-mobile)}
.description{font-size:var(--font-size-normal-mobile)}
}
.box{padding:4rem 2rem;background-color:var(--base-beige-color);margin:0 auto}
.associations{max-width:1200px;margin:0 auto}
.associations h2{font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);color:var(--base-rouge-color);text-align:center;margin-bottom:3rem;position:relative}
.associations h2::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:100px;height:3px;background:var(--base-rouge-color);border-radius:2px}
.associations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;justify-items:center}
.association{background:var(--base-white-color);padding:2rem;border-radius:15px;box-shadow:0 8px 25px rgba(0,0,0,.08);text-align:center;transition:.3s;cursor:pointer;width:100%;max-width:300px}
.association:hover{transform:translateY(-5px);box-shadow:0 12px 30px rgba(0,0,0,.12)}
.association img{width:150px;height:150px;object-fit:contain;margin-bottom:1.5rem}
.association h3{font-family:var(--global-font-family-titre);font-size:var(--font-size-h3);color:var(--base-rouge-color);margin-bottom:1rem}
.association p{font-size:var(--font-size-normal);color:var(--base-noir-color);line-height:1.5}
.modal{display:none;position:fixed;z-index:1;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:rgba(0,0,0,.4)}
.modal-content{background-color:#fefefe;margin:15% auto;padding:2rem;border:1px solid #888;width:80%;max-width:600px;border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.2)}
.close{color:#aaa;float:right;font-size:28px;font-weight:700;transition:color .3s}
.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer}
@media (max-width:768px){
.box{padding:1rem;width:95%}
.associations-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
h1{font-size:var(--font-size-h1-mobile)}
h2{font-size:var(--font-size-h2-mobile)}
h3{font-size:var(--font-size-h3-mobile)}
.content,p{font-size:var(--font-size-normal-mobile)}
.agenda-button,.button,.parallax-button{font-size:var(--font-size-button-mobile)}
}
.parallax{background-image:url(../images/IMG_2768.JPEG);min-height:800px;background-attachment:fixed;background-position:center;background-repeat:no-repeat;background-size:cover;position:relative;display:flex;align-items:center;justify-content:center;margin-top:100px}
.parallax-content{color:#fff;text-align:center;background:#000000c5;padding:80px;margin-left:100px;margin-right:100px;border-radius:10px}
.parallax-content h2{font-family:var(--global-font-family-titre);color:var(--base-white-color);font-size:var(--font-size-h2);margin-bottom:20px}
.parallax-content p{font-size:var(--font-size-normal);margin-bottom:20px}
.parallax-content .parallax-button{background-color:var(--base-rouge-color);color:var(--base-white-color);padding:10px 20px;border-radius:5px;text-decoration:none;font-size:var(--font-size-button);transition:background .3s}
.parallax-content .parallax-button:hover{background-color:#000;transform:translateY(-5px);box-shadow:0 4px 10px rgba(0,0,0,.2)}
.content-section{padding:50px 20px;background-color:#fff}
.key-stats{padding:4rem 2rem;background-color:var(--base-beige-color)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem;text-align:center}
.stat-item{padding:2rem;background:var(--base-white-color);border-radius:15px;box-shadow:0 8px 25px rgba(0,0,0,.08);transition:transform .3s}
.stat-item:hover{transform:translateY(-10px)}
.stat-item i{font-size:3rem;color:var(--base-rouge-color);margin-bottom:1rem}
.stat-item h3{font-size:2.5rem;color:var(--base-rouge-color);margin:1rem 0}
.stat-item p{font-size:var(--font-size-normal);color:var(--base-noir-color)}
.testimonial-section{margin-bottom:60px;padding:40px}
.testimonial:hover{transform:translateY(-5px);box-shadow:0 4px 10px rgba(0,0,0,.2)}
.testimonial-section h2{color:var(--base-rouge-color);font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);margin-bottom:40px}
.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.testimonial{background-color:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 10px rgba(0,0,0,.1)}
.testimonial-header{display:flex;align-items:center;margin-bottom:15px}
.avatar{width:50px;height:50px;border-radius:50%;margin-right:15px;object-fit:cover}
.user-info h3{margin:0;font-size:var(--font-size-h3);font-weight:500}
.user-info p{margin:5px 0 0;font-size:var(--font-size-normal);color:var(--base-rouge-color)}
.stars{color:#710000;font-size:20px;margin-bottom:10px}
.content{font-size:var(--font-size-normal);line-height:1.6}
.minimal-accent{border-left:5px solid #710000;background-color:#f9f9f9;box-shadow:none}
.magazine-style{column-count:1}
.monthly-event{padding:4rem 2rem;background-color:var(--base-white-color)}
.event-container{max-width:1200px;margin:0 auto}
.event-container h2{font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);color:var(--base-rouge-color);text-align:center;margin-bottom:3rem;position:relative}
.event-container h2::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:100px;height:3px;background:var(--base-rouge-color);border-radius:2px}
.event-card{background:var(--base-white-color);border:2px solid var(--base-rouge-color);border-radius:15px;padding:2rem;display:grid;grid-template-columns:auto 1fr auto;gap:2rem;align-items:center;margin-bottom:2rem;box-shadow:0 8px 25px rgba(0,0,0,.08)}
.event-date{background:var(--base-rouge-color);color:var(--base-white-color);padding:1.5rem;border-radius:10px;text-align:center;min-width:120px}
.event-day{font-size:2.5rem;font-weight:700;display:block;line-height:1}
.event-month{font-size:1.2rem;text-transform:uppercase}
.event-details{flex-grow:1}
.event-details h3{font-family:var(--global-font-family-titre);font-size:var(--font-size-h3);color:var(--base-rouge-color);margin-bottom:1rem}
.event-details p{font-size:var(--font-size-normal);color:var(--base-noir-color);margin-bottom:.5rem}
.event-time{color:var(--base-rouge-color);font-weight:700}
.event-image{width:200px;height:200px;border-radius:10px;overflow:hidden}
.event-image img{width:100%;height:100%;object-fit:cover}
.agenda-text{text-align:center;font-size:var(--font-size-normal);color:var(--base-noir-color);margin:2rem 0}
.agenda-button{display:block;width:fit-content;margin:0 auto;padding:1rem 2rem;background:var(--base-rouge-color);color:var(--base-white-color);text-decoration:none;border-radius:10px;font-size:var(--font-size-button);transition:.3s}
.agenda-button:hover{background:var(--base-noir-color);transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.15)}
.quiz-container{max-width:1200px;margin:4rem auto;padding:2rem;background:var(--base-white-color);border-radius:15px;box-shadow:0 8px 25px rgba(0,0,0,.08)}
.quiz-title{font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);color:var(--base-rouge-color);text-align:center;margin-bottom:3rem;position:relative}
.quiz-title::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:100px;height:3px;background:var(--base-rouge-color);border-radius:2px}
#progress{height:4px;background:#eee;margin-bottom:2rem;border-radius:2px;overflow:hidden}
#progress::before{content:'';display:block;height:100%;background:var(--base-rouge-color);width:0;transition:width .3s}
.question-image{width:100%;height:400px;object-fit:cover;border-radius:10px;margin-bottom:2rem}
.options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}
.options button{padding:1rem;border:2px solid var(--base-rouge-color);border-radius:10px;background:var(--base-white-color);color:var(--base-rouge-color);font-size:var(--font-size-normal);cursor:pointer;transition:.3s}
.options button:hover{background:var(--base-rouge-color);color:var(--base-white-color);transform:translateY(-2px)}
#next-btn{display:block;width:fit-content;margin:2rem auto;padding:1rem 2rem;background:var(--base-rouge-color);color:var(--base-white-color);border:none;border-radius:10px;font-size:var(--font-size-button);cursor:pointer;transition:.3s}
#next-btn:hover{background:var(--base-noir-color);transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.15)}
#feedback{text-align:center;margin:1rem 0;font-size:var(--font-size-normal);color:var(--base-rouge-color);font-weight:700}
#result{text-align:center;margin-top:2rem;font-size:var(--font-size-h3);color:var(--base-rouge-color)}
@media (max-width:768px){
.associations-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.event-card{grid-template-columns:1fr;text-align:center}
.event-date,.event-image{margin:0 auto}
.quiz-container{padding:1rem}
.question-image{height:300px}
.options{grid-template-columns:1fr}
}
@media (max-width:480px){
.box{padding:2rem 1rem}
.association img{width:120px;height:120px}
.event-image{width:150px;height:150px}
}
.scroll-indicator{position:fixed;bottom:2rem;right:2rem;width:50px;height:50px;background:#fff;border-radius:8px;cursor:pointer;z-index:999;box-shadow:0 2px 10px rgba(0,0,0,.1);transition:var(--transition);opacity:1;display:flex;align-items:center;justify-content:center;overflow:hidden}
.scroll-indicator:hover{transform:scale(1.05);background-color:var(--light-color)}
.scroll-indicator.hidden{opacity:0;pointer-events:none}
.scroll-indicator svg{width:24px;height:24px;transition:var(--transition)}
.scroll-indicator.up svg{transform:rotate(180deg)}
.scroll-indicator path{fill:var(--primary-color)}
.gallery-section{padding:4rem 2rem;background-color:var(--base-beige-color)}
.gallery-section h2{text-align:center;color:var(--base-rouge-color);margin-bottom:2rem;font-family:var(--global-font-family-titre);font-size:var(--font-size-h2)}
.gallery-filters{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}
.filter-btn{padding:.8rem 1.5rem;border:2px solid var(--base-rouge-color);border-radius:30px;background:0 0;color:var(--base-rouge-color);cursor:pointer;transition:.3s;font-size:var(--font-size-normal)}
.filter-btn.active,.filter-btn:hover{background:var(--base-rouge-color);color:var(--base-white-color)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.gallery-item{position:relative;border-radius:15px;overflow:hidden;aspect-ratio:1;cursor:pointer;transition:transform .3s}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.gallery-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:2rem;color:var(--base-white-color);transform:translateY(100%);transition:transform .3s}
.gallery-item:hover .gallery-overlay{transform:translateY(0)}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-overlay h3{color:var(--base-white-color);margin-bottom:.5rem;font-size:var(--font-size-h3)}
.gallery-overlay p{font-size:var(--font-size-normal);opacity:.9}
@media (max-width:768px){
.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.filter-btn{padding:.6rem 1.2rem;font-size:var(--font-size-normal-mobile)}
.gallery-overlay h3{font-size:var(--font-size-h3-mobile)}
.gallery-overlay p{font-size:var(--font-size-normal-mobile)}
}
.gallery-pagination{display:flex;justify-content:center;align-items:center;gap:2rem;margin-top:2rem;padding:1rem}
.pagination-btn{background:0 0;border:2px solid var(--base-rouge-color);color:var(--base-rouge-color);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.3s}
.pagination-btn:hover:not(:disabled){background:var(--base-rouge-color);color:var(--base-white-color);transform:scale(1.1)}
.pagination-btn:disabled{opacity:.5;cursor:not-allowed;border-color:#ccc;color:#ccc}
.page-info{font-size:var(--font-size-normal);color:var(--base-rouge-color);font-weight:500}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding:1rem}
@media (max-width:768px){
.gallery-grid{grid-template-columns:repeat(2,1fr)}
}
.faq-section{padding:4rem 2rem;background-color:var(--base-beige-color)}
.faq-section h2{text-align:center;color:var(--base-rouge-color);margin-bottom:3rem;font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);position:relative}
.faq-section h2::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:100px;height:3px;background:var(--base-rouge-color);border-radius:2px}
.faq-grid{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}
.faq-item{background:var(--base-white-color);border-radius:10px;overflow:hidden;box-shadow:0 4px 15px rgba(0,0,0,.1)}
.accordion{background-color:var(--base-white-color);color:var(--base-rouge-color);cursor:pointer;padding:1.5rem;width:100%;border:none;text-align:left;outline:0;font-size:var(--font-size-normal);font-weight:500;transition:.4s;display:flex;justify-content:space-between;align-items:center;border-left:4px solid transparent}
.accordion.active,.accordion:hover{background-color:var(--base-beige-color);border-left:4px solid var(--base-rouge-color)}
.accordion i{transition:transform .3s;color:var(--base-rouge-color)}
.panel{padding:0 1.5rem;background-color:var(--base-white-color);max-height:0;overflow:hidden;transition:max-height .3s ease-out}
.panel p{margin:1.5rem 0;color:var(--base-noir-color);font-size:var(--font-size-normal);line-height:1.6}
@media (max-width:768px){
.faq-section{padding:2rem 1rem}
.accordion{font-size:var(--font-size-normal-mobile);padding:1.2rem}
.panel p{font-size:var(--font-size-normal-mobile)}
}
.timeline-section{padding:4rem 2rem;background-color:var(--base-beige-color)}
.timeline-section h2{text-align:center;color:var(--base-rouge-color);margin-bottom:3rem;font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);position:relative}
.timeline-section h2::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:100px;height:3px;background:var(--base-rouge-color);border-radius:2px}
.timeline{position:relative;max-width:1200px;margin:0 auto;padding:2rem 0}
.timeline::after{content:'';position:absolute;width:4px;background-color:var(--base-rouge-color);top:0;bottom:0;left:50%;transform:translateX(-50%);border-radius:2px}
.timeline-item{padding:1rem;width:50%;position:relative;opacity:0;transform:translateX(-50px);transition:.8s}
.timeline-item.animate{opacity:1;transform:translateX(0)}
.timeline-item.right{left:50%;transform:translateX(50px)}
.timeline-item.right.animate{transform:translateX(0)}
.timeline-content{padding:2rem;background:var(--base-white-color);border-radius:15px;box-shadow:0 4px 15px rgba(0,0,0,.1);position:relative}
.timeline-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.timeline-date{color:var(--base-white-color);background:var(--base-rouge-color);display:inline-block;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-family:var(--global-font-family);font-size:var(--font-size-normal)}
.timeline-icon{width:50px;height:50px;background:var(--base-rouge-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--base-white-color);font-size:1.5rem;transition:.3s}
.timeline-details h3{color:var(--base-rouge-color);margin:1rem 0;font-size:var(--font-size-h3);font-family:var(--global-font-family-titre)}
.timeline-details p{color:var(--base-noir-color);margin-bottom:1rem;font-size:var(--font-size-normal);line-height:1.6}
.timeline-details ul{list-style-type:none;padding-left:0;margin-bottom:1rem}
.timeline-details li{color:var(--base-noir-color);margin-bottom:.5rem;padding-left:1.5rem;position:relative;font-size:var(--font-size-normal)}
.timeline-details li::before{content:'•';color:var(--base-rouge-color);position:absolute;left:0}
.duration{display:inline-flex;align-items:center;gap:.5rem;color:var(--base-rouge-color);font-weight:700;font-style:italic;font-size:var(--font-size-normal)}
@media (max-width:768px){
.timeline::after{left:31px}
.timeline-item{width:100%;padding-left:70px;padding-right:25px}
.timeline-item.right{left:0}
.timeline-content{padding:1.5rem}
.timeline-header{flex-direction:row;align-items:center;margin-bottom:1rem}
.timeline-date{font-size:var(--font-size-normal-mobile);padding:.4rem .8rem}
.timeline-icon{width:40px;height:40px;font-size:1.2rem;position:absolute;left:-55px;top:50%;transform:translateY(-50%)}
.timeline-details h3{font-size:var(--font-size-h3-mobile)}
.duration,.timeline-details li,.timeline-details p{font-size:var(--font-size-normal-mobile)}
.timeline-item.mobile-view{transform:none!important;opacity:1}
.timeline-item.animate{transform:none!important}
}
@media (max-width:480px){
.gallery-grid{grid-template-columns:1fr}
.timeline-section{padding:2rem 1rem}
.timeline-content{padding:1rem}
.timeline-item{padding-left:60px;padding-right:15px}
.timeline::after{left:21px}
.timeline-icon{left:-45px;width:35px;height:35px;font-size:1rem}
.timeline-date{padding:.3rem .6rem;font-size:.9rem}
}
.newsletter-section{padding:4rem 2rem;background:var(--base-beige-color)}
.newsletter-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative}
.newsletter-text h2{color:var(--base-rouge-color);font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);margin-bottom:1.5rem}
.newsletter-text p{color:var(--base-noir-color);font-size:var(--font-size-normal);margin-bottom:2rem}
.newsletter-benefits{list-style:none;padding:0}
.newsletter-benefits li{display:flex;align-items:center;margin-bottom:1rem;color:var(--base-noir-color);font-size:var(--font-size-normal)}
.newsletter-benefits li i{color:var(--base-rouge-color);margin-right:1rem;font-size:1.2rem}
.newsletter-form{background:var(--base-white-color);padding:2rem;border-radius:15px;box-shadow:0 8px 25px rgba(0,0,0,.08)}
.form-group{margin-bottom:1.5rem;position:relative}
.form-group input[type=email],.form-group input[type=text]{width:100%;padding:1rem 1rem 1rem 3rem;border:2px solid transparent;border-radius:8px;background:var(--base-beige-color);font-size:var(--font-size-normal);transition:.3s}
.form-group input:focus{border-color:var(--base-rouge-color);outline:0;background:var(--base-white-color)}
.form-group label{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--base-rouge-color)}
.checkbox-group{display:flex;align-items:flex-start;gap:.5rem}
.checkbox-group input[type=checkbox]{margin-top:.3rem}
.checkbox-group label{position:static;transform:none;font-size:.9rem;color:var(--base-noir-color);line-height:1.4}
.submit-btn{width:100%;padding:1rem;background:var(--base-rouge-color);color:var(--base-white-color);border:none;border-radius:8px;font-size:var(--font-size-button);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:1rem;transition:.3s;position:relative;overflow:hidden}
.submit-btn:hover{background:var(--base-noir-color);transform:translateY(-2px)}
.submit-btn.loading{pointer-events:none}
.submit-btn.loading::after{content:'';position:absolute;width:20px;height:20px;border:2px solid transparent;border-top-color:var(--base-white-color);border-radius:50%;animation:1s linear infinite spin}
.submit-btn.loading i,.submit-btn.loading span{opacity:0}
@keyframes spin{
to{transform:rotate(360deg)}
}
.newsletter-notification{position:absolute;bottom:-60px;left:50%;transform:translateX(-50%);padding:1rem 2rem;border-radius:8px;font-size:var(--font-size-normal);animation:.3s forwards slideUp}
.newsletter-notification.success{background:#4caf50;color:#fff}
.newsletter-notification.error{background:#f44336;color:#fff}
.newsletter-notification.fade-out{animation:.3s forwards slideDown}
@keyframes slideUp{
from{transform:translate(-50%,100%);opacity:0}
to{transform:translate(-50%,0);opacity:1}
}
@keyframes slideDown{
from{transform:translate(-50%,0);opacity:1}
to{transform:translate(-50%,100%);opacity:0}
}
@media (max-width:768px){
.newsletter-content{grid-template-columns:1fr;gap:2rem}
.newsletter-text{text-align:center}
.newsletter-benefits li{justify-content:center}
.newsletter-form{padding:1.5rem}
.newsletter-text h2{font-size:var(--font-size-h2-mobile)}
.newsletter-benefits li,.newsletter-text p{font-size:var(--font-size-normal-mobile)}
}
@media (max-width:480px){
.newsletter-section{padding:2rem 1rem}
.form-group input[type=email],.form-group input[type=text]{font-size:var(--font-size-normal-mobile)}
.checkbox-group label{font-size:.8rem}
}
.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out;will-change:opacity,transform}
.animate-visible{opacity:1!important;transform:translateY(0)!important}
.key-stats.animate-on-scroll{transform:translateY(50px)}
.associations-component.animate-on-scroll{transform:translateX(-50px)}
.parallax-component.animate-on-scroll{transform:scale(.95)}
.monthly-event-component.animate-on-scroll{transform:translateX(50px)}
.testimonials-carousel-component.animate-on-scroll{transform:translateY(30px) scale(.95)}
.quiz-redirect.animate-on-scroll{transform:translateY(40px)}
.bubble-quote.animate-on-scroll{transform:translateY(30px) rotate(-2deg)}
.gallery-component.animate-on-scroll{transform:translateY(40px) scale(.98)}
.timeline-component.animate-on-scroll{transform:translateX(-40px)}
.faq-component.animate-on-scroll{transform:translateY(35px)}
.newsletter-component.animate-on-scroll{transform:translateY(45px) scale(.97)}
.animate-on-scroll .association,.animate-on-scroll .faq-item,.animate-on-scroll .gallery-item,.animate-on-scroll .stat-item,.animate-on-scroll .timeline-item{opacity:0;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out;will-change:opacity,transform}
.animate-visible .association,.animate-visible .faq-item,.animate-visible .gallery-item,.animate-visible .stat-item,.animate-visible .timeline-item{opacity:1;transform:translateY(0)}
.animate-visible .association:first-child,.animate-visible .faq-item:first-child,.animate-visible .gallery-item:first-child,.animate-visible .stat-item:first-child,.animate-visible .timeline-item:first-child{transition-delay:0.1s}
.animate-visible .association:nth-child(2),.animate-visible .faq-item:nth-child(2),.animate-visible .gallery-item:nth-child(2),.animate-visible .stat-item:nth-child(2),.animate-visible .timeline-item:nth-child(2){transition-delay:0.2s}
.animate-visible .association:nth-child(3),.animate-visible .faq-item:nth-child(3),.animate-visible .gallery-item:nth-child(3),.animate-visible .stat-item:nth-child(3),.animate-visible .timeline-item:nth-child(3){transition-delay:0.3s}
.animate-visible .association:nth-child(n+4),.animate-visible .faq-item:nth-child(n+4),.animate-visible .gallery-item:nth-child(n+4),.animate-visible .stat-item:nth-child(n+4),.animate-visible .timeline-item:nth-child(n+4){transition-delay:0.4s}
@media (prefers-reduced-motion:reduce){
.animate-on-scroll,.animate-on-scroll .association,.animate-on-scroll .faq-item,.animate-on-scroll .gallery-item,.animate-on-scroll .stat-item,.animate-on-scroll .timeline-item{transition:none!important;opacity:1!important;transform:none!important}
}
.hidden{opacity:0;filter:blur(5px);transform:translateY(100px);transition:1s cubic-bezier(.4, 0, .2, 1)}
.fade-in{opacity:1;filter:blur(0);transform:translateY(0)}
.key-stats.hidden{transform:translateX(-100px)}
.social-component.hidden{transform:scale(.8)}
.associations-component.hidden{transform:translateX(100px)}
.parallax-component.hidden{transform:scale(.9)}
.monthly-event-component.hidden{transform:translateY(150px)}
.testimonials-carousel-component.hidden{transform:translateX(-100px)}
.quiz-redirect.hidden{transform:scale(.7)}
.bubble-quote.hidden{transform:translateY(100px) rotate(-10deg)}
.gallery-component.hidden{transform:translateY(100px) scale(.9)}
.timeline-component.hidden{transform:translateX(-150px)}
.faq-component.hidden{transform:translateY(100px)}
.newsletter-component.hidden{transform:scale(.8)}
.fade-in .association,.fade-in .faq-item,.fade-in .gallery-item,.fade-in .stat-item,.fade-in .timeline-item{animation:.6s forwards fadeInUp;opacity:0}
@keyframes fadeInUp{
from{opacity:0;transform:translateY(30px)}
to{opacity:1;transform:translateY(0)}
}
.fade-in .association:first-child,.fade-in .faq-item:first-child,.fade-in .gallery-item:first-child,.fade-in .stat-item:first-child,.fade-in .timeline-item:first-child{animation-delay:.2s}
.fade-in .association:nth-child(2),.fade-in .faq-item:nth-child(2),.fade-in .gallery-item:nth-child(2),.fade-in .stat-item:nth-child(2),.fade-in .timeline-item:nth-child(2){animation-delay:.4s}
.fade-in .association:nth-child(3),.fade-in .faq-item:nth-child(3),.fade-in .gallery-item:nth-child(3),.fade-in .stat-item:nth-child(3),.fade-in .timeline-item:nth-child(3){animation-delay:.6s}
@media (prefers-reduced-motion:reduce){
.hidden{transition:none;opacity:1;filter:blur(0);transform:none}
.fade-in,.fade-in .association,.fade-in .faq-item,.fade-in .gallery-item,.fade-in .stat-item,.fade-in .timeline-item{animation:none;opacity:1;transform:none}
}

.back-to-top{display:none;position:fixed;bottom:20px;right:20px;background-color:#710000;color:#fff;width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;z-index:999;transition:background-color .3s}
.back-to-top:hover{background-color:#000}
.search-container{position:fixed;top:20px;right:20px;z-index:1000;display:flex;gap:.5rem}
.search-container input{padding:.5rem;border:1px solid #ddd;border-radius:4px;width:200px}
.search-container button{background-color:#710000;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer;transition:background-color .3s}
.search-container button:hover{background-color:#000}
.contact-cta{padding:4rem 0;background:var(--base-beige-color);margin:2rem 0}
.contact-cta .container{max-width:1200px;margin:0 auto;padding:0 1rem}
.cta-content{text-align:center;max-width:800px;margin:0 auto}
.cta-content h2{color:var(--base-rouge-color);font-size:var(--font-size-h2);margin-bottom:1.5rem;font-family:var(--global-font-family-titre)}
.cta-content p{color:var(--base-noir-color);font-size:var(--font-size-normal);font-family:var(--global-font-family);line-height:1.6;margin-bottom:2rem}
.cta-buttons{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}
.cta-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:50px;font-size:var(--font-size-button);font-family:var(--global-font-family);font-weight:600;text-decoration:none;transition:.3s}
.cta-button.primary{background-color:var(--base-rouge-color);color:var(--base-white-color);border:2px solid var(--base-rouge-color)}
.cta-button.primary:hover{background-color:var(--base-noir-color);border-color:var(--base-noir-color);transform:translateY(-2px)}
.cta-button.secondary{background-color:transparent;color:var(--base-rouge-color);border:2px solid var(--base-rouge-color)}
.cta-button.secondary:hover{background-color:var(--base-rouge-color);color:var(--base-white-color);transform:translateY(-2px)}
.cta-button i{font-size:1.2rem}
@media (max-width:768px){
.contact-cta{padding:3rem 0}
.cta-content h2{font-size:var(--font-size-h2-mobile)}
.cta-content p{font-size:var(--font-size-normal-mobile)}
.cta-buttons{flex-direction:column;gap:1rem}
.cta-button{width:100%;justify-content:center;font-size:var(--font-size-button-mobile)}
}
.services-section{padding:6rem 0;background-color:var(--base-beige-color);position:relative;overflow:hidden}
.services-cta{text-align:center;max-width:1000px;margin:0 auto}
.services-cta .section-title{color:var(--base-rouge-color);font-family:var(--global-font-family-titre);font-size:var(--font-size-h2);margin-bottom:1.5rem;position:relative}
.services-cta .section-title::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:100px;height:3px;background:var(--base-rouge-color);border-radius:2px}
.services-description{font-family:var(--global-font-family);font-size:var(--font-size-normal);color:var(--base-noir-color);margin-bottom:3rem;line-height:1.6;max-width:800px;margin-left:auto;margin-right:auto}
.services-preview{display:flex;justify-content:center;gap:2rem;margin-bottom:3rem;flex-wrap:wrap}
.preview-item{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;background:var(--base-white-color);border-radius:15px;min-width:150px;box-shadow:0 4px 6px rgba(0,0,0,.1);transition:transform .3s}
.preview-item:hover{transform:translateY(-5px)}
.preview-item i{font-size:2rem;color:var(--base-rouge-color)}
.preview-item span{font-family:var(--global-font-family);color:var(--base-noir-color);font-weight:500;font-size:var(--font-size-normal)}
.services-cta .cta-button{display:inline-flex;align-items:center;gap:1rem;padding:1rem 2rem;background-color:var(--base-rouge-color);color:var(--base-white-color);text-decoration:none;border-radius:50px;font-family:var(--global-font-family);font-size:var(--font-size-button);font-weight:600;transition:.3s;border:2px solid var(--base-rouge-color)}
.services-cta .cta-button:hover{background-color:var(--base-white-color);color:var(--base-rouge-color);transform:translateY(-3px);box-shadow:0 4px 15px rgba(113,0,0,.2)}
.services-cta .cta-button i{transition:transform .3s}
.services-cta .cta-button:hover i{transform:translateX(5px)}
@media (max-width:768px){
.services-section{padding:4rem 1rem}
.services-preview{gap:1rem}
.preview-item{min-width:120px;padding:1rem}
.services-cta .section-title{font-size:var(--font-size-h2-mobile)}
.preview-item span,.services-description{font-size:var(--font-size-normal-mobile)}
.services-cta .cta-button{font-size:var(--font-size-button-mobile)}
}