/* =================================================
Base
================================================= */

body {
  width: 100%;
  height: 100%;
  margin: 0;
  background: #010101;
  color: #fefefe;
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 12px;
  font-weight: 500;
  font-style: normal;
  line-height: 1.8em;
  letter-spacing: 0;
}

h1, h2, h3, h4, h5 {
  position: absolute;
  text-indent: -999999px;
}

#wrap {
  position: relative;
  width: 100%;
  height: 100%;
}


/* =================================================
Utility
================================================= */

.sp {
  display: none;
}

a:hover {
  opacity: 0.7;
}

.linkLabel {
  line-height: 0;
  text-indent: -99999px;
}

.videoWrapper {
  position: relative;
  height: 0;
  padding-bottom: 56.25%;
}

.videoWrapper iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}


/* =================================================
Animation
================================================= */

@keyframes fadeanm {
  0% { opacity: 0; }
  100% { opacity: 1; }
}

@keyframes scaleanm {
  0% { transform: scale(1.4); opacity: 0; }
  100% { transform: scale(1); opacity: 1; }
}

@keyframes mainImg01anm {
  0% { transform: translateX(20%); opacity: 0; }
  100% { transform: translateX(0); opacity: 1; }
}

@keyframes mainImg02anm {
  0% { transform: translateX(-20%); opacity: 0; }
  100% { transform: translateX(0); opacity: 1; }
}

@keyframes mainM01anm {
  0% { transform: translateX(0); opacity: 1; }
  100% { transform: translateX(100%); opacity: 1; }
}

@keyframes mainM02anm {
  0% { transform: translateX(0); opacity: 1; }
  100% { transform: translateX(-100%); opacity: 1; }
}

@keyframes mainCoinanm {
  0% { transform: rotateZ(180deg); opacity: 0; }
  100% { transform: rotateZ(0deg); opacity: 1; }
}


/* =================================================
Main
================================================= */

#content {
  position: relative;
  width: 100%;
  padding: 0;
  overflow-x: hidden;
}

#mainAll {
  position: relative;
  width: 100%;
  background: #000;
  overflow: hidden;
}

#mainAll::before {
  content: "";
  display: block;
  padding-top: 53.33%;
}

#logo {
  position: absolute;
  top: 52.8%;
  left: 13.13%;
  z-index: 11;
  width: 34.8%;
  height: 34.75%;
  background: url("../images/top2/logo.png") no-repeat center / contain;
  text-indent: -999999px;
  overflow: hidden;
  animation: scaleanm 0.5s cubic-bezier(0,.64,.41,1) 2.4s forwards;
  opacity: 0;
}

#coin {
  position: absolute;
  top: 47.12%;
  left: 16.1%;
  z-index: 10;
  width: 8.5%;
  height: 16%;
  background: url("../images/top2/coin.png") no-repeat center / contain;
  text-indent: -999999px;
  overflow: hidden;
  animation: mainCoinanm .5s ease 2.6s forwards;
  opacity: 0;
}

#roadshow {
  position: absolute;
  top: 88.3%;
  left: 17%;
  z-index: 10;
  width: 28.46%;
  height: 8.75%;
  background: url("../images/top2/roadshow_pc.png") no-repeat center / contain;
  text-indent: -999999px;
  overflow: hidden;
  animation: fadeanm 1s cubic-bezier(0,.64,.41,1) 2.8s forwards;
  opacity: 0;
}

#odlegend {
  position: absolute;
  top: 1.8%;
  left: 7%;
  z-index: 10;
  width: 90%;
  height: 2.2%;
  background: url("../images/top2/catch1_pc.png") no-repeat center / contain;
  text-indent: -999999px;
  overflow: hidden;
}

#catch2 {
  position: absolute;
  top: 17%;
  left: 48%;
  z-index: 10;
  width: 42%;
  height: 10.12%;
  background: url("../images/top2/catch2_pc.png") no-repeat center / contain;
  text-indent: -999999px;
  overflow: hidden;
  animation: fadeanm 1s cubic-bezier(0,.64,.41,1) 2.6s forwards;
  opacity: 0;
  filter: drop-shadow(7px 8px 6px rgba(0,0,0,0.3));
}

#catch3 { display: none;}

#main_img01 {
  position: absolute;
  top: 0;
  left: 12.8%;
  z-index: 3;
  width: 33.7%;
  height: 50%;
  background: url("../images/top2/img_aoshima97_pc.png") no-repeat center bottom / auto 105%;
  text-indent: -999999px;
  overflow: hidden;
  animation: mainImg01anm 1s cubic-bezier(0,.64,.41,1) 2s forwards;
  opacity: 0;
}

#main_img02 {
  position: absolute;
  bottom: 0;
  left: 48%;
  z-index: 3;
  /*width: 46.1%;
  height: 65.93%;*/
  width: 49%;
  height: 69%;
  background: url("../images/top2/img_aoshima26_pc.png") no-repeat center / contain;
  text-indent: -999999px;
  overflow: hidden;
  animation: mainImg02anm 1s cubic-bezier(0,.64,.41,1) 2.2s forwards;
  opacity: 0;
}

