@charset "utf-8";

/* --------------------------------------------------
-------------------------------------------------- ページ全体 */
html {
	width: 100%;
	min-height: 100%;
	-webkit-text-size-adjust: 100%;
}
body {
	opacity: 0;
	width: 100%;
	min-height: 100%;
	background-color: #fff;
	color: #000;
	font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
	font-size: 16px;
	line-height: 1.5;
	overflow: hidden;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-smoothing: antialiased;
	-webkit-hyphens: auto;
	-ms-hyphens: auto;
	hyphens: auto;
	-webkit-text-size-adjust: 100%;
}

a:link {
	color: #ff3300;
	text-decoration: none;
}
a:visited {
	color: #ff3300;
	text-decoration: none;
}
a:hover {
	color: #ff3300;
	text-decoration: underline;
}
a:active {
	color: #ff3300;
	text-decoration: underline;
}

img {
	/*width: 100%;*/
}

a {
	-webkit-transition: 0.2s ease-in-out;
	-moz-transition: 0.2s ease-in-out;
	-o-transition: 0.2s ease-in-out;
	transition: 0.2s ease-in-out;
}
a:hover {

	-webkit-transition: 0.1s ease-in-out;
	-moz-transition: 0.1s ease-in-out;
	-o-transition: 0.1s ease-in-out;
	transition: 0.1s ease-in-out;
}

.btn a img {
	opacity: 1;
	-webkit-animation-duration: 0.8s;
	animation-duration: 0.8s;
}
.btn a:hover {
	opacity: 0.7;
}
.btn .disabled {
	opacity: 0.5;

}
.btn .disabled img {
    -webkit-filter: grayscale(100%);
    -moz-filter: grayscale(100%);
    -o-filter: grayscale(100%);
    -ms-filter: grayscale(100%);
    filter: grayscale(100%);
}

.fixed {
	position: fixed !important;
}

.lock {
    overflow:hidden;
}
.overlay {
    z-index:11;
    display:none;
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100%;
	background-color: #fff;
	opacity: 0.75;
}
.modal-wrap {
    z-index:12;
    display:none;
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100%;
    overflow:auto;
}
.modal-content {
    position:relative;
    display:none;
    width:100%;
    padding:10% 0;
    box-sizing: border-box;
    text-align: center;
}
.modal-image {
	margin: 0 auto;
	width: 800px;
}
.modal-text {
	padding: 40px;
	background-color: #fff;
	box-shadow: 0 0 10px 0 rgba(0,0,0,0.4);
	text-align: left;
}
.modal-text h2 {
	margin-bottom: 1.5em;
	padding: 0.5em;
	background-color: #000;
	color: #fff;
	text-align: center;
}
.modal-text h2 span {
	display: block;
	margin-top: 0.2em;
	font-size: 0.7em;
	font-weight: normal;
}
.modal-text .sign {
	text-align: right;
}
.modal-image p:not(:last-of-type) {
	margin-bottom: 30px;
} 
.modal-close {
	display: inline-block;
	margin: 20px auto 0 auto;
	padding: 5px 20px;
	background-color: #000;
	color: #fff;
	font-weight: bold;
	border: 2px solid #000;
	cursor: pointer;
	-webkit-transition: 0.2s ease-in-out;
	-moz-transition: 0.2s ease-in-out;
	-o-transition: 0.2s ease-in-out;
	transition: 0.2s ease-in-out;
}
.modal-close:hover {
	background-color: #fff;
	color: #000;
}

/* --------------------------------------------------
-------------------------------------------------- Clearfix */
.cf:before, .cf:after {
	content: "";
	display: table;
}
.cf:after {
	clear: both;
}
.cf {
	*zoom: 1;
}


/* --------------------------------------------------
-------------------------------------------------- ページ全体 */
.inner {
	position: relative;
	margin: 0 auto;
	width: 980px;
}



/* --------------------------------------------------
-------------------------------------------------- SNS */
.sns ul {
	font-size: 0;
}
.sns ul li {
	display: inline-block;
}
.sns ul li:not(:last-of-type) {
	margin-right: 10px;
}
.sns ul li:nth-child(2),
.sns ul li:nth-child(2) .fb_iframe_widget span,
.sns ul li:nth-child(2) .fb_iframe_widget iframe{
    width: 135px !important;
    height:20px !important;
}

