header{
    z-index: 2;
    width: 100%;
    top: 0;
    left: 0;
    padding: 32px 0 0;
}

.header-wrapper{
    padding: 0 120px;
    position: relative;
}

.logo-header{
    max-width: 120px;
    margin-bottom: 32px;
}

.btn-header{
    color: #FFF4DB;
    font-size: 16px;
    line-height: 22px;
    font-weight: 500;
    text-transform: uppercase;
    background: transparent;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    font-family: 'SVN-Gotham';
    right: 20px;
    top: 17px;
    z-index: 2;
    display: inline-block;
}

.header-date{
    color: #FFF4DB;
    font-size: 16px;
    line-height: 22px;
    font-weight: 500;
    margin-bottom: 16px;
    text-transform: uppercase;
    text-align: center;
    position: relative;
    padding: 0 97px;
}

.header-date::before, .header-date::after{
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #FFF4DB;
    width: 89px;
    height: 1px;
}

.header-date::after{
    right: 0;
    left: unset;
}

.header-inner{
    display: flex;
    flex-direction: column;
    align-items: center;
}

.header-description{
    max-width: 324px;
    color: #FFF4DB;
    font-size: 16px;
    line-height: 22px;
    font-weight: 500;
    text-transform: uppercase;
    text-align: center;
}
.banner{
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    min-height: 900px;
    position: relative;
    padding: 200px 0 86px;
    display: flex;
    align-items: flex-end;
    background-image: var(--bg);
    overflow: hidden;
}

.rose-mode .banner{
    background-image: var(--bg-rose);
}

.rose-mode .banner::after{
    height: 340px;
    bottom: 0;
    top: unset;
    background: linear-gradient(
    to top,
    rgba(47, 49, 82, 1) 0%,
    rgba(47, 49, 82, 0) 100%
    );
    opacity: 0.2;
}

.banner::after, .banner::before{
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: #2F315233;
}

.banner::before{
    background: #090A271A;
}

.banner-inner{
    z-index: 2;
    position: relative;
        display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-top: auto;
}

.banner-inner h1{
    font-size: clamp(54px, 7.5vw, 120px);
    line-height: 0.9;
    color: #FFF4DB;
    width: 60%;
}


.banner-images{
    width: 40%;
    position: relative;
    aspect-ratio: 507 / 416;
    padding-left: 20px;
}

.banner .container{
    max-width: 1500px;
}

.banner-vector__1 {
    left: 18%;
    z-index: 2;
    bottom: 42px;
}

.banner-vector__2 {
    bottom: -36px;
    right: -9px;
    rotate: 21deg;
}

.intro{
    padding: 160px 0 50px;
    position: relative;
}

.content-intro{
    max-width: 919px;
    text-align: center;
    color: #C77478;
    font-size: 24px;
    line-height: calc(38 / 24);
    font-weight: 500;
    text-transform: uppercase;
}

.intro-wrapper{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 38px;
}

.vector-party{
    top: -14%;
    left: -20px;
    width: 37.2%;
    /* Float above the sticky session cards (z:20) and the day header (z:30)
       so the cursive script vectors are never clipped by either. They\'re
       already translucent so they don\'t obscure card content visually,
       and pointer-events: none keeps them from intercepting clicks. */
    z-index: 35;
    pointer-events: none;
}

.img-pattern{
    right: 8%;
    transform: translateY(-50%);
    top: 50%;
}

.item-party.day-three  .img-pattern{
    right: -20px
}

.item-party:nth-child(even) .img-pattern{
    right: unset;
    left: -20px;
    top: 57%;

}

.item-party:nth-child(even) .vector-party{
    right: -20px;
    left: unset;
    top: -16.3%;
}

.day-three .vector-party{
    top: -16%;
    left: 39px;
    width: 38.9%;
}

.party-day{
    color: #C77478;
    font-size: 24px;
    line-height: calc(29 / 24);
    font-weight: 400;
    margin-bottom: 1px;
    text-align: center;
    position: relative;
    padding: 0 125px;
    font-family: "Beth Ellen", cursive;
    max-width: max-content;
    margin: 0 auto;
    margin-bottom: 2px;
}

.day-one .party-day{
    margin-bottom: -2px;
}

.day-three .party-day{
    margin-bottom: 5px;
}

.party-day::before, .party-day::after {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #C77478;
    width: 117px;
    height: 1px;
}

.party-day::after{
    left: unset;
    right: 0;
    
}

.party-date{
    color: #C77478;
    font-size: 32px;
    line-height: calc(45 / 32);
    font-weight: 700;
    text-transform: uppercase;
    text-align: center;
}

.party{
    padding: 225px 0 104px;
    z-index: 2;
    position: relative;
    background: #FFEBEF;
    overflow: hidden;

}

