@charset "UTF-8";

body {
  position: relative;
}

/* header */
header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 122;
  background: rgba(0, 0, 0, 0);
}

header a {
  pointer-events: none;
}

header h1 {
  margin: 0;
}

header section>div,
header h1,
header h1 img {
  transition: all 1s;
}

header h1 {
  display: flex;
  justify-content: center;
}

header h1 img {
  position: relative;
  top: 15.9vh;
  left: 0;
  width: 27vh;
}

header.loaded a {
  pointer-events: initial;
}

header.loaded h1 img {
  top: 0;
  left: 0;
}

header section {
  display: block;
}

header section>div {
  opacity: 0;
}

header.loaded section>div {
  opacity: 1;
}

/* header */
/* プリロード */
main {
  position: relative;
  overflow-y: hidden;
  height: 100vh;
  left: 0;
  top: 0;
  z-index: 1;
}

main.loading::before {
  content: "";
  display: block;
  position: fixed;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  z-index: 100;
  background-color: #000;
  transition: all 1s;
}

main.loading.loadDone::before {
  opacity: 0;
}

header.loaded,
section.loaded,
footer.loaded,
main.loaded #slider {
  display: block;
}

footer.loaded {
  display: flex;
  margin-bottom:20vw;
}

main.loaded {
  overflow: hidden;
  height: auto;
}

#beforPreload.loaded {
  display: none;
}

section,
section.spOnly,
footer,
body #link_li,
#slider {
  display: none;
}

#preloadCon {
  padding: 25.25vh 0 0;
  width: 100%;
  position: relative;
}

#preloadCon h2 {
  font-size: 4vh;
  line-height: 6vh;
}

#beforPreload {
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-flow: column;
  width: 100vw;
  height: 100vh;
  background: #000;
  color: #FFF;
  text-align: center;
  z-index: 121;
}

#preloadWrap {
  position: fixed;
  width: 100%;
  display: flex;
  align-items: flex-start;
  height: 100vh;
}

#preloadWrap video {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  min-width: 100%;
  min-height: 100%;
}

#preloadWrap p {
  font-size: 2.05vh;
  padding: 4vh 0 0;
  line-height: 3.8vh;
  margin: auto;
}

#preloadWrap #skip {
  font-size: 3.4vh;
  width: 6vh;
  padding: 1.3vh 0;
  margin-top: 7.4vh;
  border-bottom: 2px solid #fff;
  font-family: "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: 100;
  letter-spacing: 0;
  display: flex;
  justify-content: center;
  transition: all .2s;
}

/* プリロード */
/* main */
section nav.fixed i, section nav.fixed b {
  background: #fff;
}
#mainV {
  height: 100svh;
  width: 100vw;
  background-color: #fff;
  color: #fff;
  overflow: hidden;
  position: relative;
  /* margin-bottom: 17vw; */
  z-index: 11;
}

#mainV>ul {
  position: relative;
}

#mainV #slider {
  width: 100vw;
  height: 100%;
  margin: 0;
  z-index: 6;
}

#mainV #slider>* {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: all .75s;
  /* JSと同じ値 -> var nextSpeed */
  display: none;
}
#topfloatingSns{
  display: flex;
  justify-content: space-between;
  position: fixed;
  z-index: 5;
  top: 5.38vw;
  right: 14.87vw;
  width: 28.49vw;
}
#topfloatingSns img,
#topfloatingSns svg{
  height: 6.26vw;
  width: auto;
}
#mainV #slider>li::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  background: linear-gradient(to bottom, rgba(40, 40, 40, 0), rgba(35, 35, 35, .4));
  display: inline-block;
  width: 100%;
  height: 100%;
  z-index: 2;
}

#mainV #slider>.active,
#mainV #slider>.nextActive,
#mainV #slider>.nextActive2,
#mainV #slider>.beforeActive,
#mainV #slider>.beforeActive2 {
  display: block;
  opacity: 1;
  z-index: 1;
}

#mainV #slider>.nextActive {
  opacity: 0;
}

#mainV #slider>.beforeActive {
  z-index: 2;
}

#mainV #slider>.beforeActive2 {
  opacity: 0;
  z-index: 2;
}

#mainV #slider img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

#mainV #slider img.topSlider {
  display: none;
}

#mainV #slider .msg {
  position: absolute;
  font-weight: bold;
  width: 100vw;
  height: auto;
  bottom: 10.5vh;
  left: 0;
  z-index: 3;
  text-align: center;
}

