@charset "UTF-8";
@import url(main.css);
h1.display-4.fw-bold.bandeauTitre.titles.text-color-seventh { color: #000 !important; }

span.display-4.fw-bold.lh-1.text-body-emphasis.mb-3.titles { color: #fff !important; }

p.fs-5.mt-4 { color: #fff !important; }

h2.display-6.fw-bold.p-3.pt-lg-3.m-0.titles { color: #000 !important; }

/*------------------------------------------------------------------------------------------MODIFS----------------------------------------------------------------------------------------*/
a.images-gda__item, .fournisseurs-gda__card, .cta-gda__card, a.cta-gda__cta, .card.card-cover.h-100.overflow-hidden.rounded-4.shadow-lg, .gda-header-intro__image-frame, img.gda-header-intro__image, a.gda-header-intro__btn, .gda-cuisine__shape.gda-cuisine__shape--left, img.gda-cuisine__image, .gda-cuisine__shape.gda-cuisine__shape--right, .icones-gda__card, .gda-luxe-editorial__wrap, img.gda-luxe-editorial__image, a.defile-images-item, .gda-amenagement__card, .gda-amenagement__image-wrap, a.gda-mobilier__cta, .gda-mobilier__img, .realisations-gda__item, .gda-cuisine-services__card { border-radius: 12px !important; }

.realisations-section { background-color: #d8dac5; padding: 60px 20px; }

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

.realisations-main-title { text-align: center; color: #646e56; margin-bottom: 32px; font-family: 'Noto Serif'; font-size: clamp(2.6rem, 5vw, 4.8rem); font-weight: 700; line-height: 1.02; letter-spacing: -0.04em; }

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

.filter-btn { color: #646e56; font-size: 11px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; cursor: pointer; background: transparent; border-width: 1.5px; border-style: solid; border-color: rgba(100, 110, 86, 0.4); border-image: initial; padding: 10px 22px; border-radius: 12px; transition: background 0.3s, border-color 0.3s, color 0.3s; }

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

.filter-btn.active { color: #d8dac5; background: #646e56; border-color: #646e56; }

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

.realisation-card { border-radius: 12px; overflow: hidden; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); transition: transform 0.2s; }

.realisation-card:hover { transform: translateY(-4px); }

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

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

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

.modal-content { max-width: 500px; max-height: 70vh; width: auto; height: auto; border-radius: 8px; background: #fff; }

.modal-close { position: absolute; top: 24px; right: 32px; color: #fff; font-size: 36px; font-weight: bold; cursor: pointer; z-index: 1100; }

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

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

.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 #fff !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: 2px solid #fff !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: 2px solid #fff !important; border-radius: 0px !important; box-shadow: none !important; transition: 0.3s ease; }

a#maps-url { display: inline-flex; align-items: center; justify-content: center; background-color: #a8c73d; /* Vert signature de la DA */ color: #ffffff !important; /* Force le texte en blanc */ font-weight: 600; font-size: 14px; letter-spacing: 0.05em; border: 2px solid transparent; border-radius: 0px !important; transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1); box-shadow: 0 4px 15px rgba(144, 167, 109, 0.25); white-space: nowrap; }

a#maps-url:hover { background-color: #7d925a; /* Vert un peu plus soutenu */ transform: scale(1.05); /* L'effet "grow" */ box-shadow: 0 6px 20px rgba(144, 167, 109, 0.4); color: #ffffff !important; }

/* Style du bouton CTA Header */
a.grow.button_header.button-header-telephone { display: inline-flex; align-items: center; justify-content: center; background-color: #646e56; /* Vert signature de la DA */ color: #ffffff !important; /* Force le texte en blanc */ font-weight: 600; font-size: 14px; letter-spacing: 0.05em; border: 2px solid transparent; border-radius: 12px !important; transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1); box-shadow: 0 4px 15px rgba(144, 167, 109, 0.25); white-space: nowrap; }

/* Effet au survol (Hover) */
a.grow.button_header.button-header-telephone:hover { background-color: #7d925a; /* Vert un peu plus soutenu */ transform: scale(1.05); /* L'effet "grow" */ box-shadow: 0 6px 20px rgba(144, 167, 109, 0.4); color: #ffffff !important; }

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

/*------------------------------------------------------------------------------------------FORMULAIRE DE CONTACT----------------------------------------------------------------------------------------*/
#contact { position: relative !important; overflow: hidden; min-height: 720px; padding: 12px 16px !important; isolation: isolate; background: #111009 !important; }

#contact .background-image-div-opacity { position: absolute !important; inset: 0; z-index: 0; background-size: cover !important; background-position: center !important; background-repeat: no-repeat !important; transform: scale(1.02); }

#contact::before { content: ""; position: absolute; inset: 0; background: rgba(8, 6, 4, 0.22); z-index: 1; pointer-events: none; }

#contact > .row { position: relative !important; z-index: 2 !important; max-width: 1280px; margin: 0 auto !important; align-items: center !important; }

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

#contact .titles { max-width: 560px; margin: 0 auto 0 0; }

#contact .titles h1 { margin: 0 0 18px; color: #ffffff !important; line-height: 1.08; text-align: left !important; }

#contact .titles p { margin: 0; color: rgba(255, 255, 255, 0.78) !important; line-height: 1.9; text-align: left !important; }

#contact #formContact { width: 100%; max-width: 620px; margin: 0 auto; padding: 30px 30px 24px !important; background: rgba(255, 255, 255, 0.1) !important; border: 1px solid rgba(255, 255, 255, 0.18) !important; border-radius: 0 !important; backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); box-shadow: 0 14px 40px rgba(0, 0, 0, 0.22); }

#contact #formContact .form-control { background: rgba(255, 255, 255, 0.92) !important; border: 1px solid rgba(17, 16, 9, 0.08) !important; border-radius: 0 !important; box-shadow: none !important; }

#contact #formContact textarea.form-control { min-height: 150px; resize: vertical; padding-top: 18px; }

#contact #formContact .form-control:focus { border-color: rgba(176, 138, 106, 0.9) !important; box-shadow: 0 0 0 0.15rem rgba(176, 138, 106, 0.16) !important; }

#contact #formContact .form-floating > label { color: rgba(17, 16, 9, 0.62) !important; }

#contact #formContact input.form-control[type="file"] { padding: 14px 16px; }

#contact #formContact .btn-outline-danger, #contact #formContact button[type="submit"], #contact .modal-content { border-radius: 0 !important; }

#contact #formContact .checkbox { margin-bottom: 20px !important; }

#contact #formContact .checkbox label { color: rgba(255, 255, 255, 0.76) !important; line-height: 1.8; }

#contact #formContact .checkbox a { color: #ffffff !important; text-decoration: underline; }

#contact #formContact button[type="submit"] { display: inline-flex !important; align-items: center; justify-content: center; width: 100%; min-height: 54px; padding: 14px 24px !important; background: rgba(255, 255, 255, 0.16) !important; border: 1px solid rgba(255, 255, 255, 0.36) !important; color: #ffffff !important; font-weight: 700 !important; letter-spacing: 0.18em; text-transform: uppercase; box-shadow: none !important; transition: background 0.25s ease, border-color 0.25s ease, color 0.25s ease; }

#contact #formContact button[type="submit"]:hover, #contact #formContact button[type="submit"]:focus { background: rgba(255, 255, 255, 0.24) !important; border-color: rgba(255, 255, 255, 0.5) !important; color: #ffffff !important; }

@media (max-width: 991px) { #contact { min-height: auto; padding: 42px 14px !important; } #contact > .row { row-gap: 24px; } #contact .col-lg-6.text-center.text-color-sixth { padding: 6px 8px 0; } #contact .titles { max-width: 100%; margin: 0 auto; } #contact .titles h1, #contact .titles p { text-align: center !important; } #contact #formContact { max-width: 100%; padding: 24px 18px 20px !important; } }

@media (max-width: 767px) { #contact { padding: 34px 12px !important; } #contact .titles h1 { margin-bottom: 14px; } #contact .titles p { line-height: 1.75; } #contact #formContact { padding: 20px 14px 18px !important; } #contact #formContact textarea.form-control { min-height: 130px; } #contact #formContact button[type="submit"] { min-height: 50px; letter-spacing: 0.14em; } }

/*-------------------------------------------------------------------------------------------------ICONES----------------------------------------------------------------------------------------*/
.icones-gda { position: relative; padding: 70px 40px 60px; background: #595959; overflow: hidden; isolation: isolate; }

.icones-gda * { box-sizing: border-box; }

.icones-gda__ornament { position: absolute; inset: 0; z-index: 0; pointer-events: none; display: flex; align-items: flex-start; justify-content: center; }

.icones-gda__ornament-logo { width: 100%; max-width: 520px; height: auto; object-fit: contain; opacity: 0.08; margin-top: 30px !important; }

.icones-gda__container { position: relative; z-index: 1; max-width: 1600px; margin: 0 auto; }

.icones-gda__head { max-width: 900px; margin: 0 auto 58px; text-align: center; }

.icones-gda__mark { position: relative; display: inline-flex; width: 52px; height: 52px; border: 1px solid rgba(194, 227, 90, 0.3); border-radius: 50%; margin-bottom: 18px; align-items: center; justify-content: center; }

.icones-gda__mark::before { content: ""; width: 16px; height: 16px; border-radius: 50%; background: #c2e35a; box-shadow: 0 0 0 5px rgba(194, 227, 90, 0.16); }

.icones-gda__line { width: 320px; max-width: 70%; height: 1px; margin: 0 auto 28px; background: rgba(232, 234, 216, 0.14); }

.icones-gda__title { margin: 0 0 22px; color: #ffffff; font-size: clamp(2.1rem, 3.3vw, 4rem); line-height: 1.05; font-weight: 500; letter-spacing: -0.03em; }

.icones-gda__intro { margin: 0 auto; max-width: 900px; color: rgba(232, 234, 216, 0.8); font-size: 18px; line-height: 1.9; font-weight: 400; }

.icones-gda__grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 18px; }

.icones-gda__card { min-height: 245px; padding: 36px 22px 28px; border: 1px solid rgba(232, 234, 216, 0.12); background: rgba(255, 255, 255, 0.01); text-align: center; transition: transform 0.3s ease, border-color 0.3s ease, background 0.3s ease; }

.icones-gda__card:hover { transform: translateY(-4px); border-color: rgba(194, 227, 90, 0.3); background: rgba(255, 255, 255, 0.03); }

.icones-gda__icon { display: flex; align-items: center; justify-content: center; width: 74px; height: 74px; margin: 0 auto 18px; color: #c2e35a; }

.icones-gda__icon svg { width: 52px; height: 52px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

.icones-gda__divider { display: block; width: 1px; height: 36px; margin: 0 auto 18px; background: rgba(232, 234, 216, 0.18); }

.icones-gda__label { margin: 0; color: #ffffff; font-size: 1.12rem; line-height: 1.35; font-weight: 500; }

@media (min-width: 1600px) { .icones-gda { padding: 110px 56px 120px; } .icones-gda__ornament-logo { max-width: 620px; margin-top: -4px; } .icones-gda__head { max-width: 1020px; margin-bottom: 68px; } .icones-gda__mark { width: 60px; height: 60px; margin-bottom: 20px; } .icones-gda__line { width: 420px; margin-bottom: 34px; } .icones-gda__title { font-size: 4.6rem; } .icones-gda__intro { font-size: 18px; max-width: 980px; } .icones-gda__grid { gap: 22px; } .icones-gda__card { min-height: 275px; padding: 40px 24px 32px; } .icones-gda__icon { width: 82px; height: 82px; margin-bottom: 20px; } .icones-gda__icon svg { width: 58px; height: 58px; } .icones-gda__label { font-size: 1.28rem; } }

@media (max-width: 1199px) { .icones-gda__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

@media (max-width: 767px) { .icones-gda { padding: 72px 20px 80px; } .icones-gda__ornament-logo { max-width: 320px; margin-top: 30px; } .icones-gda__head { margin-bottom: 40px; } .icones-gda__line { margin-bottom: 22px; max-width: 82%; } .icones-gda__title { font-size: 2rem; line-height: 1.1; } .icones-gda__intro { font-size: 15px; line-height: 1.75; } .icones-gda__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; } .icones-gda__card { min-height: 210px; padding: 28px 16px 22px; } .icones-gda__icon { width: 62px; height: 62px; margin-bottom: 14px; } .icones-gda__icon svg { width: 44px; height: 44px; } .icones-gda__divider { height: 28px; margin-bottom: 14px; } .icones-gda__label { font-size: 1rem; } }

@media (max-width: 480px) { .icones-gda__grid { grid-template-columns: 1fr; } .icones-gda__title { font-size: 1.8rem; } }

/*-------------------------------------------------------------------------------------------------ACCUEIL----------------------------------------------------------------------------------------*/
.gda-accueil { position: relative; min-height: 78vh; display: flex; align-items: center; justify-content: center; padding: 80px 32px 50px; overflow: hidden; background-color: #d8dac5; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FFFLeqxCNFDVB3XsjO8Yl1BlNjYM2%2Fimages%2FGalerie_fin_de_page_9pbv.webp"); background-size: cover; background-position: center center; background-repeat: no-repeat; isolation: isolate; }

.gda-accueil__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(72, 97, 50, 0.48) 0%, rgba(72, 97, 50, 0.58) 45%, rgba(61, 72, 48, 0.68) 100%); z-index: 0; pointer-events: none; }

.gda-accueil__content { position: relative; z-index: 1; width: 100%; max-width: 1240px; text-align: center; color: #ffffff; }

.gda-accueil__logo { display: block; width: 100%; max-width: 240px; height: auto; margin: 0 auto 26px; object-fit: contain; }

.gda-accueil__eyebrow { display: inline-block; margin: 0 0 22px; padding: 10px 18px; border: 1px solid rgba(255, 255, 255, 0.24); background: rgba(255, 255, 255, 0.08); backdrop-filter: blur(8px); color: #f5f6ef; font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; border-radius: 999px; }

.gda-accueil__title { margin: 0; font-size: 55px; line-height: 1.04; font-weight: 300; letter-spacing: -0.03em; text-shadow: 0 10px 30px rgba(0, 0, 0, 0.16); }

.gda-accueil__title span { display: block; margin-top: 16px; font-size: clamp(1rem, 2vw, 1.45rem); line-height: 1.5; font-weight: 400; letter-spacing: 0.01em; color: rgba(255, 255, 255, 0.92); }

.gda-accueil__actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 16px; margin-top: 40px; }

.gda-accueil__btn { display: inline-flex; align-items: center; justify-content: center; min-width: 210px; min-height: 54px; padding: 14px 28px; border-radius: 12px; text-decoration: none; font-size: 14px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; transition: transform 0.3s ease, background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease; }

.gda-accueil__btn--primary { background: #a8c73d; color: #646e56; border: 1px solid #a8c73d; box-shadow: 0 14px 32px rgba(0, 0, 0, 0.14); }

.gda-accueil__btn--primary:hover { background: #d2ee79; border-color: #d2ee79; color: #646e56; transform: translateY(-2px); }

.gda-accueil__btn--secondary { background: rgba(255, 255, 255, 0.08); color: #ffffff; border: 1px solid rgba(255, 255, 255, 0.3); backdrop-filter: blur(8px); }

.gda-accueil__btn--secondary:hover { background: rgba(255, 255, 255, 0.16); color: #ffffff; border-color: rgba(255, 255, 255, 0.46); transform: translateY(-2px); }

.gda-accueil__scroll { position: absolute; left: 50%; bottom: 26px; transform: translateX(-50%); z-index: 1; color: #d8dac5; opacity: 0.9; animation: gda-accueil-bounce 2s ease-in-out infinite; }

@keyframes gda-accueil-bounce { 0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(8px); } }

@media (max-width: 767px) { .gda-accueil { min-height: 68vh; padding: 70px 20px 45px; background-position: center center; } .gda-accueil__logo { max-width: 180px; margin-bottom: 22px; } .gda-accueil__eyebrow { margin-bottom: 18px; padding: 9px 14px; font-size: 11px; letter-spacing: 0.14em; } .gda-accueil__title span { margin-top: 14px; } .gda-accueil__actions { margin-top: 30px; gap: 12px; } .gda-accueil__btn { width: 100%; max-width: 320px; min-width: 0; } .gda-accueil__scroll { bottom: 18px; } }

/*-------------------------------------------------------------------------------------------------INTRO----------------------------------------------------------------------------------------*/
.gda-presentation { position: relative; padding: 70px 40px; background: #fff; overflow: hidden; }

.gda-presentation__inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }

.gda-presentation__gallery { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: 14px; height: 560px; }

.gda-presentation__col { display: flex; flex-direction: column; gap: 14px; }

.gda-presentation__col--left .gda-presentation__img:first-child { flex: 0 0 175px; }

.gda-presentation__col--left .gda-presentation__img:last-child { flex: 1 1 auto; min-height: 330px; }

.gda-presentation__col--right .gda-presentation__img:first-child { flex: 1; }

.gda-presentation__col--right .gda-presentation__img:last-child { flex: 0 0 145px; }

.gda-presentation__img { position: relative; overflow: hidden; border-radius: 12px; }

.gda-presentation__img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94); }

.gda-presentation__img:hover img { transform: scale(1.04); }

.gda-presentation__img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, transparent 60%, rgba(78, 90, 62, 0.18)); pointer-events: none; }

.gda-presentation__badge { position: absolute; bottom: 14px; left: 14px; z-index: 2; background: rgba(255, 255, 255, 0.92); border-radius: 4px; padding: 5px 11px; font-size: 11px; font-weight: 500; color: #3d4830; letter-spacing: 0.06em; }

.gda-presentation__content { padding-left: 16px; }

.gda-presentation__eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }

.gda-presentation__eyebrow-line { display: block; width: 36px; height: 1.5px; background: #90a76d; flex-shrink: 0; }

.gda-presentation__eyebrow-text { font-size: 25px; font-weight: 500; font-family: 'Dancing Script'; letter-spacing: 0.22em; color: #90a76d; }

.gda-presentation__title { font-size: clamp(2rem, 2.8vw, 3rem); font-weight: 500; line-height: 1.12; letter-spacing: -0.02em; color: #3d4830; margin: 0 0 28px; }

.gda-presentation__title em { font-style: italic; color: #5a6e47; }

.gda-presentation__divider { width: 48px; height: 2px; background: #90a76d; border-radius: 2px; margin-bottom: 28px; }

.gda-presentation__text p { font-size: 18px; line-height: 1.85; color: rgba(61, 72, 48, 0.78); margin: 0 0 16px; font-weight: 300; }

.gda-presentation__text p:last-child { margin-bottom: 0; }

.gda-presentation__bottom { margin-top: 44px; display: flex; align-items: center; justify-content: flex-start; gap: 24px; }

.gda-presentation__logo { display: flex; align-items: center; justify-content: flex-start; }

.gda-presentation__logo img { display: block; width: 120px; height: auto; object-fit: contain; opacity: 0.85; }

/* Très grands écrans (INTACT) */
@media (min-width: 1600px) { .gda-presentation { padding: 110px 70px; } .gda-presentation__inner { max-width: 1520px; gap: 120px; } .gda-presentation__gallery { gap: 18px; height: 720px; grid-template-columns: 1.1fr 0.9fr; } .gda-presentation__col { gap: 18px; } .gda-presentation__col--left .gda-presentation__img:first-child { flex: 0 0 220px; } .gda-presentation__col--left .gda-presentation__img:last-child { min-height: 460px; } .gda-presentation__col--right .gda-presentation__img:last-child { flex: 0 0 180px; } .gda-presentation__badge { bottom: 18px; left: 18px; padding: 7px 14px; font-size: 12px; } .gda-presentation__content { padding-left: 10px; max-width: 700px; } .gda-presentation__eyebrow { gap: 14px; margin-bottom: 30px; } .gda-presentation__eyebrow-line { width: 44px; } .gda-presentation__eyebrow-text { font-size: 12px; letter-spacing: 0.28em; } .gda-presentation__title { font-size: 3.8rem; line-height: 1.06; margin-bottom: 34px; } .gda-presentation__divider { width: 60px; margin-bottom: 34px; } .gda-presentation__text p { font-size: 17px; line-height: 1.95; margin-bottom: 18px; } .gda-presentation__bottom { margin-top: 54px; } .gda-presentation__logo img { width: 150px; } }

/* Tablette et Desktop moyen */
@media (max-width: 991px) { .gda-presentation { padding: 80px 24px; } .gda-presentation__inner { display: flex; flex-direction: column; gap: 80px; /* Augmentation drastique de l'espace global */ align-items: center; } .gda-presentation__gallery { order: -1; width: 100%; max-width: 520px; height: 540px; /* Augmenté pour éviter que l'image ne déborde vers le bas */ display: grid; grid-template-columns: 1.08fr 0.92fr; margin: 0 auto 20px auto; /* Marge supplémentaire de sécurité */ } .gda-presentation__content { order: 1; padding-left: 0; display: flex; flex-direction: column; align-items: center; text-align: center; width: 100%; } .gda-presentation__eyebrow { justify-content: center; } .gda-presentation__divider { margin-left: auto; margin-right: auto; } .gda-presentation__bottom { justify-content: center; width: 100%; } .gda-presentation__logo { justify-content: center; } }

/* Petit Mobile */
@media (max-width: 580px) { .gda-presentation { padding: 72px 20px; } .gda-presentation__inner { gap: 60px; /* Bel espace sur mobile également */ } .gda-presentation__gallery { height: 380px; /* Augmenté pour contenir les images proprement */ gap: 10px; width: 100%; max-width: 100%; margin-bottom: 10px; } .gda-presentation__col { gap: 10px; } .gda-presentation__col--left .gda-presentation__img:first-child { flex: 0 0 125px; } .gda-presentation__col--left .gda-presentation__img:last-child { min-height: 200px; } .gda-presentation__col--right .gda-presentation__img:last-child { flex: 0 0 105px; } .gda-presentation__title { font-size: 1.8rem; } .gda-presentation__text p { font-size: 15px; } .gda-presentation__bottom { margin-top: 34px; } .gda-presentation__logo img { width: 105px; } }

/*-------------------------------------------------------------------------------------------------SERVICES----------------------------------------------------------------------------------------*/
.services-gda { background: #595959; padding: 90px 40px; position: relative; overflow: hidden; }

.services-gda::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: clamp(150px, 25vw, 350px); background-color: #ffffff; clip-path: polygon(0 0, 100% 0, 50% 100%); z-index: 0; pointer-events: none; }

.services-gda__head { text-align: center; max-width: 760px; margin: 0 auto 78px; position: relative; z-index: 1; }

.services-gda__eyebrow { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 20px; }

.services-gda__eyebrow-line { display: block; width: 32px; height: 1.5px; background: #90a76d; flex-shrink: 0; }

.services-gda__eyebrow-text { font-size: 25px; font-weight: 500; font-family: 'Dancing Script'; letter-spacing: 0.22em; color: #90a76d; }

.services-gda__title { font-size: clamp(1.9rem, 2.8vw, 2.8rem); font-weight: 500; line-height: 1.12; letter-spacing: -0.02em; color: #3d4830; margin: 0; }

.services-gda__title em { font-style: italic; color: #5a6e47; }

.services-gda__grid { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; position: relative; z-index: 1; }

.services-gda__card { position: relative; background: #f2f3e9; border: 1px solid rgba(144, 167, 109, 0.18); border-radius: 12px; padding: 38px 32px 32px; overflow: hidden; text-decoration: none; display: block; transition: border-color 0.3s, transform 0.35s cubic-bezier(0.22, 1, 0.36, 1); cursor: pointer; }

.services-gda__card::before { content: ''; position: absolute; inset: 0; background: #3d4830; transform: translateY(100%); transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1); z-index: 0; border-radius: 12px; }

.services-gda__card:hover { transform: translateY(-4px); border-color: #3d4830; }

.services-gda__card:hover::before { transform: translateY(0); }

.services-gda__card > * { position: relative; z-index: 1; }

.services-gda__num { display: block; font-size: 18px; font-weight: 500; font-family: 'Dancing Script'; letter-spacing: 0.18em; color: #90a76d; margin-bottom: 18px; transition: color 0.3s; }

.services-gda__card:hover .services-gda__num { color: #b8cf90; }

.services-gda__card-title { font-size: 1.2rem; font-weight: 500; color: #3d4830; margin: 0 0 14px; line-height: 1.25; transition: color 0.3s; }

.services-gda__card:hover .services-gda__card-title { color: #f2f3e9; }

.services-gda__sep { width: 32px; height: 1.5px; background: #90a76d; margin-bottom: 16px; border-radius: 2px; transition: width 0.3s; }

.services-gda__card:hover .services-gda__sep { width: 48px; }

.services-gda__text { font-size: 14.5px; line-height: 1.8; color: rgba(61, 72, 48, 0.72); margin: 0 0 32px; font-weight: 300; transition: color 0.3s; }

.services-gda__card:hover .services-gda__text { color: rgba(242, 243, 233, 0.72); }

.services-gda__cta { display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; font-weight: 500; letter-spacing: 0.08em; color: #90a76d; opacity: 0; transform: translateY(6px); transition: opacity 0.3s 0.1s, transform 0.3s 0.1s; }

.services-gda__card:hover .services-gda__cta { opacity: 1; transform: translateY(0); color: #b8cf90; }

.services-gda__cta-arrow { display: inline-block; transition: transform 0.25s; }

.services-gda__card:hover .services-gda__cta-arrow { transform: translateX(4px); }

@media (min-width: 1600px) { .services-gda { padding: 120px 70px; } .services-gda::before { height: 420px; } .services-gda__head { max-width: 900px; margin-bottom: 96px; } .services-gda__title { font-size: 3.5rem; line-height: 1.08; } .services-gda__eyebrow-text { font-size: 12px; letter-spacing: 0.28em; } .services-gda__eyebrow-line { width: 42px; } .services-gda__grid { max-width: 1520px; gap: 28px; } .services-gda__card { padding: 48px 40px 40px; min-height: 360px; border-radius: 16px; } .services-gda__card::before { border-radius: 16px; } .services-gda__num { font-size: 12px; margin-bottom: 22px; } .services-gda__card-title { font-size: 1.55rem; margin-bottom: 18px; } .services-gda__sep { width: 40px; margin-bottom: 20px; } .services-gda__card:hover .services-gda__sep { width: 60px; } .services-gda__text { font-size: 16px; line-height: 1.9; margin-bottom: 38px; } .services-gda__cta { font-size: 13.5px; } }

@media (max-width: 991px) { .services-gda { padding: 80px 24px; } .services-gda__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

@media (max-width: 640px) { .services-gda { padding: 64px 20px; } .services-gda__head { margin-bottom: 48px; } .services-gda__grid { grid-template-columns: 1fr; } }

/*-------------------------------------------------------------------------------------------------IMAGES----------------------------------------------------------------------------------------*/
.images-gda { background: #595959; padding: 70px 0 100px; overflow: hidden; }

.images-gda__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; width: 100%; margin: 0; }

.images-gda__item { position: relative; display: block; height: 370px; overflow: hidden; text-decoration: none; background: #c5c8b8; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05); transform: translateZ(0); }

.images-gda__item img { width: 100%; height: 100%; display: block; object-fit: cover; transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94), filter 0.5s ease; }

.images-gda__overlay { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 28px; text-align: center; background: rgba(61, 72, 48, 0.85); opacity: 0; transition: opacity 0.4s ease; }

.images-gda__overlay-eyebrow { display: block; color: #c2e35a; font-size: 11px; font-weight: 700; letter-spacing: 0.26em; text-transform: uppercase; }

.images-gda__overlay-title { display: block; color: #ffffff; font-size: clamp(1.35rem, 2vw, 1.95rem); font-weight: 500; line-height: 1.15; max-width: 190px; }

.images-gda__item:hover img { transform: scale(1.08); filter: brightness(0.8); }

.images-gda__item:hover .images-gda__overlay { opacity: 1; }

/* Très grands écrans */
@media (min-width: 1600px) { .images-gda { padding: 90px 0 120px; } .images-gda__grid { gap: 16px; } .images-gda__item { height: 620px; } .images-gda__overlay { padding: 40px; gap: 16px; } .images-gda__overlay-eyebrow { font-size: 12px; letter-spacing: 0.3em; } .images-gda__overlay-title { font-size: 2.3rem; max-width: 240px; } }

@media (max-width: 1199px) { .images-gda__grid { gap: 12px; } .images-gda__item { height: 420px; } }

@media (max-width: 991px) { .images-gda { padding: 80px 0; } .images-gda__grid { grid-template-columns: repeat(2, 1fr); gap: 12px; padding: 0 12px; } .images-gda__item { height: 400px; } }

@media (max-width: 600px) { .images-gda { padding: 64px 0; } .images-gda__grid { grid-template-columns: 1fr; gap: 10px; padding: 0 10px; } .images-gda__item { height: 320px; } .images-gda__overlay-title { font-size: 1.6rem; max-width: 180px; } }

/*-------------------------------------------------------------------------------------------------CTA ACCUEIL----------------------------------------------------------------------------------------*/
.cta-gda { position: relative; width: 100%; min-height: 560px; overflow: hidden; box-sizing: border-box; display: flex; align-items: center; }

.cta-gda * { box-sizing: border-box; }

.cta-gda__bg { position: absolute; inset: 0; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FFFLeqxCNFDVB3XsjO8Yl1BlNjYM2%2Fimages%2FGD_Agencement_images_roj5.webp"); background-size: cover; background-position: center; background-repeat: no-repeat; filter: brightness(0.62) saturate(0.78); transform: scale(1.05); z-index: 0; }

.cta-gda__inner { position: relative; z-index: 2; width: 100%; padding: 80px 56px; }

.cta-gda__card { background: rgba(216, 218, 197, 0.13); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border: 1px solid rgba(255, 255, 255, 0.2); padding: 56px 60px; max-width: 760px; min-height: 360px; display: flex; flex-direction: column; justify-content: center; }

.cta-gda__title { margin: 0 0 10px; font-size: clamp(30px, 4vw, 48px); font-weight: 300; line-height: 1.08; color: #ffffff; letter-spacing: -0.03em; }

.cta-gda__title strong { font-weight: 700; }

.cta-gda__sub { font-size: 11px; font-weight: 700; letter-spacing: 0.22em; color: #c2e35a; text-transform: uppercase; margin: 0 0 26px; display: block; }

.cta-gda__sep { width: 42px; height: 1px; background: rgba(255, 255, 255, 0.4); margin-bottom: 22px; }

.cta-gda__text { margin: 0 0 34px; font-size: 15px; line-height: 1.9; color: rgba(255, 255, 255, 0.82); font-weight: 400; max-width: 580px; }

.cta-gda__cta { display: inline-flex; align-items: center; justify-content: center; width: 100%; max-width: 260px; padding: 14px 24px; background: #a8c73d; border: 1px solid #a8c73d; color: #646e56; font-size: 11px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; text-decoration: none; transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, transform 0.25s ease; }

.cta-gda__cta:hover { background: #d6ee82; border-color: #d6ee82; color: #646e56; transform: translateY(-2px); }

/* Très grands écrans (INTACT) */
@media (min-width: 1600px) { .cta-gda { min-height: 720px; } .cta-gda__inner { padding: 110px 90px; } .cta-gda__card { max-width: 980px; min-height: 460px; padding: 74px 78px; } .cta-gda__title { font-size: 4.3rem; line-height: 1.02; margin-bottom: 14px; } .cta-gda__sub { font-size: 12px; letter-spacing: 0.28em; margin-bottom: 32px; } .cta-gda__sep { width: 54px; margin-bottom: 28px; } .cta-gda__text { font-size: 17px; line-height: 2; max-width: 720px; margin-bottom: 42px; } .cta-gda__cta { max-width: 300px; padding: 16px 28px; font-size: 12px; letter-spacing: 0.22em; } }

/* Tablette et Desktop moyen */
@media (max-width: 991px) { .cta-gda { min-height: 500px; } .cta-gda__inner { padding: 64px 32px; display: flex; justify-content: center; /* Centre la carte dans le conteneur */ } .cta-gda__card { max-width: 620px; padding: 46px 40px; min-height: 320px; align-items: center; /* Centre les éléments enfants (bouton, séparateur) */ text-align: center; /* Centre les textes */ } .cta-gda__sep { margin-left: auto; margin-right: auto; /* Centre le trait de séparation */ } .cta-gda__text { margin-left: auto; margin-right: auto; /* Centre le paragraphe */ } }

/* Petit Mobile */
@media (max-width: 640px) { .cta-gda { min-height: 460px; } .cta-gda__inner { padding: 40px 20px; } .cta-gda__card { padding: 34px 26px; max-width: 100%; min-height: auto; } .cta-gda__title { font-size: 28px; } .cta-gda__text { font-size: 14px; line-height: 1.8; max-width: 100%; } .cta-gda__cta { width: 100%; max-width: 100%; /* Le bouton prend toute la largeur pour une meilleure UX mobile */ } }

/*-------------------------------------------------------------------------------------------------ACCUEIL PAGES----------------------------------------------------------------------------------------*/
.gda-header-intro { position: relative; overflow: hidden; background: linear-gradient(0deg, #ffffff 0%, #ffffff 16%, #585858 16%, #585858 52%); }

.gda-header-intro * { box-sizing: border-box; }

.gda-header-intro__container { max-width: 1360px; margin: 0 auto; padding: 0 32px; }

.gda-header-intro__grid { display: grid; grid-template-columns: minmax(320px, 0.9fr) minmax(480px, 1.1fr); align-items: center; gap: 34px; min-height: 760px; }

.gda-header-intro__content { position: relative; z-index: 2; padding: 24px 0 40px; margin-top: -28px; }

.gda-header-intro__info { max-width: 520px; }

.gda-header-intro__logo { display: block; width: 100%; max-width: 150px; height: auto; object-fit: contain; margin: 0 0 18px; }

.gda-header-intro__title { margin: 0 0 22px; font-size: clamp(2.6rem, 4.4vw, 4.6rem); line-height: 0.98; font-weight: 400; letter-spacing: -0.03em; color: #ffffff; }

.gda-header-intro__lead { margin: 0 0 28px; max-width: 470px; font-size: 1.1rem; line-height: 1.75; font-weight: 300; color: rgba(232, 234, 216, 0.86); }

.gda-header-intro__btn { display: inline-flex; align-items: center; justify-content: center; min-width: 210px; padding: 18px 30px; background: #a8c73d; color: #1f1f1f; text-decoration: none; font-size: 0.74rem; font-weight: 700; letter-spacing: 0.28em; text-transform: uppercase; transition: background 0.25s ease, transform 0.25s ease; }

.gda-header-intro__btn:hover { background: #595959; transform: translateY(-2px); }

.gda-header-intro__media { position: relative; z-index: 1; padding: 40px 0; }

.gda-header-intro__image-holder { position: relative; width: 100%; max-width: 760px; margin-left: auto; }

.gda-header-intro__image-frame { position: absolute; inset: 0; border: 1px solid rgba(232, 234, 216, 0.28); z-index: 1; pointer-events: none; }

.gda-header-intro__image { position: relative; z-index: 2; display: block; width: 100%; height: 620px; object-fit: cover; transform: translate(28px, 26px); }

/* Très grands écrans (INTACT) */
@media (min-width: 1600px) { .gda-header-intro { background: linear-gradient(0deg, #ffffff 0%, #ffffff 18%, #646e56 18%, #646e56 54%); } .gda-header-intro__container { max-width: 1540px; padding: 0 48px; } .gda-header-intro__grid { grid-template-columns: minmax(420px, 0.92fr) minmax(680px, 1.08fr); min-height: 900px; gap: 72px; } .gda-header-intro__content { margin-top: -42px; padding: 20px 0 40px; } .gda-header-intro__info { max-width: 610px; } .gda-header-intro__logo { max-width: 180px; margin-bottom: 22px; } .gda-header-intro__title { font-size: 5rem; max-width: 760px; margin-bottom: 24px; } .gda-header-intro__lead { font-size: 1.22rem; line-height: 1.85; max-width: 560px; margin-bottom: 32px; } .gda-header-intro__btn { min-width: 230px; padding: 19px 34px; font-size: 0.76rem; } .gda-header-intro__image-holder { max-width: 900px; } .gda-header-intro__image { height: 730px; transform: translate(34px, 30px); } }

@media (min-width: 1900px) { .gda-header-intro__container { max-width: 1700px; padding: 0 60px; } .gda-header-intro__grid { grid-template-columns: minmax(460px, 0.9fr) minmax(760px, 1.1fr); min-height: 980px; gap: 90px; } .gda-header-intro__content { margin-top: -56px; } .gda-header-intro__logo { max-width: 195px; } .gda-header-intro__title { font-size: 4rem; max-width: 920px; } .gda-header-intro__lead { font-size: 1.28rem; max-width: 590px; } .gda-header-intro__image-holder { max-width: 1020px; } .gda-header-intro__image { height: 790px; transform: translate(40px, 34px); } }

/* Tablette et Desktop moyen */
@media (max-width: 991px) { .gda-header-intro { background: linear-gradient(0deg, #ffffff 0%, #ffffff 12%, #646e56 12%, #646e56 60%); } .gda-header-intro__container { padding: 0 24px; } .gda-header-intro__grid { grid-template-columns: 1fr; gap: 26px; min-height: auto; padding: 52px 0 72px; } .gda-header-intro__content { margin-top: -8px; padding: 0; } .gda-header-intro__info { max-width: 100%; display: flex; flex-direction: column; align-items: center; /* Centre les éléments enfants */ text-align: center; /* Centre les textes */ margin: 0 auto; } .gda-header-intro__logo { max-width: 135px; margin: 0 auto 16px; /* Centré horizontalement */ } .gda-header-intro__title { max-width: 620px; margin-left: auto; margin-right: auto; margin-bottom: 18px; font-size: clamp(2.4rem, 7vw, 4rem); } .gda-header-intro__lead { max-width: 100%; margin-left: auto; margin-right: auto; margin-bottom: 24px; font-size: 1.04rem; line-height: 1.72; } .gda-header-intro__media { padding: 12px 0 0; } .gda-header-intro__image-holder { max-width: calc(100% - 18px); margin: 0 auto; /* Annule l'alignement à droite (margin-left: auto) pour centrer l'image */ transform: translateX(-9px); /* Compense visuellement le décalage du cadre pour un centrage parfait de l'ensemble */ } .gda-header-intro__image { height: 440px; transform: translate(18px, 18px); } }

/* Petit Mobile */
@media (max-width: 640px) { .gda-header-intro { background: linear-gradient(0deg, #ffffff 0%, #ffffff 10%, #646e56 10%, #646e56 64%); } .gda-header-intro__container { padding: 0 20px; } .gda-header-intro__grid { padding: 38px 0 52px; gap: 16px; } .gda-header-intro__content { margin-top: 0; } .gda-header-intro__logo { max-width: 118px; margin-bottom: 14px; } .gda-header-intro__title { font-size: 2.3rem; line-height: 1.02; margin-bottom: 16px; } .gda-header-intro__lead { font-size: 0.98rem; line-height: 1.68; margin-bottom: 22px; } .gda-header-intro__btn { min-width: 180px; padding: 15px 22px; font-size: 0.66rem; letter-spacing: 0.24em; } .gda-header-intro__media { padding-top: 8px; } .gda-header-intro__image-holder { max-width: calc(100% - 12px); transform: translateX(-6px); } .gda-header-intro__image { height: 300px; transform: translate(12px, 12px); } }

@media (max-width: 420px) { .gda-header-intro__title { font-size: 2.05rem; } .gda-header-intro__lead { font-size: 0.94rem; } .gda-header-intro__btn { width: 100%; max-width: 220px; margin: 0 auto; /* S'assure que le bouton reste centré s'il prend toute la largeur dispo */ } .gda-header-intro__image { height: 255px; } }

/*-------------------------------------------------------------------------------------------------CERCLE----------------------------------------------------------------------------------------*/
/* ============================================= SECTION : gda-categories-circles Isolée — n'affecte aucun autre bloc du site ============================================= */
.gda-categories-circles { padding: 72px 32px 64px; background: #fff; overflow: hidden; }

.gda-categories-circles__container { max-width: 1100px; margin: 0 auto; }

.gda-categories-circles__track { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); /* Modifié pour 5 éléments */ align-items: start; justify-items: center; gap: 40px 24px; /* Espace ajusté entre les éléments */ }

/* --- Item --- */
.gda-categories-circles__item { text-decoration: none; text-align: center; color: #646e56; width: 100%; max-width: 200px; display: flex; flex-direction: column; align-items: center; gap: 0; }

/* --- Cercle photo --- */
.gda-categories-circles__thumb { position: relative; width: 160px; height: 160px; margin: 0 auto 20px; border-radius: 50%; overflow: visible; display: block; flex-shrink: 0; }

/* Anneau décoratif externe */
.gda-categories-circles__ring { position: absolute; inset: -5px; border-radius: 50%; border: 1.5px solid rgba(144, 167, 109, 0.35); transition: border-color 0.4s ease, inset 0.4s ease; pointer-events: none; }

/* Image circulaire */
.gda-categories-circles__thumb img { width: 160px; height: 160px; border-radius: 50%; object-fit: cover; display: block; transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94); }

/* --- Numéro d'ordre discret --- */
.gda-categories-circles__item:nth-child(1) .gda-categories-circles__thumb::before, .gda-categories-circles__item:nth-child(2) .gda-categories-circles__thumb::before, .gda-categories-circles__item:nth-child(3) .gda-categories-circles__thumb::before, .gda-categories-circles__item:nth-child(4) .gda-categories-circles__thumb::before, .gda-categories-circles__item:nth-child(5) .gda-categories-circles__thumb::before { content: ""; position: absolute; bottom: 4px; right: 4px; width: 26px; height: 26px; border-radius: 50%; background: #c2e35a; z-index: 2; }

.gda-categories-circles__item:nth-child(1) .gda-categories-circles__thumb::before { content: "01"; font-size: 10px; font-weight: 700; color: #646e56; display: flex; align-items: center; justify-content: center; letter-spacing: 0.05em; }

.gda-categories-circles__item:nth-child(2) .gda-categories-circles__thumb::before { content: "02"; font-size: 10px; font-weight: 700; color: #646e56; display: flex; align-items: center; justify-content: center; letter-spacing: 0.05em; }

.gda-categories-circles__item:nth-child(3) .gda-categories-circles__thumb::before { content: "03"; font-size: 10px; font-weight: 700; color: #646e56; display: flex; align-items: center; justify-content: center; letter-spacing: 0.05em; }

.gda-categories-circles__item:nth-child(4) .gda-categories-circles__thumb::before { content: "04"; font-size: 10px; font-weight: 700; color: #646e56; display: flex; align-items: center; justify-content: center; letter-spacing: 0.05em; }

.gda-categories-circles__item:nth-child(5) .gda-categories-circles__thumb::before { content: "05"; font-size: 10px; font-weight: 700; color: #646e56; display: flex; align-items: center; justify-content: center; letter-spacing: 0.05em; }

/* --- Label --- */
.gda-categories-circles__label { display: block; font-size: 1.45rem; line-height: 1.18; color: #646e56; font-family: 'Noto Serif'; letter-spacing: -0.02em; margin-bottom: 10px; transition: color 0.3s ease; }

/* --- CTA discret --- */
.gda-categories-circles__cta { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: #90a76d; opacity: 0; transform: translateY(4px); transition: opacity 0.35s ease, transform 0.35s ease; }

/* --- Hover --- */
.gda-categories-circles__item:hover .gda-categories-circles__thumb img { transform: scale(1.07); }

.gda-categories-circles__item:hover .gda-categories-circles__ring { inset: -8px; border-color: #c2e35a; }

.gda-categories-circles__item:hover .gda-categories-circles__label { color: #3d4830; }

.gda-categories-circles__item:hover .gda-categories-circles__cta { opacity: 1; transform: translateY(0); }

/* ============================================= RESPONSIVE ============================================= */
@media (min-width: 1600px) { .gda-categories-circles { padding: 88px 48px 72px; } .gda-categories-circles__container { max-width: 1360px; } .gda-categories-circles__thumb, .gda-categories-circles__thumb img { width: 190px; height: 190px; } .gda-categories-circles__label { font-size: 1.65rem; } }

@media (max-width: 991px) { .gda-categories-circles { padding: 56px 24px 48px; } .gda-categories-circles__track { grid-template-columns: repeat(3, minmax(0, 1fr)); /* Adaptation pour 3 éléments */ gap: 48px 20px; } .gda-categories-circles__thumb, .gda-categories-circles__thumb img { width: 130px; height: 130px; } .gda-categories-circles__label { font-size: 1.25rem; } }

@media (max-width: 580px) { .gda-categories-circles { padding: 44px 16px 36px; } .gda-categories-circles__track { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 36px 12px; } .gda-categories-circles__item { max-width: 100%; } .gda-categories-circles__thumb, .gda-categories-circles__thumb img { width: 108px; height: 108px; } .gda-categories-circles__label { font-size: 1.1rem; line-height: 1.12; } .gda-categories-circles__cta { display: none; } }

/*-------------------------------------------------------------------------------------------------INTRO CUISINE----------------------------------------------------------------------------------------*/
.gda-cuisine { position: relative; padding: 95px 40px; background: #ffffff; overflow: hidden; }

.gda-cuisine__container { max-width: 1380px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }

.gda-cuisine__visual { position: relative; min-height: 570px; }

.gda-cuisine__shape { position: absolute; z-index: 0; }

.gda-cuisine__shape--left { left: 0; top: 40px; width: 76px; height: 465px; background: #595959; }

.gda-cuisine__shape--right { left: 400px; top: 92px; width: 132px; height: 500px; background: #a8c73d; z-index: 0; }

.gda-cuisine__image-wrap { position: absolute; left: 34px; top: 0; width: calc(100% - 60px); max-width: 470px; height: 540px; z-index: 1; overflow: hidden; box-shadow: 0 18px 40px rgba(0, 0, 0, 0.08); }

.gda-cuisine__image { width: 100%; height: 100%; display: block; object-fit: cover; }

.gda-cuisine__content { position: relative; z-index: 2; max-width: 760px; padding-right: 10px; }

.gda-cuisine__eyebrow { display: inline-block; margin-bottom: 20px; color: #90a76d; font-size: 25px; font-family: 'Dancing Script', cursive; font-weight: 500; letter-spacing: 0.24em; }

.gda-cuisine__title { margin: 0 0 24px; color: #3d4830; font-size: clamp(2rem, 3vw, 3.1rem); line-height: 1.08; font-weight: 500; letter-spacing: -0.02em; }

.gda-cuisine__text { max-width: 720px; }

.gda-cuisine__text p { margin: 0 0 16px; color: rgba(100, 110, 86, 0.82); font-size: 18px; line-height: 1.85; font-weight: 400; }

.gda-cuisine__text p:last-child { margin-bottom: 0; }

/* --- GRANDS ECRANS INTACTS --- */
@media (min-width: 1600px) { .gda-cuisine { padding: 120px 60px; } .gda-cuisine__container { max-width: 1560px; grid-template-columns: 1fr 1fr; gap: 60px; } .gda-cuisine__visual { min-height: 660px; } .gda-cuisine__shape--left { width: 88px; height: 540px; top: 46px; } .gda-cuisine__shape--right { left: 450px; top: 102px; width: 160px; height: 580px; } .gda-cuisine__image-wrap { left: 40px; width: calc(100% - 70px); max-width: 540px; height: 620px; } .gda-cuisine__title { font-size: 3.5rem; } .gda-cuisine__text p { font-size: 17px; line-height: 1.95; } }

/* --- TABLETTE --- */
@media (max-width: 1100px) { .gda-cuisine { padding: 80px 24px; } .gda-cuisine__container { display: flex; flex-direction: column; /* Force l'ordre visuel */ gap: 60px; } .gda-cuisine__visual { order: -1; /* Place le visuel au-dessus */ max-width: 560px; width: 100%; min-height: 560px; margin: 0 auto; } .gda-cuisine__content { max-width: 100%; padding-right: 0; text-align: center; /* Centre les textes */ display: flex; flex-direction: column; align-items: center; /* Centre les éléments */ } .gda-cuisine__text { margin: 0 auto; /* Assure le centrage du bloc de texte */ } }

/* --- MOBILE --- */
@media (max-width: 640px) { .gda-cuisine { padding: 64px 20px; } .gda-cuisine__container { gap: 40px; } .gda-cuisine__visual { min-height: 380px; /* Légèrement augmenté pour bien contenir les formes */ max-width: 400px; /* Limite la largeur sur mobile */ } /* Ajustement des formes pour qu'elles restent proportionnelles et bien placées */ .gda-cuisine__shape--left { width: 42px; height: 300px; top: 30px; left: 0; } .gda-cuisine__shape--right { left: auto; /* Annule le left fixe de la version bureau */ right: 0; /* Aligne sur la droite de la div visual */ top: 60px; width: 60px; height: 320px; } .gda-cuisine__image-wrap { left: 20px; /* Centre visuellement l'image entre les deux formes */ width: calc(100% - 40px); /* Laisse 20px de chaque côté */ max-width: 100%; height: 350px; } .gda-cuisine__eyebrow { margin-bottom: 14px; font-size: 20px; /* Légèrement plus lisible sur mobile */ } .gda-cuisine__title { margin-bottom: 18px; font-size: 1.9rem; line-height: 1.1; } .gda-cuisine__text p { font-size: 15px; line-height: 1.75; } }

/*-------------------------------------------------------------------------------------------------PLACARD----------------------------------------------------------------------------------------*/
.gda-features { background: #585858; /* Couleur beige/vert pâle pour la partie basse */ padding: 100px 24px; overflow: hidden; /* Empêche le triangle de déborder */ }

/* NOUVEAU : Le triangle blanc inversé en haut de la section */
.gda-features::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; /* clamp() permet au triangle de s'adapter gracieusement du mobile au desktop */ height: clamp(250px, 40vw, 200px); background-color: #ffffff; clip-path: polygon(0 0, 100% 0, 50% 100%); z-index: 0; pointer-events: none; /* Empêche de bloquer les clics */ }

.gda-features * { box-sizing: border-box; }

.gda-features__container { position: relative; z-index: 1; /* Place le contenu au-dessus du triangle de fond */ max-width: 1100px; margin: 0 auto; }

/* --- En-tête --- */
.gda-features__header { text-align: center; max-width: 720px; margin: 0 auto 64px; }

.gda-features__title { color: white; font-size: clamp(2.2rem, 3.5vw, 3rem); font-weight: 600; line-height: 1.15; letter-spacing: -0.02em; margin: 0 0 20px; }

.gda-features__intro { color: white; font-size: 16.5px; line-height: 1.7; margin: 0; }

/* --- Grille --- */
.gda-features__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; }

/* --- Cartes --- */
.gda-features__card { background: #ffffff; display: flex; align-items: flex-start; gap: 24px; padding: 40px; border-radius: 12px; box-shadow: 0 15px 40px rgba(0, 0, 0, 0.04); border: 1px solid rgba(144, 167, 109, 0.12); /* Bordure subtile adaptée au fond */ transition: transform 0.3s ease, box-shadow 0.3s ease; }

.gda-features__card:hover { transform: translateY(-4px); box-shadow: 0 20px 50px rgba(0, 0, 0, 0.06); }

/* --- Icônes --- */
.gda-features__icon { flex-shrink: 0; width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; color: #90a76d; background: rgba(144, 167, 109, 0.1); border-radius: 8px; }

.gda-features__icon svg { width: 24px; height: 24px; }

/* --- Contenu Texte des Cartes --- */
.gda-features__content { display: flex; flex-direction: column; gap: 8px; }

.gda-features__card-title { margin: 0; color: #3d4830; font-size: 18px; font-weight: 700; line-height: 1.3; }

.gda-features__card-text { margin: 0; color: rgba(61, 72, 48, 0.65); font-size: 14.5px; line-height: 1.6; }

/* --- Responsive --- */
@media (max-width: 991px) { .gda-features { padding: 80px 24px; } .gda-features__grid { gap: 24px; } .gda-features__card { padding: 32px 24px; gap: 20px; } }

@media (max-width: 768px) { .gda-features__grid { grid-template-columns: 1fr; } .gda-features__title { font-size: 2rem; } .gda-features__header { margin-bottom: 48px; } }

/*-------------------------------------------------------------------------------------------------CTA----------------------------------------------------------------------------------------*/
.gda-luxe-editorial { position: relative; background: #ffffff; padding: 80px 24px; }

.gda-luxe-editorial * { box-sizing: border-box; }

/* La bande foncée en arrière-plan avec couleur personnalisable dans le HTML */
.gda-luxe-editorial__top-band { position: absolute; top: 0; left: 0; width: 100%; height: 45%; background-color: #595959; /* Couleur par défaut : #3d4830 */ }

/* La carte centrale */
.gda-luxe-editorial__wrap { position: relative; z-index: 1; max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; background: #f5f4f1; box-shadow: 0 25px 50px rgba(0, 0, 0, 0.08); }

/* --- Partie Gauche (Texte) --- */
.gda-luxe-editorial__content { padding: 80px 70px; display: flex; flex-direction: column; justify-content: center; }

.gda-luxe-editorial__eyebrow { display: inline-block; margin-bottom: 24px; color: #90a76d; font-family: 'Dancing Script', cursive; font-size: 25px; letter-spacing: 0.28em; }

.gda-luxe-editorial__title { margin: 0 0 24px; color: #3d4830; font-size: clamp(1.8rem, 2.5vw, 2.2rem); line-height: 1.2; font-weight: 500; letter-spacing: -0.01em; }

.gda-luxe-editorial__text { max-width: 90%; }

.gda-luxe-editorial__text p { margin: 0; color: rgba(61, 72, 48, 0.85); font-size: 18px; line-height: 1.8; font-weight: 400; }

/* --- Partie Droite (Image) --- */
.gda-luxe-editorial__media { position: relative; width: 100%; height: 90%; overflow: hidden; }

.gda-luxe-editorial__image { width: 100%; height: 100%; display: block; object-fit: cover; }

/* --- CTA Button --- */
.gda-luxe-editorial__cta { margin-top: 40px; padding: 12px 24px; background-color: #a8c73d; color: white; text-align: center; font-size: 16px; font-weight: 700; border-radius: 4px; text-decoration: none; display: inline-block; transition: background-color 0.3s ease; align-self: flex-start; /* Empêche le bouton de s'étirer sur desktop */ }

.gda-luxe-editorial__cta:hover { background-color: #7a8f5d; color: white; }

/* --- Responsive (Tablette & Petit Desktop) --- */
@media (max-width: 1100px) { .gda-luxe-editorial { padding: 60px 24px; } .gda-luxe-editorial__wrap { display: flex; flex-direction: column; /* Force l'affichage en colonne pour pouvoir inverser l'ordre */ } .gda-luxe-editorial__media { order: -1; /* Fait passer l'image au-dessus du texte */ height: 400px; width: 100%; /* S'assure que l'image prend toute la place */ } .gda-luxe-editorial__content { order: 1; /* Le texte passe en dessous */ padding: 56px 40px; align-items: center; /* Centre les éléments enfants (bouton, titres) */ text-align: center; /* Centre le texte */ } .gda-luxe-editorial__text { max-width: 100%; /* Laisse le texte respirer */ margin: 0 auto; /* Assure le centrage global */ } .gda-luxe-editorial__cta { align-self: center; /* Centre le bouton */ } }

/* --- Responsive (Mobile) --- */
@media (max-width: 640px) { .gda-luxe-editorial { padding: 40px 16px; } .gda-luxe-editorial__top-band { height: 35%; } .gda-luxe-editorial__content { padding: 40px 24px; } .gda-luxe-editorial__eyebrow { margin-bottom: 16px; } .gda-luxe-editorial__title { font-size: 1.8rem; /* Légèrement augmenté pour plus d'impact */ margin-bottom: 20px; } .gda-luxe-editorial__text p { font-size: 15px; } .gda-luxe-editorial__media { height: 300px; /* Un peu plus grand pour mieux voir la photo */ } .gda-luxe-editorial__cta { width: 100%; /* Le bouton prend toute la largeur sur petit écran */ max-width: 320px; } }

/*--------------------------------------------------------------------------------------------SERVICES SALLE DE BAIN----------------------------------------------------------------------------------------*/
.gda-amenagement { /* Le vert olive du fond, inspiré de ton image et de ta charte */ background-color: #595959; padding: 100px 24px; font-family: 'DM Sans', sans-serif; }

.gda-amenagement * { box-sizing: border-box; }

.gda-amenagement__container { max-width: 1400px; margin: 0 auto; }

/* --- En-tête --- */
.gda-amenagement__header { text-align: center; max-width: 780px; margin: 0 auto 60px; }

.gda-amenagement__title { font-family: 'Playfair Display', Georgia, serif; font-size: clamp(2rem, 3.5vw, 3rem); font-weight: 500; color: #ffffff; margin: 0 0 20px; line-height: 1.2; }

.gda-amenagement__intro { font-size: 18px; line-height: 1.7; color: rgba(255, 255, 255, 0.85); margin: 0; font-weight: 300; }

/* --- Grille (4 colonnes) --- */
.gda-amenagement__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }

/* --- Cartes Blanches --- */
.gda-amenagement__card { background: #ffffff; padding: 20px; /* Crée le cadre blanc autour de l'image comme sur la maquette */ display: flex; flex-direction: column; text-align: center; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08); transition: transform 0.4s ease, box-shadow 0.4s ease; }

.gda-amenagement__card:hover { transform: translateY(-6px); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12); }

/* --- Image container --- */
.gda-amenagement__image-wrap { width: 100%; aspect-ratio: 1 / 1; /* Format carré pour une belle harmonie visuelle */ overflow: hidden; margin-bottom: 28px; background: #f5f4f1; }

.gda-amenagement__image { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.8s ease; }

.gda-amenagement__card:hover .gda-amenagement__image { transform: scale(1.05); /* Léger zoom au survol pour le côté premium */ }

/* --- Textes de la carte --- */
.gda-amenagement__card-title { font-family: 'Playfair Display', Georgia, serif; font-size: 1.4rem; font-weight: 500; color: #3d4830; margin: 0 0 16px; line-height: 1.3; }

.gda-amenagement__card-text { font-size: 16px; line-height: 1.65; color: rgba(61, 72, 48, 0.75); margin: 0 0 20px; font-weight: 300; flex-grow: 1; /* Pousse le contenu vers le bas uniformément */ }

/* --- Responsive --- */
@media (max-width: 1199px) { .gda-amenagement__grid { grid-template-columns: repeat(2, 1fr); gap: 32px; } }

@media (max-width: 767px) { .gda-amenagement { padding: 70px 20px; } .gda-amenagement__header { margin-bottom: 48px; } .gda-amenagement__grid { grid-template-columns: 1fr; /* Passage sur 1 seule colonne */ gap: 24px; } .gda-amenagement__card { padding: 16px; } }

/*--------------------------------------------------------------------------------------------ICONES CARTES----------------------------------------------------------------------------------------*/
.gda-cuisine-services { position: relative; padding: 70px 40px 60px; background: #646e56; overflow: hidden; isolation: isolate; }

.gda-cuisine-services * { box-sizing: border-box; }

.gda-cuisine-services__ornament { position: absolute; inset: 0; z-index: 0; pointer-events: none; display: flex; align-items: flex-start; justify-content: center; }

.gda-cuisine-services__ornament-logo { width: 100%; max-width: 520px; height: auto; object-fit: contain; opacity: 0.08; margin-top: 30px !important; }

.gda-cuisine-services__container { position: relative; z-index: 1; max-width: 1600px; margin: 0 auto; }

.gda-cuisine-services__head { max-width: 900px; margin: 0 auto 58px; text-align: center; }

.gda-cuisine-services__mark { position: relative; display: inline-flex; width: 52px; height: 52px; border: 1px solid rgba(194, 227, 90, 0.3); border-radius: 50%; margin-bottom: 18px; align-items: center; justify-content: center; }

.gda-cuisine-services__mark::before { content: ""; width: 16px; height: 16px; border-radius: 50%; background: #c2e35a; box-shadow: 0 0 0 5px rgba(194, 227, 90, 0.16); }

.gda-cuisine-services__line { width: 320px; max-width: 70%; height: 1px; margin: 0 auto 28px; background: rgba(232, 234, 216, 0.14); }

.gda-cuisine-services__title { margin: 0 0 22px; color: #ffffff; font-family: Georgia, "Times New Roman", serif; font-size: clamp(2.1rem, 3.3vw, 4rem); line-height: 1.05; font-weight: 500; letter-spacing: -0.03em; }

.gda-cuisine-services__intro { margin: 0 auto; max-width: 900px; color: rgba(232, 234, 216, 0.8); font-size: 18px; line-height: 1.9; font-weight: 400; }

.gda-cuisine-services__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }

.gda-cuisine-services__card { min-height: 245px; padding: 36px 22px 28px; border: 1px solid rgba(232, 234, 216, 0.12); background: rgba(255, 255, 255, 0.01); text-align: center; transition: transform 0.3s ease, border-color 0.3s ease, background 0.3s ease; }

.gda-cuisine-services__card:hover { transform: translateY(-4px); border-color: rgba(194, 227, 90, 0.3); background: rgba(255, 255, 255, 0.03); }

.gda-cuisine-services__icon { display: flex; align-items: center; justify-content: center; width: 74px; height: 74px; margin: 0 auto 18px; color: #c2e35a; }

.gda-cuisine-services__icon svg { width: 52px; height: 52px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

.gda-cuisine-services__divider { display: block; width: 1px; height: 36px; margin: 0 auto 18px; background: rgba(232, 234, 216, 0.18); }

.gda-cuisine-services__label { margin: 0; color: #ffffff; font-family: Georgia, "Times New Roman", serif; font-size: 1.12rem; line-height: 1.35; font-weight: 500; }

@media (min-width: 1600px) { .gda-cuisine-services { padding: 110px 56px 120px; } .gda-cuisine-services__ornament-logo { max-width: 620px; margin-top: -4px; } .gda-cuisine-services__head { max-width: 1020px; margin-bottom: 68px; } .gda-cuisine-services__mark { width: 60px; height: 60px; margin-bottom: 20px; } .gda-cuisine-services__line { width: 420px; margin-bottom: 34px; } .gda-cuisine-services__title { font-size: 4.6rem; } .gda-cuisine-services__intro { font-size: 18px; max-width: 980px; } .gda-cuisine-services__grid { gap: 22px; } .gda-cuisine-services__card { min-height: 275px; padding: 40px 24px 32px; } .gda-cuisine-services__icon { width: 82px; height: 82px; margin-bottom: 20px; } .gda-cuisine-services__icon svg { width: 58px; height: 58px; } .gda-cuisine-services__label { font-size: 1.28rem; } }

@media (max-width: 1199px) { .gda-cuisine-services__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

@media (max-width: 767px) { .gda-cuisine-services { padding: 72px 20px 80px; } .gda-cuisine-services__ornament-logo { max-width: 320px; margin-top: 30px; } .gda-cuisine-services__head { margin-bottom: 40px; } .gda-cuisine-services__line { margin-bottom: 22px; max-width: 82%; } .gda-cuisine-services__title { font-size: 2rem; line-height: 1.1; } .gda-cuisine-services__intro { font-size: 15px; line-height: 1.75; } .gda-cuisine-services__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; } .gda-cuisine-services__card { min-height: 210px; padding: 28px 16px 22px; } .gda-cuisine-services__icon { width: 62px; height: 62px; margin-bottom: 14px; } .gda-cuisine-services__icon svg { width: 44px; height: 44px; } .gda-cuisine-services__divider { height: 28px; margin-bottom: 14px; } .gda-cuisine-services__label { font-size: 1rem; } }

@media (max-width: 480px) { .gda-cuisine-services__grid { grid-template-columns: 1fr; } .gda-cuisine-services__title { font-size: 1.8rem; } }

/*--------------------------------------------------------------------------------------------CTA 3D----------------------------------------------------------------------------------------*/
.gda-mobilier { background: #ffffff; padding: 110px 40px; position: relative; overflow: hidden; }

.gda-mobilier * { box-sizing: border-box; }

.gda-mobilier__container { max-width: 1260px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }

/* --- Galerie --- */
.gda-mobilier__gallery { display: grid; grid-template-columns: 5fr 4fr; grid-template-rows: 300px 280px; gap: 14px; }

.gda-mobilier__img { overflow: hidden; border-radius: 0px; position: relative; }

.gda-mobilier__img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.65s cubic-bezier(0.25, 0.46, 0.45, 0.94); }

.gda-mobilier__img:hover img { transform: scale(1.05); }

.gda-mobilier__img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, transparent 55%, rgba(61, 72, 48, 0.15)); pointer-events: none; }

.gda-mobilier__img--1 { grid-column: 1; grid-row: 1; }

.gda-mobilier__img--2 { grid-column: 2; grid-row: 1; }

.gda-mobilier__img--3 { grid-column: 1; grid-row: 2; }

.gda-mobilier__img--4 { grid-column: 2; grid-row: 2; }

.gda-mobilier__badge { position: absolute; bottom: 14px; left: 14px; z-index: 2; background: rgba(255, 255, 255, 0.92); border-radius: 4px; padding: 5px 12px; font-size: 10px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: #3d4830; }

/* --- Contenu --- */
.gda-mobilier__content { padding-left: 12px; }

.gda-mobilier__eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }

.gda-mobilier__eyebrow-line { display: block; width: 32px; height: 1.5px; background: #90a76d; flex-shrink: 0; }

.gda-mobilier__eyebrow-text { font-size: 25px; font-weight: 500; font-family: 'Dancing Script'; letter-spacing: 0.22em; color: #90a76d; }

.gda-mobilier__title { font-size: clamp(1.8rem, 2.5vw, 2.7rem); font-weight: 500; line-height: 1.15; letter-spacing: -0.02em; color: #3d4830; margin: 0 0 28px; }

.gda-mobilier__title em { font-style: italic; color: #5a6e47; }

.gda-mobilier__sep { width: 48px; height: 2px; background: #90a76d; border-radius: 2px; margin-bottom: 32px; }

.gda-mobilier__text p { font-size: 18px; line-height: 1.85; color: rgba(61, 72, 48, 0.75); font-weight: 300; margin: 0 0 20px; }

.gda-mobilier__text p:last-child { margin-bottom: 0; }

/* --- Points forts --- */
.gda-mobilier__features { margin-top: 36px; display: flex; flex-direction: column; gap: 16px; }

.gda-mobilier__feature { display: flex; align-items: flex-start; gap: 16px; }

.gda-mobilier__feature-dot { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; background: #f2f3e9; border: 1px solid rgba(144, 167, 109, 0.3); display: flex; align-items: center; justify-content: center; margin-top: 1px; }

.gda-mobilier__feature-dot span { display: block; width: 7px; height: 7px; border-radius: 50%; background: #a7c63e; }

.gda-mobilier__feature-text { font-size: 16px; line-height: 1.65; color: rgba(61, 72, 48, 0.78); font-weight: 300; }

.gda-mobilier__feature-text strong { font-weight: 600; color: #3d4830; display: block; margin-bottom: 2px; font-size: 17px; }

/* --- CTA --- */
.gda-mobilier__cta { margin-top: 44px; display: inline-flex; align-items: center; gap: 10px; padding: 13px 28px; border-radius: 0px; border: 1.5px solid #90a76d; background: transparent; color: #3d4830; font-size: 13.5px; font-weight: 500; letter-spacing: 0.04em; text-decoration: none; cursor: pointer; transition: background 0.25s, color 0.25s; }

.gda-mobilier__cta:hover { background: #3d4830; color: #f2f3e9; }

.gda-mobilier__cta-arrow { display: inline-block; transition: transform 0.25s; }

.gda-mobilier__cta:hover .gda-mobilier__cta-arrow { transform: translateX(4px); }

/* --- Responsive --- */
@media (max-width: 1024px) { .gda-mobilier__container { grid-template-columns: 1fr; gap: 56px; } .gda-mobilier__content { padding-left: 0; } .gda-mobilier__gallery { max-width: 580px; } }

@media (max-width: 640px) { .gda-mobilier { padding: 72px 20px; } .gda-mobilier__gallery { grid-template-rows: 200px 180px; gap: 10px; } }

/*--------------------------------------------------------------------------------------------REALISATIONS----------------------------------------------------------------------------------------*/
/* ============================================= SECTION : realisations-gda Isolée — n'affecte aucun autre bloc du site ============================================= */
.realisations-gda { background: #d8dac5; padding: 100px 40px 90px; text-align: center; overflow: hidden; }

.realisations-gda__header { max-width: 700px; margin: 0 auto 52px; }

.realisations-gda__eyebrow { display: inline-block; margin-bottom: 16px; color: #90a76d; font-family: 'Dancing Script'; font-size: 25px; font-weight: 700; letter-spacing: 0.28em; }

.realisations-gda__title { margin: 0; color: #646e56; font-size: clamp(2.6rem, 5vw, 4.8rem); font-weight: 700; line-height: 1.02; letter-spacing: -0.04em; }

/* --- Filtres --- */
.realisations-gda__filters { display: flex; justify-content: center; gap: 10px; flex-wrap: wrap; margin-bottom: 52px; }

.realisations-gda__filters button { background: transparent; border: 1.5px solid rgba(100, 110, 86, 0.4); color: #646e56; padding: 10px 22px; font-size: 11px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; cursor: pointer; border-radius: 12px; transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease; }

.realisations-gda__filters button:hover { background: rgba(100, 110, 86, 0.12); border-color: #646e56; }

.realisations-gda__filters button.active { background: #646e56; border-color: #646e56; color: #d8dac5; }

/* --- Grille --- */
.realisations-gda__grid { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }

/* --- Item --- */
.realisations-gda__item { position: relative; aspect-ratio: 1 / 1; overflow: hidden; cursor: pointer; background: #c5c8b8; }

.realisations-gda__item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.65s cubic-bezier(0.25, 0.46, 0.45, 0.94), filter 0.45s ease; }

.realisations-gda__overlay { position: absolute; inset: 0; background: rgba(100, 110, 86, 0.82); display: flex; align-items: flex-end; padding: 22px 24px; opacity: 0; transition: opacity 0.35s ease; }

.realisations-gda__cat { display: inline-block; background: #c2e35a; color: #646e56; font-size: 10px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; padding: 6px 14px; transform: translateY(8px); transition: transform 0.35s ease; }

.realisations-gda__item:hover img { transform: scale(1.06); filter: brightness(0.82); }

.realisations-gda__item:hover .realisations-gda__overlay { opacity: 1; }

.realisations-gda__item:hover .realisations-gda__cat { transform: translateY(0); }

.realisations-gda__item.is-hidden { display: none; }

.realisations-gda__item.is-visible { animation: gdaFadeIn 0.4s ease forwards; }

@keyframes gdaFadeIn { from { opacity: 0;
    transform: scale(0.97); }
  to { opacity: 1;
    transform: scale(1); } }

/* --- Responsive --- */
@media (max-width: 991px) { .realisations-gda { padding: 80px 24px 70px; } .realisations-gda__grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } .realisations-gda__filters { gap: 8px; } }

@media (max-width: 580px) { .realisations-gda { padding: 64px 16px 56px; } .realisations-gda__header { margin-bottom: 36px; } .realisations-gda__filters button { padding: 9px 14px; font-size: 10px; } .realisations-gda__grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } }

/* SECTION : fournisseurs-gda  Style : Épuré, Moderne, Minimaliste */
.fournisseurs-gda { position: relative; padding: 80px 40px; overflow: hidden; }

.fournisseurs-gda * { box-sizing: border-box; margin: 0; padding: 0; }

.fournisseurs-gda__container { max-width: 1200px; margin: 0 auto; text-align: center; }

.fournisseurs-gda__intro { margin-bottom: 60px; }

.fournisseurs-gda__subtitle { font-size: 25px; font-weight: 700; font-family: 'Dancing Script'; letter-spacing: 0.2em; color: #90a76d; margin-bottom: 12px; display: block; }

.fournisseurs-gda__title { font-size: clamp(1.8rem, 3vw, 2.5rem); color: #3d4830; font-weight: 500; }

.fournisseurs-gda__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; align-items: stretch; }

.fournisseurs-gda__card { background: #fcfcfb; border: 1px solid #90a76d; /* Le contour vert est maintenant permanent */ padding: 50px 40px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-decoration: none; }

.fournisseurs-gda__logo-wrapper { margin-bottom: 24px; display: flex; align-items: center; justify-content: center; }

.fournisseurs-gda__logo-wrapper img { max-width: 200px; height: auto; max-height: 200px; display: block; object-fit: contain; }

/* Responsive */
@media (max-width: 991px) { .fournisseurs-gda { padding: 60px 24px; } .fournisseurs-gda__grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; } }

@media (max-width: 480px) { .fournisseurs-gda__card { padding: 40px 24px; } .fournisseurs-gda__title { font-size: 1.6rem; } }

.defile-images { position: relative; padding: 80px 0; background: #ffffff; overflow: hidden; }

.defile-images::before { content: ''; position: absolute; top: -100px; right: -100px; width: 500px; height: 500px; background: radial-gradient(circle, rgba(91, 189, 30, 0.14), rgba(91, 189, 30, 0.06), transparent 80%); border-radius: 50%; z-index: 1; }

.defile-images::after { content: ''; position: absolute; bottom: -80px; left: -80px; width: 450px; height: 450px; background: radial-gradient(circle, rgba(91, 189, 30, 0.12), rgba(91, 189, 30, 0.04), transparent 80%); border-radius: 50%; z-index: 1; }

.defile-images-gallery { display: flex; gap: 24px; animation: defile-images-scroll 90s linear infinite; position: relative; z-index: 2; }

.defile-images-gallery:hover { animation-play-state: paused; }

.defile-images-item { position: relative; width: 340px; height: 340px; flex-shrink: 0; border-radius: 0px; overflow: hidden; cursor: pointer; transition: transform .35s ease, box-shadow .35s ease; box-shadow: 0 12px 30px rgba(0, 0, 0, 0.1); text-decoration: none; color: inherit; }

.defile-images-item:hover { transform: translateY(-10px); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15); }

.defile-images-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }

.defile-images-item:hover img { transform: scale(1.08); }

.defile-images-item::after { display: none; }

@keyframes defile-images-scroll { 0% { transform: translateX(0); }
  100% { transform: translateX(calc(-364px * 15)); } }

@media (max-width: 768px) { .defile-images { padding: 60px 0; } .defile-images-gallery { gap: 16px; animation-duration: 70s; } .defile-images-item { width: 260px; height: 260px; border-radius: 0px; } @keyframes defile-images-scroll { 0% { transform: translateX(0); }
    100% { transform: translateX(calc(-276px * 15)); } } }

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