*{margin:0;padding:0;box-sizing: border-box;}
html{margin:0;padding:0;height:100%;}
header, footer, aside, nav, section,article,time,figure,label{display: block;}
ul,ol{list-style:none;}
a{outline:none;text-decoration:none;color:#f90;}
a img{border:0;}
fieldset{border:0;}
.clear{margin:0;padding:0;height:0;clear:both;}
body {margin:0;padding:0;font-size:14px;background:#500e09;color:#fff;background-size: cover;font-family:sans-serif;-webkit-text-size-adjust:100%;}
p{line-height:1.4;}
img {display: block;}
/*Header
--------------------------------------------------------------------------------------------------------------*/
/*
.top {position:relative; height:0; padding-top:160%; background:url(../images/sp_top.jpg) no-repeat 0 0; background-size:contain;}
header {background:url(../images/sp_header.jpg) no-repeat center center,#000; background-size:contain; height:60px;}
.top header {position:absolute; top:32%; left:0; width:100%; height:22%; }
header h1 {width:auto; height:100%; margin:0 auto;}
header h1 a {display:block; height:100%; width:auto; text-indent: 120%; overflow: hidden; white-space: nowrap;background:url(../images/logo.png) no-repeat center center ; background-size:contain; }
.logo-3ban a {background:url(../images/logo-3ban.png) no-repeat 60% center; background-size:contain;}
.logo-4ban a {background:url(../images/logo-4ban.png) no-repeat 60% center; background-size:contain;}
.logo-5ban a {background:url(../images/logo-5ban.png) no-repeat 60% center; background-size:contain;}
.logo-6ban a {background:url(../images/logo-6ban.png) no-repeat 60% center; background-size:contain;}
.logo-7ban a {background:url(../images/logo-7ban.png) no-repeat 60% center; background-size:contain;}
.logo-8ban a {background:url(../images/logo-8ban.png) no-repeat 60% center; background-size:contain;}
.top header h1 a {background-position: 95% center;}
.top .reg_btn {position:absolute; top:60%; left:0; width:100%;}
*/
.top {
	height: 420px;
	position:relative;
	background:url(../images/sp_top.jpg) no-repeat center top;
	background-size:cover;
	display: flex;
	flex-direction: column;
}
.top header {
	flex-grow: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
}
.top header h1{
	width: 100%;
	height: auto;
	background: url(../images/sp_header.jpg) no-repeat center #000;
	background-size: auto 120px;
}
.top header h1 a {
	width: 100%;
	height: 100px;
	background: url(../images/logo.png) no-repeat center;
	background-size: auto 100px;
	position: relative;
}
header h1 a::after{
	width: 80px;
	height: 24px;
	content: "";
	position: absolute;
	right: 8px;
	bottom: 8px;
	background-size: contain;
	background-position: right bottom;
	background-repeat: no-repeat;
}
.logo-3ban a::after{
	background-image:url(../images/logo-3ban.png);
}
.logo-4ban a::after {
	background-image:url(../images/logo-4ban.png);
}
.logo-5ban a::after {
	background-image:url(../images/logo-5ban.png);
}
.logo-6ban a::after {
	background-image:url(../images/logo-6ban.png);
}
.logo-7ban a::after {
	background-image:url(../images/logo-7ban.png);
}
.logo-8ban a::after {
	background-image:url(../images/logo-8ban.png);
}
.top .reg_btn {
	padding: 10px 0;
	width: 100%;
}
.btn-desc{
	margin: 8px 8px 0 8px;
	padding: 8px 4px;
	background: #000;
	color: #fc3;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	position: relative;
	font-size: 12px;
	font-weight: bold;
}
.btn-desc::after{
	margin: 0 auto;
	width: 0;
	height: 0;
	content: "";
	border-style: solid;
	border-width: 0 6px 16px 6px;
	border-color: transparent transparent #000000 transparent;
	position: absolute;
	top: -16px;
	right: 0;
	left: 0;
}
header {background:url(../images/sp_header.jpg) no-repeat center center,#000; background-size:contain; height:100px;}
header h1 {width:auto; height:100%; margin:0 auto;}
header h1 a {
	display: block;
	height: 100px;
	width: auto;
	text-indent: 120%;
	overflow: hidden;
	white-space: nowrap;
	background: url(../images/logo.png) no-repeat center;
	background-size: auto 100px;
	position: relative;
	position: relative;
}

.reg_btn a {display: block; text-indent: 120%; overflow: hidden; white-space: nowrap; width:250px; height:60px; margin:0 auto; background:url(../images/sp_btn.jpg) no-repeat 0 0; background-size:contain;box-shadow: 2px 2px 3px rgba(0,0,0,0.3);}


/*Main
--------------------------------------------------------------------------------------------------------------*/
#main {background:#330d0a; }

article {margin-bottom:10px; padding-bottom:1px;}
article h2 {line-height:30px; padding:5px 5px 5px 5px; background:linear-gradient(to bottom,#741715 0%,#500e09 100%),#500e09; font-size:21px;box-shadow: 2px 2px 3px rgba(0,0,0,0.3); text-align: center;}
article p {margin:15px;}

/*
.playlist ul li{margin:15px 15px 25px;}
.playlist ul li figure {position:relative; width:95px; box-shadow: 2px 2px 3px rgba(0,0,0,0.3); float:left;}
.playlist ul li figure img {position: relative; z-index: 1; width: 100%;}
.playlist ul li figure p {margin:0 !important; position:absolute; top:5px; left:5px; font-size:16px; font-family: "ƒqƒ‰ƒMƒm–¾’© ProN W6", "HiraMinProN-W6", "HG–¾’©E", "‚l‚r ‚o–¾’©", "MS PMincho", "MS –¾’©", serif; text-shadow:2px 2px 3px rgba(0,0,0,0.7); z-index: 2;}
.playlist p {margin:0 0 10px 110px; }
.playlist a.more {display:block; padding:8px 15px; color:#fff; background:#8e3606; box-shadow: 2px 2px 3px rgba(0,0,0,0.4); margin-left:110px; text-align:center;}
.playlist ul li:nth-of-type(2n) figure {float:right;}
.playlist ul li:nth-of-type(2n) p {margin:0 110px 10px 0;}
.playlist ul li:nth-of-type(2n) a.more { margin:0 110px 0 0;}
*/

nav ul {margin-top:15px;}
nav ul li a {display: block; background:url(../images/side_arrow.png) no-repeat 96% center,#570000; background-size:auto 16px; color:#fff; padding:15px; border-bottom:1px solid #330d0a;}

.play img {width:100%;}

article.gallery {margin-bottom:30px;}
article.gallery img {display: block; width:100%;}
article.gallery .detail {overflow: hidden; margin:15px 15px 10px; box-shadow: 2px 2px 3px rgba(0,0,0,0.4);}
article.gallery ul {margin:15px auto 30px; width: 290px; height:90px;}
article.gallery ul li {float: left; width:90px; height:90px; margin-right:10px;box-shadow: 2px 2px 3px rgba(0,0,0,0.4); }
article.gallery ul li:nth-of-type(3n) {margin:0;}

article.exp {margin-bottom:30px;}
article.exp figure {margin:15px auto ; width:290px; height:95px;}
.thum {width:95px; height:95px; position:relative; float:left;}
.thum img {display: block; width: 100%;}
article.exp figure .thum p {position: absolute; bottom: 0; left:0; width:100%; padding:5px 0; text-align: center; background:rgba(0,0,0,0.5); margin:0; font-size:12px;}
figure .thum:first-of-type:after {content:""; display: block; position:absolute;top:25px; left:102px; height:50px; width:80px; height:50px;background:url(../images/X.png) no-repeat right center; background-size:contain;}
figure .thum:last-of-type {float:right;}

article.faq h3 { padding:5px 0 5px 40px; background:url(../images/Q.jpg) no-repeat 0 0; font-size:16px; background-size: 30px 30px; margin:15px; font-weight: normal; min-height:30px;}
article.faq p {padding:5px 0 20px 40px; border-bottom:1px solid #000; background:url(../images/A.jpg) no-repeat 0 0; margin:15px; background-size: 30px 30px;}

article.rule h3,.success h3 {background:url(../images/h3.png) no-repeat 0 center; margin:15px 15px 0; padding:5px 5px 5px 25px;}
article.rule h4 {margin:15px 15px 0; padding:5px 5px 5px 5px;}
article.rule ul{margin: 15px;}
/*Form
--------------------------------------------------------------------------------------------------------------*/
.form fieldset{padding:10px 10px 0 10px;position:relative;}
.form fieldset label{width:120px;height:40px;line-height:40px;background:#141414;color:#fff;text-align:center;position:absolute;top:15px;left:10px; font-size:12px;}
.form fieldset p{padding:5px 0 0 120px; margin:0;}
.form .error{margin:5px 0 0 0;padding:5px;text-align:center;background:#ffe5e5;color:#f33;}
.form input[type="text"],.form input[type="password"],.form textarea,.form select
{padding:10px;width:100%;font-size:14px;line-height:18px;color:#666;border:1px solid #ddd;-webkit-appearance:none;border-radius:0;}
.form input[type="text"].qtr{width:25%;float:left;}
.form textarea{height:120px;}
.form select{background:url(../images/icon_select.png) no-repeat right #fff;background-size:40px 40px;}
.form .msg{padding:10px;}
.form p a{color:#f90;}
.form p span{padding:10px;line-height:20px;float:left;}
.regular-radio{display:none;}
.form fieldset p .regular-radio + label{margin:2px 5px;padding:10px;width:36px;height:36px;line-height:0;border-radius:50%;-webkit-appearance:none;background-color:#fafafa;border:1px solid #ddd;display:inline-block;position:relative;float:left;top:0;left:0;}
.regular-radio:checked + label:after{content:' ';width:20px;height:20px;border-radius:50%;position:absolute;top:7px;left:7px;background:#99a1a7;}
.entery_btn{padding:10px; background:none;}
.entery_btn button{width:100%;height:60px;line-height:60px;text-align:center;border:0;font-size:16px;color:#111;background:linear-gradient(to bottom,#ffac0d 0%,#ff7e02 100%),#ffac0d;}
.block{background:#000; margin:7px 10px; padding:5px 10px;}
.msg,.alert{background:#000; margin:7px 10px; padding:5px 10px; font-size:80%;}
.entery_btn p {margin:0 0 15px;}

.juyo { background:rgba(255,255,255,0.1); border:1px dotted #f00 !important; padding:8px !important; box-sizing:border-box;}
.form .msg span,.form .juyo span{float:none; padding:0;}
.form .juyo{margin:10px 10px 0;}
.juyo a{color:#f90;}
/*Footer
--------------------------------------------------------------------------------------------------------------*/
footer{background:#111;clear:both;position:relative;}
footer address {font-style: normal; text-align: center; font-size:12px; padding:10px 0;}

/* mother bar */
#mother{width:100%; height:40px; background:#141414;}
#mother h1{display:block; margin:0 5px; color:#fff; line-height:40px; text-indent:-9999px; background-position:center;}

/* karamail button */
#mailButton li{display:block; width:50%; float:left;}
#mailButton li a{display:block; text-align:center; font-size:180%; padding:15px 0; text-decoration:none; color:#fff; font-weight:bold; border:1px solid #ccc;}
#mailButton li.male a{border-radius:10px 0 0 10px; -webkit-border-radius:10px 0 0 10px; -moz-border-radius:10px 0 0 10px; border-color:#006cff; text-shadow:0 -1px 1px #006cff;
background: -webkit-gradient(linear, left top, left bottom, from(#5d93ff), color-stop(0.49, #117cff), color-stop(0.5, #026dc7), to(#004c8d) );
background: -moz-linear-gradient(top, #5d93ff, #117cff 49%, #026dc7 50%, #004c8d);}
#mailButton li.female a{border-radius:0 10px 10px 0; -webkit-border-radius:0 10px 10px 0; -moz-border-radius:0 10px 10px 0; border-color:#fd1a5a; text-shadow:0 -1px 1px #fd1a5a;
background: -webkit-gradient(linear, left top, left bottom, from(#ff8ca7), color-stop(0.49, #ff577f), color-stop(0.5, #ff3363), to(#ff0c45) );
background: -moz-linear-gradient(top, #ff8ca7, #ff577f 49%, #ff3363 50%, #ff0c45);}
#mailButton li.male a:hover,#mailButton li.male a:active{border-color:#006cff; text-shadow:0 -1px 1px #107cff;
background: -webkit-gradient(linear, left top, left bottom, from(#6da3ff), color-stop(0.49, #218cff), color-stop(0.5, #127dd7), to(#105c9d) );
background: -moz-linear-gradient(top, #6da3ff, #218cff 49%, #127dd7 50%, #105c9d);}
#mailButton li.female a:hover,#mailButton li.female a:active{border-color:#fd1a5a; text-shadow:0 -1px 1px #ff2a6a;
background: -webkit-gradient(linear, left top, left bottom, from(#ff9cb7), color-stop(0.49, #ff678f), color-stop(0.5, #ff4373), to(#ff1c55) );
background: -moz-linear-gradient(top, #ff9cb7, #ff678f 49%, #ff4373 50%, #ff1c55);}

.clearfix:after {
    content:" ";
    display:block;
    clear:both;
}

/* campaign */
.campaign h4 {border:0; font-size:14px; color:#fff; text-indent:0; padding:10px 0 10px 20px;}
.campaign h5 {font-weight:normal; font-size:12px;color:#fff; padding:10px 0 10px 20px;}
.campaign p{padding:0 10px 0 20px;}
.cam_msg {font-size:11px; color:#aaa; padding:0;}
.campaign strong {font-weight:bold; color:#f00;}
.camMenu { margin-bottom:10px;padding-left:20px;}
.camMenu dt { font-weight:bold; font-size:16px; margin:5px 0;}
.camMenu dt:before{content:"¥"; color:#714769;}
.camMenu dd {margin-bottom:10px;}
.camMenu table {border-collapse:collapse; width:270px; color:#000;}
.camMenu table th{text-align:center; background:#ccc; width:90px; border:1px solid #aaa;}
.camMenu table td{text-align:right; width:90px; background:#fff; border:1px solid #aaa; padding-right:10px; box-sizing:border-box;}
.camMenu table tr td:last-child{background:#ff0;}

#campaign_btn,
#campaign_btn_entry {
	position: absolute;
	top: 0px;
	right: 0px; 
	z-index: 1;
}
#campaign_btn a,
#campaign_btn_entry a {
	width: 70px;
	height: 70px;
	display: block;
	background: url(../images/cam_btn.png) no-repeat 0 0;
	text-indent: 120%;
	overflow: hidden;
	white-space: nowrap;
	background-size: contain;
}

.playlist .slick-slider{
	padding: 8px 0 0 0;
	display: flex;
	flex-direction: column-reverse;
}
.slick-dots{
	padding: 8px 16px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.slick-dots li{
	margin: 0;
	padding: 0 0 8px 0;
	width: 32%;
}
.slick-dots .slick-active .slide-nav{
	background: rgba(255,255,255,.2);
}

.playlist .slide-nav{
	margin: 0;
	padding: 0 4px 0 12px;
	line-height: 20px;
	border-left: 1px solid #fff;
	border-bottom: 1px solid #fff;
	text-align: center;
	transition: .3s;
	position: relative;
}
.slide-nav::after{
	margin: auto 0;
	width: 0;
	height: 0;content: "";
	border-style: solid;
	border-width: 3px 0 3px 4px;
	border-color: transparent transparent transparent #fff;
	position: absolute;
	top: 0;
	left: 4px;
	bottom: 0;
}
.slide-thumb{
	position: relative;
}
.slide-title{
	margin: 0;
	padding: 8px;
	position: absolute;
	right: 0;
	bottom: 0;
	font-size: 16px;
	font-weight: bold;
	font-family: serif;
	text-shadow:2px 2px 3px rgba(0,0,0,0.7);
	z-index: 2;
}
.content-img{
	width: 100%;
	height: auto;
	object-fit: contain;
}
.slide-txt{
	margin: 8px 8px 0 8px;
	padding: 8px;
	background: #000;
}
.slide-bottom{
	margin: 0 8px;
	padding: 0 8px 8px 8px;
	background: #000;
}
.slide-btn{
	width :100%;
	height: 44px;
	line-height: 44px;
	font-size: 16px;
	font-weight: bold;
	font-family: serif;
	background: #f90;
	color: #000;
	text-align: center;
	display: block;
	position: relative;
}
.slide-btn::after{
	margin: auto 0;
	width: 0;
	height: 0;content: "";
	border-style: solid;
	border-width: 6px 0 6px 8px;
	border-color: transparent transparent transparent #000;
	position: absolute;
	top: 0;
	left: 8px;
	bottom: 0;
}