@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Open+Sans');

a,a:visited {
	text-decoration: none;
	outline: none;
  color: #ff711b;
  -webkit-tap-highlight-color:rgba(255,255,255,0.25);
}
a:hover {
  text-decoration: underline;
  outline: none;
}
a[href*="tel:"] { cursor: default; }

button {
  outline: none;
  -webkit-tap-highlight-color:rgba(255,255,255,0.25);
}

p {
	margin: 0 0 25px;
  background: url(../img/transparent.png);
}
p.small {
  margin: 0 0 12px;
}
td { background: url(../img/transparent.png); }

em,h4 {
  color: #ff4a4a;
  font-weight: bold;
}
i,var { font-style: normal; }

img { vertical-align: bottom; }

html {
  position: relative;
  min-height: 100%;
  background: #000;
  font-size: 6.25%;
  overflow-y: scroll;
  overflow-x: hidden;
}
body {
  min-height: 100%;

	font: 10rem/1 "Open Sans", "Arial", sans-serif;
  
  color: #fff;
  overflow: hidden;
  overflow-wrap: break-word;
  word-break: normal;
  word-wrap: break-word;
  -webkit-font-smoothing: antialiased;
}
.mac body, .safari body { font-family: "Open Sans", "Hiragino Kaku Gothic Pro", sans-serif; }

div,section {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
h1,h2,h3,h4,h5,h6 {
  margin: 0;
}
ul,ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
button {
  padding: 0;
  border: none;
  outline: none;
  background-color: transparent;
  cursor: pointer;
}
button:active,button:focus {
  border: none;
  outline: none;
}
figure {
  margin: 0;
}
em { font-style: normal; }

.text-right { text-align: right; }

.center, .img_center { text-align: center; }

p.caption {
  margin: 5px 0 0 8px;
}

.brackets_mgn {
  margin: 0 -0.45em 0 -0.5em;
}

.gloNav_bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  background: #03000c;
  -webkit-box-shadow: 0 0 7px 1px rgba(0,0,0,0.8);
  box-shadow: 0 0 7px 1px rgba(0,0,0,0.8);
}
#gloNav .news li p {
  margin: 0;
  overflow: hidden;
}
#gloNav.close .news li:first-child p .marquee {
  margin: 0;
  /*padding-left: 100%;*/
  display: inline-block;
  white-space: nowrap;
}
#gloNav.close .news li:first-child p .marquee.move {
  -webkit-animation: marquee 10s linear infinite;
  animation: marquee 10s linear infinite;
}
/*#gloNav.close .news li:first-child p .marquee:after {
  content:"";
  white-space:nowrap;
  padding-right:50px;
}*/
.gloNav_bg ul.navi li {
  position: relative;
}
.gloNav_bg ul.navi li.new:after {
  bottom: -4px;
  right: 0;
  left: 0;
  margin: 0 auto;
  -webkit-transform: scale(0.43);
  -ms-transform: scale(0.43);
  transform: scale(0.43);
  -webkit-transform-origin: 50% 100%;
  -ms-transform-origin: 50% 100%;
  transform-origin: 50% 100%;
}
#contents {
  position: relative;
  min-height: 800px;
  z-index: 10;
}
#contents main {
  position: relative;
}

/*
.package {
  position: absolute;
  top: -147px;
  left: -webkit-calc(50% - 222px);
  left: calc(50% - 222px);
  width: -webkit-calc(50% + 222px);
  width: calc(50% + 222px);
  max-width: 862px;
  height: 1210px;
  opacity: 0;
  z-index: 2;
  background: url(../img/bg_package.jpg) 0 0 / 862px auto no-repeat;
}
*/

.package {
  position: absolute;
  top: -147px;
  left: -webkit-calc(50% - 222px);
  left: calc(50% - 222px);
  width: -webkit-calc(50% + 222px);
  width: calc(50% + 222px);
  max-width: 862px;
  height: 1210px;
  opacity: 0;
  z-index: 2;
  background: url(../img/bg_package.jpg) 0 0 / 862px auto no-repeat;
}

