body{
    font-family: 'Montserrat', sans-serif;
    margin: 0px;
    background-color: #eeeeee;
}

/* Navigation bar on top of every page */
.navbar{
    font-family: 'ABeeZee', 'Montserrat', sans-serif;
    font-weight: bolder;
    border-bottom: 3px solid #d6d5d5;
    background-color:rgba(255,255,255,0.9);
    backdrop-filter: blur(10px);
    transition: all 0.5s;
}
.topNavBar{
    position: absolute;
    top:0;
    background-color: transparent !important;
    border: transparent !important;
    backdrop-filter:unset;
}
.navbar-brand{
    background-color: transparent !important;
}
.topNavBar .navbar-brand{
    background-color: #f2f2f2 !important;
    transition: all 0.5s;
}
.nav-link {
    display:inline-block;
    position: relative;
    text-align: center;
    margin-right: 16px;
    color: #004403 !important;
    transition: color 0.5s; 
    padding-right: 0.5rem!important;
    padding-left: 0.5rem !important;
}
.nav-link:hover{
    color:#5DB66D !important;
}
.nav-link::after{
    content: "";
    opacity:0;
    transition: all 0.5s;
    position: absolute;
    left: 0;
    bottom: 2px;
    width: 100%;
    height: 2px;
    background: #5DB66D;
}
.nav-link:hover::after{
    opacity: 1;
    transform: translate(0, 4px);
}
.nav-item{
    display:inline-flex;
    flex-direction:column;
    align-self:center;
    text-decoration: none !important;
}
.active-nav-link{
    border-bottom: 2px solid #5DB66D !important;
    color:#5DB66D !important;
}
.dropdown-menu{
    border: transparent;
    background-color: rgba(235, 233, 233, 0.95);
}
.dropdown-item{
    color: #004403 !important;
    letter-spacing: 1px;
}
.dropdown-item:hover{
    background-color: rgba(174, 206, 179, 0.9) !important; 
}
/* EZ Fresh on the top left in the navigation bar */
.navbar-brand{
    text-decoration: none;
    font-size: 1.5em; 
    color:#004403 !important;
    letter-spacing: 1px;
}
/* Make the dropdown appear on hover */
.navbar .nav-item .dropdown-menu{ 
    display: none; 
}
.navbar .nav-item:hover .dropdown-menu{
    display: block; 
}
.navbar .nav-item .dropdown-menu{ 
    margin-top:0; 
}

/* Login */
.loginForm{
    font-family: 'ABeeZee', 'Montserrat', sans-serif;
    background-image: url(assets/flower-4865379_1920.png);
    background-size: cover;
    background-repeat:no-repeat;
    position:relative;
    display:flex;
    justify-content: center;
    min-height: 100vh;
    min-width: auto;
}
.formMsg{
    text-align: center;
    margin: 1rem;
    background-color: #eeeeee;
}
.loginInput{
    margin:0.5rem;
    padding:0.5rem;
    border-radius: 1rem 0rem 1rem 0rem;
    transition: all 0.2s;
    border: transparent !important;
    background-color: rgba(255, 255, 255) !important;
    outline:none;
}
.loginInput:focus{
    background-color: #ffffff;
}
.formOption{
    margin-bottom: 0.5rem;
    background-color: #eeeeee;
}
.formInputErr{
    box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25) !important; 
}
.formErrMsg{
    color:#dc3545;
    font-size:0.85em;
}
.formHidden{
    display:none !important;
}

/* The body of the home page */

/* Opening section */
.startsec{
    display: flex;
    justify-content: center;
    align-content: center;
    padding-top: 80px;
    background-image: url(assets/leaves-5643327_1920.png);
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
}
.startsectag{
    display: flex;
    justify-content: left;
    flex-wrap:wrap;
    font-size:small;
    text-align: center;
    line-height: 333%;
    padding-right: 31%;
    padding-top: 17%;
    padding-bottom: 17%;
    padding-left: 20%;
    background-image: url(assets/sec-framed-price-tag.png);
    background-repeat: no-repeat;
    background-position:center;
    background-size:contain;
}
/* Weekly Recipe Haul */
.recipeCredit{
    font-size:small;
    font-style:italic;
}
/* Footer */
.endFooter{
    font-family: 'ABeeZee', 'Montserrat', sans-serif;
    position:relative;
    left: 0;
    bottom: 0;
    width: 100%;
    background-color: #e0e0e0;
    background-image: linear-gradient(to bottom, rgba(255,255,255,0.50) 0%, rgba(0,0,0,0.50) 100%), radial-gradient(at 50% 0%, rgba(255,255,255,0.10) 0%, rgba(0,0,0,0.50) 50%);
    background-blend-mode: soft-light,screen;
    color:#ffffff;
}
.footercol{
    display:flex;
    flex-direction:column;
    color:#004403;
}

