/* ============================================
   L'équipe — Revue intellectuelle
   Parti-pris : monochrome, accent bleu rare
   ============================================ */

/* ── Hero — pattern projet (cohérence visuelle avec le-projet.html) ── */
.equipe-hero {
  padding: calc(var(--nav-height, 80px) + 6rem) 1.5rem 5rem;
  text-align: center;
  background: var(--color-bg-alt);
  border-bottom: 1px solid var(--border);
}
.equipe-hero .breadcrumb {
  justify-content: center;
  margin-bottom: 3rem;
  color: var(--body);
  font-size: .8rem;
}
.equipe-hero .breadcrumb a { color: var(--body); }
.equipe-hero .breadcrumb a:hover { color: var(--navy); }
.equipe-hero .breadcrumb .sep { color: var(--body); opacity: .55; }
.equipe-hero-inner {
  max-width: 760px;
  margin: 0 auto;
}
.equipe-hero .eyebrow {
  display: inline-block;
  font-family: var(--font-display);
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--navy);
  margin-bottom: 1.5rem;
  position: relative;
  padding-left: 1.85rem;
}
.equipe-hero .eyebrow::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 1.25rem;
  height: 1px;
  background: var(--color-accent);
  transform: translateY(-50%);
}
.equipe-hero h1 {
  font-family: var(--font-heading);
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 700;
  color: var(--navy);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 1.5rem;
}
.equipe-h1-accent {
  display: block;
  color: var(--navy);
  font-style: italic;
  font-weight: 500;
}
.equipe-hero h1::after {
  content: '';
  display: block;
  width: 48px;
  height: 2px;
  background: var(--color-accent);
  margin: 1.5rem auto 0;
}
.equipe-hero .hero-desc {
  font-family: var(--font-body);
  font-size: 1.15rem;
  color: var(--body);
  line-height: 1.7;
  max-width: 540px;
  margin: 0 auto;
}

/* ── Citation Rousseau — bloc éditorial plein-écran sur navy-deep ── */
.equipe-citation {
  padding: 5rem 1.5rem;
  text-align: center;
  background: var(--navy-deep);
  position: relative;
  overflow: hidden;
}
.equipe-citation::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(45, 91, 215,.08) 0%, transparent 70%);
  pointer-events: none;
}
.equipe-citation-inner {
  max-width: 680px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.equipe-citation blockquote {
  font-family: var(--font-heading);
  font-size: clamp(1.35rem, 2.8vw, 1.75rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1.7;
  color: rgba(255,255,255,.92);
  border: none;
  border-radius: 0;
  background: none;
  padding: 0;
  margin: 0 0 1.75rem;
  position: relative;
}
.equipe-citation blockquote::before {
  content: '';
  display: block;
  width: 40px;
  height: 2px;
  background: var(--color-accent);
  margin: 0 auto 2rem;
}
.equipe-citation cite {
  display: block;
  font-size: .8rem;
  font-style: normal;
  color: rgba(255,255,255,.45);
  font-family: var(--font-display);
  letter-spacing: .06em;
  text-transform: uppercase;
}
.equipe-citation cite em {
  text-transform: none;
  font-style: italic;
  letter-spacing: .02em;
}

/* ── Rythme des sections ── */
.section {
  padding: 4.5rem 0;
}

/* ── Section headers ── */
.equipe-section-header {
  margin-bottom: 3rem;
  max-width: 780px;
}
.equipe-section-header--center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
.equipe-section-label {
  display: inline-block;
  font-family: var(--font-display);
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .22em;
  color: var(--body);
  margin-bottom: 1.25rem;
}
.equipe-section-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 3.6vw, 2.8rem);
  font-weight: 500;
  font-style: normal;
  color: var(--ink);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0 0 1.1rem;
}
.equipe-section-desc {
  font-family: var(--font-body);
  font-size: 1.02rem;
  color: var(--body);
  line-height: 1.75;
  max-width: 620px;
  margin: 0;
}
.equipe-section-header--center .equipe-section-desc {
  margin: 0 auto;
}

/* ── Grille des membres ── */
.equipe-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, 220px);
  gap: 2.75rem 1.5rem;
  justify-content: center;
}

/* ── Carte membre — épurée ── */
.equipe-card {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  text-align: center;
}
.equipe-card[data-bio] {
  cursor: pointer;
}

