@charset "utf-8";

/*----------------------------------------------------------------------------------------------
	access
----------------------------------------------------------------------------------------------*/

.access_morinoha_logo {
  text-align: center;
}

.access_ttl01 {
  text-align: center;
  margin-top: 70px;
}

.access_sec01_ttl01 {
  font-size: 39px;
  letter-spacing: 0.1em;
  margin-top: 2em;
}

.access_sec01_txt01 {
  font-size: 16px;
  line-height: 2.5;
  letter-spacing: .1em;
  margin-top: 2em;
}

.access_map {
  width: clamp(300px, 95%, 1600px);
  margin-inline: auto;
  margin-top: 70px;
}

@media (max-width: 800px) {
  .access_morinoha_logo img {
    height: 65vw;
  }

  .access_ttl01 {
    margin-top: 40px;
  }

  .access_ttl01 img {
    height: 18vw;
  }

  .access_sec01_ttl01 {
    font-size: clamp(25px, 4.2vw, 70px);
    letter-spacing: 0.1em;
    margin-top: 2em;
  }

  .access_sec01_txt01 {
    font-size: clamp(15px, 1.6vw, 27px);
    line-height: 2;
    letter-spacing: .1em;
    margin-top: 1.5em;
    text-align: justify;
    padding: 0 5%;
  }

  .access_map {
    width: clamp(300px, 100%, 1600px);
    margin-top: 1em;
  }

}

.l-access_sec02 {
  position: relative;
  background: url(../../img/access/bg_train.jpg) no-repeat;
  background-size: contain;
  background-position: center bottom;
  background-color: #39383F;
  padding: 160px 0;
  color: #C9BCB8;
}

@media (max-width: 800px) {
  .l-access_sec02 {
    position: relative;
    background: url(../../img/access/bg_train_sp.jpg) no-repeat;
    background-size: contain;
    background-position: center top;
    background-color: #534947;
    padding: 40px 0;
  }
}

.access_sec02 {
  text-align: center;
}

.access_sec02_ttl01 {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
  position: relative;
  text-align: left;
  color: #fff;
  font-size: 17px;
}

.u-en01 {
  font-family: 'garamond', sans-serif;
  font-size: 1em;
  letter-spacing: 0.1em;
}

.u-en02 {
  font-family: 'garamond', sans-serif;
  font-size: 3.47em;
  margin-left: 8px;
}

.u-jp01 {
  font-size: 1.29em;
  letter-spacing: 0.05em;
  margin-left: 16px;
}

.access_sec02_ttl01::after {
  content: '';
  display: block;
  position: absolute;
  width: 150%;
  height: .8px;
  background: #fff;
  bottom: 0;
  left: -50%;
}

.l-access_sec02_in {
  width: clamp(300px, 90%, 1000px);
  margin-inline: auto;
  margin-top: 70px;
}

.access_sec02_img01 {
  position: relative;
}

.access_sec02_img01 picture {
  position: relative;
  display: block;
  width: calc(100vw - calc(100vw - 100%) / 2);
}

.access_sec02_txt01 {
  margin-top: 150px;
}

.access_sec02_txt02 {
  font-size: clamp(14px, 1.6vw, 17px);
  line-height: 2;
  margin-top: 1.5em;
}

.access_sec02_list01 {
  display: flex;
  gap: 5.4%;
  margin-top: 70px;
}

.access_sec02_list01 li {
  width: calc(calc(100% - 10.8%) / 3);
}

.access_sec02_list01_txt {
  text-align: center;
  margin-top: 2em;
}

.access_sec02_list01_notes {
  margin-top: 1em;
  font-size: 10px;
  text-align: justify;
  color: #fff;
}

.l-access_sec03 {
  position: relative;
  padding: 120px 0;
}

.access_sec03_zu01 {
  position: relative;
  width: clamp(300px, 90%, 1196px);
  margin-inline: auto;
  margin-left: 5%;
}

.access_sec03 {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
}

.access_sec03_ttl01 {
  font-size: clamp(16px, 1.5vw, 25px);
}

.access_sec03_zuset {
  display: flex;
  gap: 5.4%;
  margin-top: 70px;
}

.access_sec03_zu02 {
  margin-top: 10px;
}

.access_sec03_list01_notes {
  margin-top: 1em;
  font-size: 10px;
  text-align: justify;
}

.l-access_sec04 {
  position: relative;
  padding: 120px 0;
  background: #F5F3E8;
}

.l-access_sec04 .access_sec02_ttl01 {
  color: #000;
}

