:root {
  --fond_clair: #f9f5f0;
  --beige_clair: #ead7c4;
  --beige_foncé: #a67c52;
  --police_grise: #6d6d6d;
  --vert: #d6d4c8;
  --orange: #E1A66C;
}
@font-face {
  font-family: 'PlayfairDisplay-Italic';
  src: url('PlayfairDisplay-Italic.ttf') format('truetype');
  /*font-weight: normal;
  font-style: normal;*/
}
/*-------------------------------------------------------------------------*/
.pk-container {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 10px;
  margin-top: 20px;
  /*margin-left: 10px;*/
  align-items: center; /* Centrage vertical */
}
.pk-text {
  flex: 2;
  margin-left: 50px;
  /*padding: 10px;*/
}
.pk-texte1 {
  font-size: 2em;
  color: var(--beige_foncé);
  font-family: 'PlayfairDisplay-Italic';
  margin-bottom: 20px;
}
.pk-texte2 {
  margin-bottom: 20px;
  font-size: 1em;
  color: var(--police_grise);
  /*ont-family: 'PlayfairDisplay-Italic';*/
}
.pk-texte3 {
  margin-bottom: 10px;
  font-size: 1.5em;
  color: var(--beige_foncé);
  font-family: 'PlayfairDisplay-Italic';
}
.pk-texte4 {
  margin-bottom: 5px;
  font-size: 1em;
  color: var(--police_grise);
  list-style: disc inside;
}
.pk-texte4 {
  display: table; /* crée une largeur commune basée sur le plus grand élément */
}
.pk-texte4 li {
  display: table-row; /* chaque <li> agit comme une ligne */
}
.pk-texte4 li::after {
  content: "";
  display: block;
  width: 100%; /* prend la largeur de la table */
  height: 1px;
  background: var(--beige_foncé);
  margin: 2px 0 5px 0;
  border-radius: 1px;
}
.pk-texte5 {
  margin-bottom: 10px;
  font-size: 1em;
  color: var(--police_grise);
}
.pk-image1 {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 20px ;
  margin-right: 10px ;
}
.pk-image1 img {
  height:300px;
  width: auto;
  max-width: 100%;
}
/*-------------------------------------------------------------------------*/
.seance-container {
  display: flex;
  background-color: var(--beige_clair) ;
  justify-content: center;
  align-items: flex-start;
  gap: 10px;
  margin-top: 50px;
  /*margin-left: 10px;*/
  align-items: center; /* Centrage vertical */
}
.seance-text {
  flex: 3;
  margin-left: 50px;
  margin-bottom: 40px;
  display: flex;
  flex-direction: column; /* pour garder la verticalité */
  align-items: left;    /* centre horizontalement tous les enfants */
}

.seance-texte1 {
  font-size: 1.5em;
  color: var(--beige_foncé);
}
.seance-texte2 {
  font-size: 1em;
  color: var(--police_grise);
}
.seance-texte3 {
  margin-bottom: 5px;
  font-size: 1em;
  color: var(--police_grise);
  list-style: disc inside;
}

.seance-texte3 {
  display: table; /* crée une largeur commune basée sur le plus grand élément */
}

.seance-texte3 li {
  display: table-row; /* chaque <li> agit comme une ligne */
}

.seance-texte3 li::after {
  content: "";
  display: block;
  width: 100%; /* prend la largeur de la table */
  height: 1px;
  background: var(--beige_foncé);
  margin: 2px 0 5px 0;
  border-radius: 1px;
}
.seance-image2 {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 20px ;
  margin-right: 10px ;
}
.seance-image2 img {
  height:auto;
  width: 200px;
  max-width: 100%;
}
/*--------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------*/
.seance3-container {
  display: flex;
  background-color: var(--fond_clair) ;
  justify-content: center;
  align-items: flex-start;
  gap: 10px;
  margin-top: 20px;
  /*margin-left: 10px;*/
  align-items: center; /* Centrage vertical */
}
.seance3-text { 
  flex: 3; 
  margin-left: 50px; 
  display: flex; 
  flex-direction: column; /* pour garder la verticalité */ 
  align-items: left; /* centre horizontalement tous les enfants */ 
} 
.seance3-texte1 { 
  font-size: 1.5em; 
  color: var(--beige_foncé); 
} 
.seance3-texte2 { 
  font-size: 1em; 
  color: var(--police_grise); 
}
/* Conteneur des étapes */
.seance3-steps {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 18px;
}

/* Une étape (numéro + contenu) */
.seance3-step {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  background-color: #f4eee7;
  border-radius: 12px;
  padding: 14px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
  border-left: 4px solid rgba(166,124,82,0.06); /* accent subtle */
}

