/* ============================================
   DJIB-SOLIDEV — Premium NGO Stylesheet
   Inspired by Action Contre la Faim
   ============================================ */

:root{
  --color-red:#E63946;
  --color-red-dark:#C1121F;
  --color-blue-deep:#1D3557;
  --color-blue-sky:#457B9D;
  --color-cream:#F1FAEE;
  --color-gold:#FFC107;
  --color-black:#1A1A1A;
  --color-grey:#6B7280;
  --color-light:#F8FAFC;
  --shadow-sm:0 2px 6px rgba(0,0,0,.08);
  --shadow-md:0 8px 24px rgba(0,0,0,.12);
  --shadow-lg:0 20px 60px rgba(0,0,0,.18);
  --transition:cubic-bezier(.4,0,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Montserrat',system-ui,-apple-system,sans-serif;
  color:var(--color-black);
  background:#fff;
  line-height:1.6;
  overflow-x:hidden;
}
body[dir="rtl"]{font-family:'Noto Sans Arabic','Cairo','Tajawal',sans-serif}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .3s var(--transition)}
button{font-family:inherit;cursor:pointer;border:none;background:none}

h1,h2,h3,h4,h5{font-family:'Montserrat',sans-serif;font-weight:800;line-height:1.2;color:var(--color-blue-deep)}
.h-display{font-size:clamp(2.5rem,6vw,5.5rem);font-weight:900;letter-spacing:-.02em;line-height:1.05}
.h-title{font-size:clamp(1.8rem,3.5vw,3rem)}
.h-section{font-size:clamp(1.4rem,2.5vw,2.2rem)}
.eyebrow{display:inline-block;font-size:.85rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--color-red);padding:.4rem 1rem;background:rgba(230,57,70,.08);border-radius:30px;margin-bottom:1rem}

.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0;position:relative}
.section-dark{background:var(--color-blue-deep);color:#fff}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}
.section-cream{background:var(--color-cream)}

.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,0,0,.06);
  transition:all .3s var(--transition);
}
.header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:2rem}
.logo{display:flex;align-items:center;gap:.75rem;font-weight:900;color:var(--color-blue-deep)}
.logo img{height:48px;width:auto}
.logo span{font-size:1.1rem;letter-spacing:-.02em}
.logo small{display:block;font-size:.7rem;color:var(--color-red);font-weight:700;letter-spacing:.15em}

.nav-menu{display:flex;align-items:center;gap:1.75rem;list-style:none}
.nav-menu a{font-weight:600;font-size:.95rem;color:var(--color-blue-deep);position:relative;padding:.5rem 0}
.nav-menu a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-red);transition:width .3s var(--transition)}
.nav-menu a:hover::after,.nav-menu a.active::after{width:100%}

.nav-actions{display:flex;align-items:center;gap:1rem}

.lang-switcher{display:flex;gap:.25rem;background:var(--color-light);padding:.25rem;border-radius:30px}
.lang-btn{padding:.4rem .85rem;border-radius:30px;font-size:.8rem;font-weight:700;color:var(--color-grey);transition:all .3s}
.lang-btn.active{background:var(--color-red);color:#fff}

.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.9rem 1.75rem;border-radius:50px;
  font-weight:700;font-size:.95rem;
  transition:all .3s var(--transition);
  cursor:pointer;border:2px solid transparent;
}
.btn-primary{background:var(--color-red);color:#fff;box-shadow:0 6px 20px rgba(230,57,70,.35)}
.btn-primary:hover{background:var(--color-red-dark);transform:translateY(-2px);box-shadow:0 10px 30px rgba(230,57,70,.5)}
.btn-outline{border-color:#fff;color:#fff}
.btn-outline:hover{background:#fff;color:var(--color-blue-deep)}
.btn-dark{background:var(--color-blue-deep);color:#fff}
.btn-dark:hover{background:#0d1f3a;transform:translateY(-2px)}
.btn-gold{background:var(--color-gold);color:var(--color-black)}
.btn-gold:hover{background:#ffb300;transform:translateY(-2px)}
.btn-lg{padding:1.1rem 2.25rem;font-size:1.05rem}

.burger{display:none;flex-direction:column;gap:5px;width:32px;height:24px;justify-content:center}
.burger span{display:block;width:100%;height:3px;background:var(--color-blue-deep);border-radius:3px;transition:all .3s}

.hero{
  position:relative;height:100vh;min-height:680px;
  overflow:hidden;color:#fff;
  display:flex;align-items:center;
}
.hero-slides{position:absolute;inset:0;z-index:1}
.hero-slide{
  position:absolute;inset:0;opacity:0;
  background-size:cover;background-position:center;
  transition:opacity 1.5s ease;
  transform:scale(1.05);
}
.hero-slide.active{opacity:1;animation:kenBurns 8s ease-in-out infinite alternate}
@keyframes kenBurns{from{transform:scale(1.05)}to{transform:scale(1.15)}}
.hero-slide::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(29,53,87,.85) 0%,rgba(26,26,26,.65) 60%,rgba(230,57,70,.4) 100%);
}
.hero-content{position:relative;z-index:2;width:100%}
.hero-eyebrow{
  display:inline-block;padding:.6rem 1.25rem;
  background:var(--color-red);color:#fff;
  font-size:.85rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  border-radius:30px;margin-bottom:1.5rem;
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(230,57,70,.6)}50%{box-shadow:0 0 0 20px rgba(230,57,70,0)}}
.hero h1{color:#fff;max-width:900px;margin-bottom:1.5rem;text-shadow:0 4px 30px rgba(0,0,0,.5)}
.hero p{font-size:clamp(1.1rem,1.4vw,1.35rem);max-width:680px;margin-bottom:2.5rem;opacity:.95}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}

.hero-dots{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;gap:.6rem;z-index:3}
.hero-dot{width:40px;height:4px;background:rgba(255,255,255,.3);border-radius:4px;cursor:pointer;transition:background .3s}
.hero-dot.active{background:var(--color-red)}

.hero-scroll{position:absolute;bottom:2rem;right:2rem;color:#fff;font-size:.8rem;letter-spacing:.2em;writing-mode:vertical-rl;z-index:3;opacity:.7}

.stats{
  background:linear-gradient(135deg,var(--color-blue-deep) 0%,#0d1f3a 100%);
  color:#fff;padding:4rem 0;
  position:relative;overflow:hidden;
}
.stats::before{content:'';position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(230,57,70,.15),transparent 70%);}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem;text-align:center;position:relative}
.stat-item{padding:1rem}
.stat-number{font-size:clamp(2.5rem,4vw,3.8rem);font-weight:900;color:var(--color-gold);line-height:1;display:block;margin-bottom:.5rem}
.stat-label{font-size:.95rem;opacity:.85;font-weight:500}

.urgent-banner{
  position:relative;padding:5rem 0;color:#fff;
  background:linear-gradient(135deg,var(--color-red) 0%,#8B0000 100%);
  overflow:hidden;
}
.urgent-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center;position:relative;z-index:1}
.urgent-tag{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);padding:.5rem 1rem;border-radius:30px;font-size:.85rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.5rem;border:1px solid rgba(255,255,255,.3)}
.urgent-tag i{animation:pulse-icon 1.5s infinite}
@keyframes pulse-icon{0%,100%{transform:scale(1)}50%{transform:scale(1.3)}}
.urgent-banner h2{color:#fff;font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1rem}
.urgent-banner p{font-size:1.1rem;opacity:.95;margin-bottom:2rem;max-width:560px}

.donation-card{
  background:#fff;color:var(--color-black);
  border-radius:20px;padding:2.5rem;
  box-shadow:var(--shadow-lg);
}
.donation-card h3{color:var(--color-blue-deep);margin-bottom:.5rem}
.progress-info{display:flex;justify-content:space-between;font-size:.9rem;margin-top:1rem;color:var(--color-grey)}
.progress-info strong{color:var(--color-red);font-size:1.1rem}
.progress-bar{height:14px;background:var(--color-cream);border-radius:14px;overflow:hidden;margin-top:.5rem;position:relative}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-red),var(--color-gold));border-radius:14px;width:0;transition:width 2s ease;position:relative}
.progress-fill::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 2s infinite}
@keyframes shimmer{from{transform:translateX(-100%)}to{transform:translateX(100%)}}

