@charset "UTF-8";
/* A Modern CSS Reset */

*{
  margin: 0;
  padding: 0;
  font-family: 'Shippori Mincho', serif;
  font-weight:normal;
  font-style: normal;
  list-style: none;
  font-size: 14px;
  line-height: 28px;
  color: #CECECE;
}

h1 ,h2 , h3 , h4{
  font-family: 'Shippori Mincho', serif;
}

html, body {
    height: 100%;
    /* overflow: hidden; */
}

.main {
    position: relative; /*必ず必要*/
 z-index: 2;

}

.video {
  position: fixed;
 right: 0;
 bottom: 0;
 min-width: 100%;
 min-height: 100%;
 width: auto;
 height: auto;
 z-index: -100;
 background: url(img/poster.jpg) no-repeat;
 background-size: cover;
}


.en{
  font-family: 'Cinzel', serif;
}

a{
  text-decoration: none;
}

img{
  width: 100%;
  max-width: 100%;
  vertical-align: bottom;
}

.wrapper {
  margin: 0 auto;
  height: 100%;
}

.contents{
  margin: 0 auto;
  text-align: center;
  padding-top: 70px;
}

section{
  padding:80px 0px;
  box-sizing: border-box;
  width: 100%;
  margin:0px auto;
  text-align: center;
}

h2{
  font-family: 'Cinzel';
  font-style: normal;
  font-weight: 400;
  font-size: 40px;
  line-height: 67px;
  letter-spacing: 4px;
  color: #CECECE;
  font-family: 'Cinzel', serif;
}

h3{
  font-family: 'Cinzel';
  font-style: normal;
  font-weight: 400;
  font-size: 28px;
  line-height: 32px;
  letter-spacing: 2px;
  color: #574833;
}

.border_bottom{
  border-bottom: solid 1px #CECECE;
}

section h2{
  margin-bottom: 32px;
}

.head-border {
    position: relative;
    display: inline-block;
    padding: 0 180px;
}
 
.head-border:before,
.head-border:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 100px;
    height: 1px;
    background-color: #CECECE;
}
 
.head-border:before {
    left: 0;
}
 
.head-border:after {
    right: 0;
}

/*header*/
/*ナビのスタイル*/
header {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 1000;
    width: 100%;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0) 100%);
}

header img {
    width: auto;
    height: 64px;
    margin: 0 auto;
}

header .logo{
  text-align: center;
    display: block;
}



nav.NavMenu{
position: fixed;
z-index: 12;
top: 0;
left: 0;
background: rgba(255, 255, 255, 0.8);
text-align: center;
width: 400px;
max-width: 100%;
height: 100%;
display: none;
}

.NavInner{
width: 100%;
margin: 0 auto;
padding-top: 60px;
}

nav.NavMenu ul li{
font-size: 24px;
list-style-type: none;
width: 100%;
padding-bottom: 0px;
}

nav.NavMenu ul li:last-child{
padding-bottom: 0;
}

nav.NavMenu ul li a {
    display: block;
    margin: 0 auto;
    text-decoration: none;
    color: #333333;
    text-align: left;
    padding: 12px 40px;
    font-size: 16px;
    font-weight: 400;
}

.header_right{
  display: flex;
  width: 50%;
  justify-content: center;
  margin: 0 auto;
}

.header_right a{
  display: inline-block;
}

.menu__sublink-item a{
  width: 90%;
  margin: 0 auto 16px;
}

.menu__sublink-item{
  margin-bottom: 16px;
}


.header_pc {
    position: absolute;
    right: 0;
    width: 400px;
    top: 18px;
}

/*ボタンのスタイル*/
.Toggle {
position: fixed;
left:18px;
top: 7px;
width: 45px;
height: 45px;
cursor: pointer;
z-index: 13;
display: block;
}

.Toggle span {
display: block;
position: absolute;
width: 35px;
border-bottom: solid 4px #CECECE;
-webkit-transition: .35s ease-in-out;
-moz-transition: .35s ease-in-out;
transition: .35s ease-in-out;
left: 6px;
}

.Toggle span:nth-child(1) {
top: 9px;
}

.Toggle span:nth-child(2) {
top: 20px;
}

.Toggle span:nth-child(3) {
top: 31px;
}

