@charset "utf-8";

header{
  padding: 0;
  position: relative;
  background: #fff none;
}
.head_content{
  width: 100%;
  padding:2rem 1.5rem;
  background: transparent;
  position: static;
}
.head_content h1{
  width:9.0rem;
  position: static;  
}
.menu-pc{
  display: none;
}
.ham{
  display: block;
}

/*------------- .ham-btn -------------*/

/*   ボタンタグ設定   */
button.ham-btn {
  display: block;
  position: fixed;
  top: 15px;
  right: 15px;
  z-index: 9999;
  width: 60px;
  height:60px;
  border-radius: 50%;
  border: 1px solid var(--green);
  background:rgba(255, 255, 255, 0.8);
  font-size: 1.1rem;
  cursor: pointer;
}

/*   ハンバーガーボタン3本線   */
button.ham-btn span.bar {
  display: inline-block;
  transition: all .4s;/*アニメーションの設定*/
  position: absolute;
  left: 16px;
  height: 2px;
  border-radius: 2px;
  background: var(--green);
  width: 44%;
}
button.ham-btn span.bar1 {top:15px;}
button.ham-btn span.bar2 {top:23px;}
button.ham-btn span.bar3 {top:31px;}

button.ham-btn .menu, button.ham-btn .close {
  width: 100%;
  position: absolute;
  top: 2.8rem;
  left: 0;
  text-align: center;
  color: var(--green);
  font-family: Roboto, sans-serif;
  margin: 10px 0;
  transition: .5s;
}
button.ham-btn .menu {
  opacity: 1;
}
button.ham-btn .close {
  opacity: 0;
}

/*activeクラスが付与されると線が回転して×に*/
button.ham-btn.active span.bar1 {
  top: 16px;
  left: 20px;
  transform: translateY(6px) rotate(-45deg);
  width: 30%;
}
button.ham-btn.active span.bar2 {
  opacity: 0;/*真ん中の線は透過*/
}
button.ham-btn.active span.bar3 {
  top: 28px;
  left: 20px;
  transform: translateY(-6px) rotate(45deg);
  width: 30%;
}
button.ham-btn.active .menu {
  opacity: 0;
}
button.ham-btn.active .close {
  opacity: 1;
}

button.ham-btn:hover {
  opacity: 0.6;
}

.ham.active .menu-sp {
  left: 0;
}


/*------------- .ham li -------------*/

.ham .menu-sp {
  padding: 2rem 0;
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 10rem;
  left: 120%;
  z-index: 999;
  background: #447d56;
  transition: all 0.5s 0s ease;
}
.menu-sp ul.main li a{
  display: block;
  padding: 1rem 3rem;
  color: #fff;
  border-bottom: 1px dotted var(--lightgreen);
  background: url(../img/spmenu-arr-down.svg) no-repeat 90% center;
  background-size: 12px;
}
.menu-sp ul.main li:last-child{
background: #d05807;
}
.menu-sp ul.main li:last-child a{
  padding: 1.5rem 3rem;
  background: url(../img/spmenu-arr-link.svg) no-repeat 89% center;
  background-size: 6px;
}

.menu-sp ul.subsns{
  display: flex;
  align-items: center;
  padding: 2rem 3rem 0;
}
.menu-sp ul.subsns li{
  width: 4rem;
  padding: 0 1.5rem 0 0;
}
.menu-sp ul.subsns li:last-child{
  width: 18rem;
  padding: 0.5rem 0 0;
}



/*-----------------------------
FV SP
------------------------------*/
.fv-container {
  background: none;
  position: relative;
}

/*FV スライダー SP
------------------------------*/
.slider{
  width: 100%;
  padding: 0 1.5rem;
}

/*FV 予約円ボタン SP
------------------------------*/
.fv-btn{
  display: block;
  width: 10rem;
  position: absolute;
  right: 2.5%;
  top: 17%;
  z-index: 100;
}
.fv-btn p a{
  display: block;
  width: 10rem;
  height: 10rem;
  padding:2.2rem 0 0 0;
  border-radius: 50%;
  color: #fff;
  background: var(--dimgreen);
  position: relative;
}
.fv-btn p a{
  opacity: 1;
}
.fv-btn p a span{
  display: block;
  padding:2.3rem 0 0 2.4rem;
  line-height: 1.3;
  font-size: 1.3rem;
  font-weight: bold;
  background: url(../img/icon-contact.svg),url(../img/btn-arr.svg);  
  background-repeat: no-repeat,no-repeat;
  background-position:center top,72% 93%;
  background-size:21px,6px;
}


