/*
 *   Message (page contact)
 */

.alert {
    padding: 15px;
    margin-bottom: 20px;
    border-radius: 5px;
}
.alert-success {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}
.alert-danger {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}


/*
 *  Media Query
 */

/* Icones pied de page */
@media (min-width: 768px) {
  .iconeViolet {
    width: 2rem;   /* 32px */
    height: 2rem;
  }
}

@media (min-width: 1200px) {
  .iconeViolet {
    width: 2.5rem; /* 40px */
    height: 2.5rem;
  }
}



.modal-xl {
    max-width: 1400px;
}

#zcal-container iframe {
    width: 100%;
    height: 85vh;
    border: none;
    display: block;
}

.modal {
    transform: none !important;
}


.btn-violet {
  --bs-btn-color: #fff;
  --bs-btn-bg: #8a2be2;
  --bs-btn-border-color: #8a2be2;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #7329d1;
  --bs-btn-hover-border-color: #6b27c5;
  --bs-btn-focus-shadow-rgb: 138,43,226;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #6b27c5;
  --bs-btn-active-border-color: #6425b9;
}




/*
 * Polices
 */

.taillePied{
 font-size: 2.3rem;
 font-weight: 400;
 color: #7C52A7;
}

.footer-nav{
  font-size: 1.5rem
}

.text-justify {
  text-align: justify !important;
}

.taille2-3{
  font-weight: 400;
	font-size: 1.9rem;
  font-style: italic;
}

p, li{
	font-size: 1.8rem;
	font-weight: 300;
}

.accordion-button{
	font-size: 1.6rem;
	font-weight: 300;
}

.accordion-body, li{
 font-size: 1.5rem;
 font-weight: 300;
}

.titreFin{
  font-weight: 300;
}



/*
 *  Balises générales
 */

html, body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.7rem;
  font-weight: 300;
}

body{
  overflow-x: hidden;

}

.couleurTitre, .couleurTitrePerso{
	
 	color:#7C52A7;	
}


 
.couleurTitrePerso{
 	font-family: YoureInvited;
}

 /* (optionnel) on atténue encore un peu les titres */
  h1, h3, h5, h6 {
    font-weight: 300;           /* Light */
    color: #495057;
    }

h2{
  font-size: 2rem;
}

h4{
  font-size: 1.8rem;
  font-weight: 300;  
}




/*
 *  Marges
 */

 li{
  padding-top: 20px;
 }

.margeHaut{
  margin-top: 14em;
}

.margeBas{
  margin-bottom: 14em;
}

.margeHautPetit{
  margin-top: 5em;
}

.margeHautMoyen{
  margin-top: 3em;
}

.margeHaut20{
  margin-top: 20px;
}

.margeBas{
  margin-bottom: 10em;
}




/* 
 * Menu
 */

.navbar {
  border-bottom: 1px solid #eaeaea;
}

.navbar-nav .nav-link {
  color: #6a0dad; /* violet */
  font-weight: 600;
  margin: 0 15px;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: color 0.3s ease;
}

.navbar-nav .nav-link:hover {
  color: #9b59b6; /*9b59b6 violet plus clair au survol */
}

.navbar-brand {
  cursor: pointer;
}

.navbar-brand:hover {
  opacity: 0.45;
}

.navbar-logo {
  height: 55px;        /* ajuste ici */
  width: auto;
  display: block;
}


.navbar-toggler {
  border: none;
}