#mainV #slider li .msg a.viewMore {
  height: auto;
}

#mainV #slider .msg h3 {
  font-size: 19.57vw;
  line-height: 15vw;
  font-family: 'BStyle', "BStyle-Regular", "DIN Alternate Bold", "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  transform: initial;
  font-weight: 400;
  margin-left: 0;
}

#mainV #slider img.icon {
  width: 11vw;
  margin-left: .75vw;
  height: auto;
  object-fit: initial;
}

#mainV #slider .msg p {
  font-size: 7vw;
  line-height: 7vw;
  height: 23vw;
  padding-top: 3vw;
  text-align: center;
}

#mainMsg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 6;
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: none;
}

#mainMsg img {
  width: 81%;
  position: absolute;
  bottom: 8.5vh;
}

#mainV #slider li .msg a {
  display: none;
}

#mainVPager {
  position: absolute;
  left: 10vw;
  bottom: 3vh;
  flex-flow: nowrap;
  align-items: center;
  z-index: 2;
  display: flex;
}

#mainVPager div {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  cursor: pointer;
  font-family: "Bebas Neue", "Bebas", "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}

#mainVPager button {
  display: none;
}

#mainVPager>div {
  font-size: 7.97vw;
  padding: .75vw;
  line-height: 7vw;
  font-weight: 300;
  display: flex;
  align-items: center;
}

#mainVPager .align_border div {
  height: 1px;
}

#mainVPager .align_border div:first-child {
  background: #FFF;
  width: 11vw;
}

/* ファーストビューの表示時上詰め回避 */
#mainVbottom {
  margin-top: 100vh;
}

/* ファーストビューの表示時上詰め回避 */
/* バイカーズフェスティバルとは */
.inner_content.about‗fes {
  display: flex;
  flex-wrap: nowrap;
}

.inner_content.about‗fes>div.txt {
  padding: 3vw;
}

/* バイカーズフェスティバルとは */
/* こんな楽しみ方 */
#HowToEnjoy {
  display: flex;
  flex-wrap: wrap;
}

#HowToEnjoy>div {
  width: 50%;
}

/* こんな楽しみ方 */
/* 開催日 */
.fesSchedule {
  padding: 0 9.5vw 16vw 10.87vw;
  font-weight: bold;
  font-size: 4.35vw;
  letter-spacing: -.05vw;
}

#dateAndTime {
  font-size: 9.18vw;
  letter-spacing: .55vw;
  display: flex;
  align-items: flex-end;
  height: 14.5vw;
}

#dateAndTime .blackBox {
  display: inline-block;
  color: #FFF;
  background: #000;
  font-size: 3.14vw;
  padding: .5vw .5vw 1.25vw 1vw;
  margin: 0vw 3vw 1vw .5vw;
}

#dateAndTime .big_num {
  margin: 0 0 -1vw;
  font-size: 14.25vw;
}

#venue {
  font-size: 3.14vw;
  letter-spacing: 0;
  padding: 2vw 0 3.25vw;
  border-bottom: 2px solid #000;
  margin: 0;
}

#begins {
  padding: 4vw 0 .25vw;
  font-size: 3.5vw;
  letter-spacing: .08vw;
  display: flex;
  align-items: flex-end;
}

#begins p {
  font-size: 3vw;
  line-height: 3.5vw;
  display: flex;
  align-items: flex-end;
  margin-bottom: -.5vw;
}

#begins span {
  font-size: 6vw;
  margin-bottom: 1.25vw;
}

.fesSchedule img {
  width: 100%;
}

/* 開催日 */
/* BIKER'S INFO */
.innerContent .iconTtl {
  font-family: "Bebas Neue", "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-family: "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 6vw;
  font-weight: 300;
  letter-spacing: .1vw;
  background-image: url(../img/common/arrowRightBlack.svg);
  background-repeat: no-repeat;
  background-position: 44% 57%;
  margin-bottom: 6vw;
}

.innerContent p {
  font-size: 3.32vw;
}

.innerContent .iconTtl img {
  margin: 0 1.25vw -.25vw 0;
  width: 9.9vw;
}

.controllScrollOver {
  margin: 0 0 7vw 10.87vw;
}

