.tour-top-container {
  display: flex;
  flex-direction: column;
  margin-top: 80px;
}

.tour-top-info {
  padding: 8px 0 0;
}

.tour-category {
  font-size: 16px;
  font-weight: bold;
}

.tour-title {
  margin: 0;
  font-size: 24px;
  font-weight: bold;
}

.tour-tags-container {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
}

.tour-tag-item {
  padding: 3px 8px 5px;
  color: #ffffff;
  font-size: 14px;
  font-weight: bold;
}

.tour-tag-color1 {
  background-color: #fa5726;
}

.tour-tag-color2 {
  background-color: #57c948;
}

.tour-tag-color3 {
  background-color: #17b8f4;
}

.tour-tag-color4 {
  background-color: #e3c311;
}

.tour-top-gallery-wrapper {
  background-color: #cfdce5;
}

.tour-top-gallery-container {
  margin: 0 auto;
  max-width: 1160px;
}

.tour-top-gallery-container .splide__list {
  aspect-ratio: 390 / 240;
}

.tour-top-gallery-item {
  background-position: center;
  background-size: cover;
}

.tour-top-gallery-container .splide__arrow {
  background-color: #233441;
  width: 40px;
  height: 40px;
  color: #ffffff;
  font-size: 27px;
  opacity: 1;
}

.tour-top-gallery-container .splide__arrow:hover {
  opacity: 0.7;
}

.tour-top-gallery-container .splide__arrow--prev {
  left: 8px;
}

.tour-top-gallery-container .splide__arrow--next {
  right: 8px;
}

.tour-top-gallery-container .splide__arrow svg {
  width: 1em;
  height: 1em;
}

.tour-top-gallery-page-number {
  position: absolute;
  inset: auto 0 24px;
  text-align: center;
  color: #ffffff;
  font-size: 16px;
  font-weight: bold;
}

.tour-top-text :first-child {
  margin-top: 24px;
}

.tour-top-text :last-child {
  margin-bottom: 24px;
}

.tour-section-header {
  margin: 12px 0 40px;
}

.tour-info {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  justify-content: center;
  gap: 16px 24px;
  padding: 0 16px;
}

.tour-info-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.tour-info-icon {
  height: 24px;
  font-size: 24px;
}

.tour-info-title {
  margin-top: 4px;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
}

.tour-info-text {
  margin-top: 4px;
  text-align: center;
  font-size: 14px;
}

.tour-activity-section {
  padding: 0 16px;
}

.tour-activity-headline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0;
  border-top: solid 1px #cfdce5;
  padding: 16px 0;
  font-size: 16px;
  line-height: 24px;
  cursor: pointer;
}

.tour-activity-headline>.fa-chevron-down {
  flex: 0 0 auto;
  margin: 0 24px;
}

.tour-activity-content {
  margin-bottom: 40px;
}

.tour-activity-content:not(.show) {
  display: none;
}

.tour-activity-text> :first-child {
  margin-top: 0;
}

.tour-activity-text> :last-child {
  margin-bottom: 0;
}

