@charset "UTF-8";
@import url(main.css);
b, strong { font-weight: 600 !important; font-size: 1.1em !important; }

.spacer { display: none; }

div:has(> .first-activity-div) { padding: 100px 0; }

/*******************************AJUSTEMENTS SEO***********************************************/
.first-banner-seo-page h1 { width: 80%; max-width: 800px; margin: auto; text-shadow: 10px 10px 10px #424d5b; background-color: #142234; padding: 10px; border-radius: 40px; }

.first-banner-seo-page { background: #142234 !important; }

.first-banner-seo-page .logo-seo-page { content: url("https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FLogo_hcxv.webp?alt=media&token=036937cc-66f2-4ff3-a3b1-ab219ee48167"); }

.first-banner-seo-page .background-image-div-opacity { background-image: url(https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FCharte_Graphique_1_wc81.webp?alt=media&token=b397610a-d376-4fd5-99ae-932463015bb1) !important; background-attachment: scroll !important; background-size: cover !important; background-position: bottom !important; opacity: 1 !important; }

.bandeau { background-image: url(https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FCharte_Graphique_1_wc81.webp?alt=media&token=b397610a-d376-4fd5-99ae-932463015bb1) !important; background-attachment: scroll !important; background-size: cover !important; background-position: bottom !important; background-color: #142234; }

.bandeau h1 { font-weight: 300 !important; width: 80%; text-shadow: 10px 10px 10px #424d5b; background-color: #142234; padding: 10px; border-radius: 40px; }

div#custom-cards .logo_nav { content: url("https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FLogo_hcxv.webp?alt=media&token=036937cc-66f2-4ff3-a3b1-ab219ee48167"); }

#bandeau-title-seo .titles { font-weight: 300 !important; width: 80%; margin: auto !important; }

#photo-text-seo-page h2.titles, #seo-text-images h2.titles { font-weight: 300 !important; }

.first-activity-div .card-cover a, .second-activity-div .card-cover a, .third-activity-div .card-cover a { font-weight: 300 !important; }

/*------------Bloc actu------------------------------*/
#news-posts-bloc { margin-top: 150px !important; margin-bottom: 150px !important; }

/*****************************************NAVBAR*********************************************/
.animated-border-button:after { background-color: #b49930 !important; }

@media (max-width: 999px) { .dropdown-menu { transform: none !important; } }

/*******************************************BANNIERE PAGES SECONDAIRES****************************/
.sl-page-hero { position: relative; min-height: 40vh; padding: 110px 6vw 70px; background: #142234; color: #ffffff; font-family: "Google Sans", sans-serif; overflow: hidden; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FCharte_Graphique_1_wc81.webp"); background-size: contain; background-position: bottom right; background-repeat: no-repeat; }

.sl-page-hero::before { content: ""; position: absolute; right: -260px; bottom: -320px; width: 760px; height: 760px; border-radius: 50%; background: radial-gradient(circle, rgba(180, 153, 48, 0.18) 0%, rgba(180, 153, 48, 0.1) 28%, rgba(180, 153, 48, 0.05) 48%, rgba(180, 153, 48, 0.02) 62%, rgba(180, 153, 48, 0) 78%); filter: blur(18px); pointer-events: none; z-index: 0; }

.sl-page-hero__inner { position: relative; z-index: 1; max-width: 1180px; min-height: 260px; margin: 0 auto; padding: 42px 54px; display: grid; grid-template-columns: 220px auto minmax(0, 1fr); gap: 44px; align-items: center; }

.sl-page-hero__logo { width: 100%; max-width: 200px; height: auto; filter: drop-shadow(0 18px 35px rgba(0, 0, 0, 0.28)); }

.sl-page-hero__separator { width: 2px; height: 150px; background: linear-gradient(180deg, transparent, #b49930, #685b3d, #b49930, transparent); }

.sl-page-hero__badge { display: inline-flex; margin-bottom: 18px; padding: 10px 16px; border-radius: 999px; background: #263d5b6b; border: 1px solid rgba(219, 211, 191, 0.2); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.72rem; line-height: 1; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #dbd3bf; }

.sl-page-hero h1 { margin: 0; max-width: 660px; font-family: "Cabin", sans-serif; font-size: 2.5rem; line-height: 1.2; text-transform: uppercase; letter-spacing: 0.22rem; color: #ffffff; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35); }

@media (max-width: 900px) { .sl-page-hero { min-height: auto; padding: 96px 24px 64px; } .sl-page-hero__inner { min-height: auto; grid-template-columns: 1fr; gap: 28px; padding: 0; text-align: center; } .sl-page-hero__logo { max-width: 190px; margin: 0 auto; } .sl-page-hero__separator { width: 160px; height: 2px; margin: 0 auto; background: linear-gradient(180deg, transparent, #b49930, #6e603c, #8d7412, transparent); } .sl-page-hero h1 { margin: 0 auto; font-size: 2.4rem; line-height: 1; } }

@media (max-width: 600px) { .sl-page-hero { padding: 82px 20px 56px; } .sl-page-hero__logo { max-width: 160px; } .sl-page-hero__badge { font-size: 0.62rem; letter-spacing: 0.14rem; } .sl-page-hero h1 { font-size: 1.9rem; letter-spacing: 0.14rem; } }

/*******************************************FORMULAIRE DE CONTACT*********************************************/
/*******************************************CONTACT FORM****************************/
#contact { position: relative !important; margin: 0 !important; padding: 110px 6vw !important; background: #142234 !important; color: #ffffff !important; font-family: "Google Sans", sans-serif !important; overflow: hidden !important; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FCharte_Graphique_1_wc81.webp") !important; background-size: contain !important; background-position: bottom right !important; background-repeat: no-repeat !important; }

#contact::before { content: "" !important; position: absolute !important; right: -260px !important; bottom: -320px !important; width: 760px !important; height: 760px !important; border-radius: 50% !important; background: radial-gradient(circle, rgba(180, 153, 48, 0.18) 0%, rgba(180, 153, 48, 0.1) 28%, rgba(180, 153, 48, 0.05) 48%, rgba(180, 153, 48, 0.02) 62%, rgba(180, 153, 48, 0) 78%) !important; filter: blur(18px) !important; pointer-events: none !important; }

#contact::after { content: "" !important; position: absolute !important; left: -260px !important; top: -240px !important; width: 620px !important; height: 620px !important; border-radius: 50% !important; background: radial-gradient(circle, rgba(38, 61, 91, 0.8) 0%, rgba(38, 61, 91, 0.35) 38%, rgba(38, 61, 91, 0) 72%) !important; filter: blur(18px) !important; pointer-events: none !important; }

#contact .background-image-div-opacity { display: none !important; }

#contact > .row { position: relative !important; z-index: 1 !important; max-width: 980px !important; margin: 0 auto !important; padding: 0 !important; display: flex !important; flex-direction: column !important; align-items: center !important; gap: 34px !important; }

#contact > .row::before { content: "Devis gratuit" !important; display: inline-flex !important; margin: 0 auto 0 !important; padding: 10px 16px !important; border-radius: 999px !important; background: #263d5b6b !important; border: 1px solid rgba(219, 211, 191, 0.2) !important; backdrop-filter: blur(10px) !important; font-family: "Cabin", sans-serif !important; font-size: 0.72rem !important; line-height: 1 !important; text-transform: uppercase !important; letter-spacing: 0.24rem !important; font-weight: 700 !important; color: #dbd3bf !important; }

#contact > .row::after { content: "Contactez-nous" !important; display: block !important; margin: -16px auto 18px !important; max-width: 900px !important; text-align: center !important; font-family: "Cabin", sans-serif !important; font-size: 3.6rem !important; line-height: 0.95 !important; text-transform: uppercase !important; letter-spacing: 0.38rem !important; color: #ffffff !important; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35) !important; order: 1 !important; }

#contact .col-lg-6.text-center.text-color-sixth { display: none !important; }

#contact .col-md-10.col-lg-6 { width: 100% !important; max-width: 980px !important; flex: 0 0 100% !important; padding: 0 !important; margin: 0 auto !important; justify-content: center !important; order: 2 !important; }

#contact #formContact { width: 100% !important; max-width: 980px !important; margin: 0 auto !important; padding: 42px !important; border-radius: 34px !important; background: linear-gradient(180deg, rgba(38, 61, 91, 0.72), rgba(38, 61, 91, 0.34)) !important; border: 1px solid rgba(219, 211, 191, 0.16) !important; box-shadow: 0 34px 80px rgba(0, 0, 0, 0.34) !important; backdrop-filter: blur(10px) !important; color: #ffffff !important; }

#contact #formContact .row { margin: 0 !important; }

#contact #formContact .form-floating, #contact #formContact .mb-3, #contact #formContact .mb-4 { margin-bottom: 18px !important; }

#contact #formContact .form-control { min-height: 58px !important; border-radius: 18px !important; background: rgba(20, 34, 52, 0.72) !important; border: 1px solid rgba(219, 211, 191, 0.18) !important; color: #ffffff !important; font-family: "Google Sans", sans-serif !important; font-size: 1rem !important; box-shadow: none !important; transition: border-color 0.3s ease, background 0.3s ease, box-shadow 0.3s ease !important; }

#contact #formContact textarea.form-control { min-height: 160px !important; padding: 18px !important; resize: vertical !important; }

#contact #formContact .form-control:focus { background: rgba(20, 34, 52, 0.9) !important; border-color: #b49930 !important; box-shadow: 0 0 0 4px rgba(180, 153, 48, 0.16) !important; color: #ffffff !important; }

#contact #formContact .form-control::placeholder { color: rgba(219, 211, 191, 0.58) !important; }

#contact #formContact label { color: rgba(219, 211, 191, 0.78) !important; font-family: "Google Sans", sans-serif !important; }

#contact #formContact .form-floating > label { padding-left: 18px !important; }

#contact #formContact .form-floating > .form-control:focus ~ label, #contact #formContact .form-floating > .form-control:not(:placeholder-shown) ~ label { color: #dbd3bf !important; opacity: 0.9 !important; }

#contact #attachments { padding: 15px 18px !important; line-height: 1.4 !important; }

#contact #erase-file { border-radius: 18px !important; background: #8e7203 !important; border: 1px solid rgba(219, 211, 191, 0.22) !important; color: #ffffff !important; }

#contact .checkbox { margin: 6px 0 26px !important; color: #dbd3bf !important; font-size: 0.92rem !important; line-height: 1.6 !important; }

#contact .checkbox label { color: #dbd3bf !important; }

#contact .checkbox input { accent-color: #8e7203 !important; margin-right: 8px !important; }

#contact .checkbox a { color: #b49930 !important; text-decoration: none !important; font-weight: 700 !important; }

#contact .checkbox a:hover { color: #dbd3bf !important; }

#contact #formContact button[type="submit"] { display: inline-flex !important; width: 100% !important; align-items: center !important; justify-content: center !important; gap: 12px !important; padding: 16px 24px !important; border-radius: 999px !important; background: #8e7203 !important; color: #ffffff !important; text-decoration: none !important; font-family: "Cabin", sans-serif !important; text-transform: uppercase !important; letter-spacing: 0.2rem !important; font-size: 0.82rem !important; font-weight: 700 !important; border: 1px solid rgba(219, 211, 191, 0.22) !important; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28) !important; transition: transform 0.3s ease, background 0.3s ease, color 0.3s ease, box-shadow 0.3s ease !important; }

#contact #formContact button[type="submit"]:hover { background: #b49930 !important; color: #ffffff !important; transform: translateY(-4px) !important; box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36) !important; }

#contact .modal-content { border-radius: 28px !important; background: #142234 !important; border: 1px solid rgba(219, 211, 191, 0.16) !important; color: #ffffff !important; box-shadow: 0 34px 80px rgba(0, 0, 0, 0.34) !important; }

#contact .modal-header, #contact .modal-footer { border-color: rgba(219, 211, 191, 0.16) !important; }

#contact .modal-title { font-family: "Cabin", sans-serif !important; text-transform: uppercase !important; letter-spacing: 0.16rem !important; color: #ffffff !important; }

#contact .modal-body, #contact .modal-body p { color: #dbd3bf !important; }

@media (max-width: 900px) { #contact { padding: 86px 24px !important; } #contact > .row::after { font-size: 2.8rem !important; line-height: 1 !important; } #contact #formContact { padding: 34px 28px !important; } }

@media (max-width: 600px) { #contact { padding: 72px 20px !important; } #contact > .row::before { font-size: 0.62rem !important; letter-spacing: 0.14rem !important; } #contact > .row::after { font-size: 2.1rem !important; letter-spacing: 0.16rem !important; } #contact #formContact { padding: 28px 22px !important; border-radius: 28px !important; } #contact #formContact button[type="submit"] { font-size: 0.72rem !important; padding: 15px 20px !important; } }

#contact #formContact .form-control::placeholder { color: transparent !important; opacity: 0 !important; }

/*******************************************AVANT / APRES****************************/
.photoTitleText:has(+ div#avant-apres) { position: relative !important; background: transparent !important; }

.photoTitleText:has(+ div#avant-apres) .titles::before { content: "Avant / Après" !important; display: inline-flex !important; margin-bottom: 18px !important; padding: 10px 16px !important; border-radius: 999px !important; background: #263d5b6b !important; border: 1px solid rgba(219, 211, 191, 0.2) !important; backdrop-filter: blur(10px) !important; font-family: "Cabin", sans-serif !important; font-size: 0.72rem !important; line-height: 1 !important; text-transform: uppercase !important; letter-spacing: 0.24rem !important; font-weight: 700 !important; color: #dbd3bf !important; }

.photoTitleText:has(+ div#avant-apres) h2 { display: none; }

#avant-apres { position: relative !important; margin: 0 !important; background: transparent !important; padding-bottom: 110px; }

#avant-apres .row { position: relative !important; z-index: 1 !important; max-width: 1580px !important; margin: 0 auto !important; display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 24px !important; justify-content: center !important; }

#avant-apres .before-after-images-column { width: 100% !important; max-width: none !important; flex: initial !important; padding: 0 !important; margin: 0 !important; }

#avant-apres .image-before-after-container { position: relative !important; width: 100% !important; height: 100% !important; border-radius: 28px !important; overflow: hidden !important; background: linear-gradient(180deg, rgba(38, 61, 91, 0.72), rgba(38, 61, 91, 0.34)) !important; border: 1px solid rgba(219, 211, 191, 0.16) !important; box-shadow: 0 24px 54px rgba(0, 0, 0, 0.18) !important; backdrop-filter: blur(10px) !important; transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease !important; }

#avant-apres .image-before-after-container:hover { border-color: rgba(219, 211, 191, 0.28) !important; box-shadow: 0 34px 74px rgba(0, 0, 0, 0.28) !important; }

#avant-apres .before-image-gallery, #avant-apres .after-image-gallery { width: 100% !important; height: 100% !important; min-height: 360px !important; object-fit: cover !important; border-radius: 28px !important; }

#avant-apres .before-image-gallery { z-index: 2 !important; }

#avant-apres .after-image-gallery { position: relative !important; z-index: 1 !important; }

#avant-apres .image-before-after-container::after { content: "" !important; position: absolute !important; inset: 0 !important; z-index: 3 !important; background: linear-gradient(180deg, rgba(20, 34, 52, 0.02), rgba(20, 34, 52, 0.22)) !important; pointer-events: none !important; }

#avant-apres .slider-before-after-images { z-index: 5 !important; background: rgba(219, 211, 191, 0.92) !important; box-shadow: 0 0 0 1px rgba(20, 34, 52, 0.14) !important; }

#avant-apres .slider-before-after-images::before, #avant-apres .slider-before-after-images::after { background: #dbd3bf !important; }

#avant-apres .before-after-slider-button { border-radius: 999px !important; background: #8e7203 !important; color: #ffffff !important; border: 1px solid rgba(219, 211, 191, 0.22) !important; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28) !important; transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease !important; }

#avant-apres .image-before-after-container:hover .before-after-slider-button { background: #b49930 !important; transform: scale(1.04) !important; box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36) !important; }

#avant-apres .before-after-slider-button i, #avant-apres .left-arrow-before i, #avant-apres .right-arrow-before i { color: #ffffff !important; font-size: 1rem !important; line-height: 1 !important; }

#avant-apres .left-arrow-before, #avant-apres .right-arrow-before { color: #ffffff !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; }

@media (max-width: 1100px) { #avant-apres .row { grid-template-columns: repeat(2, 1fr) !important; } }

@media (max-width: 900px) { .photoTitleText:has(+ div#avant-apres) { padding: 86px 24px 20px !important; text-align: center !important; } .photoTitleText:has(+ div#avant-apres) h2 { font-size: 2.8rem !important; line-height: 1 !important; } #avant-apres { padding: 28px 24px 86px !important; } }

@media (max-width: 600px) { .photoTitleText:has(+ div#avant-apres) { padding: 72px 20px 18px !important; } .photoTitleText:has(+ div#avant-apres) .titles::before { font-size: 0.62rem !important; letter-spacing: 0.14rem !important; } .photoTitleText:has(+ div#avant-apres) h2 { font-size: 2.1rem !important; letter-spacing: 0.16rem !important; } #avant-apres { padding: 24px 20px 72px !important; } #avant-apres .row { grid-template-columns: 1fr !important; } #avant-apres .image-before-after-container { min-height: 330px !important; border-radius: 24px !important; } #avant-apres .before-image-gallery, #avant-apres .after-image-gallery { min-height: 330px !important; border-radius: 24px !important; } #avant-apres .before-after-slider-button { width: 46px !important; height: 46px !important; } }

/*************************************************GALERIE***********************/
#myGallery > img { border-radius: 28px !important; }

#myGallery { padding-bottom: 110px !important; }

/*******************************************CTA DEVIS****************************/
.sl-cta { position: relative; padding: 110px 6vw; background: #dbd3bf; color: #142234; font-family: "Google Sans", sans-serif; overflow: hidden; }

.sl-cta::before { content: ""; position: absolute; right: -220px; bottom: -260px; width: 680px; height: 680px; border-radius: 50%; background: radial-gradient(circle, rgba(20, 34, 52, 0.18) 0%, rgba(20, 34, 52, 0.1) 32%, rgba(20, 34, 52, 0.04) 52%, rgba(20, 34, 52, 0) 72%); pointer-events: none; }

.sl-cta::after { content: ""; position: absolute; left: -180px; top: -220px; width: 520px; height: 520px; border-radius: 50%; background: radial-gradient(circle, rgba(142, 114, 3, 0.22) 0%, rgba(142, 114, 3, 0.11) 36%, rgba(142, 114, 3, 0) 72%); pointer-events: none; }

.sl-cta__inner { position: relative; z-index: 1; max-width: 1220px; margin: 0 auto; padding: 64px 56px; text-align: center; border-radius: 34px; background: rgba(255, 255, 255, 0.32); border: 1px solid rgba(20, 34, 52, 0.14); box-shadow: 0 34px 80px rgba(20, 34, 52, 0.18); backdrop-filter: blur(10px); }

.sl-cta__eyebrow { display: inline-flex; margin-bottom: 18px; padding: 10px 16px; border-radius: 999px; background: rgba(20, 34, 52, 0.1); border: 1px solid rgba(20, 34, 52, 0.14); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.72rem; line-height: 1; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #263d5b; }

.sl-cta h2 { margin: 0 0 28px; font-family: "Cabin", sans-serif; font-size: 3.6rem; line-height: 0.95; text-transform: uppercase; letter-spacing: 0.38rem; font-weight: 700; color: #142234; }

.sl-cta p { max-width: 720px; margin: 0 auto 36px; font-size: 1.08rem; line-height: 1.85; color: #263d5b; }

.sl-cta__btn { display: inline-flex; align-items: center; justify-content: center; gap: 12px; padding: 16px 24px; border-radius: 999px; background: #142234; color: #ffffff; text-decoration: none; font-family: "Cabin", sans-serif; text-transform: uppercase; letter-spacing: 0.2rem; font-size: 0.82rem; font-weight: 700; border: 1px solid rgba(20, 34, 52, 0.18); box-shadow: 0 18px 38px rgba(20, 34, 52, 0.28); transition: transform 0.3s ease, background 0.3s ease, color 0.3s ease, box-shadow 0.3s ease; }

.sl-cta__btn svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.3s ease; }

.sl-cta__btn:hover { background: #8e7203; color: #ffffff; transform: translateY(-4px); box-shadow: 0 24px 48px rgba(20, 34, 52, 0.34); }

.sl-cta__btn:hover svg { transform: rotate(-10deg) scale(1.12); }

@media (max-width: 900px) { .sl-cta { padding: 86px 24px; } .sl-cta__inner { padding: 52px 34px; } .sl-cta h2 { font-size: 2.8rem; line-height: 1; } }

@media (max-width: 600px) { .sl-cta { padding: 72px 20px; } .sl-cta__inner { padding: 44px 24px; border-radius: 28px; } .sl-cta__eyebrow { font-size: 0.62rem; letter-spacing: 0.14rem; } .sl-cta h2 { font-size: 2.1rem; letter-spacing: 0.16rem; } .sl-cta p { font-size: 0.96rem; } .sl-cta__btn { width: 100%; max-width: 340px; font-size: 0.72rem; padding: 15px 20px; } }

/*******************************************HERO BANNER******************************************/
.sl-hero { position: relative; width: 100vw; height: 100vh; min-height: 680px; overflow: hidden; background: #142234; color: #ffffff; font-family: "Google Sans", sans-serif; }

.sl-hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }

.sl-hero__overlay { position: absolute; inset: 0; z-index: 2; background: linear-gradient(90deg, rgba(20, 34, 52, 0.35) 0%, rgba(20, 34, 52, 0.72) 48%, rgba(20, 34, 52, 0.96) 100%), radial-gradient(circle at 78% 45%, rgba(180, 153, 48, 0.18), transparent 34%); }

.sl-hero__content { position: relative; z-index: 3; width: 90vw; max-width: 860px; min-height: 100%; margin-left: auto; padding-top: 7vh; padding-right: 6vw; padding-bottom: 7vh; padding-left: 6vw; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; opacity: 0; transform: translateX(48px) scale(0.98); animation: slHeroReveal 1s cubic-bezier(0.22, 1, 0.36, 1) 2s forwards; }

.sl-hero__logo { width: 62vw; max-width: 270px; height: auto; margin-bottom: 34px; filter: drop-shadow(0 18px 35px rgba(0, 0, 0, 0.28)); }

.sl-hero__title { display: flex; flex-direction: column; align-items: flex-start; gap: 28px; margin: 0; }

.sl-hero__title-main { font-family: "Cabin", sans-serif; font-size: 3.6rem; line-height: 0.95; text-transform: uppercase; letter-spacing: 0.38rem; font-weight: 700; color: #ffffff; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35); }

.sl-hero__title-sub { max-width: 520px; font-family: "Cabin", sans-serif; font-size: 1.5rem; text-transform: uppercase; letter-spacing: 0.22rem; font-weight: 500; color: #dbd3bf; }

.sl-hero__title-badge { display: inline-flex; align-items: center; justify-content: center; padding: 12px 18px; border-radius: 999px; background: #263d5b6b; border: 1px solid rgba(219, 211, 191, 0.2); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.72rem; line-height: 1; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #dbd3bf; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.22); }

.sl-hero__buttons { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 36px; }

.sl-hero__btn { display: inline-flex; align-items: center; gap: 12px; padding: 16px 24px; border-radius: 999px; background: #8e7203; color: #ffffff; text-decoration: none; font-family: "Cabin", sans-serif; text-transform: uppercase; letter-spacing: 0.2rem; font-size: 0.82rem; font-weight: 700; border: 1px solid rgba(219, 211, 191, 0.22); box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28); transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease; }

.sl-hero__btn svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.3s ease; }

.sl-hero__btn:hover { background: #b49930; transform: translateY(-4px); box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36); }

.sl-hero__btn:hover svg { transform: translateX(4px) scale(1.08); }

.sl-hero__btn:first-child:hover svg { transform: rotate(-10deg) scale(1.12); }

.sl-hero__btn--secondary { background: rgba(38, 61, 91, 0.82); color: #dbd3bf; backdrop-filter: blur(10px); }

.sl-hero__btn--secondary:hover { background: #b49930; color: #ffffff; }

@keyframes slHeroReveal { to { opacity: 1;
    transform: translateX(0) scale(1); } }

@media (max-width: 1550px) { .sl-hero__title { gap: 12px !important; } .sl-hero__logo { max-width: 210px !important; margin-bottom: 18px !important; } }

@media (max-width: 1200px) { .sl-hero__title-main { font-size: 3.8rem; } }

@media (max-width: 900px) { .sl-hero { min-height: 760px; } .sl-hero__overlay { background: linear-gradient(180deg, rgba(20, 34, 52, 0.45), rgba(20, 34, 52, 0.94)); } .sl-hero__content { width: 100%; max-width: 100%; margin: 0; padding: 120px 24px 56px; align-items: center; text-align: center; } .sl-hero__logo { width: 220px; max-width: 80%; } .sl-hero__title { align-items: center; } .sl-hero__title-main { font-size: 2.8rem; line-height: 1; } .sl-hero__title-sub { font-size: 0.9rem; line-height: 1.5; } .sl-hero__buttons { justify-content: center; width: 100%; } .sl-hero__btn { width: 100%; max-width: 340px; justify-content: center; } }

@media (max-width: 600px) { .sl-hero__content { padding-top: 110px; } .sl-hero__title-main { font-size: 2.1rem; letter-spacing: 0.16rem; } .sl-hero__title-sub { font-size: 0.75rem; letter-spacing: 0.12rem; } .sl-hero__title-badge { font-size: 0.62rem; letter-spacing: 0.14rem; padding: 10px 14px; } .sl-hero__btn { font-size: 0.72rem; padding: 15px 20px; } }

.sl-hero::after { content: ""; position: absolute; left: 50%; bottom: 34px; z-index: 4; width: 34px; height: 54px; transform: translateX(-50%); opacity: 0; animation: slScrollAppear 0.8s ease 2.8s forwards, slScrollFloat 1.8s ease-in-out 3.6s infinite; background-image: url("data:image/svg+xml,%3Csvg width='34' height='54' viewBox='0 0 34 54' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='1.5' y='1.5' width='31' height='51' rx='15.5' stroke='%23dbd3bf' stroke-width='3'/%3E%3Ccircle cx='17' cy='15' r='3' fill='%23b49930'/%3E%3Cpath d='M17 32V42M17 42L12 37M17 42L22 37' stroke='%23dbd3bf' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; background-size: contain; pointer-events: none; }

@keyframes slScrollAppear { to { opacity: 1; } }

@keyframes slScrollFloat { 0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(10px); } }

@media (max-width: 600px) { .sl-hero::after { bottom: 22px; width: 28px; height: 44px; } }

/*******************************************NOS ATOUTS****************************/
.sl-reassurance { position: relative; padding: 110px 6vw; background: #142234; color: #ffffff; font-family: "Google Sans", sans-serif; overflow: hidden; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FCharte_Graphique_1_wc81.webp"); background-size: contain; background-position: bottom right; background-repeat: no-repeat; }

.sl-reassurance::before { content: ""; position: absolute; inset: auto -10% -35% -10%; height: 70%; background: radial-gradient(circle at 50% 50%, rgba(180, 153, 48, 0.14), transparent 60%); pointer-events: none; }

.sl-reassurance__inner { position: relative; z-index: 1; max-width: 1180px; margin: 0 auto; }

.sl-reassurance__eyebrow { display: inline-flex; margin-bottom: 18px; padding: 10px 16px; border-radius: 999px; background: #263d5b6b; border: 1px solid rgba(219, 211, 191, 0.2); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.72rem; line-height: 1; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #dbd3bf; }

.sl-reassurance h2 { margin: 0 0 54px; font-family: "Cabin", sans-serif; font-size: 3.6rem; line-height: 0.95; text-transform: uppercase; letter-spacing: 0.38rem; font-weight: 700; color: #ffffff; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35); }

.sl-reassurance__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }

.sl-reassurance__card { padding: 34px 28px; border-radius: 28px; background: linear-gradient(180deg, rgba(38, 61, 91, 0.72), rgba(38, 61, 91, 0.34)); border: 1px solid rgba(219, 211, 191, 0.16); box-shadow: 0 24px 54px rgba(0, 0, 0, 0.18); backdrop-filter: blur(10px); }

.sl-reassurance__icon { width: 62px; height: 62px; margin-bottom: 26px; display: inline-flex; align-items: center; justify-content: center; border-radius: 20px; background: #8e7203; color: #ffffff; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28); transition: transform 0.35s ease, background 0.35s ease, box-shadow 0.35s ease; }

.sl-reassurance__icon svg { width: 30px; height: 30px; fill: none; stroke: currentColor; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.35s ease; }

.sl-reassurance__card:hover .sl-reassurance__icon { background: #b49930; transform: translateY(-6px) rotate(-3deg); box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36); }

.sl-reassurance__card:hover .sl-reassurance__icon svg { transform: scale(1.12); }

.sl-reassurance h3 { margin: 0 0 14px; font-family: "Cabin", sans-serif; font-size: 1rem; line-height: 1.35; text-transform: uppercase; letter-spacing: 0.2rem; font-weight: 700; color: #ffffff; }

.sl-reassurance p { margin: 0; font-size: 1rem; line-height: 1.75; color: #dbd3bf; }

@media (max-width: 1100px) { .sl-reassurance__grid { grid-template-columns: repeat(2, 1fr); } }

@media (max-width: 900px) { .sl-reassurance { padding: 86px 24px; text-align: center; } .sl-reassurance h2 { font-size: 2.8rem; line-height: 1; } .sl-reassurance__card { display: flex; flex-direction: column; align-items: center; } }

@media (max-width: 600px) { .sl-reassurance { padding: 72px 20px; } .sl-reassurance__grid { grid-template-columns: 1fr; } .sl-reassurance h2 { font-size: 2.1rem; letter-spacing: 0.16rem; margin-bottom: 36px; } .sl-reassurance__eyebrow { font-size: 0.62rem; letter-spacing: 0.14rem; } .sl-reassurance__card { padding: 30px 24px; } .sl-reassurance h3 { font-size: 0.86rem; letter-spacing: 0.14rem; } .sl-reassurance p { font-size: 0.94rem; } }

/***********************************************************************CARROUSEL DE VIDEOS*****************************************/
.sl-intro { position: relative; padding: 100px 6vw; background: #142234; color: #ffffff; font-family: "Google Sans", sans-serif; overflow: hidden; }

.sl-intro::before { content: ""; position: absolute; top: -28%; left: -18%; width: 520px; height: 520px; background: radial-gradient(circle, rgba(180, 153, 48, 0.16), transparent 68%); pointer-events: none; }

.sl-intro::after { content: ""; position: absolute; right: -18%; bottom: -34%; width: 620px; height: 620px; background: radial-gradient(circle, rgba(38, 61, 91, 0.9), transparent 66%); pointer-events: none; }

.sl-intro__inner { position: relative; z-index: 1; max-width: 1220px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1fr) 430px; gap: 72px; align-items: center; }

.sl-intro__badge { display: inline-flex; margin-bottom: 24px; padding: 12px 18px; border-radius: 999px; background: #263d5b6b; border: 1px solid rgba(219, 211, 191, 0.2); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.72rem; line-height: 1; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #dbd3bf; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.22); }

.sl-intro h2 { max-width: 720px; margin: 0 0 34px; font-family: "Cabin", sans-serif; font-size: 3.6rem; line-height: 0.98; text-transform: uppercase; letter-spacing: 0.22rem; font-weight: 700; color: #ffffff; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35); }

.sl-intro p { max-width: 690px; margin: 0 0 18px; font-size: 1.05rem; line-height: 1.85; color: #dbd3bf; }

.sl-intro p:last-child { margin-bottom: 0; }

.sl-intro__reels { position: relative; display: flex; justify-content: center; align-items: center; }

.sl-intro__phone { position: relative; width: 315px; aspect-ratio: 9 / 16; padding: 12px; border-radius: 42px; background: linear-gradient(145deg, rgba(219, 211, 191, 0.22), rgba(38, 61, 91, 0.12)), #0e1928; border: 1px solid rgba(219, 211, 191, 0.24); box-shadow: 0 34px 80px rgba(0, 0, 0, 0.38), inset 0 0 0 1px rgba(255, 255, 255, 0.06); overflow: hidden; }

.sl-intro__phone-top { display: none; position: absolute; top: 18px; left: 50%; z-index: 4; width: 86px; height: 24px; transform: translateX(-50%); border-radius: 999px; background: rgba(14, 25, 40, 0.92); box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28); }

.sl-intro__track { position: relative; width: 100%; height: 100%; border-radius: 32px; overflow: hidden; background: #263d5b; }

.sl-intro__slide { position: absolute; inset: 0; opacity: 0; transform: scale(1.04); transition: opacity 0.55s ease, transform 0.55s ease; pointer-events: none; }

.sl-intro__slide.is-active { opacity: 1; transform: scale(1); pointer-events: auto; }

.sl-intro__slide video { width: 100%; height: 100%; object-fit: cover; }

.sl-intro__reels-label { position: absolute; left: 26px; bottom: 26px; z-index: 4; padding: 9px 13px; border-radius: 999px; background: rgba(20, 34, 52, 0.72); border: 1px solid rgba(219, 211, 191, 0.18); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.18rem; font-weight: 700; color: #dbd3bf; }

.sl-intro__arrow { position: absolute; z-index: 5; width: 54px; height: 54px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; border: 1px solid rgba(219, 211, 191, 0.22); background: #8e7203; color: #ffffff; cursor: pointer; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28); transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease; }

.sl-intro__arrow svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.3s ease; }

.sl-intro__arrow:hover { background: #b49930; transform: translateY(-4px); box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36); }

.sl-intro__arrow--prev { left: -20px; }

.sl-intro__arrow--next { right: -20px; }

.sl-intro__arrow--prev:hover svg { transform: translateX(-4px) scale(1.08); }

.sl-intro__arrow--next:hover svg { transform: translateX(4px) scale(1.08); }

.sl-intro__dots { position: absolute; bottom: -34px; left: 50%; display: flex; gap: 9px; transform: translateX(-50%); }

.sl-intro__dots span { width: 8px; height: 8px; border-radius: 999px; background: rgba(219, 211, 191, 0.35); transition: width 0.3s ease, background 0.3s ease; }

.sl-intro__dots span.is-active { width: 26px; background: #b49930; }

@media (max-width: 1100px) { .sl-intro__inner { grid-template-columns: 1fr; gap: 64px; } .sl-intro__content { text-align: center; } .sl-intro h2, .sl-intro p { margin-left: auto; margin-right: auto; } .sl-intro__reels { max-width: 430px; margin: 0 auto; } }

@media (max-width: 900px) { .sl-intro { padding: 86px 24px 110px; } .sl-intro h2 { font-size: 2.8rem; line-height: 1; } }

@media (max-width: 600px) { .sl-intro { padding: 72px 20px 104px; } .sl-intro__badge { font-size: 0.62rem; letter-spacing: 0.14rem; } .sl-intro h2 { font-size: 2.1rem; letter-spacing: 0.16rem; } .sl-intro p { font-size: 0.96rem; } .sl-intro__phone { width: 250px; border-radius: 34px; } .sl-intro__track { border-radius: 25px; } .sl-intro__arrow { width: 46px; height: 46px; } .sl-intro__arrow--prev { left: -8px; } .sl-intro__arrow--next { right: -8px; } }

/****************************************SAVOIR FAIRE*************************************************/
.sl-savoirfaire { position: relative; padding: 100px 6vw; background: #142234; color: #ffffff; font-family: "Google Sans", sans-serif; overflow: hidden; }

.sl-savoirfaire::before { content: ""; position: absolute; top: -24%; right: -14%; width: 560px; height: 560px; background: radial-gradient(circle, rgba(180, 153, 48, 0.15), transparent 68%); pointer-events: none; }

.sl-savoirfaire::after { content: ""; position: absolute; left: -18%; bottom: -34%; width: 620px; height: 620px; background: radial-gradient(circle, rgba(38, 61, 91, 0.9), transparent 66%); pointer-events: none; }

.sl-savoirfaire__inner { position: relative; z-index: 1; max-width: 1220px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1fr) 520px; gap: 78px; align-items: center; }

.sl-savoirfaire__badge { display: inline-flex; margin-bottom: 24px; padding: 12px 18px; border-radius: 999px; background: #263d5b6b; border: 1px solid rgba(219, 211, 191, 0.2); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.72rem; line-height: 1; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #dbd3bf; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.22); }

.sl-savoirfaire h2 { max-width: 740px; margin: 0 0 34px; font-family: "Cabin", sans-serif; font-size: 3.6rem; line-height: 0.98; text-transform: uppercase; letter-spacing: 0.22rem; font-weight: 700; color: #ffffff; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35); }

.sl-savoirfaire p { max-width: 700px; margin: 0 0 18px; font-size: 1.05rem; line-height: 1.85; color: #dbd3bf; }

.sl-savoirfaire__subtitle { display: block; margin: 34px 0 20px; font-family: "Cabin", sans-serif; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #ffffff; }

.sl-savoirfaire__list { max-width: 720px; margin: 0; padding: 0; list-style: none; columns: 2; column-gap: 34px; }

.sl-savoirfaire__list li { position: relative; break-inside: avoid; margin: 0 0 14px; padding-left: 28px; font-size: 0.98rem; line-height: 1.5; color: #dbd3bf; }

.sl-savoirfaire__list li::before { content: ""; position: absolute; left: 0; top: 0.58em; width: 9px; height: 9px; border-radius: 999px; background: #b49930; box-shadow: 0 0 0 6px rgba(180, 153, 48, 0.14); }

.sl-savoirfaire__media { position: relative; min-height: 560px; display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }

.sl-savoirfaire__image { position: relative; margin: 0; height: 430px; border-radius: 34px; overflow: hidden; background: #263d5b; border: 1px solid rgba(219, 211, 191, 0.16); box-shadow: 0 34px 80px rgba(0, 0, 0, 0.34); }

.sl-savoirfaire__image--top { align-self: start; }

.sl-savoirfaire__image--bottom { align-self: end; }

.sl-savoirfaire__image::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20, 34, 52, 0.08), rgba(20, 34, 52, 0.34)); pointer-events: none; }

.sl-savoirfaire__image img { width: 100%; height: 100%; object-fit: cover; }

@media (max-width: 1100px) { .sl-savoirfaire__inner { grid-template-columns: 1fr; gap: 68px; } .sl-savoirfaire__content { text-align: center; } .sl-savoirfaire h2, .sl-savoirfaire p, .sl-savoirfaire__list { margin-left: auto; margin-right: auto; } .sl-savoirfaire__list { text-align: left; } .sl-savoirfaire__media { max-width: 620px; margin: 0 auto; } }

@media (max-width: 900px) { .sl-savoirfaire { padding: 86px 24px; } .sl-savoirfaire h2 { font-size: 2.8rem; line-height: 1; } }

@media (max-width: 600px) { .sl-savoirfaire { padding: 72px 20px; } .sl-savoirfaire__badge { font-size: 0.62rem; letter-spacing: 0.14rem; } .sl-savoirfaire h2 { font-size: 2.1rem; letter-spacing: 0.16rem; } .sl-savoirfaire p { font-size: 0.96rem; } .sl-savoirfaire__list { columns: 1; } .sl-savoirfaire__media { min-height: auto; grid-template-columns: 1fr; } .sl-savoirfaire__image { height: 330px; } .sl-savoirfaire__image--bottom { transform: none; } }

/*******************************************NOS PRESTATIONS****************************/
.sl-prestations { position: relative; padding: 110px 6vw; background: #142234; color: #ffffff; font-family: "Google Sans", sans-serif; overflow: hidden; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FCharte_Graphique_1_wc81.webp"); background-size: contain; background-position: bottom right; background-repeat: no-repeat; }

.sl-prestations::before { content: ""; position: absolute; inset: auto -10% -35% -10%; height: 70%; background: radial-gradient(circle at 50% 50%, rgba(180, 153, 48, 0.14), transparent 60%); pointer-events: none; }

.sl-prestations__inner { position: relative; z-index: 1; max-width: 1180px; margin: 0 auto; }

.sl-prestations__eyebrow { display: inline-flex; margin-bottom: 18px; padding: 10px 16px; border-radius: 999px; background: #263d5b6b; border: 1px solid rgba(219, 211, 191, 0.2); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.72rem; line-height: 1; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #dbd3bf; }

.sl-prestations h2 { margin: 0 0 54px; font-family: "Cabin", sans-serif; font-size: 3.6rem; line-height: 0.95; text-transform: uppercase; letter-spacing: 0.38rem; font-weight: 700; color: #ffffff; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35); }

.sl-prestations__grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 22px; }

.sl-prestations__card { position: relative; width: calc(33% - 17px); min-height: 230px; padding: 34px 28px; border-radius: 28px; background: linear-gradient(180deg, rgba(38, 61, 91, 0.72), rgba(38, 61, 91, 0.34)); border: 1px solid rgba(219, 211, 191, 0.16); box-shadow: 0 24px 54px rgba(0, 0, 0, 0.18); backdrop-filter: blur(10px); text-decoration: none; color: #ffffff; overflow: hidden; transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease; }

.sl-prestations__card::after { content: ""; position: absolute; right: 24px; bottom: 24px; width: 34px; height: 34px; opacity: 0.45; transform: translateX(-6px); transition: opacity 0.35s ease, transform 0.35s ease; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23dbd3bf' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='m12 5 7 7-7 7'/%3E%3C/svg%3E"); background-size: contain; background-repeat: no-repeat; background-position: center; }

.sl-prestations__card:hover { transform: translateY(-8px); border-color: rgba(219, 211, 191, 0.28); box-shadow: 0 34px 74px rgba(0, 0, 0, 0.28); }

.sl-prestations__card:hover::after { opacity: 1; transform: translateX(0); }

.sl-prestations__icon { width: 62px; height: 62px; margin-bottom: 26px; display: inline-flex; align-items: center; justify-content: center; border-radius: 20px; background: #8e7203; color: #ffffff; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28); transition: transform 0.35s ease, background 0.35s ease, box-shadow 0.35s ease; }

.sl-prestations__icon svg { width: 30px; height: 30px; fill: none; stroke: currentColor; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.35s ease; }

.sl-prestations__card:hover .sl-prestations__icon { background: #b49930; transform: translateY(-6px) rotate(-3deg); box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36); }

.sl-prestations__card:hover .sl-prestations__icon svg { transform: scale(1.12); }

.sl-prestations h3 { max-width: 260px; margin: 0; font-family: "Cabin", sans-serif; font-size: 1rem; line-height: 1.35; text-transform: uppercase; letter-spacing: 0.2rem; font-weight: 700; color: #ffffff; }

@media (max-width: 1100px) { .sl-prestations__card { width: calc(50% - 11px); } }

@media (max-width: 900px) { .sl-prestations { padding: 86px 24px; text-align: center; } .sl-prestations h2 { font-size: 2.8rem; line-height: 1; } .sl-prestations__card { display: flex; min-height: 220px; flex-direction: column; align-items: center; } .sl-prestations h3 { max-width: none; } }

@media (max-width: 600px) { .sl-prestations { padding: 72px 20px; } .sl-prestations__card { width: 100%; min-height: auto; padding: 30px 24px 56px; } .sl-prestations h2 { font-size: 2.1rem; letter-spacing: 0.16rem; margin-bottom: 36px; } .sl-prestations__eyebrow { font-size: 0.62rem; letter-spacing: 0.14rem; } .sl-prestations h3 { font-size: 0.86rem; letter-spacing: 0.14rem; } }

/*******************************************AVIS GOOGLE****************************/
div.googleReviews-div { position: relative !important; margin: 0 !important; padding: 110px 6vw !important; background: #142234 !important; color: #ffffff !important; font-family: "Google Sans", sans-serif !important; overflow: hidden !important; }

div.googleReviews-div::before { content: "" !important; position: absolute !important; inset: auto -10% -35% -10% !important; height: 70% !important; background: radial-gradient(circle at 50% 50%, rgba(180, 153, 48, 0.14), transparent 60%) !important; pointer-events: none !important; }

div.googleReviews-div > .container { position: relative !important; z-index: 2 !important; max-width: 1180px !important; margin: 0 auto 44px !important; padding: 0 !important; }

div.googleReviews-div > .container > .card { padding: 34px 38px !important; border-radius: 28px !important; background: linear-gradient(180deg, rgba(38, 61, 91, 0.72), rgba(38, 61, 91, 0.34)) !important; border: 1px solid rgba(219, 211, 191, 0.16) !important; box-shadow: 0 24px 54px rgba(0, 0, 0, 0.18) !important; backdrop-filter: blur(10px) !important; color: #ffffff !important; }

div.googleReviews-div > .container > .card > div { padding: 0 !important; }

div.googleReviews-div .avatar-google-place { width: 78px !important; height: 78px !important; min-width: 78px !important; margin: 0 22px 0 0 !important; padding: 10px !important; object-fit: contain !important; border-radius: 999px !important; background: #ffffff !important; border: 1px solid rgba(219, 211, 191, 0.22) !important; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28) !important; }

div.googleReviews-div h3 { margin: 0 0 10px !important; font-family: "Cabin", sans-serif !important; font-size: 2rem !important; line-height: 1 !important; text-transform: uppercase !important; letter-spacing: 0.24rem !important; font-weight: 700 !important; color: #ffffff !important; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35) !important; }

div.googleReviews-div #place-rating { display: inline-flex !important; align-items: center !important; flex-wrap: wrap !important; gap: 4px !important; font-size: 1rem !important; line-height: 1.4 !important; color: #dbd3bf !important; }

div.googleReviews-div .star { color: #b49930 !important; margin: 0 1px !important; filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.22)) !important; }

div.googleReviews-div #maps-url, div.googleReviews-div a.button_homepageScreen { display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 12px !important; padding: 16px 24px !important; border-radius: 999px !important; background: #8e7203 !important; color: #ffffff !important; text-decoration: none !important; font-family: "Cabin", sans-serif !important; text-transform: uppercase !important; letter-spacing: 0.2rem !important; font-size: 0.82rem !important; font-weight: 700 !important; border: 1px solid rgba(219, 211, 191, 0.22) !important; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28) !important; transition: transform 0.3s ease, background 0.3s ease, color 0.3s ease, box-shadow 0.3s ease !important; }

div.googleReviews-div #maps-url:hover, div.googleReviews-div a.button_homepageScreen:hover { background: #b49930 !important; color: #ffffff !important; transform: translateY(-4px) !important; box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36) !important; }

div.googleReviews-div #maps-url i, div.googleReviews-div a.button_homepageScreen i { width: 20px !important; height: 20px !important; margin: 0 !important; font-size: 20px !important; line-height: 1 !important; color: currentColor !important; transition: transform 0.3s ease !important; }

div.googleReviews-div #maps-url:hover i, div.googleReviews-div a.button_homepageScreen:hover i { transform: translateX(4px) scale(1.08) !important; }

div.googleReviews-div #google-reviews-widget { position: relative !important; z-index: 2 !important; max-width: 1240px !important; margin: 0 auto !important; padding: 0 62px !important; }

div.googleReviews-div .owl-stage-outer { overflow: hidden !important; padding: 10px 0 22px !important; }

div.googleReviews-div .owl-item .card { min-height: 250px !important; margin: 0 12px 24px !important; padding: 28px 24px !important; border-radius: 28px !important; background: linear-gradient(180deg, rgba(38, 61, 91, 0.72), rgba(38, 61, 91, 0.34)) !important; border: 1px solid rgba(219, 211, 191, 0.16) !important; box-shadow: 0 24px 54px rgba(0, 0, 0, 0.18) !important; backdrop-filter: blur(10px) !important; color: #ffffff !important; transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease !important; }

div.googleReviews-div .owl-item .card:hover { transform: translateY(-8px) !important; border-color: rgba(219, 211, 191, 0.28) !important; box-shadow: 0 34px 74px rgba(0, 0, 0, 0.28) !important; }

div.googleReviews-div .owl-item .card > .d-flex { justify-content: flex-start !important; flex-wrap: nowrap !important; margin: 0 0 20px !important; text-align: left !important; }

div.googleReviews-div .avatar-google-reviews { width: 46px !important; height: 46px !important; min-width: 46px !important; margin: 0 14px 0 0 !important; padding: 8px !important; object-fit: contain !important; border-radius: 999px !important; background: #ffffff !important; border: 1px solid rgba(219, 211, 191, 0.22) !important; box-shadow: 0 12px 28px rgba(0, 0, 0, 0.2) !important; }

div.googleReviews-div .owl-item .mx-2 { margin-left: 0 !important; margin-right: 0 !important; color: #ffffff !important; font-family: "Cabin", sans-serif !important; font-size: 0.84rem !important; line-height: 1.35 !important; text-transform: uppercase !important; letter-spacing: 0.12rem !important; font-weight: 700 !important; }

div.googleReviews-div .owl-item small, div.googleReviews-div .text-muted { color: rgba(219, 211, 191, 0.75) !important; font-family: "Google Sans", sans-serif !important; font-size: 0.82rem !important; text-transform: none !important; letter-spacing: 0 !important; font-weight: 400 !important; }

div.googleReviews-div .card-body { padding: 0 !important; color: #dbd3bf !important; }

div.googleReviews-div .card-body span { display: inline-flex !important; gap: 2px !important; margin-bottom: 16px !important; }

div.googleReviews-div .card-text, div.googleReviews-div .lead, div.googleReviews-div .fs-6 { margin: 0 !important; font-family: "Google Sans", sans-serif !important; font-size: 1rem !important; line-height: 1.75 !important; font-weight: 400 !important; color: #dbd3bf !important; }

div.googleReviews-div .owl-nav { position: absolute !important; inset: 42% 0 auto 0 !important; z-index: 5 !important; display: flex !important; justify-content: space-between !important; pointer-events: none !important; }

div.googleReviews-div .owl-prev, div.googleReviews-div .owl-next { width: 54px !important; height: 54px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; border-radius: 999px !important; border: 1px solid rgba(219, 211, 191, 0.22) !important; background: #8e7203 !important; color: #ffffff !important; cursor: pointer !important; pointer-events: auto !important; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28) !important; transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease !important; }

div.googleReviews-div .owl-prev:hover, div.googleReviews-div .owl-next:hover { background: #b49930 !important; transform: translateY(-4px) !important; box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36) !important; }

div.googleReviews-div .owl-prev span, div.googleReviews-div .owl-next span { display: block !important; margin-top: -4px !important; font-size: 42px !important; line-height: 1 !important; color: #ffffff !important; font-family: Arial, sans-serif !important; font-weight: 300 !important; }

div.googleReviews-div .owl-dots { margin-top: 14px !important; }

div.googleReviews-div .owl-dot span { background: rgba(219, 211, 191, 0.35) !important; }

div.googleReviews-div .owl-dot.active span { background: #b49930 !important; }

@media (max-width: 900px) { div.googleReviews-div { padding: 86px 24px !important; text-align: center !important; } div.googleReviews-div > .container > .card { padding: 30px 24px !important; } div.googleReviews-div .avatar-google-place { margin: 0 auto 18px !important; } div.googleReviews-div h3 { font-size: 1.7rem !important; letter-spacing: 0.18rem !important; } div.googleReviews-div #google-reviews-widget { padding: 0 54px !important; } div.googleReviews-div .owl-nav { inset: 45% 0 auto 0 !important; } }

@media (max-width: 600px) { div.googleReviews-div { padding: 72px 20px !important; } div.googleReviews-div h3 { font-size: 1.35rem !important; letter-spacing: 0.14rem !important; } div.googleReviews-div #place-rating { justify-content: center !important; font-size: 0.92rem !important; } div.googleReviews-div #maps-url, div.googleReviews-div a.button_homepageScreen { width: 100% !important; max-width: 340px !important; font-size: 0.72rem !important; padding: 15px 20px !important; } div.googleReviews-div #google-reviews-widget { padding: 0 0 72px !important; } div.googleReviews-div .owl-item .card { min-height: auto !important; margin: 0 8px 20px !important; padding: 28px 22px !important; } div.googleReviews-div .owl-nav { top: auto !important; bottom: 0 !important; justify-content: center !important; gap: 16px !important; } div.googleReviews-div .owl-prev, div.googleReviews-div .owl-next { width: 46px !important; height: 46px !important; } div.googleReviews-div .owl-prev span, div.googleReviews-div .owl-next span { font-size: 36px !important; } }

/*******************************************RESEAUX SOCIAUX****************************/
.sl-social { position: relative; padding: 110px 6vw; background: #142234; color: #ffffff; font-family: "Google Sans", sans-serif; overflow: hidden; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2Fv0MkHYdj88dfc8hubAXJkgUEaHJ2%2Fimages%2FCharte_Graphique_1_wc81.webp"); background-size: contain; background-position: bottom right; background-repeat: no-repeat; }

.sl-social::before { content: ""; position: absolute; right: -220px; bottom: -260px; width: 680px; height: 680px; border-radius: 50%; background: radial-gradient(circle, rgba(180, 153, 48, 0.18) 0%, rgba(180, 153, 48, 0.1) 32%, rgba(180, 153, 48, 0.04) 52%, rgba(180, 153, 48, 0) 72%) !important; pointer-events: none; z-index: 0; }

.sl-social__inner { position: relative; z-index: 1; max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1fr) 420px; gap: 72px; align-items: center; }

.sl-social__eyebrow { display: inline-flex; margin-bottom: 18px; padding: 10px 16px; border-radius: 999px; background: #263d5b6b; border: 1px solid rgba(219, 211, 191, 0.2); backdrop-filter: blur(10px); font-family: "Cabin", sans-serif; font-size: 0.72rem; line-height: 1; text-transform: uppercase; letter-spacing: 0.24rem; font-weight: 700; color: #dbd3bf; }

.sl-social h2 { max-width: 720px; margin: 0 0 28px; font-family: "Cabin", sans-serif; font-size: 3.6rem; line-height: 0.95; text-transform: uppercase; letter-spacing: 0.38rem; font-weight: 700; color: #ffffff; text-shadow: 0 16px 40px rgba(0, 0, 0, 0.35); }

.sl-social p { max-width: 650px; margin: 0 0 34px; font-size: 1.05rem; line-height: 1.85; color: #dbd3bf; }

.sl-social__btn { display: inline-flex; align-items: center; justify-content: center; gap: 12px; padding: 16px 24px; border-radius: 999px; background: #8e7203; color: #ffffff; text-decoration: none; font-family: "Cabin", sans-serif; text-transform: uppercase; letter-spacing: 0.2rem; font-size: 0.82rem; font-weight: 700; border: 1px solid rgba(219, 211, 191, 0.22); box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28); transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease; }

.sl-social__btn svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.3s ease; }

.sl-social__btn:hover { background: #b49930; color: #ffffff; transform: translateY(-4px); box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36); }

.sl-social__btn:hover svg { transform: translateX(4px) scale(1.08); }

.sl-social__embed { position: relative; width: 100%; min-height: 400px; padding: 14px; border-radius: 34px; background: linear-gradient(180deg, rgba(38, 61, 91, 0.72), rgba(38, 61, 91, 0.34)); border: 1px solid rgba(219, 211, 191, 0.16); box-shadow: 0 34px 80px rgba(0, 0, 0, 0.34); backdrop-filter: blur(10px); overflow: hidden; }

.sl-social__embed iframe { width: 100%; height: 400px; border: 0; border-radius: 24px; background: #ffffff; }

@media (max-width: 1100px) { .sl-social__inner { grid-template-columns: 1fr; gap: 58px; } .sl-social__content { text-align: center; } .sl-social h2, .sl-social p { margin-left: auto; margin-right: auto; } .sl-social__embed { max-width: 430px; margin: 0 auto; } }

@media (max-width: 900px) { .sl-social { padding: 86px 24px; } .sl-social h2 { font-size: 2.8rem; line-height: 1; } }

@media (max-width: 600px) { .sl-social { padding: 72px 20px; } .sl-social__eyebrow { font-size: 0.62rem; letter-spacing: 0.14rem; } .sl-social h2 { font-size: 2.1rem; letter-spacing: 0.16rem; } .sl-social p { font-size: 0.96rem; } .sl-social__btn { width: 100%; max-width: 340px; font-size: 0.72rem; padding: 15px 20px; } .sl-social__embed, .sl-social__embed iframe { min-height: 500px; height: 500px; } }

/*---------------------------------Boutons-------------------------------------------------*/
a.button_header, a.button_homepageScreen, a.button_homepageDoubleScreen, a.phone-number-button { display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 12px !important; padding: 16px 24px !important; border-radius: 999px !important; background: #8e7203 !important; color: #ffffff !important; text-decoration: none !important; font-family: "Cabin", sans-serif !important; text-transform: uppercase !important; letter-spacing: 0.2rem !important; font-size: 0.82rem !important; font-weight: 700 !important; border: 1px solid rgba(219, 211, 191, 0.22) !important; box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28) !important; transition: all 0.3s ease !important; }

a.button_header:hover, a.button_homepageScreen:hover, a.button_homepageDoubleScreen:hover, a.phone-number-button:hover { background: #b49930 !important; color: #ffffff !important; transform: translateY(-4px) !important; box-shadow: 0 24px 48px rgba(0, 0, 0, 0.36) !important; }

a.button_header svg, a.button_homepageScreen svg, a.button_homepageDoubleScreen svg, a.phone-number-button svg, a.button_header i, a.button_homepageScreen i, a.button_homepageDoubleScreen i, a.phone-number-button i { width: 20px !important; height: 20px !important; font-size: 20px !important; line-height: 1 !important; color: currentColor !important; fill: none !important; stroke: currentColor !important; stroke-width: 2 !important; stroke-linecap: round !important; stroke-linejoin: round !important; transition: transform 0.3s ease !important; }

a.button_header:hover svg, a.button_homepageScreen:hover svg, a.button_homepageDoubleScreen:hover svg, a.phone-number-button:hover svg, a.button_header:hover i, a.button_homepageScreen:hover i, a.button_homepageDoubleScreen:hover i, a.phone-number-button:hover i { transform: translateX(4px) scale(1.08) !important; }

@media (max-width: 600px) { a.button_header, a.button_homepageScreen, a.button_homepageDoubleScreen, a.phone-number-button { font-size: 0.72rem !important; padding: 15px 20px !important; } }

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