@charset "utf-8";

/*=====================================================
COMMON-LAYOUT
======================================================*/


div.container {
	position: relative;
}
div.container.top{
	padding: 50px 10px 90px;
}
div.container.dtl{
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
}


.mbtn {
	display: flex;
	justify-content: space-between;
}

.mbtn li {
	width: 31.25%;
}
.mbtn::after{
	content:'';
	display: block;
	width: 31.25%;
}
.mbtn li a .img{
	position: relative;
	overflow: hidden;
	max-height: 300px;
	height: 69.9vw;
}
.mbtn li a .img img{
	min-height: 300px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
}


.mbtn li a .bg {
	position: absolute;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	z-index: 1;
}
.mbtn li a .txt {
	position: absolute;
	top:60%;
	left:5%;
	width: 90%;
	transform: translateY(-50%);
	color: #fff;
	font-size: 36px;
	line-height: 1.4;
	text-align: center;
	opacity: 0;
	z-index: 3;
	transition:0.3s all ease-in-out;
}
.mbtn li a .bg:before {
	content: "";
	position: absolute;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.6);
	opacity: 0;
	transition:0.3s all ease-in-out;
	z-index: 2;
}
.mbtn li a .img:after {
	content: "";
	position: absolute;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	border: solid 8px rgba(255,255,255,0.5);
	box-sizing: border-box;
	transition:0.3s all ease-in-out;
	z-index: 3;
}
.mbtn li a .bg img {
	transform: scale(1);
	transition:0.3s all ease-in-out;
}

.mbtn li.active a .txt,
.mbtn li a:hover .txt {
	top:50%;
	opacity: 1;
}
.mbtn li.active a .bg:before,
.mbtn li a:hover .bg:before {
	opacity: 1;
}
/*.mbtn li.active a .img:after,
.mbtn li a:hover .img:after {
	border: solid 8px rgba(255,255,255,0.7);
}*/
.mbtn li.active a .bg img,
.mbtn li a:hover .bg img {
	transform: scale(1.1);
}

.mbtn .ccttl {
	text-align: center;
	font-size: 18px;
}

.mbtn .p_bar {
	position: relative;
}

.mbtn .kaisi {
	position: relative;
	top:0;
	left: 0;
	font-size: 20px;
	width: 15%;
	color: #000;
	border: solid 1px #000;
	text-align: center;
	padding: 6px 0;
}

.mbtn .kansei {
	position: absolute;
	top:0;
	right: 0;
	font-size: 20px;
	width: 15%;
	color: #fff;
	background: #000;
	border: solid 1px #000;
	text-align: center;
	padding: 6px 0;
}
.mbtn .bar {
	position: absolute;
	top:calc(50% - 5px);
	left: 15%;
	width: 70%;
	background: url(../images/progress/bar.png) repeat-x;
	height: 10px;
}
.mbtn .bar:before {
	content: "";
	position: absolute;
	top:0;
	left: 0;
	width: 40%;
	background: #3a2160;
	height: 10px;
	min-width: 8px;
}

.mbtn .bar:after {
	content: "";
	position: absolute;
	top:-14px;
	left: 0;
	width: 40%;
	height: 14px;
	padding-right: 8px;
	background: url(../images/progress/sankaku.png) bottom right no-repeat;
	min-width: 8px;
}

#p01 .mbtn .bar:before,
#p01 .mbtn .bar:after {
	width: 40%;
}
#p02 .mbtn .bar:before,
#p02 .mbtn .bar:after {
	width: 70%;
}
#p03 .mbtn .bar:before,
#p03 .mbtn .bar:after {
	width: 50%;
}







/*詳細ページ*/


.smenu_wrap {
	position: relative;
	width: 23.4375%;
}
.smenu {
	position: absolute;
	top:0;
	left:0;
}
.smenu li {
	font-size: 16px;
	line-height: 1.3;
	border-bottom: dotted 1px #000;
}
.smenu li a {
	display: block;
	width: 100%;
	height: 100%;
	padding: 15px 10px;
	position: relative;
	overflow: hidden;
}
.smenu li a:before {
	content: "";
	display: block;
	position: absolute;
	top:0;
	left: 0;
	bottom: 0;
	right: 0;
	width: 0;
	height: 100%;
	background: rgba(58,33,96,0.1);
	/*transform: translateX(-100%);*/
	transition:0.3s all ease-in-out;
	z-index: -1;
}
/*.smenu li a.cr,.smenu li a:hover {
	color: #fff;
}*/
.smenu li.active a:before,.smenu li a.cr:before,.smenu li a:hover:before {
	width: 100%;
}



.contents {
	width: 73.34375%;
	margin: 0 0 0 auto;
}