.l-access_sec04 .access_sec02_ttl01::after {
  background: #000;
}

.l-access_sec04_in {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
  margin-top: 70px;
}

.access_sec04_set01 {
  display: flex;
  gap: 5.4%;
}

.access_sec04_set01_01 {
  width: 74.6%;
}

.access_sec04_set01_02 {
  display: flex;
  align-items: center;
}

.l-access_sec04 .access_sec02_txt02 {
  margin-top: 4em;
}

.access_bus_img03 {
  margin-top: 70px;
  box-shadow: 0px 0px 10px 0px rgba(128, 98, 57, 0.2);
}

.l-access_sec05 {
  position: relative;
  background: url(../../img/access/bg_drive.jpg) no-repeat;
  background-size: contain;
  background-position: center top;
  background-color: #2a282c;
  padding: 160px 0;
  color: #C9BCB8;
}

.l-access_sec05_in {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
  margin-top: 70px;
}

.access_sec05_set01 {
  display: flex;
  text-align: justify;
  gap: 6.4%;
}

.access_sec05_set01_01 {
  width: 37.7%;
}

.access_sec05_txt02 {
  margin-top: 70px;
}

.access_sec05_set01_01_img01 {
  margin-top: 30px;
}

.access_sec05_topics {
  padding: 84px 6% 74px;
  background: #fff;
  margin-top: 70px;
  color: #000;
  text-align: justify;
}

.access_sec05_topics_in {
  display: flex;
  gap: 5%;
}

