@charset "UTF-8";

body {
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI",
    "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic",
    Verdana, Meiryo, sans-serif;

  line-height: 1.5;
  text-rendering: optimizelegibility;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "palt";
  background: rgb(255, 255, 255);
  color: #151515;
  letter-spacing: 0.05em;
}
img {
  width: 100%;
  height: auto;
  max-width: 100%;
  -ms-interpolation-mode: bicubic;
}
body {
  opacity: 0;
  transition-duration: 400ms;
  transition-delay: 400ms;
}
body.onload {
  opacity: 1;
}
/* ========================================================================================================
HEADER
======================================================================================================== */

header {
  position: fixed;
  width: 100%;
  z-index: 990;
  background-color: #fff;
  /* border-bottom: solid 1px #999; */
}
header a {
  transition: all 0.2s ease;
}
header a:hover {
  opacity: 0.5;
}
header .header-wrap {
  /* padding: 10px 0px; */
  height: 70px;
  padding: 0px 40px;
  display: flex;
  justify-content: space-between;
  border-bottom: solid 1px #f5f5f5;
  /* box-shadow: 0 0 20px rgb(0 0 0 / 10%); */
}
.h-logo {
  fill: #151515;
  width: 80px;
  display: flex;
  align-items: center;
  padding: 10px 0px;
  /* height: 50px; */
  z-index: 992;
}
.site-logo {
  width: 100%;
  height: auto;
}
.h-menu {
  display: flex;
}
.h-menu .dropdown {
  position: fixed;
  background: #ffffff;
  left: 0;
  z-index: -1;
  opacity: 0;
  transition: all 0.25s ease;
  height: 0;
  overflow: hidden;
  width: 100vw;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: solid 1px #f5f5f5;
}

.h-menu .list-mune li.dropdown-nav:hover .dropdown {
  opacity: 1;
  height: 100px;
  overflow: auto;
  transition: all 0.25s ease;
}
.h-menu .dropdown-inner {
  display: inline-flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  padding: 30px 40px 10px;
}
.h-menu .spots .dropdown-inner {
}
.h-menu .spots .dropdown-inner li {
  width: auto;
  padding-bottom: 20px;
}
.h-menu .dropdown-inner li {
  width: 25%;
  padding-bottom: 15px;
}
.h-menu .dropdown-inner li a {
  font-size: 12px;
  padding-right: 30px;
}
body.en-US .h-menu .dropdown-inner li a {
  font-size: 10px;
}
.h-menu .dropdown.open .dropdown-inner {
}
.h-menu .wrap {
  display: flex;
}
.list-mune {
  display: flex;
  align-items: center;
}
.list-mune li {
  height: 100%;
  position: relative;
}
.list-mune li a {
  display: flex;
  flex-direction: column;
  font-weight: 700;
  justify-content: center;
  align-items: flex-start;
  font-size: 13px;
  line-height: 1.2;
  text-align: left;
  height: 100%;
  padding-right: 20px;
  color: #151515;
}
.list-mune li a span {
  font-size: 10px;
  color: #b1b1b1;
  line-height: 1.5;
}
.hakuba-logo {
  width: 65px;
  display: flex;
  align-items: center;
  margin-left: 20px;
}
.hakuba-logo a {
  display: block;
  line-height: 0;
}
.bogo-language-switcher {
  display: flex;
  align-items: center;
  margin-left: 30px;
  /* flex-direction: row-reverse; */
}
.bogo-language-switcher .en-US {
  order: 2;
}
.bogo-language-switcher .ja {
  order: 1;
  position: relative;
}
.bogo-language-switcher .ja span {
  padding-left: 0px;
}
.bogo-language-switcher .ja:before {
  content: "";
  background-color: #333;
  width: 2px;
  height: 100%;
  position: absolute;
  right: 0;
}

.bogoflags,
.bogoflags-before:before {
  display: none !important;
}
.bogo-language-name {
  font-size: 14px;
  font-weight: 600;
  padding: 0 10px;
  color: #cccccc;
}
.bogo-language-switcher a {
  font-weight: 700;
}
.bogo-language-switcher .current a {
  color: #111;
}
.translation a.active {
  color: #333333;
}

.nav-button {
  position: relative;
  display: flex;
  flex-direction: column;
  z-index: 992;
  justify-content: center;
  margin-left: 15px;
}
.nav-button p {
  color: #151515;
  font-size: 11px;
  font-weight: bold;
  margin-top: 4px;
  transition: all 0.2s ease;
}
.nav-button.active p {
  opacity: 0;
}
.nav-button .line {
  display: block;
  width: 36px;
  height: 18px;
  position: relative;
}

.nav-button,
.nav-button span {
}

.nav-button span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #151515;
  /* border-radius: 1px; */
  transition: all 0.3s ease;
}

.nav-button span:nth-of-type(1) {
  top: 0;
}

.nav-button span:nth-of-type(2) {
  top: calc(50% - 1px);
}

.nav-button span:nth-of-type(3) {
  bottom: 0;
}

body.open {
  overflow: hidden;
}

#full-nav {
  /* display: none; */
  /* background: #ffffff; */
  width: 100vw;
  height: 100vh;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  pointer-events: none;
  overflow: hidden;
  bottom: 0;
  z-index: 991;
  /* opacity: 0; */
  transition: 1000ms;
}
#full-nav .mask {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  background-color: #000;
  opacity: 0.5; /* display: none; */
  transition: all 0.7s ease;
  background-color: transparent;
}
#full-nav .full-nav-inner {
  height: auto;
  min-height: 100vh;
  width: 360px;
  background-color: #ffffff;
  position: relative;
  margin-left: auto;
  z-index: 1;
  transform: translateX(360px);
  opacity: 1;
  transition: all 0.7s ease;
  line-height: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#full-nav .full-nav-list-mune {
  padding: 40px 40px 80px;
  height: 100%;
}
#full-nav .full-nav-list-mune li {
  margin-bottom: 20px;
}
#full-nav .full-nav-list-mune .contact {
  margin-top: 40px;
}
#full-nav .full-nav-list-mune li:last-child {
}
#full-nav .full-nav-list-mune li a {
  display: flex;
  flex-direction: column;
  font-weight: 700;
  font-size: 14px;
  border-bottom: solid 1px #ddd;
  padding-bottom: 12px;
  color: #151515;
}
#full-nav .full-nav-list-mune li a span {
  font-size: 12px;
  color: #848484;
  line-height: 2;
}
#full-nav .full-nav-list-mune li.child-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#full-nav .full-nav-list-mune li.child-nav a {
  border: unset;
  padding-bottom: 0px;
}
#full-nav .full-nav-list-mune li.child-nav .child-inner {
  /* padding-left: 10px; */
  /* padding-top: 20px; */
}
#full-nav .full-nav-list-mune li.child-nav .child-inner li {
  margin-bottom: 0;
  border-bottom: solid 1px #ddd;
}
#full-nav .full-nav-list-mune li.child-nav .child-inner li a {
  font-size: 12px;
  padding: 18px 0px;
  padding-left: 15px;
  position: relative;
  display: block;
}
#full-nav .full-nav-list-mune li.child-nav .child-inner li a:before {
  content: "";
  width: 8px;
  height: 1px;
  background-color: #000;
  left: 0;
  position: absolute;
  top: 50%;
  top: calc(50% - 1px);
}
#full-nav .full-nav-list-mune li.child-nav .child-inner li a span {
  font-size: 12px;
  padding-top: 0;
  padding-left: 5px;
}
#full-nav .nav-button .line {
  width: 100%;
  height: 100%;
  /* padding: 0px; */
  margin-left: auto;
}
#full-nav .parts-flex {
  display: flex;
  align-items: center;
  padding: 20px 40px;
  justify-content: space-between;
}
#full-nav .parts-flex .bogo-language-switcher {
  margin-left: 0px;
}
#full-nav .nav-button {
  width: 30px;
  height: 30px;
  display: inline-block;
  transition: all 0.2s ease;
  margin-left: auto;
}
#full-nav a,
.acd-label .box {
  transition: all 0.2s ease;
}
#full-nav a:hover,
.acd-label .box:hover {
  opacity: 0.5;
}

#full-nav .contact a:hover {
  opacity: 1;
}
#full-nav .nav-button span {
}
#full-nav .nav-button span:nth-of-type(1) {
  transform: rotateZ(45deg);
  top: calc(50% - 1px);
}

#full-nav .nav-button span:nth-of-type(2) {
  transform: rotateZ(135deg);
}

.acd-check {
  display: none;
}
.acd-label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  border-bottom: solid 1px #ddd;
  padding-bottom: 16px;
}
.acd-label .box {
  width: 14px;
  height: 14px;
  position: relative;
  padding: 10px;
  cursor: pointer;
}
.acd-label .box span {
  background-color: #999;
  display: block;
  position: absolute;
  /* top: 50%; */
  transition: all 0.25s ease;
}

.acd-label .box span:nth-of-type(1) {
  height: 1px;
  width: 50%;
  top: calc(50% - 0px);
  /* top: 50%; */
  left: 25%;
}

.acd-label .box span:nth-of-type(2) {
  width: 1px;
  height: 50%;
  left: calc(50% - 1px);
  /* left: 50%; */
  top: 25%;
}
.acd-content {
  height: 0;
  opacity: 0;
  transition: 0.5s;
  visibility: hidden;
  width: 100%;
}
.acd-check:checked + .acd-label + .acd-content {
  height: 400px;
  opacity: 1;
  visibility: visible;
}
#acd-check2:checked + .acd-label + .acd-content {
  height: 190px;
}
#acd-check1:checked + .acd-label + .acd-content {
  height: 410px;
}
.acd-check:checked + .acd-label .box span:nth-of-type(2) {
  opacity: 0;
}

#full-nav.open {
  opacity: 1;
  overflow: auto;
  pointer-events: auto;
  transition: 1000ms;
  overflow-x: hidden;
}
#full-nav.open .full-nav-inner {
  transform: translateX(0px);
  /* opacity: 1; */
  transition: all 0.7s ease;
}
#full-nav.open .mask {
  transition: all 0.7s ease;
  background-color: #000;
}
#full-nav .sns-wrap {
  background-color: #222;
  bottom: 0;
  width: 100%;
}
#full-nav .sns-wrap .wrap {
  padding: 40px;
}
#full-nav .sns-wrap p {
  color: #fff;
  font-size: 14px;
  font-weight: 600;
}
#full-nav .sns {
  /* background-color: #111; */
  display: inline-flex;
  width: 100%;
  /* padding: 20px 40px; */
  align-items: center;
  justify-content: flex-start;
  margin-top: 5px;
}
#full-nav .sns li {
  width: 24px;
  height: 24px;
  position: relative;
  padding: 10px;
}
#full-nav .sns li a {
  height: 100%;
  width: 100%;
  /* position: absolute; */
  display: block;
}
#full-nav .sns li a img {
  height: 100%;
  width: 100%;
  fill: #fff;
}
/* ---HEADER-fin--- */

/* ========================================================================================================
top-fv-sec
======================================================================================================== */

#top-fv-sec {
}
#top-fv-sec .main-text {
  font-size: 7vw;
  color: #fff;
  /* position: absolute; */
  z-index: 2;
  line-height: 1.2;
  letter-spacing: 0.5vw;
  margin: auto;
  margin-left: 0;
  font-weight: bold;
  filter: drop-shadow(10px 10px 10px rgba(0, 0, 0, 0.1));
}
#top-fv-sec .main-text h1 {
}

