﻿/*
  ColorUi for uniApp  v2.1.6 | by 文晓港 2019-05-31 10:44:24
  仅供学习交流，如作它用所承受的法律责任一概与作者无关  
  
  *使用ColorUi开发扩展与插件时，请注明基于ColorUi开发 
  
  （QQ交流群：240787041）
*/

/* ==================
        初始化
 ==================== */
/* body {
	background-color: #f1f1f1;
	font-size: 28upx;
	color: #333333;
	font-family: Helvetica Neue, Helvetica, sans-serif;
} */

view,
scroll-view,
swiper,
button,
input,
textarea,
label,
navigator,
image {
    box-sizing: border-box;
}

.round {
    border-radius: 5000upx;
}

.radius {
    border-radius: 6upx;
}

/* ==================
          图片
 ==================== */

image {
    max-width: 100%;
    display: inline-block;
    position: relative;
    z-index: 0;
}

    image.loading::before {
        content: "";
        background-color: #f5f5f5;
        display: block;
        position: absolute;
        width: 100%;
        height: 100%;
        z-index: -2;
    }

    image.loading::after {
        content: "\e7f1";
        font-family: "cuIcon";
        position: absolute;
        top: 0;
        left: 0;
        width: 32upx;
        height: 32upx;
        line-height: 32upx;
        right: 0;
        bottom: 0;
        z-index: -1;
        font-size: 32upx;
        margin: auto;
        color: #ccc;
        -webkit-animation: cuIcon-spin 2s infinite linear;
        animation: cuIcon-spin 2s infinite linear;
        display: block;
    }

.response {
    width: 100%;
}

/* ==================
         开关
 ==================== */

switch,
checkbox,
radio {
    position: relative;
}

    switch::after,
    switch::before {
        font-family: "cuIcon";
        content: "\e645";
        position: absolute;
        color: #ffffff !important;
        top: 0%;
        left: 0upx;
        font-size: 26upx;
        line-height: 26px;
        width: 50%;
        text-align: center;
        pointer-events: none;
        transform: scale(0, 0);
        transition: all 0.3s ease-in-out 0s;
        z-index: 9;
        bottom: 0;
        height: 26px;
        margin: auto;
    }

    switch::before {
        content: "\e646";
        right: 0;
        transform: scale(1, 1);
        left: auto;
    }

    switch[checked]::after,
    switch.checked::after {
        transform: scale(1, 1);
    }

    switch[checked]::before,
    switch.checked::before {
        transform: scale(0, 0);
    }

    /* #ifndef MP-ALIPAY */
    radio::before,
    checkbox::before {
        font-family: "cuIcon";
        content: "\e645";
        position: absolute;
        color: #ffffff !important;
        top: 50%;
        margin-top: -8px;
        right: 5px;
        font-size: 32upx;
        line-height: 16px;
        pointer-events: none;
        transform: scale(1, 1);
        transition: all 0.3s ease-in-out 0s;
        z-index: 9;
    }

    radio .wx-radio-input,
    checkbox .wx-checkbox-input,
    radio .uni-radio-input,
    checkbox .uni-checkbox-input {
        margin: 0;
        width: 24px;
        height: 24px;
    }

    checkbox.round .wx-checkbox-input,
    checkbox.round .uni-checkbox-input {
        border-radius: 100upx;
    }

    /* #endif */

    switch[checked]::before {
        transform: scale(0, 0);
    }

    switch .wx-switch-input,
    switch .uni-switch-input {
        border: none;
        padding: 0 24px;
        width: 48px;
        height: 26px;
        margin: 0;
        border-radius: 100upx;
    }

        switch .wx-switch-input:not([class*="bg-"]),
        switch .uni-switch-input:not([class*="bg-"]) {
            background: #8799a3 !important;
        }

        switch .wx-switch-input::after,
        switch .uni-switch-input::after {
            margin: auto;
            width: 26px;
            height: 26px;
            border-radius: 100upx;
            left: 0upx;
            top: 0upx;
            bottom: 0upx;
            position: absolute;
            transform: scale(0.9, 0.9);
            transition: all 0.1s ease-in-out 0s;
        }

        switch .wx-switch-input.wx-switch-input-checked::after,
        switch .uni-switch-input.uni-switch-input-checked::after {
            margin: auto;
            left: 22px;
            box-shadow: none;
            transform: scale(0.9, 0.9);
        }

radio-group {
    display: inline-block;
}



switch.radius .wx-switch-input::after,
switch.radius .wx-switch-input,
switch.radius .wx-switch-input::before,
switch.radius .uni-switch-input::after,
switch.radius .uni-switch-input,
switch.radius .uni-switch-input::before {
    border-radius: 10upx;
}

switch .wx-switch-input::before,
radio.radio::before,
checkbox .wx-checkbox-input::before,
radio .wx-radio-input::before,
switch .uni-switch-input::before,
radio.radio::before,
checkbox .uni-checkbox-input::before,
radio .uni-radio-input::before {
    display: none;
}

radio.radio[checked]::after,
radio.radio .uni-radio-input-checked::after {
    content: "";
    background-color: transparent;
    display: block;
    position: absolute;
    width: 8px;
    height: 8px;
    z-index: 999;
    top: 0upx;
    left: 0upx;
    right: 0;
    bottom: 0;
    margin: auto;
    border-radius: 200upx;
    /* #ifndef MP */
    border: 7px solid #ffffff !important;
    /* #endif */
    /* #ifdef MP */
    border: 8px solid #ffffff !important;
    /* #endif */
}

.switch-sex::after {
    content: "\e71c";
}

.switch-sex::before {
    content: "\e71a";
}

.switch-sex .wx-switch-input,
.switch-sex .uni-switch-input {
    background: #e54d42 !important;
    border-color: #e54d42 !important;
}

.switch-sex[checked] .wx-switch-input,
.switch-sex.checked .uni-switch-input {
    background: #0081ff !important;
    border-color: #0081ff !important;
}

switch.red[checked] .wx-switch-input.wx-switch-input-checked,
checkbox.red[checked] .wx-checkbox-input,
radio.red[checked] .wx-radio-input,
switch.red.checked .uni-switch-input.uni-switch-input-checked,
checkbox.red.checked .uni-checkbox-input,
radio.red.checked .uni-radio-input {
    background-color: #e54d42 !important;
    border-color: #e54d42 !important;
    color: #ffffff !important;
}

switch.orange[checked] .wx-switch-input,
checkbox.orange[checked] .wx-checkbox-input,
radio.orange[checked] .wx-radio-input,
switch.orange.checked .uni-switch-input,
checkbox.orange.checked .uni-checkbox-input,
radio.orange.checked .uni-radio-input {
    background-color: #f37b1d !important;
    border-color: #f37b1d !important;
    color: #ffffff !important;
}

switch.yellow[checked] .wx-switch-input,
checkbox.yellow[checked] .wx-checkbox-input,
radio.yellow[checked] .wx-radio-input,
switch.yellow.checked .uni-switch-input,
checkbox.yellow.checked .uni-checkbox-input,
radio.yellow.checked .uni-radio-input {
    background-color: #fbbd08 !important;
    border-color: #fbbd08 !important;
    color: #333333 !important;
}

switch.olive[checked] .wx-switch-input,
checkbox.olive[checked] .wx-checkbox-input,
radio.olive[checked] .wx-radio-input,
switch.olive.checked .uni-switch-input,
checkbox.olive.checked .uni-checkbox-input,
radio.olive.checked .uni-radio-input {
    background-color: #8dc63f !important;
    border-color: #8dc63f !important;
    color: #ffffff !important;
}

switch.green[checked] .wx-switch-input,
switch[checked] .wx-switch-input,
checkbox.green[checked] .wx-checkbox-input,
checkbox[checked] .wx-checkbox-input,
radio.green[checked] .wx-radio-input,
radio[checked] .wx-radio-input,
switch.green.checked .uni-switch-input,
switch.checked .uni-switch-input,
checkbox.green.checked .uni-checkbox-input,
checkbox.checked .uni-checkbox-input,
radio.green.checked .uni-radio-input,
radio.checked .uni-radio-input {
    background-color: #39b54a !important;
    border-color: #39b54a !important;
    color: #ffffff !important;
    border-color: #39B54A !important;
}

switch.cyan[checked] .wx-switch-input,
checkbox.cyan[checked] .wx-checkbox-input,
radio.cyan[checked] .wx-radio-input,
switch.cyan.checked .uni-switch-input,
checkbox.cyan.checked .uni-checkbox-input,
radio.cyan.checked .uni-radio-input {
    background-color: #1cbbb4 !important;
    border-color: #1cbbb4 !important;
    color: #ffffff !important;
}

