@charset "utf-8";


/*【全体の設定】
━━━━━━━━━━━━━━━━━━━━━━━*/
html {
	height: 100%;
	}
body {
	width: 100%;
	height: 100%;
	text-align: center;
	font-size: 14px;
	line-height: 1.5em;
	font-family: "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ ゴシック", "MS Gothic", monospace;
	}

#bg {
	background-image: url("../../img/raillore/bg.gif");
	background-repeat: repeat;
	background-position: center top;
	background-color: #ddf4ff;
	width:100%;
	min-width: 980px;
	position: relative;
	}


#main {
	width: 980px;
	margin: 0 auto;
	background-repeat: repeat-y;
	background-position: center top;
	}


/*【ヘッダー】
━━━━━━━━━━━━━━━━━━━━━━━*/
#page_header {
	width: 100%;
	height: 100px;
	min-width: 980px;
	margin: 0 auto;
	background-image: url("../../img/raillore/bg_header.png");
	background-repeat: no-repeat;
	background-position: center top;
	}
#page_header_wrapper {
	width:980px;
	margin: 0 auto;
	position: relative;
/*	z-index: 1;*/
	}
#page_header h1 {
	float: left;
	left: 12px;
	top: 0px;
	position: relative;
	}
#page_header_string {
	float: left;
	margin: 12px 0 0 20px;
	position: relative;
	}
#page_header_twitter {
	position: absolute;
	float: right;
	right: 16px;
	top:56px;
	}

/*【フッター】
━━━━━━━━━━━━━━━━━━━━━━━*/
#page_footer {
	width: 100%;
	min-width: 980px;
	height: 60px;
	margin: 0;
	background-image: url("../../img/raillore/bg_footer.png");
	background-repeat: no-repeat;
	background-position: center top;
	}
#page_footer p {
	width: 600px;
	margin: 0 auto;
	padding: 20px 10px 0;
	text-align: center;
	text-shadow: 1px 0px 0px #456d85;
	font-weight: nomal;
	color: #fff;
	font-size: 19px;
	}

/*【トップイメージ】
━━━━━━━━━━━━━━━━━━━━━━━*/

#top_image {
	width:980px;
	text-align: center;
	margin: 8px auto 0;
	position: relative;
	}

#top_image .top_border {
	border: 3px solid #fff;
	}

#top_image .img_copy {
	position: absolute;
	margin: 0 auto;
	left: 0px;
	top: 0px;
	}

.f_clear {
	clear: both;
	}

.blank1 {
	clear: both;
	width: 800px;
	height: 8px;
	margin: 0 auto;
	}

.blank2 {
	clear: both;
	width: 800px;
	height: 16px;
	margin: 0 auto;
	}

.captionbar {
	clear: both;
	width: 540px;
	height: 36px;
	margin: 0 auto;
	text-align: center;
	border: 2px solid #fff;
	background-color:rgba(90,90,140,1.0);
	border-radius:20px;
	-webkit-border-radius:20px;
	-moz-border-radius:20px;
	}

.captionbar p {
	color: #fff;
	font-size: 24px;
	padding: 8px 0 0;
	line-height: 24px;
	font-weight: bold;
	text-shadow: 1px 1px 0px #224;
	}

.frame_wrapper {
	position: relative;
	text-align: center;
	margin: 0 auto;
	width: 970px;
	border:2px solid #779;
	background-color:rgba(222,222,233,0.9);
	border-radius:8px;
	-webkit-border-radius:8px;
	-moz-border-radius:8px;
	}

.frame_box {
	margin: 0 auto;
	width: 920px;
	border:1px solid #447;
	background-color:rgba(255,255,255,1.0);
	//border-radius:4px;
	//-webkit-border-radius:4px;
	//-moz-border-radius:4px;
	}

/*【ストア】
━━━━━━━━━━━━━━━━━━━━━━━*/
.store {
	width: 980px;
	margin: 12px auto;
	}
.store h1 {
	display: none;
	}

.store_box {
	position: relative;
	margin: 12px auto 0;
	text-align: center;
/*	width: 800px;*/
	width: 910px;
	height: 110px;
	}
.android {
/*
	position: absolute;
	text-align: center;
	top: 0px;
	left: 36px;
*/
	position: relative;
	text-align: center;
	margin: 0 auto;
	float: left;
	width: 450px;
	}
.android .text {
	color: #000;
	padding: 4px 20px;
	/*font-weight: bold;*/
	text-align: center;	/*配信後はleftに*/
}
.iphone {
/*
	position: absolute;
	text-align: center;
	top: 0px;
	left: 400px;
*/
	position: relative;
	text-align: center;
	margin: 0 auto;
	float: left;
	width: 450px;
	}
