h2{
font-size: 1.5rem;
	}
.section-mark-en {
        font-size: 100px;
	    letter-spacing: -0.025em;
    }
@media screen and (max-width: 600px) {
h2{
font-size: 1.2rem;
	}
.section-mark-en {
        font-size: 50px;
    }
}


/* mv */
.mv{
  position: relative;
  padding-bottom:100px;
}

.mv-bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.mv-inner {
  width: 100%;
  margin: 0 auto;
}

.mv .mv-grid img{
  max-width: unset;
  height: unset;
  vertical-align: unset;	
}
/* グリッド分割 */
.mv-grid {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  z-index: 2;
}

.grid-area {
  position: relative;
}

/* mv内のposition調整 */
.mv-char{
  position: absolute;
  z-index: -1;
}

.mv-sauna-f{
  bottom: 100px;
  left: 0;
}

.mv-sauna-m{
  bottom:100px;
  left: 300px;
}

.mv-book-f{
    bottom: 130px;
    right: 10%;
}

  .mv-logo-kuni::before,
  .mv-logo-kuni::after,
  .mv-logo-maru::before,
  .mv-logo-inn::before,
  .area-tl::before,
  .area-tr::before,
  .area-bl::before,
  .area-br::before{
    z-index: 2;
  }

.mv-logo-kuni::before {
    position: absolute;
    content: "";
    background-image: url(../img/mv-sub-05.png);
    width: 97px;
    height: 157px;
    top: -47px;
    left: -40%;
}

.mv-logo-kuni::after {
    position: absolute;
    content: "";
    background-image: url(../img/mv-sub-11.png);
    width: 78px;
    height: 161px;
    top: -30px;
    right: -125px;
}

.mv-logo-maru::before {
    position: absolute;
    content: "";
    background-image: url(../img/mv-sub-06.png);
    width: 60px;
    height: 171px;
    top: 0;
    left: -200px;
}

.mv-logo-inn::before {
    position: absolute;
    content: "";
    background-image: url(../img/mv-sub-10.png);
    width: 81px;
    height: 155px;
    top: 15px;
    right: -90px;
}


.area-tl::before{
    position: absolute;
    content: "";
    background-image: url(../img/mv-sub-04.png);
    width: 104px;
    height: 154px;
    top: 130px;
    right: 80px;
}

.area-tr::before{
    position: absolute;
    content: "";
    background-image: url(../img/mv-sub-12.png);
    width: 226px;
    height: 156px;
    top: 200px;
    right: 200px;
}

.area-bl::before{
    position: absolute;
    content: "";
    background-image: url(../img/mv-sub-09.png);
    width: 121px;
    height: 166px;
    bottom: 260px;
    right: 75px;
    z-index: 2;
}

.area-br::before{
    position: absolute;
    content: "";
    background-image: url(../img/mv-sub-13.png);
    width: 99px;
    height: 190px;
    bottom: 250px;
    left: 260px;
}

/* ロゴ・キャッチコピー */
.mv-logo{
	position: absolute;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 170px;
	font-weight: 700;
	color: #fff;
	z-index: 3;
	position: absolute;
	top:40%;
	left: 50%;
	transform: translate(-50%,-50%);
    line-height: 0.85;
}

.mv-logo-line {
    font-family: "all-round-gothic", sans-serif;
  font-weight: 700;
  position: relative;
  color: #fff;
  display: inline-block;
  line-height: 0.7;
}


.mv-copy{
  position: absolute;
  height: 88px;
  line-height: 88px;
  padding:0 15px;
  font-size: 2.6vw;
  color: #fff;
  background-color: #5997c9;
  left: 260px;
  border-radius: 3px;
}

.mv-copy-01{
  bottom:18%;
}

.mv-copy-02{
  bottom:calc(18% - 102px);
}

/* ハッシュタグ群 */
.mv-tags {
  position: absolute;
  bottom: 30%;
  left: 60%;
  transform: translateX(-50%);
  z-index: 10;
}

.mv-tags ul {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
  padding: 0;
  margin: 0;
  list-style: none;
}

.mv-tags li {
  font-size: 20px;
  font-weight: 500;
  color: #3178b1;
  padding: 0 12px;
   height: 60px;
  line-height: 60px;
  background: #fff;
  border-radius: 3px;
    text-align: center;
  white-space: nowrap;
}

.mv .wave-wrapper {
  width: 100%;
  height: auto;
  line-height: 0; /* 余白除去 */
}

.mv .wave-wrapper svg {
  position: absolute;
  display: block;
  width: 100%;
  height: auto;
  z-index: 10;
  bottom: 8px;
  left: 0;
}

/* レスポンシブ */
@media screen and (max-width: 1700px) {
  .mv-logo {
    font-size: 135px;
}
/* 
.mv-tags{
    font-size: 16px;
} */

.mv-copy {
    height: 70px;
    line-height: 70px;
    font-size: 40px;
    left: 260px;
}

.mv-copy-01 {
    bottom: 18%;
}

.mv-copy-02 {
    bottom: calc(18% - 84px);
}

.mv-tags ul li{
        font-size: 16px;
        height: 40px;
        line-height: 40px;
  }

.mv-char{
  transform: scale(0.8);
  bottom: 25px;
}

.mv-sauna-m {
    left: 210px;
}

  .mv-logo-kuni::before,
  .mv-logo-kuni::after,
  .mv-logo-maru::before,
  .mv-logo-inn::before,
  .area-tl::before,
  .area-tr::before,
  .area-bl::before,
  .area-br::before {
    transform: scale(0.8);
  }

  .area-tl::before {
    top: 70px;
    right: 80px;
}

  .area-tr::before {
    top: 100px;
    right: 120px;
}

  .area-bl::before {
    bottom: 190px;
    right:0;
}

  .area-br::before{
  bottom: 180px;
    left: 180px;
  }
}

@media screen and (max-width: 1400px) {
  .mv-char{
  transform: scale(0.6);
  bottom: -32px;
}

.mv-copy {
    height: 60px;
    line-height: 60px;
    font-size: 36px;
    left: 260px;
}

    .mv-copy {
    left: 210px;
}

.mv-tags {
    bottom: 28%;
}

  .mv-logo-kuni::before,
  .mv-logo-kuni::after,
  .mv-logo-maru::before,
  .mv-logo-inn::before,
  .area-tl::before,
  .area-tr::before,
  .area-bl::before,
  .area-br::before {
    transform: scale(0.6);
  }

  .area-tl::before {
    top: 80px;
    right: 50px;
}

  .area-tr::before {
    top: 50px;
    right: 80px;
}

.area-bl::before {
    bottom: 150px;
    }

.area-br::before {
  bottom: 160px;
        left: 180px;
  }

    .mv-sauna-f {
    left: -55px;
}

.mv-sauna-m {
    left: 22%;
}

.mv-book-f {
    right: -55px;
}

.wave-wrapper svg {
    bottom: 5px;
}
}