.sns ul li:nth-child(3),
.sns ul li:nth-child(3) iframe{
    height: 20px !important;
}


/* -------------------------------------------------- ページ全体 */
#wrapper {

}
#contents {
	margin: 0 auto;
}

.separate {
	background-color: #e9e9e9;
}

.btn ul li .off {
	opacity: 0.5;
}
/* --------------------------------------------------
-------------------------------------------------- ナビゲーション */


/* --------------------------------------------------
-------------------------------------------------- キービジュアル */
#kv {
	overflow: hidden;
}
#kv .inner {
	height: 1230px;
}
#kv h1 {
	position: absolute;
	top: -50px;
	left: -58px;
}
#kv .book-walker {
	display: block;
	position: absolute;
	top: 80px;
	left: 304px;
	z-index:10;
}

#kv .sub01 {
	position: absolute;
	top: 49px;
	right: 0;
}
/*#kv .sub02 {
	position: absolute;
	top: 876px;
	left: 35px;
}*/
#kv .sub02 {
	position: absolute;
	top: 680px;
	left: 160px;
}
#kv .illust span {
	display: block;
	position: absolute;
}
#kv .illust .illust-nishino {
	top: 300px;
	left: 520px;
}
#kv .illust .illust-rose {
	top: 373px;
	left: 263px;
}
#kv .illust .illust-takeuchi {
	top: 303px;
	left: 673px;
}
#kv .illust .illust-shimizu {
	top: 201px;
	left: 323px;
}
#kv .illust .illust-matsuura {
	top: 224px;
	left: 476px;
}
#kv .illust .illust-tarosuke {
	top: 147px;
	left: 631px;
}
#kv .illust .illust-marquis {
	top: 56px;
	left: 391px;
}
#kv .illust .illust-francisca {
	top: 234px;
	left: 223px;
}
#kv .illust .illust-risachan {
	top: 193px;
	left: 567px;
}
#kv .illust .illust-gabriella {
	top: 476px;
	left: 164px;
}
#kv .illust .illust-baloon {
	top: 574px;
	left: 551px;
}

#kv .bonus-bn01 {
	display: block;
	position: absolute;
	top: 645px;
	left: 117px;
}

#kv .pop {
	display: block;
	position: absolute;
	top: 804px;
	left: 50px;
}

#kv .author {
	position: absolute;
	top: 421px;
	left: 56px;
	-webkit-animation-delay: 2.2s;
	animation-delay: 2.2s;
}

#kv .latest p {
	position: absolute;
	top: 458px;
	right: 0;
	-webkit-animation-delay: 2s;
	animation-delay: 2s;
}
#kv .latest figure {
	position: absolute;
	top: 516px;
	right: 20px;
	border: 1px solid #cecece;
	-webkit-animation-delay: 2s;
	animation-delay: 2s;
}
#kv .latest .btn {
	position: absolute;
	top: 740px;
	right: 20px;
	-webkit-animation-delay: 2.2s;
	animation-delay: 2.2s;
}
#kv .latest .btn ul {
	font-size: 0;
}
#kv .latest .btn ul li {
	margin-bottom: 7px;
	background-color: #000;
	border: 2px solid #000;
}

#kv .kakuyomu {
	display: block;
    position: absolute;
    top: 828px;
    right: 20px;
}

#kv .kakuyomu a:hover {
	opacity: 0.9;
}

#kv .sasaki {
	display: block;
    position: absolute;
    top: 902px;
    right: 20px;
}

#kv .sasaki a:hover {
	opacity: 0.9;
}

#kv .sns {
	position: absolute;
	top: 15px;
	right: 0;
	z-index: 3;
}

#kv .catch p {
	position: absolute;
}
#kv .catch p:nth-of-type(1) {
	top: 955px;
	left: 60px;
}
#kv .catch p:nth-of-type(2) {
	top: 992px;
	left: 60px;
}


/* --------------------------------------------------
-------------------------------------------------- ムービー */