.Toggle.active span:nth-child(1) {
top: 18px;
left: 6px;
-webkit-transform: rotate(-45deg);
-moz-transform: rotate(-45deg);
transform: rotate(-45deg);
border-bottom: solid 3px #000;
}
.Toggle.active span:nth-child(2),
.Toggle.active span:nth-child(3) {
top: 18px;
-webkit-transform: rotate(45deg);
-moz-transform: rotate(45deg);
transform: rotate(45deg);
border-bottom: solid 3px #000;
}

.bg1{
  background: rgba(170, 140, 100, 0.5);
  padding: 40px;
  box-sizing: border-box;
}
/*top*/
.mv img{
  width: 90%;
  max-width:1000px;
  margin: 0 auto;
}

.news .bg2{
  background: rgba(255, 255, 255, 0.7);
  align-items: center;
}

.news .bg2{
  align-items: center;
  padding: 40px;
  box-sizing: border-box;
}

.news h2{
  width: 30%;
  font-size: 32px;
  line-height: 64px;
  margin-bottom: 0;
  color: #333333;
}

.news_item{
  width: 70%;
  padding-left: 40px;
  border-left: solid 1px #333333;
}

.news_item a{
  justify-content: left;
}

.news_item a p{
  color: #333333;
  text-decoration: underline;
}


/*.news_item a p:hover{
  text-decoration: underline;
}*/

.news_item{
  text-decoration: underline;
}

.news_item .day{
  margin-right: 20px;
}

/*menu*/
.banner {
    border: none!important;
    display: block;
    width: 800px;
max-width:100%;
    margin: 0 auto 40px!important;
}

.banner:hover{
  opacity: 0.8;
}
.menu h3{
  background: #CECECE;
  padding: 4px 8px;
  display: inline-block;
  text-align: left;
  margin-bottom: 24px;
}

.menu .bg1{
  text-align: left
}

.h3_border{
  position: relative;
}

.h3_border:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 100%;
    height: 1px;
    left: 0;
    z-index: -1;
    background-color: #CECECE;
}

.menu .flexbox{
  justify-content: space-between;
}
.menu .box{
  width: 46%;
}

.menu .mg{
  margin-bottom: 40px;
}

.menu .jp{
  font-size: 24px;
}

.menu .jp span{
  font-size: 24px;
  font-family: 'Shippori Mincho', serif;
  border-bottom: solid 1px #CECECE; 
}

.between{
  display: flex;
  justify-content: space-between;
  margin: 4px 0;
}

.between span{
  margin-right: 20px;
}

.small{
  font-size: 12px;
}

.price_outer{
  margin-bottom: 20px;
  width: 90%;
}

.price{
  font-size: 18px;
  font-family: 'Shippori Mincho', serif;
}

.menu a{
  border: solid 1px #CECECE;
  padding: 8px;
  box-sizing: border-box;
  margin: 16px 0 8px 0;
  letter-spacing: 1px;
}

.menu a span{
  background: #CECECE;
  color: rgba(0, 0, 0, 0.8);
  font-size: 12px;
  line-height: 24px;
  letter-spacing: 1px;
  padding: 4px 8px
}

h4{
  font-weight: 400;
  font-size: 28px;
  line-height: 48px;
  margin-bottom: 32px;
}

h5{
  font-size: 20px;
  line-height: 32px;
  letter-spacing: 2px;
}

p{
  line-height: 28px;
}


.s_jp{
  font-family: 'Shippori Mincho', serif;
  width: 140px;
  text-align: left;
}

.map iframe{
  width: 66%;
  filter:grayscale(100%);
  -webkit-filter:grayscale(100%)
}

.map h4{
  margin-bottom: 24px;
}

.map .textbox{
  width: 34%;
  text-align: left;
}

.border_box{
  display: flex;
  align-items: center;
}

.border{
  width: 100%;
  height: 1px;
  background: #CECECE;
  margin-left: 1em;
}

.address {
  margin-bottom: 12px;
}

.station{
  margin-bottom: 24px;
}


/*chef*/
.chef .textbox{
  background: rgba(255, 255, 255, 0.8); 
  padding: 40px 60px;

}

.chef .flexbox{
  align-items: flex-start;
  justify-content: center;
}


.chef .border{
  background: rgba(0, 0, 0, 0.8);
}

.name{
  font-family: 'Shippori Mincho', serif;
  font-size: 35px;
  line-height: 30px;
  margin: 24px 0;
}

.chef .s_jp {
    width: 44px;
}

.sommelier .s_jp {
    width: 80px!important;
}