.donation-amounts{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin:1.5rem 0}
.amount-btn{padding:.85rem;border:2px solid var(--color-cream);border-radius:10px;font-weight:700;color:var(--color-blue-deep);transition:all .3s;background:#fff}
.amount-btn:hover,.amount-btn.active{background:var(--color-red);color:#fff;border-color:var(--color-red);transform:translateY(-2px)}

.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}
.card{
  background:#fff;border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow-sm);transition:all .4s var(--transition);
  position:relative;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md)}
.card-img{position:relative;overflow:hidden;aspect-ratio:4/3}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--transition)}
.card:hover .card-img img{transform:scale(1.1)}
.card-tag{position:absolute;top:1rem;left:1rem;background:var(--color-red);color:#fff;padding:.3rem .8rem;border-radius:30px;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;z-index:2}
.card-body{padding:1.75rem}
.card-body h3{font-size:1.25rem;margin-bottom:.75rem;color:var(--color-blue-deep)}
.card-body p{color:var(--color-grey);font-size:.95rem;margin-bottom:1rem}
.card-link{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;color:var(--color-red)}
.card-link:hover{gap:.8rem}

.pillar{
  background:#fff;padding:2.5rem 2rem;border-radius:16px;
  text-align:center;border-top:4px solid var(--color-red);
  transition:all .4s;box-shadow:var(--shadow-sm);
}
.pillar:hover{transform:translateY(-10px);box-shadow:var(--shadow-md)}
.pillar-icon{width:80px;height:80px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,var(--color-red),var(--color-gold));color:#fff;font-size:2rem}
.pillar h3{margin-bottom:.75rem}
.pillar p{color:var(--color-grey);font-size:.95rem}

.timeline{position:relative;max-width:1000px;margin:3rem auto}
.timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:3px;background:linear-gradient(var(--color-red),var(--color-blue-deep));transform:translateX(-50%)}
.timeline-item{position:relative;width:50%;padding:1.5rem 3rem;}
.timeline-item:nth-child(odd){left:0;text-align:right}
.timeline-item:nth-child(even){left:50%}
.timeline-item::before{content:'';position:absolute;top:2rem;width:20px;height:20px;border-radius:50%;background:var(--color-red);border:4px solid #fff;box-shadow:0 0 0 3px var(--color-red);z-index:1}
.timeline-item:nth-child(odd)::before{right:-10px}
.timeline-item:nth-child(even)::before{left:-10px}
.timeline-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm)}
.timeline-date{font-size:.85rem;color:var(--color-red);font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem}
.timeline-card h4{margin-bottom:.5rem}
.timeline-card p{color:var(--color-grey);font-size:.9rem}

.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;grid-auto-flow:dense}
.gallery-item{position:relative;overflow:hidden;border-radius:12px;cursor:pointer;aspect-ratio:1;background:#eee}
.gallery-item:nth-child(7n+1){grid-row:span 2;aspect-ratio:1/2}
.gallery-item:nth-child(11n+5){grid-column:span 2;aspect-ratio:2/1}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s,filter .4s}
.gallery-item::after{content:'\f00e';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(29,53,87,.8);color:#fff;font-size:2rem;opacity:0;transition:opacity .4s}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-item:hover::after{opacity:1}

.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:9999;display:none;align-items:center;justify-content:center;padding:2rem}
.lightbox.active{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:8px}
.lightbox-close{position:absolute;top:2rem;right:2rem;color:#fff;font-size:2rem;background:rgba(255,255,255,.1);width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);color:#fff;width:60px;height:60px;border-radius:50%;font-size:1.5rem;display:flex;align-items:center;justify-content:center}
.lightbox-prev{left:2rem}
.lightbox-next{right:2rem}

.partners-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem}
.partner-logo{
  background:#fff;border-radius:12px;padding:1.5rem;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;box-shadow:var(--shadow-sm);
  transition:all .3s;min-height:140px;
}
.partner-logo:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.partner-logo i{font-size:2rem;color:var(--color-red);margin-bottom:.75rem}
.partner-logo strong{font-size:.95rem;color:var(--color-blue-deep);margin-bottom:.25rem}
.partner-logo small{color:var(--color-grey);font-size:.8rem}

