@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: "Montserrat", 'sans-serif';
    font-size: 16px;
    color: #000000;
    line-height: 1.5;
    background: #FFFFFF;
}

.w-100 {
    width: 100% !important;
}

.container {
    max-width: 1250px;
    margin: 0 auto;
}

p {
    font-weight: 400;
    padding-bottom: 10px;
}

a {
    text-decoration: none;
    color: inherit;
}

/* Alignement du texte */
.text-left {
    text-align: left !important;
}

.text-center {
    text-align: center !important;
}

.text-right {
    text-align: right !important;
}

.text-justify {
    text-align: justify !important;
}

/* ==== PADDING TOP 2px to 100px ==== */
.pt-2 {
    padding-top: 2px;
}

.pt-4 {
    padding-top: 4px;
}

.pt-6 {
    padding-top: 6px;
}

.pt-8 {
    padding-top: 8px;
}

.pt-10 {
    padding-top: 10px;
}

.pt-12 {
    padding-top: 12px;
}

.pt-14 {
    padding-top: 14px;
}

.pt-16 {
    padding-top: 16px;
}

.pt-18 {
    padding-top: 18px;
}

.pt-20 {
    padding-top: 20px;
}

.pt-22 {
    padding-top: 22px;
}

.pt-24 {
    padding-top: 24px;
}

.pt-26 {
    padding-top: 26px;
}

.pt-28 {
    padding-top: 28px;
}

.pt-30 {
    padding-top: 30px;
}

.pt-32 {
    padding-top: 32px;
}

.pt-34 {
    padding-top: 34px;
}

.pt-36 {
    padding-top: 36px;
}

.pt-38 {
    padding-top: 38px;
}

.pt-40 {
    padding-top: 40px;
}

.pt-42 {
    padding-top: 42px;
}

.pt-44 {
    padding-top: 44px;
}

.pt-46 {
    padding-top: 46px;
}

.pt-48 {
    padding-top: 48px;
}

.pt-50 {
    padding-top: 50px;
}

.pt-52 {
    padding-top: 52px;
}

.pt-54 {
    padding-top: 54px;
}

.pt-56 {
    padding-top: 56px;
}

.pt-58 {
    padding-top: 58px;
}

.pt-60 {
    padding-top: 60px;
}

.pt-62 {
    padding-top: 62px;
}

.pt-64 {
    padding-top: 64px;
}

.pt-66 {
    padding-top: 66px;
}

.pt-68 {
    padding-top: 68px;
}

.pt-70 {
    padding-top: 70px;
}

.pt-72 {
    padding-top: 72px;
}

.pt-74 {
    padding-top: 74px;
}

.pt-76 {
    padding-top: 76px;
}

.pt-78 {
    padding-top: 78px;
}

.pt-80 {
    padding-top: 80px;
}

.pt-82 {
    padding-top: 82px;
}

.pt-84 {
    padding-top: 84px;
}

.pt-86 {
    padding-top: 86px;
}

.pt-88 {
    padding-top: 88px;
}

.pt-90 {
    padding-top: 90px;
}

.pt-92 {
    padding-top: 92px;
}

.pt-94 {
    padding-top: 94px;
}

.pt-96 {
    padding-top: 96px;
}

.pt-98 {
    padding-top: 98px;
}

.pt-100 {
    padding-top: 100px;
}

.pt-102 {
    padding-top: 102px;
}

.pt-104 {
    padding-top: 104px;
}

.pt-106 {
    padding-top: 106px;
}

.pt-108 {
    padding-top: 108px;
}

.pt-110 {
    padding-top: 110px;
}

.pt-112 {
    padding-top: 112px;
}

.pt-114 {
    padding-top: 114px;
}

.pt-116 {
    padding-top: 116px;
}

.pt-118 {
    padding-top: 118px;
}

.pt-120 {
    padding-top: 120px;
}

.pt-122 {
    padding-top: 122px;
}

.pt-124 {
    padding-top: 124px;
}

.pt-126 {
    padding-top: 126px;
}

.pt-128 {
    padding-top: 128px;
}

.pt-130 {
    padding-top: 130px;
}

.pt-132 {
    padding-top: 132px;
}

.pt-134 {
    padding-top: 134px;
}

.pt-136 {
    padding-top: 136px;
}

.pt-138 {
    padding-top: 138px;
}

.pt-140 {
    padding-top: 140px;
}

.pt-142 {
    padding-top: 142px;
}

.pt-144 {
    padding-top: 144px;
}

.pt-146 {
    padding-top: 146px;
}

.pt-148 {
    padding-top: 148px;
}

.pt-150 {
    padding-top: 150px;
}

.pt-152 {
    padding-top: 152px;
}

.pt-154 {
    padding-top: 154px;
}

.pt-156 {
    padding-top: 156px;
}

.pt-158 {
    padding-top: 158px;
}

.pt-160 {
    padding-top: 160px;
}

.pt-162 {
    padding-top: 162px;
}

.pt-164 {
    padding-top: 164px;
}

.pt-166 {
    padding-top: 166px;
}

.pt-168 {
    padding-top: 168px;
}

.pt-170 {
    padding-top: 170px;
}

.pt-172 {
    padding-top: 172px;
}

.pt-174 {
    padding-top: 174px;
}

.pt-176 {
    padding-top: 176px;
}

.pt-178 {
    padding-top: 178px;
}

.pt-180 {
    padding-top: 180px;
}

.pt-182 {
    padding-top: 182px;
}

.pt-184 {
    padding-top: 184px;
}

.pt-186 {
    padding-top: 186px;
}

.pt-188 {
    padding-top: 188px;
}

.pt-190 {
    padding-top: 190px;
}

.pt-192 {
    padding-top: 192px;
}

.pt-194 {
    padding-top: 194px;
}

.pt-196 {
    padding-top: 196px;
}

.pt-198 {
    padding-top: 198px;
}

.pt-200 {
    padding-top: 200px;
}

/* ==== PADDING BOTTOM 2px to 100px ==== */
.pb-2 {
    padding-bottom: 2px;
}

.pb-4 {
    padding-bottom: 4px;
}

.pb-6 {
    padding-bottom: 6px;
}

.pb-8 {
    padding-bottom: 8px;
}

.pb-10 {
    padding-bottom: 10px;
}

.pb-12 {
    padding-bottom: 12px;
}

.pb-14 {
    padding-bottom: 14px;
}

.pb-16 {
    padding-bottom: 16px;
}

.pb-18 {
    padding-bottom: 18px;
}

.pb-20 {
    padding-bottom: 20px;
}

.pb-22 {
    padding-bottom: 22px;
}

.pb-24 {
    padding-bottom: 24px;
}

.pb-26 {
    padding-bottom: 26px;
}

.pb-28 {
    padding-bottom: 28px;
}

.pb-30 {
    padding-bottom: 30px;
}

.pb-32 {
    padding-bottom: 32px;
}

.pb-34 {
    padding-bottom: 34px;
}

.pb-36 {
    padding-bottom: 36px;
}

.pb-38 {
    padding-bottom: 38px;
}

.pb-40 {
    padding-bottom: 40px;
}

.pb-42 {
    padding-bottom: 42px;
}

.pb-44 {
    padding-bottom: 44px;
}

.pb-46 {
    padding-bottom: 46px;
}

.pb-48 {
    padding-bottom: 48px;
}

.pb-50 {
    padding-bottom: 50px;
}

.pb-52 {
    padding-bottom: 52px;
}

.pb-54 {
    padding-bottom: 54px;
}

.pb-56 {
    padding-bottom: 56px;
}

.pb-58 {
    padding-bottom: 58px;
}

.pb-60 {
    padding-bottom: 60px;
}

.pb-62 {
    padding-bottom: 62px;
}

.pb-64 {
    padding-bottom: 64px;
}

.pb-66 {
    padding-bottom: 66px;
}

.pb-68 {
    padding-bottom: 68px;
}

.pb-70 {
    padding-bottom: 70px;
}

.pb-72 {
    padding-bottom: 72px;
}

.pb-74 {
    padding-bottom: 74px;
}

.pb-76 {
    padding-bottom: 76px;
}

.pb-78 {
    padding-bottom: 78px;
}

.pb-80 {
    padding-bottom: 80px;
}

.pb-82 {
    padding-bottom: 82px;
}

.pb-84 {
    padding-bottom: 84px;
}

.pb-86 {
    padding-bottom: 86px;
}

.pb-88 {
    padding-bottom: 88px;
}

.pb-90 {
    padding-bottom: 90px;
}

.pb-92 {
    padding-bottom: 92px;
}

.pb-94 {
    padding-bottom: 94px;
}

.pb-96 {
    padding-bottom: 96px;
}

.pb-98 {
    padding-bottom: 98px;
}

.pb-100 {
    padding-bottom: 100px;
}

.pb-102 {
    padding-bottom: 102px;
}

.pb-104 {
    padding-bottom: 104px;
}

.pb-106 {
    padding-bottom: 106px;
}

.pb-108 {
    padding-bottom: 108px;
}

.pb-110 {
    padding-bottom: 110px;
}

.pb-112 {
    padding-bottom: 112px;
}

.pb-114 {
    padding-bottom: 114px;
}

.pb-116 {
    padding-bottom: 116px;
}

.pb-118 {
    padding-bottom: 118px;
}

.pb-120 {
    padding-bottom: 120px;
}

.pb-122 {
    padding-bottom: 122px;
}

.pb-124 {
    padding-bottom: 124px;
}

.pb-126 {
    padding-bottom: 126px;
}

.pb-128 {
    padding-bottom: 128px;
}

.pb-130 {
    padding-bottom: 130px;
}

.pb-132 {
    padding-bottom: 132px;
}

.pb-134 {
    padding-bottom: 134px;
}

.pb-136 {
    padding-bottom: 136px;
}

.pb-138 {
    padding-bottom: 138px;
}

.pb-140 {
    padding-bottom: 140px;
}

.pb-142 {
    padding-bottom: 142px;
}

.pb-144 {
    padding-bottom: 144px;
}

.pb-146 {
    padding-bottom: 146px;
}

