/*  General CSS*/

/********** 共通
 ******************************/

body{
    background: #fff;
    font-family: -apple-system, ‘Helvetica Neue’, ‘Hiragino Kaku Gothic ProN’, ‘游ゴシック Medium’, ‘メイリオ’, meiryo, sans-serif;
}

div.box , div.box2 {
	max-width: 878px;
	height: auto;
	margin: 0 auto;
	padding: 0 20px;
	background: url(../img/box_bg.png) repeat-y center top;
	background-size: 100%;
}

div.box2 {
	text-align: center;
}

img.slice {
	vertical-align: text-bottom;
}

.bold {
	font-weight: bold;
}

p.last {
	padding-bottom: 50px;
}

.tright {
	text-align: right;
}

div.box2 p a {
	color: #333;
	text-decoration: none;
}

.red {
	color: #f00;
}

.bgyl {
	background: #ffff99;
}

.pr5 {
	padding-right: 5px;
}
.pb5 {
	padding-bottom: 5px;
}

.pb30 {
	padding-bottom: 30px;
}

div.faq_contact {
	position: relative;
}

div.faq_contact img.faq_btn {
	position: absolute;
	right: 13%;
	bottom: 40%;
	width: 28%;
}

@media screen and (min-width:769px) {
	/* 画面サイズが769pxから */

h2 , h3 , h4 {
	background: #000;
	font-size: 200%;
	padding: 30px 0;
	text-align: center;
	color: #fff;
}

div.box p {
	margin-top: 30px;
}

.moni_txt {	padding-top: 30px;}

.pt30 {	padding-top: 30px;}

.pb50 {	padding-bottom: 50px;}

.tokusyo_txt {
	text-align: right;
	padding: 0 5px 10px 0;
	font-size: 100%;
}

.forsp {
	display: none;
}

}

@media screen and (min-width:481px) and (max-width:768px) {
	/* 画面サイズが481pxから768pxまで */

h2 , h3 , h4 {
	background: #000;
	font-size: 150%;
	padding: 30px 0;
	text-align: center;
	color: #fff;
}

div.box p {	margin-top: 20px;}

.moni_txt {	padding-top: 20px;}

.pt30 {	padding-top: 20px;}
.pb50 {	padding-bottom: 50px;}

.tokusyo_txt {
	text-align: right;
	padding: 0 5px 5px 0;
	font-size: 90%;
}

.forsp {
	display: none;
}

}

@media screen and (max-width:480px) { 
	/* 画面サイズが480pxまで */

h2 , h3 , h4 {
	background: #000;
	font-size: 100%;
	padding: 20px 0;
	text-align: center;
	color: #fff;
}

.pt30 {	padding-top: 20px;}
.moni_txt {
	padding-top: 20px;
	font-size: 80%;
}

.tokusyo_txt {
	text-align: right;
	padding:10px;
	font-size: 80%;
}

.nonesp {
	display: none;
}

}


/********** ヘッダー
 ******************************/
 
header {
	width: 100%;
	height: auto;
}

header div.headline {
	padding: 10px 0;
	text-align: center;
	color: #f40000;
	font-weight: bold;
	background: #fff203;
}

header div.head_bg {
	background: url(../img/head_bg.png) no-repeat center top;
	background-size: 100%;
	border-bottom: 3px solid #f00;
}

header div.head_txtimg {
	max-width: 860px;
	margin: 0 auto;
	position: relative;
}

header div.btn01 {
	width: 40%;
	position: absolute;
	left: 10%;
	bottom: 6%;
}

header div.btn01 img {
	width: 100%;
	height: auto;
}


header div.uri {
	text-align: center;
	background: #000;
	position: relative;
}

header div.uri img.uri_txt {
	max-width: 860px;
	width: 90%;
	height: auto;
}

header div.uri img.arrow {
	width: 10%;
	max-width: 116px;
	position: absolute;
	left: 46%;
	top: 0;
}

@media screen and (min-width:769px) {
	/* 画面サイズが769pxから */

header div.headline {
	font-size: 90%;
}

header p.uri_txt2 {
	font-size: 22px;
	font-weight: bold;
	text-align: center;
	line-height: 2.0;
	padding: 50px 0;
	margin-top: 0;
}

}