h3 {
	font-size: 24px;
	padding-bottom: 5px;
	border-bottom: double 4px #000;
}

.contents .p_bar.dtl {
	position: relative;
}
.contents .p_bar.dtl .kaisi,
.contents .p_bar.dtl .kansei {
	font-size: 20px;
	width: 8%;
	line-height: 1.2;
	padding: 14px 0;
	text-align: center;
}
.contents .p_bar.dtl .kaisi span,
.contents .p_bar.dtl .kansei span{
	display: block;
	font-size: 16px;
}
.contents .p_bar.dtl .kaisi {
	position: relative;
	top:0;
	left: 0;
	color: #000;
	border: solid 1px #000;
}

.contents .p_bar.dtl .kansei {
	position: absolute;
	top:0;
	right: 0;
	color: #fff;
	background: #000;
	border: solid 1px #000;
}
.contents .p_bar.dtl .bar {
	position: absolute;
	top:calc(50% - 6px);
	left: 8%;
	width: 84%;
	background: url(../images/progress/bar.png) repeat-x;
	height: 12px;
}
.contents .p_bar.dtl .bar:before {
	content: "";
	position: absolute;
	top:0;
	left: 0;
	width: 40%;
	background: #3a2160;
	height: 12px;
	min-width: 8px;
}

.contents .p_bar.dtl .bar:after {
	content: "";
	position: absolute;
	top:-14px;
	left: -8px;
	width: 40%;
	height: 14px;
	/*padding-right: 8px;*/
	padding-right: 16px;
	background: url(../images/progress/sankaku.png) bottom right/16px no-repeat;
	min-width: 8px;
  max-width: calc(100% - 8px);
}
.contents .p_bar.dtl .bar .day {
	position: absolute;
	display: inline-block;
	font-size: 16px;
	top:-42px;
	left: 40%;
	/*transform: translateX(-50%);*/
	transform: translateX(-40%);
}



div#s_main_wrap {
    position: relative;
    max-width: 940px;
    margin:0 auto 50px;
    overflow: hidden;
}

ul.s_main {
}


ul.s_main li {
    top:0;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    position: absolute;
    display: none;
    /*opacity:0;
    transition:1s all ease-in-out 0s;*/
}

ul.s_main li.active {
	position: relative;
	max-height: 625px;
	height: 63vw;
	overflow: hidden;
}
ul.s_main li img{
	width: auto;
  height: auto;
  min-width: 100%;
  min-height: 100%;
  /*max-width: inherit;*/
	position: absolute;
	left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

ul.s_main li.active{
	opacity:1;
}

.slideprev{
	position: absolute;
	top:46%;
	left:10px;
	width:45px;
	cursor: pointer;
	z-index:9;
	opacity: 1;
	transition:0.3s all ease-in-out 0s;
}
.slidenext{
	position: absolute;
	top:46%;
	right: 10px;
	width:45px;
	cursor: pointer;
	z-index:9;
	opacity:1;
	transition:0.3s all ease-in-out 0s;
}

.slideprev:hover{
	opacity: 0.6;
}

.slidenext:hover{
	opacity: 0.6;
}

div#s_thum_wrap {
	position: relative;
	max-width: 940px;
	margin:0 auto;
    display: flex;
    justify-content: center;
}

#s_thum_inner {
    width: 65%;
    overflow: hidden;
}

#s_thum_wrap ul.s_thum {
	overflow-x: scroll;
	height: calc(100% + 20px);
	display: flex;
}

ul.s_thum li {
	width: 110px;
	max-width: 110px;
	padding: 0 10px;
	box-sizing: content-box;
	cursor: pointer;
    float: left;
}

ul.s_thum li p {
	font-size: 14px;
	line-height: 1.3;
	text-align: center;
	margin-top: 5px;
	word-break: break-all;
}
ul.s_thum li div {
	background: #000;
  overflow: hidden;
  height: 73px;
  position: relative;
  width: 110px;
}
ul.s_thum li img {
	opacity: 0.4;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
}
ul.s_thum li.active img {
	opacity: 1;
}

.slidefirst{
	position: absolute;
	top:25%;
	left:0;
	width:17.1%;
	cursor: pointer;
	z-index:9;
	opacity: 1;
	transition:0.5s all ease-in-out 0s;
}
.slideend{
	position: absolute;
	top:25%;
	right: 0;
	width:17.1%;
	cursor: pointer;
	z-index:9;
	opacity:1;
	text-align: right;
	transition:0.5s all ease-in-out 0s;
}

.slidefirst:hover{
	opacity: 0.6;
}

.slideend:hover{
	opacity: 0.6;
}


.no_common {
	max-width: 600px;
	margin: 80px auto 80px;
	border:solid 1px #000;
	border-top:solid 15px #392161;
	padding: 15px 30px 30px;
}