#top-fv-sec .swiper-container {
  position: absolute;
  top: 0;
  z-index: 1;
  height: 100%;
  width: 100%;
  left: 0;
  right: 0;
}
#top-fv-sec .swiper-slide {
}
#top-fv-sec .swiper-slide .thumb {
  height: 100%;
  width: 100%;
  background-position: center;
  background-size: cover;
}
#top-fv-sec .element {
  z-index: 2;
  height: 100%;
}
#top-fv-sec .element .inner {
  padding: 40px;
  display: flex;
  height: calc(100% - 80px);
}

#top-fv-sec .fv-wrap {
  position: relative;
  min-height: 600px;
  height: calc(100vw * 9 / 16);
  overflow: hidden;
  /* padding-top: 70px; */
}
#top-fv-sec .scrolldown p {
  position: relative;
  top: calc(100% - 75.79px + 10px);
  font-size: 10px;
  font-weight: 900;
  color: #fff;
  text-align: end;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  line-height: 1;
}
#top-fv-sec .scrolldown {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 2;
  padding: 10px 10px 90px;
  height: 100px;
  top: 0;
  bottom: 0;
  margin: auto;
}
#top-fv-sec .scrolldown::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: calc(50% - 1px);
  width: 1px;
  height: 100px;
  background: #fff;
  animation: sdl 3s cubic-bezier(1, 0, 0, 1) infinite;
}
#top-fv-sec .scrolldown::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: calc(50% - 1px);
  width: 1px;
  height: 100px;
  background: rgba(255, 255, 255, 0.4);
}

@keyframes sdl {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}

/* ---top-fv fin--- */

/* ========================================================================================================
top-news-info-sec
======================================================================================================== */

#top-news-info-sec {
  position: absolute;
  bottom: 0;
  z-index: 10;
  width: 100%;
}
#top-news-info-sec .wrap {
  background-color: rgb(0 0 0 / 40%);
  background-color: rgba(0,0,0,0.4);
}
#top-news-info-sec .inner {
  /* padding: 15px 0; */
}
#top-news-info-sec .flex {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
#top-news-info-sec .inner a {
  width: 100%;
  /* width: calc(100% - 200px); */
  display: flex;
  justify-content: space-between;
  transition: all 0.2s ease;
  padding: 15px 0;
}
#top-news-info-sec .inner a:hover {
  opacity: 0.5;
}
#top-news-info-sec .inner a:hover svg {
  /* transform: translate(0px, 0px); */
}
#top-news-info-sec .info-tit {
  display: flex;
  align-items: center; /* width: 100%; */ /* width: calc(100% - 100px); */
}
#top-news-info-sec .flex p {
  display: inline-block;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 400;
  color: #fff;
}
#top-news-info-sec .flex span {
  height: 16px;
  width: 1px;
  background-color: #fff;
  display: inline-block;
  opacity: 0.5;
}
#top-news-info-sec .flex p.tit {
  margin-right: 20px;
  color: #fff;
}
#top-news-info-sec .flex p.text {
  margin-left: 20px;
  /* white-space: nowrap; */
  height: 16px;
  text-overflow: ellipsis;
  width: calc(100% - 100px);
  -webkit-line-clamp: 1;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  font-weight: 400;
}
#top-news-info-sec .flex svg {
  width: 50px;
  height: 12px;
  fill: #fff;
  /* transition: all 0.25s ease; */
  /* transform: translateX(-30px); */
}

/* ---top-news_info fin--- */

/* ========================================================================================================
top-about-sec
======================================================================================================== */

#top-about-sec {
  background-color: #ffffff;
}
#top-about-sec .wrap {
  position: relative;
}
#top-about-sec .inner {
  padding: 120px 0px 120px;
  position: relative;
  z-index: 1;
  padding-bottom: 160px;
}

#top-about-sec .text-area p {
  font-size: 18px;
  line-height: 2.5;
  font-weight: bold;
  margin-bottom: 35px;
  color: #151515;
  letter-spacing: 0.08em;
}
#top-about-sec .text-area p:last-child {
  margin-bottom: 60px;
}
#top-about-sec .l-btn a {
  max-width: 360px;
}

/* ---top-news_info fin--- */

/* ========================================================================================================
top-mv-sec
======================================================================================================== */

#top-mv-sec {
}
#top-mv-sec .wrap {
  height: 40vw;
  position: relative;
  overflow: hidden;
}
#top-mv-sec .inner {
  height: 100%;
  width: 100%;
  position: relative;
}
#top-mv-sec .wrap iframe {
}
#top-mv-sec .iframe-wrap {
  position: relative;
  padding-bottom: 62.5%;
  bottom: 0;
  top: -30%;
  margin: auto;
  /* height: 100%; */
  width: 100%;
  /* z-index: -999; */
}
#top-mv-sec .wrap iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0%;
}

/* ---top-mv-sec fin--- */

/* ========================================================================================================
top-route-sec
======================================================================================================== */

#top-route-sec {
  background-color: #fff;
}
#top-route-sec .wrap {
}
#top-route-sec .inner {position: relative;/* padding: 60px 40px; */}
#top-route-sec .swiper-slide {
  opacity: 0.6;
  position: relative;
  transition: all 0.2s ease;
}
#top-route-sec .swiper-slide a {
  transition: all 0.2s ease;
  display: block;
}
#top-route-sec .swiper-slide a:hover .thumb {
}
#top-route-sec .swiper-slide .thumb-wrap {
  position: relative;
  padding-bottom: 150%;
  z-index: 0;
}
#top-route-sec .swiper-slide .thumb {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition: all 0.2s ease;
  z-index: 0;
}
#top-route-sec .swiper-slide .box {
  position: relative;
  z-index: 2;
  background-color: #ffffff;
  width: calc(100% - 30px);
  right: 0;
  left: 0;
  margin: auto;
  margin-top: -40px;
  opacity: 0;
  transition: all 0.2s ease;
}
#top-route-sec .swiper-slide .box .box-inner {
  padding: 20px;
}
#top-route-sec .swiper-slide .box .route-tit {
  font-size: 18px;
  line-height: 1;
  margin-bottom: 15px;
  color: #151515;
  letter-spacing: 0.08em;
}
#top-route-sec .swiper-slide .box p {
  font-size: 13px;
  /* color: #333; */
  font-weight: 400;
  line-height: 1.8;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  height: 70px;
  margin-bottom: 10px;
}
#top-route-sec .swiper-slide .box .rout-level {
}
#top-route-sec .swiper-slide.swiper-slide-prev,
#top-route-sec .swiper-slide.swiper-slide-active,
#top-route-sec .swiper-slide.swiper-slide-next {
  opacity: 1; /* transition-duration: 300ms; */
}
#top-route-sec .swiper-slide.swiper-slide-prev .box,
#top-route-sec .swiper-slide.swiper-slide-active .box,
#top-route-sec .swiper-slide.swiper-slide-next .box {
  opacity: 1;
}
#top-route-sec .swiper-pagination {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  /* flex-wrap: wrap; */
}
#top-route-sec .swiper-pagination-bullet {
  width: 12%;
  height: auto;
  border-radius: unset;
  background: unset;
  font-size: 12px;
  font-weight: 600;
  opacity: 0.3;
  transition: all 0.2s ease;
  margin-bottom: 10px;
  padding-right: 10px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  height: 12px;
  line-height: 1.2;
}
#top-route-sec .swiper-pagination-bullet:hover {
  opacity: 1;
}
#top-route-sec .swiper-pagination-bullet-active {
  color: #151515;
  opacity: 1;
}
#top-route-sec .swiper-pagination span:nth-child(1)::before {
  content: "絶景スポット巡り";
}
#top-route-sec .swiper-pagination span:nth-child(2)::before {
  content: "白馬見どころ巡り";
}
#top-route-sec .swiper-pagination span:nth-child(3)::before {
  content: "白馬・八方ポタリング";
}
#top-route-sec .swiper-pagination span:nth-child(4)::before {
  content: "姫川周辺散策";
}
#top-route-sec .swiper-pagination span:nth-child(5)::before {
  content: "歴史感じる散輪ルート";
}
#top-route-sec .swiper-pagination span:nth-child(6)::before {
  content: "里山風景と仁科三湖";
}
#top-route-sec .swiper-pagination span:nth-child(7)::before {
  content: "仁科三湖と小熊黒沢林道";
}
#top-route-sec .swiper-pagination span:nth-child(8)::before {
  content: "絶景！黒菱林道";
}

body.en-US #top-route-sec .swiper-pagination span:nth-child(1)::before {
  content: "SUPERB VIEW CYCLING ROUTE";
}
body.en-US #top-route-sec .swiper-pagination span:nth-child(2)::before {
  content: "HAKUBA’S BEST SCENIC SPOTS ROUTE";
}
body.en-US #top-route-sec .swiper-pagination span:nth-child(3)::before {
  content: "SCENIC SHORT CYCLING ROUTE";
}
body.en-US #top-route-sec .swiper-pagination span:nth-child(4)::before {
  content: "RURAL SCENE ALONG THE HIME RIVER";
}
body.en-US #top-route-sec .swiper-pagination span:nth-child(5)::before {
  content: "TSUGAIKE SCENIC ROUTE WITH VARIUS BLOOM";
}
body.en-US #top-route-sec .swiper-pagination span:nth-child(6)::before {
  content: "VILLAGE FOREST AND NISHINA THREE LAKES";
}
body.en-US #top-route-sec .swiper-pagination span:nth-child(7)::before {
  content: "NISHINA THREE LAKES AND MT.KOGUMA HILL CLIMB";
}
body.en-US #top-route-sec .swiper-pagination span:nth-child(8)::before {
  content: "GLORIOUS SCENE KUROBISHI HILL CLIMB";
}
/* ---top-fin--- */

#top-route-sec .swiper-button-next,
#top-route-sec .swiper-button-prev {
  position: absolute;
  z-index: 10;
  cursor: pointer;
  width: 40px;
  top: calc(50% - 70px);
  opacity: 0.6;
  height: 40px;
  background-color: #fff;
  border-radius: 100%;
}
#top-route-sec .swiper-button-next:hover,
#top-route-sec .swiper-button-prev:hover {
  opacity: 1;
}

#top-route-sec .swiper-button-next img,
#top-route-sec .swiper-button-prev img {
  width: 10px;
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
#top-route-sec .swiper-button-next {
  right: 20px;
}
#top-route-sec .swiper-button-prev {
  left: 20px;
  transform: scale(-1, 1);
}
#top-route-sec .swiper-area {
  margin-bottom: 30px;
}
#top-route-sec .swiper-container {
  padding-bottom: 40px;
}
#top-route-sec .recommended {
}
#top-route-sec .recommended .flex {
  display: flex;
  align-items: flex-start;
}
#top-route-sec .recommended .flex h2 {
  font-size: 24px;
  line-height: 1;
  margin-bottom: 10px;
  font-weight: bold;
}
#top-route-sec .recommended .flex .img-area {
  width: 50%;
}
#top-route-sec .recommended .flex .text-area {
  width: 50%;
  padding-left: 3.552%;
}
#top-route-sec .recommended .flex h5 {
  font-size: 14px;
  line-height: 1;
  margin-bottom: 20px;
}
#top-route-sec .recommended .flex .excerpt {
  font-size: 14px;
  line-height: 2;
  margin-bottom: 20px;
  font-weight: 400;
}
#top-route-sec .recommended .flex .link {
}
#top-route-sec .recommended .flex .link a {
  font-size: 12px;
  margin-right: 10px;
  text-decoration: underline;
  font-weight: 600;
  color: #666;
  transition: all 0.2s ease;
}
#top-route-sec .recommended .flex .link a:hover {
  opacity: 0.5;
}
#top-route-sec .recommended .l-btn {
  margin-bottom: 20px;
}
#top-route-sec .c-btn {
  margin-bottom: 120px;
}

