
:root {
  --blue:      #4A90E2;
  --blue-mid:  #5BA0E5;
  --blue-pale: #EAF3FB;
  --teal:      #00CC66;
  --teal-mid:  #00A855;
  --teal-pale: rgba(0, 204, 102, 0.1);
  --teal-acc:  #00CC66;
  --gray-900:  #1C1C1E;
  --gray-600:  #4A4A50;
  --gray-400:  #8E8E96;
  --gray-100:  #F5F5F3;
  --gray-50:   #FAFAF8;
  --border:    #E4E4E0;
  --white:     #FFFFFF;
}




/* ─── PAGE HERO ─── */
.page-hero {
  background: var(--blue);
  padding: clamp(10rem, 15vw, 12rem) clamp(1.5rem, 5vw, 4rem) clamp(3rem, 6vw, 5rem);
  position: relative; overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  text-align: center;
  min-height: 50vh;
}
.page-hero::before {
  content: ''; position: absolute; right: -8%; top: -40%;
  width: 50%; padding-bottom: 50%; border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.05); pointer-events: none;
}
.breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 0.75rem; color: rgba(255,255,255,0.35); margin-bottom: 1.5rem; }
.breadcrumb a { color: rgba(255,255,255,0.35); text-decoration: none; transition: color .15s; }
.breadcrumb a:hover { color: rgba(255,255,255,0.7); }
.breadcrumb-current { color: rgba(255,255,255,0.65); }
.page-hero-kicker { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--teal-acc); margin-bottom: 1rem; display: flex; align-items: center; justify-content: center; gap: 7px; }
.page-hero-kicker::before, .page-hero-kicker::after { content: ''; width: 20px; height: 1.5px; background: var(--teal-acc); display: block; }
.page-hero h1 { font-family: 'Playfair Display', serif; font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 400; line-height: 1.2; color: var(--white); letter-spacing: -0.02em; margin-bottom: 1rem; max-width: 620px; }
.page-hero-sub { font-size: 0.95rem; font-weight: 300; line-height: 1.75; color: rgba(255,255,255,0.6); max-width: 540px; }

/* ─── COMPTEUR ─── */
.projets-count { background: var(--gray-100); border-bottom: 1px solid var(--border); display: grid; grid-template-columns: repeat(4, 1fr); }
.count-item { padding: 22px 5%; text-align: center; border-right: 1px solid var(--border); }
.count-item:last-child { border-right: none; }
.count-n { font-family: 'Playfair Display', serif; font-size: 2rem; color: var(--blue); margin-bottom: 3px; }
.count-l { font-size: 0.95rem; font-weight: 500; color: var(--gray-600); }

/* ─── SECTION LABEL ─── */
.section-wrap { padding: clamp(3rem, 6vw, 5rem) clamp(1.5rem, 5vw, 4rem); }
.section-wrap.tight { padding-bottom: 0; }
.section-label { display: flex; align-items: center; gap: 12px; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--teal); margin-bottom: 2.5rem; }
.section-label::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.pill { padding: 3px 10px; border-radius: 100px; font-size: 0.68rem; font-weight: 500; }
.pill.actif { background: var(--teal-pale); color: var(--teal); }
.pill.new { background: var(--blue-pale); color: var(--blue); }
.pill.done { background: var(--gray-100); color: var(--gray-400); }
.pill.event { background: #FFF3E0; color: #E65100; }

/* ─── CARTE MOUSA (grande, 2 volets) ─── */
.mousa-card {
  border: 1px solid var(--border); border-radius: 16px; overflow: hidden;
  margin-bottom: 16px;
  transition: box-shadow .2s;
}
.mousa-card:hover { box-shadow: 0 8px 32px rgba(74,144,226,0.08); }

/* Header carte Mousa */
.mousa-header {
  display: grid; grid-template-columns: 380px 1fr;
  min-height: 320px;
}
.mousa-photo {
  position: relative; overflow: hidden;
  background: var(--blue);
}
.mousa-photo img {
  width: 100%; height: 100%; object-fit: cover; object-position: center 15%;
  display: block; transition: transform .5s ease; filter: brightness(0.85);
}
.mousa-card:hover .mousa-photo img { transform: scale(1.03); }
.mousa-photo-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(74,144,226,0.35) 0%, transparent 65%); }
.mousa-photo-label {
  position: absolute; bottom: 16px; left: 16px;
  font-size: 0.72rem; color: rgba(255,255,255,0.85);
  background: rgba(74,144,226,0.6); backdrop-filter: blur(4px);
  padding: 4px 10px; border-radius: 100px;
}
.mousa-intro {
  padding: 32px 32px 24px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.mousa-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.projet-status { font-size: 0.65rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.07em; padding: 4px 10px; border-radius: 100px; }
.projet-status.actif { background: var(--teal-pale); color: var(--teal); }
.projet-type { font-size: 0.72rem; color: var(--gray-400); }
.mousa-name {
  font-family: 'Playfair Display', serif; font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 400; line-height: 1.15; color: var(--gray-900);
  letter-spacing: -0.01em; margin-bottom: 10px;
}
.mousa-name em { font-style: italic; color: var(--blue); }
.mousa-tagline {
  font-size: 1rem; line-height: 1.7; color: var(--gray-600);
  margin-bottom: 18px;
}
.mousa-person { display: flex; align-items: center; gap: 10px; }
.person-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--blue-pale); display: flex; align-items: center; justify-content: center; font-family: 'Playfair Display', serif; font-size: 0.9rem; color: var(--blue); flex-shrink: 0; }
.person-name { font-size: 0.85rem; font-weight: 500; color: var(--gray-900); }
.person-role { font-size: 0.75rem; color: var(--gray-400); }

