@charset "UTF-8";
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: normal;
  font-size: 100%;
  vertical-align: baseline;
}

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
  display: block;
}

ol,
ul {
  list-style: none;
}

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

a {
  color: inherit;
  text-decoration: none;
}

button {
  margin: 0;
  padding: 0;
  border: none;
  -webkit-box-shadow: none;
          box-shadow: none;
  background: transparent;
  cursor: pointer;
  font: inherit;
}

input,
select,
textarea {
  font: inherit;
  color: inherit;
  vertical-align: top;
}

input[type=submit],
input[type=button] {
  border-radius: 0px;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  cursor: pointer;
  background: transparent;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

.row.jc-center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.title-ja {
  opacity: 0;
}

.animate__slideInRight {
  opacity: 1;
}

.card__div {
  opacity: 0;
}

.animate__slideInRight {
  opacity: 1;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 63px;
}

body {
  line-height: 1.6;
  font-family: "Noto Sans JP", "sans-serif";
  color: #4a3636;
  font-size: 12px;
  background-color: #e9f6f8;
}

.inner {
  padding-inline: 20px;
  max-width: 375px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .inner {
    padding-inline: 40px;
    max-width: 1104px;
    margin-inline: auto;
  }
}

.button {
  height: 32px;
  padding: 4px 22px 4px 22px;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #fff;
  -webkit-box-shadow: 0px 6px 0px 0px #4a3636;
          box-shadow: 0px 6px 0px 0px #4a3636;
  color: #4a3636;
  font-size: 14px;
  font-weight: 700;
  white-space: nowrap;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
}
.button:hover {
  background: #ffee56;
}

.button2 {
  height: 40px;
  padding: 4px 22px 7px 22px;
  font-size: 16px;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
}
@media screen and (min-width: 960px) {
  .button2 {
    height: 56px;
    padding: 8px 38px 10px 38px;
    border: 3px solid #4a3636;
    font-size: 20px;
  }
}

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

.hidden-pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .hidden-pc {
    display: inline-block;
  }
}

@media screen and (min-width: 768px) {
  .dib-pc {
    display: inline-block;
  }
}

.title {
  position: relative;
}

.title-box {
  text-align: center;
}

.title-icon {
  width: 37.333px;
  display: inline-block;
}
@media screen and (min-width: 768px) {
  .title-icon {
    width: 48px;
  }
}

.title-en {
  font-family: "Courgette", "cursive";
  font-size: 16px;
  font-weight: 400;
  line-height: 1.25; /* 20px */
  padding-top: 1px;
}
@media screen and (min-width: 768px) {
  .title-en {
    font-size: 20px;
  }
}

.title-ja {
  font-family: "Kiwi Maru", "serif";
  font-size: 20px;
  font-weight: 500;
  line-height: 1.25; /* 25px */
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: inline-block;
  position: relative;
  padding-top: 6px;
  padding-bottom: 12px;
}
@media screen and (min-width: 768px) {
  .title-ja {
    font-size: 32px;
    padding-top: 8px;
    padding-bottom: 16px;
  }
}
.title-ja::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 6px;
  bottom: 0px;
  left: 0;
  background: #ffee56;
}
@media screen and (min-width: 768px) {
  .title-ja::after {
    height: 8px;
  }
}

.text-adress {
  font-weight: 400;
  text-decoration: underline;
  text-underline-offset: 1.5px;
}
.text-adress:hover {
  color: #67b0c7;
}

.inline {
  display: inline;
}

li {
  position: relative;
  padding-left: 18px;
  list-style: none;
}
@media screen and (min-width: 768px) {
  li {
    padding-left: 24px;
  }
}

li:before {
  content: "";
  position: absolute;
  top: 8px;
  left: 7.9px;
  width: 4px;
  height: 4px;
  background-color: #333;
  border-radius: 50%;
}
@media screen and (min-width: 768px) {
  li:before {
    top: 15px;
    left: 8px;
  }
}

.header {
  position: sticky;
  top: 0;
  left: 0;
  background-color: #fff;
  z-index: 999;
}

.header-inner {
  height: 63px;
  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;
  white-space: nowrap;
  padding-inline: 20px;
}
@media screen and (min-width: 768px) {
  .header-inner {
    height: 65px;
    padding-inline: 24px;
    max-width: 1512px;
    margin-inline: auto;
  }
}

.header-logo img {
  width: 210px;
}
@media screen and (min-width: 768px) {
  .header-logo img {
    width: 183px;
  }
}

.header-nav {
  display: none;
}
@media screen and (min-width: 768px) {
  .header-nav {
    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: 17.5px;
    margin-top: -5px;
  }
}

.header-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .header-list {
    padding-top: 4px;
  }
}

.header-item {
  font-size: 11px;
  font-weight: 400;
}
.header-item:hover {
  color: #67b0c7;
  text-decoration: underline;
  text-underline-offset: 1.5px;
}
@media screen and (min-width: 960px) {
  .header-item {
    font-size: 12px;
  }
}

@media screen and (min-width: 768px) {
  .header-btn {
    margin-top: 1px;
  }
}

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

.drawer-icon {
  width: 32px;
  height: 27px;
  z-index: 1;
  position: relative;
}
.drawer-icon.is-checked .drawer-icon__bar1 {
  width: 32px;
  top: 14px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.drawer-icon.is-checked .drawer-icon__bar2 {
  display: none;
}
.drawer-icon.is-checked .drawer-icon__bar3 {
  top: 14px;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.drawer-icon__bar1 {
  position: absolute;
  top: 0;
  left: 0;
  width: 25.6px;
  height: 3px;
  border-radius: 1.5px;
  background: #4a3636;
  -webkit-transition: top 0.3s linear, -webkit-transform 0.3s linear;
  transition: top 0.3s linear, -webkit-transform 0.3s linear;
  transition: transform 0.3s linear, top 0.3s linear;
  transition: transform 0.3s linear, top 0.3s linear, -webkit-transform 0.3s linear;
}

.drawer-icon__bar1-2 {
  position: absolute;
  top: 0;
  left: 27.2px;
  width: 4.8px;
  height: 3px;
  border-radius: 1.5px;
  background: #4a3636;
}

.drawer-icon__bar2 {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  width: 32px;
  height: 3px;
  border-radius: 1.5px;
  background: #4a3636;
}

.drawer-icon__bar3 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 32px;
  height: 3px;
  border-radius: 1.5px;
  background: #4a3636;
  -webkit-transition: top 0.3s linear, -webkit-transform 0.3s linear;
  transition: top 0.3s linear, -webkit-transform 0.3s linear;
  transition: transform 0.3s linear, top 0.3s linear;
  transition: transform 0.3s linear, top 0.3s linear, -webkit-transform 0.3s linear;
}

/*----------------------------------
    drawer
-----------------------------------*/
.drawer-content {
  z-index: 50;
  width: 100%;
  height: calc(100% - 63px);
  position: fixed;
  top: 63px;
  background: #fff;
  padding: 82px 114px;
  display: none;
  -webkit-transition: -webkit-transform 0.3s linear;
  transition: -webkit-transform 0.3s linear;
  transition: transform 0.3s linear;
  transition: transform 0.3s linear, -webkit-transform 0.3s linear;
  text-align: center;
}

.drawer-content__menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
}

.drawer-content__link {
  font-size: 14px;
}

.drawer-btn {
  margin-top: 3px;
}

.fv {
  background-color: #e9f6f8;
  padding-bottom: 156px;
}
@media screen and (min-width: 768px) {
  .fv {
    padding-bottom: 97px;
  }
}

.fv__inner {
  background: url(../img/sp/fv-sp.png) no-repeat center center/cover;
  padding-inline: 20px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .fv__inner {
    background: url(../img/pc/fv-pc.png) no-repeat center center/cover;
    height: 738px;
    padding-inline: 40px;
  }
}

.fv__title {
  margin-bottom: -32px;
}
.fv__title-text {
  padding-top: 18.1px;
  text-align: center;
  text-shadow: 0px 0px 30px #fff;
  font-family: "Kiwi Maru", "serif";
  font-size: 14px;
  font-weight: 400;
  line-height: 1.25; /* 17.5px */
}
@media screen and (min-width: 768px) {
  .fv__title-text {
    font-size: 24px;
    font-weight: 500;
    padding-top: 34px;
  }
}

.fv__title-img {
  text-align: center;
  margin-top: 21px;
}
@media screen and (min-width: 768px) {
  .fv__title-img {
    margin-top: 24px;
  }
}

.fv__title-img1 img {
  width: 335px;
}
@media screen and (min-width: 768px) {
  .fv__title-img1 img {
    width: 520px;
  }
}

.fv__title-img2 {
  margin-top: 12px;
}
@media screen and (min-width: 768px) {
  .fv__title-img2 {
    margin-top: 16px;
  }
}
.fv__title-img2 img {
  width: 240px;
}
@media screen and (min-width: 768px) {
  .fv__title-img2 img {
    width: 356px;
  }
}

.fv__contents__wrap {
  position: relative;
}

.fv__contents__main-img {
  position: absolute;
  bottom: -145px;
  position: relative;
  text-align: center;
  height: 408px;
  max-width: 375px;
  z-index: 1;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .fv__contents__main-img {
    bottom: -65px;
    height: 510px;
    max-width: 690px;
  }
}
@media screen and (min-width: 960px) {
  .fv__contents__main-img {
    max-width: 848px;
  }
}
.fv__contents__main-img .main-img {
  width: 200px;
}
@media screen and (min-width: 768px) {
  .fv__contents__main-img .main-img {
    width: 250px;
  }
}

.fv__contents__main-contain {
  width: 160px;
  position: absolute;
  inset-block: 0;
  inset-inline: 0;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin-inline: auto;
  top: 49.9%;
  -webkit-transform: translateY(-52.2%);
          transform: translateY(-52.2%);
  overflow: hidden;
  border-radius: 12.8px;
}
@media screen and (min-width: 768px) {
  .fv__contents__main-contain {
    width: 200px;
    top: 49.8%;
    border-radius: 16px;
  }
}