.iphone .text {
	color: #000;
	padding: 4px 20px;
	/*font-weight: bold;*/
	text-align: center;	/*配信後はleftに*/
}

.iphone_center {
	position: relative;
	text-align: center;
	}

.iphone_center .text {
	color: #000;
	padding: 4px 20px;
	/*font-weight: bold;*/
	text-align: center;	/*配信後はleftに*/
}

.android_center {
	position: relative;
	text-align: center;
	}

.android_center .text {
	color: #000;
	padding: 4px 20px;
	/*font-weight: bold;*/
	text-align: center;	/*配信後はleftに*/
}


#moeapp_store {
	width: 980px;
	margin: 12px auto;
	}
#moeapp_store h1 {
	display: none;
	}

#moeapp_dl {
	margin: 12px auto 8px;
	}

#moeapp_dl .button {
	margin: 0 4px;
	}

#moeapp_dl2 {
	margin: 12px auto 8px;
	}

#moeapp_dl2 .button {
	margin: 0 4px;
	}


#moeapp_text {
	width: 900px;
	height: 76px;
	margin: 8px auto 0;
	position: relative;
	text-align: center;
	}

#moeapp_text p {
	color: #000;
	font-size: 20px;
	padding: 2px 0px;
	line-height: 26px;
	text-shadow: 1px 0px 0px #aaa;
	}

#moeapp_text1 {
	width: 900px;
	height: 34px;
	margin: 8px auto 0;
	position: relative;
	text-align: center;
	}

#moeapp_text1 p {
	color: #000;
	font-size: 20px;
	padding: 2px 0px;
	line-height: 26px;
	text-shadow: 1px 0px 0px #aaa;
	}

#moeapp_text2 {
	width: 900px;
	height: 60px;
	margin: 8px auto;
	position: relative;
	text-align: center;
	}

#moeapp_text2 p {
	color: #000;
	font-size: 20px;
	padding: 2px 0px;
	line-height: 26px;
	text-shadow: 1px 0px 0px #aaa;
	}

#moeapp_text2 .red {
	color: #f00;
	text-shadow: 1px 0px 0px #faa;
	}

#moeapp_text1  a:visited {
	font-weight: bold;
	text-shadow: 1px 0px 0px #aaa;
	}

#moeapp_text2  a:visited {
	font-weight: bold;
	text-shadow: 1px 0px 0px #aaa;
	}

/*【インフォメーション】
━━━━━━━━━━━━━━━━━━━━━━━*/
#information {
	width: 980px;
	margin: 12px auto;
}

#information h1 {
	display: none;
	}

#information .text_box {
	overflow:auto;
	margin: 12px auto;
	text-align: left;
	width: 880px;
	height: 76px;
	background-color:#fff;
	}

#information .text_box p {
	font-size: 18px;
	color: #222;
	text-shadow: 0px 0px 1px #aaa;
	line-height: 31px;
	margin: 3px 0;
	padding: 4px 10px 4px;
	}

/*【ストーリー】
━━━━━━━━━━━━━━━━━━━━━━━*/
#story {
	width: 980px;
	margin: 12px auto;
	}

#story h1 {
	display: none;
	}

#story .storyboxt {
	position: relative;
	width: 900px;
	height: 520px;
	text-align: left;
	margin: 0 auto;
	background-image: url("../../img/raillore/tstory_bg.jpg");
	background-repeat: no-repeat;
	background-position: center top;
	overflow: hidden;
	}

#story .storybox {
	position: relative;
	width: 900px;
	text-align: left;
	margin: 0 auto;
	}

#story .story_title {
	position: relative;
	font-size: 24px;
	color: #fff;
	line-height: 28px;
	height: 28px;
	margin: 0 auto;
	padding: 14px 0 0 0;
	font-weight: bold;
	z-index: 1;
	text-align: center;
	text-shadow: 1px 1px 1px #a6c, 0px 0px 0px #009, 1px 0px 1px #009, -1px 0px 1px #009, 0px 1px 1px #009, 0px -1px 1px #009;
	}

#story .tbox {
	position: relative;
	margin: 0 auto;
	text-align: left;
	}

#story .tcg1 {
	position: relative;
	margin: 10px 0 0 30px;
	float: left;
	border: 3px solid #fff;
	}

#story .tbox1 {
	position: relative;
	margin: 20px 0 0 20px;
	width: 455px;
	height: 380px;
	padding: 10px 12px 0 16px;
	float: left;
	background-color: rgba(255,255,255,0.9);
	border-radius:32px;
	-webkit-border-radius:32px;
	-moz-border-radius:32px;

	}

