/* ==================
          边框
 ==================== */
/* -- 实线 -- */
.solid,
.solid-top,
.solid-right,
.solid-bottom,
.solid-left,
.solids,
.solids-top,
.solids-right,
.solids-bottom,
.solids-left,
.dashed,
.dashed-top,
.dashed-right,
.dashed-bottom,
.dashed-left {
    position: relative
}

.solid::after,
.solid-top::after,
.solid-right::after,
.solid-bottom::after,
.solid-left::after,
.solids::after,
.solids-top::after,
.solids-right::after,
.solids-bottom::after,
.solids-left::after,
.dashed::after,
.dashed-top::after,
.dashed-right::after,
.dashed-bottom::after,
.dashed-left::after {
    content: " ";
    width: 200%;
    height: 200%;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: inherit;
    -webkit-transform: scale(.5);
    transform: scale(.5);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    pointer-events: none;
    box-sizing: border-box
}

.solid::after {
    border: 1px solid rgba(0, 0, 0, .1)
}

.solid-top::after {
    border-top: 1px solid rgba(0, 0, 0, .1)
}

.solid-right::after {
    border-right: 1px solid rgba(0, 0, 0, .1)
}

.solid-bottom::after {
    border-bottom: 1px solid rgba(0, 0, 0, .1)
}

.solid-left::after {
    border-left: 1px solid rgba(0, 0, 0, .1)
}

.solids::after {
    border: 8px solid #eee
}

.solids-top::after {
    border-top: 8px solid #eee
}

.solids-right::after {
    border-right: 8px solid #eee
}

.solids-bottom::after {
    border-bottom: 8px solid #eee
}

.solids-left::after {
    border-left: 8px solid #eee
}

/* -- 虚线 -- */
.dashed::after {
    border: 1px dashed #ddd
}

.dashed-top::after {
    border-top: 1px dashed #ddd
}

.dashed-right::after {
    border-right: 1px dashed #ddd
}

.dashed-bottom::after {
    border-bottom: 1px dashed #ddd
}

.dashed-left::after {
    border-left: 1px dashed #ddd
}

/* -- 阴影 -- */
.shadow[class*="white"] {
    --ShadowSize: 0 1px 6px
}

.shadow-lg {
    --ShadowSize: 0px 20px 50px 0px
}

.shadow-warp {
    position: relative;
    box-shadow: 0 0 5px rgba(0, 0, 0, .1)
}

.shadow-warp:before,
.shadow-warp:after {
    position: absolute;
    content: "";
    top: 5px;
    bottom: 15px;
    left: 5px;
    width: 50%;
    box-shadow: 0 15px 5px rgba(0, 0, 0, .2);
    -webkit-transform: rotate(-3deg);
    transform: rotate(-3deg);
    z-index: -1
}

.shadow-warp:after {
    right: 5px;
    left: auto;
    -webkit-transform: rotate(3deg);
    transform: rotate(3deg)
}

.shadow-blur {
    position: relative
}

.shadow-blur::before {
    content: "";
    display: block;
    background: inherit;
    -webkit-filter: blur(5px);
    filter: blur(5px);
    position: absolute;
    width: 100%;
    height: 100%;
    top: 5px;
    left: 5px;
    z-index: -1;
    opacity: .4;
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    border-radius: inherit;
    -webkit-transform: scale(1);
    transform: scale(1)
}

/* ==================
          按钮
 ==================== */
.cu-btn {
    position: relative;
    border: 0px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding: 0 15px;
    font-size: 14px;
    height: 32px;
    line-height: 1;
    text-align: center;
    text-decoration: none;
    overflow: visible;
    margin-left: 0;
    -webkit-transform: translate(0px, 0px);
    transform: translate(0px, 0px);
    margin-right: 0
}

.cu-btn::after {
    display: none
}

.cu-btn:not([class*="bg-"]) {
    background-color: #f0f0f0
}

.cu-btn[class*="line"] {
    background-color: initial
}

.cu-btn[class*="line"]::after {
    content: " ";
    display: block;
    width: 200%;
    height: 200%;
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid currentColor;
    -webkit-transform: scale(.5);
    transform: scale(.5);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    box-sizing: border-box;
    border-radius: 6px;
    z-index: 1;
    pointer-events: none
}

.cu-btn.round[class*="line"]::after {
    border-radius: 500px
}

.cu-btn[class*="lines"]::after {
    border: 6px solid currentColor
}

.cu-btn[class*="bg-"]::after {
    display: none
}

.cu-btn.sm {
    padding: 0 5px;
    font-size: 5px;
    height: 24px
}

.cu-btn.lg {
    padding: 0 20px;
    font-size: 16px;
    height: 40px
}

.cu-btn.cuIcon.sm {
    width: 24px;
    height: 24px
}

.cu-btn.cuIcon {
    width: 32px;
    height: 32px;
    border-radius: 250px;
    padding: 0
}

button.cuIcon.lg {
    width: 40px;
    height: 40px
}

.cu-btn.shadow-blur::before {
    top: 4px;
    left: 4px;
    -webkit-filter: blur(6px);
    filter: blur(6px);
    opacity: .6
}

.cu-btn.button-hover {
    -webkit-transform: translate(1px, 1px);
    transform: translate(1px, 1px)
}

.block {
    display: block
}

.cu-btn.block {
    display: flex
}

.cu-btn[disabled] {
    opacity: .6;
    color: #fff
}

/* ==================
          徽章
 ==================== */
.cu-tag {
    font-size: 12px;
    vertical-align: middle;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding: 0px 8px;
    height: 24px;
    font-family: Helvetica Neue, Helvetica, sans-serif;
    white-space: nowrap
}

.cu-tag:not([class*="bg"]):not([class*="line"]) {
    background-color: #f1f1f1
}

.cu-tag[class*="line-"]::after {
    content: " ";
    width: 200%;
    height: 200%;
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid currentColor;
    -webkit-transform: scale(.5);
    transform: scale(.5);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    box-sizing: border-box;
    border-radius: inherit;
    z-index: 1;
    pointer-events: none
}

.cu-tag.radius[class*="line"]::after {
    border-radius: 6px
}

.cu-tag.round[class*="line"]::after {
    border-radius: 500px
}

.cu-tag[class*="line-"]::after {
    border-radius: 0
}

.cu-tag + .cu-tag {
    margin-left: 5px
}

.cu-tag.sm {
    font-size: 5px;
    padding: 0px 6px;
    height: 16px
}

.cu-capsule {
    display: inline-flex;
    vertical-align: middle
}

.cu-capsule + .cu-capsule {
    margin-left: 5px
}

.cu-capsule .cu-tag {
    margin: 0
}

.cu-capsule .cu-tag[class*="line-"]:last-child::after {
    border-left: 0px solid transparent
}

.cu-capsule .cu-tag[class*="line-"]:first-child::after {
    border-right: 0px solid transparent
}

.cu-capsule.radius .cu-tag:first-child {
    border-top-left-radius: 6px;
    border-bottom-left-radius: 6px
}

.cu-capsule.radius .cu-tag:last-child::after,
.cu-capsule.radius .cu-tag[class*="line-"] {
    border-top-right-radius: 6px;
    border-bottom-right-radius: 6px
}

.cu-capsule.round .cu-tag:first-child {
    border-top-left-radius: 100px;
    border-bottom-left-radius: 100px;
    text-indent: 4px
}

.cu-capsule.round .cu-tag:last-child::after,
.cu-capsule.round .cu-tag:last-child {
    border-top-right-radius: 100px;
    border-bottom-right-radius: 100px;
    text-indent: -4px
}

.cu-tag.badge {
    border-radius: 100px;
    position: absolute;
    top: -5px;
    right: -5px;
    font-size: 5px;
    padding: 0px 5px;
    height: 14px;
    color: #fff
}

.cu-tag.badge:not([class*="bg-"]) {
    background-color: #dd514c
}

.cu-tag:empty:not([class*="cuIcon-"]) {
    padding: 0px;
    width: 8px;
    height: 8px;
    top: -4px;
    right: -4px
}

.cu-tag[class*="cuIcon-"] {
    width: 16px;
    height: 16px;
    top: -4px;
    right: -4px
}

/* ==================
          头像
 ==================== */
.cu-avatar {
    font-variant: small-caps;
    margin: 0;
    padding: 0;
    display: inline-flex;
    text-align: center;
    justify-content: center;
    align-items: center;
    background-color: #ccc;
    color: #fff;
    white-space: nowrap;
    position: relative;
    width: 32px;
    height: 32px;
    background-size: cover;
    background-position: 50%;
    vertical-align: middle;
    font-size: 1.5em
}

.cu-avatar.sm {
    width: 24px;
    height: 24px;
    font-size: 1em
}

.cu-avatar.lg {
    width: 48px;
    height: 48px;
    font-size: 2em
}

.cu-avatar.xl {
    width: 56px;
    height: 56px;
    font-size: 2.5em
}

