@charset "UTF-8";
@import url(main.css);
/* ------------------------------------------------------------Cards partenaires*/
.servicesGallery-card-custom { position: relative; overflow: hidden; height: 100%; }

.card-body-custom { height: 100%; min-height: 65vh; }

.card-header-fixed-custom { bottom: 0; transition: opacity 0.3s ease; z-index: 2; text-align: left !important; padding-left: 15px !important; padding-bottom: 1.5rem !important; }

.card-overlay-custom { position: absolute; top: 0; left: 0; right: 0; bottom: 0; opacity: 0; transition: all 0.6s ease; z-index: 1; pointer-events: none; transform: translateY(100%); padding: 0; display: flex; flex-direction: column; }

.card-header-inside h3 { text-align: left; padding-left: 15px; }

.card-content-custom { flex: 1; overflow-y: auto; padding: 0 15px; text-align: left; }

.card-description-custom { margin-top: 15px; padding-right: 70px; padding-left: 20px; }

.card-footer-custom { padding: 15px; background: none; border-top: none; font-size: 1.2rem !important; font-weight: 700 !important; display: flex !important; justify-content: flex-start !important; }

.card-footer-custom .obftrucs { text-align: left; margin-left: 15px !important; }

.servicesGallery-card-custom:hover .card-overlay-custom { opacity: 1; transform: translateY(0); pointer-events: auto; }

.servicesGallery-card-custom:hover .card-header-fixed-custom { opacity: 0; }