.chef .text{
  font-family: 'Shippori Mincho', serif!important;
font-size: 14px;
font-weight: 400;
line-height: 39px;
letter-spacing: 0em;
text-align: left;

}

.sommelier .head-border:before, .head-border:after {
  width: 60px;
}

.sommelier .head-border {
    padding: 0 80px;
}

.chef p{
  color: #333333;
  text-align: left;
}

.chef span{
  font-family: Cinzel;
  font-size: 16px;
  line-height: 32px;
  color: rgba(0, 0, 0, 0.4);
}

.name
.chef .textbox{
  width: 64%;
}

/*footer*/
.reservation{
  position: relative;
    overflow: hidden;
  padding: 80px;
}

.reservation::before{
  background: rgba(255, 255, 255, 0.8);
  position: absolute;
    z-index: -5000;
    content: '';
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: block;
}

.reservation h2{
  color: #333333;
  text-align: center;
}

.textflex{
  display: flex;
  color: #333333;
  justify-content: center;
  align-items: center;
}

.reservation p{
  color: #333333;
  text-align: center;
}

.reservation .button{
  margin: 20px auto;
}

.textflex p:first-child{
  margin-right: 4px;
}

.tel{
  color: #333333;
  font-size: 20px;
  line-height: 36px;
  letter-spacing: 0em;
  text-align: center;
}

.footer_navi.flexbox {
    padding: 80px 0;
}

.footer_logo{
  width: 80%;
}

.insta a{
  display: flex;
  font-family: Cinzel;
  font-size: 11px;
  font-weight: 400;
  line-height: 19px;
  letter-spacing: 1px;
  text-align: left;
  margin-bottom: 12px;
}

.insta img{
  width: 27px;
  margin-left: 12px; 
}

.bg2{
  position: relative;
    overflow: hidden;
}

.bg2::before {
    position: absolute;
    background-color: #000;
    z-index: -5000;
    content: '';
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: block;
}

.footer_navi .box1 .textbox{
  margin-bottom: 12px;
}

.footer_navi .box2 h3{
  color: white;
  font-size: 17px;
  margin-bottom: 16px;
}

.footer_navi .box2 .button{
  margin-bottom: 16px;
}

.box_s{
  width: 42%;
}

.box_s a{
  display: block;
}



footer .navi{
  border-top: solid 1px #CECECE;
  padding-top: 24px;
}

footer .navi li{
  font-family: Cinzel;
  font-size: 14px;
  font-weight: 400;
  line-height: 22px;
  letter-spacing: 1px;
}


.contact_footer{
  background: black;
}

@media screen and (max-width: 1199px) {
   /*480px以下に適用されるCSS（スマホ用）*/ 
  .pc_only{
    display: none!important;
  }
  .wrapper{
   
  }

  *{
    font-size: 14px;
    font-weight: 400;
    line-height: 39px;
    letter-spacing: 0em;
  }

  h2{
    font-size: 24px;
    line-height: 30px;
    margin-bottom:8px;
  }

  section h2 {
    margin-bottom: 24px;
  }

  .name{
    font-size: 20px;
  }

header img {
    width: auto;
    height: 48px;
    margin: 0 auto;
}

header .logo {
    text-align: center;
    display: flex;
    height: 60px;
    align-items: center;
}

.main{
  overflow: hidden;
}


.header_pc {
    position: absolute;
    right: 7px;
    width: auto;
    top: 6px;
}

.header_pc .flexbox{
  display: flex;
}

  body{
    font-size: 16px;
  }

  .top_logo h1 {
    font-size: 18px;
    line-height:27px;
    text-align: center;
  }

section {
    padding:30px 20px 40px;
    box-sizing: border-box;
    margin-bottom: -40px;
  }

  a.btn.border {
    max-width: 100%;
    box-sizing: border-box;
    margin:0 0 20px 0;
  }

  .insta img {
    width: 40px;
  }

  footer p{
    font-size: 12px;
  }


  .modaal-content-container{
    padding: 0!important;
  }

  .small{
  font-size: 12px;
}

.bg1{
  padding: 20px;
}

.news .bg2{
  padding: 20px;
}
.news_item{
  border: none;
  padding: 0;
  width: 100%;
  text-align: left;
}

.news_item a {
   margin-bottom: 12px;
    padding-bottom: 8px;
    display: block;
    border-bottom: solid 1px #CECECE;
}

.menu .box {
    width: 100%;
    padding: 16px 0;
}

.menu h3 {
    padding: 2px 4px;
    font-size: 14px;
    margin-bottom: 16px;
}

.h3_border:after{
  top: 36%;
}

h4{
  margin-bottom: 16px;
}

.head-border {
    padding: 0 120px;
}

.menu .jp {
    font-size: 19px;
}

.menu .jp span {
    font-size: 22px;
  }


.chef img{
  width: 100%;
}

.chef .textbox{
  padding: 20px;
}

.map.flexbox {
    padding: 20px;
    display: flex;
    flex-flow: column-reverse;
}

.map iframe{
  width: 100%;
}

.map .textbox{
  width: 100%;
}

.footer_navi .box {
    text-align: center;
}

.s_jp {
    font-size: 12px;
    margin: 16px 0;
}

.insta a{
  justify-content: center;
}

.box_s {
    width: 90%;
    margin: 0 auto;
}

.news h2{
  font-size: 28px;
}

footer .navi {
  margin-top: 40px;
}

.footer_navi.flexbox {
    padding: 40px 0;
    display: flex;
    flex-flow: column-reverse;
}

.contact-head:before, .contact-head:after{
  width: 70px;
}

.contact-head {
    padding: 0 90px;
}

.footer_logo {
    width: 40%;
    margin: 20px auto;
}

}

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

  }
  .sp_only{
    display: none!important;
  }

  section{
    max-width: 1200px;
  }

  header{
    height: 100px;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;

  }

  .flexbox{
    display: flex;
    justify-content: space-around;
  }

  .footer_navi.flexbox {
    max-width: 1200px;
    margin: 0 auto;
}

  .footer_navi .box1{
    width: 33%
  }

  .footer_navi .box2 {
    width: 64%;
    display: flex;
    flex-flow: column;
    justify-content: space-between;
}

