/* ==========================================================================*/
/*   initial*/
/* ==========================================================================*/
/* ==========================================================================*/
/*   mixin*/
/* ==========================================================================*/
/* ==========================================================================*/
/*   page*/
/* ==========================================================================*/
/* opening
-------------------------------------------------------------------------- */
#opening {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background: #fff;
  z-index: 9999;
  transition: 1s cubic-bezier(0.215, 0.61, 0.355, 1) 9s;
}

#opening .scene01 {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 103;
  transition: 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 5s;
}

#opening .scene01__1 {
  position: relative;
  opacity: 0;
  transition: 1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

#opening .scene01__1:after {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  display: block;
  content: '';
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, white 50%);
  transition: 3s cubic-bezier(0.39, 0.575, 0.565, 1);
}

#opening .scene01__2 {
  position: relative;
  opacity: 0;
  transition: 2s cubic-bezier(0.39, 0.575, 0.565, 1) 2s;
}

#opening .scene02 {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: #fff;
  z-index: 101;
  opacity: 0;
  transition: 4s cubic-bezier(0.39, 0.575, 0.565, 1) 3s;
}

#opening .scene02 img {
  position: absolute;
  top: 0;
  right: 0;
  height: 126.891522333%;
  width: auto;
  -webkit-transform: translate(-20%, 0);
  -ms-transform: translate(-20%, 0);
  transform: translate(-20%, 0);
  transition: 30s cubic-bezier(0.215, 0.61, 0.355, 1) 3s;
}

#opening .scene03 {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: url(../img/top/img_opening03.jpg) no-repeat center center;
  background-size: cover;
  z-index: 102;
  opacity: 0;
  transition: 4s cubic-bezier(0.39, 0.575, 0.565, 1) 5s;
}

#opening .scene03 img {
  position: absolute;
  top: 0;
  right: 0;
  height: 126.891522333%;
  width: auto;
  -webkit-transform: translate(-20%, 0);
  -ms-transform: translate(-20%, 0);
  transform: translate(-20%, 0);
  transition: 30s cubic-bezier(0.215, 0.61, 0.355, 1) 3s;
}

#opening .scene04 {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) scale(0.9);
  -ms-transform: translate(-50%, -50%) scale(0.9);
  transform: translate(-50%, -50%) scale(0.9);
  z-index: 104;
  opacity: 0;
  transition: opacity 1s cubic-bezier(0.39, 0.575, 0.565, 1) 5.5s, -webkit-transform 1s cubic-bezier(0.215, 0.61, 0.355, 1) 5.5s;
  transition: opacity 1s cubic-bezier(0.39, 0.575, 0.565, 1) 5.5s, transform 1s cubic-bezier(0.215, 0.61, 0.355, 1) 5.5s;
  transition: opacity 1s cubic-bezier(0.39, 0.575, 0.565, 1) 5.5s, transform 1s cubic-bezier(0.215, 0.61, 0.355, 1) 5.5s, -webkit-transform 1s cubic-bezier(0.215, 0.61, 0.355, 1) 5.5s;
}

#opening .skip {
  position: absolute;
  top: 20px;
  right: 25px;
  background: #21b8d7;
  cursor: pointer;
  z-index: 200;
}

.is-loaded #opening {
  z-index: -1;
  opacity: 0;
  visibility: hidden;
}

.is-loaded #opening .scene01 {
  opacity: 0;
}

.is-loaded #opening .scene01__1 {
  opacity: 1;
}

.is-loaded #opening .scene01__1:after {
  width: 0;
}

.is-loaded #opening .scene01__2 {
  opacity: 1;
}

.is-loaded #opening .scene02 {
  opacity: 1;
}

.is-loaded #opening .scene02 img {
  -webkit-transform: translate(60%, -30%) rotate(-30deg);
  -ms-transform: translate(60%, -30%) rotate(-30deg);
  transform: translate(60%, -30%) rotate(-30deg);
}

.is-loaded #opening .scene03 {
  opacity: 1;
}

.is-loaded #opening .scene03 img {
  -webkit-transform: translate(60%, -30%) rotate(-30deg);
  -ms-transform: translate(60%, -30%) rotate(-30deg);
  transform: translate(60%, -30%) rotate(-30deg);
}

.is-loaded #opening .scene04 {
  -webkit-transform: translate(-50%, -50%) scale(1);
  -ms-transform: translate(-50%, -50%) scale(1);
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
}

.is-skip #opening {
  transition: 0s linear 0s;
}

/* content
-------------------------------------------------------------------------- */
#content {
  position: relative;
}

#content .visual {
  position: relative;
}

#content .visual__text {
  position: absolute;
  top: 0;
  left: 0;
}

#content .visual__image img, #content .visual__text img {
  width: 100%;
  height: auto;
}

#content .visual__banner {
  position: absolute;
  top: 40px;
  left: 40px;
  text-align: center;
}

#content .visual__banner li + li {
  margin-top: 7px;
}

#content .visual__banner a {
  transition: 0.2s cubic-bezier(0.075, 0.82, 0.165, 1);
}

#content .visual__banner a:hover, #content .visual__banner a:active {
  opacity: 0.5;
}

#content .visual__tieup {
  *zoom: 1;
  position: fixed;
  bottom: 20px;
  right: 0;
  padding-left: 31px;
  z-index: 9989;
}

#content .visual__tieup:after {
  content: '';
  display: table;
  clear: both;
}

#content .visual__tieup dt {
  position: absolute;
  bottom: 0;
  left: 0;
  transition: 0.2s cubic-bezier(0.075, 0.82, 0.165, 1);
  cursor: pointer;
}

#content .visual__tieup dt:hover, #content .visual__tieup dt:active {
  opacity: 0.5;
}

#content .visual__tieup dd {
  overflow: hidden;
  display: none;
  background: rgba(0, 0, 0, 0.8);
}

#content .visual__tieup ul {
  *zoom: 1;
  padding: 22.5px 10px 22.5px;
}

#content .visual__tieup ul:after {
  content: '';
  display: table;
  clear: both;
}

#content .visual__tieup li {
  float: left;
}

#content .visual__tieup li + li {
  margin-left: 5px;
}

#content .visual__tieup a {
  transition: 0.2s cubic-bezier(0.075, 0.82, 0.165, 1);
}

#content .visual__tieup a:hover, #content .visual__tieup a:active {
  opacity: 0.5;
}

#content .comment {
  position: absolute;
  top: 50px;
  left: 260px;
}

#content .comment a {
  transition: 0.2s cubic-bezier(0.075, 0.82, 0.165, 1);
}

#content .comment a:hover, #content .comment a:active {
  opacity: 0.5;
}

#content .logo {
  position: relative;
  padding: 10px 0;
  text-align: center;
}

#content .logo:after {
  width: 167px;
  height: 244px;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-440px, -42px);
  -ms-transform: translate(-440px, -42px);
  transform: translate(-440px, -42px);
  content: '';
  display: block;
  background: url(../img/top/img_logo.png) no-repeat center center;
  z-index: 99;
}