/* About page */
.parasectag{
    background-image: url(assets/clean-price-tag.png);
    background-position:top !important;
    background-size: 100% 100%;
    text-align: left;
    font-size: 1em !important;
    line-height: 22px;
    padding-top:14%;  /*15*/
    padding-bottom:10%;  /*15*/
    padding-left:18%;  /*40*/
    padding-right:33%;  /*30*/
}
.profile:hover{
    border: 10px solid rgba(196, 196, 196, 0.5);
    width:80%;
    height:auto;
    transition: all 0.3s;
}
.profile-icon:hover::after{
    opacity: 1;
    transition: all 0.3s;
}
.profile-icon::after{
    content:"";
    opacity:0;
    background-image: url(assets/linkedin-icon.png);
    background-size: 40px;
    height: 40px;
    width: 40px;
    position: absolute;
    bottom: -84px;
    left: 69px;
}

/* Product Page */
.productstart{
    background-image: url(assets/leaves-5643327_1920.png);
    background-repeat: no-repeat;
    background-size: cover;
    font-family: 'ABeeZee', 'Montserrat', sans-serif;
    min-height:500px;
}
.productCaption{
    font-size:small;
    color:black;
    position:absolute;
    height: auto;
    max-width:50%;
    padding:5%;
}
/* Timeline from https://www.w3schools.com/howto/howto_css_timeline.asp*/
/* The line */
.timeline {
    font-family: 'ABeeZee', 'Montserrat', sans-serif;
    font-size: 0.8em;
    position: relative;
    max-width: 1000px;
    margin: 0 auto;
}
.timeline::after {
    content: '';
    position: absolute;
    width: 6px;
    background-color:#bbe7c3;
    top: 0;
    bottom: 0;
    left: 50%;
    margin-left: -3px;
}
/* Container around content */
.timeContainer {
    padding: 10px 40px;
    position: relative;
    background-color: inherit;
    width: 50%;
}
/* The circles on the timeline */
.timeContainer::after {
    content: '';
    position: absolute;
    width: 25px;
    height: 25px;
    right: -13px;
    background-color:rgb(246, 255, 250);
    border: 4px solid #eeeeee;
    top: 15px;
    border-radius: 50%;
    z-index: 1;
}
/* Place the container to the left */
.left {
    left: 0;
}
/* Place the container to the right */
.right {
    left: 50%;
}
/* Add arrows to the left container (pointing right) */
.left::before {
    content: " ";
    height: 0;
    position: absolute;
    top: 22px;
    width: 0;
    z-index: 1;
    right: 30px;
    border: medium solid #e5ebe5;
    border-width: 10px 0 10px 10px;
    border-color: transparent transparent transparent #e5ebe5;
}
/* Add arrows to the right container (pointing left) */
.right::before {
    content: " ";
    height: 0;
    position: absolute;
    top: 22px;
    width: 0;
    z-index: 1;
    left: 30px;
    border: medium solid #e5ebe5;
    border-width: 10px 10px 10px 0;
    border-color: transparent #e5ebe5 transparent transparent;
}
/* Fix the circle for containers on the right side */
.right::after { 
    left: -13px; 
}
/* The actual content */
.timeContent {
    padding: 20px 30px;
    background-color:#e5ebe5;
    position: relative;
    border-radius: 1rem 0rem 1rem 0rem;
}
/* Media queries - Responsive timeline on screens less than 768px wide */
@media screen and (max-width: 768px) {
    /* Place the timelime to the left */
    .timeline::after {
        left: 31px;
    }
    /* Full-width containers */
    .timeContainer {
        width: 100%;
        padding-left: 70px;
        padding-right: 25px;
    }
    .smallContainer{
        width:70% !important;
        left:0% !important; 
    }
    /* Make sure that all arrows are pointing leftwards */
    .timeContainer::before {
        left: 60px;
        border: medium solid #e5ebe5;
        border-width: 10px 10px 10px 0;
        border-color: transparent #e5ebe5 transparent transparent;
    }
    /* Make sure all circles are at the same spot */
    .left::after, .right::after {
        left: 15px;
    }
    .smallleft::after, .smallright::after{
        left: 4%;
    }
    /* Make all right containers behave like the left ones */
    .right {
        left: 0%;
    }
    .smallright{
        left: 4%;
    }
    /* Centers login placement */
    .form{
        justify-content:center;
        align-items: center;
    }
}
.faq-tab:hover{
    background-color: rgba(255, 255, 255,0.5);
}
.faq-tab::after{
    content: "";
    opacity:0;
    width: 0% !important;
    left: 43%;
    bottom: -2px;
    height: 4px;
}
.faq-tab:hover::after{
    opacity: 1;
    width:100% !important;
    transform: translate(-43%, 0px);
}
  
