@charset "UTF-8";

/* -------------------------------------------------- */
/* PC*/
/* -------------------------------------------------- */
/* -------------------------------------------------- */
/* aboutページ
/* -------------------------------------------------- */
#aboutHeader a::after {
	background: url(../../img/common/icon_arrow_down.svg) center center/cover no-repeat;
}

#overViewTableRegal a::after {
	background: url(../../img/common/icon_pdf.svg) center center/cover no-repeat;
}


.aboutContentTitle {
	font-size: 3.4rem;
	line-height: 1.68;
	font-weight: bold;
}

#about {
	padding-bottom: 80px;
}

#aboutHeader {
	padding-top: 40px;
	margin-bottom: 60px;
}

#aboutHeader ul {
	display: flex;
}

#aboutHeader ul li {
	width: 20%;
	text-align: center;
	border-left: 1px solid #c3c3c3;
}

#aboutHeader ul li:last-child {
	border-right: 1px solid #c3c3c3;
}

#aboutHeader ul li a {
	padding-top: 20px;
	padding-bottom: 20px;
	font-size: clamp(1.4rem, 1vw, 1.9rem);
	font-weight: bold;
	line-height: 1;
	display: block;
	color: #007ac1;
	position: relative;
	transition: .3s all ease;
}

#aboutHeader ul li a::after {
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	width: clamp(30px, 3.1vw, 37px);
	height: clamp(30px, 3.1vw, 37px);
	content: "";
	position: absolute;
}

#aboutHeader ul li a:hover {
	opacity: .6;
}

.aboutTable table {
	width: 100%;
	border: 1px solid #d2d7da;
}

.aboutTable table .other {
	padding-top: 1em;
}

.aboutTable th {
	width: 150px;
	padding-left: 20px;
	font-size: 1.8rem;
	border: 1px solid #d2d7da;
	background: #eaf1f5;
	text-align: left;
	font-weight: bold;
	vertical-align: middle;
	line-height: 1;
}

.aboutTable td {
	width: calc(100% - 150px);
	padding-top: 22px;
	padding-bottom: 22px;
	padding-left: 20px;
	font-size: 1.8rem;
	border: 1px solid #d2d7da;
}

/* greeting */
/* ----------------------------------- */
#greeting {
	margin-bottom: 120px;
}

#greeting .subSectionContentTtl {
	margin-bottom: 40px;
}

#aboutGreetingImage {
	position: relative;
	margin-bottom: 80px;
}

#aboutGreetingImage img {
	width: 100%;
}

#aboutGreetingImageName {
	padding: 35px 55px;
	position: absolute;
	right: 0;
	top: 50%;
	background: #FFFFFF;
	transform: translateY(-50%);
}

#aboutGreetingImageName h3 {
	width: 100%;
	display: flex;
	align-items: center;
	gap: 30px;
}

#aboutGreetingImageName h3 .name {
	font-size: 4.4rem;
	line-height: 1;
	display: inline-block;
}

#aboutGreetingImageName h3 .job {
	font-size: clamp(1.8rem, 1.6vw, 2.4rem);
	display: inline-block;
}


#aboutGreetingText h4 {
	margin-bottom: 30px;
}

#aboutGreetingText p {
	font-size: 2rem;
	line-height: 2.25;
	display: block;
}

/* overView */
/* ----------------------------------- */
#overView {
	margin-bottom: 120px;
}

#overView h2 {
	margin-bottom: 40px;
}

.overViewTableInfoBottom {
	margin-top: 14px;
}

.overViewTableInfoBottom p {
	line-height: 1.3;
}

.overViewTableListTop {
	margin-bottom: 30px;
}

.overViewTableListMiddle {
	margin-bottom: 30px;
}

.overViewTableDevItemTop {
	margin-bottom: 16px;
}

.overViewTableDevItemMiddle {
	margin-bottom: 16px;
}

#overViewTableHeaderPartner p {
	position: relative;
	display: block;
}