/* Les deux volets en bas */
.mousa-volets {
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--border);
}
.volet {
  padding: 24px 28px;
  position: relative;
}
.volet + .volet { border-left: 1px solid var(--border); }
.volet-icon {
  width: 32px; height: 32px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 12px;
}
.volet-icon.blue { background: var(--blue-pale); }
.volet-icon.teal { background: var(--teal-pale); }
.volet-icon svg { width: 16px; height: 16px; }
.volet-title { font-size: 1.1rem; font-weight: 500; color: var(--gray-900); margin-bottom: 8px; }
.volet-desc { font-size: 0.95rem; line-height: 1.7; color: var(--gray-600); margin-bottom: 12px; }
.volet-items { display: flex; flex-direction: column; gap: 4px; }
.volet-item { display: flex; align-items: flex-start; gap: 7px; font-size: 0.9rem; color: var(--gray-600); line-height: 1.5; }
.volet-item::before { content: ''; width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; margin-top: 6px; }
.volet.blue .volet-item::before { background: var(--blue); }
.volet.teal .volet-item::before { background: var(--teal-mid); }

/* ─── GRILLE PROJETS SECONDAIRES ─── */
.projets-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.projet-card {
  border: 1px solid var(--border); border-radius: 14px; overflow: hidden;
  display: flex; flex-direction: column;
  transition: box-shadow .2s, transform .15s;
}
.projet-card:hover { box-shadow: 0 6px 24px rgba(74,144,226,0.07); transform: translateY(-1px); }

.projet-photo-wrap {
  height: 200px; position: relative; overflow: hidden;
  background: var(--blue);
}
.projet-photo-wrap img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  display: block; transition: transform .5s ease; filter: brightness(0.87);
}
.projet-card:hover .projet-photo-wrap img { transform: scale(1.04); }
.projet-photo-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(74,144,226,0.5) 0%, transparent 60%); }
.projet-photo-num { position: absolute; top: 14px; left: 14px; font-family: 'Playfair Display', serif; font-size: 2.2rem; color: rgba(255,255,255,0.12); line-height: 1; }

.projet-content { padding: 22px 24px; flex: 1; display: flex; flex-direction: column; }
.projet-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.projet-title { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 400; line-height: 1.25; color: var(--gray-900); margin-bottom: 8px; }
.projet-desc { font-size: 0.95rem; line-height: 1.7; color: var(--gray-600); flex: 1; margin-bottom: 16px; }
.projet-footer { padding-top: 14px; border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
.projet-tag { font-size: 0.72rem; font-weight: 500; color: var(--blue); background: var(--blue-pale); padding: 4px 10px; border-radius: 100px; }
.projet-tag.teal { color: var(--teal); background: var(--teal-pale); }

/* ─── ÉVÉNEMENTS SOLIDAIRES ─── */
.events-section {
  background: var(--gray-50);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.events-inner { padding: clamp(3rem, 6vw, 5rem) clamp(1.5rem, 5vw, 4rem); }
.events-head {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem); align-items: start;
  margin-bottom: 2.5rem;
}
.events-kicker { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--teal-mid); margin-bottom: 0.75rem; }
.events-title { font-family: 'Playfair Display', serif; font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 400; line-height: 1.25; color: var(--gray-900); letter-spacing: -0.01em; }
.events-sub { font-size: 0.88rem; line-height: 1.75; color: var(--gray-600); }

/* Grille photos événements */
.events-photos {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 220px 160px;
  gap: 4px;
  border-radius: 12px; overflow: hidden;
  margin-bottom: 2rem;
}
.event-photo {
  position: relative; overflow: hidden; background: var(--blue);
  cursor: default;
}
.event-photo.large { grid-column: span 2; }
.event-photo img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  display: block; transition: transform .5s ease; filter: brightness(0.82);
}
.event-photo:hover img { transform: scale(1.04); }
.event-photo-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(74,144,226,0.75));
  padding: 24px 14px 12px;
  font-size: 0.75rem; color: rgba(255,255,255,0.9); font-weight: 500;
}

/* Liste événements */
.events-list {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
}
.event-item {
  background: var(--white); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px;
  display: flex; flex-direction: column; gap: 6px;
}
.event-icon { font-size: 1.1rem; line-height: 1; }
.event-name { font-size: 0.85rem; font-weight: 500; color: var(--gray-900); }
.event-freq { font-size: 0.75rem; color: var(--gray-400); }
.event-impact { font-size: 0.78rem; color: var(--teal); font-weight: 500; margin-top: 4px; }