.cu-avatar .avatar-text {
    font-size: .4em
}

.cu-avatar-group {
    direction: rtl;
    unicode-bidi: bidi-override;
    padding: 0 5px 0 20px;
    display: inline-block
}

.cu-avatar-group .cu-avatar {
    margin-left: -15px;
    border: 4px solid #f1f1f1;
    vertical-align: middle
}

.cu-avatar-group .cu-avatar.sm {
    margin-left: -5px;
    border: 1px solid #f1f1f1
}

/* ==================
         进度条
 ==================== */
.cu-progress {
    overflow: hidden;
    height: 14px;
    background-color: #ebeef5;
    display: inline-flex;
    align-items: center;
    width: 100%
}

.cu-progress + div,
.cu-progress + span {
    line-height: 1
}

.cu-progress.xs {
    height: 5px
}

.cu-progress.sm {
    height: 5px
}

.cu-progress div {
    width: 0;
    height: 100%;
    align-items: center;
    display: flex;
    justify-items: flex-end;
    justify-content: space-around;
    font-size: 5px;
    color: #fff;
    transition: width .6s ease
}

.cu-progress span {
    align-items: center;
    display: flex;
    font-size: 5px;
    color: #333;
    text-indent: 5px
}

.cu-progress.text-progress {
    padding-right: 30px
}

.cu-progress.striped div {
    background-image: linear-gradient(45deg, hsla(0, 0%, 100%, .15) 25%, transparent 0, transparent 50%, hsla(0, 0%, 100%, .15) 0, hsla(0, 0%, 100%, .15) 75%, transparent 0, transparent);
    background-size: 36px 36px
}

.cu-progress.active div {
    -webkit-animation: progress-stripes 2s linear infinite;
    animation: progress-stripes 2s linear infinite
}

@-webkit-keyframes progress-stripes {
    from {
        background-position: 36px 0
    }
    to {
        background-position: 0 0
    }
}

@keyframes progress-stripes {
    from {
        background-position: 36px 0
    }
    to {
        background-position: 0 0
    }
}

/* ==================
          加载
 ==================== */
.cu-load {
    display: block;
    line-height: 3em;
    text-align: center
}

.cu-load::before {
    font-family: cuIcon;
    display: inline-block;
    margin-right: 6px
}

.cu-load.loading::before {
    content: "\\e67a";
    -webkit-animation: cuIcon-spin 2s infinite linear;
    animation: cuIcon-spin 2s infinite linear
}

.cu-load.loading::after {
    content: "加载中..."
}

.cu-load.over::before {
    content: "\\e64a"
}

.cu-load.over::after {
    content: "没有更多了"
}

.cu-load.erro::before {
    content: "\\e658"
}

.cu-load.erro::after {
    content: "加载失败"
}

.cu-load.load-cuIcon::before {
    font-size: 16px
}

.cu-load.load-cuIcon::after {
    display: none
}

.cu-load.load-cuIcon.over {
    display: none
}

.cu-load.load-modal {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 60px;
    left: 0;
    margin: auto;
    width: 115px;
    height: 115px;
    background-color: #fff;
    border-radius: 5px;
    box-shadow: 0 0 0px 1000px rgba(0, 0, 0, .5);
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    font-size: 14px;
    z-index: 9999;
    line-height: 2.4em
}

.cu-load.load-modal [class*="cuIcon-"] {
    font-size: 30px
}

.cu-load.load-modal img {
    width: 35px;
    height: 35px
}

.cu-load.load-modal::after {
    content: "";
    position: absolute;
    background-color: #fff;
    border-radius: 50%;
    width: 100px;
    height: 100px;
    font-size: 5px;
    border-top: 6px solid rgba(0, 0, 0, .05);
    border-right: 6px solid rgba(0, 0, 0, .05);
    border-bottom: 6px solid rgba(0, 0, 0, .05);
    border-left: 6px solid #f37b1d;
    -webkit-animation: cuIcon-spin 1s infinite linear;
    animation: cuIcon-spin 1s infinite linear;
    z-index: -1
}

.load-progress {
    pointer-events: none;
    top: 0;
    position: fixed;
    width: 100%;
    left: 0;
    z-index: 2000
}

.load-progress.hide {
    display: none
}

.load-progress .load-progress-bar {
    position: relative;
    width: 100%;
    height: 4px;
    overflow: hidden;
    transition: all .2s ease 0s
}

.load-progress .load-progress-spinner {
    position: absolute;
    top: 5px;
    right: 5px;
    z-index: 2000;
    display: block
}

.load-progress .load-progress-spinner::after {
    content: "";
    display: block;
    width: 12px;
    height: 12px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border: solid 4px transparent;
    border-top-color: inherit;
    border-left-color: inherit;
    border-radius: 50%;
    -webkit-animation: load-progress-spinner .4s linear infinite;
    animation: load-progress-spinner .4s linear infinite
}

@-webkit-keyframes load-progress-spinner {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }
    100% {
        -webkit-transform: rotate(1turn);
        transform: rotate(1turn)
    }
}

@keyframes load-progress-spinner {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0)
    }
    100% {
        -webkit-transform: rotate(1turn);
        transform: rotate(1turn)
    }
}

/* ==================
          列表
 ==================== */
.grayscale {
    -webkit-filter: grayscale(1);
    filter: grayscale(1)
}

.cu-list + .cu-list {
    margin-top: 15px
}

.cu-list > .cu-item {
    transition: all .6s ease-in-out 0s;
    -webkit-transform: translateX(0px);
    transform: translateX(0px)
}

.cu-list > .cu-item.move-cur {
    -webkit-transform: translateX(-115px);
    transform: translateX(-115px)
}

.cu-list > .cu-item .move {
    position: absolute;
    right: 0;
    display: flex;
    width: 115px;
    height: 100%;
    -webkit-transform: translateX(100%);
    transform: translateX(100%)
}

.cu-list > .cu-item .move div {
    display: flex;
    flex: 1;
    justify-content: center;
    align-items: center
}

.cu-list.menu-avatar {
    overflow: hidden
}

.cu-list.menu-avatar > .cu-item {
    position: relative;
    display: flex;
    padding-right: 5px;
    height: 60px;
    background-color: #fff;
    justify-content: flex-end;
    align-items: center
}

.cu-list.menu-avatar > .cu-item > .cu-avatar {
    position: absolute;
    left: 15px
}

.cu-list.menu-avatar > .cu-item .flex .text-cut {
    max-width: 28px
}

.cu-list.menu-avatar > .cu-item .content {
    position: absolute;
    left: 146px;
    width: calc(100% - 48px - 30px - 55px - 5px);
    line-height: 1.6em
}

.cu-list.menu-avatar > .cu-item .content.flex-sub {
    width: calc(100% - 48px - 30px - 5px)
}

.cu-list.menu-avatar > .cu-item .content > div:first-child {
    font-size: 15px;
    display: flex;
    align-items: center
}

.cu-list.menu-avatar > .cu-item .content .cu-tag.sm {
    display: inline-block;
    margin-left: 5px;
    height: 14px;
    font-size: 8px;
    line-height: 16px
}

.cu-list.menu-avatar > .cu-item .action {
    width: 50px;
    text-align: center
}

.cu-list.menu-avatar > .cu-item .action div + div {
    margin-top: 5px
}

.cu-list.menu-avatar.comment > .cu-item .content {
    position: relative;
    left: 0;
    width: auto;
    flex: 1
}

.cu-list.menu-avatar.comment > .cu-item {
    padding: 15px 15px 15px 55px;
    height: auto
}

.cu-list.menu-avatar.comment .cu-avatar {
    align-self: flex-start
}

.cu-list.menu > .cu-item {
    position: relative;
    display: flex;
    padding: 0 15px;
    min-height: 50px;
    background-color: #fff;
    justify-content: space-between;
    align-items: center
}

.cu-list.menu > .cu-item:last-child:after {
    border: none
}

.cu-list.menu-avatar > .cu-item:after,
.cu-list.menu > .cu-item:after {
    position: absolute;
    top: 0;
    left: 0;
    box-sizing: border-box;
    width: 200%;
    height: 200%;
    border-bottom: 1px solid #ddd;
    border-radius: inherit;
    content: " ";
    -webkit-transform: scale(.5);
    transform: scale(.5);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    pointer-events: none
}

.cu-list.menu > .cu-item.grayscale {
    background-color: #f5f5f5
}

.cu-list.menu > .cu-item.cur {
    background-color: #fcf7e9
}

.cu-list.menu > .cu-item.arrow {
    padding-right: 45px
}

.cu-list.menu > .cu-item.arrow:before {
    position: absolute;
    top: 0;
    right: 15px;
    bottom: 0;
    display: block;
    margin: auto;
    width: 15px;
    height: 15px;
    color: #8799a3;
    content: "\\e6a3";
    text-align: center;
    font-size: 17px;
    font-family: cuIcon;
    line-height: 15px
}

