@charset "utf-8";

/* --------------------------------------------------
-------------------------------------------------- ページ全体 */
html {
	width: 100%;
	min-height: 100%;
	-webkit-text-size-adjust: 100%;
}
body {
	width: 100%;
	min-height: 100%;
	background-color: #fff;
	color: #000;
	font-family: Verdana, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
	font-size: 20px;
	line-height: 1.5;
	overflow: hidden;
}

a:link {
	color: #a08c5a;
	text-decoration: none;
}
a:visited {
	color: #a08c5a;
	text-decoration: none;
}
a:hover {
	color: #a08c5a;
	text-decoration: underline;
}
a:active {
	color: #a08c5a;
	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 img {
	opacity: 0.6;
	-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;
}

.fixed {
	position: fixed !important;
	top: 0 !important;
	z-index: 500;
}
.motion {
	-webkit-animation-duration: 0.3s;
	animation-duration: 0.3s;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
	animation-timing-function: ease-out;
}

@-webkit-keyframes leftToRight {
  from {
    width: 0;
  }

  to {
    width: 100%;
  }
}

@keyframes leftToRight {
  from {
    width: 0;
  }

  to {
   width: 100%;
  }
}

.leftToRight {
  -webkit-animation-name: leftToRight;
  animation-name: leftToRight;
}


@-webkit-keyframes fadeInUpMini {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInUpMini {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInUpMini {
  -webkit-animation-name: fadeInUpMini;
  animation-name: fadeInUpMini;
}

@-webkit-keyframes fadeInDownMini {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInDownMini {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInDownMini {
  -webkit-animation-name: fadeInDownMini;
  animation-name: fadeInDownMini;
}


/* --------------------------------------------------
-------------------------------------------------- Clearfix */

.cf:before, .cf:after {
	content: "";
	display: table;
}
.cf:after {
	clear: both;
}
.cf {
	*zoom: 1;
}

/* --------------------------------------------------
-------------------------------------------------- ページ全体 */
.inner {
	position: relative;
	margin: 0 auto;
	width: 1000px;
}


/* --------------------------------------------------
-------------------------------------------------- ヘッダー */
header {
	height: 60px;
	position: relative;
	background-color: #73d4ed;
	z-index: 1000;
}
header h1 {
	padding: 14px 0;
	line-height: 1px;
}
header .sns {
	position: absolute;
	top: 10px;
	right: 0;
}
header .sns ul {
	overflow: hidden;
	letter-spacing: -0.4em;
}
header .sns ul li {
	margin-left: 10px;
	display: inline-block;
}


/* --------------------------------------------------
-------------------------------------------------- ナビゲーション */
#nav {
	position: absolute;
	top: 60px;
	width: 100%;
	background-color: rgba(160, 142, 237, 0.8);
}
#nav nav {
	padding: 6px 0;
}
#nav ul {
	font-size: 0;
	text-align: center;
}
#nav ul li {
	display: inline-block;
}
#nav ul li:first-child {
	border-left: 2px solid #fff;
}
#nav ul li:last-child {
	border-right: 2px solid #fff;
}
#nav ul li a {
	display: block;
	margin: 4px 0;
}
#nav ul li:not(:last-child) a {
	border-right: 1px solid #fff;
}

/* --------------------------------------------------
-------------------------------------------------- コンテンツ */
#contents {
	margin-top: 50px;
}

/* -------------------------------------------------- メイン */
#main {
	position: relative;
	height: 790px;
	z-index: -1;
}
#main h1 {
	display: none;
	position: absolute;
	top: -113px;
	left: -43px;
	-webkit-animation-delay: 2.2s;
	animation-delay:2.2s;
	-webkit-animation-duration: 1s;
	animation-duration: 1s;
}
#main h2 {
	display: none;
	position: absolute;
	top: 18px;
	left: 337px;
	-webkit-animation-delay: 2.3s;
	animation-delay: 2.3s;
	-webkit-animation-duration: 1s;
	animation-duration: 1s;
}
#main p {
	display: none;
	position: absolute;
}
#main p.catch01 {
	top: 7px;
	right: -25px;
	-webkit-animation-delay: 1s;
	animation-delay:1s;
	-webkit-animation-duration: 0.8s;
	animation-duration: 0.8s;
}
#main p.catch02 {
	top: 306px;
	left: 300px;
	-webkit-animation-delay: 2s;
	animation-delay: 2s;
	-webkit-animation-duration: 1s;
	animation-duration: 1s;
}
#main p.catch03 {
	top: 361px;
	left: 239px;
	-webkit-animation-delay: 1.7s;
	animation-delay:1.7s;
	-webkit-animation-duration: 1s;
	animation-duration: 1s;
}
#main p.catch04 {
	top: 459px;
	left: 263px;
	-webkit-animation-delay: 1.6s;
	animation-delay:1.6s;
	-webkit-animation-duration: 1s;
	animation-duration: 1s;
}

#main .release-date {
	display: none;
	position: absolute;
	top: 471px;
	left: 740px;
	-webkit-animation-delay: 3s;
	animation-delay: 3s;
	-webkit-animation-duration: 1s;
	animation-duration: 1s;
}
#main .release-cover {
	display: none;
	position: absolute;
	top: 551px;
	left: 828px;
	-webkit-animation-delay: 2.8s;
	animation-delay: 2.8s;
	-webkit-animation-duration: 1s;
	animation-duration: 1s;
}