switch.blue[checked] .wx-switch-input,
checkbox.blue[checked] .wx-checkbox-input,
radio.blue[checked] .wx-radio-input,
switch.blue.checked .uni-switch-input,
checkbox.blue.checked .uni-checkbox-input,
radio.blue.checked .uni-radio-input {
    background-color: #0081ff !important;
    border-color: #0081ff !important;
    color: #ffffff !important;
}

switch.purple[checked] .wx-switch-input,
checkbox.purple[checked] .wx-checkbox-input,
radio.purple[checked] .wx-radio-input,
switch.purple.checked .uni-switch-input,
checkbox.purple.checked .uni-checkbox-input,
radio.purple.checked .uni-radio-input {
    background-color: #6739b6 !important;
    border-color: #6739b6 !important;
    color: #ffffff !important;
}

switch.mauve[checked] .wx-switch-input,
checkbox.mauve[checked] .wx-checkbox-input,
radio.mauve[checked] .wx-radio-input,
switch.mauve.checked .uni-switch-input,
checkbox.mauve.checked .uni-checkbox-input,
radio.mauve.checked .uni-radio-input {
    background-color: #9c26b0 !important;
    border-color: #9c26b0 !important;
    color: #ffffff !important;
}

switch.pink[checked] .wx-switch-input,
checkbox.pink[checked] .wx-checkbox-input,
radio.pink[checked] .wx-radio-input,
switch.pink.checked .uni-switch-input,
checkbox.pink.checked .uni-checkbox-input,
radio.pink.checked .uni-radio-input {
    background-color: #e03997 !important;
    border-color: #e03997 !important;
    color: #ffffff !important;
}

switch.brown[checked] .wx-switch-input,
checkbox.brown[checked] .wx-checkbox-input,
radio.brown[checked] .wx-radio-input,
switch.brown.checked .uni-switch-input,
checkbox.brown.checked .uni-checkbox-input,
radio.brown.checked .uni-radio-input {
    background-color: #a5673f !important;
    border-color: #a5673f !important;
    color: #ffffff !important;
}

switch.grey[checked] .wx-switch-input,
checkbox.grey[checked] .wx-checkbox-input,
radio.grey[checked] .wx-radio-input,
switch.grey.checked .uni-switch-input,
checkbox.grey.checked .uni-checkbox-input,
radio.grey.checked .uni-radio-input {
    background-color: #8799a3 !important;
    border-color: #8799a3 !important;
    color: #ffffff !important;
}

switch.gray[checked] .wx-switch-input,
checkbox.gray[checked] .wx-checkbox-input,
radio.gray[checked] .wx-radio-input,
switch.gray.checked .uni-switch-input,
checkbox.gray.checked .uni-checkbox-input,
radio.gray.checked .uni-radio-input {
    background-color: #f0f0f0 !important;
    border-color: #f0f0f0 !important;
    color: #333333 !important;
}

switch.black[checked] .wx-switch-input,
checkbox.black[checked] .wx-checkbox-input,
radio.black[checked] .wx-radio-input,
switch.black.checked .uni-switch-input,
checkbox.black.checked .uni-checkbox-input,
radio.black.checked .uni-radio-input {
    background-color: #333333 !important;
    border-color: #333333 !important;
    color: #ffffff !important;
}

switch.white[checked] .wx-switch-input,
checkbox.white[checked] .wx-checkbox-input,
radio.white[checked] .wx-radio-input,
switch.white.checked .uni-switch-input,
checkbox.white.checked .uni-checkbox-input,
radio.white.checked .uni-radio-input {
    background-color: #ffffff !important;
    border-color: #ffffff !important;
    color: #333333 !important;
}

/* ==================
          边框
 ==================== */

/* -- 实线 -- */

.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;
        transform: scale(0.5);
        transform-origin: 0 0;
        pointer-events: none;
        box-sizing: border-box;
    }

    .solid::after {
        border: 1upx solid rgba(0, 0, 0, 0.1);
    }

    .solid-top::after {
        border-top: 1upx solid rgba(0, 0, 0, 0.1);
    }

    .solid-right::after {
        border-right: 1upx solid rgba(0, 0, 0, 0.1);
    }

    .solid-bottom::after {
        border-bottom: 1upx solid rgba(0, 0, 0, 0.1);
    }

    .solid-left::after {
        border-left: 1upx solid rgba(0, 0, 0, 0.1);
    }

    .solids::after {
        border: 8upx solid #eee;
    }

    .solids-top::after {
        border-top: 8upx solid #eee;
    }

    .solids-right::after {
        border-right: 8upx solid #eee;
    }

    .solids-bottom::after {
        border-bottom: 8upx solid #eee;
    }

    .solids-left::after {
        border-left: 8upx solid #eee;
    }

    /* -- 虚线 -- */

    .dashed::after {
        border: 1upx dashed #ddd;
    }

    .dashed-top::after {
        border-top: 1upx dashed #ddd;
    }

    .dashed-right::after {
        border-right: 1upx dashed #ddd;
    }

    .dashed-bottom::after {
        border-bottom: 1upx dashed #ddd;
    }

    .dashed-left::after {
        border-left: 1upx dashed #ddd;
    }

/* -- 阴影 -- */

.shadow[class*='white'] {
    --ShadowSize: 0 1upx 6upx;
}

.shadow-lg {
    --ShadowSize: 0upx 40upx 100upx 0upx;
}

.shadow-warp {
    position: relative;
    box-shadow: 0 0 10upx rgba(0, 0, 0, 0.1);
}

    .shadow-warp:before,
    .shadow-warp:after {
        position: absolute;
        content: "";
        top: 20upx;
        bottom: 30upx;
        left: 20upx;
        width: 50%;
        box-shadow: 0 30upx 20upx rgba(0, 0, 0, 0.2);
        transform: rotate(-3deg);
        z-index: -1;
    }

    .shadow-warp:after {
        right: 20upx;
        left: auto;
        transform: rotate(3deg);
    }

.shadow-blur {
    position: relative;
}

    .shadow-blur::before {
        content: "";
        display: block;
        background: inherit;
        filter: blur(10upx);
        position: absolute;
        width: 100%;
        height: 100%;
        top: 10upx;
        left: 10upx;
        z-index: -1;
        opacity: 0.4;
        transform-origin: 0 0;
        border-radius: inherit;
        transform: scale(1, 1);
    }

/* ==================
          按钮
 ==================== */

.cu-btn {
    position: relative;
    border: 0upx;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding: 0 30upx;
    font-size: 28upx;
    height: 64upx;
    line-height: 1;
    text-align: center;
    text-decoration: none;
    overflow: visible;
    margin-left: initial;
    transform: translate(0upx, 0upx);
    margin-right: initial;
}

    .cu-btn::after {
        display: none;
    }

    .cu-btn:not([class*="bg-"]) {
        background-color: #f0f0f0;
    }

    .cu-btn[class*="line"] {
        background-color: transparent;
    }

        .cu-btn[class*="line"]::after {
            content: " ";
            display: block;
            width: 200%;
            height: 200%;
            position: absolute;
            top: 0;
            left: 0;
            border: 1upx solid currentColor;
            transform: scale(0.5);
            transform-origin: 0 0;
            box-sizing: border-box;
            border-radius: 12upx;
            z-index: 1;
            pointer-events: none;
        }

    .cu-btn.round[class*="line"]::after {
        border-radius: 1000upx;
    }

    .cu-btn[class*="lines"]::after {
        border: 6upx solid currentColor;
    }

    .cu-btn[class*="bg-"]::after {
        display: none;
    }

    .cu-btn.sm {
        padding: 0 20upx;
        font-size: 20upx;
        height: 48upx;
    }

    .cu-btn.lg {
        padding: 0 40upx;
        font-size: 32upx;
        height: 80upx;
    }

    .cu-btn.cuIcon.sm {
        width: 48upx;
        height: 48upx;
    }

    .cu-btn.cuIcon {
        width: 64upx;
        height: 64upx;
        border-radius: 500upx;
        padding: 0;
    }

button.cuIcon.lg {
    width: 80upx;
    height: 80upx;
}

.cu-btn.shadow-blur::before {
    top: 4upx;
    left: 4upx;
    filter: blur(6upx);
    opacity: 0.6;
}

.cu-btn.button-hover {
    transform: translate(1upx, 1upx);
}

.block {
    display: block;
}

.cu-btn.block {
    display: flex;
}

.cu-btn[disabled] {
    opacity: 0.6;
    color: #ffffff;
}

/* ==================
          徽章
 ==================== */