.cu-list.menu > .cu-item button.content {
    padding: 0;
    background-color: initial;
    justify-content: flex-start
}

.cu-list.menu > .cu-item button.content:after {
    display: none
}

.cu-list.menu > .cu-item .cu-avatar-group .cu-avatar {
    border-color: #fff
}

.cu-list.menu > .cu-item .content > div:first-child {
    display: flex;
    align-items: center
}

.cu-list.menu > .cu-item .content > span[class*=cuIcon] {
    display: inline-block;
    margin-right: 5px;
    width: 1.6em;
    text-align: center
}

.cu-list.menu > .cu-item .content > img {
    display: inline-block;
    margin-right: 5px;
    width: 1.6em;
    height: 1.6em;
    vertical-align: middle
}

.cu-list.menu > .cu-item .content {
    font-size: 15px;
    line-height: 1.6em;
    flex: 1
}

.cu-list.menu > .cu-item .content .cu-tag.sm {
    display: inline-block;
    margin-left: 5px;
    height: 14px;
    font-size: 8px;
    line-height: 16px
}

.cu-list.menu > .cu-item .action .cu-tag:empty {
    right: 5px
}

.cu-list.menu {
    display: block;
    overflow: hidden
}

.cu-list.menu.sm-border > .cu-item:after {
    left: 15px;
    width: calc(200% - 55px)
}

.cu-list.grid > .cu-item {
    position: relative;
    display: flex;
    padding: 5px 0 15px;
    transition-duration: 0s;
    flex-direction: column
}

.cu-list.grid > .cu-item:after {
    position: absolute;
    top: 0;
    left: 0;
    box-sizing: border-box;
    width: 200%;
    height: 200%;
    border-right: 1px solid rgba(0, 0, 0, .1);
    border-bottom: 1px solid rgba(0, 0, 0, .1);
    border-radius: inherit;
    content: " ";
    -webkit-transform: scale(.5);
    transform: scale(.5);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    pointer-events: none
}

.cu-list.grid > .cu-item span {
    display: block;
    margin-top: 5px;
    color: #888;
    font-size: 13px;
    line-height: 20px
}

.cu-list.grid > .cu-item [class*=cuIcon] {
    position: relative;
    display: block;
    margin-top: 5px;
    width: 100%;
    font-size: 24px
}

.cu-list.grid > .cu-item .cu-tag {
    right: auto;
    left: 50%;
    margin-left: 5px
}

.cu-list.grid {
    background-color: #fff;
    text-align: center
}

.cu-list.grid.no-border > .cu-item {
    padding-top: 5px;
    padding-bottom: 5px
}

.cu-list.grid.no-border > .cu-item:after {
    border: none
}

.cu-list.grid.no-border {
    padding: 5px 5px
}

.cu-list.grid.col-3 > .cu-item:nth-child(3n):after,
.cu-list.grid.col-4 > .cu-item:nth-child(4n):after,
.cu-list.grid.col-5 > .cu-item:nth-child(5n):after {
    border-right-width: 0
}

.cu-list.card-menu {
    overflow: hidden;
    margin-right: 15px;
    margin-left: 15px;
    border-radius: 5px
}

/* ==================
          操作条
 ==================== */
.cu-bar {
    display: flex;
    position: relative;
    align-items: center;
    min-height: 50px;
    justify-content: space-between
}

.cu-bar .action {
    display: flex;
    align-items: center;
    height: 100%;
    justify-content: center;
    max-width: 100%
}

.cu-bar .action.border-title {
    position: relative;
    top: -5px
}

.cu-bar .action.border-title span[class*="bg-"]:last-child {
    position: absolute;
    bottom: -.5rem;
    min-width: 2rem;
    height: 6px;
    left: 0
}

.cu-bar .action.sub-title {
    position: relative;
    top: -.2rem
}

.cu-bar .action.sub-title span {
    position: relative;
    z-index: 1
}

.cu-bar .action.sub-title span[class*="bg-"]:last-child {
    position: absolute;
    display: inline-block;
    bottom: -.2rem;
    border-radius: 6px;
    width: 100%;
    height: .6rem;
    left: .6rem;
    opacity: .3;
    z-index: 0
}

.cu-bar .action.sub-title span[class*="text-"]:last-child {
    position: absolute;
    display: inline-block;
    bottom: -.7rem;
    left: .5rem;
    opacity: .2;
    z-index: 0;
    text-align: right;
    font-weight: 900;
    font-size: 18px
}

.cu-bar.justify-center .action.border-title span:last-child,
.cu-bar.justify-center .action.sub-title span:last-child {
    left: 0;
    right: 0;
    margin: auto;
    text-align: center
}

.cu-bar .action:first-child {
    margin-left: 15px;
    font-size: 15px
}

.cu-bar .action span.text-cut {
    text-align: left;
    width: 100%
}

.cu-bar .cu-avatar:first-child {
    margin-left: 5px
}

.cu-bar .action:first-child > span[class*="cuIcon-"] {
    margin-left: -.3em;
    margin-right: .3em
}

.cu-bar .action:last-child {
    margin-right: 15px
}

.cu-bar .action > span[class*="cuIcon-"],
.cu-bar .action > div[class*="cuIcon-"] {
    font-size: 18px
}

.cu-bar .action > span[class*="cuIcon-"] + span[class*="cuIcon-"] {
    margin-left: .5em
}

.cu-bar .content {
    position: absolute;
    text-align: center;
    width: calc(100% - 160px);
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
    height: 30px;
    font-size: 16px;
    line-height: 30px;
    cursor: none;
    pointer-events: none;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden
}

.cu-bar.ios .content {
    bottom: 7px;
    height: 15px;
    font-size: 16px;
    line-height: 15px
}

.cu-bar.btn-group {
    justify-content: space-around
}

.cu-bar.btn-group button {
    padding: 5px 16px
}

.cu-bar.btn-group button {
    flex: 1;
    margin: 0 5px;
    max-width: 50%
}

.cu-bar .search-form {
    background-color: #f5f5f5;
    line-height: 32px;
    height: 32px;
    font-size: 12px;
    color: #333;
    flex: 1;
    display: flex;
    align-items: center;
    margin: 0 15px
}

.cu-bar .search-form + .action {
    margin-right: 15px
}

.cu-bar .search-form input {
    flex: 1;
    padding-right: 15px;
    height: 32px;
    line-height: 32px;
    font-size: 13px;
    background-color: initial
}

.cu-bar .search-form [class*="cuIcon-"] {
    margin: 0 .5em 0 .8em
}

.cu-bar .search-form [class*="cuIcon-"]::before {
    top: 0px
}

.cu-bar.fixed,
.nav.fixed {
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 1024;
    box-shadow: 0 1px 6px rgba(0, 0, 0, .1)
}

.cu-bar.foot {
    position: fixed;
    width: 100%;
    bottom: 0;
    z-index: 1024;
    box-shadow: 0 -1px 6px rgba(0, 0, 0, .1)
}

.cu-bar.tabbar {
    padding: 0;
    height: calc(50px + env(safe-area-inset-bottom) / 2);
    padding-bottom: calc(env(safe-area-inset-bottom) / 2)
}

.cu-tabbar-height {
    min-height: 50px;
    height: calc(50px + env(safe-area-inset-bottom) / 2)
}

.cu-bar.tabbar.shadow {
    box-shadow: 0 -1px 6px rgba(0, 0, 0, .1)
}

.cu-bar.tabbar .action {
    font-size: 12px;
    position: relative;
    flex: 1;
    text-align: center;
    padding: 0;
    display: block;
    height: auto;
    line-height: 1;
    margin: 0;
    background-color: inherit;
    overflow: initial
}

.cu-bar.tabbar.shop .action {
    width: 60px;
    flex: initial
}

.cu-bar.tabbar .action.add-action {
    position: relative;
    z-index: 2;
    padding-top: 25px
}

.cu-bar.tabbar .action.add-action [class*="cuIcon-"] {
    position: absolute;
    width: 35px;
    z-index: 2;
    height: 35px;
    border-radius: 50%;
    line-height: 35px;
    font-size: 25px;
    top: -16px;
    left: 0;
    right: 0;
    margin: auto;
    padding: 0
}

.cu-bar.tabbar .action.add-action::after {
    content: "";
    position: absolute;
    width: 50px;
    height: 50px;
    top: -25px;
    left: 0;
    right: 0;
    margin: auto;
    box-shadow: 0 -3px 8px rgba(0, 0, 0, .08);
    border-radius: 25px;
    background-color: inherit;
    z-index: 0
}

.cu-bar.tabbar .action.add-action::before {
    content: "";
    position: absolute;
    width: 50px;
    height: 15px;
    bottom: 15px;
    left: 0;
    right: 0;
    margin: auto;
    background-color: inherit;
    z-index: 1
}