/*キャンペーン SP
------------------------------*/
.campaign{
  width: auto;
  margin: 0;
  padding:4rem 0;
  position: static;
}
.campaign h2{
  max-width: 54rem;
  margin: 0 auto;
  padding: 0 6rem;
  text-align: center;
}
.campaign h2 span{
  display: block;
  padding: 0 0 1.5rem;
}
.campaign h2 + p{
  padding: 2.5rem 0 3.5rem;
  text-align: center;
  font-size: 1.6rem;
}
.campaign h2 + p br + br{
  display: block;
}
/* FV用-予約ボタン */
.btn-fv{
  display: none;
}
.btn-fv-ttl{
  display: none;
}

/* 特典 SP
------------------------------*/
.campaign-list{
  padding: 3rem 0;
  background: var(--dimgreen);
  position: relative;
}
.campaign-list p.campaing-note{
  width: 100%;
  position: absolute;
  top: -20px;
  left: 0;
}
.campaign-list p.campaing-note span{
  display: block;
  width: 220px;
  margin: 0 auto;
}

.campaign-list ol{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 0 2rem;
}
.campaign-list ol li{
  width: 70%;
  margin: 0 auto;
  padding: 0 0 1.5rem;
  border-bottom: 1px solid #76a685;
}

.btn-cam-ttl{
  display: block;
  padding: 1.5rem 0;
  font-size: 1.3rem;
  text-align: center;
  color: #fff;
}
.btn-cam-ttl span{
  color: var(--yellow);
}

/*------------------------------
フッター SP
------------------------------*/
footer{  
  padding: 1rem 0;
  background: #113f20;
}
footer section{
  display: none;
  align-items: flex-end;
}
footer section h2{
  width: 12rem;
  margin-right: 8rem;
}

footer section nav ul{
  display: flex;
  flex-wrap: wrap;
  width: 44rem;
  font-size: 1.3rem; 
}
footer section nav ul li{
  padding: 0.2rem 0.8rem 0;
  font-family: 'Noto Sans JP', sans-serif;
}
footer section nav ul li a{
  color: #f3f7f4;
}
footer section nav ul li:first-child{
  width: 100%;
  padding: 0.2rem 0.8rem 0;
}

footer .foot-sns{
  width: 18rem;
  margin-left:auto;
}
footer .foot-sns ul{
  display: flex;
  flex-wrap: wrap;
  padding: 0 0 1rem;
}
footer .foot-sns ul li{
  padding: 0 1rem;
}
footer .foot-sns ul li img{
  display: block;
  width: 1.8rem;
}

/* コピーライト---- */
footer .copy,
footer .copy-sns{
  color: #f3f7f4;
  font-size: 1.2rem;
}
footer .copy{
  display: block;
  text-align: center;
}
footer .copy-sns{display: none;}

/* 追従ボタン SP ---- */
.btn-follow{
  display: none;
  position: fixed;
  top: 30%;
  right: -1rem;
}
.btn-follow div{
  width: 14rem;
  padding: 1rem;
  background: #fff;
  border-radius: 0.5rem;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
}
.btn-follow div p:first-child a{
  display: block;
  padding: 4rem 0;
  border-radius: 0.5rem 0 0 0;
  line-height: 1.4;
  font-weight: bold;
  color: #fff;
  background: var(--dimgreen);
}
.btn-follow div p:first-child a span{
  display: block;
  padding: 4rem 0 0 3rem;
  background: url(../img/icon-contact.svg),url(../img/btn-arr-yellow.svg);  
  background-repeat: no-repeat,no-repeat;
  background-position:center top,76% 96%;
  background-size:31px,8px;
}
.btn-follow div p:first-child a span strong{
  color: var(--yellow);
}