.main-contain__head {
  background: linear-gradient(265deg, #ac3790 -3.52%, #d65a5c 44.94%, #f4c06d 92.38%);
  padding: 5.5px 7px;
  color: #fff;
  text-align: center;
  font-weight: 700;
  font-size: 12.8px;
}
@media screen and (min-width: 768px) {
  .main-contain__head {
    font-size: 16px;
    padding: 8px 12px;
  }
}

.main-contain__body {
  background: #fff;
  padding-bottom: 18px;
  color: #4a3636;
}
@media screen and (min-width: 768px) {
  .main-contain__body {
    padding-block: 16px 24px;
  }
}

.mein-contain-text {
  position: relative;
  padding-top: 13px;
}
@media screen and (min-width: 768px) {
  .mein-contain-text {
    font-size: 14px;
    padding-top: 0;
  }
}
.mein-contain-text::after {
  content: "";
  position: absolute;
  width: 48px;
  height: 2.4px;
  bottom: -3.2px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background: #ce2073;
}
@media screen and (min-width: 768px) {
  .mein-contain-text::after {
    width: 56px;
    height: 4px;
    bottom: -4px;
  }
}

.main-contain-time {
  font-weight: 700;
  margin-top: 6.4px;
  margin-bottom: 17px;
}
@media screen and (min-width: 768px) {
  .main-contain-time {
    font-size: 16px;
    margin-top: 8px;
  }
}

.fv-btn {
  margin-bottom: 6px;
}
@media screen and (min-width: 768px) {
  .fv-btn {
    margin-top: 21px;
    margin-bottom: 8px;
  }
}

@media screen and (min-width: 768px) {
  .button-pc {
    height: 40px;
    padding: 4px 22px 7px 22px;
    font-size: 16px;
    -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
            box-shadow: 0px 4px 0px 0px #4a3636;
  }
}

.fv__content-imag__wrap {
  position: relative;
}

.fv__contents__img1 {
  position: absolute;
  top: -96px;
  left: -21.2%;
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
}
@media screen and (min-width: 768px) {
  .fv__contents__img1 {
    left: -22%;
    top: -32px;
  }
}
@media screen and (min-width: 960px) {
  .fv__contents__img1 {
    left: -10%;
    top: -32px;
  }
}
.fv__contents__img1 img {
  width: 142px;
  height: 80px;
}
@media screen and (min-width: 768px) {
  .fv__contents__img1 img {
    width: 244px;
    height: 130px;
  }
}

.fv__contents__img2 {
  position: absolute;
  top: -102px;
  right: 25px;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .fv__contents__img2 {
    right: -7%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: -16px;
  }
}
@media screen and (min-width: 960px) {
  .fv__contents__img2 {
    right: 4.3%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: -16px;
  }
}
.fv__contents__img2 img {
  width: 110px;
}
@media screen and (min-width: 768px) {
  .fv__contents__img2 img {
    width: 180px;
    height: 180px;
  }
}

.img-food-biscuit {
  position: absolute;
  bottom: -11px;
  left: 0px;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .img-food-biscuit {
    left: 0%;
    bottom: -15px;
  }
}
.img-food-biscuit img {
  width: 54.069px;
}
@media screen and (min-width: 768px) {
  .img-food-biscuit img {
    width: 127px;
  }
}

.img-food-drink {
  position: absolute;
  bottom: 5px;
  left: 43px;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .img-food-drink {
    left: 12%;
    bottom: 24px;
  }
}
.img-food-drink img {
  width: 47.257px;
}
@media screen and (min-width: 768px) {
  .img-food-drink img {
    width: 111px;
  }
}

.img-cats-chatora {
  position: absolute;
  bottom: -11.5px;
  right: 9px;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .img-cats-chatora {
    right: 0%;
    bottom: -58px;
  }
}
.img-cats-chatora img {
  width: 98px;
}
@media screen and (min-width: 768px) {
  .img-cats-chatora img {
    width: 233px;
  }
}

.img-cats-blackcat {
  position: absolute;
  bottom: 47px;
  right: 0px;
}
@media screen and (min-width: 768px) {
  .img-cats-blackcat {
    right: 7.5%;
    bottom: 45px;
  }
}
.img-cats-blackcat img {
  width: 62px;
}
@media screen and (min-width: 768px) {
  .img-cats-blackcat img {
    width: 170px;
  }
}

.about {
  padding-top: 32px;
  background-color: #e9f6f8;
  z-index: 1;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .about {
    padding-top: 80px;
  }
}

.about__inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  .about__inner {
    padding-inline: 114px;
    max-width: 1076px;
  }
}

.about__wrap {
  position: relative;
  background-color: #fff;
  padding-inline: 20px;
  padding-block: 39px 46px;
  text-align: center;
  border-radius: 24px;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .about__wrap {
    padding-inline: 35px;
    border-radius: 40px;
    padding-block: 41px 46px;
  }
}
@media screen and (min-width: 960px) {
  .about__wrap {
    padding-inline: 43px;
  }
}

.about__nikukyuu {
  position: absolute;
  right: 1px;
  top: -11px;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .about__nikukyuu {
    right: -4.4%;
    top: -82px;
  }
}
.about__nikukyuu img {
  width: 19.749px;
}
@media screen and (min-width: 768px) {
  .about__nikukyuu img {
    width: 39.572px;
  }
}

.about__nikukyuu2 {
  position: absolute;
  right: 0px;
  top: 22.43px;
}
@media screen and (min-width: 768px) {
  .about__nikukyuu2 {
    right: -5.1%;
    top: -23px;
  }
}
.about__nikukyuu2 img {
  width: 19.749px;
}
@media screen and (min-width: 768px) {
  .about__nikukyuu2 img {
    width: 39.572px;
  }
}

.about__nikukyuu3 {
  display: none;
}
@media screen and (min-width: 768px) {
  .about__nikukyuu3 {
    display: inline-block;
    position: absolute;
    right: 0.9%;
    top: 39px;
  }
}
.about__nikukyuu3 img {
  width: 19.749px;
}
@media screen and (min-width: 768px) {
  .about__nikukyuu3 img {
    width: 39.572px;
  }
}

.about__nikukyuu4 {
  display: none;
}
@media screen and (min-width: 768px) {
  .about__nikukyuu4 {
    display: inline-block;
    position: absolute;
    right: 0.5%;
    top: 99px;
  }
}
.about__nikukyuu4 img {
  width: 19.749px;
}
@media screen and (min-width: 768px) {
  .about__nikukyuu4 img {
    width: 39.572px;
  }
}

.about__syasenn {
  display: none;
}
@media screen and (min-width: 768px) {
  .about__syasenn {
    display: inline-block;
    position: absolute;
    top: -22px;
    left: -22.2%;
  }
}
.about__syasenn img {
  width: 250px;
}

.about__img-right {
  position: absolute;
  right: -140px;
  top: 273px;
}
@media screen and (min-width: 768px) {
  .about__img-right {
    right: -36.8%;
    top: 71px;
  }
}
@media screen and (min-width: 1280px) {
  .about__img-right {
    right: -46.8%;
    top: 71px;
  }
}
.about__img-right .about-img-r {
  width: 200px;
}
@media screen and (min-width: 768px) {
  .about__img-right .about-img-r {
    width: 480px;
  }
}

.about__img-left {
  position: absolute;
  left: -139px;
  top: 395px;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .about__img-left {
    left: -36.6%;
    top: 72px;
  }
}
@media screen and (min-width: 1280px) {
  .about__img-left {
    left: -51.6%;
    top: 72px;
  }
}
.about__img-left .about-img-l {
  width: 200px;
}
@media screen and (min-width: 768px) {
  .about__img-left .about-img-l {
    width: 480px;
  }
}

.about_title {
  padding-top: 1px;
}

.about__img1 {
  position: absolute;
  left: 4.5%;
  top: -9.23px;
}
@media screen and (min-width: 768px) {
  .about__img1 {
    left: 5.5%;
    top: -3.23px;
  }
}
.about__img1 img {
  width: 87.4px;
}
@media screen and (min-width: 768px) {
  .about__img1 img {
    width: 130px;
  }
}
@media screen and (min-width: 960px) {
  .about__img1 img {
    width: 146px;
  }
}

.about__img2 {
  position: absolute;
  right: 0%;
  top: -10px;
}
@media screen and (min-width: 768px) {
  .about__img2 {
    right: 5.68%;
    top: 1px;
  }
}
@media screen and (min-width: 768px) and (min-width: 960px) {
  .about__img2 {
    right: 5.68%;
    top: 5px;
  }
}
.about__img2 img {
  width: 87.6px;
}
@media screen and (min-width: 768px) {
  .about__img2 img {
    width: 130px;
  }
}
@media screen and (min-width: 960px) {
  .about__img2 img {
    width: 146px;
  }
}

.about__content {
  padding-top: 25px;
}
@media screen and (min-width: 768px) {
  .about__content {
    padding-top: 32px;
  }
}

.about__content-head {
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.55; /* 22.4px */
}
@media screen and (min-width: 768px) {
  .about__content-head {
    font-size: 16px;
    letter-spacing: -0.2px;
  }
}

.about-letter {
  padding-right: 1px;
  text-align: center;
  white-space: nowrap;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.55; /* 22.4px */
}
@media screen and (min-width: 768px) {
  .about-letter {
    font-size: 16px;
    letter-spacing: -0.2px;
  }
}

.about__content-text {
  padding-top: 23.5px;
  font-family: "Noto Sans JP", "sans-serif";
  font-size: 12px;
  font-weight: 400;
  line-height: 1.59;
}
@media screen and (min-width: 768px) {
  .about__content-text {
    font-size: 16px;
    padding-top: 33px;
    line-height: 1.63;
  }
}

.about__content-text-tag {
  font-weight: 700;
}