.chef img{
  width: 33%;
}

.chef .textbox{
  width: 64%;
}

}

/*========= モーダル表示のためのCSS ===============*/

/*全て共通：hideエリアをはじめは非表示*/
.hide-area{
  display: none;
}

/*全て共通：モーダルのボタンの色を変更したい場合*/
.modaal-close:after, 
.modaal-close:before{
  background:#ccc;  
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before{
  background:#666;
}

/*確認を促すモーダル：タイトルの色を変更したい場合*/
#modaal-title{
  font-size:1.2rem;
  text-align: center;
  margin: 0 0 20px 0;
}

/*動画表示のモーダル：余白を変更したい場合*/
.modaal-video .modaal-inner-wrapper{
  padding:0;
}

.modaal-container{
  height: 100%;
  padding-top: 40px;
}

.modaal-content-container{
  text-align: left;
}

.info_container{
  padding-top: 40px;
  color: white;
}

.info_container h3{
  color: white;
  font-family: 'Shippori Mincho', serif;
  margin-bottom: 20px;
}

.modaal-close:focus:after, .modaal-close:focus:before, .modaal-close:hover:after, .modaal-close:hover:before {
    background: #666!important;
}
/*以下はコンテンツ内のレイアウト*/
.info-list dl,
.gallery-list{
  display: flex;
}

.info-list dt{
  margin:0 10px 0 0;
}

.gallery-list li{
  margin:0 10px 0 0;
}

.modaal-container{
  text-align: center!important;
  background: none!important;
}

.button {
  position: relative;
  display: block;
  overflow: hidden;
  display: block;
  background: transparent;
  transition: 0.3s ease-in-out;
  letter-spacing: 1px;
  line-height: 1.2;
}

.button::before {
  transition: 0.3s ease-in-out;
}
.button * {
  transition: 0.3s ease-in-out;
}
/* サイズ */
.button--xl {
  font-size: 32px;
  padding: 16px;
  width: 720px;
  text-align: center;
  box-sizing: border-box;
  font-weight: 200;
}
.button--l {
  font-size: 18px;
  padding: 18px 64px 18px 18px;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
}
.button--m {
  font-size: 15px;
  padding: 12px 64px 12px 12px;
  width: 240px;
  box-sizing: border-box;
  text-align: left;
}
.button--s {
  font-size: 13px;
  padding: 9px 48px 9px 9px;
  width: 100%;
  box-sizing: border-box;
  text-align: left;
}

@media screen and (max-width: 768px) {
  .button--xl,
  .button--l {
    font-size: 15px;
    padding: 12px 64px 12px 12px;
    width: 100%;
    text-align: left;
    font-weight: 400;
  }
}

