@charset "utf-8";

/* ---------------------------------- */
/*				TOP				  */
/* ---------------------------------- */
#mv {
	position: relative;
}

@media screen and (max-width: 599px) {
#mv .img {
	top: 0;
	left: 0;
	//height: 67vh;
	//background-image: url(../img/mv_sp.jpg);
	//background-size: cover;
	//background-repeat: no-repeat;
	position: relative;
	z-index: 1;
	//opacity: 1;
}
}

@media screen and (min-width: 600px) and (max-width: 1024px) {
	#mv .img {
	top: 0;
	left: 0;
	//background-image: url(../img/mv.jpg);
	//background-size: 100%;
	position: relative;
	z-index: 1;
	//opacity: 1;
}	
}

@media screen and (min-width: 1025px) {
#mv .img {
	top: 0;
	left: 0;
	//background-image: url(../img/mv.jpg);
	//background-size: 100%;
	position: relative;
	z-index: 1;
	opacity: 1;
}
}

#mv .img img {
	//opacity: 0;
	//display: block;
}

#mv .logo {
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 262px;
	height: 262px;
	margin: auto auto;
	position: absolute;
	z-index: 2;
	opacity: 0;
}

#main .contents {
	padding: 200px 0 100px 0;
	background-color: #edefef;
	background-image: url(../img/contents_bg.jpg);
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 100%;
	margin-top:-5px;
}

#comment {
	border: solid 2px #516987;
	width: 770px;
	margin: 0 auto 45px;
	padding: 30px;
}

#desc p {
	line-height: 2;
	margin: 0 0 80px 0;
}

#desc .logo {
}

#desc .logo img {
	width: 538px;
}

#main h2 {
	font-size: 36px;
	margin: 0 0 75px 0;
}

#menu {
	/*padding: 20px 0 170px 0;*/
	padding: 1em 0 0 0 ;
}

#menu a {
	color: #112e53;
}

#menu a:hover {
	text-decoration: none;
}

#menu ul {
	width: 770px;
	margin: 0 auto;
}

#menu ul:after {
	content: "";
	clear: both;
	display: block;
}

#menu ul li {
	width: 360px;
}

#menu ul li img {
	margin: 0 0 40px 0;
	display: block;
	-webkit-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-moz-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-o-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
}

#menu a:hover img {
	-webkit-filter: brightness(110%);
	-moz-filter: brightness(110%);
	-o-filter: brightness(110%);
	filter: brightness(110%);
}

#menu ul li .tit {
	font-size: 1.3rem;
	font-style: oblique;
	margin: 0 0 20px 0;
	display: block;
	position: relative;
}

#menu ul li .newstit {
	font-size: 1.3rem;
	font-style: oblique;
	margin: 0 0 20px 0;
	display: block;
	position: relative;
}


#menu ul li .tit::after {
	content: "";
	width: 18px;
	height: 1px;
	margin: 10px auto 0 auto;
	background-color: #112e53;
	display: block;
	z-index: -1;
	-webkit-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-moz-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-o-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
}

#menu ul li .newstit::after {
	content: "";
	width: 18px;
	height: 1px;
	margin: 10px auto 0 auto;
	background-color: #112e53;
	display: block;
	z-index: -1;
	-webkit-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-moz-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-o-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
}


#menu a:hover .tit::after {
	-webkit-transform: scaleX(2.7);  
	-moz-transform: scaleX(2.7);
	transform: scaleX(2.7);
}

#menu ul li .kana {
	font-size: 12px;
	display: block;
}

#menu ul li .read {
	/*font-size: 13px;*/
	display: block;
	line-height: 2;
	text-align: center;
	padding-top: 1rem;
}


#menu ul li:nth-child(1) {
	float: left;
	margin: 0 0 50px 0;
}

#menu ul li:nth-child(2) {
	float: right;
	margin: 0 0 50px 0;
}

#menu ul li:nth-child(3) {
	float: left;
	margin: 0 0 50px 0;
}

#menu ul li:nth-child(4) {
	float: right;
	margin: 0 0 50px 0;
}

#menu ul li:nth-child(5) {
	float: left;
}

#menu ul li:nth-child(6) {
	float: right;
}





#menu .flex{
display: flex;
width:100%;

justify-content: center;
}
#menu .flex_item{
display: flex;
max-width:45%;


}
#menu .flex_read{
display: flex;
width:45%;
align-items: center;
/*font-style: oblique;*/
/*display: block;
position: relative;*/
font-size: 13px;
line-height: 2;
text-align: left;
}

#menu .flex_read_tit{
font-size: 1.1rem;
}

@media screen and (max-width: 640px) {
#menu .flex{
display: flex;
width:100%;
flex-direction: column;

}
#menu .flex_item{
display: flex;
width:auto;

}
#menu .flex_read{
display: flex;
width:50%;

}
#menu .flex_read_tit{
font-size: 1.1rem;
}