.cu-bar.tabbar .btn-group {
    flex: 1;
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding: 0 5px
}

.cu-bar.tabbar button.action::after {
    border: 0
}

.cu-bar.tabbar .action [class*="cuIcon-"] {
    width: 50px;
    position: relative;
    display: block;
    height: auto;
    margin: 0 auto 5px;
    text-align: center;
    font-size: 20px
}

.cu-bar.tabbar .action .cuIcon-cu-image {
    margin: 0 auto
}

.cu-bar.tabbar .action .cuIcon-cu-image img {
    width: 25px;
    height: 25px;
    display: inline-block
}

.cu-bar.tabbar .submit {
    align-items: center;
    display: flex;
    justify-content: center;
    text-align: center;
    position: relative;
    flex: 2;
    align-self: stretch
}

.cu-bar.tabbar .submit:last-child {
    flex: 2.6
}

.cu-bar.tabbar .submit + .submit {
    flex: 2
}

.cu-bar.tabbar.border .action::before {
    content: " ";
    width: 200%;
    height: 200%;
    position: absolute;
    top: 0;
    left: 0;
    -webkit-transform: scale(.5);
    transform: scale(.5);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    border-right: 1px solid rgba(0, 0, 0, .1);
    z-index: 3
}

.cu-bar.tabbar.border .action:last-child:before {
    display: none
}

.cu-bar.input {
    padding-right: 5px;
    background-color: #fff
}

.cu-bar.input input {
    overflow: initial;
    line-height: 32px;
    height: 32px;
    min-height: 32px;
    flex: 1;
    font-size: 15px;
    margin: 0 5px
}

.cu-bar.input .action {
    margin-left: 5px
}

.cu-bar.input .action [class*="cuIcon-"] {
    font-size: 24px
}

.cu-bar.input input + .action {
    margin-right: 5px;
    margin-left: 0px
}

.cu-bar.input .action:first-child [class*="cuIcon-"] {
    margin-left: 0px
}

.cu-custom {
    display: block;
    position: relative
}

.cu-custom .cu-bar .content {
    width: calc(100% - 210px)
}

.cu-custom .cu-bar .content img {
    height: 30px;
    width: 110px
}

.cu-custom .cu-bar {
    min-height: 0;
    box-shadow: 0px 0px 0px;
    z-index: 9999
}

.cu-custom .cu-bar .border-custom {
    position: relative;
    background: rgba(0, 0, 0, .15);
    border-radius: 500px;
    height: 15px
}

.cu-custom .cu-bar .border-custom::after {
    content: " ";
    width: 200%;
    height: 200%;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: inherit;
    -webkit-transform: scale(.5);
    transform: scale(.5);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    pointer-events: none;
    box-sizing: border-box;
    border: 1px solid #fff;
    opacity: .5
}

.cu-custom .cu-bar .border-custom::before {
    content: " ";
    width: 1px;
    height: 110%;
    position: absolute;
    top: 22.5%;
    left: 0;
    right: 0;
    margin: auto;
    -webkit-transform: scale(.5);
    transform: scale(.5);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    pointer-events: none;
    box-sizing: border-box;
    opacity: .6;
    background-color: #fff
}

.cu-custom .cu-bar .border-custom span {
    display: block;
    flex: 1;
    margin: auto !important;
    text-align: center;
    font-size: 17px
}

/* ==================
         导航栏
 ==================== */
.nav {
    white-space: nowrap
}

::-webkit-scrollbar {
    display: none
}

.nav .cu-item {
    height: 45px;
    display: inline-block;
    line-height: 45px;
    margin: 0 5px;
    padding: 0 5px
}

.nav .cu-item.cur {
    border-bottom: 4px solid
}

/* ==================
         时间轴
 ==================== */
.cu-timeline {
    display: block;
    background-color: #fff
}

.cu-timeline .cu-time {
    width: 55px;
    text-align: center;
    padding: 5px 0;
    font-size: 13px;
    color: #888;
    display: block
}

.cu-timeline > .cu-item {
    padding: 15px 15px 15px 55px;
    position: relative;
    display: block;
    z-index: 0
}

.cu-timeline > .cu-item:not([class*="text-"]) {
    color: #ccc
}

.cu-timeline > .cu-item::after {
    content: "";
    display: block;
    position: absolute;
    width: 1px;
    background-color: #ddd;
    left: 30px;
    height: 100%;
    top: 0;
    z-index: 8
}

.cu-timeline > .cu-item::before {
    font-family: cuIcon;
    display: block;
    position: absolute;
    top: 18px;
    z-index: 9;
    background-color: #fff;
    width: 25px;
    height: 25px;
    text-align: center;
    border: none;
    line-height: 25px;
    left: 18px
}

.cu-timeline > .cu-item:not([class*="cuIcon-"])::before {
    content: "\\e763"
}

.cu-timeline > .cu-item[class*="cuIcon-"]::before {
    background-color: #fff;
    width: 25px;
    height: 25px;
    text-align: center;
    border: none;
    line-height: 25px;
    left: 18px
}

.cu-timeline > .cu-item > .content {
    padding: 15px;
    border-radius: 6px;
    display: block;
    line-height: 1.6
}

.cu-timeline > .cu-item > .content:not([class*="bg-"]) {
    background-color: #f1f1f1;
    color: #333
}

.cu-timeline > .cu-item > .content + .content {
    margin-top: 5px
}

/* ==================
         聊天
 ==================== */
.cu-chat {
    display: flex;
    flex-direction: column
}

.cu-chat .cu-item {
    display: flex;
    padding: 15px 15px 35px;
    position: relative
}

.cu-chat .cu-item > .cu-avatar {
    width: 40px;
    height: 40px
}

.cu-chat .cu-item > .main {
    max-width: calc(100% - 115px);
    margin: 0 20px;
    display: flex;
    align-items: center
}

.cu-chat .cu-item > img {
    height: 155px
}

.cu-chat .cu-item > .main .content {
    padding: 5px;
    border-radius: 6px;
    display: inline-flex;
    max-width: 100%;
    align-items: center;
    font-size: 15px;
    position: relative;
    min-height: 40px;
    line-height: 20px;
    text-align: left
}

.cu-chat .cu-item > .main .content:not([class*="bg-"]) {
    background-color: #fff;
    color: #333
}

.cu-chat .cu-item .date {
    position: absolute;
    font-size: 12px;
    color: #8799a3;
    width: calc(100% - 155px);
    bottom: 5px;
    left: 65px
}

.cu-chat .cu-item .action {
    padding: 0 15px;
    display: flex;
    align-items: center
}

.cu-chat .cu-item > .main .content::after {
    content: "";
    top: 15px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    z-index: 100;
    display: inline-block;
    overflow: hidden;
    width: 12px;
    height: 12px;
    left: -6px;
    right: auto;
    background-color: inherit
}

.cu-chat .cu-item.self > .main .content::after {
    left: auto;
    right: -6px
}

.cu-chat .cu-item > .main .content::before {
    content: "";
    top: 15px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    z-index: -1;
    display: inline-block;
    overflow: hidden;
    width: 12px;
    height: 12px;
    left: -6px;
    right: auto;
    background-color: inherit;
    -webkit-filter: blur(5px);
    filter: blur(5px);
    opacity: .3
}

.cu-chat .cu-item > .main .content:not([class*="bg-"])::before {
    background-color: #333;
    opacity: .1
}

.cu-chat .cu-item.self > .main .content::before {
    left: auto;
    right: -6px
}

.cu-chat .cu-item.self {
    justify-content: flex-end;
    text-align: right
}

.cu-chat .cu-info {
    display: inline-block;
    margin: 5px auto;
    font-size: 12px;
    padding: 8px 6px;
    background-color: rgba(0, 0, 0, .2);
    border-radius: 6px;
    color: #fff;
    max-width: 200px;
    line-height: 1.4
}

/* ==================
         卡片
 ==================== */
.cu-card {
    display: block;
    overflow: hidden
}

.cu-card > .cu-item {
    display: block;
    background-color: #fff;
    overflow: hidden;
    border-radius: 5px;
    margin: 15px
}

.cu-card > .cu-item.shadow-blur {
    overflow: initial
}

.cu-card.no-card > .cu-item {
    margin: 0px;
    border-radius: 0px
}

.cu-card .grid.grid-square {
    margin-bottom: -5px
}

.cu-card.case .image {
    position: relative
}

.cu-card.case .image img {
    width: 100%
}

.cu-card.case .image .cu-tag {
    position: absolute;
    right: 0;
    top: 0
}

.cu-card.case .image .cu-bar {
    position: absolute;
    bottom: 0;
    width: 100%;
    background-color: initial;
    padding: 0px 15px
}

.cu-card.case.no-card .image {
    margin: 15px 15px 0;
    overflow: hidden;
    border-radius: 5px
}

.cu-card.dynamic {
    display: block
}

