html, body{
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;
    margin: 0px;
    padding: 0px;
    height: 100%;
    width: 100%;
    overflow: hidden;
    background-image: linear-gradient(to bottom right, rgba(239, 246, 255, .8), rgba(239, 246, 255, .2), rgba(240, 253, 244, .2));
}
@media screen and (min-width: 1600px) {
    body {
        zoom: 1.1;
    }
}
[v-cloak] {
    display:none !important;
}

.fx-container{
    width:100%;
    height:100%;
    display: flex;
    flex-direction: column;
    background: radial-gradient(76.43% 136.99% at 50% 47.12%, #fff 32.69%, #dbdeff 66.83%);
    background-image: linear-gradient(to bottom, #f1eaff, #ffffff);
}
.fx-header{
    height: 60px;
    background-color: #FFF4EE;
    display: flex;
    align-items: center;
    justify-content: right;
    border-bottom: 1px solid rgba(0, 0, 0, 0.07);
    padding: 0 20px;
    box-sizing: border-box;
}
.fx-header .el-row{
    align-items: center;
}
.fx-main{
    padding: 0px;
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
}
.fx-block{
    min-width: 0px;
    width: 760px;
    max-width: 80%;
}
.fx-block-hr{
    border-bottom: 1px solid rgba(0, 0, 0, 0.07);
    margin: 4px 0;
}
.fx-block-row{
    display: flex;
    align-items: center;
    padding: 12px 0px;
    cursor: pointer;
    transition: box-shadow 0.3s ease-in-out;
    border-radius: 2px;
}
.fx-block-row:hover{
    border-radius: 2px;
    background-color: rgb(250, 250, 250);
    box-sizing: border-box;
}

.ft-title{
    font-size: 24px;
    line-height: 28px;
    font-weight: 800;
}
.ft-subtitle{
    font-size: 16px;
    line-height: 24px;
    color: rgb(115, 115, 115);
}
.ft-text{
    font-size: 16px;
    line-height: 24px;
    color: rgb(19, 19, 19);
}
.ft-form-item{
    padding: 8px 0;
}
.ft-form-label{
    font-size: 12px;
    line-height: 18px;
    font-weight: 500;
}
.ft-form-description{
    display: block;
    color: rgb(115, 115, 115);
}

.fh-logo{
    width: 38px;
    height: 38px;
    background-color: #9454ab;
    border-radius: 12px;
    margin: 0 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.fh-logo img{
    width: 100%;
    height: 100%;
    border-radius: 10px;
}
.fh-logo .el-icon{
    color: white;
}

.login-head{
    width: 100%;
    height: 30%;
    align-items: center;
    background-color: cadetblue;
    color: white;
}
.login-body{
    position: relative;
    padding: 0px;
    box-sizing: border-box;
    width: 100%;
    min-width: 540px;
    border-radius: 20px;
    border: 8px solid rgba(228, 95, 79, 0.3);
    background: white;
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.15);
}
.login-body .login-button{
    width:100%;
    font-size:18px;
    font-weight:500;
    color:white;
    border-radius:8px;
    margin:0;
    box-sizing: border-box;
    background: #0f172a;
}
.login-body .login-button:hover{
    background: #0f172a;
}
.login-body .el-link{
    color: #3b82f6;
}
.login-body-left{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    min-height: 475px;
    color: white;
    border-radius: 15px;
    border: 5px solid white;
    position: relative;
    background: linear-gradient(45deg, rgb(212, 52, 33), rgb(255, 106, 11), rgb(255, 93, 7));
    background-size: 150% 150%;
    background: repeating-linear-gradient(45deg, #ff6600, #ff6600 1px, #ff5500 2px, #ff5500 3px);
}
.login-body-left img{
    max-width: 100%;
    max-height: 100%;
    width: 80%;
}
.login-body-right{
    position: relative;
    padding: 32px 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: white;
    border-radius: 15px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.login-body-form{
    min-height: 220px;
}
.login-message {
    color: rgba(151, 33, 33, 1);
    margin-bottom: 15px;
    font-size: 14px;
    text-align: center;
}
.login-agreement{
    color: rgb(115, 115, 115);
    font-weight: 400;
    font-size: 14px;
    position: absolute;
    bottom: 20px;
    left: 0;
    right: 0;
    width: 100%;
    margin: 0 auto;
}
.login-agreement a{
    color: currentColor;
    text-decoration: none;
    cursor: pointer;
}

.captcha-container {
    display: flex;
    flex-direction: column;
    row-gap: 10px;
    align-items: center;
}
.captcha-container .captcha-image {
    position: relative;
}
.captcha-container .captcha-img {
    width: 100%;
    height: 45px;
    cursor: pointer;
}
.captcha-container .captcha-input {
    width: 100%;
}
