

body{
    margin:0;
    font-family: Verdana,Arial,Helvetica,"游ゴシック", "YuGothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐ ゴシック", sans-serif;
    font-size: 14px;
}
*{
    margin:0;
    padding:0;
}

ul {
    list-style-type:none;
    margin-block-start: 0em;
    margin-block-end: 0em;
    padding-inline-start: 0px;
 }

.clearfix{
    content: "";
    display:block;
    clear: both;
}
.br-sp {
    display: block;
}
.br-pc {
    display: none;
}

.pcOnly {
    display: none;
}
.spOnly {
    display: inline;
}

  
  /* 768px以上(PC)  **************/
  @media (min-width: 768px) {
        .br-sp {
         display: none;
        }
        .br-pc {
            display: block;
        }
        .pcOnly {
            display: inline;
        }
        
        .spOnly {
            display: none;
        }
    }



/* ブレイクポイント *****************************
    768px以上PC 
    768px以下SP 
    First Viewvに限り：1400pxから画像のサイズを固定
************************************************/



 /* 各ぺージに共通 **************************************/

/* g-menu ********************/
.menu{
    position: fixed;
    top: 0;
    background: linear-gradient(rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0));
    width: 100%;
    /* height:64px; */
    padding: 13px 10px 10px;
    z-index: 10;
}
 .menu ul{
    display: none;
}

.menu .logo{
    width: 30%;
    padding-left: 10px ;
}
.logo a{
    display: block;
}

.logo img{
    width: 100%;
}



 /* 768px以上(PC)  **************/
@media (min-width: 768px) {
    .menu{
        /* ↓途中から固定する設定（スクロールしても付いてくる）begin*/
        position: -webkit-sticky;
        position: sticky;
        top: 0;
        /* ↑途中から固定する設定（スクロールしても付いてくる）end */
        display: flex;
        justify-content: space-between;
        background-color: black;
        width: 100%;
        padding:0;
    }
    .menu .logo{
        display: block;
        width: 11%;
        min-width: 102px;
        max-width: 130px;
        padding: 10px 0 10px 38px;
    }
    .menu .logo img{
        width: 100%;
    }
    
    .menu ul{
        display: flex;
        float:right;
        padding:14px 10px 0;
    }
    .menu li{
        list-style-type:none;
        margin-right:28px;

    }
    .menu a{
        display: block;
        text-decoration: none;
        text-align: center;
    }
    .menu ul img{
        vertical-align: middle;/*img直下の空白の削除*/
        width:65%;
        margin-bottom:2px;
    }
    .menu a p{
        text-align: center;

        font-size:12px;
        font-weight: 400;
        color:#fff;
        letter-spacing: 0.2em;
        font-family: 'Crimson Text', serif;
    }

}

/* ハンバーガーメニュー （SPのみ）*/
.menu-btn {
    position: fixed;
    top: 10px;
    right: 10px;
    display: flex;
    height: 60px;
    width: 60px;
    justify-content: center;
    align-items: center;
    z-index: 90;
    background-color: #ed85a2;
}
.menu-btn span,
.menu-btn span:before,
.menu-btn span:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #ffffff;
    position: absolute;
}
.menu-btn span:before {
    bottom: 8px;
}
.menu-btn span:after {
    top: 8px;
}

#menu-btn-check:checked ~ .menu-btn span {
    background-color: rgba(255, 255, 255, 0);/*メニューオープン時は真ん中の線を透明にする*/
}
#menu-btn-check:checked ~ .menu-btn span::before {
    bottom: 0;
    transform: rotate(45deg);
}
#menu-btn-check:checked ~ .menu-btn span::after {
    top: 0;
    transform: rotate(-45deg);
}
#menu-btn-check {
    display: none;
}

/* ハンバーガーメニューの中身設定 */
.hbm-logo{
    width: 22%;
    margin: 0 auto;
    padding-top:18px;
}
.hbm-logo img{
    width: 100%;
}

.menu-content {
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 100%;/*leftの値を変更してメニューを画面外へ*/
    z-index: 80;
    background-color: #f096af;
    opacity: 0.9;
    transition: all 0.5s;/*アニメーション設定*/
}

#menu-btn-check:checked ~ .menu-content {
    left: 0;/*メニューを画面内へ*/
}


.menu-content ul {
    padding: 80px 22px 0;
}
.menu-content ul li {
    border-bottom: solid 1px #ffffff;
    list-style: none;
}
.menu-content ul li a {
    display: block;
    width: 100%;
    font-size: 1.5rem;
    box-sizing: border-box;
    color:#000000;
    text-decoration: none;
    padding: 12px 15px 14px 0;
    position: relative;
}


