body {
    padding: 0;
    margin: 0;
    background: #f2f6e9;
    min-width: 320px;
}

/* default fonts */
h1, h2, h3 {
    font-family: "Montserrat", serif;
    font-weight: 700;
    font-size: 3em;
    color: #333;
    margin-top: 10px;
    text-align: center;
    text-transform: uppercase;
}

h1{
    font-size: 3em;
}
h2 {
    font-size: 2.6em;
}
h3 {
    font-size: 1.4em;
}
p { 
    font-weight: 400;
    font-size: 1em;
}

/* ------ */
.navbar {
    background-color:#1F2F39;
}

.nav-link, .navbar-brand {
    color: #fefefa;
    cursor: pointer;
    margin-left: 10px;
    font-family: "Montserrat", sans-serif;
    font-size: 1em;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.nav-link {
    margin-right: 1em !important;
}
.nav-link:focus, .navbar-brand:hover, .nav-link:hover{
    color: #C7A997;
}

/* nav links pos */
.navbar-collapse {
    margin-right: 125px;
    justify-content: center;
    align-items: center;
}

@media only screen and (max-width: 768px)
 {
    .navbar-collapse{
        margin-right: 0;
    }
    .nav-link{
        margin-right: 0.5em !important;
    }
    .nav-item a{
        font-size: 0.9em;
    }
 }

.header {
    background-image: url('images/header-background.jpg');
    background-size: cover;
    background-position: center;
    position: relative;
}
.overlay {
    position: absolute;
    min-height: 100%;
    min-width: 100%;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.5); /*set lightness of bg */
}

.description {
	left: 50%;
	position: absolute;
	top: 45%;
	transform: translate(-50%, -50%);
	text-align: center;
}
.description h1 {
	color: #C7A997;
    text-shadow: 0px 0px 10px #000;
}
.description p {
	color: #fefefa;
    font-size: 1.2em;
	line-height: 1.5;
}
.description button {
    border:1px solid #BB9882;
    background: #BB9882;
    border-radius: 5px;
    color:#fff;
    box-shadow: 0px 0px 10px 0.5px #000;;
}
.description button:hover {
	border:1px solid #fff;
    background:#fff;
    color:#333;
}