#movie {
	background: url(../images/movie_dot01.png),url(../images/movie_bg01.png), url(../images/movie_bg02.jpg) top center repeat-x #ff2883;
	padding-bottom: 93px;
	margin-bottom: 82px;
	text-align: center;
}
#movie .inner {
	width: 898px;
	margin: 0 auto;
}

#movie h2 {
	margin-bottom: 48px;
}

#movie h2 img {
	margin-top: -30px;
}

#movie .mainvideo iframe{
	width: 898px;
	height: 505px;
}

#movie p {
	padding-top: 15px;
	font-size: 28px;
	color: #fff;
	font-weight: bold;
}
/* --------------------------------------------------
-------------------------------------------------- メディアミックス */

#mediamix {
	background: url(../images/mediamix_dot01.png), url(../images/mediamix_bg01.png) top center no-repeat,url(../images/mediamix_bg02.png) #00fff6;
	text-align: center;
	padding-bottom: 118px;
}

#mediamix .inner {
	width: 898px;
}

#mediamix h2 {
	margin-bottom: 48px;
}

#mediamix h2 img {
	margin-top: -30px;
}

#mediamix .audio-drama {
	margin-bottom: 38px;
}

#mediamix .audio-drama h3 {
	margin-bottom: 30px;
}

#mediamix .audio-drama .txt01 {
	margin-bottom: 38px;
}

#mediamix .audio-drama .txt02 {
	padding-bottom: 15px;
}

#mediamix .audio-drama .box {
	padding: 50px 0 30px;
	background-color: rgba(255,255,255,0.80)
}

#mediamix .audio-drama .cast {
	margin-top: -72px;
	padding-bottom: 30px;
}

#mediamix .comic-cont {
	display: flex;
	padding: 34px 38px;
	background-color: rgba(255,255,255,0.80);
}

#mediamix .comicalize h3 {
	margin-bottom: 22px;
}

#mediamix .comicalize .comic-img {
	margin-right: 18px;
}

#mediamix .comicalize .txt {
	margin-bottom: 10px;
}

#mediamix .btn ul li:first-child {
	margin-bottom: 28px;
}
/* --------------------------------------------------
-------------------------------------------------- 書き下ろし小説、解説 */

#special-text {
	padding-bottom: 92px;
	background: url(../images/special-text-dot01.png),url(../images/special-text-bg02.png) top center no-repeat,url(../images/special-text-bg01.png) ;
}

#special-text h2 {
	text-align: center;
	margin-bottom: 25px;
}

#special-text h2 img {
	margin-top: -40px;
}

#special-text .reading {
	background-color: rgba(97, 94, 169, 0.5);
	margin-bottom: 40px;
}
#special-text .reading ul {
	padding: 20px;
	font-size: 0;
}
#special-text .reading ul li {
	display: inline-block;
	text-align: center;
}
#special-text .reading ul li:nth-of-type(1) {
	margin-bottom:10px;
}
#special-text .reading ul li:nth-of-type(2) {
	border: 2px solid #000;
    margin-right:30px;
}
#special-text .reading ul li:nth-of-type(3) {
	border: 2px solid #fff;
}
#special-text  .novel-limited{
	background-color: rgba(97, 94, 169, 0.5);
	position: relative;
}
#special-text  .novel-limited h3 {
	text-align: center;
    width: 980px;
    margin: 0 auto;
    position: absolute;
    top: -14px;
    left: 0;
}
#special-text  .novel-limited ul {
	padding: 42px 40px 32px;
}