.controllScrollWrap {
  height: 73.91vw;
  width: 89.37vw;
  overflow-x: scroll;
  overflow-y: hidden;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.controllScrollWrap::-webkit-scrollbar {
  display: none;
}

.controllScrollWrap>ul {
  display: flex;
  height: 100%;
  padding-left: 1vw;
}

.controllScrollWrap>ul li {
  height: 100%;
  margin: 0 6.8vw 0 0;
  padding: 0;
}

.controllScrollWrap>ul li:last-child {
  padding-right: 20vw;
}

.controllScrollWrap a {
  height: 100%;
  display: inline-block;
  width: auto;
  position: relative;
}

.controllScrollWrap a::after {
  content: "";
  position: absolute;
  right: 2vw;
  bottom: 2vw;
  width: 3vw;
  height: 3vw;
  background: url(../img/top/arrowRightDown.svg) 100% no-repeat;
  z-index: 1;
}

.controllScrollWrap img {
  height: 100%;
  max-width: initial;
}

.controllScrollWrap>ul li .firstViewSlide {
  display: none;
}

.controllScrollWrap>ul li .msg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: column;
  color: #FFF;
  z-index: 1;
  text-shadow: 0 .72vw 1.45vw #000;

  justify-content: flex-start;
  margin-top: 11vw;
}

.controllScrollWrap>ul li .msg h3 {
  font-family: 'BStyle', "BStyle-Regular", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 8.45vw;
}

.controllScrollWrap>ul li .msg .icon {
  display: none;
}

.controllScrollWrap>ul li .msg p {
  font-size: 3.86vw;
  line-height: 5.8vw;
}

.controllScrollWrap>ul li .msg b {
  font-size: 4.83vw;
  line-height: 10vw;
  text-align: center;
}

.controllScrollWrap>ul li .msg b.rows3 {
  line-height: 6vw;
  text-align: center;
  margin-bottom: 2vw;
}

.controllScrollWrap>ul li .msg h4 {
  font-family: "DIN Alternate Bold", "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 3.86vw;
}

.controllScrollBarOver {
  margin-top: 2vw;
  display: flex;
  align-items: center;
  height: 5vw;
  justify-content: space-between;
}

.controllScrollBarWrap {
  position: relative;
}

.controllScrollBar {
  width: 80vw;
  height: 1px;
  background: #333;
}

.controllScrollBarActive {
  position: absolute;
  top: -1px;
  left: 0;
  width: 5vw;
  height: 3px;
  background: #333;
}

/* .controllScrollButtonWrap {
  display: none;
} */


/* フォトアルバムのトップ画像文字レイヤー */
ul#mainVPhotoVer,
ul#mainVPhotoVer li {
  width: 100%;
  height: 100%;
}

ul#mainVPhotoVer li .msg {
  position: absolute;
  left: 0;
  top: -3vw;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: column;
  color: #FFF;
  z-index: 1;
  text-shadow: 0 .72vw 1.45vw #000;
  font-size: 6.04vw;
  font-weight: bold;
  line-height: 8.45vw;
  text-align: center;
}

ul#mainVPhotoVer li>img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

ul#mainVPhotoVer li .msg .big {
  font-size: 7.8vw;
  letter-spacing: .02vw;
}

ul#mainVPhotoVer li .msg img {
  width: 14.44vw;
  margin-top: 2vw;
}


/* タブ */

#toppageTab {
  height: 15.94vw;
  /* margin-top: 8.7vw; */
  border-bottom: none;
}

#toppageTab li {
  font-size: 4.6vw;
  line-height: 6vw;
  width: 50%;
  border-left: none;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #000;
  font-weight: 400;
  color: #FFF;
}

#toppageTab li.active {
  background-color: #fff;
  color: #000;
  border: 1px solid #000;
  border-bottom: none;
  font-weight: bold;
}

.tabContent {
  display: none;
  background: #FFF;
  padding-top: 7.97vw;
  padding-bottom: 7vw;
}

.tabContent.active {
  display: block;
}

#Familyfriendly img {
  width: 100%;
  height: auto;
  padding: 0;
}

/* BIKER'S INFO */
.mainmenu {
  display: flex;
  flex-wrap: wrap;
  /* gap: 4.83vw; */
  margin: 0 auto 4.5vw;
  width: 78.75vw;
}

.mainmenu a {
  overflow: hidden;
  width: 100%;
  display: block;

}

.mainmenu a img {
  width: 100%;
}

.mainmenu a.w152 {
  width: 36.71vw;
}

.mainmenu a.w183 {
  width: 44.2vw;
}

.mainmenu a.w123 {
  width: 29.71vw;
}

