@charset "UTF-8";
@import url(main.css);
a.button_homepageScreen { border-radius: 10px; }

div#fullHeight { height: 80vh !important; }

img.fondDegradeLogo { padding-top: 50px !important; }

.titleText.text-white.text-center.fs-2.mb-4.mt-lg-5.titles { margin-bottom: 3rem !important; }

main a, main a:hover, main a:visited { color: #3f68ae !important; }

.d-block.mx-lg-auto.img-fluid { border-radius: var(--bs-border-radius-lg) !important; }

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

.row.align-items-center.g-lg-5.py-5.position-relative { margin-top: 10px !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: 2px solid #3e5887 !important; border-radius: var(--bs-border-radius-lg) !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: 2px solid #3e5887 !important; border-radius: var(--bs-border-radius-lg) !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: 2px solid #3e5887 !important; border-radius: var(--bs-border-radius-lg) !important; box-shadow: none !important; transition: 0.3s ease; }

.card.card-cover.h-100.overflow-hidden.rounded-4.shadow-lg { border-radius: var(--bs-border-radius-lg) !important; }

.black-screen { border-radius: var(--bs-border-radius-lg) !important; }

.background-image-div-opacity { background-attachment: scroll; }

form#formContact { border: 1px solid #3e66af !important; }

.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 { box-shadow: none !important; }

/************* NAVBAR *************/
/* Force l’affichage et la position de la navbar */
#navigation-bar-hide { opacity: 1 !important; top: 0 !important; }

/* Dimensions du conteneur de la marque (logo) */
.navbar-brand { height: 10vh !important; width: 10vw !important; }

/* Logo principal */
.logo_nav { height: 9vh !important; transition: all 0.3s ease; /* animation fluide */ }

/* Décalage du logo lorsqu’il est dans la navbar */
.navbar .logo_nav { padding-left: 2rem; }

/* Navbar : état unique (pas de changement au scroll) */
.navbar { background-color: rgba(51, 51, 51, 0.5) !important; /* fond semi-transparent */ backdrop-filter: blur(1rem); /* effet de flou */ border-bottom: 1px solid #fafafa; }

/* Effet de zoom léger au survol du logo */
.logo_nav:hover { transform: scale(1.025); }

/* Bouton avec bordure animée (pseudo-élément) */
.animated-border-button::after { background-color: #fafafa; }

.py-5 { padding-top: 6rem !important; padding-bottom: 6rem !important; }

div#fullHeight { height: 75vh; }

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

.sliderLogoContainer.mx-auto { width: 10rem !important; }

.mx-auto.col-lg-11.px-4.py-4.mb-5.mt-5.text-color-primary.rounded-3.shadow-lg.bg-primaryColor.position-relative { box-shadow: none !important; }

#contour.mx-auto.col-lg-11.px-4.py-4.mb-5.mt-5.text-color-primary.rounded-3.shadow-lg.bg-primaryColor.position-relative { margin: 0 !important; width: 100%; margin-bottom: 4rem !important; }

/*------------------- BOUTON CTA --------------------------*/
/* 🎯 Style bouton bleu plein */
a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2 { display: inline-block; border: 2px solid #3e66af; border-radius: 0px !important; padding: 10px 28px; background-color: #3e66af !important; /* 🔵 avant hover */ color: #ffffff !important; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; text-decoration: none; transition: all 0.3s ease; box-shadow: 0 6px 18px rgba(62, 102, 175, 0.4); }

/* 🌊 Hover / focus / active */
a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2:hover, a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2:focus, a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2:active { background-color: #4f7fd6 !important; /* 🔵 après hover */ border-color: #4f7fd6; color: #ffffff !important; box-shadow: 0 8px 24px rgba(79, 127, 214, 0.5); }

/* 🩵 Texte interne (span, strong, svg) */
a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2 span, a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2 strong, a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2 svg { color: #ffffff !important; fill: #ffffff !important; }

/*------------------- BOUTON NAV --------------------------*/
/* 🎯 Style bouton bleu contour */
a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone { display: inline-block; border: 2px solid #fff; border-radius: 10px !important; padding: 10px 28px; background-color: transparent !important; color: #fff !important; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; text-decoration: none; transition: all 0.3s ease; }

/* 🌊 Hover / focus / active */
a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone:hover, a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone:focus, a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone:active { background-color: #4f7fd6 !important; border-color: #4f7fd6; color: #ffffff !important; box-shadow: 0 6px 20px rgba(79, 127, 214, 0.45); }

/* 🩵 Contenu interne */
a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone:hover span, a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone:hover strong, a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone:hover svg { color: #ffffff !important; fill: #ffffff !important; }

/*------------------------------------------------------------------------------------------- SERVICES----------------------------------------------------------------------------------------------------*/
/* ===================================== SECTION SERVICES ===================================== */
.services-section { padding: 80px 20px; background: rgba(96, 112, 145, 0.14); }

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

/* TITRES */
.services-title { font-size: clamp(32px, 4vw, 42px); font-weight: 600; text-align: center; color: #3e5887; margin-bottom: 16px; line-height: 1.2; }

.services-subtitle { font-size: 19px; color: #666; text-align: center; max-width: 700px; margin: 0 auto 60px; line-height: 1.6; }

/* SUPPRIMER TOUT TRAIT / SOULIGNEMENT SUR LA FLÈCHE */
.card-arrow { text-decoration: none !important; }

.card-arrow::after, .card-arrow::before { content: none !important; }

.card-arrow:hover, .card-arrow:focus, .card-arrow:active { text-decoration: none !important; }

/* ===================================== GRILLE – DESKTOP (≥1025px) 3 cartes / 2 centrées dessous ===================================== */
.services-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 30px; max-width: 1200px; margin: 0 auto; }

/* CARTE */
.service-card { grid-column: span 2; aspect-ratio: 1; width: 100%; height: 18rem; position: relative; border-radius: var(--bs-border-radius-lg) !important; background: linear-gradient(to bottom, rgba(62, 88, 135, 0.92) 0%, rgba(62, 88, 135, 0.96) 100%); overflow: hidden; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08); transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); }

.service-card:hover { transform: translateY(-8px); box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15); }

/* POSITIONNEMENT DES CARTES */
.services-grid .service-card:nth-child(1) { grid-column: 1 / span 2; }

.services-grid .service-card:nth-child(2) { grid-column: 3 / span 2; }

.services-grid .service-card:nth-child(3) { grid-column: 5 / span 2; }

.services-grid .service-card:nth-child(4) { grid-column: 2 / span 2; }

.services-grid .service-card:nth-child(5) { grid-column: 4 / span 2; }

/* CONTENU */
.card-image { width: 100%; height: 100%; }

.card-content { height: 100%; padding: 30px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }

/* ICÔNE */
.card-icon-img { width: 120px; margin-bottom: 20px; filter: brightness(0) invert(1); }

/* TITRE */
.card-title { font-size: 20px; font-weight: 700; color: #ffffff; text-transform: uppercase; line-height: 1.3; }

/* FLÈCHE */
.card-arrow { position: absolute; bottom: 16px; right: 16px; width: 44px; height: 44px; background: #ffffff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; color: #2c2c2c; opacity: 0; transform: translateX(10px); transition: all 0.3s ease; }

.service-card:hover .card-arrow { opacity: 1; transform: translateX(0); }

@media (max-width: 1024px) { .services-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; max-width: 900px; } .service-card { grid-column: auto !important; aspect-ratio: 1 / 0.82; /* ⬅️ réduit clairement la hauteur */ max-height: 340px; /* ⬅️ garde une élégance visuelle */ } .card-content { padding: 22px; } .card-icon-img { width: 68px; margin-bottom: 14px; } .card-title { font-size: 18px; } }

@media (max-width: 768px) { .services-section { padding: 60px 20px; } .services-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; max-width: 480px; } .service-card { aspect-ratio: 1 / 0.78; /* ⬅️ encore plus basse */ max-height: 300px; } .card-content { padding: 20px; } .card-icon-img { width: 60px; } .card-title { font-size: 17px; } }

@media (max-width: 480px) { .services-grid { grid-template-columns: 1fr; max-width: 360px; } .service-card { aspect-ratio: 1 / 0.75; max-height: 260px; } .card-icon-img { width: 54px; } .card-title { font-size: 16px; } }

/*------------------------------------------------------------------------------------------- Réalisations----------------------------------------------------------------------------------------------------*/
/* ===================================== SECTION LUXURY SPLIT ===================================== */
/* ===================================== REA-ED – SECTION ===================================== */
.luxury-section { width: 100%; min-height: 600px; position: relative; overflow: hidden; }

/* Motif de fond léger */
.luxury-section::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 50%, rgba(180, 180, 180, 0.03) 0%, transparent 50%), radial-gradient(circle at 80% 80%, rgba(180, 180, 180, 0.03) 0%, transparent 50%); pointer-events: none; }

.luxury-container { display: grid; grid-template-columns: 1fr 1fr; min-height: 600px; max-width: 1400px; margin: 0 auto; align-items: center; gap: 80px; padding: 60px 40px; }

/* ===================================== PARTIE GAUCHE - IMAGES ===================================== */
.luxury-left { position: relative; display: flex; align-items: center; justify-content: center; min-height: 500px; }

.luxury-images { position: relative; width: 100%; max-width: 620px; /* 👈 images plus grandes */ height: 520px; /* 👈 plus de présence */ }

/* Image 1 - Plus grande, en arrière */
.luxury-image-1 { position: absolute; top: 0; left: 0; width: 58%; height: 75%; z-index: 1; transform: rotate(-2deg); }

/* Image 2 - Plus petite, devant et décalée */
.luxury-image-2 { position: absolute; bottom: 0; right: 0; width: 54%; height: 68%; z-index: 2; transform: rotate(2deg); }

.luxury-image { border-radius: 0px !important; overflow: hidden; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15); transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1); background: #ffffff; padding: 12px; }

.luxury-image:hover { transform: rotate(0deg) scale(1.02); box-shadow: 0 25px 70px rgba(0, 0, 0, 0.25); z-index: 3; }

.luxury-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s ease; }

.luxury-image:hover img { transform: scale(1.05); }

/* ===================================== PARTIE DROITE - CONTENU ===================================== */
.luxury-right { display: flex; align-items: center; justify-content: flex-start; padding: 40px 0; }

.luxury-content { max-width: 520px; }

/* Titre avec effet typographique */
.luxury-title { display: flex; flex-direction: column; gap: 4px; margin-bottom: 24px; }

.luxury-title-line1 { font-size: clamp(42px, 4vw, 58px); font-weight: 300; letter-spacing: 8px; color: #4f7fd6; text-transform: uppercase; line-height: 1; }

.luxury-title-line2 { font-size: clamp(42px, 4vw, 42px); font-weight: 400; letter-spacing: 6px; color: #3e66af; text-transform: uppercase; line-height: 1; }

/* Ligne décorative */
.luxury-divider { width: 60px; height: 2px; background: linear-gradient(to right, #7a9b92, transparent); margin-bottom: 28px; }

/* Description */
.luxury-description { font-size: 15px; line-height: 1.8; color: #888; margin-bottom: 36px; font-weight: 400; }

/* Bouton élégant */
.luxury-button { display: inline-block; padding: 14px 36px; background: transparent; color: #3e66af !important; font-size: 13px; font-weight: 600; letter-spacing: 0.5px; text-decoration: none; border: 2px solid #3e66af; border-radius: var(--bs-border-radius-lg) !important; transition: all 0.4s ease; position: relative; overflow: hidden; }

.luxury-button::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: #3e66af; transition: left 0.4s ease; z-index: -1; }

.luxury-button:hover::before { left: 0; }

.luxury-button:hover { color: #ffffff !important; border-color: #3e66af; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(122, 155, 146, 0.3); }

/* ===================================== RESPONSIVE ===================================== */
@media (max-width: 1024px) { .luxury-container { gap: 36px; /* 👈 rapproche images / texte */ padding: 48px 28px; } .luxury-images { max-width: 500px; height: 440px; } .luxury-image-1 { height: 72%; } .luxury-image-2 { height: 68%; } }

@media (max-width: 868px) { .luxury-container { grid-template-columns: 1fr; gap: 28px; /* 👈 clé du rapprochement */ padding: 44px 22px; } .luxury-left { min-height: auto; } .luxury-images { max-width: 100%; height: 420px; } .luxury-right { justify-content: center; text-align: center; padding-top: 0; /* 👈 supprime l’effet “bloc séparé” */ } .luxury-content { max-width: 520px; margin: 0 auto; } .luxury-title-line1, .luxury-title-line2 { font-size: clamp(34px, 7vw, 44px); letter-spacing: 4px; } .luxury-divider { margin: 18px auto 24px; } .luxury-button { width: 100%; max-width: 260px; } }

@media (max-width: 640px) { .luxury-container { padding: 36px 18px; gap: 24px; } .luxury-images { height: 340px; } .luxury-image { padding: 6px; } .luxury-title-line1, .luxury-title-line2 { font-size: 30px; letter-spacing: 3px; } .luxury-description { font-size: 14px; margin-bottom: 24px; } .luxury-button { padding: 12px 26px; font-size: 12px; } }

/*------------------------------------------------------------------------------------------- Icones----------------------------------------------------------------------------------------------------*/
/* =============================== SECTION INLINE SERVICES =============================== */
.services-inline { background: rgba(96, 112, 145, 0.14); padding: 120px 40px; }

/* CONTAINER */
.services-inline-container { max-width: 1400px; margin: 0 auto; display: flex; justify-content: center; align-items: stretch; gap: 60px; }

/* ITEM */
.service-inline-item { flex: 1; max-width: 360px; text-align: center; opacity: 0; transform: translateY(30px); transition: all 1.6s ease; }

.service-inline-item img { width: 140px; margin: 0 auto 26px; display: block; filter: brightness(1) saturate(1.2); }

.service-inline-item h3 { font-size: 17px; letter-spacing: 2px; text-transform: uppercase; font-weight: 600; margin-bottom: 14px; color: #000; }

.service-inline-item p { font-size: 16px; color: #777; line-height: 1.7; }

/* DIVIDER */
.service-divider { width: 1px; height: 120px; background: rgba(0, 0, 0, 0.08); align-self: center; }

/* ANIMATION ACTIVE */
.service-inline-item.active { opacity: 1; transform: translateY(0); }

/* =============================== RESPONSIVE =============================== */
@media (max-width: 1024px) { .services-inline { padding: 100px 30px; } .services-inline-container { flex-direction: column; align-items: center; gap: 70px; } .service-divider { display: none; } .service-inline-item { max-width: 520px; } }

@media (max-width: 768px) { .services-inline { padding: 80px 24px; } .service-inline-item img { width: 120px; } .service-inline-item h3 { font-size: 16px; } .service-inline-item p { font-size: 15px; } }

@media (max-width: 480px) { .services-inline { padding: 70px 16px; } .service-inline-item { max-width: 100%; } .service-inline-item img { width: 100px; } .service-inline-item h3 { font-size: 15px; letter-spacing: 1.5px; } .service-inline-item p { font-size: 14.5px; } }

/*------------------------------------------------------------------------------------------- PRESENTATION----------------------------------------------------------------------------------------------------*/
/* =============================== SECTION PRESENTATION-ED =============================== */
.presentation-ed-section { background: #ffffff; padding: clamp(70px, 8vw, 120px) 5%; }

/* =============================== CONTAINER =============================== */
.presentation-ed-container { max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: 1.3fr 1fr; /* image volontairement plus large */ gap: clamp(40px, 6vw, 80px); align-items: center; }

/* =============================== IMAGE =============================== */
.presentation-ed-image { width: 100%; }

.presentation-ed-image img { width: 100%; height: auto; /* image toujours entière */ display: block; border-radius: var(--bs-border-radius-lg) !important; }

/* =============================== CONTENU TEXTE =============================== */
.presentation-ed-content { max-width: 580px; }

/* TITRE */
.presentation-ed-title { margin-bottom: 34px; line-height: 1.1; }

.presentation-ed-title-light { display: block; font-size: clamp(26px, 3vw, 34px); font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: #8fa6cf; }

.presentation-ed-title-strong { display: block; font-size: clamp(32px, 4vw, 44px); font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: #3e5887; }

/* TEXTE */
.presentation-ed-text { font-size: 1.05rem; line-height: 1.85; color: #555; }

/* =============================== RESPONSIVE =============================== */
@media (max-width: 900px) { .presentation-ed-container { grid-template-columns: 1fr; gap: 60px; text-align: center; } .presentation-ed-content { margin: 0 auto; } }

@media (max-width: 480px) { .presentation-ed-text { font-size: 1rem; } }

/*------------------------------------------------------------------------------------------- CTA----------------------------------------------------------------------------------------------------*/
/* ===================================== HELP-ED – SECTION ===================================== */
.help-ed-section { width: 100%; padding: 110px 20px; background: #ffffff; }

/* ===================================== CONTAINER ===================================== */
.help-ed-container { max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.1fr; /* texte gauche / image droite */ gap: 80px; align-items: center; }

/* ===================================== IMAGE DROITE ===================================== */
.help-ed-left { height: 520px; }

.help-ed-left img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: var(--bs-border-radius-lg) !important; }

/* ===================================== CONTENU GAUCHE ===================================== */
.help-ed-right { max-width: 560px; }

/* TITRE BI-TON */
.help-ed-title { margin-bottom: 26px; line-height: 1.15; }

.help-ed-title-light { font-size: 50px; font-weight: 400; color: #4f7fd6; /* plus clair */ letter-spacing: 2px; }

.help-ed-title-strong { font-size: clamp(42px, 4vw, 42px); font-weight: 700; color: #3e66af; /* plus foncé */ }

/* TEXTE */
.help-ed-text { font-size: 1.05rem; line-height: 1.8; color: #555; margin-bottom: 42px; }

/* ===================================== CTA ===================================== */
.help-ed-button { display: inline-block; padding: 16px 42px; background: #3e66af; color: #ffffff !important; font-size: 0.85rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; text-decoration: none; border-radius: var(--bs-border-radius-lg) !important; transition: background 0.3s ease, transform 0.25s ease; }

.help-ed-button:hover { background: #6f95e6; color: #fff !important; transform: translateY(-2px); }

a.help-ed-button:visited { color: white !important; }

/* ===================================== RESPONSIVE ===================================== */
@media (max-width: 1024px) { .help-ed-container { gap: 60px; } .help-ed-left { height: 460px; } .help-ed-title-light { font-size: 2rem; } .help-ed-title-strong { font-size: 2.5rem; } }

@media (max-width: 768px) { .help-ed-section { padding: 90px 20px; } .help-ed-container { grid-template-columns: 1fr; gap: 50px; text-align: center; } .help-ed-left { height: 360px; } .help-ed-right { max-width: 100%; margin: 0 auto; } }

@media (max-width: 480px) { .help-ed-section { padding: 70px 16px; } .help-ed-left { height: 280px; } .help-ed-title-light { font-size: 1.7rem; } .help-ed-title-strong { font-size: 2.1rem; } .help-ed-button { width: 100%; text-align: center; padding: 16px; } }

/*------------------------------------------------------------------------------------------- ACCUEIL DEMOLITION----------------------------------------------------------------------------------------------------*/
/* =============================== HERO =============================== */
.accueil-demolition-hero { position: relative; min-height: 100vh; background: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2F89zez1yVO8NF6FZLSiKIA7CXrSh2%2Fimages%2FDesign_sans_titre_-_2026-01-02T091658454_quvf.webp") center/cover no-repeat; display: flex; align-items: center; overflow: hidden; }

/* Overlay */
.accueil-demolition-overlay { position: absolute; inset: 0; background: linear-gradient(110deg, rgba(62, 88, 135, 0.9), rgba(62, 88, 135, 0.7)); z-index: 1; }

/* =============================== LOGO =============================== */
.accueil-demolition-logo { position: absolute; top: 48px; left: 0; width: 100%; padding-left: clamp(20px, 6vw, 90px); z-index: 3; }

.accueil-demolition-logo img { height: 90px; width: auto; }

/* =============================== CONTAINER =============================== */
.accueil-demolition-container { position: relative; z-index: 2; width: 100%; }

.accueil-demolition-content { max-width: 720px; padding-left: clamp(20px, 6vw, 90px); }

/* =============================== TITRE =============================== */
.accueil-demolition-title { font-size: clamp(36px, 5vw, 64px); font-weight: 800; line-height: 1.15; color: #fff; margin-bottom: 24px; }

/* =============================== TEXTE =============================== */
.accueil-demolition-description { max-width: 560px; font-size: 16px; line-height: 1.65; color: rgba(255, 255, 255, 0.9); margin-bottom: 36px; }

/* =============================== CTA =============================== */
.accueil-demolition-cta-group { display: flex; gap: 16px; flex-wrap: wrap; }

.btn { padding: 14px 26px; font-size: 13px; font-weight: 600; text-transform: uppercase; text-decoration: none; transition: all 0.3s ease; }

.btn-primary { color: #fff !important; border: 2px solid #3e66af; }

.btn-primary:hover { background: #3e66af; }

.btn-secondary { color: #fff !important; border: 2px solid rgba(255, 255, 255, 0.5); }

/* =============================== SCROLL =============================== */
.accueil-demolition-scroll { position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%); z-index: 3; text-align: center; color: #fff; }

.mouse { width: 22px; height: 36px; border: 2px solid #fff; border-radius: 14px; margin: 0 auto 6px; position: relative; }

.mouse span { width: 3px; height: 8px; background: #3e66af; position: absolute; top: 8px; left: 50%; transform: translateX(-50%); }

/* =============================== RESPONSIVE =============================== */
@media (max-width: 768px) { .accueil-demolition-logo { top: 24px; } .accueil-demolition-logo img { height: 70px; } .accueil-demolition-content { padding-top: 120px; } .accueil-demolition-cta-group { flex-direction: column; width: 100%; } .btn { width: 100%; text-align: center; } .accueil-demolition-scroll { bottom: 24px; } }

/*------------------------------------------------------------------------------------------- Intro----------------------------------------------------------------------------------------------------*/
/* ================================================== INTRO-ED ================================================== */
.intro-ed { width: 100%; position: relative; overflow: hidden; }

.intro-ed::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 20% 50%, rgba(255, 255, 255, 0.04), transparent 60%), radial-gradient(circle at 80% 80%, rgba(255, 255, 255, 0.04), transparent 60%); pointer-events: none; }

/* ================================================== CONTAINER ================================================== */
.intro-ed__container { position: relative; z-index: 1; max-width: 1400px; margin: 0 auto; padding: 80px 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }

/* ================================================== IMAGE ================================================== */
.intro-ed__media img { width: 100%; height: 520px; object-fit: cover; display: block; box-shadow: 0 30px 70px rgba(0, 0, 0, 0.18); border-radius: var(--bs-border-radius-lg) !important; }

/* ================================================== CONTENU ================================================== */
.intro-ed__content { max-width: 560px; }

.intro-ed__title { font-size: clamp(32px, 4vw, 44px); font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px; color: #3e66af; margin-bottom: 24px; }

.intro-ed__text { font-size: 17px; line-height: 1.8; color: #000; }

/* ================================================== CTA ================================================== */
.intro-ed__cta { display: inline-block; margin-top: 36px; padding: 14px 36px; font-size: 13px; font-weight: 600; text-transform: uppercase; border-radius: 10px; letter-spacing: 0.5px; text-decoration: none; color: #3e66af !important; border: 2px solid #3e66af; transition: all 0.35s ease; }

.intro-ed__cta:hover { background: #3e66af; color: #ffffff !important; transform: translateY(-2px); box-shadow: 0 10px 28px rgba(62, 102, 175, 0.3); }

/* ================================================== RESPONSIVE ================================================== */
@media (max-width: 1024px) { .intro-ed__container { gap: 48px; padding: 64px 28px; } .intro-ed__media img { height: 440px; } }

@media (max-width: 868px) { .intro-ed__container { grid-template-columns: 1fr; gap: 36px; } .intro-ed__content { text-align: center; margin: 0 auto; } .intro-ed__cta { margin-left: auto; margin-right: auto; } }

@media (max-width: 640px) { .intro-ed__container { padding: 48px 18px; } .intro-ed__media img { height: 320px; } .intro-ed__title { font-size: 28px; } .intro-ed__text { font-size: 14px; } }

/*------------------------------------------------------------------------------------------- Icone cinq cartes----------------------------------------------------------------------------------------------------*/
/* ================================================== RESET LOCAL ================================================== */
* { margin: 0; padding: 0; box-sizing: border-box; }

/* ================================================== FIVE-ED – SECTION ================================================== */
.five-ed-section { position: relative; width: 100%; padding: 72px 56px; font-family: Arial, sans-serif; color: #ffffff; overflow: hidden; }

.five-ed-section::before { content: ""; position: absolute; inset: 0; background: rgba(30, 45, 70, 0.85); backdrop-filter: blur(2px); z-index: 1; }

/* Image de fond */
.five-ed-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }

/* ================================================== CONTAINER ================================================== */
.five-ed-container { position: relative; z-index: 2; max-width: 1400px; margin: 0 auto; }

/* ================================================== TITRE & INTRO ================================================== */
.five-ed-header { max-width: 820px; margin-bottom: 40px; }

.five-ed-title { font-size: clamp(30px, 3.5vw, 38px); font-weight: 300; line-height: 1.25; color: #e8eef5; border-left: 3px solid #c9a961; padding-left: 18px; margin-bottom: 14px; }

.five-ed-intro { font-size: 19px; line-height: 1.7; color: #b8c5d6; }

/* ================================================== GRID ================================================== */
.five-ed-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }

/* ================================================== CARTE ================================================== */
.five-ed-card { border: 1px solid rgba(255, 255, 255, 0.22); padding: 40px 32px; transition: background 0.3s ease, border-color 0.3s ease; border-radius: var(--bs-border-radius-lg); }

.five-ed-card:hover { background: rgba(255, 255, 255, 0.04); border-color: rgba(255, 255, 255, 0.38); }

/* ================================================== ICÔNE ================================================== */
.five-ed-icon { margin-bottom: 20px; }

.five-ed-icon img { width: 54px; height: 54px; object-fit: contain; display: block; filter: brightness(0) invert(1); opacity: 0.9; }

/* ================================================== TEXTE CARTE ================================================== */
.five-ed-card-title { font-size: 12px; letter-spacing: 1.8px; text-transform: uppercase; color: #ffffff; font-weight: 600; margin-bottom: 12px; }

.five-ed-card-text { font-size: 15px; line-height: 1.65; color: #b8c5d6; }

/* ================================================== RESPONSIVE ================================================== */
@media (max-width: 1200px) { .five-ed-grid { grid-template-columns: repeat(3, 1fr); } }

@media (max-width: 768px) { .five-ed-section { padding: 56px 24px; } .five-ed-header { margin-bottom: 32px; } .five-ed-grid { grid-template-columns: 1fr; } .five-ed-card { padding: 32px 24px; } }

/*------------------------------------------------------------------------------------------- Icone cartes----------------------------------------------------------------------------------------------------*/
/* ================================================== RESET LOCAL ================================================== */
* { margin: 0; padding: 0; box-sizing: border-box; }

/* ================================================== CARTE-ED – SECTION ================================================== */
.carte-ed-section { position: relative; width: 100%; padding: 72px 56px; font-family: Arial, sans-serif; color: #ffffff; overflow: hidden; }

.carte-ed-section::before { content: ""; position: absolute; inset: 0; background: rgba(30, 45, 70, 0.85); backdrop-filter: blur(2px); z-index: 1; }

/* Image de fond déplacée dans le HTML */
.carte-ed-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }

/* ================================================== CONTAINER ================================================== */
.carte-ed-container { position: relative; z-index: 2; max-width: 1400px; margin: 0 auto; }

/* ================================================== TITRE & INTRO ================================================== */
.carte-ed-header { max-width: 820px; margin-bottom: 40px; }

.carte-ed-title { font-size: clamp(30px, 3.5vw, 38px); font-weight: 300; line-height: 1.25; color: #e8eef5; border-left: 3px solid #c9a961; padding-left: 18px; margin-bottom: 14px; }

.carte-ed-intro { font-size: 19px; line-height: 1.7; color: #b8c5d6; }

/* ================================================== GRID ================================================== */
.carte-ed-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

/* ================================================== CARTE ================================================== */
.carte-ed-card { border: 1px solid rgba(255, 255, 255, 0.22); padding: 40px 32px; transition: background 0.3s ease, border-color 0.3s ease; border-radius: var(--bs-border-radius-lg) !important; }

.carte-ed-card:hover { background: rgba(255, 255, 255, 0.04); border-color: rgba(255, 255, 255, 0.38); }

/* ================================================== ICÔNE ================================================== */
.carte-ed-icon { margin-bottom: 20px; }

.carte-ed-icon img { width: 54px; height: 54px; object-fit: contain; display: block; filter: brightness(0) invert(1); opacity: 0.9; }

/* ================================================== TEXTE CARTE ================================================== */
.carte-ed-card-title { font-size: 12px; letter-spacing: 1.8px; text-transform: uppercase; color: #ffffff; font-weight: 600; margin-bottom: 12px; }

.carte-ed-card-text { font-size: 15px; line-height: 1.65; color: #b8c5d6; }

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

@media (max-width: 768px) { .carte-ed-section { padding: 56px 24px; } .carte-ed-header { margin-bottom: 32px; } .carte-ed-grid { grid-template-columns: 1fr; } .carte-ed-card { padding: 32px 24px; } }

/*------------------------------------------------------------------------------------------- Quatre images----------------------------------------------------------------------------------------------------*/
/* ================================================== PHOTO-TITRE – SECTION ================================================== */
.photo-titre { position: relative; background: linear-gradient(135deg, #1a2332, #2a3646); color: #ffffff; padding: 80px 40px; /* bloc volontairement compact */ text-align: center; font-family: 'Zilla Slab', serif; overflow: hidden; /* empêche les SVG d'agrandir le bloc */ }

/* ================================================== SVG DÉCORATIFS (HAUT / BAS) ================================================== */
.photo-titre-svg { position: absolute; left: 50%; transform: translateX(-50%); width: 110px; height: auto; pointer-events: none; z-index: 1; }

.photo-titre-svg-top { top: 0; /* collé au bord haut */ }

.photo-titre-svg-bottom { bottom: 0; /* collé au bord bas */ }

/* ================================================== HEADER ================================================== */
.photo-titre-header { position: relative; z-index: 2; max-width: 820px; margin: 0 auto 58px; margin-top: 5px; }

.photo-titre-title { font-size: 2rem; text-transform: uppercase; letter-spacing: 2px; margin: 12px 0; margin-top: 55px !important; }

.photo-titre-intro { font-size: 1rem; color: #d2edf2; }

/* ================================================== GRID ================================================== */
.photo-titre-grid { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(4, 1fr); gap: 36px; max-width: 1300px; margin: 0 auto; }

/* ================================================== CARTE (SANS HOVER) ================================================== */
.photo-titre-card { position: relative; height: 440px; overflow: hidden; }

/* Image de fond */
.photo-titre-image { position: absolute; inset: 0; background-size: cover; background-position: center; }

/* Bandeau texte */
.photo-titre-text { position: absolute; bottom: 0; left: 0; right: 0; margin: 0 18px 18px; padding: 22px 28px; background: rgba(15, 15, 15, 0.95); text-align: left; }

.photo-titre-text h3 { font-size: 1.15rem; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }

.photo-titre-text p { font-size: 0.95rem; color: #67a1ad; }

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

@media (max-width: 768px) { .photo-titre { padding: 64px 20px; } .photo-titre-grid { grid-template-columns: 1fr; gap: 28px; } .photo-titre-card { height: 360px; } .photo-titre-text { margin: 0 14px 14px; padding: 18px; } }

/*------------------------------------------------------------------------------------------- trois Cartes----------------------------------------------------------------------------------------------------*/
/* =============================== TROIS-CARTES – SECTION =============================== */
.trois-cartes-section { position: relative; padding: 110px 20px; background: linear-gradient(135deg, #1a2332, #2a3646); overflow: hidden; }

/* SVG décoratifs */
.trois-cartes-svg { position: absolute; left: 50%; transform: translateX(-50%); width: 90px; z-index: 3; }

.trois-cartes-svg-top { top: -1px; }

.trois-cartes-svg-bottom { bottom: -1px; }

/* =============================== CONTAINER =============================== */
.trois-cartes-container { max-width: 1200px; margin: 0 auto; text-align: center; }

.trois-cartes-label { font-size: 14px; font-weight: 600; letter-spacing: 3px; color: #4f7fd6; margin-bottom: 2px; display: inline-block; }

.trois-cartes-title { font-size: clamp(34px, 5vw, 52px); color: #ffffff; margin-bottom: 24px; }

.trois-cartes-title span { color: #4f7fd6; }

/* INTRO */
.trois-cartes-intro { max-width: 890px; margin: 0 auto 64px; font-size: 18px; line-height: 1.7; color: rgba(255, 255, 255, 0.75); }

/* =============================== GRID =============================== */
.trois-cartes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }

/* =============================== CARD =============================== */
.trois-cartes-card { background: #2a3646; border: 1px solid rgba(255, 255, 255, 0.2); padding: 48px 32px; text-align: center; box-shadow: 0 22px 45px rgba(0, 0, 0, 0.45); border-radius: 50px !important; }

.trois-cartes-icon-wrapper { width: 96px; height: 96px; margin: 0 auto 18px; border-radius: 22px; background: linear-gradient(180deg, rgba(62, 102, 175, 0.45), rgba(62, 102, 175, 0.18)); display: flex; align-items: center; justify-content: center; }

.trois-cartes-icon-wrapper img { width: 52px; height: 52px; object-fit: contain; }

.trois-cartes-card-title { font-size: 22px; font-weight: 600; color: #ffffff; }

/* =============================== RESPONSIVE =============================== */
@media (max-width: 900px) { .trois-cartes-grid { grid-template-columns: 1fr; } .trois-cartes-section { padding: 90px 16px; } }

/*------------------------------------------------------------------------------------------- Cartes Bleu----------------------------------------------------------------------------------------------------*/
/* ================================================== WHY CHOOSE – VERSION BLEUE ================================================== */
.why-blue { background: #f5f8fc; padding: 90px 20px; text-align: center; font-family: Arial, sans-serif; }

/* ================= HEADER ================= */
.why-blue-header { max-width: 720px; margin: 0 auto 60px; }

.why-blue-subtitle { font-size: 14px; letter-spacing: 2px; color: #4f7fd6; text-transform: uppercase; }

.why-blue-title { font-size: 36px; font-weight: 700; margin: 10px 0; color: #1f2f4a; }

.why-blue-title span { color: #4f7fd6; }

.why-blue-intro { font-size: 15px; color: #6b7a90; line-height: 1.6; }

/* ================= GRID ================= */
.why-blue-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; max-width: 1200px; margin: 0 auto; }

/* ================= CARD ================= */
.why-blue-card { background: #1f2f4a; color: #ffffff; padding: 44px 32px; box-shadow: 0 18px 40px rgba(0, 0, 0, 0.25); text-align: center; border-radius: var(--bs-border-radius-lg) !important; }

.why-blue-icon { width: 64px; height: 64px; margin: 0 auto 22px; display: flex; align-items: center; justify-content: center; }

.why-blue-icon img { width: 100%; height: 100%; object-fit: contain; }

/* Texte carte */
.why-blue-card h3 { font-size: 18px; margin-bottom: 14px; font-weight: 600; }

.why-blue-card p { font-size: 14px; line-height: 1.6; color: rgba(255, 255, 255, 0.75); margin-bottom: 22px; }

/* Lien bas de carte */
.why-blue-link { font-size: 13px; letter-spacing: 1px; text-transform: uppercase; color: #4f7fd6; }

.why-blue-logo { display: block; margin: 0 auto 18px; height: 64px; width: auto; }

/* ================= RESPONSIVE ================= */
@media (max-width: 900px) { .why-blue-grid { grid-template-columns: 1fr; } .why-blue { padding: 70px 16px; } }

/* ================================================== GALERIE ÉDITORIALE ================================================== */
.galerie-ed { background: #3e66af4d; padding: 90px 40px; }

.galerie-ed-header { text-align: center; max-width: 720px; margin: 0 auto 60px; }

.galerie-ed-header h1 { font-size: 36px; font-weight: 400; margin-bottom: 12px; color: #3e5887; }

.galerie-ed-header p { font-size: 13px; letter-spacing: 1px; text-transform: uppercase; color: #000; }

/* GRID */
.galerie-ed-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; max-width: 1400px; margin: 0 auto; }

/* CARD */
.galerie-card { background: transparent; text-align: center; }

/* IMAGE */
.galerie-image { height: 360px; overflow: hidden; }

.galerie-image img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* BUTTON */
.galerie-btn { width: 100%; margin-top: 14px; padding: 12px; border: none; background: #3e5887; color: #fff; text-transform: uppercase; letter-spacing: 2px; font-size: 11px; cursor: pointer; }

/* TEXTE CACHÉ / AFFICHÉ */
.galerie-text { max-height: 0; overflow: hidden; transition: max-height 0.5s ease; }

/* Rectangle bleu */
.galerie-text p { margin-top: 14px; padding: 18px 20px; background: #3e5887; color: #ffffff; font-size: 14px; line-height: 1.6; text-align: left; }

/* OUVERT */
.galerie-card.active .galerie-text { max-height: 1000px; }

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

@media (max-width: 600px) { .galerie-ed { padding: 70px 20px; } .galerie-ed-grid { grid-template-columns: 1fr; } }

/*-------------------Galerie Custom--------------------------*/
/* ========================== SECTION GALERIE ========================== */
#custom-gallery { padding: 40px 15px; background: #3e66af1a; }

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

/* ========================== TITRE & SOUS-TITRE ========================== */
.gallery-header { text-align: center; margin-bottom: 50px; }

.gallery-title { font-size: 42px; font-weight: 700; color: #3e66af; margin-bottom: 15px; }

.gallery-subtitle { font-size: 14px; letter-spacing: 2px; text-transform: uppercase; color: #000; max-width: 700px; margin: 0 auto; }

/* ========================== GRILLE IMAGES ========================== */
#custom-gallery .image { height: 400px; margin: 20px 0; }

/* ========================== IMAGE WRAPPER ========================== */
.img-wrapper { position: relative; height: 100%; overflow: hidden; border-radius: var(--bs-border-radius-lg) !important; }

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

/* ========================== OVERLAY HOVER ========================== */
.img-overlay { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.7); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.3s ease; }

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

.img-wrapper:hover .img-overlay { opacity: 1; }

/* ========================== OVERLAY LIGHTBOX ========================== */
#overlay { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.7); z-index: 999; display: flex; align-items: center; justify-content: center; user-select: none; }

#overlay img { width: 80%; max-height: 90vh; object-fit: contain; padding: 5%; }

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

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

/* ========================== BOUTONS LIGHTBOX ========================== */
#nextButton, #prevButton, #exitButton { color: #fff; transition: opacity 0.3s ease; cursor: pointer; }

#nextButton, #prevButton { font-size: 2em; }

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

#exitButton { position: absolute; top: 20px; right: 20px; font-size: 2em; }

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

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

/* =============================== SECTION =============================== */
.apartment-types-section { position: relative; padding: 110px 20px; background: linear-gradient(135deg, #1a2332, #2a3646); overflow: hidden; }

/* SVG décoratifs */
.apartment-svg { position: absolute; left: 50%; transform: translateX(-50%); width: 90px; z-index: 3; }

.apartment-svg-top { top: -1px; }

.apartment-svg-bottom { bottom: -1px; }

/* =============================== CONTAINER =============================== */
.apartment-types-container { max-width: 1200px; margin: 0 auto; text-align: center; }

.apartment-types-label { font-size: 12px; font-weight: 600; letter-spacing: 3px; color: #4f7fd6; margin-bottom: 14px; display: inline-block; }

.apartment-types-title { font-size: clamp(34px, 5vw, 52px); color: #ffffff; margin-bottom: 64px; }

.apartment-types-title span { color: #4f7fd6; }

/* =============================== GRID =============================== */
.apartment-types-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }

/* =============================== CARD =============================== */
.apartment-card { background: #2a3646; border: 1px solid rgba(255, 255, 255, 0.2); padding: 48px 32px; border-radius: 50px !important; text-align: center; box-shadow: 0 22px 45px rgba(0, 0, 0, 0.45); }

/* Icône principale */
.apartment-icon-wrapper { width: 96px; height: 96px; margin: 0 auto 18px; border-radius: 22px; background: linear-gradient(180deg, rgba(62, 102, 175, 0.45), rgba(62, 102, 175, 0.18)); display: flex; align-items: center; justify-content: center; }

.apartment-icon-wrapper img { width: 52px; height: 52px; object-fit: contain; }

/* Icône au-dessus du titre */
.apartment-card-icon { display: block; font-size: 22px; margin-bottom: 10px; opacity: 0.9; }

/* Texte */
.apartment-card-title { font-size: 22px; font-weight: 600; color: #fff; margin-bottom: 8px; }

.apartment-card-subtitle { font-size: 15px; color: rgba(255, 255, 255, 0.55); }

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

@media (max-width: 640px) { .apartment-types-grid { grid-template-columns: 1fr; } .apartment-types-section { padding: 90px 16px; } }

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