/* ---top-route-sec fin--- */

/* ========================================================================================================
top-spots-tit-sec
======================================================================================================== */

#top-spots-tit-sec .inner {
  padding: 140px 0px;
  z-index: 1;
  position: relative;
}

/* ---top-spots-tit-sec fin--- */

/* ========================================================================================================
top-spots-tit-sec
======================================================================================================== */

#top-spots-sec {
  background-color: #fff;
}

#top-spots-sec .swiper-container {
  /* padding-right: 0px; */
  padding-top: 20px;
}
#top-spots-sec .swiper-slide .thumb-wrap {
  position: relative;
  padding-bottom: 66.666%;
}
#top-spots-sec .swiper-slide a {
  display: block;
}

#top-spots-sec .swiper-slide .box {
  padding-bottom: 10px;
}
#top-spots-sec .swiper-slide .box p {
  font-size: 12px;
  /* font-style: italic; */
  line-height: 1.5;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  height: 16px;
  margin-top: 15px;
  color: #666;
}
#top-spots-sec .swiper-button-next,
#top-spots-sec .swiper-button-prev {
  position: absolute;
  z-index: 10;
  cursor: pointer;
  width: 40px;
  top: calc(50% - 30px);
  height: 40px;
  background-color: #fff;
  border-radius: 100%;
  opacity: 0.6;
  transition-duration: 300ms;
}
#top-spots-sec .swiper-button-next:hover,
#top-spots-sec .swiper-button-prev:hover {
}
#top-spots-sec .swiper-button-next:hover,
#top-spots-sec .swiper-button-prev:hover {
  opacity: 1;
}
#top-spots-sec .swiper-button-next img,
#top-spots-sec .swiper-button-prev img {
  width: 10px;
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
#top-spots-sec .swiper-button-disabled {
  opacity: 0;
}
#top-spots-sec .swiper-button-next {
  right: 20px;
}
#top-spots-sec .swiper-button-prev {
  left: 20px;
  transform: scale(-1, 1);
}
#top-spots-sec .element {
  margin-bottom: 100px;
}
#top-spots-sec .element:last-child {
  margin-bottom: 0px;
}
#top-spots-sec .element .excerpt {
  margin-top: 20px;
}
#top-spots-sec .element .excerpt .flex {
  display: flex;
  align-items: flex-start;
}
#top-spots-sec .element .excerpt .flex .text-area {
  width: calc(100% - 280px);
  padding-right: 40px;
}
#top-spots-sec .element .excerpt .flex .text-area p {
  font-size: 14px;
  line-height: 1.8;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  height: 50px;
  font-weight: 400;
}
#top-spots-sec .element .excerpt .flex .l-btn {
  width: 280px;
}

/* ---top-spots-sec fin--- */

/* ========================================================================================================
top-rental-sec
======================================================================================================== */

#top-rental-sec .inner {
  position: relative;
  z-index: 1;
  padding: 140px 0px;
}

#top-rental-sec .common-tit01 .tit-area {
}
#top-rental-sec .common-tit01 .tit-area h2,
#top-rental-sec .common-tit01 .tit-area h5 {
  color: #fff;
}
#top-rental-sec .common-tit01 .text-area {
  margin-bottom: 40px;
  width: 100%;
}
#top-rental-sec .common-tit01 .text-area p {
  overflow: unset;
  display: block;
  color: #fff;
  height: auto;
  /* font-weight: 600; */
  letter-spacing: 0.05em;
  line-height: 1.8;
}

#top-rental-sec .bg-position {
}

/* ---top-rental-sec fin--- */

/* ========================================================================================================
top-rental-sec
======================================================================================================== */

#top-wear-acc-sec {
}
#top-wear-acc-sec .wrap {
  display: flex;
  position: relative;
  /* background-color: #000; */
}
#top-wear-acc-sec .box {
  position: relative;
  width: 50%;
}
#top-wear-acc-sec .box .box-inner {
  position: relative;
  z-index: 1;
  padding-top: 15%;
  padding-bottom: 15%;
}

#top-wear-acc-sec .bg-position {
  opacity: 1;
}

/* ---top-rental-sec fin--- */

/* ========================================================================================================
attention-sec
======================================================================================================== */

#attention-sec {
  background-color: #fff;
}
#attention-sec .wrap {
  position: relative;
  z-index: 1;
}
#attention-sec .inner {
  position: relative;
  /* background-color: #000; */
}
#attention-sec .common-tit03 {
  position: relative;
  z-index: 1;
  padding: 100px 0px;
}
#attention-sec .bg-position {
  opacity: 1;
}
#attention-sec .common-h-inner {
  padding-top: 100px;
  padding-bottom: 100px;
}

/* ---attention-sec fin--- */

/* ========================================================================================================
top-info-sec
======================================================================================================== */

#top-info-sec {
  background-color: #fff;
}
#top-info-sec .wrap {
}

#top-info-sec .common-unit-three li:nth-child(n + 4) {
  margin-bottom: 0;
}
/* ---top-info-sec fin--- */

/* ========================================================================================================
top-link-sec
======================================================================================================== */
#top-link-sec {
  background-color: #fff;
}
#top-link-sec .common-h-inner {
  padding-top: 100px;
  padding-bottom: 100px;
}
#top-link-sec ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#top-link-sec ul li {
  width: calc(25% - 15px);
  margin-bottom: 20px;
}
#top-link-sec ul li a {
  display: block;
  line-height: 0;
  transition: all 0.2s ease;
}
#top-link-sec ul li .shadow:hover {
  /* box-shadow: 0 0 20px rgb(0 0 0 / 30%); */
  opacity: 0.6;
}
#top-link-sec ul li .box {
}
#top-link-sec ul li:nth-child(n + 5) {
  margin-bottom: 0px;
}
#top-link-sec ul::after {
  display: block;
  content: "";
  width: calc(50% - 10px);
}

/* ---top-link-sec fin--- */

/* ========================================================================================================
footer
======================================================================================================== */

footer {
  background-color: #222;
  color: #fff;
}
footer .common-w-inner {
  padding: 0 40px;
}
footer .wrap {
  padding: 120px 0px 8px 0px;
}
footer .elemnt01 {
  margin-bottom: 60px;
  border-bottom: solid 1px #fff;
}
footer .elemnt01 a {
  color: #fff;
}
footer .elemnt01 .list-mune li {
  padding-bottom: 20px;
}
footer .elemnt01 .list-mune li:nth-child(1) {
  margin-left: 0px;
}

footer .elemnt02 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 60px;
  flex-wrap: wrap;
}
footer .h-logo {
  fill: #fff;
}
footer .elemnt02 .list {
  margin-bottom: 20px;
  display: flex;
  flex-wrap: wrap;
}

footer .elemnt02 ul {
  display: flex;
  align-items: center;
  margin-right: 20px;
  margin-bottom: 10px;
}

footer .elemnt02 ul li {
  width: 70px;
  margin-right: 20px;
}

footer .elemnt02 ul li a {
  width: 100%;
}

footer .elemnt02 ul.sns {
  margin-left: 0px;
}

footer .elemnt02 ul.sns li {
  height: 25px;
  width: 25px;
  margin-left: 0px;
}
footer .elemnt02 .l-btn {
  margin-bottom: 30px;
}
footer .elemnt02 .l-btn a {
  min-width: 200px;
}
footer .elemnt02 .l-btn a:hover {
  opacity: 1;
  background-color: #fff;
  color: #151515;
}
footer .elemnt02 .l-btn a:hover svg {
  fill: #151515;
}
footer .elemnt02 .l-btn a svg {
  fill: #fff;
}
footer .list-mune {
  flex-wrap: wrap;
}

footer .elemnt02 ul.sns li a {
  display: block;
  position: relative;
  height: 100%;
  width: 100%;
}

footer .elemnt02 ul.sns li img {
  position: absolute;
  width: 100%;
  height: 100%;
  fill: #fff;
}
footer .elemnt03 {
}
footer .elemnt03 p {
  font-size: 12px;
  margin-bottom: 5px;
  line-height: 1.5;
}
footer .elemnt03 p.copylight {
  margin-bottom: 0px;
  margin-top: 20px;
  font-size: 10px;
}
footer a {
  transition: all 0.2s ease;
}
footer a:hover {
  opacity: 0.5;
}

/* ========================================================================================================
===========================================================================================================

page

===========================================================================================================
======================================================================================================== */

/* ========================================================================================================
top-fv-sec
======================================================================================================== */

.archive-page {
  background-color: #f9f9f9;
}
#page-fv-sec {
  background-color: #000;
}
#page-fv-sec .common-tit01 .tit-area h5 {
  margin-bottom: 20px;
}
#page-fv-sec .common-tit01 .tit-area p {
  font-size: 14px;
  line-height: 1.8;
}
#page-fv-sec .wrap {
  position: relative;
}
#page-fv-sec .bg-position {
  /* height: 56.353%; */
  opacity: 0.8;
}
#page-fv-sec .inner {
  position: relative;
  z-index: 1;
  padding: 160px 0px 220px;
}
#page-fv-sec .common-tit02 {
}
.shift-sec .common-h-inner {
  padding-top: 0px;
}
#page-fv-sec .common-tit02 .tit-area {
  display: block;
  color: #fff;
  margin-bottom: 0;
}
#page-fv-sec .common-tit02 .tit-area h2 {
  margin-bottom: 20px;
  font-size: 40px;
}
#page-fv-sec .common-tit02 .tit-area h5 {
  padding-left: 0;
  margin-bottom: 30px;
}
#page-fv-sec .common-tit02 .tit-area p {
  font-size: 16px;
  font-weight: 600;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
.shift-sec {
  margin-top: -140px;
  position: relative;
  z-index: 2;
}

#map-sec {
  background-color: #fff;
}

#map-sec .common-tit02 .tit-area h2 {
}
#map-sec .common-tit02 .tit-area h5 {
}
#map-sec .hot {
  margin-bottom: 60px;
}
#map-sec .hot .text {
  font-size: 14px;
  line-height: 1.8;
  margin: 20px 0px;
}
/* ========================================================================================================
page-route-top
======================================================================================================== */

.page-route-top .common-unit-two li .tag {
  margin-bottom: 30px;
}