@media screen and (max-width: 1150px) {
.mv-logo {
    font-size: 110px;
}

.mv-char{
  transform: scale(0.5);
        bottom: -75px;
}

.mv-copy {
    height: 55px;
    line-height: 55px;
    font-size: 30px;
    left: 180px;
}

.mv-copy-02 {
    bottom: calc(18% - 69px);
}

.area-tl::before {
    top: 45px;
    right: 0;
}

.area-tr::before {
    top: 0;
        right: 20%;
}

.area-bl::before {
        bottom: 85px;
    }


    .area-br::before {
        bottom: 74px;
        left: 110px;
    }

.mv-logo-maru::before {
    top: 0;
    left: -120px;
}

.mv-logo-inn::before {
    top: -35px;
    right: -90px;
}

.mv-sauna-m
{
    left: 8%;
}

.mv .wave-wrapper svg {
    bottom: 25px;
}
}



@media screen and (max-width: 950px) {

.mv-char {
    transform: scale(0.6);
    bottom: -110px;
}

  .mv-logo {
    font-size: 90px;
}

.mv-copy{
    height: 50px;
    line-height: 50px;
    font-size: 26px;
    left: 140px;
}

.mv-copy-01{
    bottom: 18%;
}

.mv-copy-02{
    bottom:calc( 18% - 64px) ;
}

.mv-char {
    transform: scale(0.4);
    bottom: -110px;
}

  .mv-logo-kuni::before,
  .mv-logo-kuni::after,
  .mv-logo-maru::before,
  .mv-logo-inn::before,
  .area-tl::before,
  .area-tr::before,
  .area-bl::before,
  .area-br::before {
    transform: scale(0.4);
  }

.area-bl::before {
    bottom: 75px;
    right: -60px;
}

.area-br::before{
    bottom: 65px;
    left: 90px;
}

.mv-logo-kuni::after {
    top: -25px;
    right: -90px;
}

  .mv-logo-maru::before {
    top: -20px;
    left: -80px;
}

.mv-logo-inn::before {
    top: -40px;
    right: -120px;
}

.mv-logo-inn::after {
    top: -35px;
    right: -90px;
}

 .mv .wave-wrapper svg{
    bottom: 40px;
  }

    .mv-sauna-f {
        left: -95px;
    }

    .mv-sauna-m {
        left: -7%;
    }

    .mv-book-f {
        right: -150px;
    }

    .mv-tags {
        bottom: 29%;
        width: 56%;
    }
  
}

@media screen and (max-width: 768px) {

.mv-bg {
    width: 100%;
height:850px;
    object-fit: cover;
    display: block;
  /* will-change: transform;
  backface-visibility: hidden;
  transform: translateZ(0); */
}
  
/* .mv::before{
    position: absolute;
    content: "";
    background-image: url(../img/mv-sp-bg-book.png);
    background-position: center;
    background-repeat: no-repeat;
    width: calc(745px * 0.7);
    height: calc(602px * 0.7);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
} */

.mv-logo {
    font-size: 90px;
    top: 40%;
    left: 50%;
}

.mv-copy {
  font-size: 30px;
    height: 60px;
    line-height: 60px;
    left: -45%;
}

.mv-copy-01 {
        bottom: -100px;
    }

.mv-copy-02 {
        bottom: -163px;
    }

    .mv-char {
      transform: scale(0.4);
      left: -10%;
      bottom: -105px;
  }

    .mv-sauna-m {
        left: 65%;
    }


  .mv-tags {
    bottom: 20px;
    
  }


.mv-book-f{
  display: none;
}

  .mv-logo-kuni::before,
  .mv-logo-kuni::after,
  .mv-logo-maru::before,
  .mv-logo-inn::before,
  .area-tl::before,
  .area-tr::before,
  .area-bl::before,
  .area-br::before {
    transform: scale(0.6);
  }

    .area-tl::before {
        top: 90px;
        right: 10px;
  }

      .area-tr::before {
        display: none;
        bottom: 143px;
        right: 0;
        top: initial;
    }

    .mv-logo-kuni::before {
    top: -80px;
    left: -70%;
    }

    .mv-logo-kuni::after {
        top: -60px;
        right: -140px;
    }

        .mv-logo-maru::before {
        top: 0;
        left: -140px;
    }

        .area-bl::before {
          top: 0;
        bottom: initial;
        left: 0;
        right:initial;
    }

        .area-br::before {
        bottom: initial;
        top: 0;
        left: initial;
        right: 30px;
        }

    .mv-tags {
        bottom: 170px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 10;
        width: 90%;
    }


    .mv-tags ul {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        gap: 8px;
    }

        .mv-tags ul li {
        font-size: 16px;
        height: 35px;
        line-height: 35px;
    }

     .mv .wave-wrapper svg {
        bottom: 64px;
    }
  }

@media screen and (max-width: 560px) {
  .mv-bg {
      object-position: 51% 24%;
	     height: 650px;
  }

  .mv-logo {
    font-size: 50px;
    top: 38%;
    left: 53%;
  }

    .mv-copy {
      font-size: 5.8vw;
      height: 40px;
      line-height: 40px;
      left: -58%;
  }

    .mv-copy-01 {
        bottom: -30px;
  }
  .mv-copy-02 {
bottom: -75px;
  }
    .mv-logo-kuni::before,
  .mv-logo-kuni::after,
  .mv-logo-maru::before,
  .mv-logo-inn::before,
  .area-tl::before,
  .area-tr::before,
  .area-bl::before,
  .area-br::before {
    transform: scale(0.4);
  }

    .area-br::before {
        bottom: initial;
        top: -30px;
        left: initial;
        right: 10px;
    }

        .area-bl::before {
        left: -15px;
    }

    .mv-logo-inn::before {
		top: -60px;
        right: -140px;
}

    .mv-logo-kuni::before {
        top: -60px;
        left: -100px;
    }

  .mv-logo-kuni::after {
        top: -60px;
        right: -100px;
    }

        .mv-logo-maru::before {
        top: -15px;
        left: -90px;
    }

        .mv-char {
        transform: scale(0.4);
        bottom: -125px;
    }

        .mv-sauna-f {
        left: -70px;
    }

        .mv-sauna-m {
        left: -7px;
    }

        .mv-tags {
        width: 95%;
        }

        .mv-tags ul li {
        font-size: 4.3vw;
        height: 25px;
        line-height: 25px;
            padding: 0 10px;
    }

    .mv-tags ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  max-width: 100%;
}

    .wave-wrapper svg {
        bottom: 63px;
    }
}

