@font-face {
    font-family: "Lato";
    src: url("../fonts/Lato/Lato-Light.ttf") format("truetype");
    font-weight: 300;
    font-display: swap;
}

@font-face {
    font-family: "Lato";
    src: url("../fonts/Lato/Lato-Regular.ttf") format("truetype");
    font-weight: 400;
    font-display: swap;
}

@font-face {
    font-family: "Lato";
    src: url("../fonts/Lato/Lato-Italic.ttf") format("truetype");
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: "Lato";
    src: url("../fonts/Lato/Lato-Bold.ttf") format("truetype");
    font-weight: 600;
    font-display: swap;
}

@font-face {
    font-family: "Lato";
    src: url("../fonts/Lato/Lato-Bold.ttf") format("truetype");
    font-weight: 700;
    font-display: swap;
}

@font-face {
    font-family: "Lato";
    src: url("../fonts/Lato/Lato-Black.ttf") format("truetype");
    font-weight: 900;
    font-display: swap;
}

@font-face {
    font-family: "LiberationSans";
    src: url("../fonts/LiberationSans/LiberationSans-Regular.ttf") format("truetype");
    font-weight: 400;
    font-display: swap;
}

@font-face {
    font-family: "LiberationSans";
    src: url("../fonts/LiberationSans/LiberationSans-Bold.ttf") format("truetype");
    font-weight: 700;
    font-display: swap;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

:root {
  --color_blue: #38BDF8;
  --color_bg_blue: #F2F8FC;
  --color_violet: #A855F7;
  --color_text: #002043;
  scroll-behavior: unset;
}

html {
  /* scroll-behavior: smooth !important; */
}

body {
    font-family: "Lato";
    font-weight: 400;
    font-size: 17px;
    line-height: 1.55;
    color: var(--color_text);
    background: #fff;
}

input {
    font-family: "Lato";
}

p:not(:last-child) {
    margin-bottom: 26px;
}

ul, ol {
    list-style-type: none;
    padding: 0;
}

a {
    transition: .3s;
    text-decoration: none;
}

main {
    display: flex;
}

.login-sidebar {
    width: 31vw;
    padding: 2.55vh 1.68vw 3.9vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 3vh 0;
    box-sizing: border-box;
}

.login-body {
    width: 69vw;
    height: 100vh;
}

.login-body img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: 50% 50%;
}

.logo {
    display: block;
}

.logo img {
    display: block;
    width: 8.594vw;
    height: auto;
}

.login-sidebar__form-wrap {
    max-width: 19.5315vw;
    width: 100%;
    display: flex;
    flex-direction: column;
    margin: 0 auto;
}

.login-sidebar__form-wrap__title {
    font-weight: 600;
    font-size: 1.469vw;
    line-height: 1.2;
    color: #232323;
    margin-bottom: 0.8vh;
}

.login-sidebar__form-wrap__subtitle {
    font-size: 0.88vw;
    line-height: 1.3;
    color: #969696;
    margin-bottom: 2.55vh;
}

.login-sidebar__form {
    width: 100%;
}

.login-sidebar__form__google-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4vw;
    border: 0.05vw solid #E6E8E7;
    box-shadow: 0 0.05vw 0.1vw 0 #00000008;
    border-radius: 0.5vw;
    margin-bottom: 2vh;
    font-weight: 600;
    font-size: 0.88vw;
    line-height: 1.2;
    color: #232323;
    text-align: center;
    padding: 0.25vw 0.5vw;
    min-height: 2.64vw;
    transition: .3s;
    box-sizing: border-box;
}

.login-sidebar__form__google-btn:hover {
    border-color: var(--color_blue);
    color: var(--color_blue);
}

.login-sidebar__form__checkbox {
    width: 100%;
}

.login-sidebar__form__checkbox input {
    display: none;
}

.login-sidebar__form__checkbox input:checked + span:before {
    background: url('data:image/svg+xml,<svg width="800px" height="800px" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"><g id="Interface / Check_Big"><path id="Vector" d="M4 12L8.94975 16.9497L19.5572 6.34326" stroke="%2338BDF8" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></g></svg>') no-repeat;
    background-size: cover;
    background-position: 50% 50%;
    border-color: var(--color_blue);
}