.pb-148 {
    padding-bottom: 148px;
}

.pb-150 {
    padding-bottom: 150px;
}

.pb-152 {
    padding-bottom: 152px;
}

.pb-154 {
    padding-bottom: 154px;
}

.pb-156 {
    padding-bottom: 156px;
}

.pb-158 {
    padding-bottom: 158px;
}

.pb-160 {
    padding-bottom: 160px;
}

.pb-162 {
    padding-bottom: 162px;
}

.pb-164 {
    padding-bottom: 164px;
}

.pb-166 {
    padding-bottom: 166px;
}

.pb-168 {
    padding-bottom: 168px;
}

.pb-170 {
    padding-bottom: 170px;
}

.pb-172 {
    padding-bottom: 172px;
}

.pb-174 {
    padding-bottom: 174px;
}

.pb-176 {
    padding-bottom: 176px;
}

.pb-178 {
    padding-bottom: 178px;
}

.pb-180 {
    padding-bottom: 180px;
}

.pb-182 {
    padding-bottom: 182px;
}

.pb-184 {
    padding-bottom: 184px;
}

.pb-186 {
    padding-bottom: 186px;
}

.pb-188 {
    padding-bottom: 188px;
}

.pb-190 {
    padding-bottom: 190px;
}

.pb-192 {
    padding-bottom: 192px;
}

.pb-194 {
    padding-bottom: 194px;
}

.pb-196 {
    padding-bottom: 196px;
}

.pb-198 {
    padding-bottom: 198px;
}

.pb-200 {
    padding-bottom: 200px;
}

/* ==== MARGIN TOP 2px to 100px ==== */
.mt-2 {
    margin-top: 2px;
}

.mt-4 {
    margin-top: 4px;
}

.mt-6 {
    margin-top: 6px;
}

.mt-8 {
    margin-top: 8px;
}

.mt-10 {
    margin-top: 10px;
}

.mt-12 {
    margin-top: 12px;
}

.mt-14 {
    margin-top: 14px;
}

.mt-16 {
    margin-top: 16px;
}

.mt-18 {
    margin-top: 18px;
}

.mt-20 {
    margin-top: 20px;
}

.mt-22 {
    margin-top: 22px;
}

.mt-24 {
    margin-top: 24px;
}

.mt-26 {
    margin-top: 26px;
}

.mt-28 {
    margin-top: 28px;
}

.mt-30 {
    margin-top: 30px;
}

.mt-32 {
    margin-top: 32px;
}

.mt-34 {
    margin-top: 34px;
}

.mt-36 {
    margin-top: 36px;
}

.mt-38 {
    margin-top: 38px;
}

.mt-40 {
    margin-top: 40px;
}

.mt-42 {
    margin-top: 42px;
}

.mt-44 {
    margin-top: 44px;
}

.mt-46 {
    margin-top: 46px;
}

.mt-48 {
    margin-top: 48px;
}

.mt-50 {
    margin-top: 50px;
}

.mt-52 {
    margin-top: 52px;
}

.mt-54 {
    margin-top: 54px;
}

.mt-56 {
    margin-top: 56px;
}

.mt-58 {
    margin-top: 58px;
}

.mt-60 {
    margin-top: 60px;
}

.mt-62 {
    margin-top: 62px;
}

.mt-64 {
    margin-top: 64px;
}

.mt-66 {
    margin-top: 66px;
}

.mt-68 {
    margin-top: 68px;
}

.mt-70 {
    margin-top: 70px;
}

.mt-72 {
    margin-top: 72px;
}

.mt-74 {
    margin-top: 74px;
}

.mt-76 {
    margin-top: 76px;
}

.mt-78 {
    margin-top: 78px;
}

.mt-80 {
    margin-top: 80px;
}

.mt-82 {
    margin-top: 82px;
}

.mt-84 {
    margin-top: 84px;
}

.mt-86 {
    margin-top: 86px;
}

.mt-88 {
    margin-top: 88px;
}

.mt-90 {
    margin-top: 90px;
}

.mt-92 {
    margin-top: 92px;
}

.mt-94 {
    margin-top: 94px;
}

.mt-96 {
    margin-top: 96px;
}

.mt-98 {
    margin-top: 98px;
}

.mt-100 {
    margin-top: 100px;
}

.mt-102 {
    margin-top: 102px;
}

.mt-104 {
    margin-top: 104px;
}

.mt-106 {
    margin-top: 106px;
}

.mt-108 {
    margin-top: 108px;
}

.mt-110 {
    margin-top: 110px;
}

.mt-112 {
    margin-top: 112px;
}

.mt-114 {
    margin-top: 114px;
}

.mt-116 {
    margin-top: 116px;
}

.mt-118 {
    margin-top: 118px;
}

.mt-120 {
    margin-top: 120px;
}

.mt-122 {
    margin-top: 122px;
}

.mt-124 {
    margin-top: 124px;
}

.mt-126 {
    margin-top: 126px;
}

.mt-128 {
    margin-top: 128px;
}

.mt-130 {
    margin-top: 130px;
}

.mt-132 {
    margin-top: 132px;
}

.mt-134 {
    margin-top: 134px;
}

.mt-136 {
    margin-top: 136px;
}

.mt-138 {
    margin-top: 138px;
}

.mt-140 {
    margin-top: 140px;
}

.mt-142 {
    margin-top: 142px;
}

.mt-144 {
    margin-top: 144px;
}

.mt-146 {
    margin-top: 146px;
}

.mt-148 {
    margin-top: 148px;
}

.mt-150 {
    margin-top: 150px;
}

.mt-152 {
    margin-top: 152px;
}

.mt-154 {
    margin-top: 154px;
}

.mt-156 {
    margin-top: 156px;
}

.mt-158 {
    margin-top: 158px;
}

.mt-160 {
    margin-top: 160px;
}

.mt-162 {
    margin-top: 162px;
}

.mt-164 {
    margin-top: 164px;
}

.mt-166 {
    margin-top: 166px;
}

.mt-168 {
    margin-top: 168px;
}

.mt-170 {
    margin-top: 170px;
}

.mt-172 {
    margin-top: 172px;
}

.mt-174 {
    margin-top: 174px;
}

.mt-176 {
    margin-top: 176px;
}

.mt-178 {
    margin-top: 178px;
}

.mt-180 {
    margin-top: 180px;
}

.mt-182 {
    margin-top: 182px;
}

.mt-184 {
    margin-top: 184px;
}

.mt-186 {
    margin-top: 186px;
}

.mt-188 {
    margin-top: 188px;
}

.mt-190 {
    margin-top: 190px;
}

.mt-192 {
    margin-top: 192px;
}

.mt-194 {
    margin-top: 194px;
}

.mt-196 {
    margin-top: 196px;
}

.mt-198 {
    margin-top: 198px;
}

.mt-200 {
    margin-top: 200px;
}

/* ==== MARGIN BOTTOM 2px to 100px ==== */
.mb-2 {
    margin-bottom: 2px;
}

.mb-4 {
    margin-bottom: 4px;
}

.mb-6 {
    margin-bottom: 6px;
}

.mb-8 {
    margin-bottom: 8px;
}

.mb-10 {
    margin-bottom: 10px;
}

.mb-12 {
    margin-bottom: 12px;
}

.mb-14 {
    margin-bottom: 14px;
}

.mb-16 {
    margin-bottom: 16px;
}

.mb-18 {
    margin-bottom: 18px;
}

.mb-20 {
    margin-bottom: 20px;
}

.mb-22 {
    margin-bottom: 22px;
}

.mb-24 {
    margin-bottom: 24px;
}

.mb-26 {
    margin-bottom: 26px;
}

.mb-28 {
    margin-bottom: 28px;
}

.mb-30 {
    margin-bottom: 30px;
}

.mb-32 {
    margin-bottom: 32px;
}

.mb-34 {
    margin-bottom: 34px;
}

.mb-36 {
    margin-bottom: 36px;
}

.mb-38 {
    margin-bottom: 38px;
}

.mb-40 {
    margin-bottom: 40px;
}

.mb-42 {
    margin-bottom: 42px;
}

.mb-44 {
    margin-bottom: 44px;
}

.mb-46 {
    margin-bottom: 46px;
}

.mb-48 {
    margin-bottom: 48px;
}

.mb-50 {
    margin-bottom: 50px;
}

.mb-52 {
    margin-bottom: 52px;
}

.mb-54 {
    margin-bottom: 54px;
}

.mb-56 {
    margin-bottom: 56px;
}

.mb-58 {
    margin-bottom: 58px;
}

.mb-60 {
    margin-bottom: 60px;
}

.mb-62 {
    margin-bottom: 62px;
}

.mb-64 {
    margin-bottom: 64px;
}

.mb-66 {
    margin-bottom: 66px;
}

.mb-68 {
    margin-bottom: 68px;
}

.mb-70 {
    margin-bottom: 70px;
}

.mb-72 {
    margin-bottom: 72px;
}

.mb-74 {
    margin-bottom: 74px;
}

.mb-76 {
    margin-bottom: 76px;
}

.mb-78 {
    margin-bottom: 78px;
}

.mb-80 {
    margin-bottom: 80px;
}

.mb-82 {
    margin-bottom: 82px;
}

.mb-84 {
    margin-bottom: 84px;
}

.mb-86 {
    margin-bottom: 86px;
}

.mb-88 {
    margin-bottom: 88px;
}

.mb-90 {
    margin-bottom: 90px;
}

.mb-92 {
    margin-bottom: 92px;
}

.mb-94 {
    margin-bottom: 94px;
}

.mb-96 {
    margin-bottom: 96px;
}

.mb-98 {
    margin-bottom: 98px;
}

.mb-100 {
    margin-bottom: 100px;
}

.mb-102 {
    margin-bottom: 102px;
}

.mb-104 {
    margin-bottom: 104px;
}

.mb-106 {
    margin-bottom: 106px;
}

.mb-108 {
    margin-bottom: 108px;
}

.mb-110 {
    margin-bottom: 110px;
}

.mb-112 {
    margin-bottom: 112px;
}

