@charset "UTF-8";
.p-mv {
  display: flex;
  position: sticky;
  top: 0;
  flex-direction: column;
  justify-content: flex-end;
  padding: 30px 48px;
  height: calc(100vh - 60px);
  height: 100svh;
}

.p-mv_heading {
  color: var(--white);
  font-style: normal;
  font-weight: 500;
  font-size: 84px;
  line-height: 1.1;
  font-family: "Zen Maru Gothic", sans-serif;
}

.p-mv_anchor {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 36px 0 0;
}

.p-mv_anchor_item a {
  display: block;
  position: relative;
  opacity: 0.8;
  transition: background-color 0.3s, color 0.3s;
  border-radius: 22px;
  background-color: rgba(0, 0, 0, 0.5);
  padding: 10px 48px 10px 20px;
  color: var(--white);
  font-weight: 700;
  font-size: 24px;
  line-height: 1;
}
.p-mv_anchor_item a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%) rotate(90deg);
  filter: invert(98%) sepia(60%) saturate(926%) hue-rotate(188deg) brightness(128%) contrast(100%);
  background-image: url("/common/img/common_ico_arrow1.svg");
  background-position: 0 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 18px;
  height: 16px;
  content: "";
}

.p-mv_movie {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.p-mv_movie video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 70%;
}

.p-lead {
  display: flex;
  position: relative;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transform: translateZ(1px);
  z-index: 1;
  border-radius: 25px 25px 0 0;
  background-color: #EEE6D5;
  padding: 48px 0px;
}
.p-lead:after {
  display: block;
  position: absolute;
  right: 32px;
  bottom: 0;
  background-image: url("../img/index_ico_lead.webp");
  background-position: 0 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 101px;
  height: 45px;
  content: "";
}

.p-lead_heading {
  width: 324px;
}

.p-lead_text {
  margin: 38px 0 0;
  color: var(--black);
  font-weight: 700;
  font-size: 23px;
  line-height: 2.8;
  letter-spacing: 0.928px;
  text-align: center;
}

.p-lead_logo {
  margin: 62px 0 0;
  width: 195px;
}

.p-section {
  position: relative;
  transform: translateZ(1px);
  z-index: 1;
  background-color: var(--white);
  padding: 0 0 86px;
}
.p-section:not(:has(~ .p-section)) {
  padding-bottom: 0;
}
.p-section:not(:has(+ .banner)) {
  padding-bottom: 64px;
}

.p-section_heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  border-top: solid 1px var(--black);
  border-bottom: solid 1px var(--black);
  padding: 18px 24px;
}

.p-section_heading-place {
  display: flex;
  position: relative;
  align-items: flex-end;
  padding: 10px 34px 10px 0;
  font-style: normal;
  font-weight: 500;
  font-size: 31px;
  line-height: 1;
  font-family: "Zen Maru Gothic", sans-serif;
}
.p-section_heading-place:before {
  display: block;
  position: absolute;
  top: 0;
  right: 15px;
  background-color: var(--black);
  width: 1px;
  height: 100%;
  content: "";
}
.p-section_heading-place ruby {
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
}
.p-section_heading-place rt {
  font-weight: 500;
  font-size: 16px;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  text-transform: uppercase;
}

.p-section_heading-place-set {
  margin: 0 -8px 0 -4px;
  font-size: 37px;
}

.p-section_heading-text {
  flex: 1;
  font-style: normal;
  font-weight: 500;
  font-size: 28px;
  line-height: 1.2;
  font-family: "Zen Maru Gothic", sans-serif;
  letter-spacing: -0.8px;
}

.p-section_text {
  margin: 36px 0 0;
  padding: 0 48px;
  font-size: 16px;
  line-height: 1.6;
}

.p-section_image {
  margin: 36px 0 0;
  padding: 0 46px;
}

.p-section_map {
  margin: 25px 0 0;
  padding: 0 25px;
}

.p-section_button {
  margin: 48px 0 0;
  text-align: center;
}

.p-detail-mv {
  background-color: #EEE6D5;
  padding: 104px 0 48px;
}

