:root{
    --white: #fff;
    --blue-50:#E6F5FA;
    --blue-500:#0099CD;
    --red-500: #DE3D2F;
    --navy-100:#000046;
    --navy-400:#33336B;
    --green-500: #0A8C4B;
    --violet-500: #000046;
    --primary: #001F29;

    --size-1: 1px;
    --size-14: 14px;
    --size-16: 16px;
    --size-24: 24px;
    --size-32: 32px;
    --size-38: 38px;
}

@font-face {
    font-family: 'Proxima Nova Light';
    src: url('https://cdn.core.doutorfinancas.pt/assets/fonts/proxima_nova_alt_light-webfont.woff2') format('woff2'),
    url('https://cdn.core.doutorfinancas.pt/assets/fonts/proxima_nova_alt_light-webfont.woff') format('woff');
    font-style: normal;
    font-weight: 300;
}

@font-face {
    font-family: 'Proxima Nova';
    src: url('https://cdn.core.doutorfinancas.pt/assets/fonts/proxima_nova_alt_regular-webfont.woff2') format('woff2'),
    url('https://cdn.core.doutorfinancas.pt/assets/fonts/proxima_nova_alt_regular-webfont.woff') format('woff');
    font-style: normal;
    font-weight: 400;
}

@font-face {
    font-family: 'Proxima Nova Semibold';
    src: url('https://cdn.core.doutorfinancas.pt/assets/fonts/proxima_nova_alt_semibold-webfont.woff2') format('woff2'),
    url('https://cdn.core.doutorfinancas.pt/assets/fonts/proxima_nova_alt_semibold-webfont.woff') format('woff');
    font-style: normal;
    font-weight: 600;
}

@font-face {
    font-family: 'Proxima Nova Bold';
    src: url('https://cdn.core.doutorfinancas.pt/assets/fonts/proxima_nova_alt_bold-webfont.woff2') format('woff2'),
    url('https://cdn.core.doutorfinancas.pt/assets/fonts/proxima_nova_alt_bold-webfont.woff') format('woff');
    font-style: normal;
    font-weight: 700;
}

body{
    font-family: "Proxima Nova" !important;
    overflow: hidden;
}

/* --------------------------Background Color-------------------------- */

.bg-white {
    background-color: var(--white);
}
.bg-blue-50 {
    background-color: var(--blue-50);
}
.bg-blue-500 {
    background-color: var(--blue-500);
}
.bg-navy-100 {
    background-color: var(--navy-100);
}
.bg-navy-400 {
    background-color: var(--navy-400);
}

/* ------------------------------ Gap ----------------------------- */

.gap-16{
    gap: var(--size-16);
}
.gap-24{
    gap: var(--size-24);
}

/* --------------------------Font Size-------------------------- */

.font-14 {
    font-size: var(--size-14);
}

.font-32 {
    font-size: var(--size-32);
}

.font-semibold {
    font-family: 'Proxima Nova Semibold';
}
/* --------------------------Color Text-------------------------- */

.color-navy-100 {
    color: var(--navy-100);
}
.color-blue-500 {
    color: var(--blue-500);
}
.color-white {
    color: var(--white);
}

/* --------------------------Borders-------------------------- */

.border-1-solid-navy-100{
    border: 1px solid var(--navy-100);
}

/* --------------------------Changes Form-------------------------- */

.form-outline .form-control{
    transition: none; !important;
    background-image: none;
}
.invalid-feedback{
    margin-left: 20px;
    top: 45px;
}

.was-validated .form-control:invalid{
    margin-bottom: 3rem;
    background-image: none;
}

.form-outline .form-control:focus ~ .form-notch .form-notch-leading {
    border-top: var(--size-1) solid var(--blue-500);
    border-bottom: var(--size-1) solid var(--blue-500);
    border-left: var(--size-1) solid var(--blue-500);
}

.form-outline .form-control:focus ~ .form-notch .form-notch-trailing {
    border-top: var(--size-1) solid var(--blue-500);
    border-right: var(--size-1) solid var(--blue-500);
    border-bottom: var(--size-1) solid var(--blue-500);
}

.form-outline .form-control:focus ~ .form-notch .form-notch-middle {
    border-top: 0;
    border-bottom: var(--size-1) solid var(--blue-500);
}

.form-outline .form-control:hover:not(:focus) ~ .form-notch .form-notch-leading {
    border-top: var(--size-1) solid #000;
    border-bottom: var(--size-1) solid #000;
    border-left: var(--size-1) solid #000;
}

.form-outline .form-control:hover:not(:focus) ~ .form-notch .form-notch-trailing {
    border-top: var(--size-1) solid #000;
    border-right: var(--size-1) solid #000;
    border-bottom: var(--size-1) solid #000;
}

.form-outline .form-control:hover:not(:focus) ~ .form-notch .form-notch-middle {
    border-top: var(--size-1) solid #000;
    border-bottom: var(--size-1) solid #000;
}

.form-label:active {
    color: var(--blue-500); !important;
}

.was-validated .form-outline .form-control:valid~.form-notch .form-notch-trailing,
.was-validated .form-outline .form-control:valid~.form-notch .form-notch-middle,
.was-validated .form-outline .form-control:valid~.form-notch .form-notch-leading {
    border-color: var(--blue-500);;
}

.form-control.form-control-lg:focus~.form-label, .form-outline .form-control.form-control-lg.active~.form-label{
    background-color: #E6F5FA !important;
    color: #0099CD !important;
    padding-top: 0 !important;
    padding-right: 1% !important;
    padding-left: 1% !important;
    margin-top: 1% !important;
    z-index: 10;
}

/* --------------------------Essential CSS-------------------------- */

p{
    margin: 0;
}

.form-login {
    min-height: 580px;
    max-width: 960px;
}

.logo{max-width: 188px}

.success-text{
    font-size: 20px;
    font-weight: 600;
    line-height: 24px;
    color: var(--green-500);
}

.button-icon {
    max-width: var(--size-24);
}

.green-check {
    width: 40px;
    height: 40px;
}

.info-text {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
    color: var(--violet-500);
    padding-bottom: var(--size-32);
    padding-top: var(--size-16);
}

.return-text{
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
    color: var(--violet-500);
}

.go-back{
    width: 28px;
    height: 28px;
}

.pin-fraction{
    width: 40px;
    height: 40px;
    margin: auto;
    text-align: center;
}

.error-feedback{
    color: var(--red-500);
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
}

.text-caption{
    font-size: 20px;
    font-weight: 600;
    line-height: 24px;
    color: var(--violet-500);
}
/* --------------------------------------------------------- */


.plus-bg-left{
    position: absolute;
    left: -90px;
    bottom: -90px;
    z-index: -1;
}

.plus-bg-right{
    position: absolute;
    transform: rotate(180deg);
    right: -90px;
    top: -90px;
    z-index: -1;
}

#loading {
    width: 2rem;
    height: 2rem;
    border: 5px solid #f3f3f3;
    border-top: 6px solid #09c;
    border-radius: 100%;
    margin: auto;
    display: none;
    animation: spin 1s infinite linear;
}

.padding-top-32{
    padding-top: var(--size-32);
}

#loading.display {
    display: block;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

/* --------------------------Media Queris-------------------------- */

@media only screen and (max-width: 992px) {
    .rounded-lg-3 {
        border-radius: 8px;
    }
}


