@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;500;600;700&display=swap');

html { scroll-behavior: smooth; }
body {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 14px;
	line-height: 1.75;
	color: #000;
	background: #fff url(../images/bg.svg) top center repeat;
	background-size: 100% auto;
	margin: 0;
	padding: 0;
	position: relative;
	text-align: center;
}

* {
	font-size: 1em;
	box-sizing: border-box;
	background-size: contain;
}

html, body, p, h1, h2, h3, h4, h5, ul, ol, li, dd, dl, dt, div {
	padding: 0;
	margin: 0;
	font-weight: 500;
}

img {
	border: 0;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	vertical-align:top;
	max-width: 100%;
}

html { height: 100%; }
li { list-style-type: none; }
a {
	color: inherit;
	text-decoration: none;
}
a.underline,
.underline a { text-decoration: underline; }
.none { display: none; }
.sp { display: none; }
.pc { display: block; }

/* for modern brouser */
.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	line-height: 0;
	font-size: 0;
	visibility: hidden;
}

/* IE7,MacIE5 */
.clearfix { display: inline-block; }

/* WinIE6 below, Exclude MacIE5 \*/
* html .clearfix { height: 1%; }
.clearfix { display: block; }
.tcenter { text-align: center; }
.tright { text-align: right; }

/* 選択色 */
::selection {
	color: #fff;
	background: #ea609e;
}

::-moz-selection {
	color: #fff;
	background: #ea609e;
}

/* header */
header {
	display: grid;
	grid-gap: 0.5em;
	grid-template-columns: 1fr 2fr;
	padding: 1em 2em;
	width: 100%;
	background: #ea609e;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 99;
}
header h1 { text-align: left; }
header img {
	width: 50%;
	max-width: 150px;
}

.scrolled {
    background: rgba(0,0,0,0.85);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
}

ul.menu {
	display: flex;
	align-items: flex-end;
	justify-content: end;
}
ul.menu li {
	display: inline-block;
	padding-left: 1.5em;
	font-weight: 700;
	font-size: 1.2em;
	color: #fff;
}
ul.menu li.slash {
	color: #ccc;
	font-weight: 300;
}

main {
	margin: 0 auto;
	padding: 8em 0 0;
}
main h1 { margin-bottom: 4em; }
main h1 img {
	width: 80%;
	max-width: 900px;
}
main h2.logo { margin: -25em auto 3em; }
main h2.logo img {
	width: 70%;
	max-width: 600px;
	filter: drop-shadow(0.25em 0.25em 0.125em rgb(0, 0, 0, 1));
}
.yoyakuBtn img {
	width: 60%;
	max-width: 350px;
}

section { padding: 2em; }

/* NEWS LIST */
ul.news {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	z-index: 2;
	padding: 0;
	border-bottom: #ea609e dashed 1px;
}
ul.news li {
	padding: 1em;
	border-bottom: #ea609e dashed 1px;
	color: #000;
	font-size: 1.25em;
	display: grid;
	grid-gap: 0;
	grid-template-columns: 5em 1fr;
	background: rgba(255,255,255,0.75);
}
ul.news li:last-child { border: 0; }
ul.news li p {
	display: inline-block;
	vertical-align: middle;
	text-align: center;
}
ul.news li p:last-child {
	text-align: left;
}
ul.news li p:first-child {
	color: #ea609e;
	text-align: left;
}
ul.news li p:first-child span {
	display: block;
	width: 100%;
	font-size: 0.75em;
}
ul.news li a {
	color: #000;
	text-decoration: underline;
}
ul.news li a:hover {
	color: #fff;
	background: #ea609e;
}

.newsTTL {
	width: 100%;
	max-width: 1000px;
	height: 3.5em;
	margin: 0 auto;
	padding: 0;	
	border-bottom: #ea609e dashed 1px;
	display: grid;
	grid-gap: 0;
	grid-template-columns: 1fr 3fr;
}
.newsTTL p:first-child {
	color: #000;
	padding: 0;
	font-weight: 700;
	text-align: left;
}
.newsTTL p:first-child img { height: 2.5em; }
.newsTTL p:last-child {
	text-align: right;
}
.newsTTL p:last-child span {
	background: #ea609e;
	color: #fff;
	padding: 0.4em 1em 0.25em;
	font-weight: 700;
	font-size: 1.25em;
}
.newsTTL p:last-child span small { font-size: 0.8em; }
.newsTTL p:last-child span strong { font-size: 1.25em; }

.viewAll {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	text-align: right;
	padding: 1em;
}
.viewAll img { height: 1.25em; }