.mb-114 {
    margin-bottom: 114px;
}

.mb-116 {
    margin-bottom: 116px;
}

.mb-118 {
    margin-bottom: 118px;
}

.mb-120 {
    margin-bottom: 120px;
}

.mb-122 {
    margin-bottom: 122px;
}

.mb-124 {
    margin-bottom: 124px;
}

.mb-126 {
    margin-bottom: 126px;
}

.mb-128 {
    margin-bottom: 128px;
}

.mb-130 {
    margin-bottom: 130px;
}

.mb-132 {
    margin-bottom: 132px;
}

.mb-134 {
    margin-bottom: 134px;
}

.mb-136 {
    margin-bottom: 136px;
}

.mb-138 {
    margin-bottom: 138px;
}

.mb-140 {
    margin-bottom: 140px;
}

.mb-142 {
    margin-bottom: 142px;
}

.mb-144 {
    margin-bottom: 144px;
}

.mb-146 {
    margin-bottom: 146px;
}

.mb-148 {
    margin-bottom: 148px;
}

.mb-150 {
    margin-bottom: 150px;
}

.mb-152 {
    margin-bottom: 152px;
}

.mb-154 {
    margin-bottom: 154px;
}

.mb-156 {
    margin-bottom: 156px;
}

.mb-158 {
    margin-bottom: 158px;
}

.mb-160 {
    margin-bottom: 160px;
}

.mb-162 {
    margin-bottom: 162px;
}

.mb-164 {
    margin-bottom: 164px;
}

.mb-166 {
    margin-bottom: 166px;
}

.mb-168 {
    margin-bottom: 168px;
}

.mb-170 {
    margin-bottom: 170px;
}

.mb-172 {
    margin-bottom: 172px;
}

.mb-174 {
    margin-bottom: 174px;
}

.mb-176 {
    margin-bottom: 176px;
}

.mb-178 {
    margin-bottom: 178px;
}

.mb-180 {
    margin-bottom: 180px;
}

.mb-182 {
    margin-bottom: 182px;
}

.mb-184 {
    margin-bottom: 184px;
}

.mb-186 {
    margin-bottom: 186px;
}

.mb-188 {
    margin-bottom: 188px;
}

.mb-190 {
    margin-bottom: 190px;
}

.mb-192 {
    margin-bottom: 192px;
}

.mb-194 {
    margin-bottom: 194px;
}

.mb-196 {
    margin-bottom: 196px;
}

.mb-198 {
    margin-bottom: 198px;
}

.mb-200 {
    margin-bottom: 200px;
}

.space-2 {
    height: 2px;
}

.space-4 {
    height: 4px;
}

.space-6 {
    height: 6px;
}

.space-8 {
    height: 8px;
}

.space-10 {
    height: 10px;
}

.space-12 {
    height: 12px;
}

.space-14 {
    height: 14px;
}

.space-16 {
    height: 16px;
}

.space-18 {
    height: 18px;
}

.space-20 {
    height: 20px;
}

.space-22 {
    height: 22px;
}

.space-24 {
    height: 24px;
}

.space-26 {
    height: 26px;
}

.space-28 {
    height: 28px;
}

.space-30 {
    height: 30px;
}

.space-32 {
    height: 32px;
}

.space-34 {
    height: 34px;
}

.space-36 {
    height: 36px;
}

.space-38 {
    height: 38px;
}

.space-40 {
    height: 40px;
}

.space-42 {
    height: 42px;
}

.space-44 {
    height: 44px;
}

.space-46 {
    height: 46px;
}

.space-48 {
    height: 48px;
}

.space-50 {
    height: 50px;
}

.space-52 {
    height: 52px;
}

.space-54 {
    height: 54px;
}

.space-56 {
    height: 56px;
}

.space-58 {
    height: 58px;
}

.space-60 {
    height: 60px;
}

.space-62 {
    height: 62px;
}

.space-64 {
    height: 64px;
}

.space-66 {
    height: 66px;
}

.space-68 {
    height: 68px;
}

.space-70 {
    height: 70px;
}

.space-72 {
    height: 72px;
}

.space-74 {
    height: 74px;
}

.space-76 {
    height: 76px;
}

.space-78 {
    height: 78px;
}

.space-80 {
    height: 80px;
}

.space-82 {
    height: 82px;
}

.space-84 {
    height: 84px;
}

.space-86 {
    height: 86px;
}

.space-88 {
    height: 88px;
}

.space-90 {
    height: 90px;
}

.space-92 {
    height: 92px;
}

.space-94 {
    height: 94px;
}

.space-96 {
    height: 96px;
}

.space-98 {
    height: 98px;
}

.space-100 {
    height: 100px;
}

.space-102 {
    height: 102px;
}

.space-104 {
    height: 104px;
}

.space-106 {
    height: 106px;
}

.space-108 {
    height: 108px;
}

.space-110 {
    height: 110px;
}

.space-112 {
    height: 112px;
}

.space-114 {
    height: 114px;
}

.space-116 {
    height: 116px;
}

.space-118 {
    height: 118px;
}

.space-120 {
    height: 120px;
}

.space-122 {
    height: 122px;
}

.space-124 {
    height: 124px;
}

.space-126 {
    height: 126px;
}

.space-128 {
    height: 128px;
}

.space-130 {
    height: 130px;
}

.space-132 {
    height: 132px;
}

.space-134 {
    height: 134px;
}

.space-136 {
    height: 136px;
}

.space-138 {
    height: 138px;
}

.space-140 {
    height: 140px;
}

.space-142 {
    height: 142px;
}

.space-144 {
    height: 144px;
}

.space-146 {
    height: 146px;
}

.space-148 {
    height: 148px;
}

.space-150 {
    height: 150px;
}

.space-152 {
    height: 152px;
}

.space-154 {
    height: 154px;
}

.space-156 {
    height: 156px;
}

.space-158 {
    height: 158px;
}

.space-160 {
    height: 160px;
}

.space-162 {
    height: 162px;
}

.space-164 {
    height: 164px;
}

.space-166 {
    height: 166px;
}

.space-168 {
    height: 168px;
}

.space-170 {
    height: 170px;
}

.space-172 {
    height: 172px;
}

.space-174 {
    height: 174px;
}

.space-176 {
    height: 176px;
}

.space-178 {
    height: 178px;
}

.space-180 {
    height: 180px;
}

.space-182 {
    height: 182px;
}

.space-184 {
    height: 184px;
}

.space-186 {
    height: 186px;
}

.space-188 {
    height: 188px;
}

.space-190 {
    height: 190px;
}

.space-192 {
    height: 192px;
}

.space-194 {
    height: 194px;
}

.space-196 {
    height: 196px;
}

.space-198 {
    height: 198px;
}

.space-200 {
    height: 200px;
}

.swal2-confirm.my-custom-btn {
    width: 150px;
    padding: 15px;
    color: #702D82;
    text-align: center;
    text-decoration: none;
    padding: 15px 40px;
    border-radius: 41px;
    border: 0.75px solid rgba(255, 255, 255, 0.48);
    background: white;
    font-size: 15px;
    font-style: normal;
    font-weight: 600;
    line-height: 25px;
    letter-spacing: -0.6px;
    font-family: "Montserrat", sans-serif;
    display: inline-block;
    margin-top: 50px;
    transition: all 0.8s ease-in;
}

.swal2-confirm.my-custom-btn:focus {
    outline: none;
}

.calendar-mobile {
    display: none;
}

nav {
    width: 100%;
    position: absolute;
    top: 0;
    z-index: 1000;
    border-bottom: 0.1px solid rgba(255, 255, 255, 0.22);
}

nav .container {
    width: 100%;
    height: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 180px;
}

nav .container img {
    width: 80px;
    height: auto;
}

nav .container .nav-contents {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 40px;
}

nav .container .nav-contents .links {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 30px;
}

nav .container .nav-contents .links a {
    text-decoration: none;
    color: rgba(255, 255, 255, 0.70);
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 500;
    line-height: 25px;
    letter-spacing: -0.45px;
}

nav .container .nav-contents .links a:hover,
nav .container .nav-contents .links a.active {
    color: #FCD22A;
}

nav .container .nav-contents .hr-v {
    width: 1px;
    height: 40px;
    background: rgba(255, 255, 255, 0.35);
}

nav .container .nav-contents .btn-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 15px;
}

.btn-primary {
    color: white;
    text-align: center;
    text-decoration: none;
    padding: 12px 30px;
    border-radius: 40px;
    border: 0.5px solid rgba(255, 255, 255, 0.48);
    background: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 500;
    line-height: 25px;
    letter-spacing: -0.45px;
}

.btn-primary:hover {
    background: #FEF7FF;
    border: 1px solid rgba(68, 19, 80, 0.56);
}

