@charset "utf-8";

.header .gNavi {
	background: none;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
}
.header .gNaviBg {
	background: #1F5CCD;
}
.header .gNavi .naviUl {
	border-color: #fff;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
}
.header .gNaviBg .naviUl {
	border-color: #1F5CCD;
}
.header .gNavi > ul > .li02 > a:before {
	visibility: visible;
	opacity: 1;
}
#container {
	padding: 100px 0 0;
}
.main .aboutBox {
	background: url("../images/company/about_bg.png") no-repeat center top;
	background-size: cover;
}
.main .aboutBox .comSection {
	display: flex;
	justify-content: flex-end;
}
.main .aboutBox .textBox {
	padding: 10px 0 0 40px;
	width: 50%;
	height: 720px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	box-sizing: border-box;
}
.main .aboutBox .comTitle {
	padding-bottom: 28px;
	text-align: left;
}
.main .aboutBox .comTitle .line {
	margin: 0 0 0 -6px;
	left: 0;
}
.main .aboutBox .textBox .text {
	margin-bottom: 40px;
	min-height: 184px;
	box-sizing: border-box;
}
.main .aboutBox .textBox ul {
	display: flex;
	justify-content: space-between;
	box-sizing: border-box;
}
.main .aboutBox .textBox li {
	width: 30%;
	box-sizing: border-box;
}
.main .aboutBox .textBox li img {
	margin-bottom: 15px;
	width: 60px;
	display: block;
}
.main .aboutBox .textBox li .num {
	margin-bottom: 5px;
	display: block;
	font-size: 24px;
	font-weight: bold;
}
.main .serviceBox {
	padding: 120px 0;
}
.main .serviceBox .comTitle {
	padding-bottom: 7px;
}
.main .serviceBox .text {
	margin-bottom: 43px;
	color: #B4BEC8;
	font-size: 20px;
	text-align: center;
}
.main .serviceBox ul {
	margin: 0 -15px;
	display: flex;
}
.main .serviceBox li {
	width: 33.33%;
	padding: 0 15px;
	box-sizing: border-box;
}
.main .serviceBox li a {
	display: block;
	position: relative;
}
.main .serviceBox li a .photo {
	width: 100%;
	height: 460px;
	object-fit: cover;
}
.main .serviceBox li a .name {
	position: absolute;
	left: 40px;
	bottom: 31px;
	color: #fff;
	font-size: 32px;
	font-weight: bold;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
}
.main .serviceBox li a:hover .name {
	opacity: 0;
	visibility: hidden;
}
.main .serviceBox li a .textBox {
	padding: 33px 40px 35px;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
	background: rgba(0,90,255,0.8);
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
	visibility: hidden;
	opacity: 0;
}
.main .serviceBox li a:hover .textBox {
	opacity: 1;
	visibility: visible;
}
.main .serviceBox li a .textBox .txt01 {
	margin-bottom: 30px;
	font-size: 32px;
	font-weight: bold;
}
.main .serviceBox li a .textBox .txt02 {
	margin-bottom: 20px;
	min-height: 1px;
	flex: 1;
}
.main .serviceBox li a .textBox .link {
	display: flex;
	align-items: center;
	color: #fff;
}
.main .serviceBox li a .textBox .link img {
	margin-left: 8px;
	width: 16px;
}
.main .historyBox {
	padding-top: 120px;
	height: 640px;
	box-sizing: border-box;
	background: url("../images/company/history_bg.png") no-repeat center bottom;
	background-size: cover;
}
.main .historyBox .comTitle {
	padding: 34px 0 65px;
	font-size: 40px;
}
.main .historyBox .mySwiper {
	padding: 0 40px;
	background: url("../images/company/line.png") no-repeat center bottom 45px;
	background-size: 100% 4px;
}
.main .historyBox .swiper-slide {
	text-align: center;
}
.main .historyBox .swiper-slide .txt {
	margin-bottom: 40px;
	min-height: 180px;
	position: relative;
	font-size: 20px;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
	opacity: 0;
	visibility: hidden;
}
.main .historyBox .swiper-slide-active .txt {
	opacity: 1;
	visibility: visible;
}
.main .historyBox .swiper-slide .txt:before {
	margin-left: -2px;
	width: 4px;
	height: 80px;
	position: absolute;
	left: 50%;
	top: 65px;
	background: linear-gradient(#005AFF 0%, rgba(0,90,255,0) 100%);
	content: "";
}
.main .historyBox .swiper-slide .txt span {
	position: relative;
	z-index: 1;
}
.main .historyBox .swiper-slide .time {
	position: relative;
}
.main .historyBox .swiper-slide .time:before {
	margin-left: -8px;
	width: 16px;
	height: 16px;
	position: absolute;
	left: 50%;
	top: -31px;
	border-radius: 50%;
	background: #005AFF;
	content: "";
}
.main .historyBox .swiper-slide .time:after {
	margin-left: -12px;
	width: 24px;
	height: 24px;
	position: absolute;
	left: 50%;
	top: -35px;
	border-radius: 50%;
	border: 4px solid rgba(255,255,255,1);
	content: "";
	box-sizing: border-box;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
	opacity: 0;
	visibility: hidden;
}
.main .historyBox .swiper-slide-active .time:after {
	opacity: 1;
	visibility: visible;
}
.main .conceptBox {
	padding: 120px 0 90px;
}
.main .conceptBox ul {
	margin: 0 -15px;
	display: flex;
	flex-wrap: wrap;
}
.main .conceptBox li {
	padding: 0 15px 30px;
	width: 33.33%;
	box-sizing: border-box;
}
.main .conceptBox li .textBox {
	padding: 31px 38px 38px;
	height: 100%;
	font-size: 20px;
	box-sizing: border-box;
	background: linear-gradient(to bottom right, #F5F6F7 50%, #fff 50%);
	border: 2px solid #C8D2DC;
}
.main .conceptBox li:nth-child(1),
.main .conceptBox li:nth-child(2) {
	width: 50%;
}
.main .conceptBox li .txt01 {
	margin-bottom: 7px;
	display: block;
	font-size: 32px;
	font-weight: bold;
}
.main .contactBox {
	padding: 120px 0;
	background: url("../images/company/contact_bg.png") no-repeat center center;
	background-size: cover;
}
.main .contactBox .inner {
	display: flex;
}
.main .contactBox .inner .textBox {
	padding-right: 40px;
	width: 50%;
	box-sizing: border-box;
}
.main .contactBox .inner .map {
	width: 50%;
}
.main .contactBox .inner .map iframe {
	width: 100%;
	height: 440px;
	display: block;
}
.main .contactBox .comTitle {
	padding-bottom: 24px;
	color: #fff;
	text-align: left;
}
.main .contactBox .comTitle .line {
	margin: 0 0 0 -6px;
	left: 0;
}
.main .contactBox .comTitle .line:before {
	background: #fff;
}
.main .contactBox .listUl {
	margin-bottom: 52px;
}
.main .contactBox .listUl li {
	padding-bottom: 24px;
	display: flex;
	align-items: flex-start;
	color: #fff;
}
.main .contactBox .listUl li img {
	margin: 4px 16px 0 0;
	width: 16px;
}
.main .contactBox .listUl li a {
	color: #fff;
}
.main .contactBox .listUl li a:hover {
	text-decoration: underline;
}
.main .contactBox .linkUl {
	margin-right: -40px;
	display: flex;
}
.main .contactBox .linkUl li {
	margin-right: 40px;
	width: 200px;
}
.main .contactBox .linkUl li a {
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 68px;
	border: 2px solid #fff;
	border-radius: 36px;
}
.main .contactBox .linkUl li a img {
	margin-left: 12px;
	width: 16px;
}
.main .contactBox .linkUl li a:hover {
	background: #005AFF;
}

@media all and (min-width: 1240px) {
	.main .contactBox .linkUl.pc {
		display: flex !important;
	}
}

@media all and (min-width: 750px) and (max-width: 1239px) {
	#container {
		padding-top: 80px;
	}
	.main .aboutBox {
		background-image: url("../images/company/sp_about_bg.png");
		background-position: center bottom;
	}
	.main .aboutBox .comSection {
		display: block;
	}
	.main .aboutBox .textBox {
		padding: 96px 0 68px;
		width: auto;
		height: auto;
	}
	.main .aboutBox .comTitle {
		padding-bottom: 6px;
		color: #fff;
	}
	.main .aboutBox .comTitle .line {
		margin-left: -4px;
	}
	.main .aboutBox .comTitle .line:before {
		background: #fff;
	}
	.main .aboutBox .text01 {
		margin-bottom: 36px;
		color: #fff;
		font-size: 20px;
	}
	.main .aboutBox .text {
		color: #fff;
		font-size: 28px;
	}
	.main .aboutBox .textBox li img {
		margin-bottom: 12px;
		width: 60px;
	}
	.main .aboutBox .textBox li .num {
		margin-bottom: 0;
		color: #fff;
		font-size: 32px;
	}
	.main .aboutBox .textBox li .txt {
		color: #fff;
		font-size:24px;
	}
	.main .serviceBox {
		padding: 80px 0 70px;
		background: #F5F6F7;
	}
	.main .serviceBox .comTitle {
		padding-bottom:6px;
	}
	.main .serviceBox .text {
		margin-bottom: 36px;
		font-size: 20px;
	}
	.main .serviceBox ul {
		margin: 0 -14px;
	}
	.main .serviceBox li {
		padding: 0 14px;
	}
	.main .serviceBox li a .photo {
		height: 210px;
	}
	.main .serviceBox li a .name {
		margin-top: 16px;
		position: static;
		display: block;
		visibility: visible !important;
		opacity: 1 !important;
		color: #141E28 !important;
		font-size: 28px;
		font-weight: normal;
		line-height: 48px;
		background: url("../images/common/arrow02_blue.png") no-repeat right center;
		background-size: 28px auto;
	}
	.main .serviceBox li a .textBox {
		display: none;
	}
	.main .historyBox {
		padding: 80px 0 74px;
		height: auto;
	}
	.main .historyBox .comTitle {
		padding: 32px 0 64px;
		font-size: 40px;
	}
	.main .historyBox .mySwiper {
		padding: 0;
		background-size: 100% 4px;
		background-position: center bottom 54px;
	}
	.main .historyBox .swiper-slide .txt {
		margin-bottom: 40px;
		min-height: 156px;
		font-size: 28px;
	}
	.main .historyBox .swiper-slide .txt:before {
		width: 4px;
		height: 80px;
		top: 60px;
	}
	.main .historyBox .swiper-slide .time {
		font-size: 24px;
	}
	.main .historyBox .swiper-slide .time:before {
		margin-left: -8px;
		width: 16px;
		height: 16px;
		top: -28px;
	}
	.main .historyBox .swiper-slide .time:after {
		margin-left: -12px;
		width: 24px;
		height: 24px;
		border-width: 4px;
		top: -32px;
	}
	.main .conceptBox {
		padding: 80px 0 60px;
		background: #F5F6F7;
	}
	.main .conceptBox ul {
		margin: 0 -10px;
	}
	.main .conceptBox li {
		padding: 0 10px 20px;
	}
	.main .conceptBox li .textBox {
		padding: 24px 18px 40px;
		color: #646E78;
		font-size: 24px;
		border: 1px solid #fff;
	}
	.main .conceptBox li .txt01 {
		color: #141E28;
		font-size: 28px;
	}
	.main .contactBox {
		padding: 80px 0;
	}
	.main .contactBox .comTitle .line {
		margin-left: -4px;
	}
	.main .contactBox .inner {
		display: block;
	}
	.main .contactBox .inner .textBox {
		padding: 0;
		width: auto;
	}
	.main .contactBox .listUl {
		margin-bottom: 0;
	}
	.main .contactBox .listUl li {
		padding-bottom: 38px;
		font-size: 28px;
	}
	.main .contactBox .listUl li img {
		margin-right: 20px;
		width: 28px;
	}
	.main .contactBox .inner .map {
		width: auto;
	}
	.main .contactBox .inner .map iframe {
		height: 420px;
	}
	.main .contactBox .linkUl.sp {
		margin: 40px -10px 0;
		display: flex !important;
	}
	.main .contactBox .linkUl li {
		margin: 0;
		padding: 0 10px;
		width: 50%;
		box-sizing: border-box;
	}
	.main .contactBox .linkUl li a {
		border-width: 2px;
		font-size: 28px;
		line-height: 78px;
	}
	.main .contactBox .linkUl li a img {
		margin-left: 20px;
		width: 28px;
	}
	
}


@media all and (min-width: 0) and (max-width: 749px) {
	#container {
		padding-top: 40px;
	}
	.main .aboutBox {
		background-image: url("../images/company/sp_about_bg.png");
		background-position: center bottom;
	}
	.main .aboutBox .comSection {
		display: block;
	}
	.main .aboutBox .textBox {
		padding: 48px 0 34px;
		width: auto;
		height: auto;
	}
	.main .aboutBox .comTitle {
		padding-bottom: 3px;
		color: #fff;
	}
	.main .aboutBox .comTitle .line {
		margin-left: -2px;
	}
	.main .aboutBox .comTitle .line:before {
		background: #fff;
	}
	.main .aboutBox .text01 {
		margin-bottom: 18px;
		color: #fff;
		font-size: 10px;
	}
	.main .aboutBox .text {
		color: #fff;
		font-size: 14px;
	}
	.main .aboutBox .textBox li img {
		margin-bottom: 6px;
		width: 30px;
	}
	.main .aboutBox .textBox li .num {
		margin-bottom: 0;
		color: #fff;
		font-size: 16px;
	}
	.main .aboutBox .textBox li .txt {
		color: #fff;
		font-size: 12px;
	}
	.main .serviceBox {
		padding: 40px 0 35px;
		background: #F5F6F7;
	}
	.main .serviceBox .comTitle {
		padding-bottom: 3px;
	}
	.main .serviceBox .text {
		margin-bottom: 18px;
		font-size: 10px;
	}
	.main .serviceBox ul {
		margin: 0 -7px;
	}
	.main .serviceBox li {
		padding: 0 7px;
	}
	.main .serviceBox li a .photo {
		height: 105px;
	}
	.main .serviceBox li a .name {
		margin-top: 8px;
		position: static;
		display: block;
		visibility: visible !important;
		opacity: 1 !important;
		color: #141E28 !important;
		font-size: 14px;
		font-weight: normal;
		line-height: 24px;
		background: url("../images/common/arrow02_blue.png") no-repeat right center;
		background-size: 14px auto;
	}
	.main .serviceBox li a .textBox {
		display: none;
	}
	.main .historyBox {
		padding: 40px 0 37px;
		height: auto;
	}
	.main .historyBox .comTitle {
		padding: 16px 0 32px;
		font-size: 20px;
	}
	.main .historyBox .mySwiper {
		padding: 0;
		background-size: 100% 2px;
		background-position: center bottom 27px;
	}
	.main .historyBox .swiper-slide .txt {
		margin-bottom: 20px;
		min-height: 78px;
		font-size: 14px;
	}
	.main .historyBox .swiper-slide .txt:before {
		width: 2px;
		height: 40px;
		top: 30px;
	}
	.main .historyBox .swiper-slide .time {
		font-size: 12px;
	}
	.main .historyBox .swiper-slide .time:before {
		margin-left: -4px;
		width: 8px;
		height: 8px;
		top: -14px;
	}
	.main .historyBox .swiper-slide .time:after {
		margin-left: -6px;
		width: 12px;
		height: 12px;
		border-width: 2px;
		top: -16px;
	}
	.main .conceptBox {
		padding: 40px 0 30px;
		background: #F5F6F7;
	}
	.main .conceptBox ul {
		margin: 0 -5px;
	}
	.main .conceptBox li {
		padding: 0 5px 10px;
	}
	.main .conceptBox li .textBox {
		padding: 12px 9px 20px;
		color: #646E78;
		font-size: 12px;
		border: 1px solid #fff;
	}
	.main .conceptBox li .txt01 {
		color: #141E28;
		font-size: 14px;
	}
	.main .contactBox {
		padding: 40px 0;
	}
	.main .contactBox .comTitle .line {
		margin-left: -2px;
	}
	.main .contactBox .inner {
		display: block;
	}
	.main .contactBox .inner .textBox {
		padding: 0;
		width: auto;
	}
	.main .contactBox .listUl {
		margin-bottom: 0;
	}
	.main .contactBox .listUl li {
		padding-bottom: 19px;
		font-size: 14px;
	}
	.main .contactBox .listUl li img {
		margin-right: 10px;
		width: 14px;
	}
	.main .contactBox .inner .map {
		width: auto;
	}
	.main .contactBox .inner .map iframe {
		height: 210px;
	}
	.main .contactBox .linkUl.sp {
		margin: 20px -5px 0;
		display: flex !important;
	}
	.main .contactBox .linkUl li {
		margin: 0;
		padding: 0 5px;
		width: 50%;
		box-sizing: border-box;
	}
	.main .contactBox .linkUl li a {
		border-width: 1px;
		font-size: 14px;
		line-height: 38px;
	}
	.main .contactBox .linkUl li a img {
		margin-left: 10px;
		width: 14px;
	}
}