@font-face {
	font-family: "remixicon";
	src: url('../font/remixicon.eot?t=1737565391901');
	/* IE9*/
	src: url('../font/remixicon.eot?t=1737565391901#iefix') format('embedded-opentype'),
		/* IE6-IE8 */
		url("../font/remixicon.woff2?t=1737565391901") format("woff2"),
		url("../font/remixicon.woff?t=1737565391901") format("woff"),
		url('../font/remixicon.ttf?t=1737565391901') format('truetype'),
		/* chrome, firefox, opera, Safari, Android, iOS 4.2+*/
		url('../font/remixicon.svg?t=1737565391901#remixicon') format('svg');
	/* iOS 4.1- */
	font-display: swap;
}

[class^="ri-"],
[class*="ri-"] {
	font-family: 'remixicon' !important;
	font-style: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.ri-lg {
	font-size: 1.3333em;
	line-height: 0.75em;
	vertical-align: -.0667em;
}

.ri-xl {
	font-size: 1.5em;
	line-height: 0.6666em;
	vertical-align: -.075em;
}

.ri-xxs {
	font-size: .5em;
}

.ri-xs {
	font-size: .75em;
}

.ri-sm {
	font-size: .875em
}

.ri-1x {
	font-size: 1em;
}

.ri-2x {
	font-size: 2em;
}

.ri-3x {
	font-size: 3em;
}

.ri-4x {
	font-size: 4em;
}

.ri-5x {
	font-size: 5em;
}

.ri-6x {
	font-size: 6em;
}

.ri-7x {
	font-size: 7em;
}

.ri-8x {
	font-size: 8em;
}

.ri-9x {
	font-size: 9em;
}

.ri-10x {
	font-size: 10em;
}

.ri-fw {
	text-align: center;
	width: 1.25em;
}

.ri-close-large-line:before {
	content: "\f4c8";
}

.ri-menu-line:before {
	content: "\ef3e";
}

body {
	font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	color: #1f2329;
	line-height: 1.5;
	background-color: #fff;
}

a,
a:focus,
a:hover {
	cursor: pointer;
	color: inherit;
	text-decoration: none;
	outline: none !important;
}

ol,
ul {
	list-style: none;
	margin: 0;
	padding: 0;
}


.btn:focus,
.btn:active:focus,
.btn.active:focus,
.btn.focus,
.btn:active.focus,
.btn.active.focus {
	outline: none;
	border-color: transparent;
	box-shadow: none;
}


li {
	list-style-type: none;
}

.app-wrapper {
	position: relative;
	height: 100%;
	width: 100%;
}

.app-main {
	min-height: 100vh;
}

.navbar {
	width: 100%;
	transition: background-color 0.3s ease;
}

.navbar.bg-white {
	background-color: white !important;
}

#navbar-icon {
	transition: transform 0.3s ease;
}

#navbar-toggler.collapsed #navbar-icon {
	transform: rotate(180deg);
}

.navbar-toggler:focus,
.navbar-toggler:active {
	outline: none;
	box-shadow: none;
	border: none;
}

.m-navbar-logo {
	width: 8.375rem;
	height: 1.5rem;
	background-size: 100%;
	background-repeat: no-repeat;
}

.m-navbar-logo-light {
	background-image: url(../img/logo-light.png);
}

.m-navbar-logo-dark {
	background-image: url(../img/logo.png);
}

.nav-link {
	font-size: .9375rem;
}

.video-background {
	margin-top: 60px;
	position: relative;
	width: 100%;
	height: 50vh;
	background: url('../img/index-video-01.png') no-repeat center center;
	background-size: cover;
	overflow: hidden;
}

.video-background::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 18, 252, .2);
	z-index: 1;
}

.video-background video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
	display: none;
}

.video-loaded .video-background video {
	display: block;
}

.overlay-text {
	width: 100%;
	padding: 0 2rem;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 2;
	color: white;
	text-align: center;
}

.overlay-text h1 {
	font-size: 2.4rem;
	line-height: 1.4;
}

.m-banner {
	margin-top: 60px;
	min-width: 0;
	height: 50vh;
	display: block;
}

.m-banner-wrapper {
	height: 50vh;
	display: block;
	position: absolute;
	z-index: -1;
	width: 100%;
	top: 0;
	left: 0;
	overflow: hidden;
	background: url(../img/banner.png) no-repeat 50% / cover;
}

.m-banner-text {
	padding-top: 19vh;
	text-align: center;
	display: block;
}

.plan-wrapper {
	min-width: 0;
	height: 31.25rem;
	background: url(../img/plan.png) no-repeat 100% / cover;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.digital-wrapper {
	height: 12.375rem;
	background: url(../img/index-bg-01.png) no-repeat 100% / cover;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.about-wrapper {
	height: 100%;
	background: url(../img/about-bg.png) no-repeat 100% / cover;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.banner-wrapper {
	display: block;
	width: 100%;
	height: 7.8125rem;
	position: relative;
}

.banner-bg-01 {
	background: url(../img/product-banner.png) no-repeat 50% / cover;
}

.banner-bg-02 {
	background: url(../img/cooperate-banner.png) no-repeat 50% / cover;
}

.banner-bg-03 {
	background: url(../img/about-banner.png) no-repeat 50% / cover;
}

.banner-bg-04 {
	background: url(../img/news-banner.png) no-repeat 50% / cover;
}

.card-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border: 2px solid #FFF;
	background: linear-gradient(90deg, #EFF5FF 0%, #F7F9FE 100%);
}

.card-header img {
	width: 3.25rem;
}

.nav-tabs .nav-link.active {
	border-bottom: 3px solid #006CFC;
	;
	font-weight: bold;
	color: #006CFC !important;
}

.nav-tabs .nav-link {
	color: #333;
}

.detail img {
	display: block;
	margin: 0 auto;
	width: 100%;
	border-radius: .625em;
}

.card-title {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	word-break: break-word;
}

.app-download {
	background: linear-gradient(180deg, #C2E6FF 0%, #FFF 100%);
}