.about__content-foot {
  display: inline-block;
  padding-bottom: 5.5px;
  margin-top: 30.5px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  border-bottom: 2px dashed var(--lp-blue, #9ed0e0);
  font-weight: 700;
  font-size: 14px;
}
@media screen and (min-width: 375px) {
  .about__content-foot {
    font-size: 14px;
  }
}
@media screen and (min-width: 768px) {
  .about__content-foot {
    font-size: 20px;
    padding-bottom: 10.5px;
    margin-top: 43.5px;
  }
}

.about__button {
  margin-top: 31px;
  padding-bottom: 2px;
}
@media screen and (min-width: 768px) {
  .about__button {
    margin-top: 42px;
    padding-bottom: 8px;
  }
}

.about__img-area {
  position: relative;
}

.about__img-area__top {
  height: 177.87px;
}
@media screen and (min-width: 768px) {
  .about__img-area__top {
    height: 259px;
  }
}

.about__arrow {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.about__arrow img {
  width: 100px;
}
@media screen and (min-width: 768px) {
  .about__arrow img {
    width: 140px;
  }
}

.about__img-line {
  display: none;
}
.about__img-line img {
  width: 806.851px;
}
@media screen and (min-width: 768px) {
  .about__img-line {
    display: inline-block;
    position: absolute;
    top: -227.01px;
    right: -106%;
  }
}

.about__img-line2 {
  display: none;
}
.about__img-line2 img {
  width: 806.851px;
}
@media screen and (min-width: 768px) {
  .about__img-line2 {
    display: inline-block;
    position: absolute;
    top: -194.01px;
    right: -98%;
  }
}

.about__img-kaidan {
  position: absolute;
  top: -152px;
  left: -78px;
  width: 221px;
  height: 432px;
  z-index: 0;
  position: relative;
}
@media screen and (min-width: 480px) {
  .about__img-kaidan {
    top: -152px;
    left: -64.27%;
  }
}
@media screen and (min-width: 768px) {
  .about__img-kaidan {
    top: -508px;
    left: -51.27%;
    width: 427px;
    height: 433px;
  }
}
.about__img-kaidan img {
  width: 100%;
}
.about__img-kaidan::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 221px;
  height: 433px;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(68.58%, rgba(233, 246, 248, 0)), color-stop(80.78%, #e9f6f8));
  background: linear-gradient(180deg, rgba(233, 246, 248, 0) 68.58%, #e9f6f8 80.78%);
}
@media screen and (min-width: 768px) {
  .about__img-kaidan::after {
    display: none;
  }
}

.about__img-goods {
  position: absolute;
  right: 1px;
  top: 11.67px;
}
@media screen and (min-width: 768px) {
  .about__img-goods {
    right: -21.4%;
    top: -228.33px;
  }
}
.about__img-goods img {
  width: 48px;
}
@media screen and (min-width: 768px) {
  .about__img-goods img {
    width: 101px;
  }
}

.about__img-goods2 {
  position: absolute;
  top: 53.67px;
  right: 37px;
}
@media screen and (min-width: 768px) {
  .about__img-goods2 {
    top: -72.33px;
    right: -30.5%;
  }
}
.about__img-goods2 img {
  width: 133px;
}
@media screen and (min-width: 768px) {
  .about__img-goods2 img {
    width: 308px;
  }
}

.onomichi {
  position: absolute;
  bottom: 0px;
  inset-inline: 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .onomichi {
    bottom: -6px;
    padding-right: 5px;
  }
}
.onomichi img {
  width: 356px;
}
@media screen and (min-width: 768px) {
  .onomichi img {
    width: 892px;
  }
}

.js-swiper1 {
  padding-bottom: 32px;
}

.swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}

/* 画像のサイズ調整 */
.js-swiper1 .swiper-slide {
  width: 100px;
}
@media screen and (min-width: 960px) {
  .js-swiper1 .swiper-slide {
    width: 150px;
  }
}
@media screen and (min-width: 1280px) {
  .js-swiper1 .swiper-slide {
    width: 200px;
  }
}
.js-swiper1 .swiper-slide img {
  height: auto;
  width: 100px;
}
@media screen and (min-width: 960px) {
  .js-swiper1 .swiper-slide img {
    width: 150px;
  }
}
@media screen and (min-width: 1280px) {
  .js-swiper1 .swiper-slide img {
    width: 200px;
  }
}

.hou-to-enter {
  overflow: hidden;
  padding-block: 32px;
  position: relative;
  background-color: #e9f6f8;
}
@media screen and (min-width: 768px) {
  .hou-to-enter {
    padding-block: 84px;
  }
}

.hou-to-enter__map {
  width: 136px;
  position: absolute;
  z-index: 0;
}
@media screen and (min-width: 768px) {
  .hou-to-enter__map {
    width: 420px;
    top: 26px;
    left: 2.4%;
  }
}

.hou-to-enter__cat-tabby {
  width: 105px;
  position: absolute;
  right: 6.6%;
  top: 33px;
}
@media screen and (min-width: 480px) {
  .hou-to-enter__cat-tabby {
    right: 15.3%;
    top: 38px;
  }
}
@media screen and (min-width: 768px) {
  .hou-to-enter__cat-tabby {
    width: 153px;
    right: 15.3%;
    top: 58px;
  }
}
@media screen and (min-width: 960px) {
  .hou-to-enter__cat-tabby {
    width: 201px;
    right: 15.3%;
    top: 58px;
  }
}
@media screen and (min-width: 1280px) {
  .hou-to-enter__cat-tabby {
    width: 238px;
    right: 15.3%;
    top: 58px;
  }
}

.hou-to-enter__cat-gray {
  width: 94px;
  position: absolute;
  right: -8%;
  top: 37.5px;
}
@media screen and (min-width: 480px) {
  .hou-to-enter__cat-gray {
    right: 2.95%;
    top: 38px;
  }
}
@media screen and (min-width: 768px) {
  .hou-to-enter__cat-gray {
    width: 149px;
    right: 2.95%;
    top: 68px;
  }
}
@media screen and (min-width: 960px) {
  .hou-to-enter__cat-gray {
    width: 199px;
    right: 3.95%;
    top: 68px;
  }
}
@media screen and (min-width: 1280px) {
  .hou-to-enter__cat-gray {
    width: 214px;
    right: 6.95%;
    top: 68px;
  }
}

.hou-to-enter__nikukyuu__box1 {
  position: absolute;
  top: 105px;
  right: 10%;
}
@media screen and (min-width: 768px) {
  .hou-to-enter__nikukyuu__box1 {
    top: 233px;
    right: 5.3%;
  }
}

.nikukyuu__box1-1 {
  position: absolute;
  width: 20.115px;
  top: 1px;
  right: 14px;
}
@media screen and (min-width: 768px) {
  .nikukyuu__box1-1 {
    width: 36.572px;
    top: 1px;
    right: 14px;
  }
}

.nikukyuu__box1-2 {
  position: absolute;
  width: 20.115px;
  top: 33px;
  right: 18px;
}
@media screen and (min-width: 768px) {
  .nikukyuu__box1-2 {
    width: 36.572px;
    top: 62px;
    right: 19px;
  }
}

.nikukyuu__box1-3 {
  position: absolute;
  width: 20.115px;
  top: 67px;
  right: -18px;
}
@media screen and (min-width: 768px) {
  .nikukyuu__box1-3 {
    width: 36.572px;
    top: 121px;
    right: -44px;
  }
}

.nikukyuu__box1-4 {
  position: absolute;
  width: 20.115px;
  top: 100px;
  right: -15px;
}
@media screen and (min-width: 768px) {
  .nikukyuu__box1-4 {
    width: 36.572px;
    top: 183px;
    right: -38.2px;
  }
}

.hou-to-enter__nikukyuu__box2 {
  position: absolute;
  top: 571px;
  left: 6%;
}
@media screen and (min-width: 768px) {
  .hou-to-enter__nikukyuu__box2 {
    top: 655px;
    left: 2.75%;
  }
}

.nikukyuu__box2-1 {
  position: absolute;
  width: 20.115px;
  top: 10px;
  left: 0%;
}
@media screen and (min-width: 768px) {
  .nikukyuu__box2-1 {
    width: 36.572px;
    top: 10px;
    left: 0%;
  }
}

.nikukyuu__box2-2 {
  position: absolute;
  width: 20.115px;
  top: 43px;
  left: -2px;
}
@media screen and (min-width: 768px) {
  .nikukyuu__box2-2 {
    width: 36.572px;
    top: 72px;
    left: -5px;
  }
}

.nikukyuu__box2-3 {
  position: absolute;
  width: 20.115px;
  top: 77px;
  left: 32px;
}
@media screen and (min-width: 768px) {
  .nikukyuu__box2-3 {
    width: 36.572px;
    top: 131px;
    left: 58px;
  }
}

.nikukyuu__box2-4 {
  position: absolute;
  width: 20.115px;
  top: 108px;
  left: 30px;
}
@media screen and (min-width: 768px) {
  .nikukyuu__box2-4 {
    width: 36.572px;
    top: 192px;
    left: 52px;
  }
}

.hou-to-enter__nikukyuu__box3 {
  position: absolute;
  top: 910px;
  right: 6%;
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}
@media screen and (min-width: 768px) {
  .hou-to-enter__nikukyuu__box3 {
    display: none;
  }
}

.nikukyuu__box3-1 {
  position: absolute;
  width: 20.115px;
  top: 0px;
  left: 0%;
}

.nikukyuu__box3-2 {
  position: absolute;
  width: 20.115px;
  top: 34px;
  left: -3px;
}

.nikukyuu__box3-3 {
  position: absolute;
  width: 20.115px;
  top: 66px;
  left: 32px;
}

.nikukyuu__box3-4 {
  position: absolute;
  width: 20.115px;
  top: 100px;
  left: 29px;
}

.hou-to-enter__line {
  position: absolute;
  width: 8px;
  top: 565px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .hou-to-enter__line {
    display: none;
  }
}

.hou-to-enter__line2 {
  position: absolute;
  width: 8px;
  top: 959px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .hou-to-enter__line2 {
    display: none;
  }
}

.hou-to-enter__line-pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .hou-to-enter__line-pc img {
    width: 80px;
  }
}
@media screen and (min-width: 960px) {
  .hou-to-enter__line-pc img {
    width: 100px;
  }
}
@media screen and (min-width: 1280px) {
  .hou-to-enter__line-pc img {
    width: 113px;
  }
}
@media screen and (min-width: 768px) {
  .hou-to-enter__line-pc {
    display: block;
    position: absolute;
    top: 367px;
    left: 32%;
    z-index: 2;
  }
}
@media screen and (min-width: 960px) {
  .hou-to-enter__line-pc {
    display: block;
    position: absolute;
    top: 391px;
    left: 30%;
    z-index: 2;
  }
}
@media screen and (min-width: 1280px) {
  .hou-to-enter__line-pc {
    display: block;
    position: absolute;
    top: 391px;
    left: 26.6%;
    z-index: 2;
  }
}

.hou-to-enter__line-pc2 {
  display: none;
}
@media screen and (min-width: 768px) {
  .hou-to-enter__line-pc2 img {
    width: 80px;
  }
}
@media screen and (min-width: 960px) {
  .hou-to-enter__line-pc2 img {
    width: 100px;
  }
}
@media screen and (min-width: 1280px) {
  .hou-to-enter__line-pc2 img {
    width: 113px;
  }
}
@media screen and (min-width: 768px) {
  .hou-to-enter__line-pc2 {
    display: block;
    position: absolute;
    top: 367px;
    left: 59.3%;
    z-index: 2;
  }
}
@media screen and (min-width: 960px) {
  .hou-to-enter__line-pc2 {
    display: block;
    position: absolute;
    top: 391px;
    left: 59.3%;
    z-index: 2;
  }
}
@media screen and (min-width: 1280px) {
  .hou-to-enter__line-pc2 {
    display: block;
    position: absolute;
    top: 391px;
    left: 59.3%;
    z-index: 2;
  }
}

.hou-to-enter__inner {
  position: relative;
  z-index: 1;
  text-align: center;
}

@media screen and (min-width: 768px) {
  .title-en {
    padding-top: 3px;
  }
}

.hou-to-enter__title-ja {
  padding-top: 6.5px;
}
@media screen and (min-width: 768px) {
  .hou-to-enter__title-ja {
    padding-top: 8px;
  }
}

.step__boxes {
  margin-top: 31.5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 50px;
}
@media screen and (min-width: 768px) {
  .step__boxes {
    margin-top: 40px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 20px;
  }
}
@media screen and (min-width: 960px) {
  .step__boxes {
    gap: 33px;
  }
}
@media screen and (min-width: 1280px) {
  .step__boxes {
    gap: 33px;
  }
}

.step__box {
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
}
@media screen and (min-width: 768px) {
  .step__box {
    width: 230px;
    gap: 18px;
  }
}
@media screen and (min-width: 960px) {
  .step__box {
    width: 260px;
    gap: 20px;
  }
}
@media screen and (min-width: 1280px) {
  .step__box {
    width: 320px;
    gap: 25px;
  }
}

@media screen and (min-width: 768px) {
  .step__box2 {
    margin-top: 68px;
  }
}

.step__img {
  width: 196px;
}
@media screen and (min-width: 768px) {
  .step__img {
    width: 230px;
  }
}
@media screen and (min-width: 960px) {
  .step__img {
    width: 260px;
  }
}
@media screen and (min-width: 1280px) {
  .step__img {
    width: 280px;
  }
}

.step__title {
  font-size: 16px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .step__title {
    font-size: 16px;
  }
}
@media screen and (min-width: 960px) {
  .step__title {
    font-size: 18px;
  }
}
@media screen and (min-width: 1280px) {
  .step__title {
    font-size: 20px;
  }
}

.step__title3 {
  margin-left: 2px;
}
@media screen and (min-width: 768px) {
  .step__title3 {
    margin-top: 3px;
    margin-left: 0;
  }
}

.step__body {
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .step__body {
    font-size: 12px;
    line-height: 1.59;
    white-space: nowrap;
    margin-top: -7px;
  }
}
@media screen and (min-width: 960px) {
  .step__body {
    font-size: 14px;
    line-height: 1.59;
    white-space: nowrap;
    margin-top: -7px;
  }
}
@media screen and (min-width: 1280px) {
  .step__body {
    font-size: 16px;
    line-height: 1.59;
    white-space: nowrap;
    margin-top: -7px;
  }
}

.step__content-text-tag {
  font-family: "Noto Sans JP", "sans-serif";
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.3px;
}
@media screen and (min-width: 768px) {
  .step__content-text-tag {
    font-size: 12px;
    font-weight: 700;
  }
}
@media screen and (min-width: 960px) {
  .step__content-text-tag {
    font-size: 14px;
    font-weight: 700;
  }
}
@media screen and (min-width: 1280px) {
  .step__content-text-tag {
    font-size: 16px;
    font-weight: 700;
  }
}

@media screen and (min-width: 768px) {
  .step__body3 {
    margin-top: -4px;
  }
}

.step__follow {
  padding-block: 8px 4px;
  padding-inline: 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 8px;
  background: #fff;
}
@media screen and (min-width: 768px) {
  .step__follow {
    padding-block: 8px;
    padding-inline: 12px;
    margin-top: -7px;
  }
}

.step__box-icon {
  width: 20px;
}
@media screen and (min-width: 768px) {
  .step__box-icon {
    width: 24px;
    height: 24px;
  }
}

.step__follow-text {
  margin-top: -1px;
  font-size: 14px;
  font-weight: 700;
}
.step__follow-text:hover {
  color: #67b0c7;
  text-decoration: underline;
  text-underline-offset: 1.5px;
}
@media screen and (min-width: 768px) {
  .step__follow-text {
    font-size: 14px;
  }
}
@media screen and (min-width: 1280px) {
  .step__follow-text {
    font-size: 16px;
  }
}

.step__button {
  margin-top: 17px;
  margin-left: 1px;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .step__button {
    margin-top: 48px;
  }
}

.prizes {
  position: relative;
  overflow: hidden;
  padding-top: 88.67px;
  background-color: #e9f6f8;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .prizes {
    padding-top: 188px;
  }
}

