:root{
    --primary: #E7D6C4;
    --secondary: #F7F1E4;

    --font-primary: "Italiana", sans-serif;
    --font-cursive: "Corinthia", cursive;
}

p, div.menu_item{
    font-size: 20px;
    font-weight: 600;
}
h2,h3{
    font-weight: bold;
}

*{
    font-family: var(--primary);
    letter-spacing: .1rem;
    box-sizing: border-box;
}
.secondary_btn_heart{
    position: relative;
}
.secondary_btn_heart::before{
    position: absolute;
    transform: translate(-50%, -50%);
    left: 0;
    top: 0;
    font-family: "Font Awesome 5 Free";
    font-weight: 900; 
    content: "\f004";
}
.secondary_btn_heart::after{
    position: absolute;
    transform: translate(50%, -50%);
    right: 0;
    top: 0;
    font-family: "Font Awesome 5 Free";
    font-weight: 900; 
    content: "\f004";
}

.inner-1300{
    max-width: 1300px;
    width: 100%;
}

div.header{
    position: fixed;
    padding: 16px;
    background-color: var(--primary);
    z-index: 99999;
}
    div.menu_holder{
        gap: 64px;
    }
    div.menu_item{
        width: 100%;
        text-align: center;
    }
    div.menu_item_names{
        font-size: 48px;
        font-family: var(--font-cursive);
    }
div.menu_holder_res{
    display: none;
}
div.res_menu{
    display: none;
}

div.hero{
    width: 100%;
    height: 100vh;
    background-size: cover;
    background-position: center;
}

div.timer{
    background-color: var(--secondary);
    flex-direction: column;
    gap: 32px;
    padding: 16px;
}
    div.timer_inner{
        width: 100%;
        justify-content: space-evenly;
    }
    div.timer_item{
        display: flex;
        flex-direction: column;
        text-align: center;
    }
        div.timer_item span{
            font-family: var(--font-cursive);
            font-size:  32px;
        }
        div.timer_item i span{
            font-family: var(--font-primary);
            font-style: normal;
            font-size: 64px;
        }
    div.timer_date{
        font-size: 48px;
    }

div.story{
    background-color: var(--primary);
    padding-bottom: 128px;
}
    div.story h2{
        font-size: 64px;
        font-family: var(--font-cursive);
    }
div.story_inner{
    position: relative;
    margin-top: 32px;
    gap: 32px;
}
    div.story_left{
        min-height: 500px;
    }
        div.story_left *{
            min-height: 500px;
        }
    div.story_divider{
        height: 100%;
        margin-left: 80px;
    }
        div.story_divider i{
            font-size: 24px;
        }
        div.vertical_divider{
            height: 400px;
            width: 2px;
            margin-top: -5px;
            margin-left: -1px;
            background: black;
        }
.story_img_1, .story_img_2{
    max-width: 400px;
    width: 100%;
    object-fit: cover;
}

.story_img_1{
    border-radius: 100px;
    margin-left: 80px;
}
.story_img_2{    
    max-width: 300px;
    z-index: 9;
    top: 100px;
    position: absolute;
    left: 0;
    /* top: 200px; */
}
div.program{
    background-color: var(--secondary);
}
div.program_title p{
    font-size: 32px;
    font-family: var(--font-cursive);
}
div.program_title h2{
    font-size: 64px;
}
div.program_container{
    justify-content: center;
    padding: 0 32px;
    flex-wrap: wrap;
    gap: 16px;
}
div.program_divider{
    width: 100%;
    height: 2px;
    background-color: black;
    transform: translateY(14px);
}
    div.program_item{
        min-width: 130px;
        text-align: center;
    }
        div.program_item i{
            font-size: 24px;
        }
    div.program_icon img{
        width: 64px;
        padding: 16px 0;
    }
.mt-32{
    margin-top: 32px;
}
div.info{
    background-color: var(--primary);
}
    div.info h2{
        font-size: 64px;
        font-family: var(--font-cursive);
    }
        div.info_inner h3{
            text-align: center;
            font-family: var(--font-cursive);
            font-size: 48px;
        }
        div.color_row{
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 32px;
            margin-bottom: 32px;;
        }
            div.color{
                width: 32px;
                height: 32px;
                border-radius: 100px;
            }
div.rsvp_yes{
    display: none;
    flex-direction: column;
}
    div.rsvp_yes h2{
        margin-bottom: 32px;
    }
    section.rsvp-section{
        display: none;
        flex-direction: column;
    }
    #saveBtn{
        display: none;
    }