.btn-follow div p:last-child a{
  display:block;  
  border-radius: 0 0 0 0.5rem;  
  width: 13rem;
  overflow: hidden;
}

.back{
  display: none;
  position: fixed;
  z-index: 999;
  right: 2%;
  bottom: 20%;  
  width: 6rem;
  height: 6rem;
}
.back a{
  display: block;
  width: 6rem;
  height: 6rem;
  padding: 2rem 0 0;
  border-radius: 50%;
  border: 5px solid #fff;
  background: var(--dimgreen);
}
.back a::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  margin: 0 auto;
  border-top: 4px solid #fff;
  border-right: 4px solid #fff;
  transform: rotate(-45deg);
}



/*----------------------------------------------------
タブレット用 750px以上
----------------------------------------------------*/

@media only screen and (min-width: 520px) {

  /*FV 予約ボタン 520
  ------------------------------*/
  .fv-btn{
    width: 14rem;
    right:-1%;
    top: 20%;
  }
  .fv-btn p a{
    width: 12rem;
    height: 12rem;
    padding:3rem 0 0 0;
  }
  .fv-btn p a span{
    padding:2.3rem 0 0 3rem;
    font-size: 1.5rem;
  }


}



/*----------------------------------------------------
タブレット用 750px以上
----------------------------------------------------*/

@media only screen and (min-width: 750px) {

  .back{
  display: block;
  }

  .campaign h2 + p br + br{
    display: none;
  }

  /*FV 予約ボタン 750
  ------------------------------*/
  .fv-btn{
    display: none;
  }
  /* 特典 750 ---------- */
  .btn-cam-ttl{
    text-align: center;
    font-size: 1.4rem;
  }

  /* 追従ボタン TB ---- */
  .btn-follow{
    display: block;
  }

}


/*----------------------------------------------------
PC用 1000px以上
----------------------------------------------------*/

@media only screen and (min-width: 1000px) {

  /* ヘッダー PC
  -------------------------------*/
  header{
    padding: 0;
    background: var(--dimgreen) ;
  }

  .head_content{
    padding:0;
  }
  .head_content h1{
    position: absolute;
    top: 3rem;
    left: 3rem;
    z-index: 10;
  }

  .fv-container {
    background: transparent;
  }
  /*FV スライダー 1000 ------------*/
  .slider{
    padding:0;
  }
  /*キャンペーン 1000 -------------*/
  .campaign{
    width: 38%;   
    padding:11rem 0 0 0;
    position: absolute;
    top: 0;
    left: 6%;
  }
  .campaign h2{
    width: 27rem;       
    margin: 0;
    padding: 0;
    text-align: left;
  }
  .campaign h2 span{
    display: block;
    padding: 0 0 1rem;
    font-size: 1.6rem;
  }
  .campaign h2 + p{
    padding: 1.5rem 0;
    text-align: left;
    font-size: 1.4rem;
  }

  /* FV用-予約ボタン 1000 */
  .btn-fv{
    display: block;
    width: 30rem;
  }
  .btn-fv a{
    display: block;
    text-align: center;
    letter-spacing: 0.1rem;
    padding: 1rem 0;
    border-radius: 10rem;
    color: #fff;
    background: var(--dimgreen);
    font-size: 1.8rem;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;  
  }
  .btn-fv a span{
    display: block;
    max-width: 22rem;
    margin: 0 auto;
    background-image: url("../img/icon-contact.svg"), url("../img/btn-arr.svg");
    background-repeat: no-repeat,no-repeat;
    background-size: 20px,10px;
    background-position: 4% 55%, 95% 60%;
  }

  .btn-fv-ttl{
    display: block;
    line-height: 1.6;
    padding: 1.5rem 0;
    font-size: 1.3rem;
    color: var(--darkgreen);
  }
  .btn-fv-ttl span{
    font-weight: bold;
    color: var(--red);
  }
  .btn-fv-ttl br{
    display: block;
  }

  /* 特典 1000
  ------------------------------*/
  .campaign-list{
    padding: 3rem 0;
    background: var(--dimgreen);
    position: relative;
  }
  .campaign-list p.campaing-note{
    width: 100%;
    position: absolute;
    top: -100px;
    left: 0;
  }
  .campaign-list p.campaing-note span{
    width: 220px;
    margin: 0;
  }

  .campaign-list ol{
    flex-direction: row;
    padding: 0;
  }
  .campaign-list ol li{
    width: 30%;
    margin: 0;
    padding: 0;
    border-bottom: none;
  }

  .btn-cam-ttl{
    display: none;
  }


  /*------------------------------
  フッター 1000
  ------------------------------*/
  footer{  
    padding: 5rem 0;
  }
  footer section{
    display: flex;
  }

  /* コピーライト---- */
  footer .copy{display: none;}
  footer .copy-sns{display: block;}


}