@media screen and (max-width: 360px) {
.mv-logo {
  font-size: 56px;
}

.mv-sauna-f {
        left: -100px;
}

.mv-sauna-m {
    left: -22px;
}

  .mv-char {
    transform: scale(0.3);
    bottom: -155px;
}

  .mv-copy{
    font-size: 4vw;
    height: 25px;
    line-height: 25px;
    left: -45%;
  }

    .mv-copy-01 {
        bottom: -36px;
    }
  .mv-copy-02 {
  bottom: -66px;
}

  .mv-tags ul li {
  gap: 0;
  }

  .mv-tags ul li {
    font-size: 10px;
    height: 20px;
    line-height: 20px;
    padding: 0 10px;
  }
	
    .mv-tags {
        bottom: 240px;
    }
	
	.mv .wave-wrapper svg {
		bottom: 69px;
	}
	
	.mv-char {
		transform: scale(0.3);
		bottom: -150px;
	}
	
    .mv-tags {
        bottom: 120px;
    }
}

/* about */
.about{
  width: 100%;
  padding-top: 40px;
}

.about-inner {
    width: 90%;
    max-width: 1600px;
    margin: 0 auto 50px;
}

.about h2{
  margin-bottom: 40px;
}

.about .flex-box{
  display: flex;
  justify-content: start;
      align-items: center;
}

.about .flex-item{
  width: 33.33%;
}

.about .section-mark-en{
  color: #b1cfe1;
  line-height: 1;
  letter-spacing: -0.025em;
}

.about .nitalago{
  font-size: 28px;
  line-height: 2.2;
  letter-spacing: 0.05em; 
}

.about span{
  position: relative;
  color: #e5b44b;
}

.about span::before{
    position: absolute;
    content: "";
    background-image: url(../img/common/boreder-line-dot.png);
    border: #e5b44b ;
    width: 161px;
    height: 6px;
    left: 4px;
    bottom: -12px;
}

.about .flex-box .img-area{
  position:relative ;
}

.about .flex-box .img-area::before{
    position: absolute;
    content: "";
    background-image: url(../img/about-01.png);
    width: 548px;
    height: 394px;
    left: -70px;
    bottom: -105px;
    z-index: 15;
}

.about .flex-box .img-area::after {
    position: absolute;
    content: "";
    background-image: url(../img/about-02.png);
    width: 202px;
    height: 219px;
    left: -90px;
    bottom: -310px;
    z-index: 16;
}

@media screen and (max-width: 1650px) {

.about-inner {
    margin: 0 auto 150px;
}

  .about .flex-box {
        flex-wrap: wrap;
        justify-content: space-between;
  }

  .about .flex-item {
    width: 45%;
    margin-bottom: 40px;
  }

  .about .flex-box .img-area {
    width: 100%;
    height: 300px; /* 高さ調整 */
    position: relative;
  }

  .about .flex-box .img-area::before {
    left: 50%;
    bottom: -40px;
    transform: translateX(-50%);
  }

  .about .flex-box .img-area::after {
      left: 35%;
      bottom: -180px;
      transform: translateX(-50%);
  }
}

@media screen and (max-width: 1150px) {

  .about-inner {
    width: 90%;
    max-width: 1600px;
    margin: auto;
    margin-bottom: 250px;
}

.about h2 {
  font-size: 20px;
    margin-bottom: 30px;
}

.about .section-mark-en {
    font-size: 80px;
    color: #b1cfe1;
    line-height: 1;
    letter-spacing: -0.025em;
}

.about .nitalago {
    font-size: 24px;
    line-height: 2.2;
    letter-spacing: 0.05em;
}

.about span::before {
    width: 153px;
    height: 6px;
    left: 0px;
    bottom: -12px;
}

}

@media screen and (max-width: 768px) {

  .about-inner {
    width: 90%;
    max-width: 1600px;
    margin: auto;
    margin-bottom: 0;
}


  .about .flex-box {
    flex-direction: column;
    align-items: center;
  }

    .about .flex-item:nth-child(1) {
      width: 60%;
    order: 1;
  }

  .about .flex-item:nth-child(2) {
    width: 50%;
    order: 3; 
  }

  .about .img-area {
    order: 2;
  }

  .about .flex-box>:nth-of-type(2){
    width: 100%;
  }

  .about .section-mark-en {
    font-size: 80px;
  }

  .about .nitalago {
    font-size: 22px;
    line-height: 2;
    max-width: 400px;
    margin: auto;
  }

  .about .flex-box .img-area {
    width: 100%;
    height: 480px;
  }

  .about span::before {
    position: absolute;
    content: "";
    background-image: url(../img/common/boreder-line-dot.png);
    border: #e5b44b;
    width: 140px;
    height: 6px;
    left: 0px;
    bottom: -12px;
}

  .about .flex-box .img-area::before {
    background-image: url(../img/about-01-sp.png);
    top:0;
    left: 50%;
    transform: translateX(-50%);
  }

  .about .flex-box .img-area::after {
        left: 58%;
        bottom: -40px;
        transform: scale(0.75);
  }
}

@media screen and (max-width: 600px) {
.about {
    padding-top: 0px;
	margin-top: -30px;
}
    .about h2 {
        font-size: 1.2rem;
        margin-bottom: 15px;
      }

  

    .about .flex-item:nth-child(1) {
        width: 100%;
        order: 1;
    }

      .about .section-mark-en {
    font-size: 50px;
  }
      .about .flex-box .img-area {
        width: 100%;
        height: 320px;
    }

  .about .nitalago {

        line-height: 1.8;
        margin: auto;
        font-size: 1.2rem;
  }

    .about span::before {
        position: absolute;
        content: "";
        background-image: url(../img/common/boreder-line-dot.png);
        border: #e5b44b;
        width: 116px;
        height: 6px;
        left: -2px;
        bottom: -12px;
    }

    .about .flex-box .img-area::before {
        top: -70px;
        transform: translateX(-50%) scale(0.60);
  }

  .about .flex-box .img-area::after {
        left: 45%;
        bottom: -40px;
        transform: scale(0.55);
  }
}

@media screen and (max-width: 360px) {
	.about h2 {
		font-size: 14px;
	}
	
  .about .flex-box .img-area::before {
    top: -70px;
    transform: translateX(-50%) scale(0.5);
}

    .about .flex-box .img-area::after {
    left: 45%;
    bottom: 0;
    transform: scale(0.45);
}
}

/* need */
/* テキストのstyle */
.need{
  width: 100%;
  background-image: url(../img/need-bg.png);
}

.need .wave-wrapper{
  position: relative;
      height: auto;
    line-height: 0;
}

.need .wave-wrapper svg {
display: block;
    height: auto;
    width: 100%;
}

.need .wave-top {
  top: -5px;
}

.need .wave-bottom {
  bottom:-5px;
}

.need-inner{
  width: 100%;
  max-width: 1600px;
  margin: auto;
  text-align: center;
  margin-top: 25px;
}