.no_common .logo {
	width: 62%;
	margin: 0 auto;
	text-align: center;
}


.no_common .no01 {
	display: flex;
	justify-content: center;
	align-items: center;
}


.no_common .bkr {
	width: 50px;
	margin-right: 30px
}
.no_common .copy {
	display: inline-block;
	max-width: calc(100% - 82px);
	font-size: 20px;
	color: #000;
}




@media screen and (max-width: 1280px){
	
	.mbtn li a .txt {
		font-size: 2.8vw;
	}
	
	.mbtn .kaisi {
		font-size: 1.5625vw;
	}

	.mbtn .kansei {
		font-size: 1.5625vw;
	}
	
	.mbtn .ccttl {
		font-size: 1.4vw;
	}
	
	.mbtn .smenu li {
		font-size: 1.25vw;
	}
	
	
	
	
	.contents .p_bar.dtl .kaisi,
	.contents .p_bar.dtl .kansei {
		font-size: 1.9vw;
		padding: 15px 0;
	}
	.contents .p_bar.dtl .kaisi span,
	.contents .p_bar.dtl .kansei span{
		font-size: 1.4vw;
	}
	
	ul.s_thum li p {
		font-size: 1vw;
	}
	

}


@media screen and (max-width: 767px){
	
	div.container.top{
		padding: 35px 10px 50px;
	}
	
    div.container.dtl{
    	display: block;
    }
	
	.mbtn {
		display: block;
	}

	.mbtn li {
		width: 100%;
		margin-bottom: 40px;
	}
	.mbtn li:last-child {
		margin-bottom:0;
	}
	
	
	.mbtn li a .txt {
		font-size: 8vw;
		top:50%;
		opacity: 1;
	}
	.mbtn li a .bg:before {
		opacity: 0.4;
	}
	.mbtn li a:after {
		border: solid 6px rgba(255,255,255,0.7);
	}
	.mbtn li a .bg img {
		transform: scale(1.1);
	}
	
	.mbtn .kaisi {
		font-size: 4vw;
	}

	.mbtn .kansei {
		font-size: 4vw;
	}
	
	.mbtn .ccttl {
		font-size: 5vw;
		margin-bottom: 10px;
	}
	
	.mbtn .smenu {
		position: static;
		width: 100%;
		display: flex;
		flex-wrap: wrap;

		justify-content: space-between;
		margin-bottom: 30px;
	}
	.mbtn .smenu li {
		width: 48%;
		font-size: 14px;
		line-height: 1.3;
		text-align: center;
		border-bottom: dotted 1px #000;
	}

	.mbtn .contents {
		width: 100%;
		margin: 0 auto;
	}
	
	
	
	h3 {
		font-size: 20px;
		padding-bottom: 5px;
	}
	
	.smenu_wrap {
			width: 100%;
	}
	.smenu {
		position: static;
		width: 100%;
		/*display: flex;
		flex-wrap: wrap;
		justify-content: space-between;*/
		margin-top: 30px;
		border-top: dotted 1px #000;
	}
	.smenu li {
		width: 100%;
		font-size: 14px;
		line-height: 1.3;
		text-align: center;
		border-bottom: dotted 1px #000;
	}

	.contents {
		width: 100%;
		margin: 0 auto;
	}
	
	.contents .p_bar.dtl .bar .day {
		font-size: 12px;
		top:-32px;
	}
	
	.contents .p_bar.dtl .kaisi,
	.contents .p_bar.dtl .kansei {
		font-size: 3.6vw;
		padding: 8px 0;
		width: 12%
	}
	.contents .p_bar.dtl .kaisi span,
	.contents .p_bar.dtl .kansei span{
		font-size: 3vw;
	}
	
	.contents .p_bar.dtl .bar {
		width: 76%;
		left: 12%;
	}
	
	div#s_main_wrap {
		margin: 0 auto 50px;
	}
	
	ul.s_thum li {
		/*box-sizing: border-box;*/
	}

	ul.s_thum li p {
		font-size: 12px;
		margin-top: 5px;
	}
	
	.slidefirst{
		top:-45px;
		width:35%;
	}
	.slideend{
		top:-45px;
		width:35%;
	}
	
    .slideprev{
		width:25px;
	}
    .slidenext{
		width:25px;
	}
    #s_thum_inner{
        width: 100%;
    }
}


@media screen and (max-width: 600px){

	
	
	.no_common {
		padding: 15px 20px 20px;
	}

	.no_common .logo {
		width: 85%;
	}

	.no_common .bkr {
		width: 35px;
		margin-right: 10px
	}
	.no_common .copy {
		max-width: calc(100% - 45px);
		font-size: 15px;
font-feature-settings : "palt";
	}

	
	
}