@charset "UTF-8";
/*トップページのみCSS*/

.l-main__body > .c-postContent{
	margin: 0;
}
.home #content .l-container {
  padding-left: 0;
  padding-right: 0;
  max-width: 100vw;
}

.home #content .l-article {
  max-width: 100%;
}

.content-inner {
  width: 80%;
  margin: 80px auto;
}
@media (max-width:1366px) {
  .content-inner {
    width: 90%;
  }  
}
@media screen and (max-width: 767px) {
  .content-inner {
    width: 100%;
  }  
}


.home section li:not(.slide-box) a {
  color: #231815;
  text-decoration: none;
}

.home h2{
  font-size: clamp(30px, 4.4vw, 42px);
  font-size: clamp(26px, 3.8vw, 40px);
  line-height: 1.5;
  margin-bottom: 15px;
	font-weight: 450;
}
.home .category_ttl{
  font-size: clamp(19px, 3vw, 20px);
  font-weight: 450;
}
.home .feature_item{
  position: relative;
}
.home .feature_item .feature_text{
  position: absolute;
  bottom: 5px;
  left: 10px;
  color: #fff;
  text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
  font-size: clamp(18px, 1.6vw, 21px);
  font-weight: 450;
	z-index: 1;
}

/*------ メインスライド -------*/

.main-slide {
  background-color: #fff;
}

.main-slide .slider {
  position: relative;
  margin-left: 0;
  margin-right: 0;
}
.main-slide .slick-list{
  margin-left: 0;
  margin-right: 0;
}
.slick-slide img {
  width: 100%;
  /*  height: calc(95vh - 74px);*/
  object-fit: cover;
  height: 90vh;
}

.main-slide .national-park::before{
	content: "";
	width: 90%;
	height: 90px;
	background: url("../img/parks.png") no-repeat;;
	background-size: contain;
	display: block;
	position: absolute;
	left: 50%;
	top:85px;
  bottom: 5.4vh;
  transform: translateX(-50%);
	z-index: 1;
}

.main-slide .slide-text {
  position: absolute;
  left: 50%;
  bottom: 5.4vh;
  transform: translateX(-50%);
  text-align: left;
  color: #fff;
  z-index: 1;
  display: block;
  background: radial-gradient(rgba(0, 0, 0, 0.2) 0%, transparent 60%);
  width: 90%;
}
.main-slide .slide-text h1 {
  font-size: clamp(26px, 3.8vw, 40px);
  line-height: 1.1;
  font-weight: 450;
  margin-bottom: 10px;
}

.main-slide .slide-text p {
  font-size: clamp(15px, 2.3vw, 22px);
  line-height: 1.2;
}

.main-slide .btn {
  font-size: 16px;
}

.main-slide .slick-dots {
  bottom: 50px;
  padding-left: 0 !important;
  text-align: right;
  padding-right: 3%;
  display: none !important;
}

.main-slide .slick-dots li.slick-active button:before,
.main-slide .slick-dots li button:before {
  color: #fff;
}

.main-slide .slick-dots li button:before {
  opacity: 0.5;
  font-size: 9.5px;
}

.main-slide .slick-dots li.slick-active button:before{
  opacity: 1;
}
.main-message.content-inner {
  margin: 40px auto 60px;
}


/* video */

.main-slide .slide-box {
  position: relative;
  overflow: hidden;
  width: 100vw;
  /*  height: calc(90vh - 74px);*/
  z-index: -100;
  height: 90vh;
}

.main-slide .slide-box a {
  z-index: 99999;
}

.main-slide .youtube-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  min-width: 1920px;
  min-height: calc(90vh - 75.28px);
  transform: translate(-50%, -50%);
  z-index: -1;
  min-height: 90vh;
}


/* overlay */
.overlay::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  background: rgba(0, 0, 0, 0.2);
  z-index: 0;
}

.overlay.first::before {
  /*background: rgba(0, 0, 0, 0.1);*/
}

.overlay::after {
    background: linear-gradient(180deg, #23181500, #00000075 30%, #000000b0);
    bottom: 0;
    content: "";
    height: 29%;
    left: 0;
    position: absolute;
    width: 100%;
    z-index: 0;
}



/*キャッチコピー*/
.home.page .main-message h2 {
  font-size: clamp(22px, 2.5vw, 40px);
  /*  margin-bottom: 0.5em;*/
  line-height: 1.5;
}

.home .main-message p {
  font-size: clamp(16px, 1.3vw, 22px);
}

/*------ NEWS -------*/

.news {
  background: #f8f9fa;
	padding: 70px 0;
}

.news .content-inner {
  position: relative;
  margin: 0 auto;
}

.news .error {
  font-size: 14px;
}

.news h2 {
  margin-bottom: 30px;
}

.news a {
  margin-bottom: 1em;
  display: flex;
  align-items: baseline;
}

.news .news__title {
  font-size: clamp(14px, 1vw, 16px);
}

.news .news__date {
  margin-right: 1.5em;
  color: #666;
  font-size: clamp(14px, 1vw, 16px);
  min-width: 5.5em;
}
#section_news .btn{
  font-size: 14px;
  max-width: 160px;
  border:1px solid #000;
} 
#section_news .content-inner{
  display: flex;
  width: 750px;
  max-width: 80%;
}
.news_title{
  margin-right: 50px;
}

