/* the stuff we use 100% of the time - good for templates */

* {
    margin: 0; padding: 0; border: 0; box-sizing: border-box; /* reset rule */
}

img, video, figure {
    max-width: 100%; /* a good default setting like the reset rule */
}

:root {
    font-size: 62.5% /* makes standard rem = px */
}

body {
    height: 200vh;
    max-width: 1800px; 
    background-image: linear-gradient(pink, #c77dff, #70d6ff);
}

#alert {
    width: 95%;
    border: 2px solid red;
    font-size: small;
    margin: 10px auto;
    background-color: antiquewhite;
}

    .alert {
        color: red;
        text-align: center;
        font-size: 2vh;
    }

#container {
    width: 95vw;
    height: 95%;
    margin: 2vh auto;
    /* border: 2px solid orange; */
}  

    #top {
        height: 20vh;
        margin-bottom: 10px;
        font-size: 4rem;
        line-height: 15vh;
    }

        .logo {
            height: 13vh; aspect-ratio: 4/4;
            float: left;
            padding: 1vh 0 1vh 1vw;
            position: absolute;
        }

        #title {
            border: 2px solid purple;
            width: 100%;
            height: 65%;
            background-image: radial-gradient(Blue, lightblue);
            
        }

            #store_name {
                max-height: 100%;
                text-align: center;
                font-family: 'Rochester', cursive;
                font-size: 6vh;
                color: #034403;
                line-height: 5vh;
                padding-top: 1vh;
            }

                #slogan { /*something is off */
                    max-height: 100%;
                    max-width: 50%;
                    margin-top: 1.5vh;
                    margin-left: 45%;
                    text-align: center;
                    font-size: 3vh;
                    color: #034403;
                    line-height: 5vh;
                    padding-right: 5vw;
                }

            ul {
                display: flex;
                list-style-type: none; 
                justify-content: space-evenly;
            }

                #main-nav > li {
                    display: block;
                    border: 2px solid purple;
                    width: 22%; height: 20%;
                    text-align: center;
                    line-height: 5vh;
                    font-size: 3vh;
                    background-image: radial-gradient(#c77dff, #70d6ff, #034403);
                    margin: 1vh auto 1vh auto;
                    border-radius: 20px;
                }

                    #main-nav a {
                        display: block;
                        width: 100%; height: 100%;
                        text-decoration: none;
                        color: purple;
                        font-weight: bold; 
                    }

            .middle {
                height: 165vh;
                /* border: 2px solid red; */
                display: flex; 
            }

                #sidebar_nav {
                    height: 65vh;
                    width: 20vw;
                    font-size: 2rem;
                    border: 5px solid hotpink;
                    background-color:#83C5BE;
                    margin-top: 5vh;
                    
                }

                    #sidebar_nav ul {
                        display: block;
                        height: 165vh;
                        width: 95%;
                        font-size: 2rem;
                        margin: auto;
                        justify-content: space-between;
                    }

                        #sidebar_nav a {
                            margin-top: 5%;
                            display: block;
                            text-decoration: none;
                            padding: 2%;
                            border: 2px solid purple;  
                            background-color: #c77dff;
                            color: white;
                        }

                            #sidebar_nav a:hover {
                                background-color: darkorchid;
        
                            }

        #mainbody {
            margin: 2vh auto 0 5vw;
            width: 65vw;
            height: 100%;
            border: 5px solid hotpink;  
            display: block;  
            background-color:#83C5BE;
                          
        }

            div #family_photo {
                
                text-align: center;  
               
            }
                .photo {
                    border: 2px solid green;
                    flex-direction: row wrap;
                    height: 50vh; 
                    margin-top: 2vh;
                }

                section {
                    text-align: center;
                   
                }

                    h4 {
                        font-family: 'Rochester', cursive;
                        font-size: 5rem;
                        margin-top: 5vh;
                    }
                
                        section p {
                            margin-top: 3vh;
                            padding: 0 2vw 0 2vw;
                            font-family: 'Times New Roman', Times, serif;
                            font-size: 2rem;
                        }

                


                
