@charset "UTF-8";
/* CSS Document */
/*-----------------------------
 *
 * 初期スタイル
 *
 *----------------------------*/
*{
    box-sizing: border-box;
}
html{
    font-size: 62.5%;/*16px × 62.5%=10px*/
}
body{
    color: #000;
    background-color: #9F794E;
    font-family: 'Hannari','ヒラギノ明朝 Pro W6','Yu Gothic',serif;
    font-size: 1.6rem;
    line-height: 1.85;
    font-feature-settings: "palt";
    letter-spacing: 0.05em;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}
img{
    max-width: 100%;
    height: auto;
}
.pc__img{
    display: block;
    margin: 0 auto;
}
.sp__img{
    display: none;
}

/*-----------------------------
 *
 * 汎用スタイル
 *
 *----------------------------*/
.bg-wihte{
    background-color: #fff;
}
.mt10{
    margin-top:10px;
}
.mt20{
    margin-top:20px;
}
.mt30{
    margin-top:30px;
}
.mt40{
    margin-top:40px;
}
.mb20{
    margin-bottom:20px;
}
.mb30{
    margin-bottom:30px;
}
.mb50{
    margin-bottom:50px;
}
.pl20{
    padding-left:20px;
}
.pl30{
    padding-left:30px;
}
.text-center{
    text-align: center;
}
.text-left{
    text-align: left;
}
.text-right{
    text-align: right;
}
.tableA{
    width:100%;
    font-size: 2.2rem;
}
.tableA th{
    text-align:left;
    width:200px;
    padding:10px 20px;
    font-weight: bold;
}
.sp_br{
    display:none;
}
.text_attention{
    font-size:1.4rem;
}
.lineH1{
    line-height: 1;
}
/*-----------------------------
 *
 * fixed
 *
 *----------------------------*/

.fixed_RB{
    z-index:10;
}
/*-----------------------------
 *
 * pagetop
 *
 *----------------------------*/
#page-top{
    width: 40px;
    height: 40px;
    position: fixed;
    right: 10px;
    bottom: 50px;
    background: #707070;
    border-radius: 32px;
    opacity: 0.8;
}
#page-top a{
    position: relative;
    display: block;
    width: 40px;
    height: 40px;
    text-decoration: none;
}
#page-top  a:hover{
    opacity: 0.8;
}
#page-top a:before{
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f077';
    font-size: 27px;
    color: #fff;
    position: absolute;
    width: 40px;
    height: 40px;
    top: -7px;
    text-align: center;
}
/*-----------------------------
 *
 * facebook
 *
 *----------------------------*/
#sns_fb{
    width: 40px;
    height: 40px;
    position: fixed;
    right: 10px;
    bottom: 210px;
    background: #ccc;
    border-radius: 32px;
}
#sns_fb a{
    position: relative;
    display: block;
    width: 40px;
    height: 40px;
    text-decoration: none;
}
#sns_fb i{
    font-size: 26px;
    color: #fff;
    position: absolute;
    width: 40px;
    height: 40px;
    top: 8px;
    text-align: center;
}
#sns_fb i:hover{
    color: #333;
}
/*-----------------------------
 *
 * twitter
 *
 *----------------------------*/
#sns_twitter{
    width: 40px;
    height: 40px;
    position: fixed;
    right: 10px;
    bottom: 160px;
    background: #ccc;
    border-radius: 32px;
}
#sns_twitter a{
    position: relative;
    display: block;
    width: 40px;
    height: 40px;
    text-decoration: none;
}
#sns_twitter i:hover{
    color: #333;
}
#sns_twitter i{
    font-size: 27px;
    color: #fff;
    position: absolute;
    width: 40px;
    height: 40px;
    top: 6px;
    right: -1px;
    text-align: center;
}
/*-----------------------------
 *
 * hatena
 *
 *----------------------------*/
 #sns_hatena{
    width: 40px;
    height: 40px;
    position: fixed;
    right: 10px;
    bottom: 110px;
    background: #ccc;
    border-radius: 32px;
}
#sns_hatena a{
    position: relative;
    display: block;
    width: 40px;
    height: 40px;
    text-decoration: none;
}
#sns_hatena i:hover{
    color: #333;
}
#sns_hatena i{
    font-size: 23px;
    color: #fff;
    position: absolute;
    width: 40px;
    height: 40px;
    top: 9px;
    right: -1px;
    text-align: center;
}
.fa-hatena::before{
    content: "B!";
    font-family: Verdana;
    font-weight: bold;
}
/*-----------------------------
 *
 * header
 *
 *----------------------------*/
