@charset "UTF-8";
.l_header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99999;
  width: 100%;
}
.l_header_inner {
  width: 100%;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: clamp(2rem, 0.5436893204rem + 3.8834951456vw, 8rem);
  padding-right: clamp(2rem, 0.5436893204rem + 3.8834951456vw, 8rem);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #08223F;
}
.l_header_logo {
  width: clamp(10rem, 6.6019417476rem + 9.0614886731vw, 24rem);
}
@media only screen and (max-width: 1368px) {
  .l_header_logo {
    width: 125px;
  }
}
@media only screen and (max-width: 768px) {
  .l_header_logo {
    width: 100px;
  }
}
.l_header_box {
  display: flex;
  align-items: center;
  gap: 118px;
}
.l_header_nav ul {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: clamp(2rem, 1.0291262136rem + 2.5889967638vw, 6rem);
}
@media only screen and (max-width: 1368px) {
  .l_header_nav ul {
    gap: 30px;
  }
}
@media only screen and (max-width: 768px) {
  .l_header_nav ul {
    display: block;
    margin-top: 38px;
  }
}
.l_header_nav ul li {
  text-align: center;
}
.l_header_nav ul li figure {
  width: 42px;
  margin: 0 auto;
  transition: all 0.3s;
}
@media only screen and (max-width: 768px) {
  .l_header_nav ul li figure {
    width: 25px;
    margin: 0;
  }
}
.l_header_nav ul li p {
  color: #ffffff;
  font-size: clamp(1.8rem, 1.7514563107rem + 0.1294498382vw, 2rem);
  margin-top: 15px;
  transition: all 0.3s;
}
@media only screen and (max-width: 1368px) {
  .l_header_nav ul li p {
    font-size: 14px;
  }
}
@media only screen and (max-width: 768px) {
  .l_header_nav ul li p {
    margin-top: 0;
    font-size: 18px;
  }
}
@media only screen and (max-width: 768px) {
  .l_header_nav ul li a {
    display: flex;
    align-items: center;
    gap: 10px;
    border-bottom: 1px solid #fff;
    padding-bottom: 20px;
    padding-top: 20px;
  }
}
.l_header_nav ul li a:hover p {
  color: #FFD713;
}
.l_header_nav ul li a:hover figure {
  transform: rotate(10deg) scale(1.1);
}
.l_header_nav ul li .sp_arrow {
  width: 10px;
  margin-right: 10px;
  margin-left: auto;
}

.l_ft {
  background-color: #08223F;
  padding-bottom: clamp(2rem, 1.2718446602rem + 1.9417475728vw, 5rem);
}
@media only screen and (max-width: 768px) {
  .l_ft {
    padding-top: 50px;
    padding-bottom: 68px;
  }
}
.l_ft_bottom {
  display: flex;
  justify-content: space-between;
  margin-top: clamp(4rem, 3.2718446602rem + 1.9417475728vw, 7rem);
}
@media only screen and (max-width: 768px) {
  .l_ft_bottom {
    flex-wrap: wrap;
    justify-content: center;
  }
}
.l_ft_link {
  color: #ffffff;
  display: flex;
  gap: 20px;
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
}
.l_ft .copy {
  font-size: 12px;
  font-weight: 600;
  color: #ffffff;
}
@media only screen and (max-width: 768px) {
  .l_ft .copy {
    width: 100%;
    order: 2;
    text-align: center;
    margin-top: 50px;
  }
}
.l_ft_logo {
  text-align: center;
}
.l_ft_logo img {
  width: clamp(13.5rem, 9.3737864078rem + 11.003236246vw, 30.5rem);
}
.l_ft_sns {
  display: flex;
  gap: clamp(1.5rem, 1.2815533981rem + 0.5825242718vw, 2.4rem);
  justify-content: center;
  align-items: center;
  margin-top: clamp(3rem, 2.7572815534rem + 0.6472491909vw, 4rem);
}
.l_ft_sns img {
  width: 45px;
}
.l_ft_top {
  margin-top: clamp(12.7rem, 12.2145631068rem + 1.2944983819vw, 14.7rem);
  position: relative;
}