.cu-tag {
    font-size: 24upx;
    vertical-align: middle;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding: 0upx 16upx;
    height: 48upx;
    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: 1upx solid currentColor;
        transform: scale(0.5);
        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: 12upx;
    }

    .cu-tag.round[class*="line"]::after {
        border-radius: 1000upx;
    }

    .cu-tag[class*="line-"]::after {
        border-radius: 0;
    }

    .cu-tag + .cu-tag {
        margin-left: 10upx;
    }

    .cu-tag.sm {
        font-size: 20upx;
        padding: 0upx 12upx;
        height: 32upx;
    }

.cu-capsule {
    display: inline-flex;
    vertical-align: middle;
}

    .cu-capsule + .cu-capsule {
        margin-left: 10upx;
    }

    .cu-capsule .cu-tag {
        margin: 0;
    }

        .cu-capsule .cu-tag[class*="line-"]:last-child::after {
            border-left: 0upx solid transparent;
        }

        .cu-capsule .cu-tag[class*="line-"]:first-child::after {
            border-right: 0upx solid transparent;
        }

    .cu-capsule.radius .cu-tag:first-child {
        border-top-left-radius: 6upx;
        border-bottom-left-radius: 6upx;
    }

    .cu-capsule.radius .cu-tag:last-child::after,
    .cu-capsule.radius .cu-tag[class*="line-"] {
        border-top-right-radius: 12upx;
        border-bottom-right-radius: 12upx;
    }

    .cu-capsule.round .cu-tag:first-child {
        border-top-left-radius: 200upx;
        border-bottom-left-radius: 200upx;
        text-indent: 4upx;
    }

    .cu-capsule.round .cu-tag:last-child::after,
    .cu-capsule.round .cu-tag:last-child {
        border-top-right-radius: 200upx;
        border-bottom-right-radius: 200upx;
        text-indent: -4upx;
    }

.cu-tag.badge {
    border-radius: 200upx;
    position: absolute;
    top: -10upx;
    right: -10upx;
    font-size: 20upx;
    padding: 0upx 10upx;
    height: 28upx;
    color: #ffffff;
}

    .cu-tag.badge:not([class*="bg-"]) {
        background-color: #dd514c;
    }

.cu-tag:empty:not([class*="cuIcon-"]) {
    padding: 0upx;
    width: 16upx;
    height: 16upx;
    top: -4upx;
    right: -4upx;
}

.cu-tag[class*="cuIcon-"] {
    width: 32upx;
    height: 32upx;
    top: -4upx;
    right: -4upx;
}

/* ==================
          头像
 ==================== */

.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: #ffffff;
    white-space: nowrap;
    position: relative;
    width: 64upx;
    height: 64upx;
    background-size: cover;
    background-position: center;
    vertical-align: middle;
    font-size: 1.5em;
}

    .cu-avatar.sm {
        width: 48upx;
        height: 48upx;
        font-size: 1em;
    }

    .cu-avatar.lg {
        width: 96upx;
        height: 96upx;
        font-size: 2em;
    }

    .cu-avatar.xl {
        width: 128upx;
        height: 128upx;
        font-size: 2.5em;
    }

    .cu-avatar .avatar-text {
        font-size: 0.4em;
    }

.cu-avatar-group {
    direction: rtl;
    unicode-bidi: bidi-override;
    padding: 0 10upx 0 40upx;
    display: inline-block;
}

    .cu-avatar-group .cu-avatar {
        margin-left: -30upx;
        border: 4upx solid #f1f1f1;
        vertical-align: middle;
    }

        .cu-avatar-group .cu-avatar.sm {
            margin-left: -20upx;
            border: 1upx solid #f1f1f1;
        }

/* ==================
         进度条
 ==================== */

.cu-progress {
    overflow: hidden;
    height: 28upx;
    background-color: #ebeef5;
    display: inline-flex;
    align-items: center;
    width: 100%;
}

    .cu-progress + view,
    .cu-progress + text {
        line-height: 1;
    }

    .cu-progress.xs {
        height: 10upx;
    }

    .cu-progress.sm {
        height: 20upx;
    }

    .cu-progress view {
        width: 0;
        height: 100%;
        align-items: center;
        display: flex;
        justify-items: flex-end;
        justify-content: space-around;
        font-size: 20upx;
        color: #ffffff;
        transition: width 0.6s ease;
    }

    .cu-progress text {
        align-items: center;
        display: flex;
        font-size: 20upx;
        color: #333333;
        text-indent: 10upx;
    }

    .cu-progress.text-progress {
        padding-right: 60upx;
    }

    .cu-progress.striped view {
        background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
        background-size: 72upx 72upx;
    }

    .cu-progress.active view {
        animation: progress-stripes 2s linear infinite;
    }

@keyframes progress-stripes {
    from {
        background-position: 72upx 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: 6upx;
    }

    .cu-load.loading::before {
        content: "\e67a";
        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: 32upx;
    }

    .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: 140upx;
        left: 0;
        margin: auto;
        width: 260upx;
        height: 260upx;
        background-color: #ffffff;
        border-radius: 10upx;
        box-shadow: 0 0 0upx 2000upx rgba(0, 0, 0, 0.5);
        display: flex;
        align-items: center;
        flex-direction: column;
        justify-content: center;
        font-size: 28upx;
        z-index: 9999;
        line-height: 2.4em;
    }

        .cu-load.load-modal [class*="cuIcon-"] {
            font-size: 60upx;
        }

        .cu-load.load-modal image {
            width: 70upx;
            height: 70upx;
        }

        .cu-load.load-modal::after {
            content: "";
            position: absolute;
            background-color: #ffffff;
            border-radius: 50%;
            width: 200upx;
            height: 200upx;
            font-size: 10px;
            border-top: 6upx solid rgba(0, 0, 0, 0.05);
            border-right: 6upx solid rgba(0, 0, 0, 0.05);
            border-bottom: 6upx solid rgba(0, 0, 0, 0.05);
            border-left: 6upx solid #f37b1d;
            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: 4upx;
        overflow: hidden;
        transition: all 200ms ease 0s;
    }

    .load-progress .load-progress-spinner {
        position: absolute;
        top: 10upx;
        right: 10upx;
        z-index: 2000;
        display: block;
    }

        .load-progress .load-progress-spinner::after {
            content: "";
            display: block;
            width: 24upx;
            height: 24upx;
            -webkit-box-sizing: border-box;
            box-sizing: border-box;
            border: solid 4upx transparent;
            border-top-color: inherit;
            border-left-color: inherit;
            border-radius: 50%;
            -webkit-animation: load-progress-spinner 0.4s linear infinite;
            animation: load-progress-spinner 0.4s linear infinite;
        }

@-webkit-keyframes load-progress-spinner {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0);
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes load-progress-spinner {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0);
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

/* ==================
          列表
 ==================== */
.grayscale {
    filter: grayscale(1);
}

.cu-list + .cu-list {
    margin-top: 30upx
}

.cu-list > .cu-item {
    transition: all .6s ease-in-out 0s;
    transform: translateX(0upx)
}

    .cu-list > .cu-item.move-cur {
        transform: translateX(-260upx)
    }

    .cu-list > .cu-item .move {
        position: absolute;
        right: 0;
        display: flex;
        width: 260upx;
        height: 100%;
        transform: translateX(100%)
    }

        .cu-list > .cu-item .move view {
            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: 10upx;
        height: 140upx;
        background-color: #ffffff;
        justify-content: flex-end;
        align-items: center
    }

        .cu-list.menu-avatar > .cu-item > .cu-avatar {
            position: absolute;
            left: 30upx
        }

        .cu-list.menu-avatar > .cu-item .flex .text-cut {
            max-width: 510upx
        }

        .cu-list.menu-avatar > .cu-item .content {
            position: absolute;
            left: 146upx;
            width: calc(100% - 96upx - 60upx - 120upx - 20upx);
            line-height: 1.6em;
        }

            .cu-list.menu-avatar > .cu-item .content.flex-sub {
                width: calc(100% - 96upx - 60upx - 20upx);
            }

            .cu-list.menu-avatar > .cu-item .content > view:first-child {
                font-size: 30upx;
                display: flex;
                align-items: center
            }

            .cu-list.menu-avatar > .cu-item .content .cu-tag.sm {
                display: inline-block;
                margin-left: 10upx;
                height: 28upx;
                font-size: 16upx;
                line-height: 32upx
            }

        .cu-list.menu-avatar > .cu-item .action {
            width: 100upx;
            text-align: center
        }

            .cu-list.menu-avatar > .cu-item .action view + view {
                margin-top: 10upx
            }

    .cu-list.menu-avatar.comment > .cu-item .content {
        position: relative;
        left: 0;
        width: auto;
        flex: 1;
    }

    .cu-list.menu-avatar.comment > .cu-item {
        padding: 30upx 30upx 30upx 120upx;
        height: auto
    }

    .cu-list.menu-avatar.comment .cu-avatar {
        align-self: flex-start
    }