#special-text  .novel-limited ul li {
	display: inline-block;
	margin-bottom: 10px;
}
/* --------------------------------------------------
-------------------------------------------------- 店舗特典 */
#bonus {
	background-image: url(../images/bonus-bg-chara01.png), url(../images/bonus-bg-stripe01.png), url(../images/bonus-bg-dot01.png);
	background-position: center top, center left, center left;
	background-repeat: no-repeat, repeat, repeat;
	padding-bottom: 80px;
}
#bonus h2 {
	padding: 0 0 25px 0;
	text-align: center;
}
#bonus h2 img {
	margin-top: -40px;
}
#bonus h3 {
	padding: 0 0 30px 0;
	text-align: center;
}
#bonus .items:not(:last-of-type) {
	margin-bottom: 12px;
}
#bonus .items:nth-of-type(2) h3 {
	padding: 0 0 10px 0;
}
#bonus .items:nth-of-type(2) ul li:last-child {
	display: block;
	text-align: left;
	margin-left: 40px;
}
#bonus ul {
	font-size: 0;
	text-align: center;
}
#bonus ul li {
	display: inline-block;
	margin: 0 25px;
	margin-bottom: 20px;
}
#bonus2 {
	padding: 32px 0 80px;
	background-image: url(../images/bonus-bg-chara02.png), url(../images/bonus-bg-stripe02.png), url(../images/bonus-bg-dot02.png);
	background-position: center -320px, center left, center left;
	background-repeat: no-repeat, repeat, repeat;
	text-align: center;
}
#bonus2 h3 {
	margin-bottom: 16px;
}
#bonus2 .img { margin-top:-10px; }

@media screen and (min-width:2000px){
	#bonus2 {
		background-position: center 21%, center left, center left;
		background-size:cover,auto,auto;
	}
}

#bonus2 h2 {
	padding: 24px 0;
	text-align: center;
}
#bonus2 .img { text-align:center; }



/* --------------------------------------------------
-------------------------------------------------- キャンペーン情報 */
#special {
	margin-bottom: 83px;
	min-height: 906px;
	background-image: url(../images/special-bg01.png);
	background-position: center top;
	background-repeat: no-repeat;
}
#special h2 {
	padding: 0 0 6px 0;
	text-align: center;
}
#special h2 img {
	margin-top: -35px;
}
#special p {
	margin-left: 40px;
}
#special p:nth-of-type(1) {
	margin-bottom: 2px;
}
#special ul {
	margin-left: 40px;
}
#special ul li {
	margin-bottom: 25px;
}


/* --------------------------------------------------
-------------------------------------------------- 物語 */
#story {
	margin-bottom: 83px;
	min-height: 800px;
	background-image: url(../images/story-bg01.png);
	background-position: center top;
	background-repeat: no-repeat;
	text-align: center;
}
#story h2 {
	padding: 0 0 30px 0;
	text-align: center;
}
#story h2 img {
	margin-top: -35px;
}
#story p {
	color: #643800;
	font-size: 30px;
	font-weight: bold;
}


/* --------------------------------------------------
-------------------------------------------------- 注目情報 */
#character {
	/* padding-bottom: 20px; */
}
#character h2 {
	margin-bottom: 50px;
	padding: 0 0 50px 0;
	background-color: #000;
	text-align: center;
}
#character h2 img {
	margin-top: -27px;
}
#character #gnav {
	position: relative;
	margin-bottom: 80px;
}
#character #subnav {
	opacity: 0;
	position: fixed;
	top: 0;
	width:980px;
    transform: translate3d(0, -100%, 0);
   	-webkit-animation-duration: 0.3s;
	animation-duration: 0.3s;
}
#character #subnav.fixed {
	top: 0;
}
#character nav ul {
	font-size: 0;
	text-align: left;
}
#character nav ul li {
	display: inline-block;
	background-position: center top;
	background-repeat: no-repeat;
}
#character nav ul li img {
	opacity: 0;
}
#character nav ul li a {
	display: block;
}

#character #gnav ul li { position:relative; }
#character #gnav ul li.new:before { background:url(../images/ico_new.png) no-repeat left top; width:51px; height:51px; display:block; content:""; position:absolute; left:0; top:0; }

