@charset "UTF-8";

/* ---------------------------------------
  about
-----------------------------------------*/

.section {
	padding: 90px 0;
}

.section + .section::before {
	content: "";
	width: 100%;
	max-width: 1046px;
	height: 1px;
	background-color: #424142;
	position: absolute;
	left: 0;
	top: 0;
	margin: 0 auto;
}

.section .inner {
	align-items: flex-start;
}

.section .inner .ttlwrap {
	width: 250px;
}

.section .inner .ttlwrap .secttl {
	font-weight: 500;
	font-size: 2.6rem;
	line-height: 1.75;
	letter-spacing: 0.2em;
}

.section .inner .ttlwrap .secttl span.en {
	display: block;
	color: #7bccf1;
	font-size: 1.8rem;
	line-height: 1;
	letter-spacing: 0.1em;
	margin-bottom: .5em;
}

.section .inner .cntwrap {
	width: calc(100% - 250px);
	padding-top: 35px;
}

.section .imgwrap {
	margin-top: 80px;
}

.section .imgwrap .img {
	width: 48.95%;
	max-width: 512px;
}

@media screen and (max-width: 1440px) and (min-width: 768px) {
	.section + .section::before {
		width: 92%;
		max-width: 1046px;
		right: 0;
		margin: 0 auto;
	}
}

@media screen and (max-width: 767px) {
	.section {
		padding: 13rem 0;
	}

	.section + .section::before {
		width: 63rem;
		max-width: inherit;
		height: .2rem;
		right: 0;
		margin: 0 auto;
	}

	.section .inner .ttlwrap {
		width: 100%;
		margin-bottom: 7rem;
	}

	.section .inner .ttlwrap .secttl {
		font-size: 3.9rem;
	}

	.section .inner .ttlwrap .secttl span.en {
		font-size: 2.7rem;
	}

	.section .inner .cntwrap {
		width: 100%;
		padding-top: 0;
	}

	.section .imgwrap {
		margin-top: 12rem;
	}

	.section .imgwrap .img {
		width: 30.8rem;
		max-width: inherit;
	}
}

/* intro
--------------------------------*/
#sec_intro {
	padding: 0 0 30px;
}

#sec_intro .ttlwrap .ttl {
	writing-mode: vertical-rl;
	text-align: left;
	font-weight: 500;
	font-size: 2.8rem;
	line-height: 2.3;
	letter-spacing: 0.3em;
	white-space: nowrap;
	margin-left: -.65em;
	margin-top: 10px;
}

#sec_intro .cntwrap {
	padding-top: 0;
}

#sec_intro .cntwrap .txt {
	font-size: 1.7rem;
	line-height: 2.05;
}

#sec_intro .cntwrap .txt + .txt {
	margin-top: 1em;
}

#sec_intro .imgwrap {
	margin-top: 110px;
}

@media screen and (max-width: 767px) {
	#sec_intro {
		padding: 0 0 5rem;
	}

	#sec_intro .ttlwrap {
		margin-bottom: 13rem;
	}

	#sec_intro .ttlwrap .ttl {
		font-size: 4.2rem;
		margin: 0 auto;
	}

	#sec_intro .cntwrap .txt {
		font-size: 2.6rem;
	}

	#sec_intro .cntwrap .txt + .txt {
		margin-top: 2em;
	}

	#sec_intro .imgwrap {
		margin-top: 16rem;
	}
}


/* service
--------------------------------*/
#sec_service::before {
	content: none;
}

#sec_service .cntwrap .list li {
	position: relative;
	line-height: 1.72;
	padding-left: 22px;
}

#sec_service .cntwrap .list li::before {
	content: "";
	width: 11px;
	height: 11px;
	background-color: #7bccf1;
	border-radius: 50%;
	position: absolute;
	left: 0;
	top: 11px;
}

#sec_service .cntwrap .list li + li {
	margin-top: .75em;
}

@media screen and (max-width: 767px) {
	#sec_service .cntwrap .list li {
		letter-spacing: 0.025em;
		padding-left: 3rem;
	}

	#sec_service .cntwrap .list li::before {
		width: 1.6rem;
		height: 1.6rem;
		top: 1.6rem;
	}

	#sec_service .cntwrap .list li + li {
		margin-top: .65em;
	}
}


/* company
--------------------------------*/
#sec_company .cntwrap dl {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start:
}

#sec_company .cntwrap dl dt,
#sec_company .cntwrap dl dd {
	line-height: 1.63;
}