/* .mainmenu a::after, */
#bannerEverntWrap:after,
#Familyfriendly a:after,
#bannerScheduleWrap:after,
#appInfo:after,
#pcSidepaddingWrap div:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-bottom: 2px solid;
  border-image: linear-gradient(to right, transparent 10%, rgba(255, 255, 255, 1) 10%, rgba(255, 255, 255, 1) 90%, transparent 90%, transparent 100%);
  border-image-slice: 1;
  pointer-events: none;
}

#bannerAutoCampWrap div:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-bottom: 2px solid;
  border-image: linear-gradient(to right, transparent 10%, rgba(255, 255, 255, 1) 10%, rgba(255, 255, 255, 1) 80%, transparent 80%, transparent 100%);
  border-image-slice: 1;
} 
.mainmenu a:last-child:after {
  border-image: none;
  /* border-image-slice: none; */
  border: none;
}


/***********************************************************/
/*
.mainmenu a:last-child:after {
  border-image: none;
  border: none;
}

.mainmenu div a:nth-child(even):after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-bottom: 2px solid;
  border-image: linear-gradient(to right, transparent 0%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 50%, transparent 50%, transparent 50%);
  border-image-slice: 1;
}

.mainmenu div a:nth-child(odd):after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-bottom: 2px solid;
  border-image: linear-gradient(to left, transparent 0%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 50%, transparent 50%, transparent 50%);
  border-image-slice: 1;
}
*/
/***********************************************************/

.btnLandscape {
  height: 15vw;
  width: 100%;
  padding-left: 3vw;
  color: #fff;
  display: flex;
  align-items: center;
  margin-bottom: 4vw;
  border-radius: 1.21vw;
  background-image: url(../img/common/arrowRight.svg);
  background-repeat: no-repeat;
  background-position: 95% 50%;
}

.btnLandscape.green {
  background-color: #727B5E;
}

.btnLandscape.blue {
  background-color: #688484;
}

.btnLandscape.braun {
  background-color: #7B735E;
}

#topfloatingMenu {
  position: fixed;
  display: flex;
  flex-wrap: wrap;
  top: 0;
  left: 0;
  align-items: center;
  justify-content: space-around;
  height: 13.56vw;
  font-weight: bold;
  line-height: 4.62vw;
  width: 36.28vw;
  padding: 2.08vw 7.85vw 2.08vw 2.85vw;
  z-index: 10;
  font-size: 3.33vw;
  background: url(../img/top/appYellowBack.svg) no-repeat;
  background-size: cover;
  cursor: pointer;
}

#topfloatingMenu svg {
  height: 8.28vw;
  width: auto;
}

/* バナー一覧 */
.mainmenu>div {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.mainmenu>div .bannerMsg p:last-child{
  top: initial;
  right: 0;
  left: 0;
  bottom: 4vw;
  text-align: center;
}
.mainmenu .noOrder {
  flex-flow: column;
}

.mainmenu .noOrder>* {
  margin-bottom: 8vw;
}

.mainmenu .fullWideSp {
  width: 100vw;
  margin-left: -10.625vw;
}

#spMainBannerHelfSize {
  display: flex;
  flex-wrap: wrap;
}

#spMainBannerHelfSize>a {
  display: block;
  width: 100vw;
}

/* #spMainBannerHelfSize > a:nth-child(even)::after{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-bottom: 4px solid;
  border-image: linear-gradient(to right, transparent 15%, rgba(255, 255, 255, 1) 15%, rgba(255, 255, 255, 1) 85%, transparent 85%, transparent 85%);
  border-image-slice: 4;
}
#spMainBannerHelfSize > a:nth-child(even)::before{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: -1px;
  width: 100%;
  height: 100%;
  border-left: 4px solid;
  border-image: linear-gradient(to bottom, transparent 15%, rgba(255, 255, 255, 1) 15%, rgba(255, 255, 255, 1) 85%, transparent 0%, transparent 85%);
  border-image-slice: 4;
  z-index: 2;
} */
#spMainBannerHelfSize>a::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-bottom: 2px solid;
  border-image: linear-gradient(to left, transparent 7%, rgba(255, 255, 255, 1) 7%, rgba(255, 255, 255, 1) 90%, transparent 0%, transparent 90%);
  border-image-slice: 2;
}

.layerWrap {
  position: relative;
  width: 100vw;
  height: 77vw;
}

.layerWrap .layer1 {
  padding-top: 5.6vw;
}

