@charset "UTF-8";
/*////////////////////////
sacay-salto.jp
home.css
///////////////////////*/
main section{
  padding: 2em 15px 4em;
  max-width: 1030px;
   margin: 0 auto;
}

main section:last-child{
    padding-bottom: 4rem;
}

main #slider{
    width: 100%;
    height: 80vh;
}
#slider .wrapper{
   display: flex;
   justify-content: center;
   align-content: center;
   flex-direction: column;
  position:absolute;
   height: 100%;
   margin: 0 4%;
   width: 30%;
}
.wrapper h1{
   text-align: center;
   font-size: 1.4em;
   margin: 5% 0 8%;
}
.wrapper img{
   width: 100%;
   max-width: 360px;
   height: auto;
}

#read {
  /*margin: 70px auto 60px;*/
  /*position: relative;*/
}
#read .txt_cont {
  /*position: absolute;*/
}
#read .txt_cont .cont_title {
  font-size: 2.6em;
  font-weight: bold;
  line-height: 1.2em;
  margin-bottom: .8em;
  letter-spacing: .1em;
}
#read .txt_cont .cont_subtitle {
  font-size: 2em;
  font-weight: bold;
  line-height: 1.2em;
  margin-bottom: 1em;
}
.cont_txt {
  font-size: 1.6em;
  letter-spacing: .1em;
  /*font-weight: bold;*/
  line-height: 1.5em;
}

.read_txt{
    font-size: 1.35rem;
    line-height: 2.8rem;
    /*text-align: center;*/
   margin: 2em auto 1em;
}


@media (max-width: 767px){
main section{
    padding: 2em 0 4em;
}
main #slider{
    height: 70vh;
}
   #slider .wrapper{
   width: 100%;
   margin: auto;
   justify-content: end;
}
   .wrapper h1{
   text-align: center;
   font-size: 1.4em;
   margin: 5% 4% 8%;
}
}



/*
sec_title
*/
.sec_ti{
    font-size: 4.8em;
    /*text-align: center;*/
    /*color: #E9471F;*/
}


.flex_box{
   display: flex;
   justify-content: space-between;
   align-items: center;
}
.flex_cont{
    padding: 2em 0 5em;
   width: 45%;
}

.ttl{
   position: relative;
}
.ttl .ttl_cont {
   position:absolute;
   top: 0;
  left: 0;
   width: 100%;
   height: 100%;
   display: flex;
   justify-content: center;
   align-content: center;
   flex-direction: column;
}


/*
menu
*/

#menu .ttl img, #read .ttl img{
   width: 100%;
   height: auto;
}
#menu .ttl .ttl_cont {
   justify-content: end;
}
#menu h2{
   color: #fff;
font-size: 2.6em;
 /* letter-spacing: 3px;*/
 margin: 0 0 2.0em 1em;
  font-weight: bold;
line-height: 1.3;
}
#menu h3, #access h3, #shopinfo h3{
   color: #AD7A29;
   font-size: 2.2em;
   margin-bottom: .8em;
}
#menu h2 span, #access h2 span{
    font-size: .5em;
    display: block;
    /*margin-left: 2rem;*/
   margin-top: .4em;
}
#menu .cont{
   margin-bottom: 3em;
}
#menu .bg_ill2{
   background-image: url("/images/bg_ill_02.png");
   background-size: contain;
   background-repeat: no-repeat;
   background-position: top right;
}
#menu .bg_ill3{
   background-image: url("/images/bg_ill_03.png");
   background-size: contain;
   background-repeat: no-repeat;
   background-position: top right;
}
#menu .dotline{
   border-bottom: 1px dashed #fff;
   padding-bottom: .8em;
}
#menu .time{
   line-height: 1.6em;
    font-size: 1.8em;
    margin-bottom: .8em;
}
.mark{
   border: 1px solid #FFF;
   border-radius: 2em;
   padding: .3em .6em;
}
.mark.wh{
   background: #fff;
   color: #344C53;
}
#menu .cont_txt{
    line-height: 2em;
    font-size: 1.3em;
    margin-bottom: 1.5em;
}
#menu small{
   font-size: .9em;
}
#menu h4 small{
   font-size: .85em;
}
#menu ul{
    display: flex;
    flex-wrap: wrap;
   /*justify-content: space-between;*/
    list-style: none;
}

#menu ul li{
    width: 30%;
   margin-right: 1.5%;
     margin-left: 1.5%;
    margin-bottom: 4rem;
}

#menu ul li img{
    width: 100%;
    height: auto;
}
#menu ul li strong{
   display: block;
  margin: -3.0em .5em 2em;
  color: #EA1E1E;
  font-size: 1.4em;
  line-height: 1.3;
}
#menu ul li p{
    margin-top: 1.5em;
    font-size: 1.4em;
    line-height: 1.0em;
}

#menu ul li p span{
    display: block;
    font-size: 1.1rem;
    margin-top: 0.5rem;
    line-height: 1.5rem;
}

#menu ul li p span.vegan{
    display: inline-block;
    font-size: 1.1rem;
    color: #000;
    border: 0.5px solid #000;
    padding: 0.3rem 0.5rem;
    margin-bottom: 0.5rem;
}

#menu .drink_flex{
    display: flex;
    /*justify-content: center;*/
}

#menu .drink_flex .drink_cont{
    width: calc(100%/2);
    padding: 0 5% 0 0;
}

