.cercle-histoire {
  background: var(--blanc);
  margin-top: 50px;
  padding: 110px 0 80px;
  position: relative;
  overflow: hidden;
}
.cercle-histoire-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 0;
  align-items: start;
  position: relative;
}
.cercle-disque {
  position: absolute;
  left: 45%;
  top: 200px;
  transform: translateX(-70%);
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: var(--jaune);
  z-index: 0;
  pointer-events: none;
}

.cercle-histoire-gauche {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 16px;
  position: relative;
  z-index: 1;
}

.cercle-badge {
  margin-top: 50px;
  width: 200px;
  height: 200px;
  position: relative;
  z-index: 2;
  flex-shrink: 0;
}

.cercle-badge img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 4px 16px rgba(0,0,0,0.18));
}

.cercle-badge-ph {
  width: 130px;
  height: 130px;
  border-radius: 50%;
  background: var(--rouge);
  border: 5px solid var(--jaune);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--blanc);
  text-align: center;
  line-height: 1.3;
  box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}

.cercle-histoire-texte {
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  z-index: 1;
}

.cercle-surtitre {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--rouge);
}

.cercle-histoire-titre {
  font-size: clamp(1.9rem, 3.5vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.cercle-histoire-texte p {
  font-size: 1rem;
  line-height: 1.78;
  color: #333;
}

.cercle-histoire-btns {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 6px;
}   

.cercle-mosaique-section {
  background: var(--blanc);
  padding: 0 var(--marge);
  padding-bottom: 50px;
  padding-top: 50px;
}

.cercle-mosaique-inner {
  display: grid;
  grid-template-columns: 1fr 4px 0.5fr; 
  align-items: stretch;
  min-height: 520px;
}

.cercle-mosaique-img {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: stretch;
}

.cercle-mosaique-img img {
  width: 100%;
  height: 100%;
  max-height: 1000px;
  object-fit: contain;   
  object-position: center center;
  display: block;
}

.cercle-mosaique-ph {
  width: 100%;
  background: #c0c0c0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-style: italic;
  color: rgba(0,0,0,0.35);
  text-align: center;
  line-height: 1.6;
  padding: 40px 24px;
  min-height: 520px;
}

.cercle-mosaique-separateur {
  background: var(--rouge);
  width: 4px;
  align-self: stretch;
  flex-shrink: 0;
}

.cercle-hymne {
  padding: 60px 48px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  background: var(--blanc);
}

.cercle-hymne-titre {
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.cercle-hymne-paroles {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.hymne-strophe {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.hymne-vers {
  font-size: 1rem;
  line-height: 1.55;
  color: #333;
}

.hymne-refrain {
  font-size: 0.96rem;
  line-height: 1.55;
  color: var(--gris-texte);
  font-style: italic;
}

.cercle-equipe {
  background: var(--rouge);
  padding: 60px var(--marge);
  display: flex;
  align-items: center;
  gap: 80px;
}

.cercle-equipe-texte {
  flex: 1;
}

.cercle-equipe-texte h2 {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 700;
  color: var(--blanc);
  line-height: 1.15;
  margin-bottom: 16px;
}

.cercle-equipe-texte p {
  font-size: 1rem;
  line-height: 1.75;
  color: rgba(255,255,255,0.88);
}

.cercle-equipe-btn {
  flex-shrink: 0;
}

.cercle-enseignants {
  background: var(--gris);
  padding: 80px var(--marge);
}

.cercle-enseignants-header {
  text-align: center;
  margin-bottom: 48px;
}

.cercle-enseignants-titre {
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  font-weight: 700;
  letter-spacing: -0.02em;
}

.enseignants-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 700px;
  margin: 0 auto 40px;
}

.enseignant-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  border-radius: 10px;
  overflow: hidden;
  background: var(--blanc);
  box-shadow: 0 2px 12px rgba(0,0,0,0.07);
  transition: box-shadow var(--transition), transform var(--transition);
}

.enseignant-card:hover {
  box-shadow: 0 8px 28px rgba(0,0,0,0.14);
  transform: translateY(-4px);
}

.enseignant-photo {
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--gris-moyen);
}

.enseignant-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: filter var(--transition);
}

.enseignant-card:hover .enseignant-photo img {
  filter: brightness(1.05);
}

.enseignant-photo-ph {
  width: 100%;
  height: 100%;
  min-height: 180px;
  background: var(--gris-moyen);
  display: flex;
  align-items: center;
  justify-content: center;
}

.enseignant-photo-ph svg { opacity: 0.25; }

.enseignant-nom {
  width: 100%;
  background: var(--rouge);
  color: var(--blanc);
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
  padding: 12px 10px;
  line-height: 1.3;
}

.enseignants-contact {
  text-align: center;
}

.cercle-ca {
  background: var(--rouge);
  padding: 80px var(--marge);
}

.cercle-ca-header {
  margin-bottom: 40px;
}

.cercle-ca-header .cercle-surtitre {
  color: rgba(255,255,255,0.65);
}

.cercle-ca-titre {
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  font-weight: 700;
  color: var(--blanc);
  letter-spacing: -0.02em;
}

.ca-grid-principal {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 0 auto 16px;
}

.ca-grid-secondaire {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
  margin: 0 auto;
}

.ca-card {
  background: var(--blanc);
  border-radius: 10px;
  padding: 20px 22px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.ca-card-sm {
  padding: 16px 18px;
  gap: 12px;
}

.ca-photo {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--rouge);
}

.ca-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.ca-photo-ph {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/*.ca-photo-ph svg { opacity: 0.3; }*/

.ca-card-sm .ca-photo {
  width: 44px;
  height: 44px;
}

.ca-infos {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.ca-role {
  font-size: 1.15rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--rouge);
}

.ca-nom {
  font-size: 1rem;
  font-weight: 700;
  color: var(--noir);
  line-height: 1.2;
}

.ca-sous-role {
  font-size: 0.86rem;
  color: var(--gris-texte);
  font-style: italic;
  margin-top: 2px;
}

.ca-contact {
  font-size: 0.86rem;
  color: var(--rouge);
  word-break: break-all;
  margin-top: 4px;
  display: block;
  text-decoration: none;
}

.ca-contact:hover { text-decoration: underline; }

.ca-tel {
  font-size: 0.86rem;
  color: var(--gris-texte);
  display: block;
  margin-top: 1px;
}

/* RESPONSIVE */

@media (max-width: 1100px) {
  .cercle-histoire-inner {
    max-width: 760px;
    gap: 0;
    display: block;
  }

  .cercle-histoire-gauche{
    display: none;
  }

  .cercle-disque{
    display: none;
  }

  .cercle-equipe {
    flex-direction: column;
    gap: 28px;
    align-items: flex-start;
  }

  .cercle-mosaique-separateur{
    margin-top: 50px;
  }

  .ca-grid-principal { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 900px) {
  .cercle-histoire {
    padding: 100px 20px 50px;
    overflow: hidden;
  }

  .cercle-histoire-inner {
    grid-template-columns: 1fr;
    max-width: 100%;
    padding: 0;
    gap: 24px;
  }

  .cercle-badge { width: 90px; height: 90px; }
  .cercle-badge-ph { width: 90px; height: 90px; }

  .cercle-mosaique-section { padding: 0 20px 40px; }

  .cercle-mosaique-inner {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .cercle-mosaique-separateur {
    width: 100%;
    height: 4px;
    margin-top: 30px;
  }

  .cercle-mosaique-ph { min-height: 280px; }

  .cercle-hymne {
    padding: 40px 20px;
    text-align: center;
  }

  .cercle-hymne-titre { text-align: center; }
  .hymne-strophe { align-items: center; }

  .cercle-equipe { padding: 40px 20px; }

  .cercle-enseignants,
  .cercle-ca { padding-left: 20px; padding-right: 20px; }

  .enseignants-grid {
    grid-template-columns: repeat(3, 1fr);
    max-width: 100%;
  }

  .ca-grid-principal  { grid-template-columns: 1fr 1fr; max-width: 100%; }
  .ca-grid-secondaire { grid-template-columns: 1fr 1fr; max-width: 100%; }
}

@media (max-width: 600px) {
  .cercle-histoire { padding: 88px 16px 40px; }
  .cercle-histoire-titre { font-size: 1.9rem; }
  .cercle-histoire-texte p { font-size: 0.92rem; }

  .cercle-mosaique-section { padding: 0 16px 32px; }

  .cercle-equipe { padding: 36px 16px; }
  .cercle-equipe-texte h2 { font-size: 1.5rem; }
  .cercle-equipe-texte p  { font-size: 0.92rem; }

  .cercle-enseignants,
  .cercle-ca { padding-left: 16px; padding-right: 16px; }

  .cercle-enseignants-titre { font-size: 1.8rem; }
  .cercle-ca-titre { font-size: 1.8rem; }

  .enseignants-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }

  .ca-grid-principal  { grid-template-columns: 1fr; }
  .ca-grid-secondaire { grid-template-columns: 1fr; }

  .ca-card { padding: 16px; gap: 12px; }
  .ca-role { font-size: 0.9rem; }
  .ca-nom  { font-size: 0.92rem; }

  .cercle-hymne { padding: 32px 16px; }
  .cercle-hymne-titre { font-size: 1.8rem; }
  .hymne-vers   { font-size: 0.92rem; }
  .hymne-refrain { font-size: 0.88rem; }
}
