#view {
  visibility: hidden;
  opacity: 0;
}
#view.complete {
  visibility: visible;
  opacity: 1;
}

.allcontainer {
  background: #C8161D;
}

/*-------------------------------------------------
---------------------------------------------------*/
.inner {
  max-width: 1240px;
  margin: auto;
  position: relative;
}

.mv {
  background: url(../../images/bg_main.png) no-repeat 50% 0;
  background-size: 100% auto;
  text-align: center;
  position: relative;
}
.mv h1 {
  position: relative;
  z-index: 2;
}
.mv::before {
  content: "";
  width: 100%;
  height: calc(100% - 80px);
  background: url(../../images/bg_sakura.png) no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: 0;
  left: 0;
}
.mv::after {
  content: "";
  width: 100%;
  height: 0;
  padding-bottom: 13.64%;
  background: url(../../images/bg_after.png) no-repeat;
  background-size: 100% auto;
  position: absolute;
  bottom: 80px;
  left: 0;
}

.container {
  background: url(../../images/bg_contents.png);
  background-attachment: fixed;
  margin-top: -80px;
  padding: 144px 0 80px;
}
.container .campaign {
  text-align: center;
  padding: 0 0 64px;
  position: relative;
  line-height: 1;
}
.container .campaign img {
  max-width: 1240px;
  width: 100%;
}
.container .campaign::after {
  content: "";
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0);
  position: absolute;
  top: 0;
  left: 0;
}
.container .mt1 {
  margin-top: -1px;
}

footer {
  position: relative;
  background: #fff;
}
footer::before {
  content: "";
  background: url(../../images/campaign_fl.png) no-repeat 100% 50%;
  background-size: 100% auto;
  padding: 0 0 20% 0;
  width: 38%;
  position: absolute;
  left: 0;
  bottom: 20%;
}
footer .inner {
  border-top: 1px solid #666;
  max-width: 780px;
}
footer .inner .ttl_ {
  text-align: center;
  color: #0a2c86;
  font-size: 1.5em;
  font-weight: bold;
  padding: 32px 0 8px 0;
}
footer .inner .inq_lst {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 24px 0 48px 0;
}
footer .inner .inq_lst li {
  width: 48%;
}
footer .inner .inq_lst li a {
  cursor: default;
}
footer .inner .inq_lst li a:hover {
  opacity: 1;
}
footer .inner .f_logo {
  text-align: center;
  padding-bottom: 24px;
}
footer .inner .privacy_link {
  text-align: right;
  padding: 0 0 24px 0;
}
footer .inner .privacy_link a {
  color: #222;
  font-size: 0.875em;
}
footer .copyr {
  background: #0a2c86;
  padding: 16px 0;
  font-size: 0.875em;
  color: #fff;
  text-align: center;
}

.cv_area {
  position: fixed;
  left: 0;
  top: 12%;
  z-index: 9999;
}
.cv_area ul li {
  width: 60px;
}
.cv_area ul li:first-child {
  margin-bottom: 8px;
}

@media screen and (max-width: 767px) {
  .allcontainer {
    overflow: hidden;
  }
  .inner {
    margin: 0 16px;
  }
  .mv {
    padding: 7.5% 0;
  }
  .container {
    margin-top: -80px;
    padding: 48px 0 40px;
  }
  .container .campaign {
    padding: 0 0 16px;
  }
  .container .campaign img {
    max-width: inherit;
    width: 100%;
  }
  footer {
    padding-bottom: 33.3333%;
  }
  footer .inner {
    border-top: 1px solid #666;
  }
  footer .inner .ttl_ {
    text-align: center;
    color: #0a2c86;
    font-size: 1em;
    font-weight: bold;
    padding: 40px 0 0;
  }
  footer .inner .inq_lst {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 24px 0 24px 0;
  }
  footer .inner .inq_lst li {
    width: calc(50% - 8px);
  }
  footer .inner .inq_lst li a {
    cursor: default;
  }
  footer .inner .inq_lst li a:hover {
    opacity: 1;
  }
  footer .inner .f_logo {
    text-align: center;
    padding-bottom: 24px;
    width: 60%;
    margin: auto;
  }
  footer .inner .privacy_link {
    text-align: center;
    padding: 0 0 24px 0;
  }
  footer .inner .privacy_link a {
    color: #222;
    font-size: 0.875em;
  }
  footer .copyr {
    background: #0a2c86;
    padding: 16px 0;
    font-size: 0.675em;
    color: #fff;
    text-align: center;
  }
  .cv_area {
    position: fixed;
    left: 0;
    top: auto;
    bottom: 0;
    z-index: 9999;
    line-height: 1;
    padding-bottom: env(safe-area-inset-bottom);
  }
  .cv_area ul {
    display: flex;
    justify-content: center;
  }
  .cv_area ul li {
    width: 100%;
  }
  .cv_area ul li:first-child {
    margin-bottom: 0;
  }
  .cv_area ul li a {
    display: block;
    background: #0a2c86;
    text-align: center;
    position: relative;
    padding: 8px 0;
    width: 92.5%;
    margin: auto;
  }
  .cv_area ul li a img {
    width: 45%;
    margin: auto;
  }
  .cv_area ul li a::before {
    content: "";
    width: calc(100% - 8px);
    height: calc(100% - 10px);
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
    position: absolute;
    top: 4px;
    left: 4px;
  }
  .cv_area ul li a::after {
    content: "";
    background: #fff;
    width: 20px;
    height: 8px;
    -webkit-clip-path: polygon(0 46%, 50% 46%, 50% 0%, 83% 50%, 50% 100%, 50% 54%, 0 54%);
            clip-path: polygon(0 46%, 50% 46%, 50% 0%, 83% 50%, 50% 100%, 50% 54%, 0 54%);
    position: absolute;
    top: calc(50% - 4px);
    right: 16px;
  }
  .cv_area ul li a:hover {
    opacity: 1;
  }
}
/*# sourceMappingURL=layout.css.map */