@charset "UTF-8";
@font-face {
  font-family: "Courgette"; /* Google Fontsで指定したフォントファミリー名 */
  src: url("../fonts/Courgette/Courgette-Regular.ttf") format("truetype"); /* .ttf 形式 */
  font-weight: 100 900; /* フォントの太さ（normal） */
  font-style: normal; /* フォントのスタイル（normal） */
}
@font-face {
  font-family: "Josefin Sans"; /* Google Fontsで指定したフォントファミリー名 */
  src: url("../fonts/Josefin_Sans/JosefinSans-VariableFont_wght.ttf") format("truetype"); /* .ttf 形式 */
  font-weight: 100 900; /* フォントの太さ（normal） */
  font-style: normal; /* フォントのスタイル（normal） */
}
@font-face {
  font-family: "Noto Sans JP"; /* Google Fontsで指定したフォントファミリー名 */
  src: url("../fonts/Noto_Sans_JP/NotoSansJP-VariableFont_wght.ttf") format("truetype"); /* .ttf 形式 */
  font-weight: 100 900; /* フォントの太さ（normal） */
  font-style: normal; /* フォントのスタイル（normal） */
}
@font-face {
  font-family: "Kiwi Maru"; /* Google Fontsで指定したフォントファミリー名 */
  src: url("../fonts/Kiwi_Maru/KiwiMaru-Regular.ttf") format("truetype"); /* .ttf 形式 */
  font-weight: 100 900; /* フォントの太さ（normal） */
  font-style: normal; /* フォントのスタイル（normal） */
}
@font-face {
  font-family: "フォントファミリー名"; /* Google Fontsで指定したフォントファミリー名 */
  src: url("./fonts/フォントファイル名.ttf") format("truetype"); /* .ttf 形式 */
  font-weight: 100 900; /* フォントの太さ（normal） */
  font-style: normal; /* フォントのスタイル（normal） */
}
/* スムーススクロール */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 64px;
}

body {
  font-family: "Noto Sans JP", system-ui;
  font-size: 12px;
  line-height: 1.6;
  font-weight: regular;
  color: #4a3636;
  background: #e9f6f8;
}
@media screen and (min-width: 768px) {
  body {
    font-size: 16px;
  }
}

img {
  width: 100%;
}

.btn-14px-base {
  font-size: 14px;
  font-weight: 700;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  height: 32px;
  padding: 6px 24px 8px 24px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #ffffff;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
}
.btn-14px-base a {
  font-weight: inherit;
}
.btn-14px-base:hover {
  background: #ffee56;
}

.heading {
  position: relative;
  text-align: center;
}
.heading .heading__logo svg {
  width: 38px;
  height: 38px;
}
.heading .heading__logo svg path {
  fill: #9ed0e0;
}
@media screen and (min-width: 768px) {
  .heading .heading__logo svg {
    width: 48px;
    height: 48px;
  }
}
.heading .heading__title {
  font-family: "Courgette", system-ui;
  font-size: 16px;
  line-height: 1.25;
}
@media screen and (min-width: 768px) {
  .heading .heading__title {
    font-size: 20px;
  }
}
.heading .heading__text {
  font-family: "Kiwi Maru", system-ui;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.25;
  margin-top: 6px;
  display: inline-block;
}
@media screen and (min-width: 768px) {
  .heading .heading__text {
    font-size: 32px;
  }
}
.heading .heading__text::after {
  content: "";
  display: block;
  width: inline-size;
  height: 6px;
  background: #ffee56;
  margin-inline: auto;
  margin-top: 6px;
}
@media screen and (min-width: 768px) {
  .heading .heading__text::after {
    height: 8px;
    margin-top: 8px;
  }
}

.link {
  text-decoration: underline;
}
.link:hover {
  color: #67b0c7;
  text-decoration-color: #67b0c7;
}