/* ------------------------------------------------------------BANDE DÉFILANTE*/
.bolon-section { display: flex; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FZDcXugfbuYawvHLBTcZ2cX0j3MH2%2Fimages%2Fbackground_site_web_horizontal_3mdo.webp"); background-size: cover; background-position: center; padding: 80px 60px; font-family: 'Libre Baskerville', serif; color: white; gap: 40px; }

.bolon-left { width: 55%; display: flex; flex-direction: column; justify-content: space-between; }

.bolon-top-left p { font-size: 1rem; max-width: 400px; line-height: 1.6; }

.bolon-top-right { align-self: flex-end; margin-top: -2.5rem; margin-bottom: 2rem; }

.bolon-top-right ul { list-style: none; margin: 0; padding: 0; font-size: 1rem; font-style: italic; text-transform: uppercase; line-height: 1.8; text-align: right; }

.bolon-title { margin: 60px 0 40px 0; }

.bolon-title h1 { font-size: 4.5rem; margin: 0; }

.btn-pill { margin-top: 20px; display: inline-block; padding: 10px 28px; border: 1px solid white; border-radius: 999px; text-decoration: none; color: white; font-size: 0.9rem; transition: background 0.3s ease; }

.btn-pill:hover { background-color: rgba(255, 255, 255, 0.1); }

.bolon-bottom-text p { font-size: 1rem; line-height: 1.6; margin-bottom: 20px; max-width: 600px; }

.bolon-right { width: 45%; display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-end; }

.bolon-right img { width: 100%; height: auto; object-fit: cover; }

/* ------------------------------------------------------------BANDE DÉFILANTE*/
.infinite-scroll-banner { overflow: hidden; width: 100%; height: 120px; /* ajuste selon la taille de ton image */ background-color: transparent; position: relative; }

.scroll-track { display: flex; width: max-content; animation: scroll-left 10s linear infinite; }

.scroll-track img { height: 100px; margin-right: 40px; }

@keyframes scroll-left { 0% { transform: translateX(0%); }
  100% { transform: translateX(-50%); } }

/* ------------------------------------------------------------BOUTON SOMMAIRE*/
.btnSommaire img { height: 50px; transition: all 0.4s cubic-bezier(0.86, 0.01, 0.15, 0.99); }

/* Style normal*/
.btnSommaire { position: fixed; bottom: 110px; right: 23px; z-index: 20 !important; }

/* Style HOVER*/
.btnSommaire:hover img { height: 60px; }

/*-------------------Galerie Custom Réalisations--------------------------*/
#custom-gallery { padding-bottom: 40px !important; }

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

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

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

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

.gallery-title-wrapper { background-color: #38524E; text-align: center; padding: 10px 0; margin-bottom: 0px; }

.gallery-title { color: white; margin: 0; font-size: 2.2em; font-weight: 400 !important; }

.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; }

/*-------------------SOMMAIRE--------------------------*/
#section-titres .container { max-width: 900px; margin: 0 auto; padding: 40px 20px; }

.titre-liste a { text-decoration: none; display: block; }

.titre-liste a h2 { text-transform: uppercase; color: #D9B382; font-style: italic; font-weight: 400 !important; font-size: 2em; text-align: center; margin: 10px 0 0 0; padding-top: 4px; position: relative; transition: color 0.3s ease; cursor: pointer; }

.titre-liste a h2::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; border-top: 1.5px solid #D9B382; transition: border-color 0.3s ease; }

.titre-liste a:hover h2 { color: #A87C5F; }

.titre-liste a:hover h2::before { border-top-color: #A87C5F; }

/*--------------------------------- Bloc accordéon questions FAQ*/
.accordion-button:not(.collapsed) { color: black !important; background-color: #E9E2CF !important; box-shadow: inset 0 calc(var(--bs-accordion-border-width)* -1) 0 #A87C5F !important; }

/*----------------------------------------  Supprimer bandeau pages secondaires*/
.websitePageTitle-div { display: none !important; }

/* ------------------------------------------------------------Bannières secondaires */
.banniere { position: relative; background-size: cover; background-position: center; height: 400px; display: flex; align-items: center; justify-content: center; text-align: center; }

.banniere .icon { width: 180px; margin-bottom: 20px; }

.banniere h1 { font-size: 2.2rem; font-weight: bold; color: white; text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.6); }

.banniere-sol-pvc { background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FZDcXugfbuYawvHLBTcZ2cX0j3MH2%2Fimages%2Ffonds_pages_secondaires6_khfl.webp"); }

.banniere-moquette { background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FZDcXugfbuYawvHLBTcZ2cX0j3MH2%2Fimages%2Ffonds_pages_secondaires2_5ovy.webp"); }

.banniere-bolon { background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FZDcXugfbuYawvHLBTcZ2cX0j3MH2%2Fimages%2FIMG_20250704_133223_ghlw.webp"); }

.banniere-escaliers { background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FZDcXugfbuYawvHLBTcZ2cX0j3MH2%2Fimages%2Ffonds_pages_secondaires4_r0jf.webp"); }

.banniere-ragréage { background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FZDcXugfbuYawvHLBTcZ2cX0j3MH2%2Fimages%2Ffonds_pages_secondaires5_n24k.webp"); }

.banniere-réalisations { background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FZDcXugfbuYawvHLBTcZ2cX0j3MH2%2Fimages%2Ffonds_pages_secondaires1_8bpa.webp"); }

.banniere-contact { background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FZDcXugfbuYawvHLBTcZ2cX0j3MH2%2Fimages%2Ffonds_pages_secondaires_hvq5.webp"); }

/* ------------------------------------------------------------Logo blanc footer */
.logo-footer > img { filter: brightness(0) invert(1); }

/* ------------------------------------------------------------BOUTON DEVIS EN BAS A DROITE */
.btnDevis img { height: 80px; transition: all 0.4s cubic-bezier(0.86, 0.01, 0.15, 0.99); }

/* Style normal */
.btnDevis { position: fixed; bottom: 10px; right: 10px; z-index: 20 !important; }

/* Style HOVER */
.btnDevis:hover img { height: 100px; }

/*----------------------------------------  Cards Homepage*/
.gpj-card-container { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px; padding: 40px 20px; background-color: #EEDCD5; box-sizing: border-box; }

.gpj-card { flex: 1 1 calc(25% - 20px); /* Au lieu de 33.333% */ max-width: calc(25% - 20px); /* 4 cartes par ligne sur écran large */ aspect-ratio: 2.8 / 2.8; /* Cartes un peu moins hautes */ border: 2px solid #B16B5E; border-radius: 30px; padding: 10px; /* Réduit le padding interne */ background: transparent; box-sizing: border-box; }

.gpj-card-inner { width: 100%; height: 100%; position: relative; border-radius: 20px; overflow: hidden; }

.gpj-card-inner img { width: 100%; height: 100%; object-fit: cover; border-radius: 20px; display: block; }

.gpj-card-text { position: absolute; bottom: 20px; left: 0; width: 100%; text-align: center; color: white; padding: 0 20px; box-sizing: border-box; transition: transform 0.4s ease; }

.gpj-card-text h3 { font-size: 1.4rem; margin-bottom: 10px; text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.8); }

.gpj-hover-content { transform: translateY(100%); opacity: 0; transition: all 0.4s ease; }

.gpj-card-inner:hover .gpj-card-text { transform: translateY(-40px); }

.gpj-card-inner:hover .gpj-hover-content { transform: translateY(0); opacity: 1; }

.gpj-hover-content p { font-size: 1.0rem; margin-bottom: 15px; background: rgba(20, 20, 20, 0.6); padding: 10px; border-radius: 10px; }

.gpj-hover-content button { background: linear-gradient(to right, #EAADA1, #AC6146); border: none; padding: 10px 20px; color: white; font-weight: bold; border-radius: 20px; cursor: pointer; transition: background-color 0.3s ease; }

.gpj-hover-content button:hover { background: linear-gradient(to right, #AC6146, #EAADA1); }

/* Responsive layout */
@media (max-width: 1024px) { .gpj-card { flex: 1 1 calc(33.333% - 20px); max-width: calc(33.333% - 20px); } }

@media (max-width: 768px) { .gpj-card { flex: 1 1 calc(50% - 20px); max-width: calc(50% - 20px); } }

@media (max-width: 480px) { .gpj-card { flex: 1 1 100%; max-width: 100%; } }

@media (max-width: 768px) { .carte-inner:hover .carte-text { transform: none; } .carte-hover { transform: translateY(0) !important; opacity: 1 !important; transition: none !important; } .carte-text { transform: none !important; } }

@media (max-width: 768px) { .gpj-card-inner:hover .gpj-card-text { transform: none; } .gpj-hover-content { transform: translateY(0) !important; opacity: 1 !important; transition: none !important; } .gpj-card-text { transform: none !important; } }

/*----------------------------------------  CHANGER WIDTH TITRE CAROUSEL*/
.videoTitle { width: 80% !important; }

/*-------------------Bloc maps-----------------------*/
.maps-section .content { color: white !important; }

.maps-section .map-content { padding: 50px; }

.maps-section iframe { border-radius: 20px !important; }

/*----------------------------------------  Shadowbox navbar homepage*/
.navbar { box-shadow: 0px 6px 15px rgba(0, 0, 0, 0.2); }

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