html,
body {
  font-size: 1.02865px;
}

@media screen and (max-width: 767px) {
  html {
    font-size: 0.833333px;
  }
}

html,
body,
* {
  font-family:
    -apple-system,
    BlinkMacSystemFont,
    Helvetica Neue,
    Helvetica,
    Segoe UI,
    Arial,
    Roboto,
    PingFang SC,
    miui,
    Hiragino Sans GB,
    Microsoft Yahei,
    sans-serif;
}

body {
  background-color: #f8f8f8;
  font-size: 14rem;
  color: #000000;
}

* {
  color: inherit;
}

main {
  margin-bottom: 50rem;
}

a {
  text-decoration: none;
  color: var(--color-text-primary);
}

.link-hover:hover,
.link-hover:hover *,
a:hover {
  color: var(--color-primary);
  cursor: pointer;
  text-decoration: none !important;
}

hr {
  margin-top: 15rem;
  margin-bottom: 15rem;
}

input,
textarea {
  outline: none;
}

/* 禁止选择复制 */
.no-select,
.no-select * {
  -webkit-user-select: none;
  /* Safari */
  -moz-user-select: none;
  /* Firefox */
  -ms-user-select: none;
  /* IE/Edge */
  user-select: none;
  /* 标准语法 */
}

.position-relative {
  position: relative;
}

.position-absolute {
  position: absolute;
}

.position-sticky-top {
  position: sticky;
  top: 0;
  z-index: 1;
}

.position-absolute-left-top {
  left: 0;
  top: 0;
  position: absolute;
}

.position-absolute-left-bottom {
  left: 0;
  bottom: 0;
  position: absolute;
}