@media screen and (min-width:481px) and (max-width:768px) {
	/* 画面サイズが481pxから768pxまで */

header div.headline {
	font-size: 80%;
}

header p.uri_txt2 {
	font-size: 110%;
	font-weight: bold;
	text-align: center;
	line-height: 2.0;
	padding: 30px 0;
	margin-top: 0;
}

}

@media screen and (max-width:480px) { 
	/* 画面サイズが480pxまで */
header p.uri_txt2 {
	font-size: 80%;
	font-weight: bold;
	text-align: center;
	line-height: 2.0;
	padding: 20px 0;
	margin-top: 0;
}
}

/********** 登録フォーム
 ******************************/

div.form_box label {
	display: none;
}


@media screen and (min-width:769px) {
	/* 画面サイズが769pxから */

div.form_box {
	width: 675px;
	height: 247px;
	margin: 0 auto;
	padding-top: 20px;
	background: url(../img/form_bg.png) no-repeat center 20px;
}

div.form_box table {
	width: 540px;
	height: auto;
	margin: 65px auto 0;
}

div.form_box table th {
	width: 150px;
	height: 40px;
	line-height: 40px;
	text-align: right;
	color: #fff;
}

div.form_box table td {
	height: 40px;
	line-height: 40px;
	padding-left: 10px;
}

div.form_box input.text {
	width: 350px;
	height: 30px;
	padding-left: 10px;
	color: #888;
}

div.form_box div.btn {
	width: 528px;
	height: 85px;
	margin: 0 auto;
}

div.box p.formtxt1 {
	margin-left: 100px;
	line-height: 1.6;
}

}

@media screen and (min-width:481px) and (max-width:768px) {
	/* 画面サイズが481pxから768pxまで */

div.form_box {
	max-width: 768px;
	height: auto;
	margin: 0 auto;
	padding: 20px 0 40px;
	background: url(../img/form_bg.png) no-repeat center 20px;
	background-size: 100%;
}

div.form_box table {
	max-width: 700px;
	height: auto;
	margin: 9% auto 0;
	font-size: 90%;
}

div.form_box table th {
	width: ;
	height: 30px;
	line-height: 30px;
	text-align: right;
	color: #fff;
}

div.form_box table td {
	height: 30px;
	line-height: 30px;
	padding-left: 10px;
}

div.form_box input.text {
	width: 300px;
	height: 20px;
	padding-left: 5px;
	color: #888;
}

div.form_box div.btn {
	max-width: 768px;
	height: auto;
	margin: 0 auto;
	text-align: center;
}

div.form_box div.btn input {
	width: 80%;
	height: auto;
}

div.box p.formtxt1 {
	font-size: 90%;
	padding-left: 10px;
	line-height: 1.4;
}

}

@media screen and (max-width:480px) { 
	/* 画面サイズが480pxまで */
div.form_box {
	max-width: 480px;
	height: auto;
	margin: 0 auto;
}

div.form_box table {
	width: 100%;
	height: auto;
	margin: 10px auto 0;
	font-size: 90%;
	background: #c00;
	border-radius: 5px 5px 0 0;
}

div.form_box table th {
	display: block;
	width: 100%;
	text-align: left;
	padding: 10px;
	color: #fff;
}

div.form_box table td {
	display: block;
	width: 100%;
	height: 30px;
	line-height: 30px;
	padding-left: 10px;
}

div.form_box table td:nth-child(2) {
	padding-bottom: 20px;
} 

div.form_box input.text {
	width: 300px;
	height: 20px;
	padding-left: 5px;
	color: #888;
}

div.form_box div.btn {
	max-width: 480px;
	height: auto;
	margin: 0 auto 20px;
	padding: 20px 0;
	text-align: center;
	background: #ddd;
	border-radius: 0 0 5px 5px;
}

div.form_box div.btn input {
	width: 80%;
	height: auto;
}

div.box p.formtxt1 {
	font-size: 90%;
	padding: 0 0 20px 10px;
}

}

/********** 登録フォーム下の免責事項
 ******************************/

@media screen and (min-width:769px) {

#dl_box2 {
	width: 80%;
	margin: 0 auto;
	padding: 10px;
	color: #666;
	font-size: 12px;
	line-height: 1.2;
	border-top: 1px dotted #ccc;
	border-bottom: 1px dotted #ccc;
	clear: both;
}

#pp {
	width: 80%;
	height: 100px;
	margin:15px auto 0;
	padding:1px 15px 15px 15px;
	border: 3px double #222;
	color: #666;
	overflow: auto;
}