.prizes__wrap {
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .prizes__wrap {
    padding-inline: 30px;
  }
}

.prizes__img-left {
  display: none;
}
@media screen and (min-width: 768px) {
  .prizes__img-left {
    display: block;
    position: absolute;
    top: -90px;
    left: -1.2%;
  }
}
@media screen and (min-width: 960px) {
  .prizes__img-left {
    top: -118px;
    left: 0.2%;
  }
}
.prizes__img-left img {
  width: 230px;
}
@media screen and (min-width: 960px) {
  .prizes__img-left img {
    width: 315px;
  }
}

.prizes__img-right {
  display: none;
}
@media screen and (min-width: 768px) {
  .prizes__img-right {
    display: block;
    position: absolute;
    top: -90px;
    right: -1.2%;
  }
}
@media screen and (min-width: 960px) {
  .prizes__img-right {
    top: -118px;
    right: 0.2%;
  }
}
.prizes__img-right img {
  width: 230px;
}
@media screen and (min-width: 960px) {
  .prizes__img-right img {
    width: 315px;
  }
}
@media screen and (min-width: 960px) {
  .prizes__img-right img {
    width: 315px;
  }
}

.prizes__inner {
  border-radius: 24px;
  background: #fff;
  position: relative;
  padding-top: 59.33px;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .prizes__inner {
    padding-top: 68.33px;
    max-width: 1024px;
  }
}

.prizes_title {
  position: absolute;
  top: -63px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .prizes_title {
    top: -117px;
    left: 50%;
  }
}
.prizes_title::before {
  content: "";
  position: absolute;
  display: inline-block;
  top: -20px;
  left: 54%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 238px;
  height: 83px;
  background: url("../img/prizes/device=SP head.png") no-repeat center center/cover; /* 画像のパスを指定 */
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .prizes_title::before {
    top: -31px;
    left: 50%;
    width: 354px;
    height: 148.97px;
    background: url("../img/prizes/device=PC head.png") no-repeat center center/cover; /* 画像のパスを指定 */
  }
}

.prizes__title-box {
  position: relative;
  z-index: 2;
}

.prizes__text-head__wrap {
  text-align: center;
}

.prizes__text-head {
  white-space: nowrap;
}
@media screen and (min-width: 375px) {
  .prizes__text-head {
    font-size: 12px;
  }
}
@media screen and (min-width: 768px) {
  .prizes__text-head {
    font-size: 16px;
    font-weight: 400;
    white-space: normal;
  }
}
@media screen and (min-width: 1280px) {
  .prizes__text-head {
    font-size: 16px;
  }
}

.prizes__card__wrap {
  margin-top: 47px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 768px) {
  .prizes__card__wrap {
    margin-top: 81px;
    gap: 32px;
  }
}