#story .tbox1 p {
	font-size: 18px;
	color: #000;
	text-shadow: 1px 0px 1px #b00;
	line-height: 24px;
	margin: 0;
	padding: 20px 0 0 10px;
	font-weight: normal;
	}

#story .systxt {
	position: relative;
	margin: 10px auto 0;
	text-align: left;
	line-height: 22px;
	width: 880px;
	height: 24px;
	clear: both;
	}

#story .sbox {
	position: relative;
	width: 890px;
	height: 2050px;
	margin: 4px auto 0;
	text-align: center;
	background-image: url("../../img/raillore/story_bg.jpg");
	background-repeat: no-repeat;
	background-position: left top;
	border-radius:8px;
	-webkit-border-radius:8px;
	-moz-border-radius:8px;
	}

#story .scg {
	position: relative;
	margin: 20px auto;
	z-index: 1;
	}

#story .sdcg {
	position: absolute;
	margin: 0;
	z-index: 2;
	}

#story .stxt {
	position: absolute;
	margin: 0 0;
	text-align: left;
	line-height: 22px;

	//background-color: rgba(70,90,100,0.8);
	background-color: rgba(245,245,245,0.7);
//	border-radius:8px;
//	-webkit-border-radius:8px;
//	-moz-border-radius:8px;
	}

#story .stxt p {
	padding: 20px 20px 0 30px;
	color: #700;
	font-size: 16px;
	//font-weight: bold;
	//text-shadow: 0px 1px 0px #000, 0px -1px 0px #000, 1px 0px 0px #000, -1px 0px 0px #000, 0px 0px 2px #000;
	text-shadow: 1px 0px 1px #00f,1px 0px 1px #fff,0px 1px 1px #fff;
	}


#story .stxt01 {
	top:80px;
	left:80px;

	width: 750px;
	height:240px;
}


#story .stxt02 {
	top:520px;
	left:80px;

	width: 750px;
	height:200px;
}

#story .stxt03 {
	top:920px;
	left:80px;

	width: 750px;
	height:280px;
}

#story .stxt04 {
	top:1250px;
	left:80px;

	line-height: 21px;

	width: 750px;
	height:360px;
}

#story .stxt05 {
	top:1660px;
	left:80px;

	line-height: 21px;

	width: 750px;
	height:360px;
}


/*【キャラクター】
━━━━━━━━━━━━━━━━━━━━━━━*/
#chara {
	width: 980px;
	margin: 12px auto;
	}

#chara h1 {
	display: none;
	}

#chara .c_cg1 {
	position: absolute;
	text-align: left;
	margin: 0;
	z-index: 3;
	top: 40px;
	left: 200px;
	}

#chara .c_cg2 {
	position: absolute;
	margin: 0;

	bottom:0px;
	left:0px;

	z-index: 2;
	}

#chara .chara_base {
	position: relative;
	margin: 0 auto;
	width: 920px;
	height: 900px;

	border-top: 1px solid #48b;
	border-bottom: 1px solid #48b;

	background-color:rgba(60,120,180,0.2);

	background-image: url("../../img/raillore/charabg.png");
	background-repeat: no-repeat;
	background-position: left top;

	overflow: hidden;
	}


#chara .cbg01 {
	}
#chara .cbg02 {
	}
#chara .cbg03 {
	}
#chara .cbg04 {
	}
#chara .cbg05 {
	}
#chara .cbg06 {
	}

#chara .cg1pos01 {
	left: 380px;
	top: -70px;
	}
#chara .cg1pos02 {
	left: 370px;
	top: -35px;
	}
#chara .cg1pos03 {
	left: 370px;
	top: -30px;
	}
#chara .cg1pos04 {
	left: 370px;
	top: -10px;
	}
#chara .cg1pos05 {
	left: 400px;
	top: -30px;
	}
#chara .cg1pos06 {
	left: 410px;
	top: -30px;
	}

#chara .cg2pos01 {
	bottom:-10px;
	left:20px;
	}
#chara .cg2pos02 {
	bottom:-10px;
	left:20px;
	}
#chara .cg2pos03 {
	bottom:-10px;
	left:20px;
	}
#chara .cg2pos04 {
	bottom:-10px;
	left:20px;
	}
#chara .cg2pos05 {
	bottom:-10px;
	left:20px;
	}
#chara .cg2pos06 {
	bottom:-2px;
	left:20px;
	}

