@charset "utf-8";

/*-----------------------------
カテゴリ一覧
-----------------------------*/

/* ========== top ========== */
.site-main{
    background: 
  linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0)),
  url('../img/other/hero02.jpg') center / cover no-repeat;
    padding: 150px 0 0;}
main::after{
  content:"";
  display:block;
  width:100%;
  height:200px;
  background:url(../img/top/main_footer_bg.png) center 50px/120% no-repeat;
}

/* ========== Hero ========== */
.hero02{
  padding:1em 0;
}
.hero02 .logo{width:250px;margin:2em auto;display:block;}
.hero02 .txt{width:450px;margin:1em auto;display:block;}
.hero02-content h1{
    color: #fff;
    font-size: 2.5rem;
    margin: 0 ;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
    background-image: url(../img/top/nature-section_bg.svg);
    background-position: center;
    background-size: 450px;
    background-repeat: no-repeat;
    padding:1.5em 0;
}
.tours h2.logo_title{
    font-size: 2.5rem;
    font-weight: 900;
    background-image: url(../img/top/about_title_rubi.svg);
    background-position: 75% 30%;
    background-size: 500px;
    background-repeat: no-repeat;
    width: auto;
    margin: 0 auto;
}
.tours a {
    box-shadow: 0 0 5px #999;
    border-radius: 20px;
}
.tours h2.logo_title img{
    width: 200px;
    vertical-align: bottom;
    padding: 0 0.5em;
}
.tours .text{
    width: 90%;
    margin: 20px auto;
    max-width: 1200px;
    font-size: 1.2em;
    line-height: 1.8em;
}
.nature-section h2 {
    background-position: 80% 20%;
}    
.nature-section h2{
    color: #fff;
    font-size: 3.5rem;
    margin: 0;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
    padding: 1em 0 0;
}
.nature-section h2 img {
    padding: 1.5em 0;
}
.category_menu{background:url('../img/other/category_menu.jpg') center/cover no-repeat;}
.category_menu::before {
    content: "";
    display: block;
    width: 100%;
    height: 200px;
       background: url(../img/top/guide_top.png) center / cover no-repeat;
}
.category_menu::after{
  content:"";
  display:block;
  width:100%;
  height:200px;
  background:url(../img/top/main_footer_bg.png) center 50px/120% no-repeat;
}
.category_menu h2{
    color: #fff;
    font-size: 2rem;
    margin: 0 ;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
}
.category_menu ul{
  width:80%;
  margin:0 auto;
  list-style:none;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:1em;
  padding:3em 0;
  justify-content:space-between;
}
.category_menu ul li{width:20%;  text-align: center;}

@media screen and (max-width: 1024px) {
    .category_menu ul li {
        width: 100%;
        text-align: center;
    }
}
.category_menu ul li a{
  font-family: "ten-mincho", serif;
  font-weight: 400;
  font-style: normal;
  color:#fff;
  background-image:url(../img/common/btn_next_smaller.svg);
  background-position:right center;
  background-repeat:no-repeat;
  padding:0 20px 0 0;
}
.about_gallery-caption{
  color:#fff;
}

.reserve-plus{
  width: 280px;
  margin: 0 auto;
  padding: 1.5em 1em;
  height: 30px;
 } 
.sales::before {
    background: url(../img/top/guide_top.png) center / cover no-repeat;
}
.sales h2{
    background: url(../img/other/手配.svg)80% center / cover no-repeat;
    background-size: 600px;
}
.sales h2 img {
    padding: 0.5em;
}
.waterfall-item .image-area .title-svg {
    position: initial;
     max-width:  initial;
    transform: initial;
}
/* アクセスページ */