#menu ul li .newstit {
	font-size: 1rem;
	font-style: oblique;
	margin: 0 0 20px 0;
	display: block;
	position: relative;
}
}



#movie,
#taikenkai{
	padding: 3em 0 0 0;
	/*padding: 20px 0 0 0;*/
}

#taikenkai .mov {
	width: 770px;
	height: 435px;
	margin: 0 auto 110px auto;
	background-color: #a0a0a0;
	display: block;
}

#movie p,
#taikenkai p{
	font-size: 18px;
	line-height: 2;
	margin: 0 0 45px 0;
}

#taikenkai {
	border: solid 2px #516987;
	width: 770px;
	margin: 0 auto 45px;
	padding: 30px;
}

#taikenkai h3 {
	font-size: 24px;
	font-weight: bold;
	line-height: 1.6;
	border-bottom: dotted 2px #516987;
	margin: 0 0 20px;
	padding: 0 0 10px;
}

#taikenkai h3 span {
	font-size: 80%;
}

#taikenkai p {
	margin: 0 0 20px;
}

#taikenkai .tenpo,
#taikenkai ul {
	text-align: left;
	font-size: 16px;
	width: 250px;
	margin: 0 auto;
}

#taikenkai ul {
	line-height: 1.6;
}

#taikenkai .link a {
	color: #fff;
	font-size: 18px;
	width: 500px;
	height: 80px;
	margin: 0 auto;
	background-color: #112e53;
	display: block;
}

#taikenkai .link a span {
	padding: 0 0 0 0;
	margin: 25px auto 0 auto;
	display: inline-block;
	position: relative;
}

#taikenkai .link a span::after {
	content: "";
	left: 0;
	width: 100%;
	height: 2px;
	margin: 10px 0 0 0;
	background-color: #516987;
	display: block;
	position: relative;
	-webkit-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-moz-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-o-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
}

#taikenkai .link a:hover span::after {
	-webkit-transform: scaleX(2.0);  
	-moz-transform: scaleX(2.0);
	transform: scaleX(2.0);
}
@media screen and (max-width: 640px) {
    #taikenkai .link a:hover span::after {
        -webkit-transform: scaleX(1.0);  
        -moz-transform: scaleX(1.0);
        transform: scaleX(1.0);
    }
}

@media screen and (max-width: 1000px) {
	#mv .logo {
		width: 35%;
		height: 58%;
	}
	#comment {
		width: 90%;
	}
	#desc .logo img {
		width: 51%;
	}
	#menu ul {
		width: 90%;
	}
	#menu ul li {
		width: 47%;
	}
	#movie .mov,
    #taikenkai .mov{
		width: 90%;
	}
	#movie .link a,
    #taikenkai .link a{
		width: 90%;
	}
	#taikenkai {
		width: 90%;
	}
}

@media screen and (max-width: 768px) {
	#desc {
		padding: 0 0 50px 0;
	}
    #desc .logo.topimg img {
		width: 90%;
	}
	#menu {
		padding: 0;
	}
	#menu ul li {
		width: 100%;
		margin: 0 0 70px 0;
		float: none;
	}
	#menu ul li img {
		margin: 0 0 30px 0;
	}
	#main .contents {
		padding: 80px 0 80px 0;
		//margin-top: -1rem;
	}
	#desc p {
		margin: 0 0 40px 0;
		font-size: 14px;
	}
}

@media screen and (max-width: 640px) {
	#main h2 {
	font-size: 28px;
		margin: 0 0 40px 0;
	}
	#comment {
		padding: 20px;
	}
	#menu ul li .read {
		font-size: 13px;
		display: block;
		line-height: 2;
		text-align: center;
		padding-top: 1rem;
	}
	#movie p,
    #taikenkai p{
		font-size: 15px;
	}
	#movie .mov,
    #taikenkai .mov    {
		margin: 0 auto 60px auto;
	}

	#taikenkai {
		padding: 20px;
	}
	#taikenkai h3 {
		font-size: 20px;
	}
	#taikenkai p {
		margin: 0 0 15px;
	}
	#taikenkai .tenpo,
	#taikenkai ul {
		font-size: 14px;
		width: 200px;
	}

}

@media screen and (max-width: 420px) {
	#comment {
		padding: 20px 15px;
	}
	#movie p,
    #taikenkai p{
		font-size: 12px;
	}
	#taikenkai {
		padding: 20px 15px;
	}
	#taikenkai h3 {
		font-size: 16px;
	}
	#taikenkai p {
		margin: 0 0 12px;
	}
	#taikenkai .tenpo,
	#taikenkai ul {
		font-size: 12px;
	}
}