/* ─── PROJETS RÉALISÉS ─── */
.realises-section { border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.realises-list { display: flex; flex-direction: column; }
.realise-row {
  display: grid; grid-template-columns: 24px 1fr auto;
  gap: 16px; align-items: center;
  padding: 18px clamp(1.5rem, 5vw, 4rem);
  border-bottom: 1px solid var(--border); transition: background .15s;
}
.realise-row:last-child { border-bottom: none; }
.realise-row:hover { background: var(--gray-50); }
.realise-check { width: 20px; height: 20px; border-radius: 50%; background: var(--teal-pale); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.realise-check svg { width: 10px; height: 10px; }
.realise-title { font-size: 0.9rem; font-weight: 500; color: var(--gray-900); margin-bottom: 2px; }
.realise-desc { font-size: 0.8rem; color: var(--gray-600); line-height: 1.5; }
.realise-year { font-size: 0.75rem; color: var(--gray-400); white-space: nowrap; }

/* ─── VISION ─── */
.vision-section { padding: clamp(3rem, 6vw, 5rem) clamp(1.5rem, 5vw, 4rem); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.vision-kicker { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--teal-mid); margin-bottom: 1rem; }
.vision-title { font-family: 'Playfair Display', serif; font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 400; line-height: 1.25; color: var(--gray-900); letter-spacing: -0.01em; margin-bottom: 1.25rem; }
.vision-text { font-size: 0.9rem; line-height: 1.8; color: var(--gray-600); margin-bottom: 1rem; }
.vision-right { display: flex; flex-direction: column; gap: 10px; }
.vision-card { background: var(--gray-50); border: 1px solid var(--border); border-radius: 12px; padding: 18px 20px; }
.vision-card-horizon { font-size: 0.68rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.07em; color: var(--gray-400); margin-bottom: 6px; }
.vision-card-title { font-size: 0.9rem; font-weight: 500; color: var(--gray-900); margin-bottom: 8px; }
.vision-card-items { display: flex; flex-direction: column; gap: 4px; }
.vision-card-item { display: flex; align-items: flex-start; gap: 7px; font-size: 0.8rem; color: var(--gray-600); line-height: 1.45; }
.vision-card-item::before { content: ''; width: 4px; height: 4px; border-radius: 50%; background: var(--blue); flex-shrink: 0; margin-top: 7px; }

/* ─── CTA FINAL ─── */
.cta-section { background: var(--blue); padding: clamp(3rem, 6vw, 5rem) clamp(1.5rem, 5vw, 4rem); display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: center; }
.cta-kicker { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--teal-acc); margin-bottom: 0.75rem; }
.cta-title { font-family: 'Playfair Display', serif; font-size: clamp(1.4rem, 2.5vw, 2rem); font-weight: 400; color: var(--white); line-height: 1.2; margin-bottom: 0.75rem; }
.cta-sub { font-size: 0.88rem; font-weight: 300; color: rgba(255,255,255,0.6); line-height: 1.65; max-width: 480px; }
.cta-right { display: flex; gap: 10px; flex-shrink: 0; }
.btn-main { font-size: 0.88rem; font-weight: 500; background: var(--white); color: var(--blue); padding: 12px 24px; border-radius: 8px; text-decoration: none; display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; }
.btn-sec { font-size: 0.88rem; color: rgba(255,255,255,0.7); background: transparent; border: 1px solid rgba(255,255,255,0.25); padding: 12px 20px; border-radius: 8px; text-decoration: none; white-space: nowrap; }

/* ─── RESPONSIVE ─── */
@media (max-width: 960px) {
  .mousa-header { grid-template-columns: 1fr; grid-template-rows: 260px auto; }
  .projets-grid { grid-template-columns: 1fr; }
  .events-head { grid-template-columns: 1fr; }
  .events-photos { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 160px; }
  .event-photo.large { grid-column: span 2; }
  .events-list { grid-template-columns: repeat(2,1fr); }
  .vision-section { grid-template-columns: 1fr; }
  .cta-section { grid-template-columns: 1fr; }
  .cta-right { flex-direction: column; align-items: flex-start; }
  .projets-count { grid-template-columns: repeat(2,1fr); }
  .footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .nav-links { display: none; }
  .mousa-volets { grid-template-columns: 1fr; }
  .volet + .volet { border-left: none; border-top: 1px solid var(--border); }
  .events-photos { grid-template-columns: 1fr; grid-template-rows: repeat(3, 180px); }
  .event-photo.large { grid-column: span 1; }
  .events-list { grid-template-columns: repeat(2,1fr); }
  .realise-row { grid-template-columns: 24px 1fr; }
  .realise-year { display: none; }
  .projets-count { grid-template-columns: repeat(2,1fr); }
  .footer-top { grid-template-columns: 1fr; gap: 2rem; }
}