#overViewTableHeaderPartner p::after {
	left: 0;
	bottom: -22px;
	font-size: 1.4rem;
	white-space: nowrap;
	content: "(敬称略、順不同)";
	position: absolute;
}

#overViewTable #overViewTableRegalHead {
	line-height: 1.3;
}

#overViewTableRegal p {
	margin-bottom: 23px;
}

#overViewTableRegal a {
	border-radius: 12px;
	padding: 22px 54px 22px 22px;
	font-weight: 600;
	display: inline-block;
	background: rgba(210, 215, 218, 0.3);
	position: relative;
	transition: all 0.3s ease;
}

#overViewTableRegal a:hover {
	opacity: .7;
}

#overViewTableRegal a::after {
	content: "";
	position: absolute;
	right: 22px;
	top: 50%;
	transform: translateY(-50%);
	width: 22px;
	height: 25px;
}

.overViewTablePlace {
	font-feature-settings: "palt";
}

/* access */
/* ----------------------------------- */
#access {
	margin-bottom: 120px;
}

#access h2 {
	margin-bottom: 40px;
}

#accessItems {
	display: flex;
	justify-content: space-between;
	gap: 6%;
}

.accessItem {
	width: 50%;
}

.accessMapTitle {
	margin-bottom: 24px;
	font-size: 3rem;
	font-weight: 500;
	display: block;
}

.accessMap {
	margin-bottom: 20px;
	width: 100%;
	aspect-ratio: 560 / 260;
	position: relative;
}

.accessMapWrap {
	position: absolute;
	width: 100%;
	height: 100%;
}

.accessMapWrap iframe {
	width: 100%;
	height: 100%;
}

.accessInfo {
	margin-bottom: 20px;
}

.accessInfo span {
	font-size: 1.8rem;
	line-height: 1.67;
	display: block;
}

.accessProcess {
	padding: 20px;
	background: rgba(234, 241, 245, 0.8);
}

.accessProcess h4 {
	font-size: 1.6rem;
	font-weight: bold;
}

.accessProcess span {
	font-size: 1.6rem;
	letter-spacing: .075em;
	display: block;
}

/* history */
/* ----------------------------------- */
#history {
	margin-bottom: 120px;
}

#history h2 {
	margin-bottom: 40px;
	display: block;
}

#historyList ul li {
	display: flex;
	align-items: stretch;
	border: 5px solid #e5f8fb;
	position: relative;
}

#historyList ul li:not(:last-child) {
	margin-bottom: 30px;
}

#historyList ul li:not(:last-child)::after {
	clip-path: polygon(100% 45%, 0 45%, 50% 100%);
	width: 44px;
	height: 23px;
	left: 50%;
	transform: translateX(-50%);
	bottom: -17px;
	position: absolute;
	content: "";
	background: #e5f8fb;
}

#historyList .year {
	width: 155px;
	font-size: 2.6rem;
	font-weight: 400;
	display: grid;
	place-content: center;
	background: #e5f8fb;
	color: #007ac1;
	font-family: "MuseoModerno", sans-serif;
}

#historyList .historyDetail {
	font-size: 2rem;
	padding: 30px;
	width: calc(100% - 155px);
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

#historyList .historyDetail .eventWrap {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

#historyList .historyDetail .date{
	width: 3em;
	text-align: right;
}

#historyList .historyDetail.addImg {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}

.historyDetail img {
	width: 260px;
	height: auto;
}

/* works */
/* ----------------------------------- */
#works h2 {
	margin-bottom: 40px;
}

