.activeIntroSect {
  position: relative;
  z-index: 2;
}

.activeIntroSect__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (min-width: 768px) {
  .activeIntroSect__head {
    gap: 124px;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__head {
    gap: 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__head .enTtl {
    -webkit-writing-mode: sideways-rl;
        -ms-writing-mode: sideways-rl;
            writing-mode: sideways-rl;
  }
}

@media screen and (min-width: 768px) {
  .activeIntroSect__head .headingUnit {
    width: 760px;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__head .headingUnit {
    width: 242px;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__visual {
    margin-left: -20px;
    margin-right: -20px;
  }
}

@media screen and (min-width: 768px) {
  .activeIntroSect__cont .usableList {
    margin-top: 80px;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__cont .usableList {
    margin-top: 60px;
  }
}

@media screen and (min-width: 768px) {
  .activeIntroSect__cont .usableList__inner {
    gap: 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__cont .usableList__inner {
    gap: 60px 24px;
  }
}

@media screen and (min-width: 768px) {
  .activeIntroSect__cont .usableList__item {
    width: 220px;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__cont .usableList__item {
    width: calc(50% - 12px);
  }
}

@media screen and (min-width: 768px) {
  .activeIntroSect__cont .usableList__item .descriptionCard__cont .heading {
    font-size: 18px;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__cont .usableList__item .descriptionCard__cont .heading {
    font-size: 14px;
  }
}

.activeIntroSect__cont .usableList__item .descriptionCard__cont .caption {
  display: block;
  margin-top: 10px;
}

@media screen and (min-width: 768px) {
  .activeIntroSect__head + .activeIntroSect__cont {
    margin-top: 80px;
  }
}

@media screen and (max-width: 768px) {
  .activeIntroSect__head + .activeIntroSect__cont {
    margin-top: 60px;
  }
}

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

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

@media screen and (max-width: 768px) {
  .activeSpotSect {
    margin-top: 100px;
  }
}

.activeSpotSect:before {
  content: '';
  left: 50%;
  -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(10%, #000000), color-stop(90%, #000000), to(transparent));
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000000 10%, #000000 90%, transparent 100%);
          mask-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(10%, #000000), color-stop(90%, #000000), to(transparent));
          mask-image: linear-gradient(to bottom, transparent 0%, #000000 10%, #000000 90%, transparent 100%);
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: calc(100vw - var(--scrollbar));
  z-index: -1;
}

@media screen and (min-width: 768px) {
  .activeSpotSect:before {
    background: url("../imgs/pc/bg-gourmet-01@1.5x.jpg") no-repeat top center/cover;
    height: calc(1600 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .activeSpotSect:before {
    background: url("../imgs/sp/bg-gourmet-01.jpg") no-repeat top center/cover;
    height: 100%;
  }
}

@media screen and (max-width: 768px) {
  .activeSpotSect__head .headingUnit .heading {
    font-size: 18px;
  }
}

@media screen and (min-width: 768px) {
  .activeSpotSect__head .headingUnit .heading + .txt {
    max-width: 660px;
  }
}

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

@media screen and (min-width: 768px) {
  .activeSpotSect__head + .activeSpotSect__cont {
    margin-top: 100px;
  }
}

@media screen and (max-width: 768px) {
  .activeSpotSect__head + .activeSpotSect__cont {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .aerialSect {
    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;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 60px 120px;
    margin-top: 200px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .aerialSect {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (max-width: 768px) {
  .aerialSect {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .aerialSect__head {
    width: 320px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .aerialSect__head {
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  .aerialSect__cont {
    width: 760px;
  }
}

@media screen and (max-width: 768px) {
  .aerialSect__cont {
    margin-left: -20px;
    margin-right: -20px;
  }
}

@media screen and (max-width: 768px) {
  .aerialSect__head + .aerialSect__cont {
    margin-top: 100px;
  }
}

@media screen and (max-width: 768px) {
  .areaInfoSect__head {
    text-align: center;
  }
}

@media screen and (min-width: 768px) {
  .areaInfoSect__head + .areaInfoSect__cont {
    margin-top: 80px;
  }
}

@media screen and (max-width: 768px) {
  .areaInfoSect__head + .areaInfoSect__cont {
    margin-top: 60px;
  }
}

@media screen and (min-width: 768px) {
  .bgLayer--location:after {
    background: url("../imgs/pc/bg-nature-01@1.5x.jpg") top center no-repeat;
    background-size: 100% auto;
  }
}

@media screen and (max-width: 768px) {
  .bgLayer--location:after {
    background: url("../imgs/sp/bg-nature-01.jpg") top center no-repeat;
    background-size: 100% auto;
  }
}

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

@media screen and (max-width: 768px) {
  .childIntroSect__head {
    margin: -20px;
    position: relative;
    z-index: 1;
  }
}

.childIntroSect__ttl {
  left: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: calc(700 / 750 * 100vw);
  z-index: 1;
}

@media screen and (min-width: 768px) {
  .childIntroSect__cont {
    width: 660px;
  }
}

@media screen and (max-width: 768px) {
  .childIntroSect__cont {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .childIntroSect__block:not(:first-child) {
    margin-top: 60px;
  }
}

@media screen and (max-width: 768px) {
  .childIntroSect__block:not(:first-child) {
    margin-top: 100px;
  }
}

@media screen and (max-width: 768px) {
  .childIntroSect__block .headingUnit .heading--default {
    font-size: 18px;
    padding-left: 20px;
  }
}

@media screen and (min-width: 768px) {
  .childIntroSect__block .headingUnit + .usableList {
    margin-top: 60px;
  }
}

@media screen and (max-width: 768px) {
  .childIntroSect__block .headingUnit + .usableList {
    margin-top: 100px;
  }
}

.childIntroSect__block .headingUnit + .photo {
  margin-top: 24px;
}

@media screen and (min-width: 768px) {
  .childIntroSect__block .usableList__inner {
    gap: 20px;
  }
}

@media screen and (max-width: 768px) {
  .childIntroSect__block .usableList__inner {
    gap: 24px;
  }
}

@media screen and (min-width: 768px) {
  .childIntroSect__block .usableList__item {
    width: calc(50% - 10px);
  }
}

@media screen and (max-width: 768px) {
  .childIntroSect__block .usableList__item {
    width: calc(50% - 12px);
  }
}

.childIntroSect__block .descriptionCard__cont .caption {
  display: block;
  margin-top: 10px;
}

@media screen and (max-width: 768px) {
  .childServiceSect {
    margin-top: 100px;
  }
}

.childServiceSect__head {
  display: grid;
}

@media screen and (min-width: 768px) {
  .childServiceSect__head {
    gap: 80px;
  }
}

@media screen and (max-width: 768px) {
  .childServiceSect__head {
    gap: 40px;
  }
}

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

@media screen and (max-width: 768px) {
  .childServiceSect__head .headingUnit .heading {
    font-size: 18px;
  }
}

.childServiceSect__label {
  border: 1px solid currentColor;
  color: #616c78;
  font-size: 18px;
  letter-spacing: .05em;
}

@media screen and (min-width: 768px) {
  .childServiceSect__label {
    padding: 12px 40px;
  }
}

@media screen and (max-width: 768px) {
  .childServiceSect__label {
    padding: 8px;
    text-align: center;
  }
}

.childServiceSect__label .inner {
  display: block;
  line-height: 1.6;
}

.childServiceSect__label .inner:before {
  content: '';
  margin-top: calc((1 - 1.6) * .5em);
}

.childServiceSect__label .inner:after {
  margin-bottom: calc((1 - 1.6) * .5em);
}

.childServiceSect__label .inner:before, .childServiceSect__label .inner:after {
  content: '';
  display: block;
  height: 0;
  width: 0;
}

@media screen and (min-width: 768px) {
  .childServiceSect__cont {
    max-width: 560px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .childServiceSect__cont {
    max-width: inherit;
  }
}

.childServiceSect__cont .usableList:not(:first-child) {
  margin-top: 100px;
}

@media screen and (min-width: 768px) {
  .childServiceSect__cont .usableList__inner {
    gap: 24px;
  }
}

@media screen and (max-width: 768px) {
  .childServiceSect__cont .usableList__inner {
    gap: 100px 24px;
  }
}

@media screen and (min-width: 768px) {
  .childServiceSect__cont .usableList__item {
    width: calc(50% - 12px);
  }
}

@media screen and (max-width: 768px) {
  .childServiceSect__cont .usableList__item {
    width: calc(50% - 12px);
  }
}

.childServiceSect__cont .usableList--large .usableList__inner {
  display: block;
}

.childServiceSect__cont .usableList--large .usableList__item {
  width: 100%;
}

@media screen and (min-width: 768px) {
  .childServiceSect__cont .usableList--large .usableList__item:not(:first-child) {
    margin-top: 40px;
  }
}

@media screen and (max-width: 768px) {
  .childServiceSect__cont .usableList--large .usableList__item:not(:first-child) {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .childServiceSect__head + .childServiceSect__cont {
    margin-top: 80px;
  }
}

@media screen and (max-width: 768px) {
  .childServiceSect__head + .childServiceSect__cont {
    margin-top: 100px;
  }
}

.introSect__head {
  position: relative;
  z-index: 1;
  width: calc(100vw - var(--scrollbar));
}

@media screen and (min-width: 768px) {
  .introSect__head {
    margin-left: calc((100% - 100vw + var(--scrollbar)) / 2);
  }
}

@media only screen and (min-width: 768px) and (max-width: 1200px) {
  .introSect__head {
    margin-left: -20px;
    width: calc(100% + 40px);
  }
}

@media screen and (max-width: 768px) {
  .introSect__head {
    margin-left: -20px;
  }
}

.introSect__ttl {
  left: 50%;
  position: absolute;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  z-index: 2;
}

@media screen and (min-width: 768px) {
  .introSect__ttl {
    top: calc(160 / 1440 * 100vw);
    width: calc(350 / 1400 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .introSect__ttl {
    top: calc(245 / 750 * 100vw);
    width: calc(385 / 750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .introSect__cont .headingUnit .heading + .txt {
    max-width: 660px;
  }
}

@media screen and (min-width: 768px) {
  .introSect__cont .modalFigure {
    margin-top: 80px;
  }
}

@media screen and (max-width: 768px) {
  .introSect__cont .modalFigure {
    margin-top: 60px;
  }
}

@media screen and (min-width: 768px) {
  .introSect__head + .introSect__cont {
    margin-top: 140px;
  }
}

@media screen and (max-width: 768px) {
  .introSect__head + .introSect__cont {
    margin-top: 100px;
  }
}

.introSect__bottom {
  width: calc(100vw - var(--scrollbar));
}

@media screen and (min-width: 768px) {
  .introSect__bottom {
    margin-left: calc((100% - 100vw + var(--scrollbar)) / 2);
  }
}

@media only screen and (min-width: 768px) and (max-width: 1200px) {
  .introSect__bottom {
    margin-left: -20px;
    width: calc(100% + 40px);
  }
}

@media screen and (max-width: 768px) {
  .introSect__bottom {
    margin-left: -20px;
  }
}

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

@media screen and (max-width: 768px) {
  .introSect__bottom {
    margin-top: 60px;
  }
}

@media screen and (min-width: 768px) {
  .introSect__bottom .generalSlider .swiper-slide {
    width: calc((100% - 40px) / 3);
  }
}

@media screen and (max-width: 768px) {
  .introSect__bottom .generalSlider .swiper-slide {
    width: 189px;
  }
}

@media screen and (min-width: 768px) {
  .introSect__bottom .generalSlider--disableMode .swiper-wrapper {
    gap: 20px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.keyVisualMovie {
  position: relative;
  width: 100%;
  z-index: 1;
}

@media screen and (min-width: 768px) {
  .keyVisualMovie {
    aspect-ratio: 16 / 9;
  }
}

@media screen and (max-width: 768px) {
  .keyVisualMovie {
    height: 690px;
  }
}

.keyVisualMovie__movie {
  height: 100%;
  width: 100%;
}

.keyVisualMovie__video {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
  opacity: 0;
  position: relative;
  -webkit-transition: opacity .6s ease;
  transition: opacity .6s ease;
  width: 100%;
}

.keyVisualMovie__video.is-start {
  opacity: 1;
}

.keyVisualMovie__video:-webkit-media-controls {
  display: none !important;
}

.keyVisualMovie__video:-webkit-media-controls-start-playback-button {
  -webkit-appearance: none;
  display: none !important;
}

.keyVisualMovie__poster {
  display: none;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.keyVisualMovie__poster .photo {
  height: 100%;
  width: 100%;
}

.keyVisualMovie__poster .photo__pic, .keyVisualMovie__poster .photo__image {
  height: 100%;
  width: 100%;
}

.keyVisualMovie__poster .photo__image {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
}

.keyVisualMovie__btn {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: rgba(255, 255, 255, 0.8);
  border: 1px solid #cccccc;
  color: #616c78;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-family: "EB Garamond", serif;
  font-size: 13px;
  gap: 6px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  letter-spacing: .1em;
  padding: 6px 10px;
  position: absolute;
  -webkit-transition: background-color .6s ease, opacity .6s ease;
  transition: background-color .6s ease, opacity .6s ease;
  z-index: 3;
}

@media screen and (min-width: 768px) {
  .keyVisualMovie__btn {
    bottom: 40px;
    left: 28px;
  }
}

@media screen and (max-width: 768px) {
  .keyVisualMovie__btn {
    bottom: 20px;
    right: 18px;
  }
}

.keyVisualMovie__btn.is-hidden {
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}

.keyVisualMovie__btn .t {
  display: inline-block;
  line-height: 1;
  white-space: nowrap;
}

.keyVisualMovie__btn .icon {
  display: block;
}

.keyVisualMovie__btn .icon .stopSVG {
  display: block;
  height: auto;
  width: 7px;
}

.keyVisualMovie__btn .icon .playSVG {
  display: block;
  height: auto;
  width: 5px;
}

@media screen and (min-width: 768px) {
  .keyVisualMovie__btn:hover {
    background-color: white;
  }
}

@media (hover: hover) and (pointer: fine) {
  .keyVisualMovie__btn:hover {
    background-color: white;
  }
}

@media screen and (min-width: 768px) {
  .lifeInfoDesc__map {
    height: 813px;
    width: 650px;
  }
}

@media screen and (max-width: 768px) {
  .lifeInfoDesc__map {
    aspect-ratio: 1 / 1;
  }
}

.lifeInfoDesc__map .lifeInfoDesc__item {
  height: 100%;
  width: 100%;
}

.lifeInfoDesc__select {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px;
}

@media screen and (min-width: 768px) {
  .lifeInfoDesc__cont {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 64px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (min-width: 768px) {
  .lifeInfoDesc__head + .lifeInfoDesc__cont {
    margin-top: 80px;
  }
}

@media screen and (max-width: 768px) {
  .lifeInfoDesc__head + .lifeInfoDesc__cont {
    margin-top: 60px;
  }
}

.lifeInfoDesc__trigger {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-shadow: 0 0 20px 3px rgba(51, 51, 51, 0.1);
          box-shadow: 0 0 20px 3px rgba(51, 51, 51, 0.1);
  color: #504e4a;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  -webkit-transition: background-color .6s ease-in-out;
  transition: background-color .6s ease-in-out;
  z-index: 1;
}

@media screen and (min-width: 768px) {
  .lifeInfoDesc__trigger {
    min-height: 40px;
    padding: 16px;
    width: calc((100% - 16px) / 3);
  }
}

@media screen and (max-width: 768px) {
  .lifeInfoDesc__trigger {
    min-height: 35px;
    padding: 6px;
    width: calc(50% - 4px);
  }
}

.lifeInfoDesc__trigger .inner {
  letter-spacing: .05em;
  line-height: 1.6;
}

.lifeInfoDesc__trigger .inner:before {
  content: '';
  margin-top: calc((1 - 1.6) * .5em);
}

.lifeInfoDesc__trigger .inner:after {
  margin-bottom: calc((1 - 1.6) * .5em);
}

.lifeInfoDesc__trigger .inner:before, .lifeInfoDesc__trigger .inner:after {
  content: '';
  display: block;
  height: 0;
  width: 0;
}

@media screen and (min-width: 768px) {
  .lifeInfoDesc__trigger .inner {
    font-size: 16px;
  }
}

@media screen and (max-width: 768px) {
  .lifeInfoDesc__trigger .inner {
    font-size: 14px;
  }
}

@media screen and (min-width: 768px) {
  .lifeInfoDesc__trigger:hover {
    background-color: #eae4d0;
  }
}

@media (hover: hover) and (pointer: fine) {
  .lifeInfoDesc__trigger:hover {
    background-color: #eae4d0;
  }
}

.lifeInfoDesc__trigger.is-active {
  background-color: #eae4d0;
}

@media screen and (min-width: 768px) {
  .lifeInfoDesc__table {
    width: 440px;
  }
}

@media screen and (max-width: 768px) {
  .lifeInfoDesc__table {
    margin-top: 60px;
  }
}

.lifeInfoDesc__plot .trigger {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  background: none;
  border: 0;
  color: #504e4a;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-family: YakuHanJP, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  gap: 10px;
  letter-spacing: .05em;
  padding-bottom: .8em;
  text-align: left;
  width: 100%;
}

.lifeInfoDesc__plot .num {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  aspect-ratio: 1 / 1;
  background-color: #8fa4b9;
  border-radius: 50%;
  color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 13px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  letter-spacing: 0;
  line-height: .8;
  text-align: center;
  width: 20px;
}

.lifeInfoDesc__plot .desc {
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  display: inline-block;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.lifeInfoDesc__plot .name {
  display: inline-block;
  font-size: 14px;
  letter-spacing: .05em;
  line-height: 1.6;
}

.lifeInfoDesc__plot .name:before {
  content: '';
  margin-top: calc((1 - 1.6) * .5em);
}

.lifeInfoDesc__plot .name:after {
  margin-bottom: calc((1 - 1.6) * .5em);
}

.lifeInfoDesc__plot .name:before, .lifeInfoDesc__plot .name:after {
  content: '';
  display: block;
  height: 0;
  width: 0;
}

.lifeInfoDesc__plot .time {
  display: inline-block;
  line-height: 1;
}

@media screen and (min-width: 768px) {
  .lifeInfoDesc__plot .time {
    font-size: 18px;
  }
}

@media screen and (max-width: 768px) {
  .lifeInfoDesc__plot .time {
    font-size: 16px;
  }
}

.lifeInfoDesc__plot .time .min {
  display: inline-block;
  text-align: right;
  width: 1.5em;
}

.lifeInfoDesc__plot .dist {
  display: inline-block;
  font-size: 18px;
  white-space: nowrap;
  line-height: 1.6;
}

.lifeInfoDesc__plot .dist:before {
  content: '';
  margin-top: calc((1 - 1.6) * .5em);
}

.lifeInfoDesc__plot .dist:after {
  margin-bottom: calc((1 - 1.6) * .5em);
}

.lifeInfoDesc__plot .dist:before, .lifeInfoDesc__plot .dist:after {
  content: '';
  display: block;
  height: 0;
  width: 0;
}

.lifeInfoDesc__plot .meter {
  font-size: 13px;
  letter-spacing: .1em;
}

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

@media screen and (max-width: 768px) {
  .lifeInfoDesc__plot .meter {
    display: block;
    text-align: right;
  }
}

.lifeInfoDesc__item {
  display: none;
}

.lifeInfoDesc__item.is-active {
  display: block;
}

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

@media screen and (max-width: 768px) {
  .locationSect {
    margin-top: 100px;
  }
}

@media screen and (max-width: 768px) {
  .locationSect__head .headingUnit .heading {
    font-size: 18px;
  }
}

@media screen and (min-width: 768px) {
  .locationSect__head .headingUnit .txt {
    width: 660px;
  }
}

@media screen and (min-width: 768px) {
  .locationSect__head + .locationSect__cont {
    margin-top: 80px;
  }
}

@media screen and (max-width: 768px) {
  .locationSect__head + .locationSect__cont {
    margin-top: 100px;
  }
}

.mapBlock {
  background-color: #cccccc;
  color: #666666;
  height: 100%;
  width: 100%;
}

.mapBlock .centerLabel {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  background-color: #00703c;
  -webkit-box-shadow: initial !important;
          box-shadow: initial !important;
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 86%, 56% 86%, 50% 100%, 44% 86%, 0 86%);
          clip-path: polygon(0 0, 100% 0, 100% 86%, 56% 86%, 50% 100%, 44% 86%, 0 86%);
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  opacity: 1 !important;
  overflow: visible !important;
  text-align: center;
}

@media screen and (min-width: 768px) {
  .mapBlock .centerLabel {
    height: 79px;
    padding-top: 10px;
    -webkit-transform: translate(-50%, -140px);
            transform: translate(-50%, -140px);
    width: 96px;
  }
}

@media screen and (max-width: 768px) {
  .mapBlock .centerLabel {
    height: 55px;
    padding-top: 7px;
    -webkit-transform: translate(-50%, -110px);
            transform: translate(-50%, -110px);
    width: 67px;
  }
}

@media screen and (min-width: 768px) {
  .mapBlock .centerLabel img {
    height: 49px;
  }
}

@media screen and (max-width: 768px) {
  .mapBlock .centerLabel img {
    height: 34px;
  }
}

@media screen and (min-width: 768px) {
  .natureSect {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 0 120px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .natureSect {
    gap: 60px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (min-width: 768px) {
  .natureSect__head {
    width: 320px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .natureSect__head {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .natureSect__head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (max-width: 768px) {
  .natureSect__head .headingUnit {
    width: 242px;
  }
}

@media screen and (max-width: 768px) {
  .natureSect__head .enTtl {
    -webkit-writing-mode: sideways-rl;
        -ms-writing-mode: sideways-rl;
            writing-mode: sideways-rl;
  }
}

@media screen and (min-width: 768px) {
  .natureSect__head .enTtl + .headingUnit {
    margin-top: 60px;
  }
}

@media screen and (min-width: 768px) {
  .natureSect__cont {
    margin-right: -120px;
    width: 880px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1439px) {
  .natureSect__cont {
    margin-right: 0;
    width: calc(760 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .natureSect__cont {
    margin: 60px -20px 0;
  }
}

@media screen and (min-width: 768px) {
  .natureSect__bottom {
    margin-top: 200px;
    width: 100%;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .natureSect__bottom {
    margin-top: 100px;
  }
}

@media screen and (max-width: 768px) {
  .natureSect__bottom {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .relaxIntroSect {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 60px 120px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (min-width: 768px) {
  .relaxIntroSect__head {
    width: 320px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .relaxIntroSect__head {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .relaxIntroSect__head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (max-width: 768px) {
  .relaxIntroSect__head .headingUnit {
    width: 242px;
  }
}

@media screen and (max-width: 768px) {
  .relaxIntroSect__head .enTtl {
    -webkit-writing-mode: sideways-rl;
        -ms-writing-mode: sideways-rl;
            writing-mode: sideways-rl;
  }
}

@media screen and (min-width: 768px) {
  .relaxIntroSect__head .enTtl + .headingUnit {
    margin-top: 60px;
  }
}

@media screen and (min-width: 768px) {
  .relaxIntroSect__cont {
    margin-right: -120px;
    width: 880px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1439px) {
  .relaxIntroSect__cont {
    margin-right: 0;
    width: calc(760 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .relaxIntroSect__cont {
    margin-top: 60px;
  }
}

.shoppingStreetList__ttl {
  border: 1px solid currentColor;
  color: #616c78;
  font-size: 18px;
  padding: 12px;
  text-align: center;
}

.shoppingStreetList__ttl .inner {
  display: block;
  letter-spacing: .05em;
  line-height: 1.6;
}

.shoppingStreetList__ttl .inner:before {
  content: '';
  margin-top: calc((1 - 1.6) * .5em);
}

.shoppingStreetList__ttl .inner:after {
  margin-bottom: calc((1 - 1.6) * .5em);
}

.shoppingStreetList__ttl .inner:before, .shoppingStreetList__ttl .inner:after {
  content: '';
  display: block;
  height: 0;
  width: 0;
}

.shoppingStreetList__list {
  display: grid;
  gap: .64em 0;
  grid-auto-flow: column;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(4, auto);
}

.shoppingStreetList__ttl + .shoppingStreetList__list {
  margin-top: 40px;
}

.shoppingStreetList__item {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
}

.shoppingStreetList__item .num {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  aspect-ratio: 1 / 1;
  background-color: #8fa4b9;
  border-radius: 50%;
  color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-family: YakuHanJP, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 13px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  letter-spacing: .05em;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  width: 20px;
}

.shoppingStreetList__item .txt {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.shoppingStreetSect {
  position: relative;
  z-index: 2;
}

@media screen and (min-width: 768px) {
  .shoppingStreetSect {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 120px;
    margin-top: 200px;
  }
}

@media screen and (max-width: 768px) {
  .shoppingStreetSect {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .shoppingStreetSect__head {
    width: 540px;
  }
}

@media screen and (min-width: 768px) {
  .shoppingStreetSect__cont {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    min-width: 440px;
  }
}

@media screen and (max-width: 768px) {
  .shoppingStreetSect__cont {
    margin-top: 40px;
  }
}

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

@media screen and (max-width: 768px) {
  .siteAreaBlock {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .siteAreaBlock__item {
    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;
    gap: 40px;
    max-width: 900px;
  }
}

@media screen and (min-width: 768px) {
  .siteAreaBlock__item .headingUnit {
    width: 320px;
  }
}

@media screen and (min-width: 768px) {
  .siteAreaBlock__item .headingUnit .heading {
    font-size: 24px;
  }
}

@media screen and (max-width: 768px) {
  .siteAreaBlock__item .headingUnit + * {
    margin-top: 40px;
  }
}

@media screen and (min-width: 768px) {
  .siteAreaBlock__item:not(:first-child) {
    margin-top: 200px;
  }
}

@media screen and (max-width: 768px) {
  .siteAreaBlock__item:not(:first-child) {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .siteAreaBlock__item--right {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (min-width: 768px) {
  .siteAreaBlock__item--center {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-left: auto;
    margin-right: auto;
    max-width: 880px;
  }
}

@media screen and (min-width: 768px) {
  .siteAreaBlock__item--center .headingUnit {
    text-align: center;
    width: 100%;
  }
}

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

@media screen and (min-width: 768px) {
  .spotGalleryList {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 32px;
    padding-top: 60px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .spotGalleryList {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList {
    margin-left: -20px;
    margin-right: -20px;
  }
}

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

@media screen and (min-width: 768px) {
  .spotGalleryList__left {
    width: 480px;
  }
}

.spotGalleryList__left .spotGalleryList__item .descriptionCard {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
}

.spotGalleryList__left .spotGalleryList__item .descriptionCard__cont {
  margin-top: 0;
}

.spotGalleryList__left .spotGalleryList__item:nth-child(1) {
  margin: 0 0 0 auto;
}

.spotGalleryList__left .spotGalleryList__item:nth-child(1) .descriptionCard {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

@media screen and (min-width: 768px) {
  .spotGalleryList__left .spotGalleryList__item:nth-child(1) .descriptionCard__head {
    width: 320px;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__left .spotGalleryList__item:nth-child(1) .descriptionCard__head {
    width: 237px;
  }
}

.spotGalleryList__left .spotGalleryList__item:nth-child(2) {
  position: relative;
}

@media screen and (min-width: 768px) {
  .spotGalleryList__left .spotGalleryList__item:nth-child(2) {
    margin-top: -30px;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__left .spotGalleryList__item:nth-child(2) {
    margin-top: -20px;
  }
}

.spotGalleryList__left .spotGalleryList__item:nth-child(2) .descriptionCard {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

@media screen and (min-width: 768px) {
  .spotGalleryList__left .spotGalleryList__item:nth-child(2) .descriptionCard__head {
    width: 220px;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__left .spotGalleryList__item:nth-child(2) .descriptionCard__head {
    width: 189px;
  }
}

@media screen and (min-width: 768px) {
  .spotGalleryList__main {
    position: absolute;
    right: -120px;
    top: 0;
    width: 760px;
    z-index: 0;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1439px) {
  .spotGalleryList__main {
    min-width: 688px;
    right: 0;
    width: calc(100% - 480px - 32px);
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .spotGalleryList__main {
    position: relative;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__main {
    margin-top: 60px;
  }
}

@media screen and (min-width: 768px) {
  .spotGalleryList__right {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin-top: 194px;
    min-width: 688px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .spotGalleryList__right {
    margin-top: 0;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__right {
    margin-top: 60px;
  }
}

.spotGalleryList__right .spotGalleryList__item .descriptionCard {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
}

.spotGalleryList__right .spotGalleryList__item:nth-child(1) {
  position: relative;
  z-index: 2;
}

@media screen and (min-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(1) {
    margin: 0 auto 0 250px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}

@media screen and (min-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(1) .descriptionCard {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(1) .descriptionCard {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}

@media screen and (min-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(1) .descriptionCard__head {
    width: 220px;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(1) .descriptionCard__head {
    width: 189px;
  }
}

.spotGalleryList__right .spotGalleryList__item:nth-child(2) {
  position: relative;
  z-index: 1;
}

@media screen and (min-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(2) {
    margin-top: -30px;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(2) {
    margin-top: -10px;
  }
}

.spotGalleryList__right .spotGalleryList__item:nth-child(2) .descriptionCard {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

@media screen and (min-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(2) .descriptionCard__head {
    width: 320px;
  }
}

@media screen and (max-width: 768px) {
  .spotGalleryList__right .spotGalleryList__item:nth-child(2) .descriptionCard__head {
    width: 237px;
  }
}

@media screen and (min-width: 768px) {
  .spotGalleryList--rev {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}

@media screen and (min-width: 768px) {
  .spotGalleryList--rev .spotGalleryList__main {
    left: -120px;
    right: auto;
  }
}

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

.stationCard__ttl {
  color: #ffffff;
  font-family: "EB Garamond", serif;
  font-style: italic;
  left: 50%;
  letter-spacing: .05em;
  line-height: 1;
  position: absolute;
  text-align: center;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  white-space: nowrap;
  z-index: 2;
}

@media screen and (min-width: 768px) {
  .stationCard__ttl {
    font-size: 48px;
  }
}

@media print, screen and (min-width: 768px) and (max-width: 1199px) {
  .stationCard__ttl {
    font-size: calc(48 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .stationCard__ttl {
    font-size: 24px;
  }
}

.tavernSect {
  position: relative;
  z-index: 2;
}

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

@media screen and (max-width: 768px) {
  .tavernSect {
    margin-top: 100px;
  }
}

.tavernSect:before {
  content: '';
  left: 50%;
  -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(10%, #000000), color-stop(90%, #000000), to(transparent));
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000000 10%, #000000 90%, transparent 100%);
          mask-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(10%, #000000), color-stop(90%, #000000), to(transparent));
          mask-image: linear-gradient(to bottom, transparent 0%, #000000 10%, #000000 90%, transparent 100%);
  max-height: 100%;
  position: absolute;
  top: 0;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  width: calc(100vw - var(--scrollbar));
  z-index: -1;
}

@media screen and (min-width: 768px) {
  .tavernSect:before {
    background: url("../../common/imgs/pc/bg-pattern-01@1.5x.jpg") no-repeat top center/cover;
    height: calc(1600 / 1440 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .tavernSect:before {
    background: url("../../common/imgs/sp/bg-pattern-01.jpg") no-repeat top center/cover;
    height: 1453px;
  }
}

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

@media screen and (max-width: 768px) {
  .tavernSect__head {
    margin-left: -20px;
    margin-right: -20px;
  }
}

.tavernSect__ttl {
  left: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 2;
}

@media screen and (min-width: 768px) {
  .tavernSect__ttl {
    width: 739px;
  }
}

@media screen and (max-width: 768px) {
  .tavernSect__ttl {
    width: calc(744 / 750 * 100vw);
  }
}

@media screen and (max-width: 768px) {
  .tavernSect__cont .headingUnit .heading {
    font-size: 18px;
  }
}

@media screen and (min-width: 768px) {
  .tavernSect__cont .headingUnit .heading + .txt {
    max-width: 660px;
  }
}

@media screen and (min-width: 768px) {
  .tavernSect__cont .spotGalleryList {
    margin-top: 100px;
  }
}

@media screen and (max-width: 768px) {
  .tavernSect__cont .spotGalleryList {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .tavernSect__head + .tavernSect__cont {
    margin-top: 200px;
  }
}

@media screen and (max-width: 768px) {
  .tavernSect__head + .tavernSect__cont {
    margin-top: 100px;
  }
}

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

@media screen and (max-width: 768px) {
  .viewSect {
    margin-top: 100px;
  }
}

@media screen and (min-width: 768px) {
  .viewSect__head .headingUnit .heading {
    font-size: 24px;
  }
}

@media screen and (max-width: 768px) {
  .viewSect__head .headingUnit .heading {
    font-size: 18px;
  }
}

@media screen and (max-width: 768px) {
  .viewSect__cont {
    margin-left: -20px;
    margin-right: -20px;
  }
}

@media screen and (max-width: 768px) {
  .viewSect__cont .panoramaFigure__body {
    height: 250px;
  }
}

.viewSect__head + .viewSect__cont {
  margin-top: 24px;
}

@media screen and (min-width: 768px) {
  .location-childrearing {
    padding: 200px 0 0;
  }
}

@media screen and (max-width: 768px) {
  .location-childrearing {
    padding: 100px 0 0;
  }
}

@media screen and (min-width: 768px) {
  .location-nature {
    padding: 200px 0 0;
  }
}

@media screen and (max-width: 768px) {
  .location-nature {
    padding: 100px 0 0;
  }
}

@media screen and (min-width: 768px) {
  .location-areaInfo {
    padding: 200px 0;
  }
}

@media screen and (max-width: 768px) {
  .location-areaInfo {
    padding: 100px 0;
  }
}