.access_sec05_topics_01 {
  width: 54%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.access_sec05_topics_ttl01 {
  font-family: 'garamond', sans-serif;
  font-size: 27px;
  letter-spacing: 0.05em;
  position: relative;
}

.access_sec05_topics_ttl01::after {
  content: '';
  display: block;
  width: 7em;
  height: .8px;
  background: #000;
  margin-top: .8em;
}

.access_sec05_topics_ttl02 {
  font-size: clamp(18px, 1.6vw, 42px);
  line-height: 1.6;
  letter-spacing: .1em;
  margin-top: 1.3em;
}

.access_sec05_topics_txt {
  font-size: clamp(14px, 1.1vw, 17px);
  line-height: 2;
  margin-top: 1.5em;
}

.access_sec05_txt02_notes {
  margin-top: 1em;
  font-size: 10px;
  text-align: justify;
  color: #fff;
}

@media (max-width: 800px) {
  .access_sec02 {
    text-align: center;
  }

  .access_sec02_ttl01 {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
    position: relative;
    text-align: left;
    color: #fff;
    font-size: 12px;
  }

  .u-en01 {
    font-family: 'garamond', sans-serif;
    font-size: 1em;
    letter-spacing: 0.1em;
  }

  .u-en02 {
    font-family: 'garamond', sans-serif;
    font-size: 2.47em;
    margin-left: 8px;
  }

  .u-jp01 {
    display: block;
    font-size: 1.29em;
    letter-spacing: 0.05em;
    margin-left: 0;
    margin-top: .8em;
  }

  .access_sec02_ttl01::after {
    content: '';
    display: block;
    position: absolute;
    width: 150%;
    height: .8px;
    background: #fff;
    bottom: 2.8em;
    left: -50%;
  }

  .l-access_sec02_in {
    width: clamp(300px, 90%, 1000px);
    margin-inline: auto;
    margin-top: 30px;
  }

  .access_sec02_img01 {
    position: relative;
  }

  .access_sec02_img01 picture {
    position: relative;
    display: block;
    width: calc(100vw - calc(100vw - 100%) / 2);
  }

  .access_sec02_txt01 {
    margin-top: 40px;
  }

  .access_sec02_txt01 img {
    height: 26vw;
  }

  .access_sec02_txt02 {
    font-size: clamp(14px, 1.6vw, 17px);
    line-height: 2;
    margin-top: 1.5em;
    text-align: justify;
  }

  .access_sec02_list01 {
    display: flex;
    gap: 50px;
    margin-top: 30px;
    flex-direction: column;
    align-items: center;
  }

  .access_sec02_list01 li {
    width: 50%;
  }

  .access_sec02_list01_txt {
    text-align: center;
    margin-top: 1em;
  }

  .access_sec02_list01_notes {
    margin-top: 5em;
    font-size: 10px;
    text-align: center;
    color: #fff;
  }

  .l-access_sec03 {
    position: relative;
    padding: 60px 0;
  }

  .access_sec03_zu01 {
    position: relative;
    width: 100%;
    margin-inline: auto;
    margin-left: 0;
    margin-top: 10px;
  }

  .access_sec03 {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
  }

  .access_sec03_ttl01 {
    font-size: clamp(15px, 1.5vw, 25px);
  }

  .access_sec03_zuset {
    display: flex;
    gap: 60px;
    margin-top: 60px;
    flex-direction: column;
  }

  .access_sec03_zu02 {
    margin-top: 20px;
  }

  .access_sec03_zu_r .access_sec03_zu02 img {
    padding: 0 10%;
  }

  .l-access_sec04 {
    position: relative;
    padding: 60px 0;
    background: #F5F3E8;
  }

  .l-access_sec04 .access_sec02_ttl01 {
    color: #000;
  }

  .l-access_sec04 .access_sec02_ttl01::after {
    background: #000;
  }

  .l-access_sec04_in {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
    margin-top: 40px;
  }

  .access_sec04_set01 {
    display: flex;
    gap: 30px;
    flex-direction: column;
  }

  .access_sec04_set01_01 {
    width: 100%;
  }

  .access_sec04_set01_02 {
    display: flex;
    align-items: center;
  }

  .l-access_sec04 .access_sec02_txt02 {
    margin-top: 3em;
  }

  .access_bus_img03 {
    margin-top: 40px;
    box-shadow: 0px 0px 10px 0px rgba(128, 98, 57, 0.2);
  }

  .l-access_sec05 {
    position: relative;
    background: url(../../img/access/bg_drive_sp.jpg) no-repeat;
    background-size: contain;
    background-position: center top;
    background-color: #39383F;
    padding: 60px 0;
    color: #C9BCB8;
  }

  .l-access_sec05_in {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
    margin-top: 40px;
  }

  .access_sec05_set01 {
    display: flex;
    text-align: justify;
    gap: 30px;
    flex-direction: column;
  }

  .access_sec05_set01_01 {
    width: 100%;
  }

  .access_sec05_set01_01_ttl01 {
    text-align: center;
  }

  .access_sec05_txt02 {
    margin-top: 40px;
  }

  .access_sec05_set01_01_img01 {
    margin-top: 30px;
    padding: 0 20%;
  }

  .access_sec05_topics {
    padding: 40px 8% 40px;
    background: #fff;
    margin-top: 40px;
    color: #000;
    text-align: justify;
  }

  .access_sec05_topics_in {
    display: flex;
    gap: 30px;
    flex-direction: column;
  }

  .access_sec05_topics_01 {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .access_sec05_topics_ttl01 {
    font-family: 'garamond', sans-serif;
    font-size: 16px;
    letter-spacing: 0.05em;
    position: relative;
  }

  .access_sec05_topics_ttl01::after {
    content: '';
    display: block;
    width: 4em;
    height: .3px;
    background: #000;
    margin-top: .5em;
  }

  .access_sec05_topics_ttl02 {
    font-size: clamp(14px, 1.6vw, 42px);
    line-height: 1.6;
    letter-spacing: .1em;
    margin-top: 1.3em;
  }

  .access_sec05_topics_txt {
    font-size: clamp(14px, 1.1vw, 17px);
    line-height: 2;
    margin-top: 1.5em;
  }

  .access_sec05_topics_02 {
    padding: 0 10%;
  }
}

/*----------------------------------------------------------------------------------------------
	location
----------------------------------------------------------------------------------------------*/

.location_sec02 {
  position: relative;
  padding: 160px 0 0;
}

.l-location_sec02_in {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
}

.location_sec02_set01 {
  display: flex;
  gap: 2.4%;
}

.location_sec02_ttl01 {
  margin-inline: auto;
  position: relative;
  text-align: left;
  font-size: 17px;
  margin-top: 2em;
  margin-bottom: 2em;
}

.location_sec02_set01_01 {
  width: 48.7%;
  position: relative;
}

.location_sec02_set01_02 {
  width: 48.7%;
  position: relative;
}

.location_sec02_set01_02_in {
  width: calc(100% + calc(100vw - 206%) / 2);
  display: flex;
  flex-wrap: wrap;
  gap: 28px 3.6%;
}

.location_ec02_txt02 {
  font-size: clamp(14px, 1.1vw, 17px);
  line-height: 2;
  margin-top: 1.5em;
}

.location_sec02_set01_02_img01 {
  position: relative;
}

.location_sec02_set01_02_img02 {
  width: calc(calc(100% - 3.6%) / 2);
  position: relative;
}

.location_sec02_set01_02_img03 {
  width: calc(calc(100% - 3.6%) / 2);
  position: relative;
}

.location_sec02_ttl01 .u-jp01 {
  display: block;
  font-size: 1.29em;
  letter-spacing: 0.05em;
  margin-left: 0;
  margin-top: .8em;
}

.location_sec02_ttl01::after {
  content: '';
  display: block;
  position: absolute;
  width: 130%;
  height: .8px;
  background: #000;
  bottom: 2.8em;
  left: -50%;
}

.location_sec02_set02 {
  display: flex;
  gap: 2.4%;
}

.location_sec02_set02_01 {
  position: relative;
  width: 48.7%;
}

.location_sec02_set02_01_in {
  position: absolute;
  width: 112%;
  top: -28vw;
  left: -12%;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.location_sec02_set02_01_img01,
.location_sec02_set02_01_img02 {
  position: relative;
}

.location_sec02_set02_02 {
  width: 48.7%;
  position: relative;
  padding: 70px 0 0 40px;
}

.location_sec02_04_list {
  width: clamp(300px, 75%, 1280px);
  margin-inline: auto;
  margin-top: calc(70px + 12vw);
  display: flex;
  flex-wrap: wrap;
  gap: 70px 9%;
}

.location_sec02_04_list li {
  width: calc(calc(100% - 9%) / 2);
}

.location_sec02_04_list_img+.location_sec02_04_list_txt {
  margin-top: 1.5em;
}

.location_sec03 {
  position: relative;
  padding: 160px 0 0;
}

.l-location_sec03_in {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
}

.location_sec03_ttl01 {
  margin-inline: auto;
  position: relative;
  text-align: left;
  font-size: 17px;
}

.location_sec03_ttl01::after {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: .8px;
  background: #000;
  bottom: 0;
  left: -30%;
}

.location_sec03_gourmet_list {
  display: flex;
  gap: 3.4%;
  margin-top: 70px;
}

.location_sec03_gourmet_list_txt {
  text-align: center;
  margin-top: 1.5em;
}

.location_sec04 {
  position: relative;
  padding: 160px 0;
}


.location_sec05_topics {
  width: clamp(300px, 75%, 1000px);
  padding: 84px 6% 74px;
  background: #fff;
  margin-inline: auto;
  margin-top: 100px;
  color: #000;
  text-align: justify;
  border: .5px solid #000;
}

.location_sec05_topics_in {
  display: flex;
  gap: 5%;
}

.location_sec05_topics_01 {
  width: 54%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.location_sec05_topics_ttl01 {
  font-family: 'garamond', sans-serif;
  font-size: 27px;
  letter-spacing: 0.05em;
  position: relative;
}

.location_sec05_topics_ttl01::after {
  content: '';
  display: block;
  width: 7em;
  height: .8px;
  background: #000;
  margin-top: .8em;
}

.location_sec05_topics_ttl02 {
  font-size: clamp(18px, 1.6vw, 42px);
  line-height: 1.6;
  letter-spacing: .1em;
  margin-top: 1.3em;
}

.location_sec05_topics_txt {
  font-size: clamp(14px, 1.1vw, 17px);
  line-height: 2;
  margin-top: 1.5em;
}

.location_sec05_topics_02 {
  position: relative;
}

.location_sec05 {
  position: relative;
  background: url(../../img/location/location_play-spot_bg.jpg) no-repeat;
  background-size: cover;
  background-position: center bottom;
  padding: 160px 0;
  color: #C9BCB8;
}

.location_sec05_set01 {
  display: flex;
  gap: 4.4%;
}

.location_sec05_set01_01 {
  width: 54.8%;
}

.location_sec05 .location_sec02_ttl01 {
  color: #fff;
}

.location_sec05 .location_sec02_ttl01::after {
  background: #fff;
  width: 110%;
}

.location_sec05_set01_02 {
  width: 40.8%;
}

.location_sec05_set02 {
  margin-top: 160px;
}

.location_sec05_set02_01 {
  display: flex;
  gap: 4.1%;
}

.location_sec05_set02_01_in {
  position: relative;
  width: 19.2%;
}

.location_sec05_set02_01_img01 {
  position: absolute;
  width: 200%;
  top: 0;
  left: -100%;
}

.location_play-spot_t01 {
  margin-top: 3em;
}

.location_play-spot_t02 {
  margin-top: 4em;
}

.location_sec05_set02_02 {
  width: 76.7%;
}

.location_sec05_set01_02_in {
  width: calc(100% + calc(100vw - 246%) / 2);
}

.location_sec05_set02_02_list {
  display: flex;
  flex-wrap: wrap;
  gap: 38px 3.4%;
}

.location_sec05_set02_02_list_item {
  width: calc(calc(100% - 6.8%) / 3);
}

.location_sec05_list_img {
  position: relative;
}

@media (max-width: 800px) {
  .location_sec02 {
    position: relative;
    padding: 60px 0 0;
  }

  .l-location_sec02_in {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
  }

  .location_sec02_set01 {
    display: flex;
    gap: 2.4%;
    flex-direction: column;
  }

  .location_sec02_ttl01 {
    margin-inline: auto;
    position: relative;
    text-align: left;
    font-size: 12px;
    margin-top: 2em;
    margin-bottom: 2em;
  }

  .location_sec02_set01_01 {
    width: 100%;
    position: relative;
  }

  .location_sec02_set01_02 {
    width: 100%;
    position: relative;
    margin-top: 20px;
  }

  .location_sec02_set01_02_in {
    width: 90%;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 3.6%;
    margin-left: 16%;
  }

  .location_ec02_txt02 {
    font-size: clamp(14px, 1.1vw, 17px);
    line-height: 2;
    margin-top: 1.5em;
  }

  .location_sec02_set01_02_img01 {
    position: relative;
  }

  .location_sec02_set01_02_img02 {
    width: calc(calc(100% - 9.6%) / 2);
    position: relative;
  }

  .location_sec02_set01_02_img03 {
    width: calc(calc(100% - 9.6%) / 2);
    position: relative;
  }

  .location_sec02_ttl01 .u-jp01 {
    display: block;
    font-size: 1.29em;
    letter-spacing: 0.05em;
    margin-left: 0;
    margin-top: .8em;
  }

  .location_sec02_ttl01::after {
    content: '';
    display: block;
    position: absolute;
    width: 150%;
    height: .5px;
    background: #000;
    bottom: 2.8em;
    left: -50%;
  }

  .location_sec02_set02 {
    display: flex;
    gap: 20px;
    flex-direction: column;
    margin-top: 10px;
  }

  .location_sec02_set02_01 {
    position: relative;
    width: 100%;
  }

  .location_sec02_set02_01_in {
    position: relative;
    width: 112%;
    top: 0;
    left: -11.5%;
    display: flex;
    flex-direction: column-reverse;
    gap: 10px;
  }

  .location_sec02_set02_01_img01,
  .location_sec02_set02_01_img02 {
    position: relative;
  }

  .location_sec02_set02_02 {
    width: 100%;
    position: relative;
    padding: 0 10% 0 10%;
  }

  .location_sec02_04_list {
    width: 90%;
    margin-inline: auto;
    margin-top: 60px;
    display: flex;
    flex-wrap: wrap;
    gap: 60px 5%;
    justify-content: center;
  }

  .location_sec02_04_list li {
    width: calc(calc(100% - 5%) / 2);
  }

  .location_sec02_04_list li:nth-child(1),
  .location_sec02_04_list li:nth-child(2) {
    width: 80%;
  }

  .location_sec02_04_list_img+.location_sec02_04_list_txt {
    margin-top: 1.5em;
  }

  .location_sec02_04_list_img+.location_sec02_04_list_txt.u-size {
    padding: 0 8%;
  }

  .location_sec03 {
    position: relative;
    padding: 100px 0 0;
  }

  .l-location_sec03_in {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
  }

  .location_sec03_ttl01 {
    margin-inline: auto;
    position: relative;
    text-align: left;
    font-size: 12px;
  }

  .location_sec03_ttl01::after {
    content: '';
    display: block;
    position: absolute;
    width: 130%;
    height: .5px;
    background: #000;
    bottom: 2.8em;
    left: -30%;
  }

  .location_sec03_gourmet_list {
    width: 80%;
    margin-inline: auto;
    display: flex;
    gap: 40px;
    margin-top: 40px;
    flex-direction: column;
    align-content: center;
  }

  .location_sec03_gourmet_list_txt {
    text-align: center;
    margin-top: 1.5em;
  }

  .location_sec04 {
    position: relative;
    padding: 60px 0;
  }


  .location_sec05_topics {
    width: clamp(300px, 75%, 1000px);
    padding: 40px 8% 40px;
    background: #fff;
    margin-inline: auto;
    margin-top: 60px;
    color: #000;
    text-align: justify;
    border: .5px solid #000;
  }

  .location_sec05_topics_in {
    display: flex;
    gap: 30px;
    flex-direction: column;
  }

  .location_sec05_topics_01 {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .location_sec05_topics_ttl01 {
    font-family: 'garamond', sans-serif;
    font-size: 16px;
    letter-spacing: 0.05em;
    position: relative;
  }

  .location_sec05_topics_ttl01::after {
    content: '';
    display: block;
    width: 4em;
    height: .3px;
    background: #000;
    margin-top: .5em;
  }

  .location_sec05_topics_ttl02 {
    font-size: clamp(16px, 1.6vw, 42px);
    line-height: 1.6;
    letter-spacing: .1em;
    margin-top: 1.3em;
  }

  .location_sec05_topics_txt {
    font-size: clamp(14px, 1.1vw, 17px);
    line-height: 2;
    margin-top: 1.5em;
  }

  .location_sec05_topics_02 {
    position: relative;
    margin: 0 10%;
  }

  .location_sec05 {
    position: relative;
    background: url(../../img/location/location_play-spot_bg_sp.jpg) no-repeat;
    background-size: contain;
    background-position: center top;
    background-color: #534947;
    padding: 40px 0 60px;
    color: #C9BCB8;
  }

  .location_sec05_set01 {
    display: flex;
    gap: 40px;
    flex-direction: column;
  }

  .location_sec05_set01_01 {
    width: 100%;
  }

  .location_sec05 .location_sec02_ttl01 {
    color: #fff;
  }

  .location_sec05 .location_sec02_ttl01::after {
    background: #fff;
    width: 150%;
  }

  .location_sec05_set01_02 {
    width: 100%;
    margin-top: 40px;
  }

  .location_sec05_set02 {
    margin-top: 40px;
  }

  .location_sec05_set02_01 {
    display: flex;
    gap: 40px;
    flex-direction: column;
  }

  .location_sec05_set02_01_in {
    position: relative;
    width: 100%;
  }

  .location_sec05_set02_01_img01 {
    position: relative;
    width: 97%;
    top: 0;
    left: -7%;
  }

  .location_play-spot_t01 {
    margin-top: 2em;
    margin-left: 12%;
    margin-right: 12%;
  }

  .location_play-spot_t02 {
    margin-top: 2em;
  }

  .location_sec05_set02_02 {
    width: 100%;
  }

  .location_sec05_set01_02_in {
    width: 98%;
    margin-left: 8%;
    /* margin-top: 20px; */
  }

  .location_sec05_set02_02_list {
    display: flex;
    flex-wrap: wrap;
    gap: 30px 3.4%;
    flex-direction: column;
    align-content: center;
  }

  .location_sec05_set02_02_list_item {
    width: 80%;
  }

  .location_sec05_list_img {
    position: relative;
  }
}

/*----------------------------------------------------------------------------------------------
	child-raising
----------------------------------------------------------------------------------------------*/
.child_sec02 {
  position: relative;
  padding: 160px 0 0;
}

.l-child_sec02_in {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
  position: relative;
  z-index: 2;
}

.child_sec02_set01 {
  display: flex;
  gap: 2.4%;
}

.child_sec02_set01_01 {
  width: 40%;
  position: relative;
}

.child_sec02_ttl01 {
  margin-inline: auto;
  position: relative;
  text-align: left;
  font-size: 17px;
  margin-top: 2em;
  margin-bottom: 2em;
}

.child_sec02_ttl01 .u-jp01 {
  display: block;
  font-size: 1.29em;
  letter-spacing: 0.05em;
  margin-left: 0;
  margin-top: .8em;
}

.child_sec02_ttl01::after {
  content: '';
  display: block;
  position: absolute;
  width: 135%;
  height: .8px;
  background: #000;
  bottom: 2.8em;
  left: -50%;
}

.child_sec02_set01_02 {
  width: 57.6%;
  position: relative;
  flex: 1;
}

.child_sec02_set01_02_img01 {
  position: relative;
}

.child_sec02_03 {
  position: relative;
  z-index: 1;
}

.child_sec02_03::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 650px;
  background: #D38087;
  top: -70px;
  left: 0;
  z-index: -1;
}

.child_sec02_set02_01 {
  width: clamp(300px, 80%, 870px);
  color: #fff;
  margin-inline: auto;
  padding-top: 70px;
  position: relative;
}

.child_chiild-care_ill01 {
  position: absolute;
  width: 23.7%;
  top: 10px;
  left: -20%;
}

.child_chiild-care_ill02 {
  position: absolute;
  width: 57.9%;
  top: -43px;
  right: -50%;
  z-index: -1;
}

.child_sec02_ttl02 {
  font-size: clamp(20px, 1.8vw, 41px);
  text-align: center;
}

.child_sec02_ttl02 span {
  display: inline-block;
  font-size: .6em;
  letter-spacing: 0.05em;
  transform: translateY(-.25em);
}


.child_sec02_03_txt01 {
  font-size: clamp(14px, 1.1vw, 17px);
  line-height: 2;
  margin-top: 1.5em;
  column-count: 2;
  column-gap: 3em;
}

.child_sec02_set02_02_ttl01 {
  font-size: clamp(18px, 1.5vw, 27px);
  text-align: center;
  color: #fff;
  margin-top: 70px;
}

.child_sec02_set02_02_in {
  width: clamp(300px, 80%, 1034px);
  margin-inline: auto;
  margin-top: 40px;
  display: flex;
  gap: 3.4%;
  margin-top: 40px;
}

.child_sec02_set02_02_img01 {
  width: calc(calc(100% - 6.8%) / 3);
  position: relative;
}

.child_sec02_set02_02_img01 .img_caption_white,
.child_sec02_set02_02_img01 .img_caption_black {
  bottom: 46%;
}

.child_sec02_04 {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
  display: flex;
  margin-top: 120px;
  gap: 4%;
}

.child_sec02_04_img {
  width: 48%;
  position: relative;
}

.child_sec02_04_txtbox {
  width: 48%;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-top: .5px solid #000;
  border-bottom: .5px solid #000;
  padding: 0 5%;
  text-align: justify;
}

.child_sec02_04_txtbox_in_ttl01 {
  font-size: clamp(20px, 1.5vw, 29px);
  position: relative;
  display: inline-block;
  z-index: 1;
  margin-bottom: 1em;
}

.child_sec02_04_txtbox_in_ttl01::after {
  content: '';
  display: block;
  position: absolute;
  width: 106%;
  height: .4em;
  background: #E7BCBE;
  bottom: 0;
  left: -3%;
  z-index: -1;
}

.child_sec02_04_txtbox_in_txt01 {
  font-size: clamp(14px, 1.1vw, 17px);
  line-height: 2;
}

.child_sec02_04_txtbox_in_txt02 {
  font-size: 14px;
  line-height: 2;
  margin-top: 1em;
}

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

.child_sec03_in {
  width: clamp(300px, 90%, 1400px);
  margin-inline: auto;
  margin-top: 160px;
}

.child_sec03_ttl01 {
  font-size: clamp(16px, 1.5vw, 27px);
  text-align: center;
}

.lchild_sec03_list {
  display: flex;
  gap: 3.4%;
  margin-top: 50px;
}

.location_sec03_gourmet_list_txt {
  text-align: center;
  margin-top: 1.5em;
  padding: 0 13%;
}

.child_sec04_topics {
  padding: 84px 6%;
  background: #E9D3D4;
  margin-inline: auto;
  margin-top: 70px;
  color: #000;
  text-align: justify;
}

.child_sec04_topics_in {
  display: flex;
  gap: 5%;
}

.child_sec04_topics_01 {
  width: 31%;
}

.child_sec04_topics_ttl01 {
  font-size: clamp(18px, 1.3vw, 27px);
  line-height: 1.6;
  letter-spacing: .1em;
}

.child_sec04_topics_txt {
  font-size: clamp(14px, 1.1vw, 17px);
  line-height: 2;
  margin-top: 1.5em;
}

@media (max-width: 800px) {
  .child_sec02 {
    position: relative;
    padding: 60px 0 0;
  }

  .l-child_sec02_in {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
    position: relative;
    z-index: 2;
  }

  .child_sec02_set01 {
    display: flex;
    gap: 30px;
    flex-direction: column;
  }

  .child_sec02_set01_01 {
    width: 100%;
    position: relative;
  }

  .child_sec02_ttl01 {
    margin-inline: auto;
    position: relative;
    text-align: left;
    font-size: 12px;
    margin-top: 2em;
    margin-bottom: 2em;
  }

  .child_sec02_ttl01 .u-jp01 {
    display: block;
    font-size: 1.29em;
    letter-spacing: 0.05em;
    margin-left: 0;
    margin-top: .8em;
  }

  .child_sec02_ttl01::after {
    content: '';
    display: block;
    position: absolute;
    width: 150%;
    height: .5px;
    background: #000;
    bottom: 2.8em;
    left: -50%;
  }

  .child_sec02_set01_02 {
    width: 85%;
    margin-inline: auto;
    position: relative;
    flex: 1;
  }

  .child_sec02_set01_02_img01 {
    position: relative;
  }

  .child_sec02_03 {
    position: relative;
    z-index: 1;
  }

  .child_sec02_03::before {
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 1410px;
    background: #D38087;
    top: -70px;
    left: 0;
    z-index: -1;
  }

  .child_sec02_set02_01 {
    width: clamp(300px, 80%, 870px);
    color: #fff;
    margin-inline: auto;
    padding-top: 70px;
    position: relative;
  }

  .child_chiild-care_ill01 {
    position: absolute;
    width: 27.7%;
    top: 29px;
    left: -8%;
  }

  .child_chiild-care_ill02 {
    position: absolute;
    width: 72.9%;
    top: 277px;
    right: -32px;
    z-index: -1;
  }

  .child_sec02_ttl02 {
    font-size: clamp(20px, 1.8vw, 41px);
    text-align: center;
  }

  .child_sec02_ttl02 span {
    display: inline-block;
    font-size: .6em;
    letter-spacing: 0.05em;
    transform: translateY(-.55em);
  }


  .child_sec02_03_txt01 {
    font-size: clamp(14px, 1.1vw, 17px);
    line-height: 2;
    margin-top: 1em;
    column-count: 1;
    column-gap: 3em;
  }

  .child_sec02_set02_02_ttl01 {
    font-size: clamp(18px, 1.5vw, 27px);
    text-align: center;
    color: #fff;
    margin-top: 135px;
  }

  .child_sec02_set02_02_in {
    width: clamp(300px, 80%, 1034px);
    margin-inline: auto;
    margin-top: 40px;
    display: flex;
    gap: 20px;
    margin-top: 15px;
    flex-direction: column;
    align-items: center;
  }

  .child_sec02_set02_02_img01 {
    width: 80%;
    position: relative;
  }

  .child_sec02_set02_02_img01 .img_caption_white,
  .child_sec02_set02_02_img01 .img_caption_black {
    bottom: 46%;
  }

  .child_sec02_04 {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
    display: flex;
    margin-top: 60px;
    gap: 30px;
    flex-direction: column;
  }

  .child_sec02_04_img {
    width: 100%;
    position: relative;
  }

  .child_sec02_04_txtbox {
    width: 100%;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-top: .5px solid #000;
    border-bottom: .5px solid #000;
    padding: 30px 5%;
    text-align: justify;
  }

  .child_sec02_04_txtbox_in_ttl01 {
    font-size: clamp(17px, 1.5vw, 29px);
    position: relative;
    display: inline-block;
    z-index: 1;
    margin-bottom: 1em;
  }

  .child_sec02_04_txtbox_in_ttl01::after {
    content: '';
    display: block;
    position: absolute;
    width: 106%;
    height: .4em;
    background: #E7BCBE;
    bottom: 0;
    left: -3%;
    z-index: -1;
  }

  .child_sec02_04_txtbox_in_txt01 {
    font-size: clamp(14px, 1.1vw, 17px);
    line-height: 2;
  }

  .child_sec02_04_txtbox_in_txt02 {
    font-size: 11px;
    line-height: 2;
    margin-top: 1em;
  }

  .child_sec02_04.u-reverse {
    flex-direction: column;
  }

  .child_sec03_in {
    width: clamp(300px, 90%, 1400px);
    margin-inline: auto;
    margin-top: 60px;
  }

  .child_sec03_ttl01 {
    font-size: clamp(16px, 1.5vw, 27px);
    text-align: center;
  }

  .lchild_sec03_list {
    width: 80%;
    margin-inline: auto;
    display: flex;
    gap: 40px;
    margin-top: 20px;
    flex-direction: column;
    align-items: center;
  }

  .location_sec03_gourmet_list_txt {
    text-align: center;
    margin-top: 1.5em;
    padding: 0 5%;
  }

  .child_sec04_topics {
    padding: 40px 8%;
    background: #E9D3D4;
    margin-inline: auto;
    margin-top: 40px;
    color: #000;
    text-align: justify;
  }

  .child_sec04_topics_in {
    display: flex;
    gap: 20px;
    flex-direction: column;
  }

  .child_sec04_topics_01 {
    width: 100%;
  }

  .child_sec04_topics_ttl01 {
    font-size: clamp(18px, 1.3vw, 27px);
    line-height: 1.6;
    letter-spacing: .1em;
  }

  .child_sec04_topics_txt {
    font-size: clamp(14px, 1.1vw, 17px);
    line-height: 2;
    margin-top: 1.5em;
  }
}