@charset "UTF-8";
.filter_navi {
  margin-bottom: 3rem;
}
.filter_navi::after {
  content: "";
  clear: both;
  display: block;
  margin-bottom: 3rem;
}
.filter_navi #filter_navi_btn {
  display: block;
  padding: 0.75em 0;
  color: #000000;
  fill: #000000;
  text-align: center;
  line-height: 1;
  vertical-align: middle;
  z-index: 100;
}
.filter_navi #filter_navi_btn::after {
  content: "";
  display: inline-block;
  margin-top: -0.5em;
  margin-bottom: auto;
  margin-left: 1em;
  width: 0.6em;
  height: 0.6em;
  border-style: solid;
  border-width: 0 1px 1px 0;
  line-height: 1;
  vertical-align: middle;
  transform: rotate(45deg);
}
.filter_navi #filter_navi_btn .icn {
  display: inline-block;
  margin-right: 1em;
  width: 1.25em;
  height: 1.25em;
  vertical-align: middle;
  line-height: 1;
}
.filter_navi #filter_navi_panel {
  overflow: hidden;
}
.filter_navi #filter_navi_panel .filter_form {
  display: block;
  margin-top: -200vh;
  width: 100%;
  opacity: 0;
  transition: all 0.2s;
}
.filter_navi #filter_navi_panel .filter_list {
  display: flex;
  flex-wrap: wrap;
  float: left;
  margin-top: 1.5rem;
  width: 100%;
}
.filter_navi #filter_navi_panel .filter_list .filter_set {
  padding: 0;
  border: none;
}
.filter_navi #filter_navi_panel .filter_list .filter_set legend {
  display: block;
  margin-bottom: 0.75em;
  padding-bottom: 0.75em;
  width: 100%;
  border-bottom: solid thin #707070;
  color: #000000;
  fill: #000000;
  font-family: "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: bold;
  line-height: 1;
}
.filter_navi #filter_navi_panel .filter_list .filter_set ul {
  list-style: none;
  padding: 0;
}
.filter_navi #filter_navi_panel .filter_list .filter_set ul > li:not(:last-child) {
  margin-bottom: 0.5em;
}
.filter_navi #filter_navi_panel .filter_list .filter_set .filter {
  display: inline-block;
  padding-left: 1.5em;
}
.filter_navi #filter_navi_panel .filter_list .filter_set .filter::before {
  content: "";
  display: inline-block;
  margin-left: -2em;
  margin-right: 0.3em;
  width: 1.2em;
  height: 1.2em;
  vertical-align: middle;
  border: solid thin #DFE1E3;
  vertical-align: middle;
  line-height: 1;
}
.filter_navi #filter_navi_panel .filter_list .filter_set .switch:checked + .filter::before {
  border-color: #000000;
  background-color: #000000;
  background-image: url(../images/icn-checked.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% 100%;
}
.filter_navi #filter_navi_panel .submit_btn {
  display: block;
  padding: 0.5em 1em;
  min-width: 13.375em;
  border-radius: 0;
  border: solid thin;
  text-align: center;
  text-decoration: none;
  line-height: 1.25;
  margin-right: auto;
  margin-left: auto;
  padding: 0.75em;
  background-color: #000000 !important;
  color: #FFFFFF !important;
  font-size: 1em;
}
.filter_navi #filter_navi_panel .submit_btn:not(.has-text-color) {
  color: #000000;
  fill: #000000;
}
.filter_navi #filter_navi_panel .submit_btn:not(.has-background) {
  background: none;
}
.filter_navi #filter_navi_panel .submit_btn:hover {
  box-shadow: 0 1px 1px 1px rgba(0, 0, 0, 0.3);
  transform: translate(0, -1px);
}
.filter_navi #filter_navi_panel .submit_btn:active {
  box-shadow: -1px 1px 1px rgba(0, 0, 0, 0.3) inset;
  transform: translate(0, 1px);
}
.filter_navi #filter_navi_panel .submit_btn::before {
  content: "";
  display: inline-block;
  margin-right: 1.5em;
  margin-top: -0.25em;
  width: 1.5em;
  height: 1.5em;
  background-image: url(../../assets/images/icn-link_self.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100% 100%;
  vertical-align: middle;
}
.filter_navi #filter_navi_panel .submit_btn.has-white-color::before {
  background-image: url(../../assets/images/icn-link_self-w.svg);
}
.filter_navi #filter_navi_panel .submit_btn[target=_blank]::before {
  background-image: url(../../assets/images/icn-link_blank.svg);
}
.filter_navi #filter_navi_panel .submit_btn::before {
  background-image: url(../images/icn-link_self-w.svg);
}
.filter_navi #filter_navi_switch:checked + #filter_navi_btn::after {
  margin-top: auto;
  margin-bottom: -0.5em;
  transform: rotate(-135deg);
}
.filter_navi #filter_navi_switch:checked ~ #filter_navi_panel .filter_form {
  margin-top: 0rem;
  opacity: 1;
}
@media screen and (max-width: 719px) {
  .filter_navi #filter_navi_panel .filter_list .filter_set {
    margin-bottom: 10%;
    width: 100%;
  }
  .filter_navi #filter_navi_panel .filter_list .filter_set .filter {
    font-size: 0.875em;
  }
  .filter_navi #filter_navi_panel .filter_list .filter_set ul {
    display: flex;
    flex-wrap: wrap;
  }
  .filter_navi #filter_navi_panel .filter_list .filter_set ul > li {
    margin-left: 12%;
    width: 38%;
  }
}
@media (min-width:720px) {
  .filter_navi {
    margin-bottom: 4.5rem;
  }
  .filter_navi #filter_navi_panel .filter_list {
    margin-top: 3rem;
  }
  .filter_navi #filter_navi_panel .filter_list .filter_set {
    margin-bottom: 5%;
    width: 21.25%;
    width: 21.25%;
  }
  .filter_navi #filter_navi_panel .filter_list .filter_set:not(:nth-child(4n+0)) {
    margin-right: 5%;
  }
  .filter_navi #filter_navi_panel .filter_list .filter_set:first-child:last-child {
    margin-right: auto;
    margin-left: auto;
  }
  .filter_navi #filter_navi_panel .filter_list .filter_set legend {
    margin-bottom: 1em;
    padding-bottom: 1em;
    text-align: center;
  }
  .filter_navi #filter_navi_panel .filter_list .filter_set ul {
    padding: 0 1em;
  }
  .filter_navi #filter_navi_panel .submit_btn {
    width: 16em;
  }
}

