@charset "UTF-8";
@import url(main.css);
/************************************************ MODIFS GLOBALES ************************************************/
.spacer { display: none; }

h1, h2, h3 { font-weight: 700 !important; }

/************************* BOUTONS *************************/
button, input[type="button"], input[type="submit"], input[type="reset"], a[class*="btn"], a[class*="button"] { position: relative; overflow: hidden; text-decoration: none; transition: all 0.5s 0.2s ease; cursor: pointer; font-weight: 600 !important; display: inline-flex; align-items: center; justify-content: center; border-radius: 0 !important; padding: 0.5rem 1rem !important; }

button span, input[type="button"] span, input[type="submit"] span, input[type="reset"] span, a[class*="btn"] span, a[class*="button"] span { transition: all 0.5s 0.2s ease; }

button:hover, input[type="button"]:hover, input[type="submit"]:hover, input[type="reset"]:hover, a[class*="btn"]:hover, a[class*="button"]:hover { color: #AD2831 !important; }

button:hover span, input[type="button"]:hover span, input[type="submit"]:hover span, input[type="reset"]:hover span, a[class*="btn"]:hover span, a[class*="button"]:hover span { color: #AD2831 !important; }

button:before, button:after, input[type="button"]:before, input[type="button"]:after, input[type="submit"]:before, input[type="submit"]:after, input[type="reset"]:before, input[type="reset"]:after, a[class*="btn"]:before, a[class*="btn"]:after, a[class*="button"]:before, a[class*="button"]:after { content: ""; position: absolute; width: 0; height: 2px; background-color: #FFCFD3; transition: all 0.3s cubic-bezier(0.35, 0.1, 0.25, 1); }

button:before, input[type="button"]:before, input[type="submit"]:before, input[type="reset"]:before, a[class*="btn"]:before, a[class*="button"]:before { right: 0; top: 0; transition: all 0.5s cubic-bezier(0.35, 0.1, 0.25, 1); }

button:after, input[type="button"]:after, input[type="submit"]:after, input[type="reset"]:after, a[class*="btn"]:after, a[class*="button"]:after { left: 0; bottom: 0; }

button:hover:before, button:hover:after, input[type="button"]:hover:before, input[type="button"]:hover:after, input[type="submit"]:hover:before, input[type="submit"]:hover:after, input[type="reset"]:hover:before, input[type="reset"]:hover:after, a[class*="btn"]:hover:before, a[class*="btn"]:hover:after, a[class*="button"]:hover:before, a[class*="button"]:hover:after { width: 100%; }

button:active, button:focus, input[type="button"]:active, input[type="button"]:focus, input[type="submit"]:active, input[type="submit"]:focus, input[type="reset"]:active, input[type="reset"]:focus, a[class*="btn"]:active, a[class*="btn"]:focus, a[class*="button"]:active, a[class*="button"]:focus { outline: none; border: none; }

/************************* FOOTER *************************/
footer img.logo_nav { filter: brightness(0) invert(1); }

.d-flex.flex-column.flex-lg-row:has(.bi-geo-alt) { display: none !important; }

/************************************************ NAVBAR ************************************************/
#navigation-bar-hide { opacity: 1 !important; top: 0 !important; }

.navbar { transition: background .3s ease; }

.navbar.scrolled { background: #FFF8FC !important; border-bottom: 1px solid #C2BCBF; }

.animated-border-button span { color: #FFF8FC !important; }

.animated-border-button::after { background: #FFF8FC; }

.animated-border-button.scrolled span { color: #250902 !important; transition: all 0.3s ease-in-out; }

.animated-border-button.scrolled span:hover { color: #AD2831 !important; }

.animated-border-button.scrolled::after { background: #AD2831 !important; }

.navbar img.logo_nav { height: 100% !important; }

a.navbar-brand { width: 18vh; }

.navbar .container-fluid { padding: 0 1.5rem !important; }

footer img.logo_nav { filter: brightness(0) invert(1); }

.navbar:has(.navbar-collapse.collapse.show) { background: #640D14 !important; }

.navbar.scrolled:has(.navbar-collapse.collapse.show) { background: #FFF8FC !important; }

/************************************************ ACCUEIL ************************************************/
/************************* HERO *************************/
.carousel-item-homepage img, .first-carousel-img { transform: none !important; transition: none !important; box-shadow: none !important; filter: none !important; opacity: 1 !important; }

.carousel-item-homepage::before { content: ''; width: 100%; height: 100%; background: #640D14; position: absolute; display: block; z-index: 1; top: 0; left: 0; opacity: 0.6; }

#fullHeight p, #fullHeight h1 { letter-spacing: normal !important; }

#fullHeight p { font-size: 1.1rem; line-height: 150% !important; }

#fullHeight h1 { line-height: 120% !important; }

img.fondDegradeLogo { max-height: 35vh; }

.titleText.text-white.text-center.fs-2.mb-4.mt-lg-5.titles { max-width: 1100px; margin: auto; }

lottie-player.lottie-scroll { display: none; }

/************************* À PROPOS *************************/
.about-section { max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; padding: 6rem 2rem; }

.image-container { position: relative; height: 100%; }

.main-image { width: 100%; height: 100%; object-fit: cover; box-shadow: 0 0 1rem 0 rgba(250, 250, 250, 0.1); }

.image-container::after { content: ''; position: relative; display: block; border-bottom: 1rem solid #640D14; border-left: 1rem solid #640D14; width: 20%; height: 40%; bottom: calc(40% + 1rem); left: -2rem; }

.image-container::before { content: ''; position: absolute; display: block; border-bottom: 1rem solid #AD2831; border-left: 1rem solid #AD2831; width: 30%; height: 30%; bottom: -2rem; left: 1rem; }

.about-content-container { padding: 20px 0; }

.section-label { color: #C2BCBF; font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 20px; display: flex; align-items: center; gap: 15px; }

.section-label::before { content: ''; width: 40px; height: 2px; background-color: #C2BCBF; }

.main-title { font-size: 42px; font-weight: 700 !important; color: #640D14; line-height: 1.2; margin-bottom: 25px; }

.description { color: #250902; font-size: 15px; line-height: 1.8; margin-bottom: 35px; }

.features { display: flex; gap: 3rem; }

.feature { display: flex; flex-direction: column; gap: 1rem; align-items: center; margin-top: 1rem; }

.feature-icon { width: auto; height: 3.5rem; flex-shrink: 0; margin-top: 2px; object-fit: contain; }

.feature-content h3 { font-size: 13px; color: #AD2831; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 0 !important; }

.feature-content p { font-size: 13px; color: rgba(37, 9, 2, 0.6); }

@media (max-width: 992px) { .about-section { grid-template-columns: 1fr; gap: 1.5rem; padding: 2rem; } .quote-card { position: relative; bottom: auto; left: auto; margin-top: 0.5rem; max-width: 100%; } .main-title { font-size: 32px; } .features { flex-direction: column; gap: 25px; } }

/************************* CARDS *************************/
.cards-section { width: 100%; padding: 3rem 2rem 6rem 2rem; }

.presta-top { max-width: 1400px; margin: auto; display: flex; flex-direction: column; align-items: center; margin-bottom: 3rem; padding: 0 2rem; }

.presta-main-title h2 { font-size: 42px; color: #640D14; }

.cards-grid { display: flex; gap: 3rem; max-width: 1400px; margin: auto; width: 100%; justify-content: center; align-items: center; }

.card-link { position: relative; overflow: hidden; text-decoration: none; display: flex; min-height: 420px; border-radius: 0; width: 100%; justify-content: center; align-items: center; }

.card-bg { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.5s ease; }

.card-link:hover .card-bg { transform: scale(1.05); }

.card-overlay { position: absolute; inset: 0; background: rgba(173, 40, 49, 0.7); transition: all 0.3s ease; }

.card-link:hover .card-overlay { background: rgba(255, 207, 211, 0.9); }

.card-link::before, .card-link::after { content: ""; position: absolute; height: 3px; width: 0; background-color: #AD2831; transition: all 0.5s ease-out; z-index: 3; }

.card-link::before { top: 0; right: 0; }

.card-link::after { bottom: 0; left: 0; }

.card-link:hover::before, .card-link:hover::after { width: 100%; }

.card-borders { position: absolute; inset: 0; z-index: 3; pointer-events: none; }

.card-borders::before, .card-borders::after { content: ""; position: absolute; width: 3px; height: 0; background-color: #AD2831; transition: all 0.5s ease-out; }

.card-borders::after { top: 0; right: 0; }

.card-borders::before { bottom: 0; left: 0; }

.card-link:hover .card-borders::before, .card-link:hover .card-borders::after { height: 100%; }

.card-body-presta { position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; justify-content: center; padding: 2rem; text-align: center; align-items: center; transform: translateY(1rem); transition: all 0.5s ease; }

.card-title-presta h3 { font-size: 1.4rem !important; color: #FFF8FC; line-height: 1.2; transition: all 0.5s ease; text-transform: uppercase; }

.card-desc p { font-size: 1rem; color: #FFF8FC !important; line-height: 1.7; margin: 0 0 1.25rem; transition: all 0.5s ease; }

.card-more { display: inline-flex; align-items: center; gap: 8px; font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: #AD2831; opacity: 0; transform: translateY(6px); transition: opacity 0.5s ease,transform 0.3s 0.2s ease; }

.card-link:hover .card-more { opacity: 1; transform: translateY(0); }

.card-link:hover .card-body-presta { opacity: 1; transform: translateY(0); }

.card-link:hover .card-title-presta h3 { color: #AD2831 !important; }

.card-link:hover .card-desc p { color: #250902 !important; }

.card-more-arrow { display: inline-block; transition: transform 0.3s ease; }

.card-link:hover .card-more-arrow { transform: translateX(4px); }

@media (max-width: 992px) { .cards-grid { flex-direction: column; } .card-link { min-height: 320px; } .card-more { opacity: 1; transform: translateY(0); color: #FFF8FC; } }

/************************* PICTOS *************************/
.picto_card .text-shadow.text-color-sixth.text-center.fs-4.mt-4.p-1 p:nth-child(1) { color: #640D14; font-weight: 600; }

.picto_card .text-shadow.text-color-sixth.text-center.fs-4.mt-4.p-1 p:nth-child(2) { font-size: 1rem !important; color: #250902; }

.position-relative.bg-sixthColor.picto_card { padding: 2rem; }

.picto_card .row.row-cols-1.row-cols-lg-4.d-flex.g-3.px-3.my-5.position-relative.justify-content-center { padding: 0 !important; max-width: 1400px; margin: auto; }

/************************* RÉALISATIONS *************************/
.real-accueil { margin: auto; width: 100%; padding: 6rem 0; display: flex; flex-direction: column; align-items: center; }

.real-accueil::before { content: ''; height: 50vh; width: 90%; margin: auto; background: url(https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fga0w2jVUMvNMiitTSHsaiNSCAkE3%2Fimages%2Ficone_be9i.webp); opacity: 0.05; background-size: contain; background-repeat: no-repeat; position: absolute; display: block; background-position: center; }

.real-accueil-button { background: #AD2831; color: #FFF8FC; }

.real-accueil-button:hover { background: #FFCFD3; }

.partenaires-image-slider { margin: auto; margin-bottom: 3rem; width: 100%; overflow: hidden; display: flex; }

.partenaires-image-slider > * { flex: 0 0 100%; }

.partenaires { height: 30vh; width: max-content; justify-content: center; align-items: center; overflow: hidden; }

.partenaires img { height: 100%; transition: all 0.3s ease-in-out; }

.partenaires:hover img { transform: scale(1.03); }

.partenaires-group { display: flex; gap: 2rem; padding-right: 2rem; will-change: transform; animation: scrolling 80s linear infinite; }

/* Animation infinie */
@keyframes scrolling { 0% { transform: translateX(0); }
  100% { transform: translateX(-100%); } }

/************************* CTA *************************/
#cta h2 { color: #FFF8FC !important; }

#cta a { background-color: #FFF8FC; color: #640D14 !important; }

#cta a:hover { background-color: #FFCFD3; color: #AD2831 !important; }

#cta .background-image-div-opacity { background-attachment: scroll !important; }

@media screen and (max-width: 992px) { #cta .background-image-div-opacity { background-image: url(https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fga0w2jVUMvNMiitTSHsaiNSCAkE3%2Fimages%2Ffond-cta-mobile_obe6.webp) !important; } }

#carte .display-6.fw-bold.text-body-emphasis.lh-1.mb-5.titles p { font-size: 12px !important; letter-spacing: 2px; margin-bottom: 20px; display: flex; align-items: center; gap: 15px; }

#carte .display-6.fw-bold.text-body-emphasis.lh-1.mb-5.titles p::before { content: ''; width: 40px; height: 2px; background-color: #C2BCBF; }

#carte .display-6.fw-bold.text-body-emphasis.lh-1.mb-5.titles h2 { font-size: 42px !important; }

#carte .fs-5.lead.mt-4.mb-4 p { font-size: 1rem !important; }

div#carte { box-shadow: none !important; max-width: 1400px; }

#carte .row.flex-lg-row-reverse.align-items-center.g-5.py-2.px-4.mt-5.position-relative.z-1 { margin-top: 0 !important; gap: 5rem; }

#carte .col-lg-5.my-0 { padding: 0; align-self: stretch; width: 35% !important; }

#carte .col-lg-5.my-0 img { height: 100%; width: 100%; object-fit: contain; }

#carte li p span, #carte ::marker { color: #AD2831; }

@media screen and (max-width: 992px) { #carte .col-lg-5.my-0 { width: 100% !important; } #carte .col-lg-7.my-0.order-1.order-lg-1.order-xl-1.order-xxl-1 { padding: 0.5rem; } }

/************************* FACEBOOK *************************/
.fd-social { text-align: center; padding: 4rem 2rem 6rem; display: flex; flex-direction: column; align-items: center; max-width: 1400px; margin: auto; }

.fd-social .section-label { justify-content: center; }

.fd-social-header h2 { font-size: 42px; color: #640D14; }

.fd-social-links { display: flex; justify-content: center; align-items: center; gap: 80px; flex-wrap: wrap; }

.fd-social-item { display: flex; flex-direction: column; align-items: center; text-decoration: none; transition: transform 0.3s ease; }

.fd-social-item span { color: #AD2831; transition: all 0.3s ease; font-weight: 700; }

.fd-social-item .bi-facebook { font-size: 6rem; color: #AD2831; transition: all 0.3s ease; }

.fd-social-item:hover { transform: translateY(4px); }

.fd-social-item:hover .bi-facebook { color: #FFCFD3; }

.fd-social-item:hover span { color: #FFCFD3; }

@media (max-width: 768px) { .fd-social { padding: 80px 25px; } .fd-social-header h2 { font-size: 30px; } .fd-social-links { gap: 50px; } }

/************************* BLOC SEO *************************/
.seo-bloc { padding: 2rem 2rem 0; background: url(https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fga0w2jVUMvNMiitTSHsaiNSCAkE3%2Fimages%2F470206294_603419615485569_7265567467521787845_n_lkle.webp); position: relative; background-attachment: fixed; background-size: cover; }

.seo-bloc::after { content: ''; position: absolute; bottom: -3rem; left: 0; display: block; height: 3rem; width: 100%; background: #640D14; }

.seo-bloc::before { content: ''; position: absolute; top: 0; left: 0; display: block; height: 100%; width: 100%; background: linear-gradient(rgba(100, 13, 20, 0.4), #640d14); }

.first-activity-div.shadow-lg, .second-activity-div.shadow-lg, .third-activity-div.shadow-lg { box-shadow: none !important; border-radius: 0 !important; max-width: 1400px; }

.seo-bloc .card.card-cover.h-100.overflow-hidden.rounded-4.shadow-lg { border-radius: 0 !important; box-shadow: none !important; }

.row.flex-lg-row.align-items-center.g-5.py-2.px-4.mt-2.position-relative.z-1 { margin-top: 0 !important; }

.seo-bloc h3 { color: #640D14; font-size: 36px; }

.seo-bloc .display-6.titles.fw-bold.text-body-emphasis.lh-1.mb-5 { margin-bottom: 0 !important; }

.seo-bloc p { color: #250902; }

.seo-bloc .black-screen { background-color: #640D14; }

.fs-2.fw-700.titles.text-color-sixth { color: black !important; }

/************************************************ PAGES PRESTATION ************************************************/
/************************* HERO *************************/
#hero { padding: 15vh 2rem !important; clip-path: polygon(0 0, 100% 0, 100% 70%, 50% 100%, 0 70%); }

#hero .content { max-width: 1400px; color: #FFF8FC; }

#hero::before { content: ''; position: absolute; top: 0; left: 0; display: block; height: 100%; width: 100%; background: rgba(100, 13, 20, 0.8); clip-path: polygon(0 0, 100% 0, 100% 70%, 50% 100%, 0 70%); z-index: 1; }

#hero .background-image-div-opacity { background-attachment: scroll !important; }

@media (max-width: 768px) { #hero { clip-path: polygon(0 0, 100% 0, 100% 90%, 50% 100%, 0 90%); } #hero::before { clip-path: polygon(0 0, 100% 0, 100% 90%, 50% 100%, 0 90%); } }

/************************* CARTES SERVICES *************************/
.service-cards-section { max-width: 1400px; margin: 0 auto; padding: 4rem 2rem 6rem; }

.service-cards-section.beton.paysage { background-color: #E6E4E5; max-width: 100%; }

.section-header { display: flex; flex-direction: column; align-items: center; margin-bottom: 3rem; }

.section-title h2 { font-size: 42px; line-height: 1.2; color: #640D14; text-align: center; }

.service-cards-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2rem; }

.service-cards-section.beton .service-cards-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 2rem; }

.service-cards-section.beton.paysage .service-cards-grid { max-width: 1400px; margin: auto; padding: 0 2rem; }

@media (max-width: 768px) { .service-cards-grid, .service-cards-section.beton.service-cards-grid { grid-template-columns: 1fr !important; } .service-cards-section.beton.paysage .service-cards-grid { padding: 0 !important; } }

.service-card { background-color: #FFF8FC; position: relative; overflow: hidden; }

.service-cards-section.beton.paysage .service-card { background-color: #E6E4E5; }

.service-card::before, .service-card::after { content: ''; position: absolute; width: 65%; height: 3px; z-index: 1; }

.service-card::before { top: 0; right: 0; background-color: #640D14; }

.service-card::after { bottom: 0; left: 0; background-color: #AD2831; }

.service-card-body { padding: 1.25rem 1.4rem 1.6rem; position: relative; }

.service-card-shadow-div { position: absolute; display: block; height: 100%; width: 100%; top: 0; left: 0; background: transparent; z-index: 2; }

.service-card-shadow-div::before, .service-card-shadow-div::after { content: ''; position: absolute; width: 3px; height: 85%; background-color: #640D14; }

.service-card-shadow-div::before { left: 0; bottom: 0; background-color: #AD2831; }

.service-card-shadow-div::after { right: 0; top: 0; background-color: #640D14; }

.service-card-image { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; display: block; position: relative; }

.service-card-title h3 { font-size: 1.5rem; text-transform: uppercase; font-weight: 600; color: #AD2831; margin-bottom: 0.5rem; line-height: 1.3; }

.service-card-description { font-size: 1rem; color: #250902; line-height: 1.65; }

/************************* ÉTAPES *************************/
#etapes svg#a { height: 20vh !important; width: auto; position: relative; }

#etapes .card.overflow-hidden.rounded-3.px-3.py-3.border-0.svg-picto-card::after { content: ''; position: absolute; top: calc(20vh + 3rem); left: calc(50% - .75rem); display: block; width: 1.5rem; height: 1.5rem; border-radius: 50%; background-color: #640D14; }

.card.overflow-hidden.rounded-3.px-3.py-3.border-0.svg-picto-card { overflow: visible !important; }

#etapes .row.row-cols-1.row-cols-lg-3.d-flex.g-3.px-3.my-5.position-relative.justify-content-center::before { content: ''; position: absolute; top: calc(20vh + 4.5rem); left: -2rem; display: block; width: 100vw; height: 3px; border-bottom: 5px dotted #640D14; }

#etapes .text-shadow.text-color-sixth.text-center.fs-4.mt-4.p-1 { margin-top: 5rem !important; max-width: 80%; margin: auto; }

#etapes p { display: flex; flex-direction: column; font-size: 1.25rem; font-weight: 400; }

@media screen and (max-width: 992px) { #etapes .row.row-cols-1.row-cols-lg-3.d-flex.g-3.px-3.my-5.position-relative.justify-content-center::before { content: ''; position: absolute; top: -2rem; left: 1rem; display: block; width: 3px; height: 105%; border-left: 5px dotted #640D14; border-bottom: none; } #etapes .card.overflow-hidden.rounded-3.px-3.py-3.border-0.svg-picto-card::after { content: ''; position: absolute; top: 11vh; left: -1.1rem; display: block; width: 1.5rem; height: 1.5rem; border-radius: 50%; background-color: #640D14; z-index: 3; } }

/************************* POURQUOI *************************/
#confiance .display-5.titles.mb-2.fw-bold.text-body-emphasis.ctaLinks-title.text-color-sixth p { font-size: 12px !important; letter-spacing: 2px; margin-bottom: 20px; display: flex; align-items: center; gap: 15px; color: #FFCFD3 !important; justify-self: center !important; }

#confiance .display-5.titles.mb-2.fw-bold.text-body-emphasis.ctaLinks-title.text-color-sixth p::before { content: ''; width: 40px; height: 2px; background-color: #FFCFD3; }

#confiance::before { content: ''; position: absolute; top: 0; left: 0; display: block; height: 100%; width: 100%; background: rgba(100, 13, 20, 0.8); z-index: 1; }

#confiance h2 { font-size: 42px !important; }

#confiance .content { display: flex; flex-direction: column; align-items: center; max-width: 800px; position: relative; }

#confiance .content::after { content: ''; width: 8rem; height: 6rem; background: url(https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fga0w2jVUMvNMiitTSHsaiNSCAkE3%2Fimages%2Ficone-light_2yfz.webp); background-size: contain; background-position: center; background-repeat: no-repeat; }

@media screen and (max-width: 992px) { #confiance h2 { font-size: 36px !important; } }

/************************************************ PAGE RÉALISATIONS ************************************************/
.realisations-section { padding: 60px 20px; }

.overlay { max-width: 1400px; margin: 0 auto; padding: 40px 20px; }

.filter-tabs { display: flex; justify-content: center; gap: 12px; margin-bottom: 32px; flex-wrap: wrap; }

.filter-btn { background: #E6E4E5; color: #640D14; font-size: 1.1rem; cursor: pointer; display: flex; align-items: center; border: none; justify-content: center; min-height: 52px; line-height: 1.2; text-align: center; }

.filter-btn p { margin-bottom: 0 !important; }

.filter-btn.active { background: #640D14; color: #FFF8FC; }

.filter-btn:hover { background: #FFCFD3; color: #AD2831; }

.realisations-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; }

.realisation-card { overflow: hidden; transition: all 0.3s ease; border: 2px solid transparent; }

.realisation-card:hover { transform: translateY(-4px); border: 2px solid #AD2831; }

.realisation-card img { width: 100%; height: 320px; object-fit: cover; display: block; cursor: pointer; }

.realisation-card.hidden { display: none; }

/* Modal pour l’image agrandie */
.modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(100, 13, 20, 0.85); align-items: center; justify-content: center; }

.modal-content { max-width: 1400px; background-color: transparent !important; max-height: 70vh; width: auto; object-fit: contain; border-radius: 0 !important; }

.modal-close { position: absolute; top: 24px; right: 32px; color: #FFF8FC; font-size: 36px; font-weight: bold; cursor: pointer; z-index: 1100; transition: all 0.3s ease; }

.modal-close:hover { color: #FFCFD3; }

@media (max-width: 900px) { .filter-tabs { gap: 8px; font-size: 0.9rem; } .filter-btn { padding: 10px 20px; font-size: 1rem; min-height: 48px; } .realisations-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 16px; } .realisation-card img { height: 240px; } .modal-content { max-width: 90%; max-height: 90%; } }

/************************************************ PAGE CONTACT ************************************************/
div#contact { padding-top: 8vh !important; min-height: 100vh; }

#contact .col-lg-6.text-center.text-color-sixth { padding-left: 6rem; text-align: left !important; }

#contact p { line-height: 150% !important; font-size: 1.2rem; }

#contact p:nth-child(1) { font-weight: 600; letter-spacing: 2px; margin-bottom: 20px; display: flex; align-items: center; gap: 15px; font-size: 1rem; color: #FFCFD3; }

#contact p:nth-child(1)::before { content: ''; width: 40px; height: 2px; background-color: #FFCFD3; }

#contact p a { text-decoration: none; color: #FFCFD3; transition: all 0.3s ease; }

#contact p a:hover { font-weight: 700 !important; color: #C2BCBF; }

@media screen and (max-width: 992px) { #contact .col-lg-6.text-center.text-color-sixth { padding-left: 2rem; } }

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