/* -------------------------------------------------- */
/* TAB&SP */
/* -------------------------------------------------- */
@media screen and (max-width: 1024px) {
	.layoutInner {
		padding-left: 4%;
		padding-right: 4%;
	}

	.aboutContentTitle {
		font-size: clamp(2.8rem, 3vw, 3.2rem);
	}

	#aboutHeader {
		margin-bottom: 80px;
	}

	#aboutHeader ul {
		display: grid;
		grid-template-columns: 1fr 1fr 1fr;
		gap: 8px 0;
	}

	#aboutHeader ul li {
		width: 100%;
	}

	#aboutHeader ul li a {
		font-size: 1.6rem;
	}

	#aboutHeader ul li a::after {
		width: 37px;
		height: 37px;
	}

	#aboutHeader ul li:nth-child(3) {
		border-right: 1px solid #c3c3c3;
	}

	/* greeting */
	/* ----------------------------------- */
	#greeting {
		margin-bottom: 80px;
	}

	#aboutGreetingImage {

	}

	#aboutGreetingImageName {
		top: auto;
		bottom: 10%;
		transform: translateY(0);
	}

	#aboutGreetingImageName {
		padding: 20px 50px;
	}

	#aboutGreetingImageName h3 {
		width: 100%;
		display: flex;
		align-items: flex-start;
		flex-direction: column;
		gap: 5px;
	}

	#aboutGreetingImageName h3 .name {
		font-size: clamp(2.4rem, 5vw, 3.4rem);
	}

	#aboutGreetingImageName h3 .job {
		font-size: clamp(1.4rem, 2.2vw, 1.8rem);
	}

	#aboutGreetingText h4 {
		margin-bottom: 25px;
	}

	#aboutGreetingText p {
		font-size: 1.6rem;
		margin-top: 15px;
		line-height: 1.85;
	}

	#aboutGreetingImage {
		margin-bottom: 50px;
	}

	/* overView */
	/* ----------------------------------- */
	#overView {
		margin-bottom: 80px;
	}

	#overView h2 {
		margin-bottom: 40px;
	}

	.aboutTable th {
		width: 150px;
		border: 1px solid #d2d7da;
		background: #eaf1f5;
		text-align: left;
		padding-left: 12px;
		font-size: 1.7rem;
		font-weight: bold;
		vertical-align: middle;
		line-height: 1;
	}

	.aboutTable td {
		width: calc(100% - 150px);
		border: 1px solid #d2d7da;
		padding-top: 22px;
		padding-bottom: 22px;
		padding-left: 20px;
		font-size: 1.5rem;
	}

	/* access */
	/* ----------------------------------- */
	#access {
		margin-bottom: 80px;
	}

	.accessMapTitle {
		font-size: 2.4rem;
		font-weight: 600;
	}

	.accessMapWrap {
		position: absolute;
		width: 100%;
		height: 100%;
	}

	.accessMapWrap iframe {
		width: 100%;
		height: 100%;
	}

	.accessInfo span {
		font-size: 1.6rem;
	}

	.accessProcess {
		padding: 12px;
		background: rgba(234, 241, 245, 0.8);
	}

	.accessProcess h4 {
		font-size: 1.4rem;
		font-weight: bold;
	}

	.accessProcess span {
		font-size: 1.4rem;
		letter-spacing: .075em;
		display: block;
	}

	/*  history*/
	/* ----------------------------------- */
	#history {
		margin-bottom: 80px;
	}

	#historyList ul li p {
		font-size: 1.8rem;
		padding: 24px;
		width: calc(100% - 120px);
	}

	#historyList .historyDetail {
		font-size: 1.6rem;
	}

	/* works */
	/* ----------------------------------- */
	#works h2 {
		margin-bottom: 40px;
	}
}