.party-session__list{
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.item-party{
    position: relative;
}

.party-session {
    display: flex;
    flex-wrap: wrap;
    border-radius: 20px;
    overflow: hidden;
    margin-top: 0;
    box-shadow: 0px 5px 5px 0px #3228281A;
    position: relative;
    z-index: 2;
}

.item-party__header{
    margin-bottom: 54px;
}

.img-spin-party {
    z-index: 3;
    /* transform: translateX(-50%); */
}

.party-images{
    width: 45.5%;
    position: relative;
}

.party-content{
    width: 54.5%;
    padding: 39px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding-bottom: 41px;
    /* background-color: #FFEAEF80; */
    /* mix-blend-mode: multiply; */
    background-repeat: no-repeat;
    background-size: cover;
    justify-content: space-between;
    gap: 20px;
    position: relative;
    isolation: isolate;
}

.party-session__afternoon .party-content::before {
    content: '';
    position: absolute;
    inset: 0;
    background-color: #FFDEFD;
    mix-blend-mode: color;
    z-index: 2;
    pointer-events: none;

}

.party-content::after{
    content: '';
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    mix-blend-mode: multiply;
}


.day-two .party-session__afternoon .party-content::before{
    background-color: #B9CEE8;
}

.day-three .party-session__afternoon .party-content::before{
    background-color: #FFFBEE;
    mix-blend-mode: multiply;
}

.day-one .party-session__evening .party-content{
    background-color: #03805E;

}

.day-two .party-session__evening .party-content{
    background-color: #274738;
}

.day-three .party-session__evening .party-content{
    background-color: #2C2E35;
}

.party-session__afternoon .party-content::after{
    background-image: url(../images/PK_PAPER_10.png);
}

.party-session__evening .party-content::after{
    background-image: url(../images/PK_PAPER_10_evening.png);
}

.swiper-slide.image-party{
    aspect-ratio: 710 / 850;
    position: relative;
    height: auto;
}

.slider-party .swiper-wrapper{
    align-items: stretch;
}

.swiper-slide.image-party img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.swiper-slide.image-party::before{
    position: absolute;
    content: '';
    width: 100%;
    height: 100%;
    object-fit: cover;
    left: 0;
    top: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.3) 8.88%, rgba(0, 0, 0, 0) 41.42%);

}
.logo-party {
    max-width: 15vw;
    left: 50%;
    transform: translateX(-50%);
    top: 30px;
    z-index: 12;

}

.swiper-progress-bar {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 6px;
    background: rgba(255,255,255,0.6);
    z-index: 3;
}

.swiper-progress-bar__fill {
    height: 100%;
    background: #fff;
    transition: width 0.3s ease;
}

.party-images .swiper-arrow{
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #FFFFFF4D;
    border: 1px solid #FFFFFF66;
    border-radius: 50%;
    bottom: 20px;
    top: unset;
    z-index: 12;
    
    transition: all .3s ease;
}

.party-images .swiper-button-next{
    right: 16px;
}

.party-images .swiper-button-prev{
    left: 16px;
}

.party-images .swiper-arrow::after{
    display: none;
}

.party-images .swiper-arrow svg{
    width: 24px;
    height: 24px;
    transition: all .3s ease;
}

.party-images .swiper-arrow:hover svg path{
    fill: #CA5F64
}

.party-images .swiper-arrow:hover{
    background: #fff;
}

.party-images .swiper-pagination {
    bottom: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 100% !important; 
    display: flex;
    align-items: center;
    gap: 0;
    background: rgba(255, 255, 255, 0.6);

}

.party-images .swiper-pagination-bullet {
    flex: 1;
    height: 6px;
    border-radius: 0;
    background: rgba(255, 255, 255, 0.6);
    opacity: 1;
    margin: 0 !important;
    transition: background 0.3s ease;
}

.party-images .swiper-pagination-bullet-active {
    background: #ffffff;
    border-radius: 10px

}

.party-session__label{
    color: #D26BB8;
    font-size: 16px;
    line-height: calc(19 / 16);
    font-weight: 500;
    text-align: center;
    max-width: max-content;
    margin-bottom: 20px;
    position: relative;
    padding: 0 108px;
    z-index: 2;
}

.day-two .party-session__afternoon .party-session__label{
    color: #324D97;
}

.day-two .party-session__evening .party-session__label{
    color: #EEE681;
}

.day-three .party-session__afternoon .party-session__label{
    color: #F87229;
}

.day-three .party-session__evening .party-session__label{
    color: #FFB9C5;
}

.day-two .party-session__evening .party-session__label::before, .day-two .party-session__evening .party-session__label::after{
    background-color: #EEE681;
}

.day-two .party-session__afternoon .party-session__label::before, .day-two .party-session__afternoon .party-session__label::after{
    background-color: #324D97;
}

.day-three .party-session__afternoon .party-session__label::before, .day-three .party-session__afternoon .party-session__label::after{
    background-color: #C77478;
}

.day-three .party-session__evening .party-session__label::before, .day-three .party-session__evening .party-session__label::after{
    background-color: #FFB9C5;
}

.day-one .party-session__evening .img-party__info svg path {
    fill: #FFAAD3;
}

.day-one .party-session__evening .party-content .party-session__label{
    color: #FFAAD3;
}

.day-two .party-session__afternoon .img-party__info svg path {
    fill: #324D97;
}

.day-two .party-session__evening .img-party__info svg path {
    fill: #EEE681;
}

.day-two .party-session__evening .party-session__note{
    color: #EEE681;
}

.day-three .party-session__afternoon .img-party__info svg path {
    fill: #F87229;
}

.day-three .party-session__evening .img-party__info svg path {
    fill: #FFB9C5;
}

.day-three .party-session__evening .party-session__note{
    color: #FFB9C5;
}

.day-three .party-session__afternoon .party-session__note{
    color: #F87229;
}

.day-three .party-session__afternoon .party-session__subtitle{
    color: #F87229 !important;
}

