@charset "UTF-8";

/* companymessage ---------------------------------------*/
.companymessage {
	padding: 120px 20px 0;
	margin-bottom: 170px;
}

.companymessage-block {
	display: flex;
	gap: calc(68 / 1080 * 100%);
	margin-top: 58px;
	margin-left: calc(58 / 1080 * 100%);
}

.companymessage-summary {
	width: calc(222 / 1022 * 100%);
	order: 2;
}

.companymessage-image {
	width: 100%;
	margin-bottom: 26px;
}

.companymessage-jobtitle {
	font-size: 16px;
	font-weight: 500;
	line-height: 1.875;
	letter-spacing: 0.05em;
	margin: 0 0 16px calc(8 / 222 * 100%);
}

.companymessage-name {
	font-size: 30px;
	font-weight: 500;
	margin-left: calc(8 / 222 * 100%);
}

.companymessage-text {
	width: calc(640 / 1022 * 100%);
	font-size: 20px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.06em;
	order: 1;
}


/* companydata ---------------------------------------*/
.companydata {
	padding: 0 20px;
	margin-bottom: 150px;
}

.companydata-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0 20px;
	margin: 30px auto 0 calc(64 / 1080 * 100%);
	width: calc(857 / 1080 * 100%);
}

.companydata-list dt {
	width: 140px;
	padding: 16px 0;
	font-size: 20px;
	font-weight: 400;
	line-height: 1.6;
}

.companydata-list dd {
	width: calc(100% - 160px);
	padding: 16px 0;
	font-size: 20px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.05em;
}

.companydata-textlist {

}

.companydata-textlist > li {
	position: relative;
	font-size: 20px;
	line-height: 1.6;
	letter-spacing: 0.05em;
	padding-left: 24px;
}

.companydata-textlist > li::before {
    position: absolute;
    top: 0;
    left: 2px;
    font-size: 20px;
    content: '・';
}

.companydata-list dd.companydata-logolist {
	padding-left: 16px;
}

.companydata-list dd.companydata-logolist img:first-of-type {
	display: block;
	margin: -6px 0 10px;
}


/* companymap ---------------------------------------*/
.companymap {
	padding: 0 20px;
	margin-bottom: 170px;
}

.companymap-map {
	position: relative;
	width: calc(875 / 1080 * 100%);
	margin: 28px auto 24px calc(114 / 1080 * 100%);
	padding-top: 25.46%;
    height: 0;
}

.companymap-map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.companymap-info {
	font-size: 20px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.03em;
	margin-left: calc(120 / 1080 * 100%);
}


/* companyhistory ---------------------------------------*/
.companyhistory {
	padding: 0 20px;
	margin-bottom: 170px;
}

.companyhistory-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0 20px;
	position: relative;
	margin: 54px auto 0 calc(120 / 1080 * 100%);
	width: calc(900 / 1080 * 100%);
}