.cu-card.dynamic > .cu-item {
    display: block;
    background-color: #fff;
    overflow: hidden
}

.cu-card.dynamic > .cu-item > .text-content {
    padding: 0 15px 0;
    max-height: 6.4em;
    overflow: hidden;
    font-size: 15px;
    margin-bottom: 5px
}

.cu-card.dynamic > .cu-item .square-img {
    width: 100%;
    height: 100px;
    border-radius: 6px
}

.cu-card.dynamic > .cu-item .only-img {
    width: 100%;
    height: 155px;
    border-radius: 6px
}

/* card.dynamic>.cu-item .comment {
  padding: 5px;
  background-color: #f1f1f1;
  margin: 0 15px 15px;
  border-radius: 6px;
} */
.cu-card.article {
    display: block
}

.cu-card.article > .cu-item {
    padding-bottom: 15px
}

.cu-card.article > .cu-item .title {
    font-size: 15px;
    font-weight: 900;
    color: #333;
    line-height: 50px;
    padding: 0 15px
}

.cu-card.article > .cu-item .content {
    display: flex;
    padding: 0 15px
}

.cu-card.article > .cu-item .content > img {
    width: 110px;
    height: 6.4em;
    margin-right: 5px;
    border-radius: 6px
}

.cu-card.article > .cu-item .content .desc {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between
}

.cu-card.article > .cu-item .content .text-content {
    font-size: 14px;
    color: #888;
    height: 4.8em;
    overflow: hidden
}

/* ==================
         表单
 ==================== */
.cu-form-group {
    background-color: #fff;
    padding: 1px 15px;
    display: flex;
    align-items: center;
    min-height: 50px;
    justify-content: space-between
}

.cu-form-group + .cu-form-group {
    border-top: 1px solid #eee
}

.cu-form-group .title {
    text-align: justify;
    padding-right: 15px;
    font-size: 15px;
    position: relative;
    height: 30px;
    line-height: 30px
}

.cu-form-group input {
    flex: 1;
    font-size: 15px;
    color: #555;
    padding-right: 5px
}

.cu-form-group > span[class*="cuIcon-"] {
    font-size: 18px;
    padding: 0;
    box-sizing: border-box
}

.cu-form-group spanarea {
    margin: 16px 0 15px;
    height: 4.6em;
    width: 100%;
    line-height: 1.2em;
    flex: 1;
    font-size: 14px;
    padding: 0
}

.cu-form-group.align-start .title {
    height: 1em;
    margin-top: 16px;
    line-height: 1em
}

.cu-form-group uni-picker {
    flex: 1;
    padding-right: 20px;
    overflow: hidden;
    position: relative
}

.cu-form-group uni-picker .picker {
    line-height: 50px;
    font-size: 14px;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
    width: 100%;
    text-align: right
}

.cu-form-group uni-picker::after {
    font-family: cuIcon;
    display: block;
    content: "\\e6a3";
    position: absolute;
    font-size: 17px;
    color: #8799a3;
    line-height: 50px;
    width: 30px;
    text-align: center;
    top: 0;
    bottom: 0;
    right: -5px;
    margin: auto
}

.cu-form-group spanarea[disabled],
.cu-form-group spanarea[disabled] .placeholder {
    color: transparent
}

/* ==================
         模态窗口
 ==================== */
.cu-modal {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1110;
    opacity: 0;
    outline: 0;
    text-align: center;
    -ms-transform: scale(1.185);
    -webkit-transform: scale(1.185);
    transform: scale(1.185);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-perspective: 1000px;
    perspective: 1000px;
    background: rgba(0, 0, 0, .6);
    transition: all .3s ease-in-out 0s;
    pointer-events: none
}

.cu-modal::before {
    content: "\\200B";
    display: inline-block;
    height: 100%;
    vertical-align: middle
}

.cu-modal.show {
    opacity: 1;
    transition-duration: .3s;
    -ms-transform: scale(1);
    -webkit-transform: scale(1);
    transform: scale(1);
    overflow-x: hidden;
    overflow-y: auto;
    pointer-events: auto
}

.cu-dialog {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    margin-left: auto;
    margin-right: auto;
    width: 640px;
    max-width: 100%;
    background-color: #f8f8f8;
    border-radius: 5px;
    overflow: hidden
}

.cu-modal.bottom-modal::before {
    vertical-align: bottom
}

.cu-modal.bottom-modal .cu-dialog {
    width: 100%;
    border-radius: 0
}

.cu-modal.bottom-modal {
    margin-bottom: -500px
}

.cu-modal.bottom-modal.show {
    margin-bottom: 0
}

.cu-modal.drawer-modal {
    -webkit-transform: scale(1);
    transform: scale(1);
    display: flex
}

.cu-modal.drawer-modal .cu-dialog {
    height: 100%;
    min-width: 100px;
    border-radius: 0;
    margin: initial;
    transition-duration: .3s
}

.cu-modal.drawer-modal.justify-start .cu-dialog {
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%)
}

.cu-modal.drawer-modal.justify-end .cu-dialog {
    -webkit-transform: translateX(100%);
    transform: translateX(100%)
}

.cu-modal.drawer-modal.show .cu-dialog {
    -webkit-transform: translateX(0);
    transform: translateX(0)
}

.cu-modal .cu-dialog > .cu-bar:first-child .action {
    min-width: 50px;
    margin-right: 0;
    min-height: 50px
}

/* ==================
         轮播
 ==================== */
uni-swiper .a-swiper-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    background: rgba(0, 0, 0, .3);
    border-radius: 50%;
    vertical-align: middle
}

uni-swiper[class*="-dot"] .wx-swiper-dots,
uni-swiper[class*="-dot"] .a-swiper-dots,
uni-swiper[class*="-dot"] .uni-swiper-dots {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center
}

uni-swiper.square-dot .wx-swiper-dot,
uni-swiper.square-dot .a-swiper-dot,
uni-swiper.square-dot .uni-swiper-dot {
    background-color: #fff;
    opacity: .4;
    width: 5px;
    height: 5px;
    border-radius: 5px;
    margin: 0 8px !important
}

uni-swiper.square-dot .wx-swiper-dot.wx-swiper-dot-active,
uni-swiper.square-dot .a-swiper-dot.a-swiper-dot-active,
uni-swiper.square-dot .uni-swiper-dot.uni-swiper-dot-active {
    opacity: 1;
    width: 15px
}

uni-swiper.round-dot .wx-swiper-dot,
uni-swiper.round-dot .a-swiper-dot,
uni-swiper.round-dot .uni-swiper-dot {
    width: 5px;
    height: 5px;
    position: relative;
    margin: 4px 8px !important
}

uni-swiper.round-dot .wx-swiper-dot.wx-swiper-dot-active::after,
uni-swiper.round-dot .a-swiper-dot.a-swiper-dot-active::after,
uni-swiper.round-dot .uni-swiper-dot.uni-swiper-dot-active::after {
    content: "";
    position: absolute;
    width: 5px;
    height: 5px;
    top: 0px;
    left: 0px;
    right: 0;
    bottom: 0;
    margin: auto;
    background-color: #fff;
    border-radius: 5px
}

uni-swiper.round-dot .wx-swiper-dot.wx-swiper-dot-active,
uni-swiper.round-dot .a-swiper-dot.a-swiper-dot-active,
uni-swiper.round-dot .uni-swiper-dot.uni-swiper-dot-active {
    width: 5px;
    height: 5px
}

.screen-swiper {
    min-height: 375px
}

.screen-swiper img,
.screen-swiper video,
.swiper-item img,
.swiper-item video {
    width: 100%;
    display: block;
    height: 100%;
    margin: 0;
    pointer-events: none
}

.card-swiper {
    height: 205px !important
}

.card-swiper uni-swiper-item {
    width: 32px !important;
    left: 35px;
    box-sizing: border-box;
    padding: 20px 0px 35px;
    overflow: initial
}

.card-swiper uni-swiper-item .swiper-item {
    width: 100%;
    display: block;
    height: 100%;
    border-radius: 5px;
    -webkit-transform: scale(.7);
    transform: scale(.7);
    transition: all .2s ease-in 0s;
    overflow: hidden
}

.card-swiper uni-swiper-item.cur .swiper-item {
    -webkit-transform: none;
    transform: none;
    transition: all .2s ease-in 0s
}

.tower-swiper {
    height: 205px;
    position: relative;
    max-width: 725px;
    overflow: hidden
}

.tower-swiper .tower-item {
    position: absolute;
    width: 150px;
    height: 170px;
    top: 0;
    bottom: 0;
    left: 50%;
    margin: auto;
    transition: all .2s ease-in 0s;
    opacity: 1
}

.tower-swiper .tower-item.none {
    opacity: 0
}

.tower-swiper .tower-item .swiper-item {
    width: 100%;
    height: 100%;
    border-radius: 6px;
    overflow: hidden
}

/* ==================
          步骤条
 ==================== */