.menu-content ul li a::before {
    content: "";
    width: 7px;
    height: 7px;
    border-top: solid 2px #ffffff;
    border-right: solid 2px #ffffff;
    transform: rotate(45deg);
    position: absolute;
    right: 11px;
    top: 16px;
}

 /* 768px以上(PC)  **************/
 @media (min-width: 768px) {
    .menu-btn{
        display: none;
    }

 }


 /* 各ページトップの見出し */
 .p-topBox{
    position:relative;
    height: 22vh;
    width: 100%;
    background-image:url(../img/menu-title_bk.jpg);
    margin: 0;
    padding: 0;
    z-index: 5;
    background-size: cover;
    background-position: center center;
}


.p-topBox::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color:rgb(255, 255, 255,0.4);
}

.page-title{
    position: absolute;
    top:50%;
    left:50%;
    transform: translate(-50%,-50%);
}



 .p-top_h1{
    border-radius: 240px 15px 100px 15px / 15px 200px 15px 185px;
    font-size: 3rem;
    background-color: rgb(211 59 143 / 0.2);
    padding: 1.8rem;
    color: rgb(255, 255, 255,0.9);
    font-family: 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    letter-spacing: 0.2rem;
}




 /* 768px以上(PC)  **************/
@media (min-width: 768px) {
    .p-topBox{
        height: 30vh;
    }
    .p-top_h1{
        padding: 1.8rem 3rem;
        letter-spacing: 0.14rem;
    }
    
}





 /* top ********************************************/

/* スクロール促すアニメーション **********************/
.scroll-container {
    width: 24px;
    height: 24px;
    display: block;
    position: absolute;
    top:70%;
    left:50%;
    transform: translate(-50%,-50%);
  }
  
  .chevron {
    position: absolute;
    width: 28px;
    height: 8px;
    opacity: 0;
    transform: scale3d(0.5, 0.5, 0.5);
    animation: move 3s ease-out infinite;
  }
  
  .chevron:first-child {
    animation: move 3s ease-out 1s infinite;
  }
  
  .chevron:nth-child(2) {
    animation: move 3s ease-out 2s infinite;
  }
  
  .chevron:before,
  .chevron:after {
    content: ' ';
    position: absolute;
    top: 0;
    height: 100%;
    width: 51%;
    background: #fff;
  }
  
  .chevron:before {
    left: 0;
    transform: skew(0deg, 30deg);
  }
  
  .chevron:after {
    right: 0;
    width: 50%;
    transform: skew(0deg, -30deg);
  }
  
  @keyframes move {
    25% {
      opacity: 1;
  
    }
    33% {
      opacity: 1;
      transform: translateY(30px);
    }
    67% {
      opacity: 1;
      transform: translateY(40px);
    }
    100% {
      opacity: 0;
      transform: translateY(55px) scale3d(0.5, 0.5, 0.5);
    }
  }
  
  .text {
    display: block;
    margin-top: 75px;
    margin-left: -30px;
    font-family: "Helvetica Neue", "Helvetica", Arial, sans-serif;
    font-size: 12px;
    color: #fff;
    text-transform: uppercase;
    white-space: nowrap;
    opacity: .25;
    animation: pulse 2s linear alternate infinite;
  }
  
  @keyframes pulse {
    to {
      opacity: 1;
    }
  }

    /* 768px以上(PC)  **************/
    @media (min-width: 768px) {
        .scroll-container {
            display: none;
        }
    }

  /* スクロール促すアニメーション END**********************/


/* slider ********/
.sliderBox{
    position:relative; 
    }
    
.slick-slide::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: rgba(122, 122, 122, 0.3);
}


.slick-slide img {
    margin: auto;
    max-height: 100%;
    max-width: 100%;
    object-fit: cover;
    width: 100%;
    height: 100vh;
    vertical-align: bottom;
}
    
    
    @media (min-width: 1400px) {
        .slick-slide img {
            height: 80vh;
        }
    }
    
    
/* スライダー上のタイトル画像 */

.sl_title_img{
    width: 33%;
    display: block;
    position: absolute;
    top:50%;
    left:50%;
    transform: translate(-50%,-50%);
}
.sl_title_img img{
    width:100%;
}


/* 768px以上(PC)  **************/
    @media (min-width: 768px) {
        .sl_title_img{
            width: 14%;
        }
    }