.header{
    position: relative;
    height: 600px;
    height: 65vw;
    background-image: url(../images/header/kv_img.png);
    background-size: cover;
}
.navbar{
    position: fixed;
    z-index: 200;
    top:0;
    width:100%;
    height:50px;
    background-color:rgba(59,64,67,0.5);
}
.nav_logo{
    margin-left: 40px;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
}
.nav_logo img{
    vertical-align: middle;
}
.header .logo{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    background-color: #fff;
    width:250px;
    height:250px;
    opacity: 0.8;
}
.header .logo img{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.contactBox{
    display: flex;
    position: absolute;
    top: 50%;
    right:80px;
    transform: translateY(-50%);
}
.tell_sp,.reserve_sp{
    display:none;
}
.header .tell_pc a{
    color:#fff;
    font-size:2rem;
}
.header .reserve_pc a{
    color: #fff;
    font-size: 1.6rem;
    font-weight: 600;
    display: block;
    margin: 0 0 0 10px;
    max-width: 400px;
    border-radius: 5px;
    padding: 5px 10px;
    background: #D80000;
    transition: all 300ms 0s ease;
}
.header .tell_pc a:hover,.header .reserve_pc a:hover{
    opacity: 0.8;
}
.site-title{
    padding-bottom: 40px;
}

/*　ハンバーガーボタン　*/
.hamburger {
    display : block;
    position: fixed;
    z-index : 101;
    right : 13px;
    top   : 4px;
    width : 42px;
    height: 42px;
    cursor: pointer;
    text-align: center;
  }
  .hamburger span {
    display : block;
    position: absolute;
    width   : 30px;
    height  : 2px ;
    left    : 6px;
    background : rgb(255, 255, 255);
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition   : 0.3s ease-in-out;
    transition        : 0.3s ease-in-out;
  }
  .hamburger span:nth-child(1) {
    top: 10px;
  }
  .hamburger span:nth-child(2) {
    top: 20px;
  }
  .hamburger span:nth-child(3) {
    top: 30px;
  }
  
  /* ナビ開いてる時のボタン */
  .hamburger.active span:nth-child(1) {
    top : 16px;
    left: 6px;
    -webkit-transform: rotate(-45deg);
    -moz-transform   : rotate(-45deg);
    transform        : rotate(-45deg);
  }
  
  .hamburger.active span:nth-child(2),
  .hamburger.active span:nth-child(3) {
    top: 16px;
    -webkit-transform: rotate(45deg);
    -moz-transform   : rotate(45deg);
    transform        : rotate(45deg);
  }
  
  nav.globalMenuSp {
    position: fixed;
    top  : 50px;
    right : 0;
    color: #000;
    background: #fff;
    text-align: center;
    transform: translateX(100%);
    transition: all 0.6s;
    width: 100%;
    border-bottom: 1px solid #ccc;
  }
  
  nav.globalMenuSp ul {
    background: #fff;
    margin: 0 auto;
    padding: 0;
    width: 100%;
  }
  
  nav.globalMenuSp ul li {
    list-style-type: none;
    padding: 0;
    width: 100%;
    border-bottom: 1px solid #ccc;
  }
  nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }
  nav.globalMenuSp ul li:hover{
    background :#ccc;
  } 
  
  nav.globalMenuSp ul li a {
    display: block;
    color: #000;
    padding: 1em 0;
    text-decoration :none;
  }
  
  /* このクラスを、jQueryで付与・削除する */
  nav.globalMenuSp.active {
    transform: translateX(0%);
  }
/*-----------------------------
 *
 * section
 *
 *----------------------------*/
.inner{
    max-width: 1096px;
    margin: 0 auto;
    padding: 50px 20px;
    margin-bottom: 30px;
}
.section-title {
    position: relative;
    display: inline-block;
    margin:0 auto 20px;
    padding: 0 55px;
    color: rgb(0, 0, 0);
    font-size: 3.6rem;
    letter-spacing: 0.2em;
}
.section-title:before, .section-title:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 45px;
    height: 1px;
    background-color: black;
}
.section-title:before {
    left:0;
}
.section-title:after {
    right: 0;
}
/*-----------------------------
 *
 * info
 *
 *----------------------------*/
#info,#info h2{
    color:#fff;
    text-align:center;
}
#info .section-title:before, #info .section-title:after {
    background-color:#fff ;
}
#info p{
    text-align: left;
}
#info p.lead{
    font-size: 2.4rem;
    text-align: center;
    margin-bottom:30px;
}
/*-----------------------------
 *
 * shop
 *
 *----------------------------*/
 #shop h3{
     font-size:2.5rem;
     margin-bottom:10px;
 }
