@charset "UTF-8";
@-webkit-keyframes bound {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0;
  }
  8% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
    opacity: 1;
  }
  17% {
    -webkit-transform: scale(1.332);
            transform: scale(1.332);
    opacity: 1;
  }
  34% {
    scale: 1;
    opacity: 1;
  }
  51% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
    opacity: 1;
  }
  68% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  84% {
    -webkit-transform: scale(1.03525);
            transform: scale(1.03525);
    opacity: 1;
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@keyframes bound {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0;
  }
  8% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
    opacity: 1;
  }
  17% {
    -webkit-transform: scale(1.332);
            transform: scale(1.332);
    opacity: 1;
  }
  34% {
    scale: 1;
    opacity: 1;
  }
  51% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
    opacity: 1;
  }
  68% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  84% {
    -webkit-transform: scale(1.03525);
            transform: scale(1.03525);
    opacity: 1;
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@-webkit-keyframes pop {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
  }
  5% {
    opacity: 0.3;
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@keyframes pop {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
  }
  5% {
    opacity: 0.3;
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@-webkit-keyframes pop_sp {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.5);
            transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@keyframes pop_sp {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.5);
            transform: scale(1.5);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@-webkit-keyframes pop_02 {
  0% {
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
    opacity: 0;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@keyframes pop_02 {
  0% {
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
    opacity: 0;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@-webkit-keyframes text_anime_left {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -1000% 0;
  }
}
@keyframes text_anime_left {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -1000% 0;
  }
}
@-webkit-keyframes text_anime_right {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 1000% 0;
  }
}
@keyframes text_anime_right {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 1000% 0;
  }
}
:where(button, [type=button], [type=reset], [type=submit]) {
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}

/* -----------------------------
common reset
------------------------------*/
html {
  -ms-scroll-chaining: none;
      overscroll-behavior: none;
}

html, body, h1, h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, table, caption, th, td, img, form {
  margin: 0;
  padding: 0;
  border: none;
  font-style: normal;
  font-weight: normal;
  font-size: 62.5%;
  list-style-type: none;
}

body {
  font-size: 16px;
  font-weight: normal;
  font-family: "M PLUS 1", sans-serif;
  color: #000;
  line-height: 1.7;
  overflow-x: hidden;
  text-align: center;
  -webkit-text-size-adjust: 100%;
}

main {
  overflow-x: hidden;
}

img {
  vertical-align: bottom;
}

a img {
  border: none;
}

a:hover img {
  border: none;
}

a {
  color: #000;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

a:link {
  text-decoration: none;
}

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

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

ul, ol, dl {
  list-style-position: outside;
}

li, dt, dd {
  font-size: 16px;
}

button {
  background: none;
  margin: 0;
  padding: 0;
  border: none;
}

*, *:before, *:after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

@media only screen and (max-width: 768px) {
  li, dt, dd {
    font-size: inherit;
  }
}
em {
  font-style: normal;
}

/*------------------------------
module
------------------------------*/
.clearFix:after {
  content: "";
  display: block;
  clear: both;
}

.clearFix {
  zoom: 1;
}

.textL {
  text-align: left;
}

.textC {
  text-align: center;
}

.textR {
  text-align: right;
}

.ps_ab {
  position: absolute;
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

/* -----------------------------
layout
------------------------------*/
img {
  max-width: 100%;
  width: 100%;
}

.sp {
  display: none;
}

.pc {
  display: block;
}

.sp-inline {
  display: none !important;
}

.pc-inline {
  display: inline-block !important;
}

ul.inline li {
  display: inline-block;
  vertical-align: top;
}

body {
  background: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0 auto;
}

@media only screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  .sp-inline {
    display: inline-block !important;
  }
  .pc-inline {
    display: none !important;
  }
  body {
    min-width: 100%;
    width: 100%;
  }
}
section .inner {
  max-width: 1060px;
  padding: 0 min(2.93vw, 30px);
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  section .inner {
    width: 100%;
    padding: 0 7.692vw;
  }
}

.btn_style-01_wrap {
  width: min(58.594vw, 600px);
  height: min(8.008vw, 82px);
}
@media only screen and (max-width: 768px) {
  .btn_style-01_wrap {
    width: 100%;
    height: 21.026vw;
  }
}

.btn_style-01 {
  width: 100%;
  height: 100%;
  display: block;
  position: relative;
  background: #fff;
  border: solid 2px #000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: bold;
  -webkit-box-shadow: 4px 4px 0px 0 #000;
          box-shadow: 4px 4px 0px 0 #000;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  padding-left: min(6.348vw, 65px);
}
@media only screen and (max-width: 768px) {
  .btn_style-01 {
    font-size: 4.103vw;
    line-height: 1.3;
    letter-spacing: 0.1rem;
    padding-left: 7.692vw;
  }
}
.btn_style-01:hover {
  opacity: 1;
  cursor: pointer;
  -webkit-transform: translateY(0.3rem);
          transform: translateY(0.3rem);
  -webkit-box-shadow: 0 0 0 0;
          box-shadow: 0 0 0 0;
}
.btn_style-01::before {
  position: absolute;
  display: inline-block;
  content: "";
  background: url(../img/icon_arrow.svg) no-repeat center;
  background-size: contain;
  width: min(1.27vw, 13px);
  height: min(1.953vw, 20px);
  right: min(3.906vw, 40px);
  top: 0;
  bottom: 0;
  margin: auto 0;
}
@media only screen and (max-width: 768px) {
  .btn_style-01::before {
    width: 2.564vw;
    height: 4.103vw;
    right: 7.692vw;
  }
}
.btn_style-01::after {
  position: absolute;
  display: inline-block;
  content: "";
  background: url(../img/share_icon_x.svg) no-repeat center;
  background-size: contain;
  width: min(4.883vw, 50px);
  height: min(4.883vw, 50px);
  left: min(13.184vw, 135px);
  top: 0;
  bottom: 0;
  margin: auto 0;
}
@media only screen and (max-width: 768px) {
  .btn_style-01::after {
    width: 12.821vw;
    height: 12.821vw;
    left: 5.128vw;
  }
}
.btn_style-01 strong {
  font-size: min(2.148vw, 22px);
  font-weight: 700;
  margin-right: 3px;
}
@media only screen and (max-width: 768px) {
  .btn_style-01 strong {
    font-size: 5.641vw;
    font-weight: 800;
    margin-right: 1vw;
  }
}

.btn_style-02 {
  width: 100%;
  height: 100%;
  display: block;
  position: relative;
  background: #fff;
  border: solid 2px #000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: bold;
  -webkit-box-shadow: 4px 4px 0px 0 #000;
          box-shadow: 4px 4px 0px 0 #000;
  font-size: min(1.953vw, 20px);
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
@media only screen and (max-width: 768px) {
  .btn_style-02 {
    font-size: 5.128vw;
    line-height: 1.3;
    letter-spacing: 0.1rem;
  }
}
.btn_style-02:hover {
  opacity: 1;
  cursor: pointer;
  -webkit-transform: translateY(0.3rem);
          transform: translateY(0.3rem);
  -webkit-box-shadow: 0 0 0 0;
          box-shadow: 0 0 0 0;
}
.btn_style-02::before {
  position: absolute;
  display: inline-block;
  content: "";
  background: url(../img/icon_arrow02.svg) no-repeat center;
  background-size: contain;
  width: min(0.977vw, 10px);
  height: min(1.27vw, 13px);
  right: min(3.906vw, 40px);
  top: 0;
  bottom: 0;
  margin: auto 0;
}
@media only screen and (max-width: 768px) {
  .btn_style-02::before {
    width: 2.564vw;
    height: 4.103vw;
    right: 7.692vw;
  }
}
.btn_style-02 strong {
  font-size: min(2.148vw, 22px);
  font-weight: 700;
}
@media only screen and (max-width: 768px) {
  .btn_style-02 strong {
    font-size: 5.641vw;
    font-weight: 800;
  }
}
.btn_style-02_wrap_green a {
  font-size: min(1.367vw, 14px);
  -webkit-box-shadow: 4px 4px 0px 0 #00B68D;
          box-shadow: 4px 4px 0px 0 #00B68D;
  border: solid 2px #00B68D;
  color: #008978;
}
@media only screen and (max-width: 768px) {
  .btn_style-02_wrap_green a {
    font-size: 3.59vw;
  }
}
.btn_style-02_wrap_green a:hover {
  -webkit-box-shadow: 0 0 0 0;
          box-shadow: 0 0 0 0;
}
.btn_style-02_wrap_green a::before {
  width: min(0.781vw, 8px);
  right: min(1.465vw, 15px);
  background: url(../img/premium_stage/icon_arrow02_green.svg) no-repeat center;
  background-size: contain;
}
@media only screen and (max-width: 768px) {
  .btn_style-02_wrap_green a::before {
    width: 1.795vw;
    height: 2.564vw;
    right: 3.846vw;
  }
}

.wrapper {
  position: relative;
}
.wrapper:not(#top) main .content {
  padding: min(11.719vw, 120px) 0 0;
}
@media only screen and (max-width: 768px) {
  .wrapper:not(#top) main .content {
    padding-top: 15.385vw;
  }
}

/* -----------------------------
テキストアニメーション
------------------------------*/
.text_anime {
  position: relative;
  z-index: 1;
}
.text_anime.z0 {
  z-index: 3;
}
@media only screen and (max-width: 768px) {
  .text_anime.z0 {
    z-index: 2;
  }
}
.text_anime.z10 {
  z-index: 10;
}
.text_anime .text_anime_item.red {
  position: relative;
  z-index: 5;
  width: 100%;
  height: min(2.93vw, 30px);
  background: #EB1E00;
}
.text_anime .text_anime_item.red .text_anime_item_img {
  -webkit-animation: text_anime_left 1000s linear infinite;
          animation: text_anime_left 1000s linear infinite;
}
@media only screen and (max-width: 768px) {
  .text_anime .text_anime_item.red .text_anime_item_img {
    -webkit-animation: text_anime_left 300s linear infinite;
            animation: text_anime_left 300s linear infinite;
  }
}
@media only screen and (max-width: 768px) {
  .text_anime .text_anime_item.red {
    height: 7.692vw;
  }
}
.text_anime .text_anime_item.gr {
  position: absolute;
  left: 0;
  width: 100%;
  height: min(2.93vw, 30px);
  background: #00B68D;
}
.text_anime .text_anime_item.gr .text_anime_item_img {
  -webkit-animation: text_anime_right 1000s linear infinite;
          animation: text_anime_right 1000s linear infinite;
}
@media only screen and (max-width: 768px) {
  .text_anime .text_anime_item.gr .text_anime_item_img {
    -webkit-animation: text_anime_right 300s linear infinite;
            animation: text_anime_right 300s linear infinite;
  }
}
@media only screen and (max-width: 768px) {
  .text_anime .text_anime_item.gr {
    height: 7.692vw;
    z-index: 5;
  }
}
.text_anime .text_anime_item.gr.g01 {
  -webkit-transform: rotate(-2deg);
          transform: rotate(-2deg);
  bottom: -28px;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  .text_anime .text_anime_item.gr.g01 {
    bottom: -8.462vw;
  }
}
.text_anime .text_anime_item.gr.g02 {
  -webkit-transform: rotate(2deg);
          transform: rotate(2deg);
  bottom: 28px;
}
@media only screen and (max-width: 768px) {
  .text_anime .text_anime_item.gr.g02 {
    bottom: 8.462vw;
  }
}
.text_anime .text_anime_item_img {
  width: 100%;
  height: 100%;
  background: url(../img/anime-matsuri_text.png) repeat-x left -9vw center;
  background-size: 150px auto;
}
@media only screen and (max-width: 768px) {
  .text_anime .text_anime_item_img {
    background-size: 37.179vw auto;
  }
}

#pagetop {
  position: fixed;
  right: min(2.93vw, 30px);
  bottom: min(2.93vw, 30px);
  z-index: 10;
  opacity: 0;
  -webkit-transition: 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  transition: 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}
#pagetop.active {
  opacity: 1;
  pointer-events: auto;
}
@media only screen and (max-width: 768px) {
  #pagetop {
    right: 2.564vw;
    bottom: 5.128vw;
  }
}
#pagetop a {
  display: block;
  width: min(7.813vw, 80px);
  height: min(7.813vw, 80px);
  -webkit-transition: 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  transition: 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
@media only screen and (max-width: 768px) {
  #pagetop a {
    width: 17.949vw;
    height: 17.949vw;
  }
}
#pagetop a:hover {
  opacity: 1;
  -webkit-transform: translateY(-7px);
          transform: translateY(-7px);
}
@media only screen and (max-width: 768px) {
  #pagetop a:hover {
    -webkit-transform: none;
            transform: none;
  }
}