.btn-primary:hover span {
    background-image: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.btn-outlined {
    color: white;
    text-align: center;
    text-decoration: none;
    padding: 12px 30px;
    border-radius: 40px;
    border: 0.5px solid rgba(255, 255, 255, 0.78);
    background: transparent;
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 500;
    line-height: 25px;
    letter-spacing: -0.45px;
}

.btn-outlined:hover {
    background: #FEF7FF;
    border: 1px solid rgba(68, 19, 80, 0.56);
}

.btn-outlined:hover span {
    background-image: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.btn-secondary {
    text-align: center;
    text-decoration: none;
    padding: 12px 30px;
    border-radius: 40px;
    border: 1px solid rgba(68, 19, 80, 0.56);
    background: #FEF7FF;
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 500;
    line-height: 25px;
    letter-spacing: -0.45px;
}

.btn-secondary span {
    background-image: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.btn-secondary:hover {
    border: 0.5px solid rgba(255, 255, 255, 0.48);
    background: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
}

.btn-secondary:hover span {
    color: #FFFFFF;
}

.btn-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 50px;
    height: 50px;
    background-color: transparent;
    border: 0.75px solid rgba(255, 255, 255, 0.48);
    color: white;
    border-radius: 50px;
    cursor: pointer;
    transition: all 0.4s ease-in-out;
    display: none;
}

.btn-icon i {
    font-size: 20px;
}

.hero-section {
    width: 100%;
    min-height: 850px;
    box-sizing: border-box;
    position: relative;
}

.hero-section .img-float {
    position: absolute;
    top: 180px;
    left: 45px;
    z-index: -1;
}

.hero-section .img-float img {
    width: 400px;
    height: auto;
}

.hero-section.slide1 {
    background: url('../images/home/hero-bg-1.webp') center/cover no-repeat;
}

.hero-section.slide2 {
    background: url('../images/home/hero-bg-2.webp') center/cover no-repeat;
}

.hero-section.slide3 {
    background: url('../images/home/hero-bg-3.webp') center/cover no-repeat;
}

.hero-section .container {
    max-width: 1250px;
    margin: auto;
    display: flex;
    align-items: center;
}

.hero-section .container .txt {
    width: 70%;
    margin-top: 370px;
}

.hero-section .container .txt h1 {
    color: #FFF;
    font-family: "Montserrat", sans-serif;
    font-size: 80px;
    font-style: normal;
    font-weight: 700;
    line-height: 70px;
    letter-spacing: -3.2px;
    text-transform: uppercase;
    margin: 0;
    margin-left: 0px;
}

.hero-section .container .txt h1 span {
    color: #FCD22A;
}

.hero-section .container .txt p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 24px;
    font-style: normal;
    font-weight: 500;
    line-height: 25px;
    letter-spacing: -0.72px;
    margin-top: 10px;
}

.hero-section .container .img {
    width: 30%;
    padding-top: 235px;
}

.hero-section .container .img img {
    width: 100%;
    height: 100%;
}

.breadcrumb-section {
    width: 100%;
    height: 700px;
    box-sizing: border-box;
    position: relative;
}

.breadcrumb-section .img-float {
    position: absolute;
    top: 235px;
    left: 95px;
    z-index: 0;
}

.breadcrumb-section .img-float img {
    width: 450px;
    height: auto;
}

.breadcrumb-section.bg-about {
    background: url('../images/about/banner.webp') center/cover no-repeat;
}

.breadcrumb-section.bg-eglises {
    background: url('../images/eglises/banner-eglise.webp') center/cover no-repeat;
}

.breadcrumb-section.bg-evenements {
    background: url('../images/evenements/banner.webp') center/cover no-repeat;
}


.breadcrumb-section.bg-ministeres {
    background: url('../images/ministeres/banner.webp') center/cover no-repeat;
}

.breadcrumb-section.bg-enseignements {
    background: url('../images/enseignements/banner.webp') center/cover no-repeat;
}

.breadcrumb-section.bg-servir {
    background: url('../images/servir/banner-servir.webp') center/cover no-repeat;
}

.breadcrumb-section.bg-contact {
    background: url('../images/contact/banner.webp') center/cover no-repeat;
}


.breadcrumb-section .container .txt {
    padding-top: 450px;
    padding-left: 30px;
}

.breadcrumb-section .container .txt h1 {
    color: #FFF;
    font-family: "Montserrat", sans-serif;
    font-size: 80px;
    font-style: normal;
    font-weight: 700;
    line-height: 70px;
    letter-spacing: -3.2px;
    text-transform: uppercase;
    margin: 0;
    margin-left: 0px;
}

.breadcrumb-section .container .txt p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 22px;
    letter-spacing: -0.72px;
    padding-left: 85px;
}

.breadcrumb-section .container .txt p span {
    font-weight: 300;
    font-style: italic;
    color: #FCD22A;
}

.header-title {
    font-family: "Montserrat", sans-serif;
    font-size: 50px;
    line-height: 55px;
    font-weight: 800;
    letter-spacing: -2px;
    color: #441350;
    text-transform: uppercase;
}

.header-title span {
    color: #DA302D;
}

.mandate-section {
    width: 100%;
    padding: 70px 0;
    background: url('../images/bg/bg-2.webp'), url('../images/bg/bg-2.webp');
    background-position: top, bottom center;
    background-size: cover;
    text-align: center;
    font-family: "Montserrat", sans-serif;
}

.mandate-small {
    font-size: 25px;
    font-weight: 500;
    letter-spacing: -0.64px;
    color: #340D3D;
    margin-bottom: 15px;
}

.mandate-title {
    font-size: 28px;
    font-weight: 600;
    line-height: 30px;
    letter-spacing: -1.12px;
    color: #340D3D;
    margin-bottom: 25px;
}

.mandate-verse {
    color: #441350;
    font-style: italic;
    font-size: 16px;
    font-weight: 500;
    line-height: 22px;
    letter-spacing: -0.48px;
    margin-bottom: 12px;
}

.mandate-ref {
    color: #DA302D;
    font-weight: 500;
    font-size: 22px;
    font-style: italic;
    letter-spacing: -0.33px;
}


.programme {
    min-height: 400px;
    background: linear-gradient(145deg, #441350 0%, #3F01EB 100%);
    margin: 0 auto;
    max-width: 1250px;
    border-radius: 50px;
    padding: 30px;
    background-size: cover;
    background-position: center;
    font-family: "Montserrat", sans-serif;
    color: #fff;
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    margin-top: 100px;
    margin-bottom: 150px;
}

.programme .img {
    width: 40%;
}

.programme .img img {
    width: 90%;
    height: 100%;
}

.programme .txt {
    width: 55%;
    padding-top: 50px;
}

.programme .txt h2 {
    color: white;
}

.programme .txt h2 span {
    color: #FCD22A;
}

.programme .txt .dates {
    padding-top: 50px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.programme .txt .dates .content {
    display: flex;
    align-items: center;
    gap: 15px;
}

.programme .txt .dates .content img {
    width: 35px;
    height: 35px;
}

.programme .txt .dates .content p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 20px;
    font-style: normal;
    font-weight: 600;
    line-height: 30px;
    letter-spacing: -0.8px;
    margin: 0;
}

.calendar-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    justify-content: center;
    align-items: center;
    z-index: 999;
}

.calendar-content {
    padding: 45px;
    border-radius: 12px;
    max-width: 500px;
    width: 90%;
    background: linear-gradient(145deg, #441350 0%, #3F01EB 100%);

}

.calendar-content a {
    display: block;
}

.btn-tertiary {
    cursor: pointer;
}

.programme .close-modal {
    position: absolute;
    top: 15px;
    right: 15px;
    background: transparent;
    border: none;
    color: #fff;
    font-size: 22px;
    cursor: pointer;
    padding: 5px;
    z-index: 1000;
}

body.modal-open {
    overflow: hidden;
}

/* Sous-modal pour le culte du dimanche */
.sub-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    justify-content: center;
    align-items: center;
    z-index: 1000;
}

.sub-modal-content {
    padding: 40px;
    border-radius: 12px;
    max-width: 500px;
    width: 90%;
    background: linear-gradient(145deg, #441350 0%, #3F01EB 100%);
}

.sub-modal-buttons {
    display: flex;
    flex-direction: column;
    gap: 15px;
}



.modal-title {
    color: white;
    font-size: 24px;
    font-weight: 600;
    text-align: center;
    margin-bottom: 20px;
    font-family: "Montserrat", sans-serif;
}

.modal-subtitle {
    color: rgba(255, 255, 255, 0.9);
    font-size: 16px;
    text-align: center;
    margin-bottom: 30px;
    font-family: "Montserrat", sans-serif;
    line-height: 1.5;
}

.back-btn {
    background: transparent;
    border: none;
    color: rgba(255, 255, 255, 0.8);
    font-size: 14px;
    cursor: pointer;
    padding: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
    position: absolute;
    top: 15px;
    left: 15px;
    transition: color 0.3s ease;
}

.back-btn:hover {
    color: white;
}

.close-sub-modal {
    position: absolute;
    top: 15px;
    right: 15px;
    background: transparent;
    border: none;
    color: #fff;
    font-size: 22px;
    cursor: pointer;
    padding: 5px;
    z-index: 1000;
}

.vision {
    background-image: url("../images/home/line-1.png");
    background-repeat: no-repeat;
    background-position: bottom center;
    background-size: 100% auto;
}

.vision .container {
    display: flex;
    gap: 30px;
}

.vision-image {
    width: 50%;
    margin-bottom: -6px;
}

.vision-text {
    width: 50%;
}

.vision-image img {
    margin-top: 20px;
    width: 100%;
    object-fit: cover;
}

.vision-subtitle {
    font-size: 35px;
    font-weight: 700;
    line-height: 36px;
    letter-spacing: -1.4px;
    color: #340D3D;
    margin-bottom: 20px;
}

.vision-text p {
    font-size: 19px;
    font-weight: 400;
    line-height: 28px;
    letter-spacing: -0.57px;
    color: #340D3D;
    margin-bottom: 10px;
}

.btn-vision {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}


.about .container .contents {
    display: flex;
    flex-direction: column;
}

.about .container .contents .content1 {
    display: flex;
    justify-content: space-between;
}

.about .container .contents .content1 .img {
    width: 45%;
}

.about .container .contents .content1 .img p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 22px;
    font-style: italic;
    font-weight: 500;
    line-height: 30px;
    letter-spacing: -0.88px;
    margin-bottom: 10px;
}

.about .container .contents .content1 .img h6 {
    color: #DA302D;
    font-family: "Montserrat", sans-serif;
    font-size: 28px;
    font-style: italic;
    font-weight: 500;
    line-height: 38px;
    letter-spacing: -0.56px;
    margin: 0;
}

.about .container .contents .content1 .img-container {
    position: relative;
}

.about .container .contents .content1 .img img {
    width: 105%;
    height: 70%;
}

.about .container .contents .content1 .img .arrow {
    width: 350px !important;
    height: 300px !important;
    position: absolute;
    top: -100px;
    right: -100px;
}

.about .container .contents .content1 .txt {
    width: 49%;
    padding-top: 15px;
}

.about .container .contents .content1 .txt h5 {
    color: #DA302D;
    font-family: "Montserrat", sans-serif;
    font-size: 26px;
    font-style: normal;
    font-weight: 700;
    line-height: 36px;
    letter-spacing: -0.78px;
}

