:root {
  --theme-color: #252525;
  --theme-color-gray: #F6F6F6;
  --theme-color-purple: #2e0059;
  --theme-color-purple-weak: #8554fd;
  --theme-color-purple-thin: #f3eeff;
  --theme-color-green: #25e577;
  --theme-color-light-blue: #02a1e4;
  --theme-bg-color: #d0d5f3;
  --theme-bg-color-thin: rgba(208, 213, 243, 0.5);
  --theme-linear-gradient: linear-gradient(151.11deg, rgba(134, 85, 255, 1), rgba(37, 229, 119, 1) 100%);
  --px: 1 / 1920 * 100vw;
  --custom-size: var(--px);
  --header-h: 90px;
  --px-20-40: max(20px, 40 * var(--px));
  --px-10-20: max(10px, 20 * var(--px));
  --main-margin: max(40px, 120 * var(--px));
  --main-thin-margin: 40px;
  --section-padding-top: max(30px, 100 * var(--px));
  --section-padding-bottom: max(30px, 120 * var(--px));
  --font-16: max(12px, 16 * var(--px));
  --font-18: max(16px, 18 * var(--px));
  --font-20: max(18px, 20 * var(--px));
  --font-22: max(19px, 22 * var(--px));
  --font-24: max(20px, 24 * var(--px));
  --font-26: max(22px, 26 * var(--px));
  --font-28: max(24px, 28 * var(--px));
  --font-30: max(26px, 30 * var(--px));
}

@font-face {
  font-family: 'SourceHanSans';
  src: url("../../fonts/SourceHanSansCN-Normal.otf");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'SourceHanSans';
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  src: url("../../fonts/SourceHanSansCN-Bold.otf");
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  /* Safari */
  -moz-box-sizing: border-box;
  /* Firefox */
}

html {
  color: var(--theme-color);
  font-family: 'SourceHanSans';
}

img {
  display: block;
  font-size: 0px;
  max-width: 100%;
  position: relative;
}

video {
  max-width: 100%;
}

section h1,
section h2,
section h3,
section h4,
section h5,
section h6 {
  font-size: 100%;
  font-weight: normal;
}

li {
  list-style: none;
}

.clearfix:after {
  content: "";
  visibility: hidden;
  height: 0;
  display: block;
  clear: both;
  zoom: 1;
}

a {
  text-decoration: none;
  color: var(--theme-color);
  font-weight: 400;
}

.header-expand a:hover {
  color: var(--theme-color-blue) !important;
}

p {
  line-height: 1.5;
}

p+p {
  margin-top: clamp(5px, 10 * var(--px), 10px);
}

/* body,
button,
input,
select,
textarea {
  font: 16px/1.5 tahoma, arial, \5b8b\4f53;
} */
input,
select,
textarea {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  color: #000;
  outline: none;
  font-size: 14px;
  font-weight: 400;
  resize: none;
  border: 0;
}

::-webkit-input-placeholder {
  font-size: 14px;
  color: #b2b2b2;
  font-weight: 400;
}

:-moz-placeholder {
  font-size: 14px;
  color: #b2b2b2;
  font-weight: 400;
}

::-moz-placeholder {
  font-size: 14px;
  color: #b2b2b2;
  font-weight: 400;
}

:-ms-input-placeholder {
  font-size: 14px;
  color: #b2b2b2;
  font-weight: 400;
}

.flex {
  display: flex;
}

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

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

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

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

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

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

.img-lay {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
}

.img-lay-contain {
  object-fit: contain;
  width: 100%;
  height: 100%;
  display: block;
}

.icon-lay {
  --lay-icon-w: 60px;
  width: var(--lay-icon-w);
  height: var(--lay-icon-w);
  border-radius: 50%;
  background-color: var(--theme-color);
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  transition: 0.3s;
}

.banner-lay {
  position: relative;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.content_id {
  display: none;
}

.main {
  margin: 0 var(--main-margin);
  height: 100%;
}

.main-l {
  margin-left: var(--main-margin);
}

.main-r {
  margin-right: var(--main-margin);
}

.main-thin {
  margin: 0 var(--main-thin-margin);
  position: relative;
}

.main-l-thin {
  margin-left: var(--main-thin-margin);
}

.main-r-thin {
  margin-right: var(--main-thin-margin);
}

svg path {
  transition: 0.3s;
}

.swiper {
  height: 100%;
}

.card-wrap {
  display: flex;
  /* justify-content: space-between; */
  flex-wrap: wrap;
  --column: 3;
  --gap: max(10px, 30 * var(--px));
  gap: var(--gap);
}

.card-wrap>.item {
  /* min-width: calc((100% - (var(--column) - 1) * var(--gap)) / var(--column)); */
  /* flex: 1; */
  width: calc((100% - (var(--column) - 1) * var(--gap)) / var(--column));
}

:not(html, body, .el-scrollbar__wrap)::-webkit-scrollbar-button {
  display: none;
}

:not(html, body, .el-scrollbar__wrap)::-webkit-scrollbar {
  width: 3px;
  height: 10px;
  border-radius: 5px;
  background-color: #ddd;
}

:not(html, body, .el-scrollbar__wrap) .vertical-scrollbar::-webkit-scrollbar {
  height: 10px;
}

:not(html, body, .el-scrollbar__wrap)::-webkit-scrollbar-thumb {
  background-color: red;
  border-radius: 5px;
}

body:not(.wfEditorMode) object {
  display: none;
}

.pic-txt-wrap {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  position: relative;
}

.pic-txt-wrap .txt {
  padding: var(--px-20-40);
}

.container {
  margin-top: max(30px, 130 * var(--px));
  position: relative;
}

.container-thin {
  margin-top: max(30px, 70 * var(--px));
  position: relative;
}

.sec-wrap {
  --padding: max(20px, calc(var(--header-h) + 130 * var(--px)));
  padding: var(--padding) 0;
}

.sec-wrap-thin {
  --padding: max(20px, calc(var(--header-h) + 30 * var(--px)));
  padding: var(--padding) 0;
}

section {
  position: relative;
  overflow: hidden;
}

svg .proto {
  visibility: hidden;
}

.full-page {
  height: 100vh;
}

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