*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Montserrat', sans-serif;
}
html{
    scroll-behavior: smooth;
}
::-webkit-scrollbar {
    width: 5px;
    height: 10px;
}
::-webkit-scrollbar-track {
    background: var(--verde-mais-claro);
}
::-webkit-scrollbar-thumb {
    background: var(--verde-claro);
}
:root{
    --branco: #f3f2f2;
    --preto: #202020;
    --verde-escuro: #677d57;
    --verde-claro: #9eb092;
    --verde-mais-claro: #cfe1c3;
    --cinza: #e0e2de;
}

.animated{/*------------ ANIMAÇÃO COMEÇA ZERO ------------*/
    opacity: 0;
}

/*---------------------- KEY FRAMES ----------------------*/
@keyframes luxuryBlur {
  from {
    opacity: 0;
    transform: translateY(60px) scale(0.95);
    filter: blur(12px);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}
@keyframes cinematicReveal {
  from {
    opacity: 0;
    clip-path: inset(100% 0 0 0);
  }

  to {
    opacity: 1;
    clip-path: inset(0 0 0 0);
  }
}
@keyframes pulo{
    0%{
        transform: scale(var(--scale)) translateY(0);
    }
    35%{
        transform: scale(var(--scale)) translateY(0px);
    }
    40%{
        transform:scale(var(--scale)) translateY(-15px);
    }
    50%{
        transform:scale(var(--scale)) translateY(0);
    }
    60%{
        transform:scale(var(--scale)) translateY(-15px);
    }
    65%{
        transform:scale(var(--scale)) translateY(0);
    }
    100%{
        transform:scale(var(--scale)) translateY(0);
    }
}
@keyframes rotate {
    0% {
        transform: rotate(10deg);
    }
    50% {
        transform: rotate(-10deg);
    }
    100% {
        transform: rotate(10deg);
    }
}
@keyframes enter {
    from{
        opacity: 0;
    }
    to{
        opacity: 1;

    }
}
@keyframes enter-right {
    from{
        opacity: 0;
        transform: translateX(200px);
    }
    to{
        opacity: 1;
        transform: translateX(0);
    }
}
@keyframes enter-left {
    from{
        opacity: 0;
        transform: translateX(-200px);
    }
    to{
        opacity: 1;
        transform: translateX(0);
    }
}
@keyframes enter-top {
    from{
        opacity: 0;
        transform: translateY(200px);
    }
    to{
        opacity: 1;
        transform: translateY(0);
    }
}
@keyframes enter-bottom {
    from{
        opacity: 0;
        transform: translateY(-200px);
    }
    to{
        opacity: 1;
        transform: translateY(0);
    }
}

/*---------------------------------------------------SESSÃO 1--------------------------------------------------*/
main .sessao1{
    width: 100%;
    height: auto;
    background-color: var(--branco);
}

.custom-shape-divider-bottom-1779819036 {
    position: absolute;
    z-index: 1;
    bottom: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
    transform: rotate(180deg);
}
.custom-shape-divider-bottom-1779819036 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 60px;
    transform: rotateY(180deg);
}
.custom-shape-divider-bottom-1779819036 .shape-fill {
    fill: var(--branco);
}

main .sessao1 .container .img{
    width: 100%;
    height: 100vh;
}
main .sessao1 .container .img img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: bottom;
}
main .sessao1 .container .sobre-container{
    width: 100%;
    height: 100vh;
    position: absolute;
    top:80%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;

}
main .sessao1 .container .sobre-container .nomes{
    width: 700px;
    height: auto;
    object-fit: cover;
    object-position: top;
}
main .sessao1 .container .sobre-container .nomes.visivel{
    animation: enter-top 2s forwards;
    animation-delay: 0.5s;
}

/*----------------------------------------------SESSÃO 2-----------------------------------------------*/
main .sessao2{
    width: 100%;
    height: auto;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: var(--verde-escuro);
}

.custom-shape-divider-top-1779907592 { 
    position: absolute; 
    top: 0; 
    left: 0; 
    width: 100%; 
    overflow: hidden; 
    line-height: 0; 
    transform: rotate(180deg); 
} 
.custom-shape-divider-top-1779907592 svg { 
    position: relative; 
    display: block; 
    width: calc(100% + 1.3px); 
    height: 60px; 
} 
.custom-shape-divider-top-1779907592 .shape-fill { 
    fill: #F3F2F2; 
}