.about .container .contents .content1 .txt h6 {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 35px;
    letter-spacing: -0.56px;
}

.about .container .contents .content1 .txt p {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.57px;
}

.about .container .contents .content1 .txt p span {
    font-weight: 700;
}

.about .container .contents .content2 {
    display: flex;
    justify-content: space-between;
}

.about .container .contents .content2 .img {
    width: 45%;
}

.about .container .contents .content2 .img img {
    width: 100%;
    height: 100%;
}

.about .container .contents .content2 .txt {
    width: 49%;
}

.about .container .contents .content2 .txt img {
    width: 100%;
    height: 130%;
    object-fit: contain;
}

.about .container .contents .content3 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-top: 50px;
    gap: 50px;
}


.about .container .contents .content3 p {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 500;
    line-height: 30px;
    letter-spacing: -0.76px;
    text-align: center;
    padding: 10px 85px;
    margin: auto;
}

.banner-icc {
    position: relative;
    width: 100%;
    height: auto;
    padding: 100px 0;
    background: url('../images/bg/bg-1.webp');
    background-size: cover;
    background-position: center;
    color: #fff;
    text-align: center;
    font-family: "Montserrat", sans-serif;
}

.banner-icc .container {
    position: relative;
    z-index: 2;
}

.banner-icc h2 {
    font-size: 50px;
    font-weight: 800;
    color: #FCD22A;
    margin-bottom: 20px;
    letter-spacing: -2px;
}

.banner-icc p {
    max-width: 960px;
    margin: 0 auto;
    font-size: 17px;
    line-height: 1.55;
}

.banner-icc p strong {
    font-weight: 700;
    color: #fff;
}

.mission p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 20px;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.6px;
}

.mission .cards-container {
    padding-top: 50px;
}

.mission .cards-container h5 {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 32px;
    font-style: normal;
    font-weight: 700;
    line-height: 42px;
    letter-spacing: -0.64px;
    margin: 0;
}

.mission .cards {
    padding-top: 50px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 30px;
}

.mission .cards .card {
    width: 48.5%;
    min-height: 300px;
    border-radius: 10px;
    border: 0.1px solid #702D82;
    box-sizing: border-box;
    padding: 50px;
    cursor: pointer;
    transition: all 0.3s ease-in;
}

.mission .cards .card:hover {
    background: linear-gradient(118.36deg, #702D82 12.3%, #3F01EB 112.18%);
}

.mission .cards .card:hover h6 {
    color: white;
}

.mission .cards .card:hover span {
    color: #FCD22A;
}

.mission .cards .card:hover p {
    color: white;
}

.mission .cards .card h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 28px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.56px;
    margin-bottom: 20px;
}

.mission .cards .card img {
    width: 60px;
    height: 60px;
    margin-bottom: 30px;
}

.mission .cards .card .card-icon {
    position: relative;
    width: 90px;
    height: 90px;
    margin-bottom: 30px;
}

.mission .cards .card .card-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    position: absolute;
    top: 0;
    left: 0;
    transition: opacity .3s ease;
}

.mission .cards .card .card-icon img.hover {
    opacity: 0;
}

.mission .cards .card:hover .card-icon img.hover {
    opacity: 1;
}

.mission .cards .card:hover .card-icon img.default {
    opacity: 0;
}

/* ----- HERO SIMPLE ----- */
.cta-simple {
    position: relative;
    width: 100%;
    height: auto;
    padding: 140px 80px;
    display: flex;
    align-items: center;
    color: #fff;
    font-family: "Montserrat", sans-serif;
}

.cta {
    background-image: url("../images/bg/cta.webp");
    background-size: cover;
    background-position: right;
}

.cta-1 {
    background-image: url("../images/bg/cta-1.webp");
    background-size: cover;
    background-position: right;
}

.cta-2 {
    background-image: url("../images/bg/cta-2.webp");
    background-size: cover;
    background-position: right;
}

.cta-3 {
    background-image: url("../images/bg/cta-3.webp");
    background-size: cover;
    background-position: right;
}

.cta-4 {
    background-image: url("../images/bg/cta-4.webp");
    background-size: cover;
    background-position: right;
}

.cta-5 {
    background-image: url("../images/bg/cta-5.webp");
    background-size: cover;
    background-position: right;
}

/* ----- TEXTE ----- */
.cta-text {
    position: relative;
    z-index: 2;
}

.cta-text h1 {
    font-size: 70px;
    font-weight: 800;
    margin: 0 0 25px 0;
    line-height: 65px;
    text-transform: uppercase;
}

.cta-text h1 span {
    color: #FCD22A;
}

.event-box {
    margin: 0 auto;
    max-width: 1250px;
    border-radius: 26px;
    padding: 110px 90px 90px 120px;
    background-image: url("../images/evenements/evenement-1/cover.webp");
    background-size: cover;
    background-position: center;
    font-family: "Montserrat", sans-serif;
    color: #fff;
}

.event-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 50px;
}

.event-left {
    width: 65%;
}

.sub-title {
    font-size: 16px;
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: -0.48px;
    margin-bottom: 15px;
}

.event-name {
    font-size: 60px;
    font-weight: 800;
    text-transform: uppercase;
    line-height: 55px;
    letter-spacing: -2.4px;
    margin-bottom: 15px;
}

.event-name span {
    color: #FCD22A;
}

.event-desc {
    font-size: 16px;
    font-weight: 300;
    line-height: 22px;
    letter-spacing: -0.48px;
}

.event-image img {
    width: 350px;
    height: auto;
}

.event-infos {
    display: flex;
    gap: 40px;
    margin-top: 35px;
}

.info-card {
    display: flex;
    align-items: center;
    gap: 25px;
    background: #F1E1FF;
    color: #441350;
    padding: 20px 45px;
    border-radius: 16px;
    width: 500px;
}

.info-card img {
    width: 70px;
}

.info-card .text-box h3 {
    color: #441350;
    font-weight: 800;
    font-size: 22px;
    line-height: 25px;
    letter-spacing: -0.88px;
}

.info-card .text-box p {
    color: #702D82;
    font-size: 18px;
    font-weight: 500;
    line-height: 20px;
    letter-spacing: -0.54px;
}

.text-underline {
    text-decoration: underline !important;
}

.implantation-wrapper {
    position: relative;
    width: 100%;
    padding-top: 60px;
    font-family: "Montserrat", sans-serif;
}

/* ====== SHAPE ====== */
.shape-implant {
    position: absolute;
    right: 400px;
    top: -60px;
    width: 300px;
    pointer-events: none;
}

/* ====== LAYOUT TEXTE + IMAGE ====== */
.implant-content {
    display: flex;
    justify-content: space-between;
    gap: 0;
}

/* ====== TEXTE À GAUCHE ====== */
.implant-content .text-box {
    max-width: 420px;
}

.implant-content .text-box .text-box-1 {
    font-size: 28px;
    line-height: 34px;
    letter-spacing: -1.12px;
    font-weight: 700;
    color: #340D3D;
    margin-bottom: 20px;
}

.implant-content .text-box .text-box-2 {
    color: #340D3D;
    font-size: 20px;
    line-height: 30px;
    letter-spacing: -0.8px;
    margin-top: 15px;
}

.implant-content .text-box .text-box-2 span {
    font-weight: 600;
}

.implant-content .text-box strong {
    font-weight: 800;
}

/* ====== IMAGE COLLÉE À DROITE ====== */
.implant-content .img-box {
    width: 55%;
    display: flex;
    justify-content: flex-end;
}

.img-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0 0 0 30px;
    /* arrondi bas-gauche (comme ton image) */
}


.implantations-cards {
    padding: 80px 0;
    font-family: "Montserrat", sans-serif;
}

.implantations-cards .cards-grid {
    display: flex;
    gap: 40px;
    justify-content: space-between;
    flex-wrap: wrap;
}

.implantations-cards .title-box {
    color: #340D3D;
    font-size: 28px;
    line-height: 34px;
    letter-spacing: -1.12px;
    text-align: center;
    margin-bottom: 70px;
}

/* ====== CARD ====== */
.implant-card {
    width: 48%;
    max-width: 580px;
    transition: 0.3s ease;
}

/* ===== IMAGE ===== */
.implant-card img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 22px;
    display: block;
}

/* ===== Titre + Flèche alignés ===== */
.implant-card .card-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 18px;
    margin-bottom: 40px;
}

.implant-card h3 {
    font-size: 25px;

    letter-spacing: -0.75px;
    font-weight: 700;
    color: #000000;
    line-height: 1.2;
    margin: 0;
    max-width: 80%;
}

/* ===== Ligne ===== */
.implant-card hr {
    border: none;
    border-bottom: 0.1px solid rgba(0, 0, 0, 0.25);
    margin-top: 15px;
}

/* Supprimer la ligne (border bottom) sur la dernière card */
.implant-card:last-child hr {
    display: none;
}

/* ===== Bouton flèche ===== */
.implant-card .card-link {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 60px;
    height: 60px;
    border: 0.1px solid #4F05D7;
    border-radius: 50%;
    color: #4F05D7;
    font-size: 20px;
    transition: 0.4s ease;
}

/* ===== HOVER EFFECT ===== */
.implant-card:hover .card-link {
    background: #4F05D7;
    color: #fff;
    transform: rotate(-45deg);
    /* Flèche orientée vers le haut */
}

.modal-content-wrapper {
    max-height: 90vh;
    overflow-y: auto;
}

