html {
    font-size:62.5%;
}
body {
    background-size: 10px 10px;
    margin: 0 auto;
    background-color: #ffffff;
    background-image: radial-gradient(#9fd8f6 15%, transparent 20%),
                    radial-gradient(#9fd8f6 15%, transparent 20%);
    background-position: 0 0, 15px 15px;
    color:#602100;
    font-size: 1.6rem;
}
a:link, a:visited {
	color:#d40c4e;
}
a:hover {
	opacity:0.7;
}

/****************footer & global menu*/
footer {
    background-color:#dd525a;
    color: #fff;
    font-size: 0.9em;
    padding: 20px;
    padding-bottom:30px;
    text-align: center;
	height:auto;
    display:block;
    line-height: 1.5;
    padding-bottom: 50px;
}
footer ul {
    margin: 0.5em;
    padding: 0;
}
footer li {
    display: inline;
    margin: 5px 10px;
	border:none;
}
footer li a:link, footer li a:visited {
    color: #fff;
}	
footer li a:hover {
    opacity:0.7;
}
footer p {
	margin-top:2em;
}
@media screen and (max-width: 768px) {
    html {
        font-size:52.5%;
    }
}

.wrap {
	color:#602100;
    line-height: 1.4;
	padding:0 0 30px;
    margin:0 auto;
    font-family:"Helvetica Neue", Helvetica, Arial, "Lucida Grande", "ヒラギノ角ゴ ProN W3", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	width:1000px;
	text-align:center;
}
section {
    margin: 20px auto 30px;
    text-align: left;
    overflow: hidden;
    padding-bottom:40px;
    background-color: #9fd8f6;
}
h1 {
    margin: 0;
}
h1 img{
    vertical-align: bottom;
}
h2 {
    text-align: center;
    margin:30px 0 20px;
}

small {
    color:#d3d3d3;
    margin-top: 30px;
    display: block;
}
@media screen and (max-width: 768px) {
    .wrap{
		width:100%;
		margin:0 auto !important;
        background-size: contain;
        padding: 0;
        padding-bottom: 20px;
        background-color:#ffffff;
        background-image: none;
	}
    section {
        width: 95%;
        box-sizing: border-box;
        padding:0;
		margin: 20px auto;
    }
    p {
        margin: 10px;
    }
	h1 {
		width: 100%;
    	margin: 0;
	}
    h1 img {
        width:100%;
    }
    h2 {
        clear:both;
        width:auto;
        margin: 20px auto 5%;
    }
    h2 img {
        height: 80px;
    }
}

/*メニュー*/
nav {
    font-size:2rem;
}
nav ul {
    display: flex;
    justify-content: space-between;
}
nav ul li {
    width: 25%;
    margin:0;
    padding: 10px 0;
    background-color: #ffffff;
    border: solid 1px #eb619f;
}
nav ul li a {
    text-decoration: none;
    padding:10px 0;
    width:100%;
    display: block;
    font-weight: bold;
    transition-property: opacity;
    transition-duration: 0.3s;
    transition-timing-function: ease-out;
}
nav ul li a:link, nav ul li a:visited {
    color:#eb619f;
}
nav ul li a:hover {
    opacity:0.6;
}
@media screen and (max-width: 768px) {
    nav {
        padding: 0;
        font-size: 1.8rem;
    }
    nav ul li {
        width:auto;
        margin-bottom: 0;
        padding:0;
    }
    nav ul li img {
        width:auto !important;
        height:27px;
    }
}

/*ストーリー*/
#story {
    text-align: center;
    padding-top: 60px;
}
#story p {
    margin: 20px 0;
}
#story h2 {
    position: absolute;
}
#story h2 img {
    position: relative;
    top: -60px;
    left: 650px;
}
.image {
    text-align: center;
    margin-left: 150px;
}
.image img {
    width:auto;
    max-width: 100%;
}
#story p.catch {
    font-weight: bold;
    color:#d40c4e;
    margin:30px 0;
    font-size:2rem;
}

@media screen and (max-width: 768px) {
    #story {
        padding:0;
    }
    #story h2 {
        position: absolute;
        right: 10%;
    }
    #story h2 img {
        position: relative;
        left: 0;
        top: 0;
    }
    .image {
        display:block;
        margin:20px auto;
        width:90%;
    }
    .image img {

    }
    #story p {
        width:95%;
        margin:0 auto;
        font-size: 1.3rem;
        margin-bottom: 40px;
    }
    #story p.catch {
        margin:0 auto;
        margin-bottom: 25px;
        margin-top: 25px;
        font-size:1.8rem;
    }
}


/*キャラクター*/
.chara_list {
    overflow: hidden;
    width:90%;
    margin:40px auto 30px;
    display:flex;
    justify-content: space-around;
    flex-wrap: wrap;
}
.chara_list li {
    width:45%;
    text-align: center;
}
.chara_list img {
    width:250px;
    border: solid 1px;
}
#chara h3, #comics h3, #cd h3 {
    font-size:2rem;
    color:#fff;
    font-weight: bold;
    background-color: #dd525a;
}
#chara h3 {
    width:250px;
    margin:20px auto;
}
@media screen and (max-width: 768px) {
    .chara_list {
        width:94%;
        font-size:1.3rem;
        margin-top: 30px;
    }
    .chara_list li {
        width:46%;
    }
    .chara_list img {
        width:90%;
    }
    #chara h3 {
        width:auto;
    }
}