#character #gnav ul li:nth-of-type(1) a {
	background-image: url(../images/chara-long-bt01-off.jpg);
}
#character #gnav ul li:nth-of-type(2) a {
	background-image: url(../images/chara-long-bt02-off.jpg);
}
#character #gnav ul li:nth-of-type(3) a {
	background-image: url(../images/chara-long-bt03-off.jpg);
}
#character #gnav ul li:nth-of-type(4) a {
	background-image: url(../images/chara-long-bt04-off.jpg);
}
#character #gnav ul li:nth-of-type(5) a {
	background-image: url(../images/chara-long-bt05-off.jpg);
}
#character #gnav ul li:nth-of-type(6) a {
	background-image: url(../images/chara-long-bt06-off.jpg);
}
#character #gnav ul li:nth-of-type(7) a {
	background-image: url(../images/chara-long-bt07-off.jpg);
}
#character #gnav ul li:nth-of-type(8) a {
	background-image: url(../images/chara-long-bt08-off.jpg);
}
#character #gnav ul li:nth-of-type(9) a {
	background-image: url(../images/chara-long-bt09-off.jpg);
}
#character #gnav ul li:nth-of-type(10) a {
	background-image: url(../images/chara-long-bt10-off.jpg);
}
#character #gnav ul li:nth-of-type(11) a {
	background-image: url(../images/chara-long-bt11-off.jpg);
}
#character #gnav ul li:nth-of-type(12) a {
	background-image: url(../images/chara-long-bt12-off.jpg);
}
#character #gnav ul li:nth-of-type(13) a {
	background-image: url(../images/chara-long-bt13-off.jpg);
}
#character #gnav ul li:nth-of-type(14) a {
	background-image: url(../images/chara-long-bt14-off.jpg);
}
#character #gnav ul li:nth-of-type(15) a {
	background-image: url(../images/chara-long-bt15-off.jpg);
}
#character #gnav ul li:nth-of-type(16) a {
	background-image: url(../images/chara-long-bt16-off.jpg);
}
#character #gnav ul li:nth-of-type(17) a {
	background-image: url(../images/chara-long-bt17-off.jpg);
}

#character #gnav ul li:nth-of-type(1) a:hover {
	background-image: url(../images/chara-long-bt01-on.jpg);
}
#character #gnav ul li:nth-of-type(2) a:hover {
	background-image: url(../images/chara-long-bt02-on.jpg);
}
#character #gnav ul li:nth-of-type(3) a:hover {
	background-image: url(../images/chara-long-bt03-on.jpg);
}
#character #gnav ul li:nth-of-type(4) a:hover {
	background-image: url(../images/chara-long-bt04-on.jpg);
}
#character #gnav ul li:nth-of-type(5) a:hover {
	background-image: url(../images/chara-long-bt05-on.jpg);
}
#character #gnav ul li:nth-of-type(6) a:hover {
	background-image: url(../images/chara-long-bt06-on.jpg);
}
#character #gnav ul li:nth-of-type(7) a:hover {
	background-image: url(../images/chara-long-bt07-on.jpg);
}
#character #gnav ul li:nth-of-type(8) a:hover {
	background-image: url(../images/chara-long-bt08-on.jpg);
}
#character #gnav ul li:nth-of-type(9) a:hover {
	background-image: url(../images/chara-long-bt09-on.jpg);
}
#character #gnav ul li:nth-of-type(10) a:hover {
	background-image: url(../images/chara-long-bt10-on.jpg);
}
#character #gnav ul li:nth-of-type(11) a:hover {
	background-image: url(../images/chara-long-bt11-on.jpg);
}
#character #gnav ul li:nth-of-type(12) a:hover {
	background-image: url(../images/chara-long-bt12-on.jpg);
}
#character #gnav ul li:nth-of-type(13) a:hover {
	background-image: url(../images/chara-long-bt13-on.jpg);
}
#character #gnav ul li:nth-of-type(14) a:hover {
	background-image: url(../images/chara-long-bt14-on.jpg);
}
#character #gnav ul li:nth-of-type(15) a:hover {
	background-image: url(../images/chara-long-bt15-on.jpg);
}
#character #gnav ul li:nth-of-type(16) a:hover {
	background-image: url(../images/chara-long-bt16-on.jpg);
}
#character #gnav ul li:nth-of-type(17) a:hover {
	background-image: url(../images/chara-long-bt17-on.jpg);
}