.features .row {
    margin-left: auto;
    margin-right: auto;
}
.feature-title {
    font-size: 1.7em;
	color: #333;
	margin-bottom: 20px;
	text-transform: uppercase;
}
.features {
    margin-top: 20px;
    margin-bottom: 10px;
}
.features img {
	-webkit-box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
	-moz-box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
	box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
	margin-bottom: 16px;
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.input-wrapper {
    display: flex;
    justify-content: center;
}
.input-wrapper .container-input p {
    text-align: center;
}
.form-group{
    width: 100%;
    margin-bottom: 0.75em;
}
.container-input{
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 500px;
}
.btn-secondary{
    margin-bottom: 25px;
    background-color: #1F2F39;
}

@media only screen and (max-width: 768px)
 {
    .description{
        width: 70%;
    }
    .features{
        padding: 0;

    }
    .feature-box, .input-wrapper{
        text-align: center
    }
    .feature-title{
        font-size: 1.4em;
    }
    .features p{
        font-size: 1em;
        margin-left: auto;
        margin-right: auto;
    }
    .form-group{
        width: 90%;
        margin-bottom: 0;
    }
 }

@media only screen and (max-width: 425px)
 {
    .description h1{
        font-size: 2.6em;
    }
   .feature-title{
    font-size: 1.7em;
    margin-bottom: 5px;
   }
   .feature-box{
    padding-left: 0;
    padding-right: 0;
   }
   .features p {
    width: 90%;
   }
   .input-wrapper{
    margin-top: 10px;
   }
   .form-group{
    width: 100%;
   }
 }

/* menu page */
.menu-title{
    margin-top: 10px;
    margin-bottom: 5px;
}
.menu-row{
    align-items: stretch;
}

.card{

    margin-top: 10px;
    margin-bottom: 25px;
    box-shadow: 0.5px 0.5px 2px rgba(0, 0, 0, 0.4);
}
.menu-card-img{
    width: 100%;
    height: 225px;
    object-fit: cover;
}
.card-price{
    font-size: 1.3em;
    margin-bottom: 20px;
}
.btn-order{
    margin: auto;
    width: auto;
    margin-top: 20px;
    margin-bottom: 20px;
    background-color: #1F2F39;
    color: white;
    text-decoration: none;
    padding: 10px 15px 10px 15px;
    border-radius: 10px;
    border: none;
}
.btn-order:hover{
    background-color: #395669;
}

@media only screen and (max-width: 768px)
 {
    .menu-container{
        text-align: center;
    }

    .menu h2{
        font-size: 2.4em;
    }

    .card-title{
        font-size: 1.5em;
    }

    .card p{
        font-size: 1.1em;
    }
 }
/* gallery, about page */
.gallery-body{
    width: 90%;
    margin-top: 20px;
    margin-bottom: 10px;
}
.gallery-body .text-top{
    text-align: center;
    width: 70%;
    margin-left: auto;
    margin-right: auto;
}

.text-top h1{
    font-size: 2.6em;
}
.text-top p{
    font-size: 1.1em;
}
.gallery-body a{
    text-decoration: none;
}
.post-text h4{
    font-size: 1.4em;
}
.gallery-form{
    margin: auto;
    margin-top: 30px;
    margin-bottom: 10px;
    width: 60%;
}

.gallery-form .form-control{
    margin-bottom: 10px;
}

.img-input{
    width: 40%;
    margin-left: auto;
    margin-right: auto;
}
    .overlay-about{
    position: absolute;
    min-height: 100%;
    min-width: 100%;
    left: 0;
    top: 0;
    background: rgba(0, 0, 0, 0.6); /*set lightness of bg */
}

    .about-page-header{
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: url('images/about-page-header.jpg');
    background-size: cover;
    background-position: center;
    position: relative; 
    height: 400px; 
}

.about-header-text{
    position: relative; /*reminder: this is so that the text doesnt get affected by the overlay*/
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.about-page-header h1{
    color: #C7A997;
    font-size: 4em;
    text-shadow: 0px 0px 25px #000;
}
.about-page-header p{
    color: #fefefa;
    font-size: 1.3em;
    line-height: 1.5;
    width: 50%;
}

.text-holder{
    text-align: center;
    padding-top: 15px;
}
.text-holder h1{
    font-size: 2.2em;
    margin-top: 0;
}
.text-holder p{
    font-size: 1.1em;
    width: 90%;
    margin-top: 10px;
    margin-left: auto;
    margin-right: auto;
}

.grid-container {
    display: flex;
    justify-content: center;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    align-items: center;
    margin-bottom: 10px;
  }
  .grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    flex-wrap: wrap;
  }
  .grid-item{
    max-width: 500px;
    margin-left: 10px;
    margin-right: 10px;
  }

  .img-about{
    width: 100%;
  }

  @media only screen and (max-width: 768px)
 {
    .gallery-body{
        width: 90%;
        text-align: center;
    }
    .gallery-form{
        width: 90%;
    }
    .text-top h1{
        font-size: 2.5em;
    }
    .about-page-header h1{
    color: #C7A997;
    font-size: 3em;
    text-shadow: 0px 0px 25px #000;
    }
    .about-page-header p{
    font-size: 1.2em;
    width: 80%;
    }
    .grid-container{
        width: 90%;
    }
    .grid-item{
        max-width: 800px;
    }
    .text-holder{
        align-items: center;
        text-align: center;
    }
 }

@media only screen and (max-width: 425px)
{
    .gallery-body{
        width: 100%;
    }
    .gallery-form{
        width: 95%;
    }
    .grid-container{
        width: 100%;
    }
    h2{
        font-size: 2.2em;
    }
}
/* contact page */
.contact-title{
    margin-top: 20px;
    color: #333;
	font-size: 2em;
	margin-bottom: 20px;
}
.contact-form{
    margin: auto;
    margin-top: 30px;
    margin-bottom: 10px;
    width: 50%;
}
.form-check-input:checked{
    background-color: #1F2F39;
}
.form-label{
    font-family:'Gill Sans', 'Gill Sans MT', 'Trebuchet MS', sans-serif;
    font-size: 1.1em;
}
.contact-form .form-control{
    height: 45px;
    margin-bottom: 20px;
}
.btn{
    margin-left: auto;
    margin-right: auto;
    width: auto;
    margin-top: 10px;
    margin-bottom: 20px;
    background-color: #1F2F39;
    color: white;
    padding: 10px 25px 10px 25px;
    border-radius: 20px;
    border: none;
}
.btn:hover{
    background-color: #395669;
}
.gender-input{
    margin-bottom: 10px;
}

@media only screen and (max-width: 768px)
 {
    .contact-form{
        width: 80%;
    }
 }

@media only screen and (max-width: 425px)
 {
    .contact-form{
        width: 90%;
        text-align: center;
    }

    .form-label{
        font-size: 1.2em;
    }
 }

/* footer */
.page-footer {
    background-color: #222;
    color: #ccc;
    padding-top: 20px;
    text-align: center;
}
.footer-copyright {
    color: #666;
    padding: 20px 0;
}
.footer-text{
    width: 55%;
}
i{
    font-size: 1.4em;
    padding: 20px;
}

@media only screen and (max-width: 768px)
 {
    .page-footer p{
        font-size: 0.9em;
    }
    .footer-text{
    width: 70%;
    }
    .footer-copyright{
        padding: 10px 0;
    }
    i{
        font-size: 1.2em;
        padding: 15px;
    }
 }

 @media only screen and (max-width: 425px)
 {
    .footer-text{
        width: 90%;
    }
    i{
        font-size: 1.1em;
        padding: 10px;
    }
    .footer-copyright{
        font-size: 0.9em;
    }
 }