.modal-content {
    max-height: 90vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.modal-content-wrapper {
    overflow-y: auto;
    padding-right: 10px;
    max-height: calc(90vh - 80px);
}

.modal-content-wrapper::-webkit-scrollbar {
    width: 6px;
}

.modal-content-wrapper::-webkit-scrollbar-thumb {
    background: #702D82;
    border-radius: 10px;
}


.modal-implant {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(4px);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 99999;
}

/* === CARTE STYLE === */
.modal-content {
    background: #F6ECFF;
    border: 1px solid rgba(68, 19, 80, 0.66);
    border-radius: 25px;
    padding: 35px;
    position: relative;
    animation: scaleUp .3s ease;
    font-family: "Montserrat", sans-serif;
}

@keyframes scaleUp {
    0% {
        transform: scale(0.8);
        opacity: 0;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* === BOUTON FERMETURE === */
.close-modal {
    position: absolute;
    right: 25px;
    top: 18px;
    font-size: 30px;
    cursor: pointer;
    color: #441350;
}

/* === GRID === */
.modal-grid {
    display: flex;
    align-items: center;
    gap: 65px;
}

/* === IMAGE === */
.modal-img img {
    width: 100%;
    height: 420px;
    object-fit: cover;
    border-radius: 18px;
    display: block;
}

/* === TEXTE INFO === */
.modal-info {
    word-wrap: break-word;
    overflow-wrap: break-word;
    white-space: normal;
}

.modal-info h2 {
    font-weight: 800;
    font-size: 60px;
    letter-spacing: -2.2px;
    color: #702D82;
    line-height: 50px;
    text-transform: uppercase;
}

.modal-info h2 span {
    color: #DA302D;
}

.modal-info hr {
    margin: 25px 0 25px;
    border: 0;
    height: 1px;
    background: rgba(68, 19, 80, 0.27);
}

/* ===== Lignes d’infos (icone + texte) ===== */
.modal-info .info-line {
    display: flex;
    align-items: flex-start;
    gap: 30px;
    padding: 0 40px 0 0;
    margin-bottom: 14px;
}

/* ===== Icone dans un bloc séparé ===== */
.modal-info .info-line .icon-box img {
    width: 40px;
    height: 40px;
    display: block;
    object-fit: contain;
    margin-top: 3px;
    /* ajuste verticalement si besoin */
}

/* ===== Texte séparé ===== */
.modal-info .info-line .text-box {
    font-size: 20px;
    line-height: 20px;
    text-decoration: underline;
    color: #702D82;
    font-weight: 700;
    align-items: center;
}

.modal-info .info-line .no-underline {
    text-decoration: none !important;
}

/* ------------------ FAMILLES IMPACT ------------------ */

.familles-impact {
    padding: 50px 0;
    background: #FFFFFF;
    text-align: center;
    font-family: "Montserrat", sans-serif;
}

.familles-impact h1 {
    font-size: 50px;
    font-weight: 800;
    letter-spacing: -2px;
    line-height: 1.2;
    color: #441350;
    margin-bottom: 30px;
}

.familles-impact h1 .red {
    color: #DA302D;
}

/* --- sous texte --- */
.familles-impact .desc {
    color: #340D3D;
    font-size: 20px;
    letter-spacing: -0.6px;
    max-width: 830px;
    margin: 0 auto 30px;
    line-height: 1.5;
}

/* --- texte info + verset --- */
.familles-impact .info {
    color: #340D3D;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.6px;
    line-height: 1.5;
    max-width: 850px;
    margin: 0 auto 50px;
}

.familles-impact .info strong {
    font-weight: 800;
    color: #441350;
}

.familles-impact .verset {
    color: #DA302D;
    font-weight: 500;
    font-style: italic;
    display: inline-block;
    margin-top: 10px;
}


/* Ministères */
.ministere .container {
    max-width: 1250px;
    margin: auto;
    padding-top: 100px;
    position: relative;
}

.ministere .container p {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    text-align: center;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin-top: 50px;
}

.ministere .container p span {
    font-weight: 700;
}

.ministere .content1 {
    display: flex;
    justify-content: right;
    align-items: start;
    padding-top: 20px;
    gap: 100px;
}

.ministere .content1 .img {
    width: 51%;
}

.ministere .content1 .img img {
    width: 100%;
    height: 100%;
}

.ministere .content1 .txt {
    width: 34%;
}

.ministere .content1 .txt h6 {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 23px;
    font-style: normal;
    font-weight: 400;
    line-height: 33px;
    letter-spacing: -0.46px;
    margin: 0;
    margin-top: 20px;
}

.ministere .content1 .txt .obj {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-top: 20px;
}

.ministere .content1 .txt div {
    display: flex;
    align-items: flex-start;
    gap: 25px;
}

.ministere .content1 .txt div img {
    width: 52px;
    height: 37px;
    margin-top: 5px;
}

.ministere .content1 .txt div p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
    letter-spacing: -0.76px;
    margin: 0;
}

.ministere .content1 .txt div p span {
    font-weight: 700;
}

.ministere .container-2 {
    max-width: 1250px;
    margin: auto;
    padding-top: 100px;
    position: relative;
}

.ministere .container-2 h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.60px;
    margin: 0;
    margin-top: 50px;
}

.ministere .container-2 p {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin-top: 20px;
}

.ministere .container-2 p span {
    font-weight: 700;
}

.ministere .content2 {
    display: flex;
    justify-content: left;
    align-items: start;
    padding-top: 20px;
    gap: 50px;
}

.ministere .content2 .img {
    width: 51%;
}

.ministere .content2 .img img {
    width: 115%;
    height: 100%;
    margin-left: -100px;
}

.ministere .content2 .txt {
    width: 40%;
}

.ministere .content2 .txt h6 {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.57px;
    margin: 0;
    margin-top: 20px;
}

.ministere .content2 .txt .obj {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-top: 20px;
}

.ministere .content2 .txt div {
    display: flex;
    align-items: flex-start;
    gap: 25px;
}

.ministere .content2 .txt div img {
    width: 52px;
    height: 37px;
    margin-top: 5px;
}

.ministere .content2 .txt div p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
    letter-spacing: -0.76px;
    margin: 0;
}

.ministere .content2 .txt div p span {
    font-weight: 700;
}

.ministere .content2 .txt a {
    color: white;
    text-align: center;
    text-decoration: none;
    padding: 15px 40px;
    border-radius: 41px;
    border: 0.75px solid rgba(255, 255, 255, 0.48);
    background: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
    font-size: 15px;
    font-style: normal;
    font-weight: 600;
    line-height: 25px;
    letter-spacing: -0.6px;
    font-family: "Montserrat", sans-serif;
    display: inline-block;
    margin-top: 50px;
    transition: all 0.8s ease-in;
}

.ministere .content2 .txt a:hover {
    border: 0.75px solid rgba(68, 19, 80, 0.56);
    background: rgba(254, 247, 255, 0.07);
    background: linear-gradient(90deg, #CE3C13 0%, #742F87 89.39%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.ministere .container-3 {
    max-width: 1250px;
    margin: auto;
    padding-top: 150px;
    position: relative;
}

.ministere .container-3 h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.60px;
    margin: 0;
    margin-top: 50px;
}

.ministere .container-3 p {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin-top: 20px;
}

.ministere .container-3 p span {
    font-weight: 700;
}

.ministere .content3 {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 20px 0px;
}

.ministere .content3 .txt {
    width: 68%;
    min-height: 410px;
    background: linear-gradient(145deg, #441350 0%, #3F01EB 100%);
    border-radius: 50px;
    margin-left: -160px;
    box-sizing: border-box;
    padding: 60px 200px 60px 285px;
}

.ministere .content3 .txt h6 {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 23px;
    font-style: normal;
    font-weight: 400;
    line-height: 33px;
    letter-spacing: -0.46px;
    margin: 0;
}

.ministere .content3 .txt p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 500;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin-top: 0px;
}

.ministere .content3 .txt .obj {
    display: flex;
    flex-direction: column;
    gap: 15px;
    padding-top: 20px;
}

.ministere .content3 .txt div {
    display: flex;
    align-items: flex-start;
    gap: 25px;
}

.ministere .content3 .txt div img {
    width: 52px;
    height: 37px;
    margin-top: 5px;
}

.ministere .content3 .txt div p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
    letter-spacing: -0.76px;
    margin: 0;
}

.ministere .content3 .txt div p span {
    font-weight: 700;
}

.ministere .content3 .img {
    width: 30%;
}

.ministere .content3 .img img {
    width: 100%;
    height: 100%;
}

.ministere .content4 p {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 28px;
    font-style: italic;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin-top: 20px;
}

.ministere .content4 .verset {
    color: #DA302D;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-weight: 600;
    line-height: 40px;
    letter-spacing: -0.76px;
    margin-top: -5px;
    margin-bottom: 100px;
}


.ministere .content4 .cards {
    margin: auto;
    display: flex;
    align-items: center;
    gap: 25px;
    flex-wrap: wrap;
    padding-top: 50px;
}

.ministere .content4 .cards .card {
    width: 45%;
    height: 500px;
    border-radius: 20px;
    box-sizing: border-box;
    padding: 60px 40px 60px 45px;
}

.ministere .content4 .cards .card img {
    width: 100px;
    height: 100px;
}

.ministere .content4 .cards .card h2 {
    text-align: left;
    color: white;
    margin-top: 105px;
    line-height: 42px;
}

.ministere .content4 .cards .card h2 span {
    color: #FCD22A;
}

.ministere .content4 .cards .card p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
    letter-spacing: -0.60px;
    text-align: left;
    margin-top: 10px;
}

.enseignements .container {
    padding-top: 100px;
    position: relative;
}

.enseignements .container img {
    width: 350px !important;
    height: 300px !important;
    position: absolute;
    top: 100px;
    left: 460px;
}

.enseignements .content1 {
    display: flex;
    align-items: center;
    justify-content: left;
    gap: 100px;
}

.enseignements .content1 .img {
    width: 50%;
}

.enseignements .content1 .img img {
    width: 100%;
    height: 100%;
}

.enseignements .content1 .txt {
    width: 35%;
}

.enseignements .content1 .txt h6 {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 35px;
    font-style: normal;
    font-weight: 600;
    line-height: 40px;
    letter-spacing: -1.32px;
    margin: 0;
}

.enseignements .content1 .txt p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    max-width: 90%;
}

.enseignements .content1 .txt p span {
    font-weight: 700;
}

.enseignements .content2 {
    width: 50%;
    margin: auto;
    padding-top: 100px;
    text-align: center;
}

.enseignements .content2 h6 {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.56px;
    margin: 0;
    margin-top: 20px;
}