.navbar-toggler-icon {
  background-image: url("data:image/svg+xml;c2arset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='%236a0dad' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

.dropdown-menu {
  background-color: #ffffff; /* fond blanc */
}

.dropdown-item {
  color: #6a0dad !important; /* violet lisible */
}

.dropdown-toggle::after {
  display: inline-block !important;
  margin-left: 0.35em;
  vertical-align: 0.15em;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid transparent;
  border-bottom: 0;
  border-left: 0.3em solid transparent;
  color: #6a0dad; /* même couleur que le texte */
}



/* 
 * Icone svg
 */
.method-item {
  padding: 2.5rem 1.5rem;
}

.method-item svg {
  width: 48px;
  height: 48px;
  fill: #7C52A7;
  margin-bottom: 1rem;
}

.method-title {
  font-size: 1.5	rem;
  font-weight: 500;
  margin-bottom: 0.4rem;
}

.method-comment {
  font-size: 1.3rem;
  color: #6c757d;
  line-height: 1.4;
}

.method-comment {
  font-style: italic;
  opacity: 0.8;
}

.iconeViolet{
  fill: #7C52A7;
  margin-bottom: 0.7rem;
  text-decoration: none;

    /* Taille de base */
  width: 2rem;   /* 24px */
  height: 2rem;
  
  /* Limites de sécurité */
  min-width: 20px;
  max-width: 64px;
}


/* ====================
	Bannière déroulante
   ===================== */
.scroller {
  display: flex;
  font-size: 0;          /* supprime l’espace entre les blocs */
  gap: 0;
}

.scroller img {
  width: 100vw;
  height: 200px;          /* 40vh */
  object-fit: contain;
}
@media (min-width: 576px) {
  .scroller img {
    width: 33.333333vw;
    height: 200px;       /* ou 200 px */
  }
}






/*
 *  Bannières pages
 */

.fade-imageContact{
  position: relative;
  width: 100vw;
  background-image: url("../img/bannieres_page/contact.jpg");
  background-size: cover;
  min-height: 45vh;
  background-repeat: no-repeat;
  background-position: center;
}

.fade-imageContact::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(255, 255, 255, 0.55);
  z-index: 1;
}

.page-contact-content {
  position: relative;
  z-index: 2;
}

.fade-imageAccueil{
  position: relative;          /* référence de pile */
  min-height: 45vh;
}

.fade-imageAccueil::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/bannieres_page/montagne4.jpg") top center/cover no-repeat;
  opacity: .3;                 /* 30 % */
  z-index: 1;
}

/* contenu 100 % opaque */
.fade-imageAccueil, .container { z-index: 2; }


.page-quintessence {
  position: relative;
  width: 100vw;
  background-image: url("../img/bannieres_page/centreFleur2.jpg");
  background-size: cover;
  min-height: 45vh;
  background-repeat: no-repeat;
  background-position: center;
}

.page-quintessence::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(255, 255, 255, 0.55);
  z-index: 1;
}

.page-quintessence-content {
  position: relative;
  z-index: 2;
}


.page-rdv{
  position: relative;
  width: 100vw;
  background-image: url("../img/bannieres_page/chemin-pelerins.jpg");
  background-size: cover;
  min-height: 45vh;
  background-repeat: no-repeat;
  background-position: center;
}

.page-rdv::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(255, 255, 255, 0.70);
  z-index: 1;
}

.page-rdv-content{
  position: relative;
  z-index: 2;
}



.page-entretienDecouverte{
  position: relative;
  width: 100vw;
  background-image: url("../img/bannieres_page/entretienDecouverte2.jpg");
  background-size: cover;
  min-height: 45vh;
  background-repeat: no-repeat;
  background-position: center;
}

.page-entretienDecouverte::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(255, 255, 255, 0.70);
  z-index: 1;
}

.page-entretienDecouverte-content{
  position: relative;
  z-index: 2;
}


/*
 * Sections
 */

.section2 {
  background-color: #dfb6fa;
}

.section2 {
  background-color: #dfb6fa;
}

.sectionFooter{
	background-color: #e3c8f5;
}



/*
 *  Carousel
 */
 
#carousel-images .carousel {
  width: 100%;         /* carousel prend toute la largeur */
  max-width: 900px;    /* largeur max sur grand écran */
  margin: 0 auto;
  position: relative;  /* flèches restent positionnées correctement */
}

#carousel-images .carousel-item img {
  width: 100%;         /* prend toute la largeur du carousel */
  height: auto;        /* hauteur automatique pour garder le ratio */
  display: block;
  margin: 0 auto;
  object-fit: contain;  /* l'image s'adapte sans être coupée */
  background-color: #000; /* optionnel : couleur de fond si l'image ne remplit pas complètement */
}

/* Media queries pour petits écrans */
@media (max-width: 768px) {
  #carousel-images .carousel {
    max-width: 100%; /* occupe toute la largeur */
  }
}











.accordion-button:not(.collapsed) {
  color: #fff;                   /* texte blanc */
  background-color: #b080cf;     /* fond gris (exemple) */
  border-color: #b080cf;         /* bordure plus foncée */
  box-shadow: inset 0 -1px 0 rgba(0,0,0,.125),
              0 0 0 .25rem rgba(167, 4, 158, 0.5); /* halo de la même teinte */
}

/* 2) Couleur du focus (quand on navigue au clavier) */
.accordion-button:focus {
  border-color: #f097f3;
  box-shadow: 0 0 0 .25rem rgba(108, 117, 125, .5);
}

	/*
     *
	 *   ANCIENNE VERSION
	 *
	 */