.cu-steps {
    display: flex
}

uni-scroll-view.cu-steps {
    display: block;
    white-space: nowrap
}

uni-scroll-view.cu-steps .cu-item {
    display: inline-block
}

.cu-steps .cu-item {
    flex: 1;
    text-align: center;
    position: relative;
    min-width: 50px
}

.cu-steps .cu-item:not([class*="text-"]) {
    color: #8799a3
}

.cu-steps .cu-item [class*="cuIcon-"],
.cu-steps .cu-item .num {
    display: block;
    font-size: 20px;
    line-height: 40px
}

.cu-steps .cu-item::before,
.cu-steps .cu-item::after,
.cu-steps.steps-arrow .cu-item::before,
.cu-steps.steps-arrow .cu-item::after {
    content: "";
    display: block;
    position: absolute;
    height: 0;
    width: calc(100% - 40px);
    border-bottom: 1px solid #ccc;
    left: calc(0px - (100% - 40px) / 2);
    top: 20px;
    z-index: 0
}

.cu-steps.steps-arrow .cu-item::before,
.cu-steps.steps-arrow .cu-item::after {
    content: "\\e6a3";
    font-family: cuIcon;
    height: 15px;
    border-bottom-width: 0;
    line-height: 15px;
    top: 0;
    bottom: 0;
    margin: auto;
    color: #ccc
}

.cu-steps.steps-bottom .cu-item::before,
.cu-steps.steps-bottom .cu-item::after {
    bottom: 20px;
    top: auto
}

.cu-steps .cu-item::after {
    border-bottom: 1px solid currentColor;
    width: 0;
    transition: all .3s ease-in-out 0s
}

.cu-steps .cu-item[class*="text-"]::after {
    width: calc(100% - 40px);
    color: currentColor
}

.cu-steps .cu-item:first-child::before,
.cu-steps .cu-item:first-child::after {
    display: none
}

.cu-steps .cu-item .num {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    line-height: 20px;
    margin: 5px auto;
    font-size: 12px;
    border: 1px solid currentColor;
    position: relative;
    overflow: hidden
}

.cu-steps .cu-item[class*="text-"] .num {
    background-color: currentColor
}

.cu-steps .cu-item .num::before,
.cu-steps .cu-item .num::after {
    content: attr(data-index);
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    transition: all .3s ease-in-out 0s;
    -webkit-transform: translateY(0px);
    transform: translateY(0px)
}

.cu-steps .cu-item[class*="text-"] .num::before {
    -webkit-transform: translateY(-20px);
    transform: translateY(-20px);
    color: #fff
}

.cu-steps .cu-item .num::after {
    -webkit-transform: translateY(20px);
    transform: translateY(20px);
    color: #fff;
    transition: all .3s ease-in-out 0s
}

.cu-steps .cu-item[class*="text-"] .num::after {
    content: "\\e645";
    font-family: cuIcon;
    color: #fff;
    -webkit-transform: translateY(0px);
    transform: translateY(0px)
}

.cu-steps .cu-item[class*="text-"] .num.err::after {
    content: "\\e646"
}

/* ==================
          布局
 ==================== */
/*  -- flex弹性布局 -- */
.flex {
    display: flex
}

.basis-xs {
    flex-basis: 20%
}

.basis-sm {
    flex-basis: 40%
}

.basis-df {
    flex-basis: 50%
}

.basis-lg {
    flex-basis: 60%
}

.basis-xl {
    flex-basis: 80%
}

.flex-sub {
    flex: 1
}

.flex-twice {
    flex: 2
}

.flex-treble {
    flex: 3
}

.flex-direction {
    flex-direction: column
}

.flex-wrap {
    flex-wrap: wrap
}

.align-start {
    align-items: flex-start
}

.align-end {
    align-items: flex-end
}

.align-center {
    align-items: center
}

.align-stretch {
    align-items: stretch
}

.self-start {
    align-self: flex-start
}

.self-center {
    align-self: center
}

.self-end {
    align-self: flex-end
}

.self-stretch {
    align-self: stretch
}

.align-stretch {
    align-items: stretch
}

.justify-start {
    justify-content: flex-start
}

.justify-end {
    justify-content: flex-end
}

.justify-center {
    justify-content: center
}

.justify-between {
    justify-content: space-between
}

.justify-around {
    justify-content: space-around
}

/* grid布局 */
.grid {
    display: flex;
    flex-wrap: wrap
}

.grid.grid-square {
    overflow: hidden
}

.grid.grid-square .cu-tag {
    position: absolute;
    right: 0;
    top: 0;
    border-bottom-left-radius: 6px;
    padding: 6px 6px;
    height: auto;
    background-color: rgba(0, 0, 0, .5)
}

.grid.grid-square > div > span[class*="cuIcon-"] {
    font-size: 26px;
    position: absolute;
    color: #8799a3;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column
}

.grid.grid-square > div {
    margin-right: 5px;
    margin-bottom: 5px;
    border-radius: 6px;
    position: relative;
    overflow: hidden
}

.grid.grid-square > div.bg-img img {
    width: 100%;
    height: 100%;
    position: absolute
}

.grid.col-1.grid-square > div {
    padding-bottom: 100%;
    height: 0;
    margin-right: 0
}

.grid.col-2.grid-square > div {
    padding-bottom: calc((100% - 5px) / 2);
    height: 0;
    width: calc((100% - 5px) / 2)
}

.grid.col-3.grid-square > div {
    padding-bottom: calc((100% - 20px) / 3);
    height: 0;
    width: calc((100% - 20px) / 3)
}

.grid.col-4.grid-square > div {
    padding-bottom: calc((100% - 30px) / 4);
    height: 0;
    width: calc((100% - 30px) / 4)
}

.grid.col-5.grid-square > div {
    padding-bottom: calc((100% - 40px) / 5);
    height: 0;
    width: calc((100% - 40px) / 5)
}

.grid.col-2.grid-square > div:nth-child(2n),
.grid.col-3.grid-square > div:nth-child(3n),
.grid.col-4.grid-square > div:nth-child(4n),
.grid.col-5.grid-square > div:nth-child(5n) {
    margin-right: 0
}

.grid.col-1 > div {
    width: 100%
}

.grid.col-2 > div {
    width: 50%
}

.grid.col-3 > div {
    width: 33.33%
}

.grid.col-4 > div {
    width: 25%
}

.grid.col-5 > div {
    width: 20%
}

/*  -- 内外边距 -- */
.margin-0 {
    margin: 0
}

.margin-xs {
    margin: 5px
}

.margin-sm {
    margin: 5px
}

.margin {
    margin: 15px
}

.margin-lg {
    margin: 20px
}

.margin-xl {
    margin: 25px
}

.margin-top-xs {
    margin-top: 5px
}

.margin-top-sm {
    margin-top: 5px
}

.margin-top {
    margin-top: 15px
}

.margin-top-lg {
    margin-top: 20px
}

.margin-top-xl {
    margin-top: 25px
}

.margin-right-xs {
    margin-right: 5px
}

.margin-right-sm {
    margin-right: 5px
}

.margin-right {
    margin-right: 15px
}

.margin-right-lg {
    margin-right: 20px
}

.margin-right-xl {
    margin-right: 25px
}

.margin-bottom-xs {
    margin-bottom: 5px
}

.margin-bottom-sm {
    margin-bottom: 5px
}

.margin-bottom {
    margin-bottom: 15px
}

.margin-bottom-lg {
    margin-bottom: 20px
}

.margin-bottom-xl {
    margin-bottom: 25px
}

.margin-left-xs {
    margin-left: 5px
}

.margin-left-sm {
    margin-left: 5px
}

.margin-left {
    margin-left: 15px
}

.margin-left-lg {
    margin-left: 20px
}

.margin-left-xl {
    margin-left: 25px
}

.margin-lr-xs {
    margin-left: 5px;
    margin-right: 5px
}

.margin-lr-sm {
    margin-left: 5px;
    margin-right: 5px
}

.margin-lr {
    margin-left: 15px;
    margin-right: 15px
}

.margin-lr-lg {
    margin-left: 20px;
    margin-right: 20px
}

.margin-lr-xl {
    margin-left: 25px;
    margin-right: 25px
}

.margin-tb-xs {
    margin-top: 5px;
    margin-bottom: 5px
}

.margin-tb-sm {
    margin-top: 5px;
    margin-bottom: 5px
}

.margin-tb {
    margin-top: 15px;
    margin-bottom: 15px
}

.margin-tb-lg {
    margin-top: 20px;
    margin-bottom: 20px
}

.margin-tb-xl {
    margin-top: 25px;
    margin-bottom: 25px
}

.padding-0 {
    padding: 0
}

.padding-xs {
    padding: 5px
}

.padding-sm {
    padding: 5px
}

.padding {
    padding: 15px
}

.padding-lg {
    padding: 20px
}

.padding-xl {
    padding: 25px
}