/*------ コンテンツ -------*/
#section_category .category_nav{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.category_link_list a{
  font-size: clamp(26px, 5vw, 46px);
  display: block;
  line-height: normal;
  font-weight: 450;
}
.category_link_list a span{
  font-size: clamp(26px, 4vw, 40px);
}
.category_link,.category_img{
  max-width: 32.5rem;
  width: 100%;
  margin-bottom: 80px;
}
.category_img{
  width: 38%;
}

.category_img img {
    opacity: 1;
    transition: opacity 0.5s ease;
    width: 100%;
    aspect-ratio: 3 / 4;
    display: flex;
    align-items: center;
    justify-content: center;
    object-fit: cover;
}

.category_img img.is-fade {
  opacity: 0.8;
}

.top_feature_img {
  width: 100%;
  aspect-ratio: 3 / 4;
  overflow: hidden;
}
.top_feature_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.home .feature_flex.over .feature_item {
    flex: 0 0 22%;
}
@media screen and (min-width: 1367px){
  #section_category .category_nav {
      /*width: 80%;*/
      margin: auto;
  }
	.category_img img {
			/*aspect-ratio: 3 / 3;*/
	}
}
@media screen and (max-width: 920px) {
	.category_img{
		width: 100%;
	}
}
@media screen and (max-width: 767px) {
  .main-slide .slick-dots {
    bottom: 20px;
  }
  .front-contents-section{
    padding: 0 5%;
  }
  .front-contents-section.news{
    padding: 50px 5% 30px;
  }
  .category_img{
    display: none;
  }
  .category_link{
    margin-bottom: 30px;
    width: 100%;
    max-width: 100%;
  }
  #section_news .content-inner{
    display: block;
    width: 100%;
    max-width: 100%;
  }

  .feature_flex_over_wrap,
  .feature_flex_wrap{
    width: calc(100vw * 0.95);
  }
  .home .feature_flex.over .feature_item {
    flex: 0 0 70%;
  }
  .home .feature_item .feature_text {
    font-size: clamp(15px, 3.7vw, 20px);
  }
  .home .category_ttl {
    font-size: clamp(14px, 3vw, 16px);
  }
  .category_link_list a {
    font-size: clamp(30px, 4.4vw, 42px);
    display: flex;
    align-items: center;
  }
  .category_link_list a span {
    font-size: clamp(23px, 4vw, 26px);
		padding-left: 10px;
  }
  .content-inner {
    margin: 70px auto;
  }
  .category_link_list{
    display: grid;
    gap: 4px;
  }
}

@media screen and (max-width: 480px){
  .overlay::after {
    height: 34%;
  }
}





/* トップ　スライド */
.slider-ui {
    max-width: 100%;
}
.scroll-container {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE */
}
.scroll-container::-webkit-scrollbar {
    display: none; /* Chrome, Safari */
}
.feature_item.item {
    flex: 0 0 280px;
    scroll-snap-align: start;
    display: flex;
    align-items: flex-end;
}
.slider-nav {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-top: 24px;
    height: 3rem;
}
.slider-nav .arrow {
    color: #000;
    border: none;
    background: #00000000;
    font-size: 24px;
    cursor: pointer;
    transition: opacity 0.3s;
    width: 3rem;
    height: 3rem;
    line-height: 1;
    border-radius: 50%;
    transition: all 0.3s ease-out;
}
.slider-nav #nextBtn.arrow {
    margin-right: 10px;
}
.slider-nav .arrow:hover {
    background-color: #013087;
    border-color: #013087;
    color: #fff;
    opacity: 1;
    border-radius: 50%;
}
.slider-nav .arrow.disabled {
    opacity: 0.3;
    pointer-events: none;
}
.progress {
    width: 300px;
    height: 2px;
    background: #ccc;
    position: relative; /* 子要素の基準にするため必須 */
    overflow: hidden;
}
.progress-bar {
    position: absolute; /* absoluteに変更 */
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    background: #000;
    transition: left 0.2s linear, width 0.2s linear; /* leftを監視 */
}
.feature_item.item:last-child {
    margin-right: 30px;
}