/* 768px以下(SP)  **************/
.top_h2{
    font-size: 5rem;
    line-height: 4.5rem;
    color: rgb(134, 143, 152,0.4);
    margin: 12% 0 8%;
    font-family: 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.contents{
    width: 94%;
    margin: 0 auto;
}
ul.ct_Box li{
    display: block;
    margin: 0 auto 94px;
    list-style-type:none;
}
.ct_txt h3{
    margin-bottom: 10px;
    }

.ct_img{
    width:100%;
    margin-bottom: 22px;
}
.ct_img img{
    width:100%;
    vertical-align: middle;/*img直下の空白の削除*/
} 
.ct_txt{
    width: 98%;
    margin: 1%;
}


/* 768px以上(PC)  **************/
    @media (min-width: 768px) {
    .top_h2{
        line-height: 4rem;
        color: rgb(134, 143, 152,0.4);
        margin: 9% 0 5%;
        font-family: 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    }
        
    .contents{
        width: 94%;
        max-width:1210px;
        margin: 0 auto;
    }
    ul.ct_Box li{
        display: flex;
        max-width: 1200px;
        list-style-type:none;
    }
    .ct_list2{
        flex-flow: row-reverse;
    }
    .ct_img{
        width:50%;
    }
    .ct_txt{
        width: 38%;
        margin: 1% 6%;
    }

    .ct_txt h3{
        margin-bottom: 10px;
        }
    
    }

/* menuページ ******************************************/

/* 768px以下(SP)  **************/

.ptb_01{
    background-image:url(../img/apollo_midashi01.jpg);
}
.ptb_02{
    background-image:url(../img/apollo_midashi02.jpg);
}
.ptb_03{
    background-image:url(../img/apollo_midashi03.jpg);
}
.ptb_04{
    background-image:url(../img/apollo_midashi04.jpg);
    margin-bottom: 36px;
}

.menu-h2{
    width: 90%;
    margin: 30px 20px auto; 
    font-size: 5rem;
    line-height: 2.95rem;
    letter-spacing: 0.1rem;
    color: rgb(134, 143, 152,0.4);
    font-family: 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}



.ck-Li{
    display: block;
    width: 90%;
    margin: 0 auto;
    margin-top: 20px;
    margin-bottom: 65px;
}

.ck-Li > li{
    width: 100%;
    margin-bottom: 50px;
    min-width: 270px;
}

.ck-Li_Box h3{
    margin-bottom: 6px;
}

.ck-Li_Box p{
    margin-bottom: 10px;
    letter-spacing: 0.2em;
    font-size: 0.8rem;
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;

}

.ck-Li_Box ul {
    display: flex;
    color: brown;
}
.ck-Li_Box ul li{
    width:33%;
    margin: 0 2% 0 0;
    padding: 1%;
    border: dotted 1px brown;
}

.ck-Li_Box img{
    width: 100%;
}


/* 768px以上(PC)  **************/
@media (min-width: 768px) {

    
    .ptb_04{
        margin-bottom: 58px;
    }

    .menu-h2{
        margin: 65px auto 22px 0;
    }

    .menu-h2 span{
        display: none;
    }

    .ck-Li{
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        width: 100%;
        margin: 0 auto;
    }

    .ck-Li > li{
        width: 27%;
        margin-right:4%;
        min-width: 314px;
    }

    .ck-Li_Box h3{
        margin-bottom: 5px;
    }
    

    .ck-Li_Box ul li{
        margin: 0 2% 0 0;
    }
    

    .ck-Li_Box img{
        width: 100%;
    }
}

/* Newsページ ********************************************/
/* 768px以下(SP)  **************/

.kizi {
    width:90%;
    margin: 48px auto;
    padding-bottom: 30px;
    border-bottom: 1px dotted #000;
}

.kizi img{
    width:100%;
    max-width: 600px;
}
.kizi .day{
    display: flex;
    font-size: 0.8rem;
    margin-bottom: 24px;
}
.kizi div{
    margin-bottom: 22px;
    font-size: 1rem;
}
.kizi div p:first-child{
    margin-bottom: 14px;
}

.kizi .day span:first-child {
    font-size: 1.5em;
    letter-spacing: 0.2em;
 }
 
 .kizi .day span:last-child {
   display: block;
   border: 1px solid #000;
   font-size: 1.2em;
   width: 90px;
   padding: 2px;
   margin-left: 20px;
   text-align: center;
}



/* access ***********************************************/

/* 768px以下(SP)  **************/

.access_h2{
    width: 90%;
    margin: 0; 
    font-size: 42px;
    line-height: 1em;
    letter-spacing: 0.05em;
    color: rgba(39, 39, 39, 0.4);
    font-family: 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.ac-info{
   display: block;
   margin-bottom: 54px;
   max-width: 1400px;
}
.ac-info p{
    width: 100%;
    max-width:500px;
}
.ac-info p img{
    width: 100%;
}
.ac-info table{
    width: 98%;
    border-collapse: collapse;
    margin-top: 20px;
    }
.ac-info table th, td{
    border-bottom: 1px solid #999;
    border-top: 1px solid #999;
    padding: 2% !important;

}
.ac-info table th{
    text-align: center;
}

.ac-map{
    margin-bottom: 50px;
}

.map {
    width: 86%;
    margin: auto;
    max-width: 1400px;
    max-height: 500px;
    position: relative;
    padding-top: 36.25%;
    margin-bottom: 10px;
  }

  
  .map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

/* 768px以上(PC)  **************/
@media (min-width: 768px) {

    .access_h2{
        font-size: 65px;
    }

    .ac-info{
        display: flex;
        justify-content: space-between;
        flex-flow: row-reverse;
        margin-bottom: 84px;
    }

    .ac-info table th, td{
        border-bottom: 1px solid #999;
        /* padding: 5px 10px !important; */
        
    }
    
       .ac-info p{
        width: 50%;
    }
    .ac-info p img{
        width: 100%;
    }

    .ac-info table{
        width: 45%;
        height:258px;
        margin-top: 20px;
    }
    .ac-info table th{
        width: 30%;
        height: 10px;
    }
    
    .ac-map{
        margin-bottom: 120px;
    }

    .map {
        width: 98%;
      }
}



/* about ***********************************************/

.ab-contents{
    width: 100%;
    font-size: 0.9rem;
    letter-spacing: 1px;

}
.ab-contents h2{
    font-size: 1rem; 
    margin:0;
}
  
  /* 背景画像 */
 .parallax::before {
    width: 100%;
    height: 100vh;
    content: "";
    background-image: url(../img/lineup_wh.jpg); 
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    position: fixed;
    left: 0;
    top: 0;
    z-index: -2;
  }

  /*お店コンテンツ */
  .cntn00 {
      width: 100%;
      margin:50px auto 17vw auto;
  }

.cntn00 > p{
    width: 87%;
}
.cntn00 > p img{
    width: 100%;
    vertical-align: middle;/*img直下の空白の削除*/
}
.cntn00txt{
    position: relative;
    margin-left: auto;
    bottom: 20px;
    background-color: rgb(254, 255, 245, 0.7);
    width: 73%;
    padding: 36px 34px;
    word-break: break-all;
    z-index:-1;
}


/* 768px以上(PC)  **************/
@media (min-width: 768px) {
    .cntn00 {
        position: relative;
          display: flex;
          justify-content: flex-end;
          width: 93%;
          max-width:1388px;
          margin:50px auto 22vw auto;
      }

      .cntn00 > p{
        position: absolute;
        left: 0;
        bottom: -7vw;
        width: 48%;
        max-width: 632px;
      }
      .cntn00 > p img{
        box-shadow: 30px 30px 30px 0 rgba(0, 0, 0, 0.15);
      }
      .cntn00txt{
        display: block;
        width: 37%;
        padding: 90px 9vw;
        margin-right:20px ;
      }
}

   /* 伝統の味コンテンツ*/
.cntn01{
    display: block;
    width: 72%;
    margin:50px auto 156px auto;
}

.cntn01IMG {
    width: 78%;
    margin: 0 auto 20px auto;
}
.cntn01IMG img{
    width: 100%;
}

.cntn01TXT{
    width: 100%;
    letter-spacing: 1px;
}

.cntn01TXT h2{
    text-align: center;
}

   /* 768px以上(PC)  **************/
@media (min-width: 768px) {
    .cntn01{
        display: flex;
        flex-flow: row-reverse;
        width: 84%;
        max-width:1038px;
        margin:50px auto 230px auto;
    }

    .cntn01TXT{
        width: 56%;
        padding: 2% 17px 2% 0;
        letter-spacing: 1px;
    }
    .cntn01IMG {
        width: 33%;
        margin: 0;
    }
    .cntn01TXT h2{
        text-align: start;
    }
}

 /* イートインコンテンツ*/
 .pr00 {
    position: relative;
    display: block;
    width: 100%;
    margin: 0 auto 150px auto;
   }
   .pr00::before {
    content: "";
    width: 68%;
    height: 77%;
    background-color: rgb(254, 255, 245, 0.7);
    position: absolute;
    bottom: -4vw;
    left: 0;
    z-index: -1;
  }
   .pr00 p:first-child{
    position: relative;
    bottom: 40px;
    width: 86%;
    }
  .pr00 p img,.pr00in p img{
    width: 100%;
    vertical-align: middle;/*img直下の空白の削除*/
   }
   .pr00in{
    position: relative;
    width: 92%;
   }
   .pr00in p:first-of-type{
    margin-bottom: 27px;
    padding: 0 16px;
   }
   .pr00in p:last-child{
    position: relative;
    margin-left: auto;
    width: 77%;
   }


/* 768px以上(PC)  **************/
@media (min-width: 768px) {
   .pr00 {
    display: flex;
    justify-content: space-between;
    width: 91%;
    max-width:1388px;
    margin: 0 auto ;
    margin-bottom: 200px;
   }
   .pr00::before {
    width: 76.92%;
    height: 26vw;
    bottom: -4vw;
    z-index: -1;
  }
   .pr00 p:first-child{
    bottom: 40px;
    width: 47%;
    box-shadow: 30px 30px 30px 0 rgba(0, 0, 0, 0.15);
    }
   .pr00in{
    width: 42%;
    margin-right: 43px;
   }
   
   .pr00in p:first-of-type{
    margin-bottom: 47px;
    padding: 0;
   }
   .pr00in p:last-child{
    position: absolute;
    right: 0;
    bottom: -20px;
    width: 80%;
   }
}



  /* 食材コンテンツ */
  .cntn02{
    background-color: rgb(254, 255, 245, 0.7);
    padding: 20px 0;
    margin-bottom: 82px;
  }
  .cntn02 ul {
    display: flex;
  }

  .cntn02 li {
    width: 50%;
  }
  .cntn02 li img{
    width: 100%;
  }
 .cntn02 h2{
    text-align: center;
    margin: 8px 0;
 }

.cntn02 p{
    width: 90%;
    margin: 0 auto;
  }


/* 768px以上(PC)  **************/
@media (min-width: 768px) {

  .cntn02{
    padding: 7.5vw 10vw;
    margin-bottom: 180px;
  }
  .cntn02 ul {
    max-width: 1165px;
    margin: 0 auto;
    margin-bottom: 22px;
  }

.cntn02 p{
    width: 65%;
    max-width:722px;
    margin:22px auto 0 auto;
  }

}

  /* 店長コンテンツ */
.cntn03{
    position:relative;
    width: 98%;
    margin: 50px auto 17vw auto;
}
.cntn03 div{
    position: relative;
    bottom: 37px;
    width: 80%;
    margin-left: auto;
    padding: 50px 16px 27px 16px;
    background-color: rgb(254, 255, 245, 0.7);
    z-index: -1;
}
.cntn03 h2{
    margin: 10px auto 15px auto;
}
.cntn03 p:first-child{
    z-index: 1;
    width: 50%;
}
.cntn03 img{
    width: 100%;
}

  /* 768px以上(PC)  **************/
@media (min-width: 768px) {
    .cntn03{
        display: flex;
        align-items: flex-start;
        width: 90%;
        max-width: 1370px;
        margin: 50px auto 17vw auto;
    }
    .cntn03 div{
        bottom: 50px;
        width: 57%;
        padding: 6vw;
        background-color: rgb(254, 255, 245, 0.7);
    }
    .cntn03 p:first-child{
        position:relative;
        left: 32px;
        width: 32%;
    }
}


/* footer ***********************************************/

/* 768px以下(SP)  **************/
.footer{
    background-color: black;
    color: #fff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 15px;
    letter-spacing: 0.2em;
}
.f_content{
    width: 94%;
    margin: 0 auto;

}
.f_logo{
    width: 68%;
    margin: 0 auto;
    padding: 12px 0;
}
.f_logo img{
    width: 100%;
}
.f_box{
    width:100%;
    margin-bottom: 10%;
}
.f_ad{
    padding: 0 10px 25px ;
    border-bottom:double 4px #999;
}

.f_icon {
    display: flex;
    width:50%;

}

.f_icon li {
    margin:15px 15px 0px 0px;
}


/* 768px以上(PC)  **************/
@media (min-width: 768px) {
    
    .f_logo{
        width: 27%;
        margin: 0 auto 0 0 ;
        padding-top: 18px;
        padding-left:17px;
    }
    .f_box{
        display:flex;
        border-bottom:double 4px #999;
    }
    .f_ad{
        width:50%;
        border: none;
    }
    .f_icon {
        justify-content: flex-end;
    }
    .f_icon li {
        margin:0 15px ;
    }
    .f_icon li a {
        display: block;
    }

}