.access-top h2,.sales-top h2{
    background-position: 80% 5%;
    padding: 1em 0 0;
    margin-bottom: -40px;
}
#access_title{
    background: url(../img/other/access_logo.svg)top center / cover no-repeat ;
    background-size: 500px;
    background-position: 80% 0;
}
.access::before {
    background: url(../img/top/guide_top.png) center / cover no-repeat;
}
.access-car{
  display: flex;
  flex-wrap: wrap;
  gap: 5%;
}
.access-block {
  margin: 0 auto 40px;
}
.access-img {
  width: 100%;
    height: 200px;
    object-fit: cover;
    object-position: center;
    display: block;
    border-radius: 10px;
    margin-bottom: 10px;
}
.access h3 {
    color: #fff;
    font-size: 2.8rem;
    margin: 0 0 10px;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
}
.access h4 {
    color: #fff;
    font-size: 1.8rem;
    margin: 0 0 10px;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
}
.access p, .access ul li{
    color: #fff;
}
.access .about_gallery-caption{
  color: #000;
}
.about h2 {
    background-image: url(../img/top/about_title_rubi.svg);
    background-position: 80% 64%;
    background-size: 600px;
    background-repeat: no-repeat;
    width: auto;
    margin: 0 auto;
    padding: 5em 0 0;
}
.access-guide::before {
    content: "";
    display: block;
    width: 100%;
    height: 200px;
    background: url(../img/top/bg_sobo.png) center / cover no-repeat;
}
.nature-section.access{
    background-repeat:no-repeat,no-repeat,no-repeat;
    background-position:center top,99% 15%,center top;
    background-size:cover,400px,cover;
}
.access-guide{
        background: url(../img/top/waterfall-gallery_bird.svg) 95% 10% / 380px no-repeat, linear-gradient(to bottom, #66b9ff 0%, #0074d9 100%) center / cover no-repeat;
    }
.access-block02 {
    max-width: 1200px;
    margin: 0 auto 40px;
    display: flex;
    gap:1%;
}
.access-block03 p{
    font-size: 1.1rem;
   margin:0 auto;
}
.access-block03 ul{
   margin:0 auto;
}
.access-block03 ul li{
   color: #fff;
    font-size: 0.7rem;
    list-style: disc;
}
.access-block02 h3{
    color: #fff;
    font-size: 2.5rem;
    margin: 0 0 10px;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
    background-image: url(../img/top/guide_title_rub.svg);
    background-position: center;
    background-size: 200px;
    background-repeat: no-repeat;
    width: auto;
    margin: 0 auto;
}
.access-block02 h4{
    color: #fff;
    font-size: 1.8rem;
    margin: 0 0 10px;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
}
.btn_map{
    background: #41C364;
    box-shadow: 3px 3px 5px rgb(33 33 33 / 33%);
    text-decoration: none;
    display: flex;
    justify-content: center;
    border-radius: 40px;
    margin: 0 0 5px;
    height: 30px;
    width: 280px;
    margin: 0 auto;
    padding: 1.5em 1em;
    height: 30px;
}
.add{
  max-width: 1200px;
  margin: 0 auto;
}
.access-table{
    text-align: left;
    margin: 0 auto;
    margin-right: 0;
}

.access-table th{
  border-bottom:1px solid;
  padding:5px;
}
.access-table td{
  border-bottom:1px solid #ccc;
  padding:5px;
}
/* faq　よくある質問 */
.faq-top{
    background: none;
}
.faq-top h2{
    background-position: 80% 5%;
    padding: 1em 0 0;
    margin-bottom: -40px;
}
.faq-top::after{
    content: "";
    display: block;
    width: 100%;
    height: 200px;
    background: url(../img/top/main_footer_bg.png) center 50px / 120% no-repeat;
}

.faq-wrap {
    display: flex;
    gap:3em;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto 40px;
}
.faq {
   width:48%;
}
.faq p{
   padding:0;
   margin: 20px 0;
}
.faq p::before {
    content: "A. ";
    font-weight: 600;
}
/* ===== FAQ全体設定 ===== */
.faq details {
  overflow: hidden;
  border-bottom: 4px dotted #b6e8c3;
  margin-bottom: 0.8em;
  transition: all 0.4s ease;
}

/* summary部分 */
.faq summary {
  font-size: 1.3rem;
  line-height: 1.5em;
  cursor: pointer;
  list-style: none;
  position: relative;
  padding: 0 2em 0.5em 0;
  font-weight: 600;
  transition: color 0.3s ease;
}

.faq summary:hover {
  color: #005eb8;
}

/* デフォルトの▶マーカーを消す */
.faq summary::-webkit-details-marker {
  display: none;
}

/* ＋アイコン */
.faq summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 0;
  font-size: 1.8rem;
  font-weight: 900;
  color: #008cd6;
  transform: rotate(0deg);
  transition: transform 0.4s ease, color 0.3s ease;
}