.login-sidebar__form__checkbox label span {
    display: flex;
    gap: 0.635vw;
    font-weight: 400;
    font-size: 0.785vw;
    line-height: 1.3;
    color: #4C5560;
    cursor: pointer;
    transition: .3s;
}

.login-sidebar__form__checkbox label span:hover {
    color: var(--color_blue);
}

.login-sidebar__form__checkbox label span:before {
    content: '';
    width: 0.735vw;
    min-width: 0.735vw;
    height: 0.735vw;
    border: 0.1vw solid #4C5560;
    border-radius: 0.2vw;
    margin-top: 0.1vw;
    transition: .3s;
}

.login-sidebar__form__or {
    margin: 4vh 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5vw;
    font-weight: 500;
    font-size: 0.785vw;
    line-height: 1;
    color: #6E6E6E;
}

.login-sidebar__form__or:before {
    content: '';
    width: 100%;
    height: 0.05vw;
    display: block;
    background: #D9D9D9;
}

.login-sidebar__form__or:after {
    content: '';
    width: 100%;
    height: 0.05vw;
    display: block;
    background: #D9D9D9;
}

.login-sidebar__form__tabs {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 4vh;
}

.login-sidebar__form__tabs-head {
    display: flex;
}

.login-sidebar__form__tabs-head__item {
    width: 50%;
    cursor: pointer;
    text-align: center;
    font-weight: 400;
    font-size: 0.879vw;
    line-height: 1;
    color: #667686;
    padding: 0.44vw 0.25vw;
    border-bottom: 0.15vw solid #9AAEC2;
    transition: .3s;
}

.login-sidebar__form__tabs-head__item.active {
    font-weight: 700;
    color: #212832;
    border-color: var(--color_blue);
}

.login-sidebar__form__tabs-head__item:hover {
    color: var(--color_blue);
}

.login-sidebar__form__tabs-content {
    width: 100%;
}

.login-sidebar__form__tabs-content__item {
    display: none;
    flex-direction: column;
    gap: 2vh;
}

.login-sidebar__form__tabs-content__item.active {
    display: flex;
}

.login-sidebar__form__input {
    width: 100%;
}

.login-sidebar__form__input label {
    position: relative;
    display: block;
}

.login-sidebar__form__input span {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0.59vw;
    margin: auto;
    font-weight: 400;
    font-size: 0.879vw;
    line-height: 1;
    color: #9A9A9A;
    transition: .3s;
    padding: 0 0.2vw;
    background: #fff;
    height: 1vw;
}

.login-sidebar__form__input input {
    width: 100%;
    height: 2.885vw;
    border: 0.05vw solid #D9D9D9;
    border-radius: 0.5vw;
    padding: 0.5vw 0.79vw;
    font-weight: 400;
    font-size: 0.879vw;
    line-height: 1;
    color: #232323;
    box-sizing: border-box;
    outline: none;
    transition: .3s;
}

.login-sidebar__form__input input:focus {
    border-color: var(--color_blue);
}

.login-sidebar__form__input input:focus + span,
.login-sidebar__form__input input.filled + span {
    color: var(--color_blue);
    font-size: 0.685vw;
    transform: translateY(-1.274vw);
}

.login-sidebar__form__forgot-password {
    font-size: 0.685vw;
    line-height: 1.15;
    color: #4C5560;
}

.login-sidebar__form__btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    cursor: pointer;
    background: linear-gradient(180deg, #A855F7 0%, #38BDF8 100%) padding-box, linear-gradient(180deg, #A855F7 0%, #38BDF8 100%) border-box;
    border: none;
    height: 2.64vw;
    transition: .3s;
    font-weight: 600;
    font-size: 0.879vw;
    line-height: 1;
    color: #fff;
    border-radius: 0.5vw;
    padding: 0.5vw;
    text-transform: uppercase;
    box-sizing: border-box;
    border: 0.01vw solid transparent;
}

