body {
    font-family: 'Poppins', sans-serif;
    font-size: 15px; 
}

:root {
    --color-main: #3BB2B8;
    --color-secondary: #32959a;    
}

/*CONTENT*/
.login-content {
    max-width: 400px;
    margin: 0 auto;
    padding: 20px;
    background-color: #f8f9fa;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.login-content p { 
    font-family: var(--font-paragraph) !important;    
    font-size: 15px;
    color: #333;
    text-align: center;
}

.login-logo {
    text-align: center !important;
    margin: 0 0 20px 0 !important;
    padding: 20px 0 !important;
}

.login-logo img {
    width: 260px;
    text-align: center !important;
    margin: 0 auto !important;
}

.login-logo h1 {
    font-family: var(--font-title) !important;
    margin-bottom: 30px;
    color: var(--color-primary);
    font-size: 25px;
    text-indent: 0;
    text-transform: uppercase;
    font-weight: 800;
    text-align: center;
}

.login-logo h1 span {
    color: var(--color-secondary);
}

.login-content h2 {
    text-align: center;
    font-weight: 800;
    color: var(--color-main) !important;
}

.box-button {
    margin-top: 15px;
}

.btn-primary {
    border-radius: 0 !important;
    color: #fff;
    padding: 12px 0;
    text-transform: uppercase;
    background-color: var(--color-main) !important;
    border-color: var(--color-main) !important;
}

.btn-primary:focus {
     outline: none !important; 
     box-shadow: none !important;
}

/*FORM*/
form {
    margin-top: 30px;
}

form input {
    border-width: 1px !important;
    border-radius: 0 !important;
}

.text-right {
    text-align: right !important;
}

form label {
    color: #666 !important;
}

form input[type=text]:focus,
form input[type=email]:focus,
form input[type=password]:focus {
    outline: none !important; 
    box-shadow: 0 0 5px var(--color-main) !important;
    border: 1px solid var(--color-main) !important; 
    transition: 0.5s;
    background-color: #f9f9f9 !important;   
}

.btn-password {
    color: #999;
    cursor: pointer;
    position: absolute;
    top: 2px;
    right: 2px;
    height: 54px;
    display: flex;
    align-items: center;
    border-radius: 0;
}

.icon::before {
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
}

.btn-password:before {
    font-family: "Font Awesome 5 Free"; font-weight: 900; content: "\f070";
 }
 
.active:before {
    font-family: "Font Awesome 5 Free"; font-weight: 900; content: "\f06e";
 }
 
 .btn-password:focus {
    outline: none !important; 
    box-shadow: none;    
}

/*ICONS NORMALIZE*/
[class^="icon-"]:before,
[class*=" icon-"]:before {
    position: relative !important;
    top: .125em !Important;
    margin-right: .4em !Important;
}

.icon-notext:before {
    top: 0;
    margin-right: 0 !important;;
}


/** MESSAGE */
.message {
    display: block;
    margin-bottom: 20px;
    padding: 15px;
    text-align: center;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    border: 1px solid #cccccc;
    font-weight: 500;
    background-color: #f9f9f9;
}

.message.success {
    color: #ffffff;
    border-color: var(--bs-success);
    background-color: var(--bs-success);
}

.message.info {
    color: #ffffff;
    border-color: var(--bs-info);
    background-color: var(--bs-info);
}

.message.warning {
    color: #ffffff;
    border-color: var(--bs-warning);
    background-color: var(--bs-warning);
}

.message.error {
    color: #ffffff;
    border-color: var(--bs-danger);
    background-color: var(--bs-danger);
}


/*DEFAULT LOAD*/
.ajax_load {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: calc(var(--index-modal) * 2);
}

.ajax_load_box {
    margin: auto;
    text-align: center;
    color: #ffffff;
    font-weight: var(--weight-bold);
    text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.5);
}

.ajax_load_box_circle {
    border: 16px solid #e3e3e3;
    border-top: 16px solid var(--bs-success);
    border-radius: 50%;
    margin: auto;
    width: 80px;
    height: 80px;

    -webkit-animation: spin 1.2s linear infinite;
    -o-animation: spin 1.2s linear infinite;
    animation: spin 1.2s linear infinite;
}

.ajax_load_box_title {
    margin-top: 15px;
    font-weight: var(--weight-strong);
}

@-webkit-keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(360deg);
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}