.cu-list.menu > .cu-item {
    position: relative;
    display: flex;
    padding: 0 30upx;
    min-height: 100upx;
    background-color: #ffffff;
    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: 1upx solid #ddd;
        border-radius: inherit;
        content: " ";
        transform: scale(.5);
        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: 90upx
    }

        .cu-list.menu > .cu-item.arrow:before {
            position: absolute;
            top: 0;
            right: 30upx;
            bottom: 0;
            display: block;
            margin: auto;
            width: 30upx;
            height: 30upx;
            color: #8799a3;
            content: "\e6a3";
            text-align: center;
            font-size: 34upx;
            font-family: cuIcon;
            line-height: 30upx
        }

    .cu-list.menu > .cu-item button.content {
        padding: 0;
        background-color: transparent;
        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: #ffffff
    }

    .cu-list.menu > .cu-item .content > view:first-child {
        display: flex;
        align-items: center
    }

    .cu-list.menu > .cu-item .content > text[class*=cuIcon] {
        display: inline-block;
        margin-right: 10upx;
        width: 1.6em;
        text-align: center
    }

    .cu-list.menu > .cu-item .content > image {
        display: inline-block;
        margin-right: 10upx;
        width: 1.6em;
        height: 1.6em;
        vertical-align: middle
    }

    .cu-list.menu > .cu-item .content {
        font-size: 30upx;
        line-height: 1.6em;
        flex: 1
    }

        .cu-list.menu > .cu-item .content .cu-tag.sm {
            display: inline-block;
            margin-left: 10upx;
            height: 28upx;
            font-size: 16upx;
            line-height: 32upx
        }

    .cu-list.menu > .cu-item .action .cu-tag:empty {
        right: 10upx
    }

.cu-list.menu {
    display: block;
    overflow: hidden
}

    .cu-list.menu.sm-border > .cu-item:after {
        left: 30upx;
        width: calc(200% - 120upx)
    }

.cu-list.grid > .cu-item {
    position: relative;
    display: flex;
    padding: 20upx 0 30upx;
    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: " ";
        transform: scale(.5);
        transform-origin: 0 0;
        pointer-events: none
    }

    .cu-list.grid > .cu-item text {
        display: block;
        margin-top: 10upx;
        color: #888;
        font-size: 26upx;
        line-height: 40upx
    }

    .cu-list.grid > .cu-item [class*=cuIcon] {
        position: relative;
        display: block;
        margin-top: 20upx;
        width: 100%;
        font-size: 48upx
    }

    .cu-list.grid > .cu-item .cu-tag {
        right: auto;
        left: 50%;
        margin-left: 20upx
    }

.cu-list.grid {
    background-color: #ffffff;
    text-align: center
}

    .cu-list.grid.no-border > .cu-item {
        padding-top: 10upx;
        padding-bottom: 20upx
    }

        .cu-list.grid.no-border > .cu-item:after {
            border: none
        }

    .cu-list.grid.no-border {
        padding: 20upx 10upx
    }

    .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: 30upx;
    margin-left: 30upx;
    border-radius: 20upx
}


/* ==================
          操作条
 ==================== */

.cu-bar {
    display: flex;
    position: relative;
    align-items: center;
    min-height: 100upx;
    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: -10upx;
        }

            .cu-bar .action.border-title text[class*="bg-"]:last-child {
                position: absolute;
                bottom: -0.5rem;
                min-width: 2rem;
                height: 6upx;
                left: 0;
            }

        .cu-bar .action.sub-title {
            position: relative;
            top: -0.2rem;
        }

            .cu-bar .action.sub-title text {
                position: relative;
                z-index: 1;
            }

                .cu-bar .action.sub-title text[class*="bg-"]:last-child {
                    position: absolute;
                    display: inline-block;
                    bottom: -0.2rem;
                    border-radius: 6upx;
                    width: 100%;
                    height: 0.6rem;
                    left: 0.6rem;
                    opacity: 0.3;
                    z-index: 0;
                }

                .cu-bar .action.sub-title text[class*="text-"]:last-child {
                    position: absolute;
                    display: inline-block;
                    bottom: -0.7rem;
                    left: 0.5rem;
                    opacity: 0.2;
                    z-index: 0;
                    text-align: right;
                    font-weight: 900;
                    font-size: 36upx;
                }

    .cu-bar.justify-center .action.border-title text:last-child,
    .cu-bar.justify-center .action.sub-title text:last-child {
        left: 0;
        right: 0;
        margin: auto;
        text-align: center;
    }

    .cu-bar .action:first-child {
        margin-left: 30upx;
        font-size: 30upx;
    }

    .cu-bar .action text.text-cut {
        text-align: left;
        width: 100%;
    }

    .cu-bar .cu-avatar:first-child {
        margin-left: 20upx;
    }

    .cu-bar .action:first-child > text[class*="cuIcon-"] {
        margin-left: -0.3em;
        margin-right: 0.3em;
    }

    .cu-bar .action:last-child {
        margin-right: 30upx;
    }

    .cu-bar .action > text[class*="cuIcon-"],
    .cu-bar .action > view[class*="cuIcon-"] {
        font-size: 36upx;
    }

        .cu-bar .action > text[class*="cuIcon-"] + text[class*="cuIcon-"] {
            margin-left: 0.5em;
        }

    .cu-bar .content {
        position: absolute;
        text-align: center;
        width: calc(100% - 340upx);
        left: 0;
        right: 0;
        bottom: 0;
        top: 0;
        margin: auto;
        height: 60upx;
        font-size: 32upx;
        line-height: 60upx;
        cursor: none;
        pointer-events: none;
        text-overflow: ellipsis;
        white-space: nowrap;
        overflow: hidden;
    }

    .cu-bar.ios .content {
        bottom: 7px;
        height: 30px;
        font-size: 32upx;
        line-height: 30px;
    }

    .cu-bar.btn-group {
        justify-content: space-around;
    }

        .cu-bar.btn-group button {
            padding: 20upx 32upx;
        }

        .cu-bar.btn-group button {
            flex: 1;
            margin: 0 20upx;
            max-width: 50%;
        }

    .cu-bar .search-form {
        background-color: #f5f5f5;
        line-height: 64upx;
        height: 64upx;
        font-size: 24upx;
        color: #333333;
        flex: 1;
        display: flex;
        align-items: center;
        margin: 0 30upx;
    }

        .cu-bar .search-form + .action {
            margin-right: 30upx;
        }

        .cu-bar .search-form input {
            flex: 1;
            padding-right: 30upx;
            height: 64upx;
            line-height: 64upx;
            font-size: 26upx;
            background-color: transparent;
        }

        .cu-bar .search-form [class*="cuIcon-"] {
            margin: 0 0.5em 0 0.8em;
        }

            .cu-bar .search-form [class*="cuIcon-"]::before {
                top: 0upx;
            }

    .cu-bar.fixed,
    .nav.fixed {
        position: fixed;
        width: 100%;
        top: 0;
        z-index: 1024;
        box-shadow: 0 1upx 6upx rgba(0, 0, 0, 0.1);
    }

    .cu-bar.foot {
        position: fixed;
        width: 100%;
        bottom: 0;
        z-index: 1024;
        box-shadow: 0 -1upx 6upx rgba(0, 0, 0, 0.1);
    }

    .cu-bar.tabbar {
        padding: 0;
        height: calc(100upx + env(safe-area-inset-bottom) / 2);
        padding-bottom: calc(env(safe-area-inset-bottom) / 2);
    }

.cu-tabbar-height {
    min-height: 100upx;
    height: calc(100upx + env(safe-area-inset-bottom) / 2);
}

.cu-bar.tabbar.shadow {
    box-shadow: 0 -1upx 6upx rgba(0, 0, 0, 0.1);
}

.cu-bar.tabbar .action {
    font-size: 22upx;
    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: 140upx;
    flex: initial;
}

.cu-bar.tabbar .action.add-action {
    position: relative;
    z-index: 2;
    padding-top: 50upx;
}

    .cu-bar.tabbar .action.add-action [class*="cuIcon-"] {
        position: absolute;
        width: 70upx;
        z-index: 2;
        height: 70upx;
        border-radius: 50%;
        line-height: 70upx;
        font-size: 50upx;
        top: -35upx;
        left: 0;
        right: 0;
        margin: auto;
        padding: 0;
    }

    .cu-bar.tabbar .action.add-action::after {
        content: "";
        position: absolute;
        width: 100upx;
        height: 100upx;
        top: -50upx;
        left: 0;
        right: 0;
        margin: auto;
        box-shadow: 0 -3upx 8upx rgba(0, 0, 0, 0.08);
        border-radius: 50upx;
        background-color: inherit;
        z-index: 0;
    }

    .cu-bar.tabbar .action.add-action::before {
        content: "";
        position: absolute;
        width: 100upx;
        height: 30upx;
        bottom: 30upx;
        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 10upx;
}