main .sessao2 .container{
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
main .sessao2 .container h3{
    font-size: 40px;
    font-family: 'libre baskerville';
    letter-spacing: -2px;
    margin-top: 40px;
    padding: 0;
    font-weight: light;
    line-height: 0px;
    color: var(--verde-claro);
}
main .sessao2 .container h3.visivel{
    animation: luxuryBlur 2s forwards;
    animation-delay: 0.5s;
}

main .sessao2 .container .convite{
    width: 80%;
    text-align: center;
    font-size: 35px;
    letter-spacing: -2.5px;
    padding-top: 50px;
    line-height: 28px;
    color: var(--branco);
    margin-bottom: 50px;
    margin-top: 50px;
}
main .sessao2 .container .convite.visivel{
    animation: enter 2s forwards;
    animation-delay: 0.5s;
}
main .sessao2 .container .data{
    width:70%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 80px;
    margin-top: 50px;
}
main .sessao2 .container .data h1{
    font-family: 'libre baskerville';
    font-size: 70px;
    letter-spacing: -2px;
    font-weight: lighter;
    color: var(--verde-claro);
}
main .sessao2 .container .data h1.visivel{
    animation: enter-top 2s forwards;
    animation-delay: 0.5s;
}
main .sessao2 .container .data .data-type{
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    margin-top: 60px;
    gap: 250px;
}
main .sessao2 .container .data .data-type .dia{
    width: 220px;
    text-align: center;
    margin-bottom: 20px;
    font-family: 'libre baskerville';
    font-size: 50px;
    letter-spacing: -2px;
    font-weight: 600;
    border-bottom: 2px solid var(--verde-claro);
    border-top: 2px solid var(--verde-claro);
    line-height: 70px;
    color: var(--verde-claro);
}
main .sessao2 .container .data .data-type .dia.visivel{
    animation: enter-left 2s forwards;
    animation-delay: 0.7s;
}
main .sessao2 .container .data .data-type .ano{
    width: 220px;
    margin-bottom: 20px;
    font-family: 'libre baskerville';
    text-align: center;
    font-size: 50px;
    letter-spacing: -2px;
    font-weight: 600;
    border-bottom: 2px solid var(--verde-claro);
    border-top: 2px solid var(--verde-claro);
    line-height: 70px;
    color: var(--verde-claro);
}
main .sessao2 .container .data .data-type .ano.visivel{
    animation: enter-right 2s forwards;
    animation-delay: 0.7s;
}
main .sessao2 .container .data .data-type .numero{
    font-family: 'Great Vibes';
    position:absolute;
    font-size: 180px;
    letter-spacing: 3px;
    font-weight: 200;
    color: var(--branco);
}
main .sessao2 .container .data .data-type .numero.visivel{
    animation: enter-top 2s forwards;
    animation-delay: 0.7s;
}

/*timer inicio*/
main .sessao2 .container .timer{
    width: 100%;
    max-width: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 50px;
    margin-top: 50px;
}
main .sessao2 .container .timer h2{
    font-size: 80px;
    font-family: 'libre baskerville';
    letter-spacing: -2px;
    font-weight: lighter;
    color: var(--branco);
}
main .sessao2 .container .timer h2.visivel{
    animation: enter-top 2s forwards;
    animation-delay: 0.5s;
}
main .sessao2 .container .timer .timer-container{
    width: 100%;
    max-width: auto;
    display: flex;
    gap: 30px;
    flex-direction: row;
    justify-content: center;
    align-items: center;
}
main .sessao2 .container .timer .timer-container.visivel{
    animation: luxuryBlur 2s forwards;
    animation-delay: 0.8s;
}
main .sessao2 .container .timer .timer-container .box .number{
    font-family: 'libre baskerville';
    font-size: 90px;
    letter-spacing: -2px;
    font-weight: lighter;
    color: var(--verde-claro);
}
main .sessao2 .container .timer .timer-container .box .label{
    font-size: 30px;
    letter-spacing: -2px;
    font-weight: light;
    text-align: center;
    color: var(--branco);
}
main .sessao2 .container .timer .timer-container .separator{
    height: 100%;
    font-family: 'libre baskerville';
    font-size: 70px;
    letter-spacing: -2px;
    font-weight: lighter;
    color: var(--verde-claro);
}
main .sessao2 .container .timer .timer-container .separator .br{
    opacity: 0;
    font-size: 20px;
}
/*timer fim*/

main .sessao2 .container .igreja{
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 50px;
}
main .sessao2 .container .igreja img{
    width: 100%;
    height: auto;
    object-fit: cover;
}
main .sessao2 .container .igreja img.visivel{
    animation: enter 2s forwards;
    animation-delay: 0.5s;
}
main .sessao2 .container .igreja .txt{
    position: absolute;
    background-image: linear-gradient(transparent, transparent, var(--verde-escuro));
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: end;
    align-items: center;
    text-align: center; 
    padding-bottom: 80px;
    letter-spacing: -2px;
    color: var(--branco);
}
main .sessao2 .container .igreja .txt h1{
    font-size: 80px;
    font-family: 'libre baskerville';
    font-weight: lighter;
    color: var(--branco);
}
main .sessao2 .container .igreja .txt h1.visivel{
    animation: enter-top 2s forwards;
    animation-delay: 0.5s;
}
main .sessao2 .container .igreja .txt p{
    font-size: 40px;
}
main .sessao2 .container .igreja .txt p.visivel{
    animation: enter-top 2s forwards;
    animation-delay: 0.5s;
}

.custom-shape-divider-top-1780503066 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}