/* -----------------------------
header
------------------------------*/
.header {
  position: fixed;
  display: block;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 9999;
}
.header_inner {
  position: relative;
  z-index: 1;
  background: #EB1E00;
  padding-left: min(2.93vw, 30px);
}
@media only screen and (max-width: 768px) {
  .header_inner {
    padding: 0 5.128vw;
  }
}
.header_inner > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: min(6.836vw, 70px);
}
@media only screen and (max-width: 768px) {
  .header_inner > div {
    height: 15.385vw;
  }
}
.header_logo {
  width: min(13.184vw, 135px);
}
@media screen and (max-width: 1250px) {
  .header_logo {
    width: min(11.719vw, 120px);
  }
}
@media only screen and (max-width: 768px) {
  .header_logo {
    width: 23.59vw;
  }
}
.header_link_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
}
.header_list {
  position: relative;
  height: 100%;
  padding-right: min(1.953vw, 20px);
}
@media only screen and (max-width: 768px) {
  .header_list {
    display: none;
  }
}
.header_list::before {
  position: absolute;
  content: "";
  width: 2px;
  height: 100%;
  right: 0;
  top: 0;
  background: #fff;
}
.header_list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 0 min(2.441vw, 25px);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
}
@media screen and (max-width: 1250px) {
  .header_list ul {
    gap: 0 min(1.465vw, 15px);
  }
}
.header_list ul li.current {
  border-bottom: solid 2px #fff;
}
@media screen and (max-width: 1250px) {
  .header_list ul li.x {
    width: min(3.418vw, 35px);
  }
}
.header_list ul a {
  font-size: min(1.563vw, 16px);
  font-weight: 600;
  color: #fff;
}
@media screen and (max-width: 1250px) {
  .header_list ul a {
    font-size: min(1.367vw, 14px);
  }
}
.header_hamburger {
  padding: 0 min(1.465vw, 15px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media only screen and (max-width: 768px) {
  .header_hamburger {
    padding: 0;
  }
}
.header_hamburger_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: min(0.781vw, 8px) 0;
}
@media only screen and (max-width: 768px) {
  .header_hamburger_inner {
    gap: 1.538vw 0;
  }
}
.header_hamburger:hover {
  cursor: pointer;
}
.header_hamburger_block {
  position: relative;
  width: min(2.93vw, 30px);
  height: min(1.953vw, 20px);
  text-align: center;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .header_hamburger_block {
    width: 7.692vw;
    height: 5.128vw;
  }
}
.header_hamburger-span {
  position: absolute;
  display: inline-block;
  width: 100%;
  height: min(0.195vw, 2px);
  background: #fff;
  left: 0;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
@media only screen and (max-width: 768px) {
  .header_hamburger-span {
    height: 0.513vw;
  }
}
.header_hamburger-span:first-of-type {
  top: 0;
}
.header_hamburger-span:nth-of-type(2) {
  opacity: 1;
  top: 0;
  bottom: 0;
  margin: auto 0;
}
.header_hamburger-span:last-of-type {
  bottom: 0;
}
.header_hamburger_text {
  font-size: min(1.172vw, 12px);
  text-align: center;
  font-weight: 700;
  line-height: 1;
  color: #fff;
}
@media only screen and (max-width: 768px) {
  .header_hamburger_text {
    font-size: 2.564vw;
  }
}
.header_hamburger.active .header_hamburger-span:first-of-type {
  top: min(0.977vw, 10px);
  -webkit-transform: rotate(40deg);
          transform: rotate(40deg);
}
@media only screen and (max-width: 768px) {
  .header_hamburger.active .header_hamburger-span:first-of-type {
    top: 2.564vw;
  }
}
.header_hamburger.active .header_hamburger-span:nth-of-type(2) {
  opacity: 0;
}
.header_hamburger.active .header_hamburger-span:last-of-type {
  bottom: min(0.781vw, 8px);
  -webkit-transform: rotate(-40deg);
          transform: rotate(-40deg);
}
@media only screen and (max-width: 768px) {
  .header_hamburger.active .header_hamburger-span:last-of-type {
    bottom: 2.051vw;
  }
}
.header .header_menu {
  width: 100%;
  height: 0;
  visibility: hidden;
}
@media only screen and (max-width: 768px) {
  .header .header_menu {
    overflow-x: hidden;
    position: fixed;
    background: #F7F0D8;
  }
}
.header .header_menu.open {
  visibility: visible;
  height: 100vh;
}
@media only screen and (max-width: 768px) {
  .header .header_menu.open {
    -ms-scroll-chaining: none;
        overscroll-behavior: none;
    height: calc(100% - 15.385vw);
  }
}
.header .header_menu.open .header_menu_overlay {
  display: block;
}
@media only screen and (max-width: 768px) {
  .header .header_menu.open .header_menu_overlay {
    display: none;
  }
}
.header .header_menu.open .header_menu_inner {
  -webkit-transform: translateX(0%);
          transform: translateX(0%);
}
.header .header_menu.open.h750 {
  overflow-y: auto;
}
.header .header_menu_overlay {
  position: absolute;
  left: 0;
  top: 0;
  z-index: -11;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.7);
  display: none;
}
.header .header_menu_inner {
  position: relative;
  width: min(36.133vw, 370px);
  min-height: min(73.242vw, 750px);
  height: 100vh;
  margin: 0 0 0 auto;
  background: #F7F0D8;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: all 0.25s ease;
  transition: all 0.25s ease;
}
@media only screen and (max-width: 768px) {
  .header .header_menu_inner {
    width: 100%;
    height: auto;
    min-height: 100dvh;
    background: url(../img/header_illust04.png) no-repeat center bottom, #F7F0D8;
    background-size: contain;
  }
}
.header .header_menu_inner::before {
  position: absolute;
  display: inline-block;
  content: "";
  width: min(4.785vw, 49px);
  height: min(9.473vw, 97px);
  left: min(2.441vw, 25px);
  top: -10px;
  background: url(../img/header_illust01.png) no-repeat center;
  background-size: contain;
}
@media only screen and (max-width: 768px) {
  .header .header_menu_inner::before {
    width: 12.564vw;
    height: 24.872vw;
    left: 6.41vw;
    top: 0;
  }
}
.header .header_menu_inner::after {
  position: absolute;
  display: inline-block;
  content: "";
  width: min(7.031vw, 72px);
  height: min(7.227vw, 74px);
  right: min(2.441vw, 25px);
  top: -10px;
  background: url(../img/header_illust02.png) no-repeat center;
  background-size: contain;
}
@media only screen and (max-width: 768px) {
  .header .header_menu_inner::after {
    width: 18.462vw;
    height: 18.974vw;
    top: 0;
    right: 6.41vw;
  }
}
.header .header_menu_inner_bg {
  width: 100%;
  height: 100%;
  padding: min(3.418vw, 35px) min(6.348vw, 65px) min(17.578vw, 180px);
  background: url(../img/header_illust03.png) no-repeat center top;
  background-size: contain;
}
@media only screen and (max-width: 768px) {
  .header .header_menu_inner_bg {
    position: relative;
    height: initial;
    padding: 8.974vw 6.41vw 41.026vw;
  }
}
.header .header_menu_inner_bg::after {
  position: absolute;
  display: inline-block;
  content: "";
  width: 100%;
  height: min(28.906vw, 296px);
  left: min(0vw, 0px);
  bottom: 0;
  background: url(../img/header_illust04.png) no-repeat center bottom min(6.836vw, 70px);
  background-size: contain;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .header .header_menu_inner_bg::after {
    display: none;
  }
}
.header .header_menu_list_logo {
  width: min(17.578vw, 180px);
  margin: 0 auto min(2.93vw, 30px);
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list_logo {
    width: 46.154vw;
    margin-bottom: 7.692vw;
  }
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list .btn_style-01_wrap {
    height: auto;
  }
}
.header .header_menu_list .btn_style-01 {
  width: min(23.438vw, 240px);
  height: min(6.348vw, 65px);
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list .btn_style-01 {
    width: 100%;
    height: 16.667vw;
  }
}
.header .header_menu_list .btn_style-01 {
  padding-left: min(2.441vw, 25px);
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list .btn_style-01 {
    padding-left: 7vw;
  }
}
.header .header_menu_list .btn_style-01 strong {
  font-size: min(1.563vw, 16px);
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list .btn_style-01 strong {
    font-size: 4.615vw;
    margin-right: 0;
  }
}
.header .header_menu_list .btn_style-01::before {
  width: min(1.172vw, 12px);
  height: min(1.66vw, 17px);
  right: min(1.953vw, 20px);
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list .btn_style-01::before {
    width: 2.564vw;
    height: 3.846vw;
    right: 6.41vw;
  }
}
.header .header_menu_list .btn_style-01::after {
  width: min(3.906vw, 40px);
  height: min(3.906vw, 40px);
  left: min(1.953vw, 20px);
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list .btn_style-01::after {
    width: 10.256vw;
    height: 10.256vw;
    left: 15.385vw;
  }
}
.header .header_menu_list ul {
  position: relative;
  margin-bottom: min(2.93vw, 30px);
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list ul {
    margin-bottom: 7.692vw;
  }
}
.header .header_menu_list ul::after {
  position: absolute;
  display: inline-block;
  content: "";
  width: min(3.32vw, 34px);
  height: min(11.426vw, 117px);
  right: min(-2.93vw, -30px);
  top: 0;
  background: url(../img/header_kira01.png) no-repeat center;
  background-size: contain;
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list ul::after {
    width: 8.718vw;
    height: 30vw;
    right: 0vw;
  }
}
.header .header_menu_list ul::before {
  position: absolute;
  display: inline-block;
  content: "";
  width: min(3.32vw, 34px);
  height: min(4.98vw, 51px);
  left: min(-2.93vw, -30px);
  bottom: min(7.813vw, 80px);
  background: url(../img/header_kira02.png) no-repeat center;
  background-size: contain;
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list ul::before {
    width: 8.718vw;
    height: 12.821vw;
    bottom: 30vw;
    left: 2.564vw;
  }
}
.header .header_menu_list ul li:hover {
  opacity: 0.7;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}
.header .header_menu_list ul li:not(:last-of-type) {
  margin-bottom: min(1.953vw, 20px);
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list ul li:not(:last-of-type) {
    margin-bottom: 5.128vw;
  }
}
.header .header_menu_list ul li a {
  font-size: min(1.563vw, 16px);
  font-weight: 700;
}
@media only screen and (max-width: 768px) {
  .header .header_menu_list ul li a {
    font-size: 4.615vw;
  }
}
.header .header_menu_list ul li.current a {
  color: #EB1E00;
}

/* -----------------------------
Xシェア
------------------------------*/
.share {
  position: relative;
  padding: min(12.695vw, 130px) 0 min(9.766vw, 100px);
  background: #F7F0D8;
}
@media only screen and (max-width: 768px) {
  .share {
    padding: 41.026vw 0 15.385vw;
  }
}
.share .inner {
  position: relative;
  z-index: 1;
}
.share .inner::before {
  position: absolute;
  display: inline-block;
  content: "";
  width: min(63.477vw, 650px);
  height: min(10.449vw, 107px);
  left: -40%;
  top: -50px;
  background: url(../img/share_chouchin01.png) no-repeat center;
  background-size: contain;
  z-index: -1;
}
@media screen and (max-width: 1440px) {
  .share .inner::before {
    left: -37%;
  }
}
@media only screen and (max-width: 768px) {
  .share .inner::before {
    width: 41.026vw;
    height: 18.718vw;
    left: 0;
    top: -28.205vw;
    background: url(../img/share_chouchin01_sp.png) no-repeat center;
    background-size: contain;
  }
}
.share .inner::after {
  position: absolute;
  display: inline-block;
  content: "";
  width: min(63.477vw, 650px);
  height: min(10.449vw, 107px);
  right: -40%;
  top: -50px;
  background: url(../img/share_chouchin02.png) no-repeat center;
  background-size: contain;
  z-index: -1;
}
@media screen and (max-width: 1440px) {
  .share .inner::after {
    right: -37%;
  }
}
@media only screen and (max-width: 768px) {
  .share .inner::after {
    width: 41.026vw;
    height: 18.718vw;
    right: 0;
    top: -28.205vw;
    background: url(../img/share_chouchin02_sp.png) no-repeat center;
    background-size: contain;
  }
}
.share_ttl {
  width: min(39.063vw, 400px);
  margin: 0 auto min(1.953vw, 20px);
}
@media only screen and (max-width: 768px) {
  .share_ttl {
    width: 100%;
    margin-bottom: 5.128vw;
  }
}
.share .btn_style-01_wrap {
  margin: 0 auto;
}

/* -----------------------------
footer
------------------------------*/
.footer {
  overflow: hidden;
  padding: min(5.859vw, 60px) 0;
  background: #00B68D;
}
.footer a {
  display: inline-block;
}
@media only screen and (max-width: 768px) {
  .footer {
    padding: 10.256vw 0 17.949vw;
    background: url(../img/footer_cloud_sp.png) no-repeat center bottom, #00B68D;
    background-size: contain, auto;
  }
}
.footer .inner {
  position: relative;
  max-width: 1060px;
  margin: 0 auto;
  padding: 0 min(2.93vw, 30px);
}
@media only screen and (max-width: 768px) {
  .footer .inner {
    max-width: 100%;
    padding: 0 6.41vw;
  }
}
.footer .inner::before {
  position: absolute;
  display: inline-block;
  content: "";
  background: url(../img/footer_cloud01.png) no-repeat center;
  background-size: contain;
  width: min(33.887vw, 347px);
  height: min(11.328vw, 116px);
  left: -16%;
  top: -10px;
  z-index: 0;
  pointer-events: none;
}
@media screen and (max-width: 1440px) {
  .footer .inner::before {
    left: -22%;
  }
}
@media only screen and (max-width: 768px) {
  .footer .inner::before {
    display: none;
  }
}
.footer .inner::after {
  position: absolute;
  display: inline-block;
  content: "";
  background: url(../img/footer_cloud02.png) no-repeat center;
  background-size: contain;
  width: min(33.887vw, 347px);
  height: min(11.328vw, 116px);
  right: -16%;
  bottom: -60px;
  z-index: 0;
  pointer-events: none;
}
@media screen and (max-width: 1440px) {
  .footer .inner::after {
    right: -22%;
  }
}
@media only screen and (max-width: 768px) {
  .footer .inner::after {
    display: none;
  }
}
.footer__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(8.789vw, 90px);
  margin-bottom: min(2.93vw, 30px);
}
@media only screen and (max-width: 768px) {
  .footer__top {
    display: block;
    margin-bottom: 10.256vw;
  }
}
.footer__top_logo {
  width: min(20.215vw, 207px);
}
@media only screen and (max-width: 768px) {
  .footer__top_logo {
    width: 34.872vw;
    margin: 0 auto 7.692vw;
  }
}
.footer__dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(2.93vw, 30px);
}
@media only screen and (max-width: 768px) {
  .footer__dl {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 0;
  }
}
.footer__dl > div {
  width: min(15.625vw, 160px);
}
@media only screen and (max-width: 768px) {
  .footer__dl > div {
    width: 41.026vw;
  }
}
.footer__link_block {
  margin-bottom: min(1.953vw, 20px);
}
@media only screen and (max-width: 768px) {
  .footer__link_block {
    margin-bottom: 2.564vw;
  }
}
.footer__link_block ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.footer__link_block ul li {
  padding: 0 min(1.953vw, 20px);
  line-height: 1;
}
@media only screen and (max-width: 768px) {
  .footer__link_block ul li {
    padding: 0 2vw;
  }
}
.footer__link_block ul li a {
  font-size: min(1.367vw, 14px);
  color: #fff;
}
@media only screen and (max-width: 768px) {
  .footer__link_block ul li a {
    font-size: 3.59vw;
  }
}
.footer__link_block ul li:first-child {
  border-right: solid 1px #fff;
}
.footer__copy {
  color: #fff;
  font-size: 1rem;
}