.need h2{
  max-width: 550px;
  height: 80px;
  line-height: 80px;
  font-size: 25px;
  color: #fff;
  background-color: #5997c9;
  border-radius: 5px;
margin: 70px auto 30px auto;
}

.need .section-mark-en{
  font-size: 120px;
  color: #fff;
}

.need .flex-box{
  display:flex;
  justify-content: center;
  gap: 20px;
  margin-top: 30px;
}

.balloon-01{
margin-top: 50px;
}

.balloon-03{
margin-top: 30px;
}

.need .flex-item{
    width: 30%; /* 3カラム想定 */
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

.need h3{
  position: relative;
  font-size: 22px;
  color: #376991;
  margin-top: 60px;
}

.need .balloon-01 h3::before{
  content: "HOPE!";
  position: absolute;
  top: -75px;
  left: 0;
  font-family: "all-round-gothic", sans-serif;
  font-size: 40px;
  font-weight: bold;
  color: #8fbee3;
  transform: rotate(-10deg); /* ← ここで傾ける！ */
  z-index: 2;
}

.need .balloon-02 h3::before{
    content: "HOPE!";
    position: absolute;
    top: -75px;
    right: -10px;
    font-family: "all-round-gothic", sans-serif;
    font-size: 40px;
    font-weight: bold;
    color: #8fbee3;
    transform: rotate(15deg);
    z-index: 2;
}

.need .balloon-03 h3::before{
    content: "HOPE!";
    position: absolute;
    top: -65px;
    right: -40px;
    font-family: "all-round-gothic", sans-serif;
    font-size: 40px;
    font-weight: bold;
    color: #8fbee3;
    transform: rotate(30deg);
    z-index: 2;
}

.need-hope-text{
  color: #333;
  text-align: left;
  margin-top: 15px;
}

.balloon-03 .need-hope-text{
  margin-left: 30px;
}

.need-answer-label{
  position: relative;
  font-size: 50px;
  color: #e5b44b;
}

.need-answer-label::after{
  content: '';
  width: 320px;
  height: 1px;
  display: inline-block;
  background-color: #050505;
  position: absolute;
  bottom: 1px;
  left: 50%;
  transform: translateX(-50%);
}

.balloon-01 .need-answer-label::before,
.balloon-03 .need-answer-label::before{
  content: "";
  position: absolute;
  top: -28px;
  right: 40px;
  width: 43px;
  height: 49px;
  background-image: url(../img/common/need-answer-01.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.balloon-02 .need-answer-label::before{
  content: "";
  position: absolute;
  top: -20px;
  left: 50px;
  width: 43px;
  height: 49px;
  background-image: url(../img/common/need-answer-02.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.need-answer-title{
  font-size: 22px;
  color: #36aba4;
  margin-top: 20px;
}

.need-answer-desc{
  color: #333333;
  line-height: 33px;
  text-align: left;
  margin-top:20px;
}

/* 配置 */

.flex-item-text-box-t {
  position: relative;
  padding: 60px 40px 40px;
  z-index: 1;
}

.balloon-01 .flex-item-text-box-t::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 440px;
  height: 310px;
  background-image: url(../img/need-01.png); /* 左の吹き出し画像 */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: -1;
}

.balloon-02 .flex-item-text-box-t::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 440px;
  height: 310px;
  background-image: url(../img/need-02.png); /* 中央の吹き出し画像 */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: -1;
}

.balloon-03 .flex-item-text-box-t::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 440px;
  height: 310px;
  background-image: url(../img/need-03.png); /* 右の吹き出し画像 */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: -1;
}

.flex-item-text-box-t-inner {
  text-align: center;
  z-index: 1;
}

.flex-item-img {
  position: relative;
  top: -35px;
}

.flex-item-img img{
  position: relative;
  z-index: 1;
}

.balloon-03 img{
  left: 30px;
}

.flex-item-img::before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 360px;
    height: 550px;
    background: #dce4e8;
    border-radius: 30px;
    z-index: 0;
      /* 破線の border を背景で再現 */
  background-image:
    repeating-linear-gradient(to bottom, #5997c9 0 14px, transparent 0px 20px),  /* top */
    repeating-linear-gradient(to bottom, #5997c9 0 14px, transparent 0px 20px),  /* bottom */
    repeating-linear-gradient(to bottom, #5997c9 0 14px, transparent 0px 20px), /* left */
    repeating-linear-gradient(to bottom, #5997c9 0 14px, transparent 0px 20px); /* right */

  background-repeat: no-repeat;
  background-position:
    top left,
    bottom left,
    top left,
    top right;

  background-size:
    100% 3px,     /* 横線：幅100%、高さ3px */
    100% 3px,
    3px 100%,     /* 縦線：幅3px、高さ100% */
    3px 100%;
}

.flex-item-text-b {
  position: relative;
  background: #fff;
  border-radius: 60px;
  padding: 50px 52px;
  width: 100%;
  height: 370px;
  z-index: 1;
  text-align: center;
}

.balloon-01 .flex-item-text-b::before{
  content: "";
  position: absolute;
  bottom: -145px;
  left: 90px;
  width: 85px;
  height: 166px;
  background-image: url(../img/need-07.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.balloon-02 .flex-item-text-b::before{
  content: "";
  position: absolute;
  bottom: -90px;
  right: 80px;
  width: 93px;
  height: 140px;
  background-image: url(../img/need-08.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.balloon-03 .flex-item-text-b::before{
  content: "";
  position: absolute;
  bottom: -80px;
  right: 10px;
  width: 60px;
  height: 171px;
  background-image: url(../img/need-09.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.balloon-01 .flex-item-text-b {
    top: -160px;
}

.balloon-02 .flex-item-text-b {
      top: -55px;
}

.balloon-03 .flex-item-text-b {
      top: -65px;
}

@media screen and (max-width: 1500px) {

  .need-inner {
    margin-bottom: 100px;
}

  .need .flex-box {
    flex-direction: column;
    align-items: center;
    gap: 100px;
  }

  .need .flex-item {
    width: 100%;
    max-width: 600px;
  }
	
	.balloon-01 .need-answer-label::before,
.balloon-03 .need-answer-label::before{
  right: 100px;
}

.balloon-02 .need-answer-label::before{
  left: 110px;
}	
}

@media screen and (max-width: 768px) {

    .need-inner {
    margin-bottom:0;
}

  .need .pc{
    display: none;
  }

  .need .sp{
    position: relative;
    display: block;
  }

  .need h2 {
    font-size: 24px;
    width: 385px;
    height: 70px;
    line-height: 70px;
  }

  .need .section-mark-en {
    font-size: 90px;
    color: #fff;
    line-height: 1.1;
}

      .need .flex-item {
        width: 100%;
        max-width: none;
    }


.slick-prev {
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translateY(-50%);
  width: 88px;
  height: 88px;
  background: url(../img/common/nrrd-sp-prev.png) no-repeat center center;
  background-size: contain;
  border: none;
  z-index: 10;
}
.slick-next {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 88px;
  height: 88px;
  background: url(../img/common/nrrd-sp-next.png) no-repeat center center;
  background-size: contain;
  border: none;
  z-index: 10;
}

.photo-slider {
  width: 100%;
  overflow: hidden;
}

.slick-track {
  display: flex;
  align-items: stretch;
}

.slick-slide {
  display: flex ;
  justify-content: center;
  height: auto ;
}

.photo-slide {
  width: 100% ;
  display: flex;
  justify-content: center;
}

.photo-slide .flex-item {
  width: 100%;
  max-width: 480px;
  flex-shrink: 0;
  margin-top: 50px;
}

.balloon-02 .flex-item-text-b {
top: -145px;
}

.balloon-03 .flex-item-text-b {
    top: -135px;
}
	
.balloon-01 .need-answer-label::before,
.balloon-03 .need-answer-label::before {
        right: 50px;
}
	
.balloon-02 .need-answer-label::before {
        left:50px;
}
}

@media screen and (max-width: 600px) {
  .photo-slider {
    padding-left: 0;
    padding-right: 0;
    overflow: hidden; /* はみ出しを強制カット */
  }


  .slick-prev {
      position: absolute;
      top: 33%;
      left: 0;
      transform: translateY(-50%);
      width: 88px;
      height: 88px;
      background: url(../img/common/nrrd-sp-prev.png) no-repeat center center;
      background-size: contain;
      border: none;
      z-index: 10;
      transform: scale(0.5);
  }
  .slick-next {
      position: absolute;
      top: 33%;
      right: 0;
      transform: translateY(-50%);
      width: 88px;
      height: 88px;
      background: url(../img/common/nrrd-sp-next.png) no-repeat center center;
      background-size: contain;
      border: none;
      z-index: 10;
      transform: scale(0.5);
  }


  .need .section-title {
    font-size: 20px;
    height: 60px;
    line-height: 60px;
    width: 80%;
    max-width: 350px;
  }

  .need .section-mark-en {
    font-size: 50px;
  }

  .flex-item-text-box-t {
    padding: 40px 20px 30px;
  }

  .balloon-01 .flex-item-text-box-t::before,
  .balloon-02 .flex-item-text-box-t::before,
  .balloon-03 .flex-item-text-box-t::before {
    width: 300px;
    height: 220px;
    background-size: contain;
  }

  .flex-item-text-b::before{
    transform: scale(0.6);
  }

  .balloon-01 .flex-item-text-b::before{
    bottom: -90px;
    left: 150px;
  }

  .balloon-02 .flex-item-text-b::before{
    bottom: -65px;
    right: 30px;
  }

  .balloon-03 .flex-item-text-b::before{
    transform: scale(0.6);
  }


  .need h3.need-hope-title {
    font-size: 18px;
    margin-top: 20px;
  }

.need .balloon-01 h3::before {
    content: "HOPE!";
    position: absolute;
    top: -36px;
    left: 0;
    font-family: "all-round-gothic", sans-serif;
    font-size: 24px;
    font-weight: bold;
    color: #8fbee3;
    transform: rotate(-10deg);
    z-index: 2;
}

  .need .balloon-02 h3::before {
    content: "HOPE!";
    position: absolute;
    top: -33px;
    right: -10px;
    font-family: "all-round-gothic", sans-serif;
    font-size: 24px;
    font-weight: bold;
    color: #8fbee3;
    transform: rotate(15deg);
    z-index: 2;
}

  .need .balloon-03 h3::before {
    content: "HOPE!";
    position: absolute;
    top: -33px;
    right: -35px;
    font-family: "all-round-gothic", sans-serif;
    font-size: 24px;
    font-weight: bold;
    color: #8fbee3;
    transform: rotate(15deg);
    z-index: 2;
}


  .need-hope-text {
    line-height: 24px;
    letter-spacing: 1px;
    margin-top: 15px;
  }

  .flex-item-img::before {
    width: 240px;
    height: 400px;
  }

  .flex-item-img img {
        width: 180px;
    height: auto;
  }

  .balloon-02 .flex-item-text-b {
        top: -110px;
        height: 300px;
	
    }

  .balloon-02 .flex-item-img img{
        top: 2px;
	            width: 250px;
}
	.balloon-03 .flex-item-img img{
		width: 220px;
	}
  .flex-item-text-b {
    padding: 35px;
    height: auto;
    width: 100%;
}

.balloon-01 .flex-item-text-b {
padding: 30px;
  top: -150px;
        height: 300px;
}

.need-answer-label {
  font-size: 30px;
}

.balloon-01 .flex-item-img{
      top: -35px;
}

  .balloon-01 .need-answer-label::before, .balloon-03 .need-answer-label::before {
    top: -20px;
    right: 15px;
    transform: scale(0.7);
}

  .balloon-02 .need-answer-label::before {
    top: -20px;
    left: 15px;
    transform: scale(0.7);
  }

  .need-answer-label::after {
    content: '';
    width: 200px;
    height: 1px;
    display: inline-block;
    background-color: #050505;
    position: absolute;
    bottom: -4px;
    left: 50%;
    transform: translateX(-50%);
}



  .need-answer-desc {
    line-height: 24px;
        margin-top: 15px;
  }

  .photo-slider {
    padding: 0 10px;
  }

  .slider-next-btn,
  .slider-prev-btn {
    width: 30px;
    height: 30px;
  }

  .slider-next-btn::after,
  .slider-prev-btn::after {
    background-size: 80%;
  }

      .balloon-03 .flex-item-text-b {
top: -95px;
        height: 300px;
}
}

@media screen and (max-width: 600px) {

    .need-answer-title {
        font-size: 1.2rem;
    }

        .need-answer-desc {
     
    }

  }

  @media screen and (max-width: 360px) {
        .balloon-02 .flex-item-img img{
      width: 80%;
		top:-20px;
    }

    .balloon-03 img{
      width: 70%;
    }
        .balloon-02 .flex-item-text-b {
        top: -130px;
    }

    .balloon-01 .flex-item-text-box-t::before, .balloon-02 .flex-item-text-box-t::before, .balloon-03 .flex-item-text-box-t::before {
    width: 270px;
    height: 190px;
    background-size: contain;
  }
  }

/* feature */
.feature{
  background-image: url(../img/feature-bg.png);
  background-position: center 380%;
  background-repeat: no-repeat;
  width: 100%;
      overflow: hidden;
}

.feature-inner {
    width: 100%;
    max-width: 1600px;
    margin: auto;
    margin-top: 25px;
}

.feature h2{
  padding-left: 100px;
}
.feature .section-mark-en{
    color: #b1cfe1;
    line-height: 1;
    padding-left: 100px;
}
  
/* ==== POINTブロック共通 ==== */
.point-block {
  position: relative;
  padding: 60px 0;
  margin: 0 50px 120px;
}

.point-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 100px;
  margin: 0 auto;
}

.reverse{
  flex-direction: row-reverse;
}

.point-left,
.point-right {
  flex: 1;
  position: relative;
}

/* ==== 左側（画像部分） ==== */
.point-img {
  position: relative;
}

.point-01 .point-img::before,
.point-02 .point-img::before,
.point-03 .point-img::before{
    content: "";
    position: absolute;
    background-size: contain;
    z-index: 10;
  }

.point-01 .point-img::before {
    bottom: 0px;
    left: 50px;
    width: 94px;
    height: 180px;
    background: url(../img/feature-01-04.png) no-repeat center center;
  }

.point-02 .point-img::before {
    bottom: -25px;
    right: 50px;
    width: 115px;
    height: 188px;
    background: url(../img/feature-02-04.png) no-repeat center center;
  }

.point-03 .point-img::before {
  bottom: -40px;
  left: 50px;
  width: 85px;
  height: 184px;
  background: url(../img/feature-03-04.png) no-repeat center center;
}

.point-01 .point-img::after,
.point-02 .point-img::after,
.point-03 .point-img::after {
    content: "";
    position: absolute;
    width: 311px;
    height: 277px;
    background: url(../img/common/bg-dot.png) no-repeat center center;
    background-size: contain;
    z-index: -1;
  }

.point-01 .point-img::after {
    bottom: 75px;
    left: -170px;
  }

.point-02 .point-img::after {
    bottom: 75px;
           right: -85px;
  }


.point-03 .point-img::after{
    bottom: -100px;
    left: -200px;
}

.point-img img {
  height: auto;
  display: block;
  border-radius: inherit;
}

.point-tag {
    position: absolute;
    top: 110px;
    right: 35px;
    width: 270px;
    height: 60px;
    line-height: 60px;
    font-size: 25px;
    background-color: #009b9f;
    color: #fff;
    font-weight: bold;
    text-align: center;
}

.reverse .point-tag {
    position: absolute;
    top: 110px;
    left: 35px;
    width: 270px;
    height: 60px;
    line-height: 60px;
    font-size: 25px;
    background-color: #009b9f;
    color: #fff;
    font-weight: bold;
    text-align: center;
}

/* ==== 右側（テキスト部分） ==== */
.point-label {
    font-size: 40px;
    font-weight: bold;
    width: 180px;
    background-color: #00b4aa;
    color: #fff;
    display: flex;
    border-radius: 80px;
    margin-bottom: 0px;
    text-align: center;
    justify-content: center;
    align-items: center;
}

.point-number {
  position: relative;
  display: flex;
  align-items: center;
  gap: 35px;
  margin-bottom: 16px;
}

.point-number::before{
    content: '';
    width: calc( 100% - 20px );
    height: 1px;
    display: inline-block;
    background-color: #050505;
    position: absolute;
    bottom: 0;
    left: 0;
}

.point-number .number {
  font-size: 160px;
  color: #333;
  line-height: 1;
}

.point-title {
  font-size: 25px;
  color: #333;
  line-height: 1.8;
}

.point-title .point-highlight {
  color: #318ac8;
}

.point-text {
  margin-bottom: 20px;
}

.point-sub-images {
  display: flex;
  gap: 12px;
}

.point-sub-images img {
    height: auto;
    border-radius: 30px;
    object-fit: cover;
    border: solid 4px #318ac8;
}


@media screen and (max-width: 1500px) {
.feature{
  background-image: url(../img/feature-sp-bg.png);
  background-position: center -150%;
}

  .point-block {
    margin: 0 25px 180px;
}

  .point-inner {
    gap: 40px;
  }

  .point-left {
    flex: 6;
  }

  .point-left img{
    width: 100%;
  }

  .point-right {
    flex: 4;
  }

  .point-number .number {
    font-size: 120px;
  }

  .point-title {
    font-size: 22px;
  }

  .point-tag {
    width: 200px;
    font-size: 18px;
    height: 50px;
    line-height: 50px;
    top: 90px;
  }

  .reverse .point-tag {
    width: 200px;
    font-size: 18px;
    height: 50px;
    line-height: 50px;
    top: 90px;
  }

  .point-sub-images img {
    width: 160px;
    height: auto;
  }

  .point-label {
    font-size: 32px;
    width: 180px;
    height: 44px;
    line-height: 44px;
  }

}


 @media (max-width: 1024px) {
  .feature-inner {
      padding: 0 70px;
  }

    .point-block {
      margin: 0 0 180px 0;
    }

  .feature h2 {
    padding-left: 0;
  }

  .feature .section-mark-en{
    padding-left: 0;
  }

    .point-number .number {
    font-size: 160px;
  }
  .point-title {
    font-size: 25px;
    line-height: 1.8;
  }
  .point-text {
    margin-bottom: 0;
    max-width: 390px;
    margin: 0 auto;
    text-align: left;
  }
  .point-label {
    font-size: 40px;
    width: 210px;
    height: 54px;
    line-height: 54px;
    margin-bottom: 0;
  }

  .point-tag {
    top: 72px;
    right: 30px;
    font-size: 18px;
    width: 25vw;
    height: 42px;
    line-height: 42px;
    min-width: 180px;
  }

  .reverse .point-tag {
    top: 72px;
    left: 30px;
    width: 26vw;
    font-size: 18px;
    height: 42px;
    line-height: 42px;
    min-width: 195px;
  }

  .point-inner {
    flex-direction: column;
    gap: 40px;
  }
  .reverse {
    flex-direction: column;
  }
  .point-left,
  .point-right {
    width: 100%;
  }
  .point-img img {
    max-width: 100%;
    height: auto;
  }

  .point-01 .point-img::before,
  .point-02 .point-img::before,
  .point-03 .point-img::before{
    transform: scale(0.8);
  }

  .point-01 .point-img::after, 
  .point-02 .point-img::after, 
  .point-03 .point-img::after {
    transform: scale(0.7);
}

.point-01 .point-img::after{
  bottom: 0;
  left: -135px;

} 
.point-02 .point-img::after{
  bottom: 0;
  right: -135px;
} 
.point-03 .point-img::after{
  bottom: 0;
  left: -135px;
}

  .point-01 .point-img::before{
    bottom: -30px;
    left: 35px;
  }

  .point-02 .point-img::before {
    bottom: -25px;
    right: 50px;
}

  .point-number {
        margin: 0px 10px 40px 10px;
    align-items: center;
  }
  .point-number::before {
    width: 100%;
  }

  .reverse .point-tag {
    left: 20px;
    right: auto;
  }

  .point-sub-images {
    justify-content: center;
    gap: 24px;
    margin-top: 45px;
  }
  .point-sub-images img {
    width: 100%;
    max-width: 240px;
  }
} 

 @media (max-width: 600px) {
	 .feature {
        background-position: center 50%;
    }
	 
    .feature .pc{
      display: none;
    }

    .feature .sp{
      display:block;
    }

    .feature-inner {
        padding: 0 20px;
    }	 
	     .feature h2 {
	
    }
	     .point-number {
		        margin: 0px 10px 10px 10px;
	 }

        .point-block {
        margin: 0 0 20px 0;
			    padding: 40px 0;
    }

        .point-label {
        font-size: 25px;
        width: 130px;
        height: 40px;
        line-height: 40px;
        margin-bottom: 0;
    }

    .point-tag {
      top: 50px;
      right: 10px;
      width: auto;
      height: 25px;
      line-height: 25px;
    }

    .reverse .point-tag {
        top: 50px;
        left: 10px;
        width: auto;
        height: 25px;
        line-height: 25px;
        min-width: auto;
    }

        .point-title {
        font-size: 18px;
        line-height: 1.8;
    }

    .point-number {
    align-items: center;
    gap: 35px;
    }

    .point-number .number{
        font-size: 100px;
    }

    .point-text {
        width: 100%;
        max-width: 90%;
    }

        .point-01 .point-img::before, 
        .point-02 .point-img::before, 
        .point-03 .point-img::before {
        transform: scale(0.5);
    }

      .point-01 .point-img::after, 
  .point-02 .point-img::after, 
  .point-03 .point-img::after {
    transform: scale(0.5);
}

.point-01 .point-img::after{
  bottom: 0;
  left: -135px;

} 
.point-02 .point-img::after{
  bottom: 0;
 right: -105px;
} 
.point-03 .point-img::after{
  bottom: 0;
  left: -135px;
}

.point-sub-images {
	justify-content: center;
	align-items: center;
	gap: 10px;
	margin-top: 30px;
	 }
	 
.point-sub-images img {
	width:50%;		 
 }
}
	 
@media screen and (max-width: 360px) {
  .need .section-title {
    font-size: 16px;
    height: 45px;
    line-height: 45px;
  }

  .point-01 .point-img::before, .point-02 .point-img::before, .point-03 .point-img::before {
        transform: scale(0.4);
    }

    .point-01 .point-img::before {
    bottom: -70px;
    left: 35px;
}
.point-02 .point-img::before {
        bottom: -50px;
        right: 10px;
    }

  .point-03 .point-img::before {
    bottom: -70px;
    left: 20px;
  }
	
	    .point-label {
        font-size: 22px;
        width: 125px;
        height: 30px;
        line-height: 30px;
        margin-bottom: 0;
    }
	
	    .point-number .number {
        font-size: 65px;
    }
	
	    .point-title {
        font-size: 16px;
        line-height: 1.8;
    }

}


 /* photo */
.photo {
    width: 100%;
    background-image: url(../img/photo-bg.png);
  }

.photo h2{
  color: #fff;
  margin-bottom: 20px;
}

.label-box{
    padding: 0 20px;
}

.photo-inner{
  position: relative;
  margin-top: 110px;
}

.photo-inner::before{
  content: "";
  position: absolute; 
  bottom: 70px;
  left: 15%;
  width: 81px;
  height: 181px;
  background: url(../img/photo-05.png) no-repeat center center;
  background-size: contain;
  z-index: 10;
}

.photo-inner::after{
  content: "";
  position: absolute; 
  bottom: 70px;
  right: 15%;
  width: 99px;
  height: 173px;
  background: url(../img/photo-06.png) no-repeat center center;
  background-size: contain;
  z-index: 10;
}


.photo .section-mark-en{
  color: #fff;
}

.photo .label-box{
    width: 100%;
  max-width: 1600px;
  margin: auto;
}

.photo .section-mark-en{
    color: #fff;
    line-height: 1;
    letter-spacing: -0.025em;
}

.photo-gallery-track {
  display: flex;
  width: max-content;
  gap: 3.6vw;
}

.gallery-item {
  flex: 0 0 auto;
  width: 220px;
  height: auto;
  border-radius: 20px;
  overflow: hidden;
}

.gallery-item img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 20px;
  object-fit: cover;
}

.photo-gallery-loop {
  overflow: hidden;
  width: 100%;
  position: relative;
}

.photo-gallery-track {
  display: flex;
  flex-wrap: nowrap;
  margin-top: 100px;
}


@keyframes scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}

.photo-gallery-track>div:nth-of-type(odd){
  margin-top: 5.2vw;
}

.gallery-item {
  flex: 0 0 auto;
  border-radius: 20px;
  overflow: hidden;
  width: 17vw;
  min-width: 220px;
  height: auto;
}

.gallery-item img {
  width: 100%;
  height: auto;
  display: block;
}

.photo .wave-wrapper{
  position: relative;
      height: auto;
    line-height: 0;
}

.photo .wave-top{
  top: -5px;
}

.photo .wave-bottom {
  bottom:-5px;
}

.photo .wave-wrapper svg {
    display: block;
    height: auto;
    width: 100%;
}

.photo .button {
    display: block;
    width: 165px;
    height: 50px;
    line-height: 50px;
    margin: 100px auto 80px;
    background-color: #222741;
    color: #fff;
    text-decoration: none;
    border-radius: 25px;
    letter-spacing: 0.05em;
    transition: all 0.3s ease;
    font-size: 18px;
    text-align: center;
}

.photo .button:hover {
  background-color: #3d4769;
  transform: translateY(3px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  opacity: 1;
}

 @media (max-width: 768px) {
.photo .sp{
  display: block;
}



.photo-inner::before {
  bottom: 50px;
    transform: scale(0.6);
 }

.photo-inner::after {
  bottom: 70px;
    transform: scale(0.6);
 }

 .photo-gallery-track>div:nth-of-type(odd){
  margin-top: 50px;
}
.gallery-item {
  width: 200px;
}}
@media screen and (max-width: 600px) {
.photo-inner {
    margin-top: 70px;
}

.photo-gallery-track {
  gap: 15px;
    margin-top: 60px;
}
	.photo h2{
		    margin-bottom: 10px;
	}
}

/* access */
.access{
  text-align: center;
    margin: 10px auto 50px;
}

.access-inner{
  text-align: center;
  width: 100%;
  max-width: 1600px;
  margin: auto;
}

.access .img-wrap {
  width: 85%;
  max-width: 1000px;
  margin: auto;
  aspect-ratio: 1000 / 520; 
  overflow: hidden;
}

.access .img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover; 
  border-radius: 30px;
}

.access .section-mark-en {
    color: #b1cfe1;
        margin: 10px 0 40px;
    line-height: 1;
    letter-spacing: -0.025em;
}


.access .map-wrapper {
  width: 100%;
  max-width: 1300px;
  margin:85px auto 0;
}

.access .map-wrapper iframe {
  width: 100%;
  height: 480px;
  display: block;
  border: none;
  border-radius: 30px;
}

.access .logo{
  margin: 110px auto 52px;
}

.access .logo a{
  transition: all 0.3s;
}

.access .logo a:hover{
  opacity: 0.6;
}

.access .store-name{
margin: 55px auto 10px;
font-size: 110%;
}

.access .address{
  margin-bottom :35px;
font-size: 110%;
}

.access .button {
    display: inline-block;
    font-size: 18px;
    width: 272px;
    height: 72px;
    line-height: 72px;
    letter-spacing: 0.05em;
    border-radius: 10px;
    text-decoration: none;
    color: #fff;
    background-color: #36aba4;
    transition: all 0.3s ease;
}

@media screen and (max-width: 768px) {

  .access .section-mark-en {
    margin: 20px auto 30px;
    padding-left: 0;
  }

  .access .map-wrapper {
    margin: 40px auto 0;
  }

  .access .logo {
    margin: 60px auto 40px;
  }

  .access .store-name {
    margin: 40px auto 30px;
  }

  .access .address {
    margin-bottom: 25px;
  }

  .access a.button {
    width: 180px;
    height: 50px;
    line-height: 50px;
    font-size: 14px;
  }

  .access .logo {
  transform: scale(0.8);
  margin: 60px auto 15px;
}

  .access .store-name {
    margin: 0px auto 25px;
}

  .access .img-wrap {
    width: 100%;
    margin: auto;
  }

  .access-inner {
    padding: 0 20px;
  }
}

@media screen and (max-width: 360px) {
    .access .store-name {
      font-size: 14px;
    }
    .access .address {
      font-size: 14px;
    }
}

/* reserve */
.reserve{
  background-image: url(../img/reserve-bg.png);
  background-position: center center;
  object-fit: cover;
  height: 1000px;
}

.reserve .wave-wrapper {
    position: relative;
    height: auto;
    line-height: 0;
    margin-bottom: 150px;
    top: -5px;
}

.reserve-inner{
  text-align: center;
}

.reserve h2{
  color: #3178b1;
    margin-bottom: -30px;
}

.reserve .section-mark-en{
  color: #FFF;
}

.reserve .reserve-container{
  padding: 60px 0 75px;
  width: 1000px;
  max-height: 555px;
  border-radius: 10px;
  background-color: #ffffff80;
  margin: auto;
}

.reserve .flex-box{
  position: relative;
  display: flex;
  gap: 7px;
  width: 100%;
  max-width: 695px;
  max-height: 180px;
  margin:30px auto 0;
  padding: 8px 10px;
  border-radius: 10px;
}

.reserve .flex-box::before {
    content: "";
    position: absolute;
    background-image: url(../img/reserve-01.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 74px;
    height: 194px;
    bottom: -35px;
    left: -75px;
}

.reserve .flex-box::after {
    content: "";
    position: absolute;
    background-image: url(../img/reserve-02.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 83px;
    height: 205px;
    bottom: -47px;
    right: -80px;
}

.reserve .flex-box .flex-item{
  width: 50%;
  height: 180px;
  background-color: #36aba4;
  border-radius: 10px;
  padding: 8px 10px;
  text-decoration: none;
  transition: all 0.3s ease;
  position: relative;
}


.reserve .flex-box .flex-item:hover,
.access .button:hover {
  background-color: #2e8f89;
  transform: translateY(3px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  opacity: 1;
}

.reserve .flex-box .flex-item .frame-inner {
  position: relative;
      height: 165px;
  border: solid 1px #ffffff;
  border-radius: 5px;
  text-align: center;
}

.reserve .flex-box .flex-item .frame-inner .reserve-box-text,
.reserve .flex-box .flex-item .frame-inner .tel-box-text{
  position: relative;
  font-size: 20px;
  max-width: 250px;
  height: 50px;
  line-height: 50px;
  margin: 11px auto 0;
  color: #36aba4;
  background-color: #fff;
  border-radius: 5px;
  border: #fff 1px solid;
}


.reserve .flex-box .flex-item .frame-inner .reserve-box-text::before{
    content: "";
    position: absolute;
    background-image: url(../img/common/carender-02.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 52px;
    height: 53px;
    top:70px;
  left: 50%;
  transform: translateX(-50%);
}

.reserve .flex-box .flex-item .frame-inner .tel-box-text::before{
    content: "";
    position: absolute;
    background-image: url(../img/common/tel.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 36px;
    height: 60px;
    top: 67px;
  left: 50%;
  transform: translateX(-50%);
}


.reserve .wave-wrapper svg {
    display: block;
    height: auto;
    width: 100%;
}

@media (max-width: 1000px) {
  .reserve .flex-box::before {
    transform: scale(0.7);
    bottom: -90px;
    left: -10px;
    z-index: 1;
  }

  .reserve .flex-box::after {
    transform: scale(0.7);
    bottom: -96px;
    right: -11px;
  }
}

@media (max-width: 768px) {
.reserve {
  position: relative;
  height: 900px;
}

.reserve::before{
    content: "";
    position: absolute;
    background-image:url(../img/reserve-01.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 74px;
    height: 194px;
    bottom: -60px;
    left: 10%;
    transform: scale(0.6);
}

.reserve::after{
    content: "";
    position: absolute;
    background-image:url(../img/reserve-02.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 74px;
    height: 194px;
    bottom: -60px;
    right: 10%;
    transform: scale(0.6);
}

.reserve .wave-wrapper {
    margin-bottom: 120px;
}

.reserve h2 {
    font-size: 22px;
  }

.reserve .section-mark-en {
    padding:0 20px;
  }

.reserve .flex-box {
  flex-direction: column;
    margin: 30px auto 0;
}

.reserve .flex-box .flex-item {
    margin: auto;
    width: 80%;
    max-width: 250px;
}

.reserve .flex-box .flex-item .frame-inner .reserve-box-text,
.reserve .flex-box .flex-item .frame-inner .tel-box-text{
  width: 80%;
    font-size: 16px;
}

.reserve .flex-box .frame-inner>p:nth-of-type(1)::before{
  position: absolute;
    content: "";
    position: absolute;
    background-image: url(../img/common/icon_calendar-02.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 52px;
    height: 53px;
    top:70px;
  left: 50%;
  transform: translateX(-50%);
}

.reserve .flex-box .flex-item .frame-inner .reserve-box-text::before{
  transform: translateX(-50%) scale(0.8);
}

.reserve .flex-box .flex-item .frame-inner .tel-box-text::before{
  transform: translateX(-50%) scale(0.8);
}

.reserve .flex-box::before {
  display: none;
}

.reserve .flex-box::after {
  display: none;
}
}