/* Hover léger (desktop) */
.seance3-step:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.09);
}

/* Rond du numéro */
.step-number {
  flex: 0 0 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ead7c4, #a67c52);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.25rem;
  box-shadow: 0 4px 10px rgba(0,0,0,0.08);
  margin-top: 2px;
}

/* Corps du texte */
.step-body {
  display: flex;
  flex-direction: column;
}

/* Titre de l'étape */
.step-title {
  margin: 0;
  font-size: 1.05rem;
  color: var(--beige_foncé);
  font-weight: 700;
  margin-bottom: 6px;
}

/* Texte explicatif */
.step-text {
  margin: 0;
  color: var(--police_grise);
  line-height: 1.5;
  font-size: 0.98rem;
}
.seance3-texte3 { 
  margin-top: 20px;
  font-size: 1em; 
  color: var(--police_grise); 
}
/* Partie image = 1/5 */
.seance3-image2 {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: 20px;
}
.seance3-image2 img {
  width: 100%;     /* prend toute la largeur du 1/5 */
  height: auto;
  max-width: 100%; /* tu peux ajuster selon la taille max que tu veux */
  object-fit: cover;
}

/* Option : icône décorative (si tu veux remplacer le numéro par une icône) */
/* .step-number { font-family: "Font Awesome 6 Free"; } */



/*--------------------------------------------------------------------------*/

.final-container {
  display: flex;
  background-color: var(--beige_clair) ;
  justify-content: center;
  align-items: flex-start;
  gap: 10px;
  margin-top: 50px;
  /*margin-left: 10px;*/
  align-items: center; /* Centrage vertical */
}
.final-text {
  flex: 3;
  margin-top: 20px;
  margin-bottom: 20px;
  display: flex;
  flex-direction: column; /* pour garder la verticalité */
  align-items: center;    /* centre horizontalement tous les enfants */
}

.final-texte1 {
  font-size: 1.5em;
  color: var(--police_grise);
}


/*---------------@MEDIA-------------------------------------------------------------------------------*/

/* ---------- Responsive media queries for the provided sections ----------
Apply this at the END of your CSS file so it overrides earlier rules.
Targets only: .pk-*, .seance-*, .seance3-*, .final-* (mobile-first). */

/* ------------------ MOBILE (<= 800px) ------------------ */
@media (max-width: 800px) {
/* PK block: stack, images full width */
.pk-container {
flex-direction: column;
gap: 16px;
padding: 12px;
align-items: stretch;
}
.pk-text {
margin-left: 0;
padding: 0 6px;
order: 1;
}
.pk-image1 {
order: 2;
margin: 0 auto;
}
.pk-image1 img {
width: 95%;
height: auto;
max-width: 560px;
}
.pk-texte1 { font-size: 1.4rem; text-align: left; }
.pk-texte2,
.pk-texte5 { font-size: 0.98rem; }

/* Seance (2ème) block: stack, image under text */
.seance-container {
flex-direction: column;
gap: 16px;
padding: 12px;
align-items: stretch;
}
.seance-text {
margin-left: 0;
padding: 0 6px;
order: 1;
}
.seance-texte3 {
width: 100%;
}
.seance-image2 {
order: 2;
margin: 0 auto;
}
.seance-image2 img {
width: 95%;
height: auto;
max-width: 560px;
}
.seance-texte1 { font-size: 1.25rem; }
.seance-texte2,
.seance-texte3 { font-size: 0.98rem; }

/* Seance3 (3ème) block: steps compact, image under text */
.seance3-container {
flex-direction: column;
gap: 16px;
padding: 12px;
align-items: stretch;
}
.seance3-text {
margin-left: 0;
padding: 0 6px;
order: 1;
}
.seance3-image2 {
order: 2;
margin: 0 auto;
}
.seance3-image2 img {
width: 95%;
height: auto;
max-width: 560px;
}

.seance3-steps { gap: 12px; margin-top: 12px; }
.seance3-step {
flex-direction: row; /* number left, text right */
gap: 12px;
align-items: flex-start;
padding: 10px;
}
.step-number {
flex: 0 0 44px;
height: 44px;
font-size: 1rem;
margin-top: 0;
}
.step-title { font-size: 1rem; }
.step-text { font-size: 0.95rem; line-height: 1.45; }

/* Final block */
.final-container {
flex-direction: column;
gap: 12px;
padding: 12px;
align-items: stretch;
}
.final-text { margin-top: 0; padding: 0 6px; }
.final-texte1 { font-size: 1.1rem; text-align: left; }

/* Minor performance tweak: soften shadows on mobile */
.seance3-step,
.pk-image1 img,
.seance-image2 img {
box-shadow: 0 4px 10px rgba(0,0,0,0.04);
}
}