.photolist{
    display: flex;
    justify-content: space-between;
    align-content:flex-start;
    flex-wrap: wrap;
}
.photolist li{
    width: 16%;
    padding-top: 13%;
    margin-bottom:10px;
    position: relative;
    cursor: pointer;
}
.photolist img{
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    object-fit: cover;
}
.object-fit-img img{
    object-fit: cover;
    font-family: 'object-fit: cover;'
}

.btn_yoyaku a{
    text-align:center;
    color: #fff;
    font-size: 2.4rem;
    font-weight: 600;
    display: block;
    margin:80px auto 0;
    max-width: 400px;
    border-radius: 10px;
    padding:20px;
    background:#D80000;
    transition: all 300ms 0s ease;
}
.btn_yoyaku a:hover{
    transform: scale(0.9);
    background:#dd4848;
}
/*-----------------------------
 *
 * menu
 *
 *----------------------------*/
 #course,#foodmenu,#drinkmenu{
     margin-bottom:50px;
 }
.slider img{
    margin:auto;
}
.takeoutListWrap{
    display: flex;
    justify-content:space-around;
    flex-wrap: wrap;
}
.takeoutListWrap li{
    width: 49%;
    margin-bottom: 20px;
}
.tableA th::after{
    content: ":";
}
#foodmenu .object-fit-img img{
    transform: translateX(-50%);
}
#course h3{
    color: #0D227B;
    font-size: 2.0rem;
    white-space: nowrap;
    line-height: 2.6;
}
#course p{
    font-size: 1.4rem;
}
#course .btn_detail{
    text-align: right;
    margin-top:20px;
}
#course .btn_detail a{
    font-size: 1.4rem;
    color: #fff;
    background-color: #000000;
    border-radius: 10px;
    padding:5px 10px;
}
#course .btn_detail a:hover{
    background-color: #323232;
}
#course ul li{
    display: flex;
    justify-content:space-around;
    margin-bottom:20px;
}
#course .wrap_box1{
    overflow: hidden;
    width:250px;
    height:135px;
    padding-right: 20px;
}
#course .wrap_box1 img{
    width: 100%;
    height: auto;
}
#course .wrap_box2{
    width:100%;
    text-align: left;
}
#course .wrap_box3{
    display: flex;
}
#course .wrap_box3 p{
    display: block;
    width: 100%;
}
.icon_fdrink{
    color:#fff;
    font-size: 0.8rem;
    background-color:#8F9F4E;
    padding:5px;
}
.foodlist{
    text-align: left;
}

#takeoutmenu{
    background-color:#EDE4D9 ;
    padding:20px;
}
.wrap_flex{
    display: flex;
    flex-wrap: wrap;
    text-align: left;
}
.box_takeoutL{
    width:50%;
    padding-right: 10px;
}
.box_takeoutR{
    width:50%;
    padding-left:10px;
}
#takeoutmenu h3{
    font-size: 2.0rem;
}
#takeoutmenu p{
    font-size: 1.4rem;
}
#course .price,#takeoutmenu .price{
    font-size: 2.4rem;
}
#takeoutmenu .wrap_price{
    margin:0 0 40px;
    text-align: right;
}
.wrap_set{
    width:100%;
    background-color: #fff;
    opacity: 0.8;
    padding:20px;
    margin-bottom:40px;
}
#menu hr {
    border-top: 1px dashed rgb(173, 173, 173);
    border-right: none;
    border-bottom: none;
    border-left: none;
}
.foodlist,.drinklist{
    display: flex;
}
.foodlist,.drinklist{
    width:100%;
    margin:auto;
}
.foodlist .box1,.foodlist .box2,.drinklist .box1,.drinklist .box2{
    width:50%;
}
.foodlist table,.drinklist table{
    width:80%;
    margin-bottom:20px;
    margin-left:10%;
    font-size: 1.3rem;
}
.foodlist caption,.drinklist caption{
    text-align: left;
    font-size: 1.6rem;
    font-weight: 700;

}
.foodlist th,.drinklist th{
    width:50%;
    text-align: left;
}
.foodlist td,.drinklist td{
    width:50%;
    text-align: right;
}

/*-----------------------------
 *
 * access
 *
 *----------------------------*/
.maps-outer{
    position: relative;
    padding-top: 50%;
}
.maps{
    position: absolute;
    top:0;
    left: 0;
    width: 100%;
    height: 100%;
}

/*-----------------------------
 *
 * footer
 *
 *----------------------------*/