.archive-route #map-sec .route-level {
  font-size: 12px;
  text-align: center;
  margin-top: 10px;
  padding: 7px 15px;
  display: block;
}
.archive-route #map-sec .flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 10px;
}
.archive-route #map-sec .flex a {
  width: 24%;
}
/* ========================================================================================================
spots-top-sec
======================================================================================================== */
.page-spots-top .common-unit-three li .text-area {
  padding: 20px;
}
.page-spots-top .c-btn {
  margin-top: 40px;
}
.page-spots-top .c-btn a {
  /* width: 33.333%; */
  background-color: #fff;
  border: unset;
}
/* ========================================================================================================
page-single-route
======================================================================================================== */
.page-single-route {
}
.page-single-route #attention-sec .common-h-inner {
  padding-top: 0;
}
.page-single-route .route-level {
  /* font-size: 12px; */
}
.single-route .swiper-area .common-thumb-wrap {
  padding-bottom: 56.25%;
}
.page-single-route #page-fv-sec .common-tit02 .tit-area p {
  font-weight: 600;
  margin-bottom: 40px;
  font-size: 16px;
}
.page-single-route .slider4 {
  margin-bottom: 10px;
}

.page-single-route .swiper-area {
  margin-bottom: 60px;
}
.page-single-route .description {
}
.page-single-route .description p {
  font-size: 14px;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
.page-single-route .map-wrap {
  margin-bottom: 30px;
}
.page-single-route .date {
}
.page-single-route .date .icon-wrap {
  margin-bottom: 10px;
}
.page-single-route .date .icon-wrap ul {
  display: flex;
  flex-wrap: wrap;
}
.page-single-route .date .directions {
  width: 100%;
  margin: 40px auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.page-single-route .date .directions .flex {
  width: 50%;
  /* padding-left: 40px; */
  width: calc(50% - 20px);
}
.page-single-route .date .btn-area {
  display: flex;
  justify-content: space-between;
}
.page-single-route .date .btn-area .l-btn {
  width: 50%;
  width: calc(50% - 20px);
}
.page-single-route .date .directions .img-area {
  width: 50%;
  width: calc(50% - 20px);
}

.page-single-route .date .icon-wrap ul li {
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  width: 33%;
  margin-bottom: 10px;
}
.page-single-route .date .icon-wrap .icon {
  position: relative;
  display: inline-block;
  padding: 8px;
  border-radius: 8px;
  margin-right: 10px;
}
.page-single-route .date .icon .img-wrap {
  position: relative;
  width: 15px;
  height: 15px;
}
.page-single-route .date .icon img {
  position: absolute;
  width: 100%;
  height: 100%;
}

.page-single-route .date span.icon01 {
  background-color: rgb(230 81 0);
}
.page-single-route .date span.icon02 {
  background-color: rgb(249 168 37);
}
.page-single-route .date span.icon03 {
  background-color: rgb(255 214 0);
}
.page-single-route .date span.icon04 {
  background-color: rgb(1 87 155);
}
.page-single-route .date span.icon05 {
  background-color: rgb(124 179 66);
}
.page-single-route .date span.icon06 {
  background-color: rgb(117 117 117);
}
.page-single-route .date span.icon07 {
  background-color: #253f58;
}
.page-single-route .date span.icon08 {
  background-color: #333333;
}
.page-single-route #map-sec {
  background-color: #fbfbfb;
}
.page-single-route .date .details-wrap,
.archive-route .details-wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
.page-single-route .date .details-wrap {
  /* margin-bottom: 40px; */
}
.page-single-route .date .details-wrap .details,
.archive-route .details {
  font-size: 14px;
  display: flex;
  flex-wrap: wrap;
}
.page-single-route .date .details-wrap .details li,
.archive-route .details li {
  margin-right: 20px;
  color: #111;
  font-size: 12px;
}
.page-single-route .date .details-wrap .details li {
  margin-bottom: 10px;
}
.page-single-route .date .details-wrap .details span,
.archive-route .details span {
  font-weight: 500;
}
.page-single-route .date .details-wrap .l-btn {
}
.page-single-route .date .details-wrap .l-btn a {
}

.page-single-route #spots-tit-sec {background-color: #000;}

.page-single-route #spots-tit-sec .wrap {
  position: relative;
}

.page-single-route #spots-tit-sec.bg-sec .bg-position {
  opacity: 0.5;
}
.page-single-route #spots-cat-sec {
}
.page-single-route #spots-cat-sec .common-h-inner {
  padding-top: 0px;
}

.page-single-route #spots-cat-sec .common-tit02 h5,
#spots-support-sec .common-tit02 h5,
.page-single-route .common-tit02 .tit-area h5 {
  font-size: 16px;
}

.page-single-route #spots-cat-sec .element .common-tit02 .tit-area {
  margin-bottom: 0px;
}

.page-single-route #spots-cat-sec .element.rental {
  margin-bottom: 0px;
}
.page-single-route #spots-cat-sec .element.rental .common-tit01 h2 {
}
.page-single-route #spots-cat-sec .element.rental .common-tit01 h5 {
}

.page-single-route #spots-recommended-sec.shift-sec {
  margin-top: -200px;
  margin-bottom: 40px;
}

#route-banner-sec {
}

.page-single-route
  #spots-recommended-sec
  .common-unit-two
  .common-box
  .excerpt {
  font-size: 13px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  height: 47px;
  font-weight: 400;
}

#route-banner-sec .text-area {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  z-index: 3;
  top: 0;
  padding: 0;
}
#route-banner-sec .text-area h3 {
  color: #fff;
}
#route-banner-sec .box {
  position: relative;
}
#route-banner-sec .common-thumb-wrap {
  background-color: #000;
  padding-bottom: 56.25%;
}
#route-banner-sec .common-thumb-wrap .thumb {
  opacity: 0.7;
}
#spots-support-sec {
  background-color: #ececec;
}

#spots-support-sec .element.support-sec {
  margin-bottom: 40px;
}
.archive-support #spots-support-sec .element.support-sec {
  margin-bottom: 80px;
}
#spots-support-sec .common-tit02 {
}

.page-single-route .map-anker {
  position: fixed;
  bottom: 0;
  right: 0;
  background-color: #000;
  z-index: 10;
  display: block;
}
.page-single-route .map-anker a {
  display: flex;
  color: #fff;
  width: 100%; /* flex-wrap: wrap; */
  padding: 20px;
  align-items: center;
}
.page-single-route .map-anker a img {
  width: 15px;
  margin-right: 15px;
}
.page-single-route .map-anker a svg {
  fill: #fff;
  width: 40px;
  position: relative;
  top: -2px;
  height: 5px;
}

.page-single-route .map-sec .common-tit01 {
}
.page-single-route .map-sec .common-tit01 h2 {
  font-size: 36px;
}
.page-single-route .map-sec .common-tit01 h5 {
}
.page-single-route .map-anker p {
  margin-right: 15px;
  font-size: 12px;
  font-weight: 600;
}

.common-unit-two .support-list {
}
.common-unit-two .support-list li {
  background-color: unset;
  border-bottom: solid 1px;
  border-top: solid 1px;
  border-color: #999999;
}
.common-unit-two .support-list .text-area {
  padding: 20px 0px;
}
.common-unit-two .support-list .text-area .tit {
  font-size: 14px;
}
.support-menu {
}
.rental-support-list {
}
.rental-support-list.common-unit-two .common-box:nth-child(-n + 2) {
  border-top: solid 1px;
}
.rental-support-list.common-unit-two .common-box {
  background-color: unset; /* border-top: solid 1px; */
  border-bottom: solid 1px;
  border-color: #999;
  margin-bottom: 0px;
}
.rental-support-list.common-unit-two .common-box .text-area {
  padding: 30px 0px;
}
.rental-support-list.common-unit-two .common-box h3 {
  font-size: 13px;
}

.check-wrap {
  display: flex; /* margin-top: 10px; */
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.check-wrap .check {
  font-size: 10px;
  background-color: #e4e4e4;
  padding: 8px;
  border-radius: 5px;
  margin-right: 5px;
  margin-bottom: 5px;
  color: #333;
}
.archive-rental .check-wrap {
  margin-bottom: 0px;
}
.rental-support-list li .other a {
  font-size: 12px;
  text-decoration: underline;
  margin-right: 5px;
  width: 100vw;
  -webkit-transition: all 0.25s ease;
  transition: all 0.25s ease;
}
.rental-support-list li .other a:hover {
  opacity: 0.5;
}
.rental-support-list li .other {
  margin-top: 10px;
}

.archive-support #page-fv-sec .inner {
  padding: 120px 0px;
}

/* ========================================================================================================
===========================================================================================================

single

===========================================================================================================
======================================================================================================== */

.page-single-custom {
}
.page-single-custom #fv-sec {
}
.page-single-custom #fv-sec .inner,
.page-single02 #fv-sec .inner {
  padding: 150px 0px 0px;
}

.page-single-custom #fv-sec .flex {
  display: flex;
  align-items: center;
}
.page-single-custom #fv-sec .common-tit02 {
  width: 50%;
  padding-left: 40px;
  margin-bottom: 0px;
}
.page-single-custom #fv-sec .common-tit02 .tit-area {
  display: block;
  margin-bottom: 0px;
}
.page-single-custom #fv-sec .common-tit02 .tit-area h2 {
  font-size: 24px;
  margin-bottom: 20px;
}

.page-single-custom #fv-sec .common-tit02 .tit-area p {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 20px;
  pointer-events: none;
}
.tag span {
  margin-right: 15px;
  font-size: 12px;
  color: #666;
}

.page-single-custom #fv-sec .img-area {
  width: 50%;
}

.page-single-custom #info-sec .map-wrap {
}
.page-single-custom #info-sec .common-table {
}
.page-single-custom #info-sec .common-table .check-wrap {
  margin-top: 0px;
  margin-bottom: 0px;
}
.page-single-custom #info-sec .common-table .check-wrap .check {
  margin-top: 0px;
}
.page-single-custom #related-sec {
}
.page-single-custom #related-sec .wrap {
  background-color: #f9f9f9;
}
.page-single-custom #related-sec .common-unit-three li {
  margin-bottom: 0px;
}

.page-single-custom .map-area {
  margin-bottom: 60px;
}
.page-single-custom .info-table {
  margin-bottom: 60px;
}
.page-single-custom .common-h-inner {
  padding-top: 100px;
  padding-bottom: 100px;
}
.page-single-custom .common-tit02 {
  margin-bottom: 20px;
}
.page-single-custom .common-tit02 .tit-area h2 {
  font-size: 22px;
}
.page-single-custom .common-tit02 .tit-area h5 {
  font-size: 16px;
}

.page-single-custom .related-area {
}
.page-single-custom .common-tit02 .tit-area {
  margin-bottom: 20px;
}
.page-single-custom .related-area .common-box .text-area {
  padding: 20px;
  position: absolute;
  top: 0;
  z-index: 2;
  right: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #fff;
}
.page-single-custom .related-area .common-thumb-wrap {
  position: relative;
  z-index: 1;
  background-color: #000;
}
.page-single-custom .related-area .common-thumb-wrap .thumb {
  opacity: 0.7;
}
.page-single-custom .related-area .common-box .tit {
  font-size: 16px;
  margin-bottom: 10px;
}