.spot_thumb .slick-arrow {
  margin: auto 0.25rem;
  z-index: 10;
  width: 1.25rem;
  height: 1.25rem;
  line-height: 1;
  text-shadow: 0 0 1px rgba(0, 0, 0, 0.2), 0 0 2px rgba(0, 0, 0, 0.2), 0 0 3px rgba(0, 0, 0, 0.2), 0 0 5px rgba(0, 0, 0, 0.2), 0 0 10px rgba(0, 0, 0, 0.2);
}
.spot_thumb .slick-arrow.slick-prev {
  left: 0;
}
.spot_thumb .slick-arrow.slick-next {
  right: 0;
}
.spot_thumb .slick-arrow::before {
  display: inline-block;
  font-size: 1.25rem;
}
.spot_thumb .slick-dots {
  bottom: 0;
  z-index: 20;
}
.spot_thumb .slick-dots > li {
  margin-right: 0.2em;
  margin-left: 0.2em;
  width: 1.5em;
  height: 0.5em;
}
.spot_thumb .slick-dots > li button {
  margin: auto;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1em;
  overflow: hidden;
}
.spot_thumb .slick-dots > li button::before {
  content: "";
  width: 100%;
  height: 0;
  border: solid thin;
  color: #FFFFFF;
  font-size: 1em;
  box-shadow: 0 0 1px 0 rgba(0, 0, 0, 0.5);
}
.spot_thumb .slick-list {
  z-index: auto;
}
@media screen and (max-width: 719px) {
  .spot_thumb .slick-slider.slick-dotted {
    margin-bottom: 0;
  }
}
@media (min-width:720px) {
  .spot_thumb .slick-slider.slick-dotted {
    margin-bottom: 0.5em;
  }
}
.spot_thumb .season_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: -0.5rem;
}
.spot_thumb .season_list > [role=tab]:not([aria-expanded=true]) {
  background-color: #FFFFFF;
}
.spot_thumb .season_list > [role=tabpanel] {
  order: 1;
  width: 100%;
}
.spot_thumb .season_list > [role=tab] {
  order: 0;
  flex-grow: 1;
  max-width: calc((100% - 8px) / 5);
  margin-bottom: 0.5rem;
  padding: 0.5em;
  text-align: center;
  line-height: 1;
}
.spot_thumb .season_list > [role=tab]:not(:last-of-type) {
  margin-right: 2px;
}
.spot_thumb .season_list > [role=tab][aria-expanded=true] {
  background-color: #000000;
  color: #FFFFFF;
  fill: #FFFFFF;
}
.spot_thumb .season_list > [role=tab][data-count="0"] {
  pointer-events: none;
  opacity: 0.5;
}
@media screen and (max-width: 719px) {
  .spot_thumb .season_list > [role=tab][aria-expanded=false] {
    background-color: #F7F3F0;
  }
}