@media screen and (max-width: 340px) {
	#comment {
		padding: 15px 10px;
	}
	#movie p,
    #taikenkai p{
		font-size: 10px;
	}
	#taikenkai {
		padding: 15px 10px;
	}
	#taikenkai h3 {
		font-size: 14px;
	}
	#taikenkai .tenpo,
	#taikenkai ul {
		font-size: 10px;
		width: 160px;
	}
}


/* 201809 reglia_project */

#sleep_project {
	padding: 0 0 170px 0;
	/*	padding: 20px 0 170px 0;*/
}

#sleep_project a {
	color: #112e53;
}

#sleep_project .item_lead{
	padding: 1em 2em;
    line-height: 2;
    margin: -4em 0 2em;
}


#sleep_project a:hover {
	text-decoration: none;
}

#sleep_project ul {
	width: 770px;
	margin: 0 auto;
}

#sleep_project ul:after {
	content: "";
	clear: both;
	display: block;
}

#sleep_project ul li {
	width: 360px;
}

#sleep_project ul li img {
	margin: 0 0 40px 0;
	display: block;
	-webkit-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-moz-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-o-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
}

#sleep_project a:hover img {
	-webkit-filter: brightness(110%);
	-moz-filter: brightness(110%);
	-o-filter: brightness(110%);
	filter: brightness(110%);
}

#sleep_project ul li .tit {
	font-size: 14px;
	/*  font-style: oblique; */
	margin: 0 0 20px 0;
	display: block;
	position: relative;
    line-height: 1.5;
}


#sleep_project ul li .tit span{
	font-size: 12px;
}


#sleep_project a:hover .tit::after {
	-webkit-transform: scaleX(2.7);  
	-moz-transform: scaleX(2.7);
	transform: scaleX(2.7);
}

#sleep_project ul li .kana {
	font-size: 12px;
	display: block;
}

#sleep_project ul li:nth-child(1) {
	float: left;
	margin: 0 0 50px 0;
}

#sleep_project ul li:nth-child(2) {
	float: right;
	margin: 0 0 50px 0;
}

#sleep_project ul li:nth-child(3) {
	float: left;
}

#sleep_project ul li:nth-child(4) {
	float: right;
}

@media screen and (max-width: 1000px) {
	#sleep_project ul {
		width: 90%;
	}
	#sleep_project ul li {
		width: 47%;
	}
}

@media screen and (max-width: 768px) {
	#sleep_project {
		padding: 20px 0 40px 0;
	}
	#sleep_project ul li {
		width: 100%;
		margin: 0 0 70px 0;
		float: none;
	}
	#sleep_project ul li img {
		margin: 0 0 30px 0;
	}
}

/* 201809 reglia_project_music  */

#sleep_project_music {
	padding: 20px 0 170px 0;
}

#sleep_project_music a {
	color: #112e53;
}

#sleep_project_music .item_lead{
	padding: 1em 2em;
    line-height: 2;
    margin: -4em 0 2em;
}


#sleep_project_music a:hover {
	text-decoration: none;
}

#sleep_project_music ul {
	width: 770px;
	margin: 0 auto;
}

#sleep_project_music ul:after {
	content: "";
	clear: both;
	display: block;
}

#sleep_project_music ul li {
	width: 360px;
}

#sleep_project_music ul li.setsumei {
    line-height: 2;
    font-size: 14px;
    text-align: left;
}

#sleep_project_music .cd_list {
    font-size: 12px;
    margin: 2em 0 1em;
    padding-left: 1em;
    text-indent: -1em;
}

#sleep_project_music .time {
    font-size: 11px;
}

#sleep_project_music .music_wrap{
    width:770px;
    background: #f7f7f7;
    border-radius: 10px;
    text-align: center;
    margin: 0 auto;
    padding: 20px 30px 60px;
}


@media screen and (max-width: 1000px) {
    #sleep_project_music .music_wrap {
		width: 90%;
	}
}    

.recommend_btn {
	margin: 0 2em 1em;
	padding: 3em 0 0;
    box-sizing: border-box;
}
.recommend_btn a:hover {
	text-decoration: none;
    color: #fff;
}

.recommend_btn a {
	display: block;
	margin: 0 auto;
	padding: 1em 0 2em;
	background-color: #112e53;
	color: #fff;
	position: relative;
    line-height: 2;
}
.recommend_btn a::after {
	content: "";
	display: block;
	width: 25%;
	height: 1px;
	background-color: #fff;
	opacity: 0.5;
	position: absolute;
	bottom: 0.5em;
	left: 50%;
	transform: translateX(-50%);
	transition: 0.5s;
}
.recommend_btn a:hover::after {
	width: 75%;
	opacity: 1;
	transition: 0.5s;
}

@media only screen and (min-width: 640px) {
	.recommend_btn {
		/*  width: 385px;  */
		margin: 0 auto;
	}
}