#single-article .wrap {
  padding: 0px;
}
#single-article .common-w-inner {
  max-width: 768px;
  margin: 0 auto;
  padding-top: 80px;
  padding-bottom: 80px;
}
#single-article .meta-area {
  margin-bottom: 40px;
}
#single-article .meta-area .breadcrumbs {
  padding: 0 0 30px;
  font-size: 8px;
  line-height: 1;
  width: 100%;
  height: auto;
  overflow-x: scroll;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  white-space: nowrap;
  margin-bottom: -10px;
  -webkit-tap-highlight-color: transparent;
  transform: translate3d(0, 0, 0);
}
#single-article .meta-area .breadcrumbs-box {
  margin-bottom: 20px;
}
#single-article .meta-area .breadcrumbs-wrap {
  height: 12px;
  overflow-y: hidden;
  margin: 0;
}
#single-article .meta-area .breadcrumbs,
#single-article .meta-area .breadcrumbs a {
  font-size: 11px;
  transition-duration: 300ms;
  color: rgb(0 0 0 / 70%);
  line-height: 1;
}

#single-article .meta-area .breadcrumbs a:hover {
  opacity: 0.6;
}
#single-article .meta-area .date {
  font-size: 12px;
  font-weight: bold;
  margin-bottom: 10px;
  color: rgb(0 0 0 / 50%);
}
#single-article .meta-area .tit {
  font-size: 24px;
  line-height: 1.5;
  margin-bottom: 40px;
  word-break: break-all;
}
#single-article .article-body-wrap {
}
#single-article .article-body-wrap p {
  font-size: 15px;
  margin-bottom: 40px;
  line-height: 2;
  word-break: break-all;
  letter-spacing: 0.05em;
  /* font-size: 16px; */
}
#single-article .article-body-wrap a {
}
#single-article .article-body-wrap p a {
  font-weight: bold;
  text-decoration: underline;
  transition-duration: 300ms;
}
#single-article .article-body-wrap a:hover,
#single-article .article-body-wrap p a:hover {
  opacity: 0.6;
}
#single-article .article-body-wrap strong {
}
#single-article .article-body-wrap h3 {
  margin: 80px 0px 30px;
  font-size: 22px;
  line-height: 1.5;
}
#single-article .article-body-wrap .caption {
  font-size: 11px;
  font-style: italic;
  margin-top: -20px;
}
#single-article .article-body-wrap img {
  margin: 20px 0px;
}
#single-article .article-body-wrap .tate-img {
  margin: 0 25%;
}
#single-article .article-body-wrap .movie-wrap {
  padding: 0 0 56.25%;
  width: 100%;
  margin: 0 auto 60px;
  position: relative;
  height: 0;
  overflow: hidden;
}
#single-article .article-body-wrap .movie-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#single-article .article-body-wrap .single-table {
  margin: 60px 0px;
}
#single-article .article-body-wrap .single-table th,
#single-article .article-body-wrap .single-table tr {
  text-align: left;
}
#single-article .article-body-wrap .single-table th {
}
#single-article .article-body-wrap .btn {
  text-align: center;
  margin: 20px 0px;
}
#single-article .article-body-wrap .btn a {
  border: solid 1px #333;
  display: inline-block;
  font-size: 12px;
  transition-duration: 300ms;
  background-color: #fff;
  font-weight: bold;
  color: #333;
  padding: 20px 0px;
  width: 100%;
}
#single-article .article-body-wrap .btn a:hover {
  background-color: #000;
  opacity: 1;
  color: #fff;
}
#single-article .article-body-wrap .single-table tr {
}
#single-article .article-body-wrap ul {
  margin: 60px 0px;
  padding: 40px;
  border: solid 1px #999;
  /* background-color: #f5f5f5; */
}
#single-article .article-body-wrap ul li {
  margin-bottom: 10px;
  line-height: 1.5;
  letter-spacing: 0.01em;
  color: #151515;
}
#single-article .article-body-wrap ul li p {
  margin-bottom: 0px;
}
#single-article .article-body-wrap .info-box {
  padding: 40px 40px;
  background-color: #efefef;
  margin: 60px 0px;
  margin: 60px 0px 40px;
}
#single-article .article-body-wrap .info-box h3 {
  margin-top: 0px;
  font-size: 16px;
  margin: 20px 0px 20px;
}
#single-article .article-body-wrap .info-box p {
  font-size: 13px;
  margin-bottom: 20px;
}
#single-article .article-body-wrap .info-box a {
}
#single-article .article-body-wrap .info-box .caption {
}
#single-article .article-body-wrap .info-box img {
}
#single-article .sns-count {
  margin: 100px 0px 40px 0px;
}
#single-article .sns-count ul {
  display: flex;
  justify-content: space-between;
}
#single-article .sns-count ul li {
  padding: 0 1%;
  text-align: center;
  width: 33.3333%;
}
#single-article .sns-count ul li a {
  color: #fff;
  font-size: 12px;
  font-weight: bold;
  display: block;
  width: 100%;
  text-align: center;
  outline: 0;
  cursor: pointer;
  zoom: 1;
  padding: 5px 0;
  border-radius: 30px;
  transition: all 0.2s ease;
}
#single-article .sns-count ul li a:hover {
  opacity: 0.5;
}
#single-article .sns-count ul li.fb {
}
#single-article .sns-count ul li.tw {
}
#single-article .sns-count ul li.ln {
}
#single-article .sns-count ul li.fb a {
  background-color: #3b5998;
}
#single-article .sns-count ul li.tw a {
  background-color: #3cf;
}
#single-article .sns-count ul li.ln a {
  background-color: #00c402;
}

#single-article .sns-count li a svg {
  width: 16px;
  height: 16px;
}
#single-article .sns-count li a svg {
  fill: rgb(255 255 255);
}
.rental-template #related-sec {
  display: none;
}
.slider-thumbnail .swiper-slide {
  cursor: pointer;
  transition: all 0.25s ease;
}
.slider-thumbnail .swiper-slide:hover {
  opacity: 0.6;
}

.page-about #single-article .article-body-wrap p {
  font-weight: 600;
  font-size: 16px;
  line-height: 3;
}
.page-single02 {
  padding-top: 40px;
}
#single-article .article-body-wrap .wear h2 {
  font-size: 20px;
  background-color: #333;
  padding: 10px 20px;
  color: #fff;
}
#single-article .article-body-wrap .wear h3 {
  margin-top: 40px;
}
#single-article .article-body-wrap .wear h4 {
}
#single-article .article-body-wrap .box {
  margin-bottom: 80px;
}
.page-about #single-article .article-body-wrap .btn {
  margin-bottom: 100px;
}

/* ========================================================================================================
===========================================================================================================

unit

===========================================================================================================
======================================================================================================== */

.pc-block {
  display: block;
}
.sp-block {
  display: none;
}

/* ========================================================================================================
COMMON
======================================================================================================== */

.shadow {
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
}
.bg-position {
  background-position: center;
  background-size: cover;
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  left: 0;
}
.common-w-inner {
  padding-left: 8.784%;
  padding-right: 8.784%;
}
.common-h-inner {
  padding-top: 140px;
  padding-bottom: 140px;
}

.arrow-btn {
}
.arrow-btn a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 30px;
  border: solid 1px #333;
  color: #333;
  fill: #333;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  margin: auto;
  position: relative;
  min-width: 140px;
}
.arrow-btn a svg {
  width: 50px;
  bottom: 0;
  height: 100%;
  position: relative;
  /* transform: translate(-20px, 0px); */
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  top: -3px;
  height: 10px;
}
.arrow-btn a:hover {
}
.arrow-btn.b-w a {
  border-color: #fff;
  color: #fff;
  fill: #fff;
}
.arrow-btn.b-w a:hover {
  background-color: #fff;
}
.arrow-btn.b-w a:hover p,
.arrow-btn.b-w a:hover svg {
  color: #333;
  fill: #333;
}

.l-btn a {
  margin-left: 0;
}
.l-btn a p,
.c-btn a p {
  font-size: 12px;
  font-weight: bold;
  position: relative;
  line-height: 1.5;
}

.c-btn {
  text-align: center;
}
.c-btn a {
  justify-content: center;
}

.c-btn a svg {
  right: 80px;
  position: absolute;
  margin: auto;
}
.l-btn a:hover,
.c-btn a:hover {
  background-color: #151515;
  color: #fff;
}
.l-btn a:hover svg,
.c-btn a:hover svg {
  fill: #fff;
}

.route-level {
  font-size: 10px;
  padding: 4px 15px;
  border-radius: 10px;
  color: #fff;
  font-weight: 600;
  display: inline-block;
  line-height: 1.5;
  letter-spacing: 0;
}
.route01 {
  background-color: #d92139;
}
.route02 {
  background-color: #ee6a22;
}
.route03 {
  background-color: #eb71aa;
}
.route04 {
  background-color: #77ab3a;
}
.route05 {
  background-color: #416eb6;
}
.route06 {
  background-color: #253f58;
}
.route07 {
  background-color: #496a23;
}
.route08 {
  background-color: #742063;
}