.companyhistory-list::after {
	position: absolute;
	top: 16px;
	left: 136px;
	z-index: 1;
	width: 2px;
	height: calc(100% - 32px);
	background-image: linear-gradient(to bottom, #1491D1 3px, transparent 3px);
	background-size: 3px 6px;
	background-repeat: repeat-y;
	background-position: left top;
	content: '';
}

.companyhistory-list dt {
	position: relative;
	width: 152px;
	padding: 16px 0;
	font-size: 20px;
	font-weight: 300;
	color: #0074D8;
}

.companyhistory-list dt::after {
	position: absolute;
	top: 24px;
	left: 131px;
	z-index: 1;
	width: 11px;
	height: 11px;
	background: #1491D1;
	content: '';
}

.companyhistory-list dd {
	width: calc(100% - 172px);
	padding: 15px 0;
	font-size: 20px;
	font-weight: 400;
	letter-spacing: 0.03em;
}


/* companyorganization ---------------------------------------*/
.companyorganization {
	padding: 0 20px;
	margin-bottom: 170px;
}

.companyorganization-image {
	margin: 58px auto 0 calc(112 / 1080 * 100%);
	max-width: 782px;
}


/* companyinitiative ---------------------------------------*/
.companyinitiative {
	padding: 0 20px;
	margin-bottom: 170px;
}

.companyinitiative-block {
	display: flex;
	gap: calc(90 / 914 * 100%);
	margin: 50px auto 0 calc(89 / 1080 * 100%);
	width: calc(914 / 1080 * 100%);
}

.companyinitiative-tc {
	position: relative;
	width: calc(429 / 914 * 100%);
}

.companyinitiative-tc::after {
	position: absolute;
	top: 0;
	right: calc(-34 / 429 * 100%);
	z-index: 1;
	width: 2px;
	height: 100%;
	background-image: linear-gradient(to bottom, #000 4px, transparent 4px);
	background-size: 4px 8px;
	background-repeat: repeat-y;
	background-position: left top;
	content: '';
}

.companyinitiative-lab {
	width: calc(395 / 914 * 100%);
}

.companyinitiative-title {
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 12px;
	color: #000069;
}

.companyinitiative-text {
	font-size: 20px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.05em;
	margin-bottom: 42px;
	padding-left: 6px;
}

.companyinitiative-tc-image {
	width: calc(419 / 429 * 100%);
	margin-left: auto;
}

.companyinitiative-lab-image {
	width: calc(344 / 395 * 100%);
	margin-left: calc(15 / 395 * 100%);
}


.companyinitiative-link {
	display: block;
	width: fit-content;
	margin: 26px 12px 0 auto;
	font-size: 20px;
	font-weight: 400;
	line-height: 1.6;
}

/* sp only */
@media screen and (max-width: 767px){

	/* companymessage ---------------------------------------*/
	.companymessage {
		padding: 58px 20px 0;
		margin-bottom: 82px;
	}

	.companymessage-block {
		display: block;
		margin-top: 10px;
		margin-left: 0;
	}

	.companymessage-summary {
		display: flex;
		align-items: flex-end;
		width: 100%;
		gap: 14px;
		margin: 0 auto 30px 8px;
	}

	.companymessage-image {
		max-width: 135px;
		margin: 0;
		order: 2;
	}

	.companymessage-name-summary {
		order: 1;
		margin-bottom: 8px;
	}

	.companymessage-jobtitle {
		font-size: 14px;
		line-height: 2.143;
		margin: 0 0 10px;
	}

	.companymessage-name {
		font-size: 20px;
		margin: 0;
	}

	.companymessage-text {
		width: 100%;
		font-size: 16px;
		line-height: 2;
		letter-spacing: 0.1em;
	}


	/* companydata ---------------------------------------*/
	.companydata {
		margin-bottom: 78px;
	}

	.companydata-list {
		gap: 0;
		margin: 16px auto 0;
		width: 100%;
	}

	.companydata-list dt {
		width: 100%;
		padding: 5px 10px;
		font-size: 16px;
		line-height: 1.5;
		background: #97C3FC;
	}

	.companydata-list dd {
		width: 100%;
		padding: 16px 0 0;
		font-size: 16px;
		line-height: 1.5;
	}

	.companydata-list dd + dt {
		margin-top: 30px;
	}

	.companydata-textlist {

	}

	.companydata-textlist > li {
		font-size: 16px;
		line-height: 1.5;
		padding-left: 26px;
	}

	.companydata-textlist > li::before {
		left: 9px;
		font-size: 16px;
	}

	.companydata-list dd.companydata-logolist {
		padding: 16px 0 0 12px;
	}

	.companydata-list dd.companydata-logolist img:first-of-type {
		display: inline;
		margin: 0 14px 0 0;
	}


	/* companymap ---------------------------------------*/
	.companymap {
		margin-bottom: 70px;
	}

	.companymap-map {
		width: 100%;
		margin: 16px auto 16px;
		padding-top: 76.82%;
	}

	.companymap-info {
		font-size: 16px;
		line-height: 1.5;
		margin-left: 0;
	}


	/* companyhistory ---------------------------------------*/
	.companyhistory {
		margin-bottom: 70px;
	}

	.companyhistory-list {
		gap: 0 20px;
		margin: 30px auto 0;
		width: 100%;
	}

	.companyhistory-list::after {
		top: 10px;
		left: 91px;
		width: 2px;
		height: calc(100% - 20px);
	}

	.companyhistory-list dt {
		width: 90px;
		padding: 12px 0;
		font-size: 14px;
	}

	.companyhistory-list dt::after {
		top: 17px;
		left: 86px;
	}

	.companyhistory-list dd {
		width: calc(100% - 110px);
		padding: 12px 0;
		font-size: 14px;
		line-height: 1.714;
	}


	/* companyorganization ---------------------------------------*/
	.companyorganization {
		margin-bottom: 70px;
	}

	.companyorganization-image {
		margin: 34px auto 0;
		max-width: unset;
	}

	.companyorganization-image img {
		width: 100%;
	}


	/* companyinitiative ---------------------------------------*/
	.companyinitiative {
		padding: 0 20px;
		margin-bottom: 100px;
	}

	.companyinitiative-block {
		display: block;
		margin: 24px auto 0;
		width: 100%;
	}

	.companyinitiative-tc {
		width: 100%;
	}

	.companyinitiative-tc::after {
		display: none;
	}

	.companyinitiative-lab {
		width: 100%;
		margin-top: 66px;
	}

	.companyinitiative-title {
		margin-bottom: 12px;
	}

	.companyinitiative-text {
		margin-bottom: 32px;
		padding-left: 0;
	}

	.companyinitiative-tc-image {
		width: min(calc(331 / 353 * 100%), 331px);
		margin: 0 auto;
	}

	.companyinitiative-tc-image img {
		width: 100%;
	}

	.companyinitiative-lab-image {
		width: min(calc(289 / 353 * 100%), 289px);
		margin: 0 auto;
	}

	.companyinitiative-lab-image img {
		width: 100%;
	}

	.companyinitiative-link {
		margin: 30px auto 0;
	}

}




/* iphone5 iphoneSE用 */
@media screen and (max-width: 370px){

}