div.rsvp_inner{
    text-align: center;
}
div.rsvp_inner p{
    font-size: 32px;
    font-family: var(--font-cursive);
}
div.rsvp_inner h2{
    font-size: 64px;
}
div.rsvp_inner .btns{
    gap: 64px;
    margin-top: 32px;
}
div.form_item{
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
}
    div.form_item select, div.form_item input, div.form_item textarea{
        width: 100%;
        padding: 8px 12px;
    }
.step_buttons{
    justify-content: space-between;
}
div.masters{
    background-color: var(--primary);
}
div.masters h2{
    font-size: 64px;
    font-family: var(--font-cursive);
}
    div.masters_inner{
        display: flex;
        justify-content: center;
        gap: 4em;
    }
    div.master_item{
        text-align: center;
    }
    div.master_item img{
        max-width: 200px;
        height: 250px;
        width: 100%;
        object-fit: cover;
        border-radius: 10px;
        margin-bottom: 16px;
    }


    div.bottom{
        background-color: var(--secondary);
        color: black;
    }
        div.bottom a {
            color: black;
        }


div.question{
    width: 100%;
    position: relative;
    background-color: var(--secondary);
}
    div.question_inner{
        background-color: var(--secondary);
        padding: 32px;
        border-radius: 50px;
        gap: 32px;
    }
        div.question_left h2{
            font-size: 64px;
            font-weight: 100;
            font-family: var(--font-cursive);
            color: #000;
        }
    div.question_divider{
        position: relative;
        margin: 0 auto;
        max-width: 600px;
        width: 100%;
        border-bottom: 2px solid #000;
    }
        div.question_right_list{
            margin: 0 auto;
            max-width: 800px;
            width: 100%;
        }

            div.question_item h3{
                font-size: 1.2em;
                margin-bottom: 8px;
                color: #000;
            }

            div.question_item i{
                color: #000;
            }
            div.question_item{
                cursor: pointer;
                width: 100%;
                padding: 16px;
                border: 1px solid #000;
            }
                div.question_item_top{
                    justify-content: space-between;
                }
                div.question_item_bottom{
                    display: none;
                    margin-top: 32px;
                }
                    div.question_item_bottom p{
                        font-size: 20px;
                        color: #000;
                    }


@media only screen and (max-width: 1340px) {
    div#resMenu{
        width: 100%;
        height: 100vh;
        position: fixed;
        z-index: 99999;
        background-color: var(--primary);
        flex-direction: column;
    }
    div.menu_holder_res{
        display: flex;
        align-items: center;
    }
        div.menu_holder_res i{
            font-size: 32px;
        }
        div.res_menu_icon{
            padding: 16px;
            width: 100%;
            display: flex;
            justify-content: flex-end;
            align-items: center;
        }
            div.res_menu_icon i{
                font-size: 32px;
            }

        div.res_menu_container{
            height: 100%;
            width: 100%;
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 48px;
            flex-direction: column;
        }
            div.menu_item_res{
                font-size: 32px;
                font-weight: bold;
            }
            div.menu_item_res_title{
                font-family: var(--font-cursive);
                font-size: 64px;
            }
    div.menu_holder{
        display: none;
    }
}


@media only screen and (max-width: 1030px) {
    div.story_inner{
        flex-direction: column;
    }
    div.story_left {
        width: 100%;
        display: flex;
        justify-content: center;
        gap: 32px;
    }
    .story_img_1{
        height: 450px;
        margin-left: 0;
        max-width: 100%;
        width: 100%;
        border-radius: 0;
    }
    .story_img_2{
        height: 450px;
        position: relative;
        top: 0;
        max-width: 100%;
        width: 100%;
    }
}


@media only screen and (max-width: 700px) {
    div.masters_inner{
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 32px;
    }
}
@media only screen and (max-width: 685px) {
    
    div.story_left {
        flex-direction: column;
    }
    .story_img_1{
        height: 250px;
    }
    .story_img_2{
        display: none;
    }
    div.info_inner{
        flex-direction: column;
    }
}
@media only screen and (max-width: 500px) {
    div.menu_item_names{
        font-size: 3em;
    }
    div.story_right{
        text-align: center;
    }
}
@media only screen and (max-width: 450px) {
    
    h2{
        font-size: 14vw;
    }
}