.spot_index .spot_block[href] {
  display: block;
  color: inherit;
  fill: inherit;
  text-decoration: none;
}
.spot_index .spot_block[href]:hover {
  opacity: 0.6;
}
.spot_index .spot_block[href] .spot_thumb::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 100%;
}
.spot_index .spot_block[href] .spot_thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.spot_index:not(.index_masonry) .spot_block .spot_summary .spot_name {
  color: #000000;
  font-family: "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-size: 1em;
  font-weight: bold;
}
.spot_index:not(.index_masonry) .spot_block .spot_summary .spot_name a {
  color: inherit;
  text-decoration: none;
}
.spot_index:not(.index_masonry) .spot_block .spot_summary .spot_web,
.spot_index:not(.index_masonry) .spot_block .spot_summary .spot_fee {
  display: block;
  margin-bottom: 0.5em;
  font-size: 0.75em;
}
.spot_index:not(.index_masonry) .spot_block .spot_summary .spot_web {
  display: inline-block;
  padding: 0.25em 0.5em 0.25em 2em;
  border-radius: 0.25em;
  background-color: #DFE1E3;
  background-image: url(../images/icn-link_blank.svg);
  background-repeat: no-repeat;
  background-position: 0.5em center;
  background-size: 1em 1em;
  color: inherit;
  fill: inherit;
  text-align: center;
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
  word-break: keep-all;
}
.spot_index:not(.index_masonry) .spot_block .spot_summary .spot_text {
  clear: both;
  font-size: 0.875em;
  text-align: justify;
  line-height: 1.75;
}
.spot_index:not(.index_masonry) .spot_block .more {
  display: block;
  position: absolute;
  bottom: 0;
  right: 0;
  margin: auto;
  color: inherit;
  fill: inherit;
  font-family: "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-size: 0.875em;
  text-decoration: underline;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.1em;
  text-indent: 0.1em;
}
@media screen and (max-width: 719px) {
  .spot_index:not(.index_masonry) {
    left: 50%;
    width: 100vw;
    transform: translate(-50%, 0);
  }
  .spot_index:not(.index_masonry) .spot_block {
    display: flex;
    padding: 0.5rem 0;
    border-color: #DFE1E3;
    border-style: solid;
    border-width: 0 0 thin;
  }
  .spot_index:not(.index_masonry) .spot_block:first-child {
    border-top-width: thin;
  }
  .spot_index:not(.index_masonry) .spot_block .spot_thumb {
    flex-shrink: 0;
    flex-grow: 0;
    width: 11.2rem;
  }
  .spot_index:not(.index_masonry) .spot_block .spot_summary {
    padding: 0.5rem 1em 1.5rem;
    text-align: center;
  }
  .spot_index:not(.index_masonry) .spot_block .more {
    position: absolute;
    bottom: 0;
    left: 11.2rem;
    right: 0;
    margin: 0.5rem auto;
    padding: 0.5em;
    text-align: center;
  }
}
@media (min-width:720px) {
  .spot_index:not(.index_masonry) {
    display: flex;
    flex-wrap: wrap;
  }
  .spot_index:not(.index_masonry) .spot_block {
    padding-top: 1rem;
    padding-bottom: 3em;
    width: 23.5%;
    width: 23.5%;
  }
  .spot_index:not(.index_masonry) .spot_block:nth-child(4n+5)::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: -5vw;
    width: 100vw;
    border-top: solid thin #DFE1E3;
  }
  .spot_index:not(.index_masonry) .spot_block:not(:nth-child(4n+0)) {
    margin-right: 2%;
  }
  .spot_index:not(.index_masonry) .spot_block .spot_summary .spot_name {
    text-align: center;
  }
  .spot_index:not(.index_masonry) .spot_block .spot_summary .spot_web {
    float: left;
  }
  .spot_index:not(.index_masonry) .spot_block .spot_summary .spot_fee {
    float: right;
  }
  .spot_index:not(.index_masonry) .spot_block .spot_summary .spot_text {
    clear: both;
  }
  .spot_index:not(.index_masonry) .spot_block .more {
    left: 0;
    margin-bottom: 1.5rem;
  }
}
@media (min-width: 1333px) {
  .spot_index:not(.index_masonry) .spot_block:nth-child(4n+1)::before {
    left: calc(-50vw + 600px);
  }
}
.spot_index.index_masonry::after {
  content: "";
  clear: both;
  display: block;
}
.spot_index.index_masonry .spot_block {
  display: block;
  float: left;
  margin-bottom: 0.5rem;
  color: inherit;
  fill: inherit;
  text-decoration: none;
}
.spot_index.index_masonry .spot_block .spot_thumb img {
  width: 100%;
}
.spot_index.index_masonry .spot_block .post_title {
  margin: auto;
  font-size: 1.125em;
}
@media screen and (max-width: 719px) {
  .spot_index.index_masonry {
    left: -2%;
    width: 104%;
  }
  .spot_index.index_masonry .spot_block {
    margin-right: 2%;
    margin-left: 2%;
    width: 46%;
    font-size: 0.75em;
  }
}
@media (min-width:720px) {
  .spot_index.index_masonry {
    left: -1%;
    width: 102%;
  }
  .spot_index.index_masonry .spot_block {
    margin-right: 1%;
    margin-left: 1%;
    width: 31.333%;
    width: 31.3333333333%;
  }
}