/* -----------------------------
下層ページ 共通背景
------------------------------*/
.kasou_chouchin_left {
  position: absolute;
  top: -200px;
  left: -50px;
  width: min(9.18vw, 94px);
}
@media screen and (max-width: 1440px) {
  .kasou_chouchin_left {
    left: 10px;
  }
}
@media screen and (max-width: 1000px) {
  .kasou_chouchin_left {
    top: min(-15.625vw, -160px);
  }
}
@media only screen and (max-width: 768px) {
  .kasou_chouchin_left {
    width: 10.769vw;
    left: 3.333vw;
    top: -23.077vw;
  }
}
.kasou_chouchin_right-01 {
  position: absolute;
  top: -160px;
  right: -60px;
  width: min(11.133vw, 114px);
}
@media screen and (max-width: 1440px) {
  .kasou_chouchin_right-01 {
    right: 70px;
  }
}
@media screen and (max-width: 1000px) {
  .kasou_chouchin_right-01 {
    top: min(-12.695vw, -130px);
  }
}
@media only screen and (max-width: 768px) {
  .kasou_chouchin_right-01 {
    width: 13.59vw;
    right: 6.41vw;
    top: -21.795vw;
  }
}
.kasou_chouchin_right-02 {
  position: absolute;
  top: -160px;
  right: -130px;
  width: min(8.398vw, 86px);
}
@media screen and (max-width: 1440px) {
  .kasou_chouchin_right-02 {
    right: 10px;
  }
}
@media screen and (max-width: 1000px) {
  .kasou_chouchin_right-02 {
    top: min(-11.719vw, -120px);
  }
}
@media only screen and (max-width: 768px) {
  .kasou_chouchin_right-02 {
    width: 10.769vw;
    right: -2.564vw;
    top: -21.795vw;
  }
}