.cu-bar.tabbar button.action::after {
    border: 0;
}

.cu-bar.tabbar .action [class*="cuIcon-"] {
    width: 100upx;
    position: relative;
    display: block;
    height: auto;
    margin: 0 auto 10upx;
    text-align: center;
    font-size: 40upx;
}

.cu-bar.tabbar .action .cuIcon-cu-image {
    margin: 0 auto;
}

    .cu-bar.tabbar .action .cuIcon-cu-image image {
        width: 50upx;
        height: 50upx;
        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;
    transform: scale(0.5);
    transform-origin: 0 0;
    border-right: 1upx solid rgba(0, 0, 0, 0.1);
    z-index: 3;
}

.cu-bar.tabbar.border .action:last-child:before {
    display: none;
}

.cu-bar.input {
    padding-right: 20upx;
    background-color: #ffffff;
}

    .cu-bar.input input {
        overflow: initial;
        line-height: 64upx;
        height: 64upx;
        min-height: 64upx;
        flex: 1;
        font-size: 30upx;
        margin: 0 20upx;
    }

    .cu-bar.input .action {
        margin-left: 20upx;
    }

        .cu-bar.input .action [class*="cuIcon-"] {
            font-size: 48upx;
        }

    .cu-bar.input input + .action {
        margin-right: 20upx;
        margin-left: 0upx;
    }

    .cu-bar.input .action:first-child [class*="cuIcon-"] {
        margin-left: 0upx;
    }

.cu-custom {
    display: block;
    position: relative;
}

    .cu-custom .cu-bar .content {
        width: calc(100% - 440upx);
    }

    /* #ifdef MP-ALIPAY */
    .cu-custom .cu-bar .action .cuIcon-back {
        opacity: 0;
    }

    /* #endif */

    .cu-custom .cu-bar .content image {
        height: 60upx;
        width: 240upx;
    }

    .cu-custom .cu-bar {
        min-height: 0px;
        /* #ifdef MP-WEIXIN */
        padding-right: 220upx;
        /* #endif */
        /* #ifdef MP-ALIPAY */
        padding-right: 150upx;
        /* #endif */
        box-shadow: 0upx 0upx 0upx;
        z-index: 9999;
    }

        .cu-custom .cu-bar .border-custom {
            position: relative;
            background: rgba(0, 0, 0, 0.15);
            border-radius: 1000upx;
            height: 30px;
        }

            .cu-custom .cu-bar .border-custom::after {
                content: " ";
                width: 200%;
                height: 200%;
                position: absolute;
                top: 0;
                left: 0;
                border-radius: inherit;
                transform: scale(0.5);
                transform-origin: 0 0;
                pointer-events: none;
                box-sizing: border-box;
                border: 1upx solid #ffffff;
                opacity: 0.5;
            }

            .cu-custom .cu-bar .border-custom::before {
                content: " ";
                width: 1upx;
                height: 110%;
                position: absolute;
                top: 22.5%;
                left: 0;
                right: 0;
                margin: auto;
                transform: scale(0.5);
                transform-origin: 0 0;
                pointer-events: none;
                box-sizing: border-box;
                opacity: 0.6;
                background-color: #ffffff;
            }

            .cu-custom .cu-bar .border-custom text {
                display: block;
                flex: 1;
                margin: auto !important;
                text-align: center;
                font-size: 34upx;
            }

/* ==================
         导航栏
 ==================== */

.nav {
    white-space: nowrap;
}

::-webkit-scrollbar {
    display: none;
}

.nav .cu-item {
    height: 90upx;
    display: inline-block;
    line-height: 90upx;
    margin: 0 10upx;
    padding: 0 20upx;
}

    .nav .cu-item.cur {
        border-bottom: 4upx solid;
    }

/* ==================
         时间轴
 ==================== */

.cu-timeline {
    display: block;
    background-color: #ffffff;
}

    .cu-timeline .cu-time {
        width: 120upx;
        text-align: center;
        padding: 20upx 0;
        font-size: 26upx;
        color: #888;
        display: block;
    }

    .cu-timeline > .cu-item {
        padding: 30upx 30upx 30upx 120upx;
        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: 1upx;
            background-color: #ddd;
            left: 60upx;
            height: 100%;
            top: 0;
            z-index: 8;
        }

        .cu-timeline > .cu-item::before {
            font-family: "cuIcon";
            display: block;
            position: absolute;
            top: 36upx;
            z-index: 9;
            background-color: #ffffff;
            width: 50upx;
            height: 50upx;
            text-align: center;
            border: none;
            line-height: 50upx;
            left: 36upx;
        }

        .cu-timeline > .cu-item:not([class*="cuIcon-"])::before {
            content: "\e763";
        }

        .cu-timeline > .cu-item[class*="cuIcon-"]::before {
            background-color: #ffffff;
            width: 50upx;
            height: 50upx;
            text-align: center;
            border: none;
            line-height: 50upx;
            left: 36upx;
        }

        .cu-timeline > .cu-item > .content {
            padding: 30upx;
            border-radius: 6upx;
            display: block;
            line-height: 1.6;
        }

            .cu-timeline > .cu-item > .content:not([class*="bg-"]) {
                background-color: #f1f1f1;
                color: #333333;
            }

            .cu-timeline > .cu-item > .content + .content {
                margin-top: 20upx;
            }

/* ==================
         聊天
 ==================== */

.cu-chat {
    display: flex;
    flex-direction: column;
}

    .cu-chat .cu-item {
        display: flex;
        padding: 30upx 30upx 70upx;
        position: relative;
    }

        .cu-chat .cu-item > .cu-avatar {
            width: 80upx;
            height: 80upx;
        }

        .cu-chat .cu-item > .main {
            max-width: calc(100% - 260upx);
            margin: 0 40upx;
            display: flex;
            align-items: center;
        }

        .cu-chat .cu-item > image {
            height: 320upx;
        }

        .cu-chat .cu-item > .main .content {
            padding: 20upx;
            border-radius: 6upx;
            display: inline-flex;
            max-width: 100%;
            align-items: center;
            font-size: 30upx;
            position: relative;
            min-height: 80upx;
            line-height: 40upx;
            text-align: left;
        }

            .cu-chat .cu-item > .main .content:not([class*="bg-"]) {
                background-color: #ffffff;
                color: #333333;
            }

        .cu-chat .cu-item .date {
            position: absolute;
            font-size: 24upx;
            color: #8799a3;
            width: calc(100% - 320upx);
            bottom: 20upx;
            left: 160upx;
        }

        .cu-chat .cu-item .action {
            padding: 0 30upx;
            display: flex;
            align-items: center;
        }

        .cu-chat .cu-item > .main .content::after {
            content: "";
            top: 27upx;
            transform: rotate(45deg);
            position: absolute;
            z-index: 100;
            display: inline-block;
            overflow: hidden;
            width: 24upx;
            height: 24upx;
            left: -12upx;
            right: initial;
            background-color: inherit;
        }

        .cu-chat .cu-item.self > .main .content::after {
            left: auto;
            right: -12upx;
        }

        .cu-chat .cu-item > .main .content::before {
            content: "";
            top: 30upx;
            transform: rotate(45deg);
            position: absolute;
            z-index: -1;
            display: inline-block;
            overflow: hidden;
            width: 24upx;
            height: 24upx;
            left: -12upx;
            right: initial;
            background-color: inherit;
            filter: blur(5upx);
            opacity: 0.3;
        }

        .cu-chat .cu-item > .main .content:not([class*="bg-"])::before {
            background-color: #333333;
            opacity: 0.1;
        }

        .cu-chat .cu-item.self > .main .content::before {
            left: auto;
            right: -12upx;
        }

        .cu-chat .cu-item.self {
            justify-content: flex-end;
            text-align: right;
        }

    .cu-chat .cu-info {
        display: inline-block;
        margin: 20upx auto;
        font-size: 24upx;
        padding: 8upx 12upx;
        background-color: rgba(0, 0, 0, 0.2);
        border-radius: 6upx;
        color: #ffffff;
        max-width: 400upx;
        line-height: 1.4;
    }

/* ==================
         卡片
 ==================== */