/* Avatar circulaire avec filtre signature */
.equipe-card-avatar {
  width: 132px;
  height: 132px;
  border-radius: 50%;
  background: var(--bg-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--navy);
  font-family: var(--font-display);
  overflow: hidden;
  border: 1px solid var(--border);
}
.equipe-card-avatar picture,
.equipe-card-avatar img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.equipe-card-avatar img {
  filter: grayscale(35%) contrast(1.05) sepia(8%);
  transition: filter .4s ease;
  object-position: 50% 22%;
}
.equipe-card:hover .equipe-card-avatar img {
  filter: none;
}

.equipe-card h3 {
  font-family: var(--font-heading);
  font-size: 1.18rem;
  font-weight: 500;
  font-style: normal;
  color: var(--ink);
  margin: 0 0 .35rem;
  line-height: 1.25;
  letter-spacing: -0.005em;
  transition: color .3s ease;
}
.equipe-card:hover h3 {
  color: var(--navy-deep);
}

.equipe-card-role {
  font-family: var(--font-display);
  font-size: .68rem;
  font-weight: 600;
  color: var(--body);
  text-transform: uppercase;
  letter-spacing: .14em;
  line-height: 1.55;
  margin: 0 auto;
  min-height: 2.6em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.equipe-card-desc {
  font-family: var(--font-body);
  font-size: .85rem;
  color: var(--body);
  line-height: 1.6;
  margin-top: .75rem;
}

/* Neutralise le faux bouton injecté par le JS */
.equipe-card-more {
  display: none;
}

.equipe-card-link {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-family: var(--font-display);
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--ink);
  margin-top: .85rem;
  text-decoration: none;
  border-bottom: 1px solid var(--border);
  padding-bottom: 2px;
  transition: border-color .25s ease;
}
.equipe-card-link::after {
  content: '\2192';
  letter-spacing: 0;
  transition: transform .25s ease;
}
.equipe-card-link:hover {
  border-color: var(--ink);
}
.equipe-card-link:hover::after {
  transform: translateX(3px);
}

.equipe-card-linkedin {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-family: var(--font-display);
  font-size: .65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--body);
  text-decoration: none;
  margin-top: .65rem;
  transition: color .2s ease;
}
.equipe-card-linkedin:hover { color: var(--ink); }
.equipe-card-linkedin svg { width: 14px; height: 14px; flex-shrink: 0; }

/* ── Président — première position, taille standard ── */
#nicolas-dufrene {
  order: -1;
}

/* ── Badge "Président" placé au-dessus du nom ── */
.equipe-badge {
  display: inline-block;
  font-family: var(--font-display);
  font-size: .6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .16em;
  padding: .25rem .6rem;
  border-radius: 999px;
  margin: 0 auto .55rem;
  line-height: 1;
}
.equipe-badge--president {
  color: var(--navy);
  background: rgba(45, 91, 215, .12);
  border: 1px solid rgba(45, 91, 215, .32);
}

/* ── Directions d'études — grille aérée 3 + 2 ── */
/* Desktop : 3 cartes en haut, 2 centrées en dessous (via 6 colonnes).
   Tablette : 2 colonnes. Mobile : 1 colonne. */
.equipe-pillars {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1.75rem;
}
.equipe-pillar {
  position: relative;
  display: block;
  grid-column: span 2;
  padding: 2.25rem 2rem 2rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
/* Dernière rangée : 2 cartes centrées sur la grille de 6 colonnes */
.equipe-pillar:nth-child(4) { grid-column: 2 / span 2; }
.equipe-pillar:nth-child(5) { grid-column: 4 / span 2; }

/* Filet de couleur vertical à gauche, signature de chaque pôle */
.equipe-pillar::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: currentColor;
  opacity: 0;
  transition: opacity var(--transition);
}
.equipe-pillar--droit::after   { background: var(--color-institutions); }
.equipe-pillar--eco::after     { background: var(--color-economie); }
.equipe-pillar--societe::after { background: var(--color-international); }
.equipe-pillar--social::after  { background: var(--color-social); }
.equipe-pillar--culture::after { background: var(--color-culture); }

.equipe-pillar:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-md);
  border-color: var(--navy);
}
.equipe-pillar:hover::after { opacity: 1; }
.equipe-pillar:focus-visible {
  outline: 2px solid var(--navy);
  outline-offset: 4px;
}
.equipe-pillar-dot {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-bottom: 1.25rem;
  background: var(--steel);
}
.equipe-pillar--droit  .equipe-pillar-dot { background: var(--color-institutions); }
.equipe-pillar--eco    .equipe-pillar-dot { background: var(--color-economie); }
.equipe-pillar--societe .equipe-pillar-dot { background: var(--color-international); }
.equipe-pillar--social  .equipe-pillar-dot { background: var(--color-social); }
.equipe-pillar--culture .equipe-pillar-dot { background: var(--color-culture); }