.bg_cloud {
  position: relative;
}
.bg_cloud::before {
  position: absolute;
  display: inline-block;
  content: "";
  width: min(198.145vw, 2029px);
  height: min(32.813vw, 336px);
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  top: -187px;
  background: url(../img/kasou_ttl_cloud01.png) no-repeat center;
  background-size: contain;
  z-index: 0;
  pointer-events: none;
}
@media only screen and (max-width: 768px) {
  .bg_cloud::before {
    width: 100vw;
    height: 29.231vw;
    -webkit-transform: none;
            transform: none;
    left: -1vw;
    top: -16vw;
    background: url(../img/kasou_ttl_cloud01_sp.png) no-repeat center top;
    background-size: contain;
  }
}
.bg_cloud::after {
  width: 100%;
  height: 100%;
  position: absolute;
  display: inline-block;
  content: "";
  top: 10.5%;
  left: 0;
  right: 0;
  background: url(../img/lineup_cloud_bg.png) repeat-y center top;
  background-size: min(325.781vw, 3336px) auto;
  z-index: 0;
  pointer-events: none;
}
@media only screen and (max-width: 768px) {
  .bg_cloud::after {
    top: 12.7%;
    height: 100%;
    background: url(../img/lineup_cloud_bg_sp.png) repeat-y center top;
    background-size: 100vw auto;
  }
}