.cu-card {
    display: block;
    overflow: hidden;
}

    .cu-card > .cu-item {
        display: block;
        background-color: #ffffff;
        overflow: hidden;
        border-radius: 10upx;
        margin: 30upx;
    }

        .cu-card > .cu-item.shadow-blur {
            overflow: initial;
        }

    .cu-card.no-card > .cu-item {
        margin: 0upx;
        border-radius: 0upx;
    }

    .cu-card .grid.grid-square {
        margin-bottom: -20upx;
    }

    .cu-card.case .image {
        position: relative;
    }

        .cu-card.case .image image {
            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: transparent;
            padding: 0upx 30upx;
        }

    .cu-card.case.no-card .image {
        margin: 30upx 30upx 0;
        overflow: hidden;
        border-radius: 10upx;
    }

    .cu-card.dynamic {
        display: block;
    }

        .cu-card.dynamic > .cu-item {
            display: block;
            background-color: #ffffff;
            overflow: hidden;
        }

            .cu-card.dynamic > .cu-item > .text-content {
                padding: 0 30upx 0;
                max-height: 6.4em;
                overflow: hidden;
                font-size: 30upx;
                margin-bottom: 20upx;
            }

            .cu-card.dynamic > .cu-item .square-img {
                width: 100%;
                height: 200upx;
                border-radius: 6upx;
            }

            .cu-card.dynamic > .cu-item .only-img {
                width: 100%;
                height: 320upx;
                border-radius: 6upx;
            }

    /* card.dynamic>.cu-item .comment {
  padding: 20upx;
  background-color: #f1f1f1;
  margin: 0 30upx 30upx;
  border-radius: 6upx;
} */

    .cu-card.article {
        display: block;
    }

        .cu-card.article > .cu-item {
            padding-bottom: 30upx;
        }

            .cu-card.article > .cu-item .title {
                font-size: 30upx;
                font-weight: 900;
                color: #333333;
                line-height: 100upx;
                padding: 0 30upx;
            }

            .cu-card.article > .cu-item .content {
                display: flex;
                padding: 0 30upx;
            }

                .cu-card.article > .cu-item .content > image {
                    width: 240upx;
                    height: 6.4em;
                    margin-right: 20upx;
                    border-radius: 6upx;
                }

                .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: 28upx;
                    color: #888;
                    height: 4.8em;
                    overflow: hidden;
                }

/* ==================
         表单
 ==================== */

.cu-form-group {
    background-color: #ffffff;
    padding: 1upx 30upx;
    display: flex;
    align-items: center;
    min-height: 100upx;
    justify-content: space-between;
}

    .cu-form-group + .cu-form-group {
        border-top: 1upx solid #eee;
    }

    .cu-form-group .title {
        text-align: justify;
        padding-right: 30upx;
        font-size: 30upx;
        position: relative;
        height: 60upx;
        line-height: 60upx;
    }

    .cu-form-group input {
        flex: 1;
        font-size: 30upx;
        color: #555;
        padding-right: 20upx;
    }

    .cu-form-group > text[class*="cuIcon-"] {
        font-size: 36upx;
        padding: 0;
        box-sizing: border-box;
    }

    .cu-form-group textarea {
        margin: 32upx 0 30upx;
        height: 4.6em;
        width: 100%;
        line-height: 1.2em;
        flex: 1;
        font-size: 28upx;
        padding: 0;
    }

    .cu-form-group.align-start .title {
        height: 1em;
        margin-top: 32upx;
        line-height: 1em;
    }

    .cu-form-group picker {
        flex: 1;
        padding-right: 40upx;
        overflow: hidden;
        position: relative;
    }

        .cu-form-group picker .picker {
            line-height: 100upx;
            font-size: 28upx;
            text-overflow: ellipsis;
            white-space: nowrap;
            overflow: hidden;
            width: 100%;
            text-align: right;
        }

        .cu-form-group picker::after {
            font-family: cuIcon;
            display: block;
            content: "\e6a3";
            position: absolute;
            font-size: 34upx;
            color: #8799a3;
            line-height: 100upx;
            width: 60upx;
            text-align: center;
            top: 0;
            bottom: 0;
            right: -20upx;
            margin: auto;
        }

    .cu-form-group textarea[disabled],
    .cu-form-group textarea[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);
    transform: scale(1.185);
    backface-visibility: hidden;
    perspective: 2000upx;
    background: rgba(0, 0, 0, 0.6);
    transition: all 0.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: 0.3s;
        -ms-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: 680upx;
    max-width: 100%;
    background-color: #f8f8f8;
    border-radius: 10upx;
    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: -1000upx;
}

    .cu-modal.bottom-modal.show {
        margin-bottom: 0;
    }

.cu-modal.drawer-modal {
    transform: scale(1);
    display: flex;
}

    .cu-modal.drawer-modal .cu-dialog {
        height: 100%;
        min-width: 200upx;
        border-radius: 0;
        margin: initial;
        transition-duration: 0.3s;
    }

    .cu-modal.drawer-modal.justify-start .cu-dialog {
        transform: translateX(-100%);
    }

    .cu-modal.drawer-modal.justify-end .cu-dialog {
        transform: translateX(100%);
    }

    .cu-modal.drawer-modal.show .cu-dialog {
        transform: translateX(0%);
    }

.cu-modal .cu-dialog > .cu-bar:first-child .action {
    min-width: 100rpx;
    margin-right: 0;
    min-height: 100rpx;
}
/* ==================
         轮播
 ==================== */
swiper .a-swiper-dot {
    display: inline-block;
    width: 16upx;
    height: 16upx;
    background: rgba(0, 0, 0, .3);
    border-radius: 50%;
    vertical-align: middle;
}

swiper[class*="-dot"] .wx-swiper-dots,
swiper[class*="-dot"] .a-swiper-dots,
swiper[class*="-dot"] .uni-swiper-dots {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
}

swiper.square-dot .wx-swiper-dot,
swiper.square-dot .a-swiper-dot,
swiper.square-dot .uni-swiper-dot {
    background-color: #ffffff;
    opacity: 0.4;
    width: 10upx;
    height: 10upx;
    border-radius: 20upx;
    margin: 0 8upx !important;
}

    swiper.square-dot .wx-swiper-dot.wx-swiper-dot-active,
    swiper.square-dot .a-swiper-dot.a-swiper-dot-active,
    swiper.square-dot .uni-swiper-dot.uni-swiper-dot-active {
        opacity: 1;
        width: 30upx;
    }

swiper.round-dot .wx-swiper-dot,
swiper.round-dot .a-swiper-dot,
swiper.round-dot .uni-swiper-dot {
    width: 10upx;
    height: 10upx;
    position: relative;
    margin: 4upx 8upx !important;
}

    swiper.round-dot .wx-swiper-dot.wx-swiper-dot-active::after,
    swiper.round-dot .a-swiper-dot.a-swiper-dot-active::after,
    swiper.round-dot .uni-swiper-dot.uni-swiper-dot-active::after {
        content: "";
        position: absolute;
        width: 10upx;
        height: 10upx;
        top: 0upx;
        left: 0upx;
        right: 0;
        bottom: 0;
        margin: auto;
        background-color: #ffffff;
        border-radius: 20upx;
    }

    swiper.round-dot .wx-swiper-dot.wx-swiper-dot-active,
    swiper.round-dot .a-swiper-dot.a-swiper-dot-active,
    swiper.round-dot .uni-swiper-dot.uni-swiper-dot-active {
        width: 18upx;
        height: 18upx;
    }

.screen-swiper {
    min-height: 375upx;
}

    .screen-swiper image,
    .screen-swiper video,
    .swiper-item image,
    .swiper-item video {
        width: 100%;
        display: block;
        height: 100%;
        margin: 0;
        pointer-events: none;
    }

.card-swiper {
    height: 420upx !important;
}

    .card-swiper swiper-item {
        width: 610upx !important;
        left: 70upx;
        box-sizing: border-box;
        padding: 40upx 0upx 70upx;
        overflow: initial;
    }

        .card-swiper swiper-item .swiper-item {
            width: 100%;
            display: block;
            height: 100%;
            border-radius: 10upx;
            transform: scale(0.9);
            transition: all 0.2s ease-in 0s;
            overflow: hidden;
        }

        .card-swiper swiper-item.cur .swiper-item {
            transform: none;
            transition: all 0.2s ease-in 0s;
        }


.tower-swiper {
    height: 420upx;
    position: relative;
    max-width: 750upx;
    overflow: hidden;
}

    .tower-swiper .tower-item {
        position: absolute;
        width: 300upx;
        height: 380upx;
        top: 0;
        bottom: 0;
        left: 50%;
        margin: auto;
        transition: all 0.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: 6upx;
            overflow: hidden;
        }

/* ==================
          步骤条
 ==================== */

.cu-steps {
    display: flex;
}

scroll-view.cu-steps {
    display: block;
    white-space: nowrap;
}

    scroll-view.cu-steps .cu-item {
        display: inline-block;
    }

