@charset "UTF-8";

.cmn_intro .table td {
	font-weight: normal;
	width: calc(100% - 105px);
}

.cmn_intro .table td em {
	font-weight: bold;
}

.main > .img {
	overflow: hidden;
	position: relative;
}

.main > .img #border_01 {
	left: -217px;
	mix-blend-mode: overlay;
	position: absolute;
	top: -94px;
	width: auto;
}

.main > .img #border_02 {
	bottom: -91px;
	mix-blend-mode: overlay;
	position: absolute;
	right: -206px;
	width: auto;
}

.main > .img .cmn_ttl_94 {
	bottom: -24px;
	left: calc(50vw - 580px);
	line-height: 0;
	position: absolute;
}

.photo_photos {
	margin-top: 69px;
	padding-right: 21vw;
	position: relative;
	width: 100%;
}

.photo_photos .photos {
	display: flex;
	gap: 4vw;
}

.photo_photos .photos .photo01 {
	width: 67.5vw;
}

.photo_photos .photos .photo02 {
	margin-top: 17.5vw;
	position: relative;
	width: 25vw;
}

.photo_photos .photo01 .cmn_ttl_94 {
	line-height: 1;
	position: absolute;
	top: 21vw;
}

.cmn_intro:not(:first-of-type) {
	margin-top: 137px;
}

.flow {
	margin-top: 183px;
	position: relative;
}

.flow_hd {
	line-height: 1;
	position: absolute;
	top: -64px;
	z-index: 1;
}

.profile_wrap {
	padding-top: 68px;
	position: relative;
}

.profile_wrap .img {
	left: 0;
	position: absolute;
	top: 0;
	width: 218px;
	z-index: 1;
}

.profile_wrap .profile_hd {
	margin-bottom: 32px;
}

.profile_wrap .profile_btn {
	background-color: #000000;
	border: none;
	border-radius: 3px;
	height: 59px;
	margin-top: 21px;
	max-width: 330px;
	width: 100%;
}

.profile_wrap .profile_btn span {
	background: center right / 14px auto no-repeat url(../img/cmn/img-ic-arrow-down-w.svg);
	color: #ffffff;
	font-size: 18px;
	padding-right: 26px;
}

.profile_wrap .profile_block {
	background-color: #e4e4e4;
	margin-left: 50px;
	padding: 78px 147px 74px 242px;
	position: relative;
}

.profile_block .cmn_btn {
	display: none;
}

.profile_block table th {
	text-align: left;
	width: 124px;
}

.profile_block table th,
.profile_block table td {
	font-size: 16px;
	font-weight: bold;
	line-height: 2.5;
}

@media screen and (max-width:767px) {
	.cmn_intro .table th {
		width: 105px;
	}

	.cmn_intro .table td {
		font-weight: normal;
		width: calc(100% - 105px);
	}

	.cmn_intro .table td em {
		font-weight: bold;
	}

	.cmn_intro .cmn_btn a {
		max-width: 100%;
		width: 100%;
	}

	.main > .img {
		height: 112vw;
		position: relative;
	}

	.main > .img #border_01 {
		height: auto;
		left: -116px;
		top: -40px;
		width: 85%;
	}

	.main > .img #border_02 {
		bottom: -40px;
		height: auto;
		right: -100px;
		width: 95%;
	}

	.main > .img img {
		height: 100%;
		object-fit: cover;
	}

	.main > .img .cmn_ttl_94 {
		bottom: -24px;
		left: calc(50vw - 580px);
		line-height: 0;
		position: absolute;
	}

	.photo_photos {
		margin-top: 69px;
		padding-right: 21vw;
		position: relative;
		width: 100%;
	}

	.photo_photos .photos {
		display: flex;
		gap: 4vw;
	}

	.photo_photos .photos .photo01 {
		width: 67.5vw;
	}

	.photo_photos .photos .photo02 {
		margin-top: 17.5vw;
		position: relative;
		width: 25vw;
	}

	.photo_photos .photo01 .cmn_ttl_94 {
		line-height: 1;
		position: absolute;
		top: 21vw;
	}

	.cmn_intro:not(:first-of-type) {
		margin-top: 42px;
	}

	.flow {
		margin-top: 64px;
		position: relative;
	}

	.flow_hd {
		line-height: 1;
		position: absolute;
		top: -64px;
		z-index: 1;
	}

	.profile_wrap {
		padding-top: 68px;
		position: relative;
	}

	.profile_wrap .img {
		left: 0;
		position: absolute;
		top: 0;
		width: 132px;
		z-index: 1;
	}

	.profile_wrap .profile_hd {
		margin-bottom: 32px;
		padding-left: 157px;
	}

	.profile_wrap .profile_btn {
		background-color: #000000;
		border: none;
		border-radius: 3px;
		height: 59px;
		margin-top: 21px;
		max-width: 100%;
		width: 100%;
	}

	.profile_wrap .profile_btn span {
		background: center right / 14px auto no-repeat url(../img/cmn/img-ic-arrow-down-w.svg);
		color: #ffffff;
		font-size: 18px;
		padding-right: 26px;
	}

	.profile_wrap .profile_block {
		background-color: #e4e4e4;
		margin-left: -7.2vw;
		padding: 63px 7.2vw 74px 7.2vw;
		position: relative;
		width: 100vw;
	}

	.profile_block .cmn_btn {
		display: block;
	}

	.profile_block .cmn_btn a {
		max-width: 100%;
		width: 100%;
	}

	.profile_block .cmn_btn span {
		background-image: url(../img/cmn/img-ic-arrow-down-w.svg);
	}

	@media (hover:hover) {
		.profile_block .cmn_btn a:hover span {
			background-image: url(../img/cmn/img-ic-arrow-down-b.svg);
		}
	}

	.profile_block .profile_table_wrap {
		display: none;
	}

	.profile_block table th {
		display: block;
		text-align: left;
		width: 100%;
	}

	.profile_block table td {
		display: block;
	}

	.profile_block table th,
	.profile_block table td {
		font-size: 16px;
		font-weight: bold;
		line-height: 2.5;
	}

	.flow_map .map {
		margin-bottom: 32px;
		overflow-x: scroll;
	}

	.flow_map .cmn_btn a {
		max-width: 100%;
		width: 100%;
	}
}