@charset "utf-8";

html {
	font-size: 10px;
}

#footer small {
	margin: 6px 0 6px;
}

div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td, img {margin: 0; padding: 0;}

a img {border: none;}

li {list-style: none;}

img {
  max-width: 100%;
  border: none;
  vertical-align: bottom;
}

.color {color: #fff100;}

.color2 {color: #F6F;}

.red {color: #F00;}

.clear {clear: both;}

.half {letter-spacing:-0.3em;}
/* CSS基本設定ここまで　*/

/* Firefox, Safari, Chrome, Opera fluid Image */
img.fluid-image {
	max-width:100%;
}


.mainBox {
	width: 100%;
}

#wrap {
	width: 640px;
	max-width: 100%;
	margin: 0 auto;
}

.topImg {
	text-align:left;
}

.topImg img {
    max-width: 98%;
    margin: 0 auto;
    position: relative;
    display: block;
}

#info{
	padding:0 6px 0 10px;
	position:relative;
	margin: 0 0;
}

.detail{/* #infoテキスト */
	font-size: 1rem;
	line-height:1.3em;
	float:left;
	text-align:left;
	margin-top:-2px;
	width:58%;
}

.appsBTN {/* appleボタン */
	margin-top:-0.5em;
	text-align:right;
	width:42%;
	float:right;
}

.appsBottomBTN {
	text-align:center;
	margin:6px auto 0;
}

.fb_tw {/* facebook・twitter */
	width:100%;
	float:left;
}

.sns {
	width: auto;
  position: relative;
  overflow: hidden;
  margin: 12px 0 16px;
}

.sns ul {
  position: relative;
  float: left;
  left: 50%;
}

.sns li {
  position: relative;
  float: left;
  left: -50%
}

.sns li:nth-child(2) {
  margin-left: 6px;
}

.sns li:nth-child(3) {
  margin-left: 4px;
}


.infoText p{
	margin-bottom:-0.2em;
}

.appsBTN {/* appleボタン */
	text-align:right;
	width:42%;
	float:right;
}

.dpk_APP a{
	width:128px;
	height:37px;
	margin:0 0 0 10;
}

.topMenu {
	height:75px;
	overflow: hidden; /*floatの解除、ここがポイント*/
    position: relative; /*DWで正常にプレビューできるようになります。*/
    zoom:1;/*IE6でレイアウト崩れを防ぐためのものです。*/
}

.topMenu li{
	float:left;
}

#spBTN,
.spBTN {
	max-width: 200px;
	height: 44px;
	border: #39280c solid 1px;
	border-radius: 6px;
	margin-top: 3px;
	background: #b52d90;
	background: -webkit-linear-gradient(top,  #cb60b3 1%,#933681 50%,#840063 51%,#b52d90 100%);
	background: linear-gradient(to bottom,  #cb60b3 1%,#933681 50%,#840063 51%,#b52d90 100%);
	cursor: pointer;
}

#spBTN a{
	height:44px;
	color:#fff;
	font-weight:bold;
	line-height:3em;
	text-decoration:none;
	display:block;
}

#spBTN_off {
	color:#999;
	line-height:2.5em;
	height:44px;
	border:#39280c solid 1px;
	border-radius:6px;
	-webkit-border-radius:6px;
	margin-top:3px;
	border:#333 solid 1px;
	border-bottom:#333 solid 1px;
	background: #4da7e5;
	background: -webkit-linear-gradient(top,  #333 0%,#666 100%);
	background: linear-gradient(to bottom,  #333 0%,#666 100%);
}

#spBTN_off img {
	float:left;
	position:relative;
	top:3px;
	left:10px;
}

#box01 p {
	font-size: 1rem;
}

.box01text {
	text-align:center;
	width:90%;
	margin:0 20px 0;
	font-size: 1.6rem;
}

/* pharaoh
-------------------------------------------------- */

#pharaoh {
	margin: 0 auto;
	text-align: center;
	font-size: 1rem;
}

#pharaoh p {
	padding: 0 6px 0;
	text-align: left;
	margin-bottom: 8px;
}

#pharaoh p:nth-child(2) {
	font-weight: bold;
	color: #61380b;
	background: #f7d358;
	text-align: center;
}

#pharaoh p:nth-child(4) {
	padding-bottom: 8px;
	margin-bottom: 14px;
	border-bottom: 1px solid #f7d358;
}

/* 1st
-------------------------------------------------- */

#first {
	margin: 0 auto;
	text-align: center;
	font-size: 1rem;
}

#first p {
	padding: 0 6px 0;
	text-align: left;
	margin-bottom: 8px;
}

/* menubtn
-------------------------------------------------- */

#menubtn {
	position: relative;
	overflow: hidden;
	margin-bottom: 6px;
}

#menubtn ul {
	position: relative;
	left: 50%;
	float: left;
}