#sec_company .cntwrap dl dt:not(:first-of-type),
#sec_company .cntwrap dl dd:not(:first-of-type) {
	margin-top: .75em;
}

#sec_company .cntwrap dl dt {
	width: 128px;
	font-weight: 500;
}

#sec_company .cntwrap dl dd {
	width: calc(100% - 128px);
}

#sec_company .gmap {
	position: relative;
	width: 100%;
	height: 441px;
	margin-top: 110px;
}

#sec_company .gmap iframe {
	width: 100%;
	height: 100%;
}

#sec_company .gmap .map_btn {
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 1;
}

#sec_company .gmap .map_btn a {
	display: block;
	position: relative;
	min-width: 170px;
	height: 38px;
	text-align: center;
	color: #fff;
	font-weight: 500;
	font-size: 1.8rem;
	line-height: 1.5;
	letter-spacing: 0.1em;
	padding: 5px 32px 5px 18px;
	background-color: #7bccf1;
	text-decoration: none;
	clip-path: polygon(10px 0, 100% 0, 100% 100%, 0 100%, 0 10px);
	transition: .3s ease;
}

#sec_company .gmap .map_btn a::before {
	content: "";
	width: 11px;
	height: 14px;
	background: url(../img/common/ico_mapbtn.svg) no-repeat center / 100% auto;
	position: absolute;
	right: 16px;
	top: 50%;
	margin-top: -7px;
	transition: .3s ease;
}

#sec_company .gmap + .txt {
	font-size: 1.6rem;
	line-height: 2.125;
	text-align: justify;
	margin-top: 50px;
}

@media screen and (min-width: 768px) {
	#sec_company .gmap .map_btn a:hover {
		background-color: #9cd8f4;
	}

	#sec_company .gmap .map_btn a:hover::before {
		transform: translateX(5px);
	}
}

@media screen and (max-width: 767px) {

	#sec_company .cntwrap dl dt {
		width: 19rem;
	}

	#sec_company .cntwrap dl dd {
		width: calc(100% - 19rem);
	}

	#sec_company .gmap {
		height: 42rem;
		margin-top: 13rem;
	}

	#sec_company .gmap .map_btn a {
		min-width: 25.7rem;
		height: 5.7rem;
		font-size: 2.7rem;
		padding: .825rem 32px .825rem 18px;
		clip-path: polygon(1.5rem 0, 100% 0, 100% 100%, 0 100%, 0 1.5rem);
	}

	#sec_company .gmap .map_btn a::before {
		width: 1.65rem;
		height: 2.1rem;
		right: 2.4rem;
		margin-top: -1rem;
	}

	#sec_company .gmap + .txt {
		font-size: 2.4rem;
		letter-spacing: 0.05em;
		margin-top: 7.5rem;
	}
}


/* members
--------------------------------*/
#sec_members {
	padding-bottom: 150px;
}

#sec_members .cntwrap .block + .block {
	margin-top: 120px;
}

#sec_members .cntwrap .block .prof {
	display: flex;
	align-items: center;
	margin-bottom: 25px;
}

#sec_members .cntwrap .block .prof .ico {
	width: 60px;
	height: 67px;
	display: inline-flex;
	align-items: center;
	margin-right: 24px;
}

#sec_members .cntwrap .block .prof .ico img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: left bottom;
}

#sec_members .cntwrap .block .prof .name {
	font-size: 2.4rem;
	line-height: 1.5;
}

#sec_members .cntwrap .block .prof .name span {
	display: block;
	color: #7bccf1;
	font-weight: 500;
	font-size: 1.4rem;
	line-height: 1.5;
	letter-spacing: 0.1em;
}

#sec_members .cntwrap .block .txt {
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0.075em;
	text-align: justify;
}

#sec_members .cntwrap .img {
	width: 100%;
	margin-top: 95px;
}

@media screen and (max-width: 767px) {
	#sec_members {
		padding-bottom: 20rem;
	}

	#sec_members .cntwrap .block + .block {
		margin-top: 11.5rem;
	}

	#sec_members .cntwrap .block .prof {
		margin-bottom: 3rem;
	}

	#sec_members .cntwrap .block .prof .ico {
		width: 8.7rem;
		height: 10rem;
		margin-right: 4.3rem;
	}

	#sec_members .cntwrap .block .prof .name {
		font-size: 3.6rem;
	}

	#sec_members .cntwrap .block .prof .name span {
		font-size: 2.1rem;
	}

	#sec_members .cntwrap .block .txt {
		font-size: 2.4rem;
	}

	#sec_members .cntwrap .img {
		margin-top: 12rem;
	}
}

s