html {
    scroll-behavior: auto;
}


body {
    margin: 0;
    padding: 0;
}

#detailsContainer h1 {
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 3em;
    text-align: center;
}

.giftMessage
{
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1em;
    text-align: center;
    width: 80%;
}

#giftDiv {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: 1rem;
}




#details {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 1rem;
}

#details h2 {
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2em;
    text-align: center;
}

#details div {
    width: 90%;
    padding: 1rem;
    text-align: center;
}

.guestNameText {
    display: flex;
    width: 80%;
    padding: 1rem;
    justify-content: space-between;
}

#banner {
    background-image: url('stock5.jpg');
    background-size: cover;
    background-position: center;
    /* white font */
    height: 100vh;
    padding: 10px;

}

#currentState{
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

#currentStateHeading {
    font-family: "Quattrocento", serif;
    font-weight: 300;
    font-style: normal;
    font-size: 1.5em;
    text-align: center;
}

#responseForm {
    width: 90%;
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 1rem;
}

#responseForm button:hover {
    cursor: pointer;
}

#responseForm div {
    display: flex;
}


.buttonDiv {
    width: 70%;
    display: flex;
    justify-content: right;
}

.nameDiv {
    width: 30%;
}



#responseHeader {
    display: flex;
}

#responseHeader div {
    margin: 1rem;
}

#responseHeader p:hover {
    cursor: pointer;
}



#backButton {
    width: 30%;
    height: 15%;
    padding-left: 2rem;
    padding-top: 1rem;
}

#searchContainer {
    display: flex;
    justify-content: center;
    align-items: center;
}

.rsvpResponse {
    display: flex;
    justify-content: space-between;
    margin: 4px;
    width: 100%;
}


.rsvpResponse button {
    border: none;
    margin: 4px;
    width: 100px;
    height: 40px;
}


.responseButton {
    border: none;
    margin: 4px;
    width: 124px;
    height: 40px;
    color: black;
}

.responseButton:hover {
    cursor: pointer;
    background-color: grey;
}


.selected {
    background-color: black;
    color: white;
    padding: 0.5rem;
    cursor: pointer;
    border-color: black;
}

.deselected:hover {
    cursor: pointer;
    background-color: grey;
    color: black;
}

.deselected {
    color: black;
}

#suggestions {
    display: flex;
    flex-direction: column;
    width: 100%;
}


#nameSearch {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 50vh;
    width: 90%;
}

#nameSearch h2 {
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2em;
    text-align: center;
}


#nameSearch input {
    padding: 1rem;
    margin: 1rem;
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1em;
    border: 0px;
    width: 90%;

}

#searchBar {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: red;
    width: 100%;
}

#inputBar {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 90%;
}


#inputBar form {
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    color: white;
    padding: 0.6rem;
}

#inputBar form input {
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    background-color: #E2DED2;
}


#inputBar form input:focus {
    outline: none;
}

#searchIcon {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    width: 10%;
    height: 100%;
}


#nameSearch form {
    display: flex;
    justify-content: center;
    align-items: center;
}

#formContainer {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-radius: 15px;
    border: 1px solid black;
    width: 80%;
}

#headingContainer{
}

#inputContainer {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 95%;
}

.topBorder {
    border-top: 1px solid black;
}

#resultsContainer {
    width: 95%;
}

#resultsContainer div {
    padding: 0.1rem;
}

#resultsContainer div:hover {
    background-color: black;
    color: white;
    cursor: pointer;
    border-radius: 5px;
}


#countdown div {
    margin: 2rem;

}

#timeline {
    display: flex;
    flex-direction: column;
    background-color: #E2DED2;
}

#timelinePhoto{
    display: flex;
    background-image: url('schedule.jpg');
    background-size: cover;
    background-position: center;
    flex-grow: 1;
    height: 100vh;
    justify-content: center;
    align-items: center;
    color: white;
    font-size: 1em;
}

#timelineEvents {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    height: 80%;
}

#timelineInfo {
    display: flex;
    justify-content: center;
    align-items: center;
}



.time {
    font-family: "Quattrocento", serif;
    font-weight: 600;
    font-style: normal;
    font-size: 1.5em;
}

.event {
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.3em;
}

#timelineEvents div {
    margin: 1rem;
    text-align: center;
}


#linksMobile div {
    margin: 1rem;
}


#splash {
    font-family: "Quattrocento", serif;
    font-weight: 100;
    font-style: normal;
    font-size: 2em;
}


#images {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    height: 100%;
    width: 50%;
}

