main {
	background-color: #fcd88d;
	position: relative;
}

main::before {
	content: '';
	width: 100%;
	aspect-ratio: 1500/520;
	background-color: white;
	position: absolute;
	top: 0;
	left: 0;
}

.main_content {
	position: relative;
}

.main_img {
	width: 76%;
	aspect-ratio: 1140/655;
	border-radius: 0 calc(76vw * 0.08772);
	overflow: hidden;
	margin: 0 auto;
}

.main_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.detail_wrap {
	max-width: 870px;
	width: 90%;
	margin: 90px auto 0;
	padding-bottom: 150px;
}

.ttl_block {
	padding-bottom: 25px;
}

.ttl_block .genre {
	display: inline-flex;
	align-items: center;
	height: 24px;
	font-size: 16px;
	line-height: 1;
	padding: 0 10px;
}

.chuyo .ttl_block {
	border-bottom: solid 2px #83ccd2;
}
.toyo .ttl_block {
	border-bottom: solid 2px #cb5d6a;
}
.nanyo .ttl_block {
	/* border-bottom: solid 2px #fcd174; */
	border-bottom: solid 2px #f8b100;
}

.chuyo .ttl_block .genre {
	background-color: #83ccd2;
}
.toyo .ttl_block .genre {
	background-color: #cb5d6a;
}
.nanyo .ttl_block .genre {
	/* background-color: #fcd174; */
	background-color: #f8b100;
}

.ttl_block h1 {
	font-size: 28px;
	line-height: 38px;
	margin-top: 5px;
}

.detail_content {
	margin-top: 30px;
}

.detail_content p {
	font-size: 15px;
	line-height: 35px;
}

.detail_content img {
	width: 100%;
	display: block;
	margin: 60px auto 10px;
}

.info_block {
	width: 100%;
	border-radius: 22px 22px 22px 0;
	background-color: white;
	padding: 50px 40px 65px;
	margin-top: 170px;
}

.info_block .info_head {
	display: flex;
	align-items: flex-start;
	gap: 5px;
	font-size: 26px;
	line-height: 36px;
}

.info_block .info_head::before {
	content: '●';
}

.chuyo .info_block .info_head::before {
	color: #83ccd2;
}
.toyo .info_block .info_head::before {
	color: #cb5d6a;
}
.nanyo .info_block .info_head::before {
	/* color: #fcd174; */
	color: #f8b100;
}

.info_block .info_item {
	display: flex;
	align-items: flex-start;
	margin-top: 25px;
	font-size: 16px;
	line-height: 21px;
}

.info_block .info_item + .info_item {
	margin-top: 15px;
}

.info_block .info_item .item_head {
	width: 300px;
}

.info_block .info_item .item_content {
	width: calc(100% - 205px);
	word-break: break-all;
}

.info_block .map_block {
	margin-top: 15px;
}

.info_block .map_block .block_head {
	font-size: 16px;
	line-height: 21px;
}

.info_block .map_block .note {
	font-size: 14px;
	text-align: right;
	line-height: 20px;
	margin-top: 20px;
}

.info_block .map_block iframe {
	width: 100%;
	aspect-ratio: 790/530;
	margin-top: 10px;
}

@media screen and (max-width: 1500px) {
	main::before {
		aspect-ratio: none;
		height: 520px;
	}

	.main_img {
		max-width: 1140px;
		border-radius: 0 100px;
		width: 90%;
	}
}

@media screen and (max-width: 1265px) {
	main::before {
		aspect-ratio: 1265/520;
		height: auto;
	}
}

@media screen and (max-width: 1000px) {
	.main_img {
		border-radius: 0 70px;
	}

	.detail_wrap {
		margin-top: 60px;
	}
}

@media screen and (max-width: 800px) {
	.info_block .info_item {
		flex-wrap: wrap;
		gap: 5px;
	}

	.info_block .info_item .item_head,
	.info_block .info_item .item_content {
		width: 100%;
	}

	.info_block .info_item + .info_item {
		margin-top: 20px;
	}
}

@media screen and (max-width: 600px) {
	.main_img {
		border-radius: 0 40px;
		width: calc(100% - 30px);
	}

	.detail_wrap {
		margin-top: 40px;
		padding-bottom: 100px;
		width: calc(100% - 30px);
	}

	.ttl_block {
		padding-bottom: 20px;
	}

	.ttl_block .genre {
		font-size: 14px;
	}

	.ttl_block h1 {
		font-size: 22px;
		line-height: 30px;
	}

	.detail_content {
		margin-top: 25px;
	}

	.detail_content p {
		font-size: 14px;
		line-height: 26px;
		letter-spacing: 1px;
	}

	.info_block {
		margin-top: 100px;
		padding: 40px 25px 50px;
	}

	.info_block .info_head {
		font-size: 20px;
		line-height: 28px;
	}

	.info_block .info_item {
		font-size: 14px;
	}

	.info_block .map_block iframe {
		aspect-ratio: 4/5;
	}
}