.p-detail-mv_title {
  font-weight: 700;
  font-size: 25px;
  line-height: 1;
  letter-spacing: -0.99px;
  text-align: center;
}
.p-detail-mv_title span {
  display: inline-block;
  position: relative;
  padding: 5px 15px;
}
.p-detail-mv_title span:before, .p-detail-mv_title span:after {
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-image: url("../img/detail_ico_title.svg");
  background-position: 0 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 9px;
  height: 34px;
  content: "";
}
.p-detail-mv_title span:before {
  left: 0;
}
.p-detail-mv_title span:after {
  right: 0;
  transform: translateY(-50%) scale(-1, 1);
}

.p-detail-mv_navi {
  display: flex;
  justify-content: center;
  margin: 24px 0 0;
}
.p-detail-mv_navi ul {
  display: flex;
  align-items: center;
  gap: 12px;
  border-radius: 1000px;
  background: #E2D5B9;
  padding: 12px;
}
.p-detail-mv_navi ul li._current a {
  background-color: var(--white);
  pointer-events: none;
}
.p-detail-mv_navi ul li a {
  display: block;
  border: solid 1px var(--white);
  border-radius: 30px;
  padding: 9px 15px;
  color: var(--black, #000);
  font-weight: 700;
  font-size: 24px;
  line-height: 1;
}

.p-detail-mv_heading {
  margin: 48px 0 0;
  padding: 0 48px;
  font-style: normal;
  font-weight: 500;
  font-size: 62px;
  line-height: 1;
  font-family: "Zen Maru Gothic", sans-serif;
}

.p-detail-mv_heading-sub {
  display: block;
  margin: 0 0 18px;
  font-size: 36px;
}

.p-detail-mv_heading-set {
  margin: 0 -10px;
}

.p-detail-mv_slider {
  margin: 74px 0 0;
}

.p-detail-mv_slider-title {
  font-weight: 700;
  font-size: 30px;
  line-height: 1;
  text-align: center;
}
.p-detail-mv_slider-title span {
  display: inline-block;
  position: relative;
}
.p-detail-mv_slider-title span:before {
  display: block;
  position: absolute;
  top: -43px;
  right: -56px;
  z-index: 1;
  background-image: url("/common/img/common_ico_heading3.svg");
  background-position: 0 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 72px;
  height: 60px;
  content: "";
}

.p-detail-mv_slider-unit {
  position: relative;
  margin: 24px 0 0;
  padding: 0 0 30px;
}
.p-detail-mv_slider-unit:before, .p-detail-mv_slider-unit:after {
  display: block;
  position: absolute;
  top: 0;
  z-index: 2;
  background-image: url("../img/detail_ico_mv_slider.svg");
  background-position: 0 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 48px;
  height: 455px;
  content: "";
}
.p-detail-mv_slider-unit:before {
  left: 50px;
}
.p-detail-mv_slider-unit:after {
  right: 50px;
  transform: scale(-1, 1);
}
.p-detail-mv_slider-unit .swiper-slide {
  transition: transform 1s;
  margin: 0 60px;
  padding: 82px 0;
  width: 52.0025%;
}
.p-detail-mv_slider-unit .swiper-slide.swiper-slide-active {
  transform: scale(1.25);
}
.p-detail-mv_slider-unit .swiper-pagination {
  bottom: 0;
}
.p-detail-mv_slider-unit .swiper-pagination-bullet {
  opacity: 1;
  border: solid 1px var(--black);
  background: transparent;
  width: 12px;
  height: 12px;
}
.p-detail-mv_slider-unit .swiper-pagination-bullet-active {
  background: var(--black);
}
.p-detail-mv_slider-unit .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.p-detail-mv_slider-unit .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 6px;
}

.p-detail-mv_slider-item {
  display: block;
  position: relative;
}

.p-detail-mv_slider-text {
  display: flex;
  position: absolute;
  bottom: 25px;
  left: -12px;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  z-index: 1;
}
.p-detail-mv_slider-text span {
  display: inline-block;
  transition: background-color 0.3s, color 0.3s, border-color 0.3s;
  border: solid 1px var(--black);
  background-color: var(--white);
  padding: 3px 9px 7px;
  color: var(--black);
  font-style: normal;
  font-weight: 500;
  font-size: 22px;
  line-height: 1;
  font-family: "Zen Maru Gothic", sans-serif;
  letter-spacing: 1.32px;
}

