@charset "utf-8";
/*------------------------------------------------------------
	company
------------------------------------------------------------*/
.pageTitle {
	background-image: url("../img/company/page_title_bg.jpg");
}
#main .message {
	margin: 0 2rem;
	padding: 12.2rem 0 11.5rem;
	border-bottom: 1px solid #02aef0;
}
#main .content {
	max-width: 118.8rem;
}
#main .message .imgBox {
	margin-right: 2.5rem;
}
#main .message .imgBox .tetxtBox {
	width: calc(100% - 32rem);
}
#main .message .imgBox .tetxtBox h3 {
	margin-bottom: 3.6rem;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: 0.1em;
}
#main .message .imgBox .tetxtBox p {
	font-size: 1.7rem;
	font-weight: 500;
	line-height: 2.35;
	letter-spacing: 0.15em;
}
#main .message .imgBox .photoBox {
	margin-top: 1rem;
	width: 30rem;
	text-align: right;
}
#main .message .imgBox .photoBox .name {
	margin-top: 1.3rem;
	display: block;
}
#main .company {
	margin: 0 2rem;
	padding: 9.5rem 0;
}
#main .company .headLine02 {
	margin-bottom: 4.6rem;
}
#main .company .tableBox {
	margin: 0 1.4rem;
	position: relative;
}
#main .company table {
	position: relative;
	width: 100%;
	border-collapse: collapse;
}
#main .company th,
#main .company td {
	padding: 1.4rem 1rem 1.6rem 5rem;
	color: #fffcfc;
	text-align: left;
	line-height: 2;
	letter-spacing: 0.2em;
	vertical-align: top;
	word-break: break-all;
	border: 1px solid #02aef0;
	background-color: #404040;
}
#main .company th {
	width: 16.5%;
	color: #02aef0;
	font-weight: 400;
	letter-spacing: 0;
}
#main .company td {
	padding-left: 5.2rem;
}
#main .company .tableBox::before {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0.8rem;
	top: 0.8rem;
	content: "";
	border: 1px solid #02aef0;
	pointer-events: none;
}
#main .history {
	margin: 0 2rem;
	padding: 6.5rem 0 18.7rem;
	border-bottom: 1px solid #02aef0;
}
#main .history .headLine02 {
	margin-bottom: 4.2rem;
}
#main .history .historyList {
	max-width: 99rem;
	margin: 0 auto;
	padding-left: 2.4rem;
}
#main .history .historyList dl {
	width: 46rem;
	position: relative;
}
#main .history .historyList dl::before {
	position: absolute;
	right: -0.1rem;
	top: 2rem;
	bottom: -2.5rem;
	width: 1px;
	background: #02aef0;
	content: "";
}
#main .history .historyList dt {
	padding-bottom: 0.2rem;
	position: relative;
	line-height: 1.2;
	font-weight: 500;
	border-bottom: 1px solid #02aef0;
}
#main .history .historyList dt::before {
	position: absolute;
	right: -0.8rem;
	top: 1.3rem;
	width: 1.6rem;
	height: 1.9rem;
	background: #02aef0;
	content: "";
}
#main .history .historyList dd {
	padding: 0.6rem 0 0.1rem 13.7rem;
	font-size: 1.5rem;
	line-height: 1.96;
}
#main .history .historyList li:nth-child(2n) dl {
	margin-left: auto;
	width: calc(100% - 46rem);
}
#main .history .historyList li:nth-child(2n) dl::before {
	right: inherit;
	left: 0;
}
#main .history .historyList li:nth-child(2n) dt {
	padding-left: 4.2rem;
}
#main .history .historyList li:nth-child(2n) dt::before {
	right: inherit;
	left: -0.8rem;
}
#main .history .historyList li:nth-child(2n) dd {
	padding-left: 18.2rem;
}
#main .access {
	margin: 0 2rem;
	padding: 13.6rem 0 11.8rem;
}
#main .access .inner {
	max-width: 112rem;
	margin: -0.4rem auto 0;
}
#main .access h3 {
	margin-bottom: 2.1rem;
	font-weight: 500;
	font-size: 2.4rem;
	letter-spacing: 0.1em;
}
#main .access p {
	margin-bottom: 4.8rem;
	font-size: 1.4rem;
	line-height: 1.78;
	letter-spacing: 0.1em;
}
#main .access .map iframe {
	width: 100%;
	height: 38.3rem;
	vertical-align: top;
	border: 0;
} 
@media all and (max-width: 896px) {
	.pageTitle {
		background-image: url("../img/company/page_title_bg_sp.jpg");
	}
	#main .message {
		margin: 0 0.5rem;
		padding: 5.1rem 0.5rem 6.5rem;
	}
	#main .content {
		margin: 0 1rem;
	}
	#main .message .headLine02 {
		margin: 0 0.5rem 2.7rem;
	}
	#main .message .imgBox {
		margin-right: 0;
		display: block;
	}
	#main .message .imgBox .tetxtBox {
		margin-bottom: 5.1rem;
		width: auto;
	}
	#main .message .imgBox .tetxtBox h3 {
		margin-bottom: 2rem;
		font-size: 1.8rem;
		line-height: 1.77;
	}
	#main .message .imgBox .tetxtBox p {
		font-size: 1.4rem;
		font-weight: 400;
		line-height: 2;
		letter-spacing: 0.05em;
	}
	#main .message .imgBox .photoBox {
		margin: 0 2.5rem 0 1rem;
		width: auto;
	}
	#main .message .imgBox .photoBox > img {
		width: 100%;
	}
	#main .message .imgBox .photoBox .name {
		margin-top: 1.3rem;
	}
	#main .message .imgBox .photoBox .name img {
		width: 18.2rem;
	}
	#main .company {
		margin: 0 0.5rem;
		padding: 4.8rem 0;
	}
	#main .company .headLine02 {
		margin-bottom: 1.6rem;
	}
	#main .company .tableBox {
		margin: 0 0.5rem;
	}
	#main .company th,
	#main .company td {
		padding: 1.6rem 0.9rem 0;
		display: block;
		width: 100% !important;
		letter-spacing: 0.05em;
	}
	#main .company th {
		font-weight: 700;
		letter-spacing: 0;
		line-height: 1.5;
		border-bottom: none;
	}
	#main .company tr:not(:last-child) td {
		border-bottom: none;
	}
	#main .company td {
		padding: 0 0.9rem 1.8rem;
		font-size: 1.3rem;
		line-height: 2.15;
		border-top: none;
	}
	#main .company .tableBox::before {
		left: 0.5rem;
		top: 0.5rem;
	}
	#main .history {
		margin: 0 0.5rem;
		padding: 1rem 0 12.3rem;
	}
	#main .history .headLine02 {
		margin-bottom: 0.6rem;
	}
	#main .history .historyList {
		max-width: inherit;
		padding: 0 0.5rem 0 1.3rem;
	}
	#main .history .historyList dl {
		width: 100% !important;
	}
	#main .history .historyList dl::before {
		right: inherit !important;
		left: -0.1rem !important;
	}
	#main .history .historyList dt {
		padding: 0 1.6rem 0.7rem !important;
	}
	#main .history .historyList dt::before {
		right: inherit;
		left: -0.8rem;
		top: 1.5rem;
	}
	#main .history .historyList dd {
		padding: 0rem 0 3.4rem 1.6rem!important;
		font-size: 1.3rem;
		line-height: 2.26;
		letter-spacing: 0.1em;
	}
	#main .history .historyList li:last-child dd {
		padding-bottom: 0 !important;		
	}
	#main .history .historyList .ddStyle {
		margin-right: -1rem;
	}
	#main .access {
		margin: 0 0.5rem;
		padding: 4.6rem 0 8rem;
	}
	#main .access .inner {
		max-width: inherit;
		margin: 0 0.5rem 0;
	}
	#main .access .headLine02 {
		margin-bottom: 1.5rem;
	}
	#main .access h3 {
		margin-bottom: 1.7rem;
		font-size: 1.6rem;
	}
	#main .access p {
		margin-bottom: 3.1rem;
		font-size: 1.2rem;
		line-height: 1.4;
	}
	#main .access p .smlTxt {
		margin-top: 0.9rem;
		display: block;
		font-size: 1.1rem;
	}
	#main .access .map {
		padding-bottom: 114.4%;
		position: relative;
	}
	#main .access .map iframe {
		position: absolute;
		left: 0;
		top: 0;
		object-fit: cover;
		height: 100%;
	} 
}