@charset "UTF-8";
@import url(main.css);
a:visited { color: #ffffff !important; }

a.services-carrelage-btn:visited { color: #2170af !important; }

a.services-carrelage-btn:hover { color: white !important; }

a.video-real-btn { color: black !important; }

a.video-real-btn:visited { color: black !important; }

a.nav-link.fs-6.dropdown-toggle.px-0.text-color-secondary.text-center { color: white !important; font-family: Volkhov !important; }

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

.navbar .logo_nav { padding-left: 2rem; }

.navbar { transition: all 0.3s ease; }

.navbar.scrolled { background-color: #8dabb3 !important; backdrop-filter: blur(1rem); box-shadow: 0 2px 5px rgba(19, 57, 72, 0.2) !important; border-bottom: 1px solid #fff; }

/**************** LOGO ****************/
.navbar-brand { height: 9vh !important; width: 9vw !important; }

.logo_nav { height: 10vh !important; transition: all 0.3s ease; }

.logo_nav:hover { transform: scale(1.025); }

a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone { border-radius: 0px !important; }

center.justify-content-center.rounded-circle.overflow-hidden.text-decoration-none { background: none !important; box-shadow: none !important; }

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

a#maps-url { border-radius: 0px !important; }

.mx-auto.first-activity-div.col-lg-11.px-4.py-4.mb-5.mt-5.bg-primaryColor.text-color-primary.rounded-3.shadow-lg.position-relative { border: 1px solid #8dabb3 !important; border-radius: 0px !important; box-shadow: none !important; transition: 0.3s ease; }

.mx-auto.third-activity-div.col-lg-11.px-4.py-4.mb-4.mt-5.bg-primaryColor.text-color-primary.rounded-3.shadow-lg.position-relative { border: 1px solid #8dabb3 !important; border-radius: 0px !important; box-shadow: none !important; transition: 0.3s ease; }

.mx-auto.second-activity-div.col-lg-11.px-4.py-4.mb-5.mt-5.rounded-3.shadow-lg.bg-primaryColor.text-color-primary.position-relative { border: 1px solid #8dabb3 !important; border-radius: 0px !important; box-shadow: none !important; transition: 0.3s ease; }

.mb-5.googleReviews-div { margin-bottom: 5rem !important; margin-top: 5rem !important; }

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

.d-flex.align-items-center.justify-content-center.px-4.py-5.text-center.cta_banner.bg-sixthColor.position-relative { padding-top: 8rem !important; padding-bottom: 8rem !important; }

a#phone-analytics-tag-video-bloc { display: inline-block; padding: 16px 40px !important; background: transparent !important; color: #ffffff !important; border: 2px solid #ffffff !important; border-radius: 0px; text-decoration: none !important; text-transform: uppercase; letter-spacing: 2px; transition: all 0.3s ease; }

a#phone-analytics-tag-video-bloc:hover { background: #ffffff !important; color: #111111 !important; }

a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2 { display: inline-block; padding: 16px 40px !important; background: transparent !important; color: #ffffff !important; border: 2px solid #ffffff !important; border-radius: 0px; text-decoration: none !important; text-transform: uppercase; letter-spacing: 2px; transition: all 0.3s ease; }

/* Hover */
a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2:hover { background: #ffffff !important; color: #111111 !important; }

div#fullHeight { height: 85vh; }

.carousel-inner-homepage .carousel-item-homepage > img { animation: none !important; -webkit-animation: none !important; -o-animation: none !important; }

.sliderLogoContainer.mx-auto { width: 25vw !important; }

/*---------------------------------------------------------------------------------------------------ACCUEIL----------------------------------------------------------------------------------------------*/
* { margin: 0; padding: 0; box-sizing: border-box; }

.accueil-carrelage-wrapper { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

/* =============================== HERO MODERNE AVEC CADRE INCOMPLET =================================*/
.accueil-carrelage { position: relative; min-height: 85vh; /* RÉDUIT de 85vh à 75vh */ display: flex; align-items: center; justify-content: center; overflow: hidden; background: #1a1a1a; }

/* ===== VIDÉO DE FOND ===== */
.accueil-carrelage-video { position: absolute; top: 50%; left: 50%; min-width: 100%; min-height: 100%; width: auto; height: auto; transform: translate(-50%, -50%); object-fit: cover; z-index: 0; opacity: 0.85; }

/* ===== OVERLAY ===== */
.accueil-carrelage-overlay { position: absolute; inset: 0; background: linear-gradient(105deg, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.4) 40%, rgba(0, 0, 0, 0.3) 60%, rgba(0, 0, 0, 0.6) 100%); z-index: 1; }

/* ===== CONTAINER ===== */
.accueil-carrelage-container { position: relative; z-index: 2; width: 100%; max-width: 1400px; margin: 0 auto; padding: 250px 80px 100px; /* AJUSTÉ pour le nouveau placement du logo */ display: flex; align-items: center; justify-content: center; }

/* ===== LOGO ===== */
.accueil-carrelage-logo { position: absolute; top: -3rem; /* REPOSITIONNÉ plus haut pour un meilleur équilibre */ left: 50%; transform: translateX(-50%); z-index: 10; width: 280px; /* RÉDUIT pour un look plus élégant */ height: 280px; }

.accueil-carrelage-logo img { width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.3)); }

/* ===== CADRE INCOMPLET ===== */
.accueil-carrelage-frame { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 750px; /* AJUSTÉ pour de meilleures proportions */ height: 380px; /* AJUSTÉ */ max-width: 90%; pointer-events: none; z-index: 2; }

/* Bordure supérieure */
.accueil-carrelage-frame-top { position: absolute; top: 0; left: 0; right: 0; height: 2px; /* AFFINÉ */ background: linear-gradient(90deg, transparent 0%, rgba(31, 111, 174, 0.4) 5%, rgba(31, 111, 174, 0.9) 50%, rgba(31, 111, 174, 0.4) 95%, transparent 100%); box-shadow: 0 0 25px rgba(31, 111, 174, 0.5); border-radius: 2px 2px 0 0; }

/* Bordure droite */
.accueil-carrelage-frame-right { position: absolute; top: 0; right: 0; bottom: 0; width: 2px; /* AFFINÉ */ background: linear-gradient(180deg, rgba(31, 111, 174, 0.4) 0%, rgba(31, 111, 174, 0.9) 50%, rgba(31, 111, 174, 0.4) 100%); box-shadow: 0 0 25px rgba(31, 111, 174, 0.5); border-radius: 0 2px 2px 0; }

/* Bordure inférieure */
.accueil-carrelage-frame-bottom { position: absolute; bottom: 0; left: 0; right: 0; height: 2px; /* AFFINÉ */ background: linear-gradient(90deg, transparent 0%, rgba(31, 111, 174, 0.4) 5%, rgba(31, 111, 174, 0.9) 50%, rgba(31, 111, 174, 0.4) 95%, transparent 100%); box-shadow: 0 0 25px rgba(31, 111, 174, 0.5); border-radius: 0 0 2px 2px; }

/* ===== CONTENU ===== */
.accueil-carrelage-content { position: relative; z-index: 3; max-width: 700px; /* RÉDUIT de 800px à 700px */ text-align: center; }

/* Titre */
.accueil-carrelage-title { font-size: clamp(26px, 3.8vw, 46px); /* AJUSTÉ pour plus de présence */ font-weight: 700; color: #ffffff; margin: 0 0 20px 0; line-height: 1.2; letter-spacing: -0.5px; text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4), 0 4px 16px rgba(0, 0, 0, 0.3); }

/* Sous-titre */
.accueil-carrelage-subtitle { font-size: clamp(14px, 1.8vw, 17px); /* LÉGÈREMENT RÉDUIT */ font-weight: 300; color: rgba(255, 255, 255, 0.85); margin: 0 0 40px 0; /* RÉDUIT de 50px à 40px */ line-height: 1.7; max-width: 650px; /* RÉDUIT de 700px à 650px */ margin-left: auto; margin-right: auto; }

/* Boutons */
.accueil-carrelage-actions { display: flex; align-items: center; justify-content: center; gap: 20px; flex-wrap: wrap; }

.accueil-carrelage-btn { display: inline-flex; align-items: center; justify-content: center; padding: 16px 40px; font-size: 14px; font-weight: 600; text-decoration: none; border-radius: 4px; /* LÉGÈREMENT ARRONDI */ transition: all 0.3s ease; text-transform: uppercase; letter-spacing: 0.5px; cursor: pointer; }

.accueil-carrelage-btn-primary { background: linear-gradient(135deg, #1f6fae 0%, #1a5a8f 100%); color: #ffffff; box-shadow: 0 8px 24px rgba(31, 111, 174, 0.3); }

.accueil-carrelage-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(31, 111, 174, 0.4); color: #ffffff; }

.accueil-carrelage-btn-secondary { background: transparent; color: #ffffff; border: 2px solid rgba(255, 255, 255, 0.4); padding: 14px 38px; }

.accueil-carrelage-btn-secondary:hover { background: rgba(255, 255, 255, 0.1); border-color: rgba(255, 255, 255, 0.6); transform: translateY(-2px); color: #ffffff; }

/* =========================== RESPONSIVE =========================== */
@media (max-width: 1024px) { .accueil-carrelage-container { padding: 180px 60px 80px; } .accueil-carrelage-logo { width: 180px; height: 180px; top: -30px; } .accueil-carrelage-frame { width: 650px; height: 350px; } }

@media (max-width: 768px) { .accueil-carrelage-container { padding: 160px 30px 70px; flex-direction: column; } .accueil-carrelage-logo { width: 160px; height: 160px; top: -30px; } .accueil-carrelage-frame { width: 90%; height: 320px; } .accueil-carrelage-actions { flex-direction: column; width: 100%; gap: 16px; } .accueil-carrelage-btn { width: 100%; max-width: 320px; } }

@media (max-width: 480px) { .accueil-carrelage-container { padding: 140px 20px 60px; } .accueil-carrelage-logo { width: 140px; height: 140px; top: -30px; } .accueil-carrelage-frame { display: none; } .accueil-carrelage-btn { padding: 14px 32px; font-size: 13px; } }

/*---------------------------------------------------------------------------------------------------INTRO----------------------------------------------------------------------------------------------*/
/* =============================== SECTION À PROPOS STYLE PREMIUM =================================*/
.apropos-rdim { position: relative; background: #ebeff0; padding: 90px 20px; text-align: center; overflow: hidden; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FbDirF4nUnNOlrhtdyMKqtKOClIO2%2Fimages%2FArtisan_carreleur_1920_x_800_px_1ucj.webp"); background-size: cover; background-position: center; }

/* Container contenu */
.apropos-container { position: relative; z-index: 2; max-width: 1250px; margin: 0 auto; }

/* Petit titre */
.apropos-tag { font-size: 17px; letter-spacing: 2px; text-transform: uppercase; color: #6b7280; margin-bottom: 1px; }

/* Titre */
.apropos-title { font-size: clamp(32px, 5vw, 48px); font-weight: 600; color: #1f2937; margin-bottom: 40px; line-height: 1.3; }

/* Texte */
.apropos-text { font-size: 18px; color: #374151; line-height: 1.8; margin-bottom: 25px; }

/* Villes */
.apropos-locations { display: flex; justify-content: center; align-items: center; gap: 30px; margin: 50px 0 60px; flex-wrap: wrap; }

.apropos-locations span { font-size: 18px; color: #1f2937; padding: 10px 22px; border: 1px solid rgba(31, 41, 55, 0.2); background: rgba(255, 255, 255, 0.6); backdrop-filter: blur(4px); letter-spacing: 0.5px; transition: 0.3s ease; }

/* =============================== RESPONSIVE =================================*/
@media (max-width: 768px) { .apropos-rdim { padding: 100px 20px; } .apropos-corner-img { width: 250px; height: 250px; transform: translate(30%, -30%); } .apropos-locations { gap: 15px; } }

/*---------------------------------------------------------------------------------------------------SERVICES----------------------------------------------------------------------------------------------*/
/* =============================== SERVICES CARRELAGE - VERSION AMÉLIORÉE =================================*/
/* Reset box-sizing */
.services-carrelage, .services-carrelage * { box-sizing: border-box; }

.services-carrelage img { display: block; max-width: 100%; }

/* Section principale */
.services-carrelage { background: #ebeff0; padding: 120px 0; position: relative; }

/* Container */
.services-carrelage-container { width: 100%; max-width: 1300px; margin: 0 auto; padding: 0 60px; }

/* ===== HEADER ===== */
.services-carrelage-header { display: grid; grid-template-columns: 1fr 1px 1.2fr; align-items: center; gap: 50px; margin-bottom: 50px; }

.services-carrelage-header-left { text-align: left; }

.services-carrelage-header-right { text-align: left; }

/* Titre */
.services-carrelage-title { font-size: clamp(28px, 4vw, 42px); font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase; margin: 0; color: #1a1a1a; line-height: 1.2; }

/* Sous-titre */
.services-carrelage-subtitle { font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 300; color: #555; line-height: 1.8; margin: 0; }

/* Divider vertical */
.services-carrelage-divider { width: 1px; height: 80px; background: linear-gradient(to bottom, transparent, #c4c4c4 20%, #c4c4c4 80%, transparent); }

/* Ligne horizontale */
.services-carrelage-line { width: 100%; height: 1px; background: linear-gradient(to right, transparent, #c4c4c4 10%, #c4c4c4 90%, transparent); margin-bottom: 90px; }

/* ===== GRILLE DE CARTES ===== */
.services-carrelage-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 50px; margin-bottom: 0; }

/* ===== CARTE ===== */
.services-carrelage-card { display: flex; flex-direction: column; transition: transform 0.4s ease; }

.services-carrelage-card:hover { transform: translateY(-8px); }

/* Image container */
.services-carrelage-card-image { position: relative; width: 100%; aspect-ratio: 4 / 5; overflow: hidden; box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12), 0 2px 8px rgba(0, 0, 0, 0.06); margin-bottom: -150px; z-index: 1; }

.services-carrelage-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1); }

/* Overlay sur image au hover */
.services-carrelage-card-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(31, 111, 174, 0) 0%, rgba(31, 111, 174, 0.15) 100%); opacity: 0; transition: opacity 0.4s ease; pointer-events: none; }

.services-carrelage-card:hover .services-carrelage-card-image img { transform: scale(1.08); }

.services-carrelage-card:hover .services-carrelage-card-overlay { opacity: 1; }

/* Contenu de la carte */
.services-carrelage-card-content { background: #ffffff; padding: 40px 30px 30px; margin: 0 auto; width: 88%; text-align: center; box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08), 0 5px 15px rgba(0, 0, 0, 0.04); position: relative; z-index: 2; transition: box-shadow 0.4s ease; }

.services-carrelage-card:hover .services-carrelage-card-content { box-shadow: 0 20px 50px rgba(0, 0, 0, 0.12), 0 8px 20px rgba(0, 0, 0, 0.06); }

/* Titre de carte */
.services-carrelage-card-title { font-size: 22px; font-weight: 500; color: #1a1a1a; margin: 0 0 16px 0; letter-spacing: 0.5px; line-height: 1.3; }

/* Texte de carte */
.services-carrelage-card-text { font-size: 14px; font-weight: 300; color: #666; line-height: 1.7; margin: 0; }

/* ===== CTA ===== */
.services-carrelage-cta { text-align: center; margin-top: 90px; }

.services-carrelage-btn { display: inline-block; padding: 16px 48px; border: 2px solid #1f6fae; background: transparent; color: #1f6fae; text-decoration: none; font-size: 13px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); position: relative; overflow: hidden; }

.services-carrelage-btn::before { content: ''; position: absolute; inset: 0; background: #1f6fae; transform: scaleX(0); transform-origin: left; transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1); z-index: -1; }

.services-carrelage-btn:hover::before { transform: scaleX(1); }

.services-carrelage-btn:hover { color: #ffffff; border-color: #1f6fae; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(31, 111, 174, 0.3); }

/* =========================== RESPONSIVE =========================== */
/* Tablette */
@media (max-width: 1024px) { .services-carrelage { padding: 100px 0; } .services-carrelage-container { padding: 0 50px; } .services-carrelage-header { gap: 40px; } .services-carrelage-grid { grid-template-columns: repeat(2, 1fr); gap: 45px; } .services-carrelage-card:last-child { grid-column: 1 / -1; max-width: 450px; margin: 0 auto; } .services-carrelage-cta { margin-top: 80px; } }

/* Mobile */
@media (max-width: 768px) { .services-carrelage { padding: 80px 0; } .services-carrelage-container { padding: 0 30px; } .services-carrelage-header { grid-template-columns: 1fr; text-align: center; gap: 25px; margin-bottom: 40px; } .services-carrelage-header-left, .services-carrelage-header-right { text-align: center; } .services-carrelage-divider { display: none; } .services-carrelage-title { letter-spacing: 2px; } .services-carrelage-subtitle { font-size: 14px; } .services-carrelage-line { margin-bottom: 60px; } .services-carrelage-grid { grid-template-columns: 1fr; gap: 60px; } .services-carrelage-card:last-child { grid-column: auto; max-width: none; } .services-carrelage-card-image { margin-bottom: -40px; } .services-carrelage-card-content { width: 92%; padding: 35px 25px 25px; } .services-carrelage-card-title { font-size: 20px; } .services-carrelage-card-text { font-size: 13px; } .services-carrelage-cta { margin-top: 70px; } .services-carrelage-btn { width: 100%; max-width: 320px; } }

/* Petit mobile */
@media (max-width: 480px) { .services-carrelage { padding: 60px 0; } .services-carrelage-container { padding: 0 20px; } .services-carrelage-header { margin-bottom: 35px; } .services-carrelage-line { margin-bottom: 50px; } .services-carrelage-grid { gap: 55px; } .services-carrelage-card-image { margin-bottom: -35px; } .services-carrelage-card-content { padding: 32px 22px 22px; } .services-carrelage-card-title { font-size: 19px; margin-bottom: 14px; } .services-carrelage-cta { margin-top: 60px; } .services-carrelage-btn { padding: 14px 40px; font-size: 12px; } }

/*---------------------------------------------------------------------------------------------------REALISATION----------------------------------------------------------------------------------------------*/
/* ---------------------------------------------------------- */
/* REALISATION LAGE */
/* ---------------------------------------------------------- */
.realisation-lage { display: grid; grid-template-columns: repeat(4, 1fr); width: 100%; }

.realisation-lage-item { position: relative; width: 100%; aspect-ratio: 1 / 1; overflow: hidden; display: block; }

.realisation-lage-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }

.realisation-lage-item:hover img { transform: scale(1.05); }

/* ---------------------------------------------------------- */
/* RESPONSIVE */
/* ---------------------------------------------------------- */
@media (max-width: 992px) { .realisation-lage { grid-template-columns: repeat(2, 1fr); } }

@media (max-width: 480px) { .realisation-lage { grid-template-columns: 1fr; } }

/*---------------------------------------------------------------------------------------------------PRESENTATION----------------------------------------------------------------------------------------------*/
/* =============================== PRESENTATION CARR =================================*/
.presentation-carr { background: #f2f4f4; padding: 110px 40px; position: relative; overflow: hidden; }

/* Image décorative coin haut droit (AGRANDIE) */
.presentation-carr-corner { position: absolute; top: 0; right: 0; width: 650px; /* plus grande */ height: 650px; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FbDirF4nUnNOlrhtdyMKqtKOClIO2%2Fimages%2FRDIM_Carrelage_bmfh.webp"); background-size: cover; background-position: center; transform: translate(30%, -30%); opacity: 0.18; pointer-events: none; }

/* Container principal */
.presentation-carr-container { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 45% 55%; align-items: center; gap: 80px; position: relative; z-index: 2; }

/* ===== IMAGE ===== */
.presentation-carr-frame img { width: 100%; display: block; }

/* ===== TEXTE ===== */
.presentation-carr-content { text-align: center; /* CENTRÉ desktop */ }

.presentation-carr-subtitle { font-size: 12px; letter-spacing: 4px; text-transform: uppercase; margin-bottom: 18px; color: #8a8f93; }

.presentation-carr-title { font-size: clamp(32px, 4vw, 48px); line-height: 1.2; margin-bottom: 28px; color: #1c1c1c; }

.presentation-carr-content p { font-size: 18px; line-height: 1.8; margin-bottom: 18px; color: #4f4f4f; max-width: 560px; margin-left: auto; /* centre les paragraphes */ margin-right: auto; }

/* ================= RESPONSIVE ================= */
@media (max-width: 1024px) { .presentation-carr-container { grid-template-columns: 1fr; gap: 60px; text-align: center; } .presentation-carr-content p { max-width: 100%; } .presentation-carr-corner { width: 450px; height: 450px; opacity: 0.12; } }

@media (max-width: 600px) { .presentation-carr { padding: 80px 20px; } .presentation-carr-title { font-size: 28px; } .presentation-carr-content p { font-size: 15px; } .presentation-carr-corner { width: 320px; height: 320px; transform: translate(40%, -40%); } }

/*---------------------------------------------------------------------------------------------------CARRELAGE----------------------------------------------------------------------------------------------*/
/* =============================== POSE CARRELAGE SECTION =================================*/
.pose-carrelage { position: relative; width: 100%; padding: 100px 20px; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FbDirF4nUnNOlrhtdyMKqtKOClIO2%2Fimages%2FArtisan_carreleur_2_p832.webp"); background-size: cover; background-position: center; background-attachment: fixed; display: flex; flex-direction: column; align-items: center; }

/* Overlay sombre */
.pose-carrelage::before { content: ''; position: absolute; inset: 0; background: rgba(0, 0, 0, 0.55); z-index: 1; }

/* ===== TITRE ===== */
.pose-carrelage-title { position: relative; z-index: 2; font-family: Georgia, serif; font-size: clamp(2rem, 5vw, 3rem); color: #f5f1eb; text-align: center; margin-bottom: 15px; font-weight: 400; letter-spacing: 2px; }

/* Ligne décorative sous le titre */
.pose-carrelage-title::after { content: ""; display: block; width: 80px; height: 2px; background: #1f6fae; margin: 18px auto 0; }

.pose-carrelage-subtitle { position: relative; z-index: 2; color: #dcdcdc; margin-bottom: 60px; font-size: 1.1rem; text-align: center; }

/* ===== CARTES ===== */
.pose-carrelage-cards { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 30px; max-width: 1100px; width: 100%; }

.pose-carrelage-card { background: #f5f1eb; border-radius: 8px; padding: 35px 30px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3); transition: transform 0.3s ease, box-shadow 0.3s ease; position: relative; border: 1px solid rgba(0, 0, 0, 0.05); }

/* Accent graphique haut de carte */
.pose-carrelage-card::before { content: ""; position: absolute; top: 0; left: 0; height: 4px; width: 100%; background: linear-gradient(90deg, #1f6fae, #2eb5e5); border-top-left-radius: 9px; border-top-right-radius: 9px; }

.pose-carrelage-card h3 { font-size: 24px; margin-bottom: 18px; color: #3a3a3a; font-weight: 500; letter-spacing: 0.5px; }

.pose-carrelage-card p { font-size: 17px; color: #5c5c5c; line-height: 1.6; margin-bottom: 15px; }

.pose-carrelage-list { list-style: none; padding: 0; margin: 0; }

.pose-carrelage-list li { margin-bottom: 8px; font-size: 17px; color: #444; }

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) { .pose-carrelage { padding: 70px 15px; background-attachment: scroll; } .pose-carrelage-subtitle { margin-bottom: 40px; } }

/*---------------------------------------------------------------------------------------------------CARRELAGE EXTERIEUR----------------------------------------------------------------------------------------------*/
\
 .exterieur-carr { position: relative; background-color: #f2f4f6; padding: 120px 20px; overflow: hidden; }

/* Image de fond décorative */
.exterieur-carr::before { content: ""; position: absolute; inset: 0; background-image: url("https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2FbDirF4nUnNOlrhtdyMKqtKOClIO2%2Fimages%2FArtisan_carreleur_1920_x_800_px_1ucj.webp?alt=media&token=60e80e57-e0af-443a-81f5-a355618cdfe1"); background-size: cover; background-position: center; opacity: 0.08; z-index: 0; }

.exterieur-carr-inner { position: relative; z-index: 1; max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: center; margin-top: 2rem; margin-bottom: 2rem; }

/* IMAGE */
.exterieur-carr-image { display: flex; justify-content: center; }

.exterieur-carr-image img { width: 100%; max-width: 520px; height: auto; display: block; }

/* CONTENU */
.exterieur-carr-content { max-width: 620px; }

.exterieur-carr-subtitle { display: block; font-size: 17px; letter-spacing: 2px; text-transform: uppercase; color: #777; margin-bottom: 10px; }

.exterieur-carr-content h2 { font-size: 44px; font-weight: 800; color: #000; /* NOIR */ margin-bottom: 18px; }

.exterieur-carr-intro { font-size: 18px; line-height: 1.7; color: #444; margin-bottom: 40px; }

/* GRID TEXTE */
.exterieur-carr-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px 40px; }

.exterieur-carr-item h3 { font-size: 18px; font-weight: 700; text-transform: uppercase; color: #000; margin-bottom: 8px; }

.exterieur-carr-item p { font-size: 15px; line-height: 1.6; color: #555; }

/* =============================== RESPONSIVE ================================ */
@media (max-width: 1024px) { .exterieur-carr-inner { grid-template-columns: 1fr; gap: 60px; text-align: center; } .exterieur-carr-content { max-width: 100%; margin: 0 auto; } .exterieur-carr-image img { width: 65%; } }

@media (max-width: 600px) { .exterieur-carr { padding: 80px 20px; } .exterieur-carr-content h2 { font-size: 28px; } .exterieur-carr-grid { grid-template-columns: 1fr; gap: 26px; } .exterieur-carr-image img { width: 85%; max-width: 320px; } }

/*---------------------------------------------------------------------------------------------------VIDEO ACCUEIL----------------------------------------------------------------------------------------------*/
/* =============================== RESET =================================*/
* { margin: 0; padding: 0; box-sizing: border-box; }

/* =============================== VIDEO REAL SECTION =================================*/
.video-real-section { position: relative; min-height: 100vh; display: flex; align-items: center; justify-content: center; overflow: hidden; background: url("https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2FbDirF4nUnNOlrhtdyMKqtKOClIO2%2Fimages%2FArtisan_carreleur_1_8sl1.webp?alt=media&token=991c7f77-f562-4f4e-8eda-5ead0e8d43b7") center/cover no-repeat fixed; padding: 60px 20px; }

/* OVERLAY AVEC GRADIENT MODERNE */
.video-real-section::before { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, rgba(0, 0, 0, 0.05) 0%, rgba(0, 0, 0, 0.05) 0%, rgba(0, 0, 0, 0.05) 100%); z-index: 1; }

/* =============================== CONTENT WRAPPER =================================*/
.video-real-content { position: relative; z-index: 2; width: 100%; max-width: 1280px; display: flex; align-items: center; justify-content: center; gap: 70px; animation: fadeInUp 0.9s ease-out; }

/* =============================== VIDEO CARD 700x500 =================================*/
.video-real-card { position: relative; width: 700px; height: 500px; overflow: hidden; border-radius: 7px; box-shadow: 0 40px 80px rgba(0, 0, 0, 0.7), 0 20px 40px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.05); transition: all 0.4s ease; background: #000; }

.video-real-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0, 0, 0, 0.2) 0%, transparent 30%, transparent 70%, rgba(0, 0, 0, 0.3) 100%); z-index: 1; pointer-events: none; }

.video-real-card:hover { transform: translateY(-8px); box-shadow: 0 50px 100px rgba(0, 0, 0, 0.8), 0 25px 50px rgba(0, 0, 0, 0.6), 0 0 0 1px rgba(255, 255, 255, 0.1); }

.video-real-card video { width: 100%; height: 100%; object-fit: cover; display: block; }

/* =============================== TEXT BLOCK =================================*/
.video-real-text { max-width: 520px; color: #2a2a2a; background: rgba(255, 255, 255, 0.85); padding: 70px 65px; backdrop-filter: blur(20px) saturate(1.3); border-radius: 0px; border: 1px solid rgba(255, 255, 255, 0.6); box-shadow: 0 20px 50px rgba(0, 0, 0, 0.08), 0 8px 20px rgba(0, 0, 0, 0.05), inset 0 1px 0 rgba(255, 255, 255, 0.8); animation: fadeInRight 0.9s ease-out 0.2s both; }

/* TITLE */
.video-real-text h2 { font-size: 27px; letter-spacing: 6px; font-weight: 300; line-height: 1.3; margin-bottom: 35px; text-transform: uppercase; color: #1a1a1a; text-shadow: 0 1px 2px rgba(255, 255, 255, 0.5); }

/* PARAGRAPH */
.video-real-text p { font-size: 17px; line-height: 1.85; color: rgba(40, 40, 40, 0.85); margin-bottom: 40px; font-weight: 400; letter-spacing: 0.3px; }

/* =============================== CTA BUTTON =================================*/
.video-real-btn { position: relative; display: inline-block; padding: 17px 42px; background: linear-gradient(135deg, #ffffff 0%, #f0f0f0 100%); color: #1a1a1a; text-decoration: none; font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; border-radius: 3px; transition: all 0.35s ease; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3), 0 4px 12px rgba(0, 0, 0, 0.2); overflow: hidden; }

.video-real-btn::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, #f8f8f8 0%, #ffffff 100%); opacity: 0; transition: opacity 0.35s ease; }

.video-real-btn span { position: relative; z-index: 1; }

.video-real-btn:hover { transform: translateY(-3px); box-shadow: 0 15px 40px rgba(0, 0, 0, 0.4), 0 6px 16px rgba(0, 0, 0, 0.3); }

.video-real-btn:hover::before { opacity: 1; }

.video-real-btn:active { transform: translateY(-1px); }

/* =============================== ANIMATIONS =================================*/
@keyframes fadeInUp { from { opacity: 0;
    transform: translateY(50px); }
  to { opacity: 1;
    transform: translateY(0); } }

@keyframes fadeInRight { from { opacity: 0;
    transform: translateX(50px); }
  to { opacity: 1;
    transform: translateX(0); } }

/* =============================== RESPONSIVE DESIGN =================================*/
/* Tablettes paysage */
@media (max-width: 1200px) { .video-real-content { gap: 50px; max-width: 95%; } .video-real-card { width: 600px; height: 430px; } .video-real-text { padding: 55px 50px; } }

/* Tablettes portrait */
@media (max-width: 968px) { .video-real-section { padding: 40px 20px; } .video-real-content { flex-direction: column; gap: 50px; max-width: 700px; } .video-real-card { width: 100%; max-width: 700px; height: 500px; } .video-real-text { max-width: 100%; padding: 50px 45px; } .video-real-text h2 { font-size: 40px; letter-spacing: 4px; } }

/* Mobiles */
@media (max-width: 640px) { .video-real-section { padding: 30px 15px; background-attachment: scroll; } .video-real-content { gap: 40px; } .video-real-card { width: 100%; max-width: 100%; height: auto; aspect-ratio: 700 / 500; border-radius: 6px; } .video-real-text { padding: 40px 35px; backdrop-filter: blur(10px); } .video-real-text h2 { font-size: 32px; letter-spacing: 3px; margin-bottom: 25px; } .video-real-text p { font-size: 15px; margin-bottom: 32px; } .video-real-btn { width: 100%; text-align: center; padding: 16px 36px; } }

@media (max-width: 480px) { .video-real-text { padding: 35px 28px; } .video-real-text h2 { font-size: 28px; letter-spacing: 2px; } .video-real-text p { font-size: 14px; } .video-real-btn { padding: 15px 32px; font-size: 12px; } }

/* =============================== OPTIMISATIONS PERFORMANCE =================================*/
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; } }

/*---------------------------------------------------------------------------------------------------CARTES----------------------------------------------------------------------------------------------*/
/* =============================== SERVICE OFFERINGS SECTION =================================*/
.service-offerings { background: #e0e4e7; padding: 120px 40px; text-align: center; }

.service-container { max-width: 1200px; margin: 0 auto; }

/* TITRES */
.service-subtitle { font-size: 12px; letter-spacing: 3px; text-transform: uppercase; color: #8a8f93; margin-bottom: 15px; }

.service-title { font-size: 42px; font-weight: 500; margin-bottom: 25px; color: #2a2a2a; }

.service-intro { max-width: 750px; margin: 0 auto 70px; font-size: 16px; line-height: 1.8; color: #4f4f4f; }

/* GRID */
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 60px; }

/* CARD */
.service-card { display: flex; flex-direction: column; height: 100%; }

/* IMAGE */
.service-image { padding: 15px; border: 2px solid #0f2f4f; margin-bottom: 25px; }

.service-image img { width: 100%; height: 260px; /* HAUTEUR FIXE HARMONISÉE */ object-fit: cover; display: block; border: 1px solid #ddd; }

/* CONTENT */
.service-content { display: flex; flex-direction: column; justify-content: flex-start; min-height: 180px; /* FORCE ÉGALISATION DES BLOCS TEXTE */ }

.service-number { font-size: 22px; color: #8a8f93; margin-bottom: 8px; }

.service-card h3 { font-size: 18px; font-weight: 500; margin-bottom: 12px; color: #2a2a2a; }

.service-card p { font-size: 14px; color: #6f6f6f; line-height: 1.6; max-width: 280px; margin: 0 auto; }

/* ================= RESPONSIVE ================= */
@media (max-width: 1024px) { .service-grid { grid-template-columns: repeat(2, 1fr); } }

@media (max-width: 768px) { .service-grid { grid-template-columns: 1fr; gap: 50px; } .service-title { font-size: 32px; } .service-image img { height: 220px; } }

/* =============================== REALISATION VIDEO SLIDER =================================*/
.realisation-video { padding: 100px 40px; background: #f2f4f6; }

.realisation-video-container { max-width: 1400px; margin: 0 auto; }

.realisation-video-title { text-align: center; font-size: 38px; margin-bottom: 60px; }

/* WRAPPER */
.video-slider-wrapper { position: relative; display: flex; align-items: center; }

/* SLIDER */
.video-slider { display: flex; gap: 30px; overflow-x: auto; scroll-behavior: smooth; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }

/* cacher scrollbar */
.video-slider::-webkit-scrollbar { display: none; }

/* VIDEO ITEM */
.video-item { flex: 0 0 calc(33.333% - 20px); scroll-snap-align: start; }

.video-item video { width: 100%; height: 520px; object-fit: cover; border-radius: 12px; }

/* ARROWS */
.video-arrow { position: absolute; background: #111; color: #fff; border: none; font-size: 28px; width: 50px; height: 50px; border-radius: 50%; cursor: pointer; z-index: 10; transition: 0.3s ease; }

.video-arrow:hover { background: #1f6fae; }

.video-arrow.left { left: -25px; }

.video-arrow.right { right: -25px; }

/* ================= RESPONSIVE ================= */
/* Tablette */
@media (max-width: 1024px) { .video-item { flex: 0 0 50%; } .video-item video { height: 480px; } .video-arrow.left { left: -15px; } .video-arrow.right { right: -15px; } }

/* Mobile */
@media (max-width: 768px) { .video-item { flex: 0 0 85%; } .video-item video { height: 420px; } .realisation-video { padding: 80px 20px; } .video-arrow { width: 42px; height: 42px; font-size: 22px; } .video-arrow.left { left: -5px; } .video-arrow.right { right: -5px; } }

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

/* Media query séparée */
@media screen and (min-width: 991px) { #custom-gallery { padding: 60px 30px 0 30px; } }

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

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

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

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

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

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

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

@media screen and (min-width: 768px) { #overlay img { width: 60%; } #nextButton, #prevButton, #exitButton { font-size: 3em; } }

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

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

#nextButton:hover, #prevButton:hover, #exitButton:hover { opacity: 0.7; }

#exitButton { position: absolute; top: 15px; right: 15px; }

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

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