#menubtn ul li {
	position: relative;
	left: -50%;
	float: left;
}

#menubtn ul li:nth-child(n+2) {
	padding-left: 10px;
}

/* article
-------------------------------------------------- */

#article {
	font-size: 1rem;
}

#article img {
	margin: 6px 0 6px;
}

/*
---------------------------- */

#new p {
	padding: 0 6px 0;
	text-align: left;
}

#new p:nth-child(2) {
	font-weight: bold;
	margin: 0 6px 4px 6px;
	color: #61380b;
	background: #f7d358;
	padding: 1px 4px 1px;
}

#new p:nth-child(4) {
	margin-bottom: 8px;
}

#new p:nth-child(6) {
	margin-bottom: 10px;
}

#new p:nth-child(7) {
	font-weight: bold;
	margin: 0 6px 4px 6px;
	color: #61380b;
	background: #f7d358;
	padding: 1px 4px 1px;
}

#new p:nth-child(10) {
	margin: 6px 0 2px;
	text-align: right;
}


/*
---------------------------- */

#boss p {
	padding: 0 6px 0;
	text-align: left;
}

#boss p:nth-child(5) {
	margin: 6px 0 2px;
	text-align: right;
}

/*
---------------------------- */

#score p {
	padding: 0 6px 0;
	text-align: left;
}

#score p:nth-child(even) {
	font-weight: bold;
	margin: 0 6px 4px 6px;
	color: #61380b;
	background: #f7d358;
	padding: 1px 4px 1px;
}

#score p:nth-child(odd) {
	padding-bottom: 4px;
	margin-bottom: 10px;
	border-bottom: 1px dashed #fff;
}

/*
---------------------------- */

#rino_card p {
	padding: 0 6px 0;
	text-align: left;
}

#rino_card p:nth-child(4) {
	font-weight: bold;
	margin: 0 6px 4px 6px;
	color: #61380b;
	background: #f7d358;
	padding: 1px 4px 1px;
}

#rino_card p:nth-child(5) {
	border-bottom: 1px dashed #fff;
	padding-bottom: 4px;
	margin-bottom: 8px;
}

#rino_card p:nth-child(7) {
	font-weight: bold;
	margin: 0 6px 4px 6px;
	color: #61380b;
	background: #f7d358;
	padding: 1px 4px 1px;
}

#rino_card p:nth-child(9) {
	margin: 6px 0 2px;
	text-align: right;
}


/*
---------------------------- */

#card p {
	padding: 0 6px 0;
	text-align: left;
}

#card p:nth-child(3) {
	font-weight: bold;
	margin: 0 6px 4px 6px;
	color: #61380b;
	background: #f7d358;
	padding: 1px 4px 1px;
}

#card p:nth-child(4) {
	padding-bottom: 4px;
	margin-bottom: 8px;
	border-bottom: 1px dashed #fff;
}

#card p:nth-child(6) {
	font-weight: bold;
	margin: 0 6px 4px 6px;
	color: #61380b;
	background: #f7d358;
	padding: 1px 4px 1px;
}

#card p:nth-child(7) {
	padding-bottom: 4px;
	margin-bottom: 10px;
	border-bottom: 1px dashed #fff;
}

#card p:nth-child(9) {
	font-weight: bold;
	margin: 0 6px 4px 6px;
	color: #61380b;
	background: #f7d358;
	padding: 1px 4px 1px;
}

#card p:nth-child(11) {
	margin: 6px 0 2px;
	text-align: right;
}

/*
---------------------------- */

#difficulty p {
	padding: 0 6px 0;
	text-align: left;
}

#difficulty p:nth-child(4) {
	margin: 6px 0 2px;
	text-align: right;
}

/*
---------------------------- */

#gatsha p:nth-child(11) {
	margin: 6px 0 2px;
	text-align: right;
}

/*
---------------------------- */

#collabo {
	margin-bottom: 16px;
}

#collabo p {
	padding: 0 6px 0;
}

#collabo p:nth-child(5) {
	margin-bottom: 6px;
}

#collabo p:nth-child(7) {
	padding-bottom: 8px;
	border-bottom: 1px dashed #fff;
}

.footer{
	padding:20px 0;
}

.asobism_copy {
	clear:both;
	margin-bottom:20px;
}

.apple {
	font-size: 1.2rem !important;
}

.tw_link {/* ツイッターへのリンク */
	margin:10px 0 -10px 0;
}


.bikri {
	background:url(../../img/bikri.png) 31px 30px;
	width: 31px;
	height: 30px;
	background: url(../../img/bikri.png) 31px 30px;
	display: block;
	position: relative;
	top: 7px;
	left: 5px;
	float:left;
}

/* Youtube */
.bgmtitle {
	color:#FF0;
	text-align:center;
	padding-bottom:0.75em;
}

img.fluid-image {
	max-width:100%;
}

