* {
    margin: 0; padding: 0;
    text-decoration: none;
    scrollbar-width: none;
    box-sizing: border-box;
    font-family: 'Nunito Sans';
}
body {
    background-color: #647183;
    width: 100svw; height: 100svh;
    font-size: min(2.25vmin, 16px + 0.25vmin);

    display: flex;
    align-items: center;
    justify-content: center;
}
::-webkit-scrollbar {
    width: 0px; display: none;
}


.Background {
    object-fit: cover;
    pointer-events: none;
    object-position: center;
    width: 100%; height: 100%;

    position: fixed;
    inset: 0; z-index: -1;
}

.FormContainer > form {
    border-radius: 2em;
    background-color: #fffdf7;
    width: 27.5em; padding: 1.75em;
    box-shadow: 0em 0em 2em 1em rgba(0, 0, 0, 0.5);

    display: flex; gap: 1.75em;
    flex-direction: column;
    align-items: stretch;
}
.FormContainer .Title {
    text-align: center;
    margin-bottom: 0.25em;
    font: 700 2em Montserrat;
}
.FormContainer .HelperText {
    color: #575757;
    text-align: center;
    font: 600 1.1em 'Merriweather Sans';
}
.FormContainer .InputFields {
    display: grid; gap: 1.5em;
    grid-template-columns: 1fr 1fr;
}
.FormContainer .InputField {
    margin-top: 0.3em;
}
.FormContainer .InputField label {
    padding-left: 0.75em;
    font: 600 0.95em Poppins;

    display: block;
}
.FormContainer .InputField input {
    width: 100%;
    padding: 0.75em;
    border-radius: 0.75em;
    font: 600 1em 'Nunito Sans';
    border: none; outline: none;
    background-color: #e0e0e0;
}
.FormContainer .InputField .ErrorMessage {
    color: #f00;
    text-indent: 0.75em;
    font: 500 0.9em Poppins;

    display: none;
}
.FormContainer .PhoneNumber .Container {
    display: flex;
    align-items: stretch;
}
.FormContainer .PhoneNumber #CountryCode {
    color: #666;
    padding: 0em 0.75em;
    cursor: not-allowed;
    font: 600 1em 'Nunito Sans';
    outline: none; border: none;
    background-color: #e8e8e8;
    border-radius: 0.75em 0em 0em 0.75em;
}
.FormContainer .PhoneNumber #UserID {
    width: 100%;
    padding: 0.75em;
    font: 600 1em 'Nunito Sans';
    background-color: #e0e0e0;
    border-radius: 0em 0.75em 0.75em 0em;
}
.FormContainer .Password .Container {
    position: relative;
}
.FormContainer .Password #Password {
    padding: 0.75em 2.5em 0.75em 1em;
}
.FormContainer .Password .TogglePassword {
    height: 50%; aspect-ratio: 1;
    border: none; cursor: pointer;
    background-color: transparent;

    position: absolute;
    top: 50%; right: 4%;
    translate: 0% -50%;
}
.FormContainer .Password .TogglePassword::after {
    content: '';
    background-color: #444;

    mask-size: contain;
    -webkit-mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-image: url('ShowPassword.svg');
    -webkit-mask-image: url('ShowPassword.svg');
    position: absolute; inset: 0;
    display: none;
}
.FormContainer .Password .TogglePassword.Show::after {
    display: block;
}
.FormContainer .Password:hover .TogglePassword::after {
    background-color: #000;
}
.FormContainer .Password .TogglePassword::before {
    content: '';
    background-color: #444;

    mask-size: contain;
    -webkit-mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-image: url('HidePassword.svg');
    -webkit-mask-image: url('HidePassword.svg');
    position: absolute; inset: 0;
    display: block;
}
.FormContainer .Password .TogglePassword.Show::before {
    display: none;
}
.FormContainer .Password:hover .TogglePassword::before {
    background-color: #000;
}
.FormContainer .InputField .OTP {
    padding: 1.5em 0.5em;

    display: flex; gap: 0.85em;
}
.FormContainer .InputField .OTP input {
    text-align: center;
    font: 600 1.1em 'Nunito Sans';
    transition: 0.1s ease-out;
}
.FormContainer .InputField .OTP.Invalid input {
    background-color: #ffabab;
}
.FormContainer .InputField .OTP + .ErrorMessage {
    text-align: center;
}
.FormContainer .InputField .OTP.Invalid + .ErrorMessage {
    display: block;
}
.FormContainer .Buttons {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.FormContainer .Button {
    cursor: pointer;
    color: #8d79ff;
    font: 600 0.95em Poppins;
    border: none; outline: none;
    background-color: transparent;
}
.FormContainer .Button:hover {
    text-decoration: underline;
    text-underline-offset: 0.2em;
    text-decoration-thickness: 0.15em;
}
.FormContainer .Button.Disabled {
    color: #c2b7ff;
    cursor: not-allowed;
}
.FormContainer .Submit {
    cursor: pointer;
    border-radius: 0.75em;
    font: 600 1.1em Poppins;
    transition: 0.2s ease-out;
    background-color: #8069ff;
    border: none; outline: none;
    height: 2.5em; color: #ffffff;
}
.FormContainer .Submit:hover {
    transform: scale(1.02);
}
.FormContainer .Submit.Disabled {
    pointer-events: none;
    background-color: #9d8cff;
}


@media screen and (max-aspect-ratio: 0.6) {
    body {font-size: 3.25vmin;}

    .FormContainer > form {padding: 1.75em 1.25em;}
    .FormContainer .InputField label {font-size: 1.1em;}
    .FormContainer .InputField input {font-size: 1.15em;}
    .FormContainer .InputField .ErrorMessage {font-size: 1em;}
    .FormContainer .PhoneNumber #CountryCode {font-size: 1.15em;}
    .FormContainer .PhoneNumber #UserID {font-size: 1.15em;}
    .FormContainer .InputField .OTP input {font-size: 1.2em;}
    .FormContainer .Button {font-size: 1.1em;}
    .FormContainer .Submit {font-size: 1.2em;}
}