#character #subnav { z-index:10; }
#character #subnav ul li:nth-of-type(1) a {
	background-image: url(../images/chara-short-bt01-off.jpg);
}
#character #subnav ul li:nth-of-type(2) a {
	background-image: url(../images/chara-short-bt02-off.jpg);
}
#character #subnav ul li:nth-of-type(3) a {
	background-image: url(../images/chara-short-bt03-off.jpg);
}
#character #subnav ul li:nth-of-type(4) a {
	background-image: url(../images/chara-short-bt04-off.jpg);
}
#character #subnav ul li:nth-of-type(5) a {
	background-image: url(../images/chara-short-bt05-off.jpg);
}
#character #subnav ul li:nth-of-type(6) a {
	background-image: url(../images/chara-short-bt06-off.jpg);
}
#character #subnav ul li:nth-of-type(7) a {
	background-image: url(../images/chara-short-bt07-off.jpg);
}
#character #subnav ul li:nth-of-type(8) a {
	background-image: url(../images/chara-short-bt08-off.jpg);
}
#character #subnav ul li:nth-of-type(9) a {
	background-image: url(../images/chara-short-bt09-off.jpg);
}
#character #subnav ul li:nth-of-type(10) a {
	background-image: url(../images/chara-short-bt10-off.jpg);
}
#character #subnav ul li:nth-of-type(11) a {
	background-image: url(../images/chara-short-bt11-off.jpg);
}
#character #subnav ul li:nth-of-type(12) a {
	background-image: url(../images/chara-short-bt12-off.jpg);
}
#character #subnav ul li:nth-of-type(13) a {
	background-image: url(../images/chara-short-bt13-off.jpg);
}
#character #subnav ul li:nth-of-type(14) a {
	background-image: url(../images/chara-short-bt14-off.jpg);
}
#character #subnav ul li:nth-of-type(15) a {
	background-image: url(../images/chara-short-bt15-off.jpg);
}
#character #subnav ul li:nth-of-type(16) a {
	background-image: url(../images/chara-short-bt16-off.jpg);
}
#character #subnav ul li:nth-of-type(17) a {
	background-image: url(../images/chara-short-bt17-off.jpg);
}

#character #subnav ul li:nth-of-type(1) a:hover {
	background-image: url(../images/chara-short-bt01-on.jpg);
}
#character #subnav ul li:nth-of-type(2) a:hover {
	background-image: url(../images/chara-short-bt02-on.jpg);
}
#character #subnav ul li:nth-of-type(3) a:hover {
	background-image: url(../images/chara-short-bt03-on.jpg);
}
#character #subnav ul li:nth-of-type(4) a:hover {
	background-image: url(../images/chara-short-bt04-on.jpg);
}
#character #subnav ul li:nth-of-type(5) a:hover {
	background-image: url(../images/chara-short-bt05-on.jpg);
}
#character #subnav ul li:nth-of-type(6) a:hover {
	background-image: url(../images/chara-short-bt06-on.jpg);
}
#character #subnav ul li:nth-of-type(7) a:hover {
	background-image: url(../images/chara-short-bt07-on.jpg);
}
#character #subnav ul li:nth-of-type(8) a:hover {
	background-image: url(../images/chara-short-bt08-on.jpg);
}
#character #subnav ul li:nth-of-type(9) a:hover {
	background-image: url(../images/chara-short-bt09-on.jpg);
}
#character #subnav ul li:nth-of-type(10) a:hover {
	background-image: url(../images/chara-short-bt10-on.jpg);
}
#character #subnav ul li:nth-of-type(11) a:hover {
	background-image: url(../images/chara-short-bt11-on.jpg);
}
#character #subnav ul li:nth-of-type(12) a:hover {
	background-image: url(../images/chara-short-bt12-on.jpg);
}
#character #subnav ul li:nth-of-type(13) a:hover {
	background-image: url(../images/chara-short-bt13-on.jpg);
}
#character #subnav ul li:nth-of-type(14) a:hover {
	background-image: url(../images/chara-short-bt14-on.jpg);
}
#character #subnav ul li:nth-of-type(15) a:hover {
	background-image: url(../images/chara-short-bt15-on.jpg);
}
#character #subnav ul li:nth-of-type(16) a:hover {
	background-image: url(../images/chara-short-bt16-on.jpg);
}
#character #subnav ul li:nth-of-type(17) a:hover {
	background-image: url(../images/chara-short-bt17-on.jpg);
}