.youtube {
	max-height:100%;
}

#law {
	max-width: 96%;
	margin: 10px auto 20px;
	padding: 0 7vw 0;
	text-align: left;
	font-weight: normal;
}

#law p{
	text-indent:-1em;
	padding-left:1em;
}

.bold {
	font-size: 1.4rem;
	font-weight:bold;
	margin-top:10px;
}

#topreturn {
	margin: 20px 0 20px;
}

.cm1 {
	padding: 4px;
	text-align: left;
	background-color:#C03;
	border:#333 solid 2px;
}

.cm2 {
	padding: 4px;
	font-size: 1rem;
	text-align: left;
	background-color: #FFF;
	color:#000;
	border:#333 solid 2px;
}

/* color
-------------------------------------------------- */

.red {
}

.yellow {
	color: #ff0;
}

.green {
	color: #0f0;
}

span .bold {
	font-weight: bold;
	padding-top: 1px;
}


/* clearfix
-------------------------------------------------- */

.clearfix:after{
  content: ".";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}

#topreturn {
	color: #fff;
	background: #8a0829;
	padding: 3px 4px 4px;
	border-radius: 50% 50%;
	text-align: center;
}


.tezuka {
	max-width: 100%;
	margin: 0 auto 40px;
	text-align: center;
	background: #000;
}



.tezuka p {
	padding: 0 16px 0;
	margin: 8px 0 8px;
}

.tezuka p:nth-child(-n+4) {
  color: #ff0;
}

.tezuka p:nth-child(4) {
  margin: 0 0 32px;
}

.tezuka p:nth-child(6) {
  margin: 0 0 32px;
}

.tezuka h2 {
  font-size: 1.6rem;
  font-weight: bold;
  margin: 8px 0 8px;
}

.obi {
  background: #B40404;
  padding: 8px;
}

.tezuka p:nth-last-child(1) {
  margin: 16px 0 12px;
}

.tezuka img:nth-child(n+2) {
  margin: 12px 0 12px;
}

.playmovie {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}

.playmovie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}


.tlogo {
	margin: 100px 0  0;
}


/* notice
-------------------------------------------------- */

/*

.notice {
  margin: 36px 0 0;
}

*/

.noticeText {
  overflow: hidden;
  height: 300px;
}

.notice h1 {
  margin-bottom: 16px;
}

.notice ul {
}

.notice li {
  border-bottom: 1px solid #2e2e2e;
}

.notice li:nth-child(1) {
  border-top: 1px solid #2e2e2e;
}

.notice li p:nth-child(1) {
  color: #FFFFFF;
}

.notice li p:nth-child(2) {
  color: #424242;
  margin-top: 8px;
}

.notice li a {
  position: relative;
  display: block;
	padding: 12px 24px;
	font-size: 1.2rem;
  text-decoration: none;
}

.notice li a:before,
.notice li a:after {
  position: absolute;
  top: 50%;
  right: 5px;
  display: block;
  content: "";
  width: 12px;
  height: 3px;
  background: #888;
  border-radius: 4px;
}

.notice li a:before {
  margin-top: -4px;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
}

.notice li a:after {
  margin-top: 3px;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}

.notice_n {
  background: #faac58;
  padding: 1px 8px 1px;
  color: #fff;
  margin: 0 8px 0 0;
}




/* mainfooter
-------------------------------------------------- */

.mainfooter {
  padding: 16px;
  font-size: 0.9rem;
}

.mainfooter img {
    margin: 0 0 10px;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    width: 72px;
    max-width: inherit;
}

.mainfooter img:hover {
  opacity: 0.6;
}

.mainfooter a {
  color: rgba(180,180,180,1);
  -wenkit-transition: color 0.3s;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
  text-decoration: none;
}

.mainfooter a:hover {
  color: rgba(255,255,0,1);
}

.mainfooter p {
  font-family: Helvetica, Arial, Doroid Sans, Meiryo, "Hiragino Kaku Gothic Pro", sans-serif;
}

/* sns
-------------------------------------------------- */

.sns {
  position: relative;
  overflow: hidden;
  margin-bottom: 16px;
}

.sns ul {
  position: relative;
  float: left;
  left: 50%;
}

.sns li {
  position: relative;
  float: left;
  left: -50%
}

.sns li:nth-child(2) {
  margin-left: 2px;
}

.sns li:nth-child(3) {

}


/* 城ドラレイアウト追加
-------------------------------------------------- */

.return-top{
	margin-top:6vw;
}

.mainBox h2{
	font-size: 1.8rem;
	padding: 5vw 10vw;
	font-weight: bold;
	color:white !important;
	font-style:normal !important;
	text-align:center;
}

.top-return-btn {
	position:relative;
	margin:7vw auto 10vw;
}