.p-detail-mv_slider-image {
  border-radius: 12px;
  overflow: hidden;
}
.p-detail-mv_slider-image img {
  transition: transform 0.3s;
}

.p-detail-mv_button {
  margin: 42px 0 0;
  text-align: center;
}

.p-detail-mv_text {
  margin: 36px 0 0;
  padding: 0 49px;
  font-size: 16px;
  line-height: 1.6;
}

.p-detail-route {
  margin: 86px 0 0;
}
.p-detail-route + .p-detail-route {
  margin-top: 120px;
}

.p-detail-route_heading {
  margin: 0 auto;
  width: 388px;
}

.p-detail-route_button {
  margin: 12px 0 0;
  text-align: center;
}
.p-detail-route_button._hide {
  display: none;
}

.p-detail-spot {
  position: relative;
  margin: 38px 0 0;
}
.p-detail-spot + .p-detail-spot {
  margin-top: 0;
  padding-top: 120px;
}
.p-detail-spot:not(:has(.p-detail-spot_move)) + .p-detail-spot:not(:has(.p-detail-spot_move)) {
  padding-top: 62px;
}
.p-detail-spot._hide {
  visibility: hidden;
  padding-top: 0;
  height: 0;
  overflow: hidden;
}

.p-detail-spot-inner {
  position: relative;
  border-radius: 60px 60px 0 0;
  background-image: url("/common/img/common_bg_item3.webp");
  background-position: 0 0;
  background-size: 126px 126px;
  background-repeat: repeat;
  padding: 60px 0 140px;
  min-height: 500px;
}
.p-detail-spot-inner:before {
  display: block;
  position: absolute;
  bottom: 77px;
  left: 0;
  z-index: 1;
  background-image: url("/common/img/common_ico_flame_parts1.svg");
  background-position: 0 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 60px;
  height: 60px;
  content: "";
}
.p-detail-spot-inner:after {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  border-radius: 0 60px 0 0;
  background-color: var(--white);
  width: 100%;
  height: 77px;
  content: "";
}
.p-detail-spot._switch .p-detail-spot-inner:before {
  right: 0;
  left: auto;
  transform: scale(-1, 1);
}
.p-detail-spot._switch .p-detail-spot-inner:after {
  border-radius: 60px 0 0 0;
}

.p-detail-spot_start {
  margin: 0 0 36px;
  padding: 0 48px;
  font-size: 18px;
  line-height: 1.3;
  text-align: center;
}

.p-detail-spot_heading {
  display: flex;
  justify-content: center;
  padding: 0 48px;
}

.p-detail-spot_heading-unit {
  display: flex;
  position: relative;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 7px 18px;
}
.p-detail-spot_heading-unit:before, .p-detail-spot_heading-unit:after {
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: solid 1px var(--black);
  border-right: none;
  width: 6px;
  height: calc(100% - 5px);
  content: "";
}
.p-detail-spot_heading-unit:before {
  left: 0;
}
.p-detail-spot_heading-unit:after {
  right: 0;
  transform: translateY(-50%) scaleX(-1);
}

.p-detail-spot_heading-text {
  flex: 1;
  font-weight: 700;
  font-size: 30px;
  line-height: 1.2;
}

