@charset "UTF-8";
/*
 * htmlのfont-size用
 */
/*
   * font-size可変用
   */
/*メディアクエリー
---------------------------------------------*/
/* For modern browsers */
.clearfix:before,
.clearfix:after {
  content: "";
  display: table;
}

.clearfix:after {
  clear: both;
}

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

/* variable */
i {
  margin: auto 20px;
}

* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
}

.pc {
  display: inherit !important;
}

.sp {
  display: none !important;
}

/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 769px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: inherit !important;
  }
}
/*---------------------------------------------------------------
common
-------------------------------------------------------------- */
html {
  font-size: 62.5%;
  /* 16px x 0.625 = 10px(=1rem) */
  scroll-behavior: smooth;
}

:target {
  scroll-margin-top: 50px;
}

body {
  font-family: dnp-shuei-gothic-kin-std, sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.6rem;
  line-height: 180%;
  color: #fff;
  font-feature-settings: "palt";
  letter-spacing: 0.08em;
  background: url(../images/bg_dot.jpg) fixed;
  text-align: justify;
  text-justify: inter-ideograph;
  position: relative;
}
@media screen and (min-width: 769px) {
  body {
    background-size: auto;
  }
}

a {
  color: #000;
  text-decoration: none;
}

.content_left {
  display: none;
}
@media screen and (min-width: 769px) {
  .content_left {
    height: 100%;
    width: calc((100% - 769px) * 0.4);
    position: fixed;
    top: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: -2;
  }
}
@media screen and (min-width: 769px) {
  .content_left h1 {
    width: 80%;
    max-width: 300px;
    min-width: 100px;
  }
}

.content_right {
  display: none;
}
@media screen and (min-width: 769px) {
  .content_right {
    height: 100%;
    width: calc((100% - 769px) * 0.6);
    position: fixed;
    top: 0;
    right: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: -2;
    background: url("../images/main_1.jpg") top right;
    background-size: cover;
  }
}

#wrapper {
  width: 100%;
  max-width: 769px;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
  position: relative;
  background: linear-gradient(180deg, transparent 0%, transparent 420px, #0051E0 420px, #0051E0 100%);
  z-index: 1;
}
@media screen and (min-width: 769px) {
  #wrapper {
    margin-left: calc((100% - 769px) * 0.4);
    border-left: solid 1px #5E91EB;
    border-right: solid 1px #5E91EB;
    background: #0051E0;
  }
}
#wrapper .side_txt_left {
  margin-left: 2px;
  background-image: url(../images/side_txt.svg);
  animation-name: bgAnimTop;
  animation-duration: 40s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  background-size: auto;
  background-repeat: repeat-y;
  position: absolute;
  top: 0;
  height: 100%;
  width: 15px;
  z-index: 2;
}
#wrapper .side_txt_left::before {
  content: "";
  width: 1px;
  background-color: #5E91EB;
  opacity: 0.5;
  position: absolute;
  height: 100%;
  left: 18px;
}
#wrapper .side_txt_right {
  margin-right: 1px;
  background-image: url(../images/side_txt.svg);
  animation-name: bgAnimBottom;
  animation-duration: 40s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  background-size: auto;
  background-repeat: repeat-y;
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: 15px;
  z-index: 2;
}
#wrapper .side_txt_right::before {
  content: "";
  width: 1px;
  background-color: #5E91EB;
  opacity: 0.5;
  position: absolute;
  height: 100%;
  right: 18px;
}

.fade-in {
  transition: opacity 0.4s;
  -moz-transition: opacity 0.4s;
  -webkit-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
}

img {
  width: 100%;
  vertical-align: bottom;
}

h1,
h2,
h3 {
  font-family: "corporate-logo-ver2", sans-serif;
  font-weight: 500;
  font-style: normal;
}

/*-------------------------------
block
--------------------------------- */
.pc {
  display: none;
}
@media screen and (min-width: 769px) {
  .pc {
    display: inherit;
  }
}

@media screen and (min-width: 769px) {
  .sp {
    display: none;
  }
}

@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
h2.title {
  margin-bottom: 13.3333333333vw;
  text-align: center;
  font-size: 12.8vw;
  line-height: 120%;
  color: transparent;
  -webkit-text-stroke: 1px #0051E0;
  text-stroke: 1px #0051E0;
  display: block;
}
@media screen and (min-width: 769px) {
  h2.title {
    margin-bottom: 50px;
    font-size: 6.4rem;
  }
}
h2.title span {
  margin: 4vw 0 0;
  padding: 0;
  font-size: 3.2vw;
  font-weight: 400;
  display: block;
  -webkit-text-stroke: none;
  text-stroke: none;
  color: #0051E0;
  line-height: 100%;
  letter-spacing: 0.2em;
}
@media screen and (min-width: 769px) {
  h2.title span {
    margin: 15px 0 0;
    font-size: 1.4rem;
  }
}