@media screen and (min-width: 768px) {
  .prizes__card__wrap2 {
    margin-top: 80px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 36px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.prizes__display {
  margin-top: 38px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15px;
}
@media screen and (min-width: 768px) {
  .prizes__display {
    display: contents;
  }
}

.card__div:hover .prizes__card::before {
  opacity: 1;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.card__div:hover .prizes__card-text__wrap-1-2::before {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='37' viewBox='0 0 36 37' fill='none'%3E%3Cpath d='M36.0001 0.333252V36.3333H0L36.0001 0.333252Z' fill='%239ed0e0'/%3E%3C/svg%3E") no-repeat center center/cover;
  -webkit-transition: background 0.3s;
  transition: background 0.3s;
}
.card__div:hover .prizes__card-text__wrap-3-5::before {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='37' viewBox='0 0 36 37' fill='none'%3E%3Cpath d='M36.0001 0.333252V36.3333H0L36.0001 0.333252Z' fill='%239ed0e0'/%3E%3C/svg%3E") no-repeat center center/cover;
  -webkit-transition: background 0.3s;
  transition: background 0.3s;
}
.card__div:hover .prizes__card-img {
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.card__div-1-2 {
  position: relative;
  width: 160px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 768px) {
  .card__div-1-2 {
    width: 440px;
  }
}

.card__div-3-5 {
  position: relative;
  width: 160px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 768px) {
  .card__div-3-5 {
    width: 280px;
  }
}

.card-div5 {
  margin-top: 39px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .card-div5 {
    margin-inline: 0;
    margin-top: 0;
  }
}

.prizes__card-head-1-2 {
  position: absolute;
  top: -9%;
  -webkit-transform: translateY(50%);
          transform: translateY(50%);
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .prizes__card-head-1-2 {
    top: -8.5%;
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.prizes__card-head-1-2::before {
  content: "";
  position: absolute;
  display: inline-block;
  width: 47px;
  height: 47px;
  z-index: -1;
  background: url("../img/prizes/Star 1.png") no-repeat center center/cover; /* 画像のパスを指定 */
}
@media screen and (min-width: 768px) {
  .prizes__card-head-1-2::before {
    width: 90px;
    height: 90px;
  }
}
@media screen and (min-width: 960px) {
  .prizes__card-head-1-2::before {
    width: 100px;
    height: 100px;
  }
}

.prizes__card-head-text-1-2 {
  color: #fff;
  font-size: 7.68px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .prizes__card-head-text-1-2 {
    font-size: 14px;
  }
}
@media screen and (min-width: 960px) {
  .prizes__card-head-text-1-2 {
    font-size: 16px;
  }
}

.prizes__card-head-text2-1-2 {
  color: #fff;
  margin-top: 2px;
  font-family: Josefin Sans;
  font-size: 23.04px;
  font-weight: 700;
  line-height: 1; /* 23.04px */
}
@media screen and (min-width: 768px) {
  .prizes__card-head-text2-1-2 {
    font-size: 38px;
  }
}
@media screen and (min-width: 960px) {
  .prizes__card-head-text2-1-2 {
    font-size: 48px;
  }
}

.prizes__card-head-3-5 {
  position: absolute;
  top: -9%;
  -webkit-transform: translateY(50%);
          transform: translateY(50%);
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .prizes__card-head-3-5 {
    top: -9%;
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.prizes__card-head-3-5::before {
  content: "";
  position: absolute;
  display: inline-block;
  width: 47px;
  height: 47px;
  z-index: -1;
  background: url("../img/prizes/Star 1.png") no-repeat center center/cover; /* 画像のパスを指定 */
}
@media screen and (min-width: 768px) {
  .prizes__card-head-3-5::before {
    width: 70px;
    height: 70px;
  }
}
@media screen and (min-width: 960px) {
  .prizes__card-head-3-5::before {
    width: 80px;
    height: 80px;
  }
}

.prizes__card-head-text-3-5 {
  color: #fff;
  font-size: 7.68px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .prizes__card-head-text-3-5 {
    font-size: 10.8px;
  }
}
@media screen and (min-width: 768px) {
  .prizes__card-head-text-3-5 {
    font-size: 12.8px;
  }
}

.prizes__card-head-text2-3-5 {
  color: #fff;
  margin-top: 1px;
  font-family: Josefin Sans;
  font-size: 23.04px;
  font-weight: 700;
  line-height: 1; /* 23.04px */
}
@media screen and (min-width: 768px) {
  .prizes__card-head-text2-3-5 {
    font-size: 28.4px;
  }
}
@media screen and (min-width: 960px) {
  .prizes__card-head-text2-3-5 {
    font-size: 38.4px;
  }
}

.card__div-pc__1-2 {
  overflow: hidden;
  position: relative;
  border-radius: 8px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 768px) {
  .card__div-pc__1-2 {
    border-radius: 24px;
  }
}
.card__div-pc__1-2::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 5px solid #9ed0e0;
  width: 100%;
  height: 100%;
  content: "";
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  z-index: 1;
  border-radius: 8px;
}
@media screen and (min-width: 768px) {
  .card__div-pc__1-2::before {
    border-radius: 24px;
  }
}

.card__div-pc__3-5 {
  overflow: hidden;
  position: relative;
  border-radius: 8px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 768px) {
  .card__div-pc__3-5 {
    border-radius: 16px;
  }
}
.card__div-pc__3-5::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 5px solid #9ed0e0;
  width: 100%;
  height: 100%;
  content: "";
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  z-index: 1;
  border-radius: 8px;
}
@media screen and (min-width: 768px) {
  .card__div-pc__3-5::before {
    border-radius: 16px;
  }
}

.card__img-1-2 img {
  width: 160px;
}
@media screen and (min-width: 768px) {
  .card__img-1-2 img {
    width: 440px;
    height: auto;
    aspect-ratio: 22/17;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.card__img-3-5 img {
  width: 160px;
}
@media screen and (min-width: 768px) {
  .card__img-3-5 img {
    width: 280px;
    height: auto;
    aspect-ratio: 7/6;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.prizes__card-text__wrap-1-2 {
  background-color: #f5f5f5;
  padding-block: 9.5px 8.5px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
}
@media screen and (min-width: 768px) {
  .prizes__card-text__wrap-1-2 {
    padding-block: 28px;
  }
}
.prizes__card-text__wrap-1-2::before {
  content: "";
  position: absolute;
  display: inline-block;
  bottom: 0;
  right: 0;
  width: 36px;
  height: 36px;
  z-index: 1;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='37' viewBox='0 0 36 37' fill='none'%3E%3Cpath d='M36.0001 0.333252V36.3333H0L36.0001 0.333252Z' fill='%2367B0C7'/%3E%3C/svg%3E") no-repeat center center/cover; /* 画像のパスを指定 */
}
@media screen and (min-width: 768px) {
  .prizes__card-text__wrap-1-2::before {
    width: 100px;
    height: 100px;
  }
}
.prizes__card-text__wrap-1-2::after {
  content: "";
  position: absolute;
  display: inline-block;
  bottom: 6.12px;
  right: 5.22px;
  width: 11.52px;
  height: 11.52px;
  z-index: 1;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='13' viewBox='0 0 12 13' fill='none'%3E%3Cg clip-path='url(%23clip0_20083_126)'%3E%3Cpath d='M7.51615 5.60568C7.51615 5.77524 7.44879 5.93786 7.3289 6.05776C7.209 6.17766 7.04639 6.24502 6.87683 6.24502H5.81129V7.31058C5.81129 7.48014 5.74394 7.64276 5.62404 7.76265C5.50415 7.88255 5.34153 7.94991 5.17197 7.94991C5.00241 7.94991 4.8398 7.88255 4.7199 7.76265C4.60001 7.64276 4.53265 7.48014 4.53265 7.31058V6.24502H3.46712C3.29756 6.24502 3.13495 6.17766 3.01505 6.05776C2.89515 5.93786 2.8278 5.77524 2.8278 5.60568C2.8278 5.43612 2.89515 5.2735 3.01505 5.1536C3.13495 5.0337 3.29756 4.96635 3.46712 4.96635H4.53265V3.90079C4.53265 3.73122 4.60001 3.56861 4.7199 3.44871C4.8398 3.32881 5.00241 3.26145 5.17197 3.26145C5.34153 3.26145 5.50415 3.32881 5.62404 3.44871C5.74394 3.56861 5.81129 3.73122 5.81129 3.90079V4.96635H6.87683C7.04639 4.96635 7.209 5.0337 7.3289 5.1536C7.44879 5.2735 7.51615 5.43612 7.51615 5.60568ZM11.5913 12.0251C11.5319 12.0847 11.4613 12.132 11.3836 12.1643C11.3059 12.1966 11.2226 12.2132 11.1384 12.2132C11.0543 12.2132 10.971 12.1966 10.8933 12.1643C10.8156 12.132 10.745 12.0847 10.6856 12.0251L8.15547 9.49497C7.1669 10.2536 5.92679 10.6078 4.6867 10.4857C3.4466 10.3636 2.29938 9.77431 1.47776 8.83744C0.656136 7.90057 0.221634 6.68624 0.262394 5.44079C0.303154 4.19533 0.816124 3.01201 1.69724 2.13087C2.57837 1.24973 3.76166 0.736749 5.00708 0.695988C6.25251 0.655227 7.46681 1.08974 8.40366 1.91138C9.3405 2.73302 9.92975 3.88027 10.0519 5.12039C10.174 6.36052 9.81978 7.60066 9.06117 8.58925L11.5939 11.1215C11.7133 11.2418 11.7801 11.4045 11.7796 11.5739C11.7791 11.7433 11.7114 11.9056 11.5913 12.0251ZM5.17197 9.22858C5.8885 9.22858 6.58893 9.0161 7.1847 8.61801C7.78047 8.21992 8.24482 7.6541 8.51902 6.99211C8.79322 6.33011 8.86497 5.60166 8.72518 4.89889C8.58539 4.19611 8.24035 3.55058 7.73369 3.0439C7.22703 2.53723 6.58151 2.19218 5.87875 2.05239C5.17599 1.9126 4.44756 1.98435 3.78558 2.25856C3.1236 2.53277 2.55779 2.99712 2.15971 3.5929C1.76163 4.18869 1.54916 4.88914 1.54916 5.60568C1.55028 6.56619 1.93233 7.48703 2.6115 8.16621C3.29067 8.8454 4.21149 9.22746 5.17197 9.22858Z' fill='%23F5F5F5'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0_20083_126'%3E%3Crect width='11.5198' height='11.5198' fill='white' transform='translate(0.259766 0.693359)'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E") no-repeat center center/cover; /* 画像のパスを指定 */
}
@media screen and (min-width: 768px) {
  .prizes__card-text__wrap-1-2::after {
    bottom: 14.12px;
    right: 2.9%;
    width: 32px;
    height: 32px;
  }
}

.prizes__card-text__wrap-3-5 {
  background-color: #f5f5f5;
  padding-block: 9.5px 8.5px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
}
@media screen and (min-width: 768px) {
  .prizes__card-text__wrap-3-5 {
    padding-block: 14px;
  }
}
.prizes__card-text__wrap-3-5::before {
  content: "";
  position: absolute;
  display: inline-block;
  bottom: 0;
  right: 0;
  width: 36px;
  height: 36px;
  z-index: 1;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='37' viewBox='0 0 36 37' fill='none'%3E%3Cpath d='M36.0001 0.333252V36.3333H0L36.0001 0.333252Z' fill='%2367B0C7'/%3E%3C/svg%3E") no-repeat center center/cover; /* 画像のパスを指定 */
}
@media screen and (min-width: 768px) {
  .prizes__card-text__wrap-3-5::before {
    width: 64px;
    height: 64px;
  }
}
.prizes__card-text__wrap-3-5::after {
  content: "";
  position: absolute;
  display: inline-block;
  bottom: 6.12px;
  right: 5.22px;
  width: 11.52px;
  height: 11.52px;
  z-index: 1;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='13' viewBox='0 0 12 13' fill='none'%3E%3Cg clip-path='url(%23clip0_20083_126)'%3E%3Cpath d='M7.51615 5.60568C7.51615 5.77524 7.44879 5.93786 7.3289 6.05776C7.209 6.17766 7.04639 6.24502 6.87683 6.24502H5.81129V7.31058C5.81129 7.48014 5.74394 7.64276 5.62404 7.76265C5.50415 7.88255 5.34153 7.94991 5.17197 7.94991C5.00241 7.94991 4.8398 7.88255 4.7199 7.76265C4.60001 7.64276 4.53265 7.48014 4.53265 7.31058V6.24502H3.46712C3.29756 6.24502 3.13495 6.17766 3.01505 6.05776C2.89515 5.93786 2.8278 5.77524 2.8278 5.60568C2.8278 5.43612 2.89515 5.2735 3.01505 5.1536C3.13495 5.0337 3.29756 4.96635 3.46712 4.96635H4.53265V3.90079C4.53265 3.73122 4.60001 3.56861 4.7199 3.44871C4.8398 3.32881 5.00241 3.26145 5.17197 3.26145C5.34153 3.26145 5.50415 3.32881 5.62404 3.44871C5.74394 3.56861 5.81129 3.73122 5.81129 3.90079V4.96635H6.87683C7.04639 4.96635 7.209 5.0337 7.3289 5.1536C7.44879 5.2735 7.51615 5.43612 7.51615 5.60568ZM11.5913 12.0251C11.5319 12.0847 11.4613 12.132 11.3836 12.1643C11.3059 12.1966 11.2226 12.2132 11.1384 12.2132C11.0543 12.2132 10.971 12.1966 10.8933 12.1643C10.8156 12.132 10.745 12.0847 10.6856 12.0251L8.15547 9.49497C7.1669 10.2536 5.92679 10.6078 4.6867 10.4857C3.4466 10.3636 2.29938 9.77431 1.47776 8.83744C0.656136 7.90057 0.221634 6.68624 0.262394 5.44079C0.303154 4.19533 0.816124 3.01201 1.69724 2.13087C2.57837 1.24973 3.76166 0.736749 5.00708 0.695988C6.25251 0.655227 7.46681 1.08974 8.40366 1.91138C9.3405 2.73302 9.92975 3.88027 10.0519 5.12039C10.174 6.36052 9.81978 7.60066 9.06117 8.58925L11.5939 11.1215C11.7133 11.2418 11.7801 11.4045 11.7796 11.5739C11.7791 11.7433 11.7114 11.9056 11.5913 12.0251ZM5.17197 9.22858C5.8885 9.22858 6.58893 9.0161 7.1847 8.61801C7.78047 8.21992 8.24482 7.6541 8.51902 6.99211C8.79322 6.33011 8.86497 5.60166 8.72518 4.89889C8.58539 4.19611 8.24035 3.55058 7.73369 3.0439C7.22703 2.53723 6.58151 2.19218 5.87875 2.05239C5.17599 1.9126 4.44756 1.98435 3.78558 2.25856C3.1236 2.53277 2.55779 2.99712 2.15971 3.5929C1.76163 4.18869 1.54916 4.88914 1.54916 5.60568C1.55028 6.56619 1.93233 7.48703 2.6115 8.16621C3.29067 8.8454 4.21149 9.22746 5.17197 9.22858Z' fill='%23F5F5F5'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0_20083_126'%3E%3Crect width='11.5198' height='11.5198' fill='white' transform='translate(0.259766 0.693359)'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E") no-repeat center center/cover; /* 画像のパスを指定 */
}
@media screen and (min-width: 768px) {
  .prizes__card-text__wrap-3-5::after {
    bottom: 9.12px;
    right: 3.1%;
    width: 20.48px;
    height: 20.48px;
  }
}

.prizes__card-text-1-2 {
  color: #4a3636;
  font-weight: 700;
  background-color: #f5f5f5;
}
@media screen and (min-width: 768px) {
  .prizes__card-text-1-2 {
    font-size: 20px;
    font-weight: 700;
  }
}

.prizes__card-text-3-5 {
  color: #4a3636;
  font-weight: 700;
  background-color: #f5f5f5;
}
@media screen and (min-width: 768px) {
  .prizes__card-text-3-5 {
    font-size: 16px;
    font-weight: 700;
  }
}

.prizes__button {
  text-align: center;
  margin-top: 18px;
  padding-bottom: 35px;
}
@media screen and (min-width: 768px) {
  .prizes__button {
    margin-top: 39px;
    padding-bottom: 54px;
  }
}

.prizes__img-wrap {
  position: relative;
  z-index: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: -45px;
}
@media screen and (min-width: 768px) {
  .prizes__img-wrap {
    margin-top: 0px;
  }
}

.prizes-img {
  display: block;
  width: 100%;
  min-width: 580px;
  position: relative;
  z-index: 5;
}

/* モーダルCSS */
.modalArea {
  display: none;
  position: fixed;
  z-index: 999; /*サイトによってここの数値は調整 */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.modalBg {
  width: 100%;
  height: 100%;
  background-color: rgba(30, 30, 30, 0.9);
}

.modalWrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 24px;
  overflow: hidden;
}

.modal__img {
  width: 336px;
}
@media screen and (min-width: 768px) {
  .modal__img {
    width: 480px;
  }
}
.modal__img img {
  width: 100%;
}

.modal__text {
  padding-inline: 20px;
  padding-block: 36px 56px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .modal__text {
    padding-block: 32px 54px;
  }
}

.modal__head {
  color: #4a3636;
  font-size: 16px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .modal__head {
    font-size: 20px;
  }
}

.modal__body {
  margin-top: 12px;
  color: #000;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .modal__body {
    font-size: 16px;
    font-weight: 400;
  }
}

.js-modal-close {
  cursor: pointer;
  text-align: center;
  margin-top: 16px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .js-modal-close {
    margin-top: 24px;
  }
}

.spots {
  overflow: hidden;
  position: relative;
  z-index: 10;
  padding-top: 0px;
  margin-bottom: -1px;
  margin-top: -45.714px;
}
@media screen and (min-width: 768px) {
  .spots {
    padding-bottom: 0px;
    margin-top: -120px;
  }
}

.spots__nikukyuu {
  display: none;
  position: absolute;
  bottom: 119px;
  left: 2.4%;
  z-index: 2;
}
@media screen and (min-width: 960px) {
  .spots__nikukyuu {
    display: block;
  }
}
.spots__nikukyuu img {
  width: 70px;
}
@media screen and (min-width: 1280px) {
  .spots__nikukyuu img {
    width: 100px;
  }
}

.wave {
  width: 100%;
  z-index: 2;
}
.wave2 {
  width: 100%;
}

.spots__inner {
  position: relative;
  background: #67b0c7;
  margin-top: -1px;
  padding-top: 1px;
  margin-bottom: -1px;
  padding-bottom: 5px;
  padding-bottom: 21.84px;
}
@media screen and (min-width: 768px) {
  .spots__inner {
    padding-bottom: 3px;
  }
}

.spots__wrap {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 768px) {
  .spots__wrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.spots__head {
  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: 8px;
}
@media screen and (min-width: 768px) {
  .spots__head {
    -webkit-writing-mode: vertical-lr;
        -ms-writing-mode: tb-lr;
            writing-mode: vertical-lr;
    text-align: center;
    padding-left: 16.1375661376%;
    gap: 13px;
  }
}

@media screen and (min-width: 768px) {
  .spots__head-img {
    width: 56px;
  }
  .spots__head-img img {
    width: 100%;
  }
}

.spots__head-text {
  color: #fff;
  font-family: "Kiwi Maru", "serif";
  font-size: 28px;
  font-weight: 500;
  line-height: 1.25; /* 35px */
}
@media screen and (min-width: 768px) {
  .spots__head-text {
    font-size: 40px;
    letter-spacing: 10px;
  }
}

@media screen and (min-width: 768px) {
  .trans-pc {
    display: inline-block;
    -webkit-transform: translateX(-6px);
            transform: translateX(-6px);
    margin-top: 4px;
  }
}

.slide__container .swiper-slide {
  width: 240px !important;
}
@media screen and (min-width: 768px) {
  .slide__container .swiper-slide {
    width: 344px !important;
  }
}

.spots__card {
  height: 100%;
  border-radius: 12px;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 768px) {
  .spots__card {
    border-radius: 24px;
  }
}

.spots__card-img {
  aspect-ratio: 4/3;
  width: 240px;
}
@media screen and (min-width: 768px) {
  .spots__card-img {
    aspect-ratio: 43/30;
    width: 344px;
  }
}
.spots__card-img img {
  width: 100%;
  height: 100%;
}

.spots__card-text__wrap {
  height: 222px;
  background-color: #fff;
  padding-block: 16px 31.16px;
  padding-inline: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
@media screen and (min-width: 768px) {
  .spots__card-text__wrap {
    height: 302px;
    padding-block: 24px 40px;
    gap: 24px;
    padding-inline: 34px;
  }
}

.spots__card-title {
  text-align: center;
  color: #4a3636;
  font-size: 16px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .spots__card-title {
    font-size: 20px;
  }
}

.spots__card-text {
  color: #4a3636;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .spots__card-text {
    font-size: 16px;
  }
}

.spots__footer {
  margin-inline: auto;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .spots__footer {
    margin-top: 65px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    max-width: 1030px;
    padding-inline: 40px;
  }
}
@media screen and (min-width: 1280px) {
  .spots__footer {
    max-width: 1104px;
    padding-inline: 40px;
  }
}

.spots-img {
  width: 255px;
}
@media screen and (min-width: 768px) {
  .spots-img {
    width: 395px;
  }
}
@media screen and (min-width: 960px) {
  .spots-img {
    width: 430px;
  }
}
@media screen and (min-width: 1280px) {
  .spots-img {
    width: 495px;
  }
}

.spots__footer-body {
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .spots__footer-body {
    margin-top: 0;
  }
}

.spots-text {
  color: #fff;
  font-size: 11.444px;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .spots-text {
    font-size: 14px;
  }
}
@media screen and (min-width: 960px) {
  .spots-text {
    font-size: 15px;
  }
}
@media screen and (min-width: 1280px) {
  .spots-text {
    font-size: 16px;
  }
}

.spots__button {
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .spots__button {
    margin-left: 12px;
  }
}

.p-swiper__spots {
  position: relative;
}

.slide__container {
  position: relative;
  width: 100%;
  padding-top: 24px;
}
@media screen and (min-width: 768px) {
  .slide__container {
    padding-top: 0;
    margin-left: 32px;
  }
}

.swiper-container {
  overflow: hidden;
  position: relative;
}
.swiper__button-wrap {
  max-width: 883px;
  width: 58.3vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}

.swiper-button-prev {
  display: none;
}
@media screen and (min-width: 768px) {
  .swiper-button-prev {
    position: absolute;
    top: -5px;
    left: 0;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    display: block;
  }
  .swiper-button-prev::before {
    content: "";
    position: absolute;
    width: 70px;
    left: -200%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 23%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    border-radius: 50%;
    background-color: #ffee56;
    aspect-ratio: 1/1;
  }
}
@media screen and (min-width: 768px) and (min-width: 960px) {
  .swiper-button-prev::before {
    width: 80px;
    left: -128%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 23%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@media screen and (min-width: 768px) {
  .swiper-button-prev::after {
    content: "";
    position: absolute;
    width: 20px;
    left: -80%;
    aspect-ratio: 1/1;
    border-right: 5px solid #9ed0e0;
    border-bottom: 5px solid #9ed0e0;
    -webkit-transform: rotate(135deg);
            transform: rotate(135deg);
  }
}
@media screen and (min-width: 768px) and (min-width: 960px) {
  .swiper-button-prev::after {
    left: 0;
  }
}

.swiper-button-next {
  display: none;
}
@media screen and (min-width: 768px) {
  .swiper-button-next {
    top: -5px;
    right: 0;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    display: block;
  }
  .swiper-button-next::before {
    content: "";
    position: absolute;
    right: -105%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 23%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 70px;
    border-radius: 50%;
    background-color: #ffee56;
    aspect-ratio: 1/1;
  }
}
@media screen and (min-width: 768px) and (min-width: 960px) {
  .swiper-button-next::before {
    right: -105%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    top: 23%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 80px;
  }
}
@media screen and (min-width: 768px) {
  .swiper-button-next::after {
    content: "";
    position: absolute;
    right: 0%;
    width: 20px;
    aspect-ratio: 1/1;
    border-right: 5px solid #9ed0e0;
    border-bottom: 5px solid #9ed0e0;
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
  }
}
@media screen and (min-width: 768px) and (min-width: 960px) {
  .swiper-button-next::after {
    right: 0;
  }
}

.qa {
  margin-top: -29.775px;
  padding-top: 71.775px;
  background: #e9f6f8;
}
@media screen and (min-width: 768px) {
  .qa {
    margin-top: -29.775px;
    padding-top: 151.775px;
  }
}

.qa__boxes {
  margin-top: 23px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 11.5px;
}
@media screen and (min-width: 768px) {
  .qa__boxes {
    margin-top: 40px;
    gap: 24px;
  }
}

.qa__box {
  border-radius: 12px;
  border: 2px solid #4a3636;
  background: #fff;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .qa__box {
    border-radius: 16px;
  }
}
.qa__box.is-open .qa__img::after {
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}

.qa-box__head {
  text-align: left;
  width: 100%;
  padding-inline: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .qa-box__head {
    padding-inline: 22px;
    gap: 16px;
  }
}

.qa-box-1 {
  padding-block: 11px 11px;
}
@media screen and (min-width: 768px) {
  .qa-box-1 {
    padding-block: 24px 23px;
  }
}

.qa-box-2 {
  padding-block: 11px 9px;
}
@media screen and (min-width: 768px) {
  .qa-box-2 {
    padding-block: 23px 26px;
  }
}

.qa-box-3 {
  padding-block: 11px 9px;
}
@media screen and (min-width: 768px) {
  .qa-box-3 {
    padding-block: 24px 22px;
  }
}

.qa-box-4 {
  padding-block: 11px 9px;
}
@media screen and (min-width: 768px) {
  .qa-box-4 {
    padding-block: 24px 22px;
  }
}

.qa-box__icon {
  margin-top: 2px;
  color: #9ed0e0;
  font-family: "Josefin Sans", "sans-serif";
  font-size: 24px;
  font-weight: 400;
  line-height: 1.25; /* 30px */
}
@media screen and (min-width: 768px) {
  .qa-box__icon {
    font-size: 32px;
  }
}

.qa-box__head-text {
  font-size: 14px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .qa-box__head-text {
    font-size: 20px;
    font-weight: 700;
  }
}

.qa__img {
  position: absolute;
  top: 6px;
  -webkit-transform: translateY(50%);
          transform: translateY(50%);
  right: 4%;
  width: 27.182px;
}
.qa__img img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .qa__img {
    width: 48px;
    top: -1px;
    right: 2%;
  }
}
.qa__img::before {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 9px;
  width: 9.5px;
  height: 1.2px;
  background: #fff;
}
@media screen and (min-width: 768px) {
  .qa__img::before {
    top: 47%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    left: 15px;
    width: 18.5px;
    height: 2.2px;
  }
}
.qa__img::after {
  content: "";
  position: absolute;
  top: 8.3px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 1.2px;
  height: 9.4px;
  background: #fff;
  -webkit-transition: top 0.3s linear, -webkit-transform 0.3s linear;
  transition: top 0.3s linear, -webkit-transform 0.3s linear;
  transition: transform 0.3s linear, top 0.3s linear;
  transition: transform 0.3s linear, top 0.3s linear, -webkit-transform 0.3s linear;
}
@media screen and (min-width: 768px) {
  .qa__img::after {
    top: 12.3px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 2.2px;
    height: 18.5px;
  }
}

.qa-box__body {
  background: #f5f5f5;
  padding-inline: 14.5px;
  padding-block: 15px 14px;
  display: none;
}
@media screen and (min-width: 768px) {
  .qa-box__body {
    padding-inline: 22px;
    padding-block: 24px 22px;
  }
}

.qa-box__a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
}

.qa-box__a-text {
  font-size: 14px;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .qa-box__a-text {
    font-size: 16px;
  }
}

.entry {
  padding-top: 31px;
  padding-bottom: 32px;
  background: #e9f6f8;
}
@media screen and (min-width: 768px) {
  .entry {
    padding-top: 120px;
    padding-bottom: 120px;
  }
}

.entry__wrap {
  padding-top: 17px;
  border: 8px solid #fff;
  background: rgba(255, 255, 255, 0.5);
  padding-inline: 15.5px;
}
@media screen and (min-width: 768px) {
  .entry__wrap {
    padding-top: 35px;
    padding-inline: 48px;
  }
}

.entry__table {
  border-collapse: collapse;
  margin-top: 12px;
  width: 100%;
  table-layout: fixed;
}
@media screen and (min-width: 768px) {
  .entry__table {
    margin-top: 32px;
  }
}

.table__title-text {
  text-align: start;
  padding-left: 16px;
  font-size: 14px;
  font-weight: 700;
  position: relative;
}
@media screen and (min-width: 768px) {
  .table__title-text {
    font-size: 16px;
    min-width: 180px;
    padding-left: 32px;
  }
}
@media screen and (min-width: 768px) and (min-width: 960px) {
  .table__title-text {
    font-size: 16px;
    min-width: 240px;
    padding-left: 32px;
  }
}
.table__title-text::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  top: 45%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0px;
  background: #9ed0e0;
}
@media screen and (min-width: 768px) {
  .table__title-text::before {
    top: 45%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 17px;
  }
}

.table__text {
  font-weight: 400;
  margin-top: 8px;
  padding-bottom: 14.5px;
  line-height: 1.58;
}
@media screen and (min-width: 768px) {
  .table__text {
    padding-bottom: 0px;
    margin-top: 0;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.62; /* 25.6px */
  }
}

.table__text-area {
  font-weight: 400;
  margin-top: 8px;
  padding-bottom: 15px;
  line-height: 1.585;
}
@media screen and (min-width: 768px) {
  .table__text-area {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.625; /* 25.6px */
    margin-top: 0;
  }
}

.table__title,
.table__text,
.table__text-area {
  display: block;
}
@media screen and (min-width: 768px) {
  .table__title,
  .table__text,
  .table__text-area {
    display: inline-block;
  }
}

.entry__table tr {
  margin-top: 12px;
  display: block;
  width: 100%;
  border-bottom: 1px solid #ccc;
}
@media screen and (min-width: 768px) {
  .entry__table tr {
    display: inline-block;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 9px;
    padding-bottom: 10.5px;
  }
}
.entry__table .tr2 {
  padding-top: 0px;
}
@media screen and (min-width: 768px) {
  .entry__table .tr2 {
    padding-top: 4px;
    padding-bottom: 10px;
  }
}
.entry__table .tr3 {
  padding-top: 0px;
}
@media screen and (min-width: 768px) {
  .entry__table .tr3 {
    padding-top: 3px;
  }
}
.entry__table .tr4 {
  padding-top: 0px;
}
@media screen and (min-width: 768px) {
  .entry__table .tr4 {
    padding-top: 3px;
    padding-bottom: 10px;
  }
}
.entry__table .tr5 {
  padding-top: 0px;
  border: none;
  padding-bottom: 16px;
}
@media screen and (min-width: 768px) {
  .entry__table .tr5 {
    padding-top: 4px;
    padding-bottom: 29px;
  }
}

.img_area {
  width: 100%;
}

.contact {
  padding-top: 41px;
  background-color: #fff;
  padding-bottom: 44px;
}
@media screen and (min-width: 768px) {
  .contact {
    padding-top: 123px;
    padding-bottom: 120px;
  }
}

.contact__inner {
  padding-inline: 20px;
  max-width: 375px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .contact__inner {
    padding-inline: 40px;
    max-width: 928px;
    margin-inline: auto;
  }
}

@media screen and (min-width: 768px) {
  .contact__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.contact__head {
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .contact__head {
    margin-top: 32px;
  }
}

.contact__head-text {
  text-align: center;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .contact__head-text {
    font-size: 16px;
    font-weight: 400;
  }
}

.contact-table {
  margin-top: 27px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 26px;
}
@media screen and (min-width: 768px) {
  .contact-table {
    margin-top: 39px;
    gap: 23px;
  }
}

input[type=text],
input[type=email],
textarea {
  width: 100%;
  height: auto;
  padding: 16px;
  font-size: 14px;
  font-weight: 400;
  border-radius: 8px;
  background: #f5f5f5;
  border: 1px solid transparent; /* ボーダーを透明に設定 */
  outline: none;
}
@media screen and (min-width: 768px) {
  input[type=text],
  input[type=email],
  textarea {
    padding: 15px;
    font-size: 16px;
    font-weight: 400;
  }
}
input[type=text]:focus,
input[type=email]:focus,
textarea:focus {
  border: 1px solid #9ed0e0;
  background: #e9f6f8;
}
input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #ccc;
  font-size: 14px;
  font-weight: 400;
}
input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, textarea::-moz-placeholder {
  color: #ccc;
  font-size: 14px;
  font-weight: 400;
}
input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #ccc;
  font-size: 14px;
  font-weight: 400;
}
input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #ccc;
  font-size: 14px;
  font-weight: 400;
}
input[type=text]::placeholder,
input[type=email]::placeholder,
textarea::placeholder {
  color: #ccc;
  font-size: 14px;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
    font-size: 16px;
    font-weight: 700;
  }
  input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, textarea::-moz-placeholder {
    font-size: 16px;
    font-weight: 700;
  }
  input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, textarea:-ms-input-placeholder {
    font-size: 16px;
    font-weight: 700;
  }
  input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, textarea::-ms-input-placeholder {
    font-size: 16px;
    font-weight: 700;
  }
  input[type=text]::placeholder,
  input[type=email]::placeholder,
  textarea::placeholder {
    font-size: 16px;
    font-weight: 700;
  }
}

.form-text:focus,
.form-checkbox__input:focus,
.form-textarea:focus {
  border: 1px solid #9ed0e0;
  background: #e9f6f8;
}

.ai-start {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  margin-top: 1px;
}
@media screen and (min-width: 768px) {
  .ai-start {
    margin-top: 0;
  }
}

.contact-item {
  font-size: 14px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .contact-item {
    width: 26%;
    font-size: 16px;
  }
}
.contact-item .must {
  font-size: 14px;
  font-weight: 700;
  position: relative;
}
@media screen and (min-width: 768px) {
  .contact-item .must {
    font-size: 14px;
  }
}
@media screen and (min-width: 960px) {
  .contact-item .must {
    font-size: 16px;
  }
}
.contact-item .must::before {
  content: "必須";
  position: absolute;
  left: calc(100% + 8px);
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 40px;
  height: 27px;
  padding-block: 4px;
  padding-inline: 8px;
  border-radius: 4px;
  background: #ce2073;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
}
@media screen and (min-width: 960px) {
  .contact-item .must::before {
    left: calc(100% + 12px);
  }
}

.contact-body {
  width: 100%;
  margin-top: 10px;
}
@media screen and (min-width: 768px) {
  .contact-body {
    width: 74%;
    margin-top: 0;
  }
}

.radio-adjust {
  margin-top: 0px;
}
@media screen and (min-width: 768px) {
  .radio-adjust {
    margin-top: 16px;
    margin-bottom: 15px;
  }
}

.radio-mt {
  margin-top: 9px;
}
@media screen and (min-width: 768px) {
  .radio-mt {
    margin-top: 0px;
  }
}

.select__wrap {
  position: relative;
}
.select__wrap::before {
  position: absolute;
  content: "";
  display: inline-block;
  padding: 16px 1px 16px 0px;
  top: 0;
  right: 0;
  width: 52px;
  height: 55px;
  border-radius: 0 8px 8px 0;
  background-color: var(--select-wrap-bg-color, #9ed0e0); /* デフォルトの色 */
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .select__wrap::before {
    height: 56px;
  }
}
.select__wrap::after {
  content: "";
  position: absolute;
  top: 26px;
  right: 26px;
  -webkit-transform: translate(50%, -50%) rotate(45deg);
          transform: translate(50%, -50%) rotate(45deg);
  width: 11px;
  height: 11px;
  border-bottom: 3px solid #fff;
  border-right: 3px solid #fff;
  pointer-events: none;
}

.form-select {
  cursor: pointer;
  width: 100%;
  height: auto;
  padding-inline: 15px 16px;
  padding-block: 15px 15px;
  font-size: 14px;
  font-weight: 400;
  border-radius: 8px;
  background: #f5f5f5;
  border: 1px solid transparent; /* ボーダーを透明に設定 */
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
@media screen and (min-width: 768px) {
  .form-select {
    font-size: 16px;
  }
}

.contact-radio:nth-child(1) {
  padding-left: 2px;
}
@media screen and (min-width: 768px) {
  .contact-radio:nth-child(1) {
    padding-left: 3px;
  }
}
.contact-radio:nth-child(2) {
  padding-left: 24px;
}

.form-radio__input {
  width: 1px;
  height: 1px;
  position: absolute;
  clip: rect(0, 0, 0, 0);
  overflow: hidden;
}
.form-radio__input:checked + .contact-radio-text::after {
  opacity: 1;
}
.form-radio__input:focus + .contact-radio-text::before {
  border: 1px solid #9ed0e0;
}

.contact-radio-text {
  padding-left: 30px;
  position: relative;
  font-size: 14px;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .contact-radio-text {
    font-size: 16px;
  }
}
.contact-radio-text::before, .contact-radio-text::after {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border-radius: 50%;
  cursor: pointer;
}

.contact-radio-text::before {
  width: 24px;
  height: 24px;
  left: 0;
  background: #f5f5f5;
}

.contact-radio-text::after {
  width: 12px;
  height: 12px;
  background: #9ed0e0;
  left: 6px;
  opacity: 0;
}

.form-textarea {
  height: 160px;
  resize: none;
}

.contact__privacy {
  text-align: center;
  margin-top: -2px;
}
@media screen and (min-width: 768px) {
  .contact__privacy {
    margin-top: 17px;
  }
}

.form-checkbox__input {
  width: 1px;
  height: 1px;
  position: absolute;
  clip: rect(0, 0, 0, 0);
  overflow: hidden;
}
.form-checkbox__input:checked + .checkbox__text::after {
  opacity: 1;
}

.checkbox__text {
  font-size: 14px;
  font-weight: 400;
  padding-left: 36px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .checkbox__text {
    font-size: 16px;
  }
}
.checkbox__text a {
  font-size: 14px;
  font-weight: 400;
  text-decoration-line: underline;
  text-underline-offset: 1.5px;
}
@media screen and (min-width: 768px) {
  .checkbox__text a {
    font-size: 16px;
  }
}
.checkbox__text::before {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  width: 24px;
  height: 24px;
  border: none;
  background: #f5f5f5;
  cursor: pointer;
}
.checkbox__text::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
  left: 9px;
  width: 6px;
  height: 12px;
  border-right: 3px solid #67b0c7;
  border-bottom: 3px solid #67b0c7;
  opacity: 0;
}

.contact__button {
  text-align: center;
  margin-top: 26px;
}
@media screen and (min-width: 768px) {
  .contact__button {
    margin-top: 40px;
  }
}

.contact-button {
  height: 32px;
  padding: 4px 22px 32px 22px;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #fff;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
  color: #4a3636;
  font-size: 16px;
  font-weight: 700;
  white-space: nowrap;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
}
.contact-button:hover {
  background: #ffee56;
}
@media screen and (min-width: 768px) {
  .contact-button {
    height: 40px;
    padding: 4px 39px 7px 39px;
    font-size: 16px;
    -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
            box-shadow: 0px 4px 0px 0px #4a3636;
  }
}

.footer {
  overflow: hidden;
  padding-top: 40px;
}
@media screen and (min-width: 768px) {
  .footer {
    padding-top: 119px;
  }
}

.footer__inner {
  position: relative;
}

.footer__nikukyuu {
  display: none;
}
@media screen and (min-width: 768px) {
  .footer__nikukyuu {
    display: block;
    position: absolute;
    right: -11.2%;
    top: -40px;
    width: 100px;
  }
}
.footer__nikukyuu img {
  width: 100%;
}

.footer__head {
  text-align: center;
}

.footer__head-text {
  font-family: "Josefin Sans", "sans-serif";
  font-size: 20px;
  font-weight: 400;
  line-height: 1.25; /* 25px */
}
@media screen and (min-width: 768px) {
  .footer__head-text {
    font-size: 24px;
  }
}

.footer__link {
  padding-top: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.footer__icon {
  width: 32px;
}
@media screen and (min-width: 768px) {
  .footer__icon {
    width: 41px;
  }
}

.footer__icon a:hover svg path {
  fill: #9ed0e0;
}

.footer__logo {
  text-align: center;
  margin-inline: auto;
  margin-top: 10px;
  width: 327px;
}
@media screen and (min-width: 768px) {
  .footer__logo {
    width: 600px;
    margin-top: 36px;
  }
}
@media screen and (min-width: 960px) {
  .footer__logo {
    width: 742px;
    margin-top: 36px;
  }
}
.footer__logo img {
  width: 100%;
}

.footer__card {
  background: #fff;
  padding-bottom: 24px;
  border-radius: 16px;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: -3px;
}
@media screen and (min-width: 768px) {
  .footer__card {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    margin-bottom: 239px;
    padding-bottom: 0;
    margin-top: -3px;
  }
}

@media screen and (min-width: 768px) {
  .google-wrap {
    width: 50%;
  }
}

.google-map {
  width: 335px;
  height: 271px;
  aspect-ratio: 335/271;
}
@media screen and (min-width: 768px) {
  .google-map {
    width: 100%;
    height: 100%;
    aspect-ratio: 512/400;
  }
}

.footer__card-wrap {
  text-align: center;
  padding-inline: 24px;
}
@media screen and (min-width: 768px) {
  .footer__card-wrap {
    padding-inline: 15px;
    margin-block: auto;
    width: 50%;
    text-align: left;
  }
}
@media screen and (min-width: 960px) {
  .footer__card-wrap {
    padding-inline: 30px;
  }
}
@media screen and (min-width: 1280px) {
  .footer__card-wrap {
    padding-inline: 58px;
  }
}

.footer__card-logo {
  display: inline-block;
  margin-top: 18px;
  width: 153px;
}
@media screen and (min-width: 768px) {
  .footer__card-logo {
    width: 140px;
    margin-top: 4px;
    padding-left: 3px;
  }
}
@media screen and (min-width: 960px) {
  .footer__card-logo {
    width: 186px;
    margin-top: 4px;
    padding-left: 3px;
  }
}
.footer__card-logo img {
  width: 100%;
}

.footer__table {
  margin-top: 26px;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .footer__table {
    margin-top: 18px;
  }
}
.footer__table th {
  padding-left: 18px;
  font-weight: 700;
  position: relative;
}
@media screen and (min-width: 768px) {
  .footer__table th {
    width: 80px;
    font-size: 14px;
  }
}
@media screen and (min-width: 960px) {
  .footer__table th {
    width: 107px;
    font-size: 14px;
  }
}
.footer__table th::before {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 2px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #9ed0e0;
}
@media screen and (min-width: 960px) {
  .footer__table th {
    font-size: 16px;
  }
}
.footer__table td {
  font-weight: 400;
  width: auto;
  padding-left: 13px;
}
@media screen and (min-width: 768px) {
  .footer__table td {
    font-size: 14px;
    font-weight: 400;
  }
}
@media screen and (min-width: 960px) {
  .footer__table td {
    font-size: 16px;
  }
}
.footer__table th,
.footer__table td {
  white-space: nowrap;
  padding-block: 3px;
}
@media screen and (min-width: 768px) {
  .footer__table th,
  .footer__table td {
    padding-block: 5.5px;
  }
}

.footer__wave {
  margin-top: -26.714px;
  width: 100%;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .footer__wave {
    margin-top: -60.714px;
  }
}

.copy-wrap {
  background: #67b0c7;
  text-align: center;
  padding-bottom: 24px;
}
@media screen and (min-width: 768px) {
  .copy-wrap {
    padding-bottom: 32px;
  }
}

.footer-copylight {
  color: #fff;
  font-size: 10px;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .footer-copylight {
    font-size: 14px;
  }
}

#pagetop {
  z-index: 999;
  margin-top: 23px;
  padding-bottom: 73.714px;
  margin-inline: auto;
  display: block;
  text-align: center;
  width: 77px;
  cursor: pointer;
}
#pagetop img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  #pagetop {
    position: fixed;
    bottom: 100px;
    right: 50px;
    width: 100px;
    height: 100px;
    line-height: 100px;
    font-size: 13px;
  }
}

/*PCで見た時*/