.custom-shape-divider-top-1780503066 svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 66px;
}

.custom-shape-divider-top-1780503066 .shape-fill {
    fill: var(--verde-escuro);
}

main .sessao2 .container .recepcao{
    width: 90%;
    max-width: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 50px;
    margin-top: 50px;
}
main .sessao2 .container .recepcao p{
    font-size: 60px;
    font-family: 'libre baskerville';
    letter-spacing: -4.5px;
    font-weight: lighter;
    color: var(--branco);
}
main .sessao2 .container .recepcao p span{
    font-family: 'Ballet';
    letter-spacing: 5px;
    font-size: 90px;
}
main .sessao2 .container .recepcao p.visivel{
    animation: enter-top 2s forwards;
    animation-delay: 0.5s;
}
main .sessao2 .container .recepcao .mapa{
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
main .sessao2 .container .recepcao .mapa iframe{
    filter: sepia(40%);
    border:none;
}
main .sessao2 .container .recepcao .mapa.visivel{
    animation: enter 2s forwards;
    animation-delay: 0.5s;
}

/*calendario inicio*/
main .sessao2 .container .calender-container{
    width: 100%;
    max-width: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 50px;
    margin-top: 50px;
}
main .sessao2 .container .calender-container.visivel{
    animation: enter 2s forwards;
    animation-delay: 0.5s;
}
main .sessao2 .container .calender-container h1{
    width: 100%;
    text-align: center; 
    background-color: var(--branco);
    font-size: 60px;
    font-family: 'libre baskerville';
    letter-spacing: -2px;
    font-weight: lighter;
    color: var(--verde-claro);
}
main .sessao2 .container .calendar{
    width: 80%;
    background: var(--verde-escuro);
    backdrop-filter: blur(10px);
    border-radius: 25px;
    padding: 30px;
}
.weekdays,
.days{
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 15px;
}
.weekdays div{
    text-align: center;
    font-weight: lighter;
    font-size: 40px;
    letter-spacing: -2px;
    color: var(--verde-claro);
    font-weight: lighter;
    padding-bottom: 10px;
}
.day{
    font-size: 30px;
    letter-spacing: -2px;
    color: var(--branco);
    border-radius: 18px;
    height: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 0.3s;
    position: relative;
}
.day:hover{
    transform: scale(1.15);
    background: rgba(255, 255, 255, 0.356);
    box-shadow: 0 0 25px #bababaaa;
}
/* Dia em destaque */
.special{
    background: var(--branco);
    color: var(--verde-escuro);
    font-weight: lighter;
    transform: scale(1.08);
    box-shadow: 0 0 25px #677d57ef;
    border: 3px solid var(--branco);
}
.special:hover{
    background: var(--branco);
    transform: scale(1.3);
}
.special::after{
    content: "";
    position: absolute;
    top: 8px;
    right: 10px;

    width: 20px;
    height: 20px;

    background-image: url("/imgs/aliança.png");
    background-size: contain;
    background-repeat: no-repeat;
}
/*calendario fim*/

.custom-shape-divider-bottom-1779909134 { 
    position: absolute; 
    bottom: 0; 
    left: 0; 
    width: 100%; 
    overflow: hidden; 
    line-height: 0; 
    transform: rotate(180deg); 
} 
.custom-shape-divider-bottom-1779909134 svg { 
    position: relative; 
    display: block; 
    width: calc(100% + 1.3px); 
    height: 60px; 
    transform: rotateY(180deg); 
} 
.custom-shape-divider-bottom-1779909134 .shape-fill { 
    fill: #F3F2F2; 
}

/*---------------------------------------------------------------SESSÃO 3------------------------------------------------*/

main .sessao3{
    width: 100%;
    height: auto;
    background-color: var(--branco);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-bottom: 50px;
    padding-top: 80px;
}
main .sessao3 .container{
    width: 70%;
    height: auto;
    background-color: var(--verde-escuro);
    display: grid;
    border-top-left-radius: 10px;
    border-top-right-radius: 50px;
    border-bottom-right-radius: 10px;
    border-bottom-left-radius: 50px;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    justify-items: center;
}
main .sessao3 .container .img{
    width: 100%;
    height: 650px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
main .sessao3 .container .img img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-bottom-left-radius: 50px;
    border-top-left-radius: 10px;
}

main .sessao3 .container .formulario{
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
    border-left: 4px solid var(--verde-claro);
}
main .sessao3 .container .formulario p{
    width: 65%;
    color: var(--branco);
    letter-spacing: -1px;
    font-weight: lighter;
    font-size: 25px;
    text-align: start;
    margin-top: 60px;
}
main .sessao3 .container .formulario h1{
    width: 85%;
    color: var(--branco);
    font-family: 'libre baskerville';
    letter-spacing: -2px;
    font-weight: lighter;
    font-size: 70px;
    text-align: start;
    line-height: 30px;
    margin-bottom: 100px;
}
main .sessao3 .container .formulario div{
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
main .sessao3 .container .formulario div input{
    background-color: transparent;
    outline: none;
    width: 85%;
    height: 50px;
    border: 2px solid var(--branco);
    border-radius: 5px;
    padding: 10px;
    margin-bottom: 20px;
    font-size: 15px;
    color: var(--branco);
    transition: 0.3s ease-in-out;
}
main .sessao3 .container .formulario div input:hover,
main .sessao3 .container .formulario div input:focus{
    background-color: var(--branco);
    color: var(--preto);
    border-radius: 30px;
    transition: 0.3s ease-in-out;
}
main .sessao3 .container .formulario div label{
    width: 85%;
    color: var(--branco);
    font-size: 20px;
    text-align: start;
}
main .sessao3 .container .formulario div select{
    background-color: transparent;
    outline: none;
    width: 85%;
    height: 50px;
    border: 2px solid var(--branco);
    border-radius: 5px;
    padding: 10px;
    margin-bottom: 20px;
    font-size: 20px;
    color: var(--branco);
    transition: 0.3s ease-in-out;
}
main .sessao3 .container .formulario div select:hover,
main .sessao3 .container .formulario div select:focus{
    background-color: var(--branco);
    color: var(--preto);
    border-radius: 30px;
    transition: 0.3s ease-in-out;
}
main .sessao3 .container .formulario div textarea{
    background-color: transparent;
    outline: none;
    width: 85%;
    height: 100px;
    border: 2px solid var(--branco);
    border-radius: 5px;
    padding: 10px;
    margin-bottom: 20px;
    font-size: 15px;
    color: var(--branco);
    transition: 0.3s ease-in-out;
}
main .sessao3 .container .formulario div textarea:hover,
main .sessao3 .container .formulario div textarea:focus{
    background-color: var(--branco);
    color: var(--preto);
    border-radius: 30px;
    transition: 0.3s ease-in-out;
}
main .sessao3 .container .formulario button{
    width: 85%;
    height: 50px;
    border-radius: 5px;
    font-size: 18px;
    font-weight: 600;
    border: 2px solid var(--verde-claro);
    background-color: var(--verde-claro);
    color: var(--branco);
    cursor: pointer;
    transition: 0.3s ease-in-out;
}
main .sessao3 .container .formulario button:hover{
    transform: scale(1.05);
    background-color: var(--branco);
    border: 2px solid var(--branco);
    color: var(--verde-escuro);
    transition: 0.3s ease-in-out;
}

/*------------------------------------------------------------ Sessão 4 ------------------------------------------------*/

main .sessao4 {
    width: 100%;
    position: relative;
    height: auto;
    padding-top: 100px;
    padding-bottom: 50px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: var(--branco);
}
main .sessao4 .brasao{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
main .sessao4 .brasao img{
    width: 150px;
    height: 150px;
}
main .sessao4 .brasao img.visivel{
    animation: luxuryBlur 2s forwards;
    animation-delay: 0.5s;
}
main .sessao4 .img{
    width:100%;
    height: 700px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    justify-items: end;
}
main .sessao4 .img img{
    width: 80%;
    height: 700px;
    object-fit: cover;
    border-top-left-radius: 180px;
    border-bottom-left-radius: 20px;
    object-position: center 80%;
    transition: 0.3s ease-in-out;
}
main .sessao4 .img img.visivel{
    animation: enter-right 2s forwards;
    animation-delay: 0.5s;
}
main .sessao4 .img .txt{
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-left: 100px;
}
main .sessao4 .img .txt h1{
    width: 100%;
    font-size: 150px;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    font-family: 'libre baskerville';
    font-weight: 500;
    text-align: start;
    letter-spacing: -6.5px;
    color: var(--verde-escuro);
}
main .sessao4 .img .txt h1 p{
    font-size: 90px;
    font-family: 'Ballet';
    line-height: 70px;
    letter-spacing: 5px;
}
main .sessao4 .img .txt h1.visivel{
    animation: luxuryBlur 2s forwards;
    animation-delay: 0.5s;
}
main .sessao4 .img .txt p{
    font-size: 40px;
    text-align: justify;
    font-weight: 400;
    letter-spacing: -2.5px;
    color: var(--verde-escuro);
}
main .sessao4 .img .txt p.visivel{
    animation: enter-left 2s forwards;
    animation-delay: 0.5s;
}

main .sessao4 .txt{
    width: 80%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-top: 50px;
    color: var(--verde-escuro);
}
main .sessao4 .txt h2{
    width: 100%;
    font-size: 60px;
    font-family: 'libre baskerville';
    font-weight: lighter;
    text-align: center;
    letter-spacing: -4.5px;
}
main .sessao4 .txt h2 span{
    font-family: 'Ballet';
    font-size: 90px;
    letter-spacing: 5px;
    font-weight: 500;
    line-height: 70px;
}
main .sessao4 .txt h2.visivel{
    animation: luxuryBlur 2s forwards;
    animation-delay: 0.5s;
}
main .sessao4 .txt p{
    font-size: 40px;
    text-align: justify;
    font-weight: 400;
    letter-spacing: -2.5px;
}
main .sessao4 .txt p.visivel{
    animation: luxuryBlur 2s forwards;
    animation-delay: 0.5s;
}
main .sessao4 .txt .sub-txt{
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: end;
}
main .sessao4 .txt .sub-txt p{
    font-size: 25px;
    text-align: justify;
    font-weight: 400;
    letter-spacing: -1.5px;
}
main .sessao4 .txt .sub-txt p.visivel{
    animation: enter 2s forwards;
    animation-delay: 1.3s;
}
main .sessao4 .txt .sub-txt h3{
    font-size: 40px;
    text-align: justify;
    font-family: 'libre baskerville';
    font-weight: 500;
    letter-spacing: -2px;
}
main .sessao4 .txt .sub-txt h3.visivel{
    animation: enter 2s forwards;
    animation-delay: 1.3s;
}

/*----------------------- RODAPÉ--------------------------- */

.footer{
    background-color: var(--verde-claro);
    text-align: center;
    padding: 20px;
    color: var(--branco);
    border-top: 4px solid var(--verde-escuro);
}
.footer p{
    font-size: 15px;
}

.footer a{
    color: var(--verde-escuro);
    font-weight: 600;
    text-decoration: none;
    transition: 0.5s ease-in-out;
}

.footer a:hover{
    text-decoration: underline;
    font-size:17px;
    transition: 0.5s ease-in-out;
}