#chara .namebg {
	position: absolute;

	margin: 0;
	text-align: center;
	width: 920px;
	height: 80px;

	top: 0px;
	left: 0px;

	background-color: rgba(90,180,240,0.9);

	z-index: 1;
	}

#chara .nbgc1 {
	background-color: rgba(110,110,160,1.0);
	}
#chara .nbgc2 {
	background-color: rgba(110,110,160,1.0);
	}
#chara .nbgc3 {
	background-color: rgba(110,110,160,1.0);
	}
#chara .nbgc4 {
	background-color: rgba(110,110,160,1.0);
	}
#chara .nbgc5 {
	background-color: rgba(110,110,160,1.0);
	}
#chara .nbgc6 {
	background-color: rgba(110,110,160,1.0);
	}

#chara .namebox {
	position: absolute;
	margin: 0 auto;
	width: 920px;
	height: 80px;
	top: 0px;
	left: 0px;
	z-index: 2;
}

#chara .name {
	position: relative;
	margin: 0;
	width: 840px;
	height: 42px;
	line-height: 35px;
	font-size: 32px;
	z-index: 5;
	left: 30px;
	//border: 1px solid #fff;
	}

#chara .name p {
	padding: 10px 0 0;
	color: #fff;
	text-align: left;
	text-shadow: 1px 1px 2px #124, 0px 0px 1px #002;
	font-weight: bold;
	}

#chara .kana {
	position: relative;
	text-align: left;
	margin: 3px 0 0;
	width: 500px;
	height: 30px;
	line-height: 22px;
	z-index: 5;
	left: 30px;
	float: left;
	//border: 1px solid #fff;
	}

#chara .kana p {
	padding: 7px 0 0 8px;
	font-size: 18px;
	color: #fff;
	text-shadow: 1px 1px 2px #124, 0px 0px 1px #002;
	font-weight: bold;
	}

#chara .cv {
	position: relative;
	text-align: left;
	margin: 3px 0 0 0;
	width: 230px;
	height: 30px;
	font-size: 22px;
	line-height: 24px;
	left: 60px;
	//float: right;
	z-index: 5;
	//border: 1px solid #fff;
	}

#chara .cv p {
	padding: 7px 4px 0 0;
	color: #fff;
	text-shadow: 1px 1px 2px #124, 0px 0px 1px #002;
	font-weight: bold;
	}

#chara .line {
	position: absolute;
	margin: 0 auto;
	width: 440px;
	height: 2px;
	top: 45px;
	left: 0;
	background-color: #444;
	clear: both;
	z-index: 4;
	}

#chara .txt {
	position: absolute;
	width: 440px;
	height: 600px;
	text-align: left;
	line-height: 25px;

	top: 90px;
	left: 10px;

	background-color: rgba(90,90,120,0.7);

	z-index: 5;

//	border: 1px solid #f00;

	}


#chara .txt p {
	padding: 16px 14px 0;
	font-size: 19px;
	color: #fff;
	font-weight: normal;
	text-shadow: 1px 0px 1px #fff,1px 1px 1px #003;
	
/*
	text-shadow: 1px 0px 0px #000,
				 -1px 0px 1px #fff, 0px -1px 1px #fff, -1px -1px 1px #fff, 1px 0px 1px #fff, 0px 1px 1px #fff, 1px 1px 1px #fff,
				 -1px 0px 0px #fff, 0px -1px 0px #fff, -1px -1px 0px #fff, 1px 0px 0px #fff, 0px 1px 0px #fff, 1px 1px 0px #fff,
				 2px 0px 0px #fff,2px 1px 0px #fff;
*/
	}

#chara .spec {
	position: absolute;
	margin: 0;
	text-align: left;
	width: 340px;
	height: 70px;
	line-height: 24px;

	top: 540px;
	left: 25px;

	//background-color: rgba(20,120,230,0.6);
	background-color: rgba(40,120,190,0.7);
	z-index: 7;

	border-radius:20px;
	-webkit-border-radius:20px;
	-moz-border-radius:20px;
	}

#chara .spec p {
	padding: 10px 20px 0;
	font-size: 15px;
	color: #fff;
	text-shadow: 1px 1px 3px #588, 1px 1px 0px #000;
	}

#chara .mes {
	position: absolute;
	margin: 0;
	text-align: right;
	width: 550px;
	height: 100px;
	line-height: 40px;

	bottom: 30px;
	left: 0px;

	font-size: 20px;

	background-color: rgba(110,110,160,0.7);
	z-index: 7;
	}