.layerWrap .layer1 video {
  width: 100%;
}

.layerWrap .layer2 {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
  padding: 0;
  width: 100%;
}

.mainmenu .fullWideSp img {
  width: 100vw;
  min-width: 100vw;
}


/* #oneDayWrap .bannerMsg {
  background-position: 94% 96%;
  padding: 5vw 0 3vw 25.5vw;
} */


#bannerBigpresent .bannerMsg p:nth-child(2){
  font-size: 4.62vw;
  line-height: 6.41vw;
  font-weight: 500;
  padding: 2vw 0 0;
}
.bannerWrap,
.bannerImgWrap {
  position: relative;
  display: block;
}

.bannerImgWrap img {
  width: 100%;
}

.bannerImgWrap::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0);
  display: block;
  transition: all .4s;
  z-index: 1;
}

a:hover .bannerImgWrap::after,
a:active .bannerImgWrap::after,
.bannerImgWrap:hover::after,
.bannerImgWrap:active::after {
  background: rgba(0, 199, 77, .56);
}
/* a#bannerStamp{
  pointer-events: none;
}
a#bannerStamp:hover .bannerImgWrap::after,
a#bannerStamp:active .bannerImgWrap::after,
#bannerStamp .bannerImgWrap:hover::after,
#bannerStamp .bannerImgWrap:active::after{
  background: none;
} */

#oneDayWrap,
#eventReviewWrap {
  display: block;

}

#eventReviewWrap>div {
  position: relative;
}

#eventReviewWrap .msg {
  position: absolute;
  bottom: 0;
  font-weight: bold;
  top: 48vw;
  left: 43vw;
  width: 27vw;
}

#eventReviewWrap #btnCLICK {
  position: absolute;
  bottom: 3vw;
  left: 45.5vw;
  color: #fff;
  font-weight: bold;
}

.bannerMsgssss {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-flow: column;
  color: #FFF;
  z-index: 2;
  padding: 6vw 0 3vw 9.49vw;
  /*background-image: url(../img/common/arrowRight.svg); */
  background-repeat: no-repeat;
  background-position: 94% 14%;
  background-size: 3vw;
  text-shadow: 0 0 20px rgba(0, 0, 0, .8), 0 0 20px rgba(0, 0, 0, .8);
  transition: all .4s;
}

.bannerMsg p:first-child {
  font-size: 4.36vw;
  font-weight: bold;
  line-height: inherit;
}
.mainmenu .bannerMsg p:last-child{
  top: 8vw;
}
.bannerMsg p:last-child {
  font-size: 2.82vw;
  font-weight: bold;
  line-height: inherit;
  position: absolute;
  right: 10vw;
  top: 8vw;
}
.mainmenu .bannerMsg p:last-child{
  top: 6vw;
}

.bannerMsg p:last-child:before {
  content: "";
  position: absolute;
  width: 3vw;
  height: 3vw;
  display: block;
  left: -4vw;
  background: url(../img/common/arrow.svg) no-repeat left center;
  background-size: contain;
  transform: rotate(-90deg);
}

.bannerMsg h3 {
  font-size: 7.44vw;
  line-height: 7.9vw;
  font-family: "Rockwell","Rokkitt", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: bold;
}

#bannerPhotoWrap {
  display: block;
  margin: 0 0 7.25vw;
}

#bannerPhotoWrap .bannerMsg {
  /* padding: 23vw 0 37vw 23.5vw; */
  background-position: 50% 66%;
  justify-content: center;
  align-items: center;
  padding: 0;
  background: none;
}

#bannerPhotoWrap .bannerMsg h3 {
  font-size: 5.8vw;
}

#bannerPhotoWrap .bannerMsg p {
  font-family: "DIN Alternate Bold", "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  padding-left: 0;
  display: flex;
  flex-flow: column;
  align-items: center;
}

#bannerPhotoWrap .bannerMsg img {
  width: 10.43vw;
  margin: 1vw;
}

#bannerBikersStyleWrap .bannerMsg {
  justify-content: center;
  align-items: center;
  padding: 0;
  background-position: 94% 95.5%;
}

#bannerBikersStyleWrap .bannerMsg::after {
  content: "CLICK";
  font-family: "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 3.2vw;
  position: absolute;
  right: 8.5vw;
  bottom: 2.5vw;
}

#bannerBikersStyleWrap .bannerMsg h3 {
  font-size: 11.11vw;
}