@media screen and (max-width: 767px) {
  .sp-hide {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .pc-hide {
    display: none;
  }
}

.header {
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 200;
  width: 100%;
}

.header__inner {
  height: 64px;
  padding-block: 16px;
  padding-inline: 20px;
  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;
}
@media screen and (min-width: 768px) {
  .header__inner {
    max-width: 100%;
    padding-inline: 1.5873015873%;
  }
}

.header__logo-image {
  width: 210px;
  max-width: 60vw;
}
@media screen and (min-width: 768px) {
  .header__logo-image {
    width: 183px;
  }
}
.header__logo-image img {
  width: 100%;
}

.header__nav__icon {
  width: 32px;
  height: 24px;
  position: relative;
}

.header__nav__icon-line {
  width: 32px;
  height: 3px;
  background-color: #4a3636;
}
.header__nav__icon-line:nth-last-of-type(1) {
  position: absolute;
  top: 0;
  left: 0;
  width: 25.6px;
}
.header__nav__icon-line:nth-last-of-type(2) {
  width: 4.8px;
  height: 3px;
  position: absolute;
  top: 0;
  right: 0;
}
.header__nav__icon-line:nth-last-of-type(3) {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.header__nav__icon-line:nth-last-of-type(4) {
  position: absolute;
  bottom: 0;
  left: 0;
}

.header__nav__icon-close {
  width: 72px;
  height: 64px;
  background: url(../img/header/close.png) no-repeat center center/contain;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 200;
}
.header__nav__icon-close .header__nav__icon-line {
  display: none;
}

.header__nav-menu {
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
  position: fixed;
  top: 64px;
  right: 0;
  width: 100%;
  height: 100%;
  background: #ffffff;
  text-align: center;
  padding-top: 82px;
  padding-bottom: 213px;
  padding-inline: 114px;
  -webkit-transform: translateY(-120%);
          transform: translateY(-120%);
  z-index: 200;
  opacity: 0; /* 透明度を0にする */
  pointer-events: none;
}
.header__nav-menu.-open {
  -webkit-transition: opacity 0.7s, -webkit-transform 1s;
  transition: opacity 0.7s, -webkit-transform 1s;
  transition: transform 1s, opacity 0.7s;
  transition: transform 1s, opacity 0.7s, -webkit-transform 1s;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1; /* 透明度を1にする */
  pointer-events: auto;
}
@media screen and (min-width: 768px) {
  .header__nav-menu {
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1; /* 透明度を1にする */
    position: relative;
    top: 0;
    width: auto;
    height: auto;
    pointer-events: auto;
  }
}

.header__nav-list {
  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;
}
@media screen and (min-width: 768px) {
  .header__nav-list {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 12px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.header__nav-item {
  font-size: 14px;
}
.header__nav-item:hover {
  text-decoration: underline;
  color: #67b0c7;
  text-decoration-color: #67b0c7;
}
@media screen and (min-width: 768px) {
  .header__nav-item {
    font-size: 12px;
  }
}

.header__nav__button {
  margin-inline: auto;
}

.fv {
  margin-top: 64px;
}

.fv__inner {
  padding-top: 17px;
  margin-bottom: 152px;
  margin-inline: auto;
  background: url(../img/fv/Onomichi_fv-bg-sp.jpg) no-repeat center center/cover;
  text-align: center;
  position: relative;
  height: 554px;
  border-radius: 0px 0px 24px 24px;
}
@media screen and (min-width: 768px) {
  .fv__inner {
    padding-top: 35px;
    height: 740px;
    background: url(../img/fv/Onomichi_pc.jpg) no-repeat center center/cover;
  }
}

.fv__title__text {
  text-align: center;
  text-shadow: 0px 0px 30px #fff;
  font-family: "Kiwi Maru", system-ui;
  font-size: 14px;
  line-height: 1.25;
}
@media screen and (min-width: 768px) {
  .fv__title__text {
    font-size: 24px;
    font-weight: 500;
  }
}

.fv__title__logo-1 {
  width: 335px;
  margin-top: 20px;
  margin-inline: auto;
  max-width: 100%;
}
@media screen and (min-width: 768px) {
  .fv__title__logo-1 {
    width: 520px;
    margin-top: 24px;
  }
}

.fv__title__logo-2 {
  width: 240px;
  margin-top: 12px;
  margin-inline: auto;
  max-width: 100%;
}
@media screen and (min-width: 768px) {
  .fv__title__logo-2 {
    width: 358px;
    margin-top: 16px;
  }
}

.fv__fukidasi {
  position: absolute;
  top: 195px;
  left: calc(50% - 26px);
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  width: 140px;
}
@media screen and (min-width: 768px) {
  .fv__fukidasi {
    width: 240px;
    top: 277px;
    left: calc(50% - 146px);
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

.fv__present {
  position: absolute;
  top: 188px;
  right: calc(50% - 32px);
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  width: 110px;
}
@media screen and (min-width: 768px) {
  .fv__present {
    width: 180px;
    top: 294px;
    right: calc(50% - 116px);
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}

.fv__mobile {
  width: 200px;
  height: 408px;
  margin-inline: auto;
  position: absolute;
  bottom: -115px;
  border-top: 5.17px solid #000;
  border-inline: 4.5px solid #000;
  border-bottom: 3.57px solid #000;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-radius: 26px;
  overflow: hidden;
  position: relative;
}
@media screen and (min-width: 768px) {
  .fv__mobile {
    width: 250px;
    height: 510px;
    bottom: -34px;
    border-radius: 39px;
  }
}

.fv__mobile__image-top {
  width: 100%;
  position: relative;
}
.fv__mobile__image-top .fv__mobile__image-top__black-box {
  content: "";
  width: 75px;
  height: 14px;
  background-color: #000;
  border-radius: 0 0 8px 8px;
  position: absolute;
  top: 0;
  right: 50%;
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
  z-index: 80;
}
@media screen and (min-width: 768px) {
  .fv__mobile__image-top .fv__mobile__image-top__black-box {
    width: 95px;
    height: 16px;
  }
}
.fv__mobile__image-top .fv__mobile__image-top__black-box .fv__mobile__image-top__black-box-center {
  content: "";
  width: 100px;
  height: 10px;
  background-color: #000;
  position: absolute;
  top: 0;
  right: 50%;
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
  z-index: 90;
}
.fv__mobile__image-top .fv__mobile__image-top__black-box .fv__mobile__image-top__box-left-white {
  content: "";
  width: 10px;
  height: 15px;
  background: #ffffff;
  border-radius: 0 6px 0 0;
  z-index: 90;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
}
@media screen and (min-width: 768px) {
  .fv__mobile__image-top .fv__mobile__image-top__black-box .fv__mobile__image-top__box-left-white {
    width: 25px;
  }
}
.fv__mobile__image-top .fv__mobile__image-top__black-box .fv__mobile__image-top__box-right-white {
  width: 10px;
  height: 15px;
  background: #ffffff;
  border-radius: 6px 0 0 0;
  z-index: 90;
  position: absolute;
  top: 0;
  right: 0;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
}
@media screen and (min-width: 768px) {
  .fv__mobile__image-top .fv__mobile__image-top__black-box .fv__mobile__image-top__box-right-white {
    width: 25px;
  }
}
.fv__mobile__image-top img {
  position: relative;
  z-index: 70;
}
.fv__mobile__image-top .fv__mobile__image-top__text {
  position: absolute;
  top: 23px;
  left: 47px;
  color: #000;
  text-align: center;
  font-size: 10px;
  font-weight: 700;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .fv__mobile__image-top .fv__mobile__image-top__text {
    font-size: 11.802px;
    top: 31.74px;
    left: 61.5px;
  }
}

.fv__mobile__image-bg-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.8px 0.8px;
  width: 100%;
  background-color: #ffffff;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 10;
}

.fv__mobile__image-bg-container__image {
  height: 64px;
}
@media screen and (min-width: 768px) {
  .fv__mobile__image-bg-container__image {
    height: 80px;
  }
}
.fv__mobile__image-bg-container__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.fv__mobile__pop {
  position: absolute;
  top: 117px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 160px;
  height: 154.2px;
  width: 160px;
  padding-bottom: 19.2px;
  border-radius: 12.8px;
  background: #fff;
  text-align: center;
  z-index: 100;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .fv__mobile__pop {
    width: 200px;
    height: 194px;
    padding-bottom: 24px;
    top: 146.01px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

.fv__mobile__pop__title {
  padding: 6.4px 9.6px;
  background: linear-gradient(265deg, #ac3790 -3.52%, #d65a5c 44.94%, #f4c06d 92.38%);
  color: #fff;
  -webkit-font-feature-settings: "pref" on;
          font-feature-settings: "pref" on;
  font-size: 12.8px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .fv__mobile__pop__title {
    font-size: 16px;
  }
}

.fv__mobile__pop__text {
  margin-top: 12.8px;
  text-align: center;
  font-size: 12px;
  font-weight: 400;
  position: relative;
  padding-bottom: 3.2px;
}
@media screen and (min-width: 768px) {
  .fv__mobile__pop__text {
    margin-top: 19px;
    font-size: 14px;
    padding-bottom: 4px;
  }
}
.fv__mobile__pop__text::after {
  content: "";
  display: block;
  width: 48px;
  height: 3.2px;
  background: #ce2073;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .fv__mobile__pop__text::after {
    width: 56px;
  }
}

.fv__mobile__pop__time {
  margin-top: 3px;
}
@media screen and (min-width: 768px) {
  .fv__mobile__pop__time {
    margin-left: -2px;
  }
}

.fv__mobile__pop__button {
  margin-top: 12.8px;
}
@media screen and (min-width: 768px) {
  .fv__mobile__pop__button {
    margin-top: 18px;
    -webkit-font-feature-settings: "pref" on;
            font-feature-settings: "pref" on;
    font-size: 16px;
    font-weight: 700;
    height: 40px;
    padding: 6px 24px 8px 24px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-radius: 40px;
    border: 2px solid #4a3636;
    background: #ffffff;
    -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
            box-shadow: 0px 4px 0px 0px #4a3636;
  }
  .fv__mobile__pop__button:hover {
    background: #ffee56;
  }
}

.fv__mobile__image-bottom {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 50;
}

.fv__mobile__decoration-left {
  width: 86px;
  height: 141px;
  position: absolute;
  bottom: -156px;
  left: calc(50% - 167px);
  z-index: 60;
}
@media screen and (min-width: 768px) {
  .fv__mobile__decoration-left {
    width: 202px;
    height: 332px;
    left: calc(50% - 422px);
    bottom: -95px;
  }
}
.fv__mobile__decoration-left .fv__mobile__decoration-left__food {
  width: 54px;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 20;
}
@media screen and (min-width: 768px) {
  .fv__mobile__decoration-left .fv__mobile__decoration-left__food {
    width: 127px;
  }
}
.fv__mobile__decoration-left .fv__mobile__decoration-left__drink {
  width: 47.257px;
  position: absolute;
  right: -3px;
  bottom: 17px;
  z-index: 10;
}
@media screen and (min-width: 768px) {
  .fv__mobile__decoration-left .fv__mobile__decoration-left__drink {
    width: 111px;
    bottom: 40px;
    right: -6px;
  }
}

.fv__mobile__decoration-right {
  width: 107px;
  height: 127px;
  position: absolute;
  bottom: -156px;
  right: calc(50% - 167px);
  z-index: 60;
}
@media screen and (min-width: 768px) {
  .fv__mobile__decoration-right {
    width: 233px;
    height: 294px;
    right: calc(50% - 424px);
    bottom: -137px;
  }
}

.fv__mobile__decoration-right__cat-black {
  width: 62px;
  height: 69px;
  position: absolute;
  right: 0;
  top: 0;
}
@media screen and (min-width: 768px) {
  .fv__mobile__decoration-right__cat-black {
    width: 170px;
    right: auto;
    left: 0;
  }
}

.fv__mobile__decoration-right__cat-sleep {
  width: 98px;
  height: 72px;
  position: absolute;
  left: 0;
  bottom: 0;
}
@media screen and (min-width: 768px) {
  .fv__mobile__decoration-right__cat-sleep {
    height: auto;
    width: 233px;
  }
}

.about {
  position: relative;
}

.about__inner-bg-deco-image-top-nikukyu-pc {
  position: absolute;
  top: -54px;
  right: 10.8465608466%;
}

.about__inner {
  padding-inline: 5.3333333333%;
  padding-top: 37px;
  margin-inline: auto;
  position: relative;
  height: 923px;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .about__inner {
    height: 1117px;
  }
}
@media screen and (min-width: 1024px) {
  .about__inner {
    padding-inline: 21.9576719577%;
    padding-top: 26px;
    height: 1117px;
  }
}

.about__inner__stripe {
  width: 250px;
  position: absolute;
  top: 0;
  left: -1.5211640212%;
}
.about__inner__stripe img {
  width: 100%;
}

.about__inner__inside-white {
  padding-top: 40px;
  padding-bottom: 40px;
  margin-inline: auto;
  text-align: center;
  position: relative;
  border-radius: 24px;
  background-color: #ffffff;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .about__inner__inside-white {
    max-width: 848px;
  }
}

.about__heading-image-left {
  width: 70px;
  -webkit-transform: rotate(-8deg);
          transform: rotate(-8deg);
  position: absolute;
  top: 0px;
  left: calc(50% - 126px);
}
@media screen and (min-width: 768px) {
  .about__heading-image-left {
    width: 122px;
    top: 10px;
    left: calc(50% - 330px);
  }
  .about__heading-image-left img {
    width: 100%;
  }
}

.about__heading-image-right {
  width: 70px;
  -webkit-transform: rotate(8deg);
          transform: rotate(8deg);
  position: absolute;
  top: 0px;
  right: calc(50% - 139px);
}
@media screen and (min-width: 768px) {
  .about__heading-image-right {
    width: 122px;
    top: 19px;
    right: calc(50% - 330px);
  }
  .about__heading-image-right img {
    width: 100%;
  }
}

.about__body__heading {
  font-size: 14px;
  font-weight: 700;
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .about__body__heading {
    font-size: 16px;
    margin-top: 35px;
  }
}

.about__body__text {
  font-size: 12px;
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .about__body__text {
    font-size: 16px;
    margin-top: 32px;
  }
}

.about__body__text-present {
  font-size: 12px;
  margin-top: 17px;
}
@media screen and (min-width: 768px) {
  .about__body__text-present {
    font-size: 16px;
    margin-top: 30px;
  }
}

.about__body__text-present__span {
  font-weight: bold;
}

.about__body__text-present-bold {
  font-size: 14px;
  font-weight: 700;
  margin-top: 24px;
  padding-top: 8px;
  display: inline-block;
}
@media screen and (min-width: 768px) {
  .about__body__text-present-bold {
    font-size: 20px;
    margin-top: 36px;
  }
}
.about__body__text-present-bold::after {
  content: "";
  display: block;
  width: inline-size;
  height: 1px;
  border-bottom: dashed 3px #9ed0e0;
  margin-inline: auto;
  margin-top: 4px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  .about__body__text-present-bold::after {
    margin-top: 12px;
  }
}

.about__body__button {
  margin-top: 24px;
  -webkit-font-feature-settings: "pref" on;
          font-feature-settings: "pref" on;
  font-size: 16px;
  font-weight: 700;
  height: 40px;
  padding: 6px 24px 8px 24px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #ffffff;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
}
.about__body__button:hover {
  background: #ffee56;
}
@media screen and (min-width: 768px) {
  .about__body__button {
    /* JP/Text 20px Bold */
    font-size: 20px;
    font-weight: 700;
    height: 56px;
    padding: 10px 40px 12px 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-radius: 40px;
    border: 3px solid #4a3636;
    background: #ffffff;
    -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
            box-shadow: 0px 4px 0px 0px #4a3636;
    margin-top: 32px;
  }
  .about__body__button:hover {
    background: #ffee56;
  }
}

.about__inner-bottom-arrow {
  width: 100px;
  position: absolute;
  bottom: -36px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .about__inner-bottom-arrow {
    width: 140px;
    bottom: -50px;
  }
  .about__inner-bottom-arrow img {
    width: 100%;
  }
}

.about__inner-bg-deco-image-top-nikukyu {
  width: 54px;
  position: absolute;
  top: 25px;
  right: -0.1333333333%;
}
@media screen and (min-width: 768px) {
  .about__inner-bg-deco-image-top-nikukyu {
    width: 100px;
  }
}

.about__inner-bg-deco-image-middle-left {
  width: 200px;
  border-radius: 24px;
  position: absolute;
  top: 432px;
  left: calc(50% - 327px);
  overflow: hidden;
  z-index: 50;
}
@media screen and (min-width: 1024px) {
  .about__inner-bg-deco-image-middle-left {
    width: 480px;
    top: 100px;
    left: calc(50% - 72vw);
    border-radius: 40px;
  }
}
.about__inner-bg-deco-image-middle-left img {
  width: 100%;
}

.about__inner-bg-deco-image-middle-right {
  width: 200px;
  border-radius: 24px;
  position: absolute;
  top: 311px;
  right: calc(50% - 327px);
  overflow: hidden;
}
@media screen and (min-width: 1024px) {
  .about__inner-bg-deco-image-middle-right {
    width: 480px;
    right: calc(50% - 68.5vw);
    top: 100px;
    border-radius: 40px;
  }
  .about__inner-bg-deco-image-middle-right img {
    width: 100%;
  }
}

.about__inner-bg-deco-image-bottom-1 {
  width: 138px;
  position: absolute;
  bottom: -37px;
  left: 0.1333333333%;
}
@media screen and (min-width: 768px) {
  .about__inner-bg-deco-image-bottom-1 {
    width: 419px;
    bottom: -39px;
    left: calc(50% - 854px);
  }
  .about__inner-bg-deco-image-bottom-1 img {
    width: 100%;
    height: auto;
  }
}

.about__inner-bg-deco-image-bottom-2 {
  width: 133px;
  position: absolute;
  bottom: 60px;
  right: 15.3333333333%;
}
@media screen and (min-width: 768px) {
  .about__inner-bg-deco-image-bottom-2 {
    width: 308px;
    bottom: 183px;
    right: calc(50% - 681px);
  }
  .about__inner-bg-deco-image-bottom-2 img {
    width: 100%;
  }
}

.about__inner-bg-deco-image-bottom-3 {
  width: 48px;
  position: absolute;
  bottom: 120px;
  right: 5.7333333333%;
}
@media screen and (min-width: 768px) {
  .about__inner-bg-deco-image-bottom-3 {
    width: 101px;
    bottom: 390px;
    right: calc(50% - 606px);
  }
  .about__inner-bg-deco-image-bottom-3 img {
    width: 100%;
  }
}

.about__inner-bg-deco-image-bottom-onomichi {
  width: 355px;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .about__inner-bg-deco-image-bottom-onomichi {
    width: 100%;
    max-width: 896px;
  }
}
.about__inner-bg-deco-image-bottom-onomichi img {
  width: 100%;
}

.about__slider {
  width: 100%;
}

.about__slider__wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}

.about__slider__slide {
  width: 200px;
  border-radius: 12%;
  overflow: hidden;
}

.howTo {
  position: relative;
  padding-bottom: 18px;
  overflow: hidden;
}

.howTo__deco-left-map {
  width: 149px;
  position: absolute;
  top: 65px;
  left: 0;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .howTo__deco-left-map {
    width: 460px;
    top: 60px;
    left: 2.380952381%;
  }
}

.howTo__deco-left-nikukyu-op {
  width: 55px;
  position: absolute;
  top: 611px;
  left: 5.3333333333%;
}
@media screen and (min-width: 768px) {
  .howTo__deco-left-nikukyu-op {
    width: 100px;
    top: 704px;
    left: 2.380952381%;
  }
}

.howTo__deco-right-nikukyu-top {
  width: 55px;
  position: absolute;
  top: 136px;
  right: 5.3333333333%;
  -webkit-transform: scaleX(-1);
          transform: scaleX(-1);
}
@media screen and (min-width: 768px) {
  .howTo__deco-right-nikukyu-top {
    width: 100px;
    top: 268px;
    right: 2.380952381%;
  }
}

.howTo__deco-right-nikukyu-bottom-oplr {
  position: absolute;
  width: 55px;
  top: 942px;
  right: 5.3333333333%;
  -webkit-transform: scaleX(-1);
          transform: scaleX(-1);
}

.howTo__deco-right-cat-box {
  width: 160px;
  position: absolute;
  top: 63px;
  right: -8.6666666667%;
}
@media screen and (min-width: 768px) {
  .howTo__deco-right-cat-box {
    width: 364px;
    top: 94px;
    right: 6.9444444444%;
  }
}

.howTo__deco-right-cat-box__tabby {
  width: 105px;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .howTo__deco-right-cat-box__tabby {
    width: 238px;
  }
}

.howTo__deco-right-cat-box__kuro {
  width: 94px;
  position: absolute;
  top: 6px;
  right: 0;
}
@media screen and (min-width: 768px) {
  .howTo__deco-right-cat-box__kuro {
    width: 214px;
    top: 13px;
  }
}

.howTO__inner {
  padding-top: 62px;
  padding-bottom: 20px;
  text-align: center;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .howTO__inner {
    padding-top: 126px;
    padding-bottom: 108px;
  }
}

.howTo__lists {
  padding-top: 32px;
  text-align: center;
}
@media screen and (min-width: 1300px) {
  .howTo__lists {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding-top: 40px;
    padding-bottom: 32px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 32px;
    padding-inline: 16.1375661376%;
  }
}

.howTo__list-item {
  z-index: 100;
  padding-bottom: 16px;
}

.howTo__list-item-2 {
  padding-top: 34px;
}
@media screen and (min-width: 768px) {
  .howTo__list-item-2 {
    padding-top: 70px;
  }
}

.howTo__list-item-3 {
  padding-top: 32px;
}
@media screen and (min-width: 768px) {
  .howTo__list-item-3 {
    padding-top: 0;
  }
}

.howTo__list-item__image {
  width: 196px;
}
@media screen and (min-width: 768px) {
  .howTo__list-item__image {
    width: 320px;
    padding-inline: 20px;
  }
}

.howTo__list-item-2__image-container,
.howTo__list-item-3__image-container {
  position: relative;
}
.howTo__list-item-2__image-container::before,
.howTo__list-item-3__image-container::before {
  content: "";
  display: block;
  width: 7px;
  height: 34px;
  background: url(../img/how-to/nami-sp.png) no-repeat center center/contain;
  position: absolute;
  top: -33px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .howTo__list-item-2__image-container::before,
  .howTo__list-item-3__image-container::before {
    width: 35.3125%;
    height: 24px;
    background: url(../img/how-to/nami-pc.png) no-repeat center center/contain;
    left: -35px;
  }
}

@media screen and (min-width: 768px) {
  .howTo__list-item-2__image-container::before {
    top: 45.3333333333%;
  }
}

@media screen and (min-width: 768px) {
  .howTo__list-item-3__image-container::before {
    top: 68%;
  }
}

.howTo__list-item__text-bold {
  -webkit-font-feature-settings: "pref" on;
          font-feature-settings: "pref" on;
  margin-top: 16px;
  font-size: 16px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .howTo__list-item__text-bold {
    font-size: 20px;
    margin-top: 24px;
  }
}

.howTo__list-item__text-body {
  margin-top: 16px;
  font-size: 12px;
}
@media screen and (min-width: 768px) {
  .howTo__list-item__text-body {
    font-size: 16px;
    margin-top: 18px;
  }
}

.howTo__list-item__link-conatiner {
  margin-top: 16px;
  padding: 8px 12px;
  background-color: #ffffff;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  gap: 8px;
  -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) {
  .howTo__list-item__link-conatiner {
    margin-top: 20px;
  }
}

.howTo__list-item__link__logo {
  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;
}
.howTo__list-item__link__logo svg {
  width: 20px;
  height: 20px;
}
.howTo__list-item__link__logo svg path {
  fill: #9ed0e0;
}

.howTo__list-item__link__text {
  font-size: 14px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .howTo__list-item__link__text {
    font-size: 16px;
  }
}

.howTo__botton {
  -webkit-font-feature-settings: "pref" on;
          font-feature-settings: "pref" on;
  font-size: 16px;
  font-weight: 700;
  height: 40px;
  padding: 6px 24px 8px 24px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #ffffff;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
}
.howTo__botton:hover {
  background: #ffee56;
}
@media screen and (min-width: 768px) {
  .howTo__botton {
    /* JP/Text 20px Bold */
    font-size: 20px;
    font-weight: 700;
    height: 56px;
    padding: 10px 40px 12px 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-radius: 40px;
    border: 3px solid #4a3636;
    background: #ffffff;
    -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
            box-shadow: 0px 4px 0px 0px #4a3636;
  }
  .howTo__botton:hover {
    background: #ffee56;
  }
}

.prizes__inner {
  padding-top: 20px;
  padding-bottom: 35px;
  border-radius: 24px;
  position: relative;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .prizes__inner {
    width: 67.7248677249%;
    max-width: 1024px;
    margin-inline: auto;
    border-radius: 24px;
    padding-top: 28px;
    padding-bottom: 54px;
  }
}
.prizes__inner::before {
  content: "";
  display: block;
  width: 238px;
  height: 83px;
  background: url(../img/prizes/deco_prizes_top-sp.png) no-repeat center center/cover;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .prizes__inner::before {
    width: 366px;
    height: 150px;
    background: url(../img/prizes/deco_prizes_top-pc.png) no-repeat center center/contain;
  }
}
.prizes__inner::after {
  content: "";
  background-color: #fff;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: calc(100% - 83px);
  border-radius: 24px;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .prizes__inner::after {
    height: calc(100% - 150px);
  }
}

.prizes__inner__contents {
  width: 100%;
  padding-inline: 20px;
}
@media screen and (min-width: 768px) {
  .prizes__inner__contents {
    padding-inline: 56px;
  }
}

.prizes__deco-left {
  width: 30.76171875%;
  position: absolute;
  left: 0;
  top: 25px;
}

.prizes__deco-right {
  width: 30.76171875%;
  position: absolute;
  right: 0;
  top: 25px;
}

.prizes__text {
  font-size: 12px;
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .prizes__text {
    font-size: 16px;
    margin-top: 41px;
  }
}

.prizes__cards {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  row-gap: 15px;
  -webkit-column-gap: 4.4776119403%;
     -moz-column-gap: 4.4776119403%;
          column-gap: 4.4776119403%;
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .prizes__cards {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(2, auto);
    grid-template-areas: "a a a b b b" "c c d d e e";
    -webkit-column-gap: 32px;
       -moz-column-gap: 32px;
            column-gap: 32px;
    row-gap: 80px;
    margin-top: 80px;
  }
}

.prizes__card {
  width: 47.7611940299%;
  position: relative;
  border-radius: 8px;
  background: #f5f5f5;
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .prizes__card {
    width: 100%;
    margin-top: 0;
  }
  .prizes__card:nth-of-type(1) {
    grid-area: a;
  }
  .prizes__card:nth-of-type(2) {
    grid-area: b;
  }
  .prizes__card:nth-of-type(3) {
    grid-area: c;
  }
  .prizes__card:nth-of-type(4) {
    grid-area: d;
  }
  .prizes__card:nth-of-type(5) {
    grid-area: e;
  }
}

.prizes__card__number__container {
  position: absolute;
  width: 48px;
  text-align: center;
  top: -24px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 100;
}

.prizes__card__number__text {
  position: absolute;
  color: #ffffff;
  font-size: 7.68px;
  font-weight: 700;
  top: 5.76px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

.prizes__card__number__num {
  position: absolute;
  color: #ffffff;
  font-family: "Josefin Sans", system-ui;
  font-size: 23.04px;
  font-weight: 700;
  line-height: 1;
  top: 19.36px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

@media screen and (max-width: 767px) {
  .prizes__card__image {
    width: 100%;
    border-radius: 8px 8px 0 0;
  }
}

.prizes__card__text-container {
  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;
  height: 56px;
}
.prizes__card__text-container .prizes__card__text {
  text-align: center;
  font-size: 12px;
  font-weight: 700;
}

.prizes__card-corner-icon {
  position: absolute;
  bottom: 0;
  right: 0;
  background: url(../img/prizes/prizes__card__corner.png) no-repeat center center/contain;
  width: 36px;
  height: 36px;
  border-radius: 0 0 8px 0;
}
.prizes__card-corner-icon svg {
  position: absolute;
  bottom: 6.12px;
  right: 6.12px;
}
.prizes__card-corner-icon svg path {
  fill: #ffffff;
}

.prizes__card picture {
  overflow: hidden;
}

@media screen and (min-width: 768px) and (max-width: 1023px) {
  .prizes__card-large {
    border-radius: 24px;
  }
  .prizes__card-large .prizes__card__number__container {
    width: 70px;
    top: -40px;
    z-index: 100;
  }
  .prizes__card-large .prizes__card__number__text {
    font-size: 12px;
    top: 12px;
  }
  .prizes__card-large .prizes__card__number__num {
    font-size: 30px;
    top: 30px;
  }
  .prizes__card-large .prizes__card__button {
    border-radius: 24px;
  }
}
@media screen and (min-width: 1024px) {
  .prizes__card-large {
    border-radius: 24px;
  }
  .prizes__card-large .prizes__card__number__container {
    width: 100px;
    top: -50px;
    z-index: 100;
  }
  .prizes__card-large .prizes__card__number__text {
    font-size: 16px;
    top: 16px;
  }
  .prizes__card-large .prizes__card__number__num {
    font-size: 48px;
    top: 40px;
  }
  .prizes__card-large .prizes__card__button {
    border-radius: 24px;
  }
}
@media screen and (min-width: 768px) {
  .prizes__card-large {
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  .prizes__card-large:hover .prizes__card__image {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }
  .prizes__card-large:hover .prizes__card-corner-icon {
    background: url(../img/prizes/prizes__card__corner_hover.png) no-repeat center center/contain;
  }
  .prizes__card-large .prizes__picture__container {
    overflow: hidden;
    border-radius: 24px 24px 0 0;
  }
  .prizes__card-large .prizes__card__image {
    border-radius: 24px 24px 0 0;
  }
  .prizes__card-large .prizes__card__text-container {
    height: 120px;
  }
  .prizes__card-large .prizes__card__text {
    font-size: 20px;
  }
  .prizes__card-large .prizes__card-corner-icon {
    width: 22.7272727273%;
    border-radius: 0 0 24px 0;
  }
  .prizes__card-large svg {
    bottom: 14%;
    right: 13%;
    width: 32%;
    height: auto;
  }
}

@media screen and (min-width: 768px) and (max-width: 1023px) {
  .prizes__card-small .prizes__card__number__container {
    width: 55px;
    top: -40px;
    z-index: 100;
  }
  .prizes__card-small .prizes__card__number__container .prizes__card__number__text {
    font-size: 10px;
    top: 7px;
  }
  .prizes__card-small .prizes__card__number__container .prizes__card__number__num {
    font-size: 30px;
    top: 24px;
  }
  .prizes__card-small .prizes__card__text {
    font-size: 12px;
  }
  .prizes__card-small .prizes__card__button {
    border-radius: 16px;
  }
}
@media screen and (min-width: 1024px) {
  .prizes__card-small .prizes__card__number__container {
    width: 80px;
    top: -40px;
    z-index: 100;
  }
  .prizes__card-small .prizes__card__number__container .prizes__card__number__text {
    font-size: 13px;
    top: 9.6px;
  }
  .prizes__card-small .prizes__card__number__container .prizes__card__number__num {
    font-size: 38px;
    top: 32px;
  }
  .prizes__card-small .prizes__card__text {
    font-size: 16px;
  }
  .prizes__card-small .prizes__card__button {
    border-radius: 16px;
  }
}
@media screen and (min-width: 768px) {
  .prizes__card-small {
    border-radius: 16px;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  .prizes__card-small:hover .prizes__card__number__text {
    -webkit-transform: translateX(-15px) translateY(-3px);
            transform: translateX(-15px) translateY(-3px);
  }
  .prizes__card-small:hover .prizes__card__number__num {
    -webkit-transform: translateX(-15px) translateY(-3px);
            transform: translateX(-15px) translateY(-3px);
  }
  .prizes__card-small:hover .prizes__card__image {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s;
  }
  .prizes__card-small:hover .prizes__card-corner-icon {
    background: url(../img/prizes/prizes__card__corner_hover.png) no-repeat center center/contain;
  }
  .prizes__card-small .prizes__picture__container {
    overflow: hidden;
    border-radius: 16px 16px 0 0;
  }
  .prizes__card-small .prizes__card__image {
    border-radius: 16px 16px 0 0;
  }
  .prizes__card-small .prizes__card__text-container {
    height: 81px;
  }
  .prizes__card-small .prizes__card-corner-icon {
    width: 22.8571428571%;
    border-radius: 0 0 16px 0;
  }
  .prizes__card-small .prizes__card-corner-icon svg {
    bottom: 14.0625%;
    right: 14.0625%;
    width: 31.25%;
    height: auto;
  }
}

.prizes__card__button {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 2px solid transparent;
  border-radius: 8px;
  outline: none;
}
.prizes__card__button:hover {
  border-color: #9ed0e0;
}

.prizes__button {
  -webkit-font-feature-settings: "pref" on;
          font-feature-settings: "pref" on;
  font-size: 16px;
  font-weight: 700;
  height: 40px;
  padding: 6px 24px 8px 24px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #ffffff;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
  padding-inline: 22px;
  margin-top: 16px;
}
.prizes__button:hover {
  background: #ffee56;
}
@media screen and (min-width: 768px) {
  .prizes__button {
    /* JP/Text 20px Bold */
    font-size: 20px;
    font-weight: 700;
    height: 56px;
    padding: 10px 40px 12px 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-radius: 40px;
    border: 3px solid #4a3636;
    background: #ffffff;
    -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
            box-shadow: 0px 4px 0px 0px #4a3636;
    margin-top: 40px;
  }
  .prizes__button:hover {
    background: #ffee56;
  }
}

.prizes__modal {
  background-color: #ffffff;
  border-radius: 24px;
  width: 336px;
  padding-top: 0;
  padding-inline: 0;
  padding-bottom: 56px;
  text-align: center;
  overflow: hidden;
  border: none;
}
@media screen and (min-width: 768px) {
  .prizes__modal {
    width: 480px;
    padding-bottom: 106px;
  }
}
.prizes__modal::-ms-backdrop {
  background-color: #333;
  opacity: 0.5;
}
.prizes__modal::backdrop {
  background-color: #333;
  opacity: 0.5;
}

.prizes__card__figure {
  margin: 0;
}

.prizes__card__modal__image {
  width: 100%;
  height: 210px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .prizes__card__modal__image {
    height: 300px;
  }
}

.prizes__modal-tilte {
  font-size: 16px;
  font-weight: 700;
  margin-top: 39px;
}
@media screen and (min-width: 768px) {
  .prizes__modal-tilte {
    font-size: 20px;
    margin-top: 32px;
  }
}

.prizes__modal-text {
  color: #000;
  text-align: center;
  font-size: 12px;
  margin-top: 12px;
}
@media screen and (min-width: 768px) {
  .prizes__modal-text {
    font-size: 16px;
  }
}

.prizes__modal-button {
  margin-top: 16px;
  -webkit-font-feature-settings: "pref" on;
          font-feature-settings: "pref" on;
  font-size: 16px;
  font-weight: 700;
  height: 40px;
  padding: 6px 24px 8px 24px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #ffffff;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
}
.prizes__modal-button:hover {
  background: #ffee56;
}
@media screen and (min-width: 768px) {
  .prizes__modal-button {
    margin-top: 24px;
  }
}

.prizes__footer-bg {
  overflow: hidden;
}

.prizes__footer-bg-pic img {
  margin-top: -44px;
  width: 154.9333333333%;
  height: 260px;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .prizes__footer-bg-pic img {
    margin-top: 0;
    width: 100%;
    height: 640px;
  }
}

.spots {
  position: relative;
}
.spots::before {
  content: "";
  display: block;
  background: url(../img/spots/spots__img_bg_wave.png) repeat-x bottom left/96px 46px;
  position: absolute;
  top: -45px;
  left: 0;
  width: 100%;
  height: 46px;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .spots::before {
    background: url(../img/spots/spots__img_bg_wave.png) repeat-x bottom left/252px 120px;
    top: -119px;
    height: 142px;
  }
}

.spots__inner {
  text-align: center;
  background: #67b0c7;
  padding-bottom: 16px;
  margin-bottom: 46px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .spots__inner {
    margin-bottom: 120px;
  }
}
.spots__inner::after {
  content: "";
  background: url(../img/spots/spots__img_bg_wave.png) repeat-x bottom left/96px 46px;
  -webkit-transform: scaleY(-1);
          transform: scaleY(-1);
  width: 100%;
  height: 46px;
  position: absolute;
  left: 0;
  bottom: -45px;
}
@media screen and (min-width: 768px) {
  .spots__inner::after {
    background: url(../img/spots/spots__img_bg_wave.png) repeat-x bottom left/252px 120px;
    height: 133px;
    bottom: -119px;
  }
}

@media screen and (min-width: 1025px) {
  .spots__slider-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 32px;
    padding-left: 16.1375661376vw;
    margin-top: -24px;
  }
}

.spots__tilte {
  position: relative;
  display: inline;
  color: #ffffff;
  font-family: "Kiwi Maru", system-ui;
  font-size: 28px;
  font-weight: 500;
  line-height: 1.25;
  padding-left: 36px;
  z-index: 100;
}
@media screen and (min-width: 1025px) {
  .spots__tilte {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl; /* 右から左への縦書き */
    text-orientation: upright; /* すべての文字を縦向きに */
    padding-left: 0;
    padding-top: 64px;
    margin-top: 30px;
    font-size: 40px;
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: 10px;
  }
}
.spots__tilte::before {
  content: "";
  background: url(../img/spots/spots__star.png) no-repeat top left/28px 28px;
  position: absolute;
  top: 4px;
  left: 0;
  width: 28px;
  height: 28px;
}
@media screen and (min-width: 1025px) {
  .spots__tilte::before {
    width: 56px;
    height: 56px;
    background: url(../img/spots/spots__star.png) no-repeat top left/56px 56px;
    top: -10px;
  }
}

.spots__swiper {
  margin-top: 24px;
}

.spots__slide {
  height: 403px;
  border-radius: 12px;
  background: #ffffff;
  text-align: center;
  overflow: hidden;
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .spots__slide {
    height: 59.8958333333vw;
    padding-bottom: 31px;
    border-radius: 12px;
  }
}
@media screen and (min-width: 1025px) {
  .spots__slide {
    height: max(542px, 35.8465608466vw);
    padding-bottom: 0;
    border-radius: 24px;
  }
}

.spots__slide__image {
  width: 100%;
  height: 180px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .spots__slide__image {
    height: 240px;
  }
}
.spots__slide__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.spots__slide__title {
  font-size: 16px;
  font-weight: 700;
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .spots__slide__title {
    font-size: 20px;
    margin-top: 24px;
  }
}

.spots__slide__text {
  font-size: 12px;
  font-weight: 400;
  padding-inline: 24px;
  margin-top: 16px;
  text-align: left;
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .spots__slide__text {
    font-size: 14px;
    margin-top: 20px;
    padding-inline: 28px;
  }
}
@media screen and (min-width: 1025px) {
  .spots__slide__text {
    font-size: 16px;
    margin-top: 24px;
    padding-inline: 32px;
  }
}

.spots__slide__prev {
  width: 80px;
  height: 80px;
  display: none;
}
@media screen and (min-width: 768px) {
  .spots__slide__prev {
    display: block;
  }
}
.spots__slide__prev::after {
  content: "";
  display: block;
  width: 80px;
  height: 80px;
  background: url(../img/spots/spots__slider-arrow-left.png) no-repeat center center/contain;
  position: absolute;
  bottom: -156px;
  z-index: 200;
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .spots__slide__prev::after {
    left: 140px;
  }
}
@media screen and (min-width: 1024px) {
  .spots__slide__prev::after {
    left: 274px;
  }
}

.spots__slide__next {
  width: 80px;
  height: 80px;
  display: none;
}
@media screen and (min-width: 768px) {
  .spots__slide__next {
    display: block;
  }
}
.spots__slide__next::after {
  content: "";
  display: block;
  width: 80px;
  height: 80px;
  background: url(../img/spots/spots__slider-arrow-right.png) no-repeat center center/contain;
  position: absolute;
  bottom: -156px;
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .spots__slide__next::after {
    right: 140px;
  }
}
@media screen and (min-width: 1024px) {
  .spots__slide__next::after {
    right: 276px;
  }
}

@media screen and (min-width: 768px) {
  .spots__contents {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 63px;
    gap: 80px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    z-index: 100;
  }
}

.spots__logo {
  width: 255px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .spots__logo {
    width: 495px;
    margin-inline: 0;
  }
}

.spots__contents__text {
  color: #ffffff;
  font-size: 11.444px;
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .spots__contents__text {
    font-size: 16px;
    margin-top: 0;
  }
}

.spots__contents__button {
  margin-top: 23px;
  -webkit-font-feature-settings: "pref" on;
          font-feature-settings: "pref" on;
  font-size: 16px;
  font-weight: 700;
  height: 40px;
  padding: 6px 24px 8px 24px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #ffffff;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
}
.spots__contents__button:hover {
  background: #ffee56;
}
@media screen and (min-width: 750px) and (max-width: 1023px) {
  .spots__contents__button {
    padding-inline: 9px;
  }
}
@media screen and (min-width: 1024px) {
  .spots__contents__button {
    margin-top: 27px;
    /* JP/Text 20px Bold */
    font-size: 20px;
    font-weight: 700;
    height: 56px;
    padding: 10px 40px 12px 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-radius: 40px;
    border: 3px solid #4a3636;
    background: #ffffff;
    -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
            box-shadow: 0px 4px 0px 0px #4a3636;
    margin-left: 13px;
  }
  .spots__contents__button:hover {
    background: #ffee56;
  }
}

.spots__deco-bottom-left-pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .spots__deco-bottom-left-pc {
    display: block;
    position: absolute;
    bottom: 15px;
    left: 34px;
    width: 100px;
    height: 220px;
  }
}

.q-and-a__inner {
  padding-top: 45px;
  padding-inline: 20px;
  padding-bottom: 30px;
  max-width: 440px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .q-and-a__inner {
    padding-top: 107px;
    max-width: 1512px;
    padding-inline: 16.1375661376%;
    padding-bottom: 120px;
  }
}

.q-and-a__lists {
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .q-and-a__lists {
    margin-top: 43px;
  }
}

.q-and-a__list {
  border-radius: 12px;
  border: 2px solid #4a3636;
  overflow: hidden;
}
.q-and-a__list:nth-child(n+1) {
  margin-top: 13px;
}
@media screen and (min-width: 768px) {
  .q-and-a__list:nth-child(n+1) {
    margin-top: 24px;
  }
}

.q-and-a__list__question {
  background-color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
  padding-inline: 16px;
  padding-block: 10px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .q-and-a__list__question {
    padding-inline: 24px;
    gap: 0;
  }
  .q-and-a__list__question .q-and-a__list__question__text {
    margin-left: 16px;
    padding-top: 20px;
    padding-bottom: 19px;
  }
}

.q-and-a__list__icon-left {
  color: #9ed0e0;
  font-family: "Josefin Sans", system-ui;
  font-size: 24px;
  line-height: 1.25;
}
@media screen and (min-width: 768px) {
  .q-and-a__list__icon-left {
    font-size: 32px;
  }
}

.q-and-a__list__question__text {
  font-size: 14px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .q-and-a__list__question__text {
    font-size: 20px;
  }
}

.q-and-a__list__question__icon {
  width: 26px;
  height: 26px;
  background-color: #9ed0e0;
  border-radius: 50%;
  position: relative;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .q-and-a__list__question__icon {
    width: 48px;
    height: 48px;
  }
}
.q-and-a__list__question__icon .q-and-a__list__question__icon__line-1 {
  content: "";
  display: block;
  width: 10.182px;
  height: 1.455px;
  background-color: #ffffff;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .q-and-a__list__question__icon .q-and-a__list__question__icon__line-1 {
    width: 18.667px;
    height: 2.667px;
  }
}
.q-and-a__list__question__icon .q-and-a__list__question__icon__line-2 {
  content: "";
  display: block;
  width: 10.182px;
  height: 1.455px;
  background-color: #ffffff;
  position: absolute;
  top: 12.5px;
  left: 7.45px;
  -webkit-transform-origin: center center;
          transform-origin: center center;
  -webkit-transition: -webkit-transform 0.4s ease;
  transition: -webkit-transform 0.4s ease;
  transition: transform 0.4s ease;
  transition: transform 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}
@media screen and (min-width: 768px) {
  .q-and-a__list__question__icon .q-and-a__list__question__icon__line-2 {
    width: 18.667px;
    height: 2.667px;
    top: 24px;
    left: 15px;
  }
}
.q-and-a__list__question__icon .q-and-a__list__question__icon__line-2-rotate {
  -webkit-transition: -webkit-transform 0.4s ease;
  transition: -webkit-transform 0.4s ease;
  transition: transform 0.4s ease;
  transition: transform 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}

.q-and-a__list__answer {
  padding-inline: 16px;
  padding-block: 15px;
  background: #f5f5f5;
  display: none;
}
@media screen and (min-width: 768px) {
  .q-and-a__list__answer {
    padding-inline: 24px;
    padding-top: 23px;
    padding-bottom: 19px;
  }
}

.q-and-a__list__answer-opend {
  display: block;
}

.q-and-a__list__answer__container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.q-and-a__list__answer__text {
  font-size: 14px;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .q-and-a__list__answer__text {
    font-size: 16px;
  }
}

.entry-requirements__outer {
  padding-inline: 20px;
}
@media screen and (min-width: 768px) {
  .entry-requirements__outer {
    padding-inline: 0;
    padding-bottom: 82px;
  }
}

.entry-requirements__inner {
  padding-top: 24px;
  background-color: #ffffff;
  position: relative;
  padding-bottom: 17px;
}
@media screen and (min-width: 768px) {
  .entry-requirements__inner {
    padding-top: 40px;
    max-width: 1024px;
    padding-bottom: 40px;
    padding-inline: 56px;
    margin-inline: auto;
  }
}
.entry-requirements__inner::after {
  content: "";
  display: block;
  width: calc(100% - 12px);
  height: calc(100% - 12px);
  position: absolute;
  top: 6px;
  left: 6px;
  background-color: #e9f6f8;
}

.entry-requirements__heading {
  z-index: 100;
}

.entry-requirements__contents {
  margin-top: 24px;
  padding-inline: 23.5px;
  z-index: 100;
  position: relative;
}
@media screen and (min-width: 768px) {
  .entry-requirements__contents {
    padding-inline: 0;
    margin-top: 40px;
  }
}

.entry-requirements__list {
  padding-bottom: 15px;
  border-bottom: 1px solid #cccccc;
}
@media screen and (min-width: 768px) {
  .entry-requirements__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
@media screen and (min-width: 768px) and (min-width: 768px) {
  .entry-requirements__list {
    padding-bottom: 13px;
  }
}
.entry-requirements__list:nth-child(n+2) {
  margin-top: 12px;
}
.entry-requirements__list:last-child {
  border-bottom: none;
}

.entry-requirements__list__title {
  font-size: 14px;
  font-weight: 700;
  position: relative;
  padding-left: 16px;
}
@media screen and (min-width: 768px) {
  .entry-requirements__list__title {
    width: 26.3157894737%;
    min-width: 128px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    font-size: 16px;
    padding-left: 31px;
  }
}
.entry-requirements__list__title::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  background-color: #9ed0e0;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
}
@media screen and (min-width: 768px) {
  .entry-requirements__list__title::before {
    left: 15px;
  }
}

.entry-requirements__list__text {
  font-size: 12px;
  margin-top: 8px;
}
@media screen and (min-width: 768px) {
  .entry-requirements__list__text {
    font-size: 16px;
    margin-top: 0;
  }
}

.entry-requirements__list__lists {
  margin-top: 7px;
}
@media screen and (min-width: 768px) {
  .entry-requirements__list__lists {
    margin-top: 0;
    margin-left: 6px;
  }
}

.entry-requirements__list__list {
  position: relative;
  padding-left: 18px;
  margin-bottom: -1px;
}
@media screen and (min-width: 768px) {
  .entry-requirements__list__list {
    margin-bottom: 0;
    padding-bottom: 1px;
  }
}
.entry-requirements__list__list::before {
  content: "・";
  width: 8px;
  height: 12px;
  position: absolute;
  top: 0;
  left: 3px;
}
@media screen and (min-width: 768px) {
  .entry-requirements__list__list::before {
    left: -3px;
  }
}

.entry-requirements__bg-bottom {
  margin-top: 32px;
  width: 100%;
}

.contact {
  background-color: #ffffff;
}

.contact__inner {
  padding-block: 40px;
  padding-inline: 20px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .contact__inner {
    max-width: 848px;
    padding-top: 125px;
    padding-bottom: 120px;
    padding-inline: 0;
  }
}

.contact__text {
  margin-top: 24px;
  font-size: 12px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .contact__text {
    margin-top: 32px;
    font-size: 16px;
  }
}

.contact__form-container {
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .contact__form-container {
    margin-top: 40px;
  }
}

.contact-form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 24px;
}
@media screen and (min-width: 768px) {
  .contact-form {
    display: block;
  }
}

.contact-form__item {
  margin-top: 3px;
}
@media screen and (min-width: 768px) {
  .contact-form__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 22px;
  }
}

@media screen and (min-width: 768px) {
  .contact-form__item.-radio {
    margin-top: 36px;
  }
}

.contact-form__item.-message {
  margin-top: 7px;
}
@media screen and (min-width: 768px) {
  .contact-form__item.-message {
    margin-top: 36px;
  }
}

.contact-form__item__heading {
  font-size: 14px;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .contact-form__item__heading {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 12px;
    font-size: 16px;
  }
}

@media screen and (min-width: 768px) {
  .contact-form__item__heading-aline-top {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.contact-form__heading-tag {
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  border-radius: 4px;
  background: #ce2073;
  margin-left: 12px;
  padding-inline: 8px;
  padding-block: 4px;
}
@media screen and (min-width: 768px) {
  .contact-form__heading-tag {
    margin-left: 0;
  }
}

.contact-form__input {
  border-radius: 8px;
  background: #f5f5f5;
  padding-inline: 16px;
  padding-block: 16px;
  margin-top: 10.5px;
  border: none;
  width: 100%;
  font-size: 14px;
}
@media screen and (min-width: 768px) {
  .contact-form__input {
    width: 74%;
    margin-top: 0;
    font-size: 16px;
  }
}
.contact-form__input:focus {
  outline: #9ed0e0 solid 2px;
  background-color: #e9f6f8;
}
.contact-form__input::-webkit-input-placeholder {
  color: #cccccc;
}
.contact-form__input::-moz-placeholder {
  color: #cccccc;
}
.contact-form__input:-ms-input-placeholder {
  color: #cccccc;
}
.contact-form__input::-ms-input-placeholder {
  color: #cccccc;
}
.contact-form__input::placeholder {
  color: #cccccc;
}

.form-select-container {
  position: relative;
}
.form-select-container::before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 52px;
  height: 55px;
  border-radius: 0 8px 8px 0;
  background-color: #9ed0e0;
  pointer-events: none; /* 矢印にクリックイベントがいかないようにする */
}
.form-select-container::after {
  content: "";
  position: absolute;
  bottom: 26px;
  right: 26px;
  -webkit-transform: translate(50%, 50%);
          transform: translate(50%, 50%);
  width: 8.779px;
  height: 14.899px;
  background: url(../img/entry/contact-form-select_arrow.png) no-repeat center center;
  background-size: 100% auto;
  pointer-events: none; /* 矢印にクリックイベントがいかないようにする */
}
.form-select-container:has(.contact-form-is-error)::before {
  background-color: #ce2073;
}

.form-select {
  border-radius: 8px;
  background-color: #f5f5f5;
  padding-inline: 16px;
  padding-block: 16px;
  margin-top: 10.5px;
  border: none;
  width: 100%;
  font-size: 14px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .form-select {
    width: 74%;
    margin-top: 0;
    font-size: 16px;
  }
}
.form-select:focus {
  outline: #9ed0e0 solid 2px;
  background-color: #e9f6f8;
}

.form-radio-container {
  margin-top: 5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  margin-left: -3px;
}
@media screen and (min-width: 768px) {
  .form-radio-container {
    width: 74%;
    gap: 18px;
  }
}

.contact-form__radio-field {
  border: none; /* 枠線を削除 */
  margin: 0; /* 余白を削除 */
  padding: 0; /* パディングを削除 */
}
@media screen and (min-width: 768px) {
  .contact-form__radio-field {
    display: contents;
  }
}

.form-radio__label {
  font-size: 14px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .form-radio__label {
    font-size: 16px;
  }
}
.form-radio__label:has(.contact-form__radio-input:checked) {
  font-weight: 700;
}

.contact-form__radio-input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding-left: 32px;
  margin: 0;
}
.contact-form__radio-input::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background-color: #f5f5f5;
  margin-right: 8px;
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}
.contact-form__radio-input:checked::before {
  border: #9ed0e0 solid 2px;
}
.contact-form__radio-input:checked::after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #9ed0e0;
  position: absolute;
  top: 6px;
  left: 6px;
  pointer-events: none;
}

.contact-form__textarea {
  margin-top: 8px;
  border-radius: 8px;
  background: #f5f5f5;
  padding-inline: 16px;
  padding-block: 16px;
  border: none;
  width: 100%;
  font-size: 14px;
  height: 160px;
}
@media screen and (min-width: 768px) {
  .contact-form__textarea {
    width: 74%;
    margin-top: 0;
    font-size: 16px;
  }
}
.contact-form__textarea:focus {
  outline: #9ed0e0 solid 2px;
  background-color: #e9f6f8;
}

.contact-form-checkbox-container {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .contact-form-checkbox-container {
    margin-top: 40px;
    display: block;
  }
}

.contact-form-checkbox {
  position: relative;
  padding-left: 24px;
}
.contact-form-checkbox::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  border-radius: 4px;
  border: none;
  background-color: #f5f5f5;
  margin-right: 12px;
  position: absolute;
  top: -2px;
  left: 0;
  pointer-events: none;
}
.contact-form-checkbox:has(.contact-form-checkbox__input:checked)::after {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  position: absolute;
  top: -2px;
  left: 0px;
  pointer-events: none;
  background: url(../img/entry/contact-form-check-box-check.png) no-repeat center center/contain;
}

.contact-form-checkbox__input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.contact-form-checkbox__text {
  font-size: 14px;
}
@media screen and (min-width: 768px) {
  .contact-form-checkbox__text {
    font-size: 16px;
  }
}

.contact-form__button-container {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .contact-form__button-container {
    margin-top: 40px;
  }
}

.contact-form-is-error {
  color: #ce2073;
  border: #ce2073 solid 1px;
  background-color: #fff0f7;
}

.contact-form-heading-title-is-error {
  color: #ce2073;
}

.contact-form__button {
  -webkit-font-feature-settings: "pref" on;
          font-feature-settings: "pref" on;
  font-size: 16px;
  font-weight: 700;
  height: 40px;
  padding: 6px 24px 8px 24px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 40px;
  border: 2px solid #4a3636;
  background: #ffffff;
  -webkit-box-shadow: 0px 4px 0px 0px #4a3636;
          box-shadow: 0px 4px 0px 0px #4a3636;
}
.contact-form__button:hover {
  background: #ffee56;
}
@media screen and (min-width: 768px) {
  .contact-form__button {
    min-width: 240px;
  }
}

.footer__inner {
  padding-top: 45px;
  padding-inline: 20px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .footer__inner {
    padding-top: 120px;
    padding-inline: 0;
  }
}

.footer__heading {
  width: 182px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .footer__heading {
    width: 218px;
  }
}

.footer__heading__text {
  font-family: "Josefin Sans", system-ui;
  font-size: 20px;
  line-height: 1.25;
  color: #4a3636;
}
@media screen and (min-width: 768px) {
  .footer__heading__text {
    font-size: 24px;
  }
}

.footer__heading__sns-lists {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 24px;
  padding-inline: 3px;
}
@media screen and (min-width: 768px) {
  .footer__heading__sns-lists {
    padding-inline: 10px;
  }
}

.footer__heading__sns-list svg {
  width: 32px;
  height: 32px;
}
@media screen and (min-width: 768px) {
  .footer__heading__sns-list svg {
    width: 40px;
    height: 40px;
  }
}
.footer__heading__sns-list svg path {
  fill: #67b0c7;
}

.footer__logo {
  width: 98%;
  margin-top: 9px;
}
@media screen and (min-width: 768px) {
  .footer__logo {
    margin-top: 37px;
    max-width: 740px;
    margin-inline: auto;
  }
}

.adress-container {
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .adress-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    max-width: 1024px;
    margin-inline: auto;
  }
}

.adress__iframe-wrapper {
  position: relative;
  padding-bottom: 80.5970149254%;
  height: 0;
  overflow: hidden;
}
@media screen and (min-width: 1025px) {
  .adress__iframe-wrapper {
    width: 50%;
    padding-bottom: 39.0625%;
  }
}

.adress__iframe-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.adress__text-contaier {
  background-color: #ffffff;
  padding-inline: 20px;
  padding-top: 24px;
  padding-bottom: 30px;
}
@media screen and (min-width: 1025px) {
  .adress__text-contaier {
    width: 50%;
    padding-top: 106px;
    padding-bottom: 82px;
  }
}

.adress__text-title {
  width: 52%;
  margin-inline: auto;
  margin-top: -4px;
}
@media screen and (min-width: 768px) {
  .adress__text-title {
    width: 183px;
    margin-left: 41px;
  }
}

.adress__text-dl {
  margin-top: 30px;
  padding-left: 7px;
}
@media screen and (min-width: 768px) {
  .adress__text-dl {
    margin-top: 21px;
    margin-left: 33px;
  }
}

.adress-dl__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
}
@media screen and (min-width: 768px) {
  .adress-dl__item {
    gap: 30px;
  }
}
.adress-dl__item:nth-child(n+2) {
  margin-top: 8px;
}
@media screen and (min-width: 768px) {
  .adress-dl__item:nth-child(n+2) {
    margin-top: 12px;
  }
}