.p-detail-spot_go {
  display: flex;
  justify-content: center;
  margin: 34px 0 0;
}
.p-detail-spot_go button {
  display: flex;
  position: relative;
  align-items: center;
  gap: 12px;
  padding: 0 0 0 30px;
  color: var(--black);
  font-weight: 700;
  font-size: 18px;
  line-height: 1;
  font-family: inherit;
}
.p-detail-spot_go button:before {
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  background-image: url("/common/img/common_ico_heart1.svg");
  background-position: center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 24px;
  height: 22px;
  content: "";
}
.p-detail-spot_go button:disabled {
  pointer-events: none;
}
.p-detail-spot_go button:disabled:before {
  background-image: url("/common/img/common_ico_heart2.svg");
}
.p-detail-spot_go button span {
  display: block;
  position: relative;
  border: solid 1px var(--black);
  border-radius: 4px;
  background-color: var(--white);
  padding: 5px 9px;
}
.p-detail-spot_go button span:before, .p-detail-spot_go button span:after {
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border-width: 4px 7px 4px 0;
  border-style: solid;
  border-color: transparent #000 transparent transparent;
  width: 0;
  height: 0;
  content: "";
}
.p-detail-spot_go button span:before {
  left: -7px;
}
.p-detail-spot_go button span:after {
  left: -5px;
  border-color: transparent #fff transparent transparent;
}

.p-detail-spot_cat-name {
  margin: 36px 0 0;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.6;
  text-align: center;
}
.p-detail-spot_cat-name span {
  margin: 0 0 0 0.5em;
  font-size: 20px;
}

.p-detail-spot_text {
  margin: 36px 0 0;
  padding: 0 48px;
  color: var(--black);
  font-size: 16px;
  line-height: 1.6;
}

.p-detail-spot_slider {
  margin: 36px 0 0;
  padding: 0 0 43px;
}
.p-detail-spot_slider .swiper-slide {
  margin: 0 16px;
  width: 83.45%;
}
.p-detail-spot_slider .swiper-pagination {
  bottom: 0;
}
.p-detail-spot_slider .swiper-pagination-bullet {
  opacity: 1;
  border: solid 1px var(--black);
  background: transparent;
  width: 12px;
  height: 12px;
}
.p-detail-spot_slider .swiper-pagination-bullet-active {
  background: var(--black);
}
.p-detail-spot_slider .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.p-detail-spot_slider .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 6px;
}

.p-detail-spot_slider-image {
  border-radius: 30px;
  overflow: hidden;
}

.p-detail-spot_button {
  margin: 30px 0 0;
  text-align: center;
}
.p-detail-spot_button + .p-detail-spot_button {
  margin-top: 36px;
}

.p-detail-spot_move {
  position: absolute;
  top: -54px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  width: 64px;
  height: 151px;
}
.p-detail-spot_move:before {
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background-position: 0 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  width: 100%;
  height: 100%;
  content: "";
}
.p-detail-spot_move._foot:before {
  background-image: url("../img/detail_ico_spot_move_foot.svg");
}
.p-detail-spot_move._bus:before {
  background-image: url("../img/detail_ico_spot_move_bus.svg");
}
.p-detail-spot_move._train:before {
  background-image: url("../img/detail_ico_spot_move_train.svg");
}
.p-detail-spot_move._ship:before {
  background-image: url("../img/detail_ico_spot_move_ship.svg");
}

.p-detail-spot_move-text {
  display: flex;
  position: absolute;
  top: 50%;
  left: calc(100% + 8px);
  flex-wrap: wrap;
  gap: 0px 8px;
  transform: translateY(-50%);
  width: 320%;
  color: #575757;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.2;
}

.p-detail-spot_move-time {
  display: flex;
  align-items: baseline;
}
.p-detail-spot_move-time span {
  font-size: 18px;
}

.p-detail-access_map {
  margin: 56px 0 0;
  height: 376px;
  overflow: hidden;
  line-height: 0;
}
.p-detail-access_map iframe {
  border: none;
  width: 100%;
  height: 100%;
}
.p-detail-access_map #featurecardPanel {
  top: 67px !important;
}

.p-detail-other {
  margin: 82px 0 0;
  padding: 0 48px 64px;
}

@media screen and (min-width: 768px) and (any-hover: hover){
  .p-mv_anchor_item a:hover {
    background-color: var(--white);
    color: var(--black);
  }
  .p-mv_anchor_item a:hover:after {
    filter: none;
  }
  .p-detail-mv_navi ul li a:hover {
    background-color: var(--white);
  }
}

@media screen and (max-width: 1200px){
  .p-mv {
    margin-top: -104px;
  }
  .p-detail-mv {
    margin-top: -104px;
  }
}