/* open時（−に変化＋回転） */
.faq details[open] summary::after {
  content: "−";
  color: #005eb8;
  transform: rotate(180deg);
}

/* ===== 開閉アニメーション部分 ===== */
.faq details > div {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-0.3em);
  transition:
    max-height 0.6s ease,
    opacity 0.4s ease,
    transform 0.4s ease;
}

/* open時（スルッと開く） */
.faq details[open] > div {
  max-height: 600px; /* 内容に応じて調整 */
  opacity: 1;
  transform: translateY(0);
  padding-top: 0.6em;
}


.faq-table{
text-align: left;
}

.faq-table th{
  border-bottom:1px solid;
  padding:5px;
}
.faq-table td{
  border-bottom:1px solid #ccc;
  padding:5px;
}
/* creative パンフレット制作*/

.creative h2 {
    background: url(../img/other/price.svg) 80% center / cover no-repeat;
    background-size: 300px;
    background-position: 70% 5%;
}
.creative::before {
    background: url(../img/top/guide_top.png) center / cover no-repeat;
}
.creative-top h2{
    background-position: 80% 5%;
    padding: 1em 0 0;
    margin-bottom: -40px;
}
/*個人情報保護*/
.privacy-policy{
   width:90%;
   max-width: 1200px;
   margin: 0 auto;
}

.privacy-policy dt{
    font-size: 2.2rem;
    margin: 40px 0 10px;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
}
.privacy-policy dd{
    font-size: 1rem;
    margin: 0;
}
.privacy {
    background: none;
}
.privacy h2{
    background-position: 80% 5%;
    padding: 1em 0 0;
    margin-bottom: -40px;
}
/*服装持ち物*/
.equipment-top p {
    margin: 40px auto 0;
}
.equipment-top h2{
    background-position: 80% 5%;
    padding: 1em 0 0;
    margin-bottom: -40px;
}
.equipment h2 img {
    padding: 0.5em 0;
}
.equipment h3 {
    color: #fff;
    font-size: 2.5rem;
    margin: 0 0 10px;
    font-family: "ten-mincho", serif;
    font-weight: 400;
    font-style: normal;
    text-align: center;
}
.equipment::before {
    background: url(../img/top/guide_top.png) center / cover no-repeat;
}
.equipment-table{
text-align: left;
color:#fff;
}
.equipment-table th{
  border-bottom:1px solid;
  padding:5px;
  width:20%;
}
.equipment-table td{
  border-bottom:1px solid #ccc;
  padding:5px;
}
.equipment .waterfall-item .image-area img.photo {
    height: 500px;
}
/*conditions　旅行条件*/
.conditions-top{
    background:none;
}
.conditions-top h2{
    background-position: 80% 5%;
    padding: 1em 0 0;
    margin-bottom: -40px;
}

.conditions-list{
   width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; /* ←両端寄せ */
  gap: 20px 0; /* 行間調整 */
  padding: 0;
  list-style: none;
    }
.conditions-list li{
    flex: 0 1 calc(33.333% - 20px); /* ←3列配置にする */
  font-size: 1.2em;
  font-weight: 700;
  box-sizing: border-box;
    }   