.tour-recommend-point {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.tour-recommend-point-text> :first-child {
  margin-top: 0;
}

.tour-recommend-point-text> :last-child {
  margin-bottom: 0;
}

.tour-recommend-point-gallery-container {
  flex: 0 0 65%;
  max-width: 760px;
}

.tour-recommend-point-gallery-main .splide__list {
  aspect-ratio: 16/9 !important;
  height: auto !important;
}

.tour-recommend-point-gallery-item {
  width: 100%;
  aspect-ratio: 16/9;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #fff;
  min-width: 0;
  min-height: 0;
}

.tour-recommend-point-gallery-thumbnail {
  margin-top: 8px;
}

.tour-recommend-point-gallery-thumbnail .splide__slide:not(.is-active) {
  filter: brightness(50%);
}

.tour-recommend-point-gallery-thumbnail .splide__list .splide__slide.is-active {
  border: none;
}

.tour-recommend-point-gallery-thumbnail .splide__arrow {
  background-color: #233441;
  width: 40px;
  height: 40px;
  color: #ffffff;
  font-size: 27px;
  opacity: 1;
}

.tour-recommend-point-gallery-thumbnail .splide__arrow svg {
  width: 1em;
  height: 1em;
}

.tour-recommend-point-gallery-container .splide__arrow--prev {
  left: 0;
}

.tour-recommend-point-gallery-container .splide__arrow--next {
  right: 0;
}

.tour-recommend-point-gallery-thumbnail .splide__arrow:hover {
  opacity: 0.7;
}

.tour-recommend-point-gallery-thumbnail .tour-recommend-point-gallery-item {
  aspect-ratio: 16/9 !important;
}

.tour-activity-checklist {
  margin: 0;
  padding: 0;
  list-style: none;
}

.tour-activity-checklist li+li {
  margin-top: 8px;
}

.tour-activity-check {
  margin-right: 8px;
  width: 20px;
  height: 20px;
  color: #4e9d00;
  font-size: 20px;
}

.tour-activity-x {
  margin-right: 8px;
  width: 20px;
  height: 20px;
  color: #db5400;
  font-size: 20px;
}

.tour-reservation-container {
  background-color: #f2f8fc;
}

.tour-reservation-container .tour-activity-headline {
  border-top: none;
}

.tour-reservation-item {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  border-top: solid 1px #cfdce5;
  border-bottom: solid 1px #cfdce5;
  padding: 32px 0;
}

.tour-reservation-item+.tour-reservation-item {
  border-top: none;
}

.tour-reservation-item-name {
  margin: 0;
}

.tour-reservation-item-price {
  text-align: right;
}

.tour-reservation-item-button {
  grid-column: 1 / 3;
  margin: 16px auto 0;
  border: none;
  padding: 12px 0;
  width: 256px;
  height: 24px;
  border-radius: 40px;
  background-color: #233441;
  color: #ffffff;
  text-align: center;
  font-size: 16px;
  line-height: 24px;
  font-weight: bold;
  text-decoration: none;
}

.tour-reservation-item-button:hover {
  background-color: #0d5288;
}

.tour-layout-columns {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.tour-layout-columns>* {
  flex: 1 1 0;
}

.tour-activity-subheadline {
  margin: 0 0 8px;
  font-size: 16px;
}

.tour-activity-map {
  display: block;
  border: none;
  width: 100%;
  height: 340px;
}

.tour-reservation-jump-button {
  position: fixed;
  left: 16px;
  bottom: 16px;
  border: none;
  padding: 0;
  width: 160px;
  height: 48px;
  padding: 10px 20px;
  border-radius: 40px;
  background-color: #233441;
  color: #ffffff;
  font-size: 15px;
  font-weight: bold;
}

.tour-reservation-jump-button:hover {
  background-color: #0d5288;
}

.tour-reservation-jump-button-new {
  position: fixed;
  left: 16px;
  bottom: 16px;
  border: none;
  padding: 0;
  width: 160px;
  height: 48px;
  padding: 10px 20px;
  border-radius: 40px;
  background-color: orange;
  color: #ffffff;
  font-size: 15px;
  font-weight: bold;
}

.tour-reservation-jump-button-new:hover {
  background-color: #0d5288;
}

@media (max-width: 767px) {
  .tour-top-gallery-wrapper {
    order: -1;
  }
}

@media (min-width: 768px) {
  .tour-top-info {
    padding: 16px 0;
  }

  .tour-title {
    font-size: 32px;
  }

  .tour-top-gallery-container .splide__list {
    aspect-ratio: auto;
    height: 480px;
  }

  .tour-top-gallery-container .splide__arrow {
    width: 46px;
    height: 46px;
    font-size: 32px;
  }

  .tour-activity-section {
    padding: 0 40px;
  }

  .tour-section-header {
    margin: 24px 0 80px;
  }

  .tour-info {
    grid-template-columns: repeat(auto-fill, 258px);
    gap: 32px;
  }

  .tour-info-icon {
    height: 40px;
    font-size: 40px;
  }

  .tour-info-title {
    margin-top: 16px;
    font-size: 18px;
  }

  .tour-info-text {
    margin-top: 8px;
    font-size: 16px;
  }

  .tour-activity-headline {
    padding: 32px 0;
    font-size: 24px;
    line-height: 36px;
  }

  .tour-recommend-point {
    flex-direction: row;
  }

  .tour-recommend-point-gallery-thumbnail .splide__arrow {
    width: 46px;
    height: 46px;
    font-size: 32px;
  }

  .tour-recommend-point-gallery-container .splide__arrow--prev {
    left: 8px;
  }

  .tour-recommend-point-gallery-container .splide__arrow--next {
    right: 8px;
  }

  .tour-layout-columns {
    flex-direction: row;
  }

  .tour-reservation-item {
    grid-template-columns: 1fr auto auto;
    padding: 32px 0;
  }

  .tour-reservation-item-button {
    grid-column: auto;
    margin: 0;
    margin-left: 114px;
  }
}

.tour-top-gallery-single {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  aspect-ratio: 16/9;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tour-top-gallery-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 16/9;
  background: #000;
  display: block;
}