.map-wrap {
  padding-bottom: 56.25%;
  position: relative;
}
.map-wrap iframe {
  width: 100%;
  position: absolute;
  height: 100%;
}
.common-table {
}
.common-table table {
  width: 100%;
}
.common-table table tbody {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.common-table tr:nth-child(-n + 2) {
  border-top: solid 1px #cdcdcd;
}
.common-table tr {
  width: 50%;
  width: calc(50% - 15px);
  display: flex;
  border-bottom: solid 1px #cdcdcd;
  /* border-top: solid 1px #cdcdcd; */
  padding: 20px 0px;
}
.common-table th,
.common-table td {
  width: 140px;
  text-align: left;
  font-size: 14px;
  display: block;
  line-height: 1.5;
}
.common-table td {
  width: calc(100% - 140px);
}
.common-table td a {
  text-decoration: underline;
}
.common-table td span {
  font-size: 10px;
}
.common-table th {
  font-weight: 600;
}

.bg-sec {
  /* background-color: #000; */
}
.bg-sec .wrap {
  position: relative;
  /* background-color: #000; */
}
.bg-sec .bg-position {
  opacity: 1;
}

a .shadow {
  transition: all 0.2s ease;
}
a:hover .shadow {
  /* box-shadow: 0 0 20px rgb(0 0 0 / 30%); */
  opacity: 0.6;
}

.fadein {
  opacity: 0;
  transform: translate(0, 0);
  transition: all 500ms;
}

.fadein.scrollin {
  opacity: 1;
  transform: translate(0, 0);
}
.lazyloaded {
}

.common-unit-wrap {
}
.common-unit {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.common-unit .common-box {
  background-color: #fff;
}
.common-unit .common-box a,
.common-unit .common-box .support-a,
.common-unit .common-box .support-a .box {
  display: block;
  height: 100%;
  width: 100%;
}
.common-unit .common-box a .box {
  height: 100%;
  position: relative;
}
.common-thumb-wrap {
  position: relative;
  padding-bottom: 66.666%;
  overflow: hidden;
  line-height: 0;
}
.common-thumb-wrap .thumb {
  height: 100%;
  width: 100%;
  position: absolute;
  background-position: center;
  background-size: cover;
}
.common-unit .common-box .tag {
  margin-bottom: 10px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  height: 18px;
  color: #666;
  font-weight: 300;
}
.common-unit .common-box .tag span {
  margin-right: 5px;
  font-size: 11px;
  color: #666;
  font-weight: 400;
  line-height: 1.5;
}
.common-unit .common-box .route-level {
  margin-bottom: 10px;
}
.common-unit .common-box .details {
  margin-bottom: 10px;
  display: flex;
  flex-wrap: wrap;
}
.common-unit .common-box .details li {
  margin-right: 10px;
  color: #333;
  font-size: 12px;
  font-weight: 400;
}
.common-unit .common-box .details li span {
  font-weight: 600;
}
.common-unit .common-box .address {
  font-size: 12px;
  margin-bottom: 5px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #333;
}
.common-unit .common-box .tel {
  font-size: 12px;
  margin-bottom: 5px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #333;
}
.common-unit .common-box .check-wrap {
}
.common-unit .common-box .check-wrap .check {
}
.common-unit .common-box .other {
  display: flex;
}
.common-unit .common-box .other a,
.common-unit .common-box .other p {
  width: auto;
  font-size: 12px;
  text-decoration: underline;
  margin-right: 10px;
  color: #333;
}

.common-unit.common-unit-three {
}
.common-unit.common-unit-three:after {
  content: "";
  width: calc(33.333% - 20px);
}
.common-unit.common-unit-three .common-box {
  width: calc(33.333% - 20px);
  margin-bottom: 30px;
}
.common-unit.common-unit-three .text-area {
  padding: 30px 20px 40px;
}
.common-unit.common-unit-three .text-area .tit {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 10px;
  letter-spacing: 0.05em;
  /* font-weight: 600; */
}
.common-unit.common-unit-three .text-area .tit span {
  display: none;
}
.common-unit.common-unit-three .text-area .excerpt {
  line-height: 1.8;
  font-size: 13px;
  font-weight: 400;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  height: 42px;
  margin-bottom: 15px;
  color: #151515;
  letter-spacing: 0.05em;
}

.common-unit.common-unit-two {
}
.common-unit.common-unit-two .common-box {
  width: calc(50% - 15px);
  margin-bottom: 30px;
}
.common-unit.common-unit-two .text-area {
  padding: 30px;
}
.common-unit.common-unit-two .text-area .tit {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 10px;
  letter-spacing: 0.05em;
}
.common-unit.common-unit-two .text-area .excerpt {
  line-height: 1.8;
  font-size: 13px;
  font-weight: 400;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  height: 42px;
  margin-bottom: 10px;
  color: #151515;
  letter-spacing: 0.05em;
}

.common-tit01 {
}
.common-tit01 .tit-area {
  width: auto;
  margin-bottom: 20px;
}
.common-tit01 .tit-area h2 {
  font-size: 44px;
  line-height: 1.5;
  white-space: nowrap;
  /* margin-bottom: 10px; */
  font-weight: bold;
  color: #151515;
}
.common-tit01 .tit-area h5 {
  color: #111;
  line-height: 1;
  font-size: 20px;
  font-weight: bold;
}
.common-tit01 .tit-area p {
  font-weight: 600;
  line-height: 1.5;
}
.common-tit01 .text-area p {
  font-size: 16px;
  line-height: 2;
  font-weight: 400;
}

.common-tit02 {
  margin-bottom: 10px;
}
.common-tit02 .tit-area {
  display: flex;
  align-items: center;
}
.common-tit02 .tit-area h2 {
  font-size: 28px;
  line-height: 1;
  font-weight: bold;
}
.common-tit02 .tit-area h5 {
  padding-left: 10px;
  font-size: 18px;
  line-height: 1.2;
}
.common-tit03 .tit-area {
  margin-bottom: 20px;
  text-align: center;
  color: #fff;
}
.common-tit03 .tit-area h2 {
  font-size: 24px;
  line-height: 1;
  margin-bottom: 8px;
}
.common-tit03 .tit-area h5 {
  line-height: 1;
  font-size: 16px;
}

.common-tit01.t-w h2,
.common-tit01.t-w h5,
.common-tit01.t-w .text-area p,
.common-tit01.t-w .tit-area p,
.common-tit02.t-w h2,
.common-tit02.t-w h5,
.common-tit02.t-w .text-area p,
.common-tit02.t-w .tit-area p {
  color: #fff;
}

#top-route-sec .common-tit01 {
  display: flex;
  margin-bottom: 40px;
}
#top-route-sec .common-tit01 h2 {
  line-height: 1;
  margin-bottom: 10px;
}
#top-route-sec .common-tit01 .text-area {
  margin-left: 40px;
}
#top-route-sec .common-tit01 .text-area p {
  line-height: 1.8;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  height: 50px;
  font-size: 14px;
}

#top-spots-tit-sec .common-tit01 .text-area {
  padding: unset;
  width: 50%;
}

#top-rental-sec .common-tit01 {
  margin-bottom: 0;
  flex-direction: column;
  width: 50%;
  margin-left: auto;
}

#top-info-sec .common-tit02,
#top-link-sec .common-tit02 {
  margin-bottom: 40px;
}

#top-info-sec .common-unit.common-unit-three .text-area .excerpt {
  margin-bottom: 0px;
  font-size: 12px;
  color: #999;
  height: auto;
  font-weight: 600;
}
#top-info-sec .common-unit.common-unit-three .text-area .tit {
  margin-bottom: 0px;
}

#map-sec .common-tit02 {
  margin-bottom: 20px;
}
#map-sec .common-h-inner {
  padding-bottom: 140px;
}

.view-more-button-wrap {
  margin-top: 40px;
}

.archive .common-h-inner,
.single-route .common-h-inner {
  padding-top: 100px;
  padding-bottom: 100px;
}

.shift-sec .common-h-inner {
  padding-top: 0px;
}

.post-type-archive-find-looking .common-unit .common-box .address,
.post-type-archive-eat-shopping .common-unit .common-box .address,
.post-type-archive-stay-enjoy .common-unit .common-box .address,
.archive-spots .common-unit .common-box .address,
.post-type-archive-find-looking .common-unit .common-box .tel,
.post-type-archive-eat-shopping .common-unit .common-box .tel,
.post-type-archive-stay-enjoy .common-unit .common-box .tel,
.archive-spots .common-unit .common-box .tel,
.post-type-archive-find-looking .common-unit .common-box .route-level,
.post-type-archive-eat-shopping .common-unit .common-box .route-level,
.post-type-archive-stay-enjoy .common-unit .common-box .route-level,
.archive-spots .common-unit .common-box .route-level,
.post-type-archive-rental .common-unit .common-box .excerpt,
.post-type-archive-rental .common-unit .common-box .tag,
.post-type-archive-rental .common-unit .common-box .route-level,
.post-type-archive-accommodation .common-unit .common-box .excerpt,
.post-type-archive-accommodation .common-unit .common-box .tag,
.post-type-archive-accommodation .common-unit .common-box .route-level,
.post-type-archive-accommodation .common-unit .common-box .route-level,
.post-type-archive-mtb .common-unit .common-box .tag{
  display: none;
}
.post-type-archive-find-looking .common-unit .common-box .tag,
.post-type-archive-eat-shopping .common-unit .common-box .tag,
.post-type-archive-stay-enjoy .common-unit .common-box .tag {
  margin-block: 0px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  height: 24px;
}

.post-type-archive-rental .common-unit .common-box .check-wrap,
.post-type-archive-accommodation .common-unit .common-box .tel {
  margin-bottom: 0px;
}

.post-type-archive-support .shift-sec {
  margin-top: 60px;
}

.support-unit.common-unit .common-thumb-wrap,
.support-unit.common-unit .text-area .excerpt,
.support-unit.common-unit .text-area .tag,
.support-unit.common-unit .text-area .route-level,
.support-unit.common-unit .text-area .common-thumb-wrap {
  display: none;
}
.support-unit.common-unit .text-area {
  padding: 40px 0px;
}
.support-unit.common-unit .common-box {
  background: none;
  margin-bottom: 0px;
  border-bottom: solid 1px #999;
}
.support-unit.common-unit .common-box:nth-child(-n + 2) {
  border-top: solid 1px #999;
}
.support-unit.common-unit .common-box .box {
  box-shadow: unset;
}

.single-route #spots-recommended-sec .common-unit.common-unit-two .common-box {
  margin-bottom: 0px;
}

.archive {
  background-color: #f9f9f9;
}
.archive #page-fv-sec,
.single-route #page-fv-sec {
  background-color: #000;
}

.archive #page-fv-sec .inner,
.single-route #page-fv-sec .inner {
  position: relative;
  z-index: 1;
  padding: 160px 0px 200px;
}
.archive #page-fv-sec .common-tit01,
.single-route #page-fv-sec .common-tit01 {
}
.archive #page-fv-sec .common-tit01 .tit-area,
.single-route #page-fv-sec .common-tit01 .tit-area {
}
.archive #page-fv-sec .common-tit01 .tit-area h2,
.single-route #page-fv-sec .common-tit01 .tit-area h2 {
}
.archive #page-fv-sec .common-tit01 .tit-area h5,
.single-route #page-fv-sec .common-tit01 .tit-area h5 {
  padding-left: 0;
  margin-bottom: 30px;
}

.single-route #spots-cat-sec .common-unit .common-box .check-wrap {
  margin-bottom: 0px;
}
.single-route #page-fv-sec .common-tit01 .tit-area p {
  margin-bottom: 10px;
}
.single-route .common-tit01 .tit-area {
  margin-bottom: 25px;
}
.single-route .common-tit01 .tit-area h2 {
  font-size: 34px;
  /* margin-bottom: 8px; */
}
.single-route .common-tit01 .tit-area h5 {
  font-size: 18px;
}
.shift-sec .common-h-inner {
  padding-top: 0px;
  /* padding-bottom: 0px; */
}

.single-route .common-unit .common-box .tag {
  margin-bottom: 0px;
}
.single-route #spots-recommended-sec .common-tit02 {
  margin-bottom: 20px;
}
.single-route #spots-tit-sec .inner {
  z-index: 1;
  position: relative;
  padding: 120px 0px 240px;
}
.single-route #spots-cat-sec .common-tit02,
.single-route #spots-support-sec .common-tit02 {
  background-color: #484848;
  padding: 14px 20px;
  margin-bottom: 30px;
}
.single-route #spots-cat-sec .common-tit02 h2,
.single-route #spots-support-sec .common-tit02 h2 {
  font-size: 26px;
}
.single-route #spots-cat-sec .common-tit02 h5,
.single-route #spots-support-sec .common-tit02 h5 {
  font-size: 18px;
}
.single-route #spots-cat-sec .element {
  margin-bottom: 60px;
}
.single-route #spots-cat-sec .element:last-child {
  /* margin-bottom: 120px; */
}

.post-type-archive-support #page-fv-sec .inner,
.fixed-page #page-fv-sec .inner {
  padding: 150px 0px 70px;
}

.fixed-page {
  background-color: #fff;
}
.fixed-page .shift-sec {
  margin-top: 0px;
}
.fixed-page #single-article .inner {
  /* padding-top: 80px; */
}

.archive-route .common-unit .common-box .tag {
  margin-bottom: 30px;
}

.archive-accommodation .common-unit .common-box .tel{
  margin-bottom: 10px;
}


.cs{font-size: 10px;padding: 3px 8px;border-radius: 4px;color: #fff;font-weight: 600;display: inline-block;line-height: 1.5;letter-spacing: 0;z-index: 1;background-color: rgba(0, 87, 155, 80%);left: 20px;bottom: 15px;position: absolute;}


.mtb_guide{margin: 40px 0px;}
.mtb_guide p{
    font-size: 14px;
    line-height: 1.5;
}
.single-mtb #related-sec{
  display: none;
}