#spot_map {
  margin: 3rem auto;
}
#spot_map .sect_title {
  text-align: center;
}

.spot_single .main_head .spot_thumb {
  margin-bottom: 1.5rem;
  line-height: 1;
}
.spot_single .main_head .spot_title {
  font-size: 1.25em;
  line-height: 1.5;
}
.spot_single .main_head .spot_title .spot_type {
  display: inline-block;
  font-size: 0.625em;
}
.spot_single .main_head .spot_title .spot_name {
  display: inline-block;
  font-style: normal;
}
@media screen and (max-width: 719px) {
  .spot_single .main_head {
    padding-top: 0;
  }
  .spot_single .main_head .spot_thumb {
    left: 50%;
    width: 100vw;
    transform: translate(-50%, 0);
  }
  .spot_single .main_head .spot_thumb .slick-slider .slick-dots {
    font-size: 2em;
  }
  .spot_single .main_head .spot_thumb .slick-slider .slick-arrow {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 2rem;
    height: 2rem;
    line-height: 1;
  }
  .spot_single .main_head .spot_thumb .slick-slider .slick-arrow::before {
    font-size: 2rem;
  }
}
@media (min-width:720px) {
  .spot_single .main_head .spot_title {
    font-size: 1.875em;
  }
  .spot_single .main_head .spot_thumb .img_list::before {
    display: block;
    padding-top: 50%;
  }
  .spot_single .main_head .spot_thumb .img_list .img_main {
    margin: auto;
    width: 49%;
  }
  .spot_single .main_head .spot_thumb .img_list .img_sub {
    position: absolute;
    width: 23.5%;
  }
  .spot_single .main_head .spot_thumb .img_list .img_sub.sub01 {
    top: 0;
    left: 0;
  }
  .spot_single .main_head .spot_thumb .img_list .img_sub.sub02 {
    top: 0;
    right: 0;
  }
  .spot_single .main_head .spot_thumb .img_list .img_sub.sub03 {
    bottom: 0;
    left: 0;
  }
  .spot_single .main_head .spot_thumb .img_list .img_sub.sub04 {
    bottom: 0;
    right: 0;
  }
}
.spot_single .main_body > .narrow {
  max-width: 600px;
}
.spot_single .sect_block:not(:last-child) {
  margin-bottom: 3rem;
}
.spot_single .sect_block .sect_title {
  margin-bottom: 1.5rem;
  padding: 0.25em 0.5em;
  text-align: center;
  font-size: 1em;
}
@media (min-width:720px) {
  .spot_single .sect_block:not(:last-child) {
    margin-bottom: 4.5rem;
  }
}
.spot_single .info_list {
  display: table;
  width: 100%;
  max-width: 100%;
  font-size: 0.875em;
}
.spot_single .info_list > div {
  display: table-row;
}
.spot_single .info_list > div > dt,
.spot_single .info_list > div > dd {
  display: table-cell;
  line-height: 1.75;
}
.spot_single .info_list > div > dt {
  padding-right: 1em;
  width: 30%;
  white-space: nowrap;
  word-break: keep-all;
}
.spot_single .info_list > div:not(:first-child) > dt,
.spot_single .info_list > div:not(:first-child) > dd {
  padding-top: 0.5em;
}
.spot_single .info_list > div:not(:last-child) > dt,
.spot_single .info_list > div:not(:last-child) > dd {
  padding-bottom: 0.5em;
  border-bottom: solid thin #DFE1E3;
}
.spot_single .spot_text .block-list__layout h2 {
  font-size: 1.25em;
}
.spot_single .spot_text .block-list__layout h2:not([class*=has-text-align-]) {
  text-align: center;
}
@media (min-width:720px) {
  .spot_single .spot_text .block-list__layout {
    font-size: 1em;
  }
}
.spot_single .spot_relation {
  text-align: center;
}
.spot_single .spot_relation .link_list .link_btn {
  background-color: #FFFFFF;
}
.spot_single .spot_relation .link_list .link_btn.link_hotel::before, .spot_single .spot_relation .link_list .link_btn.link_oneday::before {
  background-image: url(../images/icn-link_onsen.svg);
}
.spot_single .spot_relation .link_list .link_btn.link_official {
  background-color: #000000;
  border-color: #000000;
  color: #FFFFFF;
  fill: #FFFFFF;
}
.spot_single .spot_relation .link_list .link_btn.link_official::before {
  background-image: url(../images/icn-link_blank-w.svg);
}
.spot_single .spot_relation .link_list .link_btn.link_document {
  background-color: #7434DB;
  border-color: transparent;
  background-image: linear-gradient(90deg, rgba(209, 255, 253, 0.5) 0%, rgba(252, 223, 232, 0.5) 100%);
  background-size: cover;
  background-repeat: no-repeat;
}
.spot_single .spot_relation .link_list .link_btn.link_document::before {
  background-image: url(../images/icn-link_blank-w.svg);
}
@media screen and (max-width: 719px) {
  .spot_single .spot_relation .link_list .link_btn:not(:last-child) {
    margin-bottom: 0.5rem;
  }
}
@media (min-width:720px) {
  .spot_single .spot_relation .link_list {
    display: flex;
    justify-content: center;
  }
  .spot_single .spot_relation .link_list .link_btn {
    min-width: 0;
    flex-basis: 13.375em;
  }
  .spot_single .spot_relation .link_list .link_btn:not(:last-child) {
    margin-right: 0.5rem;
  }
}
.spot_single .spot_relation .sns_list {
  list-style: none;
  margin-top: 3rem;
  padding: 0;
  width: 100%;
  font-size: 1.375em;
}
.spot_single .spot_relation .sns_list > li {
  display: inline-block;
}
.spot_single .spot_relation .sns_list > li:not(:last-child) {
  margin-right: 0.25em;
}
.spot_single .spot_information {
  color: #000000;
  fill: #000000;
}
.spot_single .spot_information .sect_title {
  background-color: #DFE1E3;
}
.spot_single .spot_cate {
  color: #000000;
  fill: #000000;
}
.spot_single .spot_address {
  color: #000000;
  fill: #000000;
  font-style: normal;
}
.spot_single .spot_address .spot_map {
  margin-bottom: 1rem;
  width: 100%;
}
.spot_single .spot_address .spot_map::before {
  content: "";
  display: block;
  padding-top: 56.25%;
}
.spot_single .spot_address .spot_map > iframe {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.spot_single .spot_address .address_list {
  display: table;
  margin: -0.5em 0;
  border-collapse: separate;
  border-spacing: 0 1em;
  width: 100%;
  font-size: 0.75em;
}
.spot_single .spot_address .address_list > div {
  display: table-row;
}
.spot_single .spot_address .address_list > div > dt,
.spot_single .spot_address .address_list > div > dd {
  display: table-cell;
}
.spot_single .spot_address .address_list > div > dt {
  padding-right: 0.5em;
  width: 30%;
  white-space: nowrap;
  word-break: keep-all;
}
.spot_single .spot_address .address_list > div > dd span {
  display: inline-block;
}
html[lang=ja] .spot_single .spot_address .address_list > div > dd span.postcode::before {
  content: "〒";
}
.spot_single .spot_gallery {
  margin: 0 auto;
  background-color: #000000;
}
.spot_single .spot_gallery::before {
  content: "";
  display: block;
  z-index: 0;
}
.spot_single .spot_gallery .photo_list {
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
}
.spot_single .spot_gallery .photo_list .photo_thumb {
  margin: 0;
}
.spot_single .spot_gallery .photo_list .photo_thumb:hover {
  opacity: 0.6;
}
@media screen and (max-width: 719px) {
  .spot_single .spot_gallery {
    margin-top: 3rem;
  }
  .spot_single .spot_gallery::before {
    padding-top: 133.333%;
    padding-top: 133.3333333333%;
  }
  .spot_single .spot_gallery .photo_list .photo_thumb {
    width: 33.333%;
    width: 33.3333333333%;
  }
  .spot_single .spot_gallery .photo_list .photo_thumb:nth-child(3n+0) {
    position: absolute;
    width: 66.666%;
    width: 66.6666666667%;
  }
  .spot_single .spot_gallery .photo_list .photo_thumb:nth-child(n+3) {
    margin-left: auto;
  }
  .spot_single .spot_gallery .photo_list .photo_thumb:nth-child(3) {
    top: 0;
    right: 0;
  }
  .spot_single .spot_gallery .photo_list .photo_thumb:nth-child(6) {
    bottom: 0;
    left: 0;
  }
}
@media (min-width:720px) {
  .spot_single .spot_gallery {
    margin-top: 4.5rem;
  }
  .spot_single .spot_gallery::before {
    padding-top: 33.333%;
    padding-top: 33.3333333333%;
  }
  .spot_single .spot_gallery .photo_list .photo_thumb {
    width: 16.666%;
    width: 16.6666666667%;
  }
  .spot_single .spot_gallery .photo_list .photo_thumb:nth-child(3n+0) {
    width: 33.333%;
    width: 33.3333333333%;
  }
}

.single .sub_block:has(.aside_block) {
  margin-top: 0;
}
@media screen and (max-width: 719px) {
  .single .aside_block > .inner {
    padding: 3rem 0;
  }
}
@media (min-width:720px) {
  .single .aside_block > .inner {
    padding: 4.5rem 0;
  }
}

.spot_map {
  clear: both;
  margin-top: 3rem;
}
@media (min-width:720px) {
  .spot_map {
    margin-top: 4.5rem;
  }
}

#calendar {
  background-color: #F6F8FA;
}
#calendar .sect_title {
  text-align: center;
}
@media screen and (max-width: 719px) {
  #calendar {
    margin-top: 3rem;
    padding: 3rem 0;
  }
  #calendar .sect_title {
    margin-bottom: 1.5rem;
  }
}
@media (min-width:720px) {
  #calendar {
    margin-top: 4.5rem;
    padding: 4.5rem 0;
  }
  #calendar .sect_title {
    margin-bottom: 3rem;
  }
}
#calendar .calendar_box {
  overflow-x: auto;
  width: 100%;
}
@media screen and (max-width: 719px) {
  #calendar .calendar_box {
    padding-bottom: 1em;
  }
}
#calendar .calendar_table {
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
}
#calendar .calendar_table .row_body col {
  width: 6%;
}
#calendar .calendar_table th,
#calendar .calendar_table td {
  border: dotted 0;
  line-height: 1;
}
#calendar .calendar_table thead th,
#calendar .calendar_table thead td {
  padding: 0;
}
#calendar .calendar_table tbody tr th,
#calendar .calendar_table tbody tr td {
  border-right-width: 1px;
  vertical-align: middle;
}
#calendar .calendar_table tbody tr th {
  padding: 0.25em;
  text-align: left;
}
#calendar .calendar_table tbody tr th a {
  display: inline-block;
  color: inherit;
  fill: inherit;
  text-decoration: none;
  line-height: 1.25;
}
#calendar .calendar_table tbody tr th a:hover {
  text-decoration: underline;
}
#calendar .calendar_table tbody tr td {
  padding: 0.25em 0;
  text-align: center;
}
#calendar .calendar_table .period {
  display: flex;
  width: 100%;
  height: 1em;
  font-size: 0.625em;
}
#calendar .calendar_table .period .check {
  display: block;
  width: 33.333%;
  width: 33.3333333333%;
  color: transparent;
  fill: transparent;
}
#calendar .calendar_table .period .check.check_on::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -1px;
  right: 0;
  background-color: #F0582B;
}
@media screen and (max-width: 719px) {
  #calendar .calendar_table {
    min-width: 40rem;
  }
  #calendar .calendar_table th {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    left: 0;
    z-index: 10;
  }
  #calendar .calendar_table thead th {
    background-color: #F6F8FA;
  }
  #calendar .calendar_table tbody th {
    background-image: linear-gradient(90deg, #f6f8fa 90%, rgba(246, 248, 250, 0) 100%);
  }
}
/*# sourceMappingURL=spot.css.map */