.container{max-width:1400px;margin:8rem auto 0;text-align:center;background:linear-gradient(135deg,#ffffff01 0,var(--secondary-color) 100%);color:var(--base-rouge-color)}
h1{font-family:var(--global-font-family-titre);font-size:var(--font-size-h1);margin-bottom:1rem;animation:.8s ease-out fadeInDown;color:var(--base-rouge-color)}
h1::after{display:none}
h2{font-family:var(--global-font-family);font-size:var(--font-size-h2);text-align:center;color:var(--base-rouge-color)}
p{font-size:var(--font-size-normal);margin-bottom:15px;text-align:center}
ul{padding-left:1.5rem}
.subtitle{font-family:var(--global-font-family);font-size:var(--font-size-normal);color:var(--base-noir-color);font-weight:700;opacity:.9;max-width:600px;margin:0 auto;animation:.8s ease-out .2s both fadeInUp}
.search-bar{background:var(--base-white-color);padding:2rem;border-radius:15px;box-shadow:0 8px 25px rgba(0,0,0,.08);margin:3rem auto;max-width:1000px;display:grid;grid-template-columns:repeat(3,minmax(200px,1fr)) auto;gap:1rem;align-items:end}
.search-bar select{background-color:var(--base-white-color);border:2px solid rgba(143,21,21,.2);border-radius:8px;padding:.8rem 1rem;font-size:var(--font-size-normal);color:var(--base-noir-color);cursor:pointer;transition:.3s;width:100%;min-width:200px;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%238f1515'%3e%3cpath d='M7 10l5 5 5-5z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .7rem center;background-size:1.2rem}
.search-bar select:focus,.search-bar select:hover{border-color:var(--base-rouge-color);outline:0}
.search-bar button{background:var(--base-rouge-color);color:var(--base-white-color);padding:.8rem 1.5rem;border:none;border-radius:8px;font-size:var(--font-size-button);font-weight:600;cursor:pointer;transition:.3s;height:100%;display:flex;align-items:center;justify-content:center;gap:.5rem}
.search-bar button:hover{background:var(--base-noir-color);transform:translateY(-2px)}
#events-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:2.5rem;padding:1rem}
.event{background:var(--base-white-color);border-radius:20px;overflow:hidden;box-shadow:0 8px 25px rgba(0,0,0,.08);transition:.4s cubic-bezier(.4, 0, .2, 1);height:auto;min-height:580px;display:flex;flex-direction:column;border:1px solid rgba(0,0,0,.05);animation:.6s ease-out forwards fadeInUp}
.event:hover{transform:translateY(-5px);box-shadow:0 15px 35px rgba(0,0,0,.12)}
.event-image-container{position:relative;overflow:hidden;width:100%;padding-top:50%}
.event-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s cubic-bezier(.4, 0, .2, 1);filter:brightness(.95)}
.event:hover .event-image{transform:scale(1.05);filter:brightness(1)}
.event-details{padding:1.8rem;flex:1;display:flex;flex-direction:column;gap:1.2rem;background:linear-gradient(145deg,rgba(255,255,255,.95) 0,#fff 100%)}
.event-header{display:flex;flex-direction:column;gap:1rem}
.event-title{font-family:var(--global-font-family);font-size:var(--font-size-h2);color:var(--base-rouge-color);line-height:1.3;font-weight:600;margin:0;padding:0;white-space:pre-line;word-break:break-word}
.event-meta{display:flex;flex-direction:column;gap:.8rem}
.event-date{display:inline-flex;align-items:center;background:var(--base-noir-color);color:var(--base-white-color);padding:.5rem 1rem;border-radius:8px;font-size:var(--font-size-normal);transform:translateY(0);transition:.3s;font-weight:500;box-shadow:0 3px 8px rgba(0,0,0,.1);width:fit-content}
.event-date i{margin-right:8px;font-size:var(--font-size-normal)}
.event-info{font-size:var(--font-size-normal);color:var(--base-noir-color);display:flex;align-items:center;gap:.5rem;opacity:.9;padding:.3rem 0}
.event-info i{color:var(--base-rouge-color);width:20px;text-align:center}
.event-info strong{color:var(--base-rouge-color);font-weight:600;margin-right:.3rem}
.event-content{flex:1;display:flex;flex-direction:column;gap:1rem}
.event-description{font-size:var(--font-size-normal);color:var(--base-noir-color);line-height:1.6;margin-bottom:1rem;text-align:left}
.event-description p{text-align:left;margin-bottom:.8rem}
.event-description strong{color:var(--base-rouge-color);font-weight:600}
.event-description ul{list-style-type:none;padding-left:1.5rem;margin:1rem 0}
.event-description li{position:relative;padding-left:1.5rem;margin-bottom:.5rem}
.event-description li::before{content:"•";color:var(--base-rouge-color);position:absolute;left:0;font-size:1.2em}
.event-description br{display:block;margin:.5rem 0;content:""}
.event-points{list-style-type:none;padding-left:0;margin:.5rem 0}
.event-points li{position:relative;padding-left:1.5rem;margin-bottom:.8rem;line-height:1.4}
.event-points li::before{content:"•";color:var(--base-rouge-color);position:absolute;left:0;font-size:1.2em;line-height:1}
.event-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}
.event-link{display:inline-flex;align-items:center;justify-content:center;background:var(--base-rouge-color);color:var(--base-white-color);padding:.7rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:var(--font-size-button);transition:.3s;width:100%;box-shadow:0 3px 10px rgba(143,21,21,.15)}
.event-link i{margin-left:8px;transition:transform .3s}
.event-link:hover{background:var(--base-noir-color);transform:translateY(-2px)}
.event-link:hover i{transform:translateX(4px)}
.month-section,.year-section{margin-bottom:4rem}
.month-title,.year-title{font-family:var(--global-font-family);color:var(--base-rouge-color)}
.year-title{font-size:var(--font-size-h1);border-bottom:3px solid var(--base-rouge-color);padding-bottom:.5rem;text-align:left}
.month-title{font-size:var(--font-size-h2);border-bottom:1px solid var(--base-rouge-color);padding-bottom:.5rem}
@keyframes fadeInDown{
from{opacity:0;transform:translateY(-20px)}
to{opacity:1;transform:translateY(0)}
}
@media (max-width:1200px){
.container{padding:3rem 2rem}
h1{font-size:calc(var(--font-size-h1) * .9)}
.subtitle{font-size:calc(var(--font-size-normal) * .9)}
#events-container{grid-template-columns:repeat(2,1fr)}
.search-bar{grid-template-columns:1fr 1fr;gap:1rem;padding:1.5rem}
.search-bar button{grid-column:span 2}
}
@media (max-width:900px){
h1{font-size:var(--font-size-h1-mobile)}
#events-container{grid-template-columns:1fr;max-width:600px;margin:0 auto}
.search-bar{grid-template-columns:1fr}
.search-bar button{grid-column:auto}
}
@media (max-width:768px){
.container{padding:3rem 1rem}
h1{font-size:var(--font-size-h1-mobile)}
.subtitle{font-size:var(--font-size-normal-mobile)}
.event-title{font-size:var(--font-size-h2-mobile)}
.event-date,.event-description,.event-info{font-size:var(--font-size-normal-mobile)}
.search-bar{grid-template-columns:1fr}
.search-bar select{font-size:var(--font-size-normal-mobile)}
.search-bar button{grid-column:auto;font-size:var(--font-size-button-mobile)}
}
@media (max-width:480px){
.container{padding:3rem 1rem}
h1{font-size:var(--font-size-h1-mobile)}
.subtitle{font-size:var(--font-size-normal-mobile)}
.event-title{font-size:var(--font-size-h3-mobile)}
.event-link{font-size:var(--font-size-button-mobile)}
.search-bar{padding:1rem;margin-bottom:2rem}
.search-bar button,.search-bar select{font-size:var(--font-size-normal-mobile);padding:.7rem 1rem}
#events-container{gap:1.5rem;padding:.5rem}
.event{min-height:auto}
.event-details{padding:1.2rem}
.event-title{font-size:calc(var(--font-size-h3-mobile) * .9);line-height:1.4;white-space:pre-line;word-break:break-word}
.event-meta{gap:.6rem}
.event-info{font-size:calc(var(--font-size-normal) * .9);flex-wrap:wrap;text-align:left}
.event-info i{width:16px}
.event-description{font-size:calc(var(--font-size-normal) * .95);padding-left:.8rem;text-align:left}
.event-link{padding:.6rem 1.2rem;font-size:calc(var(--font-size-button) * .9)}
.event-title{font-size:calc(var(--font-size-h3-mobile) * .9)}
.event-date,.event-description,.event-info{font-size:calc(var(--font-size-normal-mobile) * .95)}
.event-link{font-size:calc(var(--font-size-button-mobile) * .9)}
.event-points li{padding-left:1.2rem;margin-bottom:.6rem;font-size:.95em}
}
@keyframes highlight{
0%,100%{background-color:rgba(255,255,255,.98)}
50%{background-color:rgba(143,21,21,.1)}
}
.no-events{text-align:center;padding:3rem;background:var(--base-white-color);border-radius:15px;margin:2rem auto;max-width:600px;color:var(--base-noir-color);font-size:var(--font-size-h3)}
.evenement-principal img{max-width:100%;height:auto;display:block;margin:0 auto;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.1)}
@keyframes fadeInUp{
from{opacity:0;transform:translateY(20px)}
to{opacity:1;transform:translateY(0)}
}
.header-section{text-align:center;background:linear-gradient(135deg,#ffffff01 0,var(--secondary-color) 100%);color:var(--base-rouge-color);padding:3rem 2rem}
.header-title{font-family:var(--global-font-family-titre);font-size:var(--font-size-h1);margin-bottom:1rem;animation:.8s ease-out fadeInDown;color:var(--base-rouge-color)}
.header-subtitle{font-family:var(--global-font-family);font-size:var(--font-size-normal);color:var(--base-noir-color);font-weight:700;opacity:.9;max-width:600px;margin:0 auto;animation:.8s ease-out .2s both fadeInUp}
@media (max-width:768px){
.header-section{padding:3rem 1rem}
.header-title{font-size:var(--font-size-h1-mobile)}
.header-subtitle{font-size:var(--font-size-normal-mobile)}
}
@media (max-width:480px){
.header-section{padding:3rem 1rem}
.header-title{font-size:var(--font-size-h1-mobile)}
.header-subtitle{font-size:var(--font-size-normal-mobile)}
}
.event-past{opacity:.8;background:var(--base-white-color);position:relative}
.event-past::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.05);pointer-events:none;z-index:1;border-radius:20px}
.event-past .event-image{filter:grayscale(.7) brightness(.9)}
.event-past:hover .event-image{filter:grayscale(.5) brightness(.95)}
.event-past .event-title{color:var(--base-noir-color)}
.event-past .event-date{background:#707070}
.event-past-badge{position:absolute;top:15px;right:15px;background:rgba(0,0,0,.7);color:#fff;padding:5px 12px;border-radius:4px;font-size:.85rem;font-weight:700;z-index:2;text-transform:uppercase}
.event-past .event-link{background:#707070;border:1px solid #606060;color:var(--base-white-color)}
.event-past .event-link:hover{background:var(--base-noir-color)}