.adress__text-dt {
  font-size: 12px;
  font-weight: 700;
  min-width: 64px;
  width: 21%;
  padding-left: 16px;
  position: relative;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .adress__text-dt {
    font-size: 16px;
    min-width: 80px;
  }
}
.adress__text-dt::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  background-color: #9ed0e0;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
}

.adress__text-dd {
  font-size: 12px;
}
@media screen and (min-width: 768px) {
  .adress__text-dd {
    font-size: 16px;
  }
}

.to-top-footer-sp {
  width: 75px;
  margin-inline: auto;
  margin-top: 24px;
  display: block;
}
@media screen and (min-width: 768px) {
  .to-top-footer-sp {
    display: none;
  }
}

.footer__footer__inner {
  margin-top: 70px;
  text-align: center;
  padding-bottom: 24px;
  background-color: #67b0c7;
  position: relative;
}
@media screen and (min-width: 768px) {
  .footer__footer__inner {
    margin-top: 236px;
    padding-bottom: 32px;
  }
}
.footer__footer__inner::before {
  content: "";
  display: block;
  background: url(../img/footer/footer__img_bg_wave.png) repeat-x top left;
  background-size: 96px 46px;
  position: absolute;
  top: -45px;
  left: 0;
  width: 100%;
  height: 46px;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .footer__footer__inner::before {
    background-size: 252px 120px;
    top: -118px;
    height: 120px;
  }
}

.copyright {
  color: #ffffff;
  font-size: 10px;
  display: block;
}
@media screen and (min-width: 768px) {
  .copyright {
    font-size: 14px;
  }
}

.to-top-pc {
  width: 75px;
  position: fixed;
  bottom: 40px;
  right: 40px;
  z-index: 200;
}
@media screen and (max-width: 767px) {
  .to-top-pc {
    visibility: hidden;
  }
}