@media only screen and (min-width: 960px) {
	.recommend_btn {
		/* width: 385px; */
		margin: 0 auto;
	}
}


#sleep_project_music .music_wrap dl{
    padding:4em 0 1.5em;
}

#sleep_project_music .music_wrap dl dt,
#sleep_project_music .music_wrap dl dd{
    display: inline;
}

#sleep_project_music .cd_title {
    font-size: 12px;
    margin: 0;
    line-height: 2;
}

#sleep_project_music ul li img {
	margin: 0 0 5px 0;
	display: block;
	-webkit-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-moz-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	-o-transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
	transition: all 700ms cubic-bezier(0.19, 1, 0.22, 1);
}

#sleep_project_music a:hover img {
	-webkit-filter: brightness(110%);
	-moz-filter: brightness(110%);
	-o-filter: brightness(110%);
	filter: brightness(110%);
}

#sleep_project_music ul li .tit {
	font-size: 16px;
	/*  font-style: oblique; */
	margin: 0 0 20px 0;
	display: block;
	position: relative;
    line-height: 1.5;
}


#sleep_project_music ul li .tit span{
	font-size: 12px;
}


#sleep_project_music a:hover .tit::after {
	-webkit-transform: scaleX(2.7);  
	-moz-transform: scaleX(2.7);
	transform: scaleX(2.7);
}

#sleep_project_music ul li .kana {
	font-size: 12px;
	display: block;
}

#sleep_project_music ul li:nth-child(1) {
	float: left;
	margin: 0 0 50px 0;
}

#sleep_project_music ul li:nth-child(2) {
	float: right;
	margin: 0 0 50px 0;
}

#sleep_project_music ul li:nth-child(3) {
	float: left;
}

#sleep_project_music ul li:nth-child(4) {
	float: right;
}

@media screen and (max-width: 1000px) {
	#sleep_project_music ul {
		width: 90%;
	}
	#sleep_project_music ul li {
		width: 47%;
	}
}

@media screen and (max-width: 768px) {
	#sleep_project_music {
		padding: 20px 0 170px 0;
	}
	#sleep_project_music ul li {
		width: 100%;
		margin: 0 0 70px 0;
		float: none;
	}
	#sleep_project_music ul li img {
		margin: 0 0 30px 0;
	}
    #sleep_project_music ul li.setsumei {
        line-height: 2;
        font-size: 14px;
        text-align: left;
    }
}

.bnr_bg_ginza {
	padding:20px;
	margin-top:30px;
	margin-bottom:30px;
}
.bnr_bg_ginza a {
	display:block;
}
@media screen and (max-width: 599px) {	
	.bnr_bg_ginza p {
		text-align: left;
		line-height:1.8;
	}
}
@media screen and (min-width: 600px)  and (max-width: 1025px) {
	.bnr_bg_ginza p {
		text-align: center;
		line-height:1.5;
	}
}
@media screen and (min-width: 1025px) {
	.bnr_bg_ginza p {
		text-align: center;
		line-height:1.8;
		font-size:0.9rem;
	}
}


@media only screen and (max-width: 599px) {
	.sp_only {
		display: block !important;
	}
	.tablet_only {
		display: none;
	}
	.pc_only {
		display: none;
	}
	.pc_tablet_only {
		display:none;
	}
}

@media only screen and (min-width: 600px) and (max-width: 1024px) {
	.sp_only {
		display: none;
	}
	.tablet_only {
		display: block;
	}
	.pc_only {
		display: none;
	}
	.pc_tablet_only {
		display:block;
	}
}

@media only screen and (min-width: 1025px) {
	.sp_only {
		display: none;
	}
	.tablet_only {
		display: none;
	}
	.pc_only {
		display: block;
	}
	.pc_tablet_only {
		display:block;
	}
}

/* -----------------------------
	- movie 202307
----------------------------- */
.mbox {
	width: 770px;
	margin: 0 auto 100px auto;
}
@media screen and (max-width: 1000px) {
	.mbox {
		width: 90%;
	}
}
@media screen and (max-width: 768px) {
	.mbox {
		margin: 0 auto 70px auto;
	}
}
.mbox_content {
    text-align: center;
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;
}
.mbox_content iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.mbox_toptext {
    font-size: 15px!important;
    margin: 0!important;
    padding-bottom: .5rem!important;
    text-align: center!important;
}
.mbox_bottomtext {
    font-size: 15px!important;
    margin: 0!important;
    padding-top: .5rem!important;
    text-align: center!important;
}

@media (max-width: 768px) {
    .mbox_content {
        padding-top: 56%;
    }
    .mbox_toptext {
        font-size: 10px!important;
    }
    .mbox_bottomtext {
        font-size: 10px!important;
    }
}