h2.onsen {
  padding: 120px 0 0;
  display: block;
  background: url(../images/onsen.png) center top no-repeat;
}

h2.title_2 {
  margin-bottom: 13.3333333333vw;
  text-align: center;
  font-size: 12.8vw;
  line-height: 120%;
  color: transparent;
  -webkit-text-stroke: 1px #fff;
  text-stroke: 1px #fff;
  display: block;
}
@media screen and (min-width: 769px) {
  h2.title_2 {
    margin-bottom: 50px;
    font-size: 6.4rem;
  }
}
h2.title_2 span {
  margin: 4vw 0 0;
  padding: 0;
  font-size: 3.2vw;
  font-weight: 400;
  display: block;
  -webkit-text-stroke: none;
  text-stroke: none;
  color: #fff;
  line-height: 100%;
  letter-spacing: 0.2em;
}
@media screen and (min-width: 769px) {
  h2.title_2 span {
    margin: 15px 0 0;
    font-size: 1.4rem;
  }
}

h2.onsen_2 {
  padding: 120px 0 0;
  display: block;
  background: url(../images/onsen_2.png) center top no-repeat;
}

/*---------------------------------------------------------------
 navi
-------------------------------------------------------------- */
#toggle {
  padding: 10px 13px;
  position: fixed;
  top: 15px;
  right: 15px;
  background: #fff;
  border: solid 2px #0051E0;
  border-radius: 20%;
  z-index: 99;
  box-shadow: 3px 3px 0px 0 #0051E0;
}

#toggle-box {
  position: relative;
  width: 30px;
  height: 20px;
  cursor: pointer;
  display: block;
}

#toggle-box > span {
  width: 100%;
  height: 2px;
  left: 0;
  display: block;
  background: #0051E0;
  position: absolute;
  transition: transform 0.6s ease-in-out, top 0.5s ease, bottom 0.5s ease;
}

#toggle-box > span:nth-child(1) {
  top: 0;
}

#toggle-box > span:nth-child(2) {
  top: 50%;
  transform: translatey(-50%);
}

#toggle-box > span:nth-child(3) {
  bottom: 0;
}

#toggle {
  z-index: 1000;
}

#nav-content {
  z-index: 900;
  overflow: auto;
  width: 100%;
  height: 100%;
  background: #0051E0;
  color: #fff;
  position: fixed;
  top: 0;
  right: 0;
  text-align: center;
  transform: translateX(100%);
  transition: transform 1s cubic-bezier(0.215, 0.61, 0.355, 1);
  font-family: "corporate-logo-ver2", sans-serif;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 769px) {
  #nav-content {
    width: 50%;
    max-width: 400px;
    border-left: solid 1px #5E91EB;
  }
}
#nav-content nav {
  width: 80%;
  margin: 0 auto;
}
#nav-content nav h1 {
  width: 50%;
  max-width: 200px;
  margin: 0 auto 13.3333333333vw;
}
@media screen and (min-width: 769px) {
  #nav-content nav h1 {
    margin: 0 auto 50px;
  }
}
#nav-content nav ul.list {
  list-style: none;
}
#nav-content nav ul.list li {
  margin-bottom: 5.3333333333vw;
  text-align: center;
  font-size: 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  #nav-content nav ul.list li {
    margin-bottom: 20px;
    font-size: 20px;
  }
}
#nav-content nav ul.list li a {
  display: block;
  color: #fff;
  text-decoration: none;
  padding: 0;
  transition: opacity 0.6s ease;
  position: relative;
}
#nav-content nav ul.list li a:hover {
  opacity: 0.6;
}

.is-open {
  overflow: hidden;
}

.is-open #toggle-box > span {
  background: #0051E0;
}

.is-open #toggle-box > span:nth-child(1) {
  top: 50%;
  transform: rotate(45deg) translatey(-50%);
}

.is-open #toggle-box > span:nth-child(2) {
  width: 0;
}

.is-open #toggle-box > span:nth-child(3) {
  top: 50%;
  transform: rotate(-45deg) translatey(-50%);
}

.is-open #nav-content {
  z-index: 999;
  transform: translateX(0);
}

.overlay {
  background: rgba(0, 0, 0, 0.5);
  height: 100vh;
}