@media screen and (max-width: 767px){
  .p-mv {
    margin-top: -74px;
    padding: 24px 32px;
  }
  .p-mv_heading {
    font-size: 14.9333333333vw;
  }
  .p-mv_anchor {
    gap: 8px;
    margin: 24px 0 0;
  }
  .p-mv_anchor_item a {
    padding: 8px 34px 8px 16px;
    font-size: 16px;
  }
  .p-mv_anchor_item a:after {
    right: 12px;
    width: 15px;
    height: 13px;
  }
  .p-lead {
    border-radius: 16px 16px 0 0;
    padding: 32px 0;
  }
  .p-lead:after {
    right: 16px;
    width: 65px;
    height: 29px;
  }
  .p-lead_heading {
    width: 209px;
  }
  .p-lead_text {
    margin: 24px 0 0;
    font-size: 15px;
    letter-spacing: 0.6px;
  }
  .p-lead_logo {
    margin: 40px 0 0;
    width: 127px;
  }
  .p-section {
    padding: 0 0 56px;
  }
  .p-section:not(:has(+ .banner)) {
    padding-bottom: 56px;
  }
  .p-section_heading {
    padding: 12px 16px;
  }
  .p-section_heading-place {
    padding: 6px 23px 6px 0;
    font-size: 20px;
  }
  .p-section_heading-place:before {
    right: 10px;
  }
  .p-section_heading-place rt {
    font-size: 10px;
  }
  .p-section_heading-place-set {
    margin: 0 -4px;
    font-size: 24px;
  }
  .p-section_heading-text {
    margin: 0;
    font-size: 18px;
  }
  .p-section_text {
    margin: 24px 0 0;
    padding: 0 32px;
    font-size: 14px;
  }
  .p-section_image {
    margin: 22px 0 0;
    padding: 0 30px;
  }
  .p-section_map {
    margin: 16px 0 0;
    padding: 0 16px;
  }
  .p-section_button {
    margin: 34px 0 0;
  }
  .p-detail-mv {
    margin-top: -74px;
    padding: 74px 0 32px;
  }
  .p-detail-mv_title {
    font-size: 16px;
    letter-spacing: -0.64px;
  }
  .p-detail-mv_title span {
    padding: 3px 10px;
  }
  .p-detail-mv_title span:before, .p-detail-mv_title span:after {
    width: 6px;
    height: 22px;
  }
  .p-detail-mv_navi {
    margin: 16px 0 0;
  }
  .p-detail-mv_navi ul {
    gap: 8px;
    padding: 8px;
  }
  .p-detail-mv_navi ul li a {
    padding: 7px;
    font-size: 16px;
  }
  .p-detail-mv_heading {
    margin: 32px 0 0;
    padding: 0 32px;
    font-size: 40px;
  }
  .p-detail-mv_heading-sub {
    margin: 0 0 12px;
    font-size: 24px;
  }
  .p-detail-mv_heading-set {
    margin: 0 -7px;
  }
  .p-detail-mv_slider {
    margin: 48px 0 0;
  }
  .p-detail-mv_slider-title {
    font-size: 20px;
  }
  .p-detail-mv_slider-title span:before {
    top: -28px;
    right: -30px;
    width: 47px;
    height: 39px;
  }
  .p-detail-mv_slider-unit {
    margin: 16px 0 0;
    padding: 0 0 34px;
    width: 100vw;
  }
  .p-detail-mv_slider-unit:before, .p-detail-mv_slider-unit:after {
    width: 8.5333333333vw;
    height: 80vw;
  }
  .p-detail-mv_slider-unit:before {
    left: 8.5333333333vw;
  }
  .p-detail-mv_slider-unit:after {
    right: 8.5333333333vw;
  }
  .p-detail-mv_slider-unit .swiper-slide {
    margin: 0 10.1333333333vw;
    padding: 14.4vw 0 12.2666666667vw;
  }
  .p-detail-mv_slider-unit .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
  }
  .p-detail-mv_slider-unit .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
  .p-detail-mv_slider-unit .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 4px;
  }
  .p-detail-mv_slider-text {
    bottom: 18px;
    left: -8px;
    gap: 6px;
  }
  .p-detail-mv_slider-text span {
    padding: 2px 5px 3px;
    font-size: 14px;
    letter-spacing: 0.84px;
  }
  .p-detail-mv_slider-image {
    border-radius: 6px;
  }
  .p-detail-mv_button {
    margin: 26px 0 0;
  }
  .p-detail-mv_text {
    margin: 24px 0 0;
    padding: 0 32px;
    font-size: 14px;
  }
  .p-detail-route {
    margin: 56px 0 0;
  }
  .p-detail-route + .p-detail-route {
    margin-top: 74px;
  }
  .p-detail-route_heading {
    width: 251px;
  }
  .p-detail-route_button {
    margin: 0;
  }
  .p-detail-spot {
    margin: 24px 0 0;
  }
  .p-detail-spot + .p-detail-spot {
    padding-top: 74px;
  }
  .p-detail-spot:not(:has(.p-detail-spot_move)) + .p-detail-spot:not(:has(.p-detail-spot_move)) {
    padding-top: 40px;
  }
  .p-detail-spot._hide {
    padding-top: 0;
  }
  .p-detail-spot-inner {
    border-radius: 40px 40px 0 0;
    padding: 40px 0 97px;
  }
  .p-detail-spot-inner:before {
    bottom: 57px;
    width: 40px;
    height: 40px;
  }
  .p-detail-spot-inner:after {
    border-radius: 0 40px 0 0;
    height: 57px;
  }
  .p-detail-spot_start {
    margin: 0 0 24px;
    padding: 0 32px;
    font-size: 16px;
  }
  .p-detail-spot_heading {
    padding: 0 32px;
  }
  .p-detail-spot_heading-unit {
    gap: 4px;
    padding: 6px 12px;
  }
  .p-detail-spot_heading-unit:before, .p-detail-spot_heading-unit:after {
    width: 4px;
    height: calc(100% - 3px);
  }
  .p-detail-spot_heading-text {
    font-size: 20px;
  }
  .p-detail-spot_go {
    margin: 23px 0 0;
  }
  .p-detail-spot_go button {
    gap: 8px;
    padding: 0 0 0 20px;
    font-size: 12px;
  }
  .p-detail-spot_go button:before {
    width: 16px;
    height: 14px;
  }
  .p-detail-spot_go button span {
    padding: 3px 6px;
  }
  .p-detail-spot_go button span:before, .p-detail-spot_go button span:after {
    border-width: 3px 5px 3px 0;
  }
  .p-detail-spot_go button span:before {
    left: -5px;
  }
  .p-detail-spot_go button span:after {
    left: -3px;
  }
  .p-detail-spot_cat-name {
    margin: 24px 0 0;
    font-size: 14px;
  }
  .p-detail-spot_cat-name span {
    font-size: 18px;
  }
  .p-detail-spot_text {
    margin: 24px 0 0;
    padding: 0 32px;
    font-size: 14px;
  }
  .p-detail-spot_slider {
    margin: 24px 0 0;
    padding: 0 0 30px;
  }
  .p-detail-spot_slider .swiper-slide {
    margin: 0 2.6666666667vw;
  }
  .p-detail-spot_slider .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
  }
  .p-detail-spot_slider .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
  .p-detail-spot_slider .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 4px;
  }
  .p-detail-spot_slider-image {
    border-radius: 20px;
  }
  .p-detail-spot_button {
    margin: 12px 0 0;
  }
  .p-detail-spot_button + .p-detail-spot_button {
    margin-top: 24px;
  }
  .p-detail-spot_move {
    top: -40px;
    width: 42px;
    height: 98px;
  }
  .p-detail-spot_move-text {
    left: calc(100% + 4px);
    gap: 2px 4px;
    font-size: 16px;
  }
  .p-detail-spot_move-time span {
    font-size: 12px;
  }
  .p-detail-access_map {
    margin: 35px 0 0;
    height: 64.8vw;
  }
  .p-detail-other {
    margin: 53px 0 0;
    padding: 0 32px 40px;
  }
}

@media screen and (max-width: 374px){
  .p-detail-mv_navi ul li a {
    font-size: 14px;
  }
}