.testimonial{
  background:#fff;border-radius:16px;padding:2.5rem;
  position:relative;box-shadow:var(--shadow-sm);
  border-left:4px solid var(--color-red);
}
.testimonial::before{content:'"';position:absolute;top:-20px;left:20px;font-size:6rem;color:var(--color-red);font-family:Georgia,serif;line-height:1;opacity:.2}
.testimonial-text{font-style:italic;font-size:1.05rem;margin-bottom:1.5rem;color:var(--color-black)}
.testimonial-author{display:flex;align-items:center;gap:1rem}
.testimonial-avatar{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--color-red),var(--color-gold));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.testimonial-author strong{display:block;color:var(--color-blue-deep)}
.testimonial-author small{color:var(--color-grey)}

.form-group{margin-bottom:1.25rem}
.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.9rem;color:var(--color-blue-deep)}
.form-control{
  width:100%;padding:.85rem 1rem;
  border:2px solid #e5e7eb;border-radius:10px;
  font-size:1rem;font-family:inherit;
  transition:border .3s,box-shadow .3s;
  background:#fff;
}
.form-control:focus{outline:none;border-color:var(--color-red);box-shadow:0 0 0 3px rgba(230,57,70,.15)}
textarea.form-control{resize:vertical;min-height:120px}

.footer{background:#0a1830;color:#fff;padding:4rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:3rem;margin-bottom:3rem}
.footer h4{color:#fff;margin-bottom:1.25rem;font-size:1.1rem}
.footer p,.footer a{color:rgba(255,255,255,.7);font-size:.9rem}
.footer a:hover{color:var(--color-gold)}
.footer ul{list-style:none}
.footer ul li{margin-bottom:.6rem}
.footer-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:#fff;font-weight:900}
.footer-logo img{height:50px}
.social-links{display:flex;gap:.75rem;margin-top:1rem}
.social-links a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s}
.social-links a:hover{background:var(--color-red);transform:translateY(-3px)}
.newsletter-form{display:flex;gap:.5rem;margin-top:1rem}
.newsletter-form input{flex:1;padding:.65rem .85rem;border:none;border-radius:8px;font-family:inherit}
.newsletter-form button{padding:.65rem 1.25rem;background:var(--color-red);color:#fff;border-radius:8px;font-weight:700}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;text-align:center;font-size:.85rem;opacity:.7}

.page-hero{
  position:relative;padding:9rem 0 5rem;color:#fff;
  background:linear-gradient(135deg,var(--color-blue-deep),#0d1f3a);
  overflow:hidden;text-align:center;
}
.page-hero::before{content:'';position:absolute;inset:0;background:url('../assets/images/piscca-femmes-oranges-drapeaux.jpg') center/cover;opacity:.2}
.page-hero h1{position:relative;color:#fff}
.breadcrumb{position:relative;display:flex;justify-content:center;gap:.5rem;margin-top:1rem;font-size:.9rem;opacity:.85}

.dashboard{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:var(--color-light)}
.sidebar{background:var(--color-blue-deep);color:#fff;padding:2rem 0;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar-logo{padding:0 1.5rem 2rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:1.5rem}
.sidebar-menu{list-style:none}
.sidebar-menu li a{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.5rem;color:rgba(255,255,255,.75);transition:all .3s;border-left:3px solid transparent;font-size:.9rem}
.sidebar-menu li a:hover,.sidebar-menu li a.active{color:#fff;background:rgba(255,255,255,.05);border-left-color:var(--color-red)}
.dashboard-main{padding:2rem}
.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:2rem}
.kpi-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:var(--shadow-sm)}
.kpi-card .label{font-size:.8rem;color:var(--color-grey);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}
.kpi-card .value{font-size:2rem;font-weight:900;color:var(--color-blue-deep)}
.kpi-card .trend{font-size:.85rem;color:#10b981;margin-top:.25rem}
.dashboard-row{display:grid;grid-template-columns:2fr 1fr;gap:1.25rem;margin-bottom:1.25rem}
.dashboard-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm)}
.data-table{width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:.75rem;text-align:left;border-bottom:1px solid #f0f0f0;font-size:.9rem}
.data-table th{background:var(--color-light);font-weight:700;color:var(--color-blue-deep);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
.badge{display:inline-block;padding:.2rem .65rem;border-radius:30px;font-size:.7rem;font-weight:700;letter-spacing:.05em}
.badge-success{background:rgba(16,185,129,.1);color:#10b981}
.badge-warning{background:rgba(245,158,11,.1);color:#f59e0b}
.badge-danger{background:rgba(230,57,70,.1);color:var(--color-red)}

.auth-wrapper{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.auth-visual{
  background:linear-gradient(135deg,rgba(29,53,87,.92),rgba(13,31,58,.95)),url('../assets/images/numerique-elles-photo-groupe-crd.jpg') center/cover;
  color:#fff;display:flex;align-items:center;padding:3rem;
}
.auth-form-area{display:flex;align-items:center;justify-content:center;padding:3rem;background:#fff}
.auth-form{width:100%;max-width:420px}
.auth-form h2{margin-bottom:.5rem}
.auth-form p{color:var(--color-grey);margin-bottom:2rem}

@media(max-width:992px){
  .nav-menu{position:fixed;top:80px;left:0;right:0;flex-direction:column;background:#fff;padding:2rem;gap:1.5rem;box-shadow:var(--shadow-md);transform:translateY(-150%);transition:transform .4s;align-items:flex-start}
  .nav-menu.open{transform:translateY(0)}
  .burger{display:flex}
  .urgent-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .auth-wrapper{grid-template-columns:1fr}
  .auth-visual{display:none}
  .dashboard{grid-template-columns:1fr}
  .sidebar{height:auto;position:relative;display:none}
  .sidebar.open{display:block}
  .dashboard-row{grid-template-columns:1fr}
  .timeline::before{left:20px}
  .timeline-item,.timeline-item:nth-child(even){width:100%;left:0;padding-left:3.5rem;text-align:left}
  .timeline-item::before{left:10px!important}
}
@media(max-width:600px){
  .footer-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .donation-amounts{grid-template-columns:repeat(2,1fr)}
}

[dir="rtl"] .nav-menu a::after{left:auto;right:0}
[dir="rtl"] .timeline-item:nth-child(odd){text-align:left}
[dir="rtl"] .timeline-item:nth-child(even){text-align:right}
[dir="rtl"] .testimonial{border-left:none;border-right:4px solid var(--color-red)}
[dir="rtl"] .sidebar-menu li a{border-left:none;border-right:3px solid transparent}
[dir="rtl"] .sidebar-menu li a:hover,[dir="rtl"] .sidebar-menu li a.active{border-right-color:var(--color-red)}

[data-aos]{opacity:0;transition:all .8s var(--transition)}
[data-aos].aos-animate{opacity:1}
[data-aos="fade-up"]{transform:translateY(40px)}
[data-aos="fade-up"].aos-animate{transform:translateY(0)}
[data-aos="fade-right"]{transform:translateX(-40px)}
[data-aos="fade-right"].aos-animate{transform:translateX(0)}
[data-aos="fade-left"]{transform:translateX(40px)}
[data-aos="fade-left"].aos-animate{transform:translateX(0)}
[data-aos="zoom-in"]{transform:scale(.9)}
[data-aos="zoom-in"].aos-animate{transform:scale(1)}

/* ============================================
   v2 ADDITIONS — chips, project blocks, mosaics
   ============================================ */

.eyebrow-red{color:#fff;background:var(--color-red)}

/* Filter chips */
.project-filters,.gallery-filters{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;margin:0 auto 2rem;
}
.chip{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.55rem 1.1rem;border-radius:30px;
  font-size:.85rem;font-weight:700;
  background:#fff;color:var(--color-blue-deep);
  border:2px solid var(--color-cream);
  transition:all .3s var(--transition);
  text-decoration:none;
}
.chip:hover{transform:translateY(-2px);border-color:var(--color-red);color:var(--color-red);box-shadow:var(--shadow-sm)}
.chip-red{background:var(--color-red);color:#fff;border-color:var(--color-red)}
.chip-red:hover{background:var(--color-red-dark);color:#fff;border-color:var(--color-red-dark)}
.chip-active{background:var(--color-blue-deep);color:#fff;border-color:var(--color-blue-deep)}
.chip-active:hover{background:var(--color-blue-deep);color:#fff}

/* Project block layout */
.project-block{position:relative;scroll-margin-top:6rem}
.project-header{text-align:center;max-width:880px;margin:0 auto 3rem}
.project-lead{
  font-size:1.05rem;color:var(--color-grey);
  max-width:760px;margin:1rem auto 0;line-height:1.7;
}

/* Project mosaic — 1 big tile + 4 small */
.project-mosaic{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  grid-template-rows:repeat(2, minmax(160px, 1fr));
  gap:1rem;
  max-width:1200px;margin:0 auto;
}
.mosaic-big{
  grid-row:span 2;grid-column:1;
  border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow-md);
  position:relative;
  min-height:420px;
}
.mosaic-small{
  border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);
  position:relative;
}
.mosaic-big img,.mosaic-small img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--transition);
}
.mosaic-big:hover img,.mosaic-small:hover img{transform:scale(1.06)}
@media(max-width:768px){
  .project-mosaic{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .mosaic-big{grid-row:span 2;grid-column:span 2;min-height:280px}
}

/* Project facts row */
.project-facts{
  display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;
  margin:3rem auto 0;max-width:900px;
}
.fact{
  background:#fff;border-radius:14px;
  padding:1.5rem 2rem;text-align:center;
  box-shadow:var(--shadow-sm);
  min-width:140px;flex:1;
  border-top:4px solid var(--color-red);
}
.fact strong{
  display:block;font-size:2rem;font-weight:900;
  color:var(--color-blue-deep);line-height:1;margin-bottom:.4rem;
  font-family:'Montserrat',sans-serif;
}
.fact span{
  font-size:.85rem;color:var(--color-grey);
  text-transform:uppercase;letter-spacing:.05em;font-weight:600;
}
.section-cream .fact{background:#fff}

/* Gallery sections */
.gallery-section{margin-bottom:4rem;scroll-margin-top:6rem}
.gallery-section-title{
  display:flex;align-items:center;gap:.75rem;
  font-size:1.4rem;margin-bottom:1.5rem;
  color:var(--color-blue-deep);
  padding-bottom:.75rem;border-bottom:3px solid var(--color-red);
}
.gallery-section-title i{color:var(--color-red);font-size:1.2rem}
.gallery-count{
  margin-left:auto;font-size:.85rem;font-weight:600;
  color:var(--color-grey);background:var(--color-cream);
  padding:.3rem .85rem;border-radius:30px;
}

/* Two-column layout (about page) */
.two-col{
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:center;
}
@media(max-width:768px){.two-col{grid-template-columns:1fr;gap:2rem}}

/* Impact tier rows on Ramadan campaign page */
.impact-tier{
  display:flex;align-items:center;gap:1.25rem;
  padding:.85rem 0;border-bottom:1px solid var(--color-cream);
}
.impact-tier:last-child{border-bottom:none}
.impact-tier strong{
  display:inline-block;min-width:70px;
  color:var(--color-red);font-size:1.4rem;font-weight:900;
}

/* Footer fixes */
.footer ul li a{color:rgba(255,255,255,.7)}
.footer ul li a:hover{color:var(--color-gold)}
.footer ul li i{color:var(--color-red);margin-right:.5rem}

/* Smooth anchor offset for fixed header */
.section[id]{scroll-margin-top:6rem}

/* ============================================
   v3 ADDITIONS — narrative blocks, secondary grids
   ============================================ */

.project-narrative{
  max-width:880px;margin:0 auto 3rem;
  font-size:1.05rem;line-height:1.85;color:#374151;
}
.project-narrative p{margin-bottom:1.4rem}
.project-narrative p:first-of-type::first-letter{
  float:left;font-size:3.6rem;line-height:1;
  font-weight:900;color:var(--color-red);
  padding:.4rem .8rem 0 0;font-family:'Montserrat',sans-serif;
}
.project-narrative strong{color:var(--color-blue-deep);font-weight:700}
.project-narrative em{color:var(--color-red);font-style:italic;font-weight:600}

.project-secondary-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:.85rem;margin-top:2rem;
}
.project-secondary-grid img{
  width:100%;aspect-ratio:1;object-fit:cover;
  border-radius:10px;box-shadow:var(--shadow-sm);
  transition:transform .4s var(--transition);
  cursor:pointer;
}
.project-secondary-grid img:hover{
  transform:scale(1.04);box-shadow:var(--shadow-md);
}

/* Improve project block rhythm */
.project-block{padding:6rem 0}
@media(max-width:768px){
  .project-block{padding:4rem 0}
  .project-narrative{font-size:.98rem}
  .project-narrative p:first-of-type::first-letter{font-size:2.8rem}
}

/* ============================================
   v4 — Mot du Président, Donate page, Contact page
   ============================================ */

/* === MOT DU PRÉSIDENT === */
.president-section{padding:6rem 0;background:#fff}
.president-card{
  display:grid;grid-template-columns:380px 1fr;gap:3rem;
  background:linear-gradient(135deg,#fafbfc,#f5f7fa);
  border-radius:24px;padding:3rem;
  box-shadow:0 12px 40px rgba(29,53,87,.08);
  border:1px solid rgba(29,53,87,.06);
  max-width:1200px;margin:0 auto;
}
.president-photo{position:relative}
.president-photo img{
  width:100%;aspect-ratio:1/1.05;object-fit:cover;
  border-radius:18px;
  box-shadow:0 16px 50px rgba(29,53,87,.18);
  border:4px solid #fff;
}
.president-name-block{
  position:absolute;bottom:-30px;left:50%;transform:translateX(-50%);
  background:var(--color-blue-deep);color:#fff;
  padding:1rem 1.6rem;border-radius:14px;
  text-align:center;width:88%;
  box-shadow:0 10px 30px rgba(29,53,87,.3);
  border-bottom:4px solid var(--color-red);
}
.president-name-block strong{
  display:block;font-size:1.05rem;font-weight:800;
  font-family:'Montserrat',sans-serif;
}
.president-name-block small{
  display:block;font-size:.78rem;opacity:.85;
  margin-top:.3rem;
}

.president-message{font-size:1rem;line-height:1.85;color:#374151}
.president-message p{margin-bottom:1.1rem}
.president-greeting{
  font-style:italic;color:var(--color-red);
  font-weight:600;font-size:1.05rem;
}
.president-message strong{color:var(--color-blue-deep);font-weight:700}
.president-signature{
  margin-top:2rem;padding-top:1.5rem;
  border-top:2px solid var(--color-cream);
}
.president-signature p{margin-bottom:.5rem;font-style:italic;color:#6B7280}
.president-signature strong{
  display:block;color:var(--color-blue-deep);
  font-family:'Montserrat',sans-serif;font-size:1.1rem;
  font-weight:800;
}
.president-signature small{color:#6B7280;font-size:.85rem}

@media(max-width:768px){
  .president-card{grid-template-columns:1fr;gap:2rem;padding:1.75rem}
  .president-photo img{aspect-ratio:1}
  .president-name-block{position:static;transform:none;width:100%;margin-top:1rem}
}

[dir="rtl"] .president-card{direction:rtl}

/* === DONATE PAGE === */
.causes-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));
  gap:1.5rem;
}
.cause-card{
  background:#fff;border-radius:18px;padding:2rem;
  box-shadow:0 4px 20px rgba(0,0,0,.06);
  border:2px solid transparent;
  transition:all .35s var(--transition);
  display:flex;flex-direction:column;
}
.cause-card:hover{
  transform:translateY(-6px);
  box-shadow:0 14px 36px rgba(29,53,87,.14);
  border-color:rgba(230,57,70,.2);
}
.cause-card.selected{
  border-color:var(--color-red);
  box-shadow:0 14px 36px rgba(230,57,70,.22);
}
.cause-icon{
  width:64px;height:64px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.6rem;margin-bottom:1.25rem;
  box-shadow:0 6px 16px rgba(0,0,0,.15);
}
.cause-card h3{
  font-size:1.15rem;color:var(--color-blue-deep);
  margin-bottom:.6rem;font-weight:800;
  font-family:'Montserrat',sans-serif;
}
.cause-card > p{
  color:#6B7280;font-size:.92rem;line-height:1.6;
  margin-bottom:1.25rem;flex-grow:1;
}
.cause-impacts{
  background:#fafbfc;border-radius:10px;
  padding:.85rem 1rem;margin-bottom:1.25rem;
  border-left:3px solid var(--color-red);
}
.impact-row{
  display:flex;align-items:center;gap:.75rem;
  font-size:.85rem;padding:.4rem 0;
  border-bottom:1px solid #e5e7eb;
}
.impact-row:last-child{border-bottom:none}
.impact-amount{
  display:inline-block;min-width:42px;
  font-weight:900;color:var(--color-red);
  font-family:'Montserrat',sans-serif;
}
.impact-text{color:#374151;flex:1}

.cause-select-btn{
  width:100%;justify-content:center;font-size:.9rem;
}
.cause-card.selected .cause-select-btn{
  background:var(--color-red);
  border-color:var(--color-red);
}
.cause-card.selected .cause-select-btn::before{content:"✓ ";font-weight:900}

/* DONATION FORM */
.donation-form-wrapper{
  max-width:720px;margin:0 auto;
  background:#fff;border-radius:20px;padding:2.5rem;
  box-shadow:0 12px 40px rgba(29,53,87,.10);
}
.donation-form-wrapper > h2{margin-bottom:2rem}

.currency-row,.amount-row,.cause-row{margin-bottom:1.5rem}
.currency-row label,.amount-row label,.cause-row label,.form-field label{
  display:block;font-weight:700;color:var(--color-blue-deep);
  margin-bottom:.6rem;font-size:.9rem;
  text-transform:uppercase;letter-spacing:.04em;
}

.currency-buttons{display:flex;gap:.5rem;flex-wrap:wrap}
.currency-btn{
  padding:.7rem 1.2rem;border:2px solid #e5e7eb;
  background:#fff;border-radius:10px;
  font-weight:700;cursor:pointer;
  transition:all .25s var(--transition);
  font-family:inherit;color:#374151;
}
.currency-btn:hover{border-color:var(--color-red);color:var(--color-red)}
.currency-btn.active{background:var(--color-red);color:#fff;border-color:var(--color-red)}

.amount-display{
  text-align:center;padding:1.5rem 0 1rem;
  font-family:'Montserrat',sans-serif;
}
.amount-symbol{
  font-size:2rem;color:var(--color-grey);
  vertical-align:top;line-height:1.4;margin-right:.4rem;
}
.amount-value{
  font-size:4rem;font-weight:900;
  color:var(--color-red);line-height:1;
}
.amount-slider{
  width:100%;height:8px;border-radius:4px;
  background:#e5e7eb;outline:none;
  -webkit-appearance:none;appearance:none;
  cursor:pointer;
}
.amount-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:26px;height:26px;border-radius:50%;
  background:var(--color-red);cursor:pointer;
  border:3px solid #fff;
  box-shadow:0 4px 12px rgba(230,57,70,.4);
}
.amount-slider::-moz-range-thumb{
  width:26px;height:26px;border-radius:50%;
  background:var(--color-red);cursor:pointer;
  border:3px solid #fff;
  box-shadow:0 4px 12px rgba(230,57,70,.4);
}
.slider-bounds{
  display:flex;justify-content:space-between;
  margin-top:.5rem;font-size:.78rem;
  color:var(--color-grey);font-weight:600;
}
.conversion-note{
  font-size:.78rem;color:var(--color-grey);
  margin-top:.85rem;font-style:italic;
}

.cause-display{
  padding:1.1rem 1.25rem;border:2px dashed #e5e7eb;
  border-radius:10px;color:var(--color-grey);
  font-size:.95rem;display:flex;align-items:center;gap:.75rem;
}
.cause-display.filled{
  border-style:solid;border-color:var(--color-red);
  background:rgba(230,57,70,.06);color:var(--color-blue-deep);
}
.cause-display.filled i{color:var(--color-red)}

.personal-fields{
  display:grid;grid-template-columns:1fr 1fr;gap:1rem;
  margin-top:1.5rem;
}
.form-field{margin-bottom:0}
.form-field.full{grid-column:1/-1}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:.85rem 1rem;
  border:2px solid #e5e7eb;border-radius:10px;
  font-family:inherit;font-size:.95rem;
  transition:all .25s var(--transition);
  background:#fff;color:#1f2937;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{
  outline:none;border-color:var(--color-red);
  box-shadow:0 0 0 3px rgba(230,57,70,.1);
}

@media(max-width:600px){
  .personal-fields{grid-template-columns:1fr}
  .donation-form-wrapper{padding:1.5rem}
  .amount-value{font-size:3rem}
}

.secure-note{
  text-align:center;font-size:.85rem;color:var(--color-grey);
  margin-top:1rem;
}

.thanks-message{
  margin-top:2rem;padding:2rem;text-align:center;
  background:#dcfce7;border-radius:14px;
  border-left:5px solid #16a34a;
}
.thanks-message i{font-size:3rem;color:#16a34a;margin-bottom:1rem}
.thanks-message h3{color:#15803d;margin-bottom:.6rem}
.thanks-message p{color:#166534}

/* === CONTACT PAGE === */
.contact-grid{
  display:grid;grid-template-columns:1fr 1.5fr;gap:3rem;align-items:start;
}
.contact-info{display:flex;flex-direction:column;gap:1rem}
.contact-card{
  display:flex;align-items:center;gap:1rem;
  padding:1.4rem;background:#fff;
  border-radius:14px;text-decoration:none;
  color:inherit;transition:all .3s var(--transition);
  border:1px solid #e5e7eb;
}
.contact-card:hover{
  transform:translateX(6px);
  box-shadow:0 8px 24px rgba(29,53,87,.10);
  border-color:var(--color-red);
}
.contact-card-icon{
  width:50px;height:50px;border-radius:12px;
  background:var(--color-red);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.contact-card strong{
  display:block;color:var(--color-blue-deep);
  font-size:.85rem;margin-bottom:.3rem;
  text-transform:uppercase;letter-spacing:.04em;font-weight:700;
}
.contact-card span{color:#6B7280;font-size:.95rem;font-weight:500}

.contact-form-wrapper{
  background:#fff;padding:2.5rem;border-radius:20px;
  box-shadow:0 12px 40px rgba(29,53,87,.10);
}
.contact-form-wrapper h3{
  font-size:1.5rem;color:var(--color-blue-deep);
  margin-bottom:1.5rem;font-family:'Montserrat',sans-serif;
}
.contact-form-wrapper .form-field{margin-bottom:1.25rem}

@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .contact-form-wrapper{padding:1.5rem}
}

/* RTL adjustments */
[dir="rtl"] .contact-card:hover{transform:translateX(-6px)}
[dir="rtl"] .cause-impacts{border-left:none;border-right:3px solid var(--color-red)}
[dir="rtl"] .thanks-message{border-left:none;border-right:5px solid #16a34a}
[dir="rtl"] .president-message,[dir="rtl"] .president-signature{text-align:right}

/* ============================================
   V6 ADDITIONS — Enriched timeline, partners showcase
   ============================================ */

/* === ENHANCED TIMELINE === */
.chrono-timeline {
  position: relative;
  max-width: 1100px;
  margin: 3rem auto;
  padding: 1rem 0;
}
.chrono-timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, #E63946 0%, #1D3557 50%, #06b6d4 100%);
  transform: translateX(-50%);
  border-radius: 4px;
}
.chrono-event {
  position: relative;
  width: 50%;
  padding: 1.5rem 2.5rem;
  margin-bottom: 2rem;
  box-sizing: border-box;
}
.chrono-event:nth-child(odd) {
  left: 0;
  text-align: right;
}
.chrono-event:nth-child(even) {
  left: 50%;
}
.chrono-event::before {
  content: '';
  position: absolute;
  width: 24px;
  height: 24px;
  background: white;
  border: 4px solid #E63946;
  border-radius: 50%;
  top: 1.7rem;
  z-index: 2;
  box-shadow: 0 4px 12px rgba(231,57,70,0.35);
}
.chrono-event:nth-child(odd)::before { right: -14px; }
.chrono-event:nth-child(even)::before { left: -14px; }
.chrono-card {
  background: white;
  padding: 1.4rem 1.7rem;
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(29,53,87,0.08);
  border-top: 4px solid transparent;
  transition: all .3s ease;
}
.chrono-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(29,53,87,0.15);
}
.chrono-event[data-category="ramadan"] .chrono-card { border-top-color: #a855f7; }
.chrono-event[data-category="tabaski"] .chrono-card { border-top-color: #10b981; }
.chrono-event[data-category="winter"] .chrono-card { border-top-color: #06b6d4; }
.chrono-event[data-category="education"] .chrono-card { border-top-color: #3b82f6; }
.chrono-event[data-category="infrastructure"] .chrono-card { border-top-color: #f59e0b; }
.chrono-event[data-category="founding"] .chrono-card { border-top-color: #E63946; }
.chrono-event[data-category="partnership"] .chrono-card { border-top-color: #ec4899; }

.chrono-date {
  display: inline-block;
  padding: .25rem .75rem;
  background: #1D3557;
  color: white;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .04em;
  border-radius: 8px;
  margin-bottom: .8rem;
  font-family: 'Montserrat', sans-serif;
}
.chrono-card h4 {
  color: #1D3557;
  font-size: 1.12rem;
  margin: .3rem 0 .6rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
}
.chrono-card p {
  color: #4b5563;
  font-size: .95rem;
  line-height: 1.65;
  margin: 0;
}
.chrono-card .partners-tag {
  display: inline-block;
  margin-top: .8rem;
  padding: .25rem .65rem;
  background: #fef2f2;
  color: #E63946;
  font-size: .76rem;
  font-weight: 600;
  border-radius: 6px;
}

/* Mobile timeline */
@media(max-width: 800px) {
  .chrono-timeline::before { left: 24px; }
  .chrono-event {
    width: 100%;
    left: 0 !important;
    text-align: left !important;
    padding-left: 60px;
    padding-right: 1rem;
  }
  .chrono-event::before {
    left: 12px !important;
    right: auto !important;
  }
}

/* RTL timeline mirror */
[dir="rtl"] .chrono-event:nth-child(odd) { text-align: left; }
[dir="rtl"] .chrono-event:nth-child(even) { text-align: right; }

/* === IMPACT NUMBERS BANNER === */
.impact-banner {
  background: linear-gradient(135deg, #1D3557 0%, #2d4a6f 100%);
  color: white;
  padding: 4rem 0;
  position: relative;
  overflow: hidden;
}
.impact-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' fill='%23ffffff' fill-opacity='0.04'><circle cx='30' cy='30' r='12'/><circle cx='70' cy='60' r='8'/><circle cx='15' cy='75' r='6'/></svg>");
  background-size: 200px 200px;
}
.impact-banner .container { position: relative; }
.impact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 2rem;
  text-align: center;
}
.impact-number {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(2.5rem, 5vw, 3.6rem);
  font-weight: 900;
  background: linear-gradient(135deg, #E63946, #ffadad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-bottom: .3rem;
  display: block;
  line-height: 1;
}
.impact-label {
  font-size: .92rem;
  letter-spacing: .04em;
  opacity: .9;
  text-transform: uppercase;
}

/* === PARTNERS LOGOS GRID === */
.partners-showcase {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1.2rem;
  margin: 2rem 0;
}
.partner-pill {
  background: white;
  padding: 1.2rem 1rem;
  border-radius: 14px;
  border: 2px solid #f3f4f6;
  text-align: center;
  font-weight: 700;
  color: #1D3557;
  font-size: .9rem;
  transition: all .25s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100px;
  line-height: 1.3;
}
.partner-pill:hover {
  border-color: #E63946;
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(231,57,70,0.15);
}

/* === HERO SLIDESHOW IMPROVEMENTS === */
.hero-bullet {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .4rem .9rem;
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 100px;
  margin: .25rem;
  font-size: .82rem;
  color: white;
}
.hero-bullet i { color: #ffadad; }


/* ============================================
   V6 — ENRICHED EVENT TIMELINE WITH PHOTOS
   ============================================ */

.ev-timeline {
  position: relative;
  max-width: 1100px;
  margin: 2rem auto;
  padding: 1rem 0 2rem;
}
.ev-timeline::before {
  content: '';
  position: absolute;
  left: 32px;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, #E63946 0%, #1D3557 50%, #06b6d4 100%);
  border-radius: 4px;
}

.ev-card {
  position: relative;
  margin: 0 0 2.5rem 0;
  padding-left: 80px;
  display: block;
}
.ev-card .ev-marker {
  position: absolute;
  left: 18px;
  top: 1.5rem;
  width: 32px;
  height: 32px;
  border: 5px solid #E63946;
  background: white;
  border-radius: 50%;
  z-index: 2;
  box-shadow: 0 4px 14px rgba(231,57,70,0.4);
}
.ev-card[data-category="ramadan"] .ev-marker { border-color: #a855f7; box-shadow: 0 4px 14px rgba(168,85,247,0.4); }
.ev-card[data-category="tabaski"] .ev-marker { border-color: #10b981; box-shadow: 0 4px 14px rgba(16,185,129,0.4); }
.ev-card[data-category="winter"] .ev-marker { border-color: #06b6d4; box-shadow: 0 4px 14px rgba(6,182,212,0.4); }
.ev-card[data-category="education"] .ev-marker { border-color: #3b82f6; box-shadow: 0 4px 14px rgba(59,130,246,0.4); }
.ev-card[data-category="infrastructure"] .ev-marker { border-color: #f59e0b; box-shadow: 0 4px 14px rgba(245,158,11,0.4); }
.ev-card[data-category="founding"] .ev-marker { border-color: #E63946; box-shadow: 0 4px 14px rgba(231,57,70,0.5); }
.ev-card[data-category="partnership"] .ev-marker { border-color: #ec4899; box-shadow: 0 4px 14px rgba(236,72,153,0.4); }

.ev-content {
  background: white;
  border-radius: 18px;
  padding: 2rem 2.2rem;
  box-shadow: 0 12px 36px rgba(29,53,87,0.08);
  border-top: 5px solid transparent;
  transition: all .3s ease;
}
.ev-card:hover .ev-content {
  transform: translateY(-3px);
  box-shadow: 0 18px 48px rgba(29,53,87,0.14);
}
.ev-card[data-category="ramadan"] .ev-content { border-top-color: #a855f7; }
.ev-card[data-category="tabaski"] .ev-content { border-top-color: #10b981; }
.ev-card[data-category="winter"] .ev-content { border-top-color: #06b6d4; }
.ev-card[data-category="education"] .ev-content { border-top-color: #3b82f6; }
.ev-card[data-category="infrastructure"] .ev-content { border-top-color: #f59e0b; }
.ev-card[data-category="founding"] .ev-content { border-top-color: #E63946; }
.ev-card[data-category="partnership"] .ev-content { border-top-color: #ec4899; }

.ev-date {
  display: inline-block;
  padding: .35rem .9rem;
  background: linear-gradient(135deg, #1D3557, #2d4a6f);
  color: white;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .04em;
  border-radius: 8px;
  margin-bottom: .9rem;
  font-family: 'Montserrat', sans-serif;
}

.ev-title {
  color: #1D3557;
  font-size: 1.55rem;
  margin: 0 0 1rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  line-height: 1.25;
}

.ev-narrative {
  color: #374151;
  line-height: 1.75;
  font-size: 1.005rem;
  margin-bottom: 1.2rem;
}
.ev-narrative p { margin: 0 0 1rem; }
.ev-narrative p:last-child { margin-bottom: 0; }
.ev-narrative ul { margin: .6rem 0 1rem 1.4rem; }
.ev-narrative li { margin-bottom: .4rem; }
.ev-narrative strong { color: #1D3557; }
.ev-narrative em { color: #E63946; font-style: italic; font-weight: 600; }

.ev-partners {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  background: #fef2f2;
  color: #1D3557;
  padding: .6rem 1.1rem;
  border-radius: 10px;
  font-size: .9rem;
  margin-top: .5rem;
  margin-bottom: 1.2rem;
  border-left: 4px solid #E63946;
  flex-wrap: wrap;
}
.ev-partners i { color: #E63946; }
.ev-partners strong { color: #1D3557; font-weight: 600; }

[dir="rtl"] .ev-partners {
  border-left: none;
  border-right: 4px solid #E63946;
}

.ev-photos {
  margin-top: 1.5rem;
  border-top: 1px dashed #e5e7eb;
  padding-top: 1.5rem;
}
.ev-photos-label {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .08em;
  color: #6b7280;
  text-transform: uppercase;
  margin: 0 0 1rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.ev-photos-label i { color: #E63946; }

.ev-photos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: .7rem;
}
.ev-photo {
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 1;
  background: #f3f4f6;
  cursor: pointer;
  transition: all .3s ease;
}
.ev-photo:hover { transform: scale(1.04); }
.ev-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.ev-photo:hover img { transform: scale(1.08); }

@media (max-width: 720px) {
  .ev-timeline::before { left: 18px; }
  .ev-card { padding-left: 50px; }
  .ev-card .ev-marker { left: 4px; width: 24px; height: 24px; border-width: 4px; }
  .ev-content { padding: 1.4rem 1.3rem; }
  .ev-title { font-size: 1.25rem; }
}

[dir="rtl"] .ev-timeline::before { left: auto; right: 32px; }
[dir="rtl"] .ev-card { padding-left: 0; padding-right: 80px; }
[dir="rtl"] .ev-card .ev-marker { left: auto; right: 18px; }
@media (max-width: 720px) {
  [dir="rtl"] .ev-timeline::before { right: 18px; }
  [dir="rtl"] .ev-card { padding-right: 50px; }
  [dir="rtl"] .ev-card .ev-marker { right: 4px; }
}