/* -------------------------------------------------- */
/* TAB(調整) */
/* -------------------------------------------------- */
/* -------------------------------------------------- */
/* SP(調整) */
/* -------------------------------------------------- */
@media screen and (max-width: 767px) {
	#about {
		padding-bottom: 60px;
	}

	#aboutHeader {
		padding-top: 40px;
		margin-bottom: 60px;
	}

	#aboutHeader ul {
		grid-template-columns: 1fr 1fr;
	}

	#aboutHeader ul li:nth-child(3) {
		border-right: 0;
	}

	#aboutHeader ul li:nth-child(even) {
		border-right: 1px solid #c3c3c3;
	}

	#aboutHeader ul li a {
		font-size: clamp(1.4rem, 1vw, 1.6rem);
		text-align: left;
		padding-left: 16px;
	}

	.aboutTable table {
		width: 100%;
		border: 1px solid #d2d7da;
		display: block;
	}

	.aboutTable tbody {
		width: 100%;
		display: block;
	}

	.aboutTable tr {
		display: block;
		width: 100%;
	}

	.aboutTable th {
		width: 100%;
		height: 60px;
		padding-left: 16px;
		font-size: 1.6rem;
		line-height: 1.4;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	.aboutTable td {
		width: 100%;
		padding-left: 16px;
		font-size: 1.5rem;
		display: block;
	}

	/* greeting */
	/* ----------------------------------- */
	#greeting {
		margin-bottom: 60px;
	}

	#greeting h2 {
		margin-bottom: 30px;
	}

	#aboutGreetingImage {
		margin-bottom: 20px;
	}

	#aboutGreetingImageName {
		top: auto;
		bottom: 10%;
		transform: translateY(0);
	}

	#aboutGreetingText h4 {
		margin-bottom: 20px;
	}

	.aboutContentTitle {
		font-size: clamp(2.6rem, 4.7vw, 3.6rem);
		margin-bottom: 0;
	}

	#aboutGreetingText {
		margin-top: 20px;
	}

	#aboutGreetingImageName {
		padding: 15px 40px;
	}

	/* overView */
	/* ----------------------------------- */
	#overView {
		margin-bottom: 60px;
	}

	#overView h2 {
		margin-bottom: 30px;
	}

	#overViewTableHeaderPartner p {
		width: 220px;
		line-height: 1;
	}

	#overViewTableHeaderPartner p::after {
		left: inherit;
		right: 0;
		top: 50%;
		bottom: inherit;
		transform: translateY(-50%);
		font-size: 1.4rem;
		position: absolute;
		line-height: 1;
	}

	.aboutTable th {
		padding-left: 15px;
	}

	.aboutTable td {
		padding: 15px;
		font-size: 1.4rem;
	}

	.overViewBusinessContentTitle {
		font-weight: bold;
	}

	#overViewTableRegalDlBtn {
		width: 100%;
		text-align: center;
	}

	/* access */
	/* ----------------------------------- */
	#access {
		margin-bottom: 60px;
	}

	#access h2 {
		margin-bottom: 30px;
	}

	.accessMap {
		margin-bottom: 10px;
	}

	.accessMapTitle {
		margin-bottom: 10px;
		font-size: 2rem;
	}

	#accessItems {
		gap: 40px;
		display: grid;
		grid-template-columns: 1fr;
	}

	.accessItem {
		width: 100%;
	}

	.accessInfo {
		margin-bottom: 10px;
	}

	.accessInfo span {
		font-size: 1.5rem;
	}

	/* history */
	/* ----------------------------------- */
	#history {
		margin-bottom: 60px;
	}

	#history h2 {
		margin-bottom: 30px;
	}

	#historyList {
		margin-top: 32px;
	}

	#historyList ul li span {
		width: 100%;
		font-size: 1.8rem;
		font-weight: 400;
		display: grid;
		place-content: center;
	}

	#historyList ul li p {
		padding: 8px 16px;
		font-size: 1.4rem;
		width: calc(100% - 25%);
	}

	#historyList ul li {
		font-size: 1.4rem;
		flex-direction: column;
	}

	#historyList .year {
		width: 100%;
	}

	#historyList .historyDetail {
		width: 100%;
		padding: 20px 4%;
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
		font-size: 1.4rem;
	}

	#historyList .historyDetail .date {
		width: auto;
		text-align: left;
	}

	#historyList .historyDetail.addImg {
		display: flex;
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: flex-start;
		flex-direction: column;
	}

	#historyList .historyDetail .eventWrap {
		flex-direction: column;
		gap: 10px;
	}

	#historyList ul li span {
		font-size: 1.4rem;
		display: block;
	}

	.historyDetail img {
		width: 100%;
		height: auto;
	}
}