#menu dl{
    display: flex;
    justify-content: space-between;
    font-size: 1.4em;
     padding: 1.4em 0;
}

#menu dl dt{
    text-align: left;
}

#menu dl dt span{
    display: block;
    font-size: 1.1rem;
    color: #006C36;
    margin-top: 0.5rem;
    line-height: 1.5rem;
}

#menu dl dd{
    text-align: right;
}

#menu .tr{
    text-align: right;
    font-size: 1.2rem;
}

#menu .plan{
   display: flex;
   margin-bottom: 3.0em;
}
#menu .plan .plan_box{
   padding: 1em 1.5em;
   border: 1px solid #006C36;
   display: flex;
   align-items: center;
   width: 32%;
}
#menu .plan .plan_box.bg_green{
   background-color: #006C36;
   color: #fff;
}
#menu .plan .plan_box.plus{
   border:none;
   padding: .5em .5em;
   font-weight: bold;
   font-size: 1.4em;
   justify-content: center;
   width: 4%;
}
#menu .plan p{
    font-size: 1.4em;
    line-height: 1.4;
}
#menu .plan p strong{
   font-size: 1.2em;
}
#menu .plan p small{
    font-size: .7em;
}
#menu .plan p span{
    display: block;
    font-size: 1.1rem;
    margin-top: 0.5rem;
    line-height: 1.5rem;
}
.floor{
      width: 76%;
      margin: auto;
   }

@media (max-width: 767px) {

   .flex_box{
   display: block;
   margin-bottom: 4em;
   }
   .flex_cont{
   padding: 2em 0 2em;
   width: 100%;
   }
   
#menu h2, #access h2{
    font-size: 3.2em;
    /*margin: 3rem 0;*/
}

#menu h2 span, #access h2 span{
    font-size: 0.6em;
    /*margin-left: 1rem;*/
}

#menu .cont_txt {
    font-size: 1.2rem;
    margin-bottom: 3rem;
}

#menu ul{
    /*justify-content: center;*/
   flex-wrap: nowrap;
   overflow-x: scroll;
}

#menu ul li {
    width: 60%;
    margin-right: 3%;
    margin-bottom: 2.5rem;
   flex-shrink: 0;
}
#menu ul li strong{
  font-size: 2.2em;
   }
/*#menu ul li:nth-child(2n) {
    margin-right: 0;
}*/

#menu .drink_flex {
    flex-wrap: nowrap;
   overflow-x: scroll;
}

#menu .drink_flex .drink_cont {
    width: 60%;
    /*padding: 0;*/
   flex-shrink: 0;
}
#menu dl{
    padding: 1.6em 0;
}
#menu .tr {
    font-size: 1rem;
}
    
#menu .plan{
   display: block;
   margin: 0 auto 4.8em;
}
#menu .plan .plan_box, #menu .plan .plan_box.plus{
   width: 90%;
   margin:auto;
}
   .floor{
      width: 100%;
   }
}


/*
news
*/

#news .newsList{
    display: flex;
    flex-direction: column;
    width: 100%;
    margin: 5em 0;
    list-style: none;
}

#news .newsList a{
    color: #000;
}

#news  .newsList .data{
    font-size: 1.3rem;
    line-height: 2.2rem;
    display: flex;
    justify-content: center;
}

#news .newsList .data .date {
    display: inline-block;
    margin-bottom: 0.7rem;
    border: 0.5px solid #000;
    padding: 1px 4px;
    margin-right: 1rem;
}

@media (max-width: 767px) {

#news .newsList .data {
    flex-wrap: wrap;
    justify-content: flex-start;
}

.newsList{
    display: flex;
    flex-direction: column;
    width: 100%;
}
#news .newsList li{
    width: 80%;
    margin: 15px auto;
    display: flex;
}    
    
 #news .newsList li .newsPh{
    margin-bottom: 10px;
}
#news .newsList li .newsPh img{
    width: 100%;
    height: auto;
}
}




/*
access
*/
#access{
   /*padding: 8em 0 5em;*/
}
#access h2{
color: #67223F;
font-size: 2.6em;
 /* letter-spacing: 3px;*/
  margin: -.6em 0 1.6rem;
  font-weight: bold;
line-height: 1.1;
   text-align: center;
}
#access h4{
   font-size: 1.6em;
}
.access_sec{
   background: #D3D3D3;
   padding: 8% 8% 4%;
   border-radius: 30px;
   color: #344D54;
   /*margin-bottom: 8%;*/
}
.access_flex{
    display: flex;
    justify-content: center;
    align-items: center;
    /*margin: 5rem 0;*/
}

.access_flex .access{
    width: 50%;
    margin: 3em 3em 3em 0;
}

.access .address{
    font-size: 1.5em;
    line-height: 3em;
}

.access .address span{
    display: inline-block;
    border-bottom: #E9471F 1px solid;
}
.access small{
   font-size: .9em;
}

.access .btn_cont {
    text-align: left;
}

.access_flex .map{
    width: 50%;
    margin: 3rem 0;
}

.map img{
    width: 100%;
}

@media (max-width: 767px) {

   #access h2{
      text-align: left;
      margin-bottom: 1.5em;
   }
   
    .access_flex {
        flex-wrap: wrap;
    }

    .access_flex .access {
        width: 100%;
        margin: 0;
        /*padding: 0 2rem;*/
    }

    .access .btn_cont {
        text-align: center;
    }

    .access_flex .map {
        width: 100%;
        margin: 0;
    }

}
