@charset "UTF-8";

/* // 背景設定
// --------------------------------------------- */

body {
  background-color: #f4f1ed;
  color: #ddcaae;
  background-attachment: fixed;
  z-index: 1;
  /* font-family: "Lato", sans-serif; */
  font-family: "Noto Serif JP", serif;
  transition: .7s;
}

img {
  display: block;
}


header {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}

.h1 img {
  width: 145px;
}

header .sp_layout {
  width: 450px;
  margin: 0 auto;
  background-color: #251408;
  padding: 20px 25px;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}
/* // ナビ
// --------------------------------------------- */

.nav_wrapper {
  position: fixed;
  z-index: 5;
  width: 100%;
  top: 50%;
  transform: translateY(-50%);

  .nav_list {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: calc((100% - 995px) / 4);
    z-index: 5;

    li {
      margin-bottom: 10px;
      /* background-color: #fff; */
      /* border-radius: 10px; */
      /* border: solid 5px #fa8072; */
      list-style: none;

      a {
        display: inline-block;
        padding: 20px 40px;
        /* font-weight: ; */
        color: #333;
        text-decoration: none;
        transition: all .5s ease-in-out;
      }

      a:hover {
      
        color: #a7a6a6;
        
      }

      
      }
    }
  }

  @media screen and (max-width:959px) {
    .nav_list {
      display: none;
      
    }
  }

.current {
  background-color: #251210 !important;
  border-radius: 10px;
  transition: all .5s ease-in-out;

  a {
    color: #a7a6a6 !important;
  }
}



/* ハンバーガーメニュー */
@media screen and (min-width: 960px) {
  .hamburger-menu {
    display: none;
  }

  .header__nav-sp {
    display: none;
  }
}

@media screen and (max-width: 959px) {
  .header__nav-pc {
    display: none;
  }

  .hamburger-menu {
    width: 50px;
    height: 42px;
    position: relative;
    border: none;
    background: transparent;
    appearance: none;
    padding: 0;
    cursor: pointer;
    /* border: 1px solid #535252; */
    /* border-radius: 50%; */
    /* margin: 18px; */
  }

  .hamburger-menu span {
    display: inline-block;
    width: 50%;
    height: 2px;
    background: #ddcaae;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 10px;
    transition: .5s;
  }

  .hamburger-menu span:first-child {
    top: 14px;
  }

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

  .hamburger-menu span:last-child {
    top: 26px;
  }

  #js-hamburger-menu.open span {
    top: 20px;
    left: 8px;
    width: 25px;
    margin: 0;
  }

  #js-hamburger-menu.open span:first-child {
    transform: rotate(45deg);
  }

  #js-hamburger-menu.open span:nth-child(2) {
    display: none;
  }

  #js-hamburger-menu.open span:last-child {
    transform: rotate(-45deg);
  }

  .header__nav-sp {
    display: block;
    transition: right .5s;
  }

  .header__nav-sp .open {
    right: 0;
  }

  .header__nav-sp {
    display: none;
    background-image: linear-gradient(90deg, #ffd1ff, rgba(250,208,196,1));
    position: absolute;
    top: 80px;
    right: 0px;
    width: 100%;
    z-index: 9999;
  }

  .header__navItems {
    display: block;
    letter-spacing: .1rem;
    text-align: center;
    list-style: none;
    padding: 0;
    margin: 0;
  }

.navItem a {
    color: #333333;
    font-size: 14px;
    font-weight: normal;
    text-decoration: none;
    display: block;
    padding: 40px 0;
    margin: 0 auto;
    transition: .5s;
  }

  @media (hover: hover) and (pointer: fine) {
    .navigation__link:hover {
      background: #333;
    }
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ハンバーガーメニューここまで＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */




/* // コンテンツ
// --------------------------------------------- */

.article {
  max-width: 450px;
  margin: 0 auto;
  position: relative;

  @media screen and (max-width:500px) {
    max-width: none;
    width: 100%;
  }

  .fv,
  #sec00, 
  #sec01, 
  #sec02, 
  #sec03, 
  #sec04, 
  #sec05, 
  #sec06 {
    padding: 45px 20px;
    /* height: 1000px; */
  }
}


#fv {
  background-color: #251408;
}