/* Day 3 L'OPERA: keep the "Amy F'ing Dieterich" cursive decoration visible
   on mobile too — its decoration row has hide-mb in the visibility class
   (which would normally apply display:none under 992px), but on this
   session we want it to read on phones. Override the hide-mb rule and
   reposition the cursive on mobile so the whole script fits within the
   photo area instead of bleeding off the left edge (its desktop
   inline_style is left:-6%; bottom:15%, which clips on narrow phones). */
@media (max-width: 991px) {
    .day-three .party-session__evening .img-spin-party.hide-mb,
    .day-three .party-session__evening .img-spin-party {
        display: block !important;
        left: 4% !important;
        right: auto !important;
        bottom: 4% !important;
        top: auto !important;
        transform: none;
        max-width: 42%;
        width: 42%;
        height: auto;
    }
}

.party-session__label::before, .party-session__label::after {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #D26BB8;
    width: 100px;
    height: 1px;
}

.party-session__evening .party-session__label::before, .party-session__evening .party-session__label::after{
    background-color: #FFF4DB;

}



.party-session__label::after{
    left: unset;
    right: 0;
    
}

.party-session__name{
    color: #2F6696;
    font-size: clamp(40px, 4.5vw, 72px);
    line-height: 1;
    max-width: 606px;
    z-index: 2;
    position: relative;
}

.day-two .party-session__afternoon .party-session__name{
    color: #324D97;
}

.party-session__date, .party-session__time{
    font-family: "Beth Ellen", cursive;
     color: #2F6696;
    font-size: 24px;
    line-height: calc(29 / 24);
    font-weight: 400;
    text-align: center;
}

.day-two .party-session__afternoon .party-session__date, .day-two .party-session__afternoon .party-session__time{
    color: #EE2121;
}

.day-two .party-session__afternoon .party-session__note{
    color: #EE2121;
}

.day-two .party-session__afternoon .party-session__address{
    color: #0A4663;
}

.party-session__address{
    color: #2F6696;
    font-size: 24px;
    font-weight: 500;
    line-height: calc(29 / 24);
    margin-top: 31px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.party-session__address p{
    margin-bottom: 0;
}

.party-session__time{
    margin-bottom: 0;
}

.party-session__address

.party-session__address--sub{
    font-size: 20px;
    line-height: 1.2;
    font-family: 'SVN-Gotham Book';
}

.party-session__info{
    /* margin: 20px 0; */
    position: relative;
    padding: 51px 0 57px;
}

.img-party__info{
    transform: translateX(-50%);
    left: 50%;
    top: 0;
}

.img-party__info--bottom{
    top: unset;
    bottom: 0;
}

/* update color */
.img-party__info svg path{
    fill: #D26BB8;
}


.party-session__note{
    font-family: "Beth Ellen", cursive;
    color: #D26BB8;
    font-size: 24px;
    font-weight: 400;
    line-height: calc(29 / 24);
    margin-bottom: 0;
}

.party-session__conclude{
    color: #0A4663;
    font-size: 16px;
    line-height: calc(19 / 16);
    font-weight: 400;
    font-family: 'SVN-Gotham Book';
    font-style: italic;
    margin: 13px auto 0 !important;
    max-width: 412px;
}

.party-session__bottom a, .party-content > a{
    margin-top: 32px;
    display: inline-block;
    text-decoration: underline;
    color: #2F6696;
    font-size: 16px;
    line-height: calc(19 / 16);
    font-weight: 500;
    text-underline-offset: 4px;
}

.party-content > a{
    margin-top: 0;
    z-index: 11;
    color: #FFF4DB;
    margin-top: 4px;
    
}

.party-session__info{
    display: flex;
    flex-direction: column;
    align-items: center;
}

.party-session__bottom{
    /* margin-top: auto; */
    display: flex;
    flex-direction: column;
    align-items: center;
}

.party-session__evening{
    flex-direction: row-reverse;
}

.party-session__evening .party-session__note{
    line-height: calc(34 / 24);
}

.day-one .party-session__evening .party-session__note{
    color: #FFAAD3;
}

.party-session__evening .party-content{
    background-color: #C77478;
}

.party-session__evening .party-content *{
    color: #FFF4DB;
}

.party-session__bottom{
    max-width: 509px;
}

.party-session__evening .slider-party .swiper-pagination {
    background: rgba(255, 255, 255, 0.6);

}

.party-session__evening .slider-party .swiper-pagination-bullet {
    background: rgba(255, 255, 255, 0.6);
}

.party-session__evening .slider-party .swiper-pagination-bullet-active {
    background: #ffffff;

}

.list-party{
    display: flex;
    flex-direction: column;
    gap: 160px;
}

.day-two .party-images .logo-white{
    opacity: 0;
}

.day-two .party-images.active .logo-black{
     opacity: 0;
}

.day-two .party-images.active .logo-white{
    opacity: 1;

}

.day-two .party-session__evening .party-session__name, .day-three .party-session__evening .party-session__name {
    font-size: clamp(40px, 3.75vw, 60px);
    max-width: 672px;
    line-height: 1.1;
}
.day-three .party-session__evening .party-session__name{
    max-width: 575px;
}

.day-two .party-session__afternoon .polaroid--madames .polaroid__label{
        rotate: -1deg;
    bottom: 1.25vw;
}

.party-session__subtitle{
    margin-bottom: 0;
    font-family: 'SVN-Gotham Book';
    font-size: 16px;
    line-height: 19px;
    margin-top: 35px !important;
    color: #D4D7B8 !important;
}

.img-flag{
    z-index: 3;
    right: 6.3%;
    top: 5px;
}

.day-three .party-session__name{
    max-width: 530px;
}

.day-three .party-session__conclude{
    max-width: 450px;
    font-family: 'SVN-Gotham';
    font-weight: 300;
}

.day-three .party-session__afternoon .swiper-slide.image-party::before{
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.6) 0%, rgba(255, 255, 255, 0) 36.17%, rgba(255, 255, 255, 0) 43.67%);
}
.party-content__intro{
    display: flex;
    flex-direction: column;
    align-items: center;
}