.enseignements .content2 p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
    letter-spacing: -0.76px;
    max-width: 85%;
    margin: auto;
    margin-top: 15px;
}

.enseignements .content2 p span {
    font-weight: 700;
}

.enseignements .content2 img {
    width: 100%;
    height: 100%;
    margin-top: 20px;
}

.enseignements .bg-son {
    width: 100%;
    background: url('../images/bg/bg-son.webp') center/cover no-repeat;
    background-size: 1920px 800px;
    background-position-y: 300px;
}

.enseignements .content3 {
    width: 60%;
    margin: auto;
    padding-top: 100px;
    text-align: center;
}

.enseignements .content3 h6 {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 23px;
    font-style: normal;
    font-weight: 700;
    line-height: 33px;
    letter-spacing: -0.46px;
    margin: 0;
    margin-top: 20px;
}

.enseignements .content3 h6 span {
    color: #DA302D;
    font-size: 40px;
    line-height: 50px;
    letter-spacing: -0.80px;
}

.enseignements .content3 p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 500;
    line-height: 30px;
    letter-spacing: -0.76px;
    max-width: 85%;
    margin: auto;
    margin-top: 20px;
}

.enseignements .content3 p.verset {
    font-style: italic;
    font-weight: 400;
}

.enseignements .content3 p .col-red {
    font-weight: 600;
    font-size: 21px;
    color: #DA302D;
}

.enseignements .content3 p span {
    font-weight: 700;
}

.enseignements .content3 .contents {
    padding-top: 100px;
}

.enseignements .content3 .contents p {
    max-width: 100%;
}

.enseignements .content3 img {
    width: 100%;
    height: 100%;
    margin-bottom: 30px;
}

.reseaux-sociaux {
    padding-top: 10px;
}

.reseaux-sociaux .icons {
    display: flex;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    padding-top: 10px;
}

.reseaux-sociaux .icon {
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    border-radius: 50%;
    border: 1px solid rgba(68, 19, 80, 0.56);
    background: #FEF7FF;
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 500;
    line-height: 25px;
    letter-spacing: -0.45px;
}

.reseaux-sociaux .icon span {
    background-image: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.reseaux-sociaux .icon:hover {
    border: 0.5px solid rgba(255, 255, 255, 0.48);
    background: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
}

.reseaux-sociaux .icon:hover span {
    color: #FFFFFF;
}

.reseaux-sociaux .icon span i {
    font-size: 20px;
}


.servir .container {
    padding-top: 100px;
    position: relative;
}

.servir .container img {
    width: 300px !important;
    height: 300px !important;
    position: absolute;
    top: 70px;
    left: 550px;
}

.servir .content1 {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 100px 0px;
}

.servir .content1 .txt {
    width: 68%;
    min-height: 410px;
    background: linear-gradient(145deg, #441350 0%, #3F01EB 100%);
    border-radius: 50px;
    margin-left: -160px;
    box-sizing: border-box;
    padding: 50px 200px 50px 350px;
}

.servir .content1 .txt h6 {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.56px;
    margin: 0;
}

.servir .content1 .txt p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    max-width: 80%;
    margin-top: 20px;
}

.servir .content1 .txt h6 span {
    color: #FCD22A;
}

.servir .content1 .img {
    width: 30%;
}

.servir .content1 .img img {
    width: 100%;
    height: 100%;
}

.servir .content2 {
    padding: 0px 0px 100px 0px;
}

.servir .content2 .txt {
    margin-top: 50px;
    min-height: 300px;
    border: 1px solid rgba(155, 43, 182, 0.00);
    background: url('../images/bg/bg-2.webp') center/contain no-repeat;
    box-sizing: border-box;
    padding: 80px 0px;
    text-align: center;
}

.servir .content2 .txt p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 500;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin: 0;
}

.servir .content2 .txt p span {
    font-weight: 700;
}

.col-red {
    font-size: 25px !important;
    line-height: 35px !important;
    letter-spacing: -1px !important;
    font-weight: 700 !important;
    color: #DA302D !important;
    margin-top: 2px !important;
}

.servir .content2 .txt h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 29px;
    letter-spacing: -0.56px;
    max-width: 55%;
    margin: auto;
    margin-bottom: 20px;
    margin-top: 5px;
}

.servir .container-2 {
    max-width: 1250px;
    margin: auto;
}

.servir .content3 {
    display: flex;
    align-items: center;
    gap: 100px;
    padding: 0px 0px 100px 0px;
}

.servir .content3 .img {
    width: 50%;
}

.servir .content3 .img img {
    width: 100%;
    height: 100%;
}

.servir .content3 .txt {
    width: 40%;
}

.servir .content3 .txt h6 {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    font-size: 23px;
    font-style: normal;
    font-weight: 700;
    line-height: 33px;
    letter-spacing: -0.46px;
    margin: 0;
    margin-top: 20px;
}

.servir .content3 .txt .obj {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-top: 20px;
}

.servir .content3 .txt div {
    display: flex;
    align-items: center;
    gap: 25px;
}

.servir .content3 .txt div img {
    width: 50px;
    height: 35px;
}

.servir .content3 .txt div p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin: 0;
}

.servir .content3 .txt div p span {
    font-weight: 700;
}

.servir .line {
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, rgba(52, 13, 61, 0.00) 0%, #340D3D 50%, rgba(52, 13, 61, 0.00) 100%);
}

.servir .content4 {
    padding: 100px 0px 100px 0px;
}

.servir .content4 h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.56px;
    margin: 0;
    margin-top: 20px;
}

.servir .content4 p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
}

.servir .content4 .cards {
    display: flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
    padding-top: 50px;
}

.servir .content4 .cards .card {
    width: 33%;
    min-height: 430px;
    border-radius: 20px;
    box-sizing: border-box;
    padding: 40px 30px 40px 40px;
}

.servir .content4 .cards .card-large {
    width: 66.5%;
    padding-left: 150px;
}

.servir .content4 .cards .card-large h5 {
    font-family: "Montserrat", sans-serif;
    font-size: 36px !important;
    font-style: normal;
    font-weight: 700;
    line-height: 46px !important;
    letter-spacing: -0.72px !important;
    margin-bottom: 0px !important;
}

.servir .content4 .cards .card-large p {
    font-family: "Montserrat", sans-serif;
    font-size: 19px !important;
    font-weight: 400 !important;
    line-height: 30px !important;
    letter-spacing: -0.76px !important;
    margin-top: 0px !important;
}

.btn-gradient {
    display: inline-block;
    padding: 12px 30px;
    border-radius: 41px;
    border: 0.75px solid rgba(68, 19, 80, 0.56);
    background-color: white;
    text-decoration: none;
    margin-top: 10px;
    cursor: pointer;
}

.btn-gradient .btn-text {
    font-family: "Montserrat", sans-serif;
    font-weight: 600;
    font-size: 15px;
    line-height: 25px;
    letter-spacing: -0.6px;
    display: inline-block;
    background-image: linear-gradient(90deg, #CE3C13 -74.43%, #722E84 102.19%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.servir .content4 .cards .card.card1 {
    background: linear-gradient(141deg, #5B0AA2 4.08%, #3F01EB 101.54%);
}

.servir .content4 .cards .card.card2 {
    background: #E6D3F7;
    border: 0.1px solid #5A0AA4;
}

.servir .content4 .cards .card img {
    width: 70px;
    height: 70px;
}

.servir .content4 .cards .card h5 {
    font-family: "Montserrat", sans-serif;
    font-size: 26px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px;
    letter-spacing: -1.04px;
    margin: 0;
    margin-top: 50px;
}

.servir .content4 .cards .card.card1 h5 {
    color: #FCD22A;
}

.servir .content4 .cards .card.card2 h5 {
    color: #441350;
}

.servir .content4 .cards .card h6 {
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 600;
    line-height: 20px;
    letter-spacing: -0.31px;
    margin-top: 10px;
}

.servir .content4 .cards .card.card1 h6 {
    color: white;
}

.servir .content4 .cards .card.card2 h6 {
    color: #441350;
}

.servir .content4 .cards .card p {
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
    letter-spacing: -0.60px;
    margin-top: 0px;
}

.servir .content4 .cards .card.card1 p {
    color: white;
}

.servir .content4 .cards .card.card2 p {
    color: #441350;
}

.servir .content5 {
    padding: 0px 0px 100px 0px;
}

.servir .content5 .cards {
    display: flex;
    align-items: center;
    gap: 15px;
    padding-top: 50px;
}

.servir .content5 .cards .card {
    width: 35%;
    padding: 55px 25px;
    border-radius: 10px;
    border: 1px solid rgba(68, 19, 80, 0.20);
    background: #FAF4FF;
    display: flex;
    align-items: flex-start;
    gap: 15px;
}

.servir .content5 .cards .card img {
    width: 42px;
    height: 42px;
}

.servir .content5 .cards .card div p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
    letter-spacing: -0.60px;
    margin-top: 0px;
}

.servir .content5 .cards .card div p span {
    color: #EB1616;
    font-weight: 800;
    font-size: 18px;
    line-height: 28px;
    letter-spacing: -0.72px;
    text-transform: uppercase;
}

.servir .content6 {
    padding: 0px 0px 100px 0px;
}

.servir .content6 p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin-top: 0px;
    text-align: center;
}

.servir .content6 form {
    width: 70%;
    min-height: 500px;
    box-sizing: border-box;
    display: block;
    margin: auto;
    margin-top: 50px;
    border-radius: 15px;
    border: 1px solid rgba(52, 40, 59, 0.16);
    background: #F1E1FF;
    padding: 50px 80px;
}

.servir .content6 form h6 {
    color: #121212;
    font-family: "Montserrat", sans-serif;
    font-size: 23px;
    font-style: normal;
    font-weight: 700;
    line-height: 33px;
    letter-spacing: -0.46px;
    margin: 0;
    margin-top: 20px;
}

.servir .content6 form .inputs {
    display: flex;
    align-items: center;
    justify-content: space-between;
    row-gap: 15px;
    flex-wrap: wrap;
    padding-top: 20px
}