.conditions-list li a {
    display: block;
  text-align: center;
  padding: 1em 0;
  background-color: #41C364;
  border-radius: 40px;
  box-shadow: 3px 3px 5px rgb(33 33 33 / 33%);
  background-image: url(../img/common/btn_next_smaller.svg);
  background-position: 95% center;
  background-repeat: no-repeat;
  padding: 10px 20px 10px 0;
  color: #fff;
  text-decoration: none;
}
/*問い合わせ*/
.contact-top{
    background:none;
}
.contact-top h2{
    background-position: 80% 5%;
    padding: 1em 0 0;
    margin-bottom: -40px;
}



/* ========== Responsive: <=1024px ========== */
@media screen and (max-width:1024px){
.site-main {
    background: url(../img/other/hero02.jpg) center / cover no-repeat;
}
main::after {
    height: 150px;
    }
.hero02-content h1{
    font-size: 2rem;
    margin: 0 ;
    background-size: 300px;
    padding:1.5em 0;
}
.tours h2.logo_title{
    font-size: 1.6rem;

}
.tours h2.logo_title img{
    width:200px;
    display: block;
}
.category_menu::after{
  height:150px;

}
.category_menu ul li{width:100%;font-size: 1.2em; 
}

.tours h2.logo_title {
    background-size: 300px;
    background-position: center;
}

.sales h2{
    background: url(../img/other/手配.svg)top center / cover no-repeat;
    background-size: 300px;
}
#access_title{
    background-size: 300px;
    background-position: center top;
}
.access-car{
  display: initial;
  flex-wrap: wrap;
  gap: 5%;
}
.access-block {
  margin: 0 auto 20px;
  width: 95%;
}
.access-img {
    border-radius:initial;

}

.access-block02 {
    display: initial;
}
.access-block03 ul {
    margin: 20px auto;
    width: 85%;
    padding-left: 40px;
}
.access-block03 ul li{
    font-size:1em;
}
.access-guide::before {
    height: 100px;
}
.access-guide {
    background: url(../img/top/waterfall-gallery_bird.svg) top right / 380px no-repeat, linear-gradient(to bottom, #66b9ff 0%, #0074d9 100%) center / cover no-repeat;
}
.about h2 {
    background-position: 90% 70%;
    background-size: 180px;
}
.faq-wrap {
    display: initial;
}
.faq-top::after {
            height: 100px;
        }
.faq {
   width: 90%;
   margin: 0 auto;
}
.creative h2 {
        background: url(../img/other/price.svg) top center / cover no-repeat;
        background-size: 300px;
    }
.creative h2 img {
    padding: 0.5em 0;
}
.add{
  width: 90%;
}
.access-table th{
 width:20%;
}
.access-table td{
  width:80%;
}
.privacy-policy dt{
    font-size: 1.8rem;
    line-height: 1.2em;
}
.equipment-table th{
  display: block;
  width:100%;
  font-size: 1.4em;
}
.equipment-table td{
 display: block;
 margin-bottom: 20px;
 border-bottom: none;
}
.conditions-top::after {
            height: 100px;
}
.conditions-list {
    flex-direction: column;
    align-items: center;
  }
  .conditions-list li {
    flex: 1 1 100%;
    width: 90%;
  }
}
/* ========== Responsive: <=1024px ========== */
@media screen and (max-width:630px){
    main::after {
        height: 100px;
    }
    .category_menu::after {
    height: 100px;
}
.waterfall-item .image-area .title-svg {
        transform: initial;
    }
}
.waterfall-item img:first-child {
    width: 100%;
}

@media screen and (max-width: 1024px) {
    .nature-section.equipment h2, 
    .nature-section.creative h2 {
        padding: 1em 0 0;
    }
    .nature-section.equipment h2 img, 
    .nature-section.creative h2 img {
        padding: 0.5em 0;
    }
}