.padding-top-xs {
    padding-top: 5px
}

.padding-top-sm {
    padding-top: 5px
}

.padding-top {
    padding-top: 15px
}

.padding-top-lg {
    padding-top: 20px
}

.padding-top-xl {
    padding-top: 25px
}

.padding-right-xs {
    padding-right: 5px
}

.padding-right-sm {
    padding-right: 5px
}

.padding-right {
    padding-right: 15px
}

.padding-right-lg {
    padding-right: 20px
}

.padding-right-xl {
    padding-right: 25px
}

.padding-bottom-xs {
    padding-bottom: 5px
}

.padding-bottom-sm {
    padding-bottom: 5px
}

.padding-bottom {
    padding-bottom: 15px
}

.padding-bottom-lg {
    padding-bottom: 20px
}

.padding-bottom-xl {
    padding-bottom: 25px
}

.padding-left-xs {
    padding-left: 5px
}

.padding-left-sm {
    padding-left: 5px
}

.padding-left {
    padding-left: 15px
}

.padding-left-lg {
    padding-left: 20px
}

.padding-left-xl {
    padding-left: 25px
}

.padding-lr-xs {
    padding-left: 5px;
    padding-right: 5px
}

.padding-lr-sm {
    padding-left: 5px;
    padding-right: 5px
}

.padding-lr {
    padding-left: 15px;
    padding-right: 15px
}

.padding-lr-lg {
    padding-left: 20px;
    padding-right: 20px
}

.padding-lr-xl {
    padding-left: 25px;
    padding-right: 25px
}

.padding-tb-xs {
    padding-top: 5px;
    padding-bottom: 5px
}

.padding-tb-sm {
    padding-top: 5px;
    padding-bottom: 5px
}

.padding-tb {
    padding-top: 15px;
    padding-bottom: 15px
}

.padding-tb-lg {
    padding-top: 20px;
    padding-bottom: 20px
}

.padding-tb-xl {
    padding-top: 25px;
    padding-bottom: 25px
}

/* -- 浮动 --  */
.cf::after,
.cf::before {
    content: " ";
    display: table
}

.cf::after {
    clear: both
}

.fl {
    float: left
}

.fr {
    float: right
}

/* ==================
          背景
 ==================== */
.line-bogo::after,
.lines-bogo::after {
    border-color: #ff9e02
}

.line-ytc::after,
.lines-ytc::after {
    border-color: #680809
}

.line-red::after,
.lines-red::after {
    border-color: #e54d42
}

.line-orange::after,
.lines-orange::after {
    border-color: #f37b1d
}

.line-yellow::after,
.lines-yellow::after {
    border-color: #fbbd08
}

.line-olive::after,
.lines-olive::after {
    border-color: #8dc63f
}

.line-green::after,
.lines-green::after {
    border-color: #2a6
}

.line-green-b::after,
.lines-green-b::after {
    border-color: #39b54a
}

.line-cyan::after,
.lines-cyan::after {
    border-color: #1cbbb4
}

.line-blue::after,
.lines-blue::after {
    border-color: #0081ff
}

.line-purple::after,
.lines-purple::after {
    border-color: #6739b6
}

.line-mauve::after,
.lines-mauve::after {
    border-color: #9c26b0
}

.line-pink::after,
.lines-pink::after {
    border-color: #e03997
}

.line-brown::after,
.lines-brown::after {
    border-color: #a5673f
}

.line-grey::after,
.lines-grey::after {
    border-color: #8799a3
}

.line-gray::after,
.lines-gray::after {
    border-color: #aaa
}

.line-black::after,
.lines-black::after {
    border-color: #333
}

.line-white::after,
.lines-white::after {
    border-color: #fff
}

.bg-bogo {
    background-color: #ff9e02;
    color: #fff
}

.bg-ytc {
    background-color: #680809;
    color: #fff
}

.bg-red {
    background-color: #e54d42;
    color: #fff
}

.bg-orange {
    background-color: #f37b1d;
    color: #fff
}

.bg-yellow {
    background-color: #fbbd08;
    color: #333
}

.bg-olive {
    background-color: #8dc63f;
    color: #fff
}

.bg-green {
    background-color: #2a6;
    color: #fff
}

.bg-green-b {
    background-color: #39b54a;
    color: #fff
}

.bg-cyan {
    background-color: #1cbbb4;
    color: #fff
}

.bg-blue {
    background-color: #0081ff;
    color: #fff
}

.bg-purple {
    background-color: #6739b6;
    color: #fff
}

.bg-mauve {
    background-color: #9c26b0;
    color: #fff
}

.bg-pink {
    background-color: #e03997;
    color: #fff
}

.bg-brown {
    background-color: #a5673f;
    color: #fff
}

.bg-grey {
    background-color: #8799a3;
    color: #fff
}

.bg-gray {
    background-color: #f0f0f0;
    color: #333
}

.bg-black {
    background-color: #333;
    color: #fff
}

.bg-white {
    background-color: #fff;
    color: #666
}