.mv {
  background-image: url(../images/mv.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  height: 335px;
  border-radius: 20px;
}


/* 駅すぐ */
.fv .btn-top {
  position: absolute;
  top: 407px;
  right: 149px;
  width: 150px;
  z-index: 1;
  animation: fuwafuwa 2s infinite;


  @media screen and (max-width:500px) {
    right: 138px;
  }

}



@keyframes fuwafuwa {
 0% {
   transform: translateY(0px);
 }
 50% {
   transform: translateY(-15px);
 }
 100% {
   transform: translateY(0px);
 }
}

/* ＝＝＝＝＝＝＝＝ボタン＝＝＝＝＝＝＝＝ */
.button {
  margin-top: 75px;
  /* 要素をフレックス */
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-evenly;

  /* きらんの指定 */
  position: relative;

  /* ボタン大きさ */
  width: 100%;
  height: 70px;

  /* 色、影、角 */

  background-image: linear-gradient(90deg, #ffd1ff, rgba(250,208,196,1));
  border-radius: 50px;
  border: none;

  /* ボタンきらん */
  overflow: hidden;

  &::after {
    animation: anime_cvbtn02 6s infinite;
    content: '';
    position: absolute;
    top: -10%;
    left: -20%;
    width: 40px;
    height: 100%;
    transform: scale(2) rotate(20deg);
    background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, .5) 100%, rgba(255, 255, 255, 0) 0%);
  }
}

/* //ボタン　きらん　アニメーション */
@keyframes anime_cvbtn02 {
  0% {
    left: -20%;
  }

  10% {
    left: 120%;
  }

  100% {
    left: 120%;
  }
}


.btn {
  position: relative;
  color: #333;
  transform-origin: center;
  text-decoration: none;
  font-size: 19px;
  font-family: "Lato", sans-serif;
}