.top-mtb-sec{margin-bottom: 80px;}
.top-mtb-sec .common-w-inner{}
.top-mtb-sec .inner{
  padding: 60px 40px;
  position: relative;
  color: #fff;
}
.top-mtb-sec .common-tit02{
    display: flex;
    align-items: center;
}

.top-mtb-sec .text-area,
.top-mtb-sec .arrow-btn{
    /* width: 50%; */
    line-height: 1.5;
    margin-bottom: 20px;
}
.top-mtb-sec .mask{
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    background-color: #000;
    z-index: -1;
    opacity: 0.5;
}
.top-mtb-sec .thumb{
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    z-index: -2;
    background-position: center;
    background-size: cover;
}
.top-mtb-sec h2{
    font-size: 32px;
    margin-right: 10px;
}
.top-mtb-sec h5{
    font-size: 22px;
}
.top-mtb-sec p{
    line-height: 1.5;
}
/* ========================================================================================================
===========================================================================================================

responsive

===========================================================================================================
======================================================================================================== */

@media screen and (max-width: 1000px) {
  header .h-menu .list-mune {
    display: none;
  }
  .common-w-inner {
    padding-left: 40px;
    padding-right: 40px;
  }

  .common-tit01 .tit-area h2 {
    font-size: 38px;
  }
  footer .common-w-inner {
  }
  .common-unit.common-unit-three .common-box {
    width: calc(33.333% - 15px);
    margin-bottom: 20px;
  }
  .common-unit.common-unit-two .common-box {
    width: calc(50% - 10px);
    margin-bottom: 20px;
  }
  .page-single-route .date .directions {
    display: block;
  }
  .page-single-route .date .directions .img-area {
    width: 70%;
    margin-bottom: 40px;
  }
  .page-single-route .date .directions .flex {
    width: 100%;
    margin-bottom: 30px;
  }
  .page-single-route .date .icon-wrap {
    margin-bottom: 20px;
  }
  .page-single-route .date .btn-area .l-btn {
    width: calc(50% - 10px);
  }
}