/*----------------------------------------------------
PC用 1200px以上
----------------------------------------------------*/

@media only screen and (min-width: 1200px) {

 /*キャンペーン 1200 -------------*/
  .campaign{
    width: 38%;
    padding:12rem 0 0 0;
  }
  .campaign h2{
    width: 40rem;       
  }
  .campaign h2 span{
    padding: 0 0 1.5rem;
  }
  .campaign h2 + p{
    font-size: 1.6rem;
  }


}


/*----------------------------------------------------
PC用 1400px以上
----------------------------------------------------*/

@media only screen and (min-width: 1400px) {

  .ham{
    display: none;
  }

  header{
     background: var(--dimgreen) url(../img/fv-line.png) no-repeat left bottom;
  }
  .head_content{
    position: relative;
  }
  .head_content h1{
    width: 15rem;
  }

  /* ハンバーガー 三本線 ボタン PC1400
  -------------------------------------*/
  .hamburger-menu{
      display: none;
  }

  /* メインメニュー PC1400
  -------------------------------------*/
  .menu-pc{  
    display: block;
    width: 100%;
    position: absolute;
    left: 0;
    top: 30px;
    z-index: 10;
  }
  .menu-pc nav{  
    width: 108rem;
    margin-left: auto;
    padding: 0 2.5rem 0 0;
  }
  .menu-pc nav ul{
    display: flex;
    align-items: center;
    padding: 0 0 0 1rem;
    border-radius: 100rem;     
    background: rgba(255, 255, 255, 0.7);
  }
  .menu-pc nav ul li{
    text-align: center;
  }
  .menu-pc nav ul li a{
    display: block;
    padding: 1.5rem 2rem;
    font-size: 1.4rem;
  }
  .menu-pc nav ul li:last-child{
    width: 20rem;
    margin-left: auto;
  }
  .menu-pc nav ul li:last-child a{
    padding: 1.5rem 0;
    color: #fff;
    border-radius: 0 100rem 100rem 0;
    background: var(--dimgreen);
  }

  .btn-fv a span{
    max-width: 28rem;
  }

 /*キャンペーン 1400 -------------*/
  .campaign{
    width: 36%;
    padding:18rem 0 0 0;
  }
  .campaign h2 + p{
    padding: 2rem 0;
  }
  /* FV用-予約ボタン 1400 */
  .btn-fv{
    width: 40rem;
  }
  .btn-fv a{
    padding: 1rem 0;
    font-size: 2.1rem;
  }
  .btn-fv-ttl br{
    display: none;
  }


}


/*----------------------------------------------------
PC用 1600px以上
----------------------------------------------------*/

@media only screen and (min-width: 1600px) {

 /*キャンペーン 1800 -------------*/

  .campaign {
    width: 32%;
    padding: 16rem 0 0 0;
    left: 8%;
  }
  .campaign h2{
    width: 40rem;       
  }
  .campaign h2 span{
    padding: 0 0 1rem;
    font-size: 2.1rem;
  }
  .campaign h2 + p{
    padding: 2rem 0;
    font-size: 1.8rem;
  }


}


/*----------------------------------------------------
PC用 1600px以上
----------------------------------------------------*/

@media only screen and (min-width: 1800px) {

 /*キャンペーン 1800 -------------*/

  .campaign {
    padding: 16rem 0 0 0;
    left: 12%;
  }
  .campaign h2{
    width: 46rem;       
  }

  .btn-fv a{
    padding: 2rem 0;
    font-size: 2.4rem;
  }
  .btn-fv-ttl br{
    display: none;
  }


}