#mobileMenu {
    height: 100vh;
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 20px;
    z-index: 100;
}

#invitationMessage{
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    align-content: center;
    flex-grow: 1;

    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1em;
}


#invitation {
    display: flex;
    align-items: center;
    height: 100vh;
    background-color: #E2DED2;
    text-align: center;
}

#leftImage, #rightImage {
    display: none;
}

#inviteImage {
    background-image: url('invite.jpg');
    background-size: cover;
    background-position: center;
    height: 100%;
    width: 100%;
}

#mobileNav {
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
    align-items: center;
    justify-content: center;
    position: relative;
    gap: 4%;
}

.rsvpButton {
    background-color: black;
    color: white;
    width: 15%;
    text-align: center;
    padding: 1rem;
    margin-top: 4rem;
}

.rsvpButton:hover {
    cursor: pointer;
}

#searchBody {
    display: flex;
    flex-direction: column;
    background-color: #E2DED2;
}

#countdown {
    display: flex;
    justify-content: center;
    align-items: center;


    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1em;
}

#rsvp {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 1rem;
    height: 100vh;
}

#rsvp h1 {
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2em;
}

#deHarteMap{
    height: 70vh;
    width: 70vw;
}

.deharteAddress {
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1em;
}

gmp-map {
  height: 100%;
  width: 100%;

}

#rsvp Button {
    background-color: black;
    color: white;
    text-align: center;
    padding: 1rem;
    margin-top: 8rem;
    width: 124px;
    font-size: 1em;
}


#close {
    position: absolute;
    left: 0;
    top: 0;
}

#inviteHeader {
  font-family: "Quattrocento", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1em;
}


#secondsTimer {
    display: none;
}

#locationPhoto {
    display: flex;
    background-image: url('de_harte.jpg');
    background-size: cover;
    background-position: center;
    flex-grow: 1;
    height: 100vh;
    justify-content: center;
    align-items: center;
    color: white;
    font-size: 2em;
}

#location {
    display: flex;
    flex-direction: column;
    text-align: center;
}

#locationInfo {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    padding: 3rem;
    background-color: #E2DED2;
}

#locationInfo h2 {
    font-family: "Quattrocento", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2em;
}

#desktopMenuDiv{
    display: none;
}

#nav {
    display: flex;
    padding: 10px;
    z-index: 100;
    height: 1%;
    visibility: hidden;
}



#splash {
    height: 90%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}


#mobileBurger {
    padding: 10px;
}

#mobileBurger img {
    width: 40px;
    color: white;
}


a {
    margin: 10px;
    color: black;
    text-decoration: none;
}

@media screen and (min-width: 768px) {



    .rsvpResponse {
        width: 20%;
        margin-bottom: 1rem;
    }


    #nav {
        visibility: visible;
    }

    #mobileBurger {
        display: none;
    }

    #mobileNav {
        display: none;
    }

    #banner {
        background-image: url('landing.jpg');
    }

    #mobileMenu {
        display: none;
    }

    #secondsTimer {
        display: block;
    }

    
    #invitation {
        align-items: center;
        text-align: center;
    }

    #invitationMessage p {
        font-size: 1.5em;
    }

    #inviteHeader {
      font-size: 4em;
    }


    #countdown {
        font-size: 3em;
        padding: 50px;
        gap: 10px;
    }

    #countdown div {
        margin: 5rem;
    }


    #splash {
        font-size: 4em;
        color: white;
    }

    #location {
        flex-direction: row;
        height: 100vh;
        width: 100%;
        background-color: black;
    }

    #locationPhoto {
        width: 50%;
    }

    #locationInfo {
        height: auto;
        width: 50%;
    }

    #timeline {
        flex-direction: row;
    }

    #timelinePhoto {
        background-position: center;
        background-repeat: no-repeat;

    }

    #timelineInfo {
        width: 50%;
    }

    #rsvp {
        height: auto;
    }

    #desktopMenuDiv {
        display: flex;
        justify-content: space-between;
    }

    #rsvpButtonMenu {
        background-color: black;
        color: white;
        width: 5%;
        text-align: center;
        padding: 0.5rem;
    }

    #rsvpButtonMenu:hover {
        cursor: pointer;
    }

    #formContainer {
        width: 50%;
    }


    #responseForm {
        width: 100%;
    }

    #currentState {
        width: 100%;
    }


    a {
        color: white;
    }

    .guestNameText {
        width: 20%;
    }

    #details {
        flex-direction: row;
    }


    #details div {
        width: 33%;
    }


    #deHarteMap{
        height: 70vh;
        width: 35vw;
    }


}
