@charset "utf-8";
/* CSS Document */
/*************************
     reset         
*************************/
html, body, h1, h2, h3, h4, ul, ol, li, p, div, span, img, a {
	margin: 0;
	padding: 0;
	border: 0;
	font-weight: normal;
	vertical-align:baseline;
	}
body{
    line-height:1.4;
}
article, header, footer, nav, section { 
	display:block;
}
body {
	font-family: 'Noto Sans JP', "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}
ol, ul {
	list-style: none;
	list-style-type: none;
}
*, *:before, *:after {
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	     -o-box-sizing: border-box;
	    -ms-box-sizing: border-box;
	        box-sizing: border-box;
}
img{width: 100%;}
/*************************
     wappar         
*************************/
#wapper{
	display: flex;
      flex-direction: column;
      min-height: 100vh;
	background-image: url(../img/bg.jpg);
	background-size: cover;
	background-position: center;
	background-attachment: fixed;
}
footer{
	position: relative;
	z-index: 1;
	margin-top: auto;
	border-top: 1px solid #c21500;
	border-image: linear-gradient(90deg, rgba(35,4,3,1) 0%, rgba(182,112,48,1) 50%, rgba(35,4,3,1) 100%, rgba(15,174,197,1) 100%);
	border-image-slice: 1;
	text-align: center;
	padding: 20px;
	background-color: #090103;
}
footer small{
	color: #aba083;
	font-size: 0.8rem;
}
footer .footer_bnr{
	display: block;
	max-width: 350px;
	margin: 0 auto 20px;
}
/*************************
     header         
*************************/
header{
	width: 100%;
	position: relative;
}
.icon_pre{
	position: absolute;
	top: 45%;
	right: 4vw;
	width:130px;
}
@media screen and (min-width: 769px) {
	.icon_pre{
	width:200px;
	right: calc(50% - 450px);
	top: 250px;
}
	}
.series{
	position: absolute;
	bottom: 0;
}
@media screen and (min-width: 769px) {
	.series{
		left: 0;
		right: 0;
		margin: auto;
		width: 530px;
	}
}
.top_img{
	background-image:none;
}
@media screen and (min-width: 769px) {
.sp{display: none;}
.top_img{
	background-image:  url(../img/top_pc.png);
	background-position: center top;
	background-size: auto;
	height:854px ;
	/*background: linear-gradient(rgba(255,255,255,0) 60%, rgba(0,0,0,0.7) 100%),url(../images/bg_chara_01.png) bottom center no-repeat,url(../images/bg_chara_02.png) bottom center no-repeat,url(../images/bg_chara_03.png) bottom center no-repeat;
    background-size: auto;
    height: 879px;*/
}
}

/*************************
     main         
*************************/
main{
	padding: 4vh 0;
	margin: 0 4.27vw;
}
@media screen and (min-width: 769px) {
	main{
		width: 518px;
		margin: 0 auto;
	}
}
.img{
	margin-bottom: 4vh;
	position: relative;
	z-index: 1;
}
/***** form *****/
.form_box{
	position: relative;
	z-index: 1;
	border: 1px solid #c8b33d;
	border-image: linear-gradient(18deg, rgba(156,59,30,1) 0%, rgba(200,179,61,1) 50%, rgba(155,20,29,1) 100%);
	border-image-slice: 1;
	text-align: center;
	background-image: url(../img/flame_btm.png),url(../img/flame_top.png);
	background-repeat: no-repeat,no-repeat;
	background-position: bottom center,top center;
	background-size: 100%,100%,cover;
	background-color: #330705;
	padding: 4.27vh 4.27vw;
	margin: 0 0 20px;
}
.form_box:last-child{
	margin: 0 0 4vh;
}
@media screen and (min-width: 769px) {
	.form_box{
		 background-size: auto,auto,cover;
		 background-position: bottom 2px center,top 2px center;
		 padding: 40px 30px;
		 margin: 0 0 40px;
		}

	.form_box:last-child{
		margin: 0 0 60px;
	}
	}
.form_box .title{
	color: #e6c11d;
	font-size:5.625vw;
	position: relative;
	padding:0 0 30px;
	margin-bottom: 15px;
	font-family: "Sawarabi Mincho";
}

.form_box .text{
	color: #fff;
	font-size: 3.75vw;
	margin-bottom: 15px;
}
.form_box .ex{
	color: #aba083;
	font-size: 3.75vw;
	margin-bottom: 30px;}

.form_box .title:after{
	content: "...";
	ccolor: #e6c11d;
	position: absolute;
	bottom:0;
	left: 0;
	right: 0;
	margin: auto;
}
.btn_post{
	display: block;
	width: 300px;
	margin: 0 auto;
}
.caution{
	position: relative;
	z-index: 1;
	padding: 1rem 0.5rem;
	color: #aba083;
    font-size: 14px;
    background-color:rgba(31,4,5,1);
}
.caution ul {
	list-style: disc;
	margin-left: 1rem;
}
@media screen and (min-width: 769px) {
	.form_box .title{color: #e6c11d;font-size:30px;}
	.form_box .text{color: #fff;font-size: 16px;}
	.form_box .ex{color: #aba083;font-size: 16px;}
	}
.deco01{
	position: absolute;
	top: 0;
	left: -35%;
	width: 100%;
	height: 1948px;
	background-image: url(../img/deco01.png);
	background-repeat: repeat-y;
	background-size: cover;
}
.deco02{
	position: absolute;
	top: 1948px;
	left: -40%;
	width: 100%;
	height: 1948px;
	background-image: url(../img/deco01.png);
	background-repeat: repeat-y;
	background-size: cover;
}
/********** page-top *****************/
#page-top {
	
	background-color: #330705;
	border: 1px solid #c8b33d;
    border-image: linear-gradient(18deg, rgba(156,59,30,1) 0%, rgba(200,179,61,1) 50%, rgba(155,20,29,1) 100%);
    border-image-slice: 1;
    display: block;
    position: fixed;
    /*text-indent: -9999px;*/
    z-index: 2;
    bottom: -90px;
    right: 10px;
    width: 58px;
    height: 58px;
    transition: .5s;
    background-size: cover;
    background-position: right;
	z-index: 7777;
}