.aco_block {
  width: 100%;
  margin: 0 auto;
  border: solid 2px #00B68D;
  background: #fff;
  text-align: left;
}
.aco_block:not(:last-of-type) {
  margin-bottom: min(1.953vw, 20px);
}
@media only screen and (max-width: 768px) {
  .aco_block:not(:last-of-type) {
    margin-bottom: 3.846vw;
  }
}
.aco_block.active .aco_block_ttl_txt .icon::after {
  -webkit-transform: translate(-50%, -50%) rotate(-90deg);
          transform: translate(-50%, -50%) rotate(-90deg);
}
.aco_block_ttl {
  position: relative;
  gap: 0 min(3.418vw, 35px);
  padding: min(1.465vw, 15px) min(1.953vw, 20px);
  color: #fff;
  background: #00B68D;
}
.aco_block_ttl:hover {
  cursor: pointer;
}
@media only screen and (max-width: 768px) {
  .aco_block_ttl {
    display: block;
    padding: 5.128vw 17.949vw 5.128vw 5.128vw;
  }
}
.aco_block_ttl_txt p {
  font-size: min(1.563vw, 16px);
  text-align: center;
  color: #fff;
}
@media only screen and (max-width: 768px) {
  .aco_block_ttl_txt p {
    font-size: 4.103vw;
    text-align: right;
  }
}
.aco_block_ttl_txt .icon_wrap {
  position: absolute;
  width: min(2.148vw, 22px);
  height: min(2.148vw, 22px);
  right: min(2.93vw, 30px);
  top: 0;
  bottom: 0;
  margin: auto 0;
}
@media only screen and (max-width: 768px) {
  .aco_block_ttl_txt .icon_wrap {
    width: 5.641vw;
    height: 5.641vw;
    right: 5.128vw;
  }
}
.aco_block_ttl_txt .icon_wrap .icon {
  width: min(2.148vw, 22px);
  height: min(2.148vw, 22px);
  position: relative;
  display: block;
  margin: auto;
  -webkit-transition: 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
  transition: 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
  cursor: pointer;
  will-change: transform;
}
@media only screen and (max-width: 768px) {
  .aco_block_ttl_txt .icon_wrap .icon {
    width: 5.641vw;
    height: 5.641vw;
  }
}
.aco_block_ttl_txt .icon_wrap .icon:hover {
  -webkit-transform: scale(0.92);
          transform: scale(0.92);
}
.aco_block_ttl_txt .icon_wrap .icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
  height: 2px;
  background: #fff;
  display: block;
}
.aco_block_ttl_txt .icon_wrap .icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 2px;
  height: 100%;
  background: #fff;
  display: block;
  will-change: transform;
  -webkit-transition: 0.3s cubic-bezier(0.33, 1, 0.68, 1);
  transition: 0.3s cubic-bezier(0.33, 1, 0.68, 1);
}
.aco_block_cnt {
  display: none;
  padding: min(1.953vw, 20px) min(7.813vw, 80px);
}
@media only screen and (max-width: 768px) {
  .aco_block_cnt {
    padding: 5.128vw;
  }
}
.aco_block_cnt p {
  font-weight: 500;
  font-size: min(1.367vw, 14px);
}
@media only screen and (max-width: 768px) {
  .aco_block_cnt p {
    font-size: 3.59vw;
  }
}
.aco_block_cnt p:not(:last-of-type) {
  margin-bottom: min(2.93vw, 30px);
}
@media only screen and (max-width: 768px) {
  .aco_block_cnt p:not(:last-of-type) {
    margin-bottom: 4vw;
  }
}
.aco_block_cnt p.f14 {
  font-size: min(1.367vw, 14px);
}
@media only screen and (max-width: 768px) {
  .aco_block_cnt p.f14 {
    font-size: 3.59vw;
  }
}
.aco_block_cnt p.f12 {
  line-height: 1.5;
  font-size: min(1.172vw, 12px);
}
@media only screen and (max-width: 768px) {
  .aco_block_cnt p.f12 {
    font-size: 3.077vw;
  }
}
.aco_block_cnt p a {
  display: inline;
  word-wrap: break-word;
  border-bottom: solid 1px #000;
}