.servir .content6 form input,
.servir .content6 form select {
    box-sizing: border-box;
    width: 49%;
    height: 55px;
    background: white;
    border: none;
    padding-left: 30px;
    color: #85858B;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.56px;
}

.servir .content6 form input[type="checkbox"] {
    width: 15px;
    height: 15px;
    border: 1px solid #464671;
    border-radius: 0px !important;
}

.servir .content6 form textarea {
    box-sizing: border-box;
    width: 100%;
    height: 160px;
    background: white;
    border: none;
    padding-left: 30px;
    padding-top: 20px;
    color: #85858B;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.56px;
}

.servir .content6 form .check {
    display: flex;
    align-items: center;
    gap: 10px;
}

.servir .content6 form label {
    color: #525258;
    font-family: "Outfit", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.56px;
}

.servir .content7 {
    padding: 100px 0px 100px 0px;
}

.servir .content7 .img {
    width: 65%;
    margin: auto;
    padding-top: 20px;
}

.servir .content7 .img img {
    width: 100%;
    height: 100%;
}

.servir .content7 .btn {
    width: 100%;
    display: flex;
    justify-content: center;
    padding-top: 50px;
}

/* contact */
.contact .container {
    max-width: 1250px;
    margin: auto;
    padding-top: 100px;
}

.contact .container h3 {
    color: #DA302D;
    font-family: "Montserrat", sans-serif;
    font-size: 44px;
    font-style: normal;
    font-weight: 700;
    line-height: 54px;
    letter-spacing: -0.88px;
    margin: 0;
}

.contact .container h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 600;
    line-height: 38px;
    letter-spacing: -0.60px;
    margin: 0;
    margin-top: 20px;
}

.contact .container .content1 {
    padding-top: 100px;
}

.contact .container .content1 .contents {
    display: flex;
    flex-wrap: wrap;
    padding-top: 20px;
    gap: 130px;
}

.contact .container .content1 .content-one {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.contact .container .content1 .content-two {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.contact .container .content1 .content-one .content {
    display: flex;
    gap: 20px;
}

.contact .container .content1 .content-one .content img {
    width: 52px;
    height: 37px;
    margin-top: 5px;
}

.contact .container .content1 .content-one .content h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.60px;
    margin: 0;
    margin-top: 0px;
    margin-bottom: 5px;
}

.contact .container .content1 .content-one .content p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
    letter-spacing: -0.76px;
    margin: 0;
}

.contact .container .content1 .content-two .content {
    display: flex;
    align-items: center;
    gap: 20px;
}

.contact .container .content1 .content-two .content img {
    width: 28px;
    height: 28px;
}

.contact .container .content1 .content-two .content p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 17px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.68px;
    margin: 0;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: break-word !important;
}

.contact .container .content1 .content-two .content a {
    text-decoration: none;
    color: #441350;
}

.contact .content2 {
    padding-top: 100px;
    padding-bottom: 100px;
}

.contact .content2 form {
    width: 97%;
    min-height: 500px;
    box-sizing: border-box;
    display: block;
    margin: auto;
    margin-top: 50px;
    border-radius: 15px;
    border: 1px solid rgba(52, 40, 59, 0.16);
    background: #F1E1FF;
    padding: 50px 80px;
}

.contact .content2 form h6 {
    color: #121212;
    font-family: "Montserrat", sans-serif;
    font-size: 23px;
    font-style: normal;
    font-weight: 700;
    line-height: 33px;
    letter-spacing: -0.46px;
    margin: 0;
    margin-top: 20px;
}

.contact .content2 form .inputs {
    display: flex;
    align-items: center;
    justify-content: space-between;
    row-gap: 15px;
    flex-wrap: wrap;
    padding-top: 20px
}

.contact .content2 form input,
.contact .content2 form select {
    box-sizing: border-box;
    width: 49%;
    height: 55px;
    background: white;
    border: none;
    padding-left: 30px;
    color: #85858B;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.56px;
}

.contact .content2 form input[type="checkbox"] {
    width: 15px;
    height: 15px;
    border: 1px solid #464671;
    border-radius: 0px !important;
}

.contact .content2 form textarea {
    box-sizing: border-box;
    width: 100%;
    height: 160px;
    background: white;
    border: none;
    padding-left: 30px;
    padding-top: 20px;
    color: #85858B;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.56px;
}

.contact .content2 form .check {
    display: flex;
    align-items: center;
    gap: 10px;
}

.contact .content2 form label {
    color: #525258;
    font-family: "Outfit", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.56px;
}

.contact .container .content3 {
    padding-top: 100px;
}

.contact .container .content3 .contents {
    display: flex;
    flex-wrap: wrap;
    padding-top: 20px;
    gap: 130px;
}

.contact .container .content3 .content-one {
    width: 30%;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.contact .container .content3 .content-one h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.60px;
    margin: 0;
    margin-top: 0px;
    margin-bottom: 5px;
}

.contact .container .content3 .content-one .content {
    display: flex;
    align-items: center;
    gap: 20px;
}

.contact .container .content3 .content-one .content img {
    width: 28px;
    height: 28px;
}

.contact .container .content3 .content-one .content p {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 17px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    letter-spacing: -0.68px;
    margin: 0;
}

.contact .container .content3 .content-one a {
    text-decoration: none;
    color: #441350;
}

/* galerie*/

.gallery h6 {
    color: #441350;
    font-family: "Montserrat", sans-serif;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    line-height: 38px;
    letter-spacing: -0.60px;
    margin: 0;
    margin-top: 50px;
}

.gallery p {
    color: #340D3D;
    font-family: "Montserrat", sans-serif;
    text-align: center;
    font-size: 19px;
    font-style: normal;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: -0.76px;
    margin-top: 50px;
}

.gallery p span {
    font-weight: 700;
}

.gallery .btn-div {
    display: flex;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    padding: 30px 0px 50px 0px;
}

.gallery .btn-div button {
    cursor: pointer;
    padding: 12px 50px;
}

.gallery .btn-div .active {
    text-align: center;
    text-decoration: none;
    padding: 12px 50px;
    border-radius: 40px;
    border: 1px solid rgba(68, 19, 80, 0.56);
    background: #FEF7FF;
    font-family: "Montserrat", sans-serif;
    font-size: 15px;
    font-style: normal;
    font-weight: 500;
    line-height: 25px;
    letter-spacing: -0.45px;
}

.gallery .btn-div .active span {
    background-image: linear-gradient(126deg, #E77555 -26.75%, #722E84 51.89%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.gallery-tab-content {
    display: none;
}

.gallery-tab-content.active {
    display: block;
}

.masonry-gallery {
    width: 99%;
    margin: auto;
    position: relative;
}

.masonry-item {
    width: 25%;
    padding: 3px;
    box-sizing: border-box;
}

.masonry-item img {
    width: 100%;
    display: block;
}
.masonry-gallery:not(.masonry-initialized) {
    display: flex;
    flex-wrap: wrap;
}

.gallery-tab-content:not(.active) {
    display: none !important;
}




footer {
    width: 100%;
    min-height: 530px;
    background: url('../images/footer/bg-footer.webp') center/cover no-repeat;
    box-sizing: border-box;
}

footer .container {
    padding: 100px 0px 50px 0px;
    margin: auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: start;
}

footer .container .content1 {
    width: 50%;
}

footer .container .content1 img {
    width: 150px;
    height: auto;
}

footer .container .content1 form {
    margin-top: 50px;
}

footer .container .content1 form .input {
    display: flex;
    align-items: center;
    margin-top: 20px;
}

footer .container .content1 form label {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: -0.28px;
}

footer .container .content1 form input {
    width: 328px;
    height: 45px;
    padding: 12px 10px;
    border-radius: 10px 0 0 10px;
    border: 1px solid white;
}

footer .container .content1 form input:focus {
    outline: none;
    border: 2px solid #DA302D;
    box-shadow: 0 0 4px #DA302D;
}

footer .container .content1 form button {
    width: 100px;
    height: 45px;
    border-radius: 0 10px 10px 0;
    background: #DA302D;
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: -0.28px;
    border: 1px solid #DA302D;
}

footer .container .content1 .icon {
    display: flex;
    align-items: center;
    margin-top: 20px;
    gap: 10px;
}

footer .container .content1 .icon img {
    width: auto;
    height: 30px;
}

footer .container .content1 .icon p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: -0.28px;
    margin: 0;
}


footer .container .content2,
footer .container .content3 {
    width: 20%;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

footer .container .content2 h6,
footer .container .content3 h6 {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 28px;
    letter-spacing: -0.72px;
    margin: 0;
}

footer .container .content2 a,
footer .container .content3 a {
    text-decoration: none;
    color: #FFFFFF;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: -0.42px;
    font-style: normal;
    font-weight: 300;
}

footer .container .content4 {
    width: 30%;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

footer .container .content4 h6 {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 28px;
    letter-spacing: -0.72px;
    margin: 0;
}

footer .container .content4 .links-email {
    display: flex;
    gap: 20px;
    align-items: flex-start;
    flex-wrap: wrap;
}


footer .container .content4 .links-email img {
    width: 26px;
    height: 26px;
}

footer .container .content4 a {
    text-decoration: none;
    color: #FFFFFF;
    font-family: "Montserrat", sans-serif;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: -0.42px;
    font-style: normal;
    font-weight: 300;
    display: flex;
    align-items: center;
    gap: 20px;
}

footer .container .content4 a img {
    width: 26px;
    height: 26px;
}

footer .container .content2 a:hover,
footer .container .content3 a:hover,
footer .container .content4 a:hover {
    color: #FCD22A;
    font-weight: 400;
}


footer .line {
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.00) 0%, rgba(255, 255, 255, 0.34) 50%, rgba(255, 255, 255, 0.00) 100%);
}

footer p {
    color: white;
    font-family: "Montserrat", sans-serif;
    font-size: 12px;
    font-style: normal;
    font-weight: 200;
    line-height: 22px;
    letter-spacing: -0.48px;
    text-align: center;
    margin-top: 20px;
}

br.display {
    display: block;
}