.last-day__content h2{
    font-size: clamp(48px, 4.5vw, 72px);
    line-height: 1;
    text-align: center;
}

.item-party.last-day{
    margin-top: -62px;
}

.item-party.last-day .party-day{
    margin-bottom: 7px
}

.item-party.last-day .item-party__header{
    margin-bottom: 40px;
}

.style-guide-overlay{
    display: none;
    z-index: 4;
    width: 100%;
    height: 100%;
    position: relative;
}

.party-images::before{
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: #00000066;
    z-index: 3;
    opacity: 0;
    transition: opacity 1s ease;
    pointer-events: none;
}

.party-images.active::before {
    opacity: 1;
}

.party-images.active{
    background: #00000066;
}


.style-guide__content{
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 24px;
    height: 100%;
}

.party-content__intro, .party-session__info, .party-session__bottom{
    z-index: 3;
}

.style-guide-overlay.active{
    display: block;
}

.slide-up-item {
    opacity: 0;
    transform: translateY(60px);
}

.style-guide-overlay.is-animating .slide-up-item {
    animation: slideUp 0.45s cubic-bezier(0.34, 1.4, 0.64, 1) forwards;
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(100%);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.polaroid--madames {
    right: 17%;
    top: 31.2%;
    z-index: 2;
}

.polaroid{
    width: 11.75vw;
    max-width: 188px;
    display: flex;
    align-items: flex-end;
}

.img-bisous {
    top: -61px;
    left: -39px;
    width: 8.563vw;
}
.slider-party{
    height: 100%;
}

.day-one .party-session__afternoon .img-spin-party{
    max-width: 21.25vw;
    z-index: 5;
}

.day-one .party-session__evening .img-spin-party{
    max-width: 41%;
}

.day-one .party-session__evening .polaroid--madames{
    rotate: 11deg;
    left: -15%;
    top: 14px;
}

.style-guide__box-madames {
    top: 16%;
    left: 11%;
}

.day-one .party-session__evening .polaroid__label{
    bottom: 6px;
    rotate: 4deg;
}

.day-one .party-session__evening .style-guide__box{
    margin-left: 8px;
}

.day-one .party-session__evening .style-guide__box-messieurs .style-guide__box{
    gap: 17px;

}

.day-two .party-session__afternoon .style-guide__box-messieurs{
    right: unset;
    bottom: 1.25vw;
}

.day-two .party-session__afternoon .style-guide__box-madames .style-guide__desc{
    max-width: 230px;
}

.day-two .party-session__afternoon .style-guide__box-madames{
    left: unset;
    right: -3%;
    bottom: 35.6%;
    top: unset;
}

.day-two .party-session__afternoon .style-guide__box-madames .style-guide__box{
    rotate: -8deg;
    gap: 16px;
    width: 19.75vw;
    max-width: 316px;
}

.day-two .party-session__afternoon .style-guide__box-madames .polaroid--madames{
    right: unset;
    left: -31%;
    top: 20%;
    margin-bottom: -2.625vw;
}

.day-two .party-session__afternoon .style-guide__box-messieurs .style-guide__box{
    rotate: 0deg;
    gap: 16px;
}

.day-two .party-session__afternoon .style-guide__box-messieurs .polaroid--messieurs{
        margin-bottom: 0;
    right: 2%;
}

.day-two .party-session__afternoon .style-guide__content{
    padding: 20px;
}

.day-two .party-session__evening .style-guide__box-messieurs{
    flex-direction: row-reverse;
    justify-content: flex-end;
    padding-left: 39px;
    padding-bottom: 36px;
}

.day-two .party-session__evening .style-guide__box-messieurs .style-guide__box{
    rotate: 0deg;
    gap: 16px;
}

.day-two .party-session__evening .style-guide__box-messieurs .polaroid--messieurs{
    rotate: 4deg;
    margin-left: -5.2%;
    margin-bottom: 4%;
    bottom: unset;
    right: unset;
    z-index: -1;
}

.day-two .party-session__evening .style-guide__box-madames .style-guide__box{
    padding-left: 10px;
    padding-right: 10px;
    rotate: 0deg;
    margin-bottom: 33px;
}

.day-two .party-session__evening .style-guide__content{
    gap: 41px;
}

.day-two .party-session__evening .style-guide__box-madames .polaroid--madames{
    right: unset;
    top: unset;
    rotate: -14deg;
}

.day-two .party-session__evening .style-guide__box-madames .polaroid__label{
    rotate: -2deg;
    bottom: 1.25vw;
}
.day-two .party-session__evening .style-guide__box-madames{
    display: flex;
    justify-content: flex-end;
    padding-right: 12px;
}

.day-two .party-session__evening .img-spin-party{
    max-width: 13.563vw;
}

.day-three .party-session__afternoon .polaroid--madames{
    right: 0;
    top: 0;
    rotate: 7deg;
}

.day-three .party-session__afternoon .style-guide__box-messieurs .style-guide__box{
    max-width: 367px;
    width: 19.75vw;
}

.day-three .party-session__afternoon .style-guide__box-messieurs .polaroid--messieurs{
    rotate: -8deg;
    right: -17%;
    bottom: 1%;
    margin-bottom: 23px;
}

.day-three .party-session__afternoon .style-guide__box-madames{
    left: unset;
    right: 12%;
    top: 30%;
}

.day-three .party-session__afternoon .style-guide__box-messieurs {
        right: unset;
    left: 37px;
    bottom: 36px;
}

.day-three .party-session__evening .style-guide__box-messieurs{
    display: flex;
    flex-direction: row-reverse;
    justify-content: flex-end;
    padding-left: 10px;
    padding-bottom: 17px;
}

.day-three .party-session__evening .style-guide__box-messieurs .polaroid--messieurs{
    rotate: 2deg;
    margin-bottom: 0;
    bottom: -12px;
    margin-left: 10px;
    z-index: -1;
}

.day-three .party-session__evening .style-guide__box-messieurs .style-guide__box{
    rotate: -5deg;
}

.day-three .party-session__evening .style-guide__box-madames{
        display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    padding-right: 17px;
}

.day-three .party-session__evening .style-guide__content{
    gap: 36px;
}

.day-three .party-session__evening .polaroid--madames{
    top: unset;
    right: unset;
    rotate: -10deg;
    margin-right: -19px;
    margin-bottom: 65px;
}

.day-three .party-session__evening .polaroid--madames .polaroid__label{
    rotate: -1deg;
    bottom: 1vw;
}
.day-three .party-session__evening .polaroid--messieurs .polaroid__label{
    rotate: 2deg;
    left: 52%;
    bottom: 0.813vw;
}

.day-three .party-session__evening  .img-spin-party{
    max-width: 25.563vw;
}
.style-guide__box-messieurs {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    right: 20px;
    bottom: 7%;
}

.polaroid--messieurs .polaroid__label{
    color: #0A4663;
    font-size: 14px;
    bottom: 1.5vw;
}

.style-guide__box-messieurs .polaroid--messieurs{
    rotate: 13deg;
    margin-bottom: -8px;
    z-index: 2;
}

.style-guide__box-messieurs .style-guide__box{
    max-width: 367px;
    rotate: 2deg;
    width: 22.938vw;
}

.style-guide__box-messieurs .style-guide__title, .style-guide__box-messieurs .style-guide__desc{
    color: #4D5E88;
}
.polaroid--messieurs{
    rotate: -10deg;
    rotate: 10deg;
    bottom: 20.5%;
    right: 4%;

}

.polaroid__label{
    font-family: "Beth Ellen", cursive;
    font-size: 16px;
    line-height: 19px;
    color: #CA5F64;
    position: absolute;
    bottom: 13%;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    text-align: center;
    rotate: -5deg;
}
.style-guide__box{
    background-image: url('../images/PK_PAPER_10.png');
    background-repeat: no-repeat;
    background-size: cover;
    padding: 23px 17px 33px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 12px;
    max-width: 316px;
    width: 19.75vw;
    border-radius: 10px;
    margin-left: 0;
    rotate: -2deg;

}

.style-guide__title{
    color: #CA5F64;
    font-size: 16px;
    line-height: 19px;
    font-weight: 500;
    text-align: center;
    margin: 0;
}

.img-tape{
    top: -20px;
    left: 53%;
    transform: translateX(-50%);
}

.style-guide__desc{
    color: #CA5F64;
    font-size: 16px;
    line-height: 19px;
    font-family: 'SVN-Gotham Book';
    text-align: center;
}
.main-footer{
    position: relative;
    box-shadow: 0px 4px 4px 0px #00000040;
    padding: 101px 0 278px;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;

}

.vector-footer1{
    max-width: min(18.063vw, 300px);
}

.vector-footer2{
    max-width: min(19.813vw, 320px);
}

.main-footer::after{
    position: absolute;
    background: #9C373C26;
    content: '';
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.footer-inner{
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 48px;
}

.footer-inner h2{
    color: #FFF4DB;
    font-size: clamp(40px, 7.5vw, 120px);
    line-height: 1;
    text-align: center;
    /* Heading takes 68vw at narrow viewports, but on wider screens it's
       capped to the empty middle band between the two polaroid frames
       (each ~300px capped + 8% edge offsets). Lets the heading grow with
       the viewport without ever sliding under or over the polaroids. */
    max-width: min(68.063vw, calc(100vw - 800px));
    z-index: 2;
}

.img-mask{
     max-width: 13.875vw;
}

@media (max-width: 1360px){
    .day-one .party-session__evening .style-guide__box {
        margin-left: -16%;
    }
}

@media (max-width: 1024px){
    .intro {
        padding: 140px 0 40px;
    }

    .party{
        padding-top: 175px;
    }
}


@media (max-width: 991px){
    .party-images, .party-content, .banner-inner h1, .banner-images{
        width: 100%;
    }

    .banner-images{
        max-width: 420px;
        margin: 0 auto;
    }

    .btn-header{
        right: 6px;
        top: 0;
    }

    header{
        padding-top: 16px;
    }

    .header-wrapper{
        padding:24px 0 20px;
    }

    .banner{
        padding-top: 307px;
        align-items: stretch;
    }

    .banner-vector__2 {
        bottom: -37px;
        right: 23px;
        rotate: 21deg;
        max-width: 212px;
        z-index: 2;
    }

    .banner-vector__1 {
        left: 14px;
        z-index: 1;
        bottom: 18px;
        max-width: 212px;
    }

    .banner-inner{
        margin-top: auto;
        height: 100%;
        align-items: stretch;
    }

    .banner-inner h1{
        text-align: center;
    }

    .banner .container{
        height: auto;
    }

    .logo-party{
        max-width: 200px;
    }
    
    .party .container{
        padding: 0;
    }

    .item-party__header{
        padding: 0 20px;
        margin-bottom: 44px;
    }

    .party-content{
        z-index: 9;
        opacity: 1;
        mix-blend-mode: unset;
        /* margin: 0 10px; */
        border-radius: 12px;
        overflow: hidden;
        padding: 22px 15px 41px;
    }

    .img-pattern {
        right: 30%;
        transform: translateY(-50%);
        top: 52.4%;
    }

    .party-session__list{
        gap: 60px
    }

    .party-session{
        /* padding-top: 300px; */
        box-shadow: none;
        border-radius: 0;
    }

    .party-images{
        position: relative;
        top: auto;
        left: auto;
        height: auto;
    }

    .party-session__label{
        font-size: 16px;
        font-weight: 500;
        padding: 0 108px;
        margin-bottom: 41px;
    }


    .party-session__info{
        /* margin: 54px 0 50px; */
    }

    .day-one .party-session__afternoon .party-session__conclude{
        max-width: 235px;
        margin-top: 15px !important;
    }


    .party-session__bottom a{
        margin-top: 24px;
    }

    .party-session__note{
        font-size: 20px;
        line-height: 24px;
    }

    .day-two .party-session__afternoon .logo-party{
        max-width: 180px;
    }

    .day-two .party-session__evening .logo-party{
        max-width: 140px;
    }

    .icon-champagne2{
        right: -65px !important; 
        bottom: -110px !important;
    }

    .icon-champagne1{
        left: -64px !important;
        bottom: unset !important;
        top: -5px !important;
    }

    .day-two .party-session__evening .party-session__name, .day-three .party-session__evening .party-session__name{
        line-height: calc(48 / 40);
    }

    .party-session__subtitle{
        font-size: 14px;
        max-width: 208px;
        margin-top: 24px !important;
    }

    .day-two .party-session__evening .party-session__info{
        /* margin: 19px 0  17px; */
    }

    .day-three .party-session__afternoon .logo-party{
        max-width: 100px;
    }

    .img-lemon{
        top: 21%;
        right: 4%;
        max-width: 150px;
    }

    .day-three .party-session__afternoon .party-session__info{
        /* margin: 99px 0 95px; */
    }   

    .day-three .party-session__evening .logo-party{
        top: 20px;
    }

    .day-three .party-session__evening .party-session__info{
        /* margin: 24px 0 22px; */
    }

    .img-mask{
        top: 42% !important;
        left: -10px !important;
        max-width: 126px;
    }

    .day-three .party-session__evening .icon-champagne1{
        bottom: 22% !important;
        top: unset !important;
        max-width: 72px;
        left: 9% !important;
    }

    .day-three .party-session__evening .icon-champagne2{
        bottom: 17px !important;
        right: 19px !important;
        max-width: 61px;
    }

    .day-three .party-session__conclude{
        max-width: 360px;
         font-family: 'SVN-Gotham Book';
         margin-top: 16px !important;
    }

    .item-party.last-day {
        margin-top: 1px;
    }

    .item-party.last-day .party-day{
        padding: 0 96px;
    }

    .item-party.last-day .party-day::before,.item-party.last-day .party-day::after{
        width: 88px;
    }

    .main-footer{
        padding: 59px 0 0;
    }

    .footer-inner h2{
        max-width: 90.1%;
    }

    .footer-inner{
        gap: 18px;
        padding-bottom: 289px;
    }

    .vector-footer1{
        max-width: 202px;
        top: unset !important;
        bottom: 7px !important;
        left: 5% !important;
    }

    .vector-footer2{
        right: 5% !important;
        bottom: 18px !important;
        max-width: 225px;
    }

    .item-party:nth-child(even) .vector-party {
        right: 16px;
        left: unset;
        top: -5.9%;
    }

    .day-three .vector-party{
        top: -6%;
        left: -2px;
    }

    .item-party.day-three .img-pattern{
        right: unset;
        left: 0;
        top: 54%;
        max-width: 87%;
    }

    .day-two .img-pattern {
        top: 50% !important;
        left: unset !important;
        right: 0 !important;
        max-width: 93% !important;
        /* rotate: -262deg; */
        transform: scaleX(-1);
    }

    .day-one .img-pattern {
        transform: scale(-1);
        top: 50.5%;
    }

    .day-one .vector-party{
        max-width: 144px;
        top: -2%;
        /* bottom: 0; */
        right: -20px;
        left: unset;
        z-index: -1;
    }

    .swiper-progress-bar{
        display: none;
    }

    .swiper-slide.image-party{
        /* min-height: 600px; */
    }

    .swiper-slide.image-party::after {
        position: absolute;
        content: '';
        width: 100%;
        height: 80px;
        left: 0;
        bottom: 0;
        background: linear-gradient(
        to bottom,
        rgba(243, 214, 206, 0) 0%,
        rgba(243, 214, 206, 0.55) 100%
        );
    }

    .day-one .party-session__evening .img-spin-party{
        right: 16px;
        top: 20%;
        max-width: 40%;
        z-index: -1;
    }

    .day-two .party-session__evening .img-spin-party{
        right: -46px;
        top: 31%;
        max-width: 185px;
        z-index: -1;
    }

    .day-one .party-session__afternoon .img-spin-party{
        right: -10px !important;
        bottom: 24% !important;
        max-width: 197px;
        z-index: -1;
    }

    .party-content .style-guide-overlay {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 10;
        background: rgba(0, 0, 0, 0.5);
        display: none;
    }

    .party-images.active::before{
        display: none;
    }

    .party-session__bottom a {
        position: relative;
        z-index: 20;
    }

    .party-day{
        margin-bottom: 5px;
    }

    .style-guide__box{
        width: auto;
    }

    .day-one .party-session__afternoon .style-guide__box{
        margin-bottom: 61px;
        margin-left: -6px;
        gap: 12px;
    }

    .img-bisous{
        width: 139px;
        left: unset;
        top: unset;
        bottom: 23%;
        right: -70%;
    }

    .polaroid{
        width: 187px;
        max-width: 42.5vw;
    }

    .style-guide__box{
        left: unset;
        top: unset;
        bottom: 23%;
        right: -70%;
        padding-left: 16px;
        padding-right: 16px;
        gap: 15px;
    }

    .polaroid--madames{
        right: unset;
        left: 23px;
        top: 17%;

    }

    .polaroid--messieurs{
        bottom: 30.5%;
        right: 7%;
    }

    .polaroid--messieurs .polaroid__label {
        bottom: 26px;
        left: 46%;
    }

    .day-one .party-session__evening .polaroid--madames {
        rotate: -15deg;
        left: -10%;
        top: -4px;
    }

    .polaroid.polaroid--madames  .polaroid__label, .style-guide__box-madames .style-guide__desc{
        color: #CA5F64 !important
    }

    .style-guide__box-messieurs .style-guide__box{
        max-width: 367px;
        width: auto;
    }
    
    .style-guide__box-messieurs .style-guide__box{
        rotate: 0deg;
    }

    .style-guide__box-messieurs {
        right: unset;
        bottom: 11.3%;
        left: 20px;
    }

    .day-one .party-session__evening .style-guide__box-messieurs, .day-two .party-session__evening .style-guide__box-messieurs {
        right: 34px;
        bottom: 11.3%;
        left: unset;
    }

    .day-one .party-session__evening .style-guide__box-madames, .day-two .party-session__evening .style-guide__box-madames {
        left: 82px;
        right: unset;
    }

    .style-guide__box-messieurs .polaroid--messieurs{
        rotate: 3deg;
        right: -11px;
    }

    .day-one .party-session__evening .polaroid__label {
        bottom: 25px;
        rotate: -3deg;
        left: 50%;
    }

    .style-guide__box-madames{
        top: 39px;
        left: unset;
        right: 22px;
        display: flex;
        flex-direction: column-reverse;
    }

    .day-one .party-session__evening .style-guide__box{
        margin-left: 0;
        rotate: 0deg;
    }

    .day-two .party-session__afternoon .style-guide__box-madames .style-guide__box{
        width: 316px;
        max-width: 71.818vw;
    }

    .day-two .party-session__afternoon .style-guide__box-messieurs {
        right: unset;
        bottom: 10%;
        left: 26px;
    }

    .day-two .party-session__afternoon .style-guide__box-messieurs .polaroid--messieurs {
        margin-bottom: -12px;
        right: 0%;
        rotate: 13deg;
    }

    .day-two .party-session__afternoon .style-guide__box-madames{
        bottom: unset;
        top: 21px;
        flex-direction: column;
        z-index: 2;
    }

    .day-two .party-session__afternoon .polaroid--madames .polaroid__label {
        bottom: 19px;
    }

    .day-two .party-session__afternoon .style-guide__box-madames .style-guide__box{
        margin-top: -15%;
        margin-left: -9%;
    }

    .day-two .party-session__evening .style-guide__box-messieurs{
        flex-direction: column;
        /* padding-bottom: 59px; */
        padding-bottom: 0; 
        padding-left: 0;
        /* margin-left: -12px; */
        margin-left: 0;
        max-width: max-content;
        position: absolute;
    }

    .day-two .party-session__evening .style-guide__box-messieurs .polaroid--messieurs {
        rotate: 2deg;
        margin-left: -5.2%;
        margin-bottom: -1%;
    }

    .day-two .party-session__evening .style-guide__box-messieurs .style-guide__box{
        margin: 0 auto;
    }

    .day-two .party-session__evening .polaroid--messieurs .polaroid__label {
        bottom: 18px;
        left: 52%;
        rotate: 0deg;
    }

    .day-two .party-session__evening .style-guide__box-madames {
        flex-direction: column-reverse;
        position: absolute;
        padding-right: 0;
    }

    .day-two .party-session__evening .style-guide__box-madames .style-guide__box{
        margin-bottom: 0;
    }

    .day-two .party-session__evening .style-guide__box-madames .polaroid--madames{
        left: -10%;
    }

        .day-two .party-session__evening .style-guide__box-madames .polaroid__label {
        bottom: 24px;
        left: 47%;
    }

    .day-three .party-session__afternoon .style-guide__box-messieurs .style-guide__box{
        width: 316px;
        max-width: 71.818vw;
        rotate: -2deg;
        gap: 13px;

    }

    .day-three .party-session__afternoon .style-guide__box-messieurs {
        right: unset;
        left: 15%;
        bottom: 16%;
        align-items: flex-start;
    }

    .day-three .party-session__afternoon .style-guide__box-messieurs .polaroid--messieurs {
        rotate: -7deg;
        bottom: 1%;
        margin-bottom: 8px;
        left: -8%;
    }

    .day-three .party-session__afternoon .polaroid--messieurs .polaroid__label {
        bottom: 21px;
        left: 50%;
        rotate: -3deg;
    }

    .day-three .party-session__afternoon .polaroid--madames{
        rotate: 6deg;
    }

    .day-three .party-session__afternoon .style-guide__box-madames {
        left: unset;
        right: 12%;
        top: 25%;
    }

    .day-three .party-session__afternoon .polaroid.polaroid--madames .polaroid__label{
        rotate: -2deg;
        bottom: 16px;
    }

    .day-three .party-session__evening .style-guide__box-messieurs{
        flex-direction: column;
        padding: 0;
        margin-bottom: 48px;
        padding-left: 13px;
        align-items: flex-start;
    }

    .day-three .party-session__evening .style-guide__box-messieurs .polaroid--messieurs {
        rotate: 2deg;
        margin-bottom: 0;
        bottom: -7px;
        margin-left: 10px;
        z-index: -1;
        margin-left: -20px;
    }

    .day-three .party-session__evening .polaroid--messieurs .polaroid__label {
        rotate: 2deg;
        left: 50%;
        bottom: 14px;
    }

    .day-three .party-session__evening .style-guide__box-madames{
        flex-direction: column;
        /* align-items: flex-start; */
        margin-left: -12px;
        margin-bottom: -24px;
        z-index: 2;
    }

    .day-three .party-session__evening .style-guide__content {
        gap: 0;
    }

    .day-three .party-session__evening .polaroid--madames {
        top: unset;
        right: unset;
        rotate: -10deg;
        margin-right: 0;
        margin-bottom: -30px;
        margin-left: auto;
    }
     
    .day-three .party-session__evening .polaroid--madames .polaroid__label {
        rotate: -1deg;
        bottom: 15px;
    }

    .day-three .party-session__evening .img-spin-party{
        max-width: 261px;
    }

    .day-three .party-session__evening .style-guide__box-madames .style-guide__box{
        rotate: 2deg;
        margin-right: 50px;
    }

    .party-images .swiper-arrow{
        display: none;
    }

    /* Animations */
    .slide-up-item {
        opacity: 0;
        transform: translateX(-100%);
    }

    .style-guide-overlay.is-animating .polaroid.polaroid--madames, .style-guide-overlay.is-animating .style-guide__box-madames, .day-three .style-guide-overlay.is-animating .style-guide__box-messieurs  {
        animation: slideFromLeft 0.3s cubic-bezier(0.34, 1.4, 0.64, 1) forwards;
    }

    .style-guide-overlay.is-animating .polaroid.polaroid--messieurs, .style-guide-overlay.is-animating .style-guide__box-messieurs, .day-three .style-guide-overlay.is-animating .style-guide__box-madames {
        animation: slideFromRight 0.3s cubic-bezier(0.34, 1.4, 0.64, 1) forwards;
    }

    .style-guide-overlay.is-leaving .polaroid.polaroid--madames, .style-guide-overlay.is-leaving .style-guide__box-madames, .day-three .style-guide-overlay.is-leaving .style-guide__box-messieurs {
        animation: slideToLeft 0.2s ease-in forwards;
    }

    .style-guide-overlay.is-leaving .polaroid.polaroid--messieurs, .style-guide-overlay.is-leaving .style-guide__box-messieurs, .day-three .style-guide-overlay.is-leaving .style-guide__box-madames {
        animation: slideToRight 0.2s ease-in forwards;
    }

    @keyframes slideFromLeft {
        from { opacity: 0; transform: translateX(-100%); }
        to { opacity: 1; transform: translateX(0); }
    }

    @keyframes slideFromRight {
        from { opacity: 0; transform: translateX(100%); }
        to { opacity: 1; transform: translateX(0); }
    }

    @keyframes slideToLeft {
        from { opacity: 1; transform: translateX(0); }
        to { opacity: 0; transform: translateX(-100%); }
    }

    @keyframes slideToRight {
        from { opacity: 1; transform: translateX(0); }
        to { opacity: 0; transform: translateX(100%); }
    }
}

@media(max-width: 767px){
    .intro {
        padding: 120px 0 120px;
    }

    .intro-wrapper{
        gap: 58px
    }

    .content-intro{
        font-size: 20px;
        line-height: calc(32 / 20);
    }

    .container{
        padding: 0 20px;
    }

    .party {
        padding: 41px 0 104px;
    }

    .day-three .party-session__name{
        max-width: 300px;
    }

    .day-one .party-session__evening .party-session__name{
        max-width: 300px;
    }
    .day-one .party-session__evening .party-session__info{
        /* margin: 70px 0 63px */
    }

    .list-party{
        gap: 99px;
    }

    

    .img-flag{
        right: -10px;
        top: 15px;
    }

    .day-two .party-session__afternoon .party-session__info{
        /* margin: 51px 0 47px; */
    }
}