@media screen and (max-width: 940px) {
  .c-btn a svg {
    right: 40px;
    position: absolute;
  }
  .common-unit.common-unit-three .common-box,
  #top-info-sec .common-unit-three li:nth-child(n + 4),
  .page-single-custom #related-sec .common-unit-three li {
    width: calc(50% - 10px);
    margin-bottom: 20px;
  }
  #top-info-sec .common-unit-three li:nth-last-child(-n + 2) {
    margin-bottom: 0px;
  }

  #top-route-sec .swiper-pagination {
    justify-content: center;
    margin-bottom: 0px;
    margin-top: 40px;
  }
  #top-route-sec .swiper-container {
    padding-bottom: 20px;
    display: flex;
    flex-direction: column-reverse;
  }
  #top-route-sec .swiper-pagination-bullet {
    width: 10%;
    height: 1px; /* border-radius: 100%; */
    background-color: #000;
    margin-bottom: 0px;
    padding-right: 0px; /* margin: 0 8px; */
  }
  .page-single-route .date .details-wrap {
    display: block;
  }
  .page-single-route .date .details-wrap .details {
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 800px) {
  #top-route-sec .recommended .flex {
    display: block;
  }
  #top-route-sec .recommended .flex .img-area,
  #top-route-sec .recommended .flex .text-area {
    width: 100%;
    padding-left: 0px;
  }
  #top-route-sec .recommended .flex .img-area {
    margin-bottom: 20px;
  }
  .page-single-custom #fv-sec .flex {
    display: block;
  }
  .page-single-custom #fv-sec .common-tit02 {
    width: 100%;
    padding-left: 0px;
  }
  .page-single-custom #fv-sec .img-area {
    width: 100%;
    padding-left: 0px;
  }
  .common-table tr {
    width: 100%;
  }
  .common-table tr:nth-child(-n + 2) {
    border-top: unset;
  }
  .common-table tr:nth-child(1) {
    border-top: solid 1px #cdcdcd;
  }
  .page-single-custom #fv-sec .common-w-inner {
    padding: 0px;
  }
  .page-single-custom #fv-sec .common-tit02 {
    padding: 40px;
    width: auto;
    padding-bottom: 0px;
  }
  .page-single-custom #fv-sec .inner {
    padding-top: 70px;
  }
  .page-single-custom .common-h-inner {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
@media screen and (max-width: 768px) {
  .common-h-inner {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  #top-about-sec .inner {
    padding: 80px 0px 100px;
  }
  #top-about-sec .text-area p {
    font-size: 16px;
    margin-bottom: 20px;
  }
  #top-about-sec .text-area p:last-child {
    margin-bottom: 30px;
  }
  #top-route-sec .common-tit01 {
    display: block;
  }
  #top-route-sec .common-tit01 .text-area {
    margin-left: 0;
  }
  #top-route-sec .swiper-container {
    /* padding-bottom: 20px; */
    /* display: flex; */
    /* flex-direction: column-reverse; */
  }
  #top-route-sec .swiper-pagination {
    justify-content: space-between;
    /* display: none; */
  }
  #top-route-sec .swiper-pagination span::before {
    content: "";
    display: none;
  }
  #top-spots-tit-sec .inner {
    padding: 100px 0px;
  }
  .common-tit02 {
    margin-bottom: 0px;
  }
  #top-spots-sec .element .excerpt .flex {
    display: block;
  }
  #top-spots-sec .element .excerpt .flex .text-area {
    width: 100%;
    padding: 0px;
    margin-bottom: 20px;
  }
  #top-spots-sec .element .excerpt .flex .l-btn {
    width: 100%;
  }
  .arrow-btn a {
    padding: 20px 20px;
  }
  #top-wear-acc-sec .wrap {
    display: block;
  }
  #top-wear-acc-sec .box {
    width: 100%;
  }

  #top-info-sec .common-tit02,
  #top-link-sec .common-tit02 {
    margin-bottom: 20px;
  }

  #top-link-sec ul li {
    width: calc(33.33% - 15px);
  }
  .single-route
    #spots-recommended-sec
    .common-unit.common-unit-two
    .common-box {
    width: 100%;
    margin-bottom: 30px;
  }
  .page-single-route .date .directions .img-area {
    width: 100%;
  }
}
@media screen and (max-width: 640px) {
  .common-h-inner {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .common-w-inner {
    padding-left: 25px;
    padding-right: 25px;
  }
  header .header-wrap {
    padding: 0 25px;
    height: 60px;
  }
  #top-fv-sec .main-text {
    font-size: 13vw;
    margin-bottom: 20px;
  }
  header .hakuba-logo {
    display: none;
  }

  .common-unit.common-unit-three,
  .common-unit.common-unit-two {
    display: block;
  }
  .common-unit.common-unit-three .common-box,
  .common-unit.common-unit-two .common-box,
  #top-info-sec .common-unit-three li:nth-child(n + 4),
  .page-single-custom #related-sec .common-unit-three li {
    width: 100%;
    margin-bottom: 20px;
  }

  .common-unit.common-unit-three .common-box a .box {
    display: flex;
  }
  .common-unit.common-unit-three .common-box a .box .common-thumb-wrap {
    width: 35%;
    padding-bottom: unset;
  }
  .common-unit.common-unit-three .common-box a .box .common-thumb-wrap .thumb {
    /* padding-bottom: 66.666%; */
    /* height: auto; */
  }
  .common-unit.common-unit-three .common-box a .box .text-area {
    width: 65%;
  }
  .common-unit.common-unit-three .text-area .tit {
    font-size: 14px;
    height: 21px;
    line-height: 1.5;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    margin-bottom: 5px;
  }
  .common-unit.common-unit-three .text-area .excerpt {
    font-size: 10px;
    margin-bottom: 0px;
    line-height: 1.5;
    height: 32px;
    font-weight: 400;
  }
  .common-unit.common-unit-three .common-box .tag,
  .common-unit .common-box .tel,
  .common-unit .common-box .address {
    display: none;
  }
  .common-unit .common-box .check-wrap .check {
    padding: 6px;
    font-size: 10px;
  }
  #top-route-sec .text-area p.excerpt {
    overflow: auto;
    height: auto;
    display: block;
    line-height: 1.8;
    font-size: 13px;
    font-weight: 500;
  }
  #top-route-sec .common-tit01 {
    margin-bottom: 30px;
  }
  .common-tit01 .tit-area h2 {
    font-size: 34px;
    letter-spacing: -0.01em;
  }
  .common-tit01 .tit-area h5 {
    font-size: 18px;
    letter-spacing: -0.01em;
  }
  #top-fv-sec .element .inner {
    padding: 25px;
    height: calc(100% - 70px);
  }

  .pc-block {
    display: none;
  }
  .sp-block {
    display: block;
  }
  #top-route-sec .swiper-slide .box {
    width: calc(100% - 20px);
    width: 100%;
    margin-top: 0;
  }
  #top-news-info-sec .flex p.tit {
    display: none;
  }
  #top-news-info-sec .flex span {
    display: none;
  }
  #top-news-info-sec .flex p.text {
    margin-left: 0px;
  }
  #top-route-sec .route-text {
    margin-bottom: 30px;
  }
  #top-route-sec .route-text p {
    font-size: 15px;
    line-height: 2;
    font-weight: 400;
  }
  #top-route-sec .swiper-area {
    margin-bottom: 20px;
  }
  #top-route-sec .swiper-slide .box .route-tit {
    font-size: 16px;
  }
  #top-route-sec .swiper-slide .box p {
    font-size: 12px;
    height: 42px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    margin-bottom: 10px;
  }
  #top-mv-sec .iframe-wrap {
    position: relative;
    top: 0;
    z-index: 0;
  }
  #top-mv-sec .wrap {
    height: auto;
    padding: 25px;
    padding-top: 60px;
    padding-bottom: 0px;
  }
  #top-spots-tit-sec .common-tit01 .text-area {
    width: 100%;
  }
  .common-tit02 .tit-area {
    display: block;
  }
  .common-tit02 .tit-area h5 {
    padding-left: 0px;
    font-size: 16px;
  }
  .common-tit02 .tit-area h2 {
    font-size: 26px;
    line-height: 1.5;
  }
  #top-spots-sec .swiper-button-next,
  #top-spots-sec .swiper-button-prev {
    width: 30px;
    height: 30px;
    top: calc(50% - 15px);
  }
  #top-spots-sec .swiper-button-next img,
  #top-spots-sec .swiper-button-prev img {
    width: 7px;
  }
  #top-spots-sec .swiper-slide .box p {
    margin-top: 10px;
    font-size: 11px;
  }
  #top-spots-sec .element .excerpt .flex .text-area p {
    height: auto;
    overflow: auto;
    display: block;
    font-size: 13px;
  }
  #top-route-sec .recommended .flex h2 {
    font-size: 24px;
  }
  #top-route-sec .recommended .flex h5 {
    font-size: 14px;
  }
  .l-btn a p,
  .c-btn a p {
  }
  .arrow-btn a {
    /* padding: 18px 20px; */
  }
  #top-rental-sec .common-tit01 {
    width: 100%;
  }
  .common-tit03 .tit-area {
    text-align: left;
  }
  .c-btn a {
    justify-content: flex-start;
  }
  .common-tit03 .tit-area h2 {
    font-size: 24px;
  }
  .common-tit03 .tit-area h5 {
    font-size: 14px;
  }
  #attention-sec .common-w-inner {
    padding-left: 0px;
    padding-right: 0px;
  }
  #attention-sec .common-h-inner {
    padding-top: 0;
    padding-bottom: 60px;
  }
  #attention-sec .common-tit03 {
    padding: 80px 20px;
  }
  #top-link-sec ul li {
    width: calc(50% - 5px);
  }
  #top-info-sec .common-unit.common-unit-three .text-area .excerpt {
    font-size: 10px;
  }
  .page-single-route .date .icon-wrap ul li {
    width: 50%;
    font-size: 12px;
  }
  .page-single-route .date .icon .img-wrap {
    position: relative;
    width: 13px;
    height: 13px;
  }

  .page-single-route .date .details-wrap .details li {
    width: 50%;
    margin-right: 0;
  }

  #single-article .article-body-wrap p {
    font-size: 15px;
    margin-bottom: 20px;
  }
  #top-route-sec .swiper-button-next,
  #top-route-sec .swiper-button-prev {
    width: 40px;
    height: 40px;
    top: calc(50% - 120px);
  }
  #top-route-sec .swiper-button-next {
    right: 10px;
  }
  #top-route-sec .swiper-button-prev {
    left: 10px;
  }
  #top-about-sec .text-area p {
    font-size: 16px;
    line-height: 2;
  }
  #top-about-sec .text-area p br {
    display: none;
  }
  #top-about-sec .text-area {
    margin-bottom: 60px;
  }
  #top-route-sec .recommended .flex .excerpt {
    font-size: 13px;
  }
  #top-route-sec .swiper-container {
  }
  footer .elemnt02 ul li {
    width: 80px;
    margin-right: 30px;
  }
  #full-nav .full-nav-inner {
    width: 300px;
  }
  .h-logo {
    width: 70px;
    padding: 0px;
  }
  #full-nav .sns-wrap .wrap {
    padding-bottom: 140px;
  }
  #top-route-sec .c-btn {
    margin-bottom: 80px;
  }
  #top-route-sec .common-tit01 .text-area p {
    display: block;
    height: 100%;
    font-weight: 400;
  }
  #top-route-sec .swiper-slide .thumb-wrap {
    /* padding-bottom: 130%; */
  }
  #top-fv-sec .fv-wrap {
    padding-top: 0px;
    height: 100vh;
  }
  #top-route-sec .swiper-slide.swiper-slide-prev,
  #top-route-sec .swiper-slide.swiper-slide-next {
    opacity: 0.6;
    transition: all 0.2s ease;
  }
  #top-route-sec .swiper-slide.swiper-slide-active {
    opacity: 1;
  }
  .common-unit.common-unit-two .text-area {
    padding: 20px;
  }
  .support-unit.common-unit .text-area {
    padding: 30px 0px;
  }
  footer .common-w-inner {
    padding: 0 25px;
  }
  .archive #page-fv-sec .common-tit01 .tit-area p {
    font-size: 14px;
  }
  .support-unit.common-unit .common-box:nth-child(-n + 2) {
    border-top: unset;
  }
  .support-unit.common-unit .common-box {
    margin-bottom: 0px;
  }
  .support-unit.common-unit .common-box:nth-child(1) {
    border-top: solid 1px #999;
  }
  .page-single-route .map-wrap {
    padding-bottom: 150%;
  }
  .map-wrap {
    padding-bottom: 100%;
  }
  .single-route .common-tit01 .tit-area h2 {
    font-size: 30px;
    letter-spacing: 0.01em;
    word-break: break-all;
    white-space: break-spaces;
  }
  .single-route .swiper-area .common-thumb-wrap {
    padding-bottom: 66.666%;
  }
  .page-single-route .date .directions {
    width: 100%;
  }
  .nav-button {
    margin-left: 20px;
  }
  .nav-button .line {
    margin-top: 2px;
  }
  #top-spots-tit-sec .common-tit01 .tit-area {
    /* margin-bottom: 280px; */
  }
  #top-spots-tit-sec .inner {
    padding: 80px 0px;
    /* padding-top: 140px; */
  }
  #top-spots-tit-sec .common-tit01 .text-area p{
    line-height: 1.8;
}
  #top-spots-sec .common-h-inner {
    padding-top: 60px;
  }
  #top-spots-sec .element {
    margin-bottom: 60px;
  }
  #top-rental-sec .inner {
    padding: 80px 0;
  }
  #top-rental-sec .common-tit01 .text-area {
    margin-bottom: 20px;
  }
  #top-wear-acc-sec .box .box-inner {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  #top-link-sec .common-h-inner {
    padding-top: 40px;
    padding-bottom: 100px;
  }
  footer .elemnt02 .l-btn a {
    /* width: 100%; */
  }
  footer .elemnt02 .l-btn {
    display: block;
    width: 100%;
  }
  footer .elemnt01 .list-mune li {
    width: 50%;
    padding-bottom: 30px;
  }
  footer .elemnt01 a {
    font-size: 14px;
    padding-right: 0px;
  }
  footer .wrap {
    padding-top: 100px;
  }
  footer .elemnt02 ul {
    margin-bottom: 40px;
  }
  footer .elemnt02 ul.sns li {
    height: 30px;
    width: 30px;
  }
  #single-article .common-w-inner {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .page-about #single-article .article-body-wrap .btn {
    margin-bottom: 60px;
  }
  .page-about #single-article .article-body-wrap p {
    font-weight: 600;
    font-size: 15px;
    line-height: 2;
    margin-bottom: 30px;
  }
  #single-article .meta-area .tit {
    font-size: 20px;
    margin-bottom: 20px;
  }
  .page-single02 {
    padding-top: 60px;
  }
  .error404 .page-single02 {
    padding: 100px 25px;
    padding-top: 120px;
  }
  #single-article .article-body-wrap .wear h2 {
    font-size: 16px;
    padding: 10px;
  }
  #single-article .article-body-wrap .wear h3 {
    margin-top: 0px;
    font-size: 18px;
    margin-bottom: 20px;
  }
  #single-article .article-body-wrap .box {
    margin-bottom: 60px;
  }
  #single-article .article-body-wrap img {
    margin: 10px 0px;
  }
  .page-single-route .date .btn-area {
    display: block;
  }
  .page-single-route .date .btn-area .l-btn {
    width: 100%;
    margin-bottom: 20px;
  }
  .single-route #spots-cat-sec .common-tit02 h2,
  .single-route #spots-support-sec .common-tit02 h2 {
    font-size: 18px;
  }
  .single-route #spots-cat-sec .common-tit02 h5,
  .single-route #spots-support-sec .common-tit02 h5 {
    font-size: 14px;
    padding-left: 10px;
  }
  .page-single-route #spots-cat-sec .element .common-tit02 .tit-area {
    display: flex;
    /* align-items: baseline; */
  }
  .single-route #spots-cat-sec .common-tit02,
  .single-route #spots-support-sec .common-tit02 {
    padding: 10px 15px;
  }
  #route-banner-sec .text-area {
    align-items: flex-start;
  }
  .page-single-route .route-level {
    font-size: 10px;
  }
  #route-banner-sec .text-area .route-level,
  #route-banner-sec .text-area .tit {
    margin-left: 30px;
  }
  #route-banner-sec .text-area .tit {
    margin-top: 20px;
  }
  #route-banner-sec .common-thumb-wrap {
    padding-bottom: 56.25%;
  }
  .archive .common-h-inner,
  .single-route .common-h-inner {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .single-route #page-fv-sec .common-tit01 .tit-area h5 {
    padding-left: 0;
    margin-bottom: 20px;
    font-size: 14px;
    font-weight: 400;
  }
  .shift-sec {
    margin-top: -140px;
  }
  .archive #page-fv-sec .inner,
  .single-route #page-fv-sec .inner {
    padding-top: 140px;
    padding-bottom: 160px;
  }
  .page-single-route .swiper-area {
    margin-bottom: 28px;
  }
  .page-single-route .description p {
    font-size: 14px;
    line-height: 2;
  }
  .shift-sec .common-h-inner {
    padding-bottom: 60px;
    padding-top: 0px;
  }
  #map-sec .common-h-inner {
    padding-bottom: 80px;
  }
  .single-route #spots-tit-sec .inner {
    padding-top: 60px;
    padding-bottom: 220px;
  }
  .page-single-route #spots-recommended-sec.shift-sec {
    margin-bottom: 0px;
  }
  .page-single-route .slider4 {
    margin-bottom: 5px;
  }
  .page-single-route .date .icon-wrap .icon {
    padding: 6px;
  }
  #spots-recommended-sec .shift-sec .common-h-inner {
    padding-bottom: 40px;
  }
  .page-single-custom .related-area {
  }
  .page-single-custom
    .related-area
    .common-unit.common-unit-three
    .common-box
    a
    .box
    .common-thumb-wrap {
    padding-bottom: 56.25%;
    width: 100%;
  }
  .page-single-custom
    .related-area
    .common-unit.common-unit-three
    .common-box
    a
    .box
    .text-area {
    width: 100%;
    padding: 0px;
    align-items: flex-start;
  }
  .page-single-custom
    .related-area
    .common-unit.common-unit-three
    .text-area
    .tit {
    margin-left: 20px;
  }
  .page-single-custom
    .related-area
    .common-unit.common-unit-three
    .text-area
    .route-level {
    margin-left: 20px;
  }
  .page-single-custom #fv-sec .inner {
    padding-top: 60px;
  }
  .page-single-custom #fv-sec .common-tit02 {
    padding: 25px;
    width: auto;
    padding-bottom: 0px;
  }
  .page-single-custom #fv-sec .common-tit02 .tit-area h2 {
    font-size: 20px;
    margin-bottom: 10px;
    margin-top: 20px;
  }
  .page-single-custom #fv-sec .common-tit02 .tit-area p {
    margin-bottom: 0px;
  }
  .page-single-custom .map-area {
    margin-bottom: 30px;
  }
  .archive-accommodation .common-unit .common-box .tel {
    display: block;
  }
  .archive-support #page-fv-sec .inner {
    padding-bottom: 40px;
  }
  .page-single-custom .common-tit02 .tit-area h2 {
    font-size: 18px;
  }
  .page-single-custom .common-tit02 .tit-area h5 {
    font-size: 14px;
  }
  .common-table th,
  .common-table td {
    font-size: 12px;
  }
  .cs{
    left: auto;
    /* bottom: auto; */
}
.top-mtb-sec .common-tit02{display: block;}
.top-mtb-sec .inner{padding: 60px 20px;}
.top-mtb-sec h2{
  margin-bottom: 5px;
}
.top-mtb-sec h5{
  margin-bottom: 10px;
}
.top-mtb-sec .thumb{
}
.top-mtb-sec .common-w-inner{
  padding: 0;
}
.top-mtb-sec {
    margin-bottom:40px;
}
.top-mtb-sec h2 {
    font-size: 32px;
    }
.top-mtb-sec h5 {
    font-size:18px;
}
}

/* ========================================================================================================
===========================================================================================================

last

===========================================================================================================
======================================================================================================== */