#bannerBikersStyleWrap .bannerMsg p {
  font-size: 4.35vw;
  font-family: "DIN Alternate Bold", "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: 400;
  line-height: 4vw;
}

#bannerExhibitionWrap .bannerMsg p:last-child:before {
  background-image: url(../img/common/arrowBlack.svg);
}
#bannerExhibitionWrap .bannerMsg p:last-child{
  color: #000;
}


/* #bannerScheduleWrap .bannerMsg {
  color: #fff;
  background-image: url(../img/common/arrowRightBlack.svg);
  background-position: 91% 24%;
  text-shadow: none;
  padding-top: 5vw;
} */

/* #bannerScheduleWrap:hover .bannerMsg {
  color: rgb(255, 255, 255);
} */

#bannerScheduleWrap .bannerMsg p:nth-child(2) {
  line-height: 6vw;
}

#pcOrder3 #bannerMapWrap,
#pcOrder3 #bannerAutoCampWrap {
  width: 37.2vw;
}

#bannerMapWrap .bannerImgWrap,
#bannerAutoCampWrap .bannerImgWrap,
#bannerMapWrap img,
#bannerAutoCampWrap img {
  width: 100%;
}

#bannerMapWrap .bannerMsg,
#bannerAutoCampWrap .bannerMsg,
#bannerSightSeeingWrap .bannerMsg {
  background-position: 50% 93.5%;
  padding-left: 0;
  text-align: center;
}
#bannerAutoCampWrap .bannerMsg p:last-child:before,
#bannerMapWrap .bannerMsg p:last-child:before {
  left: 15vw;
}
#bannerAutoCampWrap .bannerMsg::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border-left: 2px solid;
  border-image: linear-gradient(to bottom, transparent 10%, rgba(255, 255, 255, 1) 10%, rgba(255, 255, 255, 1) 90%, transparent 90%, transparent 100%);
  border-image-slice: 1;
}
#bannerMapWrap .bannerMsg p:first-child,
#bannerAutoCampWrap .bannerMsg p:first-child {
  font-size: 3.86vw;
}

/* #bannerSightSeeingWrap {
  margin-top: -3.5vw;
} */

#bannerSightSeeingWrap .bannerMsg {
  background-position: 50% 93.5%;
  padding-left: 9.49vw;
  text-align: left;
}
#bannerSightSeeingWrap .bannerMsg p:first-child{
  font-size: 4.36vw;
}

#bannerAccessWrap .bannerMsg p span {
  font-size: 3.38vw;
}

#bannerAccessWrap .bannerMsg {
  padding-top: 4vw;
  background-position: 94% 33%;
}

#bannerAccessWrap .bannerMsg p:nth-child(2) span,
#bannerRentalBike .bannerMsg p:nth-child(2){
  display: block;
  line-height: 6.41vw;
  font-size: 4.36vw;
  font-weight: 600;
  margin-top: 3vw;
}

/* バナー一覧 */

/* アプリ */
#appInfo {
  position: relative;
  height: 110.26vw;
  background: url(../img/top/spAppBg.png) no-repeat;
  background-size: 100% auto;
}

#appInfo h3 {
  font-size: 5.13vw;
  line-height: 6.41vw;
  font-weight: 500;
}

#appInfo .bannerMsg {
  text-align: center;
  position: relative;
  height: 100%;
  display: block;
  padding: 5.9vw 0 0;
  pointer-events: none;
}

#appInfo .bannerMsg p {
  margin: 4vw 0 0;
  font-size: 3.3vw;
  line-height: 4.25vw;
}

#appInfo .bannerMsg p:last-child {
  font-size: 2.82vw;
  font-weight: normal;
  line-height: inherit;
  text-align: left;
  position: relative;
  bottom: 0;
}

#appInfo p img {
  width: 67.18vw;
}

#appInfo .controllScrollOver {
  width: 100%;
  position: absolute;
  bottom: 8.79vw;
  left: 0;
  margin: 0;
}

#appInfo .controllScrollWrap {
  width: 100%;
  height: auto;
}

#appInfo .controllScrollWrap img {
  width: 67.62vw;
  height: auto;
  margin-right: 14.1vw;
}

#appInfo ul {
  width: 80%;
  margin: auto;
  padding: 34.36vw 0 0;
  display: flex;
  bottom: 8.21vw;
  overflow: scroll;
}

#appInfo ul li img {
  height: 64.62vw;
  max-width: none;
}