.login-sidebar__form__btn:hover {
    background: linear-gradient(#fff 0 0) padding-box, linear-gradient(180deg, #A855F7 0%, #38BDF8 100%) border-box;
    color: #38BDF8;
}

.login-sidebar__form__foot {
    margin-top: 2vh;
    font-weight: 700;
    font-size: 0.735vw;
    line-height: 1.1;
    color: #212832;
}

.login-sidebar__form__foot a {
    color: var(--color_blue);
    text-decoration: underline;
    transition: .3s;
}

.login-sidebar__form__foot a:hover {
    color: #A855F7;
}

footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3.9vh 0;
}

.footer__nav ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1vh 0;
}

.footer__nav ul li {
    padding: 0 0 0 0.25vw;
    display: flex;
    align-items: center;
    gap: 0.25vw;
}

.footer__nav ul li:not(:last-child):after {
    content: '';
    width: 0.05vw;
    min-width: 0.05vw;
    height: 100%;
    display: block;
    background: linear-gradient(180deg, #A855F7 0%, #38BDF8 100%);    
}

.footer__nav ul li a {
    font-family: "LiberationSans";
    display: block;
    font-size: 0.59vw;
    line-height: 1.2;
    color: #667686;
    text-align: center;
    transition: .3s;
}

.footer__nav ul li a:hover {
    color: var(--color_blue);
}

.footer__info {
    font-family: "LiberationSans";
    font-size: 0.59vw;
    line-height: 1.35;
    color: #8E8E8E;
    text-align: center;
}

@media (max-width: 767px) {
    main {
        flex-direction: column;
    }
    .login-sidebar {
        width: 100vw;
        padding: 2vh 4vw;
        gap: 5vh 0;
    }
    .login-body {
        width: 100vw;
        height: auto;
    }
    .login-body img {
        height: auto;
    }
    .logo img {
        width: 32vw;
    }
    .login-sidebar__form-wrap {
        max-width: 62vw;
    }
    .login-sidebar__form-wrap__title {
        font-size: 6vw;
        margin-bottom: 1.8vh;
    }
    .login-sidebar__form-wrap__subtitle {
        font-size: 3.4vw;
    }
    .login-sidebar__form__google-btn {
        border: 0.4vw solid #E6E8E7;
        border-radius: 1.5vw;
        font-size: 2.8vw;
        min-height: 8.64vw;
    }
    .login-sidebar__form__checkbox label span {
        font-size: 3vw;
        gap: 0.9vw;
    }
    .login-sidebar__form__checkbox label span:before {
        width: 2.735vw;
        min-width: 2.735vw;
        height: 2.735vw;
        border: 0.1vw solid #4C5560;
        border-radius: 0.7vw;
        margin-top: 0.4vw;
    }
    .login-sidebar__form__or {
        font-size: 3.3vw;
        gap: 1.5vw;
    }
    .login-sidebar__form__or:before {
        height: 0.1vw;
    }
    .login-sidebar__form__or:after {
        height: 0.1vw;
    }
    .login-sidebar__form__tabs-head__item {
        font-size: 3vw;
        padding: 1.7vw 0.25vw;
        border-width: 0.6vw;
    }
    .login-sidebar__form__input input {
        height: 8.4vw;
        font-size: 3vw;
        padding: 0.5vw 1.79vw;
    }
    .login-sidebar__form__input span {
        font-size: 3vw;
        height: 3.1vw;
        left: 1.59vw;
    }
    .login-sidebar__form__input input:focus + span,
    .login-sidebar__form__input input.filled + span {
        font-size: 2.685vw;
        transform: translateY(-4.1vw);
    }
    .login-sidebar__form__forgot-password {
        font-size: 3vw;
    }
    .login-sidebar__form__tabs-content__item {
        gap: 2vh;
    }
    .login-sidebar__form__btn {
        height: 9.64vw;
        font-size: 3.3vw;
        border-radius: 1.5vw;
    }
    .login-sidebar__form__foot {
        margin-top: 2.5vh;
        font-size: 3vw;
    }
    .footer__nav ul li a {
        font-size: 2.6vw;
    }
    .footer__nav ul li {
        gap: 1.5vw;
        padding: 0 0 0 1.5vw;
    }
    .footer__nav ul li:not(:last-child):after {
        width: 0.25vw;
        min-width: 0.25vw;
    }
    .footer__info {
        font-size: 2.6vw;
    }
}