#chara .mes p {
	padding: 8px 28px 0 0;
	color: #fff;
	font-weight: bold;
	text-shadow: 1px 1px 3px #588, 1px 1px 0px #000, 2px 2px 0px #000;
	}

/*【サンプル画像】
━━━━━━━━━━━━━━━━━━━━━━━*/
#sample {
	width: 980px;
	margin: 12px auto;
	}

#sample h1 {
	display: none;
	}

.sample_block {
	width: 900px;
	height: 108px;
	margin: 0 auto;
	text-align: center;
	}

.sample_block .tm {
	margin: 0 10px;
	}

.sample_block a img {
	border: 1px solid #fff;
	opacity: 1;
	box-shadow: 1px 1px 2px rgba(0,0,0,0.4);
	transition: all 0.2s linear 0;
	}
.sample_block a:hover img {
	border: 1px solid #f00;
	opacity: 0.8;
	}

/*【ムービー】
━━━━━━━━━━━━━━━━━━━━━━━*/
#movie {
	width: 980px;
	margin: 12px auto;
	}

#movie h1 {
	display: none;
	}

#movie .t_title {
	position: relative;
	width: 900px;
	height:110px;
	margin: 14px auto 0;
	padding: 0;
	text-align: center;
	}

#movie .t_title p {
	padding: 4px;
	font-size: 14px;
	line-height: 16px;
	font-weight: normal;
	color: #0060ff;
	text-shadow: 1px 1px 1px #831;
	}

#movie .m_box {
	position: relative;
	width: 800px;
	margin: 0 auto;
	text-align: center;
	background-color:rgba(150,36,255,0.3);
	border-radius:8px;
	-webkit-border-radius:8px;
	-moz-border-radius:8px;
	}

/*【ページトップ】
━━━━━━━━━━━━━━━━━━━━━━━*/
#pagetop {
	position: fixed;
	bottom: 60px;
	right: 0px;
	display: none;
	z-index: 10;
	}

/*【商品仕様】
━━━━━━━━━━━━━━━━━━━━━━━*/
#product {
	width: 900px;
	margin: 0 auto 0;
	padding: 0 0 24px;
	background: transparent;
	font-size: 20px;
	line-height: 21px;
	color: #fff;
	}
#product h1 {
	font-size: 24px;
	line-height: 28px;
	font-weight: bold;
	color: #a050dd;

	text-shadow: 1px 1px 0px #fff;
	}
#product table {
	margin: 0 auto;
	}
#product th {
	border:1px solid #369;
	}
#product td {
	border:1px solid #369;
	}
#product td {
	padding: 4px 10px;
	font-size: 18px;
	color: #000;
	text-shadow: 1px 1px 1px #aaa;
	background-color: rgba(255,255,255,0.9);
	}

#product th {
	text-align: right;
	width: 180px;
	padding: 4px 6px 0 0;
	font-size: 20px;
	line-height: 24px;
	color: #fff;
	text-shadow: 1px 1px 1px #033;
	background-color:rgba(120,120,218,0.9);
	}

#product .model {
	width: 330px;
	}


/*【インストール画面】
━━━━━━━━━━━━━━━━━━━━━━━*/
#inst {
	width: 980px;
	margin: 12px auto;
	}
#inst h1 {
	display: none;
	}

#inst .title {
	font-size: 22px;
	line-height: 24px;
	font-weight: bold;
	color: #000;
	}

#inst .dl {
	margin: 12px auto 8px;
	}

#inst .dl_button {
	margin: 0 8px;
	}

#inst_android {
	display:inline;
	}
#inst_other {
	display:inline;
	}

#inst_qr {
	position: relative;
	background:#fff;
	margin: 0 auto;
	text-align: center;
	padding:0;
	width: 500px;
	height: 440px;
	line-height: 14px;
	border:1px solid #aaa;
	}

#inst_qr .titleimg {
	margin: 0 auto;
	padding:0;
	}

#inst_qr .qr {
	position: relative;
	margin: 0 auto;
	padding:0;
	width: 400px;
	height:140px;
	}
#inst_qr .qrimg {
	position: relative;
	width:135px;
	height:135px;
	margin: 0 auto;
	text-align: center;
	padding: 0;
	float:left;
	}

#inst_qr .qrtext {
	position: relative;
	text-align: left;
	width:240px;
	height:135px;
	margin: 0 auto;
	padding:20px 0 0;
	line-height: 20px;
	float:left;
	}

.apk_inst_qr {
	}

.apk_inst_qr a:hover img {
//	border: 1px solid #000;
//	opacity: 0.8;
	}

.b_button {
	margin: 16px auto 20px;
	}