.cu-steps .cu-item {
    flex: 1;
    text-align: center;
    position: relative;
    min-width: 100upx;
}

    .cu-steps .cu-item:not([class*="text-"]) {
        color: #8799a3;
    }

    .cu-steps .cu-item [class*="cuIcon-"],
    .cu-steps .cu-item .num {
        display: block;
        font-size: 40upx;
        line-height: 80upx;
    }

    .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: 0px;
        width: calc(100% - 80upx);
        border-bottom: 1px solid #ccc;
        left: calc(0px - (100% - 80upx) / 2);
        top: 40upx;
        z-index: 0;
    }

.cu-steps.steps-arrow .cu-item::before,
.cu-steps.steps-arrow .cu-item::after {
    content: "\e6a3";
    font-family: 'cuIcon';
    height: 30upx;
    border-bottom-width: 0px;
    line-height: 30upx;
    top: 0;
    bottom: 0;
    margin: auto;
    color: #ccc;
}

.cu-steps.steps-bottom .cu-item::before,
.cu-steps.steps-bottom .cu-item::after {
    bottom: 40upx;
    top: initial;
}

.cu-steps .cu-item::after {
    border-bottom: 1px solid currentColor;
    width: 0px;
    transition: all 0.3s ease-in-out 0s;
}

.cu-steps .cu-item[class*="text-"]::after {
    width: calc(100% - 80upx);
    color: currentColor;
}

.cu-steps .cu-item:first-child::before,
.cu-steps .cu-item:first-child::after {
    display: none;
}

.cu-steps .cu-item .num {
    width: 40upx;
    height: 40upx;
    border-radius: 50%;
    line-height: 40upx;
    margin: 20upx auto;
    font-size: 24upx;
    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 0.3s ease-in-out 0s;
    transform: translateY(0upx);
}

.cu-steps .cu-item[class*="text-"] .num::before {
    transform: translateY(-40upx);
    color: #ffffff;
}

.cu-steps .cu-item .num::after {
    transform: translateY(40upx);
    color: #ffffff;
    transition: all 0.3s ease-in-out 0s;
}

.cu-steps .cu-item[class*="text-"] .num::after {
    content: "\e645";
    font-family: 'cuIcon';
    color: #ffffff;
    transform: translateY(0upx);
}

.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: flex-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: 6upx;
            padding: 6upx 12upx;
            height: auto;
            background-color: rgba(0, 0, 0, 0.5);
        }

        .grid.grid-square > view > text[class*="cuIcon-"] {
            font-size: 52upx;
            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 > view {
            margin-right: 20upx;
            margin-bottom: 20upx;
            border-radius: 6upx;
            position: relative;
            overflow: hidden;
        }

            .grid.grid-square > view.bg-img image {
                width: 100%;
                height: 100%;
                position: absolute;
            }

    .grid.col-1.grid-square > view {
        padding-bottom: 100%;
        height: 0;
        margin-right: 0;
    }

    .grid.col-2.grid-square > view {
        padding-bottom: calc((100% - 20upx)/2);
        height: 0;
        width: calc((100% - 20upx)/2);
    }

    .grid.col-3.grid-square > view {
        padding-bottom: calc((100% - 40upx)/3);
        height: 0;
        width: calc((100% - 40upx)/3);
    }

    .grid.col-4.grid-square > view {
        padding-bottom: calc((100% - 60upx)/4);
        height: 0;
        width: calc((100% - 60upx)/4);
    }

    .grid.col-5.grid-square > view {
        padding-bottom: calc((100% - 80upx)/5);
        height: 0;
        width: calc((100% - 80upx)/5);
    }

        .grid.col-2.grid-square > view:nth-child(2n),
        .grid.col-3.grid-square > view:nth-child(3n),
        .grid.col-4.grid-square > view:nth-child(4n),
        .grid.col-5.grid-square > view:nth-child(5n) {
            margin-right: 0;
        }

    .grid.col-1 > view {
        width: 100%;
    }

    .grid.col-2 > view {
        width: 50%;
    }

    .grid.col-3 > view {
        width: 33.33%;
    }

    .grid.col-4 > view {
        width: 25%;
    }

    .grid.col-5 > view {
        width: 20%;
    }

/*  -- 内外边距 -- */

.margin-0 {
    margin: 0;
}

.margin-xs {
    margin: 10upx;
}

.margin-sm {
    margin: 20upx;
}

.margin {
    margin: 30upx;
}

.margin-lg {
    margin: 40upx;
}

.margin-xl {
    margin: 50upx;
}

.margin-top-xs {
    margin-top: 10upx;
}

.margin-top-sm {
    margin-top: 20upx;
}

.margin-top {
    margin-top: 30upx;
}

.margin-top-lg {
    margin-top: 40upx;
}

.margin-top-xl {
    margin-top: 50upx;
}

.margin-right-xs {
    margin-right: 10upx;
}

.margin-right-sm {
    margin-right: 20upx;
}

.margin-right {
    margin-right: 30upx;
}

.margin-right-lg {
    margin-right: 40upx;
}

.margin-right-xl {
    margin-right: 50upx;
}

.margin-bottom-xs {
    margin-bottom: 10upx;
}

.margin-bottom-sm {
    margin-bottom: 20upx;
}

.margin-bottom {
    margin-bottom: 30upx;
}

.margin-bottom-lg {
    margin-bottom: 40upx;
}

.margin-bottom-xl {
    margin-bottom: 50upx;
}

.margin-left-xs {
    margin-left: 10upx;
}

.margin-left-sm {
    margin-left: 20upx;
}

.margin-left {
    margin-left: 30upx;
}

.margin-left-lg {
    margin-left: 40upx;
}

.margin-left-xl {
    margin-left: 50upx;
}

.margin-lr-xs {
    margin-left: 10upx;
    margin-right: 10upx;
}

.margin-lr-sm {
    margin-left: 20upx;
    margin-right: 20upx;
}

.margin-lr {
    margin-left: 30upx;
    margin-right: 30upx;
}

.margin-lr-lg {
    margin-left: 40upx;
    margin-right: 40upx;
}

.margin-lr-xl {
    margin-left: 50upx;
    margin-right: 50upx;
}

.margin-tb-xs {
    margin-top: 10upx;
    margin-bottom: 10upx;
}

.margin-tb-sm {
    margin-top: 20upx;
    margin-bottom: 20upx;
}

.margin-tb {
    margin-top: 30upx;
    margin-bottom: 30upx;
}

.margin-tb-lg {
    margin-top: 40upx;
    margin-bottom: 40upx;
}

.margin-tb-xl {
    margin-top: 50upx;
    margin-bottom: 50upx;
}

.padding-0 {
    padding: 0;
}

.padding-xs {
    padding: 10upx;
}

.padding-sm {
    padding: 20upx;
}

.padding {
    padding: 30upx;
}

.padding-lg {
    padding: 40upx;
}

.padding-xl {
    padding: 50upx;
}

.padding-top-xs {
    padding-top: 10upx;
}

.padding-top-sm {
    padding-top: 20upx;
}

.padding-top {
    padding-top: 30upx;
}

.padding-top-lg {
    padding-top: 40upx;
}

.padding-top-xl {
    padding-top: 50upx;
}

.padding-right-xs {
    padding-right: 10upx;
}

.padding-right-sm {
    padding-right: 20upx;
}

.padding-right {
    padding-right: 30upx;
}

.padding-right-lg {
    padding-right: 40upx;
}

.padding-right-xl {
    padding-right: 50upx;
}

.padding-bottom-xs {
    padding-bottom: 10upx;
}

.padding-bottom-sm {
    padding-bottom: 20upx;
}

.padding-bottom {
    padding-bottom: 30upx;
}

.padding-bottom-lg {
    padding-bottom: 40upx;
}

.padding-bottom-xl {
    padding-bottom: 50upx;
}

.padding-left-xs {
    padding-left: 10upx;
}

.padding-left-sm {
    padding-left: 20upx;
}

.padding-left {
    padding-left: 30upx;
}

.padding-left-lg {
    padding-left: 40upx;
}

.padding-left-xl {
    padding-left: 50upx;
}

.padding-lr-xs {
    padding-left: 10upx;
    padding-right: 10upx;
}

.padding-lr-sm {
    padding-left: 20upx;
    padding-right: 20upx;
}

.padding-lr {
    padding-left: 30upx;
    padding-right: 30upx;
}

.padding-lr-lg {
    padding-left: 40upx;
    padding-right: 40upx;
}

.padding-lr-xl {
    padding-left: 50upx;
    padding-right: 50upx;
}

.padding-tb-xs {
    padding-top: 10upx;
    padding-bottom: 10upx;
}

.padding-tb-sm {
    padding-top: 20upx;
    padding-bottom: 20upx;
}

.padding-tb {
    padding-top: 30upx;
    padding-bottom: 30upx;
}

.padding-tb-lg {
    padding-top: 40upx;
    padding-bottom: 40upx;
}

.padding-tb-xl {
    padding-top: 50upx;
    padding-bottom: 50upx;
}

/* -- 浮动 --  */

.cf::after,
.cf::before {
    content: " ";
    display: table;
}

.cf::after {
    clear: both;
}

.fl {
    float: left;
}

.fr {
    float: right;
}

/* ==================
          背景
 ==================== */

.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: #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: #aaaaaa;
}

