@charset "utf-8";

/* CSS INFORMATION -====================================================
File name : music.css
Description : 主題歌
===================================================================== */

.music {
	padding: calc(100 / 750 * 100%) 0 calc(140 / 750 * 100%);
}

.music::before {
	content: "";
	display: block;
	width: calc(233 / 750 * 100%);
	padding-top: calc(596 / 750 * 100%);
	background: url(../images/music/bg_deco1.webp) no-repeat left top;
	background-size: cover;
	position: absolute;
	top: 0;
	right: 0;
	margin: calc(-35 / 750 * 100%) 0 0;
}

.music::after {
	content: "";
	display: block;
	width: calc(247 / 750 * 100%);
	padding-top: calc(614 / 750 * 100%);
	background: url(../images/music/bg_deco2.webp) no-repeat center top;
	background-size: cover;
	position: absolute;
	bottom: 0;
	margin: 0 0 calc(-20/ 750 * 100%);
	z-index: 1;
}

.music .inner {
	z-index: 2;
}

.music_img {
	margin-bottom: calc(35 / 650 * 100%);
}

.music_txt {
	text-align: center;
	margin-bottom: calc(70 / 650 * 100%);
	color: #63596a;
	font-family: YuGothic, "Yu Gothic Medium", "Yu Gothic", sans-serif;
}

.music_ttl {
	font-size: 3.6rem;
	font-weight: bold;
	margin-bottom: .3em;
}

.music_author {
	font-size: 2.8rem;
}

.music_comment {
	background-color: #f5f5f5;
	padding: calc(50 / 650 * 100%) calc(60 / 650 * 100%) calc(80 / 650 * 100%);
}

.music_comment_ttl {
	position: absolute;
	top: 0;
	left: 0;
	width: calc(157 / 650 * 100%);
	margin: calc(-20 / 650 * 100%) 0 0 calc(60 / 650 * 100%);
}

.music_comment dl {
	line-height: 1.833;
	letter-spacing: -.05rem;
}

.music_comment dl:not(:last-child) {
	margin-bottom: 2.5em;
}

.music_comment dt {
	font-weight: bold;
	color: #a065ff;
}

.btn_music {
	margin-top: calc(60 / 650 * 100%);
}

@media screen and (min-width: 768px) {

	.music {
		padding: calc(120 / 1400 * 100%) 0 calc(190 / 1400 * 100%);
	}

	.music::before {
		width: calc(233 / 1400 * 100%);
		padding-top: calc(596 / 1400 * 100%);
		margin: calc(-30 / 1400 * 100%) 0 0;
		background-size: contain;
	}

	.music::after {
		width: calc(247 / 1400 * 100%);
		padding-top: calc(614 / 1400 * 100%);
		margin: 0 0 calc(-20 / 1400 * 100%);
		background-size: contain;
	}

	.music_img {
		width: calc(680 / 1200 * 100%);
		margin: 0 auto calc(50 / 1200 * 100%);
	}

	.music_txt {
		margin-bottom: calc(70 / 1200 * 100%);
	}

	.music_ttl {
		font-size: 2.6rem;
	}

	.music_author {
		font-size: 1.8rem;
	}

	.music_comment {
		width: calc(1000 / 1200 * 100%);
		margin: 0 auto;
		padding: calc(55 / 1200 * 100%) calc(100 / 1200 * 100%) calc(60 / 1200 * 100%);
	}

	.music_comment_ttl {
		width: calc(157 / 1000 * 100%);
		margin: calc(-15 / 1000 * 100%) 0 0 calc(100 / 1000 * 100%);
	}

	.music_comment dl {
		line-height: 2;
	}

	.btn_music {
		margin-top: calc(80 / 1000 * 100%);
	}

}

@media screen and (min-width: 1400px) {
	.music {
		padding: 120px 0 190px;
	}

	.music::before {
		width: 233px;
		padding-top: 596px;
		margin: -30px 0 0;
	}

	.music::after {
		width: 247px;
		padding-top: 614px;
		margin: 0 0 -20px;
	}
}