#top .package {
  opacity: 1;
}
.package img {
  position: absolute;
  top: 0;
  left: 0;
  width: 862px;
  opacity: 0;
}
.package img:nth-child(1) {
  z-index: 2;
}
.package img:nth-child(2) {
  z-index: 3;
}
.package img:nth-child(3) {
  z-index: 4;
}
.package img:nth-child(4) {
  -webkit-transform: translate(0,160px);
  -ms-transform: translate(0,160px);
  transform: translate(0,160px);
  z-index: 5;
}
body:not(.packageEnd) .package img:nth-child(1) {
  -webkit-transition: opacity 0.1s linear 0.5s, -webkit-filter 0.1s linear 0.6s;;
  transition: opacity 0.1s linear 0.5s, -webkit-filter 0.1s linear 0.6s;;
  -o-transition: opacity 0.1s linear 0.5s, filter 0.1s linear 0.6s;;
  transition: opacity 0.1s linear 0.5s, filter 0.1s linear 0.6s;;
  transition: opacity 0.1s linear 0.5s, filter 0.1s linear 0.6s, -webkit-filter 0.1s linear 0.6s;
}
body:not(.packageEnd) .package img:nth-child(2) {
  -webkit-transition: opacity 0.1s linear 0.8s, -webkit-filter 0.1s linear 0.9s;
  transition: opacity 0.1s linear 0.8s, -webkit-filter 0.1s linear 0.9s;
  -o-transition: opacity 0.1s linear 0.8s, filter 0.1s linear 0.9s;
  transition: opacity 0.1s linear 0.8s, filter 0.1s linear 0.9s;
  transition: opacity 0.1s linear 0.8s, filter 0.1s linear 0.9s, -webkit-filter 0.1s linear 0.9s;
}
body:not(.packageEnd) .package img:nth-child(3) {
  -webkit-transition: opacity 0.1s linear 1.1s, -webkit-filter 0.1s linear 1.2s;
  transition: opacity 0.1s linear 1.1s, -webkit-filter 0.1s linear 1.2s;
  -o-transition: opacity 0.1s linear 1.1s, filter 0.1s linear 1.2s;
  transition: opacity 0.1s linear 1.1s, filter 0.1s linear 1.2s;
  transition: opacity 0.1s linear 1.1s, filter 0.1s linear 1.2s, -webkit-filter 0.1s linear 1.2s;
}
body:not(.packageEnd) .package img:nth-child(4) {
  -webkit-transition: opacity 0.1s linear 1.7s, -webkit-transform 0.2s cubic-bezier(0.19, 1, 0.22, 1) 1.7s, -webkit-filter 0.1s linear 1.8s;
  transition: opacity 0.1s linear 1.7s, -webkit-transform 0.2s cubic-bezier(0.19, 1, 0.22, 1) 1.7s, -webkit-filter 0.1s linear 1.8s;
  -o-transition: transform 0.2s cubic-bezier(0.19, 1, 0.22, 1) 1.7s, opacity 0.1s linear 1.7s, filter 0.1s linear 1.8s;
  transition: transform 0.2s cubic-bezier(0.19, 1, 0.22, 1) 1.7s, opacity 0.1s linear 1.7s, filter 0.1s linear 1.8s;
  transition: transform 0.2s cubic-bezier(0.19, 1, 0.22, 1) 1.7s, opacity 0.1s linear 1.7s, filter 0.1s linear 1.8s, -webkit-transform 0.2s cubic-bezier(0.19, 1, 0.22, 1) 1.7s, -webkit-filter 0.1s linear 1.8s;
}
.package img:nth-child(5) {
  z-index: 6;
  mix-blend-mode: overlay;
}
.ie .package img:nth-child(5) {
  display: none;
}
@supports (-ms-ime-align:auto) {
  .package img:nth-child(5) {
    display: none;
  }
}
#top .package img:not(:last-child) {
  -webkit-filter: grayscale(1) brightness(50);
  filter: grayscale(1) brightness(50);
}
#top.loaded .package img:not(:last-child) {
  opacity: 1;
  -webkit-filter: grayscale(0) brightness(1);
  filter: grayscale(0) brightness(1);
}
body.packageEnd.loaded .package img:nth-child(5) {
  opacity: 1;
  -webkit-animation: blink 1.2s linear infinite alternate;
  animation: blink 1.2s linear infinite alternate;
}
#top.loaded .package img:nth-child(4) {
  -webkit-transform: translate(0,0);
  -ms-transform: translate(0,0);
  transform: translate(0,0);
}
.package_sub {
  position: fixed;
  top: 0;
  left: -webkit-calc(50% - 222px);
  left: calc(50% - 222px);
  display: block;
  width: 862px;
  height: 110vh;
  -webkit-box-shadow: 0 0 34px 6px #000;
  box-shadow: 0 0 34px 6px #000;
  z-index: 1;
}
.package_sub img {
  position: absolute;
  top: -147px;
  left: 0;
  display: block;
  width: 862px;
}

