body,ol,ul,h1,h2,h3,h4,h5,h6,p,th,td,dl,dd,form,fieldset,legend,input,textarea,select{margin:0;padding:0} 

html, body {
	font-family: 'Avenir', Helvetica, Arial, sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	background-color: #f6f6f6;
}

img {
	max-width: 100%;
}


.header{
	height: 80px;
	width: 100%;
	position: absolute;
	top: 0;
}

.nav-item a{
	font-size: 19px;
	font-weight: 600;
	padding: 0 16px;
	color: #fff;
	text-decoration: none;
}

.nav-item a:hover{
	color: #f3402f;
}

.banner{
	height: 700px;
	width: 100%;
	background: url("../imgs/banner_01.jpg") 0 0 no-repeat;
	background-position: center;
	background-size: cover;
	display: flex;
	justify-content: center;
	align-items: center;

	margin-bottom: -64px;
}


.banner-text-container {
	width: 1366px;
	max-width: 100%;
}

.banner-text-container .banner-title{
	width: 30%;
	font-size: 56px;
	font-weight: bold;
	background-image: linear-gradient(270deg, #f3402f, #fd793c);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	margin-bottom: -16px;
}

.banner-text-container .sub-title{
	width: 50%;
	font-size: 21px;
	background-image: linear-gradient(270deg, #f3402f, #fd793c);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	margin-bottom: 24px;
}

.banner-text-container .small-text{
	width: 50%;
	font-size: 18px;
	color: #9a9a9aff;
}


.header-inner {
	width: 1366px;
	max-width: 100%;
	margin: 0 auto;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.data-number {
	width: 1366px;
	max-width: 100%;
	margin: 0 auto;
	text-align: center;
	margin-bottom: 64px;
}

.data-number .top{
	width: 100%;
	height: 160px;
	background-image: url("../imgs/number_background_top.png");
	background-size: contain;
	background-repeat: no-repeat;
}

span.number {
	font-size: 72px;
	font-weight: bold;
	color: #fff;
}
span.number-description{
	color: #fff;
	font-size: 21px;
}

.column-text {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.data-number .top{
	width: 100%;
	margin-bottom: 6px;
}

.number-part {
	position: relative;
	height: 160px;
}

.number-part img {
	width: 100%;
	height: 100%;
}

.number-text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: absolute;
	top: 50%;
  	left: 50%;
  	transform: translate(-50%, -50%);
}

.data-number .bottom{
	width: 100%;
	display: flex;
	justify-content: space-between;
}

.bottom .number-part {
	height: 100%;
	width: 33%;
}

.number-part {
	text-align: center;
}

.title {
	width: 100%;
	max-width: 1366px;
	margin: 0 auto;
	text-align: center;
	margin-bottom: 48px;
}

.left-right-content {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}

.text-content {
	width: 30%;
	font-size: 24px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.text-content p {
	color: #515151;
}

.part-3-mobile {
	display: none !important;
}

.part-3 {
	background: url("../imgs/part3_bg.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	min-height: 540px;
	padding: 32px 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.part-3 .title{
	margin-bottom: 64px;
}

.part-3-content {
	width: 100%;
	max-width: 1366px;
	margin: 0 auto;
}

.vertical-item {
	width: 188px;
	height: 120px;
	background-color: #fff;
	border-radius: 4px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin: 4px 8px;
}

.fade-img{
	display: flex;
	align-items: center;
}

.vertical-item:hover {
	cursor: pointer;
	background-color: #f3ceb8;
}

.vertical-item img {
	max-width: 80px;
	margin-bottom: 2px;
}

.vertical-item span{
	font-size: 21px;
	font-weight: bold;
}

.item-row{
	display: flex;
	justify-content: center;
	margin-bottom: 8px;
}

.item-row div:first-child{
	margin-right: 8px;
}

.item-row div:last-child {
	margin-left: 8px;
}

.part-4 {
	padding: 80px 0;
}

.part-4 img {
	max-width: 100%;
}

.step-container {
	margin: 0 auto;
	display: flex;
	justify-content: center;
}

.step {
	display: flex;
	flex-direction: column;
	margin-bottom: 48px;
}

.step img {
	max-width: max-content;
}

.step-title {
	color: #f54d3c;
	margin-bottom: 8px;
}

.step-title::before {
	content:'!';
	margin-right: 4px;
	background-color: #f54d3c;
	border-radius: 2px;
}


.part-5 {
	background-image: url(../imgs/keyword_background.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	padding: 64px 0;
	text-align: center;
	vertical-align: middle;
}

.part-6 {
	padding: 64px 0;
	text-align: center;
	background-image: url(../imgs/contact_bg.png);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

.part-6 h1{
	background-image: linear-gradient(270deg, #f3402f, #fd793c);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	font-size: 48px;
	margin-bottom: 24px;
}


.btn-contact {
	width: 200px;
	height: 56px;
	cursor: pointer;
	background-color: #f54d3c;
	border-radius: 4px;
	margin: 0 auto;
	text-align: center;
	line-height: 56px;
	margin-bottom: 16px;
}

.btn-contact a {
	text-align: center;
	padding: 0;
	color: #fff;
	font-size: 24px;
}

.btn-contact:hover{
	background-color: #dd2d1c;
}

.small-icon {
	height: 28px;
	padding-right: 8px;
}


.part-6 p {
	font-size: 24px;
	color: #f54d3c;
	margin-bottom: 6px;
}

.footer-bar {
	width: 100%;
	background-color: #080720;
	padding: 16px;
	box-sizing: border-box;
}

.top-part {
	max-width: 1366px;
	margin: 0 auto;
	color: #9a9a9a;
	font-size: 21px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.line-header {
	display: inline-block;
	width: 56px;
}

a {
	color: #9a9a9a;
	text-decoration: none;
	padding-right: 64px;
}

a:hover {
	text-decoration: underline;
}

.bottom-part {
	width: 1366px;
	max-width: 100%;
	margin: 0 auto;
	text-align: center;
	color: #9a9a9a;
	font-size: 14px;
	opacity: 0.5;
}

.sp-line {
	margin: 8px auto;
	height: 1px;
	max-width: 1366px;
	background-color: #9a9a9a;
	opacity: 0.5;
}

.show-mobile {
	display: none;
}

.top-part a:hover {
	color: #f54d3c;
}



@media screen and (max-width: 468px){
	.header {
		position: absolute;
		top: 0;
	}
	.banner {
		height: 600px;
		background-image: url(../imgs/banner_01_sm.jpg);
	}
	.banner-text-container {
		padding: 0 24px;
	}
	.banner-text-container .banner-title {
		width: 100%;
		font-size: 48px;
	}
	.banner-text-container .sub-title {
		width: 100%;
		font-size: 18px;
	}
	.banner-text-container .small-text {
		width: 100%;
		font-size: 14px;
	}

	.nav-item {
		display: none;
	}

	.banner {
		padding-top: 30px;
		box-sizing: border-box;
	}

	.title {
		padding: 0 16px;
	}

	span.number {
		font-size: 32px;
	}

	span.number-description{
		font-size: 10px;
		text-wrap: nowrap;
	}	

	.data-number {
		padding: 0 16px;
		margin-bottom: 64px;
	}

	.data-number .top {
		margin-bottom: 2px;
	}

	.number-part {
		height: 88px !important; 
	}

	.text-content {
		width: 100%;
	}

	.left-right-content {
		padding: 0 24px;
	}
	.text-content p {
		font-size: 16px;
	}

	.reverse-on-mobile {
		flex-direction: column-reverse;
	}

	.part-3 {
		display: none;
	}

	.vertical-item {
		height: 88px;
	}

	.part-3-mobile {
		display: block !important;
	}



	.vertical-item span {
		font-size: 14px;
	}

	.vertical-item img {
		width: 48px;
		max-width: 100%;
	}

	.fade-item {
		display: flex;
		align-items: center;
	}

	.fade-item img{
		height: 88px;
	}


	.part-6 h1 {
		font-size: 32px;
		padding: 0 8px;
	}

	.part-4 {
		padding: 48px 0;
	}

	.number-img{
		width: 100px;
	}

	.step-title {
		font-size: 18px;
	}

	.step p {
		font-size: 12px;
	}

	.part-5 {
		padding: 48px 16px;
		background-position: center;
	}

	.part-6 p {
		font-size: 16px;
	}

	.top-part {
		font-size: 14px;
	}

	.hide-mobile {
		display: none;
	}

	.top-part {
		justify-content: center;
	}

	.top-part a {
		padding-right: 16px;
	}



	.line-header {
		width: 41px;
	}
	.show-mobile {
		display: block;
		margin-bottom: 24px;
	}

}