/* 塗りつぶしボタン */
.button--fill.button--dark {
  color: #fff;
}
.button--fill.button--dark::after {
  content: '';
  display: block;
  height: 100%;
  width: 100%;
  background: #6d7275;
  z-index: -2;
  position: absolute;
  top: 0;
  left: 0;
}
/* アウトラインボタン */
.button--outline.button--dark {
  border: 1px solid rgba(0, 0, 0, 0.8);
  color: rgba(0, 0, 0, 0.8);
}
.button--outline.button--white {
  border: 1px solid #fff;
  color: #fff;
}
/* ホバー時のアニメーション */
.button::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  z-index: -1;
}
.button--outline::before.button--dark {
  background-color: rgba(0, 0, 0, 0.8);
}
.button--outline::before.button--white {
  background-color: #fff;
}
.button--fill::before.button--dark {
  background-color: rgba(0, 0, 0, 0.8);
}

.button--outline:hover {
  outline-width: 0;
}
.button--outline.button--dark:hover {
  color: #fff;
}
.button--outline.button--white:hover {
  color: rgba(0, 0, 0, 0.8);
}
.button--fill.button--white:hover {
  color: #fff;
}
.button:hover::before {
  -webkit-transform: translateX(0);
  transform: translateX(0);
}
.button--outline:hover.button--dark::before {
  background: rgba(0, 0, 0, 0.8);
}
.button--outline:hover.button--white::before {
  background: #fff;
}
.button--fill:hover.button--dark::before {
  background: rgba(0, 0, 0, 0.8);
}
/* アウトランボタンの線 */
.button__line {
  position: absolute;
  right: 0;
  top: 50%;
  overflow: hidden;
  height: 1px;
  color: white;
}
.button--xl .button__line {
  width: 64px;
}

.button--l .button__line {
  width: 48px;
}
.button--s .button__line {
  width: 32px;
}

.button--m .button__line {
  width: 32px;
}
@media screen and (max-width: 768px) {
  .button--xl .button__line,
  .button--l .button__line {
    width: 40px;
  }
}
.button--outline.button--dark .button__line {
  background: rgba(0, 0, 0, 0.8);
}
.button--outline.button--white .button__line,
.button--fill.button--dark .button__line {
  background: #fff;
}
.button--xl:hover .button__line {
  width: 80px;
}

.button--l:hover .button__line {
  width: 64px;
}

.button--s:hover .button__line {
  width: 48px;
}

.button--m:hover .button__line {
  width: 48px;
}
@media screen and (max-width: 768px) {
  .button--xl:hover .button__line,
  .button--l:hover .button__line {
    width: 56px;
  }
}
.button--outline:hover.button--dark .button__line {
  background: #fff;
}
.button--outline:hover.button--white .button__line {
  background: rgba(0, 0, 0, 0.8);
}
/* アウトラインボタン 下矢印アイコン */
.button__icon--arrowDown {
  width: 12px;
  height: 12px;
  border: 1px solid;
  border-color: transparent transparent #fff #fff;
  transform: rotate(-45deg);
  display: inline-block;
  margin-left: 16px;
  margin-bottom: 2px;
}

.button--outline:hover .button__icon--arrowDown {
  border-color: transparent transparent rgba(0, 0, 0, 0.8) rgba(0, 0, 0, 0.8);
}


.white{
  color: white;
}

/*フェード*/
/*==================================================
スタート時は要素自体を透過0にするためのopacity:0;を指定する
===================================*/

/*==================================================
ふわっ
===================================*/

.fadeUp {
animation-name:fadeUpAnime;
animation-duration:2s;
animation-fill-mode:forwards;
opacity: 0;
}

@keyframes fadeUpAnime{
  0% {
    opacity: 0;
  transform: translateY(20px);
  }

  100% {
    opacity: 1;
  transform: translateY(0);
  }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
 
.fadeUpTrigger{
    opacity: 0;
}

/* アニメーションスタートの遅延時間を決めるCSS*/

.delay-time02{
animation-delay: 0.2s;
}

.delay-time04{
animation-delay: 0.6s;
}

.delay-time06{
animation-delay: 1.0s;
}

.delay-time08{
animation-delay: 1.4s;
}

.delay-time10{
animation-delay: 1.8s;
}

.delay-time28{
animation-delay: 2.8s;
}


.start2 {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 9000;
}
.start2 p {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  display: none;
  z-index:9999;
  width: 280px;
}

