﻿body {
    background-image: url('../img/winticstellar/bg.png');
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    font-family: 'Roboto', sans-serif;
    margin: 0;
    min-width: 300px;
    height: 100vh;
    overflow-x: hidden;
    -ms-user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
}

ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

a {
    cursor: pointer;
    color: #ffffff;
    text-decoration: none;
}

input {
    outline: none;
    border: none;
}

    input[type='checkbox'] {
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
    }

    input[type='date']::-webkit-inner-spin-button {
        display: none;
        -webkit-appearance: none;
    }

    input[type='date']::-webkit-calendar-picker-indicator {
        -webkit-appearance: none;
        appearance: none;
        background-image: url(../img/winticstellar/down_arrow.png);
        background-position-y: center;
        background-position-x: center;
        background-size: 10px 6px;
        background-repeat: no-repeat;
        color: rgba(255,255,255,0);
        cursor: pointer;
        background-color: #ffffff;
    }

        input[type='date']::-webkit-calendar-picker-indicator:hover {
            background-color: #ffffff;
        }

*, ::after, ::before {
    box-sizing: border-box;
}

.container {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    line-height: 0;
}

.row {
    display: flex;
    flex-wrap: wrap;
}

.middle {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.register .middle {
    transform: translateY(calc(-50% + 11px));
}

.text-center {
    text-align: center;
}

.navbar {
    height: 70px;
    background-color: #3a4758;
    padding: 8px 0;
    text-align: center;
}

    .navbar .brand {
        display: inline-block;
    }

        .navbar .brand .logo {
            height: 53.28px;
            width: 358px;
            background: url(../img/winticstellar/full-logo.svg) transparent no-repeat 50%;
            content: "";
        }

.footer {
    height: 37px;
    width: 100%;
    bottom: 0;
    text-align: center;
    padding: 8px 0;
}

    .footer.fixed {
        position: fixed;
    }

    .footer.unfixed {
        position: relative;
    }

    .footer ul {
        width: 100%;
    }

    .footer li {
        display: inline;
        list-style: none;
        border-right: 1px solid #ffffff;
        padding: 0 20px;
    }

        .footer li:last-child {
            border-right: 0;
        }

    .footer li, .footer a {
        font-family: "Roboto";
        color: #ffffff;
        font-size: 12px;
        font-weight: 300;
        font-style: normal;
        font-stretch: normal;
        line-height: normal;
        letter-spacing: 0.8px;
    }

    .footer ul li.footer-icon {
        margin-left: 18px;
        padding-left: 28px;
    }

        .footer ul li.footer-icon.click {
            background: url('../img/winticstellar/click.png') no-repeat left top;
            background-size: contain;
        }

.privacy {
    margin: 14px auto 0 auto;
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 10px;
}

    .privacy, .privacy a {
        font-family: Roboto;
        font-size: 10px;
        font-weight: normal;
        font-style: normal;
        font-stretch: normal;
        line-height: normal;
        letter-spacing: 0.1px;
        text-align: center;
        color: #ffffff;
    }

        .privacy a {
            text-decoration: none;
            transition: all 0.3s ease-in-out;
        }

            .privacy a:hover {
                color: rgba(255, 255, 255, 0.3);
            }

.card {
    object-fit: contain;
    padding: 32px 64px 41px 64px;
    margin: 39px auto 0 auto;
    border-radius: 5px;
    position: relative;
    width: 669px;
}

    .card.full-width {
        width: 100%;
    }

    .card .background {
        z-index: -1;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        border-radius: 5px;
        background-repeat: no-repeat;
        background-size: cover;
        background-position: top right;
        border: solid 2px rgba(255, 2550, 255, 0.5);
    }

    .card.login .background {
        background-image: url(../img/winticstellar/bg_login_panel.png);
    }

    .card.profile-choosing .background {
        background-image: url(../img/winticstellar/bg_profile_panel_extended.png);
    }

    .card.register .background {
        background-image: url(../img/winticstellar/bg_registration_panel.png);
    }


    .card .title {
        font-family: Roboto;
        font-size: 20px;
        font-weight: normal;
        font-style: normal;
        font-stretch: normal;
        line-height: 0.75;
        letter-spacing: 0.2px;
        text-align: center;
        color: #3a4758;
        margin-bottom: 33px;
    }

        .card .title.left {
            text-align: left;
        }

.form-field {
    position: relative;
    margin-bottom: 32px;
    display: block;
}

    .form-field:last-child, .form-field.last {
        margin-bottom: 0;
    }

    .form-field input[type="text"], .form-field input[type="password"], .form-field input[type="email"] {
        font-family: Roboto;
        font-size: 16px;
        font-weight: normal;
        font-style: normal;
        font-stretch: normal;
        line-height: normal;
        letter-spacing: 0.2px;
        text-align: left;
        color: #8e8e8e;
        background-color: #ffffff;
        padding: 11px 15px 14px 15px;
        width: 100%;
        height: 39px;
    }

    .form-field.with-icon input[type="text"], .form-field.with-icon input[type="password"], .form-field.with-icon input[type="email"] {
        width: 505px;
        margin-left: 36px;
    }

    .form-field input:invalid {
        box-shadow: 0px 0px 90px 3px red;
    }

.info {
    font-size: 12px;
    display: block;
    line-height: 1;
    margin-left: 36px;
    margin-top: 10px;
    margin-bottom: 10px;
    position: absolute;
}

.error {
    color: #af0909;
    font-size: 12px;
    display: block;
    line-height: 1;
}

.form-field .error {
    margin-left: 36px;
    margin-top: 5px;
    position: absolute;
}


.form-field.with-icon .email {
    background: url(../img/winticstellar/email.png) transparent no-repeat 50%;
    height: 20px;
    width: 20px;
    content: "";
}

.form-field.with-icon .password {
    background: url(../img/winticstellar/password.png) transparent no-repeat 50%;
    height: 22px;
    width: 16px;
    content: "";
}

.form-field.with-icon .edit {
    background: url(../img/winticstellar/edit.png) transparent no-repeat 50%;
    content: "";
}

.form-field.with-icon .calendar {
    background: url(../img/winticstellar/calendar.png) transparent no-repeat 50%;
    height: 24px;
    width: 22px;
    content: "";
}

.form-field.with-icon .user {
    background: url(../img/winticstellar/user.png) transparent no-repeat 50%;
    height: 22px;
    width: 20px;
    content: "";
}

.form-field.with-icon .windows-logo {
    background: url(../img/winticstellar/windows-logo.png) transparent no-repeat 50%;
    height: 20px;
    width: 24px;
    content: "";
}

.form-field .google-logo {
    background: url('../img/g-normal.png') transparent 5px 50% no-repeat;
    display: inline-block;
    vertical-align: middle;
    width: 40px;
    height: 40px;
}

.form-field .login-google {
    display: block;
    background: #ffffff;
    color: rgba(0,0,0,0.54);
    border-radius: 5px;
    border: thin solid rgba(0,0,0,0.1);
    box-shadow: 1px 1px 1px rgba(0,0,0,0.1);
    white-space: nowrap;
}

    .form-field .login-google .btn-text {
        display: inline-block;
        vertical-align: middle;
        padding-left: 2px;
        font-size: 14px;
        font-weight: bold;
        font-family: 'Roboto', sans-serif;
    }

.form-field .facebook-logo {
    background: url('../img/facebook-logo.png') transparent 5px 50% no-repeat;
    display: inline-block;
    vertical-align: middle;
    width: 40px;
    height: 40px;
}

.form-field .login-facebook {
    display: block;
    background: #4267b2;
    color: #ffffff;
    border-radius: 5px;
    white-space: nowrap;
}

    .form-field .login-facebook .btn-text {
        display: inline-block;
        vertical-align: middle;
        padding-left: 2px;
        font-size: 14px;
        font-weight: bold;
        font-family: Helvetica, Arial, sans-serif;
    }

.form-field label {
    line-height: normal;
    margin-bottom: 5px;
    display: block;
    font-size: 14px;
    color: black;
}

.form-field.with-icon label {
    margin-left: 36px;
}

.cs-select {
    outline: none;
}

    .cs-select span.cs-placeholder {
        font-family: Roboto;
        font-size: 16px;
        font-weight: normal;
        font-style: normal;
        font-stretch: normal;
        line-height: normal;
        letter-spacing: 0.2px;
        text-align: left;
        color: #8e8e8e;
        background-color: #ffffff;
        display: block;
        position: relative;
        cursor: pointer;
        padding: 10px 13px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        background: url(../img/winticstellar/down_arrow.png) no-repeat right #ffffff;
        background-position-x: calc(100% - 20px);
    }

    .cs-select.cs-active span.cs-placeholder {
        background: url(../img/winticstellar/close.png) no-repeat right #c7cfdc;
        background-position-x: calc(100% - 20px);
        color: #414042;
    }

    .cs-select .cs-options {
        position: relative;
        overflow-x: hidden;
        overflow-y: auto;
        width: 100%;
        background: #fff;
        max-height: 0;
        border-bottom: 0;
        -webkit-transition: all 0.2s;
        transition: all 0.2s;
    }

    .cs-select.cs-active .cs-options {
        max-height: 221px;
        border-bottom: 1px solid #c7cfdc;
    }

    .cs-select ul {
        list-style: none;
        margin: 0;
        padding: 0;
        width: 100%;
    }

        .cs-select ul li {
            border-bottom: 1px solid #c7cfdc;
        }

            .cs-select ul li:last-child {
                border-bottom: none;
            }

            .cs-select ul li:hover {
                background-color: #c7cfdc;
            }

            .cs-select ul li span {
                padding: 10px 13px;
                height: 36px;
                display: block;
                position: relative;
                cursor: pointer;
                white-space: nowrap;
                overflow: hidden;
                text-overflow: ellipsis;
                line-height: normal;
            }

            .cs-select ul li.cs-selected span {
                background-color: #c7cfdc;
            }

    .cs-select select {
        display: none;
    }

.button {
    background-color: #3a4758;
    font-family: Roboto;
    font-size: 16px;
    font-weight: normal;
    font-style: normal;
    font-stretch: normal;
    line-height: normal;
    letter-spacing: 0.2px;
    text-align: center;
    color: #ffffff;
    padding: 10px 0;
    display: block;
    transition: all 0.3s ease-in-out;
    border: none;
    cursor: pointer;
    text-transform: uppercase;
    width: 100%;
}

    .button:focus {
        outline: none;
    }

    .button:hover {
        background-color: #4b5761;
    }

    .button.login, .button.profile, .button.register {
        width: 177px;
        height: 40px;
        margin-left: auto;
    }

    .button.login-windows, .button.registration {
        width: 505px;
        text-align: left;
        margin-left: auto;
        padding-left: 14px;
        padding-right: 14px;
    }

    .button.login-windows {
        background-color: #20ace2;
    }

        .button.login-windows:hover {
            background-color: rgba(32, 172, 226, 0.5);
        }

.checkbox {
    display: flex;
    margin-left: 36px;
}

    .checkbox input[type='checkbox'] {
        width: 16px;
        height: 16px;
        background-color: #ffffff;
        background-image: url(../img/winticstellar/checkbox_uncheck.png);
        background-position: left center;
        background-size: auto 100%;
        background-repeat: no-repeat;
        margin: 0 17px 0 0;
        transition: all 0.3s ease-in-out;
    }

        .checkbox input[type='checkbox']:checked {
            background-image: url(../img/winticstellar/checkbox_check.png);
        }

label {
    font-family: Roboto;
    font-size: 16px;
    font-weight: normal;
    font-style: normal;
    font-stretch: normal;
    line-height: 1;
    letter-spacing: 0.2px;
    text-align: left;
    color: #ffffff;
    padding: 1px 0;
}

.with-legend label {
    font-size: 12px;
    letter-spacing: 0.1px;
}

    .with-legend label.legend {
        font-size: 10px;
        position: absolute;
        margin-top: 18px;
        margin-left: 33px;
    }

.ui-widget-content {
    background-color: #ffffff;
    border: 1px solid #8e8e8e;
}

    .ui-priority-secondary, .ui-widget-content .ui-priority-secondary {
        opacity: .7;
    }

.ui-datepicker.ui-widget.ui-widget-content {
    border: none;
    padding: 0;
    margin-top: 8px;
    width: auto;
}

.ui-datepicker .ui-datepicker-header {
    background-color: #3a4758;
    height: 31px;
    box-sizing: border-box;
    padding: 7px 0;
}

.ui-datepicker-year {
    background-color: #3a4758;
    font-family: Roboto;
    font-size: 14px;
    font-weight: 500;
    font-style: normal;
    font-stretch: normal;
    line-height: normal;
    letter-spacing: normal;
    text-align: center;
    color: #ffffff;
    border: 0;
    cursor: pointer;
    width: 55px !important;
}

    .ui-datepicker-year:focus {
        outline: none;
    }

.ui-datepicker table {
    margin: 0;
    padding: 10px 14px 17px 14px;
    display: block;
}

.ui-datepicker th {
    font-family: Roboto;
    font-size: 10px;
    font-weight: 500;
    font-style: normal;
    font-stretch: normal;
    line-height: normal;
    letter-spacing: 0.1px;
    text-align: center;
    color: #485464;
    text-transform: uppercase;
    position: relative;
    padding: 0px 4.5px 5px 4.5px;
}

    .ui-datepicker th::before {
        content: '';
        display: block;
        position: absolute;
        width: 100%;
        right: 0;
        border: 0;
        bottom: 0;
        height: 16px;
        border-right: 1px solid rgba(0,0,0,0.3);
    }

.ui-datepicker td {
    position: relative;
    padding: 0;
}

    .ui-datepicker td::before {
        content: '';
        display: block;
        position: absolute;
        width: 100%;
        right: 0;
        border: 1px solid rgba(0,0,0,0.3);
        border-left: 0;
        border-bottom: 0;
        bottom: 0;
        height: 100%;
        z-index: -1;
    }

    .ui-datepicker th:last-child::before, .ui-datepicker td:last-child::before {
        border-right: 0;
    }

.ui-state-default, .ui-widget-content .ui-state-default {
    font-family: Roboto;
    font-size: 16px;
    font-weight: 500;
    font-style: normal;
    font-stretch: normal;
    line-height: normal;
    letter-spacing: 0.2px;
    text-align: center;
    color: #414042;
    padding: 6.5px;
    transition: all 0.3s ease-in-out;
}

.ui-datepicker-today .ui-state-default.ui-state-highlight {
    background-color: rgba(0,0,0,0.3);
    color: #414042;
}

.ui-state-hover {
    background-color: #4b5761 !important;
    color: #ffffff !important;
}

.ui-state-default.ui-state-active {
    background-color: #3a4758;
    color: #ffffff;
}

.ui-datepicker .ui-datepicker-title {
    font-family: Roboto;
    font-size: 14px;
    font-weight: 500;
    font-style: normal;
    font-stretch: normal;
    line-height: normal;
    letter-spacing: normal;
    text-align: center;
    color: #ffffff;
}

.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next {
    border: solid 1.5px #ffffff;
    border-radius: 50%;
    width: 18px;
    height: 18px;
    top: inherit;
    background-repeat: no-repeat;
    transition: all 0.3s ease-in-out;
}

    .ui-datepicker .ui-datepicker-prev:hover, .ui-datepicker .ui-datepicker-next:hover {
        background-color: rgba(255,255,255,0.5) !important;
    }

.ui-datepicker .ui-datepicker-prev {
    left: 15px;
    background-image: url(../img/winticstellar/cal_arrow_left.png);
    background-position: 5px 3px;
}

.ui-datepicker .ui-datepicker-next {
    right: 15px;
    background-image: url(../img/winticstellar/cal_arrow_right.png);
    background-position: 6px 3px;
}

.button-consent {
    width: calc(50% - 12px);
    margin: 0 10px;
    display: inline-block;
}

    .button-consent:first-child {
        margin-left: 0;
    }

    .button-consent:last-child {
        margin-right: 0;
    }

@-moz-document url-prefix() {
    .checkbox label {
        padding: 0;
    }
}

hr.divider {
    opacity: 0.3;
    background-color: #ffffff;
    height: 1px;
    margin: 32px 0;
    border: 0;
}

.privacy-terms {
    background-color: #ffffff;
    padding: 20px 50px;
    height: calc(100vh - 300px);
    overflow: auto;
}

    .privacy-terms p {
        line-height: normal;
    }

.inputLabel {
    color: #3a4758;
    margin-left:35px;
}

@media (min-width: 576px) {
    .container {
        max-width: 540px;
    }
}

@media (min-width: 768px) {
    .container {
        max-width: 720px;
    }
}

@media (min-width: 992px) {
    .container {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .container {
        max-width: 1140px;
    }
}