#appInfo .controllScrollItemWrap {
  margin-left: 19vw;
  width: 247vw;
}

#appBtn {
  height: 10.41vw;
  width: 67.18vw;
  display: flex;
  justify-content: space-between;
  margin: 57vw auto 0;
  pointer-events: initial;
}

#appBtn img {
  height: 100%;
  width: auto;
}

#appInfo .controllScrollButtonWrap {
  width: 93.28vw;
  margin: auto;
  right: 0;
  top: 35%;
}
#appInfo .controllScrollButtonWrap button{
  width: 10vw;
  height: 10vw;
}

#appInfo .controllScrollButtonWrap svg {
  fill: #fff;
  height: 3vw;
}

#appInfo .controllScrollButtonPrev svg {
  transform: rotate(180deg);
}

/* NEWS */
#newsSection {
  margin: 0 auto;
  width: 100vw;
  /* height: 61.54vw; */
  padding: 5.13vw;
  border: 3.85vw solid #FFE200;
  overflow: hidden;
}

#newsWrap .controllScrollButtonWrap {
  display: none;
}

#newsWrap .controllScrollOver {
  padding: 0;
  margin: 0;
  width: 100%;
}

#newsWrap .controllScrollWrap {
  width: 100%;
  height: auto;
}
#newsWrap .controllScrollWrap .controllScrollItem:nth-child(n+3){
  display: none;
}

.newsLinkWrap #newsSection>h2,
#newsSection h3 {
  border-bottom: 2px solid #000;
  padding-bottom: 3.75vw;
  font-size: 6vw;
  font-family: "Rockwell","Rokkitt", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-weight: bold;
  display: flex;
  align-items: center;
}

#newsSection>h2::after {
  content: "";
  display: block;
  background: url(../img/common/arrowRightBlack.svg) no-repeat 100%;
  width: 3vw;
  height: 5.59vw;
  margin-left: 3vw;
  background-size: 4vw;
  transition: all 0.5s 0s ease;
}

#newsSection h3 {
  border: none;
  padding-bottom: 0;
  font-size: 8.8vw;
}

#newsSection .newsLinkWrap a {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #000;
  padding-bottom: 1.75vw;
  margin-bottom: 1.85vw;
}

#newsWrap .newsLinkWrap a p {
  display: flex;
  font-size: 3.62vw;
  align-items: center;
}

#newsWrap .newsLinkWrap a p span svg {
  width: 4.68vw;
  height: auto;
  /* transform: rotate(180deg); */
  margin-left: .5vw;
}

.news_set,
.news {
  background: #FFF;
  width: 81.54vw;
  border-radius: 3vw;
  position: relative;
  box-shadow: 3px 3px 5px #ccc;
  padding: 2.5vw 5.9vw;
  transition: all .4s;
  font-size: 3.02vw;
  line-height: 5.56vw;
}

#newsSection .controllScrollOver {
  margin: 0;
}

#newsSection .controllScrollItemWrap {
  flex-flow: column;
  width: 100%;
}
#newsSection .controllScrollItemWrap .news_set,
#newsSection .controllScrollItemWrap>dl {
  background: #FFF;
  width: 81.54vw;
  border-radius: 3vw;
  position: relative;
  box-shadow: 3px 3px 5px #ccc;
  padding: 1.25vw 5.9vw 3vw;
  transition: all .4s;
  line-height: 4vw;
}

#newsSection .controllScrollItemWrap .news_set::after,
#newsSection .controllScrollItemWrap>dl::after {
  content: "";
  background: url(../img/top/arrowBottom.svg) no-repeat center center;
  position: absolute;
  display: block;
  width: 3.47vw;
  height: 3.09vw;
  right: 4.87vw;
  top: 5.5vw;
  bottom: 0;
  background-size: cover;
  transition: all 0.5s 0s ease;
}
#newsSection .controllScrollItemWrap .news_set.active::after,
#newsSection .controllScrollItemWrap > dl.active::after{
  transform: rotate(180deg);
}
#newsSection .controllScrollItemWrap .news_set summary,
#newsSection .controllScrollItemWrap > dl h4{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-right: 1vw;
}
#newsSection .controllScrollItemWrap .news_set.active summary,
#newsSection .controllScrollItemWrap > dl.active h4{
  overflow: initial;
  text-overflow: initial;
  white-space: initial;
}
#newsSection .controllScrollItemWrap .news_set p,
#newsSection .controllScrollItemWrap dd p {
  display: none;
}
#newsSection .controllScrollItemWrap .news_set.active p,
#newsSection .controllScrollItemWrap .active dd p {
  display: block;
}