/* General CSS */
.icon{
    font-family: 'ABeeZee', 'Montserrat', sans-serif;
    display:flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    text-align:center;
}
.caption{
    font-size:medium;
    background-color:#eeeeee;
}
.heading{
    font-size: 2em;
    color:#004403;
    font-weight: bold;
}
hr{
    display:block;
    width:60%;
    border-top:2px solid #5DB66D;
    margin-top:0rem;
}
.sec{
    display: flex;
    align-items: center;
    justify-content: center;
}
.secimg{
    display: flex;
    align-self: center;
    justify-content: center;
}
.card{
    text-align: center;
    background-color: transparent;
    border:transparent;
}
.card-img-top{
    border-radius: 50%;
    border: 5px solid rgba(163, 199, 166, 0.5);
    background-position: center;
}
.card-title{
    color:#474747;
    font-weight: bold;
    margin-bottom:0.5rem;
    font-size:1.1em;
}
.card-text{
    font-size: 0.9em;
}
.modal-title{
    font-weight: bold;
    color:#004403";
}
/* The highlight brush stroke */
.highlight{
    background: url(assets/green-highlight.png);
    background-repeat: no-repeat;
    background-size: 0% 95% !important;
    padding: 8px 0;
    transition: all 0.3s;
}
.highlight.siteLoaded{
    background-size: 100% 95% !important;
}
.boxText{
    position: relative;
    z-index:2;
}
.boxText::before{
    content:'';
    position:absolute;
    background: #f3f3f3 !important;
    height:40%;
    width:0% !important;
    z-index:-1 !important;
    bottom:2px;
    left:-12px;
    transition: 1000ms ease;
}
.greenBack.boxText::before{
    background: #c3ddc8 !important;
}
.fullBack.boxText::before{
    height:100% !important;
}
.siteLoaded.boxText::before{
    width:calc(100% + 20px) !important;
}
/* Leaves */
.leave{
    display:inline-block;
    padding:0.5rem 1rem;
    font-weight: bold;
    letter-spacing:1px;
    background-color:#c0d1c0;
    border-radius: 1.5rem 0rem 1.5rem 0rem;
    border: 5px solid #e6e9e6;
}

/* Change font-size for price-tag background text */
@media (min-width: 375px){
    .startText{ font-size:medium; }
}
@media (min-width: 576px){
    .startText{ font-size:x-large; }
}
@media (min-width: 768px){
    .startText{ font-size:xx-large; }
}
@media (min-width: 992px){
    .startText{ font-size:large; }
}
@media (min-width: 1200px){
    .startText{ font-size:x-large; }
}
@media screen and (min-width:768px){
    /* Place the chart in the product page */
    .chart{
        position:absolute;
        top: -30%;
    }
    /* Fix login placement */
    .form{
        padding-top:8% !important;
    }
}

/* Change color for different action handlers */
.prettyLink{
    color:#004403;
    text-decoration:none;
    border-bottom: 1px solid transparent;
    transition: all 0.5s;
}
.prettyLink:hover{
    border-bottom: 2px solid #5DB66D !important;
    color:#5DB66D !important;
}
.navbar-toggler:focus,  input:focus, .btn:focus{
    border-color:#5DB66D !important;
    outline: none;
    box-shadow: 0 0 0 0.25rem rgba(95,216,64,0.25) !important; 
}
.btn{
    font-family: 'ABeeZee', 'Montserrat', sans-serif;
    font-weight: bolder;
    border: 2px solid #72b67e; 
    padding: 0.5rem 1rem;
    background-color: rgba(114, 182, 126, 0.1);
    color:#5c915f;
    border-radius: 1.5rem;
    transition: color 0.5s;
}
.btn:hover{
    background-color:#72b67e !important; 
    color:#ffffff !important;
}
.form-check-input:checked {
    background-color: #5DB66D;
    border-color: #5DB66D;
}
.smicon:hover{
    transition: 0.5s;
    filter:invert(77%);
}