#main_img01Mark{
background: url("../images/nav/menu_new.png") no-repeat top 50% right 2%;
background-size: auto 150%;
width: 100%; height: 100%;
position: absolute;
top: 0; left: 0;
z-index: 1;
mix-blend-mode: multiply;
opacity: 0.7;
}

#main_bg01 {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 50%;
  background-image: linear-gradient(249deg, #f02222 16%, #6d1111);
}

#main_bg02 {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 50%;
  background: url("../images/top2/bg_pc.jpg") no-repeat center / 100% 100%;
}

#main_bg01m {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 15;
  width: 100%;
  height: 50%;
  background: #000;
  animation: mainM01anm 1s cubic-bezier(0,.64,.41,1) 1.7s forwards;
}

#main_bg02m {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 15;
  width: 100%;
  height: 50%;
  background: #000;
  animation: mainM02anm 1s cubic-bezier(0,.64,.41,1) 1.9s forwards;
}


/* =================================================
BNR
================================================= */

#bnrLall {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-left: 30px;
  padding: 20px 0;
  background-image: linear-gradient(143deg, #440005, #820707);
  line-height: 0;
  text-align: center;
}

.bnrimg {
  width: 19%;
  margin: 0 0.5%;
}


/* =================================================
Movie
================================================= */

#topmovarea {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 5vw 0;
  background: #fff url("../images/top/bg_keepout_w.jpg") no-repeat center / cover;
  background-attachment: fixed;
  border-bottom: 1px solid #2e1e20;
  overflow: hidden;
  line-height: 0;
}

#topmovarea .movie {
  width: 75%;
  min-width: 640px;
  margin: 0 auto;
  transform: translateX(30px);
}

#topmovarea .movie .inner {
  position: relative;
  height: 0;
  padding-bottom: 56.25%;
  background-color: #000;
  overflow: hidden;
}

#topmovarea .movie .inner iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 6px solid #595959;
  box-sizing: border-box;
}

#topmovarea .movie .tab_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 100%;
  margin-top: 1em;
}

#topmovarea .movie .tab_area ul {
  width: 100%;
}

#topmovarea .movie .tab_area li {
  position: relative;
  background: linear-gradient(-20deg, #bf0017, #850010);
  border-bottom: 2px solid #950000;
  border-radius: 3px;
  box-shadow: 0 2px 5px rgba(0,0,0,.3);
  font-weight: 800;
  color: #fff;
  text-align: center;
  overflow: hidden;
}

#topmovarea .movie .tab_area li.wide2 {
  width: 49.6%;
  height: 50px;
  margin: 0.2%;
  font-size: 14px;
}

#topmovarea .movie .tab_area li.wide4 {
  width: 24.6%;
  height: 50px;
  margin: 0.2%;
  font-size: 13px;
}

#topmovarea .movie .tab_area li a {
  display: block;
  width: 100%;
  height: 100%;
  color: #fefefe;
  text-decoration: none;
}

#topmovarea .movie .tab_area li a.active {
  background: #d6000f;
}

.movbtnM {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
  z-index: 1;
}


/* =================================================
Footer
================================================= */

footer {
  width: 100%;
  padding: 30px 0 40px 30px;
  background: #000 url("../images/common/footer_new.png") no-repeat right -5% center / auto 150%;
}

#odorucom,
#sharearea,
#privacy,
#copyright {
  width: 100%;
  text-align: center;
}

#odorucom {
  margin: 50px auto;
  font-size: 15px;
  letter-spacing: 3px;
  color: #fff;
  font-family: "Cal Sans", sans-serif;
  font-weight: 400;
  font-style: normal;
}

#sharearea {
  width: 260px;
  margin: 0 auto;
  font-size: 16px;
  text-align: right;
  font-family: "Cal Sans", sans-serif;
  font-weight: 400;
  font-style: normal;
  background: url("../images/sns/share.png") no-repeat left / auto 13px;
}

#sharearea a,
#privacy a {
  color: #d6000f;
}

#privacy,
#copyright {
  margin: 20px auto;
  font-size: 10px;
  color: #d6000f;
}

#btnpagetop {
  position: fixed;
  right: 0;
  bottom: 0;
  z-index: 15;
  width: 60px;
  height: 60px;
  background: #d6000f;
  text-align: center;
  line-height: 60px;
  transition: .3s;
  font-size: 18px;
}

#btnpagetop a {
  display: block;
  width: 100%;
  height: 100%;
  color: #000;
}

#btnpagetop:hover {
  opacity: .7;
}


/* =================================================
Effect
================================================= */

.ef-fade,
.ef-fade1,
.ef-fade2,
.ef-fade3,
.ef-fade4,
.ef-fade5,
.ef-fade6,
.ef-Left,
.ef-Right,
.ef-Up,
.ef-scale {
  opacity: 0;
  transition: .8s linear 0.1s;
}

.fade {
  opacity: 1;
  transform: none;
}
