.elementor-12 .elementor-element.elementor-element-0cc2487{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-12 .elementor-element.elementor-element-9e470b8{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-12 .elementor-element.elementor-element-7eabedd{--display:flex;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--align-items:center;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-12 .elementor-element.elementor-element-7eabedd:not(.elementor-motion-effects-element-type-background), .elementor-12 .elementor-element.elementor-element-7eabedd > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F0F4F0;}.elementor-12 .elementor-element.elementor-element-7eabedd.e-con{--align-self:center;}.elementor-12 .elementor-element.elementor-element-9de55a5.elementor-element{--align-self:center;}.elementor-12 .elementor-element.elementor-element-1ae358e{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-12 .elementor-element.elementor-element-657e6b6{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-12 .elementor-element.elementor-element-adebeec{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-12 .elementor-element.elementor-element-6197ffc{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}@media(min-width:768px){.elementor-12 .elementor-element.elementor-element-9e470b8{--content-width:1440px;}.elementor-12 .elementor-element.elementor-element-1ae358e{--content-width:1440px;}}/* Start custom CSS for container, class: .elementor-element-0cc2487 */*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0 }
    :root { --green: #3d8a4e; --green-dark: #2e6b3c; --green-light: #6cbf6c; --green-pale: #e8f5ec; --green-bg: #d4edda; --orange: #e07a39; --orange-hover: #c96428; --dark: #1c2b1c; --gray: #5a6a5a; --light-gray: #f0f4f0; --white: #fff; --border: #e0e8e0; --shadow: 0 4px 24px rgba(30, 60, 30, .10); }
    html { scroll-behavior: smooth }
    body { font-family: 'Open Sans', sans-serif; color: var(--dark); background: var(--white); overflow-x: hidden; font-size: 15px; line-height: 1.7 }
    a { text-decoration: none; color: inherit }
    img { display: block; max-width: 100% }
        /* HERO */
    .hero {  padding: 90px 40px 60px; background: linear-gradient(180deg, #e8f5ec 0%, #ffffff 100%); text-align: center; }
    .hero-top { max-width: 800px; margin: 0 auto; }
    .hero-title { font-family: 'Playfair Display', serif; font-size: clamp(36px, 5vw, 56px); line-height: 1.1; color: var(--green-dark); font-weight: 900; margin: 15px 0 20px }
    .hero-title span { color: var(--orange); }
    .hero-desc { font-size: 16px; color: var(--dark); max-width: 600px; margin: 0 auto 30px; line-height: 1.7; font-weight: 600 }
    .hero-gallery { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; align-items: center; max-width: 1300px; margin: 50px auto 0; padding: 0 20px }
    .hg-item { border-radius: 24px; overflow: hidden; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08); width: 100%; position: relative; animation: floatHero 5s ease-in-out infinite; }
    @keyframes floatHero { 0%, 100% { top: 0; } 50% { top: -15px; } }
    .hg-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s }
    .hg-item:hover img { transform: scale(1.05) }
    .hg-1 { height: 360px; transform: translateY(-20px); animation-delay: 0s; }
    .hg-2 { height: 220px; transform: translateY(30px); background: var(--green-pale); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; color: var(--green-dark); border: 2px solid rgba(108, 191, 108, .2); box-shadow: none; animation-delay: 1.2s; }
    .hg-2 strong { font-size: 36px; font-weight: 900; line-height: 1; margin-bottom: 5px; color: var(--green); font-family: 'Playfair Display', serif }
    .hg-2 span { font-size: 13px; font-weight: 700; line-height: 1.4; padding: 0 15px }
    .hg-3 { height: 220px; transform: translateY(30px); animation-delay: 2.4s; }
    .hg-4 { height: 380px; transform: translateY(-30px); animation-delay: 0.6s; }
    .hg-5 { height: 320px; transform: translateY(-10px); animation-delay: 1.8s; }
    .btn-orange { background: var(--orange); color: var(--white); padding: 13px 30px; border-radius: 50px; font-weight: 700; font-size: 15px; box-shadow: 0 8px 24px rgba(224, 122, 57, .3); transition: all .3s; display: inline-block }
    .btn-orange:hover { background: var(--orange-hover); transform: translateY(-2px) }
    .btn-outline { border: 2px solid var(--green); color: var(--green); padding: 11px 28px; border-radius: 50px; font-weight: 700; font-size: 15px; transition: all .3s; display: inline-block }
    .btn-outline:hover { background: var(--green); color: var(--white) }/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-9e470b8 *//* PRESTATIONS */
    .prestations { background: var(--white); padding: 80px 60px }
    .prestations-head { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: flex-start; margin-bottom: 50px; }
    .prestations-head-right { padding-top: 10px; }
    .prestations-head-right p { font-size: 15px; color: var(--gray); line-height: 1.8 }

    /* slider */
    .slider-wrap { position: relative; padding: 0 56px }
    .slider-track { display: flex; gap: 24px; overflow-x: hidden; padding-bottom: 10px; scrollbar-width: none; -ms-overflow-style: none; }
    .slider-track::-webkit-scrollbar { display: none; }
    .prest-card { position: relative; border-radius: 18px; overflow: visible; cursor: pointer; flex: 0 0 calc(33.3333% - 16px); scroll-snap-align: start; }
    .prest-card-img { height: 380px; border-radius: 18px; overflow: hidden; }
    .prest-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; display: block; }
    .prest-card:hover .prest-card-img img { transform: scale(1.05) }
    .prest-card-body { position: relative; background: var(--white); border-radius: 16px; padding: 22px 24px 24px; margin: -70px 16px 0; box-shadow: 0 6px 4px rgb(0 0 0 / 3%); z-index: 2; }
    .prest-card-body h3 { font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 700; color: var(--green); margin-bottom: 10px; }
    .prest-card-body p { font-size: 13.5px; color: var(--dark); line-height: 1.7 }
    .prest-card-body p strong { font-weight: 700 }
    .slider-arrow { position: absolute; top: 45%; transform: translateY(-50%); width: 46px; height: 46px; border-radius: 50%; background: var(--white); border: 1.5px solid var(--border); box-shadow: 0 4px 16px rgba(0, 0, 0, .12); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .2s, border-color .2s; z-index: 5; }
    .slider-arrow:hover { background: var(--green); border-color: var(--green) }
    .slider-arrow:hover svg polyline { stroke: var(--white) }
    .slider-arrow.prev { left: 0 }
    .slider-arrow.next { right: 0 }/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-7eabedd *//* CATALOGUE */
    .catalogue { padding: 80px 60px; background: var(--light-gray); text-align: center }
    .cat-head { margin-bottom: 50px }
    .cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
    .plant-card { background: var(--white); border-radius: 18px; overflow: hidden; box-shadow: var(--shadow); text-align: left; position: relative; display: flex; flex-direction: column; transition: transform .3s }
    .plant-card:hover { transform: translateY(-8px) }
    .plant-img { height: 220px; position: relative; overflow: hidden }
    .plant-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s }
    .plant-card:hover .plant-img img { transform: scale(1.05) }
    .plant-tag { position: absolute; top: 16px; left: 16px; background: var(--orange); color: var(--white); font-size: 11px; font-weight: 700; padding: 6px 12px; border-radius: 20px; letter-spacing: 1px; text-transform: uppercase; z-index: 2 }
    .plant-body { padding: 24px; flex-grow: 1; display: flex; flex-direction: column }
    .plant-body h4 { font-family: 'Playfair Display', serif; font-weight: 700; font-size: 19px; margin-bottom: 8px; color: var(--dark); line-height: 1.3 }
    .plant-price { font-size: 15px; color: var(--green); font-weight: 600; margin-bottom: 4px }
    .plant-price strong { font-weight: 700; font-size: 22px }
    .plant-min { font-size: 13px; color: var(--gray); margin-bottom: 20px; padding-bottom: 18px; border-bottom: 1px solid var(--border) }
    .plant-btn { text-align: center; width: 100%; padding: 12px; font-size: 14.5px; border: 2px solid var(--green); margin-top: auto; display: block }
    .plant-btn:hover { background: var(--green); color: var(--white) }/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-1ae358e *//* POINTS FORTS */
    .points { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; padding: 80px 60px; background: var(--white) }
    .points-head { grid-column: 1/-1; margin-bottom: 10px }
    .points-head .section-body { max-width: 520px }
    .point-card { background: var(--white); border: 1px solid var(--border); border-radius: 18px; padding: 32px 26px; box-shadow: var(--shadow); transition: transform .3s }
    .point-card:hover { transform: translateY(-5px) }
    .point-card-icon { width: 56px; height: 56px; border-radius: 14px; background: var(--green-pale); display: flex; align-items: center; justify-content: center; margin-bottom: 18px }
    .point-card h4 { font-weight: 700; font-size: 16px; margin-bottom: 8px }
    .point-card p { font-size: 13.5px; color: var(--gray); line-height: 1.7 }/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-657e6b6 *//* POINTS FORTS */
    .points { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; padding: 80px 60px; background: var(--white) }
    .points-head { grid-column: 1/-1; margin-bottom: 10px }
    .points-head .section-body { max-width: 520px }
    .point-card { background: var(--white); border: 1px solid var(--border); border-radius: 18px; padding: 32px 26px; box-shadow: var(--shadow); transition: transform .3s }
    .point-card:hover { transform: translateY(-5px) }
    .point-card-icon { width: 56px; height: 56px; border-radius: 14px; background: var(--green-pale); display: flex; align-items: center; justify-content: center; margin-bottom: 18px }
    .point-card h4 { font-weight: 700; font-size: 16px; margin-bottom: 8px }
    .point-card p { font-size: 13.5px; color: var(--gray); line-height: 1.7 }
    
    
    
        /* REALISATIONS */
    .realisations { padding: 80px 60px; background: var(--light-gray); position: relative; overflow: hidden }
    .real-watermark { font-family: 'Playfair Display', serif; font-size: clamp(70px, 11vw, 140px); font-weight: 900; color: rgba(61, 138, 78, .055); line-height: 1; text-align: center; margin-bottom: -55px; pointer-events: none; user-select: none }
    .real-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 36px }
    .gallery { display: grid; grid-template-columns: 1fr 1fr 1fr; grid-template-rows: 380px 380px; gap: 14px }
    .gallery-item { border-radius: 14px; overflow: hidden; position: relative; cursor: pointer }
    .gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s }
    .gallery-item:hover img { transform: scale(1.07) }
    .gallery-item::after { content: ''; position: absolute; inset: 0; background: rgba(61, 138, 78, 0); transition: background .3s }
    .gallery-item:hover::after { background: rgba(61, 138, 78, .22) }
    .gallery-wide { grid-column: span 2 }
    .real-cta { text-align: center; margin-top: 32px }/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-adebeec *//* PARTENAIRES */
    .partenaires { padding: 80px 60px; text-align: center; background: var(--white) }
    .part-watermark { font-family: 'Playfair Display', serif; font-size: clamp(60px, 9vw, 110px); font-weight: 900; color: rgba(61, 138, 78, .05); margin-bottom: -35px; line-height: 1 }
    .part-logos { display: flex; justify-content: center; align-items: center; gap: 50px; flex-wrap: wrap; margin-top: 40px }
    .part-logo { background: var(--green-pale); border-radius: 12px; padding: 18px 32px; font-weight: 700; color: var(--green); font-size: 14px; border: 1.5px solid var(--green-bg); display: flex; align-items: center; gap: 10px; transition: background .2s }
    .part-logo:hover { background: var(--green); color: var(--white) }
    .part-logo svg { flex-shrink: 0 }

    /* PETITS PLUS */
    .petits { padding: 80px 60px; background: var(--light-gray); text-align: center }
    .petits .section-body { max-width: 560px; margin: 0 auto 50px; text-align: center }
    .petits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; max-width: 900px; margin: 0 auto }
    .petits-card { background: var(--white); border-radius: 18px; padding: 36px 26px; box-shadow: var(--shadow); transition: transform .3s; text-align: center }
    .petits-card:hover { transform: translateY(-5px) }
    .petits-icon { width: 64px; height: 64px; border-radius: 50%; background: var(--green-pale); display: flex; align-items: center; justify-content: center; margin: 0 auto 18px }
    .petits-card h4 { font-size: 17px; font-weight: 700; margin-bottom: 10px }
    .petits-card p { font-size: 13.5px; color: var(--gray); line-height: 1.7 }

    /* AVIS */
    .avis { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: center; padding: 80px 60px; background: linear-gradient(140deg, var(--green-pale), var(--green-bg)) }
    .avis-text .section-title em { font-style: normal; color: var(--orange) }
    .avis-text .section-body { margin-bottom: 28px }
    .avis-mock { background: var(--white); border-radius: 20px; padding: 26px; box-shadow: 0 20px 50px rgba(0, 0, 0, .1) }
    .review { padding-bottom: 18px; margin-bottom: 18px; border-bottom: 1px solid #f0f0f0 }
    .review:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0 }
    .review-head { display: flex; align-items: center; gap: 12px; margin-bottom: 8px }
    .rev-avatar { width: 38px; height: 38px; border-radius: 50%; background: var(--green); display: flex; align-items: center; justify-content: center; font-weight: 700; color: var(--white); font-size: 14px; flex-shrink: 0 }
    .rev-name { font-weight: 700; font-size: 14px }
    .stars { color: #f4b400; font-size: 13px; letter-spacing: 1px }
    .review p { font-size: 13px; color: var(--gray); line-height: 1.65 }/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-6197ffc *//* CONTACT */
    .contact-section { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; padding: 100px 60px; background: var(--white) }
    .contact-info .section-body { margin-bottom: 24px }
    .contact-box { display: flex; align-items: center; gap: 16px; margin-bottom: 20px }
    .cb-icon { width: 48px; height: 48px; border-radius: 12px; background: var(--green-pale); display: flex; align-items: center; justify-content: center; color: var(--green); flex-shrink: 0 }
    .cb-text h5 { font-size: 15px; color: var(--dark); font-weight: 700; margin-bottom: 4px; }
    .cb-text p { font-size: 14px; color: var(--gray) }
    .contact-form { background: var(--white); padding: 40px; border-radius: 24px; box-shadow: 0 15px 40px rgba(0, 0, 0, .06); border: 1px solid var(--border) }
    .form-group { margin-bottom: 20px }
    .form-label { display: block; font-size: 13.5px; font-weight: 700; margin-bottom: 8px; color: var(--dark); font-family: 'Open Sans', sans-serif }
    .form-input { width: 100%; padding: 14px 18px; border: 1px solid #dcdcdc; border-radius: 12px; font-family: inherit; font-size: 14.5px; color: var(--dark); transition: border-color .3s }
    .form-input:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px rgba(61, 138, 78, .1) }
    textarea.form-input { height: 120px; resize: vertical }
    .contact-form .btn-orange { width: 100%; border: none; cursor: pointer; font-family: inherit; padding: 16px; font-size: 16px; }/* End custom CSS */