/* ピン */
.btn::before {
  position: absolute;
  content: "";
  background-image: url(../images/pin.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  width: 15px;
    height: 23px;
    top: 0px;
    left: -42px;
}

/* ＝＝＝＝＝＝＝＝ボタンここまで＝＝＝＝＝＝＝＝ */


/* 電話番号など */
.fv .wrap {
  text-align: center;
  margin-top: 40px;
}

.fv .contact {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  font-family: "Lato", sans-serif;
}

.fv .contact p {
  font-size: 20px;
  margin-right: 10px;
}
.fv .contact a {
  font-size: 40px;
  text-decoration: none;
  color: #f4f1ed;
}
.phone-number {
  font-size: 36px;
  font-weight: bold;
}
.close-day {
  margin: 10px 0;
  font-size: 18px;
}
.separator {
  border-top: 1px solid #d8c6a3;
  margin: 20px auto;
  width: 80%;
}
.business-hours {
  font-size: 28px;
  margin: 20px 0;
  font-family: "Lato", sans-serif;
}
.last-order {
  font-size: 18px;
  font-family: "Lato", sans-serif;
}


/* fv区切りキラキラ */
#fv .star-line {
  background-image: url(../images/fv-line.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  width: 100%;
  height: 197px;
}


/* コンセプト */
.concept {
  background-color: #251408;
}

.concept p {
  line-height: 1.8;
  padding-top: 15px;
  text-align: center;
}

.concept .drinks {
  background-image: url(../images/concept-drinks.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  height: 50px;
  width: 100px;
  margin: 50px auto 0;
}


/* 各タイトル共通 */
.article h2 {
  position: relative;
  font-family: "Lato", sans-serif;
  font-size: 40px;
  font-weight: 300;
  text-align: center;
  /* padding-top: 60px; */
}
.article .star {
display: block;
margin: 0 auto;
    width: 100px;
    /* height: 80px; */
/*  */

}


.article .subtitle {
  padding: 16px 0 30px;
  text-align: center;
}


/* システム */

.menu {
  background-color: #74502d;
}

.menu .english {
  font-family: "Lato", sans-serif;
}
.menu .box {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.menu .order,
.menu .free,
.menu .extension {
  border: 1px solid;
  width: 90%;
  height: 215px;
  margin-top: 20px;
}

.menu h3 {
  /* font-size: 18px; */
  padding: 30px 0 0 30px;
  font-weight: 300;
}

.menu .price {
  font-size: 30px;
  padding: 45px 0 0 30px;
}

.menu .time {
  padding: 30px 0 0 30px;
}


/* メニューボタン */
 .menu a img {
  display: block;
  width: 70%;
  margin: 30px auto;
 }



/* アクセス */
.access {
  background-color: #251408;
}
.access h2 img {
  width: 410px;
  margin: 0px auto;
}

.access .wrap {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.access .wrap img {
  /* width: 360px; */
  /* height: 300px; */
  border-radius: 20px;
}

.access .wrap .text {
  /* color: #f4f1ed; */
}
.access .wrap p {
  padding: 10px 0;
  line-height: 1.8;
}

.access .wrap a {
  font-size: 40px;
  text-decoration: none;
  color: #f4f1ed;
  font-family: "Lato", sans-serif;
}


/* キャスト */

.cast {
  background-color: #74502d;
  /* color: #fff; */
}

.cast img {
  display: block;
  width: 100%;
  margin: 0px auto;
}


/* ご利用のお客様へ */
.customer {
  background-color: #251408;
}

.customer h2 img {
  width: 440px;
  margin: 0px auto;
}

.customer .wrap {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.customer .area img {
  width: 100%;
  /* height: 263px; */
  border-radius: 10px;
}

.customer .area .box {
  margin-top: 10px;
  width: 100%;
  height: 215px;
}

.customer .area .box h3 {
  padding: 30px 0 0 15px;
  font-size: 18px;
  line-height: 1.5;
}

.customer .area .box .text01,
.customer .area .box .text02 {
  padding: 57px 15px 15px 15px;
}

.customer .area .box .text03 {
  padding: 30px 15px 15px 15px;
}



/* クロージング */
.closing {
  background-image: url(../images/closing-pic.png);
  background-repeat: no-repeat;
  /* background-position: 91% 242%; */
  background-size: cover;
  height: 500px;

}

.closing p {
  text-align: center;
  padding-top: 40px;
  /* color: #f4f1ed; */
  line-height: 1.6;
}



/* フッター */
footer .article {
  background-color: #251408;
  padding-top: 70px;
}

/* 仕切り線 */
footer .line {
  border: .5px solid #ca9665;
  width: 90%;
  margin: 0 auto;
}

/* ロゴ */
footer .logo {
  width: 140px;
  margin-left: 40px;
}

footer .wrap {
  display: flex;
  flex-direction: column;
}

footer .box {

  /* background-color: #ddcaae; */
  width: 85%;
  height: 215px;
  margin: 30px auto;
  line-height: 1.8;
}

footer .title {
  font-size: 18px;
  font-weight: normal;
  margin: 40px 0;
}

footer .text {
  padding-left: 40px;
}


/* 住所アイコン */
footer .postal_code {
  position: relative;
}

footer .postal_code::before {
  position: absolute;
  content: "";
  background-image: url(../images/map-icon.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  width: 13px;
  height: 17px;
  top: 7px;
    left: 1px;
  
}

/* 電話番号アイコン */
footer .phone_number {
  position: relative;
}

footer .phone_number::before {
  position: absolute;
  content: "";
  background-image: url(../images/phone-icon.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  width: 11px;
  height: 18px;
  top: 6px;
  left: 1px;

}
/* 営業時間アイコン */
footer .hour {
  position: relative;
}

footer .hour::before {
  position: absolute;
  content: "";
  background-image: url(../images/watch-icon.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  width: 18px;
  height: 18px;
  top: 6px;
  left: 1px;
}

footer .sns_icon img {
  display: block;
  width: 40px;
  height: 40px;
  margin-right: 15px;
}

footer .sns_icon {
  /* width: 200px; */
  display: flex;
  flex-direction: row;

}

footer .copyright {
  text-align: center;
  padding: 50px 0;
}