.bg-shadeTop {
    background-image: linear-gradient(#000, rgba(0, 0, 0, .01));
    color: #fff
}

.bg-shadeBottom {
    background-image: linear-gradient(rgba(0, 0, 0, .01), #000);
    color: #fff
}

.bg-bogo.light {
    color: #ff9e02;
    background-color: #fde6d2
}

.bg-ytc.light {
    color: #680809;
    background-color: #fde6d2
}

.bg-red.light {
    color: #e54d42;
    background-color: #fadbd9
}

.bg-orange.light {
    color: #f37b1d;
    background-color: #fde6d2
}

.bg-yellow.light {
    color: #fbbd08;
    background-color: rgba(254, 242, 206, .82)
}

.bg-olive.light {
    color: #8dc63f;
    background-color: #e8f4d9
}

.bg-green.light {
    color: #2a6;
    background-color: #d7f0db
}

.bg-green-b.light {
    color: #39b54a;
    background-color: #d7f0db
}

.bg-cyan.light {
    color: #1cbbb4;
    background-color: #d2f1f0
}

.bg-blue.light {
    color: #0081ff;
    background-color: #cce6ff
}

.bg-purple.light {
    color: #6739b6;
    background-color: #e1d7f0
}

.bg-mauve.light {
    color: #9c26b0;
    background-color: #ebd4ef
}

.bg-pink.light {
    color: #e03997;
    background-color: #f9d7ea
}

.bg-brown.light {
    color: #a5673f;
    background-color: #ede1d9
}

.bg-grey.light {
    color: #8799a3;
    background-color: #e7ebed
}

.bg-gradual-bogo {
    background-image: linear-gradient(45deg, #ff9e02, #a56c09);
    color: #fff
}

.bg-gradual-ytc {
    background-image: linear-gradient(45deg, #680809, #430f10);
    color: #fff
}

.bg-gradual-red {
    background-image: linear-gradient(45deg, #f43f3b, #ec008c);
    color: #fff
}

.bg-gradual-orange {
    background-image: linear-gradient(45deg, #ff9700, #ed1c24);
    color: #fff
}

.bg-gradual-green {
    background-image: linear-gradient(45deg, #2a6, #8dc63f);
    color: #fff
}

.bg-gradual-green-b {
    background-image: linear-gradient(45deg, #39b54a, #8dc63f);
    color: #fff
}

.bg-gradual-purple {
    background-image: linear-gradient(45deg, #9000ff, #5e00ff);
    color: #fff
}

.bg-gradual-pink {
    background-image: linear-gradient(45deg, #ec008c, #6739b6);
    color: #fff
}

.bg-gradual-blue {
    background-image: linear-gradient(45deg, #0081ff, #1cbbb4);
    color: #fff
}

.shadow[class*="-bogo"] {
    box-shadow: 6px 6px 8px rgba(88, 48, 156, .2)
}

.shadow[class*="-ytc"] {
    box-shadow: 6px 6px 8px rgba(88, 48, 156, .2)
}

.shadow[class*="-red"] {
    box-shadow: 6px 6px 8px rgba(204, 69, 59, .2)
}

.shadow[class*="-orange"] {
    box-shadow: 6px 6px 8px rgba(217, 109, 26, .2)
}

.shadow[class*="-yellow"] {
    box-shadow: 6px 6px 8px rgba(224, 170, 7, .2)
}

.shadow[class*="-olive"] {
    box-shadow: 6px 6px 8px rgba(124, 173, 55, .2)
}

.shadow[class*="-green"] {
    box-shadow: 6px 6px 8px rgba(34, 170, 102, .2)
}

.shadow[class*="-green-b"] {
    box-shadow: 6px 6px 8px rgba(48, 156, 63, .2)
}

.shadow[class*="-cyan"] {
    box-shadow: 6px 6px 8px rgba(28, 187, 180, .2)
}

.shadow[class*="-blue"] {
    box-shadow: 6px 6px 8px rgba(0, 102, 204, .2)
}

.shadow[class*="-purple"] {
    box-shadow: 6px 6px 8px rgba(88, 48, 156, .2)
}

.shadow[class*="-mauve"] {
    box-shadow: 6px 6px 8px rgba(133, 33, 150, .2)
}

.shadow[class*="-pink"] {
    box-shadow: 6px 6px 8px rgba(199, 50, 134, .2)
}

.shadow[class*="-brown"] {
    box-shadow: 6px 6px 8px rgba(140, 88, 53, .2)
}

.shadow[class*="-grey"] {
    box-shadow: 6px 6px 8px rgba(114, 130, 138, .2)
}

.shadow[class*="-gray"] {
    box-shadow: 6px 6px 8px rgba(114, 130, 138, .2)
}

.shadow[class*="-black"] {
    box-shadow: 6px 6px 8px rgba(26, 26, 26, .2)
}

.shadow[class*="-white"] {
    box-shadow: 6px 6px 8px rgba(26, 26, 26, .2)
}

.text-shadow[class*="-bogo"] {
    text-shadow: 6px 6px 8px rgba(88, 48, 156, .2)
}

.text-shadow[class*="-ytc"] {
    text-shadow: 6px 6px 8px rgba(88, 48, 156, .2)
}

.text-shadow[class*="-red"] {
    text-shadow: 6px 6px 8px rgba(204, 69, 59, .2)
}

.text-shadow[class*="-orange"] {
    text-shadow: 6px 6px 8px rgba(217, 109, 26, .2)
}

.text-shadow[class*="-yellow"] {
    text-shadow: 6px 6px 8px rgba(224, 170, 7, .2)
}

.text-shadow[class*="-olive"] {
    text-shadow: 6px 6px 8px rgba(124, 173, 55, .2)
}

.text-shadow[class*="-green"] {
    text-shadow: 6px 6px 8px rgba(34, 170, 102, .2)
}

.text-shadow[class*="-green-b"] {
    text-shadow: 6px 6px 8px rgba(48, 156, 63, .2)
}

.text-shadow[class*="-cyan"] {
    text-shadow: 6px 6px 8px rgba(28, 187, 180, .2)
}

.text-shadow[class*="-blue"] {
    text-shadow: 6px 6px 8px rgba(0, 102, 204, .2)
}

.text-shadow[class*="-purple"] {
    text-shadow: 6px 6px 8px rgba(88, 48, 156, .2)
}

.text-shadow[class*="-mauve"] {
    text-shadow: 6px 6px 8px rgba(133, 33, 150, .2)
}

.text-shadow[class*="-pink"] {
    text-shadow: 6px 6px 8px rgba(199, 50, 134, .2)
}

.text-shadow[class*="-brown"] {
    text-shadow: 6px 6px 8px rgba(140, 88, 53, .2)
}

.text-shadow[class*="-grey"] {
    text-shadow: 6px 6px 8px rgba(114, 130, 138, .2)
}

.text-shadow[class*="-gray"] {
    text-shadow: 6px 6px 8px rgba(114, 130, 138, .2)
}

.text-shadow[class*="-black"] {
    text-shadow: 6px 6px 8px rgba(26, 26, 26, .2)
}

.bg-img {
    background-size: cover;
    background-position: 50%;
    background-repeat: no-repeat
}

.bg-mask {
    background-color: #333;
    position: relative
}

.bg-mask::after {
    content: "";
    border-radius: inherit;
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(0, 0, 0, .4);
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0
}

.bg-mask div,
.bg-mask span {
    z-index: 5;
    position: relative
}

.bg-video {
    position: relative
}

.bg-video video {
    display: block;
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    z-index: 0;
    pointer-events: none
}

/* ==================
          文本
 ==================== */
.text-xs {
    font-size: 5px
}

.text-sm {
    font-size: 12px
}

.text-df {
    font-size: 14px
}

.text-lg {
    font-size: 16px
}

.text-xl {
    font-size: 18px
}

.text-xxl {
    font-size: 22px
}

.text-sl {
    font-size: 40px
}

.text-xsl {
    font-size: 55px
}

.text-Abc {
    text-transform: Capitalize
}

.text-ABC {
    text-transform: Uppercase
}

.text-abc {
    text-transform: Lowercase
}

.text-price::before {
    content: "¥";
    font-size: 80%;
    margin-right: 4px
}

.text-cut {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden
}

.text-bold {
    font-weight: 700
}

.text-center {
    text-align: center
}

.text-content {
    line-height: 1.6
}

.text-left {
    text-align: left
}

.text-right {
    text-align: right
}

.text-bogo,
.line-bogo,
.lines-bogo,
.cu-form-group input.text-bogo {
    color: #ff9e02
}

.text-ytc,
.line-ytc,
.lines-ytc,
.cu-form-group input.text-ytc,
.cu-form-group input.text-ytc .input-placeholder {
    color: #680809
}

.text-red,
.line-red,
.lines-red {
    color: #e54d42
}

.text-orange,
.line-orange,
.lines-orange {
    color: #f37b1d
}

.text-yellow,
.line-yellow,
.lines-yellow {
    color: #fbbd08
}

.text-olive,
.line-olive,
.lines-olive {
    color: #8dc63f
}

.text-green,
.line-green,
.lines-green {
    color: #2a6
}

.text-green-b,
.line-green-b,
.lines-green-b {
    color: #39b54a
}

.text-cyan,
.line-cyan,
.lines-cyan {
    color: #1cbbb4
}

.text-blue,
.line-blue,
.lines-blue {
    color: #0081ff
}

.text-purple,
.line-purple,
.lines-purple {
    color: #6739b6
}

.text-mauve,
.line-mauve,
.lines-mauve {
    color: #9c26b0
}

.text-pink,
.line-pink,
.lines-pink {
    color: #e03997
}

.text-brown,
.line-brown,
.lines-brown {
    color: #a5673f
}

.text-grey,
.line-grey,
.lines-grey {
    color: #8799a3
}

.text-gray,
.line-gray,
.lines-gray {
    color: #aaa
}

.text-black,
.line-black,
.lines-black {
    color: #333
}

.text-white,
.line-white,
.lines-white {
    color: #fff
}

.bg-none {
    background: none
}

.border0 {
    border: none
}

.safe-area-inset-bottom {
    height: calc(env(safe-area-inset-bottom) / 2)
}

.baseTextColor {
    color: #ff9e02
}

.baseBgColor {
    background-color: #ff9e02
}

.baseTextBold {
    font-weight: 700
}

.scroll-view {
    height: 100%;
    min-height: 100%
}

.text-333 {
    color: #333
}

.text-666 {
    color: #666
}

.text-999 {
    color: #999
}

.text-ccc {
    color: #ccc
}

.text-eee {
    color: #eee
}

.text-shadow-1-000-50 {
    text-shadow: 1px 1px 1px rgba(0, 0, 0, .5)
}

.text-font-10 {
    -webkit-transform: scale(.83);
    font-size: 12px
}

.text-font-12 {
    font-size: 12px
}

.text-font-14 {
    font-size: 14px
}

.text-font-16 {
    font-size: 16px
}

.text-font-18 {
    font-size: 18px
}

.text-font-20 {
    font-size: 20px
}

.text-font-22 {
    font-size: 22px
}

.cu-btn .contact-btn {
    font-size: 13px;
    color: #fff;
    background: none;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    position: unset
}

.width100 {
    width: 100%
}

.width50 {
    width: 50%
}

.height100 {
    height: 100%
}

.height100vh {
    height: 100vh
}

.overflow-x {
    overflow-x: auto
}

.overflow-x .overflow-x-item {
    float: left;
    display: inline-block
}

.width-height-100 {
    width: 100%;
    height: 100%
}

.radius0,
.cu-dialog.radius0 {
    border-radius: 0px
}

.radius5 {
    border-radius: 5px
}

.radius6 {
    border-radius: 6px
}

.radius8 {
    border-radius: 8px
}

.radius10 {
    border-radius: 5px
}

.radius15 {
    border-radius: 15px
}

.radiusAll {
    border-radius: 1000px
}

.padding-bottom0 {
    padding-bottom: 0
}

.padding-top0 {
    padding-top: 0
}

.padding-left0 {
    padding-left: 0
}

.padding-right0 {
    padding-right: 0
}

.margin-bottom0 {
    margin-bottom: 0
}

.margin-top0 {
    margin-top: 0
}

.margin-left0 {
    margin-left: 0
}

.margin-right0 {
    margin-right: 0
}

u-skeleton {
    width: 100vw;
    height: 100vh
}

.cu-modal.z-index9, .z-index9 {
    z-index: 9
}

.cu-modal.z-index10000,
.z-index10000 {
    z-index: 10000
}

.cu-modal.z-index999999,
.z-index999999 {
    z-index: 999999
}

.cu-bar.fixed.top-auto, .nav.fixed.top-auto {
    top: auto
}

.show-hand {
    cursor: pointer;
}