.imgOverText {
  position: relative;
  margin-left: -10.625vw;
  width: 100vw;
}

.imgOverText h2 {
  position: absolute;
  left: 0;
  top: 13vw;
  display: flex;
  justify-content: center;
  width: 100%;
}

#bannerYoutube .bannerMsg {
  text-align: center;
  padding: 1.13vw 0 3vw 0;
}

#bannerYoutube h3 img {
  width: 50.46vw;
  margin-left: 7vw;
  margin-bottom: -5vw;
}
#bannerYoutube p {
  font-size: 5.13vw;
  font-weight: 500;
  line-height: 7.25vw;
  margin-left: 7vw;
  font-family: "Noto Sans", 游ゴシック体, YuGothic, 游ゴシック, "Yu Gothic", メイリオ, sans-serif;

}

#bannerYoutube .bannerMsg p:last-child {
  font-size: 2.82vw;
  line-height: inherit;
  position: relative;
  right: initial;
  top: 5vw;

}
#bannerYoutube .bannerMsg p:last-child:before{
  left: 36vw;
}
#bannerRentalBike div:after {
  border-bottom: none;
}
#bannerStamp h3 img {
  width: 78.46vw;
  height: auto;
  position: absolute;
  left: 5.5vw;
  top: .8vw;
}

/* NEWS */
/* スポンサー */
.sponsor {
  padding-bottom: 6vw;
}

.bgBeige {
  background-color: #798178;
}

.list_ttl {
  width: 100%;
}

.sponsor .controllScrollOver,
.sponsor .swiperWrap {
  margin: 0;
}

.sponsor .controllScrollWrap,
.sponsor .swiper {
  height: 20.2vw;
  width: 48.48vw;
  margin: auto;
  border-radius: 5px;
}

.sponsor .swiper-next,
.sponsor .swiper-prev {
  background: url(../img/common/arrowRight4sliderWhite.svg) 25% center no-repeat;
  width: 25vw;
  height: 20vw;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  cursor: pointer;
}

.sponsor .controllScrollWrap>ul {
  flex-flow: nowrap;
}

.sponsor .controllScrollWrap>ul {
  display: flex;
  /* height: 20vw; */
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  /* background-color: #fff; */
  text-align: center;
  margin: auto;
  border-radius: 1.21vw;
  position: relative;
}

.sponsor .controllScrollWrap>ul li {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  text-align: center;
  margin: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  opacity: 0;
  transition: all .6s;
  z-index: 1;
}

.sponsor .controllScrollWrap>ul li a {
  display: flex;
  justify-content: center;
  align-items: center;
}

.sponsor .controllScrollWrap a::after {
  display: none;
}

.sponsor .controllScrollWrap>ul li.active {
  opacity: 1;
  z-index: 2;
}

.sponsor .controllScrollWrap>ul li.done {
  opacity: 0;
  z-index: 3;
}

.sponsor .controllScrollWrap>ul li img {
  width: 100%;
  padding: 0 5vw;
  height: auto;
}

.sponTTl {
  font-size: 5.8vw;
  font-weight: 300;
  text-align: center;
  padding: 8vw 0 7vw;
  color: #fff;
  font-family: "Bebas Neue", "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-family: "Oswald", "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  color: #FFF;
}

.sponLink {
  display: block;
  text-align: center;
  border-bottom: 2px solid #fff;
  border-bottom: 2px solid #FFF;
  color: #FFF;
  padding: 6.5vw 7vw 2vw 0;
  margin: 0 auto 3.5vw;
  width: 33.59vw;
  text-align: left;
  font-size: 3.14vw;
  font-weight: bold;
  background-image: url(../img/common/arrowRightBlack.svg);
  background-image: url(../img/common/arrowRight.svg);
  background-repeat: no-repeat;
  background-position: 100% 80%;
  background-size: 4vw;
  color: #fff;
}

/* スポンサー */
.footerTopLink {
  padding: 11.25vw 11vw 13vw;
}

.footerTopLink li {
  width: 34.3vw;
  padding-bottom: 2vw;
  border-bottom: 2px solid #000;
  font-size: 3.14vw;
}

.footerTopLink li::after {
  width: 3vw;
  height: 5.59vw;
  background-size: 4vw;
}