.equipe-pillar-body {
  position: relative;
}
.equipe-pillar h3 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 600;
  font-style: normal;
  letter-spacing: -0.01em;
  margin: 0 0 .65rem;
  line-height: 1.3;
  color: var(--ink);
  text-transform: none;
  display: flex;
  align-items: center;
  gap: .65rem;
  flex-wrap: wrap;
}
.equipe-pillar-badge {
  display: inline-block;
  font-family: var(--font-display);
  font-size: .62rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--navy);
  background: rgba(45, 91, 215, .18);
  border: 1px solid rgba(45, 91, 215, .35);
  padding: .25rem .55rem;
  border-radius: 999px;
  white-space: nowrap;
}
.equipe-pillar:hover h3 { color: var(--navy-deep); }
.equipe-pillar p {
  font-family: var(--font-body);
  font-size: .92rem;
  color: var(--body);
  line-height: 1.7;
  margin: 0;
}

/* ── Conseil scientifique — onglets desktop / blocs empilés mobile ── */
.equipe-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: .15rem;
  margin: 0 0 2.5rem;
  padding: 0 0 .25rem;
  border-bottom: 1px solid var(--border);
}
.equipe-tab {
  appearance: none;
  background: none;
  border: 0;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  padding: .8rem .6rem;
  font-family: var(--font-display);
  font-size: .78rem;
  font-weight: 600;
  color: var(--body);
  letter-spacing: .015em;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  transition: color var(--transition), border-color var(--transition);
  white-space: nowrap;
  flex: 0 1 auto;
  min-width: 0;
}
.equipe-tab:hover { color: var(--ink); }
.equipe-tab[aria-selected="true"] {
  color: var(--navy);
  border-bottom-color: var(--navy);
}
.equipe-tab:focus-visible {
  outline: 2px solid var(--navy);
  outline-offset: 2px;
  border-radius: 4px;
}
.equipe-tab-count {
  display: inline-block;
  font-family: var(--font-display);
  font-size: .68rem;
  font-weight: 600;
  color: var(--body);
  background: var(--bg-alt);
  padding: .15rem .45rem;
  border-radius: 999px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.equipe-tab[aria-selected="true"] .equipe-tab-count {
  background: var(--ice);
  color: var(--navy);
}
.equipe-tab-count--soft {
  font-style: italic;
  letter-spacing: 0;
  text-transform: none;
}

/* Onglets : on garde une seule ligne même sur écrans laptop standard */
@media (max-width: 1100px) {
  .equipe-tab {
    padding: .7rem .45rem;
    font-size: .72rem;
    gap: .35rem;
  }
  .equipe-tab-count {
    font-size: .62rem;
    padding: .12rem .38rem;
  }
}

.equipe-cs-panel {
  padding: 1.5rem 0 2rem;
  animation: equipeCsFade .35s ease;
}
.equipe-cs-panel[hidden] { display: none; }
.equipe-cs-panel-title {
  font-family: var(--font-heading);
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 1.5rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
}
.equipe-cs-panel-empty {
  font-family: var(--font-body);
  color: var(--body);
  font-style: italic;
  padding: 1rem 0;
}
@keyframes equipeCsFade {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .equipe-cs-panel { animation: none; }
}

/* ── Intro éditoriale ── */
.equipe-intro {
  padding: 4rem 1.5rem;
  background: var(--white);
}
.equipe-intro-inner {
  max-width: 720px;
  margin: 0 auto;
}
.equipe-intro p {
  font-family: var(--font-body);
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--body);
  margin: 0;
}
.equipe-intro p strong { color: var(--ink); font-weight: 600; }
.equipe-intro p a {
  color: var(--navy);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.equipe-intro p a:hover { color: var(--blue); }

/* ── Stats — bandeau clair (5 cellules équilibrées) ── */
.equipe-stats {
  background: var(--bg-alt);
  color: var(--ink);
  padding: 3.5rem 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.equipe-stats-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  text-align: center;
  align-items: center;
}
.equipe-stats-grid > div {
  position: relative;
  padding: 1rem 1rem;
}
.equipe-stats-grid > div + div::before {
  content: '';
  position: absolute;
  left: 0;
  top: 22%;
  bottom: 22%;
  width: 1px;
  background: rgba(30, 41, 59, .12);
}
.equipe-stats-grid .equipe-stat-number {
  font-size: clamp(2.4rem, 4vw, 3.4rem);
}
.equipe-stat-number {
  font-family: var(--font-heading);
  font-weight: 500;
  font-style: normal;
  color: var(--ink);
  line-height: 1;
  margin-bottom: .85rem;
  letter-spacing: -0.02em;
}
.equipe-stat-label {
  font-family: var(--font-display);
  font-size: .68rem;
  font-weight: 600;
  color: var(--body);
  text-transform: uppercase;
  letter-spacing: .22em;
  line-height: 1.5;
}

/* ── Bandeau « Le réseau » — fond clair, texte + chiffres ── */
.equipe-network {
  background: var(--color-bg-alt);
  padding: 4.5rem 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.equipe-network-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 3rem;
  align-items: center;
}
.equipe-network-eyebrow {
  display: inline-block;
  font-family: var(--font-display);
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--navy);
  margin-bottom: 1rem;
  position: relative;
  padding-left: 1.85rem;
}
.equipe-network-eyebrow::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 1.25rem;
  height: 1px;
  background: var(--color-accent);
  transform: translateY(-50%);
}
.equipe-network-text h2 {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 600;
  color: var(--navy);
  line-height: 1.2;
  letter-spacing: -0.015em;
  margin: 0 0 1.25rem;
}
.equipe-network-text > p {
  font-family: var(--font-body);
  font-size: 1.02rem;
  color: var(--body);
  line-height: 1.75;
  margin: 0 0 1.5rem;
}
.equipe-network-links {
  display: flex;
  gap: 1.75rem;
  flex-wrap: wrap;
  font-family: var(--font-display);
  font-size: .9rem;
  font-weight: 600;
}
.equipe-network .equipe-network-links a,
.equipe-network .equipe-network-links a:visited {
  color: var(--navy);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color var(--transition), border-color var(--transition);
}
.equipe-network .equipe-network-links a:hover {
  color: var(--blue);
  border-bottom-color: currentColor;
}