#main ul {
	position: absolute;
	top: 323px;
	left: 16px;
	-webkit-animation-delay: 2.4s;
	animation-delay:2.4s;
}
#main ul  li {
	margin-bottom: 4px;
}
#main .illust01, #main .illust02 {
	display: none;
	position: absolute;
}
#main .illust01 {
	top: -20px;
	left: 191px;
	-webkit-animation-delay: 0.5s;
	animation-delay: 0.5s;
	-webkit-animation-duration: 0.8s;
	animation-duration: 0.8s;
}
#main .illust02 {
	top: 30px;
	left: 203px;
	-webkit-animation-delay: 0.5s;
	animation-delay: 0.5s;
	-webkit-animation-duration: 0.8s;
	animation-duration: 0.8s;
}



/* -------------------------------------------------- あらすじ */
#story {
	background: url(/special/yome_elf/images/story-bg01.png) center top no-repeat;
}
#story-illust {
	padding-bottom: 60px;
	background: url(/special/yome_elf/images/story-illust01.png) center top no-repeat;
}

#story h1 {
	position: absolute;
	top: -40px;
}

#story p:not(:last-of-type) {
	margin-bottom: 36px;
}
#story p:first-of-type {
	padding-top: 60px;
}



/* -------------------------------------------------- キャラクター */
#character {
	min-height: 653px;
	background: #ffb8d1 url(/special/yome_elf/images/character-txt01.png) center top no-repeat;
}
#character h1 {
	position: absolute;
	top: -11px;
	left: 0;
}
#character .guide {
	position: absolute;
	top: -17px;
	right: 8px;
}

#character .character-box {
	position: absolute;
	-webkit-animation-duration: 0.8s;
	animation-duration: 0.8s;
}
#character .click-ico {
	position: absolute;
}

#character #heine {
	top: 68px;
	left: 130px;
}
#character #heine .click-ico {
	top: 119px;
	left: -91px;
}

#character #chisame {
	top: 41px;
	right: 238px;
}
#character #chisame .click-ico {
	top: -27px;
	left: -46px;
}

#character #lumina {
	top: 345px;
	left: 374px;
}
#character #lumina .click-ico {
	top: 160px;
	left: -95px;
}

#character #jill {
	top: 224px;
	right: -22px;
}
#character #jill .click-ico {
	top: 289px;
	left: 22px;
}

#character a img {
	opacity: 1;
}



/* -------------------------------------------------- 店舗特典 */
#favor {
	padding: 68px 0 40px 0;
	background: #fff9bb url(/special/yome_elf/images/favor-bg01.jpg) center top no-repeat;
}
#favor h1 {
	position: absolute;
	top: -105px;
	left: 0;
}
#favor p {
	text-align: center;
}
#favor ul {
	margin: 0 -4px;
	font-size: 0;
}
#favor ul li {
	display: inline-block;
}
#favor ul li:nth-child(1), #favor ul li:nth-child(5) {
	margin-right: 26px;
}
#favor ul li:not(:last-child), #favor ul li:nth-child(n-1) {
	margin-bottom: 20px;
}

/* -------------------------------------------------- 書籍情報 */
#information {
	background-color: #e2ddf8;
}

#information h1 {
	position: absolute;
	top: -40px;
	left: 0;
}
#information .book-block {
	padding-bottom: 70px;
	overflow: hidden;
}
#information .book-block:first-of-type {
	padding-top: 75px;
}
#information .book-block:last-of-type {
	padding-bottom: 40px;
}
#information .book-cover {
	margin-right: 40px;
	width: 253px;
	float: left;
}
#information .book-block.no01 .book-cover img {
	border: 1px solid #fd71dc;
}
#information .book-block.no02 .book-cover img {
	border: 1px solid #3ebde0;
}
#information .book-info {
	margin-left: 23px;
	width: 683px;
	float: left;
}
#information .book-catch {
	display: block;
	margin-bottom: 24px;
}
#information .book-info h2 {
	margin-bottom: 25px;
}
#information .book-author {
	margin-bottom: 33px;
	font-size: 0;
}
#information .book-author li {
	display: inline-block;
	margin-right: 30px;
}
#information .book-price {
	display: block;
	font-size: 24px;
}
#information .book-info dt {
	margin-bottom: 15px;
}
#information .book-info dd {
	margin-bottom: 25px;
}

#information .book-release {
	display: block;
	margin-bottom: 40px;
	font-size: 24px;
}
#information .book-trial {
	display: block;
	margin-bottom :22px;
}
#information .book-trial img {
	border: 3px solid #e2007e;	
}

#information .book-button {
	margin-left: 5px;
	font-size: 0;
}
#information .book-button li {
	display: inline-block;
	margin-right: 43px;
}


/* --------------------------------------------------
-------------------------------------------------- フッター */

footer {
	margin: 0 auto;
	padding: 40px 0;
	background-color: #73d4ed;
	text-align: center;
	line-height: 1;
}
footer small {
	font-size: 12px;
	color: #fff;
}
#pagetop {
	display: block;
	margin-bottom: 24px;
}

.mf-logo {
	display: block;
	margin-bottom: 10px;
}