#character .chara {
	position:relative;	
}
#character .chara:not(:last-of-type) {
	margin-bottom: 55px;
}
#character .chara.new:before { background:url(../images/ico_new.png) no-repeat left top; width:51px; height:51px; display:block; content:""; position:absolute; left:0; top:0; }
#character .chara .ura { position:absolute; left:155px; bottom:52px; }

#character .relation { padding-top:54px; background:#e9e9e9; position:relative; 	z-index:11; }
#character .relation .img img:nth-child(2){ position:absolute; left:0; top:54px; opacity:0; transition: 0.5s ease-in-out; }
#character .relation .btn { position:absolute; left:357px; bottom:26px; background:#000; }
#character .relation .btn img:nth-child(2){ position:absolute; left:0; top:0; opacity:0; transition: 0.5s ease-in-out; }
#character .relation.clicked .img img:nth-child(2){ opacity:1; }
#character .relation.clicked .btn img:nth-child(2){ opacity:1; }



/* --------------------------------------------------
-------------------------------------------------- 書籍情報 */
#books {
	position: relative;
	padding: 150px 0 50px 0;
	background-color: #e9e9e9;
	z-index:11;
}
#books .inner {
	padding-bottom: 50px;
	background-color: #fdfdfd;
}
#books h2 {
	padding: 0 0 33px;
	text-align: center;
}
#books h2:nth-of-type(1) img {
	margin-top: -35px;
}
#books h2:nth-of-type(2) {
	padding: 22px 0 33px;
}
#books .book {
	margin: 0 30px 0 70px;
	position: relative;
}
#books .book:not(:last-of-type) {
	margin-bottom: 50px;
}
#books .book .release-date {
	position: absolute;
	top: -86px;
	left: -65px;
}
#books .book .cover {
	position: relative;
	z-index: 1;
	float: left;
	margin-right: 25px;
	width: 270px;
}
#books .book .cover img {
	border: 1px solid #ccc;
}
#books .book .description {
	float: left;
	width: 585px;
}
#books .book .description h3 {
	margin-bottom: 10px;
	font-size: 28px;
	line-height: 1.2;
	font-feature-settings: "palt";
}
#books .book .description h3 .sub {
	display: block;
	font-size: 24px;
}
#books .book .description .author {
	margin-bottom: 15px;
	font-size: 0;
}
#books .book .description .author li {
	display: inline-block;
	font-size: 20px;
}
#books .book .description .author li:not(:last-of-type) {
	margin-right: 1em;
}

#books .book .description .catch {
	font-size: 24px;
	font-weight: bold;
	color: #e5005a;
	line-height: 1.2;
    margin-bottom: 20px;
}

#books .book .description .summary {
	margin-bottom: 40px;
}
#books .book .description dl {
	margin-bottom: 20px;
}
#books .book .description dl dt {
	color: #ff4200;
	font-feature-settings: "palt";
	font-size: 24px;
	font-weight: bold;
}
#books .book .description dl dd {
	text-align: justify;
	text-justify: inter-ideograph;
}
#books .book .description .btn ul {
	font-size: 0;
}
#books .book .description .btn ul li {
	display: inline-block;
	background-color: #000;
	border: 3px solid #000;
}
#books .book .description .btn ul li {
	display: inline-block;
}
#books .book .description .btn ul li:not(:last-of-type) {
	margin-right: 22px;
}

/* --------------------------------------------------
-------------------------------------------------- フッター */
footer {
	padding: 20px 0;
	background-color: #000;
	color: #fff;
	text-align: center;
}
footer .pagetop {
	display: block;
	margin-bottom: 20px;
}
footer .mf-logo {
	display: block;
	margin-bottom: 20px;
}

footer .sns {
	margin-bottom: 10px;
}
footer .sns ul {
	font-size: 0;
}
footer .sns ul li {
	display: inline-block;
}
footer .sns ul li:not(:last-of-type) {
	margin-right: 10px;
}

footer .sns ul li:nth-child(2),
footer .sns ul li:nth-child(2) .fb_iframe_widget span,
footer .sns ul li:nth-child(2) .fb_iframe_widget iframe{
    width: 135px !important;
    height:20px !important;
}

footer .sns ul li:nth-child(3),
footer .sns ul li:nth-child(3) iframe{
    height: 20px !important;
}

footer small {
	font-size: 12px;
}