.header {
    display: flex;
    align-items: center;
    padding: 15px;
}

.header .face {
    width: 3.75rem;
    height: 3.75rem;
    border-radius: 100%;
    margin-right: 20px;
    background-repeat: no-repeat;
    background-size: cover;
}

.header .user {
    flex: 1;
}

.header .user h3 {
    margin-bottom: 0.31rem;
}

.header .user p {
    font-size: 0.75rem;
}

.vip-box {
    height: 4.3125rem;
    position: relative;
    margin: 0.94rem 0;
    background-image: url("../image/user_vip_bg.png");
    background-size: 100% 4.3125rem;
    background-repeat: no-repeat;
    padding: 0.5rem 1rem;
}

.vip-box .grade {
    display: flex;
    align-items: center;
}

.vip-box .grade .icon {
    height: 1.125rem;
    margin-right: 0.5rem;
}

.vip-box .grade .txt {
    font-size: 1rem;
    font-weight: 700;
}

.vip-box .open {
    padding: 0.25rem 0.625rem;
    line-height: 1;
    background-image: linear-gradient(to right, #EA43EA, #4E11B0);
    border: 1px solid #E297D2;
    border-radius: 50px;
    font-size: 0.75rem;
}

.vip-box .max-icon {
    width: 5.375rem;
    height: 4.3125rem;
    position: absolute;
    right: 0.625rem;
    top: -2.7rem;
}

.money-box {
    background-color: #373b3f;
    border-radius: 0.5rem;
}

.money-box .tit {
    height: 2.5rem;
    display: flex;
    align-items: center;
    padding: 0 0.94rem;
    border-bottom: 1px solid #515558;
}

.money-box .tit .icon {
    width: 1.5rem;
    height: 1.5rem;
}

.money-box .con {
    height: 3.44rem;
    display: flex;
    align-items: center;
    padding: 0 0.94rem;
    justify-content: space-between;
}

.money-box .con span {
    font-size: 1rem;
}

.money-box .con span em {
    font-size: 1.38rem;
    font-style: normal;
}

.money-box .con a {
    padding: 0.31rem 0.5rem;
    border: 1px solid #976d91;
    border-radius: 3.75rem;
    font-size: 0.75rem;
    line-height: 1;
}

.menu-box {
    background-color: #373b3f;
    border-radius: 0.5rem;
    margin-top: 0.94rem;
    display: flex;
    flex-direction: column;
}

.menu-box a {
    width: 100%;
    padding: 0.94rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.menu-box .menu-icon {
    width: 1.25rem;
    height: 1.25rem;
}

.menu-box .more {
    width: 1.25rem;
    height: 1.25rem;
}

.logout {
    width: 100%;
    padding: 1.375rem 0;
    margin: 1rem auto 0 auto;
    display: block;
    text-align: center;
    background-color: #373b3f;
    border-radius: 0.5rem;
}

.login-box {
    height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-image: linear-gradient(to bottom, #7501f7, #000000);
}

.login-box h2 {
    font-size: 1.25rem;
    text-align: center;
    margin-bottom: 1rem;
}

.login-box .form {
    width: 80%;
    display: flex;
    flex-direction: column;
}

.login-box .form .input {
    width: 100%;
    height: 3.125rem;
    border: none;
    background-color: #300065;
    border-radius: 3.125rem;
    padding: 0 1rem;
    margin-bottom: 1rem;
    color: #fff;
    font-size: 1rem;
}

.login-box .form .input::placeholder {
    color: #b4b2b7;
}

.login-box .form .code {
    position: relative;
}

.login-box .form .sms-code-wrap .input {
    padding-right: 7rem;
}

.login-box .form .sms-btn {
    position: absolute;
    right: 0.25rem;
    top: 0.25rem;
    height: 2.625rem;
    line-height: 2.625rem;
    padding: 0 0.875rem;
    border-radius: 2.8125rem;
    background-image: linear-gradient(to right, #f829fa, #6f24e2);
    color: #fff;
    font-size: 0.875rem;
}

.login-box .form .image {
    height: 2.3125rem;
    position: absolute;
    right: 0.25rem;
    top: 0.25rem;
    border-radius: 2.8125rem;
}

.login-box .form .submit {
    width: 60%;
    height: 3.5rem;
    border-radius: 3.5rem;
    font-size: 1.125rem;
    text-align: center;
    line-height: 3.5rem;
    background-image: linear-gradient(to right, #f829fa, #6f24e2);
    margin: 0 auto;
    margin-top: 1rem;
}

.vod-tab {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.2rem 0;
    position: relative;
}

.vod-tab a {
    font-size: 1rem;
    padding: 0 0.625rem;
}

.vod-tab a.hover {
    color: #FF57FF;
    font-weight: 700;
}

.vod-tab a.delete {
    padding: 0;
    position: absolute;
    right: 0;
    top: 1.2rem;
}

.vod-tab a.delete img {
    width: 1.25rem;
    height: 1.25rem;
}

.vod-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.625rem;
}

.vod-list li {
    display: flex;
    flex-direction: column;
}

.vod-list li .pic {
    height: 9.0625rem;
    border-radius: 0.5rem;
    position: relative;
    display: block;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.vod-list li .pic span {
    position: absolute;
    top: 0.3125rem;
    right: 0.3125rem;
    padding: 0.4375rem 0.625rem;
    line-height: 1;
    font-size: 0.75rem;
    background-color: #000;
    border-radius: 50px;
}

.vod-list li .pic input {
    position: absolute;
    top: .5rem;
    left: .5rem;
    width: 1rem;
    height: 1rem;
    border: none;
    display: none;
}

.vod-list li .tit {
    color: #E8EAED;
    width: 100%;
    height: 1.4375rem;
    white-space: normal;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 0.625rem;
}

.vod-list li .love {
    color: #A8A8A8;
    background-image: url("../image/vod_love_icon.png");
    background-size: 1.25rem 1.25rem;
    background-repeat: no-repeat;
    background-position: left center;
    padding-left: 1.4375rem;
    margin-top: 0.2rem;
}

.vod-list li .type {
    color: #2088FF;
    margin-top: 0.2rem;
}

.upgrade-header {
    border-bottom: 2px solid rgba(255, 255, 255, .2);
    padding-bottom: 1rem;
}

.upgrade-tip {
    padding: 0.8125rem 0;
    margin-bottom: 1rem;
    font-size: 0.75rem;
}

.upgrade-tip a {
    color: #FF57FF;
}

.upgrade-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    row-gap: 2rem;
}

.upgrade-list .item {
    width: 10.125rem;
    height: 6.0625rem;
    background-image: url("../image/upgrade_bg.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    position: relative;
    line-height: 1;
}

.upgrade-list .item.day {
    background-image: url("../image/upgrade_bg_day.png");
}

.upgrade-list .item.week {
    background-image: url("../image/upgrade_bg_week.png");
}

.upgrade-list .item.month {
    background-image: url("../image/upgrade_bg_month.png");
}

.upgrade-list .item.year {
    background-image: url("../image/upgrade_bg_year.png");
}


.upgrade-list .item .spec {
    position: absolute;
    top: .5rem;
    left: 0.5rem;
    font-weight: 700;
}

.upgrade-list .item .spec img {
    width: 3.625rem;
    margin-right: .5rem;
}

.upgrade-list .item .price {
    position: absolute;
    top: 2.8rem;
    left: 0.5rem;
}

.upgrade-list .item .price span {
    font-weight: 700;
    font-size: 1.375rem;
    margin-right: .25rem;
}

.upgrade-list .item .name {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 1.4375rem;
    line-height: 1.4375rem;
    text-align: center;
}

.upgrade-list .item .icon {
    position: absolute;
    right: .5rem;
    top: -1rem;
}

.upgrade-list .item .icon img {
    width: 3.0625rem;
    height: 2.5rem;
}

.upgrade-msg {
    color: #FFBF6B;
    margin-top: 1.25rem;
}

.buy-box {
    background-color: #373b3f;
    border-radius: 0.5rem;
    margin-top: 1rem;
    padding: 0.94rem;
}

.buy-box input {
    width: 100%;
    color: #fff;
    border: none;
    height: 3rem;
    border-radius: 50px;
    font-size: 1rem;
    margin: 1rem 0;
    padding: 0 1rem;
    background-color: rgba(255, 255, 255, .3);
}

.buy-box input::placeholder {
    color: #fff;
}

.buy-box .btn {
    width: 100%;
    height: 3rem;
    display: block;
    font-size: 1rem;
    text-align: center;
    line-height: 3rem;
    border-radius: 50px;
    background-image: linear-gradient(to bottom, #FF57FF, #7728F5);
}

.money-tip {
    padding: 0.8125rem 1.25rem;
    border-bottom: 1px solid #a8a9aa;
}

.money-tip a, .money-my span {
    color: #FF57FF;
}

.money-my {
    padding: 0.8125rem 1.25rem;
}

.money-list {
    padding: 1.25rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    row-gap: 1.375rem;
}

.money-list .item {
    width: 10.125rem;
    height: 6rem;
    background-image: url("../image/buy_bg.png");
    background-repeat: no-repeat;
    background-size: 100%;
    position: relative;
    line-height: 1;
    cursor: pointer;
}

.money-list .item .num {
    position: absolute;
    bottom: 3.8rem;
    left: .625rem;
    font-size: 1.5rem;
    font-weight: 700;
}

.money-list .item .num em {
    font-size: 0.75rem;
    margin-left: .25rem;
    font-weight: normal;
}

.money-list .item .tit {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 1.375rem;
    line-height: 1.375rem;
    text-align: center;
    font-size: 0.75rem;
}

.money-list .item .du {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 3.875rem;
    line-height: 1.375rem;
    text-align: right;
    font-size: 0.75rem;
    padding-right: 5px;
    font-weight: bold;
}


.money-list .item .kf {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 2.875rem;
    line-height: 1.375rem;
    text-align: right;
    font-size: 0.75rem;
    padding-right: 5px;
    color: #FE9301;
    font-weight: bold;
}

.money-list .item .icon {
    position: absolute;
    top: 5px;
    right: .25rem;
    width: 3.6875rem;
    height: 1.4375rem;
}

.moneye-msg {
    color: #FFBF6B;
    padding: 1.25rem 1.25rem;
}

.pay-box {
    background-color: #373B3F;
    border-radius: 0.5rem;
    padding: 0 1rem;
    overflow: hidden;
}

.pay-box .item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, .2);
}

.pay-box .item:last-child {
    border-bottom: none;
}

.pay-box .btn {
    width: 100%;
    height: 3rem;
    display: block;
    font-size: 1rem;
    text-align: center;
    line-height: 3rem;
    border-radius: 50px;
    margin: 1rem 0;
    border: none;
    color: #fff;
    background-image: linear-gradient(to bottom, #FF57FF, #7728F5);
}

.form-box {
    background-color: #373B3F;
    border-radius: 0.5rem;
    padding: 0 1rem;
    overflow: hidden;
    margin-bottom: 1rem;
}

.form-box .item {
    display: flex;
    align-items: center;
    padding: 1rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, .2);
}

.form-box .item .label {
    width: 6.25rem;
    color: #A8A8A8;
    white-space: normal;
}

.form-box .item .right {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: end;
}

.form-box .item .right input {
    width: 100%;
    border: none;
    color: #A8A8A8;
    text-align: right;
    background-color: transparent;
}

.form-box .item .right .arrow {
    width: 1.25rem;
    height: 1.25rem;
}

.form-box .item:last-child {
    border-bottom: none;
}

.form-btn {
    width: 100%;
    height: 3rem;
    display: block;
    font-size: 1rem;
    text-align: center;
    line-height: 3rem;
    border-radius: .5rem;
    margin: 1rem 0;
    border: none;
    color: #fff;
    background-image: linear-gradient(to bottom, #FF57FF, #7728F5);
}