/* -----
CONTAINER AUTH
-------------------------------*/
html:has(#frmHeaderLogin){
    --theme-font-size: 16px;
}

.container-auth{
    height: 100vh;
    width: 100%;
}

.container-auth-operative{
    background: var(--content-bgcolor);
    position: relative;
}

.container-auth-operative-form{
    width: 350px;
    padding: 20px;
    max-width: 100%;
    max-height: 90%;
}

.container-auth-identity{
    position: relative;
    background: url("/sipal_is/javax.faces.resource/images/background-maggioli.jpg.xhtml?ln=include&v=20250629092816") center center no-repeat var(--content-bgcolor);
    background-position-x: right;
    background-size: contain;
}

.container-auth-identity.container-auth-identity-more-information{
    background: #E8E8E8;
}

.container-auth-identity.container-auth-identity-more-information .particles-js-canvas-el{
    position: absolute;
}

.container-auth-identity-content{
    position: relative;
    width: 375px;
    z-index: 2;
    text-align: center;
}

.container-auth-identity::before{
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    background: linear-gradient(transparent 40%, var(--content-bgcolor) 80%);
}

.container-auth-identity-credit{
    margin: 70px 60px;
    gap: 10px;
    position: absolute;
    z-index: 2;
    bottom: 0;
    right: 0;
}

@media(max-width: 767px){
    .container-auth-identity-credit{
        margin: 0 40px 30px 0
    }
    
    .container-auth-operative{
        padding-bottom: 150px;
    }
}

.container-auth-identity.container-auth-identity-more-information .container-auth-identity-credit{
    flex-direction: row-reverse;
    right: auto;
    left: 0;
}

.container-auth-identity-credit .container-auth-identity-credit-text{
    font-size: .85rem !important;
    text-align: right;
    color: #595959;
}

.container-auth-identity.container-auth-identity-more-information .container-auth-identity-credit .container-auth-identity-credit-text {
    text-align: left;
}

.container-auth-identity-credit img{
    height: 50px;
}



/* -----
HEADER LOGIN
-------------------------------*/
.container-login-header{
    margin-bottom: 20px;
    font-size: 16px;
}

.container-login-header-logo{
    height: 160px;
    max-width: 100%;
    object-fit: contain;
    image-rendering: auto;
    transition: .25s cubic-bezier(0.385, 0.135, 0.15, 0.86);
}

.container-login-header-logo.switchViewLogin{
    cursor: pointer;
}

.container-login-header-logo.active{
    transform: perspective(200px) rotateY(18deg);
}

.container-login-header-title{
    color: #00379e;
    font-size: 1.65rem;
    margin: 20px 0 0 0 !important;
}

body:not(.ui-applicativo-esterno) .container-login-header-title{
    font-size: 1.8rem;
}

.container-login-header-subtitle{
    margin-top: 10px;
    display: block;
    line-height: 20px;
    font-size: 1rem;
}

body:not(.ui-applicativo-esterno) .container-login-header-subtitle{
    font-size: 1.4rem;
    line-height: 30px;
}


@media (min-width: 768px){
    .container-login-header .container-login-header-title.container-login-header-title-left{
       margin: 0 25px -20px 25px !important;
    }   
}

@media (max-width: 767px){
    .container-login-header-logo{
        height: 145px;
    }
}



/* -----
FORM LOGIN
-------------------------------*/
body .ui-button.component-login-form-spid-provider{
    background-size: auto 25px !important;
    background-position-y: center !important;
    background-position-x: 10px !important;
    width: 100%;
    border: none !important;
    border-radius: 0 !important;
    border-bottom: 1px solid rgba(0, 0, 0, .1) !important;
}

.component-login-form-info-spid-provider{
    color: #4E4E4E;
}

.component-login-form-info-spid-provider:not(:last-child){
    border-bottom: 1px solid rgba(0,0,0,.1);    
}

.component-login-form-link{
    font-size: 14px !important;
    color: #8a8a8a !important;
    text-decoration: underline !important;
}

.authservice-button{
    border-radius: 100vmax;
    background: #F8F8F8;
    border: 1px solid #0066CC;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    text-transform: uppercase;
    width: 100%;
    padding: 5px;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #0066CC !important;
    margin-bottom: 10px;
    cursor: pointer;
}

.authservice-button img{
    height: 18px;
}

.spidProviders{
    display: none; 
    position: absolute;
    top: 0;
    right: 0;
    transform: translateX(calc(100% + 10px));
    border: 1px solid rgba(0,0,0,.1);
    height: 200px;
    width: 225px;
    max-width: 90%;
    overflow-y: auto;
    z-index: 9;
    background: var(--content-bgcolor);
    border-radius: 8px;
}

.spidProviders.full{
    width: 100%;
    top: 40px;
    right: auto;
    transform: none;
}

.spidProviders > section{ cursor: pointer; }
.spidProviders > section:hover{ background: rgba(0,0,0,.1); }

@media(max-width: 767px){
    .spidProviders{
        width: 100%;
        top: 40px;
        right: auto;
        transform: none;
    }
}






/* -----
LOGIN 2 FATTORI
-------------------------------*/
.container-component-login{
    position: relative;
    height: 290px;
    width: 350px;
}

.container-login-credentials,
.container-qr-2Factors,
.container-codice-2Factors{
    position: absolute;
    padding: 20px;
    border-radius: 24px;
    width: 100%;
}

body:not(.ui-applicativo-esterno) .container-login-credentials,
body:not(.ui-applicativo-esterno) .container-qr-2Factors,
body:not(.ui-applicativo-esterno) .container-codice-2Factors{
    box-shadow: 0 10px 33px -15px hsla(0, 0%, 7%, .16);
}

.container-qr-2Factors,
.container-codice-2Factors{
    opacity: 0;
    transform: translateY(-200px);
    display: none;
}

.form-login-container{
    opacity: 0;
    transform: translateX(50px);
    animation: HorizontalFadeIn .5s cubic-bezier(0.385, 0.135, 0.15, 0.86) forwards;
}

@keyframes fadeSlideOut {
    from { opacity: 1; transform: translateY(0); }
    to { opacity: 0; transform: translateY(-75px); }
}

@keyframes fadeSlideIn {
    from { opacity: 0; transform: translateY(-75px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes HorizontalFadeIn {
    from { opacity: 0; transform: translateX(50px); }
    to { opacity: 1; transform: translateX(0); }
}

@media (max-width: 676px){
    .container-component-login{
        height: 350px;
    }
}