@charset "UTF-8";
@import url(main.css);
.text-color-secondary { color: #135299 !important; }

.text-color-primary { color: #15244a !important; }

.background-image-div-opacity { background-attachment: local !important; }

.mt-5 { margin-top: 1rem !important; }

footer.py-2 { font-size: 1.2rem !important; }

.b-bloc-divider { border: none !important; border-width: 0 !important; box-shadow: none !important; background-color: transparent !important; }

.logo-footer > .logo_nav { height: 14vh !important; }

.lottie-scroll { display: none !important; }

.slider-with-features-carousel-logo { height: 12rem !important; }

/*  ombre bloc */
.row.p-4.pb-0.pe-lg-0.pt-lg-5.pb-lg-5.rounded-3.shadow-lg.justify-content-center.position-relative.bg-primaryColor.text-color-primary { box-shadow: 0 0rem 0rem !important; }

.text-color-third { color: #0b3c73 !important; }

.svg-picto-card > svg { width: 65% !important; }

.mx-auto.col-lg-11.px-4.py-4.mb-5.mt-5.text-color-primary.rounded-3.shadow-lg.bg-primaryColor.position-relative { box-shadow: 0 0rem 0rem rgba(0, 0, 0, 0.175) !important; }

h1 { text-shadow: 1.5px 1.5px 1.5px #ffffff !important; }

/*-------------------Services Custom--------------------------*/
/* === BLOC SERVICES === */
.bloc-services { position: relative; padding: 80px 20px; background-color: transparent; color: #05244a; isolation: isolate; overflow: hidden; }

.bloc-services__container { max-width: 1200px; margin: 0 auto; text-align: center; }

.bloc-services__header { margin-bottom: 60px; }

.bloc-services__title { font-size: 2rem; font-weight: 700; text-transform: uppercase; margin-bottom: 10px; }

/* === Grille === */
.bloc-services__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 35px; }

/* === Carte === */
.bloc-services__card { position: relative; background-color: #fff; border-radius: 16px; padding: 35px 25px; box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08); transition: transform 0.3s ease, box-shadow 0.3s ease; overflow: hidden; /* alignement vertical des éléments */ display: flex; flex-direction: column; justify-content: flex-start; align-items: center; text-align: center; }

/* Chevron latéral */
.bloc-services__card::before, .bloc-services__card::after { content: ""; position: absolute; top: 0; right: -80px; width: 90px; height: 100%; transform: skew(-20deg); }

.bloc-services__card::before { background-color: #0b3c73; right: -80px; }

.bloc-services__card::after { right: -110px; width: 90px; background-color: #a71021; }

.bloc-services__icon { font-size: 2.8rem; margin-bottom: 15px; z-index: 1; }

/* Titre */
.bloc-services__card h3 { font-size: 1.4rem; font-weight: 700; margin-bottom: 15px; z-index: 1; }

/* Texte */
.bloc-services__card p { font-size: 1.3rem; line-height: 1.6; margin: 0 0 25px; color: #05244a; flex-grow: 1; /* pousse le bouton vers le bas si texte plus court */ z-index: 1; }

/* Bouton CTA */
.bloc-services__btn { display: inline-block; background-color: #05244a; color: #fff; text-decoration: none; padding: 12px 30px; border-radius: 25px; font-weight: 600; font-size: 1.05rem; transition: background 0.3s ease, transform 0.2s ease; margin-top: auto; /* assure que tous les boutons sont alignés en bas */ z-index: 1; }

.bloc-services__btn:hover { background-color: #760b0c; transform: scale(1.05); color: #fff; }

/* === Responsive === */
@media (max-width: 768px) { .bloc-services { padding: 60px 15px; } .bloc-services__title { font-size: 1.6rem; } .bloc-services__card h3 { font-size: 1.2rem; } .bloc-services__card p { font-size: 1rem; } .bloc-services__btn { font-size: 1rem; } }

/*-------------------chauffage--------------------------*/
/* === BLOC CHAUFFAGE === */
.bloc-chauffage { width: 100%; padding: 5rem 1rem; font-family: 'Poppins', sans-serif; text-align: center; background: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FuCqU7lknmbWkSZJb63MVv1u6wzJ3%2Fimages%2FEtablissement_Mortier_6_oy5r.webp") center/cover no-repeat; background-attachment: fixed; position: relative; z-index: 0; }

.bloc-chauffage::before { content: ""; position: absolute; inset: 0; background: rgba(255, 255, 255, 0.7); z-index: 0; }

.bloc-chauffage__intro, .bloc-chauffage__grid { position: relative; z-index: 1; }

.bloc-chauffage__intro { max-width: 800px; margin: 0 auto 3rem; }

.bloc-chauffage__intro h2 { font-size: 2rem; font-weight: 700; color: #BC1618; margin-bottom: 1.2rem; }

.bloc-chauffage__intro p { font-size: 1rem; color: #0b3c73; line-height: 1.6; }

/* === Grille === */
.bloc-chauffage__grid { display: flex; flex-wrap: nowrap; justify-content: center; gap: 1.8rem; max-width: 1200px; margin: 0 auto; flex-shrink: 0; }

/* === Cartes === */
.bloc-chauffage__card { flex: 1 1 22%; min-width: 250px; max-width: 270px; border-radius: 20px; padding: 2rem 1.5rem; text-align: left; box-shadow: 0 10px 25px rgba(0, 0, 0, 0.12); backdrop-filter: blur(4px); }

.bloc-chauffage__card.clair { background: linear-gradient(135deg, #ffffff 0%, #f4f6fa 100%); color: #0b3c73; }

.bloc-chauffage__card.bleu { background: linear-gradient(135deg, #0b3c73 0%, #1d5ca5 100%); color: #fff; }

/* === Texte === */
.bloc-chauffage__card h3 { font-size: 1.2rem; font-weight: 700 !important; margin-bottom: 1.1rem; line-height: 1.4; }

.bloc-chauffage__card p { font-size: 0.95rem; line-height: 1.7; margin: 0; }

/* === Responsive === */
@media (max-width: 992px) { .bloc-chauffage__grid { flex-wrap: wrap; justify-content: center; } .bloc-chauffage__card { max-width: 100%; } }

/*-------------------tarifs--------------------------*/
/* === BLOC TARIFS GLOBAL === */
.bloc-tarifs { position: relative; padding: 5rem 1.5rem; background: url("https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2FuCqU7lknmbWkSZJb63MVv1u6wzJ3%2Fimages%2FEtablissement_Mortier_6_oy5r.webp?alt=media&token=e4454f69-fda1-419f-8568-912f54ec0c05") center/cover no-repeat; font-family: 'Poppins', sans-serif; color: #0b3c73; overflow: hidden; }

.bloc-tarifs::before { content: ""; position: absolute; inset: 0; background: rgba(255, 255, 255, 0.85); z-index: 0; }

.bloc-tarifs__container { position: relative; z-index: 2; max-width: 1100px; margin: 0 auto; text-align: center; padding: 0 1rem; }

/* === TITRE === */
.bloc-tarifs__title { font-size: 2rem; font-weight: 700; color: #BC1618; text-transform: uppercase; margin-bottom: 1rem; }

/* === INTRO === */
.bloc-tarifs__intro p { color: #0b3c73; font-size: 1rem; line-height: 1.6; max-width: 750px; margin: 0 auto 3rem; }

/* === GRILLE DES CARTES === */
.bloc-tarifs__content { display: flex; flex-wrap: wrap; justify-content: center; align-items: stretch; gap: 2rem; }

/* === CARTES === */
.bloc-tarifs__card { flex: 1 1 450px; border-radius: 20px; box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1); padding: 2rem; text-align: left; display: flex; flex-direction: column; justify-content: flex-start; }

.bloc-tarifs__card.clair { background: #ffffff; color: #0b3c73; }

.bloc-tarifs__card.bleu { background: #1d5ca5; color: #ffffff; }

/* === TITRES DE CARTES === */
.bloc-tarifs__card h3 { font-size: 1.3rem; font-weight: 700; margin-bottom: 0.8rem; }

/* === LISTES === */
.bloc-tarifs__card ul { list-style: none; padding: 0; margin: 0; }

.bloc-tarifs__card ul li { margin-bottom: 0.4rem; font-size: 1rem; line-height: 1.5; }

/* === TARIFS SOUS LES HORAIRES === */
.bloc-tarifs__tarifs { margin-top: 1.5rem; background: #f4f6fa; padding: 1rem 1.2rem; border-radius: 10px; font-size: 0.95rem; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05); }

.bloc-tarifs__tarifs p { margin: 0.3rem 0; }

/* === TABLEAU === */
.bloc-tarifs__table-container { overflow-x: auto; border-radius: 10px; }

.bloc-tarifs__table { width: 100%; border-collapse: collapse; min-width: 320px; }

.bloc-tarifs__table th, .bloc-tarifs__table td { padding: 0.8rem 1rem; border: 1px solid rgba(0, 0, 0, 0.1); text-align: left; font-size: 0.95rem; color: #ffffff; }

/* Fond beige sur les cellules */
.bloc-tarifs__table td { background-color: #0b3c73; }

/* Ligne d’en-tête plus foncée pour contraster */
.bloc-tarifs__table th { background-color: #0b3c73; font-weight: 600; }

/* Effet alterné (plus clair sur une ligne sur deux) */
.bloc-tarifs__table tr:nth-child(even) td { background-color: #0b3c73; }

/* === RESPONSIVE === */
@media (max-width: 992px) { .bloc-tarifs { padding: 4rem 0; } .bloc-tarifs__container { padding: 0 1.2rem; } .bloc-tarifs__content { flex-direction: column; gap: 1.5rem; } .bloc-tarifs__card { width: 100%; padding: 1.8rem; margin: 0 auto; max-width: 95%; } .bloc-tarifs__tarifs { margin-top: 1.2rem; } }

@media (max-width: 480px) { .bloc-tarifs__title { font-size: 1.6rem; } .bloc-tarifs__intro p { font-size: 0.9rem; } .bloc-tarifs__card h3 { font-size: 1.1rem; } .bloc-tarifs__card ul li { font-size: 0.9rem; } .bloc-tarifs__card { padding: 1.5rem; margin: 0 0.8rem; } .bloc-tarifs__tarifs { font-size: 0.9rem; padding: 0.9rem 1rem; } }

/*-------------------Galerie Custom--------------------------*/
#custom-gallery { padding-top: 40px; }

@media screen and (min-width: 991px) { #custom-gallery { padding: 60px 30px 0 30px; } }

#custom-gallery .image { height: 400px !important; margin: 20px 0; }

.img-wrapper { position: relative; height: 100%; margin-top: 15px; }

.img-wrapper img { width: 100%; }

.img-overlay { background: rgba(0, 0, 0, 0.7); width: 100%; height: 100%; position: absolute; top: 0; left: 0; display: flex; justify-content: center; align-items: center; opacity: 0; }

.img-overlay i { color: #fff; font-size: 3em; }

#overlay { background: rgba(0, 0, 0, 0.7); width: 100%; height: 100%; position: fixed; top: 0; left: 0; display: flex; justify-content: center; align-items: center; z-index: 999; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }

#overlay img { margin: 0; width: 80%; height: auto; object-fit: contain; padding: 5%; }

@media screen and (min-width: 768px) { #overlay img { width: 60%; } }

@media screen and (min-width: 1200px) { #overlay img { width: 50%; } }

#nextButton { color: #fff; font-size: 2em; transition: opacity 0.8s; }

#nextButton:hover { opacity: 0.7; }

@media screen and (min-width: 768px) { #nextButton { font-size: 3em; } }

#prevButton { color: #fff; font-size: 2em; transition: opacity 0.8s; }

#prevButton:hover { opacity: 0.7; }

@media screen and (min-width: 768px) { #prevButton { font-size: 3em; } }

#exitButton { color: #fff; font-size: 2em; transition: opacity 0.8s; position: absolute; top: 15px; right: 15px; }

#exitButton:hover { opacity: 0.7; }

@media screen and (min-width: 768px) { #exitButton { font-size: 3em; } }

.img-responsive { height: 100% !important; object-fit: cover !important; }

/*-------------------6 cartes plomberie--------------------------*/
.bloc-plomberie { width: 100%; padding: 5rem 1rem; font-family: 'Poppins', sans-serif; background: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FuCqU7lknmbWkSZJb63MVv1u6wzJ3%2Fimages%2FEtablissement_Mortier_6_oy5r.webp") center/cover no-repeat; background-attachment: fixed; position: relative; text-align: center; z-index: 0; }

.bloc-plomberie::before { content: ""; position: absolute; inset: 0; background: rgba(255, 255, 255, 0.7); z-index: 0; }

.bloc-plomberie__intro, .bloc-plomberie__grid { position: relative; z-index: 1; }

.bloc-plomberie__intro { max-width: 800px; margin: 0 auto 3rem; }

.bloc-plomberie__intro h2 { font-size: 2rem; font-weight: 700; color: #BC1618; margin-bottom: 1.2rem; }

.bloc-plomberie__intro p { font-size: 1rem; color: #0b3c73; line-height: 1.6; }

/* === Structure === */
.bloc-plomberie__grid { max-width: 1100px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 2rem; }

/* Ligne du haut (3 cartes espacées) */
.bloc-plomberie__row--top { display: flex; justify-content: space-between; width: 100%; gap: 2rem; }

/* Ligne du bas (3 cartes centrées) */
.bloc-plomberie__row--bottom { display: flex; justify-content: space-between; width: 100%; gap: 2rem; }

/* === Cartes === */
.bloc-plomberie__card { flex: 1 1 30%; max-width: 320px; border-radius: 20px; padding: 2rem 1.5rem; text-align: left; box-shadow: 0 10px 25px rgba(0, 0, 0, 0.12); backdrop-filter: blur(4px); }

.bloc-plomberie__card.clair { background: linear-gradient(135deg, #ffffff 0%, #f4f6fa 100%); color: #0b3c73; }

.bloc-plomberie__card.bleu { background: linear-gradient(135deg, #0b3c73 0%, #1d5ca5 100%); color: #fff; }

/* Texte */
.bloc-plomberie__card h3 { font-size: 1.2rem; font-weight: 700 !important; margin-bottom: 1rem; line-height: 1.5; }

.bloc-plomberie__card p { font-size: 0.95rem; line-height: 1.8; margin: 0; }

/* === Responsive === */
@media (max-width: 992px) { .bloc-plomberie__row--top, .bloc-plomberie__row--bottom { flex-direction: column; align-items: center; } .bloc-plomberie__card { max-width: 100%; } }

/*# sourceMappingURL=custom.css.map */