.line-black::after,
.lines-black::after {
    border-color: #333333;
}

.line-white::after,
.lines-white::after {
    border-color: #ffffff;
}

.bg-red {
    background-color: #e54d42;
    color: #ffffff;
}

.bg-orange {
    background-color: #f37b1d;
    color: #ffffff;
}

.bg-yellow {
    background-color: #fbbd08;
    color: #333333;
}

.bg-olive {
    background-color: #8dc63f;
    color: #ffffff;
}

.bg-green {
    background-color: #39b54a;
    color: #ffffff;
}

.bg-cyan {
    background-color: #1cbbb4;
    color: #ffffff;
}

.bg-blue {
    background-color: #0081ff;
    color: #ffffff;
}

.bg-purple {
    background-color: #6739b6;
    color: #ffffff;
}

.bg-mauve {
    background-color: #9c26b0;
    color: #ffffff;
}

.bg-pink {
    background-color: #e03997;
    color: #ffffff;
}

.bg-brown {
    background-color: #a5673f;
    color: #ffffff;
}

.bg-grey {
    background-color: #8799a3;
    color: #ffffff;
}

.bg-gray {
    background-color: #f0f0f0;
    color: #333333;
}

.bg-black {
    background-color: #333333;
    color: #ffffff;
}

.bg-white {
    background-color: #ffffff;
    color: #666666;
}

.bg-shadeTop {
    background-image: linear-gradient(rgba(0, 0, 0, 1), rgba(0, 0, 0, 0.01));
    color: #ffffff;
}

.bg-shadeBottom {
    background-image: linear-gradient(rgba(0, 0, 0, 0.01), rgba(0, 0, 0, 1));
    color: #ffffff;
}

.bg-red.light {
    color: #e54d42;
    background-color: #fadbd9;
}

.bg-orange.light {
    color: #f37b1d;
    background-color: #fde6d2;
}

.bg-yellow.light {
    color: #fbbd08;
    background-color: #fef2ced2;
}

.bg-olive.light {
    color: #8dc63f;
    background-color: #e8f4d9;
}

.bg-green.light {
    color: #39b54a;
    background-color: #d7f0dbff;
}

.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-red {
    background-image: linear-gradient(45deg, #f43f3b, #ec008c);
    color: #ffffff;
}

.bg-gradual-orange {
    background-image: linear-gradient(45deg, #ff9700, #ed1c24);
    color: #ffffff;
}

.bg-gradual-green {
    background-image: linear-gradient(45deg, #39b54a, #8dc63f);
    color: #ffffff;
}

.bg-gradual-purple {
    background-image: linear-gradient(45deg, #9000ff, #5e00ff);
    color: #ffffff;
}

.bg-gradual-pink {
    background-image: linear-gradient(45deg, #ec008c, #6739b6);
    color: #ffffff;
}

.bg-gradual-blue {
    background-image: linear-gradient(45deg, #0081ff, #1cbbb4);
    color: #ffffff;
}

.shadow[class*="-red"] {
    box-shadow: 6upx 6upx 8upx rgba(204, 69, 59, 0.2);
}

.shadow[class*="-orange"] {
    box-shadow: 6upx 6upx 8upx rgba(217, 109, 26, 0.2);
}

.shadow[class*="-yellow"] {
    box-shadow: 6upx 6upx 8upx rgba(224, 170, 7, 0.2);
}

.shadow[class*="-olive"] {
    box-shadow: 6upx 6upx 8upx rgba(124, 173, 55, 0.2);
}

.shadow[class*="-green"] {
    box-shadow: 6upx 6upx 8upx rgba(48, 156, 63, 0.2);
}

.shadow[class*="-cyan"] {
    box-shadow: 6upx 6upx 8upx rgba(28, 187, 180, 0.2);
}

.shadow[class*="-blue"] {
    box-shadow: 6upx 6upx 8upx rgba(0, 102, 204, 0.2);
}

.shadow[class*="-purple"] {
    box-shadow: 6upx 6upx 8upx rgba(88, 48, 156, 0.2);
}

.shadow[class*="-mauve"] {
    box-shadow: 6upx 6upx 8upx rgba(133, 33, 150, 0.2);
}

.shadow[class*="-pink"] {
    box-shadow: 6upx 6upx 8upx rgba(199, 50, 134, 0.2);
}

.shadow[class*="-brown"] {
    box-shadow: 6upx 6upx 8upx rgba(140, 88, 53, 0.2);
}

.shadow[class*="-grey"] {
    box-shadow: 6upx 6upx 8upx rgba(114, 130, 138, 0.2);
}

.shadow[class*="-gray"] {
    box-shadow: 6upx 6upx 8upx rgba(114, 130, 138, 0.2);
}

.shadow[class*="-black"] {
    box-shadow: 6upx 6upx 8upx rgba(26, 26, 26, 0.2);
}

.shadow[class*="-white"] {
    box-shadow: 6upx 6upx 8upx rgba(26, 26, 26, 0.2);
}

.text-shadow[class*="-red"] {
    text-shadow: 6upx 6upx 8upx rgba(204, 69, 59, 0.2);
}

.text-shadow[class*="-orange"] {
    text-shadow: 6upx 6upx 8upx rgba(217, 109, 26, 0.2);
}

.text-shadow[class*="-yellow"] {
    text-shadow: 6upx 6upx 8upx rgba(224, 170, 7, 0.2);
}

.text-shadow[class*="-olive"] {
    text-shadow: 6upx 6upx 8upx rgba(124, 173, 55, 0.2);
}

.text-shadow[class*="-green"] {
    text-shadow: 6upx 6upx 8upx rgba(48, 156, 63, 0.2);
}

.text-shadow[class*="-cyan"] {
    text-shadow: 6upx 6upx 8upx rgba(28, 187, 180, 0.2);
}

.text-shadow[class*="-blue"] {
    text-shadow: 6upx 6upx 8upx rgba(0, 102, 204, 0.2);
}

.text-shadow[class*="-purple"] {
    text-shadow: 6upx 6upx 8upx rgba(88, 48, 156, 0.2);
}

.text-shadow[class*="-mauve"] {
    text-shadow: 6upx 6upx 8upx rgba(133, 33, 150, 0.2);
}

.text-shadow[class*="-pink"] {
    text-shadow: 6upx 6upx 8upx rgba(199, 50, 134, 0.2);
}

.text-shadow[class*="-brown"] {
    text-shadow: 6upx 6upx 8upx rgba(140, 88, 53, 0.2);
}

.text-shadow[class*="-grey"] {
    text-shadow: 6upx 6upx 8upx rgba(114, 130, 138, 0.2);
}

.text-shadow[class*="-gray"] {
    text-shadow: 6upx 6upx 8upx rgba(114, 130, 138, 0.2);
}

.text-shadow[class*="-black"] {
    text-shadow: 6upx 6upx 8upx rgba(26, 26, 26, 0.2);
}

.bg-img {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.bg-mask {
    background-color: #333333;
    position: relative;
}

    .bg-mask::after {
        content: "";
        border-radius: inherit;
        width: 100%;
        height: 100%;
        display: block;
        background-color: rgba(0, 0, 0, 0.4);
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        top: 0;
    }

    .bg-mask view,
    .bg-mask cover-view {
        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: 20upx;
}

.text-sm {
    font-size: 24upx;
}

.text-df {
    font-size: 28upx;
}

.text-lg {
    font-size: 32upx;
}

.text-xl {
    font-size: 36upx;
}

.text-xxl {
    font-size: 44upx;
}

.text-sl {
    font-size: 80upx;
}

.text-xsl {
    font-size: 120upx;
}

.text-Abc {
    text-transform: Capitalize;
}

.text-ABC {
    text-transform: Uppercase;
}

.text-abc {
    text-transform: Lowercase;
}

.text-price::before {
    content: "¥";
    font-size: 80%;
    margin-right: 4upx;
}

.text-cut {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

.text-bold {
    font-weight: bold;
}

.text-center {
    text-align: center;
}

.text-content {
    line-height: 1.6;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

.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: #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: #aaaaaa;
}

.text-black,
.line-black,
.lines-black {
    color: #333333;
}

.text-white,
.line-white,
.lines-white {
    color: #ffffff;
}
