@keyframes horizontal1 {
  0% {
    -webkit-transform: translateX(-5px);
  }
  100% {
    -webkit-transform: translateX(0px);
  }
}
@keyframes horizontal2 {
  0% {
    -webkit-transform: translateX(5px);
  }
  100% {
    -webkit-transform: translateX(0px);
  }
}
@keyframes vertical {
  0% {
    -webkit-transform: translateY(-10px);
  }
  100% {
    -webkit-transform: translateY(0px);
  }
}
@keyframes jump {
  0% {
    transform: translate(0%, 80px) rotateX(30deg);
  }
  100% {
    transform: translate(0%, 0%);
    background-size: 0 0, contain;
  }
}
@keyframes mabataki {
  0% {
    background-size: 0 0, contain;
  }
  95% {
    background-size: contain, 0 0;
  }
  100% {
    background-size: 0 0, contain;
  }
}
@keyframes nav {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
/* CSS INFORMATION -====================================================
File name : base.css
Description :
===================================================================== */
html {
  min-height: 100vh;
  overflow-x: hidden;
  font-size: calc(10 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  html {
    font-size: calc(10 / 1400 * 100vw);
  }
}
@media screen and (min-width: 1400px) {
  html {
    font-size: 10px;
  }
}

body {
  margin: 0;
  padding: 0;
}

#wrapper {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 900;
  color: #fff;
  min-height: 100vh;
  background: #b6e8f2 url(../images/common/bg_pattern02.jpg) repeat top center/12rem auto;
  overflow: hidden;
}

.forSP {
  display: block;
}

.forPC {
  display: none;
}

@media screen and (min-width: 768px) {
  .forSP {
    display: none;
  }
  .forPC {
    display: block;
  }
}
img {
  width: 100%;
}

.gDef-top-banner {
  background-color: #65a7af;
  position: relative;
  z-index: 3;
}

.gDef-contents p,
.gDef-contents dl {
  font-size: 2.4rem;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .gDef-contents p,
  .gDef-contents dl {
    font-size: 1.8rem;
  }
}

.set1,
.set1 * {
  position: relative;
}
.set1 img,
.set1 * img {
  width: 100%;
  height: auto;
  display: block;
}
.set1 a,
.set1 * a {
  color: #000;
  display: block;
}

.inner {
  width: calc(690 / 750 * 100%);
  margin: 0 auto;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .inner {
    width: calc(1024 / 1400 * 100%);
    max-width: 1024px;
  }
}

svg {
  width: 100%;
  height: auto;
}

.bg_star {
  background: white url(../images/common/star_sp.gif) no-repeat top 150px center/contain;
}
@media screen and (min-width: 768px) {
  .bg_star {
    background: white url(../images/common/star_pc.gif) no-repeat top center/contain;
  }
}
@media screen and (min-width: 1400px) {
  .bg_star {
    background: white url(../images/common/star_pc.gif) no-repeat top center/1240px;
  }
}

.bg_white {
  background: #fff;
}

span.iroliro_color {
  color: transparent;
  background: repeating-linear-gradient(90deg, #EB6DA5 0 1em, #F39633 1em 2em, #EA5419 2em 3em, #56ACE1 3em 4em);
  background-clip: text;
  -webkit-background-clip: text;
}

/* =====================================================================
*    contents
* =================================================================== */
h2.ttl {
  font-size: 6.4rem;
  font-weight: 900;
  text-align: center;
  line-height: 1.4;
  margin-bottom: 7rem;
  position: relative;
  padding-top: 23.8rem;
  z-index: 30;
}
@media screen and (min-width: 768px) {
  h2.ttl {
    font-size: 4.8rem;
    padding-top: 0;
  }
}
h2.ttl .icon {
  display: block;
  width: 13.3rem;
  height: 21.4rem;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  h2.ttl .icon {
    top: auto;
    bottom: -2rem;
    right: auto;
    margin: 0;
  }
}
h2.ttl .icon::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../images/common/img_ship01.png) no-repeat center center/contain;
  animation: vertical 1s ease-in-out infinite alternate;
}

.cloud_btm {
  position: relative;
}
.cloud_btm:before {
  content: "";
  display: block;
  width: 100%;
  padding-top: calc(100 / 750 * 100%);
  background: url(../images/common/bg_cloud_top.svg) no-repeat top center/cover;
  position: absolute;
  left: 0;
  top: -2px;
  transform: scale(-1, -1);
}
@media screen and (min-width: 768px) {
  .cloud_btm:before {
    padding-top: 10rem;
  }
}

.bnr_youtube_box .inner {
  width: 85%;
  margin: auto;
}

.bnr_youtube {
  margin: 0 auto;
  width: calc(640 / 690 * 100%);
}
.bnr_youtube a {
  display: block;
  filter: drop-shadow(0 1.6rem 1.6rem rgba(0, 0, 0, 0.1));
}

@media screen and (min-width: 768px) {
  .bnr_youtube_box .inner {
    max-width: 1024px;
  }
  .bnr_youtube {
    width: calc(640 / 1024 * 100%);
  }
  .bnr_youtube a {
    position: relative;
  }
  .bnr_youtube a::after {
    content: "";
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../images/common/bnr_youtube_h.png) no-repeat center/100% 100%;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
  }
  .bnr_youtube a img {
    transition: opacity 0.3s ease;
  }
  .bnr_youtube a:hover::after {
    opacity: 1;
  }
}
/* =====================================================================
*    footer
* =================================================================== */
footer {
  position: relative;
}
footer:before {
  content: "";
  display: block;
  width: 100%;
  z-index: 1;
  padding-top: calc(100 / 750 * 100%);
  background: url(../images/common/bg_cloud_top.svg) no-repeat top center;
  background-size: cover;
  position: absolute;
  left: 0;
  bottom: -2px;
}

@media screen and (min-width: 768px) {
  footer:before {
    content: "";
    padding-top: 10rem;
  }
  footer .chara {
    width: calc(134 / 1400 * 100%);
    margin: calc(30 / 1400 * 100%) 0 0 calc(50% - 67 / 1400 * 100%);
  }
}/*# sourceMappingURL=base.css.map */