/*==========================================================================

   mixin

===========================================================================*/
/*--------------------------------------------------------------------------
   overwrite
---------------------------------------------------------------------------*/
.mode-pc .g-header .gnav__item--01 a:after {
	width: 100%;
}

/*--------------------------------------------------------------------------
   common
---------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------
   sec-concept
---------------------------------------------------------------------------*/
.sec-concept {
	margin-top: 40px;
	text-align: center;
}

@media only screen and (max-width: 767px) {
	.sec-concept {
		margin-top: 25px;
	}
}

.sec-concept__catch {
	position: relative;
	margin-bottom: 30px;
	padding-bottom: 60px;
	font-size: 17px;
	font-weight: 600;
}

@media only screen and (max-width: 767px) {
	.sec-concept__catch {
		margin-bottom: 20px;
		padding-bottom: 40px;
		font-size: 15px;
		line-height: 2;
	}
}

.sec-concept__catch::before {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 39px;
	height: 31px;
	background: url('../../img/common/ico_apple.svg') no-repeat;
	background-size: 39px 31px;
	content: '';
	transform: translateX(-50%);
}

@media only screen and (max-width: 767px) {
	.sec-concept__catch::before {
		width: 24px;
		height: 19px;
		background: url('../../img/common/ico_apple.svg') no-repeat;
		background-size: 24px 19px;
	}
}

.sec-concept__lead {
	margin-bottom: 60px;
	font-size: 14px;
	font-weight: 600;
	line-height: 2;
}

@media only screen and (max-width: 767px) {
	.sec-concept__lead {
		margin-bottom: -10px;
		font-size: 11px;
		line-height: 2.6;
	}
}

.sec-concept__txt {
	margin-top: 30px;
	font-size: 12px;
	font-weight: 600;
	line-height: 2;
}

@media only screen and (max-width: 767px) {
	.sec-concept__txt {
		margin: 16px 30px 0;
		text-align: left;
		font-size: 11px;
		line-height: 2.45;
	}
}

@media only screen and (max-width: 767px) {
	.sec-concept .c-white-box + .c-white-box {
		margin-top: 26px;
		padding-top: 15px;
	}
}

/*--------------------------------------------------------------------------
   sec-plofile
---------------------------------------------------------------------------*/
.sec-plofile {
	display: -ms-flexbox;
	display: flex;
	margin-top: 100px;
}

@media only screen and (max-width: 767px) {
	.sec-plofile {
		display: block;
		margin-top: 45px;
		padding-left: 10px;
	}
}

.sec-plofile__img {
	width: 220px;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__img {
		width: 200px;
	}
}

.sec-plofile__img img {
	width: 100%;
	height: auto;
	border-radius: 14px;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__img img {
		border-radius: 10px;
	}
}

.sec-plofile__personal {
	width: 145px;
	margin-left: 50px;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__personal {
		width: auto;
		margin: 20px 0 0;
	}
}

.sec-plofile__name {
	position: relative;
	padding-bottom: 12px;
	font-size: 18px;
	font-weight: 600;
	letter-spacing: .24em;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__name {
		font-size: 20px;
	}
}

.sec-plofile__name::before {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 134px;
	height: 8px;
	border-radius: 2px;
	background-color: #abcd03;
	content: '';
}

@media only screen and (max-width: 767px) {
	.sec-plofile__name::before {
		width: 75px;
		height: 5px;
	}
}

.sec-plofile__degree {
	margin-top: 18px;
	font-size: 11px;
	line-height: 2;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__degree {
		font-size: 12px;
	}
}

.sec-plofile__outline {
	margin-left: 50px;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__outline {
		margin: 30px 0 0;
	}
}

.sec-plofile__outline-hdg {
	font-size: 14px;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__outline-hdg {
		font-size: 12px;
	}
}

.sec-plofile__outline-list {
	margin-top: 10px;
}

.sec-plofile__outline-list .outline {
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	font-size: 13px;
	font-weight: 600;
	line-height: 2.3;
	letter-spacing: .1em;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__outline-list .outline {
		font-size: 11px;
	}
}

.sec-plofile__outline-list .outline__year {
	width: 84px;
}

@media only screen and (max-width: 767px) {
	.sec-plofile__outline-list .outline__year {
		width: 60px;
	}
}

.sec-plofile__outline-list .outline__txt {
	width: calc(100% - 84px);
}

@media only screen and (max-width: 767px) {
	.sec-plofile__outline-list .outline__txt {
		width: calc(100% - 60px);
	}
}