@media screen and (min-width:640px) {

	.mainBox h2 {
		padding: 19px 30px;
	}

	.top-return-btn {
		position:relative;
		margin:45px auto 40px;
	}

}

/* システムページ
-------------------------------------------------- */

#systemPage .topImg{
	width: 94%;
    margin: 0 auto;
    box-sizing: border-box;
    padding: 0 5px;
}

#systemPage .blackBoxSysBG{
    width: 94%;
    margin: 0 auto;
    box-sizing: border-box;
	padding: 0 5px;
	box-shadow:none;
}

#systemPage .komidasi{
	font-size: 1.4rem;
  font-weight: bold;
	width: 100%;
	box-sizing: border-box;
	padding: 2px 10px;
	height: 38px;
}

#systemPage .sys-title{
    width: 94%;
    padding: 0 5px;
    box-sizing: border-box;
}

#systemPage .blackBoxSysBG{
	width: 94%;
	margin: 0 auto;
}


/* お問い合わせページ
-------------------------------------------------- */

#contactPage .topImg{
    width: 94%;
    margin: 0 auto;
    box-sizing: border-box;
    padding: 0 5px;
}


/* サウンドページ
-------------------------------------------------- */

#dl_contents{
	width: 90%;
	margin: 0 auto;
}

.soundtrack3{
	margin-top: 5vw;
}

.soundtrack_frame{
	position: relative;
}

.soundtr_btn{
	position: absolute;
	bottom: 5vw;
	margin: 0 auto;
	right: 0;
	left: 0;
}

.soundtr_btn img{
	width: 48vw;
}

.sound_img_app {
	margin-bottom: 3vw;
}

.soundtrack2{
	margin-top: 7vw;
}

.soundtrack1{
	margin-top: 7vw;
}

.topreturn_btn{
	margin: 11vw 0;
}

@media screen and (min-width:641px) {

  .soundtr_btn img {
    width: 100%;
    max-width: 320px;
  }

  .sound_img_app {
    margin-bottom: 15px;
  }

  .soundtr_btn{
    bottom: 25px;
  }

  .soundtrack2 {
    margin-top: 30px;
  }

}

/* rules 利用規約 改定 - 2020-0401
-------------------------------------------------- */

#rules {
	width:100%;
	margin: auto;
	padding: 20px;
	box-sizing:border-box;
	background:#000;
	color:#fff;
	text-align: left;
	font-size: 1.2rem;
	font-family: "Hiragino Kaku Gothic Pro", Meiryo, Osaka, "MS P Gothic", sans-serif;
}

#rules h2 {
	margin-bottom: 10px;
	font-size: 1.8rem;
	font-weight: bold;
	text-align: center;
	color:#fff;
}

#rules p {
	margin-bottom: 6px;
}

#rules h3 {
	font-size: 1.4rem;
	font-weight:bold;
	margin: 24px 0 8px;
}

#rules ul li ul {
  display: table;
}

#rules .PtDot li {
  text-indent: -2em;
  padding-left: 2em;
}

#rules .PtParen h4 {
  font-size: 1rem;
}

#rules .PtDot .PtParen li {
  text-indent: -3em;
  padding-left: 3em;
}

#rules ul li.article2 {
  text-indent: 0em;
  padding-left: 3em;
}

#rules .article9 .PtParen li {
  text-indent: 0;
  padding-left: 0;
}

#rules ul li ul li span:first-child {
  width:36px;
}

#rules ul li ul li span {
  display: table-cell;
  text-indent: 0;
  padding-left: 0;
}

#rules .SupplementaryProvision {
  margin-top: 2em;
  font-size: 1.1rem;
}

#spBTN{
	height:44px;
	border:#39280c solid 1px;
	border-radius:6px;
	margin-top:3px;
	background: #b52d90;
	background: -webkit-linear-gradient(top,  #cb60b3 1%,#933681 50%,#840063 51%,#b52d90 100%);
	background: linear-gradient(to bottom,  #cb60b3 1%,#933681 50%,#840063 51%,#b52d90 100%);
}

#spBTN a{
	height:44px;
	color:#fff;
	font-weight:bold;
	line-height:3em;
	text-decoration:none;
	display:block;
}

#spBTN_off {
	color:#999;
	line-height:2.5em;
	height:44px;
	border:#39280c solid 1px;
	border-radius:6px;
	-webkit-border-radius:6px;
	margin-top:3px;
	border:#333 solid 1px;
	border-bottom:#333 solid 1px;
	background: #4da7e5;
	background: -webkit-linear-gradient(top,  #333 0%,#666 100%);
	background: linear-gradient(to bottom,  #333 0%,#666 100%);
}

#spBTN_off img {
	float:left;
	position:relative;
	top:3px;
	left:10px;
}

@media screen and (min-width: 737px) {
	.mainfooter,
	.mainfooter small {
		font-size: 1.0rem;
	}
}