.position-absolute-left-center {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

.position-absolute-right-top {
  position: absolute;
  top: 0;
  right: 0;
}

.position-absolute-right-center {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}

.position-absolute-right-bottom {
  position: absolute;
  bottom: 0;
  right: 0;
}

.position-absolute-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.z-index-1 {
  z-index: 10;
}

.z-index-10 {
  z-index: 10;
}

.z-index-100 {
  z-index: 10;
}

/* 隐藏元素 */
.hide-none {
  display: none !important;
}

/* 隐藏滚动条 */
.scrollbar-none::-webkit-scrollbar {
  display: none;
}

/* 聚焦不显示下划线 */
.hover-decoration-none:hover {
  text-decoration: none !important;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}

.display-none {
  display: none;
}

/* 显示块类型 */
.display-block {
  display: block;
}

.display-inline-block {
  display: inline-block;
}

.visibility-hidden {
  visibility: hidden;
}

/********************************* 自定义弹性布局 ***********************/
.flex {
  display: flex;
}

.flex-1 {
  flex: 1;
}

.flex-2 {
  flex: 2;
}

.flex-3 {
  flex: 3;
}

.flex-4 {
  flex: 4;
}

.flex-5 {
  flex: 5;
}

.flex-column {
  display: flex;
  flex-direction: column;
}

.justify-between {
  display: flex;
  justify-content: space-between;
}

.justify-center {
  display: flex;
  justify-content: center;
}

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

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

.justify-around {
  display: flex;
  justify-content: space-around;
}

.justify-evenly {
  display: flex;
  justify-content: space-evenly;
}

.align-center {
  display: flex;
  align-items: center;
}

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

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

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

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

.flex-wrap {
  flex-wrap: wrap;
}

.flex-nowrap {
  flex-wrap: nowrap;
}

.white-space-nowrap {
  white-space: nowrap;
}

/* 拆分单词换行 */
.word-break-all {
  word-break: break-all;
}

.flex-gap-5 {
  gap: 5rem;
}

.flex-gap-10 {
  gap: 10rem;
}

.flex-gap-15 {
  gap: 18rem;
}

.flex-gap-18 {
  gap: 18rem;
}

.flex-gap-20 {
  gap: 20rem;
}

.flex-gap-30 {
  gap: 30rem;
}

.flex-gap-40 {
  gap: 40rem;
}

/* 宽度100% */
.full-width {
  width: 100%;
}

/* 宽度50% */
.half-width {
  width: 50%;
}

/* 高度100% */
.full-height {
  height: 100%;
}

/* 宽带为0 */
.width-0 {
  width: 0;
}

/* 高度为0 */
.height-0 {
  height: 0;
}

.flex-order-0 {
  order: 0;
}

.flex-order-1 {
  order: 1;
}

.flex-order-2 {
  order: 2;
}

.flex-order-3 {
  order: 3;
}

.flex-order-4 {
  order: 4;
}

.flex-order-5 {
  order: 5;
}

/********************************* 背景颜色 ***********************/
/* --background-primary: #F8F8F8; */
.bg-primary {
  background-color: var(--background-primary);
}

/* --background-regular: white; */
.bg-regular {
  background-color: var(--background-regular);
}

/* --color-primary: #3879F1; */
.bg-theme-color {
  background-color: var(--color-primary);
}

.bg-theme-color-lighter {
  background: #e3f6ec;
}

.bg-black {
  background: #000000;
}

.bg-black-opacity {
  background: rgba(0, 0, 0, 0.4);
}

/* 审核中 */
.bg-state-process {
  color: white;
  background-color: var(--color-primary);
}

/* 审核未通过 */
.bg-state-danger {
  color: white;
  background-color: #d74646;
}

.bg-success {
  background-color: #e7fdfc;
}

.text-success {
  color: #59c9c7;
}

/********************************* 字体颜色 ***********************/
/* --color-text-primary: #333333; */
.text-color-primary {
  color: var(--color-text-primary);
}

/* --color-text-regular: #666666; */
.text-color-regular {
  color: var(--color-text-regular);
}

/* --color-text-secondary: #999999; */
.text-color-secondary {
  color: var(--color-text-secondary);
}

/* --color-text-placeholder: #C0C4CC; */
.text-placeholder {
  color: var(--color-text-placeholder);
}

/* --color-primary: #3879F1; */
.text-theme-primary {
  color: var(--color-primary);
}

.text-white {
  color: #ffffff;
}

.text-black {
  color: #000000;
}

.text-red {
  color: #ff0000;
}

.text-orange {
  color: #ff6261;
}

.text-gray {
  color: #999999;
}

.text-green {
  color: #27ae60;
}

.text-blue {
  color: #0287fc;
}

/********************************* 字体大小 ***********************/
/* --font-size-xs: 10rem; */
.font-size-xs {
  font-size: 10rem;
}

/* --font-size-min: 12rem; */
.font-size-min {
  font-size: var(--font-size-min);
}

/* --font-size-small: 14rem; */
.font-size-small {
  font-size: var(--font-size-small);
}

/* --font-size-normal: 16rem; */
.font-size-normal {
  font-size: var(--font-size-normal);
}

/* --font-size-big: 18rem; */
.font-size-big {
  font-size: var(--font-size-big);
}

/* --font-size-huge: 20rem; */
.font-size-huge {
  font-size: var(--font-size-huge);
}

.font-size-20 {
  font-size: 20rem !important;
}

.font-size-24 {
  font-size: 24rem !important;
}

.font-size-28 {
  font-size: 28rem !important;
}

/********************************** 字体粗细 ************************/
.font-weight-lighter {
  font-weight: lighter;
}

/* 字体加粗 */
.font-weight-bold {
  font-weight: bold;
}

/* 正常粗细 */
.font-weight-normal {
  font-weight: normal;
}

/********************************* 字体对齐方式 ***********************/
.text-align-left {
  text-align: left;
}

.text-align-center {
  text-align: center;
}

.text-align-right {
  text-align: right;
}

/********************************* 边框 ***********************/
/* --border-color-base */
.border-base {
  border: 1px solid var(--border-color-base);
}

/* --border-color-light */
.border-light {
  border: 1px solid var(--border-color-light);
}

/* --border-color-lighter */
.border-lighter {
  border: 1px solid var(--border-color-lighter);
}

/* --border-color-base */
.border-bottom-base {
  border-bottom: 1px solid var(--border-color-base);
}

/* --border-color-light */
.border-bottom-light {
  border-bottom: 1px solid var(--border-color-light);
}

/* --border-color-lighter */
.border-bottom-lighter {
  border-bottom: 1px solid var(--border-color-lighter);
}

/* --border-color-extra-lighter */
.border-bottom-extra-lighter {
  border-bottom: 1px solid var(--border-color-extra-light);
}

.box-shadow-base {
  box-shadow: 0px 0px 36px 2px rgba(51, 51, 51, 0.06);
}
/********************************* 卡片 ***********************/
.card-white {
  background: white;
  border-radius: var(--border-radius-big);
  padding: 20rem;
}

.card-gray {
  background: #f8f8f8;
  border-radius: var(--border-radius-big);
  padding: 20rem;
}

.card-black {
  background: #000000;
  border-radius: var(--border-radius-big);
  padding: 20rem;
}

.card-black-opacity {
  background: rgba(0, 0, 0, 0.4);
  border-radius: var(--border-radius-big);
  padding: 20rem;
}

/********************************* 标签 ***********************/
.tag-primary,
.tag-primary-hollow,
.tag-gray,
.tag-gray-hollow,
.tag-gray-white {
  border-radius: 20rem;
  font-size: var(--font-size-min);
  padding: 5rem 10rem;
  line-height: 1;
}

.tag-gray {
  background: #f8f8f8;
  color: var(--color-text-secondary);
}

.tag-gray-white {
  background: rgb(248 248 248 / 20%);
  color: white;
}

.tag-primary {
  background: var(--background-primary);
  color: var(--color-primary);
}

.tag-primary-hollow {
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
}

.tag-gray-hollow {
  color: var(--color-text-secondary);
  border: 1px solid var(--color-text-secondary);
}

.tag-min {
  padding: 2rem 5rem;
}

.tag-gray-hollow.active {
  color: var(--color-primary);
  border-color: var(--color-primary);
}

/********************************* 分割线 ***********************/
.split-line {
  width: 100%;
  height: 1rem;
  background: var(--border-color-base);
}

.split-line-light {
  width: 100%;
  height: 1rem;
  background: var(--border-color-light);
}

.split-line-lighter {
  width: 100%;
  height: 1rem;
  background: var(--border-color-lighter);
}

.split-line-vertical {
  width: 1rem;
  height: 100%;
  background: var(--border-color-base);
}

/********************************* margin间距 ***********************/
.margin-x-auto {
  margin-left: auto;
  margin-right: auto;
}

.margin-0 {
  margin: 0;
}

.margin-top-0 {
  margin-top: 0;
}

.margin-top-2 {
  margin-top: 2rem;
}

.margin-top-5 {
  margin-top: 5rem;
}

.margin-top-10 {
  margin-top: 10rem;
}

.margin-top-15 {
  margin-top: 15rem;
}

.margin-top-18 {
  margin-top: 18rem;
}

.margin-top-20 {
  margin-top: 20rem;
}

.margin-top-30 {
  margin-top: 30rem;
}

.margin-top-35 {
  margin-top: 35rem;
}

.margin-top-40 {
  margin-top: 40rem;
}

.margin-bottom-0 {
  margin-bottom: 0;
}

.margin-bottom-2 {
  margin-bottom: 2rem;
}

.margin-bottom-5 {
  margin-bottom: 5rem;
}

.margin-bottom-10 {
  margin-bottom: 10rem;
}

.margin-bottom-15 {
  margin-bottom: 15rem;
}

.margin-bottom-18 {
  margin-bottom: 18rem;
}

.margin-bottom-20 {
  margin-bottom: 20rem;
}

.margin-bottom-24 {
  margin-bottom: 24rem;
}

.margin-bottom-25 {
  margin-bottom: 25rem;
}

.margin-bottom-30 {
  margin-bottom: 30rem;
}

.margin-bottom-35 {
  margin-bottom: 35rem;
}

.margin-bottom-40 {
  margin-bottom: 40rem;
}

.margin-bottom-50 {
  margin-bottom: 50rem;
}

.margin-bottom-60 {
  margin-bottom: 60rem;
}

.margin-left-2 {
  margin-left: 2rem;
}

.margin-left-5 {
  margin-left: 5rem;
}

.margin-left-10 {
  margin-left: 10rem;
}

.margin-left-15 {
  margin-left: 15rem;
}

.margin-left-20 {
  margin-left: 20rem;
}

.margin-left-30 {
  margin-left: 30rem;
}

.margin-right-2 {
  margin-right: 2rem;
}

.margin-right-5 {
  margin-right: 5rem;
}

.margin-right-10 {
  margin-right: 10rem;
}

.margin-right-15 {
  margin-right: 10rem;
}

.margin-right-20 {
  margin-right: 20rem;
}

.margin-right-30 {
  margin-right: 30rem;
}

/********************************* padding间距 ***********************/
.padding-0 {
  padding: 0;
}

.padding-2 {
  padding: 2rem;
}

.padding-5 {
  padding: 5rem;
}

.padding-10 {
  padding: 10rem;
}

.padding-15 {
  padding: 15rem;
}

.padding-18 {
  padding: 18rem;
}

.padding-20 {
  padding: 20rem;
}

.padding-30 {
  padding: 30rem;
}

.paddingX-2 {
  padding-left: 2rem;
  padding-right: 2rem;
}

.paddingX-5 {
  padding-left: 5rem;
  padding-right: 5rem;
}

.paddingX-10 {
  padding-left: 10rem;
  padding-right: 10rem;
}

.paddingX-15 {
  padding-left: 15rem;
  padding-right: 15rem;
}

.paddingX-20 {
  padding-left: 20rem;
  padding-right: 20rem;
}

.paddingY-2 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.paddingY-5 {
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.paddingY-10 {
  padding-top: 10rem;
  padding-bottom: 10rem;
}

.paddingY-15 {
  padding-top: 15rem;
  padding-bottom: 15rem;
}

.paddingY-20 {
  padding-top: 20rem;
  padding-bottom: 20rem;
}

.paddingY-25 {
  padding-top: 25rem;
  padding-bottom: 25rem;
}

.paddingY-30 {
  padding-top: 30rem;
  padding-bottom: 30rem;
}

.padding-left-0 {
  padding-left: 0;
}

.padding-left-7_5 {
  padding-left: 7.5px;
}

.padding-right-0 {
  padding-right: 0;
}

.padding-right-7_5 {
  padding-right: 7.5px;
}

/********************************* 省略号 ***********************/
/* 单行省略号 */
.text-ellipsis {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 两行省略号 */
.text-ellipsis-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 3行省略号 */
.text-ellipsis-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 4行省略号 */
.text-ellipsis-4 {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* 省略号自定义字符 */
.ellipsis-more-text {
  display: none;
  position: absolute;
  right: 0;
  bottom: 4rem;
  background-color: inherit;
}

/********************************* 按钮 ***********************/
.btn-color-primary,
.btn-color-primary-light,
.btn-color-gray,
.btn-color-white {
  border-radius: var(--border-radius-big);
  border: none;
  outline: none;
  padding: 10rem;
  text-align: center;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
}

.btn-color-primary {
  background-color: var(--color-primary);
  color: white;
}

.btn-color-primary:hover {
  /* background: #0f2358; */
  color: white;
  opacity: 0.8;
}

.btn-color-primary-light {
  background-color: #e9fff4;
  border: 1rem solid var(--color-primary);
  color: var(--color-primary);
}

.btn-color-primary-light:hover {
  opacity: 0.8;
}

.btn-color-gray {
  background-color: #ededed;
  color: var(--color-text-primary);
}

.btn-color-gray:not(.btn-color-gray[disabled]):hover {
  opacity: 0.8;
  color: var(--color-text-primary);
}

.btn-color-gray[disabled] {
  color: var(--color-text-secondary);
}

.btn-color-white {
  background-color: white;
  color: var(--color-text-primary);
  border: 1px solid var(--border-color-base);
}

.btn-color-white:hover {
  background-color: var(--background-primary);
  color: var(--color-text-primary);
}

.btn-size-mini {
  padding: 5rem 10rem;
  font-size: var(--font-size-min);
}

/********************************* 圆角 ***********************/
.radius-round {
  border-radius: 50%;
}

/* --border-radius-min: 4rem; */
.radius-min {
  border-radius: var(--border-radius-min);
}

/* --border-radius-small: 6rem; */
.radius-small {
  border-radius: var(--border-radius-small);
}

/* --border-radius-base: 8rem; */
.radius-base {
  border-radius: var(--border-radius-base);
}

/* --border-radius-big: 10rem; */
.radius-big {
  border-radius: var(--border-radius-big);
}

/* --border-radius-huge: 20rem; */
.radius-huge {
  border-radius: var(--border-radius-huge);
}

/********************************* 滑动容器 ***********************/
/* 横向滑动 */
.overflow-x-auto {
  display: block;
  width: 100%;
  overflow-x: auto;
}

/* 竖向滑动 */
.overflow-y-auto {
  display: block;
  width: 100%;
  overflow-y: auto;
}

.overflow-hidden {
  overflow: hidden;
}

/*************************************** 表单样式 ***********************/
/* 常用input */
.label-regular {
  margin-right: var(--space-base);
  color: var(--color-text-primary);
  font-size: var(--font-size-normal);
  font-weight: normal;
  line-height: 60rem;
}

.input-regular::placeholder,
.textarea-regular::placeholder {
  color: var(--color-text-placeholder);
  font-size: var(--font-size-normal);
}

/* 常用input、textarea */
.input-regular,
.textarea-regular {
  border: 1px solid var(--border-color-base);
  border-radius: var(--border-radius-base);
  font-size: var(--font-size-normal);
  outline: none;
  padding: 15rem 26rem;
  width: 280rem;
  color: var(--color-text-primary);
}

.input-regular {
  height: 60rem;
}

.textarea-regular {
  height: 150rem;
}

.input-radio {
  appearance: none;
  border-radius: 50%;
  width: 16rem;
  height: 16rem;
  border: 1px solid var(--border-color-base);
  background-color: var(--background-regular);
}

.input-radio:checked {
  background-color: var(--background-orange);
}

/*******************************************************************/
/* ul样式(无点) */
.ul-drop-none {
  margin: 0;
  padding: 0;
}

.ul-drop-none li {
  list-style: none;
}

/* ul样式(有点) */
.ul-drop {
  margin: 0;
  padding: 0 0 0 20rem;
}

.ul-drop li {
  list-style: disc;
}

.ul-drop li::marker {
  font-size: 20rem;
  /* 调整标记的字体大小 */
}

/* 行高 */
.line-height-1 {
  line-height: 1;
}

.line-height-1_5 {
  line-height: 1.5;
}

.line-height-2 {
  line-height: 2;
}

.line-height-2_5 {
  line-height: 2.5;
}

.line-height-3 {
  line-height: 3;
}

/* 鼠标显示手指 */
.cursor-pointer {
  cursor: pointer;
}

/* 鼠标悬浮背景 */
.hover-bg-primary:hover {
  background-color: var(--background-primary);
}

/* checkbox选择样式 */
.checkbox-custom[type='checkbox'],
.checkbox-custom[type='checkbox']:checked::before {
  cursor: pointer;
  position: relative;
  width: 15rem;
  height: 15rem;
  border: 1px solid #ff571d;
  border-radius: 3rem;
  overflow: visible;
  outline: none;
  background: #ff571d;
  margin-right: 8rem;
}

.checkbox-custom[type='checkbox']:checked::before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
}

.checkbox-custom[type='checkbox']:checked::after {
  content: '';
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  width: 13rem;
  height: 12rem;
  background-image: url(../images/checked.png);
  background-size: 13px 12rem;
}

.height100 {
  min-height: calc(100vh - 187px);
}

/********************************* 网格布局 ***********************/
/* 1列 */
.grid-col-1 {
  display: grid;
  grid-template-columns: repeat(1, 100%);
  gap: 10rem;
}

/* 2列 */
.grid-col-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10rem;
}

/* 3列 */
.grid-col-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10rem;
}

/* 4列 */
.grid-col-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10rem;
}

/* 5列 */
.grid-col-5 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10rem;
}

/* 6列 */
.grid-col-6 {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10rem;
}

/* 7列 */
.grid-col-7 {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 10rem;
}

/* 图片object-fit */
.object-fit-contain {
  object-fit: contain;
}

.object-fit-cover {
  object-fit: cover;
}