footer .copy{
  text-align: center;
}

footer .copy img{
  vertical-align: middle;
  padding-right: 1vw;
  padding-top: 1vw;
}

footer .banner {
  height: 0px;
  opacity: 0;
  overflow: hidden;
  -webkit-transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  -o-transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: all 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
}
footer .banner li {
  float: left;
  width: 314px;
  height: 96px;
  padding: 32px 78px 0;
}
footer .banner li a {
  display: block;
  width: 314px;
  height: 96px;
  background: 0 0 no-repeat;
}
footer .banner li a img {
  display: block;
  width: 314px;
  height: 96px;
  background: 0 100% no-repeat;
  opacity: 0;
  -webkit-transition: opacity 0.15s linear;
  -o-transition: opacity 0.15s linear;
  transition: opacity 0.15s linear;
}
footer .banner li a:hover img {
  opacity: 1;
}
footer .banner li a.limited,
footer .banner li a.limited img {
  background-image: url(../img/bnr_limited.png);
}
footer .banner li a.n1shop,
footer .banner li a.n1shop img {
  background-image: url(../img/bnr_n1shop.png);
}
footer .banner li a.memories_campaign,
footer .banner li a.memories_campaign img {
  background-image: url(../img/bnr_memories_campaign.png);
}
footer .banner li a.benefits,
footer .banner li a.benefits img {
  background-image: url(../img/bnr_benefits.png);
}
footer .banner li a.popularity_vote,
footer .banner li a.popularity_vote img {
  background-image: url(../img/bnr_popularity_vote.png);
}
footer .banner li a.popularity_vote_result,
footer .banner li a.popularity_vote_result img {
  background-image: url(../img/bnr_popularity_vote_result.png);
}
footer .banner li a.memories_comments,
footer .banner li a.memories_comments img {
  background-image: url(../img/bnr_memories_comments.png);
}
footer .banner li a.preorder_now,
footer .banner li a.preorder_now img {
  background-image: url(../img/preorder_now.png);
}
footer .banner li a.disgaea_portal,
footer .banner li a.disgaea_portal img {
  background-image: url(../img/disgaea_portal.png);
}
#cboxClose {
  top: -80px;
  right: 0px;
  width: 71px;
  height: 71px;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
#cboxPrevious, #cboxNext {
  top: -webkit-calc(50% - 42.5px);
  top: calc(50% - 42.5px);
  width: 62px;
  height: 85px;
  background: url(../img/arrow.png) 0 0 no-repeat;
}
#cboxPrevious {
  left: -64px;
}
#cboxNext {
  right: -64px;
  background-position: 100% 0;
}
#cboxPrevious:hover, #cboxClose:hover {
  opacity: 1;
  background-position: 0 100%;
}
#cboxNext:hover {
  opacity: 1;
  background-position: 100% 100%;
}

.new:after {
  content: url(../img/new.png);
  position: absolute;
  height: 40px;
  -webkit-transform: scale(0.5);
  -ms-transform: scale(0.5);
  transform: scale(0.5);
  -webkit-transform-origin: 100% 0;
  -ms-transform-origin: 100% 0;
  transform-origin: 100% 0;
  -webkit-animation: blink 2.5s ease-in-out infinite;
  animation: blink 2.5s ease-in-out infinite;
}

/* =============================================================================
フロートさせたコンテンツの高さを親要素が認識しないバグを修正　Clearfix
========================================================================== */

/* For modern browsers */
.cf:before, .cf:after {
  content: "";
  display: table;
}

.cf:after { clear: both; }

/* For IE 6/7 (trigger hasLayout) */
.cf { zoom: 1; }

* html .cf { height: 1px;/*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}

.cv_div .cv {
  padding-top: 40px;
  padding-bottom: 15px;
}

.cv_div .dl_btn {
  width: 50%;
  cursor: pointer;
}

.cv_div .dl_btn:hover{
  opacity: .8;
}

.coversheets_div p{
  font-size: 1.3em;
}

.back_top{
  font-size: 1.5em;
}