/*-------------------------------
main
--------------------------------- */
.main {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}
.main h1 {
  width: 55%;
  max-width: 280px;
  margin: 10.6666666667vw auto 0;
}
@media screen and (min-width: 769px) {
  .main h1 {
    margin: 40px auto 0;
  }
}
.main .image_1 {
  width: 75%;
  margin: 8vw auto 0;
  position: relative;
  z-index: 3;
}
@media screen and (min-width: 769px) {
  .main .image_1 {
    margin: 30px auto 0;
  }
}
.main .image_1 img {
  border-radius: 5%;
}
.main .image_2 {
  width: 70%;
  margin: 8vw 0 0 auto;
  position: relative;
  z-index: 3;
}
@media screen and (min-width: 769px) {
  .main .image_2 {
    width: 75%;
    margin: 80px auto 0;
  }
}
.main .image_2 img {
  border-top-left-radius: 5%;
  border-bottom-left-radius: 5%;
}
@media screen and (min-width: 769px) {
  .main .image_2 img {
    border-radius: 5%;
  }
}
.main .copy {
  width: 75%;
  margin: 13.3333333333vw auto 0;
  font-size: 5.8666666667vw;
  font-family: "corporate-logo-ver2", sans-serif;
  letter-spacing: 0.1;
  line-height: 160%;
}
@media screen and (min-width: 769px) {
  .main .copy {
    margin: 50px auto 0;
    font-size: 3.3rem;
  }
}
.main .lead {
  width: 75%;
  margin: 5.3333333333vw auto 0;
  font-size: 3.7333333333vw;
  line-height: 2.14em;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 769px) {
  .main .lead {
    margin: 30px auto 0;
    font-size: 2rem;
  }
}
.main .date {
  width: 75%;
  margin: 16vw auto 0;
}
@media screen and (min-width: 769px) {
  .main .date {
    margin: 60px auto 0;
  }
}
.main .limit {
  width: 75%;
  margin: 8vw auto 0;
  padding: 5.3333333333vw;
  font-size: 3.2vw;
  line-height: 1.5em;
  letter-spacing: 0.075em;
  color: #fff;
  background: #004ACC;
  border-radius: 10px;
}
@media screen and (min-width: 769px) {
  .main .limit {
    margin: 30px auto 0;
    padding: 30px;
    font-size: 1.6rem;
  }
}
.main .limit h2 {
  margin-bottom: 2.6666666667vw;
  font-size: 4.8vw;
  color: #F8E93F;
}
@media screen and (min-width: 769px) {
  .main .limit h2 {
    font-size: 2.2rem;
    margin-bottom: 20px;
  }
}
.main .limit .marker {
  margin: 1.3333333333vw 0;
}
@media screen and (min-width: 769px) {
  .main .limit .marker {
    margin: 10px 0;
  }
}
.main .limit .marker span {
  font-size: 4.8vw;
  line-height: 1.6em;
  margin-top: 5.3333333333vw;
  border-bottom: dotted 1px;
}
@media screen and (min-width: 769px) {
  .main .limit .marker span {
    font-size: 2rem;
    margin-top: 20px;
  }
}
.main .limit .small {
  margin-top: 1.3333333333vw;
  font-size: 2.4vw;
  display: block;
}
@media screen and (min-width: 769px) {
  .main .limit .small {
    margin-top: 10px;
    font-size: 1.3rem;
  }
}

/*-------------------------------
item
--------------------------------- */
.item {
  width: 100%;
  margin: 26.6666666667vw auto 0;
  padding: 21.3333333333vw 5%;
  background: #F8E93F;
  color: #0051E0;
  text-align: center;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .item {
    margin: 180px auto 0;
    padding: 160px 8%;
  }
}
.item .wave_top {
  height: 20px;
  width: 100%;
  margin: 0;
  padding: 0;
  background-image: url(../images/wave_top.png);
  animation-name: bgAnimLeft;
  animation-duration: 20s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  background-size: auto;
  background-repeat: repeat-x;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}