.l_container {
  max-width: 1366px;
  width: 100%;
  padding: 0 20px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 768px) {
  .l_container {
    width: 100%;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}

.l_container_900 {
  max-width: 900px;
  width: 100%;
  padding: 0 20px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 768px) {
  .l_container_900 {
    width: 100%;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}

.l_container_1100 {
  max-width: 1100px;
  width: 100%;
  padding: 0 20px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 768px) {
  .l_container_1100 {
    width: 100%;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}

.l_container_728 {
  max-width: 728px;
  width: 100%;
  padding: 0 20px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 768px) {
  .l_container_728 {
    width: 100%;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}

.l_container_632 {
  max-width: 632px;
  width: 100%;
  padding: 0 20px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 768px) {
  .l_container_632 {
    width: 100%;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}

.container_inner {
  width: 100%;
}
@media only screen and (min-width: 767px) {
  .container_inner {
    max-width: 95.72%;
    margin-left: auto;
    margin-right: auto;
  }
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
  font-family: "M PLUS 1p", sans-serif;
  letter-spacing: 0;
  color: #08223F;
  overflow-x: hidden;
}

body {
  overflow-x: hidden;
}

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

iframe {
  width: 100%;
  height: 100%;
  vertical-align: bottom;
}

p {
  text-align: left;
}

.br {
  display: inline-block;
}

.wrapper {
  overflow-x: hidden;
}

a {
  cursor: pointer;
}

.pc {
  display: block;
}
@media only screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}

.pc_1025 {
  display: block;
}
@media only screen and (max-width: 1024px) {
  .pc_1025 {
    display: none;
  }
}

.sp {
  display: none;
}
@media only screen and (max-width: 768px) {
  .sp {
    display: block;
  }
}

@media only screen and (min-width: 767px) {
  .tb {
    display: block;
  }
}

.l_mv {
  position: relative;
  /*mv news*/
}
.l_mv_box {
  position: absolute;
  top: 35%;
  left: 5%;
  z-index: 999;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media only screen and (max-width: 768px) {
  .l_mv_box {
    top: 60%;
  }
}
.l_mv_box_sub {
  display: flex;
  align-items: center;
  gap: 20px;
}
.l_mv_box_main {
  margin-top: 20px;
}
.l_mv_news {
  position: absolute;
  right: 0;
  bottom: 40px;
  z-index: 999;
}
@media only screen and (max-width: 768px) {
  .l_mv_news {
    position: static;
    width: 100%;
    margin-top: 25px;
  }
}
.l_mv_news dl {
  display: flex;
  align-items: center;
  min-height: 50px;
}
@media only screen and (max-width: 768px) {
  .l_mv_news dl {
    flex-direction: column;
  }
}
.l_mv_news dl dt {
  background-color: #08223F;
  color: #ffffff;
  font-size: 12px;
  border-top-left-radius: 10px;
  border-bottom-left-radius: 10px;
  padding-left: 16px;
  padding-right: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  height: 50px;
}
.l_mv_news dl dt .en {
  font-family: "Stack Sans Notch", sans-serif;
  font-size: clamp(1.8rem, 1.654368932rem + 0.3883495146vw, 2.4rem);
}
.l_mv_news dl dd {
  background-color: rgba(255, 255, 255, 0.85);
  font-size: clamp(1.4rem, 1.254368932rem + 0.3883495146vw, 2rem);
  height: 50px;
  display: flex;
  align-items: center;
  padding-left: 20px;
  padding-right: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 768px) {
  .l_mv_news dl dd {
    width: 100%;
    border-radius: 10px;
    height: 30px;
  }
}
.l_mv_news dl dd .date {
  margin-right: 20px;
}

.c_btn_pink._price {
  margin-left: auto;
  margin-right: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.c_btn_pink._price a {
  width: clamp(30rem, 26.359223301rem + 9.7087378641vw, 45rem);
  height: clamp(7rem, 6.7572815534rem + 0.6472491909vw, 8rem);
}
.c_btn_pink._price .ill {
  left: -4%;
}
.c_btn_pink._price .ill img {
  width: 100%;
}
.c_btn_pink a {
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent linear-gradient(180deg, #F163AE 0%, #FF5F88 100%) 0% 0% no-repeat padding-box;
  color: #ffffff;
  font-size: 20px;
  text-align: center;
  font-weight: bold;
  width: 300px;
  border-radius: 999px;
  height: clamp(6.9rem, 6.8757281553rem + 0.0647249191vw, 7rem);
  position: relative;
  transition: all 0.5s;
}
@media only screen and (max-width: 768px) {
  .c_btn_pink a {
    margin: 0 auto;
  }
}
.c_btn_pink a:hover {
  background: #C99FF0;
}
.c_btn_pink a:hover .arrow {
  right: 20px;
}
.c_btn_pink a:hover .ill img {
  transform: rotate(5deg);
}
.c_btn_pink a .ill {
  position: absolute;
  top: 50%;
  left: -15%;
  transform: translateY(-50%);
}
@media only screen and (max-width: 768px) {
  .c_btn_pink a .ill {
    width: 86px;
    left: -7%;
  }
}
.c_btn_pink a .ill img {
  transition: all 0.3s ease-in;
  width: 75%;
}
.c_btn_pink a .arrow {
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  transition: all 0.3s ease-in;
}
.c_btn_black {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  margin-top: clamp(3.5rem, 0.7087378641rem + 7.4433656958vw, 15rem);
  position: relative;
}
.c_btn_black::after {
  content: "";
  background-color: #78BAEA;
  width: clamp(25.9rem, 18.8368932039rem + 18.8349514563vw, 55rem);
  height: clamp(6.5rem, 4.9951456311rem + 4.0129449838vw, 12.7rem);
  border-radius: 999px;
  position: absolute;
  left: 0;
  bottom: -10px;
  z-index: -1;
  transition: all 0.5s;
}
.c_btn_black a {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #08223F;
  color: #ffffff;
  font-size: clamp(2rem, 1.9029126214rem + 0.2588996764vw, 2.4rem);
  text-align: center;
  font-weight: bold;
  width: clamp(32rem, 26.4174757282rem + 14.8867313916vw, 55rem);
  border-radius: 999px;
  height: clamp(6.5rem, 4.9951456311rem + 4.0129449838vw, 12.7rem);
  position: relative;
  transition: all 0.5s;
  z-index: 0;
}
.c_btn_black a .arrow {
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  transition: all 0.3s ease-in;
}
.c_btn_black a:hover {
  transform: translateY(10px);
}
.c_btn_black a:hover .arrow {
  right: 20px;
}
.c_btn_black_wrap {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
.c_btn_black_wrap:hover .c_deco_btn_monster {
  transform: rotate(10deg);
  transition: transform 0.3s ease;
}
.c_btn_yellow {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
  z-index: 0;
  margin-top: clamp(3.5rem, 3.3786407767rem + 0.3236245955vw, 4rem);
}
@media only screen and (max-width: 768px) {
  .c_btn_yellow {
    margin-left: auto;
    margin-right: auto;
  }
}
.c_btn_yellow:after {
  content: "";
  background-color: #ffffff;
  width: 192px;
  height: 192px;
  border-radius: 50%;
  position: absolute;
  left: 0;
  bottom: -10px;
  z-index: -1;
}
.c_btn_yellow a {
  background-color: #FFD713;
  width: 192px;
  height: 192px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  transition: all 0.3s ease;
}
.c_btn_yellow a .sub {
  color: #ffffff;
  font-size: 16px;
  font-family: "Stack Sans Notch", sans-serif;
}
.c_btn_yellow a .text {
  font-size: 22px;
  margin-top: 10px;
  font-weight: bold;
}
.c_btn_yellow a figure {
  margin-top: 15px;
  transition: all 0.3s ease;
}
.c_btn_yellow a:hover figure {
  transform: translateX(5px);
}
.c_btn_yellow a:hover {
  transform: translateY(10px);
}

.c_hamburger {
  width: 100%;
  height: 100%;
  position: fixed;
  overflow: auto;
  top: -100%;
  right: 0;
  background: #08223F;
  z-index: 9000;
  transition: 0.5s;
}
.c_hamburger_btn {
  position: relative;
  cursor: pointer;
  z-index: 9999;
  background-color: #C99FF0;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c_hamburger_icon {
  position: relative;
  display: block;
  background-color: #fff;
  height: 2px;
  border-radius: 999px;
  width: 23px;
}
.c_hamburger_icon::after {
  content: "";
  background-color: #fff;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  position: absolute;
  left: 0;
  top: -8px;
}
.c_hamburger_icon::before {
  content: "";
  background-color: #fff;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  position: absolute;
  left: 0;
  top: 8px;
}
.c_hamburger_wrap {
  padding: 15px;
}
.c_hamburger_wrap .c_btn_pink {
  margin-top: 45px;
}

html.is-open .c_hamburger {
  top: 0;
}

.is-open .overlay {
  opacity: 0.8;
  visibility: visible;
}

html.is-open {
  overflow: hidden;
  height: 100%;
}
html.is-open::-webkit-scrollbar {
  display: none;
}

html.is-open .c_hamburger_icon {
  background-color: transparent;
}
html.is-open .c_hamburger_icon::after {
  top: 0;
  transform: rotate(-30deg);
  transition: 0.3s;
}
html.is-open .c_hamburger_icon::before {
  top: 0;
  transform: rotate(30deg);
  transition: 0.3s;
}

/*mvテキストアニメーション*/
.marker-anim {
  position: relative;
  display: inline-block;
  font-size: clamp(1.8rem, 1.0961165049rem + 1.8770226537vw, 4.7rem);
  font-weight: bold;
  padding: 10px 20px 15px;
  color: #ffffff;
  overflow: hidden;
  white-space: normal;
  -webkit-animation: textReveal 1.5s ease forwards;
          animation: textReveal 1.5s ease forwards;
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  .marker-anim {
    padding: 10px 13px 10px;
  }
}
.marker-anim::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0.1em;
  height: 100%;
  width: 100%;
  z-index: -1;
  transform: scaleX(0);
  transform-origin: left center;
  -webkit-animation: markerSlide 1.5s ease forwards;
          animation: markerSlide 1.5s ease forwards;
}
.marker-anim._main {
  font-size: clamp(3.7rem, 2.8019417476rem + 2.3948220065vw, 7.4rem);
  padding: 20px 30px 25px;
}
.marker-anim._main .yellow {
  color: #FFD713;
}
.marker-anim._main::before {
  background: #08223F;
}
.marker-anim._purple::before {
  background: #C99FF0;
}
.marker-anim._pink::before {
  background: #EAACBC;
}
.marker-anim._green::before {
  background: #64ABAB;
}

/* マーカーが左→右へ伸びる */
@-webkit-keyframes markerSlide {
  0% {
    transform: scaleX(0);
  }
  100% {
    transform: scaleX(1);
  }
}
@keyframes markerSlide {
  0% {
    transform: scaleX(0);
  }
  100% {
    transform: scaleX(1);
  }
}
/* テキストの左→右露出 */
@-webkit-keyframes textReveal {
  0% {
    opacity: 1;
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  100% {
    opacity: 1;
    -webkit-clip-path: inset(0 0 0 0);
            clip-path: inset(0 0 0 0);
  }
}
@keyframes textReveal {
  0% {
    opacity: 1;
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  100% {
    opacity: 1;
    -webkit-clip-path: inset(0 0 0 0);
            clip-path: inset(0 0 0 0);
  }
}
/* 順番にアニメさせる */
.l_mv_box_sub .marker-anim._purple {
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}

.l_mv_box_sub .marker-anim._purple::before {
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}

.l_mv_box_sub .marker-anim._pink {
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}

.l_mv_box_sub .marker-anim._pink::before {
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}

.l_mv_box_sub .marker-anim._green {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}

.l_mv_box_sub .marker-anim._green::before {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}

.l_mv_box .marker-anim._main {
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
}

.l_mv_box .marker-anim._main::before {
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
}

/*下からふわっとフェードイン*/
.fadeup-item {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.fadeup-item.is-active {
  opacity: 1;
  transform: translateY(0);
}

.c_headline_today {
  font-size: clamp(4.4rem, 3.9631067961rem + 1.1650485437vw, 6.2rem);
  color: #FFD713;
  font-family: "Stack Sans Notch", sans-serif;
  letter-spacing: 2.2px;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .c_headline_today {
    margin-top: 45px;
  }
}
.c_headline_today .sub_top {
  color: #ffffff;
  text-align: center;
  font-size: clamp(2.8rem, 2.5087378641rem + 0.7766990291vw, 4rem);
  font-weight: bold;
  font-family: "M PLUS 1p", sans-serif;
  margin-bottom: 5px;
}

/*h2*/
.c_headline_h2 {
  display: inline-block;
  text-align: center;
}
.c_headline_h2_wrap {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
.c_headline_h2_wrap._type02 {
  width: auto;
  margin: auto;
}
@media only screen and (max-width: 768px) {
  .c_headline_h2_wrap._type02 {
    text-align: center;
  }
}
.c_headline_h2_sub {
  text-align: center;
  color: #ffffff;
  font-size: clamp(1.8rem, 1.4601941748rem + 0.9061488673vw, 3.2rem);
  font-weight: bold;
  margin-top: clamp(1rem, 0.5631067961rem + 1.1650485437vw, 2.8rem);
}
.c_headline_h2_sub._type02 {
  text-align: left;
  font-size: clamp(1.8rem, 1.4601941748rem + 0.9061488673vw, 3.2rem);
  margin-top: 5px;
}
@media only screen and (max-width: 768px) {
  .c_headline_h2_sub._type02 {
    text-align: center;
  }
}
.c_headline_h2._type02 {
  text-align: left;
}
.c_headline_h2_pt02 {
  color: #EAACBC;
  font-size: clamp(2rem, 1.6116504854rem + 1.0355987055vw, 3.6rem);
  font-weight: bold;
  position: relative;
  text-align: center;
  margin-top: clamp(4rem, 3.5145631068rem + 1.2944983819vw, 6rem);
  line-height: 1.5;
}
.c_headline_h2_pt02::after {
  content: "";
  width: 10%;
  height: 5px;
  background-color: #EAACBC;
  position: absolute;
  left: 50%;
  bottom: -40px;
  transform: translateX(-50%);
}
@media only screen and (max-width: 768px) {
  .c_headline_h2_pt02::after {
    bottom: -20px;
  }
}

.c_headline_h2 span {
  display: inline-block;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
  font-size: clamp(3rem, 1.786407767rem + 3.2362459547vw, 8rem);
  font-family: "Stack Sans Notch", sans-serif;
  color: #ffffff;
  font-weight: bold;
}
.c_headline_h2 span._blue {
  color: #78BAEA;
}
.c_headline_h2 span._green {
  color: #64ABAB;
}
.c_headline_h2 span._yellow {
  color: #FFD713;
}
.c_headline_h2 span._pink {
  color: #BC699C;
}
.c_headline_h2 span._purple {
  color: #C99FF0;
}
.c_headline_h2 span .pl {
  margin-left: 0.5em;
}

.c_headline_h2.is-active span {
  opacity: 1;
  transform: translateY(0);
}

/*h3*/
.c_headline_h3 {
  font-size: clamp(2.6rem, 2.454368932rem + 0.3883495146vw, 3.2rem);
  color: #ffffff;
  font-weight: bold;
  letter-spacing: 1.3px;
  text-align: left;
}

.c_deco {
  /*人*/
  /*星*/
  /* ピンク：斜め右上 ↔ 斜め左下 */
  /* 青：左右にふわふわ + 少し回転 */
  /* 黄：上下にふわふわ + 斜めに少し揺れる */
  /*ufo*/
  /*intro monster*/
  /*btn monster*/
  /*map monster*/
  /*faq上　複数monster*/
  /*フッター*/
}
.c_deco_hito {
  position: absolute;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  opacity: 0;
  transition: opacity 0.5s ease-out;
  z-index: 10;
}
@media only screen and (max-width: 1368px) {
  .c_deco_hito img {
    width: 50%;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_hito img {
    width: 25%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_hito {
    opacity: 1;
  }
}
.c_deco_hito._today {
  left: 0;
  top: -3%;
  opacity: 1;
}
@media only screen and (max-width: 1368px) {
  .c_deco_hito._today {
    left: 15%;
    top: -4%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_hito._today {
    left: 16%;
    top: 38%;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_hito._today {
    left: 4%;
    top: 22%;
  }
}
.c_deco_hito._intro {
  left: 15%;
  top: 57%;
}
@media only screen and (max-width: 768px) {
  .c_deco_hito._intro {
    left: 23%;
    top: auto;
    bottom: -40%;
  }
}
.c_deco_hito._map {
  left: -8%;
  top: 60%;
}
@media only screen and (max-width: 768px) {
  .c_deco_hito._map {
    left: 9%;
    top: -1%;
  }
}
.c_deco_hito._list {
  left: -8%;
  bottom: 5%;
}
.c_deco_hito._faq {
  left: -19%;
  bottom: 5%;
  opacity: 1;
}
@media only screen and (max-width: 1368px) {
  .c_deco_hito._faq {
    left: 15%;
    bottom: 93%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_hito._faq {
    left: 23%;
    bottom: -57%;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_hito._faq {
    left: 20%;
    bottom: -35%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_hito._faq img {
    width: 50%;
  }
}
.c_deco_hito._price {
  left: 15%;
  top: 25%;
}
@media only screen and (max-width: 768px) {
  .c_deco_hito._price {
    top: 30%;
  }
}
.c_deco_hito .hito_move {
  -webkit-animation: float 6s ease-in-out infinite;
          animation: float 6s ease-in-out infinite;
}
@-webkit-keyframes float {
  0% {
    transform: translate(-50%, -50%);
  }
  50% {
    transform: translate(-50%, -55%);
  }
  100% {
    transform: translate(-50%, -50%);
  }
}
@keyframes float {
  0% {
    transform: translate(-50%, -50%);
  }
  50% {
    transform: translate(-50%, -55%);
  }
  100% {
    transform: translate(-50%, -50%);
  }
}
.c_deco_star {
  position: absolute;
}
@media only screen and (max-width: 768px) {
  .c_deco_star img {
    width: 50%;
  }
}
.c_deco_star._01, .c_deco_star._02, .c_deco_star._03 {
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
}
.c_deco_star._01 {
  -webkit-animation-name: float01;
          animation-name: float01;
}
.c_deco_star._02 {
  -webkit-animation-name: float02;
          animation-name: float02;
  -webkit-animation-duration: 7s;
          animation-duration: 7s;
}
.c_deco_star._03 {
  -webkit-animation-name: float03;
          animation-name: float03;
  -webkit-animation-duration: 5.5s;
          animation-duration: 5.5s;
}
.c_deco_star._today_pink {
  top: 7%;
  right: 23%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._today_pink {
    top: 19%;
    right: 35%;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_star._today_pink {
    top: 25%;
    right: 13%;
  }
}
.c_deco_star._today_blue {
  top: 12%;
  right: 18%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._today_blue {
    top: 20%;
    right: 25%;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_star._today_blue {
    top: 6%;
    right: 66%;
  }
}
.c_deco_star._today_yellow {
  top: 27%;
  right: 23%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._today_yellow {
    top: 25%;
    right: 33%;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_star._today_yellow {
    top: 29%;
    right: 5%;
  }
}
.c_deco_star._today_yellow02 {
  bottom: 20%;
  right: 10%;
}
.c_deco_star._intro_pink {
  top: 18%;
  left: 7%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._intro_pink {
    top: 50%;
    left: 7%;
  }
}
.c_deco_star._intro_blue {
  top: 80%;
  left: 12%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._intro_blue {
    top: 92%;
    left: 5%;
  }
}
.c_deco_star._intro_yellow {
  top: 8%;
  left: 15%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._intro_yellow {
    top: 28%;
    left: 7%;
  }
}
.c_deco_star._map_pink {
  top: -30%;
  left: -10%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._map_pink {
    top: 105%;
    left: -3%;
  }
}
.c_deco_star._map_blue {
  top: 100%;
  left: -20%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._map_blue {
    top: 101%;
    left: 14%;
  }
}
.c_deco_star._map_yellow {
  top: -59%;
  left: -15%;
}
.c_deco_star._map_yellow02 {
  top: 120%;
  left: -10%;
}
@media only screen and (max-width: 768px) {
  .c_deco_star._map_yellow02 {
    top: 103%;
    left: 9%;
  }
}
.c_deco_star._shop_pink {
  top: 40%;
  left: -8%;
}
.c_deco_star._shop_pink02 {
  top: 50%;
  left: 8%;
}
.c_deco_star._shop_blue {
  top: 65%;
  left: 0%;
}
.c_deco_star._shop_yellow {
  top: 30%;
  left: -12%;
}
.c_deco_star._shop_yellow02 {
  top: 55%;
  left: -6%;
}
.c_deco_star._faq_pink {
  top: -14%;
  left: 9%;
}
@media only screen and (max-width: 1368px) {
  .c_deco_star._faq_pink {
    top: -11%;
    left: 2%;
  }
}
.c_deco_star._faq_pink02 {
  top: -9%;
  left: 15%;
}
.c_deco_star._faq_pink03 {
  top: -4%;
  right: 8%;
}
.c_deco_star._faq_blue {
  top: -3%;
  left: 10%;
}
.c_deco_star._faq_yellow {
  top: -18%;
  left: 5%;
}
.c_deco_star._faq_yellow02 {
  top: -7%;
  left: 8%;
}
.c_deco_star._faq_yellow03 {
  top: -10%;
  right: 15%;
}
.c_deco_star._faq_yellow04 {
  top: -15%;
  right: 4%;
}
@-webkit-keyframes float01 {
  0% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(10deg);
  }
  100% {
    transform: rotate(0deg);
  }
}
@keyframes float01 {
  0% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(10deg);
  }
  100% {
    transform: rotate(0deg);
  }
}
@-webkit-keyframes float02 {
  0% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(-10deg);
  }
  100% {
    transform: rotate(0deg);
  }
}
@keyframes float02 {
  0% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(-10deg);
  }
  100% {
    transform: rotate(0deg);
  }
}
@-webkit-keyframes float03 {
  0% {
    transform: rotate(-20deg);
  }
  50% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(-20deg);
  }
}
@keyframes float03 {
  0% {
    transform: rotate(-20deg);
  }
  50% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(-20deg);
  }
}
.c_deco_ufo {
  position: absolute;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
}
.c_deco_ufo._today {
  top: 10%;
  right: 5%;
}
@media only screen and (max-width: 768px) {
  .c_deco_ufo._today {
    top: 26%;
    right: -5%;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_ufo._today {
    top: 4%;
    right: -31%;
  }
}
@media only screen and (max-width: 1368px) {
  .c_deco_ufo._today img {
    width: 55%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_ufo._today img {
    width: 35%;
  }
}
.c_deco_ufo._ft {
  top: -187%;
  right: 9%;
}
@media only screen and (max-width: 768px) {
  .c_deco_ufo._ft img {
    width: 80px;
  }
}
.c_deco_ufo._faq {
  top: -11%;
  right: 0%;
  -webkit-animation-name: ufo02;
          animation-name: ufo02;
}
@media only screen and (max-width: 768px) {
  .c_deco_ufo._faq {
    top: -15%;
    right: -29%;
  }
}
.c_deco_ufo._faq img {
  width: 40%;
}
@-webkit-keyframes ufo {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(2deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
@keyframes ufo {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(2deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
@-webkit-keyframes ufo02 {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(-10px, 35px) rotate(5deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
@keyframes ufo02 {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(-10px, 35px) rotate(5deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
.c_deco_intro_monster {
  opacity: 0;
  transform: translate(132px, 380px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.c_deco_intro_monster img {
  width: 179px;
}
.c_deco_intro_monster.is-active {
  opacity: 1;
  transform: translate(100px, 100px);
}
@media only screen and (max-width: 768px) {
  .c_deco_intro_monster.is-active {
    transform: translate(20px, 76px);
  }
}
.c_deco_slide_monster {
  position: absolute;
  z-index: 2;
  top: -53%;
  right: 5%;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: slide-monster;
          animation-name: slide-monster;
}
@media only screen and (max-width: 768px) {
  .c_deco_slide_monster {
    right: -10%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_slide_monster img {
    width: 50%;
  }
}
@-webkit-keyframes slide-monster {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(10deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
@keyframes slide-monster {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(10deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
.c_deco_btn_monster {
  position: absolute;
  top: -25%;
  left: -40%;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  .c_deco_btn_monster {
    top: -4%;
    left: -12%;
    width: 30%;
  }
}
.c_deco_map_monster {
  width: 238px;
  position: absolute;
  z-index: 2;
  top: -52%;
  right: -5%;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: slide-monster;
          animation-name: slide-monster;
}
@media only screen and (max-width: 1368px) {
  .c_deco_map_monster {
    top: -27%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_map_monster {
    top: -35%;
    right: -39%;
  }
}
@media only screen and (max-width: 1368px) {
  .c_deco_map_monster img {
    width: 60%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_map_monster img {
    width: 40%;
  }
}
@keyframes slide-monster {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(10deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
.c_deco_gallery_monster {
  position: absolute;
  bottom: -14%;
  right: 5%;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: gallery-monster;
          animation-name: gallery-monster;
}
@media only screen and (max-width: 768px) {
  .c_deco_gallery_monster {
    bottom: -45%;
  }
}
@-webkit-keyframes gallery-monster {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(10deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
@keyframes gallery-monster {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(10deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_gallery_monster img {
    width: 50%;
  }
}
.c_deco_faq_monster {
  position: absolute;
  z-index: -1;
}
.c_deco_faq_monster._01 {
  top: -10%;
  left: 20%;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: faq-monster01;
          animation-name: faq-monster01;
}
@media only screen and (max-width: 768px) {
  .c_deco_faq_monster._01 {
    top: -3%;
    left: 12%;
  }
}
@media only screen and (max-width: 1368px) {
  .c_deco_faq_monster._01 img {
    width: 70%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_faq_monster._01 img {
    width: 40%;
  }
}
@-webkit-keyframes faq-monster01 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, -35px);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes faq-monster01 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, -35px);
  }
  100% {
    transform: translate(0, 0);
  }
}
.c_deco_faq_monster._02 {
  top: -8%;
  left: 33%;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: faq-monster02;
          animation-name: faq-monster02;
}
@media only screen and (max-width: 768px) {
  .c_deco_faq_monster._02 {
    top: -3%;
    left: 45%;
  }
}
@media only screen and (max-width: 1368px) {
  .c_deco_faq_monster._02 img {
    width: 70%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_faq_monster._02 img {
    width: 40%;
  }
}
@-webkit-keyframes faq-monster02 {
  0% {
    transform: rotate(0);
  }
  50% {
    transform: rotate(15deg);
  }
  100% {
    transform: rotate(0);
  }
}
@keyframes faq-monster02 {
  0% {
    transform: rotate(0);
  }
  50% {
    transform: rotate(15deg);
  }
  100% {
    transform: rotate(0);
  }
}
.c_deco_faq_monster._03 {
  top: -7%;
  left: 47%;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: faq-monster03;
          animation-name: faq-monster03;
}
@media only screen and (max-width: 768px) {
  .c_deco_faq_monster._03 {
    top: -3%;
    left: 70%;
  }
}
@media only screen and (max-width: 1368px) {
  .c_deco_faq_monster._03 img {
    width: 70%;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_faq_monster._03 img {
    width: 50%;
  }
}
@-webkit-keyframes faq-monster03 {
  0% {
    transform: rotate(0);
  }
  50% {
    transform: rotate(-15deg);
  }
  100% {
    transform: rotate(0);
  }
}
@keyframes faq-monster03 {
  0% {
    transform: rotate(0);
  }
  50% {
    transform: rotate(-15deg);
  }
  100% {
    transform: rotate(0);
  }
}
.c_deco_faq_monster._04 {
  top: -7%;
  right: 12%;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: faq-monster04;
          animation-name: faq-monster04;
}
@media only screen and (max-width: 1368px) {
  .c_deco_faq_monster._04 img {
    width: 70%;
  }
}
@-webkit-keyframes faq-monster04 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, -35px);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes faq-monster04 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, -35px);
  }
  100% {
    transform: translate(0, 0);
  }
}
.c_deco_ft_hito {
  position: absolute;
  left: 7%;
  top: -80%;
}
@media only screen and (max-width: 768px) {
  .c_deco_ft_hito {
    left: 4%;
    top: -70%;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_ft_hito {
    left: 4%;
    top: -218%;
  }
}
@media only screen and (max-width: 1368px) {
  .c_deco_ft_hito img {
    width: 250px;
  }
}
@media only screen and (max-width: 768px) {
  .c_deco_ft_hito img {
    width: 161px;
  }
}
.c_deco_ft_char {
  position: absolute;
  right: 15%;
  top: -85%;
}
@media only screen and (max-width: 768px) {
  .c_deco_ft_char img {
    width: 131px;
  }
}
@-webkit-keyframes ft-char {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(10deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
@keyframes ft-char {
  0% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(10px, -35px) rotate(10deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg);
  }
}
.c_deco_window {
  position: absolute;
  bottom: 2%;
  right: 18%;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: price-window;
          animation-name: price-window;
}
@media only screen and (max-width: 768px) {
  .c_deco_window {
    bottom: 0%;
    right: 5%;
    -webkit-animation: none;
            animation: none;
  }
}
@media only screen and (max-width: 414px) {
  .c_deco_window {
    right: 38%;
  }
}
@-webkit-keyframes price-window {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, -35px);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes price-window {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(10px, -35px);
  }
  100% {
    transform: translate(0, 0);
  }
}
.c_deco_window img {
  width: clamp(10rem, 3.932038835rem + 16.1812297735vw, 35rem);
}

.js-scroll-anim.active .c_deco_hito {
  opacity: 1;
}

/*電車*/
/* 初期状態：右の外側 + 少し上 */
.js-train-anim {
  position: absolute;
  top: 60%;
  z-index: -1;
  transform: translate(1000px, -20px);
}
@media only screen and (max-width: 768px) {
  .js-train-anim {
    top: 82%;
  }
}

.js-train-anim.active {
  -webkit-animation: trainMove 5s ease-out forwards;
          animation: trainMove 5s ease-out forwards;
}

/* 右 → 左（少し斜め左下） */
@-webkit-keyframes trainMove {
  0% {
    transform: translate(1000px, -20px);
  }
  100% {
    transform: translate(120px, 30px);
  }
}
@keyframes trainMove {
  0% {
    transform: translate(1000px, -20px);
  }
  100% {
    transform: translate(120px, 30px);
  }
}
/*gallery ufo*/
.gallery_ufo {
  position: absolute;
  top: 0;
  right: 6%;
  transform-origin: top right;
  -webkit-animation: gallery 7s ease-out infinite;
          animation: gallery 7s ease-out infinite;
}

@-webkit-keyframes gallery {
  0% {
    transform: rotate(15deg);
  }
  50% {
    transform: rotate(-15deg);
  }
  100% {
    transform: rotate(15deg);
  }
}

@keyframes gallery {
  0% {
    transform: rotate(15deg);
  }
  50% {
    transform: rotate(-15deg);
  }
  100% {
    transform: rotate(15deg);
  }
}
.gallery_ufo_small {
  position: absolute;
  top: 10%;
  right: 30%;
  transform-origin: top right;
  -webkit-animation: gallery 7s ease-out infinite;
          animation: gallery 7s ease-out infinite;
}
@media only screen and (max-width: 768px) {
  .gallery_ufo_small {
    top: -2%;
  }
}

@keyframes gallery {
  0% {
    transform: rotate(10deg);
  }
  50% {
    transform: rotate(-10deg);
  }
  100% {
    transform: rotate(10deg);
  }
}
/*ロケット順番に飛ぶ*/
.rocket {
  position: absolute;
  bottom: 60vw;
  opacity: 1;
}

.rocket01 {
  left: 100px;
}

.rocket02 {
  left: 200px;
}

.rocket03 {
  left: 400px;
}

@-webkit-keyframes rocketFly {
  0% {
    transform: translate(-50%, 0) rotate(0deg);
    opacity: 1;
  }
  80% {
    transform: translate(-50%, -140vh) rotate(10deg);
    /* 画面外へ */
    opacity: 1;
    /* 画面外に出るまでは消さない */
  }
  100% {
    transform: translate(-50%, -160vh) rotate(15deg);
    /* さらに上で消す */
    opacity: 0;
    /* 画面外でフェードアウト */
  }
}

@keyframes rocketFly {
  0% {
    transform: translate(-50%, 0) rotate(0deg);
    opacity: 1;
  }
  80% {
    transform: translate(-50%, -140vh) rotate(10deg);
    /* 画面外へ */
    opacity: 1;
    /* 画面外に出るまでは消さない */
  }
  100% {
    transform: translate(-50%, -160vh) rotate(15deg);
    /* さらに上で消す */
    opacity: 0;
    /* 画面外でフェードアウト */
  }
}
.fly {
  -webkit-animation: rocketFly 2.2s ease-in forwards;
          animation: rocketFly 2.2s ease-in forwards;
}

.c_app {
  background-color: #ffffff;
  border: 6px solid #F0F0F0;
  border-radius: 10px;
  padding-top: clamp(3rem, 1.9077669903rem + 2.9126213592vw, 7.5rem);
  padding-bottom: clamp(3rem, 1.9077669903rem + 2.9126213592vw, 7.5rem);
  padding-left: clamp(2.5rem, 1.4077669903rem + 2.9126213592vw, 7rem);
  padding-right: clamp(2.5rem, 1.4077669903rem + 2.9126213592vw, 7rem);
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.c_app_flex {
  display: flex;
  gap: 35px;
}
@media only screen and (max-width: 768px) {
  .c_app_flex {
    flex-direction: column;
  }
}
.c_app_flex_l {
  width: 510px;
}
@media only screen and (max-width: 768px) {
  .c_app_flex_l {
    width: 100%;
  }
}
.c_app_flex_l .title {
  font-size: clamp(2rem, 1.6116504854rem + 1.0355987055vw, 3.6rem);
  color: #5F407C;
  font-weight: bold;
  letter-spacing: 1.8px;
  line-height: 54px;
}
@media only screen and (max-width: 768px) {
  .c_app_flex_l .title {
    line-height: 30px;
  }
}
.c_app_flex_l .text {
  font-size: 16px;
  letter-spacing: 0.8px;
  line-height: 27.2px;
  margin-top: 15px;
}
.c_app_flex_r {
  max-width: 225px;
}
@media only screen and (max-width: 768px) {
  .c_app_flex_r {
    width: 100%;
  }
}
.c_app .btn_area {
  display: flex;
  gap: 15px;
  align-items: center;
  margin-top: 25px;
}
.c_app .btn_area a {
  transition: all 0.3s ease-in;
}
.c_app .btn_area a:hover {
  transform: scale(1.1);
}

.c_pricelist {
  margin-top: 60px;
  margin-bottom: clamp(2.5rem, 0.4368932039rem + 5.501618123vw, 11rem);
}
@media only screen and (max-width: 768px) {
  .c_pricelist {
    margin-top: 152px;
  }
}
@media only screen and (max-width: 768px) and (max-width: 768px) {
  .c_pricelist {
    margin-top: 108px;
  }
}
.c_pricelist table {
  border: 6px solid #ffffff;
  border-radius: 10px;
}
@media only screen and (max-width: 768px) {
  .c_pricelist table {
    width: 700px;
  }
}
.c_pricelist table td {
  background-color: #D8F2F2;
  font-size: clamp(1.4rem, 1.1087378641rem + 0.7766990291vw, 2.6rem);
  border: 6px solid #ffffff;
  text-align: center;
  vertical-align: middle;
  width: 316px;
  padding: 25px;
}
@media only screen and (max-width: 768px) {
  .c_pricelist table td {
    padding: 20px;
    width: 162px;
  }
}
.c_pricelist table .g01 {
  background-color: #65ABAB;
}
.c_pricelist table .g02 {
  background-color: #79C9C9;
}
.c_pricelist table .g03 {
  background-color: #5A9191;
}
.c_pricelist table .t01 {
  color: #ffffff;
  font-size: clamp(1.7rem, 1.3359223301rem + 0.9708737864vw, 3.2rem);
  font-weight: bold;
}
.c_pricelist .note {
  margin-top: 20px;
}
.c_pricelist .note li {
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
  margin-top: 10px;
  line-height: 1.5;
}

.c_news {
  background-color: #08223F;
  padding-bottom: clamp(10rem, 2.7184466019rem + 19.4174757282vw, 40rem);
}
.c_news_wrap {
  margin-top: clamp(2.5rem, 0.6796116505rem + 4.854368932vw, 10rem);
  display: flex;
  gap: clamp(0rem, -1.6990291262rem + 4.5307443366vw, 7rem);
}
@media only screen and (max-width: 768px) {
  .c_news_wrap {
    flex-direction: column;
  }
}
.c_news_wrap_r {
  max-width: 800px;
  width: 100%;
}
.c_news_list {
  margin-top: 20px;
}
.c_news_list li a {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 25px;
  padding-bottom: 25px;
  border-bottom: 1px solid #ffffff;
}
@media only screen and (max-width: 768px) {
  .c_news_list li a {
    flex-wrap: wrap;
  }
}
.c_news_list li a .date {
  color: #EAACBC;
  font-size: clamp(1.4rem, 1.3029126214rem + 0.2588996764vw, 1.8rem);
  font-weight: bold;
}
.c_news_list li a .title {
  color: #ffffff;
  font-size: clamp(1.8rem, 1.7514563107rem + 0.1294498382vw, 2rem);
  font-weight: bold;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
@media only screen and (max-width: 768px) {
  .c_news_list li a .title {
    width: 100%;
  }
}
.c_news_list li a .tag {
  background-color: #AB6597;
  padding: 2px 25px;
  color: #ffffff;
}

.c_faq_wrap {
  background-color: #ffffff;
  border-radius: 20px;
  padding-top: clamp(3rem, 2.7572815534rem + 0.6472491909vw, 4rem);
  padding-bottom: clamp(5rem, 3.786407767rem + 3.2362459547vw, 10rem);
  padding-left: clamp(1.5rem, -1.4126213592rem + 7.7669902913vw, 13.5rem);
  padding-right: clamp(1.5rem, -1.4126213592rem + 7.7669902913vw, 13.5rem);
}
.c_faq .c_headline_h2 span {
  color: #08223F;
}
.c_faq .c_headline_h2 span._blue {
  color: #78BAEA;
}
.c_faq .c_headline_h2_sub {
  color: #08223F;
}
.c_faq_content {
  position: relative;
  z-index: 0;
  margin-top: clamp(3.5rem, 3.2087378641rem + 0.7766990291vw, 4.7rem);
  width: 100%;
}
.c_faq_content dt {
  width: 100%;
  background-color: #CEEAFF;
  color: #007DD8;
  font-size: clamp(1.6rem, 1.5029126214rem + 0.2588996764vw, 2rem);
  padding-top: clamp(1rem, 0.7572815534rem + 0.6472491909vw, 2rem);
  padding-bottom: clamp(1rem, 0.7572815534rem + 0.6472491909vw, 2rem);
  padding-left: clamp(1.5rem, 1.0145631068rem + 1.2944983819vw, 3.5rem);
  padding-right: clamp(1.5rem, 1.0145631068rem + 1.2944983819vw, 3.5rem);
}
.c_faq_content dt span {
  font-size: clamp(1.8rem, 1.5087378641rem + 0.7766990291vw, 3rem);
  font-family: "Stack Sans Notch", sans-serif;
  margin-right: clamp(1rem, 0.7572815534rem + 0.6472491909vw, 2rem);
}
.c_faq_content dd {
  width: 100%;
  font-size: clamp(1.6rem, 1.5514563107rem + 0.1294498382vw, 1.8rem);
  padding-top: clamp(1rem, 0.7572815534rem + 0.6472491909vw, 2rem);
  padding-bottom: clamp(2.5rem, 2.2572815534rem + 0.6472491909vw, 3.5rem);
  padding-left: clamp(1.5rem, 1.0145631068rem + 1.2944983819vw, 3.5rem);
  padding-right: clamp(1.5rem, 1.0145631068rem + 1.2944983819vw, 3.5rem);
  line-height: 1.5;
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 559px) {
  .c_faq_content dd {
    align-items: flex-start;
  }
}
.c_faq_content dd span {
  font-size: clamp(1.8rem, 1.5087378641rem + 0.7766990291vw, 3rem);
  color: #BC699C;
  font-family: "Stack Sans Notch", sans-serif;
  margin-right: clamp(1rem, 0.7572815534rem + 0.6472491909vw, 2rem);
}

.c_shop {
  padding-top: clamp(4.5rem, 0.6893203883rem + 10.1618122977vw, 20.2rem);
  position: relative;
}
.c_shop .c_headline_h2 span {
  color: #ffffff;
}
.c_shop .c_headline_h2 span._yellow {
  color: #FFD713;
}
.c_shop .c_headline_h2_sub {
  color: #ffffff;
}
.c_shop_wrap {
  display: flex;
  justify-content: space-between;
}
@media only screen and (max-width: 768px) {
  .c_shop_wrap {
    flex-direction: column;
  }
}
.c_shop_wrap_r {
  width: 72%;
}
@media only screen and (max-width: 768px) {
  .c_shop_wrap_r {
    width: 100%;
    margin-top: 30px;
  }
}
.c_shop_map {
  aspect-ratio: 950/475;
}
.c_shop_add {
  margin-top: clamp(2.4rem, 2.0601941748rem + 0.9061488673vw, 3.8rem);
  padding-bottom: 45px;
  margin-bottom: 45px;
  border-bottom: 1px solid #ffffff;
}
.c_shop_title {
  color: #FFD713;
  font-size: clamp(2.2rem, 2.1029126214rem + 0.2588996764vw, 2.6rem);
  letter-spacing: 1.3px;
  font-weight: bold;
  margin-bottom: 20px;
}
.c_shop_text {
  color: #ffffff;
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
  letter-spacing: 0.8px;
  line-height: 25px;
  margin-bottom: 15px;
}
.c_shop_details {
  display: flex;
  gap: 50px;
}
@media only screen and (max-width: 768px) {
  .c_shop_details {
    flex-direction: column;
  }
}
.c_shop_access {
  width: calc((100% - 50px) / 2);
}
@media only screen and (max-width: 768px) {
  .c_shop_access {
    width: 100%;
  }
}
.c_shop_car {
  width: calc((100% - 50px) / 2);
}
@media only screen and (max-width: 768px) {
  .c_shop_car {
    width: 100%;
  }
}
.c_shop_access_list li {
  font-size: 20px;
  color: #ffffff;
  font-weight: bold;
}
.c_shop_access_list li img {
  width: 36px;
}
.c_shop_access_list .c_shop_text {
  padding-left: 50px;
}
.c_shop_access_flex {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 10px;
}

.c_floating {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: fixed;
  right: 2%;
  bottom: 10%;
  z-index: 1000;
  --scale:1;
}
@media only screen and (max-width: 1368px) {
  .c_floating {
    right: 0;
  }
}
@media only screen and (max-width: 1368px) {
  .c_floating img {
    width: 80%;
  }
}
.c_floating.is-active {
  opacity: 1;
  pointer-events: auto;
  -webkit-animation-duration: 6s;
          animation-duration: 6s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: floating;
          animation-name: floating;
  transition: all 0.4s ease;
}
@media only screen and (max-width: 768px) {
  .c_floating.is-active {
    -webkit-animation: none;
            animation: none;
  }
}
.c_floating.is-active:hover {
  --scale:1.1;
}

@-webkit-keyframes floating {
  0% {
    transform: rotate(0deg) scale(var(--scale));
  }
  50% {
    transform: rotate(10deg) scale(var(--scale));
  }
  100% {
    transform: rotate(0deg) scale(var(--scale));
  }
}

@keyframes floating {
  0% {
    transform: rotate(0deg) scale(var(--scale));
  }
  50% {
    transform: rotate(10deg) scale(var(--scale));
  }
  100% {
    transform: rotate(0deg) scale(var(--scale));
  }
}
.c_floating_sp {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  opacity: 0; /* 初期は非表示 */
  pointer-events: none; /* 非表示時はクリック不可 */
  transition: opacity 0.4s ease;
}

.c_floating_sp.is-active {
  opacity: 1;
  pointer-events: auto; /* 表示時はクリック可能 */
}

.c_floating_sp a {
  position: relative;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  color: #fff;
  background-color: #F462A4;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 57px;
  width: 100%;
}

.c_floating_sp a img {
  position: absolute;
  height: 67px;
  width: auto;
}

.c_floating_sp a img.right {
  bottom: 10px;
  right: 7%;
}

.c_floating_sp a img.left {
  bottom: 10px;
  left: 7%;
}

.p_top {
  /*today*/
}
.p_top_today {
  position: relative;
  z-index: 0;
  background-color: #08223F;
  padding-top: clamp(1.7rem, 0.559223301rem + 3.0420711974vw, 6.4rem);
}
.p_top_today_contents {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(2rem, 1.2718446602rem + 1.9417475728vw, 5rem);
  margin-top: clamp(1rem, 0.5873786408rem + 1.1003236246vw, 2.7rem);
}
@media only screen and (max-width: 768px) {
  .p_top_today_contents {
    flex-direction: column;
  }
}
.p_top_today_item {
  border: 6px solid #64ABAB;
  border-radius: clamp(1.5rem, 1.3786407767rem + 0.3236245955vw, 2rem);
  width: calc((100% - 50px) / 2);
}
@media only screen and (max-width: 768px) {
  .p_top_today_item {
    width: 100%;
  }
}
.p_top_today_item dl {
  padding: 10px;
}
.p_top_today_item dt {
  background-color: #64ABAB;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  color: #ffffff;
  font-size: clamp(2.2rem, 1.6902912621rem + 1.359223301vw, 4.3rem);
  font-weight: bold;
  letter-spacing: 2px;
  text-align: center;
  padding-top: clamp(1rem, 0.8058252427rem + 0.5177993528vw, 1.8rem);
  padding-bottom: clamp(1rem, 0.8058252427rem + 0.5177993528vw, 1.8rem);
}
.p_top_today_item dd {
  background-color: #D8F2F2;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  letter-spacing: 2px;
  font-size: clamp(2rem, 1.4417475728rem + 1.4886731392vw, 4.3rem);
  font-weight: bold;
  text-align: center;
  padding-top: clamp(1rem, 0.8058252427rem + 0.5177993528vw, 1.8rem);
  padding-bottom: clamp(1rem, 0.8058252427rem + 0.5177993528vw, 1.8rem);
  margin-top: 10px;
}
.p_top_intro {
  position: relative;
  z-index: 0;
  background-color: #08223F;
}
.p_top_intro_wrap {
  position: relative;
  z-index: 1;
  background-image: linear-gradient(#9469BC, #BC699C);
  padding-top: clamp(5rem, 3.8349514563rem + 3.1067961165vw, 9.8rem);
  border-top-left-radius: clamp(16rem, 9.6893203883rem + 16.8284789644vw, 42rem);
}
.p_top_intro_bg {
  background-image: url("../img/bg_img.png");
  background-position: top right;
  background-size: 30%;
  background-repeat: repeat-y;
}
@media only screen and (max-width: 768px) {
  .p_top_intro_bg {
    background-size: 50%;
  }
}
.p_top_intro_inner {
  position: relative;
}
.p_top_intro_text {
  font-size: clamp(1.6rem, 1.2116504854rem + 1.0355987055vw, 3.2rem);
  line-height: 2;
  color: #ffffff;
  font-weight: bold;
  text-align: center;
  margin-top: clamp(2.5rem, 1.4077669903rem + 2.9126213592vw, 7rem);
}
.p_top_intro_slide {
  position: relative;
  margin-top: 97px;
}
@media only screen and (max-width: 768px) {
  .p_top_intro_slide {
    margin-top: 122px;
  }
}
.p_top_intro .swiper-slide {
  border: 10px solid #ffffff;
  border-radius: 10px;
}
.p_top_intro .swiper-wrapper {
  transition-timing-function: linear;
}
.p_top_intro .swiper-slide img {
  height: auto;
  width: 100%;
}
.p_top_attraction {
  padding-top: clamp(4rem, 0.0194174757rem + 10.6148867314vw, 20.4rem);
  padding-bottom: clamp(5.3rem, 3.1883495146rem + 5.6310679612vw, 14rem);
}
.p_top_attraction_content {
  position: relative;
  margin-top: clamp(2rem, -4.067961165rem + 16.1812297735vw, 27rem);
  text-align: center;
}
.p_top_attraction_map {
  width: 630px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 1368px) {
  .p_top_attraction_map {
    width: 47%;
  }
}
@media only screen and (max-width: 414px) {
  .p_top_attraction_map {
    width: 100%;
  }
}
.p_top_attraction_item {
  position: absolute;
  width: clamp(33rem, 31.9077669903rem + 2.9126213592vw, 37.5rem);
  border-radius: 5px;
  padding-top: clamp(3rem, 2.7572815534rem + 0.6472491909vw, 4rem);
  padding-bottom: clamp(3rem, 2.6359223301rem + 0.9708737864vw, 4.5rem);
  padding-left: clamp(2.2rem, 2.1029126214rem + 0.2588996764vw, 2.6rem);
  padding-right: clamp(2.2rem, 2.1029126214rem + 0.2588996764vw, 2.6rem);
}
@media only screen and (max-width: 768px) {
  .p_top_attraction_item {
    position: static;
    margin-top: 30px;
    margin-left: auto;
    margin-right: auto;
  }
}
.p_top_attraction_item figure {
  border-radius: 5px;
  margin-top: 10px;
}
.p_top_attraction_item .text {
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
  color: #ffffff;
  font-weight: bold;
  letter-spacing: 0.7px;
  line-height: 23.8px;
  margin-top: clamp(1.5rem, 1.3786407767rem + 0.3236245955vw, 2rem);
}
.p_top_attraction_item._01 {
  background-color: #C99FF0;
  top: -80%;
  left: -3%;
}
@media only screen and (max-width: 1368px) {
  .p_top_attraction_item._01 {
    top: -76%;
    left: 0;
  }
}
.p_top_attraction_item._02 {
  background-color: #78BAEA;
  top: -74%;
  right: 0;
}
.p_top_attraction_item._03 {
  background-color: #84C168;
  bottom: -8%;
  left: -3%;
}
@media only screen and (max-width: 1368px) {
  .p_top_attraction_item._03 {
    left: 0;
    bottom: -5%;
  }
}
.p_top_attraction_item._04 {
  background-color: #EAACBC;
  bottom: -45%;
  right: 0;
}
.p_top_attraction_item._05 {
  background-color: #64ABAB;
  top: 105%;
  left: 33%;
}
.p_top_attraction_item._undo {
  background-color: #ED9973;
  top: -48%;
  left: 35%;
}
.p_top_attraction_item._kyukei {
  background-color: #6876C1;
  left: -3%;
  bottom: -97%;
}
@media only screen and (max-width: 1368px) {
  .p_top_attraction_item._kyukei {
    left: 0;
    bottom: -90%;
  }
}
.p_top_attraction_item._block {
  background-color: #ED7395;
  right: 0;
  bottom: 43%;
}
.p_top_attraction_list {
  position: relative;
  margin-top: clamp(18.2rem, 6.840776699rem + 30.2912621359vw, 65rem);
  display: flex;
  gap: clamp(2rem, 1.6359223301rem + 0.9708737864vw, 3.5rem);
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.p_top_attraction_list li {
  width: calc((100% - 70px) / 3);
}
@media only screen and (max-width: 768px) {
  .p_top_attraction_list li {
    width: calc((100% - 20px) / 2);
  }
}
.p_top_attraction_list li figure {
  border: 10px solid #fff;
  border-radius: 5px;
}
@media only screen and (max-width: 768px) {
  .p_top_attraction_list li figure {
    border: 4px solid #fff;
  }
}
.p_top_attraction_list li .c_headline_h3 {
  text-align: center;
  margin-top: clamp(1rem, 0.8786407767rem + 0.3236245955vw, 1.5rem);
}
@media only screen and (max-width: 768px) {
  .p_top_attraction_list li .c_headline_h3 {
    font-size: 12px;
  }
}
.p_top_black {
  background-color: #08223F;
  background-image: url("../img/bg_img.png");
  background-position: top right;
  background-size: 30%;
  background-repeat: repeat-y;
  position: relative;
}
.p_top_black_wrap {
  padding-top: clamp(2.5rem, -0.2912621359rem + 7.4433656958vw, 14rem);
  padding-bottom: clamp(2.5rem, -7.8155339806rem + 27.5080906149vw, 45rem);
  background-image: url("../img/bg_img.png");
  background-position: top left;
  background-size: 30%;
  background-repeat: repeat-y;
}
@media only screen and (max-width: 768px) {
  .p_top_black_wrap {
    padding-bottom: 16rem;
    background-image: none;
  }
}
.p_top_event_wrap {
  display: flex;
  gap: clamp(2.2rem, 0.7922330097rem + 3.7540453074vw, 8rem);
}
@media only screen and (max-width: 768px) {
  .p_top_event_wrap {
    flex-direction: column;
  }
}
.p_top_event_wrap_l {
  width: 20%;
}
@media only screen and (max-width: 768px) {
  .p_top_event_wrap_l {
    width: 100%;
  }
}
.p_top_event_wrap_r {
  width: 70%;
}
@media only screen and (max-width: 768px) {
  .p_top_event_wrap_r {
    width: 100%;
  }
}
.p_top_event_list {
  display: flex;
  gap: clamp(3rem, 2.5145631068rem + 1.2944983819vw, 5rem);
}
@media only screen and (max-width: 768px) {
  .p_top_event_list {
    flex-direction: column;
  }
}
.p_top_event_list li {
  width: calc((100% - 100px) / 3);
}
@media only screen and (max-width: 768px) {
  .p_top_event_list li {
    width: 100%;
  }
}
.p_top_event_list li figure {
  aspect-ratio: 385/216;
}
.p_top_event_list li figure img {
  aspect-ratio: 385/216;
  -o-object-fit: cover;
     object-fit: cover;
}
.p_top_event_list .date {
  color: #ffffff;
  font-size: 16px;
  font-family: "Stack Sans Notch", sans-serif;
  margin-top: 15px;
  letter-spacing: 0.8px;
}
.p_top_event_list .title {
  font-size: clamp(1.8rem, 1.7514563107rem + 0.1294498382vw, 2rem);
  color: #ffffff;
  line-height: 36px;
  letter-spacing: 1px;
  margin-top: 15px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-weight: bold;
}
.p_top_event_list .tag {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 16px;
  color: #ffffff;
  letter-spacing: 0.8px;
  margin-top: 20px;
  text-decoration: underline;
}
.p_top_event_list .tag li {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.p_top_gallery {
  position: relative;
  margin-top: clamp(4.8rem, 1.3776699029rem + 9.1262135922vw, 18.9rem);
}
.p_top_gallery_box {
  border: 16px solid #ffffff;
}
@media only screen and (max-width: 768px) {
  .p_top_gallery_box {
    border: 4px solid #ffffff;
  }
}
.p_top_gallery_border {
  position: relative;
  margin: 15px;
  border: 2px solid #ffffff;
  padding-top: clamp(4.5rem, 2.1941747573rem + 6.1488673139vw, 14rem);
  padding-left: clamp(1.5rem, 0.286407767rem + 3.2362459547vw, 6.5rem);
  padding-right: clamp(1.5rem, 0.286407767rem + 3.2362459547vw, 6.5rem);
  padding-bottom: clamp(1.5rem, -0.0048543689rem + 4.0129449838vw, 7.7rem);
}
@media only screen and (max-width: 768px) {
  .p_top_gallery_border {
    margin: 5px;
    border: 1px solid #ffffff;
  }
}
.p_top_gallery_contents {
  margin-top: clamp(2rem, 1.2718446602rem + 1.9417475728vw, 5rem);
}
.p_top_price_bottom img {
  width: 100%;
}
.p_top_price_area {
  position: relative;
}
.p_top_price_area .price_bg {
  position: absolute;
  bottom: 0;
  left: 0;
}
.p_top_price_area .price_bg img {
  width: 100%;
}
.p_top_price_area .price_title {
  padding-bottom: 50px;
}
@media only screen and (max-width: 768px) {
  .p_top_price_area .price_title {
    padding-bottom: 14px;
  }
}
.p_top_price_body {
  position: relative;
  background-image: linear-gradient(#5EB6DF, #009AE3);
  padding-top: clamp(2.6rem, 1.4834951456rem + 2.9773462783vw, 7.2rem);
  padding-bottom: 120px;
}
.p_top_bg_bk {
  position: relative;
  z-index: 0;
  background-color: #08223F;
}
.p_top_bg_pk {
  background-image: linear-gradient(#9469BC, #BC699C);
  border-top-left-radius: 80px;
  border-top-right-radius: 80px;
  padding-top: clamp(6.8rem, 4.1300970874rem + 7.1197411003vw, 17.8rem);
}

/*プラグイン入れたら消すでいいと思う*/
.p_top_gallery_contents ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.p_top_gallery_contents ul li {
  width: calc((100% - 20px) / 3);
}

.p_single {
  padding-top: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  padding-bottom: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  background-color: #08223F;
}
.p_single .date {
  font-family: "Stack Sans Notch", sans-serif;
  color: #ffffff;
  font-size: clamp(1.4rem, 1.254368932rem + 0.3883495146vw, 2rem);
}
.p_single_title {
  font-size: clamp(1.8rem, 1.654368932rem + 0.3883495146vw, 2.4rem);
  color: #ffffff;
  line-height: 1.5;
  margin-top: 10px;
}
.p_single figure {
  margin-top: 15px;
  margin-bottom: 15px;
}
.p_single figure img {
  width: 100%;
}
.p_single_content p {
  color: #ffffff;
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
  line-height: 1.8;
}
.p_single .post-navigation {
  color: #ffffff;
  margin-top: clamp(4rem, 3.5145631068rem + 1.2944983819vw, 6rem);
  font-size: clamp(1.2rem, 1.054368932rem + 0.3883495146vw, 1.8rem);
  font-weight: bold;
}
.p_single .nav-links {
  display: flex;
  gap: 30px;
  justify-content: center;
  align-items: center;
}
.p_single .nav-archive a {
  background-color: #BC699C;
  padding: 10px 35px;
  border-radius: 10px;
}

.page-title {
  color: #ffffff;
  font-size: clamp(2rem, 1.4660194175rem + 1.4239482201vw, 4.2rem);
  text-align: center;
  padding-top: 30px;
  padding-bottom: 30px;
  border-bottom: 2px solid #ffffff;
  border-top: 2px solid #ffffff;
  margin-bottom: 40px;
}

.p_archive {
  padding-top: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  padding-bottom: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  background-color: #08223F;
}
.p_archive_list {
  display: flex;
  gap: 50px;
  justify-content: center;
  flex-wrap: wrap;
}
@media only screen and (max-width: 768px) {
  .p_archive_list {
    flex-direction: column;
  }
}
.p_archive_item {
  width: calc((100% - 100px) / 3);
}
@media only screen and (max-width: 768px) {
  .p_archive_item {
    width: 100%;
  }
}
.p_archive_thumb img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  aspect-ratio: 408/229;
  border-radius: 10px;
}
.p_archive_title {
  color: #ffffff;
  font-size: clamp(1.6rem, 1.5029126214rem + 0.2588996764vw, 2rem);
  margin-top: 20px;
  font-weight: bold;
}
.p_archive .date {
  font-family: "Stack Sans Notch", sans-serif;
  color: #ffffff;
  font-size: clamp(1.2rem, 1.1029126214rem + 0.2588996764vw, 1.6rem);
  margin-top: 15px;
}
.p_archive .c_news_list {
  padding-top: clamp(4rem, 3.0291262136rem + 2.5889967638vw, 8rem);
}

.p_corporation {
  background-color: #08223F;
  padding-top: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  padding-bottom: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  background-image: url("../img/bg_img.png");
  background-position: top right;
  background-size: 30%;
  background-repeat: repeat-y;
}
@media only screen and (max-width: 768px) {
  .p_corporation {
    background-size: 50%;
  }
}
.p_corporation_sec:not(:first-of-type) {
  margin-top: clamp(10rem, 7.572815534rem + 6.4724919094vw, 20rem);
}
.p_corporation_contents_image {
  max-width: 730px;
  margin-left: auto;
  margin-right: auto;
  margin-top: clamp(5rem, 3.9077669903rem + 2.9126213592vw, 9.5rem);
}
.p_corporation_contents_image img {
  border-radius: 10px;
}
.p_corporation_box {
  background-color: #fcfcfc;
  margin-top: 30px;
  padding: 30px 50px;
  font-size: clamp(1.6rem, 1.5029126214rem + 0.2588996764vw, 2rem);
  font-weight: bold;
}
@media only screen and (max-width: 768px) {
  .p_corporation_box {
    padding: 20px 15px;
  }
}
.p_corporation_box li {
  margin-top: 15px;
}
.p_corporation_box dl {
  margin-top: 15px;
}
.p_corporation_box dd {
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
  font-weight: normal;
  margin-top: 10px;
  line-height: 1.6;
}
.p_corporation_catch {
  font-size: clamp(1.8rem, 1.654368932rem + 0.3883495146vw, 2.4rem);
  line-height: 1.5;
  color: #64ABAB;
  margin-bottom: 10px;
}
.p_corporation_under .c_btn_black {
  margin-top: clamp(2rem, 1.3932038835rem + 1.6181229773vw, 4.5rem);
}
.p_corporation_under .c_btn_black a {
  background-color: #BC699C;
}
.p_corporation_form {
  margin-top: clamp(6rem, 3.8155339806rem + 5.8252427184vw, 15rem);
}

.under .l_mv_box {
  position: static;
  margin-bottom: clamp(4.5rem, 4.0145631068rem + 1.2944983819vw, 6.5rem);
  margin-left: auto;
  margin-right: auto;
}
.under .l_mv_box .marker-anim._main {
  font-size: clamp(2rem, 1.6601941748rem + 0.9061488673vw, 3.4rem);
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}
@media only screen and (max-width: 768px) {
  .under .l_mv_box .marker-anim._main {
    text-align: center;
    line-height: 1.6;
  }
}
.under .l_mv_box .marker-anim._main::before {
  background-color: #BC699C;
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}

.p_privacy,
.p_low {
  background-color: #08223F;
  padding-top: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  padding-bottom: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  background-image: url("../img/bg_img.png");
  background-position: top right;
  background-size: 30%;
  background-repeat: repeat-y;
}
@media only screen and (max-width: 768px) {
  .p_privacy,
.p_low {
    background-size: 50%;
  }
}
.p_privacy_text,
.p_privacy li,
.p_low_text,
.p_low li {
  color: #ffffff;
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
  line-height: 1.6;
  letter-spacing: 0.01em;
}
.p_privacy_contents,
.p_low_contents {
  margin-top: clamp(4rem, 3.1504854369rem + 2.2653721683vw, 7.5rem);
}
.p_privacy_contents h3,
.p_low_contents h3 {
  font-size: clamp(1.8rem, 1.7514563107rem + 0.1294498382vw, 2rem);
  font-weight: bold;
  color: #ffffff;
  line-height: 1.5;
  letter-spacing: 0.01em;
  margin-bottom: 20px;
  color: #C99FF0;
}
.p_privacy_contents li,
.p_low_contents li {
  margin-top: 10px;
}
.p_privacy_contents li ul,
.p_low_contents li ul {
  padding-left: 1em;
}
.p_privacy_contents li ul ul,
.p_low_contents li ul ul {
  padding-left: 1em;
}

/* ===== カード（項目ブロック） ===== */
.card {
  background: #ffffff;
  border-radius: 10px;
  box-shadow: 0 6px 18px rgba(16, 24, 40, 0.06);
  padding: 18px;
  margin-bottom: 18px;
  border: 1px solid rgba(0, 0, 0, 0.04);
}
.card h2 {
  font-size: clamp(1.6rem, 1.5029126214rem + 0.2588996764vw, 2rem);
  margin-bottom: clamp(1.5rem, 1.3786407767rem + 0.3236245955vw, 2rem);
  font-weight: bold;
  color: #BC699C;
}

dl.specs {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 20px 20px;
  align-items: start;
}
@media only screen and (max-width: 768px) {
  dl.specs {
    gap: 10px 20px;
  }
}

dl.specs dt {
  font-weight: bold;
  color: #08223F;
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
}
@media only screen and (max-width: 768px) {
  dl.specs dt {
    margin-top: 10px;
  }
}

dl.specs dd {
  margin: 0;
  color: #08223F;
  font-size: clamp(1.4rem, 1.3514563107rem + 0.1294498382vw, 1.6rem);
}

.note {
  color: #08223F;
  font-size: clamp(1.2rem, 1.1514563107rem + 0.1294498382vw, 1.4rem);
  margin-top: 23px;
  white-space: pre-wrap;
}

/* レスポンシブ */
@media (max-width: 768px) {
  dl.specs {
    grid-template-columns: 1fr;
  }
  .wrap {
    padding: 16px;
    margin: 18px;
  }
}
/* 印刷用: 見やすく */
@media print {
  body {
    background: white;
    color: #000;
  }
  .card {
    box-shadow: none;
    border: 1px solid #ddd;
  }
  .btn {
    display: none;
  }
}
.p_inquiry {
  background-color: #08223F;
  padding-top: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  padding-bottom: clamp(5rem, 1.359223301rem + 9.7087378641vw, 20rem);
  background-image: url("../img/bg_img.png");
  background-position: top right;
  background-size: 30%;
  background-repeat: repeat-y;
}
@media only screen and (max-width: 768px) {
  .p_inquiry {
    background-size: 50%;
  }
}

.wpcf7 .contact_form label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #ffffff;
  font-size: clamp(1.4rem, 1.3029126214rem + 0.2588996764vw, 1.8rem);
}

.contact_form span.wpcf7-form-control-wrap {
  width: 70%;
}

.contact_form p {
  margin-top: clamp(1.5rem, 1.3786407767rem + 0.3236245955vw, 2rem);
}

span.required {
  color: #BC699C;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner.btn {
  width: 300px;
  border-radius: 0;
  background: #BC699C;
  color: #fff;
  font-weight: bold;
  padding: 20px;
  font-size: clamp(1.4rem, 1.3029126214rem + 0.2588996764vw, 1.8rem);
}

.btn_area {
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn_area .btn {
  margin: 10px;
}

span.wpcf7-spinner {
  display: block;
}

.wpcf7-list-item {
  display: block;
}

.wpcf7 .contact_form .wpcf7-list-item label {
  display: block;
}

.product-option p {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

input:not([type=checkbox]):not([type=radio]),
textarea {
  width: 100%;
  background-color: #fcfcfc;
  border-radius: 5px;
  padding: 15px 20px;
  color: #08223F;
}

.wpcf7-response-output {
  color: #fff;
  font-size: clamp(1.4rem, 1.254368932rem + 0.3883495146vw, 2rem);
}

div#wpcf7cpcnf {
  color: #fff;
}
div#wpcf7cpcnf table {
  width: 100%;
  font-size: clamp(1.4rem, 1.3029126214rem + 0.2588996764vw, 1.8rem);
}
div#wpcf7cpcnf table tr p {
  margin-top: clamp(2rem, 1.7572815534rem + 0.6472491909vw, 3rem);
}

.wpcf7cp-btns {
  display: flex;
  margin-top: clamp(4rem, 3.2718446602rem + 1.9417475728vw, 7rem);
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .wpcf7cp-btns {
    flex-direction: column;
  }
}

button.wpcf7-form-control.wpcf7-submit.wpcf7cp-cfm-submit-btn {
  width: 300px;
  height: 60px;
  background: #BC699C;
  color: black;
  text-align: center;
  color: #ffffff;
  font-size: clamp(1.4rem, 1.3029126214rem + 0.2588996764vw, 1.8rem);
}

button.wpcf7-form-control.wpcf7cp-cfm-edit-btn {
  width: 300px;
  background: #fff;
  color: black;
  height: 60px;
  text-align: center;
  font-size: clamp(1.4rem, 1.3029126214rem + 0.2588996764vw, 1.8rem);
}

.agree-box p {
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
}

@media (max-width: 768px) {
  .wpcf7 .contact_form label,
.product-option p {
    flex-direction: column;
    align-items: flex-start;
  }
  .contact_form span.wpcf7-form-control-wrap {
    width: 100%;
  }
  input.btn {
    width: 100%;
  }
  span.title-contactform7 {
    margin-bottom: 5px;
  }
}
/* --- チェックボックス用 label は flex を適用しない --- */
.agree-box label {
  display: inline-flex;
  /* または block / inline-block でもOK */
  justify-content: flex-start;
  align-items: center;
}

/* チェックボックスのリセット */
input[type=checkbox] {
  width: 20px !important;
  height: 20px !important;
  padding: 0 !important;
  margin: 0 8px 0 0 !important;
  background: #ffffff !important;
}

/* 自然なチェックボックス */
.contact_form input[type=checkbox]#agree {
  appearance: auto !important;
  -webkit-appearance: checkbox !important;
  -moz-appearance: checkbox !important;
  width: 20px !important;
  height: 20px !important;
  margin: 0 8px 0 0 !important;
  cursor: pointer;
}

input#postcode {
  width: 33%;
}
/*# sourceMappingURL=style.css.map */