.equipe-network-stats {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem 2rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem 1.75rem;
}
.equipe-network-stats li { padding: 0; }
.equipe-network-num {
  display: block;
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 500;
  color: var(--navy);
  line-height: 1;
  margin-bottom: .5rem;
  letter-spacing: -0.02em;
}
.equipe-network-num--text {
  font-size: clamp(1.35rem, 2.2vw, 1.7rem);
  font-style: italic;
  font-weight: 600;
}
.equipe-network-label {
  display: block;
  font-family: var(--font-display);
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--body);
  line-height: 1.45;
}

@media (max-width: 900px) {
  .equipe-network { padding: 3rem 0; }
  .equipe-network-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .equipe-network-stats { padding: 1.5rem 1.25rem; }
}
@media (max-width: 480px) {
  .equipe-network-stats {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
}

/* ── FAQ — réutilise .faq-item / .faq-question / .faq-answer ── */
.equipe-faq {
  padding: 5rem 0;
  background: var(--white);
}
.equipe-faq .equipe-section-header {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2.5rem;
}
.equipe-faq .faq-answer-inner a {
  color: var(--navy);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.equipe-faq .faq-answer-inner a:hover { color: var(--blue); }
@media (max-width: 900px) {
  .equipe-faq { padding: 3rem 0; }
}

/* ── CTA — fond navy, 2 boutons + 1 lien tertiaire ── */
.equipe-cta .btn-terra {
  background: var(--color-accent);
}
.equipe-cta .btn-terra:hover {
  background: var(--color-accent-hover);
}
.equipe-cta {
  padding: 5rem 1.5rem;
  text-align: center;
  background: var(--navy-deep);
  color: var(--text-light-on-dark);
}
.equipe-cta-inner {
  max-width: 620px;
  margin: 0 auto;
}
.equipe-cta h2 {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 600;
  font-style: normal;
  color: #fff;
  margin: 0 0 .85rem;
  letter-spacing: -0.015em;
  line-height: 1.2;
}
.equipe-cta-desc {
  font-family: var(--font-body);
  font-size: 1rem;
  color: rgba(255, 255, 255, .65);
  line-height: 1.7;
  margin: 0 0 2.25rem;
  max-width: 480px;
  margin-inline: auto;
}
.equipe-cta-buttons {
  display: flex;
  gap: .85rem;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
.equipe-cta-link {
  font-family: var(--font-display);
  font-size: .9rem;
  font-weight: 600;
  color: rgba(255, 255, 255, .82);
  text-decoration: none;
  padding: .85rem .25rem;
  border-bottom: 1px solid rgba(255, 255, 255, .22);
  transition: color var(--transition), border-color var(--transition);
  white-space: nowrap;
}
.equipe-cta-link:hover,
.equipe-cta-link:focus-visible {
  color: #fff;
  border-bottom-color: var(--color-accent);
  outline: none;
}
@media (max-width: 600px) {
  .equipe-cta { padding: 3.5rem 1.25rem; }
  .equipe-cta-buttons { flex-direction: column; gap: .75rem; }
  .equipe-cta-buttons > .btn { width: 100%; max-width: 280px; }
}

/* ── Modale Bio ── */
.equipe-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 29, 53, .55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: var(--z-overlay, 10000);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.equipe-modal-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}
.equipe-modal {
  background: var(--card-bg, #fff);
  border: 1px solid var(--border);
  border-radius: 2px;
  max-width: 560px;
  width: 100%;
  max-height: 88vh;
  overflow-y: auto;
  padding: 3rem 2.5rem 2.5rem;
  position: relative;
}
.equipe-modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--body);
  transition: background-color .25s ease, color .25s ease, border-color .25s ease;
}
.equipe-modal-close:hover {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.equipe-modal-avatar {
  width: 112px;
  height: 112px;
  border-radius: 50%;
  background: var(--bg-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  font-size: 1.8rem;
  font-weight: 600;
  color: var(--navy);
  font-family: var(--font-display);
  overflow: hidden;
  border: 1px solid var(--border);
}
.equipe-modal-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 22%;
  filter: none;
}
.equipe-modal-name {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: 1.65rem;
  font-weight: 500;
  color: var(--ink);
  text-align: center;
  margin: 0 0 .5rem;
  letter-spacing: -0.015em;
  line-height: 1.2;
}
.equipe-modal-role {
  font-family: var(--font-display);
  font-size: .7rem;
  font-weight: 600;
  color: var(--body);
  text-transform: uppercase;
  letter-spacing: .22em;
  text-align: center;
  margin: 0 0 1.5rem;
  position: relative;
  padding-bottom: 1rem;
}
.equipe-modal-role::after {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 24px;
  height: 1px;
  background: var(--color-accent); /* accent — sous le rôle dans la modale */
}
.equipe-modal-bio {
  font-family: var(--font-body);
  font-size: .98rem;
  color: var(--body);
  line-height: 1.8;
  text-align: left;
  margin: 0 0 1.75rem;
}
.equipe-modal-linkedin,
.equipe-modal-email {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  font-family: var(--font-display);
  font-size: .68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .22em;
  text-decoration: none;
  padding: .8rem 1.25rem;
  border-radius: 2px;
  margin: 0 .25rem;
  color: var(--ink);
  border: 1px solid var(--border);
  transition: background-color .25s ease, color .25s ease, border-color .25s ease;
}
.equipe-modal-linkedin:hover,
.equipe-modal-email:hover {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.equipe-modal-footer {
  text-align: center;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .equipe-pillars {
    grid-template-columns: repeat(2, 1fr); /* 5 → 2+2+1 centrée */
    gap: 1.5rem;
  }
  .equipe-pillar,
  .equipe-pillar:nth-child(4),
  .equipe-pillar:nth-child(5) { grid-column: auto; }
  .equipe-pillar:nth-child(5) { grid-column: 1 / -1; max-width: 520px; justify-self: center; width: 100%; }
}
@media (max-width: 900px) {
  .section { padding: 3.5rem 0; }
  .equipe-section-header { margin-bottom: 2.25rem; }
  .equipe-stats { padding: 2.75rem 0; }
  .equipe-cta { padding: 3.5rem 0; }
}
@media (max-width: 640px) {
  .equipe-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 2.25rem 1rem;
  }
  .equipe-pillars {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .equipe-pillar,
  .equipe-pillar:nth-child(4),
  .equipe-pillar:nth-child(5) {
    grid-column: 1 / -1;
    max-width: none;
  }
  .equipe-pillar::before {
    font-size: 4.5rem;
    margin-bottom: 1.25rem;
    padding-bottom: 1.25rem;
  }
  .equipe-card-avatar {
    width: 96px;
    height: 96px;
  }
  .equipe-card h3 { font-size: 1rem; }
  .equipe-card-role {
    font-size: .62rem;
    letter-spacing: .12em;
    min-height: 2.4em;
  }
  .equipe-card-desc { display: none; }
  .equipe-cs-panel-title { font-size: 1.18rem; }
  .equipe-tabs { display: none !important; }
  .equipe-cs-panel[hidden] { display: block; }
  .equipe-modal {
    padding: 2.25rem 1.5rem 1.75rem;
  }
}
@media (max-width: 420px) {
  .equipe-grid {
    grid-template-columns: 1fr;
    gap: 2.25rem;
  }
  .equipe-card-avatar {
    width: 120px;
    height: 120px;
  }
}

/* ── Dark mode ── */
@media (prefers-color-scheme: dark) {
  .equipe-card-avatar img {
    filter: grayscale(35%) contrast(1.1) brightness(.95) sepia(8%);
  }
  .equipe-card:hover .equipe-card-avatar img {
    filter: none;
  }
  .equipe-stats-grid > div + div::before,
  .equipe-stats-grid > div:nth-child(even)::before {
    background: rgba(255, 255, 255, .12);
  }
}

/* ============================================
   Resserrement + raffinements 2026-05-08 #3
   On garde le parti-pris monochrome / accent bleu rare.
   On serre les espaces et on ajoute deux raffinements :
   - underline typographique animé au hover des noms
   - micro-séparateur ornemental entre certaines sections
   ============================================ */

/* ── Espacements plus serrés ── */
.section {
  padding: 3rem 0;
}
.equipe-section-header {
  margin-bottom: 2.25rem;
}

.equipe-grid {
  gap: 2.25rem 1.25rem;
}

.equipe-pillars {
  gap: 1.75rem;
}

.equipe-stats {
  padding: 2.85rem 0;
}

.equipe-cta {
  padding: 3.25rem 0;
}

@media (max-width: 900px) {
  .equipe-hero {
    padding: calc(var(--nav-height, 80px) + 3rem) 1.5rem 3rem;
  }
  .equipe-citation { padding: 3.5rem 1.5rem; }
  .equipe-intro { padding: 2.5rem 1.5rem; }
  .section { padding: 2.5rem 0; }
  .equipe-section-header { margin-bottom: 1.75rem; }
  .equipe-stats { padding: 2.25rem 0; }
  .equipe-cta { padding: 2.5rem 0; }
  .equipe-stats-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem 0;
  }
  .equipe-stats-grid > div + div::before { display: none; }
  .equipe-stats-grid > div:not(:nth-child(3n+1))::before {
    content: '';
    position: absolute;
    left: 0;
    top: 22%;
    bottom: 22%;
    width: 1px;
    background: rgba(30, 41, 59, .12);
  }
}
@media (max-width: 600px) {
  .equipe-stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .equipe-stats-grid > div:not(:nth-child(3n+1))::before { display: none; }
  .equipe-stats-grid > div:nth-child(even)::before {
    content: '';
    position: absolute;
    left: 0;
    top: 22%;
    bottom: 22%;
    width: 1px;
    background: rgba(30, 41, 59, .12);
  }
}

/* ── Raffinement : underline typographique animé sur les noms ── */
.equipe-card h3 {
  display: inline-block;
  position: relative;
  padding-bottom: 2px;
}
.equipe-card h3::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0;
  height: 1px;
  background: currentColor;
  opacity: .65;
  transform: translateX(-50%);
  transition: width .4s cubic-bezier(.4, 0, .2, 1);
}
.equipe-card[data-bio]:hover h3::after,
.equipe-card[data-bio]:focus-visible h3::after {
  width: 70%;
}

/* ── Focus rings clavier ── */
.equipe-card[data-bio]:focus-visible,
.equipe-modal-close:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 4px;
  border-radius: 2px;
}
.equipe-card[data-bio]:focus-visible {
  outline-offset: 6px;
}

/* ── Micro-séparateur ornemental entre certaines sections (3 points centrés) ── */
.section + .section::before,
.section + .equipe-stats::before {
  /* Désactivé : on laisse le rythme typographique parler */
}

/* ── Reduced motion : on neutralise tout ── */
@media (prefers-reduced-motion: reduce) {
  .equipe-card h3::after,
  .equipe-card-avatar img,
  .equipe-pillar,
  .equipe-tab {
    transition: none !important;
    animation: none !important;
  }
}