.item .wave_btm {
  height: 20px;
  width: 100%;
  margin: 0;
  padding: 0;
  background-image: url(../images/wave_btm.png);
  animation-name: bgAnimLeft;
  animation-duration: 20s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  background-size: auto;
  background-repeat: repeat-x;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
}
.item .more {
  margin: 0 auto 21.3333333333vw;
  padding: 0;
}
@media screen and (min-width: 769px) {
  .item .more {
    margin: 0 auto 150px;
  }
}
.item .more__content {
  position: relative;
  height: auto;
  max-height: 800px;
  overflow: hidden;
  transition: max-height 1s;
}
@media screen and (min-width: 769px) {
  .item .more__content {
    max-height: 1200px;
  }
}
.item .more__content::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 15%;
  transition: 1s;
  background: linear-gradient(to bottom, transparent 0%, #F8E93F 90%);
}
.item .more__content.open:after {
  z-index: -1;
  opacity: 0;
}
.item .more__btn {
  width: 100%;
  padding: 6.6666666667vw;
  margin-top: 0;
  font-size: 4.8vw;
  background: #0051E0;
  color: #fff;
  display: block;
  font-family: "corporate-logo-ver2", sans-serif;
  border-radius: 100px;
  text-align: center;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  .item .more__btn {
    padding: 30px;
    font-size: 2.4rem;
  }
}
.item .fuwafuwa {
  width: 34.6666666667vw;
  position: absolute;
  top: -16vw;
  left: 2.6666666667vw;
  z-index: 99;
}
@media screen and (min-width: 769px) {
  .item .fuwafuwa {
    width: 200px;
    position: absolute;
    top: -1%;
    left: 5%;
  }
}
.item .fuwafuwa_2 {
  width: 21.3333333333vw;
  position: absolute;
  top: -16vw;
  left: 26.6666666667vw;
  z-index: 99;
}
@media screen and (min-width: 769px) {
  .item .fuwafuwa_2 {
    width: 100px;
    position: absolute;
    top: -1%;
    left: 22%;
  }
}
.item h3 {
  margin: 13.3333333333vw auto;
  font-size: 4.8vw;
  text-align: center;
  display: inline-block;
  border-bottom: solid 1px;
}
@media screen and (min-width: 769px) {
  .item h3 {
    margin: 50px auto;
    font-size: 2.4rem;
  }
}
.item h3 span {
  font-size: 10.1333333333vw;
}
@media screen and (min-width: 769px) {
  .item h3 span {
    font-size: 4.4rem;
  }
}
.item .item_list {
  width: 100%;
  margin: 0 auto 8vw;
  padding-top: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (min-width: 769px) {
  .item .item_list {
    margin: 0 auto 30px;
  }
}
.item .item_list > li {
  width: 47%;
  margin-bottom: 8vw;
  position: relative;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .item .item_list > li {
    margin-bottom: 50px;
  }
}
.item .item_list > li .slider {
  padding: 5% 5% 7%;
  border-radius: 10%;
  background: #fff;
  margin-bottom: 2.6666666667vw;
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .item .item_list > li .slider {
    padding: 5% 5% 10%;
    margin-bottom: 20px;
  }
}
.item .item_list > li .slider img {
  vertical-align: baseline;
}
.item .item_list > li .limited {
  display: inline-grid;
  color: #fff;
  background-color: #E46833;
  width: 12vw;
  height: 12vw;
  border-radius: 50%;
  text-align: center;
  align-content: center;
  position: absolute;
  top: -1.3333333333vw;
  left: 0vw;
  font-size: 2.9333333333vw;
  line-height: 130%;
  z-index: 999;
  overflow: visible;
}
@media screen and (min-width: 769px) {
  .item .item_list > li .limited {
    width: 80px;
    height: 80px;
    top: -10px;
    left: 0px;
    font-size: 1.6rem;
  }
}
.item .item_list > li .name {
  font-size: 2.9333333333vw;
  line-height: 1.66em;
}
@media screen and (min-width: 769px) {
  .item .item_list > li .name {
    font-size: 1.8rem;
  }
}
.item .item_list > li .price {
  margin-top: 1.3333333333vw;
  font-size: 4.2666666667vw;
}
@media screen and (min-width: 769px) {
  .item .item_list > li .price {
    margin-top: 5px;
    font-size: 2.6rem;
  }
}
.item .item_list > li .price span {
  font-size: 2.4vw;
}
@media screen and (min-width: 769px) {
  .item .item_list > li .price span {
    font-size: 1.4rem;
  }
}
.item .item_list > li .buy {
  width: 80%;
  max-width: 180px;
  margin: 1.3333333333vw auto 0;
  padding: 1.8666666667vw 2.6666666667vw;
  background: #0051E0;
  color: #fff;
  font-size: 2.9333333333vw;
  display: block;
  text-align: center;
  border-radius: 50px;
}
@media screen and (min-width: 769px) {
  .item .item_list > li .buy {
    margin: 10px auto 0;
    padding: 10px;
    font-size: 1.6rem;
  }
}
.item .item_list > li .slick-dots {
  position: absolute;
  bottom: 3px;
  left: 0;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}
.item .item_list > li .slick-dots li {
  width: 13px;
  margin: 0 1px;
}
.item .item_list > li .slick-dots li button {
  padding: 1px;
}
.item .item_list > li .slick-dots li button:before {
  width: 10px;
  height: 10px;
  color: #0051E0;
}
@media screen and (min-width: 769px) {
  .item .coming {
    width: 80%;
    margin: auto;
  }
}
.item .coming figure {
  margin-bottom: 8vw;
}
@media screen and (min-width: 769px) {
  .item .coming figure {
    margin-bottom: 30px;
  }
}
.item .coming p {
  text-align: left;
}

/*-------------------------------
howto
--------------------------------- */
.howto {
  width: 100%;
  margin: 26.6666666667vw auto 0;
  padding: 0 20px;
}
@media screen and (min-width: 769px) {
  .howto {
    margin: 160px auto 0;
  }
}
.howto .howto_list {
  margin: 0 2.6666666667vw;
  padding: 13.3333333333vw 5.3333333333vw;
  background: #F8E93F;
  color: #0051E0;
  border-radius: 9999px;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .howto .howto_list {
    margin: 0 10px;
    padding: 80px 80px;
  }
}
.howto .howto_list .num {
  font-size: 5.8666666667vw;
  -webkit-text-stroke: 1px #0051E0;
  text-stroke: 1px #0051E0;
  line-height: 100%;
  color: transparent;
  margin-bottom: 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .howto .howto_list .num {
    font-size: 3.6rem;
    margin-bottom: 20px;
  }
}
.howto .howto_list h3 {
  display: block;
  font-size: 5.8666666667vw;
  line-height: 100%;
  margin-bottom: 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  .howto .howto_list h3 {
    font-size: 3.6rem;
    margin-bottom: 30px;
  }
}
.howto .howto_list figure {
  margin-bottom: 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  .howto .howto_list figure {
    margin: 20px 0;
  }
}
.howto .howto_list .txt {
  font-size: 2.9333333333vw;
  line-height: 150%;
}
@media screen and (min-width: 769px) {
  .howto .howto_list .txt {
    font-size: 1.8rem;
  }
}
.howto .slick-dots {
  position: absolute;
  bottom: -30px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}
.howto .slick-dots li {
  margin: 0 1px;
}
.howto .slick-dots li button {
  padding: 1px;
}
.howto .slick-dots li button:before {
  color: #fff;
}
.howto .slick-dots li.slick-active {
  margin: 0 1px;
}
.howto .slick-dots li.slick-active button {
  padding: 1px;
}
.howto .slick-dots li.slick-active button:before {
  color: #fff;
}

/*-------------------------------
search
--------------------------------- */
.search {
  width: 100%;
  margin: 26.6666666667vw auto 0;
  padding: 0 15%;
}
@media screen and (min-width: 769px) {
  .search {
    margin: 160px auto 0;
  }
}
.search h2 {
  font-size: 8.5333333333vw;
}
@media screen and (min-width: 769px) {
  .search h2 {
    font-size: 4.2rem;
  }
}
.search figure {
  margin-bottom: 8vw;
}
@media screen and (min-width: 769px) {
  .search figure {
    margin-bottom: 30px;
  }
}
.search p {
  font-size: 2.9333333333vw;
  line-height: 1.8em;
  margin-bottom: 8vw;
}
@media screen and (min-width: 769px) {
  .search p {
    font-size: 1.6rem;
    margin-bottom: 40px;
  }
}
.search ul {
  display: flex;
  justify-content: space-between;
}
.search ul li {
  width: 48%;
}

/*-------------------------------
profile
--------------------------------- */
.profile {
  width: 100%;
  margin: 26.6666666667vw auto 0;
  padding: 0 15%;
}
@media screen and (min-width: 769px) {
  .profile {
    margin: 160px auto 0;
  }
}
.profile h2 {
  font-size: 8.5333333333vw;
}
@media screen and (min-width: 769px) {
  .profile h2 {
    font-size: 4.2rem;
  }
}
.profile ul li {
  margin-bottom: 2.6666666667vw;
  padding: 8vw 13.3333333333vw;
  border: solid 1px #fff;
  border-radius: 20px;
}
@media screen and (min-width: 769px) {
  .profile ul li {
    margin-bottom: 20px;
    padding: 50px;
  }
}
.profile ul li figure {
  width: 70%;
  margin: 0 auto 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  .profile ul li figure {
    margin: 0 auto 20px;
  }
}
.profile ul li figure img {
  border-radius: 50%;
}
.profile ul li h3 {
  margin: 0 auto 1.3333333333vw;
  font-size: 4.2666666667vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .profile ul li h3 {
    margin: 0 auto 10px;
    font-size: 2.4rem;
  }
}
.profile ul li h3 span {
  font-size: 3.2vw;
}
@media screen and (min-width: 769px) {
  .profile ul li h3 span {
    font-size: 1.8rem;
  }
}
.profile ul li p {
  font-size: 2.9333333333vw;
  line-height: 1.8em;
}
@media screen and (min-width: 769px) {
  .profile ul li p {
    font-size: 1.6rem;
  }
}

/*-------------------------------
event
--------------------------------- */
.event {
  width: 100%;
  margin: 26.6666666667vw auto 0;
  padding: 0 13%;
}
@media screen and (min-width: 769px) {
  .event {
    margin: 160px auto 0;
  }
}
.event a {
  color: #fff;
  text-decoration: underline;
}
.event ul li {
  margin: 0 auto 21.3333333333vw;
  padding: 0;
  position: relative;
}
@media screen and (min-width: 769px) {
  .event ul li {
    margin: 0 auto 130px;
  }
}
.event ul li .num,
.event ul li .num:before,
.event ul li .num:after,
.event ul li .num_box {
  position: absolute;
  background-color: #F8E93F;
  width: 50px;
  height: 50px;
}
.event ul li .num {
  left: -15px;
  top: -20px;
}
.event ul li .num:before {
  transform: rotate(60deg);
  content: "";
}
.event ul li .num:after {
  transform: rotate(-60deg);
  content: "";
}
.event ul li .num_box {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  z-index: 1;
}
.event ul li .num_box span {
  padding: 0.2rem;
  font-size: 2.8rem;
  font-family: "corporate-logo-ver2", sans-serif;
  color: #0051E0;
}
.event ul li figure {
  margin: 0 auto 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .event ul li figure {
    margin: 0 auto 30px;
  }
}
.event ul li figure img {
  border-radius: 20px;
  border: solid 6px #F8E93F;
}
@media screen and (min-width: 769px) {
  .event ul li figure img {
    border: solid 6px #F8E93F;
  }
}
.event ul li figure.no_border {
  padding: 8vw;
}
@media screen and (min-width: 769px) {
  .event ul li figure.no_border {
    padding: 50px;
  }
}
.event ul li figure.no_border img {
  border-radius: 20px;
  border: none;
}
@media screen and (min-width: 769px) {
  .event ul li figure.no_border img {
    border: none;
  }
}
.event ul li figure.no_border_2 {
  padding: 8vw 0;
}
@media screen and (min-width: 769px) {
  .event ul li figure.no_border_2 {
    padding: 50px 0;
  }
}
.event ul li figure.no_border_2 img {
  border-radius: 20px;
  border: none;
}
@media screen and (min-width: 769px) {
  .event ul li figure.no_border_2 img {
    border: none;
  }
}
.event ul li figure.bg_dot {
  margin: 8vw 0;
  background: url(../images/bg_dot.jpg);
  border-radius: 20px;
}
@media screen and (min-width: 769px) {
  .event ul li figure.bg_dot {
    margin: 50px 0;
  }
}
.event ul li h3 {
  margin: 0 auto 2.6666666667vw;
  font-size: 5.8666666667vw;
  color: #F8E93F;
  text-align: center;
  line-height: 1.5em;
}
@media screen and (min-width: 769px) {
  .event ul li h3 {
    margin: 0 auto 20px;
    font-size: 3.2rem;
  }
}
.event ul li h3 span {
  font-size: 4.2666666667vw;
}
@media screen and (min-width: 769px) {
  .event ul li h3 span {
    font-size: 2rem;
  }
}
.event ul li p {
  font-size: 2.9333333333vw;
  line-height: 1.8em;
}
@media screen and (min-width: 769px) {
  .event ul li p {
    font-size: 1.6rem;
  }
}
.event ul li p.lead {
  text-align: center;
  font-size: 3.7333333333vw;
  line-height: 1.8em;
}
@media screen and (min-width: 769px) {
  .event ul li p.lead {
    font-size: 2.2rem;
  }
}
.event ul li h4 {
  margin: 5.3333333333vw 0 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .event ul li h4 {
    margin: 30px 0 10px;
  }
}
.event ul li.event_1 .youtube {
  margin: 8vw 0 8vw;
  padding-top: 56.25%;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .youtube {
    margin: 50px 0 50px;
  }
}
.event ul li.event_1 .youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.event ul li.event_1 .box {
  margin: 8vw 0;
  padding: 2.6666666667vw 4vw 4vw;
  border: dotted 1px;
  font-size: 3.7333333333vw;
  text-align: center;
  border-radius: 20px;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box {
    margin: 50px 0;
    padding: 20px;
    font-size: 1.4rem;
  }
}
.event ul li.event_1 .box .date {
  margin-bottom: 5.3333333333vw;
  font-size: 4.8vw;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .date {
    margin-bottom: 30px;
    font-size: 3.2rem;
  }
}
.event ul li.event_1 .box .time {
  margin: 0 auto 5.3333333333vw;
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .time {
    margin: 0 auto 20px;
  }
}
.event ul li.event_1 .box .time div {
  width: 50%;
  margin: 0 1px;
  padding: 2.6666666667vw;
  line-height: 180%;
  background: #004ACC;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .time div {
    padding: 20px;
  }
}
.event ul li.event_1 .box .time div h5 {
  font-size: 3.7333333333vw;
  font-weight: bold;
  margin-bottom: 1.3333333333vw;
  line-height: 150%;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .time div h5 {
    font-size: 2rem;
    margin-bottom: 10px;
  }
}
.event ul li.event_1 .box .time div h5 span {
  font-size: 2.9333333333vw;
  display: block;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .time div h5 span {
    font-size: 1.6rem;
  }
}
.event ul li.event_1 .box .corse li {
  padding: 4vw;
  margin-bottom: 2px;
  background: #004ACC;
  text-align: left;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .corse li {
    padding: 20px;
  }
}
.event ul li.event_1 .box .corse li h5 {
  margin-bottom: 1.3333333333vw;
  line-height: 160%;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .corse li h5 {
    margin-bottom: 5px;
    font-size: 2rem;
  }
}
.event ul li.event_1 .box .corse li h5 span {
  font-size: 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .corse li h5 span {
    font-size: 1.2rem;
  }
}
.event ul li.event_1 .box .corse li p {
  font-size: 2.9333333333vw;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box .corse li p {
    font-size: 1.6rem;
  }
}
.event ul li.event_1 .box a.btn {
  padding: 4vw;
  display: block;
  background: #F8E93F;
  margin: 8vw 0 5.3333333333vw;
  font-size: 3.7333333333vw;
  color: #004ACC;
  text-decoration: none;
  border-radius: 50px;
  font-family: "corporate-logo-ver2", sans-serif;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .box a.btn {
    padding: 20px;
    margin: 40px 0;
    font-size: 2.4rem;
  }
}
.event ul li.event_1 .more {
  margin: 0 auto;
  padding: 0;
}
.event ul li.event_1 .more__content {
  position: relative;
  height: auto;
  max-height: 250px;
  overflow: hidden;
  transition: max-height 1s;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .more__content {
    max-height: 350px;
  }
}
.event ul li.event_1 .more__content::after {
  content: "";
  position: absolute;
  top: 150px;
  left: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  transition: 1s;
  background: linear-gradient(to bottom, transparent 0%, #0051E0 30%);
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .more__content::after {
    top: 200px;
  }
}
.event ul li.event_1 .more__content.open:after {
  z-index: -1;
  opacity: 0;
}
.event ul li.event_1 .more__btn {
  width: 100%;
  padding: 4vw;
  margin-top: 0;
  font-size: 3.7333333333vw;
  border: solid 2px #fff;
  background: #0051E0;
  color: #fff;
  display: block;
  font-family: "corporate-logo-ver2", sans-serif;
  border-radius: 50px;
  text-align: center;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  .event ul li.event_1 .more__btn {
    padding: 20px;
    font-size: 2.4rem;
  }
}
.event ul li.event_2 .box {
  margin: 5.3333333333vw 0;
  border: dotted 1px;
  padding: 2.6666666667vw 4vw 4vw;
  text-align: center;
  border-radius: 20px;
}
@media screen and (min-width: 769px) {
  .event ul li.event_2 .box {
    margin: 30px 0;
    padding: 20px;
  }
}
.event ul li.event_2 .box h4 {
  font-size: 2.9333333333vw;
}
@media screen and (min-width: 769px) {
  .event ul li.event_2 .box h4 {
    font-size: 14px;
  }
}
.event ul li.event_2 .box p {
  font-size: 4.2666666667vw;
  margin-bottom: 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .event ul li.event_2 .box p {
    font-size: 20px;
    margin-bottom: 20px;
  }
}
.event ul li.event_2 .box p a {
  color: #fff;
  text-decoration: underline;
}
.event ul li.event_2 .box p span {
  font-size: 3.2vw;
}
@media screen and (min-width: 769px) {
  .event ul li.event_2 .box p span {
    font-size: 14px;
  }
}

/*-------------------------------
instagram
--------------------------------- */
.instagram {
  width: 80%;
  margin: 26.6666666667vw auto 0;
  padding: 0;
}
@media screen and (min-width: 769px) {
  .instagram {
    margin: 160px auto 0;
  }
}
.instagram .LeeepMobCol3 .LeeepListScrollInner {
  grid-template-columns: repeat(3, 33.333%);
  -moz-column-gap: 0;
       column-gap: 0;
  margin-bottom: 0;
  row-gap: 0 !important;
}
.instagram a.instagram_all {
  width: 100%;
  margin: 5.3333333333vw auto 0;
  padding: 4vw;
  background: #F8E93F;
  color: #0051E0;
  display: block;
  font-family: "corporate-logo-ver2", sans-serif;
  border-radius: 50px;
  font-size: 3.7333333333vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .instagram a.instagram_all {
    width: 50%;
    margin: 40px auto 0;
    padding: 15px;
    font-size: 2.4rem;
  }
}

/*-----------------------------
 information
------------------------------------ */
.information {
  width: 80%;
  margin: 26.6666666667vw auto 0;
  padding: 13.3333333333vw 0;
  background: #fff;
  background: url(../images/bg_dot.jpg);
  color: #0051E0;
  border-radius: 20px;
}
@media screen and (min-width: 769px) {
  .information {
    margin: 160px auto 0;
    padding: 80px 0;
  }
}
.information h2 {
  font-size: 9.6vw;
}
@media screen and (min-width: 769px) {
  .information h2 {
    font-size: 4.6rem;
  }
}
.information .information_box {
  width: 80%;
  max-width: 1000px;
  margin: 0 auto;
}
.information .information_box h3 {
  margin: 13.3333333333vw auto 5.3333333333vw;
  padding: 2.6666666667vw;
  font-size: 4.2666666667vw;
  background: #0051E0;
  color: #fff;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .information .information_box h3 {
    margin: 50px auto 20px;
    padding: 10px;
    font-size: 2.2rem;
  }
}
.information .information_box p {
  padding: 0;
  margin-bottom: 4vw;
  font-size: 2.9333333333vw;
  line-height: 1.8em;
  text-align: left;
}
@media screen and (min-width: 769px) {
  .information .information_box p {
    margin-bottom: 15px;
    font-size: 1.6rem;
  }
}
.information .information_box p::before {
  content: "※";
}
.information .information_box p span {
  color: #E83921;
}
.information .information_box p a {
  width: 90%;
  margin: 10px auto 30px;
  padding: 8px 20px 6px 30px;
  font-size: 3.2vw;
  font-weight: 500;
  color: #0051E0;
  display: block;
  text-align: center;
  border: solid 1px #0051E0;
  border-radius: 50px;
  background: #fff;
}
@media screen and (min-width: 769px) {
  .information .information_box p a {
    padding: 10px 20px 10px 30px;
    font-size: 1.8rem;
  }
}