.footer{
    background:no-repeat url("../images/footer/background.png");
    background-size: cover;
    padding: 40px 40px 10px;
    background-color: #F08300;
    color: #fff;
}
.footer .logo{
    padding:20px;
    width:200px;
    height:200px;
    margin:0 auto 32px;
    background-color: #fff;
}
.footer-text{
    margin-bottom: 64px;
    font-size: 2.2rem;
}
.footer-shopname{
    font-size: 2.6rem;
    margin-bottom: 30px;
}
.footer-tel{
    margin-bottom: 30px;
}
.br-footer{
    display: none;
}



@media screen and (max-width:950px){
    .tell_pc,.reserve_pc{
        display:none;
    }
    .header .tell_sp,.header .reserve_sp{
        display:block;
    }
    .header .tell_sp img,.header .reserve_sp img{
        height:35px;
        margin-left:10px;
    }

}
@media screen and (max-width:768px){

    /*-----------------------------
    *
    * 汎用スタイル
    *
    *----------------------------*/
    .sp_br{
        display:block;
    }
    /*-----------------------------
     *
     * header
     *
     *----------------------------*/
    .header{
        height: 300px;
        height: 80vw;/*750px × 80% = 600px*/
        background-image: url(../images/header/kv_img__sp.png);
    }
    .header .logo{
        width: 200px;
        width: 30vw;
        height: 200px;
        height: 30vw;
    }
    .nav_logo{
        margin-left: 20px;
        /* position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%); */
    }
    .logo img {
        width: 140px;
        width: 25vw;
    }
    /*-----------------------------
     *
     * section
     *
     *----------------------------*/
    .section-title{
        padding: 16px 0;
        font-size: 2rem;
        line-height: 1;
    }
    .inner{
        padding: 40px 20px 70px;
        margin-bottom: 30px;
    }

    .section-title:before, .section-title:after{
        margin-right: -40px;
        margin-left: -40px;
        width: 30px;
    }
    /*-----------------------------
     *
     * shop
     *
     *----------------------------*/
    .photolist li,.photolist2 li{
        width: 32%;
    }
    #shop h3 {
        font-size: 1.8rem;
    }
    .tableA{
        font-size:1.4rem;
        text-align: center;
    }
    .tableA td {
        display: block;
        text-align: center;
        width: 100%;
        padding:0;
    }
    .tableA th{
        display:inline-block;
        margin:auto;
        width:auto;
        padding:0;
        background: linear-gradient(transparent 70%, yellow 70%);
    }    
    .tableA th::after{
        content: "";
    }
    .tableA td {
        padding-bottom:20px;
    }
    .btn_yoyaku a {
        font-size: 1.8rem;
        margin: 30px auto 0;
        padding: 10px;
    }

    /*-----------------------------
     *
     * menu
     *
     *----------------------------*/ 
     #course h3 {
        line-height: 1.6;
    }
     #course .wrap_box3{
        flex-direction: column;
    }
    #course .wrap_box3 p{
        text-align: left;
    }
    .takeoutListWrap li {
        width: 100%;
        margin-bottom: 20px;
        display: block;
    }
    /* .slick-prev:before, .slick-next:before{
        display: none;
    } */
    .wrap_leadColum{
        flex-direction:column;
    }
    .box_takeoutL,.box_takeoutR{
        width:100%;
        padding:0px;
        text-align: center;
    }
    .box_takeoutL h3,.box_takeoutL p,.box_takeoutR h3,.box_takeoutR p{
        text-align: left;
    }
    #takeoutmenu h3{
        margin-top:20px;
    }
    .foodlist,.drinklist{
        flex-direction: column;
    }

    .foodlist .box1,.foodlist .box2,.drinklist .box1,.drinklist .box2{
        width:100%;
    }
    .foodlist table,.drinklist table{
        width:100%;
        margin:0 auto 20px;
    }
    .foodlist caption,.drinklist caption{
        text-align: center;   
    }
    /*-----------------------------
     *
     * access
     *
     *----------------------------*/
    .maps-outer{
        padding-top: 66.7%;
    }
    /*-----------------------------
     *
     * footer
     *
     *----------------------------*/
    .footer{
        padding: 40px 0;
    }
    .footer-text{
        font-size:1.6rem;
        padding:0 10px;
        margin-bottom: 32px;
    }
    .br-footer{
        display: block;
    }

}
@media screen and (max-width:650px){
    .nav_logo img{
        width:250px;
    }
}
@media screen and (max-width:400px){
    .header .tell_sp,.header .reserve_sp{
        display:none;
    }
}