#pp p {
	font-size:10px;
	line-height:1.4;
}

}


@media screen and (min-width:481px) and (max-width:768px) {

#dl_box2 {
	width: 90%;
	margin: 0 auto;
	padding: 10px;
	color: #666;
	font-size: 11px;
	line-height: 1.2;
	border-top: 1px dotted #ccc;
	border-bottom: 1px dotted #ccc;
	clear: both;
}

#pp {
	width: 90%;
	height: 100px;
	margin:15px auto 0;
	padding:1px 15px 15px 15px;
	border: 3px double #222;
	color: #666;
	overflow: auto;
}

#pp p {
	font-size:9px;
	line-height:1.4;
}


}


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

#dl_box2 {
	width: 95%;
	margin: 0 auto;
	padding: 10px;
	color: #666;
	font-size: 10px;
	line-height: 1.2;
	border-top: 1px dotted #ccc;
	border-bottom: 1px dotted #ccc;
	clear: both;
}

#pp {
	width: 90%;
	height: 100px;
	margin:15px auto 0;
	padding:1px 15px 15px 15px;
	border: 3px double #222;
	color: #666;
	overflow: auto;
}

#pp p {
	font-size:8px;
	line-height:1.4;
}

}




/********** 錬金術
 ******************************/

@media screen and (min-width:769px) {
	/* 画面サイズが769pxから */

div.midasitxt {
	font-size: 24px;
	color: #fff;
	padding: 0 0 30px 0;
	margin-top: -1px;
	text-align: center;
	line-height: 1.4;
	background: #000;
}

div.pbg_blue {
	max-width: 860px;
	height: 518px;
	padding: 45px 30px 40px 0;
	background: url(../img/pbg_blue.jpg) no-repeat center 30px;
	background-size: 100%;
}

div.pbg_blue p {
	margin-left: 50%;
	line-height: 1.4;
}

div.pbg_blue p.title {
	font-size: 34px;
	text-align: center;
}

}

@media screen and (min-width:481px) and (max-width:768px) {
	/* 画面サイズが481pxから768pxまで */

div.midasitxt {
	font-size: 20px;
	color: #fff;
	padding: 0 0 30px 0;
	margin-top: -1px;
	text-align: center;
	line-height: 1.4;
	background: #000;
}

div.pbg_blue {
	max-width: 860px;
	min-height: 424px;
	padding: 35px 30px 40px 0;
	background: url(../img/pbg_blue.jpg) no-repeat center 30px;
	background-size: 100%;
}

div.pbg_blue p {
	margin-left: 55%;
	line-height: 1.4;
	font-size: 90%;
}

div.pbg_blue p.title {
	font-size: 135%;
	text-align: center;
}

}

@media screen and (max-width:480px) { 
	/* 画面サイズが480pxまで */

div.midasitxt {
	font-size: 90%;
	color: #fff;
	padding: 0 0 20px 0;
	text-align: center;
	line-height: 1.4;
	background: #000;
}

div.pbg_blue {
	max-width: 480px;
	height: auto;
	padding: 20px 0 20px 0;
	
}

div.afbl {
	padding: 10px;
	border: 10px solid #ddd;
}

div.pbg_blue p {
	margin: 0 0 10px 0;
	line-height: 1.4;
	font-size: 85%;
}

div.pbg_blue p.title {
	font-size: 125%;
	font-weight: bold;
	padding: 10px 0 5px;
	text-align: center;
}


}








/********** footer
 ******************************/

footer {
	background: #000;
	color: #fff;
	text-align: center;
	padding: 30px;

}

footer a {
	color: #fff;
	text-decoration: none;
}


/********** page-top
 ******************************/

#page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    font-size: 77%;
}
#page-top a {
    background: #666;
    text-decoration: none;
    color: #fff;
    width: 100px;
    padding: 30px 0;
    text-align: center;
    display: block;
    border-radius: 5px;
}
#page-top a:hover {
    text-decoration: none;
    background: #999;
}









@media screen and (min-width:769px) {
	/* 画面サイズが769pxから */

}

@media screen and (min-width:481px) and (max-width:768px) {
	/* 画面サイズが481pxから768pxまで */

}

@media screen and (max-width:480px) { 
	/* 画面サイズが480pxまで */

}