/*---------------------------------------------------------------
footer
-------------------------------------------------------------- */
footer {
  width: 100%;
  margin: 13.3333333333vw auto;
  padding: 0 3.4666666667vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  footer {
    margin: 50px auto;
    padding: 0 13px;
  }
}
footer .copy {
  margin: 0 auto 26.6666666667vw;
}
@media screen and (min-width: 769px) {
  footer .copy {
    margin: 0 auto 100px;
  }
}
footer .copy .f_logo_2 {
  margin: 0 auto 5.3333333333vw;
  width: 40%;
  max-width: 150px;
}
@media screen and (min-width: 769px) {
  footer .copy .f_logo_2 {
    margin: 0 auto 20px;
  }
}
footer .copy .f_logo_2 a {
  margin: 0 auto;
  padding: 0;
  display: block;
}
footer .copy .f_logo_2 a img {
  vertical-align: bottom;
}
footer .copy small {
  text-align: center;
  font-size: 1rem;
  letter-spacing: 1px;
  color: #fff;
}
footer .f_logo {
  margin: 0 auto;
  width: 40%;
  max-width: 150px;
}
footer .f_logo a {
  margin: 0 auto;
  padding: 0;
  display: block;
}
footer .f_logo a img {
  vertical-align: bottom;
}
footer .f_icon {
  margin: 30px auto 10px;
  padding: 0;
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
footer .f_icon li {
  width: 50px;
  margin: 0 15px;
  padding: 0;
}
footer .f_icon li i {
  margin: 0;
  font-size: 4.2rem;
  color: #fff;
}
footer small {
  text-align: center;
  font-size: 1rem;
  letter-spacing: 1px;
  color: #fff;
}

/*------------------------------
animation
-------------------------------*/
.invisible {
  transition: opacity 0.5s ease;
  opacity: 0;
}

.visible {
  transition: opacity 0.5s ease;
  opacity: 1;
}
@keyframes bgAnimTop {
  0% {
    background-position: 0px 0px;
  }
  100% {
    background-position: 0px 1200px;
  }
}
@keyframes bgAnimBottom {
  0% {
    background-position: 0px 1200px;
  }
  100% {
    background-position: 0px 0px;
  }
}
@keyframes bgAnimLeft {
  0% {
    background-position: 0px 0px;
  }
  100% {
    background-position: 1200px 0px;
  }
}/*# sourceMappingURL=style.css.map */