/*コミック情報*/
div.comic_wrap {
    width:90%;
    margin:20px auto 10px;
}
#comics h3 {
    font-size:2.4rem;
    padding:5px;
}
div.comic {
    display:flex;
    margin: 30px auto;
}
.cover {
    width: 300px;
    text-align: center;
    margin-right: 50px;
    margin-left: 100px;
}
.cover img {
    width: 100%;
    vertical-align: bottom;
    border: solid 1px;
}
.text {
    width:400px;
}
dl.bio {
    overflow: hidden;
    margin:20px 0;
}
dl.bio dt {
    float:left;
    width:120px;
}
dl.bio dt:after {
    content:"：";
    display:inline;
    float:right;
}
.sell {
    margin: 40px 0;
}
a.button {
    display:block;
    text-decoration: none;
    text-align: center;
    margin:20px 0 0;
    padding:10px 0;
    background: #fff;
    width:300px;
    font-size:1.8rem;
    font-weight: bold;
    border:solid 1px #d40c4e;
}
a.button:link,a.button:visited {
    color:#d40c4e;
}
a.button:hover {
    opacity:0.7;
}
dl.novelty {
    clear:both;
    overflow: hidden;
    width:80%;
    margin:40px auto 0;
    text-align:center;
}
dl.novelty dt {
    font-size: 2rem;
    font-weight: bold;
    border: solid 1px;
    border-left: none;
    border-right: none;
    margin: 10px 0;
    padding: 0;
}
dl.novelty dd {
    float: left;
    width: 45%;
    height: auto;
    padding: 1% 1%;
    text-align:center;
}
dl.novelty dd img {
    width: 200px;
    margin-right: 0;
    margin-left: 15px;
    margin-top: 20px;
}
h4 {
    font-size: 2rem;
    font-weight: bold;
    border: solid 1px;
    border-left: none;
    border-right: none;
    padding: 0;
    text-align: center;
    width: 80%;
    margin:40px auto 0;
}

@media screen and (max-width: 768px) {
    a.button {
        float:none;
    }
	#comics div {
    	overflow: visible;	
	}
    div.comic {
        display:block;
    }
    .cover {
        margin: 0 auto;
    }
    .text {
        width:auto;
        margin: 30px 0;
        text-align: center;
    }
    dl.novelty {
        width: 100%;
	    margin: 0 auto;
    }
    dl.bio dt {
        width:100px;
    }
	dl.novelty dd {
		margin-bottom: 30px;
        height: 65vw;
	}
    dl.novelty dd img {
        width: 95%;
        bottom: 0;
        left: 5px;
        margin-left: 0;
    }
}
/****************特典情報*/
.toggle {
    cursor: pointer;
    display: block;
    text-decoration: none;
    text-align: center;
    margin: 20px auto 30px;
    padding: 10px 0;
    background: #fff;
    width: 300px;
    font-size: 1.8rem;
    font-weight: bold;
    border: solid 1px #d40c4e;
}
.toggle_area {
    display: none;
}
.shoplist dl, .shoplist ul.houjin{
    overflow:hidden;
    max-width:1000px;
    margin-bottom:10px;
}
.shoplist dl.houjin, .shoplist ul.houjin{
	margin-bottom:20px;
}
.shoplist dl dt{
    background:#dd525a;
    color:#fff;
}
.shoplist dl dt, .shoplist dl dd, .shoplist ul.houjin li{
    padding:5px;
  }
.shoplist dl dd, .shoplist ul.houjin li{
    float:left;
    margin-right:10px;
    display:block;
	width: 200px;
    text-align: left;
    text-indent: -11px;
    padding-left: 15px;
}
.shoplist ul.houjin {
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: end;
    align-items: end;
}
.shoplist ul.houjin li {
	margin-bottom:0;
	margin-left:0;
	line-height:1;
}
.shoplist dl dd:before, .shoplist ul.houjin li:before{
    content:'■';
}
.shoplist dl.houjin dd, .shoplist ul.houjin li {
	width:100%;
}

@media screen and (max-width: 769px) {
	#book h5.shoplist_title, #book .shoplist p {
		margin-left:5%;
	}
    .shoplist ul.houjin {
        width: 100%;
    }
}

/*スペシャル*/
#special h3 {
    font-size: 2rem;
    font-weight: bold;
    border-top: solid 1px;
    border-bottom: solid 1px;
    width: 90%;
    margin: 30px auto;
    padding: 5px 0;
}
#special div {
    margin-bottom:50px;
    text-align: center;
}
.link img {
    width:auto;
    max-width:100%;
    margin:20px 0;
}
@media screen and (max-width: 768px) {
    .link img {
        margin:0;
    }
}

/****************PageTOP*/
#page-top {
	position: fixed;
	bottom: 0;
	right: 0px;
	background-color:#dd525a;
	padding:10px;
	z-index: 100;
    width:100%;
    margin:0;
    text-align: right;
}
#page-top a:link, #page-top a:visited {
	color:#fff;
}