/* カテゴリースライダー専用設定 */
#slider-category .scroll-container {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
#slider-category .scroll-container::-webkit-scrollbar {
    display: none;
}
#slider-category .feature_item.item {
    flex: 0 0 280px;
    scroll-snap-align: start;
    display: flex;
    align-items: flex-end;
}

#slider-category .slider-nav {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-top: 24px;
}

@media screen and (max-width: 767px) {
  .slider-nav .arrow {
    display: none;
  }
  .feature_item.item {
    margin-right: 0;
  }
  .progress {
    width: 200px;
  }
}

@media screen and (max-width: 480px) {
    .slider-nav {
      margin-top: 15px;
      justify-content: center;
      margin-left: -5%;
    }
  #slider-category .feature_item.item {
      flex: 0 0 260px;
      scroll-snap-align: start;
      display: flex;
      align-items: flex-end;
    }
    .feature_item.item:last-child {
      margin-right: 15px;
    }
}

/* 商品スライダー専用設定 */
#slider-product .recommend_flex.scroll_contents {
    display: flex;
    gap: 16px;
    padding: 0;
    margin: 0;
    list-style: none;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
#slider-product .recommend_flex.scroll_contents::-webkit-scrollbar {
    display: none;
}
#slider-product .recommend_item {
    flex: 0 0 270px;
    scroll-snap-align: start;
    margin-right: 0;
}
#slider-product{
      margin-top: 25px;
}
@media screen and (max-width: 480px) {
    #slider-product .recommend_item {
        flex: 0 0 190px;
    }
    #slider-product .recommend_item:last-child {
    margin-right: 15px;
    }
}

/* トップページシーン・ホビーが繋ぐもの・ホビーのミッションスライダー専用設定 */
#slider-scene .scroll-container,#slider-connect .scroll-container,#slider-mission .scroll-container {
    overflow-x: inherit;
    scroll-behavior: inherit;
    scroll-snap-type: inherit;
    scrollbar-width: inherit;
}
#slider-scene .feature_item.item,#slider-connect .feature_item.item,#slider-mission .feature_item.item {
    flex: 1;
}
.feature_flex_over_wrap.common_feature_flex_over_wrap {
    width: 100%;
}
#slider-scene .feature_item.item:last-child,#slider-connect .feature_item.item:last-child,#slider-mission .feature_item.item:last-child {
    margin-right: 0px;
}
#slider-scene .slider-nav,#slider-connect .slider-nav,#slider-mission .slider-nav {
    display: none;
}
@media screen and (max-width: 767px) {
  .feature_flex_over_wrap.common_feature_flex_over_wrap {
    width: calc(100vw * 0.95);
}
#slider-scene .feature_item.item,#slider-connect .feature_item.item,#slider-mission .feature_item.item {
    flex: 0 0 330px;
}
#slider-scene .scroll-container,#slider-connect .scroll-container,#slider-mission .scroll-container {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
#slider-scene .slider-nav,#slider-connect .slider-nav,#slider-mission .slider-nav {
    display: flex;
}
#slider-scene .feature_item.item:last-child,#slider-connect .feature_item.item:last-child,#slider-mission .feature_item.item:last-child {
    margin-right: 30px;
}
}

@media screen and (max-width: 480px) {
  #slider-scene .feature_item.item,#slider-connect .feature_item.item,#slider-mission .feature_item.item {
      flex: 0 0 260px;
    }
    #slider-scene .feature_item.item:last-child,#slider-connect .feature_item.item:last-child,#slider-mission .feature_item.item:last-child {
      margin-right: 15px;
    }
}

/* フローティング追加202605 */
#floating_bnr{
	background: #fff;
	position: fixed;
	transform: translateX(0) translateY(-50%);
	right: 0;
	top: 50vh;
	display: flex;
	border-radius: 6px 0 0 6px;
	box-shadow: 0 0 8px rgba(0, 0, 0, .16);
  transition: transform 0.4s ease;
  z-index: 9999;
}
#floating_bnr.is-hidden {
  transform: translateX(110%) translateY(-50%);
}

#floating_bnr .arrow-round {
  position: relative;
  display: inline-block;
  padding: 8px;
  border: 2px solid #000;
  border-radius: 50%;
  top: 5px;
	margin-bottom: 5px;
}
#floating_bnr .arrow-round::before {
  content: '';
  width: 8px;
  height: 8px;
  border-top: solid 2px #000;
  border-right: solid 2px #000;
  position: absolute;
  transform: rotate(45deg);
  left: 3px;
  top: 4px;
}
#floating_bnr .arrow-round.arrow-right::before {
}
#floating_bnr a{
	padding: 10px 6px 15px 4px;
	font-size: 13px;
	text-align: center;
	color: #000;
	font-weight: 500;
}
#floating_bnr a:hover{
	opacity: 0.8;
}
#floating_bnr p{
	writing-mode: vertical-rl;
	line-height: 1.5
}