/* CD */
#cd { text-align: left; }
#cd h2.ttl {
	text-align: center;
	padding: 0 1em 1em 1em;
}
#cd h2.ttl img { height: 2em; }
.cd1Box {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 2em;
	padding: 1em;
	display: grid;
	grid-gap: 1em;
	grid-template-columns: 1.415fr 1fr;
	background: rgba(255,255,255,0.75);
}
#cd .jkt { margin-bottom: 1em; }
#cd .jkt img {	border: #ea609e solid 1px; }
#cd h2 {
	font-size: 1.5em;
	font-weight: bold;
}
#cd h2 span { font-size: 0.7em; }
#cd h3 {
	display: inline-block;
	margin-top: 1em;
	font-size: 1.15em;
	font-weight: bold;
	padding: 0.125em 0.5em;
	background: #ea609e;
	color: #fff;
}
#cd ol li {
	display: inline-block;
	margin-right: 0.5em;
}
#cd ol li span { color: #ea609e; }
#cd h4 {
	display: inline-block;
	margin-top: 1em;
	font-size: 1.15em;
	font-weight: bold;
}
#cd ul li {
	list-style:none;
	padding: 0 0 0 1em;
	text-indent: -1em;
	font-size: 0.8em;
	line-height: 1.75em;
	display: block;
	text-align: left;
}
#cd ul li:before { content:"・" }

.cd2Box {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 2em;
	padding: 0;
	display: grid;
	grid-gap: 1em;
	grid-template-columns: 1fr 1fr;
}
.cd2Box .jkt img { width: auto; max-width: auto; height: 23em; }

.cd3Box {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 2em;
	padding: 1em;
	border-bottom: #ccc solid 1px;
	background: rgba(255,255,255,0.75);
}
.cd3Box.noLine { border: 0; }
.cd3Box .soloCD {
	display: grid;
	grid-gap: 1em;
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}
#cd .cd3Box h2 {
	text-align: left;
	font-size: 1.25em;
}
#cd .cd3Box h2.ttl {
	display: inline-block;
	background: #ea609e;
	color: #fff;
	padding: 0.25em 0.5em;
	margin-bottom: 0.5em;
}

/* footer */
footer {
	background: #ea609e;
	color: #fff;
	font-size: 0.75em;
	text-align: center;
	padding: 2em;
}

.anchor {
	margin-top: -7em;
	padding-top: 7em;
}

.yellow { color: #ea609e; }
@media all and (max-width: 1200px) {
	main h2.logo { margin: -30vw auto 3em; }
}
@media all and (max-width: 736px) {
	.sp { display: block; }
	.pc { display: none; }
	body { font-size: 3vw; }

	header { padding: 1em; }
	header img {
		width: 20vw;
		max-width: 20vw;
	}
	ul.menu li { padding-left: 0.5em; font-size: 1.2em; }
	main { padding: 6em 3em 3em; }
	main h1 img { max-width: 100%; width: 100%; }
	main h2.logo { margin: -35vw auto 3em; }

	section { padding: 1em; }

	/* NEWS */
	ul.news li {
		font-size: 1em;
		grid-template-columns: 5em 1fr;
	}
	.newsTTL { height: 3em; }
	.newsTTL p:last-child { padding-top: 0; }
	.newsTTL p:last-child span { font-size: 3vw; }

	/* CD */
	#cd h2.ttl img { height: 1.5em; }
	.cd1Box, .cd2Box { grid-template-columns: 1fr; }
	#cd .jkt img { width: 100%; max-width: 100%; height: auto; }
	.cd3Box .soloCD { grid-template-columns: 1fr 1fr; }
}
::-webkit-full-page-media, :future, :root main { height: auto; }

/* Camera Flash Effect */
.flash-container {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: -1;
	overflow: hidden;
}

.flash-item {
	position: absolute;
	width: 250px;
	height: 250px;
	opacity: 0;
	animation: cameraFlash 0.4s ease-out forwards;
}

.flash-item img {
	width: 100%;
	height: 100%;
}

@keyframes cameraFlash {
	0% {
		opacity: 0;
		transform: scale(0.3) rotate(0deg);
	}

	15% {
		opacity: 1;
		transform: scale(1.2) rotate(15deg);
	}

	30% {
		opacity: 0.9;
		transform: scale(1) rotate(-5deg);
	}

	60% {
		opacity: 0.5;
		transform: scale(0.9) rotate(5deg);
	}

	100% {
		opacity: 0;
		transform: scale(0.6) rotate(0deg);
	}
}

a.btn {
	font-weight: 700;
	line-height: 1.5;
	position: relative;
	display: inline-block;
	padding: 0.5rem 1.5rem;
	cursor: pointer;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	border-radius: 100vh;
	background-color: #ea609e;
	color: #fff;
}
.kome {
	margin: 0.5em;
	padding: 1em;
	border: #ea609e solid 1px;
	font-size: 0.85em;
	background: #fff;
}
#cd ol.kome li {
	display:block;
	list-style: none;
	text-indent: -1em;
	margin-left: 1em;
}