/*@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,200;0,300;0,400;0,600;0,700;0,800;0,900;1,200;1,300;1,400;1,600;1,700;1,800;1,900&display=swap');*/

html, body {
    height: 100%;
}
#app {
    height: 100%;
}

#app nav.navbar {
    font-family: Nunito;
    font-style: normal;
    font-weight: 600;
    font-size: 16px;
    line-height: 22px;
}

#app nav.navbar .navbar-nav .nav-item .nav-link {
    color: #222226;
}
#app nav.navbar .navbar-nav .nav-item.active .nav-link,
#app nav.navbar .navbar-nav .nav-item .nav-link.active {
    color: #3490DC;
    position: relative;
}
#app nav.navbar .navbar-nav .nav-item.active .nav-link:after,
#app nav.navbar .navbar-nav .nav-item .nav-link.active:after {
    position: absolute;
    height: 3px;
    content: '';
    bottom: -16px;
    left: 0;
    right: 0;
    background: #3490DC;
    border-radius: 4px;
}

#app nav.navbar .navbar-nav .nav-item .nav-link.login:hover {
    color: #3490DC;
}
#app nav.navbar .navbar-nav .nav-item .nav-link.register {
    color: #3490DC;
    border: 1px solid #3490DC;
    box-sizing: border-box;
    border-radius: 5px;
    padding: 6px 27px;
}
#app nav.navbar .navbar-nav .nav-item .nav-link.register:hover {
    background-color: #E1EEFA;
}
.required-param,
.form-group .error {
    color: red;
}

#app main {
    flex: 1 0 auto;
}

footer {
    border-top: 1px solid #d7d7d7;
    margin-top: 100px;
}
footer .payment-icons-wrapper {
    padding-top: 20px;
}
footer .payment-icons {
    width: 100%;
    min-height: 30px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 10px 0 20px;
    align-items: center;
}
footer .payment-icons img {
    margin: 0 10px;
    height: 20px;
    opacity: 0.7;
}
footer .payment-icons img.visa{ height: 30px; }
footer .payment-icons img.master-card{ height: 25px; }
footer .payment-icons img.american-express{ height: 45px; }
footer .payment-icons img.jcb{ height: 35px; }
footer .payment-icons img.amazon{ height: 15px; }

footer .upper-footer {
    border-top: 1px solid #d7d7d7;
    background-color: #ffffff;
    padding-top: 20px;
    padding-bottom: 20px;
    color: #4c4c4c;
}
footer .upper-footer .footer-header {
    color: #1e1e1e;
    font-weight: bold;
    font-size: 16px;
}
footer .upper-footer .first-block div,
footer .upper-footer .second-block div,
footer .upper-footer .third-block div {
    margin-bottom: 5px;
}
footer .upper-footer a {
    color: #4c4c4c;
}
footer .upper-footer p {
    margin: 0;
}
footer .lower-footer {
    min-height: 65px;
    background-color: #1e1e1e;
    text-align: center;
    color: #565656;
}
footer .lower-footer .container {
    padding-top: 24px;
    padding-bottom: 15px;
}
footer .lower-footer,
footer .lower-footer a{
    color: #999494;
}

h1 { font-size: 30px; }
h2, h3 { font-size: 20px; font-weight: 600; }
.mr-30 { margin-right: 30px; }
@media screen and (min-width: 768px) {
    #app {
        display: flex;
        flex-direction: column;
    }
    #app .navbar-brand {
        margin-right: 90px;
    }
    #app nav.navbar {
        height: 70px;
    }

    #app nav.navbar .navbar-nav .nav-item .nav-link.register {
        margin-left: 30px;
    }

    #app nav.navbar .navbar-nav .nav-item:first-child {
        margin-left: 0;
    }
    #app nav.navbar .navbar-nav .nav-item {
        margin-left: 15px;
    }
}
@media screen and (max-width: 768px) {
    #app footer .upper-footer .container,
    #app footer .lower-footer .container {
        display: flex;
        flex-direction: column;
    }
    #app nav.navbar .navbar-nav .nav-item.active .nav-link:after,
    #app nav.navbar .navbar-nav .nav-item .nav-link.active:after {
        position: absolute;
        height: 3px;
        content: '';
        bottom: 0;
        left: 0;
        right: 0;
        background: #3490DC;
        border-radius: 4px;
    }

    #app nav.navbar .navbar-nav .nav-item .nav-link.register {
        border: none;
        padding-left: 0;
    }
}
